]> rtime.felk.cvut.cz Git - omk/sssa.git/blob - omk-devel/ulan-keil/Makefile.rules
Cleanup in repository.
[omk/sssa.git] / omk-devel / ulan-keil / Makefile.rules
1 #  Makefile.rules - OCERA make framework common project rules
2 #                   This version is adapted for SDCC build
3 #   
4 #  (C) Copyright 2003-2005 by Pavel Pisa - OCERA team member
5 #
6 #  The uLan driver is distributed under the Gnu General Public License. 
7 #  See file COPYING for details.
8 #
9 #
10 # input variables
11 # V                .. if set to 1, full command text is shown else short form is used
12 # SUBDIRS          .. list of subdirectories intended for make from actual directory
13 # lib_LIBRARIES    .. list of the user-space libraries
14 # shared_LIBRARIES .. list of the user-space shared libraries
15 # include_HEADERS  .. list of the user-space public header files
16 # nobase_include_HEADERS .. public headers copied even with directory part
17 # bin_PROGRAMS     .. list of the require binary programs
18 # utils_PROGRAMS   .. list of the development utility programs
19 # xxx_SOURCES      .. list of specific target sources
20 # INCLUDES         .. additional include directories and defines for user-space
21 # default_CONFIG   .. list of default config assignments CONFIG_XXX=y/n ...
22 # tar_EMBEDFILES   .. list of tars with embedded files
23 #
24
25 BUILD_DIR_NAME = _build
26 COMPILED_DIR_NAME = _compile
27 GROUP_DIR_NAME = 
28
29 CC = c51
30 OBJ_EXT = .obj
31 LIB_EXT = .lib
32 LIB_PREF =
33 AR = lib51
34 AS = a51intel
35 HC = oh51
36 LI = l51
37
38 # We need to ensure definition of sources directory first
39 ifndef SOURCES_DIR
40 SOURCES_DIR := $(shell ( pwd -W ) )
41 endif
42
43 all: default
44
45 USER_INCLUDE_DIR := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/include
46 USER_LIB_DIR     := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/lib
47 USER_UTILS_DIR   := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin-utils
48 USER_BIN_DIR     := $(MAKERULES_DIR)/$(COMPILED_DIR_NAME)/bin
49 USER_BUILD_DIR   := $(MAKERULES_DIR)/$(BUILD_DIR_NAME)/user
50 ifndef CONFIG_FILE
51 CONFIG_FILE      := $(MAKERULES_DIR)/config.omk
52 endif
53 ifneq ($(wildcard $(CONFIG_FILE)-default),)
54 -include $(CONFIG_FILE)-default
55 else
56 $(warning Please, run "make default-config" first)
57 endif
58 ifneq ($(wildcard $(CONFIG_FILE)),)
59 include $(CONFIG_FILE)
60 CONFIG_FILE_OK = y
61 endif
62
63 # Check and include real OCERA style Makefile.omk now
64 ifndef OMK_INCLUDED
65 include $(SOURCES_DIR)/Makefile.omk
66 OMK_INCLUDED := 1
67 endif
68
69 export SOURCES_DIR MAKERULES_DIR RELATIVE_DIR
70 export CONFIG_FILE OMK_SERIALIZE_INCLUDED OMK_VERBOSE OMK_SILENT
71
72 #CFLAGS += -ggdb
73 #CFLAGS += -O2 
74 #CFLAGS += -Wall
75 #CXXFLAGS += -ggdb
76 #CXXFLAGS += -O2
77 #CXXFLAGS += -Wall
78
79 ifndef DEFAULT_INCLUDES
80 override DEFAULT_INCLUDES = $(INCLUDES) -I $(USER_INCLUDE_DIR) -I $(SOURCES_DIR) \
81   $(shell echo $${C51INC} | sed -e 's/;/ -I /g' -e 's/^\(.\)/-I \1/')
82 endif
83 #$(warning DEFAULT_INCLUDES = $(DEFAULT_INCLUDES))
84
85 #CPPFLAGS  += -I $(USER_INCLUDE_DIR)
86
87 CPPFLAGS  += $(CONFIG_OMK_DEFINES)
88
89 #CPPFLAGS  += $(AM_CPPFLAGS)
90 #CFLAGS    += $(AM_CFLAGS)
91 #CXXFLAGS  += $(AM_CXXFLAGS)
92 #LDFLAGS   += $(CFLAGS) $(AM_CFLAGS) $(LD_PATHS:%=-L%)
93  
94 #LOADLIBES += -L$(USER_LIB_DIR) 
95
96 #LOADLIBES += $(lib_LOADLIBES:%=-l%)
97
98 SOLIB_PICFLAGS += -shared -fpic
99
100 ifndef RELATIVE_DIR
101 override RELATIVE_DIR := $(SOURCES_DIR:$(MAKERULES_DIR)%=%)
102 endif
103 ifeq ("$(RELATIVE_DIR)","")
104 override RELATIVE_DIR := .
105 endif
106 override RELATIVE_DIR := $(RELATIVE_DIR:/%=%)
107 override RELATIVE_DIR := $(RELATIVE_DIR:\\%=%)
108
109 #$(warning SOURCES_DIR = $(SOURCES_DIR))
110 #$(warning MAKERULES_DIR = $(MAKERULES_DIR))
111 #$(warning RELATIVE_DIR = $(RELATIVE_DIR))
112
113 #vpath %.c $(SOURCES_DIR)
114 #vpath %.cc $(SOURCES_DIR)
115
116 VPATH = $(SOURCES_DIR)
117 srcdir = $(SOURCES_DIR)
118
119 USER_OBJS_DIR = $(USER_BUILD_DIR)/$(RELATIVE_DIR)
120
121 .PHONY: default dep subdirs clean cleandepend default-config
122 .PHONY: check-make-ver check-dir include-pass library-pass binary-pass utils-pass
123 .PHONY: default-config-pass
124 .PHONY: check-dir-local include-pass-local library-pass-local binary-pass-local 
125 .PHONY: utils-pass-local default-config-pass-local
126
127 # Some support to serialize some targets for parallel make
128 ifneq ($(OMK_SERIALIZE_INCLUDED),y)
129 include-pass: check-dir
130 library-pass: include-pass
131 binary-pass utils-pass: library-pass
132
133 OMK_SERIALIZE_INCLUDED = y
134 endif
135
136 # Defines for quiet compilation
137 ifdef V
138   ifeq ("$(origin V)", "command line")
139     OMK_VERBOSE = $(V)
140   endif
141 endif
142 ifndef OMK_VERBOSE
143   OMK_VERBOSE = 0
144 endif
145 ifeq ($(OMK_VERBOSE),1)
146   Q =
147 else
148   Q = @
149 endif
150 ifneq ($(findstring s,$(MAKEFLAGS)),)
151   QUIET_CMD_ECHO = true
152   OMK_SILENT = 1
153 else
154   QUIET_CMD_ECHO = echo
155   CPHEADER_FLAGS += -v
156 endif
157
158 default: check-make-ver check-dir include-pass library-pass binary-pass utils-pass
159
160 #=====================================================================
161 # Common utility rules
162
163 define mkdir_def
164         [ -d $(1) ] || mkdir -p $(1) || exit 1
165 endef
166
167 ifdef LOCAL_CONFIG_H
168
169 $(LOCAL_CONFIG_H) : $(wildcard $(CONFIG_FILE)) $(wildcard $(CONFIG_FILE)-default)
170         @echo LOCAL_CONFIG_H=`pwd -W`/$(LOCAL_CONFIG_H)
171         @echo "/* Automatically generated from */" > "$(LOCAL_CONFIG_H).tmp"
172         @echo "/* config file : $< */" >> "$(LOCAL_CONFIG_H).tmp"
173         @echo "#ifndef _LOCAL_CONFIG_H" >> "$(LOCAL_CONFIG_H).tmp"
174         @echo "#define _LOCAL_CONFIG_H" >> "$(LOCAL_CONFIG_H).tmp"
175         @( $(foreach x, $(shell echo $(default_CONFIG) | sed -e 's/\<\([^ ]*\)=[^ ]\>/\1/g' ), \
176                 echo $(x).$($(x)) ; ) echo ; ) | \
177                 sed -n -e 's/^\(.*\)\.[ym]$$/#define \1 1/p' \
178                   >> "$(LOCAL_CONFIG_H).tmp"
179         @echo "#endif /*_LOCAL_CONFIG_H*/" >> "$(LOCAL_CONFIG_H).tmp"
180         @if cmp --quiet "$(LOCAL_CONFIG_H).tmp" "$(LOCAL_CONFIG_H)" ; then \
181         echo rm "$(LOCAL_CONFIG_H).tmp" ; \
182         else mv "$(LOCAL_CONFIG_H).tmp" "$(LOCAL_CONFIG_H)" ; \
183         echo Updated configuration "$(LOCAL_CONFIG_H)" ; fi
184
185 endif
186
187 check-make-ver:
188         @GOOD_MAKE_VERSION=`echo $(MAKE_VERSION) | sed -n -e 's/^[4-9]\..*\|^3\.9[0-9].*\|^3\.8[1-9].*/y/p'` ; \
189         if [ x$$GOOD_MAKE_VERSION != xy ] ; then \
190                 echo "Your make program version is too old and does not support OMK system." ; \
191                 echo "Please update to make program 3.81beta1 or newer." ; exit 1 ; \
192         fi
193
194 #=====================================================================
195 # Special rules for target filesystem and data preparation
196
197
198 define TARFILE_template
199
200 .PHONY: $(2)
201
202 $(2):
203         $(Q) ABSOLUTETARFILE=`cd $$(dir $$@) ; pwd -W`/$$@ ; \
204              ( test -e $$$$ABSOLUTETARFILE && ( cd  $(3) && tar -df $$$$ABSOLUTETARFILE ) ) || \
205              ( cd  $(3) && tar -cf $$$$ABSOLUTETARFILE . )
206
207 $(2)$(OBJ_EXT): $(2)
208         @$(QUIET_CMD_ECHO) "  TARFILE $$@"
209         $(Q) $(OBJCOPY) -I binary -O elf32-littlearm  $$^ $$@
210
211 endef
212
213 #=====================================================================
214 # User-space rules and templates to compile programs, libraries etc.
215
216 ifdef USER_RULE_TEMPLATES
217
218
219 #%.lo: %.c
220 #       $(CC) -o $@ $(LCFLAGS) -c $<
221
222 c_o_COMPILE = $(CC) $(DEFS) $(AM_CPPFLAGS)
223
224 cc_o_COMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(AM_CPPFLAGS) \
225         $(CPPFLAGS) $(AM_CXXFLAGS) $(CFLAGS) $(INCLUDES) -DOMK_FOR_USER
226
227
228 # Check GCC version for user build
229 ifndef CC_MAJOR_VERSION
230 CC_MAJOR_VERSION := sdcc
231 endif
232 # Prepare suitable define for dependency building
233 #CC_DEPFLAGS = -MT $@ -MD -MP -MF "$@.d.tmp"
234
235
236 #"OBJECT($$@)"
237 #       export C51INC="${C51INC};$$(USER_INCLUDE_DIR);$$(SOURCES_DIR)" ; \
238 #         echo fastdep "$$(DEFAULT_INCLUDES)" <$$< >"$$@.d"; \
239
240 define COMPILE_c_o_template
241 $(2): $(1) $(LOCAL_CONFIG_H)
242         @$(QUIET_CMD_ECHO) "  CC      $$@"
243         $(Q) cp $$< .;\
244         export C51INC=`echo "$$(DEFAULT_INCLUDES)" | sed -e 's/-I//' -e 's/-I/;/g' -e 's/ //g'`;\
245         $$(c_o_COMPILE) $(3) `basename $$<      ` SRC ; \
246         if [ $$$$? -le 1 ] ; \
247           then if  a51 `basename $$< .c`.src ; \
248           then \
249           touch "$$@.d" ; \
250           else echo ERRORLEVEL $$$$? ; exit 1; \
251           fi \
252         else echo ERRORLEVEL $$$$? ; exit 1; \
253         fi
254 endef
255
256
257
258 define COMPILE_cc_o_template
259 $(2): $(1) $(LOCAL_CONFIG_H)
260         @$(QUIET_CMD_ECHO) "  CXX     $$@"
261         $(Q) echo "C++ compilation not suported for this compiler"
262 endef
263
264 define COMPILE_asm_o_template
265 $(2): $(1) $(LOCAL_CONFIG_H)
266         @$(QUIET_CMD_ECHO) "  ASM      $$@"
267         $(Q) \
268         cp $$< .; \
269         if [ -f $(SOURCES_DIR)/reg1210.inc ] ; then \
270           cp $(SOURCES_DIR)/reg1210.inc .; \
271         fi;\
272         $$(AS) $(2:%$(OBJ_EXT)=%.asm)
273 endef
274
275
276 define PROGRAM_template
277 $(1)_OBJS += $$(filter %$(OBJ_EXT),$$($(1)_SOURCES:%.c=%$(OBJ_EXT)))
278 $(1)_OBJS += $$(filter %$(OBJ_EXT),$$($(1)_SOURCES:%.cc=%$(OBJ_EXT)))
279 $(1)_OBJS += $$(filter %$(OBJ_EXT),$$($(1)_SOURCES:%.asm=%$(OBJ_EXT)))
280 $(1)_OBJS += $$($(1)_EMBEDTARFILES:%=%_tarfile$(OBJ_EXT))
281 $(1)_OBJS := $$(sort $$($(1)_OBJS))
282
283 USER_OBJS  += $$($(1)_OBJS)
284 USER_SOURCES += $$($(1)_SOURCES)
285 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
286
287 $(2)/$(1): $(USER_LIB_DIR)/timestamp
288
289
290 #       $(Q) $$(shell if [ -z "$$(filter %.cc,$$($(1)_SOURCES))" ] ; \
291 #         then echo $$(CC)  $$(CPPFLAGS) $$(AM_CPPFLAGS) $$(AM_CFLAGS) $$(CFLAGS) ; \
292 #         else echo $$(CXX) $$(CPPFLAGS) $$(AM_CPPFLAGS) $$(AM_CXXFLAGS) $$(CXXFLAGS) ; fi) \
293 #         $$(AM_LDFLAGS) $$(LDFLAGS) $$($(1)_OBJS) $$(LOADLIBES) $$($(1)_LIBS:%=-l%) \
294 #         -o $(2)/$(1)
295 #       $(HC) $(2)/$(1) >$(2)/$(1).hex
296
297 #         $$(LI) $$($(1)_OBJS) $$(LOADLIBES)
298
299 $(2)/$(1): $$($(1)_OBJS)
300         @$(QUIET_CMD_ECHO) "  LINK    $$@"
301         $(Q) \
302           export C51LIB="$${C51LIB};$(USER_LIB_DIR)"; \
303           export LI_FILES="$$($(1)_OBJS) $$(lib_LOADLIBES:%=%$$(LIB_EXT))"; \
304           export LI_FILES="`echo "$$$${LI_FILES}" | sed -e 's/\(.\) \(.\)/\1,\2/g'`";\
305           $$(LI) $$$${LI_FILES}
306 endef
307
308
309
310 define LIBRARY_template
311 $(1)_OBJS += $$(filter %$(OBJ_EXT),$$($(1)_SOURCES:%.c=%$(OBJ_EXT)))
312 $(1)_OBJS += $$(filter %$(OBJ_EXT),$$($(1)_SOURCES:%.cc=%$(OBJ_EXT)))
313 $(1)_OBJS += $$(filter %$(OBJ_EXT),$$($(1)_SOURCES:%.asm=%$(OBJ_EXT)))
314 $(1)_OBJS += $$($(1)_EMBEDTARFILES:%=%_tarfile$(OBJ_EXT))
315 $(1)_OBJS := $$(sort $$($(1)_OBJS))
316
317 USER_OBJS  += $$($(1)_OBJS)
318 USER_SOURCES += $$($(1)_SOURCES)
319 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
320
321 $(USER_LIB_DIR)/$(LIB_PREF)$(1)$(LIB_EXT): $$($(1)_OBJS)
322         @$(QUIET_CMD_ECHO) "  AR      $$@"
323         $(Q) \
324         rm -f $$@; \
325         $(AR) CREATE $$@; \
326         for i in $$^ ; do $(AR) ADD $$$$i TO $$@ ; done
327         @touch $(USER_LIB_DIR)/timestamp
328 endef
329
330 define SOLIB_template
331 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.c=%.lo))
332 $(1)_OBJSLO += $$(filter %.lo,$$($(1)_SOURCES:%.cc=%.lo))
333 $(1)_OBJS += $$($(1)_EMBEDTARFILES:%=%_tarfile$(OBJ_EXT))
334 $(1)_OBJSLO := $$(sort $$($(1)_OBJSLO))
335
336 SOLIB_OBJS  += $$($(1)_OBJSLO)
337 SOLIB_SOURCES += $$($(1)_SOURCES)
338 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
339
340 $(USER_LIB_DIR)/lib$(1).so: $$($(1)_OBJSLO)
341         @$(QUIET_CMD_ECHO) "  LINK    $$@"
342         $(Q) $(LD) --shared --soname=lib$(1).so -o $$@ $$^
343 endef
344
345
346
347 library-pass-local: $(lib_LIBRARIES:%=$(USER_LIB_DIR)/$(LIB_PREF)%$(LIB_EXT)) $(shared_LIBRARIES:%=$(USER_LIB_DIR)/$(LIB_PREF)%.so)
348
349 binary-pass-local: $(bin_PROGRAMS:%=$(USER_BIN_DIR)/%)
350
351 utils-pass-local: $(utils_PROGRAMS:%=$(USER_UTILS_DIR)/%)
352
353 $(foreach prog,$(utils_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_UTILS_DIR))))
354
355 $(foreach prog,$(bin_PROGRAMS),$(eval $(call PROGRAM_template,$(prog),$(USER_BIN_DIR))))
356
357 $(foreach lib,$(lib_LIBRARIES),$(eval $(call LIBRARY_template,$(lib))))
358
359 $(foreach lib,$(shared_LIBRARIES),$(eval $(call SOLIB_template,$(lib))))
360
361 -include $(USER_OBJS_DIR)/*.d
362
363 endif
364
365 #=====================================================================
366
367
368 library-pass binary-pass utils-pass:
369         +@$(foreach dir, $(SUBDIRS), $(call mkdir_def,$(USER_OBJS_DIR)/$(dir)) ; \
370                 $(MAKE) SOURCES_DIR=$(SOURCES_DIR)/$(dir) \
371                 RELATIVE_DIR=$(RELATIVE_DIR)/$(dir) -C $(USER_OBJS_DIR)/$(dir) \
372                 -f $(SOURCES_DIR)/$(dir)/Makefile $@ || exit 1 ;)
373         +@$(call mkdir_def,$(USER_OBJS_DIR))
374         @$(MAKE) --no-print-directory -C $(USER_OBJS_DIR) \
375                 -f $(SOURCES_DIR)/Makefile USER_RULE_TEMPLATES=y $(@:%=%-local)
376
377
378 dep clean install check-dir include-pass default-config-pass:
379         +@$(foreach dir, $(SUBDIRS), $(call mkdir_def,$(USER_OBJS_DIR)/$(dir)) ; \
380                 $(MAKE) SOURCES_DIR=$(SOURCES_DIR)/$(dir) \
381                 RELATIVE_DIR=$(RELATIVE_DIR)/$(dir) -C $(USER_OBJS_DIR)/$(dir) \
382                 -f $(SOURCES_DIR)/$(dir)/Makefile $@ || exit 1 ;)
383         +@$(call mkdir_def,$(USER_OBJS_DIR))
384         @$(MAKE) --no-print-directory -C $(USER_OBJS_DIR) \
385                 -f $(SOURCES_DIR)/Makefile $(@:%=%-local)
386
387
388 dep-local:
389         
390 check-dir-local:
391         @$(call mkdir_def,$(USER_OBJS_DIR))
392         @$(call mkdir_def,$(USER_INCLUDE_DIR))
393         @$(call mkdir_def,$(USER_LIB_DIR))
394         @$(call mkdir_def,$(USER_BIN_DIR))
395         @$(call mkdir_def,$(USER_UTILS_DIR))
396
397 install-local:
398
399 default-config:
400         @echo "# Start of OMK config file" > "$(CONFIG_FILE)-default"
401         @echo "# This file should not be altered manually" >> "$(CONFIG_FILE)-default"
402         @echo "# Overrides should be stored in file $(notdir $(CONFIG_FILE))" >> "$(CONFIG_FILE)-default"
403         @echo >> "$(CONFIG_FILE)-default"
404         @$(MAKE) --no-print-directory -C $(MAKERULES_DIR) \
405                 RELATIVE_DIR="" SOURCES_DIR=$(MAKERULES_DIR) \
406                 -f $(MAKERULES_DIR)/Makefile default-config-pass
407
408 default-config-pass-local:
409         @echo Default config for $(RELATIVE_DIR)
410         @echo "# Config for $(RELATIVE_DIR)" >> "$(CONFIG_FILE)-default"
411         @$(foreach x, $(default_CONFIG), echo $(x) | \
412                 sed -e 's/^.*=x$$/#\0/' >> "$(CONFIG_FILE)-default" ; )
413
414 include-pass-local:
415         @$(call mkdir_def,$(USER_INCLUDE_DIR))
416         @$(foreach f, $(include_HEADERS), cmp --quiet $(SOURCES_DIR)/$(f) $(USER_INCLUDE_DIR)/$(notdir $(f)) \
417            || cp $(CPHEADER_FLAGS) $(SOURCES_DIR)/$(f) $(USER_INCLUDE_DIR)/$(notdir $(f)) || exit 1 ; )
418         @$(foreach f, $(nobase_include_HEADERS), cmp --quiet $(SOURCES_DIR)/$(f) $(USER_INCLUDE_DIR)/$(f) \
419            || ( mkdir -p $(USER_INCLUDE_DIR)/$(dir $(f)) && cp $(CPHEADER_FLAGS) $(SOURCES_DIR)/$(f) $(USER_INCLUDE_DIR)/$(f) ) || exit 1 ; )
420
421 ifdef USER_RULE_TEMPLATES
422
423 # User-space static libraries and applications object files
424
425 USER_SOURCES := $(sort $(USER_SOURCES))
426
427 #$(warning USER_SOURCES = $(USER_SOURCES))
428
429 $(foreach src,$(filter %.c,$(USER_SOURCES)),$(eval $(call COMPILE_c_o_template,$(SOURCES_DIR)/$(src),$(src:%.c=%$(OBJ_EXT)),)))
430
431 $(foreach src,$(filter %.cc,$(USER_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cc=%$(OBJ_EXT)),)))
432
433 $(foreach src,$(filter %.asm,$(USER_SOURCES)),$(eval $(call COMPILE_asm_o_template,$(SOURCES_DIR)/$(src),$(src:%.asm=%$(OBJ_EXT)),)))
434
435 # User-space shared libraries object files
436
437 SOLIB_SOURCES := $(sort $(SOLIB_SOURCES))
438
439 #$(warning SOLIB_SOURCES = $(SOLIB_SOURCES))
440
441 $(foreach src,$(filter %.c,$(SOLIB_SOURCES)),$(eval $(call COMPILE_c_o_template,$(SOURCES_DIR)/$(src),$(src:%.c=%.lo),$(SOLIB_PICFLAGS))))
442
443 $(foreach src,$(filter %.cc,$(SOLIB_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cc=%.lo),$(SOLIB_PICFLAGS))))
444
445 $(foreach src,$(filter %.asm,$(SOLIB_SOURCES)),$(eval $(call COMPILE_asm_o_template,$(SOURCES_DIR)/$(src),$(src:%.asm=%$(OBJ_EXT)),$(SOLIB_PICFLAGS))))
446
447 $(foreach tarfile,$(USER_EMBEDTARFILES),$(eval $(call TARFILE_template,$(tarfile),$(tarfile)_tarfile,$(SOURCES_DIR)/$(tarfile))))
448
449 endif
450
451
452 clean-local:
453         @echo Cleaning in $(USER_OBJS_DIR)
454         @rm -f $(USER_OBJS_DIR)/*$(OBJ_EXT) $(USER_OBJS_DIR)/*.lo \
455                $(USER_OBJS_DIR)/*.d \
456                $(USER_OBJS_DIR)/*.map \
457                $(LOCAL_CONFIG_H:%=$(USER_OBJS_DIR)/%) \
458                $(tar_EMBEDFILES:%=$(USER_OBJS_DIR)/%_tarfile)
459                
460