]> mj.ucw.cz Git - pciutils.git/blobdiff - lib/configure
Merge with git+ssh://git.ucw.cz/home/mj/GIT/pciutils.git
[pciutils.git] / lib / configure
index 8521d202b3f0482b816c4f1bd878b227cf8d803a..468a29f5aa6c0ffdd6e4914e01b072107da8027b 100755 (executable)
@@ -10,7 +10,7 @@ echo_n() {
 }
 
 echo_n "Configuring libpci for your system..."
-sharedir=${1:-/usr/share}
+idsdir=${1:-/usr/share}
 version=${2:-0.0}
 sys=`uname -s`
 rel=`uname -r`
@@ -22,75 +22,81 @@ then
 else
        cpu=`uname -m | sed 's/^i.86$/i386/;s/^sun4u$/sparc64/;s/^i86pc$/i386/'`
 fi
+if [ "$sys" = "GNU/kFreeBSD" -o "$sys" = "DragonFly" ]
+then
+       sys=freebsd
+fi
 host=${3:-$cpu-$sys}
-host=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)$/\1--\2/' | tr 'A-Z' 'a-z'`
+# CAVEAT: tr on Solaris is a bit weird and the extra [] is otherwise harmless.
+host=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)$/\1--\2/' | tr '[A-Z]' '[a-z]'`
 cpu=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'`
 sys=`echo $host | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'`
 rel=${4:-$rel}
 echo " $host $rel"
+zlib=$5
 
 c=config.h
-echo >$c "#define PCI_ARCH_`echo $cpu | tr 'a-z' 'A-Z'`"
-echo >>$c "#define PCI_OS_`echo $sys | tr 'a-z' 'A-Z'`"
+m=config.mk
+echo >$c "#define PCI_ARCH_`echo $cpu | tr '[a-z]' '[A-Z]'`"
+echo >>$c "#define PCI_OS_`echo $sys | tr '[a-z]' '[A-Z]'`"
+rm -f $m
 
 echo_n "Looking for access methods..."
 
 case $sys in
        linux*)
-               case $rel in
-                       2.[1-9]*|[3-9]*)        echo_n " sysfs proc"
-                                               echo >>$c '#define PCI_HAVE_PM_LINUX_SYSFS'
-                                               echo >>$c '#define PCI_HAVE_PM_LINUX_PROC'
-                                               echo >>$c '#define PCI_HAVE_LINUX_BYTEORDER_H'
-                                               echo >>$c '#define PCI_PATH_PROC_BUS_PCI "/proc/bus/pci"'
-                                               echo >>$c '#define PCI_PATH_SYS_BUS_PCI "/sys/bus/pci"'
-                                               ok=1
-                                               ;;
-               esac
+               echo_n " sysfs proc"
+               echo >>$c '#define PCI_HAVE_PM_LINUX_SYSFS'
+               echo >>$c '#define PCI_HAVE_PM_LINUX_PROC'
+               echo >>$c '#define PCI_HAVE_LINUX_BYTEORDER_H'
+               echo >>$c '#define PCI_PATH_PROC_BUS_PCI "/proc/bus/pci"'
+               echo >>$c '#define PCI_PATH_SYS_BUS_PCI "/sys/bus/pci"'
                case $cpu in
                                i386)           echo_n " i386-ports"
                                                echo >>$c '#define PCI_HAVE_PM_INTEL_CONF'
-                                               ok=1
-                                               ;;
-                               alpha|ia64|sparc|sparc64|ppc|ppc64|x86_64)
-                                               echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
                                                ;;
                esac
+               echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
                ;;
        sunos)
                case $cpu in
                                i386)           echo_n " i386-ports"
                                                echo >>$c "#define PCI_HAVE_PM_INTEL_CONF"
-                                               ok=1
                                                ;;
                                *)
-                                               echo " The PCI library is does not support Solaris for this architecture: $cpu"
+                                               echo " The PCI library does not support Solaris for this architecture: $cpu"
                                                exit 1
                                                ;;
                esac
+               echo >>$c '#define PCI_HAVE_STDINT_H'
                ;;
-               
        freebsd)
                echo_n " fbsd-device"
                echo >>$c '#define PCI_HAVE_PM_FBSD_DEVICE'
                echo >>$c '#define PCI_PATH_FBSD_DEVICE "/dev/pci"'
-               ok=1
+               ;;
+        openbsd)
+               echo_n " obsd-device"
+               echo >>$c '#define PCI_HAVE_PM_OBSD_DEVICE'
+               echo >>$c '#define PCI_PATH_OBSD_DEVICE "/dev/pci"'
                ;;
        aix)
                echo_n " aix-device"
                echo >>$c '#define PCI_HAVE_PM_AIX_DEVICE'
-               ok=1
+               echo >>$m 'CFLAGS=-g'
+               echo >>$m 'INSTALL=installbsd'
+               echo >>$m 'DIRINSTALL=mkdir -p'
                ;;
        netbsd)
                echo_n " nbsd-libpci"
                echo >>$c '#define PCI_HAVE_PM_NBSD_LIBPCI'
                echo >>$c '#define PCI_PATH_NBSD_DEVICE "/dev/pci0"'
-               ok=1
+               echo >>$m 'PCILIB=lib/libpciutils.a'
+               echo >>$m 'LDLIBS+=-lpci'
                ;;
        gnu)
                echo_n " i386-ports"
                echo >>$c '#define PCI_HAVE_PM_INTEL_CONF'
-               ok=1
                ;;
         *)
                echo " Unfortunately, your OS is not supported by the PCI Library"
@@ -100,9 +106,27 @@ esac
 
 echo >>$c '#define PCI_HAVE_PM_DUMP'
 echo " dump"
-if [ -z "$ok" ] ; then
-       echo "WARNING: No real configuration access method is available."
+
+echo_n "Checking for zlib support... "
+if [ "$zlib" = yes -o "$zlib" = no ] ; then
+       echo "$zlib (set manually)"
+else
+       if [ -f /usr/include/zlib.h ] ; then
+               zlib=yes
+       else
+               zlib=no
+       fi
+       echo "$zlib (auto-detected)"
 fi
-echo >>$c "#define PCI_PATH_IDS \"$sharedir/pci.ids\""
+if [ "$zlib" = yes ] ; then
+       echo >>$c '#define PCI_COMPRESSED_IDS'
+       echo >>$c '#define PCI_IDS "pci.ids.gz"'
+       echo >>$m 'LIBZ=-lz'
+       echo >>$m 'LDLIBS+=$(LIBZ)'
+else
+       echo >>$c '#define PCI_IDS "pci.ids"'
+fi
+echo >>$c "#define PCI_PATH_IDS_DIR \"$idsdir\""
+
 echo >>$c "#define PCILIB_VERSION \"$version\""
-sed '/^#define [^ ]*$/!d;s/^#define \(.*\)/\1=1/' <$c >config.mk
+sed '/"/{s/^#define \([^ ]*\) "\(.*\)"$/\1=\2/;p;d;};s/^#define \(.*\)/\1=1/' <$c >>$m