2019-05-19 15:07:45 +03:00
# SPDX-License-Identifier: GPL-2.0-only
2005-04-17 02:20:36 +04:00
# Makefile for the different targets used to generate full packages of a kernel
2019-08-21 10:02:04 +03:00
i n c l u d e $( srctree ) / s c r i p t s / K b u i l d . i n c l u d e
2023-03-15 18:50:18 +03:00
i n c l u d e $( srctree ) / s c r i p t s / M a k e f i l e . l i b
2005-04-17 02:20:36 +04:00
2011-05-05 00:48:11 +04:00
KERNELPATH := kernel-$( subst -,_,$( KERNELRELEASE) )
2013-04-12 16:12:50 +04:00
# Include only those top-level files that are needed by make, plus the GPL copy
2022-09-24 21:19:09 +03:00
TAR_CONTENT := Documentation LICENSES arch block certs crypto drivers fs \
2022-11-24 01:00:44 +03:00
include init io_uring ipc kernel lib mm net rust \
samples scripts security sound tools usr virt \
2023-01-22 17:14:21 +03:00
.config Makefile \
2013-04-12 16:12:50 +04:00
Kbuild Kconfig COPYING $( wildcard localversion*)
2005-04-17 02:20:36 +04:00
2015-09-02 12:57:08 +03:00
quiet_cmd_src_tar = TAR $( 2) .tar.gz
cmd_src_tar = \
i f t e s t "$(objtree)" ! = "$(srctree)" ; t h e n \
2017-12-06 13:32:57 +03:00
echo >& 2; \
echo >& 2 " ERROR:" ; \
echo >& 2 " Building source tarball is not possible outside the" ; \
2023-02-15 04:20:26 +03:00
echo >& 2 " kernel source tree. Don't set KBUILD_OUTPUT" ; \
2017-12-06 13:32:57 +03:00
echo >& 2; \
2015-09-02 12:57:08 +03:00
false; \
f i ; \
kbuild: fix broken builds because of GZIP,BZIP2,LZOP variables
Redefine GZIP, BZIP2, LZOP variables as KGZIP, KBZIP2, KLZOP resp.
GZIP, BZIP2, LZOP env variables are reserved by the tools. The original
attempt to redefine them internally doesn't work in makefiles/scripts
intercall scenarios, e.g., "make GZIP=gzip bindeb-pkg" and results in
broken builds. There can be other broken build commands because of this,
so the universal solution is to use non-reserved env variables for the
compression tools.
Fixes: 8dfb61dcbace ("kbuild: add variables for compression tools")
Signed-off-by: Denis Efremov <efremov@linux.com>
Tested-by: Guenter Roeck <linux@roeck-us.net>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
2020-06-08 12:59:44 +03:00
t a r - I $( KGZIP ) - c $( RCS_TAR_IGNORE ) - f $( 2) . t a r . g z \
2023-01-22 17:14:21 +03:00
--transform 's:^:$(2)/:S' $( TAR_CONTENT) $( 3)
2015-09-02 12:57:08 +03:00
2023-03-15 18:50:18 +03:00
# Git
# ---------------------------------------------------------------------------
2023-02-15 04:20:24 +03:00
2023-03-15 18:50:18 +03:00
filechk_HEAD = git -C $( srctree) rev-parse --verify HEAD 2>/dev/null
2023-02-15 04:20:30 +03:00
2023-03-15 18:50:18 +03:00
.tmp_HEAD : check -git FORCE
$( call filechk,HEAD)
2023-02-15 04:20:30 +03:00
2023-03-15 18:50:18 +03:00
PHONY += check-git
check-git :
@if ! $( srctree) /scripts/check-git; then \
echo >& 2 "error: creating source package requires git repository" ; \
false; \
fi
2023-02-15 04:20:30 +03:00
2023-04-17 17:25:48 +03:00
git-config-tar.gz = -c tar.tar.gz.command= " $( KGZIP) "
git-config-tar.bz2 = -c tar.tar.bz2.command= " $( KBZIP2) "
git-config-tar.lzma = -c tar.tar.lzma.command= " $( LZMA) "
git-config-tar.xz = -c tar.tar.xz.command= " $( XZ) "
git-config-tar.zst = -c tar.tar.zst.command= " $( ZSTD) "
2023-04-07 13:16:28 +03:00
2023-04-07 13:16:27 +03:00
quiet_cmd_archive = ARCHIVE $@
2023-04-07 13:16:28 +03:00
cmd_archive = git -C $( srctree) $( git-config-tar$( suffix $@ ) ) archive \
2023-04-19 20:04:24 +03:00
--output= $$ ( realpath $@ ) $( archive-args)
2023-04-07 13:16:27 +03:00
2023-04-17 17:25:48 +03:00
suffix-gzip := .gz
suffix-bzip2 := .bz2
suffix-lzma := .lzma
suffix-xz := .xz
2023-02-15 04:20:24 +03:00
# Linux source tarball
# ---------------------------------------------------------------------------
2023-04-17 17:25:48 +03:00
linux-tarballs := $( addprefix linux, .tar.gz .tar.bz2 .tar.lzma .tar.xz)
2023-04-07 13:16:28 +03:00
targets += $( linux-tarballs)
2023-04-19 20:04:24 +03:00
$(linux-tarballs) : archive -args = --prefix =linux / $$( cat $ <)
2023-04-07 13:16:28 +03:00
$(linux-tarballs) : .tmp_HEAD FORCE
2023-04-07 13:16:27 +03:00
$( call if_changed,archive)
2023-02-15 04:20:24 +03:00
2023-07-22 07:48:05 +03:00
# rpm-pkg srcrpm-pkg binrpm-pkg
2006-03-08 20:39:05 +03:00
# ---------------------------------------------------------------------------
2022-11-21 17:48:45 +03:00
2023-07-22 07:48:05 +03:00
quiet_cmd_mkspec = GEN $@
2023-09-30 13:38:47 +03:00
cmd_mkspec = $( srctree) /scripts/package/mkspec $@
2023-07-22 07:48:05 +03:00
2023-09-30 13:38:47 +03:00
rpmbuild/SPECS/kernel.spec : FORCE
2023-07-22 07:48:05 +03:00
$( call cmd,mkspec)
PHONY += rpm-sources
rpm-sources : linux .tar .gz
$( Q) mkdir -p rpmbuild/SOURCES
$( Q) ln -f linux.tar.gz rpmbuild/SOURCES/linux.tar.gz
$( Q) cp $( KCONFIG_CONFIG) rpmbuild/SOURCES/config
$( Q) $( srctree) /scripts/package/gen-diff-patch rpmbuild/SOURCES/diff.patch
PHONY += rpm-pkg srcrpm-pkg binrpm-pkg
rpm-pkg : private build -type := a
srcrpm-pkg : private build -type := s
binrpm-pkg : private build -type := b
rpm-pkg srcrpm-pkg : rpm -sources
2023-09-30 13:38:47 +03:00
rpm-pkg srcrpm-pkg binrpm-pkg : rpmbuild /SPECS /kernel .spec
+$( strip rpmbuild -b$( build-type) rpmbuild/SPECS/kernel.spec \
2023-07-22 07:48:05 +03:00
--define= '_topdir $(abspath rpmbuild)' \
$( if $( filter a b, $( build-type) ) , \
2023-07-22 07:48:06 +03:00
--target $( UTS_MACHINE) -linux --build-in-place --noprep --define= '_smp_mflags %{nil}' \
$$ ( rpm -q rpm >/dev/null 2>& 1 || echo --nodeps) ) \
2023-07-22 07:48:05 +03:00
$( RPMOPTS) )
2017-09-30 04:10:10 +03:00
2023-04-17 17:25:47 +03:00
# deb-pkg srcdeb-pkg bindeb-pkg
# ---------------------------------------------------------------------------
2023-04-17 17:25:48 +03:00
KDEB_SOURCE_COMPRESS ?= gzip
supported-deb-source-compress := gzip bzip2 lzma xz
PHONY += linux.tar.unsupported-deb-src-compress
linux.tar.unsupported-deb-src-compress :
@echo " error: KDEB_SOURCE_COMPRESS= $( KDEB_SOURCE_COMPRESS) is not supported. The supported values are: $( supported-deb-source-compress) " >& 2
@false
debian-orig-suffix := \
$( strip $( if $( filter $( supported-deb-source-compress) , $( KDEB_SOURCE_COMPRESS) ) , \
$( suffix-$( KDEB_SOURCE_COMPRESS) ) ,.unsupported-deb-src-compress) )
2023-02-15 04:20:27 +03:00
quiet_cmd_debianize = GEN $@
kbuild: give up untracked files for source package builds
When the source tree is dirty and contains untracked files, package
builds may fail, for example, when a broken symlink exists, a file
path contains whitespaces, etc.
Since commit 05e96e96a315 ("kbuild: use git-archive for source package
creation"), the source tarball only contains committed files because
it is created by 'git archive'. scripts/package/gen-diff-patch tries
to address the diff from HEAD, but including untracked files by the
hand-crafted script introduces more complexity. I wrote a patch [1] to
make it work in most cases, but still wonder if this is what we should
aim for.
To simplify the code, this patch just gives up untracked files. Going
forward, it is your responsibility to do 'git add' for what you want in
the source package. The script shows a warning just in case you forgot
to do so. It should be checked only when building source packages.
[1]: https://lore.kernel.org/all/CAK7LNAShbZ56gSh9PrbLnBDYKnjtTkHMoCXeGrhcxMvqXGq9=g@mail.gmail.com/2-0001-kbuild-make-package-builds-more-robust.patch
Fixes: 05e96e96a315 ("kbuild: use git-archive for source package creation")
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Reviewed-by: Nicolas Schier <nicolas@fjasle.eu>
2023-04-10 15:09:07 +03:00
cmd_debianize = $( srctree) /scripts/package/mkdebian $( mkdebian-opts)
2023-02-15 04:20:27 +03:00
debian : FORCE
$( call cmd,debianize)
PHONY += debian-orig
debian-orig : private source = $( shell dpkg -parsechangelog -S Source )
debian-orig : private version = $( shell dpkg -parsechangelog -S Version | sed 's /-[^-]*$ $ //')
2023-04-17 17:25:48 +03:00
debian-orig : private orig -name = $( source ) _ $( version ) .orig .tar $( debian -orig -suffix )
kbuild: give up untracked files for source package builds
When the source tree is dirty and contains untracked files, package
builds may fail, for example, when a broken symlink exists, a file
path contains whitespaces, etc.
Since commit 05e96e96a315 ("kbuild: use git-archive for source package
creation"), the source tarball only contains committed files because
it is created by 'git archive'. scripts/package/gen-diff-patch tries
to address the diff from HEAD, but including untracked files by the
hand-crafted script introduces more complexity. I wrote a patch [1] to
make it work in most cases, but still wonder if this is what we should
aim for.
To simplify the code, this patch just gives up untracked files. Going
forward, it is your responsibility to do 'git add' for what you want in
the source package. The script shows a warning just in case you forgot
to do so. It should be checked only when building source packages.
[1]: https://lore.kernel.org/all/CAK7LNAShbZ56gSh9PrbLnBDYKnjtTkHMoCXeGrhcxMvqXGq9=g@mail.gmail.com/2-0001-kbuild-make-package-builds-more-robust.patch
Fixes: 05e96e96a315 ("kbuild: use git-archive for source package creation")
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
Reviewed-by: Nicolas Schier <nicolas@fjasle.eu>
2023-04-10 15:09:07 +03:00
debian-orig : mkdebian -opts = --need -source
2023-04-17 17:25:48 +03:00
debian-orig : linux .tar $( debian -orig -suffix ) debian
2023-02-15 04:20:28 +03:00
$( Q) if [ " $( df --output= target .. 2>/dev/null) " = " $( df --output= target $< 2>/dev/null) " ] ; then \
ln -f $< ../$( orig-name) ; \
else \
cp $< ../$( orig-name) ; \
fi
2023-02-15 04:20:27 +03:00
2023-04-17 17:25:47 +03:00
KBUILD_PKG_ROOTCMD ?= 'fakeroot -u'
PHONY += deb-pkg srcdeb-pkg bindeb-pkg
deb-pkg : private build -type := source , binary
srcdeb-pkg : private build -type := source
bindeb-pkg : private build -type := binary
2015-09-02 12:57:24 +03:00
2023-04-17 17:25:47 +03:00
deb-pkg srcdeb-pkg : debian -orig
2023-02-15 04:20:27 +03:00
bindeb-pkg : debian
2023-04-17 17:25:47 +03:00
deb-pkg srcdeb-pkg bindeb-pkg :
+$( strip dpkg-buildpackage \
--build= $( build-type) --no-pre-clean --unsigned-changes \
$( if $( findstring source, $( build-type) ) , \
2023-04-17 17:25:48 +03:00
--unsigned-source --compression= $( KDEB_SOURCE_COMPRESS) ) \
2023-04-17 17:25:47 +03:00
$( if $( findstring binary, $( build-type) ) , \
kbuild: deb-pkg: support DEB_BUILD_OPTIONS=parallel=N in debian/rules
'make srcdeb-pkg' generates a source package, which you can build
later by using dpkg-buildpackage.
In older dpkg versions, 'dpkg-buildpackage --jobs=N' sets not only
DEB_BUILD_OPTIONS but also MAKEFLAGS. Hence, passing -j or --jobs
to dpkg-buildpackage was enough for kicking the parallel execution.
The behavior was changed by commit 1d0ea9b2ba3f ("dpkg-buildpackage:
Change -j, --jobs semantics to non-force mode") of dpkg project. [1]
Since then, 'dpkg-buildpackage --jobs=N' sets only DEB_BUILD_OPTIONS,
which is not parsed by the current debian/rules. To build the package
in parallel, you need to pass the alternative --jobs-force option or
set the MAKEFLAGS environment variable.
Debian policy [2] suggests the following code snippet for debian/rules.
ifneq (,$(filter parallel=%,$(DEB_BUILD_OPTIONS)))
NUMJOBS = $(patsubst parallel=%,%,$(filter parallel=%,$(DEB_BUILD_OPTIONS)))
MAKEFLAGS += -j$(NUMJOBS)
endif
I tweaked the code to filter out parallel=1 and passed --jobs=1 to
dpkg-buildpackage from scripts/Makefile.package. It is needed to force
'make deb-pkg' without the -j option to run in serial. Please note that
dpkg-buildpackage sets parallel=<nproc> in DEB_BUILD_OPTIONS by default
(that is, --jobs=auto is the default) and --jobs=1 is needed to restore
the serial execution. When dpkg-buildpackage is invoked from Kbuild,
the number of jobs is inherited from the top level Makefile. Passing
--jobs=1 to dpkg-buildpackage allows debian/rules to skip parsing
DEB_BUILD_OPTIONS.
[1] https://salsa.debian.org/dpkg-team/dpkg/-/commit/1d0ea9b2ba3f6a2de5b1a6ff55f3df7b71f73db6
[2] https://www.debian.org/doc/debian-policy/ch-source.html#s-debianrules-options
Reported-by: Bastian Germann <bage@linutronix.de>
Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
2023-08-21 01:18:02 +03:00
--rules-file= '$(MAKE) -f debian/rules' --jobs= 1 -r$( KBUILD_PKG_ROOTCMD) -a$$ ( cat debian/arch) , \
2023-04-17 17:25:47 +03:00
--no-check-builddeps) \
$( DPKG_FLAGS) )
2018-04-05 14:22:29 +03:00
scripts/package: snap-pkg target
Following in footsteps of other targets like 'deb-pkg, 'rpm-pkg' and 'tar-pkg',
this patch adds a 'snap-pkg' target for the creation of a Linux kernel snap
package using the kbuild infrastructure.
A snap, in its general form, is a self contained, sandboxed, universal package
and it is intended to work across multiple distributions and/or devices. A snap
package is distributed as a single compressed squashfs filesystem.
A kernel snap is a snap package carrying the Linux kernel, kernel modules,
accessory files (DTBs, System.map, etc) and a manifesto file. The purpose of a
kernel snap is to carry the Linux kernel during the creation of a system image,
eg. Ubuntu Core, and its subsequent upgrades.
For more information on snap packages: https://snapcraft.io/docs/
Signed-off-by: Paolo Pisati <paolo.pisati@canonical.com>
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
2017-11-27 14:07:34 +03:00
# snap-pkg
# ---------------------------------------------------------------------------
2019-08-21 10:02:03 +03:00
PHONY += snap-pkg
snap-pkg :
scripts/package: snap-pkg target
Following in footsteps of other targets like 'deb-pkg, 'rpm-pkg' and 'tar-pkg',
this patch adds a 'snap-pkg' target for the creation of a Linux kernel snap
package using the kbuild infrastructure.
A snap, in its general form, is a self contained, sandboxed, universal package
and it is intended to work across multiple distributions and/or devices. A snap
package is distributed as a single compressed squashfs filesystem.
A kernel snap is a snap package carrying the Linux kernel, kernel modules,
accessory files (DTBs, System.map, etc) and a manifesto file. The purpose of a
kernel snap is to carry the Linux kernel during the creation of a system image,
eg. Ubuntu Core, and its subsequent upgrades.
For more information on snap packages: https://snapcraft.io/docs/
Signed-off-by: Paolo Pisati <paolo.pisati@canonical.com>
Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
2017-11-27 14:07:34 +03:00
rm -rf $( objtree) /snap
mkdir $( objtree) /snap
$( MAKE) clean
$( call cmd,src_tar,$( KERNELPATH) )
sed " s@KERNELRELEASE@ $( KERNELRELEASE) @; \
s@SRCTREE@$( shell realpath $( KERNELPATH) .tar.gz) @" \
$( srctree) /scripts/package/snapcraft.template > \
$( objtree) /snap/snapcraft.yaml
cd $( objtree) /snap && \
snapcraft --target-arch= $( UTS_MACHINE)
2023-02-15 04:20:31 +03:00
# dir-pkg tar*-pkg - tarball targets
2005-05-24 13:27:37 +04:00
# ---------------------------------------------------------------------------
2023-02-15 04:20:31 +03:00
tar-install : FORCE
$( Q) $( MAKE) -f $( srctree) /Makefile
+$( Q) $( srctree) /scripts/package/buildtar $@
2023-04-07 13:16:29 +03:00
compress-tar.gz = -I " $( KGZIP) "
compress-tar.bz2 = -I " $( KBZIP2) "
compress-tar.xz = -I " $( XZ) "
compress-tar.zst = -I " $( ZSTD) "
2023-03-15 18:50:18 +03:00
quiet_cmd_tar = TAR $@
2023-04-07 13:16:29 +03:00
cmd_tar = cd $<; tar cf ../$@ $( compress-tar$( suffix $@ ) ) --owner= root --group= root --sort= name *
dir-tarballs := $( addprefix linux-$( KERNELRELEASE) -$( ARCH) , .tar .tar.gz .tar.bz2 .tar.xz .tar.zst)
2023-03-15 18:50:18 +03:00
2023-04-07 13:16:29 +03:00
$(dir-tarballs) : tar -install
2023-03-15 18:50:18 +03:00
$( call cmd,tar)
2023-02-15 04:20:31 +03:00
PHONY += dir-pkg
dir-pkg : tar -install
@echo " Kernel tree successfully created in $< "
2023-03-15 18:50:18 +03:00
PHONY += tar-pkg
tar-pkg : linux -$( KERNELRELEASE ) -$( ARCH ) .tar
2023-02-15 04:20:31 +03:00
@:
2023-03-15 18:50:18 +03:00
tar%-pkg : linux -$( KERNELRELEASE ) -$( ARCH ) .tar .% FORCE
@:
2005-05-24 13:27:37 +04:00
2023-02-15 04:20:30 +03:00
# perf-tar*-src-pkg - generate a source tarball with perf source
2010-05-31 18:13:21 +04:00
# ---------------------------------------------------------------------------
2023-03-15 18:50:18 +03:00
.tmp_perf :
$( Q) mkdir .tmp_perf
2023-02-15 04:20:30 +03:00
2023-03-15 18:50:18 +03:00
.tmp_perf/HEAD : .tmp_HEAD | .tmp_perf
$( call cmd,copy)
2023-02-15 04:20:30 +03:00
quiet_cmd_perf_version_file = GEN $@
cmd_perf_version_file = cd $( srctree) /tools/perf; util/PERF-VERSION-GEN $( dir $( abspath $@ ) )
2023-03-15 18:50:18 +03:00
# PERF-VERSION-FILE and .tmp_HEAD are independent, but this avoids updating the
2023-02-15 04:20:30 +03:00
# timestamp of PERF-VERSION-FILE.
# The best is to fix tools/perf/util/PERF-VERSION-GEN.
2023-03-15 18:50:18 +03:00
.tmp_perf/PERF-VERSION-FILE : .tmp_HEAD $( srctree ) /tools /perf /util /PERF -VERSION -GEN | .tmp_perf
2023-02-15 04:20:30 +03:00
$( call cmd,perf_version_file)
2023-04-07 13:16:27 +03:00
perf-archive-args = --add-file= $$ ( realpath $( word 2, $^) ) \
2023-03-15 18:50:18 +03:00
--add-file= $$ ( realpath $( word 3, $^) ) \
$$ ( cat $( word 2, $^) ) ^{ tree} $$ ( cat $<)
2023-02-15 04:20:30 +03:00
2023-04-07 13:16:28 +03:00
perf-tarballs := $( addprefix perf-$( KERNELVERSION) , .tar .tar.gz .tar.bz2 .tar.xz .tar.zst)
targets += $( perf-tarballs)
2023-04-19 20:04:24 +03:00
$(perf-tarballs) : archive -args = --prefix =perf -$( KERNELVERSION ) / $( perf -archive -args )
2023-04-07 13:16:28 +03:00
$(perf-tarballs) : tools /perf /MANIFEST .tmp_perf /HEAD .tmp_perf /PERF -VERSION -FILE FORCE
2023-04-07 13:16:27 +03:00
$( call if_changed,archive)
2023-03-15 18:50:18 +03:00
PHONY += perf-tar-src-pkg
perf-tar-src-pkg : perf -$( KERNELVERSION ) .tar
@:
2023-02-15 04:20:30 +03:00
2023-03-15 18:50:18 +03:00
perf-tar%-src-pkg : perf -$( KERNELVERSION ) .tar .% FORCE
@:
2010-05-31 18:13:21 +04:00
2005-04-17 02:20:36 +04:00
# Help text displayed when executing 'make help'
# ---------------------------------------------------------------------------
2019-08-21 10:02:03 +03:00
PHONY += help
help :
2010-05-31 18:13:21 +04:00
@echo ' rpm-pkg - Build both source and binary RPM kernel packages'
2022-12-27 12:21:57 +03:00
@echo ' srcrpm-pkg - Build only the source kernel RPM package'
2015-09-02 12:57:24 +03:00
@echo ' binrpm-pkg - Build only the binary kernel RPM package'
@echo ' deb-pkg - Build both source and binary deb kernel packages'
2023-04-17 17:25:47 +03:00
@echo ' srcdeb-pkg - Build only the source kernel deb package'
2015-09-02 12:57:24 +03:00
@echo ' bindeb-pkg - Build only the binary kernel deb package'
2019-10-25 14:52:32 +03:00
@echo ' snap-pkg - Build only the binary kernel snap package'
@echo ' (will connect to external hosts)'
2019-11-04 16:11:44 +03:00
@echo ' dir-pkg - Build the kernel as a plain directory structure'
2010-05-31 18:13:21 +04:00
@echo ' tar-pkg - Build the kernel as an uncompressed tarball'
@echo ' targz-pkg - Build the kernel as a gzip compressed tarball'
@echo ' tarbz2-pkg - Build the kernel as a bzip2 compressed tarball'
2011-01-30 14:18:51 +03:00
@echo ' tarxz-pkg - Build the kernel as a xz compressed tarball'
2021-10-08 14:37:59 +03:00
@echo ' tarzst-pkg - Build the kernel as a zstd compressed tarball'
2023-02-15 04:20:30 +03:00
@echo ' perf-tar-src-pkg - Build the perf source tarball with no compression'
@echo ' perf-targz-src-pkg - Build the perf source tarball with gzip compression'
@echo ' perf-tarbz2-src-pkg - Build the perf source tarball with bz2 compression'
@echo ' perf-tarxz-src-pkg - Build the perf source tarball with xz compression'
@echo ' perf-tarzst-src-pkg - Build the perf source tarball with zst compression'
2019-08-21 10:02:04 +03:00
2023-02-15 04:20:24 +03:00
PHONY += FORCE
FORCE :
2023-03-15 18:50:18 +03:00
# Read all saved command lines and dependencies for the $(targets) we
# may be building above, using $(if_changed{,_dep}). As an
# optimization, we don't need to read them if the target does not
# exist, we will rebuild anyway in that case.
existing-targets := $( wildcard $( sort $( targets) ) )
- i n c l u d e $( foreach f ,$ ( existing -targets ) ,$ ( dir $ ( f ) ) .$ ( notdir $ ( f ) ) .cmd )
2019-08-21 10:02:04 +03:00
.PHONY : $( PHONY )