]> mj.ucw.cz Git - pciutils.git/blobdiff - lib/configure
cxl: Rename caps to be device caps
[pciutils.git] / lib / configure
index 7890c4c71a6e5b2ec9a010acaf50aa8d9393dde2..45a416a7620e0763216d323ade801bdf90f6073e 100755 (executable)
@@ -6,15 +6,10 @@ LC_ALL=C
 export LC_ALL
 
 echo_n() {
 export LC_ALL
 
 echo_n() {
-       if [ -n "$BASH" ]
-       then
-               echo -n "$*"
-       else
-               echo "$*\c"
-       fi
+       printf '%s' "$*"
 }
 
 }
 
-if [ -z "$VERSION" -o -z "$IDSDIR" ] ; then
+if [ -z "$VERSION" ] ; then
        echo >&2 "Please run the configure script from the top-level Makefile"
        exit 1
 fi
        echo >&2 "Please run the configure script from the top-level Makefile"
        exit 1
 fi
@@ -30,12 +25,20 @@ if [ -z "$HOST" ] ; then
                proc=`/usr/sbin/lsdev -C -c processor -S available -F name | head -1`
                cpu=`/usr/sbin/lsattr -F value -l $proc -a type | sed 's/_.*//'`
        else
                proc=`/usr/sbin/lsdev -C -c processor -S available -F name | head -1`
                cpu=`/usr/sbin/lsattr -F value -l $proc -a type | sed 's/_.*//'`
        else
-               cpu=`uname -m | sed 's/^i.86$/i386/;s/^sun4u$/sparc64/;s/^i86pc$/i386/;s/^BePC$/i386/;s/^BeMac$/powerpc/;s/^BeBox$/powerpc/'`
+               cpu=`uname -m | sed 's/^i.86-AT386/i386/;s/^i.86$/i386/;s/^sun4u$/sparc64/;s/^i86pc$/i386/;s/^BePC$/i386/;s/^BeMac$/powerpc/;s/^BeBox$/powerpc/'`
        fi
        fi
-       if [ "$sys" = "GNU/kFreeBSD" -o "$sys" = "DragonFly" ]
+       if [ "$sys" = "DragonFly" ]
        then
                sys=freebsd
        fi
        then
                sys=freebsd
        fi
+       if [ "$sys" = "GNU/kFreeBSD" ]
+       then
+               sys=kfreebsd
+       fi
+       if [ "$sys" = "GNU" ]
+       then
+               sys=gnu
+       fi
        if [ "$sys" = "CYGWIN_NT-5.1" -o "$sys" = "CYGWIN_NT-6.0" ]
        then
                sys=cygwin
        if [ "$sys" = "CYGWIN_NT-5.1" -o "$sys" = "CYGWIN_NT-6.0" ]
        then
                sys=cygwin
@@ -44,7 +47,7 @@ if [ -z "$HOST" ] ; then
 fi
 [ -n "$RELEASE" ] && rel="${RELEASE}"
 # CAVEAT: tr on Solaris is a bit weird and the extra [] is otherwise harmless.
 fi
 [ -n "$RELEASE" ] && rel="${RELEASE}"
 # CAVEAT: tr on Solaris is a bit weird and the extra [] is otherwise harmless.
-host=`echo $HOST | sed -e 's/^\([^-]*\)-\([^-]*\)-\([^-]*\)-\([^-]*\)$/\1-\3/' -e 's/^\([^-]*\)-\([^-]*\)$/\1--\2/' | tr '[A-Z]' '[a-z]'`
+host=`echo $HOST | sed -e 's/^\([^-]*\)-\([^-]*\)-\([^-]*\)-\([^-]*\)$/\1-\3/' -e 's/^\([^-]*\)-\([^-]*\)-\([^-]*\)$/\1-\2/' -e 's/^\([^-]*\)-\([^-]*\)$/\1--\2/' | tr '[A-Z]' '[a-z]'`
 cpu=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'`
 sys=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'`
 echo " $host $rel $cpu $sys"
 cpu=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'`
 sys=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'`
 echo " $host $rel $cpu $sys"
@@ -59,6 +62,9 @@ echo >$m 'WITH_LIBS='
 echo_n "Looking for access methods..."
 LIBRESOLV=-lresolv
 LIBEXT=so
 echo_n "Looking for access methods..."
 LIBRESOLV=-lresolv
 LIBEXT=so
