]> git.ipfire.org Git - thirdparty/kmod.git/blobdiff - Makefile.am
kmod 7
[thirdparty/kmod.git] / Makefile.am
index b6ba9d8312dbfd3dc79fbfa0b1e630dae63b9b1d..0a0ad2a3c7be46428fa37bbf30dcd8927cea5939 100644 (file)
@@ -1,3 +1,6 @@
+SUBDIRS = . libkmod/docs man
+
+DISTCLEAN_LOCAL_HOOKS =
 EXTRA_DIST =
 CLEANFILES =
 ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
@@ -6,21 +9,41 @@ AM_MAKEFLAGS = --no-print-directory
 AM_CPPFLAGS = \
        -include $(top_builddir)/config.h \
        -I$(top_srcdir)/libkmod \
+       -DROOTPREFIX=\""$(rootprefix)"\" \
        -DSYSCONFDIR=\""$(sysconfdir)"\" \
-       -DLIBEXECDIR=\""$(libexecdir)"\"
-
-AM_CFLAGS = \
-       -fvisibility=hidden \
-       -ffunction-sections \
-       -fdata-sections
-
-AM_LDFLAGS = \
-       -Wl,--gc-sections \
-       -Wl,--as-needed
-
-LIBKMOD_CURRENT=0
-LIBKMOD_REVISION=0
-LIBKMOD_AGE=0
+       -DLIBEXECDIR=\""$(libexecdir)"\" \
+       ${zlib_CFLAGS}
+
+AM_CFLAGS = $(WARNINGFLAGS)
+AM_LDFLAGS = $(GCLDFLAGS)
+
+SED_PROCESS = \
+       $(AM_V_GEN)$(MKDIR_P) $(dir $@) && $(SED) \
+       -e 's,@VERSION\@,$(VERSION),g' \
+       -e 's,@prefix\@,$(prefix),g' \
+       -e 's,@exec_prefix\@,$(exec_prefix),g' \
+       -e 's,@libdir\@,$(libdir),g' \
+       -e 's,@includedir\@,$(includedir),g' \
+       -e 's,@liblzma_CFLAGS\@,${liblzma_CFLAGS},g' \
+       -e 's,@liblzma_LIBS\@,${liblzma_LIBS},g' \
+       -e 's,@zlib_CFLAGS\@,${zlib_CFLAGS},g' \
+       -e 's,@zlib_LIBS\@,${zlib_LIBS},g' \
+       < $< > $@ || rm $@
+
+%.pc: %.pc.in Makefile
+       $(SED_PROCESS)
+
+LIBKMOD_CURRENT=3
+LIBKMOD_REVISION=1
+LIBKMOD_AGE=1
+
+noinst_LTLIBRARIES = libkmod/libkmod-util.la
+libkmod_libkmod_util_la_SOURCES = libkmod/libkmod-hash.c \
+                                 libkmod/libkmod-hash.h \
+                                 libkmod/libkmod-array.c \
+                                 libkmod/libkmod-array.h \
+                                 libkmod/libkmod-util.c \
+                                 libkmod/libkmod-util.h
 
 include_HEADERS = libkmod/libkmod.h
 lib_LTLIBRARIES = libkmod/libkmod.la
@@ -31,58 +54,165 @@ libkmod_libkmod_la_SOURCES =\
        libkmod/macro.h \
        libkmod/libkmod.c \
        libkmod/libkmod-list.c \
-       libkmod/libkmod-hash.c \
-       libkmod/libkmod-loaded.c \
        libkmod/libkmod-config.c \
-       libkmod/libkmod-util.c \
        libkmod/libkmod-index.c \
        libkmod/libkmod-index.h \
-       libkmod/libkmod-module.c
+       libkmod/libkmod-module.c \
+       libkmod/libkmod-file.c \
+       libkmod/libkmod-elf.c
 
 EXTRA_DIST += libkmod/libkmod.sym
+EXTRA_DIST += libkmod/COPYING libkmod/README
 
 libkmod_libkmod_la_LDFLAGS = $(AM_LDFLAGS) \
        -version-info $(LIBKMOD_CURRENT):$(LIBKMOD_REVISION):$(LIBKMOD_AGE) \
        -Wl,--version-script=$(top_srcdir)/libkmod/libkmod.sym
+libkmod_libkmod_la_DEPENDENCIES = libkmod/libkmod-util.la \
+                                 ${top_srcdir}/libkmod/libkmod.sym
+libkmod_libkmod_la_LIBADD = libkmod/libkmod-util.la \
+                           ${liblzma_LIBS} ${zlib_LIBS}
+
+noinst_LTLIBRARIES += libkmod/libkmod-private.la
+libkmod_libkmod_private_la_SOURCES = $(libkmod_libkmod_la_SOURCES)
+libkmod_libkmod_private_la_LDFLAGS = $(AM_LDFLAGS) \
+       -Wl,--version-script=$(top_srcdir)/libkmod/libkmod.sym
+libkmod_libkmod_private_la_DEPENDENCIES  = $(libkmod_libkmod_la_DEPENDENCIES)
+libkmod_libkmod_private_la_LIBADD = $(libkmod_libkmod_la_LIBADD)
 
 pkgconfigdir = $(libdir)/pkgconfig
 pkgconfig_DATA = libkmod/libkmod.pc
