diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-05-07 10:59:19 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-05-07 10:59:19 -0400 |
| commit | b9e306e07ed58fc354bbd58124b281dd7dc697b7 (patch) | |
| tree | 2fb12d74fad1396ada7d8baf5b5c378b4363e9e5 /scripts/package/Makefile | |
| parent | 685e56d2943bb8bf3b641d85b1b6c69d24f7965f (diff) | |
| parent | a0f9c6f202962d4ca8150730e55bc34021dfebcc (diff) | |
Merge branch 'misc' of git://git.kernel.org/pub/scm/linux/kernel/git/mmarek/kbuild
Pull misc kbuild updates from Michal Marek:
"Non-critical kbuild changes:
- make coccicheck improvements, but no new semantic patches this time
- make rpm improvements
- make tar-pkg change to include the architecture in the filename.
This is a deliberate incompatibility, but nobody has complained so
far and it is useful if you build for different architectures. It
also matches what the deb-pkg and rpm-pkg targets produce.
- kbuild documentation fix"
* 'misc' of git://git.kernel.org/pub/scm/linux/kernel/git/mmarek/kbuild:
rpm-pkg: Remove pointless set -e statements
rpm-pkg: Always regenerate the specfile
rpm-pkg: Do not write to the parent directory
rpm-pkg: Do not package the whole source directory
buildtar: Add ARCH to the archive name
Coccinelle: Fix patch output when coccicheck is used with M= and C=
Coccinelle: Add support to the SPFLAGS variable
Coccinelle: Cleanup the setting of the FLAGS and OPTIONS variables
Coccinelle: Restore coccicheck verbosity in ONLINE mode (C=1 or C=2)
scripts/package/Makefile: compare objtree with srctree instead of test KBUILD_OUTPUT
doc: change example to existing Makefile fragment
scripts/tags.sh: Add magic for OFFSET and DEFINE
Diffstat (limited to 'scripts/package/Makefile')
| -rw-r--r-- | scripts/package/Makefile | 39 |
1 files changed, 15 insertions, 24 deletions
diff --git a/scripts/package/Makefile b/scripts/package/Makefile index 87bf08076b11..84a406070f6f 100644 --- a/scripts/package/Makefile +++ b/scripts/package/Makefile | |||
| @@ -27,53 +27,44 @@ RPM := $(shell if [ -x "/usr/bin/rpmbuild" ]; then echo rpmbuild; \ | |||
| 27 | 27 | ||
| 28 | # Remove hyphens since they have special meaning in RPM filenames | 28 | # Remove hyphens since they have special meaning in RPM filenames |
| 29 | KERNELPATH := kernel-$(subst -,_,$(KERNELRELEASE)) | 29 | KERNELPATH := kernel-$(subst -,_,$(KERNELRELEASE)) |
| 30 | # Include only those top-level files that are needed by make, plus the GPL copy | ||
| 31 | TAR_CONTENT := $(KBUILD_ALLDIRS) kernel.spec .config .scmversion Makefile \ | ||
| 32 | Kbuild Kconfig COPYING $(wildcard localversion*) | ||
| 33 | TAR_CONTENT := $(addprefix $(KERNELPATH)/,$(TAR_CONTENT)) | ||
| 30 | MKSPEC := $(srctree)/scripts/package/mkspec | 34 | MKSPEC := $(srctree)/scripts/package/mkspec |
| 31 | PREV := set -e; cd -P ..; | ||
| 32 | 35 | ||
| 33 | # rpm-pkg | 36 | # rpm-pkg |
| 34 | # --------------------------------------------------------------------------- | 37 | # --------------------------------------------------------------------------- |
| 35 | $(objtree)/kernel.spec: $(MKSPEC) $(srctree)/Makefile | 38 | rpm-pkg rpm: FORCE |
| 36 | $(CONFIG_SHELL) $(MKSPEC) > $@ | 39 | @if test "$(objtree)" != "$(srctree)"; then \ |
| 37 | |||
| 38 | rpm-pkg rpm: $(objtree)/kernel.spec FORCE | ||
| 39 | @if test -n "$(KBUILD_OUTPUT)"; then \ | ||
| 40 | echo "Building source + binary RPM is not possible outside the"; \ | 40 | echo "Building source + binary RPM is not possible outside the"; \ |
| 41 | echo "kernel source tree. Don't set KBUILD_OUTPUT, or use the"; \ | 41 | echo "kernel source tree. Don't set KBUILD_OUTPUT, or use the"; \ |
| 42 | echo "binrpm-pkg target instead."; \ | 42 | echo "binrpm-pkg target instead."; \ |
| 43 | false; \ | 43 | false; \ |
| 44 | fi | 44 | fi |
| 45 | $(MAKE) clean | 45 | $(MAKE) clean |
| 46 | $(PREV) ln -sf $(srctree) $(KERNELPATH) | 46 | ln -sf $(srctree) $(KERNELPATH) |
| 47 | $(CONFIG_SHELL) $(MKSPEC) >$(objtree)/kernel.spec | ||
| 47 | $(CONFIG_SHELL) $(srctree)/scripts/setlocalversion --save-scmversion | 48 | $(CONFIG_SHELL) $(srctree)/scripts/setlocalversion --save-scmversion |
| 48 | $(PREV) tar -cz $(RCS_TAR_IGNORE) -f $(KERNELPATH).tar.gz $(KERNELPATH)/. | 49 | tar -cz $(RCS_TAR_IGNORE) -f $(KERNELPATH).tar.gz $(TAR_CONTENT) |
| 49 | $(PREV) rm $(KERNELPATH) | 50 | rm $(KERNELPATH) |
| 50 | rm -f $(objtree)/.scmversion | 51 | rm -f $(objtree)/.scmversion |
| 51 | set -e; \ | ||
| 52 | $(CONFIG_SHELL) $(srctree)/scripts/mkversion > $(objtree)/.tmp_version | 52 | $(CONFIG_SHELL) $(srctree)/scripts/mkversion > $(objtree)/.tmp_version |
| 53 | set -e; \ | ||
| 54 | mv -f $(objtree)/.tmp_version $(objtree)/.version | 53 | mv -f $(objtree)/.tmp_version $(objtree)/.version |
| 55 | 54 | $(RPM) $(RPMOPTS) --target $(UTS_MACHINE) -ta $(KERNELPATH).tar.gz | |
| 56 | $(RPM) $(RPMOPTS) --target $(UTS_MACHINE) -ta ../$(KERNELPATH).tar.gz | 55 | rm $(KERNELPATH).tar.gz kernel.spec |
| 57 | rm ../$(KERNELPATH).tar.gz | ||
| 58 | |||
| 59 | clean-files := $(objtree)/kernel.spec | ||
| 60 | 56 | ||
| 61 | # binrpm-pkg | 57 | # binrpm-pkg |
| 62 | # --------------------------------------------------------------------------- | 58 | # --------------------------------------------------------------------------- |
| 63 | $(objtree)/binkernel.spec: $(MKSPEC) $(srctree)/Makefile | 59 | binrpm-pkg: FORCE |
| 64 | $(CONFIG_SHELL) $(MKSPEC) prebuilt > $@ | ||
| 65 | |||
| 66 | binrpm-pkg: $(objtree)/binkernel.spec FORCE | ||
| 67 | $(MAKE) KBUILD_SRC= | 60 | $(MAKE) KBUILD_SRC= |
| 68 | set -e; \ | 61 | $(CONFIG_SHELL) $(MKSPEC) prebuilt > $(objtree)/binkernel.spec |
| 69 | $(CONFIG_SHELL) $(srctree)/scripts/mkversion > $(objtree)/.tmp_version | 62 | $(CONFIG_SHELL) $(srctree)/scripts/mkversion > $(objtree)/.tmp_version |
| 70 | set -e; \ | ||
| 71 | mv -f $(objtree)/.tmp_version $(objtree)/.version | 63 | mv -f $(objtree)/.tmp_version $(objtree)/.version |
| 72 | 64 | ||
| 73 | $(RPM) $(RPMOPTS) --define "_builddir $(objtree)" --target \ | 65 | $(RPM) $(RPMOPTS) --define "_builddir $(objtree)" --target \ |
| 74 | $(UTS_MACHINE) -bb $< | 66 | $(UTS_MACHINE) -bb $< |
| 75 | 67 | rm binkernel.spec | |
| 76 | clean-files += $(objtree)/binkernel.spec | ||
| 77 | 68 | ||
| 78 | # Deb target | 69 | # Deb target |
| 79 | # --------------------------------------------------------------------------- | 70 | # --------------------------------------------------------------------------- |
