2
2
# Makefile for the different targets used to generate full packages of a kernel
3
3
4
4
include $(srctree)/scripts/Kbuild.include
5
+ include $(srctree)/scripts/Makefile.lib
5
6
6
7
KERNELPATH := kernel-$(subst -,_,$(KERNELRELEASE))
7
8
KBUILD_PKG_ROOTCMD ?="fakeroot -u"
@@ -26,54 +27,46 @@ fi ; \
26
27
tar -I $(KGZIP) -c $(RCS_TAR_IGNORE) -f $(2).tar.gz \
27
28
--transform 's:^:$(2)/:S' $(TAR_CONTENT) $(3)
28
29
29
- # .tmp_filelist .tmp_filelist_exclude
30
+ # tarball compression
30
31
# ---------------------------------------------------------------------------
31
32
32
- scripts/list-gitignored: FORCE
33
- $(Q)$(MAKE) -f $(srctree)/Makefile scripts_package
33
+ %.tar.gz: %.tar
34
+ $(call cmd,gzip)
34
35
35
- # 1f5d3a6b6532e25a5cdf1f311956b2b03d343a48 removed '*.rej' from .gitignore,
36
- # but it is definitely a generated file.
37
- filechk_filelist = \
38
- $< --exclude='*.rej' --output=$@_exclude --prefix=./ --rootdir=$(srctree) --stat=-
36
+ %.tar.bz2: %.tar
37
+ $(call cmd,bzip2)
39
38
40
- .tmp_filelist: scripts/list-gitignored FORCE
41
- $(call filechk,filelist )
39
+ %.tar.xz: %.tar
40
+ $(call cmd,xzmisc )
42
41
43
- # tarball
44
- # ---------------------------------------------------------------------------
45
-
46
- quiet_cmd_tar = TAR $@
47
- cmd_tar = tar -c -f $@ $(tar-compress-opt) $(tar-exclude-opt) \
48
- --owner=0 --group=0 --sort=name \
49
- --transform 's:^\.:$*:S' -C $(tar-rootdir) .
50
-
51
- tar-rootdir := $(srctree)
42
+ %.tar.zst: %.tar
43
+ $(call cmd,zstd)
52
44
53
- %.tar:
54
- $(call cmd,tar)
55
-
56
- %.tar.gz: private tar-compress-opt := -I $(KGZIP)
57
- %.tar.gz:
58
- $(call cmd,tar)
45
+ # Git
46
+ # ---------------------------------------------------------------------------
59
47
60
- %.tar.bz2: private tar-compress-opt := -I $(KBZIP2)
61
- %.tar.bz2:
62
- $(call cmd,tar)
48
+ filechk_HEAD = git -C $(srctree) rev-parse --verify HEAD 2>/dev/null
63
49
64
- %.tar.xz: private tar-compress-opt := -I $(XZ)
65
- %.tar.xz:
66
- $(call cmd,tar)
50
+ .tmp_HEAD: check-git FORCE
51
+ $(call filechk,HEAD)
67
52
68
- %.tar.zst: private tar-compress-opt := -I $(ZSTD)
69
- %.tar.zst:
70
- $(call cmd,tar)
53
+ PHONY += check-git
54
+ check-git:
55
+ @if ! $(srctree)/scripts/check-git; then \
56
+ echo >&2 "error: creating source package requires git repository"; \
57
+ false; \
58
+ fi
71
59
72
60
# Linux source tarball
73
61
# ---------------------------------------------------------------------------
74
62
75
- linux.tar.gz: tar-exclude-opt = --exclude=./$@ --exclude-from=$<_exclude
76
- linux.tar.gz: .tmp_filelist
63
+ quiet_cmd_archive_linux = ARCHIVE $@
64
+ cmd_archive_linux = \
65
+ git -C $(srctree) archive --output=$$(realpath $@) --prefix=$(basename $@)/ $$(cat $<)
66
+
67
+ targets += linux.tar
68
+ linux.tar: .tmp_HEAD FORCE
69
+ $(call if_changed,archive_linux)
77
70
78
71
# rpm-pkg
79
72
# ---------------------------------------------------------------------------
@@ -148,74 +141,62 @@ snap-pkg:
148
141
# dir-pkg tar*-pkg - tarball targets
149
142
# ---------------------------------------------------------------------------
150
143
151
- tar-pkg-tarball = linux-$(KERNELRELEASE)-$(ARCH).$(1)
152
- tar-pkg-phony = $(subst .,,$(1))-pkg
153
-
154
144
tar-install: FORCE
155
145
$(Q)$(MAKE) -f $(srctree)/Makefile
156
146
+$(Q)$(srctree)/scripts/package/buildtar $@
157
147
148
+ quiet_cmd_tar = TAR $@
149
+ cmd_tar = cd $<; tar cf ../$@ --owner=root --group=root --sort=name *
150
+
151
+ linux-$(KERNELRELEASE)-$(ARCH).tar: tar-install
152
+ $(call cmd,tar)
153
+
158
154
PHONY += dir-pkg
159
155
dir-pkg: tar-install
160
156
@echo "Kernel tree successfully created in $<"
161
157
162
- define tar-pkg-rule
163
- PHONY += $(tar-pkg-phony)
164
- $(tar-pkg-phony): $(tar-pkg-tarball)
158
+ PHONY += tar-pkg
159
+ tar-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar
165
160
@:
166
161
167
- $(tar-pkg-tarball): private tar-rootdir := tar-install
168
- $(tar-pkg-tarball): tar-install
169
- endef
170
-
171
- $(foreach x, tar tar.gz tar.bz2 tar.xz tar.zst, $(eval $(call tar-pkg-rule,$(x))))
162
+ tar%-pkg: linux-$(KERNELRELEASE)-$(ARCH).tar.% FORCE
163
+ @:
172
164
173
165
# perf-tar*-src-pkg - generate a source tarball with perf source
174
166
# ---------------------------------------------------------------------------
175
167
176
- perf-tar-src-pkg-tarball = perf-$(KERNELVERSION).$(1)
177
- perf-tar-src-pkg-phony = perf-$(subst .,,$(1))-src-pkg
178
-
179
- quiet_cmd_stage_perf_src = STAGE $@
180
- cmd_stage_perf_src = \
181
- rm -rf $@; \
182
- mkdir -p $@; \
183
- tar -c -f - --exclude-from=$<_exclude -C $(srctree) --files-from=$(srctree)/tools/perf/MANIFEST | \
184
- tar -x -f - -C $@
185
-
186
- .tmp_perf: .tmp_filelist
187
- $(call cmd,stage_perf_src)
188
-
189
- filechk_perf_head = \
190
- if test -z "$(git -C $(srctree) rev-parse --show-cdup 2>/dev/null)" && \
191
- head=$$(git -C $(srctree) rev-parse --verify HEAD 2>/dev/null); then \
192
- echo $$head; \
193
- else \
194
- echo "not a git tree"; \
195
- fi
168
+ .tmp_perf:
169
+ $(Q)mkdir .tmp_perf
196
170
197
- .tmp_perf/HEAD: .tmp_perf FORCE
198
- $(call filechk,perf_head )
171
+ .tmp_perf/HEAD: .tmp_HEAD | .tmp_perf
172
+ $(call cmd,copy )
199
173
200
174
quiet_cmd_perf_version_file = GEN $@
201
175
cmd_perf_version_file = cd $(srctree)/tools/perf; util/PERF-VERSION-GEN $(dir $(abspath $@))
202
176
203
- # PERF-VERSION-FILE and HEAD are independent, but this avoids updating the
177
+ # PERF-VERSION-FILE and .tmp_HEAD are independent, but this avoids updating the
204
178
# timestamp of PERF-VERSION-FILE.
205
179
# The best is to fix tools/perf/util/PERF-VERSION-GEN.
206
- .tmp_perf/PERF-VERSION-FILE: .tmp_perf/HEAD $(srctree)/tools/perf/util/PERF-VERSION-GEN
180
+ .tmp_perf/PERF-VERSION-FILE: .tmp_HEAD $(srctree)/tools/perf/util/PERF-VERSION-GEN | .tmp_perf
207
181
$(call cmd,perf_version_file)
208
182
209
- define perf-tar-src-pkg-rule
210
- PHONY += $(perf-tar-src-pkg-phony)
211
- $(perf-tar-src-pkg-phony): $(perf-tar-src-pkg-tarball)
212
- @:
183
+ quiet_cmd_archive_perf = ARCHIVE $@
184
+ cmd_archive_perf = \
185
+ git -C $(srctree) archive --output=$$(realpath $@) --prefix=$(basename $@)/ \
186
+ --add-file=$$(realpath $(word 2, $^)) \
187
+ --add-file=$$(realpath $(word 3, $^)) \
188
+ $$(cat $(word 2, $^))^{tree} $$(cat $<)
213
189
214
- $(perf-tar-src-pkg-tarball): private tar-rootdir := .tmp_perf
215
- $(perf-tar-src-pkg-tarball): .tmp_filelist .tmp_perf/HEAD .tmp_perf/PERF-VERSION-FILE
216
- endef
190
+ targets += perf-$(KERNELVERSION).tar
191
+ perf-$(KERNELVERSION).tar: tools/perf/MANIFEST .tmp_perf/HEAD .tmp_perf/PERF-VERSION-FILE FORCE
192
+ $(call if_changed,archive_perf)
193
+
194
+ PHONY += perf-tar-src-pkg
195
+ perf-tar-src-pkg: perf-$(KERNELVERSION).tar
196
+ @:
217
197
218
- $(foreach x, tar tar.gz tar.bz2 tar.xz tar.zst, $(eval $(call perf-tar-src-pkg-rule,$(x))))
198
+ perf-tar%-src-pkg: perf-$(KERNELVERSION).tar.% FORCE
199
+ @:
219
200
220
201
# Help text displayed when executing 'make help'
221
202
# ---------------------------------------------------------------------------
@@ -243,4 +224,13 @@ help:
243
224
PHONY += FORCE
244
225
FORCE:
245
226
227
+ # Read all saved command lines and dependencies for the $(targets) we
228
+ # may be building above, using $(if_changed{,_dep}). As an
229
+ # optimization, we don't need to read them if the target does not
230
+ # exist, we will rebuild anyway in that case.
231
+
232
+ existing-targets := $(wildcard $(sort $(targets)))
233
+
234
+ -include $(foreach f,$(existing-targets),$(dir $(f)).$(notdir $(f)).cmd)
235
+
246
236
.PHONY: $(PHONY)
0 commit comments