+EXEEXT=
+SYSINCLUDE=/usr/include
+LSPCIDIR=SBINDIR
 
 case $sys in
        linux*)
 
 case $sys in
        linux*)
@@ -74,6 +80,7 @@ case $sys in
                                                ;;
                esac
                echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
                                                ;;
                esac
                echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
+               LSPCIDIR=BINDIR
                ;;
        sunos)
                case $cpu in
                ;;
        sunos)
                case $cpu in
@@ -87,11 +94,11 @@ case $sys in
                esac
                echo >>$c '#define PCI_HAVE_STDINT_H'
                ;;
                esac
                echo >>$c '#define PCI_HAVE_STDINT_H'
                ;;
-       freebsd*)
+       freebsd*|kfreebsd*)
                echo_n " fbsd-device"
                echo >>$c '#define PCI_HAVE_PM_FBSD_DEVICE'
                echo >>$c '#define PCI_PATH_FBSD_DEVICE "/dev/pci"'
                echo_n " fbsd-device"
                echo >>$c '#define PCI_HAVE_PM_FBSD_DEVICE'
                echo >>$c '#define PCI_PATH_FBSD_DEVICE "/dev/pci"'
-               if [ "$realsys" != "GNU/kFreeBSD" ] ; then
+               if [ "$sys" != "kfreebsd" ] ; then
                        LIBRESOLV=
                fi
                ;;
                        LIBRESOLV=
                fi
                ;;
@@ -109,6 +116,7 @@ case $sys in
                echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
                LIBRESOLV=
                LIBEXT=dylib
                echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
                LIBRESOLV=
                LIBEXT=dylib
+               SYSINCLUDE=$(xcrun --sdk macosx --show-sdk-path)/usr/include
                ;;
        aix)
                echo_n " aix-device"
                ;;
        aix)
                echo_n " aix-device"
@@ -121,18 +129,42 @@ case $sys in
                echo_n " nbsd-libpci"
                echo >>$c '#define PCI_HAVE_PM_NBSD_LIBPCI'
                echo >>$c '#define PCI_PATH_NBSD_DEVICE "/dev/pci0"'
                echo_n " nbsd-libpci"
                echo >>$c '#define PCI_HAVE_PM_NBSD_LIBPCI'
                echo >>$c '#define PCI_PATH_NBSD_DEVICE "/dev/pci0"'
+               echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
                echo >>$m 'LIBNAME=libpciutils'
                echo >>$m 'WITH_LIBS+=-lpci'
                LIBRESOLV=
                ;;
                echo >>$m 'LIBNAME=libpciutils'
                echo >>$m 'WITH_LIBS+=-lpci'
                LIBRESOLV=
                ;;
-       gnu)
+       gnu)
+               echo_n " hurd i386-ports"
+               echo >>$c '#define PCI_HAVE_PM_HURD_CONF'
+               echo >>$c '#define PCI_HAVE_PM_INTEL_CONF'
+               ;;
+       djgpp)
                echo_n " i386-ports"
                echo >>$c '#define PCI_HAVE_PM_INTEL_CONF'
                echo_n " i386-ports"
                echo >>$c '#define PCI_HAVE_PM_INTEL_CONF'
+               EXEEXT=.exe
                ;;
                ;;
-       cygwin)
+       cygwin|windows)
+               echo_n " win32-cfgmgr32"
+               echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
+               echo >>$c '#define PCI_HAVE_PM_WIN32_CFGMGR32'
+               # Warning: MinGW-w64 (incorrectly) provides cfgmgr32 functions
+               # also in other import libraries, not only in libcfgmgr32.a.
+               # So always set -lcfgmgr32 as a first library parameter which
+               # instruct linker to prefer symbols from cfgmgr32.dll.
+               echo >>$m 'WITH_LIBS+=-lcfgmgr32'
+               case $cpu in i?86|x86_64)
                echo_n " i386-ports"
                echo >>$c '#define PCI_HAVE_PM_INTEL_CONF'
                echo_n " i386-ports"
                echo >>$c '#define PCI_HAVE_PM_INTEL_CONF'
