X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2FMakefile;h=f119b728e3897214f23f48d5a5824c1b0ef8d981;hb=58d9f25f25c0070c3c3df3073f375d87a9163e88;hp=49eb6fbcfb39f508e2d9023a46c5c2294fabe018;hpb=90f8c88626289b0a713abc41759e8bebe6c20ddb;p=pciutils.git diff --git a/lib/Makefile b/lib/Makefile index 49eb6fb..f119b72 100644 --- a/lib/Makefile +++ b/lib/Makefile @@ -1,32 +1,29 @@ # Makefile for The PCI Library -# (c) 1999--2008 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=init.o access.o generic.o dump.o names.o filter.o names-hash.o names-parse.o names-net.o names-cache.o params.o +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 -PCILIB=libpci.a -PCILIBPC=libpci.pc - ifdef PCI_HAVE_PM_LINUX_SYSFS -OBJS += sysfs.o +OBJS += sysfs endif ifdef PCI_HAVE_PM_LINUX_PROC -OBJS += proc.o +OBJS += proc endif ifdef PCI_HAVE_PM_INTEL_CONF -OBJS += i386-ports.o +OBJS += i386-ports endif ifdef PCI_HAVE_PM_DUMP -OBJS += dump.o +OBJS += dump endif ifdef PCI_HAVE_PM_FBSD_DEVICE -OBJS += fbsd-device.o +OBJS += fbsd-device CFLAGS += -I/usr/src/sys ifdef FREEBSD_SYS CFLAGS += -I${FREEBSD_SYS} @@ -34,37 +31,50 @@ endif endif ifdef PCI_HAVE_PM_OBSD_DEVICE -OBJS += obsd-device.o +OBJS += obsd-device endif ifdef PCI_HAVE_PM_AIX_DEVICE -OBJS += aix-device.o +OBJS += aix-device endif ifdef PCI_HAVE_PM_NBSD_LIBPCI -OBJS += nbsd-libpci.o -PCILIB=libpciutils.a +OBJS += nbsd-libpci +endif + +ifdef PCI_HAVE_PM_DARWIN_DEVICE +OBJS += darwin endif all: $(PCILIB) $(PCILIBPC) -$(PCILIB): $(OBJS) +ifeq ($(SHARED),no) +$(PCILIB): $(addsuffix .o,$(OBJS)) rm -f $@ $(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): $(PCILIBPC).in +$(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,@LIBZ@,$(LIBZ),' + -e 's,@LDLIBS@,$(LDLIBS),' init.o: init.c $(INCL) access.o: access.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-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) @@ -78,7 +88,6 @@ 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) - -example: example.c $(PCILIB)