]> git.ipfire.org Git - thirdparty/dracut.git/blobdiff - Makefile
fix(zfcp_rules): correct shellcheck regression when parsing ccw args
[thirdparty/dracut.git] / Makefile
index 98a2fbf60418ebfe39dd6c076e1dc333c76635bb..333cd68d6e0221a28da18c22290f7cc699280c33 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,10 +1,21 @@
 -include dracut-version.sh
 
-VERSION = $(shell [ -d .git ] && git describe --abbrev=0 --tags 2>/dev/null || echo $(DRACUT_VERSION))
-GITVERSION = $(shell [ -d .git ] && { v=$$(git describe --tags 2>/dev/null); [ $${v\#*-} != $$v ] && echo -$${v\#*-}; } )
+DRACUT_MAIN_VERSION ?= $(shell env GIT_CEILING_DIRECTORIES=$(CURDIR)/.. git describe --abbrev=0 --tags --always 2>/dev/null || :)
+ifeq ($(DRACUT_MAIN_VERSION),)
+DRACUT_MAIN_VERSION = $(DRACUT_VERSION)
+endif
+DRACUT_FULL_VERSION ?= $(shell env GIT_CEILING_DIRECTORIES=$(CURDIR)/.. git describe --tags --always 2>/dev/null || :)
+ifeq ($(DRACUT_FULL_VERSION),)
+DRACUT_FULL_VERSION = $(DRACUT_VERSION)
+endif
+
+HAVE_SHELLCHECK ?= $(shell command -v shellcheck >/dev/null 2>&1 && echo yes)
+HAVE_SHFMT ?= $(shell command -v shfmt >/dev/null  2>&1 && echo yes)
 
 -include Makefile.inc
 
+KVERSION ?= $(shell uname -r)
+
 prefix ?= /usr
 libdir ?= ${prefix}/lib
 datadir ?= ${prefix}/share
@@ -12,23 +23,20 @@ pkglibdir ?= ${libdir}/dracut
 sysconfdir ?= ${prefix}/etc
 bindir ?= ${prefix}/bin
 mandir ?= ${prefix}/share/man
-CFLAGS ?= -O2 -g -Wall
-CFLAGS += -std=gnu99 -D_FILE_OFFSET_BITS=64 -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2
+CFLAGS ?= -O2 -g -Wall -std=gnu99 -D_FILE_OFFSET_BITS=64 -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2
 bashcompletiondir ?= ${datadir}/bash-completion/completions
 pkgconfigdatadir ?= $(datadir)/pkgconfig
 
-man1pages = lsinitrd.1
+man1pages = man/lsinitrd.1
 
-man5pages = dracut.conf.5
+man5pages = man/dracut.conf.5
 
-man7pages = dracut.cmdline.7 \
-            dracut.bootup.7 \
-            dracut.modules.7
+man7pages = man/dracut.cmdline.7 \
+            man/dracut.bootup.7 \
+            man/dracut.modules.7
 
-man8pages = dracut.8 \
-            dracut-catimages.8 \
-            mkinitrd.8 \
-            mkinitrd-suse.8 \
+man8pages = man/dracut.8 \
+            man/dracut-catimages.8 \
             modules.d/98dracut-systemd/dracut-cmdline.service.8 \
             modules.d/98dracut-systemd/dracut-initqueue.service.8 \
             modules.d/98dracut-systemd/dracut-mount.service.8 \
@@ -40,40 +48,68 @@ man8pages = dracut.8 \
 
 manpages = $(man1pages) $(man5pages) $(man7pages) $(man8pages)
 
-.PHONY: install clean archive rpm testimage test all check AUTHORS doc dracut-version.sh
+.PHONY: install clean archive testimage test all check AUTHORS CONTRIBUTORS doc
+
+all: dracut.pc dracut-install src/skipcpio/skipcpio dracut-util
 
-all: dracut-version.sh dracut.pc dracut-install skipcpio/skipcpio
+%.o : %.c
+       $(CC) -c $(CFLAGS) $(CPPFLAGS) $(KMOD_CFLAGS) $< -o $@
 
 DRACUT_INSTALL_OBJECTS = \
-        install/dracut-install.o \
-        install/hashmap.o\
-        install/log.o \
-        install/strv.o \
-        install/util.o
+        src/install/dracut-install.o \
+        src/install/hashmap.o\
+        src/install/log.o \
+        src/install/strv.o \
+        src/install/util.o
 
 # deps generated with gcc -MM
-install/dracut-install.o: install/dracut-install.c install/log.h install/macro.h \
-       install/hashmap.h install/util.h
-install/hashmap.o: install/hashmap.c install/util.h install/macro.h install/log.h \
-       install/hashmap.h
-install/log.o: install/log.c install/log.h install/macro.h install/util.h
-install/util.o: install/util.c install/util.h install/macro.h install/log.h
-install/strv.o: install/strv.c install/strv.h install/util.h install/macro.h install/log.h
+src/install/dracut-install.o: src/install/dracut-install.c src/install/log.h src/install/macro.h \
+       src/install/hashmap.h src/install/util.h
+src/install/hashmap.o: src/install/hashmap.c src/install/util.h src/install/macro.h src/install/log.h \
+       src/install/hashmap.h
+src/install/log.o: src/install/log.c src/install/log.h src/install/macro.h src/install/util.h
+src/install/util.o: src/install/util.c src/install/util.h src/install/macro.h src/install/log.h
+src/install/strv.o: src/install/strv.c src/install/strv.h src/install/util.h src/install/macro.h src/install/log.h
+
+src/install/dracut-install: $(DRACUT_INSTALL_OBJECTS)
+       $(CC) $(LDFLAGS) -o $@ $(DRACUT_INSTALL_OBJECTS) $(LDLIBS) $(FTS_LIBS) $(KMOD_LIBS)
 
-install/dracut-install: $(DRACUT_INSTALL_OBJECTS)
+logtee: src/logtee/logtee.c
+       $(CC) $(LDFLAGS) -o $@ $<
 
-dracut-install: install/dracut-install
+dracut-install: src/install/dracut-install
        ln -fs $< $@
 
-SKIPCPIO_OBJECTS= \
-       skipcpio/skipcpio.o
+SKIPCPIO_OBJECTS = src/skipcpio/skipcpio.o
+skipcpio/skipcpio.o: src/skipcpio/skipcpio.c
+skipcpio/skipcpio: $(SKIPCPIO_OBJECTS)
+
+UTIL_OBJECTS = src/util/util.o
+util/util.o: src/util/util.c
+util/util: $(UTIL_OBJECTS)
+
+dracut-util: src/util/util
+       cp -a $< $@
+
+.PHONY: indent-c
+indent-c:
+       astyle -n --quiet --options=.astylerc $(wildcard *.[ch] */*.[ch] src/*/*.[ch])
+
+.PHONY: indent
+indent: indent-c
+ifeq ($(HAVE_SHFMT),yes)
+       shfmt -w -s .
+endif
+
+src/dracut-cpio/target/release/dracut-cpio: src/dracut-cpio/src/main.rs
+       cargo --offline build --release --manifest-path src/dracut-cpio/Cargo.toml
 
-skipcpio/skipcpio.o: skipcpio/skipcpio.c
-skipcpio/skipcpio: skipcpio/skipcpio.o
+dracut-cpio: src/dracut-cpio/target/release/dracut-cpio
+       ln -fs $< $@
 
-indent:
-       indent -i8 -nut -br -linux -l120 install/dracut-install.c
-       indent -i8 -nut -br -linux -l120 skipcpio/skipcpio.c
+ifeq ($(enable_dracut_cpio),yes)
+all: dracut-cpio
+endif
 
 doc: $(manpages) dracut.html
 
@@ -82,25 +118,33 @@ all: doc
 endif
 
 %: %.xml
-       xsltproc -o $@ -nonet http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl $<
+       @rm -f -- "$@"
+       xsltproc -o "$@" -nonet http://docbook.sourceforge.net/release/xsl/current/manpages/docbook.xsl $<
 
 %.xml: %.asc
-       asciidoc -d manpage -b docbook -o $@ $<
-
-dracut.8: dracut.usage.asc dracut.8.asc
-
-dracut.html: dracut.asc $(manpages) dracut.css dracut.usage.asc
-       asciidoc -a numbered -d book -b docbook -o dracut.xml dracut.asc
+       @rm -f -- "$@"
+       asciidoc -a "version=$(DRACUT_FULL_VERSION)" -d manpage -b docbook -o "$@" $<
+
+dracut.8: man/dracut.8.asc \
+       man/dracut.usage.asc
+
+dracut.html: man/dracut.asc $(manpages) docs/dracut.css man/dracut.usage.asc
+       @rm -f -- dracut.xml
+       asciidoc -a "mainversion=$(DRACUT_MAIN_VERSION)" \
+               -a "version=$(DRACUT_FULL_VERSION)" \
+               -a numbered \
+               -d book -b docbook -o dracut.xml man/dracut.asc
+       @rm -f -- dracut.html
        xsltproc -o dracut.html --xinclude -nonet \
-               --stringparam custom.css.source dracut.css \
+               --stringparam custom.css.source docs/dracut.css \
                --stringparam generate.css.header 1 \
                http://docbook.sourceforge.net/release/xsl/current/xhtml/docbook.xsl dracut.xml
-       rm -f -- dracut.xml
+       @rm -f -- dracut.xml
 
 dracut.pc: Makefile.inc Makefile
        @echo "Name: dracut" > dracut.pc
        @echo "Description: dracut" >> dracut.pc
-       @echo "Version: $(VERSION)$(GITVERSION)" >> dracut.pc
+       @echo "Version: $(DRACUT_FULL_VERSION)" >> dracut.pc
        @echo "dracutdir=$(pkglibdir)" >> dracut.pc
        @echo "dracutmodulesdir=$(pkglibdir)/modules.d" >> dracut.pc
        @echo "dracutconfdir=$(pkglibdir)/dracut.conf.d" >> dracut.pc
@@ -113,7 +157,6 @@ install: all
        mkdir -p $(DESTDIR)$(mandir)/man1 $(DESTDIR)$(mandir)/man5 $(DESTDIR)$(mandir)/man7 $(DESTDIR)$(mandir)/man8
        install -m 0755 dracut.sh $(DESTDIR)$(bindir)/dracut
        install -m 0755 dracut-catimages.sh $(DESTDIR)$(bindir)/dracut-catimages
-       install -m 0755 mkinitrd-dracut.sh $(DESTDIR)$(bindir)/mkinitrd
        install -m 0755 lsinitrd.sh $(DESTDIR)$(bindir)/lsinitrd
        install -m 0644 dracut.conf $(DESTDIR)$(sysconfdir)/dracut.conf
        mkdir -p $(DESTDIR)$(sysconfdir)/dracut.conf.d
@@ -134,6 +177,7 @@ ifneq ($(enable_documentation),no)
 endif
        if [ -n "$(systemdsystemunitdir)" ]; then \
                mkdir -p $(DESTDIR)$(systemdsystemunitdir); \
+               ln -srf $(DESTDIR)$(pkglibdir)/modules.d/98dracut-systemd/dracut-shutdown-onfailure.service $(DESTDIR)$(systemdsystemunitdir)/dracut-shutdown-onfailure.service; \
                ln -srf $(DESTDIR)$(pkglibdir)/modules.d/98dracut-systemd/dracut-shutdown.service $(DESTDIR)$(systemdsystemunitdir)/dracut-shutdown.service; \
                mkdir -p $(DESTDIR)$(systemdsystemunitdir)/sysinit.target.wants; \
                ln -s ../dracut-shutdown.service \
@@ -153,104 +197,104 @@ endif
                        $(DESTDIR)$(systemdsystemunitdir)/initrd.target.wants/$$i; \
                done \
        fi
-       if [ -f install/dracut-install ]; then \
-               install -m 0755 install/dracut-install $(DESTDIR)$(pkglibdir)/dracut-install; \
+       if [ -f src/install/dracut-install ]; then \
+               install -m 0755 src/install/dracut-install $(DESTDIR)$(pkglibdir)/dracut-install; \
+       fi
+       if [ -f src/skipcpio/skipcpio ]; then \
+               install -m 0755 src/skipcpio/skipcpio $(DESTDIR)$(pkglibdir)/skipcpio; \
        fi
-       if [ -f skipcpio/skipcpio ]; then \
-               install -m 0755 skipcpio/skipcpio $(DESTDIR)$(pkglibdir)/skipcpio; \
+       if [ -f dracut-util ]; then \
+               install -m 0755 dracut-util $(DESTDIR)$(pkglibdir)/dracut-util; \
        fi
+ifeq ($(enable_dracut_cpio),yes)
+       install -m 0755 dracut-cpio $(DESTDIR)$(pkglibdir)/dracut-cpio
+endif
        mkdir -p $(DESTDIR)${prefix}/lib/kernel/install.d
-       install -m 0755 50-dracut.install $(DESTDIR)${prefix}/lib/kernel/install.d/50-dracut.install
-       install -m 0755 51-dracut-rescue.install $(DESTDIR)${prefix}/lib/kernel/install.d/51-dracut-rescue.install
+       install -m 0755 install.d/50-dracut.install $(DESTDIR)${prefix}/lib/kernel/install.d/50-dracut.install
+       install -m 0755 install.d/51-dracut-rescue.install $(DESTDIR)${prefix}/lib/kernel/install.d/51-dracut-rescue.install
        mkdir -p $(DESTDIR)${bashcompletiondir}
-       install -m 0644 dracut-bash-completion.sh $(DESTDIR)${bashcompletiondir}/dracut
-       install -m 0644 lsinitrd-bash-completion.sh $(DESTDIR)${bashcompletiondir}/lsinitrd
+       install -m 0644 shell-completion/bash/dracut $(DESTDIR)${bashcompletiondir}/dracut
+       install -m 0644 shell-completion/bash/lsinitrd $(DESTDIR)${bashcompletiondir}/lsinitrd
        mkdir -p $(DESTDIR)${pkgconfigdatadir}
        install -m 0644 dracut.pc $(DESTDIR)${pkgconfigdatadir}/dracut.pc
 
-dracut-version.sh:
-       @echo "DRACUT_VERSION=$(VERSION)$(GITVERSION)" > dracut-version.sh
-
 clean:
        $(RM) *~
        $(RM) */*~
        $(RM) */*/*~
        $(RM) $(manpages:%=%.xml) dracut.xml
        $(RM) test-*.img
-       $(RM) dracut-*.rpm dracut-*.tar.bz2 dracut-*.tar.xz
-       $(RM) dracut-version.sh
-       $(RM) dracut-install install/dracut-install $(DRACUT_INSTALL_OBJECTS)
+       $(RM) dracut-*.tar.bz2 dracut-*.tar.xz
+       $(RM) dracut-install src/install/dracut-install $(DRACUT_INSTALL_OBJECTS)
        $(RM) skipcpio/skipcpio $(SKIPCPIO_OBJECTS)
+       $(RM) dracut-util util/util $(UTIL_OBJECTS)
        $(RM) $(manpages) dracut.html
+       $(RM) dracut.pc
+       $(RM) dracut-cpio src/dracut-cpio/target/release/dracut-cpio*
        $(MAKE) -C test clean
 
-dist: dracut-$(VERSION).tar.xz
-
-dracut-$(VERSION).tar.xz: doc syncheck
-       @echo "DRACUT_VERSION=$(VERSION)" > dracut-version.sh
-       git archive --format=tar $(VERSION) --prefix=dracut-$(VERSION)/ > dracut-$(VERSION).tar
-       mkdir -p dracut-$(VERSION)
-       for i in $(manpages) dracut.html dracut-version.sh; do [ "$${i%/*}" != "$$i" ] && mkdir -p "dracut-$(VERSION)/$${i%/*}"; cp "$$i" "dracut-$(VERSION)/$$i"; done
-       tar --owner=root --group=root -rf dracut-$(VERSION).tar $$(find dracut-$(VERSION) -type f)
-       rm -fr -- dracut-$(VERSION).tar.xz dracut-$(VERSION)
-       xz -9 dracut-$(VERSION).tar
-       rm -f -- dracut-$(VERSION).tar
-
-rpm: dracut-$(VERSION).tar.xz syncheck
-       rpmbuild=$$(mktemp -d -t rpmbuild-dracut.XXXXXX); src=$$(pwd); \
-       cp dracut-$(VERSION).tar.xz "$$rpmbuild"; \
-       LC_MESSAGES=C $$src/git2spec.pl $(VERSION) "$$rpmbuild" < dracut.spec > $$rpmbuild/dracut.spec; \
-       (cd "$$rpmbuild"; \
-       wget https://www.gnu.org/licenses/lgpl-2.1.txt; \
-       rpmbuild --define "_topdir $$PWD" --define "_sourcedir $$PWD" \
-               --define "_specdir $$PWD" --define "_srcrpmdir $$PWD" \
-               --define "_rpmdir $$PWD" -ba dracut.spec; ) && \
-       ( mv "$$rpmbuild"/$$(arch)/*.rpm .; mv "$$rpmbuild"/*.src.rpm .;rm -fr -- "$$rpmbuild"; ls *.rpm )
+dist: dracut-$(DRACUT_MAIN_VERSION).tar.xz
+
+dracut-$(DRACUT_MAIN_VERSION).tar.xz: doc syncheck
+       git archive --format=tar $(DRACUT_MAIN_VERSION) --prefix=dracut-$(DRACUT_MAIN_VERSION)/ > dracut-$(DRACUT_MAIN_VERSION).tar
+       mkdir -p dracut-$(DRACUT_MAIN_VERSION)
+       for i in $(manpages) dracut.html; do [ "$${i%/*}" != "$$i" ] && mkdir -p "dracut-$(DRACUT_MAIN_VERSION)/$${i%/*}"; cp "$$i" "dracut-$(DRACUT_MAIN_VERSION)/$$i"; done
+       tar --owner=root --group=root -rf dracut-$(DRACUT_MAIN_VERSION).tar $$(find dracut-$(DRACUT_MAIN_VERSION) -type f)
+       rm -fr -- dracut-$(DRACUT_MAIN_VERSION).tar.xz dracut-$(DRACUT_MAIN_VERSION)
+       xz -9 dracut-$(DRACUT_MAIN_VERSION).tar
+       rm -f -- dracut-$(DRACUT_MAIN_VERSION).tar
 
 syncheck:
        @ret=0;for i in dracut-initramfs-restore.sh modules.d/*/*.sh; do \
                 [ "$${i##*/}" = "module-setup.sh" ] && continue; \
                 read line < "$$i"; [ "$${line#*bash*}" != "$$line" ] && continue; \
                [ $$V ] && echo "posix syntax check: $$i"; bash --posix -n "$$i" ; ret=$$(($$ret+$$?)); \
-               [ $$V ] && echo "checking for [[: $$i"; if grep -Fq '[[ ' "$$i" ; then ret=$$(($$ret+1)); echo "$$i contains [["; fi \
+               [ $$V ] && echo "checking for [[: $$i"; if grep -Fq '[[ ' "$$i" ; then ret=$$(($$ret+1)); echo "$$i contains [["; fi; \
+               [ $$V ] && echo "checking for echo -n: $$i"; if grep -Fq 'echo -n ' "$$i" ; then ret=$$(($$ret+1)); echo "$$i contains echo -n"; fi \
        done;exit $$ret
-       @ret=0;for i in *.sh mkinitrd-dracut.sh modules.d/*/*.sh \
-                       modules.d/*/module-setup.sh; do \
+       @ret=0;for i in *.sh modules.d/*/*.sh modules.d/*/module-setup.sh; do \
                [ $$V ] && echo "bash syntax check: $$i"; bash -n "$$i" ; ret=$$(($$ret+$$?)); \
        done;exit $$ret
+ifeq ($(HAVE_SHELLCHECK),yes)
+ifeq ($(HAVE_SHFMT),yes)
+       shellcheck $$(shfmt -f .)
+else
+       find . -name '*.sh' -print0 | xargs -0 shellcheck
+endif
+endif
 
-check: all syncheck rpm
+check: all syncheck
        @[ "$$EUID" == "0" ] || { echo "'check' must be run as root! Please use 'sudo'."; exit 1; }
        @$(MAKE) -C test check
 
 testimage: all
-       ./dracut.sh -N -l -a debug -f test-$(shell uname -r).img $(shell uname -r)
-       @echo wrote  test-$(shell uname -r).img
+       ./dracut.sh -N -l -a debug -f test-$(KVERSION).img $(KVERSION)
+       @echo wrote  test-$(KVERSION).img
 
 debugtestimage: all
-       ./dracut.sh --debug -l -a debug -f test-$(shell uname -r).img $(shell uname -r)
-       @echo wrote  test-$(shell uname -r).img
+       ./dracut.sh --debug -l -a debug -f test-$(KVERSION).img $(KVERSION)
+       @echo wrote  test-$(KVERSION).img
 
 testimages: all
-       ./dracut.sh -l -a debug --kernel-only -f test-kernel-$(shell uname -r).img $(shell uname -r)
-       @echo wrote  test-$(shell uname -r).img
-       ./dracut.sh -l -a debug --no-kernel -f test-dracut.img $(shell uname -r)
+       ./dracut.sh -l -a debug --kernel-only -f test-kernel-$(KVERSION).img $(KVERSION)
+       @echo wrote  test-$(KVERSION).img
+       ./dracut.sh -l -a debug --no-kernel -f test-dracut.img $(KVERSION)
        @echo wrote  test-dracut.img
 
 debughostimage: all
-       ./dracut.sh --debug -H -l -f test-$(shell uname -r).img $(shell uname -r)
-       @echo wrote  test-$(shell uname -r).img
+       ./dracut.sh --debug -H -l -f test-$(KVERSION).img $(KVERSION)
+       @echo wrote  test-$(KVERSION).img
 
 hostimage: all
-       ./dracut.sh -H -l -f test-$(shell uname -r).img $(shell uname -r)
-       @echo wrote  test-$(shell uname -r).img
+       ./dracut.sh -H -l -f test-$(KVERSION).img $(KVERSION)
+       @echo wrote  test-$(KVERSION).img
 
-AUTHORS:
-       git shortlog  --numbered --summary -e |while read a rest || [ -n "$$rest" ]; do echo $$rest;done > AUTHORS
+efi: all
+       ./dracut.sh --uefi -H -l -f linux-$(KVERSION).efi $(KVERSION)
+       @echo wrote linux-$(KVERSION).efi
 
-dracut.html.sign: dracut-$(VERSION).tar.xz dracut.html
-       gpg-sign-all dracut-$(VERSION).tar.xz dracut.html
+AUTHORS:
+       @git log | git shortlog --numbered --summary -e | while read -r a rest || [ -n "$$rest" ]; do echo "$$rest"; done > AUTHORS
 
-upload: dracut.html.sign
-       kup put dracut-$(VERSION).tar.xz dracut-$(VERSION).tar.sign /pub/linux/utils/boot/dracut/
-       kup put dracut.html dracut.html.sign /pub/linux/utils/boot/dracut/
+CONTRIBUTORS:
+       @git log | git shortlog $(DRACUT_MAIN_VERSION).. --numbered --summary -e | while read -r a rest || [ -n "$$rest" ]; do echo "- $$rest"; done