1 # This version is adapted for RTEMS build
4 # lib_LIBRARIES .. list of the user-space libraries
5 # shared_LIBRARIES .. list of the user-space shared libraries
6 # include_HEADERS .. list of the user-space public header files
7 # nobase_include_HEADERS .. public headers copied even with directory part
8 # renamed_include_HEADERS .. public headers copied to the different target name
9 # bin_PROGRAMS .. list of the require binary programs
10 # utils_PROGRAMS .. list of the development utility programs
11 # test_PROGRAMS .. list of the test programs
12 # xxx_SOURCES .. list of specific target sources
13 # xxx_LIBS .. list of specific target libraries
14 # INCLUDES .. additional include directories and defines for user-space
15 # xxx_EMBEDTARFILES .. list of source subdirectories which are embedded as tar files to the application
16 # xxx_EXPORTSYMBOLS .. if "y" then include symbol table in the application for dlopen functionality
19 # OBJ_EXT - extension of object files
20 # LIB_EXT - extension of library files
21 # LIB_PREF - prefix for library files
22 # ASM_EXT - extension of assembler sources
24 include $(RTEMS_MAKEFILE_PATH)/Makefile.inc
25 include $(RTEMS_CUSTOM)
28 BUILD_DIR_NAME = _build/$(RTEMS_BSP)
29 COMPILED_DIR_NAME = _compiled/$(RTEMS_BSP)
33 USER_INCLUDE_DIR := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/include
34 USER_LIB_DIR := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/lib
35 USER_UTILS_DIR := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin-utils
36 USER_TESTS_DIR := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin-tests
37 USER_BIN_DIR := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin
38 USER_BUILD_DIR := $(MAKERULES_DIR)/$(BUILD_DIR_NAME)/user
40 LOCAL_BUILD_DIR = $(USER_OBJS_DIR)
42 DEFAULT_INCLUDES = -I $(PROJECT_INCLUDE)
44 CPPFLAGS += -I $(USER_INCLUDE_DIR)
46 CPPFLAGS += $(CONFIG_OMK_DEFINES)
48 #CPPFLAGS += $(OMK_CPPFLAGS)
49 #CFLAGS += $(OMK_CFLAGS)
50 #CXXFLAGS += $(OMK_CXXFLAGS)
51 #LDFLAGS += $(CFLAGS) $(OMK_CFLAGS) $(LD_PATHS:%=-L%)
53 LOADLIBES += -L$(USER_LIB_DIR)
55 LOADLIBES += $(lib_LOADLIBES:%=-l%)
57 SOLIB_PICFLAGS += -shared -fpic
65 RELATIVE_DIR := $(SOURCES_DIR:$(MAKERULES_DIR)%=%)
67 override RELATIVE_DIR := $(RELATIVE_DIR:/%=%)
68 override RELATIVE_DIR := $(RELATIVE_DIR:\\%=%)
69 #$(warning RELATIVE_DIR $(RELATIVE_DIR))
71 #$(warning SOURCES_DIR = $(SOURCES_DIR))
72 #$(warning MAKERULES_DIR = $(MAKERULES_DIR))
73 #$(warning RELATIVE_DIR = $(RELATIVE_DIR))
75 #vpath %.c $(SOURCES_DIR)
76 #vpath %.cc $(SOURCES_DIR)
77 #vpath %.cxx $(SOURCES_DIR)
79 USER_OBJS_DIR = $(USER_BUILD_DIR)/$(RELATIVE_DIR)
83 # Some support to serialize some targets for parallel make
84 ifneq ($(OMK_SERIALIZE_INCLUDED),y)
85 include-pass: check-dir
86 library-pass: include-pass
87 binary-pass: library-pass
89 override OMK_SERIALIZE_INCLUDED = y
90 MAKEOVERRIDES := $(filter-out OMK_SERIALIZE_INCLUDED=n,$(MAKEOVERRIDES))
93 #=====================================================================
94 # Special rules for target filesystem and data preparation
96 # Syntax: $(call TARFILE_template,<filename>,<filename2>,<directory>) FIXME: Is this correct?
97 define TARFILE_template
102 $(Q) ABSOLUTETARFILE=`cd $$(dir $$@) ; pwd`/$$@ ; \
103 ( test -e $$$$ABSOLUTETARFILE && ( cd $(3) && tar $$(TARFLAGS) -df $$$$ABSOLUTETARFILE ) ) || \
104 ( cd $(3) && tar $$(TARFLAGS) -cf $$$$ABSOLUTETARFILE . )
107 @$(QUIET_CMD_ECHO) " TARFILE $$@"
108 $(Q) $(LD) -r --accept-unknown-input-arch -b binary -o $$@.tmp $$^
109 $(Q) $(OBJCOPY) --rename-section .data=.rodata,alloc,load,readonly,data,contents $$@.tmp $$@
113 #=====================================================================
114 # User-space rules and templates to compile programs, libraries etc.
116 ifdef USER_RULE_TEMPLATES
120 # $(CC) -o $@ $(LCFLAGS) -c $<
122 c_o_COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(OMK_CPPFLAGS) \
123 $(CPPFLAGS) $(OMK_CFLAGS) $(CFLAGS) $(INCLUDES) -DOMK_FOR_USER
125 cc_o_COMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(OMK_CPPFLAGS) \
126 $(CPPFLAGS) $(OMK_CXXFLAGS) $(CFLAGS) $(CXXFLAGS) $(INCLUDES) -DOMK_FOR_USER
128 S_o_COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(OMK_CPPFLAGS) \
129 $(CPPFLAGS) $(OMK_CFLAGS) $(CFLAGS) $(ASFLAGS) -DOMK_FOR_USER
131 # Check GCC version for user build
132 ifndef CC_MAJOR_VERSION
133 CC_MAJOR_VERSION := $(shell $(CC) -dumpversion | $(SED4OMK) -e 's/\([^.]\)\..*/\1/')
135 # Prepare suitable define for dependency building
136 ifeq ($(CC_MAJOR_VERSION),2)
137 CC_DEPFLAGS = -Wp,-MD,"$@.d.tmp"
139 CC_DEPFLAGS = -MT $@ -MD -MP -MF "$@.d.tmp"
143 # Syntax: $(call COMPILE_c_o_template,<source>,<target>,<additional c-flags>)
144 define COMPILE_c_o_template
145 $(2): $(1) $$(GEN_HEADERS)
146 @$(QUIET_CMD_ECHO) " CC $$@"
147 $(Q) if $$(c_o_COMPILE) $$(CC_DEPFLAGS) $(3) -o $$@ -c $$< ; \
148 then mv -f "$$@.d.tmp" "$$@.d" ; \
149 else rm -f "$$@.d.tmp" ; exit 1; \
154 # Syntax: $(call COMPILE_cc_o_template,<source>,<target>,<additional c-flags>)
155 define COMPILE_cc_o_template
156 $(2): $(1) $$(GEN_HEADERS)
157 @$(QUIET_CMD_ECHO) " CXX $$@"
158 $(Q) if $$(cc_o_COMPILE) $$(CC_DEPFLAGS) $(3) -o $$@ -c $$< ; \
159 then mv -f "$$@.d.tmp" "$$@.d" ; \
160 else rm -f "$$@.d.tmp" ; exit 1; \
165 # Syntax: $(call COMPILE_S_o_template,<source>,<target>,<additional c-flags>)
166 define COMPILE_S_o_template
167 $(2): $(1) $$(GEN_HEADERS)
168 @$(QUIET_CMD_ECHO) " AS $$@"
169 $(Q) if $$(S_o_COMPILE) -D__ASSEMBLY__ $$(CC_DEPFLAGS) $(3) -o $$@ -c $$< ; \
170 then if [ -e "$$@.d.tmp" ] ; then mv -f "$$@.d.tmp" "$$@.d" ; fi ; \
171 else rm -f "$$@.d.tmp" ; exit 1; \
175 idl_COMPILE = $(IDL_COMPILER)
177 define COMPILE_idl_template
178 $(2).c $(2)-stubs.c $(2)-skels.c $(2)-common.c $(2).h: $(1) $$(wildcard $$(firstword $$(idl_COMPILE)))
179 @$(QUIET_CMD_ECHO) " IDL $$@"
180 $(Q) $$(idl_COMPILE) $$($(2)_IDLFLAGS) $(1)
183 RTEMS_SYSM?=rtems-syms
185 # Syntax: $(call PROGRAM_template,<executable-name>,<dir>,<link-variant>)
186 define PROGRAM_template
187 USER_IDLS += $$($(1)_SERVER_IDL) $$($(1)_CLIENT_IDL) $$($(1)_IDL)
188 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-skels.c))
189 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-common.c))
190 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-stubs.c))
191 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-common.c))
192 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_IDL:%.idl=%.c))
193 USER_GEN_SOURCES += $$($(1)_GEN_SOURCES)
195 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.c=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
196 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.cc=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
197 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.cxx=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
198 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.S=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
199 $(1)_OBJS += $$($(1)_EMBEDTARFILES:%=%_tarfile.o)
200 $(1)_OBJS := $$(sort $$($(1)_OBJS))
202 USER_OBJS += $$($(1)_OBJS)
203 USER_SOURCES += $$($(1)_SOURCES)
204 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
206 $(1)_LDFLAGS += $$(if $$(filter COMPLETE,$$($(1)_EXPORTSYMBOLS)),-Xlinker --whole-archive,)
208 $(1)_LDCOMMAND += $$(shell if [ -z "$$(filter %.cc,$$($(1)_SOURCES))" ] ; \
209 then echo $$(CC) $$(CPPFLAGS) $$(OMK_CPPFLAGS) $$(OMK_CFLAGS) $$(CFLAGS) ; \
210 else echo $$(CXX) $$(CPPFLAGS) $$(OMK_CPPFLAGS) $$(OMK_CXXFLAGS) $$(CXXFLAGS) ; fi) \
211 $$($(1)_LDFLAGS) $$(OMK_LDFLAGS) $$(LDFLAGS) $$($(1)_OBJS)
213 $(2)/$(1): $(USER_LIB_DIR)/timestamp
214 $(2)/$(1): $$($(1)_OBJS)
215 @$(QUIET_CMD_ECHO) " LINK $$@"
216 $(Q) if [ -z "$$($(1)_EXPORTSYMBOLS)" ] ; then \
217 $$($(1)_LDCOMMAND) $$(LOADLIBES) $$($(1)_LIBS:%=-l%) -Wl,-Map,$(USER_OBJS_DIR)/$(1).exe.map -o $(2)/$(1) || exit 1; \
219 rm -f $(1).prelink ; \
220 $$($(1)_LDCOMMAND) $$(LOADLIBES) $$($(1)_LIBS:%=-l%) -Wl,-Map,$(USER_OBJS_DIR)/$(1).exe.map -o $(1).prelink || exit 1 ; \
221 $(RTEMS_SYSM) -e -c "$$(CC) $$(CPPFLAGS) $$(OMK_CPPFLAGS) $$(OMK_CFLAGS) $$(CFLAGS)" \
222 -S $(1)-symbol-table.c -o $(1)-symbol-table.o $(1).prelink || exit 1 ; \
223 $$($(1)_LDCOMMAND) $(1)-symbol-table.o $$(LOADLIBES) $$($(1)_LIBS:%=-l%) -o $(2)/$(1) || exit 1 ; \
226 #@echo "$(2)/$(1): \\" >$(USER_OBJS_DIR)/$(1).exe.d
227 #@$(SED4OMK) -n -e 's/^LOAD \(.*\)$$$$/ \1 \\/p' $(USER_OBJS_DIR)/$(1).exe.map >>$(USER_OBJS_DIR)/$(1).exe.d
228 #@echo >>$(USER_OBJS_DIR)/$(1).exe.d
229 #-Wl,-Map,$(USER_OBJS_DIR)/$(1).exe.map
230 # FIXME: Why the map file was commented out?
233 # Rules for other output formats (can be specified by OUTPUT_FORMATS)
235 @$(QUIET_CMD_ECHO) " OBJCOPY $@"
236 $(Q) $(OBJCOPY) --output-target=binary -S $< $@
239 @$(QUIET_CMD_ECHO) " OBJCOPY $@"
240 $(Q) $(OBJCOPY) --output-target=ihex -S $< $@
243 @$(QUIET_CMD_ECHO) " OBJCOPY $@"
244 $(Q) $(OBJCOPY) --output-target=srec -S $< $@
246 # Syntax: $(call LIBRARY_template,<library-name>)
247 define LIBRARY_template
248 USER_IDLS += $$($(1)_SERVER_IDL) $$($(1)_CLIENT_IDL) $$($(1)_IDL)
249 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-skels.c))
250 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-common.c))
251 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-stubs.c))
252 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-common.c))
253 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_IDL:%.idl=%.c))
254 USER_GEN_SOURCES += $$($(1)_GEN_SOURCES)
256 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.c=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
257 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.cc=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
258 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.cxx=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
259 $(1)_OBJS += $$(filter %.o,$$($(1)_SOURCES:%.S=%.o) $$($(1)_GEN_SOURCES:%.c=%.o))
260 $(1)_OBJS += $$($(1)_EMBEDTARFILES:%=%_tarfile.o)
261 $(1)_OBJS := $$(sort $$($(1)_OBJS))
263 USER_OBJS += $$($(1)_OBJS)
264 USER_SOURCES += $$($(1)_SOURCES)
265 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
267 $(USER_LIB_DIR)/lib$(1).a: $$($(1)_OBJS)
268 @$(QUIET_CMD_ECHO) " AR $$@"
269 $(Q) $(AR) rcs $$@ $$^
270 @touch $(USER_LIB_DIR)/timestamp
273 $(USER_LIB_DIR)/timestamp:
276 # Syntax: $(call SOLIB_template,<library-name>)
277 define SOLIB_template
278 USER_IDLS += $$($(1)_SERVER_IDL) $$($(1)_CLIENT_IDL) $$($(1)_IDL)
279 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-skels.c))
280 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_SERVER_IDL:%.idl=%-common.c))
281 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-stubs.c))
282 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_CLIENT_IDL:%.idl=%-common.c))
283 $(1)_GEN_SOURCES += $$(filter %.c,$$($(1)_IDL:%.idl=%.c))
284 SOLIB_GEN_SOURCES += $$($(1)_GEN_SOURCES)
286 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.c=%.lo) $$($(1)_GEN_SOURCES:%.c=%.lo))
287 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.cc=%.lo) $$($(1)_GEN_SOURCES:%.c=%.lo))
288 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.cxx=%.lo) $$($(1)_GEN_SOURCES:%.c=%.lo))
289 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.S=%.lo) $$($(1)_GEN_SOURCES:%.c=%.lo))
290 $(1)_OBJS += $$($(1)_EMBEDTARFILES:%=%_tarfile.o)
291 $(1)_OBJSLO := $$(sort $$($(1)_OBJSLO))
293 SOLIB_OBJS += $$($(1)_OBJSLO)
294 SOLIB_SOURCES += $$($(1)_SOURCES)
295 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
297 $(USER_LIB_DIR)/lib$(1).so: $$($(1)_OBJSLO)
298 @$(QUIET_CMD_ECHO) " LINK $$@"
299 $(Q) $(LD) --shared --soname=lib$(1).so -o $$@ $$^
304 library-pass-local: $(lib_LIBRARIES:%=$(USER_LIB_DIR)/lib%.a) $(shared_LIBRARIES:%=$(USER_LIB_DIR)/lib%.so)
306 binary-pass-local: $(bin_PROGRAMS:%=$(USER_BIN_DIR)/%) $(utils_PROGRAMS:%=$(USER_UTILS_DIR)/%) $(test_PROGRAMS:%=$(USER_TESTS_DIR)/%) \
307 $(foreach of,$(OUTPUT_FORMATS),$(bin_PROGRAMS:%=$(USER_BIN_DIR)/%.$(of)) $(test_PROGRAMS:%=$(USER_TESTS_DIR)/%.$(of)))
309 GEN_HEADERS+=$(filter %.h,$(USER_IDLS:%.idl=%.h))
311 # Generate rules for compilation of programs and libraries
313 $(foreach prog,$(utils_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_UTILS_DIR))))
315 $(foreach prog,$(test_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_TESTS_DIR))))
317 $(foreach prog,$(bin_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_BIN_DIR))))
319 $(foreach lib,$(lib_LIBRARIES),$(eval $(call LIBRARY_template,$(lib))))
321 $(foreach lib,$(shared_LIBRARIES),$(eval $(call SOLIB_template,$(lib))))
323 # Create _build directories for sources in subdirectories i.e. *_SOURCES=dir/file.c
324 _dirs_to_create=$(filter-out ./,$(sort $(dir $(USER_SOURCES) $(SOLIB_SOURCES))))
325 ifneq ($(_dirs_to_create),)
326 $(shell mkdir -p $(addprefix $(LOCAL_BUILD_DIR)/,$(_dirs_to_create)))
330 USER_IDLS := $(sort $(USER_IDLS))
331 $(foreach src,$(filter %.idl,$(USER_IDLS)),$(eval $(call COMPILE_idl_template,$(SOURCES_DIR)/$(src),$(src:%.idl=%))))
334 -include $(USER_OBJS_DIR)/*.d
338 #=====================================================================
341 $(eval $(call omk_pass_template, include-pass,$(USER_OBJS_DIR),USER_RULE_TEMPLATES=y,$(include_HEADERS)$(nobase_include_HEADERS)$(renamed_include_HEADERS)$(config_include_HEADERS)$(LOCAL_CONFIG_H)))
342 $(eval $(call omk_pass_template, library-pass,$(USER_OBJS_DIR),USER_RULE_TEMPLATES=y,$(lib_LIBRARIES)$(shared_LIBRARIES)))
343 $(eval $(call omk_pass_template, binary-pass, $(USER_OBJS_DIR),USER_RULE_TEMPLATES=y,$(bin_PROGRAMS)$(utils_PROGRAMS)$(test_PROGRAMS)))
345 $(eval $(call omk_pass_template,clean,$(USER_OBJS_DIR),,always))
348 @$(call mkdir_def,$(USER_INCLUDE_DIR))
349 @$(call mkdir_def,$(USER_LIB_DIR))
350 @$(call mkdir_def,$(USER_BIN_DIR))
351 @$(call mkdir_def,$(USER_UTILS_DIR))
352 @$(call mkdir_def,$(USER_TESTS_DIR))
354 $(eval $(call include-pass-template,$(USER_INCLUDE_DIR),include))
356 ifdef USER_RULE_TEMPLATES
358 # User-space static libraries and applications object files
360 USER_SOURCES := $(sort $(USER_SOURCES))
361 USER_GEN_SOURCES := $(sort $(USER_GEN_SOURCES))
363 #$(warning USER_SOURCES = $(USER_SOURCES))
365 $(foreach src,$(filter %.c,$(USER_SOURCES)),$(eval $(call COMPILE_c_o_template,$(SOURCES_DIR)/$(src),$(src:%.c=%.o),)))
367 $(foreach src,$(filter %.cc,$(USER_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cc=%.o),)))
369 $(foreach src,$(filter %.cxx,$(USER_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cxx=%.o),)))
371 $(foreach src,$(filter %.S,$(USER_SOURCES)),$(eval $(call COMPILE_S_o_template,$(SOURCES_DIR)/$(src),$(src:%.S=%.o),)))
373 $(foreach src,$(filter %.c,$(USER_GEN_SOURCES)),$(eval $(call COMPILE_c_o_template,$(src),$(src:%.c=%.o),)))
375 # User-space shared libraries object files
377 SOLIB_SOURCES := $(sort $(SOLIB_SOURCES))
379 #$(warning SOLIB_SOURCES = $(SOLIB_SOURCES))
381 $(foreach src,$(filter %.c,$(SOLIB_SOURCES)),$(eval $(call COMPILE_c_o_template,$(SOURCES_DIR)/$(src),$(src:%.c=%.lo),$(SOLIB_PICFLAGS))))
383 $(foreach src,$(filter %.cc,$(SOLIB_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cc=%.lo),$(SOLIB_PICFLAGS))))
385 $(foreach src,$(filter %.cxx,$(SOLIB_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cxx=%.lo),$(SOLIB_PICFLAGS))))
387 $(foreach src,$(filter %.S,$(SOLIB_SOURCES)),$(eval $(call COMPILE_S_o_template,$(SOURCES_DIR)/$(src),$(src:%.S=%.lo),$(SOLIB_PICFLAGS))))
389 $(foreach tarfile,$(USER_EMBEDTARFILES),$(eval $(call TARFILE_template,$(tarfile),$(tarfile)_tarfile,$(SOURCES_DIR)/$(tarfile))))
395 @echo Cleaning in $(USER_OBJS_DIR)
396 @rm -f $(USER_OBJS_DIR)/*.o $(USER_OBJS_DIR)/*.lo \
397 $(USER_OBJS_DIR)/*.d \
398 $(USER_OBJS_DIR)/*.map \
399 $(LOCAL_CONFIG_H:%=$(USER_OBJS_DIR)/%) \
400 $(USER_OBJS_DIR)/*_tarfile \
401 $(USER_OBJS_DIR)/*.prelink \
402 $(USER_OBJS_DIR)/*.tmp
405 default: include-pass library-pass binary-pass
407 include-pass-submakes: extra-rules-subdirs
409 # We must go to EXTRA_RULES_SUBDIRS before going to any other
410 # directory, since the executables compiled in EXTRA_RULES_SUBDIRS
411 # might be needed there.
412 include-pass-this-dir $(foreach subdir,$(SUBDIRS),include-pass-$(subdir)-subdir): extra-rules-subdirs