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