diff options
author | Stephen Warren <swarren@nvidia.com> | 2013-02-05 14:06:28 -0500 |
---|---|---|
committer | Grant Likely <grant.likely@secretlab.ca> | 2013-02-08 09:38:07 -0500 |
commit | 22435f38337ef6a8abb33574604e77c335b75d14 (patch) | |
tree | 74b2748ef47b5f126113911d7585f5b47ab80b2b | |
parent | 1d0b1c74ed22d2614ae9206febf956f0b22c81a5 (diff) |
kbuild: create a rule to run the pre-processor on *.dts files
Create cmd_dtc_cpp to run the C pre-processor on *.dts file before
passing them to dtc for final compilation. This allows the use of #define
and #include within the .dts file.
Acked-by: Simon Glass <sjg@chromium.org>
Acked-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
Acked-by: Michal Marek <mmarek@suse.cz>
Acked-by: Srinivas Kandagatla <srinivas.kandagatla@st.com>
Signed-off-by: Stephen Warren <swarren@nvidia.com>
Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
-rw-r--r-- | Documentation/kbuild/makefiles.txt | 23 | ||||
-rw-r--r-- | scripts/Makefile.lib | 10 |
2 files changed, 33 insertions, 0 deletions
diff --git a/Documentation/kbuild/makefiles.txt b/Documentation/kbuild/makefiles.txt index 14c3f4f1b617..5198b742fde1 100644 --- a/Documentation/kbuild/makefiles.txt +++ b/Documentation/kbuild/makefiles.txt | |||
@@ -1186,6 +1186,29 @@ When kbuild executes, the following steps are followed (roughly): | |||
1186 | clean-files += *.dtb | 1186 | clean-files += *.dtb |
1187 | DTC_FLAGS ?= -p 1024 | 1187 | DTC_FLAGS ?= -p 1024 |
1188 | 1188 | ||
1189 | dtc_cpp | ||
1190 | This is just like dtc as describe above, except that the C pre- | ||
1191 | processor is invoked upon the .dtsp file before compiling the result | ||
1192 | with dtc. | ||
1193 | |||
1194 | In order for build dependencies to work, all files compiled using | ||
1195 | dtc_cpp must use the C pre-processor's #include functionality and not | ||
1196 | dtc's /include/ functionality. | ||
1197 | |||
1198 | Using the C pre-processor allows use of #define to create named | ||
1199 | constants. In turn, the #defines will typically appear in a header | ||
1200 | file, which may be shared with regular C code. Since the dtc language | ||
1201 | represents a data structure rather than code in C syntax, similar | ||
1202 | restrictions are placed on a header file included by a device tree | ||
1203 | file as for a header file included by an assembly language file. | ||
1204 | In particular, the C pre-processor is passed -x assembler-with-cpp, | ||
1205 | which sets macro __ASSEMBLY__. __DTS__ is also set. These allow header | ||
1206 | files to restrict their content to that compatible with device tree | ||
1207 | source. | ||
1208 | |||
1209 | A central rule exists to create $(obj)/%.dtb from $(src)/%.dtsp; | ||
1210 | architecture Makefiles do no need to explicitly write out that rule. | ||
1211 | |||
1189 | --- 6.8 Custom kbuild commands | 1212 | --- 6.8 Custom kbuild commands |
1190 | 1213 | ||
1191 | When kbuild is executing with KBUILD_VERBOSE=0, then only a shorthand | 1214 | When kbuild is executing with KBUILD_VERBOSE=0, then only a shorthand |
diff --git a/scripts/Makefile.lib b/scripts/Makefile.lib index bdf42fdf64c9..7910229ec665 100644 --- a/scripts/Makefile.lib +++ b/scripts/Makefile.lib | |||
@@ -269,6 +269,16 @@ cmd_dtc = $(objtree)/scripts/dtc/dtc -O dtb -o $@ -b 0 $(DTC_FLAGS) -d $(depfile | |||
269 | $(obj)/%.dtb: $(src)/%.dts FORCE | 269 | $(obj)/%.dtb: $(src)/%.dts FORCE |
270 | $(call if_changed_dep,dtc) | 270 | $(call if_changed_dep,dtc) |
271 | 271 | ||
272 | dtc-tmp = $(subst $(comma),_,$(dot-target).dts) | ||
273 | |||
274 | quiet_cmd_dtc_cpp = DTC+CPP $@ | ||
275 | cmd_dtc_cpp = $(CPP) $(cpp_flags) -x assembler-with-cpp -undef -D__DTS__ \ | ||
276 | -o $(dtc-tmp) $< ; \ | ||
277 | $(objtree)/scripts/dtc/dtc -O dtb -o $@ -b 0 $(DTC_FLAGS) $(dtc-tmp) | ||
278 | |||
279 | $(obj)/%.dtb: $(src)/%.dtsp FORCE | ||
280 | $(call if_changed_dep,dtc_cpp) | ||
281 | |||
272 | # Bzip2 | 282 | # Bzip2 |
273 | # --------------------------------------------------------------------------- | 283 | # --------------------------------------------------------------------------- |
274 | 284 | ||