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 Yamada# Include only those top-level files that are needed by make, plus the GPL copy 9a3c4d4abSMasahiro YamadaTAR_CONTENT := Documentation LICENSES arch block certs crypto drivers fs \ 10df1f1ea9SParan Lee include init io_uring ipc kernel lib mm net rust \ 11df1f1ea9SParan Lee samples scripts security sound tools usr virt \ 12f6e09b07SMasahiro Yamada .config Makefile \ 13000ec95fSMasahiro Yamada Kbuild Kconfig COPYING $(wildcard localversion*) 14000ec95fSMasahiro Yamada 15000ec95fSMasahiro Yamadaquiet_cmd_src_tar = TAR $(2).tar.gz 16000ec95fSMasahiro Yamada cmd_src_tar = \ 17000ec95fSMasahiro Yamadaif test "$(objtree)" != "$(srctree)"; then \ 18000ec95fSMasahiro Yamada echo >&2; \ 19000ec95fSMasahiro Yamada echo >&2 " ERROR:"; \ 20000ec95fSMasahiro Yamada echo >&2 " Building source tarball is not possible outside the"; \ 216fc91752SMasahiro Yamada echo >&2 " kernel source tree. Don't set KBUILD_OUTPUT"; \ 22000ec95fSMasahiro Yamada echo >&2; \ 23000ec95fSMasahiro Yamada false; \ 24000ec95fSMasahiro Yamadafi ; \ 25e4a42c82SDenis Efremovtar -I $(KGZIP) -c $(RCS_TAR_IGNORE) -f $(2).tar.gz \ 26f6e09b07SMasahiro Yamada --transform 's:^:$(2)/:S' $(TAR_CONTENT) $(3) 27000ec95fSMasahiro Yamada 2805e96e96SMasahiro Yamada# Git 297bf4582dSMasahiro Yamada# --------------------------------------------------------------------------- 307bf4582dSMasahiro Yamada 3105e96e96SMasahiro Yamadafilechk_HEAD = git -C $(srctree) rev-parse --verify HEAD 2>/dev/null 327bf4582dSMasahiro Yamada 3305e96e96SMasahiro Yamada.tmp_HEAD: check-git FORCE 3405e96e96SMasahiro Yamada $(call filechk,HEAD) 357bf4582dSMasahiro Yamada 3605e96e96SMasahiro YamadaPHONY += check-git 3705e96e96SMasahiro Yamadacheck-git: 3805e96e96SMasahiro Yamada @if ! $(srctree)/scripts/check-git; then \ 3905e96e96SMasahiro Yamada echo >&2 "error: creating source package requires git repository"; \ 4005e96e96SMasahiro Yamada false; \ 4105e96e96SMasahiro Yamada fi 42e0ca1674SMasahiro Yamada 43f8d94c4eSMasahiro Yamadagit-config-tar.gz = -c tar.tar.gz.command="$(KGZIP)" 44f8d94c4eSMasahiro Yamadagit-config-tar.bz2 = -c tar.tar.bz2.command="$(KBZIP2)" 451d29b4c2SMasahiro Yamadagit-config-tar.lzma = -c tar.tar.lzma.command="$(LZMA)" 46f8d94c4eSMasahiro Yamadagit-config-tar.xz = -c tar.tar.xz.command="$(XZ)" 47f8d94c4eSMasahiro Yamadagit-config-tar.zst = -c tar.tar.zst.command="$(ZSTD)" 48f8d94c4eSMasahiro Yamada 49f6d82835SMasahiro Yamadaquiet_cmd_archive = ARCHIVE $@ 50f8d94c4eSMasahiro Yamada cmd_archive = git -C $(srctree) $(git-config-tar$(suffix $@)) archive \ 519cedc5e8SMasahiro Yamada --output=$$(realpath $@) $(archive-args) 52f6d82835SMasahiro Yamada 531d29b4c2SMasahiro Yamadasuffix-gzip := .gz 541d29b4c2SMasahiro Yamadasuffix-bzip2 := .bz2 551d29b4c2SMasahiro Yamadasuffix-lzma := .lzma 561d29b4c2SMasahiro Yamadasuffix-xz := .xz 571d29b4c2SMasahiro Yamada 587bf4582dSMasahiro Yamada# Linux source tarball 597bf4582dSMasahiro Yamada# --------------------------------------------------------------------------- 607bf4582dSMasahiro Yamada 611d29b4c2SMasahiro Yamadalinux-tarballs := $(addprefix linux, .tar.gz .tar.bz2 .tar.lzma .tar.xz) 62f8d94c4eSMasahiro Yamada 63f8d94c4eSMasahiro Yamadatargets += $(linux-tarballs) 649cedc5e8SMasahiro Yamada$(linux-tarballs): archive-args = --prefix=linux/ $$(cat $<) 65f8d94c4eSMasahiro Yamada$(linux-tarballs): .tmp_HEAD FORCE 66f6d82835SMasahiro Yamada $(call if_changed,archive) 677bf4582dSMasahiro Yamada 6837477496SMasahiro Yamada# rpm-pkg srcrpm-pkg binrpm-pkg 69000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 70000ec95fSMasahiro Yamada 7137477496SMasahiro Yamadaquiet_cmd_mkspec = GEN $@ 7237477496SMasahiro Yamada cmd_mkspec = $(srctree)/scripts/package/mkspec > $@ 738818039fSIvan Vecera 7437477496SMasahiro Yamadakernel.spec: FORCE 7537477496SMasahiro Yamada $(call cmd,mkspec) 7637477496SMasahiro Yamada 7737477496SMasahiro YamadaPHONY += rpm-sources 7837477496SMasahiro Yamadarpm-sources: linux.tar.gz 7937477496SMasahiro Yamada $(Q)mkdir -p rpmbuild/SOURCES 8037477496SMasahiro Yamada $(Q)ln -f linux.tar.gz rpmbuild/SOURCES/linux.tar.gz 8137477496SMasahiro Yamada $(Q)cp $(KCONFIG_CONFIG) rpmbuild/SOURCES/config 8237477496SMasahiro Yamada $(Q)$(srctree)/scripts/package/gen-diff-patch rpmbuild/SOURCES/diff.patch 8337477496SMasahiro Yamada 8437477496SMasahiro YamadaPHONY += rpm-pkg srcrpm-pkg binrpm-pkg 8537477496SMasahiro Yamada 8637477496SMasahiro Yamadarpm-pkg: private build-type := a 8737477496SMasahiro Yamadasrcrpm-pkg: private build-type := s 8837477496SMasahiro Yamadabinrpm-pkg: private build-type := b 8937477496SMasahiro Yamada 9037477496SMasahiro Yamadarpm-pkg srcrpm-pkg: rpm-sources 9137477496SMasahiro Yamadarpm-pkg srcrpm-pkg binrpm-pkg: kernel.spec 9237477496SMasahiro Yamada +$(strip rpmbuild -b$(build-type) kernel.spec \ 9337477496SMasahiro Yamada --define='_topdir $(abspath rpmbuild)' \ 9437477496SMasahiro Yamada $(if $(filter a b, $(build-type)), \ 95783c55aeSMasahiro Yamada --target $(UTS_MACHINE)-linux --build-in-place --noprep --define='_smp_mflags %{nil}' \ 96783c55aeSMasahiro Yamada $$(rpm -q rpm >/dev/null 2>&1 || echo --nodeps)) \ 9737477496SMasahiro Yamada $(if $(filter b, $(build-type)), \ 9837477496SMasahiro Yamada --without devel) \ 9937477496SMasahiro Yamada $(RPMOPTS)) 100000ec95fSMasahiro Yamada 10131f735c6SMasahiro Yamada# deb-pkg srcdeb-pkg bindeb-pkg 10231f735c6SMasahiro Yamada# --------------------------------------------------------------------------- 10331f735c6SMasahiro Yamada 1041d29b4c2SMasahiro YamadaKDEB_SOURCE_COMPRESS ?= gzip 1051d29b4c2SMasahiro Yamada 1061d29b4c2SMasahiro Yamadasupported-deb-source-compress := gzip bzip2 lzma xz 1071d29b4c2SMasahiro Yamada 1081d29b4c2SMasahiro YamadaPHONY += linux.tar.unsupported-deb-src-compress 1091d29b4c2SMasahiro Yamadalinux.tar.unsupported-deb-src-compress: 1101d29b4c2SMasahiro Yamada @echo "error: KDEB_SOURCE_COMPRESS=$(KDEB_SOURCE_COMPRESS) is not supported. The supported values are: $(supported-deb-source-compress)" >&2 1111d29b4c2SMasahiro Yamada @false 1121d29b4c2SMasahiro Yamada 1131d29b4c2SMasahiro Yamadadebian-orig-suffix := \ 1141d29b4c2SMasahiro Yamada $(strip $(if $(filter $(supported-deb-source-compress), $(KDEB_SOURCE_COMPRESS)), \ 1151d29b4c2SMasahiro Yamada $(suffix-$(KDEB_SOURCE_COMPRESS)),.unsupported-deb-src-compress)) 1161d29b4c2SMasahiro Yamada 1176eabebb1SMasahiro Yamadaquiet_cmd_debianize = GEN $@ 118aa7d233fSMasahiro Yamada cmd_debianize = $(srctree)/scripts/package/mkdebian $(mkdebian-opts) 1196eabebb1SMasahiro Yamada 1206eabebb1SMasahiro Yamadadebian: FORCE 1216eabebb1SMasahiro Yamada $(call cmd,debianize) 1226eabebb1SMasahiro Yamada 1236eabebb1SMasahiro YamadaPHONY += debian-orig 1246eabebb1SMasahiro Yamadadebian-orig: private source = $(shell dpkg-parsechangelog -S Source) 1256eabebb1SMasahiro Yamadadebian-orig: private version = $(shell dpkg-parsechangelog -S Version | sed 's/-[^-]*$$//') 1261d29b4c2SMasahiro Yamadadebian-orig: private orig-name = $(source)_$(version).orig.tar$(debian-orig-suffix) 127aa7d233fSMasahiro Yamadadebian-orig: mkdebian-opts = --need-source 1281d29b4c2SMasahiro Yamadadebian-orig: linux.tar$(debian-orig-suffix) debian 129*b89b0af9SThayne Harbaugh $(Q)if [ "$$(df --output=target .. 2>/dev/null)" = "$$(df --output=target $< 2>/dev/null)" ]; then \ 130b44aa8c9SMasahiro Yamada ln -f $< ../$(orig-name); \ 131b44aa8c9SMasahiro Yamada else \ 132b44aa8c9SMasahiro Yamada cp $< ../$(orig-name); \ 133b44aa8c9SMasahiro Yamada fi 1346eabebb1SMasahiro Yamada 13531f735c6SMasahiro YamadaKBUILD_PKG_ROOTCMD ?= 'fakeroot -u' 136000ec95fSMasahiro Yamada 13731f735c6SMasahiro YamadaPHONY += deb-pkg srcdeb-pkg bindeb-pkg 13831f735c6SMasahiro Yamada 13931f735c6SMasahiro Yamadadeb-pkg: private build-type := source,binary 14031f735c6SMasahiro Yamadasrcdeb-pkg: private build-type := source 14131f735c6SMasahiro Yamadabindeb-pkg: private build-type := binary 14231f735c6SMasahiro Yamada 14331f735c6SMasahiro Yamadadeb-pkg srcdeb-pkg: debian-orig 1446eabebb1SMasahiro Yamadabindeb-pkg: debian 14531f735c6SMasahiro Yamadadeb-pkg srcdeb-pkg bindeb-pkg: 14631f735c6SMasahiro Yamada +$(strip dpkg-buildpackage \ 14731f735c6SMasahiro Yamada --build=$(build-type) --no-pre-clean --unsigned-changes \ 14831f735c6SMasahiro Yamada $(if $(findstring source, $(build-type)), \ 1491d29b4c2SMasahiro Yamada --unsigned-source --compression=$(KDEB_SOURCE_COMPRESS)) \ 15031f735c6SMasahiro Yamada $(if $(findstring binary, $(build-type)), \ 151ed79c34dSMasahiro Yamada --rules-file='$(MAKE) -f debian/rules' --jobs=1 -r$(KBUILD_PKG_ROOTCMD) -a$$(cat debian/arch), \ 15231f735c6SMasahiro Yamada --no-check-builddeps) \ 15331f735c6SMasahiro Yamada $(DPKG_FLAGS)) 154000ec95fSMasahiro Yamada 155000ec95fSMasahiro Yamada# snap-pkg 156000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 157000ec95fSMasahiro YamadaPHONY += snap-pkg 158000ec95fSMasahiro Yamadasnap-pkg: 159000ec95fSMasahiro Yamada rm -rf $(objtree)/snap 160000ec95fSMasahiro Yamada mkdir $(objtree)/snap 161000ec95fSMasahiro Yamada $(MAKE) clean 162000ec95fSMasahiro Yamada $(call cmd,src_tar,$(KERNELPATH)) 163000ec95fSMasahiro Yamada sed "s@KERNELRELEASE@$(KERNELRELEASE)@; \ 164000ec95fSMasahiro Yamada s@SRCTREE@$(shell realpath $(KERNELPATH).tar.gz)@" \ 165000ec95fSMasahiro Yamada $(srctree)/scripts/package/snapcraft.template > \ 166000ec95fSMasahiro Yamada $(objtree)/snap/snapcraft.yaml 167000ec95fSMasahiro Yamada cd $(objtree)/snap && \ 168000ec95fSMasahiro Yamada snapcraft --target-arch=$(UTS_MACHINE) 169000ec95fSMasahiro Yamada 1701fc90958SMasahiro Yamada# dir-pkg tar*-pkg - tarball targets 171000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 1721fc90958SMasahiro Yamada 1731fc90958SMasahiro Yamadatar-install: FORCE 1741fc90958SMasahiro Yamada $(Q)$(MAKE) -f $(srctree)/Makefile 1751fc90958SMasahiro Yamada +$(Q)$(srctree)/scripts/package/buildtar $@ 1761fc90958SMasahiro Yamada 1773c65a270SMasahiro Yamadacompress-tar.gz = -I "$(KGZIP)" 1783c65a270SMasahiro Yamadacompress-tar.bz2 = -I "$(KBZIP2)" 1793c65a270SMasahiro Yamadacompress-tar.xz = -I "$(XZ)" 1803c65a270SMasahiro Yamadacompress-tar.zst = -I "$(ZSTD)" 18105e96e96SMasahiro Yamada 1823c65a270SMasahiro Yamadaquiet_cmd_tar = TAR $@ 1833c65a270SMasahiro Yamada cmd_tar = cd $<; tar cf ../$@ $(compress-tar$(suffix $@)) --owner=root --group=root --sort=name * 1843c65a270SMasahiro Yamada 1853c65a270SMasahiro Yamadadir-tarballs := $(addprefix linux-$(KERNELRELEASE)-$(ARCH), .tar .tar.gz .tar.bz2 .tar.xz .tar.zst) 1863c65a270SMasahiro Yamada 1873c65a270SMasahiro Yamada$(dir-tarballs): tar-install 18805e96e96SMasahiro Yamada $(call cmd,tar) 18905e96e96SMasahiro Yamada 1901fc90958SMasahiro YamadaPHONY += dir-pkg 1911fc90958SMasahiro Yamadadir-pkg: tar-install 1921fc90958SMasahiro Yamada @echo "Kernel tree successfully created in $<" 1931fc90958SMasahiro Yamada 19405e96e96SMasahiro YamadaPHONY += tar-pkg 19505e96e96SMasahiro Yamadatar-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar 1961fc90958SMasahiro Yamada @: 1971fc90958SMasahiro Yamada 19805e96e96SMasahiro Yamadatar%-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar.% FORCE 19905e96e96SMasahiro Yamada @: 200000ec95fSMasahiro Yamada 201e0ca1674SMasahiro Yamada# perf-tar*-src-pkg - generate a source tarball with perf source 202000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 203000ec95fSMasahiro Yamada 20405e96e96SMasahiro Yamada.tmp_perf: 20505e96e96SMasahiro Yamada $(Q)mkdir .tmp_perf 206000ec95fSMasahiro Yamada 20705e96e96SMasahiro Yamada.tmp_perf/HEAD: .tmp_HEAD | .tmp_perf 20805e96e96SMasahiro Yamada $(call cmd,copy) 209e0ca1674SMasahiro Yamada 210e0ca1674SMasahiro Yamadaquiet_cmd_perf_version_file = GEN $@ 211e0ca1674SMasahiro Yamada cmd_perf_version_file = cd $(srctree)/tools/perf; util/PERF-VERSION-GEN $(dir $(abspath $@)) 212e0ca1674SMasahiro Yamada 21305e96e96SMasahiro Yamada# PERF-VERSION-FILE and .tmp_HEAD are independent, but this avoids updating the 214e0ca1674SMasahiro Yamada# timestamp of PERF-VERSION-FILE. 215e0ca1674SMasahiro Yamada# The best is to fix tools/perf/util/PERF-VERSION-GEN. 21605e96e96SMasahiro Yamada.tmp_perf/PERF-VERSION-FILE: .tmp_HEAD $(srctree)/tools/perf/util/PERF-VERSION-GEN | .tmp_perf 217e0ca1674SMasahiro Yamada $(call cmd,perf_version_file) 218e0ca1674SMasahiro Yamada 219f6d82835SMasahiro Yamadaperf-archive-args = --add-file=$$(realpath $(word 2, $^)) \ 22005e96e96SMasahiro Yamada --add-file=$$(realpath $(word 3, $^)) \ 22105e96e96SMasahiro Yamada $$(cat $(word 2, $^))^{tree} $$(cat $<) 22205e96e96SMasahiro Yamada 223f8d94c4eSMasahiro Yamada 224f8d94c4eSMasahiro Yamadaperf-tarballs := $(addprefix perf-$(KERNELVERSION), .tar .tar.gz .tar.bz2 .tar.xz .tar.zst) 225f8d94c4eSMasahiro Yamada 226f8d94c4eSMasahiro Yamadatargets += $(perf-tarballs) 2279cedc5e8SMasahiro Yamada$(perf-tarballs): archive-args = --prefix=perf-$(KERNELVERSION)/ $(perf-archive-args) 228f8d94c4eSMasahiro Yamada$(perf-tarballs): tools/perf/MANIFEST .tmp_perf/HEAD .tmp_perf/PERF-VERSION-FILE FORCE 229f6d82835SMasahiro Yamada $(call if_changed,archive) 23005e96e96SMasahiro Yamada 23105e96e96SMasahiro YamadaPHONY += perf-tar-src-pkg 23205e96e96SMasahiro Yamadaperf-tar-src-pkg: perf-$(KERNELVERSION).tar 233e0ca1674SMasahiro Yamada @: 234e0ca1674SMasahiro Yamada 23505e96e96SMasahiro Yamadaperf-tar%-src-pkg: perf-$(KERNELVERSION).tar.% FORCE 23605e96e96SMasahiro Yamada @: 237000ec95fSMasahiro Yamada 238000ec95fSMasahiro Yamada# Help text displayed when executing 'make help' 239000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 240000ec95fSMasahiro YamadaPHONY += help 241000ec95fSMasahiro Yamadahelp: 242000ec95fSMasahiro Yamada @echo ' rpm-pkg - Build both source and binary RPM kernel packages' 2439c9b55a5SJun ASAKA @echo ' srcrpm-pkg - Build only the source kernel RPM package' 244000ec95fSMasahiro Yamada @echo ' binrpm-pkg - Build only the binary kernel RPM package' 245000ec95fSMasahiro Yamada @echo ' deb-pkg - Build both source and binary deb kernel packages' 24631f735c6SMasahiro Yamada @echo ' srcdeb-pkg - Build only the source kernel deb package' 247000ec95fSMasahiro Yamada @echo ' bindeb-pkg - Build only the binary kernel deb package' 248a64c0440SGeert Uytterhoeven @echo ' snap-pkg - Build only the binary kernel snap package' 249a64c0440SGeert Uytterhoeven @echo ' (will connect to external hosts)' 250af7db99aSMatteo Croce @echo ' dir-pkg - Build the kernel as a plain directory structure' 251000ec95fSMasahiro Yamada @echo ' tar-pkg - Build the kernel as an uncompressed tarball' 252000ec95fSMasahiro Yamada @echo ' targz-pkg - Build the kernel as a gzip compressed tarball' 253000ec95fSMasahiro Yamada @echo ' tarbz2-pkg - Build the kernel as a bzip2 compressed tarball' 254000ec95fSMasahiro Yamada @echo ' tarxz-pkg - Build the kernel as a xz compressed tarball' 25588f5e1e6SPaweł Jasiak @echo ' tarzst-pkg - Build the kernel as a zstd compressed tarball' 256e0ca1674SMasahiro Yamada @echo ' perf-tar-src-pkg - Build the perf source tarball with no compression' 257e0ca1674SMasahiro Yamada @echo ' perf-targz-src-pkg - Build the perf source tarball with gzip compression' 258e0ca1674SMasahiro Yamada @echo ' perf-tarbz2-src-pkg - Build the perf source tarball with bz2 compression' 259e0ca1674SMasahiro Yamada @echo ' perf-tarxz-src-pkg - Build the perf source tarball with xz compression' 260e0ca1674SMasahiro Yamada @echo ' perf-tarzst-src-pkg - Build the perf source tarball with zst compression' 261000ec95fSMasahiro Yamada 2627bf4582dSMasahiro YamadaPHONY += FORCE 2637bf4582dSMasahiro YamadaFORCE: 2647bf4582dSMasahiro Yamada 26505e96e96SMasahiro Yamada# Read all saved command lines and dependencies for the $(targets) we 26605e96e96SMasahiro Yamada# may be building above, using $(if_changed{,_dep}). As an 26705e96e96SMasahiro Yamada# optimization, we don't need to read them if the target does not 26805e96e96SMasahiro Yamada# exist, we will rebuild anyway in that case. 26905e96e96SMasahiro Yamada 27005e96e96SMasahiro Yamadaexisting-targets := $(wildcard $(sort $(targets))) 27105e96e96SMasahiro Yamada 27205e96e96SMasahiro Yamada-include $(foreach f,$(existing-targets),$(dir $(f)).$(notdir $(f)).cmd) 27305e96e96SMasahiro Yamada 274000ec95fSMasahiro Yamada.PHONY: $(PHONY) 275