13
|
1 |
# Copyright (c) 2009-2010 Nokia Corporation and/or its subsidiary(-ies).
|
|
2 |
# All rights reserved.
|
|
3 |
# This component and the accompanying materials are made available
|
|
4 |
# under the terms of the License "Eclipse Public License v1.0"
|
|
5 |
# which accompanies this distribution, and is available
|
|
6 |
# at the URL "http://www.eclipse.org/legal/epl-v10.html".
|
|
7 |
#
|
|
8 |
# Initial Contributors:
|
|
9 |
# Nokia Corporation - initial contribution.
|
|
10 |
#
|
|
11 |
# Contributors:
|
|
12 |
#
|
|
13 |
# Description:
|
|
14 |
# Run Trace Compiler on source files to generate trace headers and decode files
|
|
15 |
|
18
|
16 |
# Expected inputs:
|
|
17 |
# TARGETEXT
|
|
18 |
|
28
|
19 |
# Set macro for TRACES keyword
|
|
20 |
ifneq ($(TRACES),)
|
|
21 |
CDEFS:=$(CDEFS) OST_TRACE_COMPILER_IN_USE
|
|
22 |
$(if $(FLMDEBUG),$(info <debug>CDEFS=$(CDEFS)</debug>))
|
|
23 |
endif
|
|
24 |
|
13
|
25 |
# Set project name as <mmp_name>
|
|
26 |
TRACE_PRJNAME:=$(basename $(notdir $(PROJECT_META)))
|
18
|
27 |
OLDTC_TRACE_PRJNAME:=$(TRACE_PRJNAME)
|
|
28 |
TRACE_RELEASABLE_ID:=$(TARGET)_$(TARGETEXT)
|
13
|
29 |
|
18
|
30 |
define get_trace_path
|
|
31 |
$(firstword $(filter %$1, $(USERINCLUDE) $(SYSTEMINCLUDE)))
|
|
32 |
endef
|
|
33 |
|
|
34 |
$(if $(FLMDEBUG),$(info <debug>INCLUDES=$(USERINCLUDE) $(SYSTEMINCLUDE)</debug>))
|
|
35 |
$(if $(FLMDEBUG),$(info <debug>TARGET=$(TARGET) TARGETEXT=$(TARGETEXT)</debug>))
|
13
|
36 |
|
28
|
37 |
# Find out TRACE_PATH by looking for the trace folder in SYSTEMINCLUDE and USERINCLUDES
|
|
38 |
# traces/<target_name>_<target_extension>
|
|
39 |
TRACE_PATH:=$(call get_trace_path,/traces/$(TRACE_RELEASABLE_ID))
|
13
|
40 |
ifneq ($(TRACE_PATH),)
|
18
|
41 |
TRACE_PRJNAME:=$(TRACE_RELEASABLE_ID)
|
|
42 |
else # obsolete forms for compatibility
|
|
43 |
# traces_<target_name>_<target_ext>
|
|
44 |
TRACE_PATH:=$(call get_trace_path,/traces_$(TARGET)_$(TARGETEXT))
|
|
45 |
ifneq ($(TRACE_PATH),)
|
|
46 |
# set project name as <target_name>_<target_ext> instead of <mmp_name>
|
|
47 |
# to trick old TCom into finding the path.
|
|
48 |
OLDTC_TRACE_PRJNAME:=$(TARGET)_$(TARGETEXT)
|
|
49 |
else
|
|
50 |
# traces_<target_name>_<target_type>
|
|
51 |
TRACE_PATH:=$(call get_trace_path,/traces_$(TARGET)_$(TARGETTYPE))
|
|
52 |
ifneq ($(TRACE_PATH),)
|
|
53 |
# set project name as <target_name>_<target_type> instead of <mmp_name>
|
|
54 |
# to trick old TCom into finding the path.
|
|
55 |
OLDTC_TRACE_PRJNAME:=$(TARGET)_$(TARGETTYPE)
|
|
56 |
else
|
|
57 |
# traces_<mmp_name>
|
|
58 |
TRACE_PATH:=$(call get_trace_path,/traces_$(TRACE_PRJNAME))
|
|
59 |
|
|
60 |
# traces
|
|
61 |
ifeq ($(TRACE_PATH),)
|
|
62 |
TRACE_PATH:=$(call get_trace_path,/traces)
|
|
63 |
endif
|
|
64 |
endif
|
|
65 |
endif
|
13
|
66 |
endif
|
|
67 |
|
|
68 |
|
|
69 |
# initialise (so what output will be correct if we don't actually run the TC)
|
|
70 |
TRACE_DICTIONARY:=
|
|
71 |
AUTOGEN_HEADER:=
|
28
|
72 |
$(if $(FLMDEBUG),$(info <debug>TRACE_PATH='$(TRACE_PATH)' TRACE_RELEASABLE_ID='$(TRACE_RELEASABLE_ID)'</debug>))
|
13
|
73 |
|
|
74 |
# Run trace compiler only if TRACE_PATH exists
|
|
75 |
ifneq ($(TRACE_PATH),)
|
18
|
76 |
TRACE_MARKER:=$(TRACE_MARKER_PATH)/tracecompile_$(TRACE_RELEASABLE_ID)_$(UID_TC).done
|
28
|
77 |
TRACE_THISCOMPONENT_ALLRULE:=$(call sanitise,$(COMPONENT_META))_alltracedone
|
13
|
78 |
TRACE_HEADERS:=
|
|
79 |
|
18
|
80 |
TRACE_SOURCE_LIST:=$(TRACE_MARKER_PATH)/tracecompile_$(TRACE_RELEASABLE_ID)_$(UID_TC).sourcelist
|
28
|
81 |
$(if $(FLMDEBUG),$(info <debug>TRACE_SOURCE_LIST=$(TRACE_SOURCE_LIST)</debug>))
|
18
|
82 |
TRACE_VARIANT_SOURCE_LIST:=$(OUTPUTPATH)/$(VARIANTPLATFORM)/$(VARIANTTYPE)/tracecompile_$(TRACE_RELEASABLE_ID)_$(UID_TC).sourcelist
|
28
|
83 |
$(if $(FLMDEBUG),$(info <debug>TRACE_VARIANT_SOURCE_LIST=$(TRACE_VARIANT_SOURCE_LIST)</debug>))
|
18
|
84 |
|
|
85 |
# The sourcelist_grouped_write macro allows us to construct a source list file, 10 objects at a time
|
|
86 |
# to avoid limits on argument lengths and sizes on Windows.
|
|
87 |
# $1 = list of source files
|
|
88 |
# $2 = ">" or ">>" i.e. for creating the file.
|
|
89 |
define sourcelist_grouped_write
|
|
90 |
$(call startrule,sourcelist_write) \
|
|
91 |
$(if $1,echo -en '$(subst $(CHAR_SPACE),\n,$(strip $(wordlist 1,10,$1)))\n' $2 $$@,true) \
|
|
92 |
$(call endrule,sourcelist_write)
|
|
93 |
$(if $1,$(call sourcelist_grouped_write,$(wordlist 11,$(words $1),$1),>>),)
|
|
94 |
endef
|
13
|
95 |
|
18
|
96 |
# Write the list of sources for this variant to a file
|
|
97 |
# Make the combined sourcelist for this target depend on it
|
|
98 |
# It's all to do with how make treats this file when it
|
|
99 |
# does exist. We are forcing it evaluate the target rule here
|
|
100 |
# even if the file is in place by making it PHONY. In other
|
|
101 |
# words, this is forcing the variant source list to always
|
|
102 |
# be written but later on we might not write to the combined
|
|
103 |
# source list if it isn't going to change.
|
|
104 |
define sourcelist_write
|
|
105 |
$(TRACE_SOURCE_LIST): $(TRACE_VARIANT_SOURCE_LIST)
|
13
|
106 |
|
18
|
107 |
.PHONY:: $(TRACE_VARIANT_SOURCE_LIST)
|
|
108 |
|
|
109 |
$(TRACE_VARIANT_SOURCE_LIST): $(SOURCE)
|
|
110 |
$(call sourcelist_grouped_write,$(SOURCE),>)
|
|
111 |
|
|
112 |
endef
|
|
113 |
|
|
114 |
$(eval $(sourcelist_write))
|
|
115 |
$(eval $(call GenerateStandardCleanTarget,$(TRACE_VARIANT_SOURCE_LIST),,))
|
|
116 |
|
|
117 |
|
|
118 |
$(if $(FLMDEBUG),$(info <debug>Trace Compiler SOURCES: $(SOURCE)</debug>))
|
13
|
119 |
|
28
|
120 |
|
|
121 |
.PHONY:: $(TRACE_THISCOMPONENT_ALLRULE)
|
|
122 |
|
|
123 |
$(TRACE_THISCOMPONENT_ALLRULE):: $(TRACE_MARKER)
|
|
124 |
|
13
|
125 |
$(TRACE_MARKER) : $(SOURCE)
|
|
126 |
|
|
127 |
TRACE_HEADERS:=$(foreach SRC,$(SOURCE),$(TRACE_PATH)/$(basename $(notdir $(SRC)))Traces.h)
|
|
128 |
|
|
129 |
$(TRACE_HEADERS): $(TRACE_MARKER)
|
|
130 |
|
28
|
131 |
TRACE_GUARD:=GUARD_$(call sanitise,$(TRACE_MARKER))
|
|
132 |
$(if $(FLMDEBUG),$(info <debug>TRACE GUARD for '$(TRACE_RELEASABLE_ID)' is: $(TRACE_GUARD)=$($(TRACE_GUARD))</debug>))
|
13
|
133 |
|
28
|
134 |
ifeq ($($(TRACE_GUARD)),)
|
|
135 |
$(TRACE_GUARD):=1
|
|
136 |
|
|
137 |
$(if $(FLMDEBUG),$(info <debug>PAST GUARD (unique trace) for '$(TRACE_RELEASABLE_ID)'</debug>))
|
13
|
138 |
# The trace compiler likes to change . into _ so we must do the same in the case of mmps with a name like
|
|
139 |
# fred.prd.mmp we want fred_prd
|
|
140 |
TRACE_PRJNAME_SANITISED:=$(subst .,_,$(TRACE_PRJNAME))
|
18
|
141 |
OLDTC_TRACE_PRJNAME_SANITISED:=$(subst .,_,$(OLDTC_TRACE_PRJNAME))
|
13
|
142 |
|
|
143 |
|
|
144 |
JAVA_COMMAND:=$(SBS_JAVATC)
|
|
145 |
TRACE_COMPILER_PATH:=$(EPOCROOT)/epoc32/tools
|
18
|
146 |
|
|
147 |
# declare the trace_compile macro but only do it once in the build
|
|
148 |
ifeq ($(trace_compile),)
|
|
149 |
|
|
150 |
# Find out which macro to declare - the one supporting the new CLI
|
|
151 |
# or the old one. First try to find TraceCompilerMain.class
|
|
152 |
# If it is there then it might be the new posix-like interface
|
|
153 |
TRACE_VER:=
|
|
154 |
TRACE_VSTR:=
|
|
155 |
|
|
156 |
TCClass:=$(wildcard $(TRACE_COMPILER_PATH)/tracecompiler/com/nokia/tracecompiler/TraceCompilerMain.class)
|
|
157 |
ifneq ($(TCClass),)
|
|
158 |
# Get the version string from the TC (assume it's the new one)
|
|
159 |
TRACE_COMPILER_START:=-classpath $(TRACE_COMPILER_PATH)/tracecompiler com.nokia.tracecompiler.TraceCompilerMain
|
|
160 |
TRACE_VSTR:=$(firstword $(subst TraceCompiler version ,,$(shell $(JAVA_COMMAND) $(TRACE_COMPILER_START) --version)))
|
|
161 |
# check if it looks like a version that supports the new cli interface: supporting up to verion 9 in the future.
|
|
162 |
TRACE_VER:=$(findstring new,$(foreach version,2 3 4 5 6 7 8 9,$(patsubst $(version).%,new,$(TRACE_VSTR))))
|
|
163 |
endif
|
|
164 |
$(if $(FLMDEBUG),$(info <debug>TRACE_VSTR=$(TRACE_VSTR) TRACE_VER=$(TRACE_VER)</debug>))
|
13
|
165 |
|
|
166 |
|
18
|
167 |
# 0. Generate a combined sourcelist from all variants.
|
|
168 |
# 0.1 Write the combined list to a temporary file
|
|
169 |
# 0.2 Check if there are new files since the last build
|
|
170 |
# md5 stored in the trace marker.
|
|
171 |
# 0.3 Rewrite the combined sourcelist if new sourcefiles have appeared
|
|
172 |
# since the last build
|
13
|
173 |
# 1. Use pipe to send inputs to trace compiler to process
|
|
174 |
# 2. Create a hash regarding to source names and put it in marker.
|
|
175 |
# 3. Show source names that are processed by trace compiler
|
18
|
176 |
|
|
177 |
ifeq ($(TRACE_VER),new)
|
13
|
178 |
define trace_compile
|
18
|
179 |
|
|
180 |
$(TRACE_SOURCE_LIST):
|
|
181 |
$(call startrule,sourcelist_combine) \
|
|
182 |
$(GNUCAT) $(TRACE_SOURCE_LIST) $$^ 2>/dev/null | $(GNUSORT) -u > $$@.new && \
|
|
183 |
$(GNUMD5SUM) -c $(TRACE_MARKER) 2>/dev/null || \
|
|
184 |
$(GNUCP) $$@.new $$@ \
|
|
185 |
$(call endrule,sourcelist_combine)
|
|
186 |
|
|
187 |
$(TRACE_MARKER) : $(PROJECT_META) $(TRACE_SOURCE_LIST)
|
13
|
188 |
$(call startrule,tracecompile) \
|
18
|
189 |
( $(GNUCAT) $(TRACE_SOURCE_LIST); \
|
13
|
190 |
echo -en "*ENDOFSOURCEFILES*\n" ) | \
|
18
|
191 |
$(JAVA_COMMAND) $(TRACE_COMPILER_START) $(if $(FLMDEBUG),-d,) --uid=$(UID_TC) --project=$(TRACE_PRJNAME) --mmp=$(PROJECT_META) --traces=$(TRACE_PATH) && \
|
|
192 |
$(GNUMD5SUM) $(TRACE_SOURCE_LIST).new > $$@ 2>/dev/null && \
|
13
|
193 |
{ $(GNUTOUCH) $(TRACE_DICTIONARY) $(AUTOGEN_HEADER); \
|
|
194 |
$(GNUCAT) $(TRACE_SOURCE_LIST) ; true ; } \
|
|
195 |
$(call endrule,tracecompile)
|
|
196 |
endef
|
|
197 |
|
18
|
198 |
else # Old inteface
|
|
199 |
TRACE_COMPILER_START:=-classpath $(TRACE_COMPILER_PATH)/tracecompiler com.nokia.tracecompiler.TraceCompiler
|
|
200 |
|
|
201 |
define trace_compile
|
|
202 |
|
|
203 |
$(TRACE_SOURCE_LIST):
|
|
204 |
$(call startrule,sourcelist_combine) \
|
|
205 |
$(GNUCAT) $(TRACE_SOURCE_LIST) $$^ 2>/dev/null | $(GNUSORT) -u > $$@.new && \
|
|
206 |
$(GNUMD5SUM) -c $(TRACE_MARKER) 2>/dev/null || \
|
|
207 |
$(GNUCP) $$@.new $$@ \
|
|
208 |
$(call endrule,sourcelist_combine)
|
|
209 |
|
|
210 |
$(TRACE_MARKER) : $(PROJECT_META) $(TRACE_SOURCE_LIST)
|
|
211 |
$(call startrule,tracecompile) \
|
|
212 |
( echo -en "$(OLDTC_TRACE_PRJNAME)\n$(PROJECT_META)\n"; \
|
|
213 |
$(GNUCAT) $(TRACE_SOURCE_LIST); \
|
|
214 |
echo -en "*ENDOFSOURCEFILES*\n" ) | \
|
|
215 |
$(JAVA_COMMAND) $(TRACE_COMPILER_START) $(UID_TC) && \
|
|
216 |
$(GNUMD5SUM) $(TRACE_SOURCE_LIST).new > $$@ 2>/dev/null && \
|
|
217 |
{ $(GNUTOUCH) $(TRACE_DICTIONARY) $(AUTOGEN_HEADER); \
|
|
218 |
$(GNUCAT) $(TRACE_SOURCE_LIST) ; true ; } \
|
|
219 |
$(call endrule,tracecompile)
|
|
220 |
endef
|
|
221 |
|
|
222 |
# End - new/old trace compiler
|
|
223 |
endif
|
|
224 |
|
|
225 |
# End - tracecompile is defined
|
|
226 |
endif
|
|
227 |
|
|
228 |
ifeq ($(TRACE_VER),new)
|
|
229 |
TRACE_DICTIONARY:=$(EPOCROOT)/epoc32/ost_dictionaries/$(TRACE_PRJNAME_SANITISED)_0x$(UID_TC)_Dictionary.xml
|
|
230 |
AUTOGEN_HEADER:=$(EPOCROOT)/epoc32/include/platform/symbiantraces/autogen/$(TRACE_PRJNAME_SANITISED)_0x$(UID_TC)_TraceDefinitions.h
|
|
231 |
else
|
|
232 |
TRACE_DICTIONARY:=$(EPOCROOT)/epoc32/ost_dictionaries/$(OLDTC_TRACE_PRJNAME_SANITISED)_0x$(UID_TC)_Dictionary.xml
|
|
233 |
AUTOGEN_HEADER:=$(EPOCROOT)/epoc32/include/internal/symbiantraces/autogen/$(OLDTC_TRACE_PRJNAME_SANITISED)_0x$(UID_TC)_TraceDefinitions.h
|
|
234 |
endif
|
|
235 |
|
13
|
236 |
$(eval $(trace_compile))
|
|
237 |
|
|
238 |
$(eval $(call GenerateStandardCleanTarget, $(TRACE_PATH)/tracebuilder.cache $(TRACE_MARKER) $(TRACE_SOURCE_LIST),,))
|
|
239 |
|
18
|
240 |
$(call makepath,$(TRACE_PATH) $(dir $(TRACE_DICTIONARY) $(AUTOGEN_HEADER)))
|
|
241 |
# End - guard that prevents repeated calls to TCom
|
13
|
242 |
endif
|
|
243 |
|
|
244 |
$(eval $(call GenerateStandardCleanTarget,$(TRACE_HEADERS),,))
|
|
245 |
|
18
|
246 |
# End - Nothing to trace (not trace path in include)
|
13
|
247 |
else
|
|
248 |
# Indicate to following parts of the FLM that we actually won't run
|
|
249 |
# trace compiler so they can set dependencies accordingly.
|
|
250 |
USE_TRACE_COMPILER:=
|
|
251 |
endif
|
|
252 |
|