1 # Makefile.rules - OCERA make framework common project rules
2 # This version is adapted for SDCC build
4 # (C) Copyright 2003-2005 by Pavel Pisa - OCERA team member
6 # The uLan driver is distributed under the Gnu General Public License.
7 # See file COPYING for details.
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.
31 BUILD_DIR_NAME = _build
32 COMPILED_DIR_NAME = _compiled
44 A51TOASX = $(MAKERULES_DIR)/a51toasx.sh
46 # We need to ensure definition of sources directory first
48 SOURCES_DIR := $(shell ( pwd -L ) )
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
59 CONFIG_FILE := $(MAKERULES_DIR)/config.omk
61 ifneq ($(wildcard $(CONFIG_FILE)-default),)
62 -include $(CONFIG_FILE)-default
64 $(warning Please, run "make default-config" first)
66 ifneq ($(wildcard $(CONFIG_FILE)),)
67 include $(CONFIG_FILE)
71 # Check and include real OCERA style Makefile.omk now
73 include $(SOURCES_DIR)/Makefile.omk
77 export SOURCES_DIR MAKERULES_DIR RELATIVE_DIR
78 export CONFIG_FILE OMK_SERIALIZE_INCLUDED OMK_VERBOSE OMK_SILENT
88 #DEFAULT_INCLUDES = -I $(PROJECT_INCLUDE)
90 CPPFLAGS += -I $(USER_INCLUDE_DIR)
92 CPPFLAGS += $(CONFIG_OMK_DEFINES)
94 #CPPFLAGS += $(AM_CPPFLAGS)
95 #CFLAGS += $(AM_CFLAGS)
96 #CXXFLAGS += $(AM_CXXFLAGS)
97 #LDFLAGS += $(CFLAGS) $(AM_CFLAGS) $(LD_PATHS:%=-L%)
99 CFLAGS += $(TARGET_ARCH)
100 LDFLAGS += $(TARGET_ARCH)
102 LOADLIBES += -L$(USER_LIB_DIR)
104 LOADLIBES += $(lib_LOADLIBES:%=-l%)
106 SOLIB_PICFLAGS += -shared -fpic
109 RELATIVE_DIR := $(SOURCES_DIR:$(MAKERULES_DIR)%=%)
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))
117 #$(warning SOURCES_DIR = $(SOURCES_DIR))
118 #$(warning MAKERULES_DIR = $(MAKERULES_DIR))
119 #$(warning RELATIVE_DIR = $(RELATIVE_DIR))
121 #vpath %.c $(SOURCES_DIR)
122 #vpath %.cc $(SOURCES_DIR)
124 VPATH = $(SOURCES_DIR)
125 srcdir = $(SOURCES_DIR)
127 USER_OBJS_DIR = $(USER_BUILD_DIR)/$(RELATIVE_DIR)
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
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
142 OMK_SERIALIZE_INCLUDED = y
145 # Defines for quiet compilation
147 ifeq ("$(origin V)", "command line")
154 ifeq ($(OMK_VERBOSE),1)
159 ifneq ($(findstring s,$(MAKEFLAGS)),)
160 QUIET_CMD_ECHO = true
163 QUIET_CMD_ECHO = echo
167 default: check-make-ver check-dir include-pass library-pass binary-pass utils-pass
169 #=====================================================================
170 # Common utility rules
173 [ -d $(1) ] || mkdir -p $(1) || exit 1
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
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 ; \
203 link_VARIANTS ?= $(DEFAULT_LD_SCRIPT_VARIANT)
205 #=====================================================================
206 # Special rules for target filesystem and data preparation
209 define TARFILE_template
214 $(Q) ABSOLUTETARFILE=`cd $$(dir $$@) ; pwd`/$$@ ; \
215 ( test -e $$$$ABSOLUTETARFILE && ( cd $(3) && tar -df $$$$ABSOLUTETARFILE ) ) || \
216 ( cd $(3) && tar -cf $$$$ABSOLUTETARFILE . )
219 @$(QUIET_CMD_ECHO) " TARFILE $$@"
220 $(Q) $(OBJCOPY) -I binary -O elf32-littlearm $$^ $$@
224 #=====================================================================
225 # User-space rules and templates to compile programs, libraries etc.
227 ifdef USER_RULE_TEMPLATES
231 # $(CC) -o $@ $(LCFLAGS) -c $<
233 c_o_COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(AM_CPPFLAGS) \
234 $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) $(INCLUDES) -DOMK_FOR_USER
236 cc_o_COMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(AM_CPPFLAGS) \
237 $(CPPFLAGS) $(AM_CXXFLAGS) $(CFLAGS) $(INCLUDES) -DOMK_FOR_USER
240 # Check GCC version for user build
241 ifndef CC_MAJOR_VERSION
242 CC_MAJOR_VERSION := sdcc
244 # Prepare suitable define for dependency building
245 #CC_DEPFLAGS = -MT $@ -MD -MP -MF "$@.d.tmp"
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" ; \
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"
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)
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))
282 USER_OBJS += $$($(1)_OBJS)
283 USER_SOURCES += $$($(1)_SOURCES)
284 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
286 -include $(USER_LIB_DIR)/$(LD_SCRIPT).ld$$(addprefix -,$(3))
288 $(2)/$(1)$(addprefix -,$(3)): $(USER_LIB_DIR)/timestamp
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
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))
314 USER_OBJS += $$($(1)_OBJS)
315 USER_SOURCES += $$($(1)_SOURCES)
316 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
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
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))
332 SOLIB_OBJS += $$($(1)_OBJSLO)
333 SOLIB_SOURCES += $$($(1)_SOURCES)
334 USER_EMBEDTARFILES += $$($(1)_EMBEDTARFILES)
336 $(USER_LIB_DIR)/lib$(1).so: $$($(1)_OBJSLO)
337 @$(QUIET_CMD_ECHO) " LINK $$@"
338 $(Q) $(LD) --shared --soname=lib$(1).so -o $$@ $$^
342 library-pass-local: $(lib_LIBRARIES:%=$(USER_LIB_DIR)/$(LIB_PREF)%$(LIB_EXT)) $(shared_LIBRARIES:%=$(USER_LIB_DIR)/$(LIB_PREF)%.so)
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))))
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))))
348 $(foreach prog,$(utils_PROGRAMS),$(foreach link,$(link_VARIANTS),$(eval $(call PROGRAM_template,$(prog),$(USER_UTILS_DIR),$(link)))))
350 $(foreach prog,$(bin_PROGRAMS),$(foreach link,$(link_VARIANTS),$(eval $(call PROGRAM_template,$(prog),$(USER_BIN_DIR),$(link)))))
352 $(foreach lib,$(lib_LIBRARIES),$(eval $(call LIBRARY_template,$(lib))))
354 $(foreach lib,$(shared_LIBRARIES),$(eval $(call SOLIB_template,$(lib))))
356 -include $(USER_OBJS_DIR)/*.d
360 #=====================================================================
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)
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)
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))
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
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" ; )
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 ; )
428 ifdef USER_RULE_TEMPLATES
430 # User-space static libraries and applications object files
432 USER_SOURCES := $(sort $(USER_SOURCES))
434 #$(warning USER_SOURCES = $(USER_SOURCES))
436 $(foreach src,$(filter %.c,$(USER_SOURCES)),$(eval $(call COMPILE_c_o_template,$(SOURCES_DIR)/$(src),$(src:%.c=%$(OBJ_EXT)),)))
438 $(foreach src,$(filter %.cc,$(USER_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cc=%$(OBJ_EXT)),)))
440 $(foreach src,$(filter %.asm,$(USER_SOURCES)),$(eval $(call COMPILE_asm_o_template,$(SOURCES_DIR)/$(src),$(src:%.asm=%$(OBJ_EXT)),)))
442 # User-space shared libraries object files
444 SOLIB_SOURCES := $(sort $(SOLIB_SOURCES))
446 #$(warning SOLIB_SOURCES = $(SOLIB_SOURCES))
448 $(foreach src,$(filter %.c,$(SOLIB_SOURCES)),$(eval $(call COMPILE_c_o_template,$(SOURCES_DIR)/$(src),$(src:%.c=%.lo),$(SOLIB_PICFLAGS))))
450 $(foreach src,$(filter %.cc,$(SOLIB_SOURCES)),$(eval $(call COMPILE_cc_o_template,$(SOURCES_DIR)/$(src),$(src:%.cc=%.lo),$(SOLIB_PICFLAGS))))
452 $(foreach src,$(filter %.asm,$(SOLIB_SOURCES)),$(eval $(call COMPILE_asm_o_template,$(SOURCES_DIR)/$(src),$(src:%.asm=%$(OBJ_EXT)),$(SOLIB_PICFLAGS))))
454 $(foreach tarfile,$(USER_EMBEDTARFILES),$(eval $(call TARFILE_template,$(tarfile),$(tarfile)_tarfile,$(SOURCES_DIR)/$(tarfile))))
459 #=====================================================================
460 # Automatic loading of compiled program by issuing "make load"
462 ifneq ($(OUTPUT_FORMATS),)
463 # Select a file extension (e.g. .bin) for "make load" command to load.
464 LOAD_EXTENSION = .$(firstword $(OUTPUT_FORMATS))
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))) $$<
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)
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
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))))
494 load: $(addprefix load-,$(firstword $(bin_PROGRAMS))-$(firstword $(link_VARIANTS)))
496 run: run-$(firstword $(link_VARIANTS))
499 #=====================================================================
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)