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 YamadaMKSPEC := $(srctree)/scripts/package/mkspec 15000ec95fSMasahiro Yamada 16000ec95fSMasahiro Yamadaquiet_cmd_src_tar = TAR $(2).tar.gz 17000ec95fSMasahiro Yamada cmd_src_tar = \ 18000ec95fSMasahiro Yamadaif test "$(objtree)" != "$(srctree)"; then \ 19000ec95fSMasahiro Yamada echo >&2; \ 20000ec95fSMasahiro Yamada echo >&2 " ERROR:"; \ 21000ec95fSMasahiro Yamada echo >&2 " Building source tarball is not possible outside the"; \ 226fc91752SMasahiro Yamada echo >&2 " kernel source tree. Don't set KBUILD_OUTPUT"; \ 23000ec95fSMasahiro Yamada echo >&2; \ 24000ec95fSMasahiro Yamada false; \ 25000ec95fSMasahiro Yamadafi ; \ 26e4a42c82SDenis Efremovtar -I $(KGZIP) -c $(RCS_TAR_IGNORE) -f $(2).tar.gz \ 27f6e09b07SMasahiro Yamada --transform 's:^:$(2)/:S' $(TAR_CONTENT) $(3) 28000ec95fSMasahiro Yamada 2905e96e96SMasahiro Yamada# Git 307bf4582dSMasahiro Yamada# --------------------------------------------------------------------------- 317bf4582dSMasahiro Yamada 3205e96e96SMasahiro Yamadafilechk_HEAD = git -C $(srctree) rev-parse --verify HEAD 2>/dev/null 337bf4582dSMasahiro Yamada 3405e96e96SMasahiro Yamada.tmp_HEAD: check-git FORCE 3505e96e96SMasahiro Yamada $(call filechk,HEAD) 367bf4582dSMasahiro Yamada 3705e96e96SMasahiro YamadaPHONY += check-git 3805e96e96SMasahiro Yamadacheck-git: 3905e96e96SMasahiro Yamada @if ! $(srctree)/scripts/check-git; then \ 4005e96e96SMasahiro Yamada echo >&2 "error: creating source package requires git repository"; \ 4105e96e96SMasahiro Yamada false; \ 4205e96e96SMasahiro Yamada fi 43e0ca1674SMasahiro Yamada 44f8d94c4eSMasahiro Yamadagit-config-tar.gz = -c tar.tar.gz.command="$(KGZIP)" 45f8d94c4eSMasahiro Yamadagit-config-tar.bz2 = -c tar.tar.bz2.command="$(KBZIP2)" 46*1d29b4c2SMasahiro Yamadagit-config-tar.lzma = -c tar.tar.lzma.command="$(LZMA)" 47f8d94c4eSMasahiro Yamadagit-config-tar.xz = -c tar.tar.xz.command="$(XZ)" 48f8d94c4eSMasahiro Yamadagit-config-tar.zst = -c tar.tar.zst.command="$(ZSTD)" 49f8d94c4eSMasahiro Yamada 50f6d82835SMasahiro Yamadaquiet_cmd_archive = ARCHIVE $@ 51f8d94c4eSMasahiro Yamada cmd_archive = git -C $(srctree) $(git-config-tar$(suffix $@)) archive \ 52f6d82835SMasahiro Yamada --output=$$(realpath $@) --prefix=$(basename $@)/ $(archive-args) 53f6d82835SMasahiro Yamada 54*1d29b4c2SMasahiro Yamadasuffix-gzip := .gz 55*1d29b4c2SMasahiro Yamadasuffix-bzip2 := .bz2 56*1d29b4c2SMasahiro Yamadasuffix-lzma := .lzma 57*1d29b4c2SMasahiro Yamadasuffix-xz := .xz 58*1d29b4c2SMasahiro Yamada 597bf4582dSMasahiro Yamada# Linux source tarball 607bf4582dSMasahiro Yamada# --------------------------------------------------------------------------- 617bf4582dSMasahiro Yamada 62*1d29b4c2SMasahiro Yamadalinux-tarballs := $(addprefix linux, .tar.gz .tar.bz2 .tar.lzma .tar.xz) 63f8d94c4eSMasahiro Yamada 64f8d94c4eSMasahiro Yamadatargets += $(linux-tarballs) 65f8d94c4eSMasahiro Yamada$(linux-tarballs): archive-args = $$(cat $<) 66f8d94c4eSMasahiro Yamada$(linux-tarballs): .tmp_HEAD FORCE 67f6d82835SMasahiro Yamada $(call if_changed,archive) 687bf4582dSMasahiro Yamada 69000ec95fSMasahiro Yamada# rpm-pkg 70000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 71000ec95fSMasahiro YamadaPHONY += rpm-pkg 721ec9bb70SMasahiro Yamadarpm-pkg: srpm = $(shell rpmspec --srpm --query --queryformat='%{name}-%{VERSION}-%{RELEASE}.src.rpm' kernel.spec) 731ec9bb70SMasahiro Yamadarpm-pkg: srcrpm-pkg 741ec9bb70SMasahiro Yamada +rpmbuild $(RPMOPTS) --target $(UTS_MACHINE)-linux -rb $(srpm) \ 75000ec95fSMasahiro Yamada --define='_smp_mflags %{nil}' 76000ec95fSMasahiro Yamada 778818039fSIvan Vecera# srcrpm-pkg 788818039fSIvan Vecera# --------------------------------------------------------------------------- 798818039fSIvan VeceraPHONY += srcrpm-pkg 806fc91752SMasahiro Yamadasrcrpm-pkg: linux.tar.gz 818818039fSIvan Vecera $(CONFIG_SHELL) $(MKSPEC) >$(objtree)/kernel.spec 826fc91752SMasahiro Yamada +rpmbuild $(RPMOPTS) --target $(UTS_MACHINE)-linux -bs kernel.spec \ 8381f59a26SMasahiro Yamada --define='_smp_mflags %{nil}' --define='_sourcedir rpmbuild/SOURCES' --define='_srcrpmdir .' 848818039fSIvan Vecera 85000ec95fSMasahiro Yamada# binrpm-pkg 86000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 87000ec95fSMasahiro YamadaPHONY += binrpm-pkg 88000ec95fSMasahiro Yamadabinrpm-pkg: 89000ec95fSMasahiro Yamada $(MAKE) -f $(srctree)/Makefile 90000ec95fSMasahiro Yamada $(CONFIG_SHELL) $(MKSPEC) prebuilt > $(objtree)/binkernel.spec 91000ec95fSMasahiro Yamada +rpmbuild $(RPMOPTS) --define "_builddir $(objtree)" --target \ 926105e4f6SMasahiro Yamada $(UTS_MACHINE)-linux -bb $(objtree)/binkernel.spec 93000ec95fSMasahiro Yamada 9431f735c6SMasahiro Yamada# deb-pkg srcdeb-pkg bindeb-pkg 9531f735c6SMasahiro Yamada# --------------------------------------------------------------------------- 9631f735c6SMasahiro Yamada 97*1d29b4c2SMasahiro YamadaKDEB_SOURCE_COMPRESS ?= gzip 98*1d29b4c2SMasahiro Yamada 99*1d29b4c2SMasahiro Yamadasupported-deb-source-compress := gzip bzip2 lzma xz 100*1d29b4c2SMasahiro Yamada 101*1d29b4c2SMasahiro YamadaPHONY += linux.tar.unsupported-deb-src-compress 102*1d29b4c2SMasahiro Yamadalinux.tar.unsupported-deb-src-compress: 103*1d29b4c2SMasahiro Yamada @echo "error: KDEB_SOURCE_COMPRESS=$(KDEB_SOURCE_COMPRESS) is not supported. The supported values are: $(supported-deb-source-compress)" >&2 104*1d29b4c2SMasahiro Yamada @false 105*1d29b4c2SMasahiro Yamada 106*1d29b4c2SMasahiro Yamadadebian-orig-suffix := \ 107*1d29b4c2SMasahiro Yamada $(strip $(if $(filter $(supported-deb-source-compress), $(KDEB_SOURCE_COMPRESS)), \ 108*1d29b4c2SMasahiro Yamada $(suffix-$(KDEB_SOURCE_COMPRESS)),.unsupported-deb-src-compress)) 109*1d29b4c2SMasahiro Yamada 1106eabebb1SMasahiro Yamadaquiet_cmd_debianize = GEN $@ 111aa7d233fSMasahiro Yamada cmd_debianize = $(srctree)/scripts/package/mkdebian $(mkdebian-opts) 1126eabebb1SMasahiro Yamada 1136eabebb1SMasahiro Yamadadebian: FORCE 1146eabebb1SMasahiro Yamada $(call cmd,debianize) 1156eabebb1SMasahiro Yamada 1166eabebb1SMasahiro YamadaPHONY += debian-orig 1176eabebb1SMasahiro Yamadadebian-orig: private source = $(shell dpkg-parsechangelog -S Source) 1186eabebb1SMasahiro Yamadadebian-orig: private version = $(shell dpkg-parsechangelog -S Version | sed 's/-[^-]*$$//') 119*1d29b4c2SMasahiro Yamadadebian-orig: private orig-name = $(source)_$(version).orig.tar$(debian-orig-suffix) 120aa7d233fSMasahiro Yamadadebian-orig: mkdebian-opts = --need-source 121*1d29b4c2SMasahiro Yamadadebian-orig: linux.tar$(debian-orig-suffix) debian 122b44aa8c9SMasahiro Yamada $(Q)if [ "$(df --output=target .. 2>/dev/null)" = "$(df --output=target $< 2>/dev/null)" ]; then \ 123b44aa8c9SMasahiro Yamada ln -f $< ../$(orig-name); \ 124b44aa8c9SMasahiro Yamada else \ 125b44aa8c9SMasahiro Yamada cp $< ../$(orig-name); \ 126b44aa8c9SMasahiro Yamada fi 1276eabebb1SMasahiro Yamada 12831f735c6SMasahiro YamadaKBUILD_PKG_ROOTCMD ?= 'fakeroot -u' 129000ec95fSMasahiro Yamada 13031f735c6SMasahiro YamadaPHONY += deb-pkg srcdeb-pkg bindeb-pkg 13131f735c6SMasahiro Yamada 13231f735c6SMasahiro Yamadadeb-pkg: private build-type := source,binary 13331f735c6SMasahiro Yamadasrcdeb-pkg: private build-type := source 13431f735c6SMasahiro Yamadabindeb-pkg: private build-type := binary 13531f735c6SMasahiro Yamada 13631f735c6SMasahiro Yamadadeb-pkg srcdeb-pkg: debian-orig 1376eabebb1SMasahiro Yamadabindeb-pkg: debian 13831f735c6SMasahiro Yamadadeb-pkg srcdeb-pkg bindeb-pkg: 13931f735c6SMasahiro Yamada +$(strip dpkg-buildpackage \ 14031f735c6SMasahiro Yamada --build=$(build-type) --no-pre-clean --unsigned-changes \ 14131f735c6SMasahiro Yamada $(if $(findstring source, $(build-type)), \ 142*1d29b4c2SMasahiro Yamada --unsigned-source --compression=$(KDEB_SOURCE_COMPRESS)) \ 14331f735c6SMasahiro Yamada $(if $(findstring binary, $(build-type)), \ 14431f735c6SMasahiro Yamada -r$(KBUILD_PKG_ROOTCMD) -a$$(cat debian/arch), \ 14531f735c6SMasahiro Yamada --no-check-builddeps) \ 14631f735c6SMasahiro Yamada $(DPKG_FLAGS)) 147000ec95fSMasahiro Yamada 148000ec95fSMasahiro YamadaPHONY += intdeb-pkg 149000ec95fSMasahiro Yamadaintdeb-pkg: 150000ec95fSMasahiro Yamada +$(CONFIG_SHELL) $(srctree)/scripts/package/builddeb 151000ec95fSMasahiro Yamada 152000ec95fSMasahiro Yamada# snap-pkg 153000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 154000ec95fSMasahiro YamadaPHONY += snap-pkg 155000ec95fSMasahiro Yamadasnap-pkg: 156000ec95fSMasahiro Yamada rm -rf $(objtree)/snap 157000ec95fSMasahiro Yamada mkdir $(objtree)/snap 158000ec95fSMasahiro Yamada $(MAKE) clean 159000ec95fSMasahiro Yamada $(call cmd,src_tar,$(KERNELPATH)) 160000ec95fSMasahiro Yamada sed "s@KERNELRELEASE@$(KERNELRELEASE)@; \ 161000ec95fSMasahiro Yamada s@SRCTREE@$(shell realpath $(KERNELPATH).tar.gz)@" \ 162000ec95fSMasahiro Yamada $(srctree)/scripts/package/snapcraft.template > \ 163000ec95fSMasahiro Yamada $(objtree)/snap/snapcraft.yaml 164000ec95fSMasahiro Yamada cd $(objtree)/snap && \ 165000ec95fSMasahiro Yamada snapcraft --target-arch=$(UTS_MACHINE) 166000ec95fSMasahiro Yamada 1671fc90958SMasahiro Yamada# dir-pkg tar*-pkg - tarball targets 168000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 1691fc90958SMasahiro Yamada 1701fc90958SMasahiro Yamadatar-install: FORCE 1711fc90958SMasahiro Yamada $(Q)$(MAKE) -f $(srctree)/Makefile 1721fc90958SMasahiro Yamada +$(Q)$(srctree)/scripts/package/buildtar $@ 1731fc90958SMasahiro Yamada 1743c65a270SMasahiro Yamadacompress-tar.gz = -I "$(KGZIP)" 1753c65a270SMasahiro Yamadacompress-tar.bz2 = -I "$(KBZIP2)" 1763c65a270SMasahiro Yamadacompress-tar.xz = -I "$(XZ)" 1773c65a270SMasahiro Yamadacompress-tar.zst = -I "$(ZSTD)" 17805e96e96SMasahiro Yamada 1793c65a270SMasahiro Yamadaquiet_cmd_tar = TAR $@ 1803c65a270SMasahiro Yamada cmd_tar = cd $<; tar cf ../$@ $(compress-tar$(suffix $@)) --owner=root --group=root --sort=name * 1813c65a270SMasahiro Yamada 1823c65a270SMasahiro Yamadadir-tarballs := $(addprefix linux-$(KERNELRELEASE)-$(ARCH), .tar .tar.gz .tar.bz2 .tar.xz .tar.zst) 1833c65a270SMasahiro Yamada 1843c65a270SMasahiro Yamada$(dir-tarballs): tar-install 18505e96e96SMasahiro Yamada $(call cmd,tar) 18605e96e96SMasahiro Yamada 1871fc90958SMasahiro YamadaPHONY += dir-pkg 1881fc90958SMasahiro Yamadadir-pkg: tar-install 1891fc90958SMasahiro Yamada @echo "Kernel tree successfully created in $<" 1901fc90958SMasahiro Yamada 19105e96e96SMasahiro YamadaPHONY += tar-pkg 19205e96e96SMasahiro Yamadatar-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar 1931fc90958SMasahiro Yamada @: 1941fc90958SMasahiro Yamada 19505e96e96SMasahiro Yamadatar%-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar.% FORCE 19605e96e96SMasahiro Yamada @: 197000ec95fSMasahiro Yamada 198e0ca1674SMasahiro Yamada# perf-tar*-src-pkg - generate a source tarball with perf source 199000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 200000ec95fSMasahiro Yamada 20105e96e96SMasahiro Yamada.tmp_perf: 20205e96e96SMasahiro Yamada $(Q)mkdir .tmp_perf 203000ec95fSMasahiro Yamada 20405e96e96SMasahiro Yamada.tmp_perf/HEAD: .tmp_HEAD | .tmp_perf 20505e96e96SMasahiro Yamada $(call cmd,copy) 206e0ca1674SMasahiro Yamada 207e0ca1674SMasahiro Yamadaquiet_cmd_perf_version_file = GEN $@ 208e0ca1674SMasahiro Yamada cmd_perf_version_file = cd $(srctree)/tools/perf; util/PERF-VERSION-GEN $(dir $(abspath $@)) 209e0ca1674SMasahiro Yamada 21005e96e96SMasahiro Yamada# PERF-VERSION-FILE and .tmp_HEAD are independent, but this avoids updating the 211e0ca1674SMasahiro Yamada# timestamp of PERF-VERSION-FILE. 212e0ca1674SMasahiro Yamada# The best is to fix tools/perf/util/PERF-VERSION-GEN. 21305e96e96SMasahiro Yamada.tmp_perf/PERF-VERSION-FILE: .tmp_HEAD $(srctree)/tools/perf/util/PERF-VERSION-GEN | .tmp_perf 214e0ca1674SMasahiro Yamada $(call cmd,perf_version_file) 215e0ca1674SMasahiro Yamada 216f6d82835SMasahiro Yamadaperf-archive-args = --add-file=$$(realpath $(word 2, $^)) \ 21705e96e96SMasahiro Yamada --add-file=$$(realpath $(word 3, $^)) \ 21805e96e96SMasahiro Yamada $$(cat $(word 2, $^))^{tree} $$(cat $<) 21905e96e96SMasahiro Yamada 220f8d94c4eSMasahiro Yamada 221f8d94c4eSMasahiro Yamadaperf-tarballs := $(addprefix perf-$(KERNELVERSION), .tar .tar.gz .tar.bz2 .tar.xz .tar.zst) 222f8d94c4eSMasahiro Yamada 223f8d94c4eSMasahiro Yamadatargets += $(perf-tarballs) 224f8d94c4eSMasahiro Yamada$(perf-tarballs): archive-args = $(perf-archive-args) 225f8d94c4eSMasahiro Yamada$(perf-tarballs): tools/perf/MANIFEST .tmp_perf/HEAD .tmp_perf/PERF-VERSION-FILE FORCE 226f6d82835SMasahiro Yamada $(call if_changed,archive) 22705e96e96SMasahiro Yamada 22805e96e96SMasahiro YamadaPHONY += perf-tar-src-pkg 22905e96e96SMasahiro Yamadaperf-tar-src-pkg: perf-$(KERNELVERSION).tar 230e0ca1674SMasahiro Yamada @: 231e0ca1674SMasahiro Yamada 23205e96e96SMasahiro Yamadaperf-tar%-src-pkg: perf-$(KERNELVERSION).tar.% FORCE 23305e96e96SMasahiro Yamada @: 234000ec95fSMasahiro Yamada 235000ec95fSMasahiro Yamada# Help text displayed when executing 'make help' 236000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 237000ec95fSMasahiro YamadaPHONY += help 238000ec95fSMasahiro Yamadahelp: 239000ec95fSMasahiro Yamada @echo ' rpm-pkg - Build both source and binary RPM kernel packages' 2409c9b55a5SJun ASAKA @echo ' srcrpm-pkg - Build only the source kernel RPM package' 241000ec95fSMasahiro Yamada @echo ' binrpm-pkg - Build only the binary kernel RPM package' 242000ec95fSMasahiro Yamada @echo ' deb-pkg - Build both source and binary deb kernel packages' 24331f735c6SMasahiro Yamada @echo ' srcdeb-pkg - Build only the source kernel deb package' 244000ec95fSMasahiro Yamada @echo ' bindeb-pkg - Build only the binary kernel deb package' 245a64c0440SGeert Uytterhoeven @echo ' snap-pkg - Build only the binary kernel snap package' 246a64c0440SGeert Uytterhoeven @echo ' (will connect to external hosts)' 247af7db99aSMatteo Croce @echo ' dir-pkg - Build the kernel as a plain directory structure' 248000ec95fSMasahiro Yamada @echo ' tar-pkg - Build the kernel as an uncompressed tarball' 249000ec95fSMasahiro Yamada @echo ' targz-pkg - Build the kernel as a gzip compressed tarball' 250000ec95fSMasahiro Yamada @echo ' tarbz2-pkg - Build the kernel as a bzip2 compressed tarball' 251000ec95fSMasahiro Yamada @echo ' tarxz-pkg - Build the kernel as a xz compressed tarball' 25288f5e1e6SPaweł Jasiak @echo ' tarzst-pkg - Build the kernel as a zstd compressed tarball' 253e0ca1674SMasahiro Yamada @echo ' perf-tar-src-pkg - Build the perf source tarball with no compression' 254e0ca1674SMasahiro Yamada @echo ' perf-targz-src-pkg - Build the perf source tarball with gzip compression' 255e0ca1674SMasahiro Yamada @echo ' perf-tarbz2-src-pkg - Build the perf source tarball with bz2 compression' 256e0ca1674SMasahiro Yamada @echo ' perf-tarxz-src-pkg - Build the perf source tarball with xz compression' 257e0ca1674SMasahiro Yamada @echo ' perf-tarzst-src-pkg - Build the perf source tarball with zst compression' 258000ec95fSMasahiro Yamada 2597bf4582dSMasahiro YamadaPHONY += FORCE 2607bf4582dSMasahiro YamadaFORCE: 2617bf4582dSMasahiro Yamada 26205e96e96SMasahiro Yamada# Read all saved command lines and dependencies for the $(targets) we 26305e96e96SMasahiro Yamada# may be building above, using $(if_changed{,_dep}). As an 26405e96e96SMasahiro Yamada# optimization, we don't need to read them if the target does not 26505e96e96SMasahiro Yamada# exist, we will rebuild anyway in that case. 26605e96e96SMasahiro Yamada 26705e96e96SMasahiro Yamadaexisting-targets := $(wildcard $(sort $(targets))) 26805e96e96SMasahiro Yamada 26905e96e96SMasahiro Yamada-include $(foreach f,$(existing-targets),$(dir $(f)).$(notdir $(f)).cmd) 27005e96e96SMasahiro Yamada 271000ec95fSMasahiro Yamada.PHONY: $(PHONY) 272