xref: /linux/scripts/Makefile.package (revision aa7d233f45b4c549750044c9921f7afcbe50925b)
1000ec95fSMasahiro Yamada# SPDX-License-Identifier: GPL-2.0-only
2000ec95fSMasahiro Yamada# Makefile for the different targets used to generate full packages of a kernel
3000ec95fSMasahiro Yamada
4000ec95fSMasahiro Yamadainclude $(srctree)/scripts/Kbuild.include
505e96e96SMasahiro Yamadainclude $(srctree)/scripts/Makefile.lib
6000ec95fSMasahiro Yamada
7000ec95fSMasahiro YamadaKERNELPATH := kernel-$(subst -,_,$(KERNELRELEASE))
8000ec95fSMasahiro YamadaKBUILD_PKG_ROOTCMD ?="fakeroot -u"
9000ec95fSMasahiro Yamada# Include only those top-level files that are needed by make, plus the GPL copy
10a3c4d4abSMasahiro YamadaTAR_CONTENT := Documentation LICENSES arch block certs crypto drivers fs \
11df1f1ea9SParan Lee               include init io_uring ipc kernel lib mm net rust \
12df1f1ea9SParan Lee               samples scripts security sound tools usr virt \
13f6e09b07SMasahiro Yamada               .config Makefile \
14000ec95fSMasahiro Yamada               Kbuild Kconfig COPYING $(wildcard localversion*)
15000ec95fSMasahiro YamadaMKSPEC     := $(srctree)/scripts/package/mkspec
16000ec95fSMasahiro Yamada
17000ec95fSMasahiro Yamadaquiet_cmd_src_tar = TAR     $(2).tar.gz
18000ec95fSMasahiro Yamada      cmd_src_tar = \
19000ec95fSMasahiro Yamadaif test "$(objtree)" != "$(srctree)"; then \
20000ec95fSMasahiro Yamada	echo >&2; \
21000ec95fSMasahiro Yamada	echo >&2 "  ERROR:"; \
22000ec95fSMasahiro Yamada	echo >&2 "  Building source tarball is not possible outside the"; \
236fc91752SMasahiro Yamada	echo >&2 "  kernel source tree. Don't set KBUILD_OUTPUT"; \
24000ec95fSMasahiro Yamada	echo >&2; \
25000ec95fSMasahiro Yamada	false; \
26000ec95fSMasahiro Yamadafi ; \
27e4a42c82SDenis Efremovtar -I $(KGZIP) -c $(RCS_TAR_IGNORE) -f $(2).tar.gz \
28f6e09b07SMasahiro Yamada	--transform 's:^:$(2)/:S' $(TAR_CONTENT) $(3)
29000ec95fSMasahiro Yamada
3005e96e96SMasahiro Yamada# tarball compression
317bf4582dSMasahiro Yamada# ---------------------------------------------------------------------------
327bf4582dSMasahiro Yamada
3305e96e96SMasahiro Yamada%.tar.gz: %.tar
3405e96e96SMasahiro Yamada	$(call cmd,gzip)
357bf4582dSMasahiro Yamada
3605e96e96SMasahiro Yamada%.tar.bz2: %.tar
3705e96e96SMasahiro Yamada	$(call cmd,bzip2)
387bf4582dSMasahiro Yamada
3905e96e96SMasahiro Yamada%.tar.xz: %.tar
4005e96e96SMasahiro Yamada	$(call cmd,xzmisc)
417bf4582dSMasahiro Yamada
4205e96e96SMasahiro Yamada%.tar.zst: %.tar
4305e96e96SMasahiro Yamada	$(call cmd,zstd)
4405e96e96SMasahiro Yamada
4505e96e96SMasahiro Yamada# Git
467bf4582dSMasahiro Yamada# ---------------------------------------------------------------------------
477bf4582dSMasahiro Yamada
4805e96e96SMasahiro Yamadafilechk_HEAD = git -C $(srctree) rev-parse --verify HEAD 2>/dev/null
497bf4582dSMasahiro Yamada
5005e96e96SMasahiro Yamada.tmp_HEAD: check-git FORCE
5105e96e96SMasahiro Yamada	$(call filechk,HEAD)
527bf4582dSMasahiro Yamada
5305e96e96SMasahiro YamadaPHONY += check-git
5405e96e96SMasahiro Yamadacheck-git:
5505e96e96SMasahiro Yamada	@if ! $(srctree)/scripts/check-git; then \
5605e96e96SMasahiro Yamada		echo >&2 "error: creating source package requires git repository"; \
5705e96e96SMasahiro Yamada		false; \
5805e96e96SMasahiro Yamada	fi
59e0ca1674SMasahiro Yamada
607bf4582dSMasahiro Yamada# Linux source tarball
617bf4582dSMasahiro Yamada# ---------------------------------------------------------------------------
627bf4582dSMasahiro Yamada
6305e96e96SMasahiro Yamadaquiet_cmd_archive_linux = ARCHIVE $@
6405e96e96SMasahiro Yamada      cmd_archive_linux = \
6505e96e96SMasahiro Yamada	git -C $(srctree) archive --output=$$(realpath $@) --prefix=$(basename $@)/ $$(cat $<)
6605e96e96SMasahiro Yamada
6705e96e96SMasahiro Yamadatargets += linux.tar
6805e96e96SMasahiro Yamadalinux.tar: .tmp_HEAD FORCE
6905e96e96SMasahiro Yamada	$(call if_changed,archive_linux)
707bf4582dSMasahiro Yamada
71000ec95fSMasahiro Yamada# rpm-pkg
72000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
73000ec95fSMasahiro YamadaPHONY += rpm-pkg
741ec9bb70SMasahiro Yamadarpm-pkg: srpm = $(shell rpmspec --srpm --query --queryformat='%{name}-%{VERSION}-%{RELEASE}.src.rpm' kernel.spec)
751ec9bb70SMasahiro Yamadarpm-pkg: srcrpm-pkg
761ec9bb70SMasahiro Yamada	+rpmbuild $(RPMOPTS) --target $(UTS_MACHINE)-linux -rb $(srpm) \
77000ec95fSMasahiro Yamada	--define='_smp_mflags %{nil}'
78000ec95fSMasahiro Yamada
798818039fSIvan Vecera# srcrpm-pkg
808818039fSIvan Vecera# ---------------------------------------------------------------------------
818818039fSIvan VeceraPHONY += srcrpm-pkg
826fc91752SMasahiro Yamadasrcrpm-pkg: linux.tar.gz
838818039fSIvan Vecera	$(CONFIG_SHELL) $(MKSPEC) >$(objtree)/kernel.spec
846fc91752SMasahiro Yamada	+rpmbuild $(RPMOPTS) --target $(UTS_MACHINE)-linux -bs kernel.spec \
8581f59a26SMasahiro Yamada	--define='_smp_mflags %{nil}' --define='_sourcedir rpmbuild/SOURCES' --define='_srcrpmdir .'
868818039fSIvan Vecera
87000ec95fSMasahiro Yamada# binrpm-pkg
88000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
89000ec95fSMasahiro YamadaPHONY += binrpm-pkg
90000ec95fSMasahiro Yamadabinrpm-pkg:
91000ec95fSMasahiro Yamada	$(MAKE) -f $(srctree)/Makefile
92000ec95fSMasahiro Yamada	$(CONFIG_SHELL) $(MKSPEC) prebuilt > $(objtree)/binkernel.spec
93000ec95fSMasahiro Yamada	+rpmbuild $(RPMOPTS) --define "_builddir $(objtree)" --target \
946105e4f6SMasahiro Yamada		$(UTS_MACHINE)-linux -bb $(objtree)/binkernel.spec
95000ec95fSMasahiro Yamada
966eabebb1SMasahiro Yamadaquiet_cmd_debianize = GEN     $@
97*aa7d233fSMasahiro Yamada      cmd_debianize = $(srctree)/scripts/package/mkdebian $(mkdebian-opts)
986eabebb1SMasahiro Yamada
996eabebb1SMasahiro Yamadadebian: FORCE
1006eabebb1SMasahiro Yamada	$(call cmd,debianize)
1016eabebb1SMasahiro Yamada
1026eabebb1SMasahiro YamadaPHONY += debian-orig
1036eabebb1SMasahiro Yamadadebian-orig: private source = $(shell dpkg-parsechangelog -S Source)
1046eabebb1SMasahiro Yamadadebian-orig: private version = $(shell dpkg-parsechangelog -S Version | sed 's/-[^-]*$$//')
1056eabebb1SMasahiro Yamadadebian-orig: private orig-name = $(source)_$(version).orig.tar.gz
106*aa7d233fSMasahiro Yamadadebian-orig: mkdebian-opts = --need-source
1076eabebb1SMasahiro Yamadadebian-orig: linux.tar.gz debian
108b44aa8c9SMasahiro Yamada	$(Q)if [ "$(df  --output=target .. 2>/dev/null)" = "$(df --output=target $< 2>/dev/null)" ]; then \
109b44aa8c9SMasahiro Yamada		ln -f $< ../$(orig-name); \
110b44aa8c9SMasahiro Yamada	else \
111b44aa8c9SMasahiro Yamada		cp $< ../$(orig-name); \
112b44aa8c9SMasahiro Yamada	fi
1136eabebb1SMasahiro Yamada
114000ec95fSMasahiro YamadaPHONY += deb-pkg
1156eabebb1SMasahiro Yamadadeb-pkg: debian-orig
1167bf4582dSMasahiro Yamada	+dpkg-buildpackage -r$(KBUILD_PKG_ROOTCMD) -a$$(cat debian/arch) $(DPKG_FLAGS) \
117e7853995SMasahiro Yamada		--build=source,binary -nc -us -uc
118000ec95fSMasahiro Yamada
119000ec95fSMasahiro YamadaPHONY += bindeb-pkg
1206eabebb1SMasahiro Yamadabindeb-pkg: debian
121000ec95fSMasahiro Yamada	+dpkg-buildpackage -r$(KBUILD_PKG_ROOTCMD) -a$$(cat debian/arch) $(DPKG_FLAGS) -b -nc -uc
122000ec95fSMasahiro Yamada
123000ec95fSMasahiro YamadaPHONY += intdeb-pkg
124000ec95fSMasahiro Yamadaintdeb-pkg:
125000ec95fSMasahiro Yamada	+$(CONFIG_SHELL) $(srctree)/scripts/package/builddeb
126000ec95fSMasahiro Yamada
127000ec95fSMasahiro Yamada# snap-pkg
128000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
129000ec95fSMasahiro YamadaPHONY += snap-pkg
130000ec95fSMasahiro Yamadasnap-pkg:
131000ec95fSMasahiro Yamada	rm -rf $(objtree)/snap
132000ec95fSMasahiro Yamada	mkdir $(objtree)/snap
133000ec95fSMasahiro Yamada	$(MAKE) clean
134000ec95fSMasahiro Yamada	$(call cmd,src_tar,$(KERNELPATH))
135000ec95fSMasahiro Yamada	sed "s@KERNELRELEASE@$(KERNELRELEASE)@; \
136000ec95fSMasahiro Yamada		s@SRCTREE@$(shell realpath $(KERNELPATH).tar.gz)@" \
137000ec95fSMasahiro Yamada		$(srctree)/scripts/package/snapcraft.template > \
138000ec95fSMasahiro Yamada		$(objtree)/snap/snapcraft.yaml
139000ec95fSMasahiro Yamada	cd $(objtree)/snap && \
140000ec95fSMasahiro Yamada	snapcraft --target-arch=$(UTS_MACHINE)
141000ec95fSMasahiro Yamada
1421fc90958SMasahiro Yamada# dir-pkg tar*-pkg - tarball targets
143000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
1441fc90958SMasahiro Yamada
1451fc90958SMasahiro Yamadatar-install: FORCE
1461fc90958SMasahiro Yamada	$(Q)$(MAKE) -f $(srctree)/Makefile
1471fc90958SMasahiro Yamada	+$(Q)$(srctree)/scripts/package/buildtar $@
1481fc90958SMasahiro Yamada
14905e96e96SMasahiro Yamadaquiet_cmd_tar = TAR     $@
15005e96e96SMasahiro Yamada      cmd_tar = cd $<; tar cf ../$@ --owner=root --group=root --sort=name *
15105e96e96SMasahiro Yamada
15205e96e96SMasahiro Yamadalinux-$(KERNELRELEASE)-$(ARCH).tar: tar-install
15305e96e96SMasahiro Yamada	$(call cmd,tar)
15405e96e96SMasahiro Yamada
1551fc90958SMasahiro YamadaPHONY += dir-pkg
1561fc90958SMasahiro Yamadadir-pkg: tar-install
1571fc90958SMasahiro Yamada	@echo "Kernel tree successfully created in $<"
1581fc90958SMasahiro Yamada
15905e96e96SMasahiro YamadaPHONY += tar-pkg
16005e96e96SMasahiro Yamadatar-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar
1611fc90958SMasahiro Yamada	@:
1621fc90958SMasahiro Yamada
16305e96e96SMasahiro Yamadatar%-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar.% FORCE
16405e96e96SMasahiro Yamada	@:
165000ec95fSMasahiro Yamada
166e0ca1674SMasahiro Yamada# perf-tar*-src-pkg - generate a source tarball with perf source
167000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
168000ec95fSMasahiro Yamada
16905e96e96SMasahiro Yamada.tmp_perf:
17005e96e96SMasahiro Yamada	$(Q)mkdir .tmp_perf
171000ec95fSMasahiro Yamada
17205e96e96SMasahiro Yamada.tmp_perf/HEAD: .tmp_HEAD | .tmp_perf
17305e96e96SMasahiro Yamada	$(call cmd,copy)
174e0ca1674SMasahiro Yamada
175e0ca1674SMasahiro Yamadaquiet_cmd_perf_version_file = GEN     $@
176e0ca1674SMasahiro Yamada      cmd_perf_version_file = cd $(srctree)/tools/perf; util/PERF-VERSION-GEN $(dir $(abspath $@))
177e0ca1674SMasahiro Yamada
17805e96e96SMasahiro Yamada# PERF-VERSION-FILE and .tmp_HEAD are independent, but this avoids updating the
179e0ca1674SMasahiro Yamada# timestamp of PERF-VERSION-FILE.
180e0ca1674SMasahiro Yamada# The best is to fix tools/perf/util/PERF-VERSION-GEN.
18105e96e96SMasahiro Yamada.tmp_perf/PERF-VERSION-FILE: .tmp_HEAD $(srctree)/tools/perf/util/PERF-VERSION-GEN | .tmp_perf
182e0ca1674SMasahiro Yamada	$(call cmd,perf_version_file)
183e0ca1674SMasahiro Yamada
18405e96e96SMasahiro Yamadaquiet_cmd_archive_perf = ARCHIVE $@
18505e96e96SMasahiro Yamada      cmd_archive_perf = \
18605e96e96SMasahiro Yamada	git -C $(srctree) archive --output=$$(realpath $@) --prefix=$(basename $@)/ \
18705e96e96SMasahiro Yamada	--add-file=$$(realpath $(word 2, $^)) \
18805e96e96SMasahiro Yamada	--add-file=$$(realpath $(word 3, $^)) \
18905e96e96SMasahiro Yamada	$$(cat $(word 2, $^))^{tree} $$(cat $<)
19005e96e96SMasahiro Yamada
19105e96e96SMasahiro Yamadatargets += perf-$(KERNELVERSION).tar
19205e96e96SMasahiro Yamadaperf-$(KERNELVERSION).tar: tools/perf/MANIFEST .tmp_perf/HEAD .tmp_perf/PERF-VERSION-FILE FORCE
19305e96e96SMasahiro Yamada	$(call if_changed,archive_perf)
19405e96e96SMasahiro Yamada
19505e96e96SMasahiro YamadaPHONY += perf-tar-src-pkg
19605e96e96SMasahiro Yamadaperf-tar-src-pkg: perf-$(KERNELVERSION).tar
197e0ca1674SMasahiro Yamada	@:
198e0ca1674SMasahiro Yamada
19905e96e96SMasahiro Yamadaperf-tar%-src-pkg: perf-$(KERNELVERSION).tar.% FORCE
20005e96e96SMasahiro Yamada	@:
201000ec95fSMasahiro Yamada
202000ec95fSMasahiro Yamada# Help text displayed when executing 'make help'
203000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
204000ec95fSMasahiro YamadaPHONY += help
205000ec95fSMasahiro Yamadahelp:
206000ec95fSMasahiro Yamada	@echo '  rpm-pkg             - Build both source and binary RPM kernel packages'
2079c9b55a5SJun ASAKA	@echo '  srcrpm-pkg          - Build only the source kernel RPM package'
208000ec95fSMasahiro Yamada	@echo '  binrpm-pkg          - Build only the binary kernel RPM package'
209000ec95fSMasahiro Yamada	@echo '  deb-pkg             - Build both source and binary deb kernel packages'
210000ec95fSMasahiro Yamada	@echo '  bindeb-pkg          - Build only the binary kernel deb package'
211a64c0440SGeert Uytterhoeven	@echo '  snap-pkg            - Build only the binary kernel snap package'
212a64c0440SGeert Uytterhoeven	@echo '                        (will connect to external hosts)'
213af7db99aSMatteo Croce	@echo '  dir-pkg             - Build the kernel as a plain directory structure'
214000ec95fSMasahiro Yamada	@echo '  tar-pkg             - Build the kernel as an uncompressed tarball'
215000ec95fSMasahiro Yamada	@echo '  targz-pkg           - Build the kernel as a gzip compressed tarball'
216000ec95fSMasahiro Yamada	@echo '  tarbz2-pkg          - Build the kernel as a bzip2 compressed tarball'
217000ec95fSMasahiro Yamada	@echo '  tarxz-pkg           - Build the kernel as a xz compressed tarball'
21888f5e1e6SPaweł Jasiak	@echo '  tarzst-pkg          - Build the kernel as a zstd compressed tarball'
219e0ca1674SMasahiro Yamada	@echo '  perf-tar-src-pkg    - Build the perf source tarball with no compression'
220e0ca1674SMasahiro Yamada	@echo '  perf-targz-src-pkg  - Build the perf source tarball with gzip compression'
221e0ca1674SMasahiro Yamada	@echo '  perf-tarbz2-src-pkg - Build the perf source tarball with bz2 compression'
222e0ca1674SMasahiro Yamada	@echo '  perf-tarxz-src-pkg  - Build the perf source tarball with xz compression'
223e0ca1674SMasahiro Yamada	@echo '  perf-tarzst-src-pkg - Build the perf source tarball with zst compression'
224000ec95fSMasahiro Yamada
2257bf4582dSMasahiro YamadaPHONY += FORCE
2267bf4582dSMasahiro YamadaFORCE:
2277bf4582dSMasahiro Yamada
22805e96e96SMasahiro Yamada# Read all saved command lines and dependencies for the $(targets) we
22905e96e96SMasahiro Yamada# may be building above, using $(if_changed{,_dep}). As an
23005e96e96SMasahiro Yamada# optimization, we don't need to read them if the target does not
23105e96e96SMasahiro Yamada# exist, we will rebuild anyway in that case.
23205e96e96SMasahiro Yamada
23305e96e96SMasahiro Yamadaexisting-targets := $(wildcard $(sort $(targets)))
23405e96e96SMasahiro Yamada
23505e96e96SMasahiro Yamada-include $(foreach f,$(existing-targets),$(dir $(f)).$(notdir $(f)).cmd)
23605e96e96SMasahiro Yamada
237000ec95fSMasahiro Yamada.PHONY: $(PHONY)
238