OSDN Git Service

Merge "diag: Read the HSIC data in a work queue"
[sagit-ice-cold/kernel_xiaomi_msm8998.git] / tools / build / Makefile.build
1 ###
2 # Main build makefile.
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 PHONY := __build
12 __build:
13
14 ifeq ($(V),1)
15   quiet =
16   Q =
17 else
18   quiet=quiet_
19   Q=@
20 endif
21
22 ifneq ($(filter 4.%,$(MAKE_VERSION)),)  # make-4
23 ifneq ($(filter %s ,$(firstword x$(MAKEFLAGS))),)
24   quiet=silent_
25 endif
26 else                                    # make-3.8x
27 ifneq ($(filter s% -s%,$(MAKEFLAGS)),)
28   quiet=silent_
29 endif
30 endif
31
32 build-dir := $(srctree)/tools/build
33
34 # Define $(fixdep) for dep-cmd function
35 ifeq ($(OUTPUT),)
36   fixdep := $(build-dir)/fixdep
37 else
38   fixdep := $(OUTPUT)/fixdep
39 endif
40
41 # Generic definitions
42 include $(build-dir)/Build.include
43
44 # do not force detected configuration
45 -include $(OUTPUT).config-detected
46
47 # Init all relevant variables used in build files so
48 # 1) they have correct type
49 # 2) they do not inherit any value from the environment
50 subdir-y     :=
51 obj-y        :=
52 subdir-y     :=
53 subdir-obj-y :=
54
55 # Build definitions
56 build-file := $(dir)/Build
57 -include $(build-file)
58
59 quiet_cmd_flex  = FLEX     $@
60 quiet_cmd_bison = BISON    $@
61
62 # Create directory unless it exists
63 quiet_cmd_mkdir = MKDIR    $(dir $@)
64       cmd_mkdir = mkdir -p $(dir $@)
65      rule_mkdir = $(if $(wildcard $(dir $@)),,@$(call echo-cmd,mkdir) $(cmd_mkdir))
66
67 # Compile command
68 quiet_cmd_cc_o_c = CC       $@
69       cmd_cc_o_c = $(CC) $(c_flags) -c -o $@ $<
70
71 quiet_cmd_cc_i_c = CPP      $@
72       cmd_cc_i_c = $(CC) $(c_flags) -E -o $@ $<
73
74 quiet_cmd_cc_s_c = AS       $@
75       cmd_cc_s_c = $(CC) $(c_flags) -S -o $@ $<
76
77 quiet_cmd_gen = GEN      $@
78
79 # Link agregate command
80 # If there's nothing to link, create empty $@ object.
81 quiet_cmd_ld_multi = LD       $@
82       cmd_ld_multi = $(if $(strip $(obj-y)),\
83                        $(LD) -r -o $@  $(filter $(obj-y),$^),rm -f $@; $(AR) rcs $@)
84
85 # Build rules
86 $(OUTPUT)%.o: %.c FORCE
87         $(call rule_mkdir)
88         $(call if_changed_dep,cc_o_c)
89
90 $(OUTPUT)%.o: %.S FORCE
91         $(call rule_mkdir)
92         $(call if_changed_dep,cc_o_c)
93
94 $(OUTPUT)%.i: %.c FORCE
95         $(call rule_mkdir)
96         $(call if_changed_dep,cc_i_c)
97
98 $(OUTPUT)%.i: %.S FORCE
99         $(call rule_mkdir)
100         $(call if_changed_dep,cc_i_c)
101
102 $(OUTPUT)%.s: %.c FORCE
103         $(call rule_mkdir)
104         $(call if_changed_dep,cc_s_c)
105
106 # Gather build data:
107 #   obj-y        - list of build objects
108 #   subdir-y     - list of directories to nest
109 #   subdir-obj-y - list of directories objects 'dir/$(obj)-in.o'
110 obj-y        := $($(obj)-y)
111 subdir-y     := $(patsubst %/,%,$(filter %/, $(obj-y)))
112 obj-y        := $(patsubst %/, %/$(obj)-in.o, $(obj-y))
113 subdir-obj-y := $(filter %/$(obj)-in.o, $(obj-y))
114
115 # '$(OUTPUT)/dir' prefix to all objects
116 objprefix    := $(subst ./,,$(OUTPUT)$(dir)/)
117 obj-y        := $(addprefix $(objprefix),$(obj-y))
118 subdir-obj-y := $(addprefix $(objprefix),$(subdir-obj-y))
119
120 # Final '$(obj)-in.o' object
121 in-target := $(objprefix)$(obj)-in.o
122
123 PHONY += $(subdir-y)
124
125 $(subdir-y):
126         $(Q)$(MAKE) -f $(build-dir)/Makefile.build dir=$(dir)/$@ obj=$(obj)
127
128 $(sort $(subdir-obj-y)): $(subdir-y) ;
129
130 $(in-target): $(obj-y) FORCE
131         $(call rule_mkdir)
132         $(call if_changed,ld_multi)
133
134 __build: $(in-target)
135         @:
136
137 PHONY += FORCE
138 FORCE:
139
140 # Include all cmd files to get all the dependency rules
141 # for all objects included
142 targets   := $(wildcard $(sort $(obj-y) $(in-target) $(MAKECMDGOALS)))
143 cmd_files := $(wildcard $(foreach f,$(targets),$(dir $(f)).$(notdir $(f)).cmd))
144
145 ifneq ($(cmd_files),)
146   include $(cmd_files)
147 endif
148
149 .PHONY: $(PHONY)