X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;f=bertos%2Frules.mk;h=f62c5cd8a1e8158843217e52de2ba9fc91df4df9;hb=22e903f490208fcc6f6de86250c723b1f200a61d;hp=68ddb9b61e4dbc371cc7cc5294bc2c22b61e0ba6;hpb=74a0e32d3bdb9d11297b409aa841de3982be6417;p=bertos.git diff --git a/bertos/rules.mk b/bertos/rules.mk index 68ddb9b6..f62c5cd8 100644 --- a/bertos/rules.mk +++ b/bertos/rules.mk @@ -36,25 +36,16 @@ endif # Initialize $(top_srcdir) with current directory, unless it was already initialized top_srcdir ?= $(shell pwd) -# Products -TRG_ELF = $(TRG:%=$(OUTDIR)/%.elf) -TRG_S19 = $(TRG:%=$(OUTDIR)/%.s19) -TRG_HEX = $(TRG:%=$(OUTDIR)/%.hex) -TRG_BIN = $(TRG:%=$(OUTDIR)/%.bin) -TRG_ROM = $(TRG:%=$(OUTDIR)/%.rom) -TRG_COF = $(TRG:%=$(OUTDIR)/%.cof) -TRG_EXE = $(TRG:%=$(OUTDIR)/%) - +# Virtual Product: based on target products may be different. +# e.g. Embedded target = hex, s19, bin +# Hosted = exe +TRG_TGT = $(TRG:%=$(OUTDIR)/%.tgt) RECURSIVE_TARGETS = all-recursive install-recursive clean-recursive # The default target .PHONY: all -ifeq ($(EMBEDDED_TARGET),1) -all:: all-recursive $(TRG_S19) $(TRG_HEX) $(TRG_BIN) -else -all:: all-recursive $(TRG_EXE) -endif +all:: all-recursive $(TRG_TGT) # Generate project documentation .PHONY: docs @@ -76,6 +67,20 @@ check: define build_target +ifeq ($$($(1)_EMBEDDED_TGT),1) +#use embedded specific map flags +$(1)_MAP_FLAGS = $$(MAP_FLAGS_EMB) +#In embedded we need s19, hex and bin +$$(OUTDIR)/$(1).tgt : $$(OUTDIR)/$(1).s19 $$(OUTDIR)/$(1).hex $$(OUTDIR)/$(1).bin +else +#use hosted specific map flags +$(1)_MAP_FLAGS = $$(MAP_FLAGS_HOST) +#in hosted application we need only executable file. +$$(OUTDIR)/$(1).tgt : $$(OUTDIR)/$(1) +endif + +$(1)_LDFLAGS += $$($(1)_MAP_FLAGS) + ifneq ($$(strip $$($(1)_MCU)),) # Define all project specific object files $(1)_CFLAGS += -mmcu=$$($(1)_MCU) @@ -100,6 +105,7 @@ $(1)_CC = $$($(1)_CROSS)$$(CC) $(1)_CXX = $$($(1)_CROSS)$$(CXX) $(1)_AS = $$($(1)_CROSS)$$(AS) $(1)_OBJCOPY = $$($(1)_CROSS)$$(OBJCOPY) +$(1)_STRIP = $$($(1)_CROSS)$$(STRIP) $(1)_COBJ = $$(foreach file,$$($(1)_CSRC:%.c=%.o),$$(OBJDIR)/$(1)/$$(file)) $(1)_CXXOBJ = $$(foreach file,$$($(1)_CXXSRC:%.cpp=%.o),$$(OBJDIR)/$(1)/$$(file)) @@ -274,7 +280,7 @@ bumprev: buildnr=`sed <"$(BUILDREV_H)" -n -e 's/#define VERS_BUILD \([0-9][0-9]*\)/\1/p'`; \ fi; \ buildnr=`expr $$buildnr + 1`; \ - buildhost=`hostname | sed -n -e '1h;2,$$H;$${g;s/\n//g;p}'`; \ + buildhost=`hostname | sed -n -e '1h;2,$$H;$${g;s/\n//g;p;}'`; \ echo "#define VERS_BUILD $$buildnr" >"$(BUILDREV_H)"; \ echo "#define VERS_HOST \"$$buildhost\"" >>"$(BUILDREV_H)"; \ echo "Building revision $$buildnr"