]> mj.ucw.cz Git - pciutils.git/commitdiff
Cleanup of the Makefile system.
authorMartin Mares <mj@ucw.cz>
Sun, 17 Feb 2008 11:38:12 +0000 (12:38 +0100)
committerMartin Mares <mj@ucw.cz>
Sun, 17 Feb 2008 11:38:12 +0000 (12:38 +0100)
Parameters of the configure script are passed from the top-level Makefile
in environment variables. DNS support has been made a regular build option
with an attempt at its auto-detection.

Makefile
lib/configure

index 3f8d50c679763b7c3f9ebb83d462bba3104623ee..f755a522ed6378b5cb023d7657f82fa7e6898c8a 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -7,6 +7,17 @@ CFLAGS=$(OPT) -Wall -W -Wno-parentheses -Wstrict-prototypes -Wmissing-prototypes
 VERSION=2.2.10-net2
 DATE=2008-02-13
 
+# Host OS and release (override if you are cross-compiling)
+HOST=
+RELEASE=
+
+# Support for compressed pci.ids (yes/no, default: detect)
+ZLIB=
+
+# Support for resolving ID's by DNS (yes/no, default: detect)
+DNS=
+
+# Installation directories
 PREFIX=/usr/local
 SBINDIR=$(PREFIX)/sbin
 SHAREDIR=$(PREFIX)/share
@@ -15,21 +26,21 @@ MANDIR:=$(shell if [ -d $(PREFIX)/share/man ] ; then echo $(PREFIX)/share/man ;
 INCDIR=$(PREFIX)/include
 LIBDIR=$(PREFIX)/lib
 PKGCFDIR=$(LIBDIR)/pkgconfig
+
+# Commands
 INSTALL=install
 DIRINSTALL=install -d
+STRIP=-s
 AR=ar
 RANLIB=ranlib
+
 PCILIB=lib/libpci.a
 PCILIBPC=lib/libpci.pc
 PCIINC=lib/config.h lib/header.h lib/pci.h lib/types.h lib/sysdep.h
 PCIINC_INS=lib/config.h lib/header.h lib/pci.h lib/types.h
-STRIP=-s
 
 -include lib/config.mk
 
-HOST=
-RELEASE=
-
 export
 
 all: $(PCILIB) lspci setpci lspci.8 setpci.8 pcilib.7 update-pciids update-pciids.8 $(PCI_IDS)
@@ -40,7 +51,7 @@ $(PCILIB): $(PCIINC) force
 force:
 
 lib/config.h lib/config.mk:
-       cd lib && ./configure "$(IDSDIR)" "$(VERSION)" "$(HOST)" "$(RELEASE)" "$(ZLIB)"
+       cd lib && ./configure
 
 lspci: lspci.o common.o $(PCILIB)
 setpci: setpci.o common.o $(PCILIB)
@@ -90,4 +101,4 @@ uninstall: all
 pci.ids.gz: pci.ids
        gzip -9 <$< >$@
 
-.PHONY: all clean distclean install uninstall force
+.PHONY: all clean distclean install install-lib uninstall force
index dbd79e63500c159c70a5a907948bdbd5f88ee7a5..20720230189bfa2398aec8090fe4a9e87e175f17 100755 (executable)
@@ -1,4 +1,6 @@
 #!/bin/sh
+# Configuration script for the PCI library
+# (c) 1998--2008 Martin Mares <mj@ucw.cz>
 
 echo_n() {
        if [ -n "$BASH" ]
@@ -9,31 +11,34 @@ echo_n() {
        fi
 }
 
-echo_n "Configuring libpci for your system..."
-idsdir=${1:-/usr/share}
-version=${2:-0.0}
-sys=`uname -s`
-rel=`uname -r`
-if [ "$sys" = "AIX" -a -x /usr/bin/oslevel -a -x /usr/sbin/lsattr ]
-then
-       rel=`/usr/bin/oslevel`
-       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/'`
+if [ -z "$VERSION" -o -z "$IDSDIR" ] ; then
+       echo >&2 "Please run the configure script from the top-level Makefile"
+       exit 1
 fi
-if [ "$sys" = "GNU/kFreeBSD" -o "$sys" = "DragonFly" ]
-then
-       sys=freebsd
+
+echo_n "Configuring libpci for your system..."
+if [ -z "$HOST" ] ; then
+       sys=`uname -s`
+       rel=`uname -r`
+       if [ "$sys" = "AIX" -a -x /usr/bin/oslevel -a -x /usr/sbin/lsattr ]
+       then
+               rel=`/usr/bin/oslevel`
+               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/'`
+       fi
+       if [ "$sys" = "GNU/kFreeBSD" -o "$sys" = "DragonFly" ]
+       then
+               sys=freebsd
+       fi
+       HOST=${3:-$cpu-$sys}
 fi
-host=${3:-$cpu-$sys}
 # 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]'`
+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
 m=config.mk
@@ -58,7 +63,6 @@ case $sys in
                esac
                echo >>$c '#define PCI_HAVE_64BIT_ADDRESS'
                echo >>$c '#define PCI_USE_DNS'
-               echo >>$m 'LDLIBS+=-lresolv'
                ;;
        sunos)
                case $cpu in
@@ -71,22 +75,16 @@ case $sys in
                                                ;;
                esac
                echo >>$c '#define PCI_HAVE_STDINT_H'
-               echo >>$c '#define PCI_USE_DNS'
-               echo >>$m 'LDLIBS+=-lresolv'
                ;;
        freebsd)
                echo_n " fbsd-device"
                echo >>$c '#define PCI_HAVE_PM_FBSD_DEVICE'
                echo >>$c '#define PCI_PATH_FBSD_DEVICE "/dev/pci"'
