xref: /linux/scripts/Makefile.package (revision f6d8283549bc200e2babdd627239ece3547d634c)
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
60*f6d82835SMasahiro Yamadaquiet_cmd_archive = ARCHIVE $@
61*f6d82835SMasahiro Yamada      cmd_archive = git -C $(srctree) archive \
62*f6d82835SMasahiro Yamada                    --output=$$(realpath $@) --prefix=$(basename $@)/ $(archive-args)
63*f6d82835SMasahiro Yamada
647bf4582dSMasahiro Yamada# Linux source tarball
657bf4582dSMasahiro Yamada# ---------------------------------------------------------------------------
667bf4582dSMasahiro Yamada
6705e96e96SMasahiro Yamadatargets += linux.tar
68*f6d82835SMasahiro Yamadalinux.tar: archive-args = $$(cat $<)
6905e96e96SMasahiro Yamadalinux.tar: .tmp_HEAD FORCE
70*f6d82835SMasahiro Yamada	$(call if_changed,archive)
717bf4582dSMasahiro Yamada
72000ec95fSMasahiro Yamada# rpm-pkg
73000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
74000ec95fSMasahiro YamadaPHONY += rpm-pkg
751ec9bb70SMasahiro Yamadarpm-pkg: srpm = $(shell rpmspec --srpm --query --queryformat='%{name}-%{VERSION}-%{RELEASE}.src.rpm' kernel.spec)
761ec9bb70SMasahiro Yamadarpm-pkg: srcrpm-pkg
771ec9bb70SMasahiro Yamada	+rpmbuild $(RPMOPTS) --target $(UTS_MACHINE)-linux -rb $(srpm) \
78000ec95fSMasahiro Yamada	--define='_smp_mflags %{nil}'
79000ec95fSMasahiro Yamada
808818039fSIvan Vecera# srcrpm-pkg
818818039fSIvan Vecera# ---------------------------------------------------------------------------
828818039fSIvan VeceraPHONY += srcrpm-pkg
836fc91752SMasahiro Yamadasrcrpm-pkg: linux.tar.gz
848818039fSIvan Vecera	$(CONFIG_SHELL) $(MKSPEC) >$(objtree)/kernel.spec
856fc91752SMasahiro Yamada	+rpmbuild $(RPMOPTS) --target $(UTS_MACHINE)-linux -bs kernel.spec \
8681f59a26SMasahiro Yamada	--define='_smp_mflags %{nil}' --define='_sourcedir rpmbuild/SOURCES' --define='_srcrpmdir .'
878818039fSIvan Vecera
88000ec95fSMasahiro Yamada# binrpm-pkg
89000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
90000ec95fSMasahiro YamadaPHONY += binrpm-pkg
91000ec95fSMasahiro Yamadabinrpm-pkg:
92000ec95fSMasahiro Yamada	$(MAKE) -f $(srctree)/Makefile
93000ec95fSMasahiro Yamada	$(CONFIG_SHELL) $(MKSPEC) prebuilt > $(objtree)/binkernel.spec
94000ec95fSMasahiro Yamada	+rpmbuild $(RPMOPTS) --define "_builddir $(objtree)" --target \
956105e4f6SMasahiro Yamada		$(UTS_MACHINE)-linux -bb $(objtree)/binkernel.spec
96000ec95fSMasahiro Yamada
976eabebb1SMasahiro Yamadaquiet_cmd_debianize = GEN     $@
98aa7d233fSMasahiro Yamada      cmd_debianize = $(srctree)/scripts/package/mkdebian $(mkdebian-opts)
996eabebb1SMasahiro Yamada
1006eabebb1SMasahiro Yamadadebian: FORCE
1016eabebb1SMasahiro Yamada	$(call cmd,debianize)
1026eabebb1SMasahiro Yamada
1036eabebb1SMasahiro YamadaPHONY += debian-orig
1046eabebb1SMasahiro Yamadadebian-orig: private source = $(shell dpkg-parsechangelog -S Source)
1056eabebb1SMasahiro Yamadadebian-orig: private version = $(shell dpkg-parsechangelog -S Version | sed 's/-[^-]*$$//')
1066eabebb1SMasahiro Yamadadebian-orig: private orig-name = $(source)_$(version).orig.tar.gz
107aa7d233fSMasahiro Yamadadebian-orig: mkdebian-opts = --need-source
1086eabebb1SMasahiro Yamadadebian-orig: linux.tar.gz debian
109b44aa8c9SMasahiro Yamada	$(Q)if [ "$(df  --output=target .. 2>/dev/null)" = "$(df --output=target $< 2>/dev/null)" ]; then \
110b44aa8c9SMasahiro Yamada		ln -f $< ../$(orig-name); \
111b44aa8c9SMasahiro Yamada	else \
112b44aa8c9SMasahiro Yamada		cp $< ../$(orig-name); \
113b44aa8c9SMasahiro Yamada	fi
1146eabebb1SMasahiro Yamada
115000ec95fSMasahiro YamadaPHONY += deb-pkg
1166eabebb1SMasahiro Yamadadeb-pkg: debian-orig
1177bf4582dSMasahiro Yamada	+dpkg-buildpackage -r$(KBUILD_PKG_ROOTCMD) -a$$(cat debian/arch) $(DPKG_FLAGS) \
118e7853995SMasahiro Yamada		--build=source,binary -nc -us -uc
119000ec95fSMasahiro Yamada
120000ec95fSMasahiro YamadaPHONY += bindeb-pkg
1216eabebb1SMasahiro Yamadabindeb-pkg: debian
122000ec95fSMasahiro Yamada	+dpkg-buildpackage -r$(KBUILD_PKG_ROOTCMD) -a$$(cat debian/arch) $(DPKG_FLAGS) -b -nc -uc
123000ec95fSMasahiro Yamada
124000ec95fSMasahiro YamadaPHONY += intdeb-pkg
125000ec95fSMasahiro Yamadaintdeb-pkg:
126000ec95fSMasahiro Yamada	+$(CONFIG_SHELL) $(srctree)/scripts/package/builddeb
127000ec95fSMasahiro Yamada
128000ec95fSMasahiro Yamada# snap-pkg
129000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
130000ec95fSMasahiro YamadaPHONY += snap-pkg
131000ec95fSMasahiro Yamadasnap-pkg:
132000ec95fSMasahiro Yamada	rm -rf $(objtree)/snap
133000ec95fSMasahiro Yamada	mkdir $(objtree)/snap
134000ec95fSMasahiro Yamada	$(MAKE) clean
135000ec95fSMasahiro Yamada	$(call cmd,src_tar,$(KERNELPATH))
136000ec95fSMasahiro Yamada	sed "s@KERNELRELEASE@$(KERNELRELEASE)@; \
137000ec95fSMasahiro Yamada		s@SRCTREE@$(shell realpath $(KERNELPATH).tar.gz)@" \
138000ec95fSMasahiro Yamada		$(srctree)/scripts/package/snapcraft.template > \
139000ec95fSMasahiro Yamada		$(objtree)/snap/snapcraft.yaml
140000ec95fSMasahiro Yamada	cd $(objtree)/snap && \
141000ec95fSMasahiro Yamada	snapcraft --target-arch=$(UTS_MACHINE)
142000ec95fSMasahiro Yamada
1431fc90958SMasahiro Yamada# dir-pkg tar*-pkg - tarball targets
144000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
1451fc90958SMasahiro Yamada
1461fc90958SMasahiro Yamadatar-install: FORCE
1471fc90958SMasahiro Yamada	$(Q)$(MAKE) -f $(srctree)/Makefile
1481fc90958SMasahiro Yamada	+$(Q)$(srctree)/scripts/package/buildtar $@
1491fc90958SMasahiro Yamada
15005e96e96SMasahiro Yamadaquiet_cmd_tar = TAR     $@
15105e96e96SMasahiro Yamada      cmd_tar = cd $<; tar cf ../$@ --owner=root --group=root --sort=name *
15205e96e96SMasahiro Yamada
15305e96e96SMasahiro Yamadalinux-$(KERNELRELEASE)-$(ARCH).tar: tar-install
15405e96e96SMasahiro Yamada	$(call cmd,tar)
15505e96e96SMasahiro Yamada
1561fc90958SMasahiro YamadaPHONY += dir-pkg
1571fc90958SMasahiro Yamadadir-pkg: tar-install
1581fc90958SMasahiro Yamada	@echo "Kernel tree successfully created in $<"
1591fc90958SMasahiro Yamada
16005e96e96SMasahiro YamadaPHONY += tar-pkg
16105e96e96SMasahiro Yamadatar-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar
1621fc90958SMasahiro Yamada	@:
1631fc90958SMasahiro Yamada
16405e96e96SMasahiro Yamadatar%-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar.% FORCE
16505e96e96SMasahiro Yamada	@:
166000ec95fSMasahiro Yamada
167e0ca1674SMasahiro Yamada# perf-tar*-src-pkg - generate a source tarball with perf source
168000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
169000ec95fSMasahiro Yamada
17005e96e96SMasahiro Yamada.tmp_perf:
17105e96e96SMasahiro Yamada	$(Q)mkdir .tmp_perf
172000ec95fSMasahiro Yamada
17305e96e96SMasahiro Yamada.tmp_perf/HEAD: .tmp_HEAD | .tmp_perf
17405e96e96SMasahiro Yamada	$(call cmd,copy)
175e0ca1674SMasahiro Yamada
176e0ca1674SMasahiro Yamadaquiet_cmd_perf_version_file = GEN     $@
177e0ca1674SMasahiro Yamada      cmd_perf_version_file = cd $(srctree)/tools/perf; util/PERF-VERSION-GEN $(dir $(abspath $@))
178e0ca1674SMasahiro Yamada
17905e96e96SMasahiro Yamada# PERF-VERSION-FILE and .tmp_HEAD are independent, but this avoids updating the
180e0ca1674SMasahiro Yamada# timestamp of PERF-VERSION-FILE.
181e0ca1674SMasahiro Yamada# The best is to fix tools/perf/util/PERF-VERSION-GEN.
18205e96e96SMasahiro Yamada.tmp_perf/PERF-VERSION-FILE: .tmp_HEAD $(srctree)/tools/perf/util/PERF-VERSION-GEN | .tmp_perf
183e0ca1674SMasahiro Yamada	$(call cmd,perf_version_file)
184e0ca1674SMasahiro Yamada
185*f6d82835SMasahiro Yamadaperf-archive-args = --add-file=$$(realpath $(word 2, $^)) \
18605e96e96SMasahiro Yamada	--add-file=$$(realpath $(word 3, $^)) \
18705e96e96SMasahiro Yamada	$$(cat $(word 2, $^))^{tree} $$(cat $<)
18805e96e96SMasahiro Yamada
18905e96e96SMasahiro Yamadatargets += perf-$(KERNELVERSION).tar
190*f6d82835SMasahiro Yamadaperf-$(KERNELVERSION).tar: archive-args = $(perf-archive-args)
19105e96e96SMasahiro Yamadaperf-$(KERNELVERSION).tar: tools/perf/MANIFEST .tmp_perf/HEAD .tmp_perf/PERF-VERSION-FILE FORCE
192*f6d82835SMasahiro Yamada	$(call if_changed,archive)
19305e96e96SMasahiro Yamada
19405e96e96SMasahiro YamadaPHONY += perf-tar-src-pkg
19505e96e96SMasahiro Yamadaperf-tar-src-pkg: perf-$(KERNELVERSION).tar
196e0ca1674SMasahiro Yamada	@:
197e0ca1674SMasahiro Yamada
19805e96e96SMasahiro Yamadaperf-tar%-src-pkg: perf-$(KERNELVERSION).tar.% FORCE
19905e96e96SMasahiro Yamada	@:
200000ec95fSMasahiro Yamada
201000ec95fSMasahiro Yamada# Help text displayed when executing 'make help'
202000ec95fSMasahiro Yamada# ---------------------------------------------------------------------------
203000ec95fSMasahiro YamadaPHONY += help
204000ec95fSMasahiro Yamadahelp:
205000ec95fSMasahiro Yamada	@echo '  rpm-pkg             - Build both source and binary RPM kernel packages'
2069c9b55a5SJun ASAKA	@echo '  srcrpm-pkg          - Build only the source kernel RPM package'
207000ec95fSMasahiro Yamada	@echo '  binrpm-pkg          - Build only the binary kernel RPM package'
208000ec95fSMasahiro Yamada	@echo '  deb-pkg             - Build both source and binary deb kernel packages'
209000ec95fSMasahiro Yamada	@echo '  bindeb-pkg          - Build only the binary kernel deb package'
210a64c0440SGeert Uytterhoeven	@echo '  snap-pkg            - Build only the binary kernel snap package'
211a64c0440SGeert Uytterhoeven	@echo '                        (will connect to external hosts)'
212af7db99aSMatteo Croce	@echo '  dir-pkg             - Build the kernel as a plain directory structure'
213000ec95fSMasahiro Yamada	@echo '  tar-pkg             - Build the kernel as an uncompressed tarball'
214000ec95fSMasahiro Yamada	@echo '  targz-pkg           - Build the kernel as a gzip compressed tarball'
215000ec95fSMasahiro Yamada	@echo '  tarbz2-pkg          - Build the kernel as a bzip2 compressed tarball'
216000ec95fSMasahiro Yamada	@echo '  tarxz-pkg           - Build the kernel as a xz compressed tarball'
21788f5e1e6SPaweł Jasiak	@echo '  tarzst-pkg          - Build the kernel as a zstd compressed tarball'
218e0ca1674SMasahiro Yamada	@echo '  perf-tar-src-pkg    - Build the perf source tarball with no compression'
219e0ca1674SMasahiro Yamada	@echo '  perf-targz-src-pkg  - Build the perf source tarball with gzip compression'
220e0ca1674SMasahiro Yamada	@echo '  perf-tarbz2-src-pkg - Build the perf source tarball with bz2 compression'
221e0ca1674SMasahiro Yamada	@echo '  perf-tarxz-src-pkg  - Build the perf source tarball with xz compression'
222e0ca1674SMasahiro Yamada	@echo '  perf-tarzst-src-pkg - Build the perf source tarball with zst compression'
223000ec95fSMasahiro Yamada
2247bf4582dSMasahiro YamadaPHONY += FORCE
2257bf4582dSMasahiro YamadaFORCE:
2267bf4582dSMasahiro Yamada
22705e96e96SMasahiro Yamada# Read all saved command lines and dependencies for the $(targets) we
22805e96e96SMasahiro Yamada# may be building above, using $(if_changed{,_dep}). As an
22905e96e96SMasahiro Yamada# optimization, we don't need to read them if the target does not
23005e96e96SMasahiro Yamada# exist, we will rebuild anyway in that case.
23105e96e96SMasahiro Yamada
23205e96e96SMasahiro Yamadaexisting-targets := $(wildcard $(sort $(targets)))
23305e96e96SMasahiro Yamada
23405e96e96SMasahiro Yamada-include $(foreach f,$(existing-targets),$(dir $(f)).$(notdir $(f)).cmd)
23505e96e96SMasahiro Yamada
236000ec95fSMasahiro Yamada.PHONY: $(PHONY)
237