-               echo >>$m 'WITH_LIBS+=-lioperm'
+               if [ "$sys" = "cygwin" ] ; then
+                       # ioperm is cygwin specific library and used only by lib/i386-io-cygwin.h
+                       echo >>$m 'WITH_LIBS+=-lioperm'
+               elif [ "$sys" = "windows" ] ; then
+                       # advapi32 is windows system library and used only by lib/i386-io-windows.h
+                       echo >>$m 'WITH_LIBS+=-ladvapi32'
+               fi
+               ;; esac
+               EXEEXT=.exe
                ;;
        beos|haiku)
                case $cpu in
                ;;
        beos|haiku)
                case $cpu in
@@ -142,6 +174,13 @@ case $sys in
                esac
                echo >>$c '#define PCI_HAVE_STDINT_H'
                ;;
                esac
                echo >>$c '#define PCI_HAVE_STDINT_H'
                ;;
+       sylixos)
+               echo >>$c '#define PCI_PATH_SYLIXOS_DEVICE "/proc/pci"'
+               echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
+               echo >>$c '#define PCI_HAVE_PM_SYLIXOS_DEVICE'
+               IDSDIR="/etc/pci"
+               LIBRESOLV=
+               ;;
        *)
                echo " Unfortunately, your OS is not supported by the PCI Library"
                exit 1
        *)
                echo " Unfortunately, your OS is not supported by the PCI Library"
                exit 1
@@ -149,6 +188,8 @@ case $sys in
 esac
 
 echo >>$m "LIBEXT="$LIBEXT
 esac
 
 echo >>$m "LIBEXT="$LIBEXT
+echo >>$m "EXEEXT="$EXEEXT
+echo >>$m "LSPCIDIR=\$($LSPCIDIR)"
 echo >>$c '#define PCI_HAVE_PM_DUMP'
 echo " dump"
 
 echo >>$c '#define PCI_HAVE_PM_DUMP'
 echo " dump"
 
@@ -156,7 +197,7 @@ echo_n "Checking for zlib support... "
 if [ "$ZLIB" = yes -o "$ZLIB" = no ] ; then
        echo "$ZLIB (set manually)"
 else
 if [ "$ZLIB" = yes -o "$ZLIB" = no ] ; then
        echo "$ZLIB (set manually)"
 else
-       if [ -f /usr/include/zlib.h -o -f /usr/local/include/zlib.h ] ; then
+       if [ -f "$SYSINCLUDE/zlib.h" -o -f /usr/local/include/zlib.h ] ; then
                ZLIB=yes
        else
                ZLIB=no
                ZLIB=yes
        else
                ZLIB=no
@@ -177,7 +218,7 @@ echo_n "Checking for DNS support... "
 if [ "$DNS" = yes -o "$DNS" = no ] ; then
        echo "$DNS (set manually)"
 else
 if [ "$DNS" = yes -o "$DNS" = no ] ; then
        echo "$DNS (set manually)"
 else
-       if [ -f /usr/include/resolv.h ] ; then
+       if [ "$sys" != "windows" -a -f "$SYSINCLUDE/resolv.h" ] ; then
                DNS=yes
        else
                DNS=no
                DNS=yes
        else
                DNS=no
@@ -222,6 +263,23 @@ if [ "$sys" = linux ] ; then
                echo >>$m "LIBKMOD_CFLAGS=$($PKG_CONFIG --cflags libkmod)"
                echo >>$m "LIBKMOD_LIBS=$($PKG_CONFIG --libs libkmod)"
        fi
                echo >>$m "LIBKMOD_CFLAGS=$($PKG_CONFIG --cflags libkmod)"
                echo >>$m "LIBKMOD_LIBS=$($PKG_CONFIG --libs libkmod)"
        fi
+
+       echo_n "Checking for udev hwdb support... "
+       if [ "$HWDB" = yes -o "$HWDB" = no ] ; then
+               echo "$HWDB (set manually)"
+       else
+               if `which pkg-config >/dev/null && pkg-config --atleast-version=196 libudev` ; then
+                       HWDB=yes
+               else
+                       HWDB=no
+               fi
+               echo "$HWDB (auto-detected)"
+       fi
+       if [ "$HWDB" = yes ] ; then
+               echo >>$c '#define PCI_HAVE_HWDB'
+               echo >>$m 'LIBUDEV=-ludev'
+               echo >>$m 'WITH_LIBS+=$(LIBUDEV)'
+       fi
 fi
 
 echo "Checking whether to build a shared library... $SHARED (set manually)"
 fi
 
 echo "Checking whether to build a shared library... $SHARED (set manually)"