X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2FMakefile;h=d89cd6c83d92dc2e6ef803ff9fb32ab2788fe67b;hb=8b122188dfd404984eb360e8d876682fe7eb1613;hp=6138fd98619c802e85b177f6424f5790b47c67de;hpb=727ce158868ed101006ecc5d3dd3faede927165c;p=pciutils.git diff --git a/lib/Makefile b/lib/Makefile index 6138fd9..d89cd6c 100644 --- a/lib/Makefile +++ b/lib/Makefile @@ -1,44 +1,102 @@ -# $Id: Makefile,v 1.1 1999/01/22 21:05:10 mj Exp $ # Makefile for The PCI Library -# (c) 1999 Martin Mares +# (c) 1999--2014 Martin Mares -include config.mk +# Expects to be invoked from the top-level Makefile and uses lots of its variables. -OBJS=access.o generic.o dump.o names.o filter.o buffer.o -INCL=internal.h pci.h config.h +OBJS=init access generic dump names filter names-hash names-parse names-net names-cache names-hwdb params caps +INCL=internal.h pci.h config.h header.h sysdep.h types.h -ifdef HAVE_PM_LINUX_PROC -OBJS += proc.o +ifdef PCI_HAVE_PM_LINUX_SYSFS +OBJS += sysfs endif -ifdef HAVE_PM_INTEL_CONF -OBJS += i386-ports.o +ifdef PCI_HAVE_PM_LINUX_PROC +OBJS += proc endif -ifdef HAVE_PM_DUMP -OBJS += dump.o +ifdef PCI_HAVE_PM_INTEL_CONF +OBJS += i386-ports endif -ifdef HAVE_PM_SYSCALLS -OBJS += syscalls.o +ifdef PCI_HAVE_PM_DUMP +OBJS += dump endif -ifdef HAVE_OWN_HEADER_H -INCL += header.h +ifdef PCI_HAVE_PM_FBSD_DEVICE +OBJS += fbsd-device +CFLAGS += -I/usr/src/sys +ifdef FREEBSD_SYS +CFLAGS += -I${FREEBSD_SYS} +endif +endif + +ifdef PCI_HAVE_PM_OBSD_DEVICE +OBJS += obsd-device +endif + +ifdef PCI_HAVE_PM_AIX_DEVICE +OBJS += aix-device +endif + +ifdef PCI_HAVE_PM_NBSD_LIBPCI +OBJS += nbsd-libpci endif -all: libpci.a +ifdef PCI_HAVE_PM_DARWIN_DEVICE +OBJS += darwin +endif -libpci.a: $(OBJS) +ifdef PCI_HAVE_PM_SYLIXOS_DEVICE +OBJS += sylixos-device +endif + +ifdef PCI_HAVE_PM_HURD_CONF +OBJS += hurd +endif + +all: $(PCILIB) $(PCILIBPC) + +ifeq ($(SHARED),no) +$(PCILIB): $(addsuffix .o,$(OBJS)) rm -f $@ - ar rcs $@ $^ - ranlib $@ + $(AR) rcs $@ $^ + $(RANLIB) $@ +else +CFLAGS += -fPIC -fvisibility=hidden +$(PCILIB): $(addsuffix .o,$(OBJS)) + ifdef PCI_HAVE_PM_DARWIN_DEVICE + $(CC) -shared $(LDFLAGS) $(SONAME) -Wl,-install_name,$(LIBDIR)/$(PCILIB) -o $@ $^ $(LIB_LDLIBS) + else + $(CC) -shared $(LDFLAGS) $(SONAME) -Wl,--version-script=libpci.ver -o $@ $^ $(LIB_LDLIBS) + endif +endif + +$(PCILIBPC): libpci.pc.in + sed <$< >$@ -e 's,@PREFIX@,$(PREFIX),' \ + -e 's,@INCDIR@,$(INCDIR),' \ + -e 's,@LIBDIR@,$(LIBDIR),' \ + -e 's,@IDSDIR@,$(IDSDIR),' \ + -e 's,@VERSION@,$(VERSION),' \ + -e 's,@LDLIBS@,$(LDLIBS),' +init.o: init.c $(INCL) access.o: access.c $(INCL) -i386-ports.o: i386-ports.c $(INCL) -proc.o: proc.c $(INCL) +params.o: params.c $(INCL) +i386-ports.o: i386-ports.c $(INCL) i386-io-hurd.h i386-io-linux.h i386-io-sunos.h i386-io-windows.h i386-io-cygwin.h +proc.o: proc.c $(INCL) pread.h +sysfs.o: sysfs.c $(INCL) pread.h generic.o: generic.c $(INCL) syscalls.o: syscalls.c $(INCL) +obsd-device.o: obsd-device.c $(INCL) +fbsd-device.o: fbsd-device.c $(INCL) +aix-device.o: aix-device.c $(INCL) dump.o: dump.c $(INCL) -names.o: names.c $(INCL) +names.o: names.c $(INCL) names.h +names-cache.o: names-cache.c $(INCL) names.h +names-hash.o: names-hash.c $(INCL) names.h +names-net.o: names-net.c $(INCL) names.h +names-parse.o: names-parse.c $(INCL) names.h +names-hwdb.o: names-hwdb.c $(INCL) names.h filter.o: filter.c $(INCL) +nbsd-libpci.o: nbsd-libpci.c $(INCL) +hurd.o: hurd.c $(INCL)