diff options
Diffstat (limited to 'tools/build/Build.include')
| -rw-r--r-- | tools/build/Build.include | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/tools/build/Build.include b/tools/build/Build.include new file mode 100644 index 000000000000..4c8daaccb82a --- /dev/null +++ b/tools/build/Build.include | |||
| @@ -0,0 +1,81 @@ | |||
| 1 | ### | ||
| 2 | # build: Generic definitions | ||
| 3 | # | ||
| 4 | # Lots of this code have been borrowed or heavily inspired from parts | ||
| 5 | # of kbuild code, which is not credited, but mostly developed by: | ||
| 6 | # | ||
| 7 | # Copyright (C) Sam Ravnborg <sam@mars.ravnborg.org>, 2015 | ||
| 8 | # Copyright (C) Linus Torvalds <torvalds@linux-foundation.org>, 2015 | ||
| 9 | # | ||
| 10 | |||
| 11 | ### | ||
| 12 | # Convenient variables | ||
| 13 | comma := , | ||
| 14 | squote := ' | ||
| 15 | |||
| 16 | ### | ||
| 17 | # Name of target with a '.' as filename prefix. foo/bar.o => foo/.bar.o | ||
| 18 | dot-target = $(dir $@).$(notdir $@) | ||
| 19 | |||
| 20 | ### | ||
| 21 | # filename of target with directory and extension stripped | ||
| 22 | basetarget = $(basename $(notdir $@)) | ||
| 23 | |||
| 24 | ### | ||
| 25 | # The temporary file to save gcc -MD generated dependencies must not | ||
| 26 | # contain a comma | ||
| 27 | depfile = $(subst $(comma),_,$(dot-target).d) | ||
| 28 | |||
| 29 | ### | ||
| 30 | # Check if both arguments has same arguments. Result is empty string if equal. | ||
| 31 | arg-check = $(strip $(filter-out $(cmd_$(1)), $(cmd_$@)) \ | ||
| 32 | $(filter-out $(cmd_$@), $(cmd_$(1))) ) | ||
| 33 | |||
| 34 | ### | ||
| 35 | # Escape single quote for use in echo statements | ||
| 36 | escsq = $(subst $(squote),'\$(squote)',$1) | ||
| 37 | |||
| 38 | # Echo command | ||
| 39 | # Short version is used, if $(quiet) equals `quiet_', otherwise full one. | ||
| 40 | echo-cmd = $(if $($(quiet)cmd_$(1)),\ | ||
| 41 | echo ' $(call escsq,$($(quiet)cmd_$(1)))';) | ||
| 42 | |||
| 43 | ### | ||
| 44 | # Replace >$< with >$$< to preserve $ when reloading the .cmd file | ||
| 45 | # (needed for make) | ||
| 46 | # Replace >#< with >\#< to avoid starting a comment in the .cmd file | ||
| 47 | # (needed for make) | ||
| 48 | # Replace >'< with >'\''< to be able to enclose the whole string in '...' | ||
| 49 | # (needed for the shell) | ||
| 50 | make-cmd = $(call escsq,$(subst \#,\\\#,$(subst $$,$$$$,$(cmd_$(1))))) | ||
| 51 | |||
| 52 | ### | ||
| 53 | # Find any prerequisites that is newer than target or that does not exist. | ||
| 54 | # PHONY targets skipped in both cases. | ||
| 55 | any-prereq = $(filter-out $(PHONY),$?) $(filter-out $(PHONY) $(wildcard $^),$^) | ||
| 56 | |||
| 57 | ### | ||
| 58 | # if_changed_dep - execute command if any prerequisite is newer than | ||
| 59 | # target, or command line has changed and update | ||
| 60 | # dependencies in the cmd file | ||
| 61 | if_changed_dep = $(if $(strip $(any-prereq) $(arg-check)), \ | ||
| 62 | @set -e; \ | ||
| 63 | $(echo-cmd) $(cmd_$(1)); \ | ||
| 64 | cat $(depfile) > $(dot-target).cmd; \ | ||
| 65 | printf '%s\n' 'cmd_$@ := $(make-cmd)' >> $(dot-target).cmd) | ||
| 66 | |||
| 67 | # if_changed - execute command if any prerequisite is newer than | ||
| 68 | # target, or command line has changed | ||
| 69 | if_changed = $(if $(strip $(any-prereq) $(arg-check)), \ | ||
| 70 | @set -e; \ | ||
| 71 | $(echo-cmd) $(cmd_$(1)); \ | ||
| 72 | printf '%s\n' 'cmd_$@ := $(make-cmd)' > $(dot-target).cmd) | ||
| 73 | |||
| 74 | ### | ||
| 75 | # C flags to be used in rule definitions, includes: | ||
| 76 | # - depfile generation | ||
| 77 | # - global $(CFLAGS) | ||
| 78 | # - per target C flags | ||
| 79 | # - per object C flags | ||
| 80 | # - BUILD_STR macro to allow '-D"$(variable)"' constructs | ||
| 81 | c_flags = -Wp,-MD,$(depfile),-MT,$@ $(CFLAGS) -D"BUILD_STR(s)=\#s" $(CFLAGS_$(basetarget).o) $(CFLAGS_$(obj)) | ||
