--- a/Makefile 2011-10-02 22:28:55.000000000 +1100 +++ b/Makefile 2011-11-28 19:40:57.000000000 +1100 @@ -1,7 +1,7 @@ # Makefile for The PCI Utilities # (c) 1998--2011 Martin Mares -OPT=-O2 +OPT=-O2 -g CFLAGS=$(OPT) -Wall -W -Wno-parentheses -Wstrict-prototypes -Wmissing-prototypes VERSION=3.1.8 @@ -52,7 +52,9 @@ PCIINC_INS=lib/config.h lib/header.h lib export -all: lib/$(PCILIB) lspci setpci example lspci.8 setpci.8 pcilib.7 update-pciids update-pciids.8 $(PCI_IDS) +pcimod-$(PCI_OS_LINUX) := pcimodules +pcimod8-$(PCI_OS_LINUX) := pcimodules.8 +all: lib/$(PCILIB) lspci lspci-udeb setpci example lspci.8 setpci.8 pcilib.7 update-pciids update-pciids.8 $(PCI_IDS) $(pcimod-1) $(pcimod8-1) lib/$(PCILIB): $(PCIINC) force $(MAKE) -C lib all @@ -63,7 +65,9 @@ lib/config.h lib/config.mk: cd lib && ./configure lspci: lspci.o ls-vpd.o ls-caps.o ls-ecaps.o ls-kernel.o ls-tree.o ls-map.o common.o lib/$(PCILIB) +lspci-udeb: lspci.o ls-vpd.o ls-caps.o ls-ecaps.o ls-kernel.o ls-tree.o ls-map.o common.o lib/libpci.a setpci: setpci.o common.o lib/$(PCILIB) +pcimodules: pcimodules.o common.o lib/$(PCILIB) LSPCIINC=lspci.h pciutils.h $(PCIINC) lspci.o: lspci.c $(LSPCIINC) @@ -75,10 +79,11 @@ ls-tree.o: ls-tree.c $(LSPCIINC) ls-map.o: ls-map.c $(LSPCIINC) setpci.o: setpci.c pciutils.h $(PCIINC) +pcimodules.o: pcimodules.c pciutils.h $(PCIINC) common.o: common.c pciutils.h $(PCIINC) update-pciids: update-pciids.sh - sed <$< >$@ "s@^DEST=.*@DEST=$(IDSDIR)/$(PCI_IDS)@;s@^PCI_COMPRESSED_IDS=.*@PCI_COMPRESSED_IDS=$(PCI_COMPRESSED_IDS)@" + sed <$< >$@ "s@^FILE=.*@FILE=$(IDSDIR)/pci.ids@" chmod +x $@ # The example of use of libpci @@ -88,12 +93,16 @@ example.o: example.c $(PCIINC) %: %.o $(CC) $(LDFLAGS) $(TARGET_ARCH) $^ $(LDLIBS) -o $@ +lspci-udeb: lspci.o + $(CC) $(LDFLAGS) $(TARGET_ARCH) $^ $(LDLIBS) -lz -lresolv -o $@ + %.8 %.7: %.man M=`echo $(DATE) | sed 's/-01-/-January-/;s/-02-/-February-/;s/-03-/-March-/;s/-04-/-April-/;s/-05-/-May-/;s/-06-/-June-/;s/-07-/-July-/;s/-08-/-August-/;s/-09-/-September-/;s/-10-/-October-/;s/-11-/-November-/;s/-12-/-December-/;s/\(.*\)-\(.*\)-\(.*\)/\3 \2 \1/'` ; sed <$< >$@ "s/@TODAY@/$$M/;s/@VERSION@/pciutils-$(VERSION)/;s#@IDSDIR@#$(IDSDIR)#" clean: rm -f `find . -name "*~" -o -name "*.[oa]" -o -name "\#*\#" -o -name TAGS -o -name core -o -name "*.orig"` rm -f update-pciids lspci setpci example lib/config.* *.[78] pci.ids.* lib/*.pc lib/*.so lib/*.so.* + rm -f pcimodules rm -rf maint/dist distclean: clean @@ -101,10 +110,11 @@ distclean: clean install: all # -c is ignored on Linux, but required on FreeBSD $(DIRINSTALL) -m 755 $(DESTDIR)$(SBINDIR) $(DESTDIR)$(IDSDIR) $(DESTDIR)$(MANDIR)/man8 $(DESTDIR)$(MANDIR)/man7 - $(INSTALL) -c -m 755 $(STRIP) lspci setpci $(DESTDIR)$(SBINDIR) + $(INSTALL) -c -m 755 $(STRIP) lspci setpci $(pcimod-1) $(DESTDIR)$(SBINDIR) + $(INSTALL) -c -m 755 $(STRIP) lspci-udeb $(DESTDIR)-udeb$(SBINDIR)/lspci $(INSTALL) -c -m 755 update-pciids $(DESTDIR)$(SBINDIR) $(INSTALL) -c -m 644 $(PCI_IDS) $(DESTDIR)$(IDSDIR) - $(INSTALL) -c -m 644 lspci.8 setpci.8 update-pciids.8 $(DESTDIR)$(MANDIR)/man8 + $(INSTALL) -c -m 644 lspci.8 setpci.8 update-pciids.8 $(pcimod8-1) $(DESTDIR)$(MANDIR)/man8 $(INSTALL) -c -m 644 pcilib.7 $(DESTDIR)$(MANDIR)/man7 ifeq ($(SHARED),yes) $(DIRINSTALL) -m 755 $(DESTDIR)$(LIBDIR) @@ -123,8 +133,10 @@ endif uninstall: all rm -f $(DESTDIR)$(SBINDIR)/lspci $(DESTDIR)$(SBINDIR)/setpci $(DESTDIR)$(SBINDIR)/update-pciids + rm -f $(DESTDIR)-udeb$(SBINDIR)/lspci rm -f $(DESTDIR)$(IDSDIR)/$(PCI_IDS) rm -f $(DESTDIR)$(MANDIR)/man8/lspci.8 $(DESTDIR)$(MANDIR)/man8/setpci.8 $(DESTDIR)$(MANDIR)/man8/update-pciids.8 + rm -f $(DESTDIR)$(SBINDIR)/pcimodules $(DESTDIR)$(MANDIR)/man8/pcimodules.8 rm -f $(DESTDIR)$(MANDIR)/man7/pcilib.7 ifeq ($(SHARED),yes) rm -f $(DESTDIR)$(LIBDIR)/$(PCILIB) $(DESTDIR)$(LIBDIR)/$(LIBNAME).so$(ABI_VERSION) --- a/lib/Makefile 2011-01-08 08:04:28.000000000 +1100 +++ b/lib/Makefile 2011-11-28 19:40:57.000000000 +1100 @@ -42,18 +42,20 @@ ifdef PCI_HAVE_PM_NBSD_LIBPCI OBJS += nbsd-libpci endif -all: $(PCILIB) $(PCILIBPC) +PCILIBA=libpci.a -ifeq ($(SHARED),no) -$(PCILIB): $(addsuffix .o,$(OBJS)) +all: $(PCILIB) $(PCILIBA) $(PCILIBPC) + +#ifeq ($(SHARED),no) +$(PCILIBA): $(addsuffix .o,$(OBJS)) rm -f $@ $(AR) rcs $@ $^ $(RANLIB) $@ -else +#else CFLAGS += -fPIC -fvisibility=hidden $(PCILIB): $(addsuffix .o,$(OBJS)) $(CC) -shared $(LDFLAGS) $(SONAME) -Wl,--version-script=libpci.ver -o $@ $^ $(LIB_LDLIBS) -endif +#endif $(PCILIBPC): libpci.pc.in sed <$< >$@ -e 's,@PREFIX@,$(PREFIX),' \