diff options
| author | Sam Ravnborg <sam@ravnborg.org> | 2007-05-06 03:23:45 -0400 |
|---|---|---|
| committer | Sam Ravnborg <sam@ravnborg.org> | 2007-05-06 03:23:45 -0400 |
| commit | 767e581d759fe6adfef5e676cd1cd8e11f603d1a (patch) | |
| tree | f208026e00ace8ba32cc4f9c1fc6168af329c167 /scripts | |
| parent | 5447d34b080a1e3e312b05a91e87eff4710a1152 (diff) | |
kbuild: enable use of code from a different dir
To introduce support for source in one directory but output files
in another directory during a non O= build prefix all paths
with $(src) repsectively $(obj).
Signed-off-by: Sam Ravnborg <sam@ravnborg.org>
Diffstat (limited to 'scripts')
| -rw-r--r-- | scripts/Makefile.build | 19 | ||||
| -rw-r--r-- | scripts/Makefile.host | 14 |
2 files changed, 16 insertions, 17 deletions
diff --git a/scripts/Makefile.build b/scripts/Makefile.build index e2ad2dccccdb..a525112847fd 100644 --- a/scripts/Makefile.build +++ b/scripts/Makefile.build | |||
| @@ -131,13 +131,13 @@ $(multi-objs-y:.o=.lst) : modname = $(modname-multi) | |||
| 131 | quiet_cmd_cc_s_c = CC $(quiet_modtag) $@ | 131 | quiet_cmd_cc_s_c = CC $(quiet_modtag) $@ |
| 132 | cmd_cc_s_c = $(CC) $(c_flags) -fverbose-asm -S -o $@ $< | 132 | cmd_cc_s_c = $(CC) $(c_flags) -fverbose-asm -S -o $@ $< |
| 133 | 133 | ||
| 134 | %.s: %.c FORCE | 134 | $(obj)/%.s: $(src)/%.c FORCE |
| 135 | $(call if_changed_dep,cc_s_c) | 135 | $(call if_changed_dep,cc_s_c) |
| 136 | 136 | ||
| 137 | quiet_cmd_cc_i_c = CPP $(quiet_modtag) $@ | 137 | quiet_cmd_cc_i_c = CPP $(quiet_modtag) $@ |
| 138 | cmd_cc_i_c = $(CPP) $(c_flags) -o $@ $< | 138 | cmd_cc_i_c = $(CPP) $(c_flags) -o $@ $< |
| 139 | 139 | ||
| 140 | %.i: %.c FORCE | 140 | $(obj)/%.i: $(src)/%.c FORCE |
| 141 | $(call if_changed_dep,cc_i_c) | 141 | $(call if_changed_dep,cc_i_c) |
| 142 | 142 | ||
| 143 | quiet_cmd_cc_symtypes_c = SYM $(quiet_modtag) $@ | 143 | quiet_cmd_cc_symtypes_c = SYM $(quiet_modtag) $@ |
| @@ -146,7 +146,7 @@ cmd_cc_symtypes_c = \ | |||
| 146 | | $(GENKSYMS) -T $@ >/dev/null; \ | 146 | | $(GENKSYMS) -T $@ >/dev/null; \ |
| 147 | test -s $@ || rm -f $@ | 147 | test -s $@ || rm -f $@ |
| 148 | 148 | ||
| 149 | %.symtypes : %.c FORCE | 149 | $(obj)/%.symtypes : $(src)/%.c FORCE |
| 150 | $(call if_changed_dep,cc_symtypes_c) | 150 | $(call if_changed_dep,cc_symtypes_c) |
| 151 | 151 | ||
| 152 | # C (.c) files | 152 | # C (.c) files |
| @@ -198,14 +198,13 @@ define rule_cc_o_c | |||
| 198 | endef | 198 | endef |
| 199 | 199 | ||
| 200 | # Built-in and composite module parts | 200 | # Built-in and composite module parts |
| 201 | 201 | $(obj)/%.o: $(src)/%.c FORCE | |
| 202 | %.o: %.c FORCE | ||
| 203 | $(call cmd,force_checksrc) | 202 | $(call cmd,force_checksrc) |
| 204 | $(call if_changed_rule,cc_o_c) | 203 | $(call if_changed_rule,cc_o_c) |
| 205 | 204 | ||
| 206 | # Single-part modules are special since we need to mark them in $(MODVERDIR) | 205 | # Single-part modules are special since we need to mark them in $(MODVERDIR) |
| 207 | 206 | ||
| 208 | $(single-used-m): %.o: %.c FORCE | 207 | $(single-used-m): $(obj)/%.o: $(src)/%.c FORCE |
| 209 | $(call cmd,force_checksrc) | 208 | $(call cmd,force_checksrc) |
| 210 | $(call if_changed_rule,cc_o_c) | 209 | $(call if_changed_rule,cc_o_c) |
| 211 | @{ echo $(@:.o=.ko); echo $@; } > $(MODVERDIR)/$(@F:.o=.mod) | 210 | @{ echo $(@:.o=.ko); echo $@; } > $(MODVERDIR)/$(@F:.o=.mod) |
| @@ -215,7 +214,7 @@ quiet_cmd_cc_lst_c = MKLST $@ | |||
| 215 | $(CONFIG_SHELL) $(srctree)/scripts/makelst $*.o \ | 214 | $(CONFIG_SHELL) $(srctree)/scripts/makelst $*.o \ |
| 216 | System.map $(OBJDUMP) > $@ | 215 | System.map $(OBJDUMP) > $@ |
| 217 | 216 | ||
| 218 | %.lst: %.c FORCE | 217 | $(obj)/%.lst: $(src)/%.c FORCE |
| 219 | $(call if_changed_dep,cc_lst_c) | 218 | $(call if_changed_dep,cc_lst_c) |
| 220 | 219 | ||
| 221 | # Compile assembler sources (.S) | 220 | # Compile assembler sources (.S) |
| @@ -229,13 +228,13 @@ $(real-objs-m:.o=.s): modkern_aflags := $(AFLAGS_MODULE) | |||
| 229 | quiet_cmd_as_s_S = CPP $(quiet_modtag) $@ | 228 | quiet_cmd_as_s_S = CPP $(quiet_modtag) $@ |
| 230 | cmd_as_s_S = $(CPP) $(a_flags) -o $@ $< | 229 | cmd_as_s_S = $(CPP) $(a_flags) -o $@ $< |
| 231 | 230 | ||
| 232 | %.s: %.S FORCE | 231 | $(obj)/%.s: $(src)/%.S FORCE |
| 233 | $(call if_changed_dep,as_s_S) | 232 | $(call if_changed_dep,as_s_S) |
| 234 | 233 | ||
| 235 | quiet_cmd_as_o_S = AS $(quiet_modtag) $@ | 234 | quiet_cmd_as_o_S = AS $(quiet_modtag) $@ |
| 236 | cmd_as_o_S = $(CC) $(a_flags) -c -o $@ $< | 235 | cmd_as_o_S = $(CC) $(a_flags) -c -o $@ $< |
| 237 | 236 | ||
| 238 | %.o: %.S FORCE | 237 | $(obj)/%.o: $(src)/%.S FORCE |
| 239 | $(call if_changed_dep,as_o_S) | 238 | $(call if_changed_dep,as_o_S) |
| 240 | 239 | ||
| 241 | targets += $(real-objs-y) $(real-objs-m) $(lib-y) | 240 | targets += $(real-objs-y) $(real-objs-m) $(lib-y) |
| @@ -246,7 +245,7 @@ targets += $(extra-y) $(MAKECMDGOALS) $(always) | |||
| 246 | quiet_cmd_cpp_lds_S = LDS $@ | 245 | quiet_cmd_cpp_lds_S = LDS $@ |
| 247 | cmd_cpp_lds_S = $(CPP) $(cpp_flags) -D__ASSEMBLY__ -o $@ $< | 246 | cmd_cpp_lds_S = $(CPP) $(cpp_flags) -D__ASSEMBLY__ -o $@ $< |
| 248 | 247 | ||
| 249 | %.lds: %.lds.S FORCE | 248 | $(obj)/%.lds: $(src)/%.lds.S FORCE |
| 250 | $(call if_changed_dep,cpp_lds_S) | 249 | $(call if_changed_dep,cpp_lds_S) |
| 251 | 250 | ||
| 252 | # Build the compiled-in targets | 251 | # Build the compiled-in targets |
diff --git a/scripts/Makefile.host b/scripts/Makefile.host index 575afbe5e370..6943a7a5bb98 100644 --- a/scripts/Makefile.host +++ b/scripts/Makefile.host | |||
| @@ -114,7 +114,7 @@ hostcxx_flags = -Wp,-MD,$(depfile) $(__hostcxx_flags) | |||
| 114 | quiet_cmd_host-csingle = HOSTCC $@ | 114 | quiet_cmd_host-csingle = HOSTCC $@ |
| 115 | cmd_host-csingle = $(HOSTCC) $(hostc_flags) -o $@ $< \ | 115 | cmd_host-csingle = $(HOSTCC) $(hostc_flags) -o $@ $< \ |
| 116 | $(HOST_LOADLIBES) $(HOSTLOADLIBES_$(@F)) | 116 | $(HOST_LOADLIBES) $(HOSTLOADLIBES_$(@F)) |
| 117 | $(host-csingle): %: %.c FORCE | 117 | $(host-csingle): $(obj)/%: $(src)/%.c FORCE |
| 118 | $(call if_changed_dep,host-csingle) | 118 | $(call if_changed_dep,host-csingle) |
| 119 | 119 | ||
| 120 | # Link an executable based on list of .o files, all plain c | 120 | # Link an executable based on list of .o files, all plain c |
| @@ -123,14 +123,14 @@ quiet_cmd_host-cmulti = HOSTLD $@ | |||
| 123 | cmd_host-cmulti = $(HOSTCC) $(HOSTLDFLAGS) -o $@ \ | 123 | cmd_host-cmulti = $(HOSTCC) $(HOSTLDFLAGS) -o $@ \ |
| 124 | $(addprefix $(obj)/,$($(@F)-objs)) \ | 124 | $(addprefix $(obj)/,$($(@F)-objs)) \ |
| 125 | $(HOST_LOADLIBES) $(HOSTLOADLIBES_$(@F)) | 125 | $(HOST_LOADLIBES) $(HOSTLOADLIBES_$(@F)) |
| 126 | $(host-cmulti): %: $(host-cobjs) $(host-cshlib) FORCE | 126 | $(host-cmulti): $(obj)/%: $(host-cobjs) $(host-cshlib) FORCE |
| 127 | $(call if_changed,host-cmulti) | 127 | $(call if_changed,host-cmulti) |
| 128 | 128 | ||
| 129 | # Create .o file from a single .c file | 129 | # Create .o file from a single .c file |
| 130 | # host-cobjs -> .o | 130 | # host-cobjs -> .o |
| 131 | quiet_cmd_host-cobjs = HOSTCC $@ | 131 | quiet_cmd_host-cobjs = HOSTCC $@ |
| 132 | cmd_host-cobjs = $(HOSTCC) $(hostc_flags) -c -o $@ $< | 132 | cmd_host-cobjs = $(HOSTCC) $(hostc_flags) -c -o $@ $< |
| 133 | $(host-cobjs): %.o: %.c FORCE | 133 | $(host-cobjs): $(obj)/%.o: $(src)/%.c FORCE |
| 134 | $(call if_changed_dep,host-cobjs) | 134 | $(call if_changed_dep,host-cobjs) |
| 135 | 135 | ||
| 136 | # Link an executable based on list of .o files, a mixture of .c and .cc | 136 | # Link an executable based on list of .o files, a mixture of .c and .cc |
| @@ -140,20 +140,20 @@ quiet_cmd_host-cxxmulti = HOSTLD $@ | |||
| 140 | $(foreach o,objs cxxobjs,\ | 140 | $(foreach o,objs cxxobjs,\ |
| 141 | $(addprefix $(obj)/,$($(@F)-$(o)))) \ | 141 | $(addprefix $(obj)/,$($(@F)-$(o)))) \ |
| 142 | $(HOST_LOADLIBES) $(HOSTLOADLIBES_$(@F)) | 142 | $(HOST_LOADLIBES) $(HOSTLOADLIBES_$(@F)) |
| 143 | $(host-cxxmulti): %: $(host-cobjs) $(host-cxxobjs) $(host-cshlib) FORCE | 143 | $(host-cxxmulti): $(obj)/%: $(host-cobjs) $(host-cxxobjs) $(host-cshlib) FORCE |
| 144 | $(call if_changed,host-cxxmulti) | 144 | $(call if_changed,host-cxxmulti) |
| 145 | 145 | ||
| 146 | # Create .o file from a single .cc (C++) file | 146 | # Create .o file from a single .cc (C++) file |
| 147 | quiet_cmd_host-cxxobjs = HOSTCXX $@ | 147 | quiet_cmd_host-cxxobjs = HOSTCXX $@ |
| 148 | cmd_host-cxxobjs = $(HOSTCXX) $(hostcxx_flags) -c -o $@ $< | 148 | cmd_host-cxxobjs = $(HOSTCXX) $(hostcxx_flags) -c -o $@ $< |
| 149 | $(host-cxxobjs): %.o: %.cc FORCE | 149 | $(host-cxxobjs): $(obj)/%.o: $(src)/%.cc FORCE |
| 150 | $(call if_changed_dep,host-cxxobjs) | 150 | $(call if_changed_dep,host-cxxobjs) |
| 151 | 151 | ||
| 152 | # Compile .c file, create position independent .o file | 152 | # Compile .c file, create position independent .o file |
| 153 | # host-cshobjs -> .o | 153 | # host-cshobjs -> .o |
| 154 | quiet_cmd_host-cshobjs = HOSTCC -fPIC $@ | 154 | quiet_cmd_host-cshobjs = HOSTCC -fPIC $@ |
| 155 | cmd_host-cshobjs = $(HOSTCC) $(hostc_flags) -fPIC -c -o $@ $< | 155 | cmd_host-cshobjs = $(HOSTCC) $(hostc_flags) -fPIC -c -o $@ $< |
| 156 | $(host-cshobjs): %.o: %.c FORCE | 156 | $(host-cshobjs): $(obj)/%.o: $(src)/%.c FORCE |
| 157 | $(call if_changed_dep,host-cshobjs) | 157 | $(call if_changed_dep,host-cshobjs) |
| 158 | 158 | ||
| 159 | # Link a shared library, based on position independent .o files | 159 | # Link a shared library, based on position independent .o files |
| @@ -162,7 +162,7 @@ quiet_cmd_host-cshlib = HOSTLLD -shared $@ | |||
| 162 | cmd_host-cshlib = $(HOSTCC) $(HOSTLDFLAGS) -shared -o $@ \ | 162 | cmd_host-cshlib = $(HOSTCC) $(HOSTLDFLAGS) -shared -o $@ \ |
| 163 | $(addprefix $(obj)/,$($(@F:.so=-objs))) \ | 163 | $(addprefix $(obj)/,$($(@F:.so=-objs))) \ |
| 164 | $(HOST_LOADLIBES) $(HOSTLOADLIBES_$(@F)) | 164 | $(HOST_LOADLIBES) $(HOSTLOADLIBES_$(@F)) |
| 165 | $(host-cshlib): %: $(host-cshobjs) FORCE | 165 | $(host-cshlib): $(obj)/%: $(host-cshobjs) FORCE |
| 166 | $(call if_changed,host-cshlib) | 166 | $(call if_changed,host-cshlib) |
| 167 | 167 | ||
| 168 | targets += $(host-csingle) $(host-cmulti) $(host-cobjs)\ | 168 | targets += $(host-csingle) $(host-cmulti) $(host-cobjs)\ |