-
-TESTS = test/test-init test/test-loaded
-
-check_PROGRAMS = test/test-init test/test-loaded
-test_test_init_SOURCES = test/test-init.c
-test_test_init_LDADD = libkmod/libkmod.la
-
-test_test_loaded_SOURCES = test/test-loaded.c
-test_test_loaded_LDADD = libkmod/libkmod.la
-
-noinst_PROGRAMS = test/test-insmod test/test-rmmod test/test-rmmod2 \
-                 test/test-lookup test/test-path-from-name \
-                 test/test-get-dependencies test/test-mod-double-ref \
-                 test/test-blacklist \
-                 $(check_PROGRAMS)
-
-test_test_rmmod_SOURCES = test/test-rmmod.c
-test_test_rmmod_LDADD = libkmod/libkmod.la
-
-test_test_rmmod2_SOURCES = test/test-rmmod2.c
-test_test_rmmod2_LDADD = libkmod/libkmod.la
-
-test_test_insmod_SOURCES = test/test-insmod.c
-test_test_insmod_LDADD = libkmod/libkmod.la
-
-test_test_lookup_SOURCES = test/test-lookup.c
-test_test_lookup_LDADD = libkmod/libkmod.la
-
-test_test_path_from_name_SOURCES = test/test-path-from-name.c
-test_test_path_from_name_LDADD = libkmod/libkmod.la
-
-test_test_get_dependencies_SOURCES = test/test-get-dependencies.c
-test_test_get_dependencies_LDADD = libkmod/libkmod.la
-
-test_test_mod_double_ref_SOURCES = test/test-mod-double-ref.c
-test_test_mod_double_ref_LDADD = libkmod/libkmod.la
-
-test_test_blacklist_SOURCES = test/test-blacklist.c
-test_test_blacklist_LDADD = libkmod/libkmod.la
+EXTRA_DIST += libkmod/libkmod.pc.in
+CLEANFILES += libkmod/libkmod.pc
+
+install-exec-hook:
+       if test "$(libdir)" != "$(rootlibdir)"; then \
+               $(MKDIR_P) $(DESTDIR)$(rootlibdir) && \
+               so_img_name=$$(readlink $(DESTDIR)$(libdir)/libkmod.so) && \
+               so_img_rel_target_prefix=$$(echo $(libdir) | sed 's,\(^/\|\)[^/][^/]*,..,g') && \
+               ln -sf $$so_img_rel_target_prefix$(rootlibdir)/$$so_img_name $(DESTDIR)$(libdir)/libkmod.so && \
+               mv $(DESTDIR)$(libdir)/libkmod.so.* $(DESTDIR)$(rootlibdir); \
+       fi
+
+uninstall-hook:
+       rm -f $(DESTDIR)$(rootlibdir)/libkmod.so*
+
+if BUILD_TOOLS
+bin_PROGRAMS = tools/kmod
+
+noinst_SCRIPTS = tools/insmod tools/rmmod tools/lsmod \
+                tools/modprobe tools/modinfo tools/depmod
+
+tools_kmod_SOURCES = tools/kmod.c tools/kmod.h tools/kmod-lsmod.c \
+                    tools/kmod-rmmod.c tools/kmod-insmod.c \
+                    tools/kmod-modinfo.c tools/kmod-modprobe.c \
+                    tools/kmod-depmod.c
+tools_kmod_CPPFLAGS = $(AM_CPPFLAGS) -DKMOD_BUNDLE_TOOL=1
+tools_kmod_CFLAGS = $(AM_CFLAGS)
+tools_kmod_LDADD = libkmod/libkmod-util.la \
+                  libkmod/libkmod.la
+
+noinst_PROGRAMS = tools/kmod-nolib
+tools_kmod_nolib_SOURCES = $(tools_kmod_SOURCES)
+tools_kmod_nolib_CPPFLAGS = $(tools_kmod_CPPFLAGS)
+tools_kmod_nolib_CFLAGS = $(tools_kmod_CFLAGS)
+tools_kmod_nolib_LDADD = libkmod/libkmod-util.la \
+                        libkmod/libkmod-private.la
+
+${noinst_SCRIPTS}: tools/kmod-nolib
+       $(AM_V_GEN) ($(RM) $@; \
+               $(LN_S) $(notdir $<) $@)
+endif
+
+# ------------------------------------------------------------------------------
+# TESTSUITE
+# ------------------------------------------------------------------------------
+
+testsuite/rootfs: $(top_srcdir)/testsuite/rootfs.tar.xz
+       $(AM_V_GEN) tar -C testsuite/ \
+               -xJf $(top_srcdir)/testsuite/rootfs.tar.xz
+
+TESTSUITE_OVERRIDE_LIBS = testsuite/uname.la testsuite/path.la \
+                         testsuite/init_module.la \
+                         testsuite/delete_module.la
+TESTSUITE_OVERRIDE_LIBS_LDFLAGS = avoid-version -module -shared -export-dynamic \
+                                 -rpath /nowhere -ldl
+
+check_LTLIBRARIES = $(TESTSUITE_OVERRIDE_LIBS)
+
+testsuite_uname_la_LDFLAGS = $(TESTSUITE_OVERRIDE_LIBS_LDFLAGS)
+testsuite_path_la_LDFLAGS = $(TESTSUITE_OVERRIDE_LIBS_LDFLAGS)
+
+testsuite_delete_module_la_LDFLAGS = $(TESTSUITE_OVERRIDE_LIBS_LDFLAGS)
+testsuite_init_module_la_LDFLAGS = $(TESTSUITE_OVERRIDE_LIBS_LDFLAGS)
+testsuite_init_module_la_SOURCES = testsuite/init_module.c \
+                                  testsuite/stripped-module.h
+testsuite_init_module_la_LIBADD = libkmod/libkmod-private.la
+
+testsuite-distclean:
+       -rm -rf testsuite/rootfs
+
+testsuite-pack-rootfs:
+       $(AM_V_GEN) ( cd testsuite && tar -cJf \
+                       $(abs_top_srcdir)/testsuite/rootfs.tar.xz \
+                       rootfs )
+
+DISTCLEAN_LOCAL_HOOKS += testsuite-distclean
+EXTRA_DIST += testsuite/rootfs.tar.xz
+
+TESTSUITE_CPPFLAGS = $(AM_CPPFLAGS) \
+                    -DTESTSUITE_ROOTFS=\"$(abs_top_builddir)/testsuite/rootfs/\" \
+                    -DABS_TOP_BUILDDIR=\"$(abs_top_builddir)\"
+TESTSUITE_LDADD = testsuite/libtestsuite.la libkmod/libkmod-private.la
+
+check_LTLIBRARIES += testsuite/libtestsuite.la
+testsuite_libtestsuite_la_SOURCES = testsuite/testsuite.c \
+                                   testsuite/testsuite.h
+testsuite_libtestsuite_la_DEPENDENCIES = testsuite/rootfs \
+                                   $(TESTSUITE_OVERRIDE_LIBS)
+testsuite_libtestsuite_la_CPPFLAGS = $(TESTSUITE_CPPFLAGS)
+
+TESTSUITE = testsuite/test-init testsuite/test-testsuite testsuite/test-loaded \
+           testsuite/test-modinfo testsuite/test-alias testsuite/test-new-module \
+           testsuite/test-modprobe
+check_PROGRAMS = $(TESTSUITE)
+TESTS = $(TESTSUITE)
+
+testsuite_test_testsuite_LDADD = testsuite/libtestsuite.la
+testsuite_test_testsuite_CPPFLAGS = $(TESTSUITE_CPPFLAGS)
+testsuite_test_init_LDADD = $(TESTSUITE_LDADD)
+testsuite_test_init_CPPFLAGS = $(TESTSUITE_CPPFLAGS)
+testsuite_test_loaded_LDADD = $(TESTSUITE_LDADD)
+testsuite_test_loaded_CPPFLAGS = $(TESTSUITE_CPPFLAGS)
+testsuite_test_modinfo_LDADD = $(TESTSUITE_LDADD)
+testsuite_test_modinfo_CPPFLAGS = $(TESTSUITE_CPPFLAGS)
+testsuite_test_alias_LDADD = $(TESTSUITE_LDADD)
+testsuite_test_alias_CPPFLAGS = $(TESTSUITE_CPPFLAGS)
+testsuite_test_new_module_LDADD = $(TESTSUITE_LDADD)
+testsuite_test_new_module_CPPFLAGS = $(TESTSUITE_CPPFLAGS)
+testsuite_test_modprobe_LDADD = $(TESTSUITE_LDADD)
+testsuite_test_modprobe_CPPFLAGS = $(TESTSUITE_CPPFLAGS)
+
+DISTCHECK_CONFIGURE_FLAGS=--enable-gtk-doc
+
+distclean-local: $(DISTCLEAN_LOCAL_HOOKS)
+
+# ------------------------------------------------------------------------------
+# custom release helpers
+# ------------------------------------------------------------------------------
+
+git-release:
+       head -1 NEWS | grep -q "kmod $(VERSION)"
+       git commit -a -m "kmod $(VERSION)"
+       git tag -m "kmod $(VERSION)" -s v$(VERSION)
+       git gc --prune=0
+
+kmod-$(VERSION).tar.xz:
+       make distcheck
+
+kmod-$(VERSION).tar.sign:
+       xz -d -c kmod-$(VERSION).tar.xz | gpg --armor --detach-sign --output kmod-$(VERSION).tar.sign
+
+tar: kmod-$(VERSION).tar.xz kmod-$(VERSION).tar.sign
+
+tar-sync: kmod-$(VERSION).tar.xz kmod-$(VERSION).tar.sign
+       kup put kmod-$(VERSION).tar.xz  kmod-$(VERSION).tar.sign /pub/linux/utils/kernel/kmod/