aboutsummaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorH. Peter Anvin <hpa@linux.intel.com>2011-11-11 18:20:34 -0500
committerH. Peter Anvin <hpa@linux.intel.com>2011-11-17 16:14:36 -0500
commitcb97914b04e7b587cf555ec5b1c69d61014f3378 (patch)
treea91957b74fcc9d1305fa9a6ec086e53a893ff9fd /scripts
parentcfcfc9eca2bcbd26a8e206baeb005b055dbf8e37 (diff)
kbuild: Add support for installing generated asm headers
Generated asm headers are supposed to live in arch/*/include/generated/asm, but objhdr-y expect them to live in the same directory they are generated in. Instead of trying to cut that particular Gordian knot, introduce genhdr-y that takes this into account; the sole user of objhdr-y, linux/version.h, should be migrated over at some later date. Suggested-by: David Woodhouse <dwmw2@infradead.org> Acked-by: David Woodhouse <dwmw2@infradead.org> Cc: Sam Ravnborg <sam@ravnborg.org> Cc: Michal Marek <mmarek@suse.cz> Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
Diffstat (limited to 'scripts')
-rw-r--r--scripts/Makefile.headersinst10
1 files changed, 8 insertions, 2 deletions
diff --git a/scripts/Makefile.headersinst b/scripts/Makefile.headersinst
index a57f5bd5a13d..d3bae5e7b601 100644
--- a/scripts/Makefile.headersinst
+++ b/scripts/Makefile.headersinst
@@ -4,12 +4,16 @@
4# header-y - list files to be installed. They are preprocessed 4# header-y - list files to be installed. They are preprocessed
5# to remove __KERNEL__ section of the file 5# to remove __KERNEL__ section of the file
6# objhdr-y - Same as header-y but for generated files 6# objhdr-y - Same as header-y but for generated files
7# genhdr-y - Same as objhdr-y but in a generated/ directory
7# 8#
8# ========================================================================== 9# ==========================================================================
9 10
10# called may set destination dir (when installing to asm/) 11# called may set destination dir (when installing to asm/)
11_dst := $(if $(dst),$(dst),$(obj)) 12_dst := $(if $(dst),$(dst),$(obj))
12 13
14# generated header directory
15gen := $(if $(gen),$(gen),$(subst include/,include/generated/,$(obj)))
16
13kbuild-file := $(srctree)/$(obj)/Kbuild 17kbuild-file := $(srctree)/$(obj)/Kbuild
14include $(kbuild-file) 18include $(kbuild-file)
15 19
@@ -33,9 +37,10 @@ wrapper-files := $(filter $(header-y), $(generic-y))
33 37
34# all headers files for this dir 38# all headers files for this dir
35header-y := $(filter-out $(generic-y), $(header-y)) 39header-y := $(filter-out $(generic-y), $(header-y))
36all-files := $(header-y) $(objhdr-y) $(wrapper-files) 40all-files := $(header-y) $(objhdr-y) $(genhdr-y) $(wrapper-files)
37input-files := $(addprefix $(srctree)/$(obj)/,$(header-y)) \ 41input-files := $(addprefix $(srctree)/$(obj)/,$(header-y)) \
38 $(addprefix $(objtree)/$(obj)/,$(objhdr-y)) 42 $(addprefix $(objtree)/$(obj)/,$(objhdr-y)) \
43 $(addprefix $(objtree)/$(gen)/,$(genhdr-y))
39output-files := $(addprefix $(install)/, $(all-files)) 44output-files := $(addprefix $(install)/, $(all-files))
40 45
41# Work out what needs to be removed 46# Work out what needs to be removed
@@ -52,6 +57,7 @@ quiet_cmd_install = INSTALL $(printdir) ($(words $(all-files))\
52 cmd_install = \ 57 cmd_install = \
53 $(PERL) $< $(srctree)/$(obj) $(install) $(SRCARCH) $(header-y); \ 58 $(PERL) $< $(srctree)/$(obj) $(install) $(SRCARCH) $(header-y); \
54 $(PERL) $< $(objtree)/$(obj) $(install) $(SRCARCH) $(objhdr-y); \ 59 $(PERL) $< $(objtree)/$(obj) $(install) $(SRCARCH) $(objhdr-y); \
60 $(PERL) $< $(objtree)/$(gen) $(install) $(SRCARCH) $(genhdr-y); \
55 for F in $(wrapper-files); do \ 61 for F in $(wrapper-files); do \
56 echo "\#include <asm-generic/$$F>" > $(install)/$$F; \ 62 echo "\#include <asm-generic/$$F>" > $(install)/$$F; \
57 done; \ 63 done; \