X-Git-Url: http://git.ipfire.org/?a=blobdiff_plain;f=Makefile;h=503d069fb51ab9016b35063ad5ad6e157b73b6f3;hb=42e004feb9ce333d3b1b624bea7d2389da2c87a6;hp=fa62cfc92bad37df46096907532158182a0a38b8;hpb=cbd69dc6ff323f269493489bc061ae0400cb63be;p=thirdparty%2Fdracut.git diff --git a/Makefile b/Makefile index fa62cfc92..503d069fb 100644 --- a/Makefile +++ b/Makefile @@ -1,5 +1,7 @@ -VERSION=026 -GITVERSION=$(shell [ -d .git ] && git rev-list --abbrev-commit -n 1 HEAD |cut -b 1-8) +-include dracut-version.sh + +VERSION ?= $(shell [ -d .git ] && git describe --abbrev=0 --tags --always 2>/dev/null || echo $(DRACUT_VERSION)) +GITVERSION ?= $(shell [ -d .git ] && { v=$$(git describe --tags --always 2>/dev/null); [ -n "$$v" ] && [ $${v\#*-} != $$v ] && echo -$${v\#*-}; } ) -include Makefile.inc @@ -11,38 +13,42 @@ sysconfdir ?= ${prefix}/etc bindir ?= ${prefix}/bin mandir ?= ${prefix}/share/man CFLAGS ?= -O2 -g -Wall -CFLAGS += -std=gnu99 -D_FILE_OFFSET_BITS=64 +CFLAGS += -std=gnu99 -D_FILE_OFFSET_BITS=64 -Wformat -Werror=format-security -Wp,-D_FORTIFY_SOURCE=2 $(KMOD_CFLAGS) bashcompletiondir ?= ${datadir}/bash-completion/completions +pkgconfigdatadir ?= $(datadir)/pkgconfig man1pages = lsinitrd.1 man5pages = dracut.conf.5 man7pages = dracut.cmdline.7 \ - dracut.bootup.7 + dracut.bootup.7 \ + dracut.modules.7 man8pages = dracut.8 \ dracut-catimages.8 \ mkinitrd.8 \ - modules.d/98systemd/dracut-cmdline.service.8 \ - modules.d/98systemd/dracut-initqueue.service.8 \ - modules.d/98systemd/dracut-mount.service.8 \ - modules.d/98systemd/dracut-pre-mount.service.8 \ - modules.d/98systemd/dracut-pre-pivot.service.8 \ - modules.d/98systemd/dracut-pre-trigger.service.8 \ - modules.d/98systemd/dracut-pre-udev.service.8 + mkinitrd-suse.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 \ + modules.d/98dracut-systemd/dracut-shutdown.service.8 \ + modules.d/98dracut-systemd/dracut-pre-mount.service.8 \ + modules.d/98dracut-systemd/dracut-pre-pivot.service.8 \ + modules.d/98dracut-systemd/dracut-pre-trigger.service.8 \ + modules.d/98dracut-systemd/dracut-pre-udev.service.8 manpages = $(man1pages) $(man5pages) $(man7pages) $(man8pages) +.PHONY: install clean archive rpm srpm testimage test all check AUTHORS doc dracut-version.sh -.PHONY: install clean archive rpm testimage test all check AUTHORS doc - -all: syncheck dracut-version.sh dracut-install +all: dracut-version.sh dracut.pc dracut-install skipcpio/skipcpio DRACUT_INSTALL_OBJECTS = \ install/dracut-install.o \ install/hashmap.o\ install/log.o \ + install/strv.o \ install/util.o # deps generated with gcc -MM @@ -52,14 +58,26 @@ install/hashmap.o: install/hashmap.c install/util.h install/macro.h install/log. 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 install/dracut-install: $(DRACUT_INSTALL_OBJECTS) + $(CC) $(LDFLAGS) -o $@ $(DRACUT_INSTALL_OBJECTS) $(LDLIBS) $(KMOD_LIBS) + +logtee: logtee.c + $(CC) $(LDFLAGS) -o $@ $< dracut-install: install/dracut-install ln -fs $< $@ +SKIPCPIO_OBJECTS= \ + skipcpio/skipcpio.o + +skipcpio/skipcpio.o: skipcpio/skipcpio.c +skipcpio/skipcpio: skipcpio/skipcpio.o + indent: indent -i8 -nut -br -linux -l120 install/dracut-install.c + indent -i8 -nut -br -linux -l120 skipcpio/skipcpio.c doc: $(manpages) dracut.html @@ -68,20 +86,34 @@ 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 $@ $< + @rm -f -- "$@" + asciidoc -d manpage -b docbook -o "$@" $< -dracut.html: dracut.asc $(manpages) +dracut.8: dracut.usage.asc dracut.8.asc + +dracut.html: dracut.asc $(manpages) dracut.css dracut.usage.asc + @rm -f -- dracut.xml asciidoc -a numbered -d book -b docbook -o dracut.xml dracut.asc + @rm -f -- dracut.html xsltproc -o dracut.html --xinclude -nonet \ - --stringparam html.stylesheet \ - http://docs.fedoraproject.org/en-US/Common_Content/css/default.css \ + --stringparam custom.css.source dracut.css \ + --stringparam generate.css.header 1 \ http://docbook.sourceforge.net/release/xsl/current/xhtml/docbook.xsl dracut.xml - rm 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 "dracutdir=$(pkglibdir)" >> dracut.pc + @echo "dracutmodulesdir=$(pkglibdir)/modules.d" >> dracut.pc + @echo "dracutconfdir=$(pkglibdir)/dracut.conf.d" >> dracut.pc -install: dracut-version.sh +install: all mkdir -p $(DESTDIR)$(pkglibdir) mkdir -p $(DESTDIR)$(bindir) mkdir -p $(DESTDIR)$(sysconfdir) @@ -94,6 +126,7 @@ install: dracut-version.sh install -m 0644 dracut.conf $(DESTDIR)$(sysconfdir)/dracut.conf mkdir -p $(DESTDIR)$(sysconfdir)/dracut.conf.d mkdir -p $(DESTDIR)$(pkglibdir)/dracut.conf.d + install -m 0755 dracut-init.sh $(DESTDIR)$(pkglibdir)/dracut-init.sh install -m 0755 dracut-functions.sh $(DESTDIR)$(pkglibdir)/dracut-functions.sh install -m 0755 dracut-version.sh $(DESTDIR)$(pkglibdir)/dracut-version.sh ln -fs dracut-functions.sh $(DESTDIR)$(pkglibdir)/dracut-functions @@ -109,10 +142,10 @@ ifneq ($(enable_documentation),no) endif if [ -n "$(systemdsystemunitdir)" ]; then \ mkdir -p $(DESTDIR)$(systemdsystemunitdir); \ - install -m 0644 dracut-shutdown.service $(DESTDIR)$(systemdsystemunitdir); \ - mkdir -p $(DESTDIR)$(systemdsystemunitdir)/shutdown.target.wants; \ + 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 \ - $(DESTDIR)$(systemdsystemunitdir)/shutdown.target.wants/dracut-shutdown.service; \ + $(DESTDIR)$(systemdsystemunitdir)/sysinit.target.wants/dracut-shutdown.service; \ mkdir -p $(DESTDIR)$(systemdsystemunitdir)/initrd.target.wants; \ for i in \ dracut-cmdline.service \ @@ -123,22 +156,29 @@ endif dracut-pre-trigger.service \ dracut-pre-udev.service \ ; do \ - install -m 0644 modules.d/98systemd/$$i $(DESTDIR)$(systemdsystemunitdir); \ + ln -srf $(DESTDIR)$(pkglibdir)/modules.d/98dracut-systemd/$$i $(DESTDIR)$(systemdsystemunitdir); \ ln -s ../$$i \ - $(DESTDIR)$(systemdsystemunitdir)/initrd.target.wants/$i; \ + $(DESTDIR)$(systemdsystemunitdir)/initrd.target.wants/$$i; \ done \ fi if [ -f install/dracut-install ]; then \ install -m 0755 install/dracut-install $(DESTDIR)$(pkglibdir)/dracut-install; \ fi + if [ -f skipcpio/skipcpio ]; then \ + install -m 0755 skipcpio/skipcpio $(DESTDIR)$(pkglibdir)/skipcpio; \ + fi 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 mkdir -p $(DESTDIR)${bashcompletiondir} install -m 0644 dracut-bash-completion.sh $(DESTDIR)${bashcompletiondir}/dracut + install -m 0644 lsinitrd-bash-completion.sh $(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 + @rm -f dracut-version.sh + @echo "DRACUT_VERSION=$(VERSION)$(GITVERSION)" > dracut-version.sh clean: $(RM) *~ @@ -146,51 +186,70 @@ clean: $(RM) */*/*~ $(RM) $(manpages:%=%.xml) dracut.xml $(RM) test-*.img - $(RM) dracut-*.rpm dracut-*.tar.bz2 + $(RM) dracut-*.rpm dracut-*.tar.bz2 dracut-*.tar.xz + $(RM) dracut-version.sh $(RM) dracut-install install/dracut-install $(DRACUT_INSTALL_OBJECTS) + $(RM) skipcpio/skipcpio $(SKIPCPIO_OBJECTS) $(RM) $(manpages) dracut.html $(MAKE) -C test clean -archive: dracut-$(VERSION)-$(GITVERSION).tar.bz2 - -dist: dracut-$(VERSION).tar.bz2 +dist: dracut-$(VERSION).tar.xz -dracut-$(VERSION).tar.bz2: doc +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) - cp $(manpages) dracut.html dracut-$(VERSION) - tar -rf dracut-$(VERSION).tar dracut-$(VERSION)/*.[0-9] dracut-$(VERSION)/dracut.html - rm -fr dracut-$(VERSION).tar.bz2 dracut-$(VERSION) - bzip2 -9 dracut-$(VERSION).tar - rm -f dracut-$(VERSION).tar + 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.bz2 +rpm: dracut-$(VERSION).tar.xz syncheck rpmbuild=$$(mktemp -d -t rpmbuild-dracut.XXXXXX); src=$$(pwd); \ - cp dracut-$(VERSION).tar.bz2 "$$rpmbuild"; \ + cp dracut-$(VERSION).tar.xz "$$rpmbuild"; \ LC_MESSAGES=C $$src/git2spec.pl $(VERSION) "$$rpmbuild" < dracut.spec > $$rpmbuild/dracut.spec; \ - (cd "$$rpmbuild"; rpmbuild --define "_topdir $$PWD" --define "_sourcedir $$PWD" \ + (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 ) + ( mv "$$rpmbuild"/{,$$(arch)/}*.rpm $(DESTDIR).; rm -fr -- "$$rpmbuild"; ls $(DESTDIR)*.rpm ) + +srpm: 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"; \ + [ -f $$src/lgpl-2.1.txt ] && cp $$src/lgpl-2.1.txt . || 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" -bs dracut.spec; ) && \ + ( mv "$$rpmbuild"/*.src.rpm $(DESTDIR).; rm -fr -- "$$rpmbuild"; ls $(DESTDIR)*.rpm ) syncheck: - @ret=0;for i in dracut-initramfs-restore.sh dracut-logger.sh \ - modules.d/99base/init.sh modules.d/*/*.sh; do \ + @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; \ - dash -n "$$i" ; ret=$$(($$ret+$$?)); \ + [ $$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 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 \ - bash -n "$$i" ; ret=$$(($$ret+$$?)); \ + [ $$V ] && echo "bash syntax check: $$i"; bash -n "$$i" ; ret=$$(($$ret+$$?)); \ done;exit $$ret -check: all syncheck +check: all syncheck rpm @[ "$$EUID" == "0" ] || { echo "'check' must be run as root! Please use 'sudo'."; exit 1; } @$(MAKE) -C test check testimage: all - ./dracut.sh -l -a debug -f test-$(shell uname -r).img $(shell uname -r) + ./dracut.sh -N -l -a debug -f test-$(shell uname -r).img $(shell uname -r) + @echo wrote test-$(shell uname -r).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 testimages: all @@ -199,16 +258,24 @@ testimages: all ./dracut.sh -l -a debug --no-kernel -f test-dracut.img $(shell uname -r) @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 + hostimage: all - ./dracut.sh -H -l -a debug -f test-$(shell uname -r).img $(shell uname -r) + ./dracut.sh -H -l -f test-$(shell uname -r).img $(shell uname -r) @echo wrote test-$(shell uname -r).img +efi: all + ./dracut.sh --uefi -H -l -f linux-$(shell uname -r).efi $(shell uname -r) + @echo wrote linux-$(shell uname -r).efi + AUTHORS: - git shortlog --numbered --summary -e |while read a rest; do echo $$rest;done > AUTHORS + git shortlog --numbered --summary -e |while read a rest || [ -n "$$rest" ]; do echo $$rest;done > AUTHORS -dracut.html.sign: dracut-$(VERSION).tar.bz2 - gpg-sign-all dracut-$(VERSION).tar.bz2 dracut.html +dracut.html.sign: dracut-$(VERSION).tar.xz dracut.html + gpg-sign-all dracut-$(VERSION).tar.xz dracut.html upload: dracut.html.sign - kup put dracut-$(VERSION).tar.bz2 dracut-$(VERSION).tar.sign /pub/linux/utils/boot/dracut/ + 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/