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 68*37477496SMasahiro Yamada# rpm-pkg srcrpm-pkg binrpm-pkg 69000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 70000ec95fSMasahiro Yamada 71*37477496SMasahiro Yamadaquiet_cmd_mkspec = GEN $@ 72*37477496SMasahiro Yamada cmd_mkspec = $(srctree)/scripts/package/mkspec > $@ 738818039fSIvan Vecera 74*37477496SMasahiro Yamadakernel.spec: FORCE 75*37477496SMasahiro Yamada $(call cmd,mkspec) 76*37477496SMasahiro Yamada 77*37477496SMasahiro YamadaPHONY += rpm-sources 78*37477496SMasahiro Yamadarpm-sources: linux.tar.gz 79*37477496SMasahiro Yamada $(Q)mkdir -p rpmbuild/SOURCES 80*37477496SMasahiro Yamada $(Q)ln -f linux.tar.gz rpmbuild/SOURCES/linux.tar.gz 81*37477496SMasahiro Yamada $(Q)cp $(KCONFIG_CONFIG) rpmbuild/SOURCES/config 82*37477496SMasahiro Yamada $(Q)$(srctree)/scripts/package/gen-diff-patch rpmbuild/SOURCES/diff.patch 83*37477496SMasahiro Yamada 84*37477496SMasahiro YamadaPHONY += rpm-pkg srcrpm-pkg binrpm-pkg 85*37477496SMasahiro Yamada 86*37477496SMasahiro Yamadarpm-pkg: private build-type := a 87*37477496SMasahiro Yamadasrcrpm-pkg: private build-type := s 88*37477496SMasahiro Yamadabinrpm-pkg: private build-type := b 89*37477496SMasahiro Yamada 90*37477496SMasahiro Yamadarpm-pkg srcrpm-pkg: rpm-sources 91*37477496SMasahiro Yamadarpm-pkg srcrpm-pkg binrpm-pkg: kernel.spec 92*37477496SMasahiro Yamada +$(strip rpmbuild -b$(build-type) kernel.spec \ 93*37477496SMasahiro Yamada --define='_topdir $(abspath rpmbuild)' \ 94*37477496SMasahiro Yamada $(if $(filter a b, $(build-type)), \ 95*37477496SMasahiro Yamada --target $(UTS_MACHINE)-linux --build-in-place --noprep --define='_smp_mflags %{nil}') \ 96*37477496SMasahiro Yamada $(if $(filter b, $(build-type)), \ 97*37477496SMasahiro Yamada --without devel) \ 98*37477496SMasahiro Yamada $(RPMOPTS)) 99000ec95fSMasahiro Yamada 10031f735c6SMasahiro Yamada# deb-pkg srcdeb-pkg bindeb-pkg 10131f735c6SMasahiro Yamada# --------------------------------------------------------------------------- 10231f735c6SMasahiro Yamada 1031d29b4c2SMasahiro YamadaKDEB_SOURCE_COMPRESS ?= gzip 1041d29b4c2SMasahiro Yamada 1051d29b4c2SMasahiro Yamadasupported-deb-source-compress := gzip bzip2 lzma xz 1061d29b4c2SMasahiro Yamada 1071d29b4c2SMasahiro YamadaPHONY += linux.tar.unsupported-deb-src-compress 1081d29b4c2SMasahiro Yamadalinux.tar.unsupported-deb-src-compress: 1091d29b4c2SMasahiro Yamada @echo "error: KDEB_SOURCE_COMPRESS=$(KDEB_SOURCE_COMPRESS) is not supported. The supported values are: $(supported-deb-source-compress)" >&2 1101d29b4c2SMasahiro Yamada @false 1111d29b4c2SMasahiro Yamada 1121d29b4c2SMasahiro Yamadadebian-orig-suffix := \ 1131d29b4c2SMasahiro Yamada $(strip $(if $(filter $(supported-deb-source-compress), $(KDEB_SOURCE_COMPRESS)), \ 1141d29b4c2SMasahiro Yamada $(suffix-$(KDEB_SOURCE_COMPRESS)),.unsupported-deb-src-compress)) 1151d29b4c2SMasahiro Yamada 1166eabebb1SMasahiro Yamadaquiet_cmd_debianize = GEN $@ 117aa7d233fSMasahiro Yamada cmd_debianize = $(srctree)/scripts/package/mkdebian $(mkdebian-opts) 1186eabebb1SMasahiro Yamada 1196eabebb1SMasahiro Yamadadebian: FORCE 1206eabebb1SMasahiro Yamada $(call cmd,debianize) 1216eabebb1SMasahiro Yamada 1226eabebb1SMasahiro YamadaPHONY += debian-orig 1236eabebb1SMasahiro Yamadadebian-orig: private source = $(shell dpkg-parsechangelog -S Source) 1246eabebb1SMasahiro Yamadadebian-orig: private version = $(shell dpkg-parsechangelog -S Version | sed 's/-[^-]*$$//') 1251d29b4c2SMasahiro Yamadadebian-orig: private orig-name = $(source)_$(version).orig.tar$(debian-orig-suffix) 126aa7d233fSMasahiro Yamadadebian-orig: mkdebian-opts = --need-source 1271d29b4c2SMasahiro Yamadadebian-orig: linux.tar$(debian-orig-suffix) debian 128b44aa8c9SMasahiro Yamada $(Q)if [ "$(df --output=target .. 2>/dev/null)" = "$(df --output=target $< 2>/dev/null)" ]; then \ 129b44aa8c9SMasahiro Yamada ln -f $< ../$(orig-name); \ 130b44aa8c9SMasahiro Yamada else \ 131b44aa8c9SMasahiro Yamada cp $< ../$(orig-name); \ 132b44aa8c9SMasahiro Yamada fi 1336eabebb1SMasahiro Yamada 13431f735c6SMasahiro YamadaKBUILD_PKG_ROOTCMD ?= 'fakeroot -u' 135000ec95fSMasahiro Yamada 13631f735c6SMasahiro YamadaPHONY += deb-pkg srcdeb-pkg bindeb-pkg 13731f735c6SMasahiro Yamada 13831f735c6SMasahiro Yamadadeb-pkg: private build-type := source,binary 13931f735c6SMasahiro Yamadasrcdeb-pkg: private build-type := source 14031f735c6SMasahiro Yamadabindeb-pkg: private build-type := binary 14131f735c6SMasahiro Yamada 14231f735c6SMasahiro Yamadadeb-pkg srcdeb-pkg: debian-orig 1436eabebb1SMasahiro Yamadabindeb-pkg: debian 14431f735c6SMasahiro Yamadadeb-pkg srcdeb-pkg bindeb-pkg: 14531f735c6SMasahiro Yamada +$(strip dpkg-buildpackage \ 14631f735c6SMasahiro Yamada --build=$(build-type) --no-pre-clean --unsigned-changes \ 14731f735c6SMasahiro Yamada $(if $(findstring source, $(build-type)), \ 1481d29b4c2SMasahiro Yamada --unsigned-source --compression=$(KDEB_SOURCE_COMPRESS)) \ 14931f735c6SMasahiro Yamada $(if $(findstring binary, $(build-type)), \ 15031f735c6SMasahiro Yamada -r$(KBUILD_PKG_ROOTCMD) -a$$(cat debian/arch), \ 15131f735c6SMasahiro Yamada --no-check-builddeps) \ 15231f735c6SMasahiro Yamada $(DPKG_FLAGS)) 153000ec95fSMasahiro Yamada 154000ec95fSMasahiro Yamada# snap-pkg 155000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 156000ec95fSMasahiro YamadaPHONY += snap-pkg 157000ec95fSMasahiro Yamadasnap-pkg: 158000ec95fSMasahiro Yamada rm -rf $(objtree)/snap 159000ec95fSMasahiro Yamada mkdir $(objtree)/snap 160000ec95fSMasahiro Yamada $(MAKE) clean 161000ec95fSMasahiro Yamada $(call cmd,src_tar,$(KERNELPATH)) 162000ec95fSMasahiro Yamada sed "s@KERNELRELEASE@$(KERNELRELEASE)@; \ 163000ec95fSMasahiro Yamada s@SRCTREE@$(shell realpath $(KERNELPATH).tar.gz)@" \ 164000ec95fSMasahiro Yamada $(srctree)/scripts/package/snapcraft.template > \ 165000ec95fSMasahiro Yamada $(objtree)/snap/snapcraft.yaml 166000ec95fSMasahiro Yamada cd $(objtree)/snap && \ 167000ec95fSMasahiro Yamada snapcraft --target-arch=$(UTS_MACHINE) 168000ec95fSMasahiro Yamada 1691fc90958SMasahiro Yamada# dir-pkg tar*-pkg - tarball targets 170000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 1711fc90958SMasahiro Yamada 1721fc90958SMasahiro Yamadatar-install: FORCE 1731fc90958SMasahiro Yamada $(Q)$(MAKE) -f $(srctree)/Makefile 1741fc90958SMasahiro Yamada +$(Q)$(srctree)/scripts/package/buildtar $@ 1751fc90958SMasahiro Yamada 1763c65a270SMasahiro Yamadacompress-tar.gz = -I "$(KGZIP)" 1773c65a270SMasahiro Yamadacompress-tar.bz2 = -I "$(KBZIP2)" 1783c65a270SMasahiro Yamadacompress-tar.xz = -I "$(XZ)" 1793c65a270SMasahiro Yamadacompress-tar.zst = -I "$(ZSTD)" 18005e96e96SMasahiro Yamada 1813c65a270SMasahiro Yamadaquiet_cmd_tar = TAR $@ 1823c65a270SMasahiro Yamada cmd_tar = cd $<; tar cf ../$@ $(compress-tar$(suffix $@)) --owner=root --group=root --sort=name * 1833c65a270SMasahiro Yamada 1843c65a270SMasahiro Yamadadir-tarballs := $(addprefix linux-$(KERNELRELEASE)-$(ARCH), .tar .tar.gz .tar.bz2 .tar.xz .tar.zst) 1853c65a270SMasahiro Yamada 1863c65a270SMasahiro Yamada$(dir-tarballs): tar-install 18705e96e96SMasahiro Yamada $(call cmd,tar) 18805e96e96SMasahiro Yamada 1891fc90958SMasahiro YamadaPHONY += dir-pkg 1901fc90958SMasahiro Yamadadir-pkg: tar-install 1911fc90958SMasahiro Yamada @echo "Kernel tree successfully created in $<" 1921fc90958SMasahiro Yamada 19305e96e96SMasahiro YamadaPHONY += tar-pkg 19405e96e96SMasahiro Yamadatar-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar 1951fc90958SMasahiro Yamada @: 1961fc90958SMasahiro Yamada 19705e96e96SMasahiro Yamadatar%-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar.% FORCE 19805e96e96SMasahiro Yamada @: 199000ec95fSMasahiro Yamada 200e0ca1674SMasahiro Yamada# perf-tar*-src-pkg - generate a source tarball with perf source 201000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 202000ec95fSMasahiro Yamada 20305e96e96SMasahiro Yamada.tmp_perf: 20405e96e96SMasahiro Yamada $(Q)mkdir .tmp_perf 205000ec95fSMasahiro Yamada 20605e96e96SMasahiro Yamada.tmp_perf/HEAD: .tmp_HEAD | .tmp_perf 20705e96e96SMasahiro Yamada $(call cmd,copy) 208e0ca1674SMasahiro Yamada 209e0ca1674SMasahiro Yamadaquiet_cmd_perf_version_file = GEN $@ 210e0ca1674SMasahiro Yamada cmd_perf_version_file = cd $(srctree)/tools/perf; util/PERF-VERSION-GEN $(dir $(abspath $@)) 211e0ca1674SMasahiro Yamada 21205e96e96SMasahiro Yamada# PERF-VERSION-FILE and .tmp_HEAD are independent, but this avoids updating the 213e0ca1674SMasahiro Yamada# timestamp of PERF-VERSION-FILE. 214e0ca1674SMasahiro Yamada# The best is to fix tools/perf/util/PERF-VERSION-GEN. 21505e96e96SMasahiro Yamada.tmp_perf/PERF-VERSION-FILE: .tmp_HEAD $(srctree)/tools/perf/util/PERF-VERSION-GEN | .tmp_perf 216e0ca1674SMasahiro Yamada $(call cmd,perf_version_file) 217e0ca1674SMasahiro Yamada 218f6d82835SMasahiro Yamadaperf-archive-args = --add-file=$$(realpath $(word 2, $^)) \ 21905e96e96SMasahiro Yamada --add-file=$$(realpath $(word 3, $^)) \ 22005e96e96SMasahiro Yamada $$(cat $(word 2, $^))^{tree} $$(cat $<) 22105e96e96SMasahiro Yamada 222f8d94c4eSMasahiro Yamada 223f8d94c4eSMasahiro Yamadaperf-tarballs := $(addprefix perf-$(KERNELVERSION), .tar .tar.gz .tar.bz2 .tar.xz .tar.zst) 224f8d94c4eSMasahiro Yamada 225f8d94c4eSMasahiro Yamadatargets += $(perf-tarballs) 2269cedc5e8SMasahiro Yamada$(perf-tarballs): archive-args = --prefix=perf-$(KERNELVERSION)/ $(perf-archive-args) 227f8d94c4eSMasahiro Yamada$(perf-tarballs): tools/perf/MANIFEST .tmp_perf/HEAD .tmp_perf/PERF-VERSION-FILE FORCE 228f6d82835SMasahiro Yamada $(call if_changed,archive) 22905e96e96SMasahiro Yamada 23005e96e96SMasahiro YamadaPHONY += perf-tar-src-pkg 23105e96e96SMasahiro Yamadaperf-tar-src-pkg: perf-$(KERNELVERSION).tar 232e0ca1674SMasahiro Yamada @: 233e0ca1674SMasahiro Yamada 23405e96e96SMasahiro Yamadaperf-tar%-src-pkg: perf-$(KERNELVERSION).tar.% FORCE 23505e96e96SMasahiro Yamada @: 236000ec95fSMasahiro Yamada 237000ec95fSMasahiro Yamada# Help text displayed when executing 'make help' 238000ec95fSMasahiro Yamada# --------------------------------------------------------------------------- 239000ec95fSMasahiro YamadaPHONY += help 240000ec95fSMasahiro Yamadahelp: 241000ec95fSMasahiro Yamada @echo ' rpm-pkg - Build both source and binary RPM kernel packages' 2429c9b55a5SJun ASAKA @echo ' srcrpm-pkg - Build only the source kernel RPM package' 243000ec95fSMasahiro Yamada @echo ' binrpm-pkg - Build only the binary kernel RPM package' 244000ec95fSMasahiro Yamada @echo ' deb-pkg - Build both source and binary deb kernel packages' 24531f735c6SMasahiro Yamada @echo ' srcdeb-pkg - Build only the source kernel deb package' 246000ec95fSMasahiro Yamada @echo ' bindeb-pkg - Build only the binary kernel deb package' 247a64c0440SGeert Uytterhoeven @echo ' snap-pkg - Build only the binary kernel snap package' 248a64c0440SGeert Uytterhoeven @echo ' (will connect to external hosts)' 249af7db99aSMatteo Croce @echo ' dir-pkg - Build the kernel as a plain directory structure' 250000ec95fSMasahiro Yamada @echo ' tar-pkg - Build the kernel as an uncompressed tarball' 251000ec95fSMasahiro Yamada @echo ' targz-pkg - Build the kernel as a gzip compressed tarball' 252000ec95fSMasahiro Yamada @echo ' tarbz2-pkg - Build the kernel as a bzip2 compressed tarball' 253000ec95fSMasahiro Yamada @echo ' tarxz-pkg - Build the kernel as a xz compressed tarball' 25488f5e1e6SPaweł Jasiak @echo ' tarzst-pkg - Build the kernel as a zstd compressed tarball' 255e0ca1674SMasahiro Yamada @echo ' perf-tar-src-pkg - Build the perf source tarball with no compression' 256e0ca1674SMasahiro Yamada @echo ' perf-targz-src-pkg - Build the perf source tarball with gzip compression' 257e0ca1674SMasahiro Yamada @echo ' perf-tarbz2-src-pkg - Build the perf source tarball with bz2 compression' 258e0ca1674SMasahiro Yamada @echo ' perf-tarxz-src-pkg - Build the perf source tarball with xz compression' 259e0ca1674SMasahiro Yamada @echo ' perf-tarzst-src-pkg - Build the perf source tarball with zst compression' 260000ec95fSMasahiro Yamada 2617bf4582dSMasahiro YamadaPHONY += FORCE 2627bf4582dSMasahiro YamadaFORCE: 2637bf4582dSMasahiro Yamada 26405e96e96SMasahiro Yamada# Read all saved command lines and dependencies for the $(targets) we 26505e96e96SMasahiro Yamada# may be building above, using $(if_changed{,_dep}). As an 26605e96e96SMasahiro Yamada# optimization, we don't need to read them if the target does not 26705e96e96SMasahiro Yamada# exist, we will rebuild anyway in that case. 26805e96e96SMasahiro Yamada 26905e96e96SMasahiro Yamadaexisting-targets := $(wildcard $(sort $(targets))) 27005e96e96SMasahiro Yamada 27105e96e96SMasahiro Yamada-include $(foreach f,$(existing-targets),$(dir $(f)).$(notdir $(f)).cmd) 27205e96e96SMasahiro Yamada 273000ec95fSMasahiro Yamada.PHONY: $(PHONY) 274