-               echo >>$c '#define PCI_USE_DNS'
-               echo >>$m 'LDLIBS+=-lresolv'
                ;;
         openbsd)
                echo_n " obsd-device"
                echo >>$c '#define PCI_HAVE_PM_OBSD_DEVICE'
                echo >>$c '#define PCI_PATH_OBSD_DEVICE "/dev/pci"'
-               echo >>$c '#define PCI_USE_DNS'
-               echo >>$m 'LDLIBS+=-lresolv'
                ;;
        aix)
                echo_n " aix-device"
@@ -97,17 +95,14 @@ case $sys in
                ;;
        netbsd)
                echo_n " nbsd-libpci"
-               echo >>$c '#define PCI_USE_DNS'
                echo >>$c '#define PCI_HAVE_PM_NBSD_LIBPCI'
                echo >>$c '#define PCI_PATH_NBSD_DEVICE "/dev/pci0"'
                echo >>$m 'PCILIB=lib/libpciutils.a'
-               echo >>$m 'LDLIBS+=-lpci -lresolv'
+               echo >>$m 'LDLIBS+=-lpci'
                ;;
        gnu)
                echo_n " i386-ports"
                echo >>$c '#define PCI_HAVE_PM_INTEL_CONF'
-               echo >>$c '#define PCI_USE_DNS'
-               echo >>$m 'LDLIBS+=-lresolv'
                ;;
         *)
                echo " Unfortunately, your OS is not supported by the PCI Library"
@@ -119,17 +114,17 @@ echo >>$c '#define PCI_HAVE_PM_DUMP'
 echo " dump"
 
 echo_n "Checking for zlib support... "
-if [ "$zlib" = yes -o "$zlib" = no ] ; then
-       echo "$zlib (set manually)"
+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
-               zlib=yes
+               ZLIB=yes
        else
-               zlib=no
+               ZLIB=no
        fi
-       echo "$zlib (auto-detected)"
+       echo "$ZLIB (auto-detected)"
 fi
-if [ "$zlib" = yes ] ; then
+if [ "$ZLIB" = yes ] ; then
        echo >>$c '#define PCI_COMPRESSED_IDS'
        echo >>$c '#define PCI_IDS "pci.ids.gz"'
        echo >>$m 'LIBZ=-lz'
@@ -137,8 +132,24 @@ if [ "$zlib" = yes ] ; then
 else
        echo >>$c '#define PCI_IDS "pci.ids"'
 fi
-echo >>$c "#define PCI_PATH_IDS_DIR \"$idsdir\""
-echo >>$c "#define PCI_ID_DOMAIN \"pci-id.ucw.cz\""
+echo >>$c "#define PCI_PATH_IDS_DIR \"$IDSDIR\""
+
+echo_n "Checking for DNS support... "
+if [ "$DNS" = yes -o "$DNS" = no ] ; then
+       echo "$DNS (set manually)"
+else
+       if [ -f /usr/include/resolv.h ] ; then
+               DNS=yes
+       else
+               DNS=no
+       fi
+       echo "$DNS (auto-detected)"
+fi
+if [ "$DNS" = yes ] ; then
+       echo >>$c "#define PCI_USE_DNS"
+       echo >>$c "#define PCI_ID_DOMAIN \"pci-id.ucw.cz\""
+       echo >>$m 'LDLIBS+=-lresolv'
+fi
 
-echo >>$c "#define PCILIB_VERSION \"$version\""
+echo >>$c "#define PCILIB_VERSION \"$VERSION\""
 sed '/"/{s/^#define \([^ ]*\) "\(.*\)"$/\1=\2/;p;d;};s/^#define \(.*\)/\1=1/' <$c >>$m