author | Iain Williamson <iain.williamson@nokia.com> |
Thu, 10 Dec 2009 16:51:17 +0000 | |
branch | wip |
changeset 80 | cc878ffa65f3 |
parent 27 | 2e850dca8de6 |
child 71 | ba3ff6a1ecab |
child 161 | 62c28226cde4 |
permissions | -rw-r--r-- |
3 | 1 |
# Copyright (c) 2006-2009 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 |
# ARMv5 EXE/DLL ABIv2 Function Like Makefile (FLM) |
|
15 |
# Knows how to build all possible ABIV2 executables for ARM |
|
16 |
# |
|
17 |
# |
|
18 |
||
19 |
# Only build feature invariant binaries in non-product builds *and* |
|
20 |
# Only build feature variant binaries in product builds. |
|
21 |
# |
|
22 |
# FEATUREVARIANTNAME != "" implies product build |
|
23 |
# FEATUREVARIANT == 1 implies a feature variant binary |
|
24 |
# |
|
25 |
# test FEATUREVARIANTNAME=="" or FEATUREVARIANT==1 |
|
26 |
# |
|
27 |
ifneq ($(or $(call equal,$(FEATUREVARIANTNAME),),$(call equal,$(FEATUREVARIANT),1)),) |
|
28 |
||
29 |
$(if $(FLMDEBUG),$(info <flm name='e32abiv2' target='$(TARGET)' type='$(TARGETTYPE)' outputpath='$(OUTPUTPATH)' metasource='$(METASOURCE)' postlinkfiletype='$(POSTLINKFILETYPE)' />)) |
|
30 |
||
31 |
# Strip switch-type parameters |
|
32 |
# |
|
33 |
POSTLINKTARGETTYPE:=$(strip $(POSTLINKTARGETTYPE)) |
|
34 |
UID1:=$(strip $(UID1)) |
|
35 |
UID2:=$(strip $(UID2)) |
|
36 |
UID3:=$(strip $(UID3)) |
|
37 |
SID:=$(strip $(SECUREID)) |
|
38 |
VENDORID:=$(strip $(VENDORID)) |
|
39 |
AUTOEXPORTS:=$(strip $(AUTOEXPORTS)) |
|
40 |
DEFFILE:=$(strip $(DEFFILE)) |
|
41 |
IMPORTLIBRARYREQUIRED:=$(strip $(IMPORTLIBRARYREQUIRED)) |
|
42 |
EPOCALLOWDLLDATA:=$(strip $(EPOCALLOWDLLDATA)) |
|
43 |
PAGED:=$(strip $(PAGED)) |
|
44 |
||
45 |
# the output directories |
|
46 |
VARIANTPLATFORM:=$(VARIANTPLATFORM)$(FEATUREVARIANTNAME) |
|
47 |
RELEASABLEPATH:=$(RELEASEPATH)/$(VARIANTPLATFORM)/$(VARIANTTYPE) |
|
48 |
INTERMEDIATEPATH:=$(OUTPUTPATH)/$(VARIANTPLATFORM)/$(VARIANTTYPE) |
|
49 |
INTERMEDIATE_PLATFORM_PATH:=$(OUTPUTPATH)/$(VARIANTPLATFORM) |
|
50 |
TRACE_MARKER_PATH:=$(OUTPUTPATH) |
|
51 |
IMPORTLIBPATH:=$(RUNTIME_LIBS_PATH) |
|
52 |
||
53 |
# LOCALLY USED VARIABLES |
|
54 |
CLEANTARGETS:= |
|
55 |
WHATRELEASE:= |
|
56 |
||
57 |
# Work out which new/delete library to use for binaries. |
|
58 |
CHECKLIB_TYPE:=symc++ |
|
59 |
STDCPPTAGFILE:= |
|
60 |
ifeq ($(NOSTDCPP),1) |
|
61 |
ifeq ($(STDCPP),1) |
|
62 |
$(info <warning>STDCPP and NOSTDCPP both specified in $(PROJECT_META)</warning>) |
|
63 |
else |
|
64 |
ifeq ($(HAS_DEDICATED_OP_NEWDEL_LIB),1) |
|
65 |
DEFAULT_NEWLIB:=$(DEFAULT_SYMBIAN_NEWLIB) |
|
66 |
endif |
|
67 |
endif |
|
68 |
else |
|
69 |
ifeq ($(STDCPP),1) |
|
70 |
CDEFS:=$(CDEFS) __SYMBIAN_STDCPP_SUPPORT__ |
|
71 |
ifneq ($(SUPPORTS_STDCPP_NEWLIB),) |
|
72 |
ifeq ($(HAS_DEDICATED_OP_NEWDEL_LIB),1) |
|
73 |
DEFAULT_NEWLIB:=$(DEFAULT_STDCPP_NEWLIB) |
|
74 |
endif |
|
75 |
CHECKLIB_TYPE:=stdc++ |
|
76 |
STDCPPTAGFILE:=$(EPOCROOT)/epoc32/tools/tag/tag_elf |
|
77 |
endif |
|
78 |
endif |
|
79 |
endif |
|
80 |
||
81 |
# If NEWLIB is specified in the MMP file, it overrides all the past stuff. |
|
82 |
ifeq ($(NEWLIB),) |
|
83 |
NEWLIB:=$(DEFAULT_NEWLIB) |
|
84 |
endif |
|
85 |
||
86 |
||
87 |
########################################################################## |
|
88 |
## OUTPUTS - externally relevant targets that this FLM generates |
|
89 |
||
90 |
||
91 |
ifeq ($(EXPORTLIBRARY),) |
|
92 |
EXPORTLIBRARY:=$(TARGET) |
|
93 |
endif |
|
94 |
||
95 |
# This will insert the file version between the name and the extension. |
|
96 |
# If there is more than one dot in generated filename the inserted position will be |
|
97 |
# BEFORE the last but two dot. E.g name1.name2.name3.dll to name1.name2{version}.name3.dll |
|
98 |
LIBEXT:=$(lastword $(subst .,$(CHAR_SPACE) ,$(EXPORTLIBRARY))) |
|
99 |
LIBBASE:=$(patsubst %.$(LIBEXT),%,$(EXPORTLIBRARY)) |
|
100 |
ifneq ($(findstring .,$(EXPORTLIBRARY)),) |
|
101 |
# Please note $(EXPORTLIBRARY) doesn't include target type. |
|
102 |
VER_E32IMPORTLIBBASE:=$(IMPORTLIBPATH)/$(LIBBASE){$(VERSIONHEX)}.$(LIBEXT) |
|
103 |
else |
|
104 |
VER_E32IMPORTLIBBASE:=$(IMPORTLIBPATH)/$(EXPORTLIBRARY){$(VERSIONHEX)} |
|
105 |
endif |
|
106 |
||
107 |
# Postlinkable targets need to be linked and elf2e32'd |
|
108 |
ifneq ($(DOPOSTLINK),) |
|
109 |
E32TARGET:=$(RELEASABLEPATH)/$(TARGET)$(if $(EXPLICITVERSION),{$(VERSIONHEX)},).$(if $(REQUESTEDTARGETEXT),$(REQUESTEDTARGETEXT),$(POSTLINKFILETYPE)) |
|
110 |
LINK_TARGET:=$(RELEASABLEPATH)/$(TARGET)$(if $(EXPLICITVERSION),{$(VERSIONHEX)},).$(if $(REQUESTEDTARGETEXT),$(REQUESTEDTARGETEXT),$(POSTLINKFILETYPE)).sym |
|
111 |
MAPFILE:=$(RELEASABLEPATH)/$(TARGET).$(if $(REQUESTEDTARGETEXT),$(REQUESTEDTARGETEXT),$(POSTLINKFILETYPE)).map |
|
112 |
else |
|
113 |
E32TARGET:= |
|
114 |
LINK_TARGET:= |
|
115 |
MAPFILE:= |
|
116 |
endif |
|
117 |
||
118 |
# libs and klibs, on the other hand need to be archived |
|
119 |
ifneq ($(call isoneof,$(TARGETTYPE),lib klib stdlib),) |
|
120 |
ARTARGET:=$(RELEASABLEPATH)/$(TARGET).lib |
|
121 |
# We need libs and klibs before we can link stuff with them: |
|
122 |
LIBRARY:: $(ARTARGET) |
|
123 |
else |
|
124 |
ARTARGET:= |
|
125 |
endif |
|
126 |
||
127 |
||
128 |
ifneq ($(IMPORTLIBRARYREQUIRED),) # no dso files for plugins, animation dlls etc |
|
129 |
# make sure we don't build import libraries more than once for UDEB and UREL |
|
130 |
# Without this, wierd target-specific variable problems happen with LIBRARY in particular |
|
131 |
||
132 |
TMP_IMPORTLIBTARGET_ROOT:=$(IMPORTLIBPATH)/$(EXPORTLIBRARY) |
|
133 |
||
134 |
# ABIv2 .dso |
|
135 |
IMPORTLIBTARGET_DSO:= |
|
136 |
IMPORTLIBTARGETVERSIONED_DSO:= |
|
137 |
||
138 |
BUILDMARKER_IMPORTLIBTARGET_DSO:=TARGET_$(subst :,,$(VER_E32IMPORTLIBBASE)).dso |
|
139 |
WHATRELEASE:=$(WHATRELEASE) $(if $(EXPLICITVERSION),,$(TMP_IMPORTLIBTARGET_ROOT).dso) |
|
140 |
WHATRELEASE:=$(WHATRELEASE) $(VER_E32IMPORTLIBBASE).dso |
|
141 |
ifeq ($($(BUILDMARKER_IMPORTLIBTARGET_DSO)),) |
|
142 |
IMPORTLIBTARGET_DSO:=$(TMP_IMPORTLIBTARGET_ROOT).dso |
|
143 |
IMPORTLIBTARGETVERSIONED_DSO:=$(VER_E32IMPORTLIBBASE).dso |
|
144 |
endif |
|
145 |
||
146 |
# ABIv1 .lib (for specific builds, toolchains and host OS platforms only) |
|
147 |
IMPORTLIBTARGET_LIB:= |
|
148 |
IMPORTLIBTARGETVERSIONED_LIB:= |
|
149 |
BUILDMARKER_IMPORTLIBTARGET_LIB:=TARGET_$(subst :,,$(VER_E32IMPORTLIBBASE)).lib |
|
150 |
# Only for builds that require and support them, and only on windows |
|
151 |
ifeq ($(OSTYPE),cygwin) |
|
152 |
ifeq ($(GENERATE_ABIV1_IMPLIBS),1) |
|
153 |
WHATRELEASE:=$(WHATRELEASE) $(if $(EXPLICITVERSION),,$(TMP_IMPORTLIBTARGET_ROOT).lib) |
|
154 |
WHATRELEASE:=$(WHATRELEASE) $(VER_E32IMPORTLIBBASE).lib |
|
155 |
ifeq ($($(BUILDMARKER_IMPORTLIBTARGET_LIB)),) |
|
156 |
IMPORTLIBTARGET_LIB:=$(TMP_IMPORTLIBTARGET_ROOT).lib |
|
157 |
IMPORTLIBTARGETVERSIONED_LIB:=$(VER_E32IMPORTLIBBASE).lib |
|
158 |
endif |
|
159 |
endif |
|
160 |
endif |
|
161 |
endif |
|
162 |
||
163 |
# Try to make sure that we get the right linkas name |
|
164 |
# If linkas is specified then split it up and |
|
165 |
# put the hex version number in the right place |
|
166 |
ifeq ($(LINKAS),) |
|
167 |
LINKASNAME=$(TARGET) |
|
168 |
LINKASTYPE=$(if $(REQUESTEDTARGETEXT),$(REQUESTEDTARGETEXT),$(POSTLINKFILETYPE)) |
|
169 |
else |
|
170 |
SPLIT_LINKAS=$(subst ., ,$(LINKAS)) |
|
171 |
LINKASNAME=$(word 1,$(SPLIT_LINKAS)) |
|
172 |
LINKASTYPE=$(word 2,$(SPLIT_LINKAS)) |
|
173 |
endif |
|
174 |
||
175 |
# ignore UID3 if it is zero |
|
176 |
ifeq ($(UID3),00000000) |
|
177 |
LINKASVERSIONED=$(LINKASNAME){$(VERSIONHEX)}.$(LINKASTYPE) |
|
178 |
else |
|
179 |
LINKASVERSIONED=$(LINKASNAME){$(VERSIONHEX)}$(if $(UID3),[$(UID3)],).$(LINKASTYPE) |
|
180 |
endif |
|
181 |
||
182 |
########################################################################## |
|
183 |
## TARGET GROUPS ## |
|
184 |
RELEASABLES:=$(strip $(E32TARGET) $(ARTARGET) $(LINK_TARGET) $(MAPFILE)) |
|
185 |
# More targets to be added later |
|
186 |
TARGETS:=$(strip $(E32TARGET) $(IMPORTLIBTARGET) $(LINK_TARGET) $(ARTARGET)) |
|
187 |
||
188 |
CREATABLEPATHS:=$(OUTPUTPATH) |
|
189 |
CREATABLEPATHS:=$(CREATABLEPATHS) $(INTERMEDIATE_PLATFORM_PATH) |
|
190 |
CREATABLEPATHS:=$(CREATABLEPATHS) $(INTERMEDIATEPATH) |
|
191 |
CREATABLEPATHS:=$(CREATABLEPATHS) $(RELEASABLEPATH) |
|
192 |
CREATABLEPATHS:=$(CREATABLEPATHS) $(RUNTIME_LIBS_PATH) |
|
193 |
CREATABLEPATHS:=$(CREATABLEPATHS) $(IMPORTLIBPATH) |
|
194 |
WHATRELEASE:=$(WHATRELEASE) $(RELEASABLES) |
|
195 |
||
196 |
||
197 |
||
198 |
## HIGH LEVEL Targets ## |
|
199 |
.PHONY:: $(ALLTARGET) |
|
200 |
||
201 |
## GLOBAL TARGETS ############################################################ |
|
202 |
$(ALLTARGET):: $(RELEASABLES) |
|
203 |
TARGET:: $(RELEASABLES) |
|
204 |
||
205 |
## Internal targets ## |
|
206 |
||
207 |
# Determine the name of the generated DSO file ############################### |
|
208 |
# This is to generate the dso with the Some{Versionhex}.file.dso |
|
209 |
# It reproduces what appears to be a problem in the current build system |
|
210 |
# that affects messageintercept{000a0000}.esockdebug.dso whose |
|
211 |
# filename differs from it's "linkas" name. |
|
212 |
E32VAR:=$(subst .,$(CHAR_SPACE) ,$(TARGET)) |
|
213 |
E32SOME:=$(word 1,$(E32VAR)) |
|
214 |
E32VAR2:=$(patsubst $(E32SOME).%,%,$(TARGET)) |
|
215 |
||
216 |
# Separate '_SH' variables created for output into bash - Preserves '{' and '}' |
|
217 |
||
218 |
ifneq ($(findstring .,$(TARGET)),) |
|
219 |
DSODEFFILENAMEBASE:=$(E32SOME){$(VERSIONHEX)}.$(E32VAR2) |
|
220 |
else |
|
221 |
DSODEFFILENAMEBASE:=$(TARGET){$(VERSIONHEX)} |
|
222 |
endif |
|
223 |
GENERATED_DSO:=$(call dblquote,$(INTERMEDIATEPATH)/$(DSODEFFILENAMEBASE).dso) |
|
224 |
GENERATED_DEFFILE:=$(INTERMEDIATEPATH)/$(DSODEFFILENAMEBASE).def |
|
225 |
||
226 |
## IMPORT LIBRARY ########################################################### |
|
227 |
||
228 |
# Static libraries will be postlinked when they are used so don't try to postlink them |
|
229 |
||
230 |
ifneq ($(IMPORTLIBRARYREQUIRED),) |
|
231 |
ifneq ($(or $(DEFFILE),$(EXPORTUNFROZEN)),) |
|
232 |
# Both ABIv2 .dso and ABIv1 .lib import library generation require a processed .def file, |
|
233 |
# unless EXPORTUNFROZEN is being used |
|
234 |
PREPPEDDEFFILE:= |
|
235 |
ifneq ($(DEFFILE),) |
|
236 |
ifeq ($(EXPORTUNFROZEN),) |
|
237 |
PREPPEDDEFFILE:=$(INTERMEDIATEPATH)/$(TARGET).prep |
|
238 |
CLEANTARGETS:=$(CLEANTARGETS) $(PREPPEDDEFFILE) |
|
239 |
define importlibtarget_prepfile |
|
240 |
$(PREPPEDDEFFILE): $(DEFFILE) |
|
241 |
$(call startrule,importlibtarget_prepfile,FORCESUCCESS) \ |
|
242 |
$(PREPDEF) $(call dblquote,$(DEFFILE)) $(call dblquote,$(PREPPEDDEFFILE)) \ |
|
243 |
$(call endrule,importlibtarget_prepfile) |
|
244 |
endef |
|
245 |
$(eval $(importlibtarget_prepfile)) |
|
246 |
endif |
|
247 |
endif |
|
248 |
||
249 |
# ABIv2 .dso |
|
250 |
ifneq ($(IMPORTLIBTARGET_DSO),) # check that we haven't tried to specify this target already |
|
251 |
||
26
96670e6a4bfd
Try to cope with the iscapi implib problem.
timothy.murphy@nokia.com
parents:
9
diff
changeset
|
252 |
# By Now we're committed to producing a target for this DSO so it's safe to |
96670e6a4bfd
Try to cope with the iscapi implib problem.
timothy.murphy@nokia.com
parents:
9
diff
changeset
|
253 |
# set the marker that will prevent any further targets from being made. |
96670e6a4bfd
Try to cope with the iscapi implib problem.
timothy.murphy@nokia.com
parents:
9
diff
changeset
|
254 |
$(eval $(BUILDMARKER_IMPORTLIBTARGET_DSO):=1) |
96670e6a4bfd
Try to cope with the iscapi implib problem.
timothy.murphy@nokia.com
parents:
9
diff
changeset
|
255 |
|
3 | 256 |
ifneq ($(EXPLICITVERSION),) |
257 |
TARGETS:=$(strip $(TARGETS) $(IMPORTLIBTARGETVERSIONED_DSO)) |
|
258 |
||
259 |
# Add this importlibrary to our global targets |
|
260 |
LIBRARY:: $(IMPORTLIBTARGETVERSIONED_DSO) |
|
261 |
$(ALLTARGET):: $(IMPORTLIBTARGETVERSIONED_DSO) |
|
262 |
TARGET:: $(IMPORTLIBTARGETVERSIONED_DSO) |
|
263 |
||
264 |
else |
|
265 |
TARGETS:=$(strip $(TARGETS) $(IMPORTLIBTARGETVERSIONED_DSO) $(IMPORTLIBTARGET_DSO)) |
|
266 |
||
267 |
# Add this importlibrary to our global targets |
|
268 |
LIBRARY:: $(IMPORTLIBTARGET_DSO) |
|
269 |
$(ALLTARGET):: $(IMPORTLIBTARGETVERSIONED_DSO) $(IMPORTLIBTARGET_DSO) |
|
270 |
TARGET:: $(IMPORTLIBTARGETVERSIONED_DSO) $(IMPORTLIBTARGET_DSO) |
|
271 |
||
272 |
||
273 |
endif |
|
274 |
||
275 |
||
276 |
||
277 |
ifneq ($(EXPORTUNFROZEN),) # Unfrozen - warn and create .dso as side-effect of the final postlink |
|
278 |
$(info <warning project='$(PROJECT_META)' component='$(COMPONENT_META)'>EXPORTUNFROZEN present in $(PROJECT_META) - unfrozen exports will be represented in import library.</warning> ) |
|
279 |
define importlibtarget_unfrozen |
|
280 |
$(IMPORTLIBTARGET_DSO): $(IMPORTLIBTARGETVERSIONED_DSO) |
|
281 |
$(call startrule,importlibtarget_unfrozen,FORCESUCCESS) \ |
|
282 |
$(GNUCP) $$(call dblquote,$$<) $$(call dblquote,$$@) \ |
|
283 |
$(call endrule,importlibtarget_unfrozen) |
|
284 |
endef |
|
285 |
||
286 |
define importlibtarget_unfrozen_ver |
|
287 |
$(IMPORTLIBTARGETVERSIONED_DSO): $(E32TARGET) |
|
288 |
$(call startrule,importlibversioned_unfrozen,FORCESUCCESS) \ |
|
289 |
$(GNUCP) "$(GENERATED_DSO)" "$$@" \ |
|
290 |
$(call endrule,importlibversioned_unfrozen) |
|
291 |
endef |
|
292 |
||
293 |
ifeq ($(EXPLICITVERSION),) |
|
294 |
# Generate the general dso if we aren't |
|
295 |
# being asked to make just the specific version. |
|
296 |
$(eval $(importlibtarget_unfrozen)) |
|
297 |
endif |
|
298 |
||
299 |
$(eval $(importlibtarget_unfrozen_ver)) |
|
300 |
else |
|
301 |
ifneq ($(DEFFILE),) # Frozen - use the def file and create .dso directly |
|
302 |
define importlibtarget_func |
|
303 |
$(IMPORTLIBTARGET_DSO): $(IMPORTLIBTARGETVERSIONED_DSO) |
|
304 |
$(call startrule,importlibtarget,FORCESUCCESS) \ |
|
305 |
$(GNUCP) "$$<" "$$@" \ |
|
306 |
$(call endrule,importlibtarget) |
|
307 |
endef |
|
308 |
||
309 |
ifeq ($(EXPLICITVERSION),) |
|
310 |
# Generate the general dso if we aren't |
|
311 |
# being asked to make just the specific version. |
|
312 |
$(eval $(importlibtarget_func)) |
|
313 |
endif |
|
314 |
||
315 |
define importlibtargetversioned_func |
|
316 |
$(IMPORTLIBTARGETVERSIONED_DSO): $(ELF2E32) $(PREPPEDDEFFILE) |
|
317 |
$(call startrule,importlibversioned,FORCESUCCESS) \ |
|
318 |
$(ELF2E32) --sid=0x$(if $(SID),$(SID),$(if $(UID3),$(UID3),0)) --version=$(VERSION) \ |
|
319 |
--definput="$(PREPPEDDEFFILE)" \ |
|
320 |
--dso=$$(call dblquote,$$@) \ |
|
321 |
--linkas=$(call dblquote,$(LINKASVERSIONED)) \ |
|
322 |
$(call endrule,importlibversioned) |
|
323 |
endef |
|
324 |
$(eval $(importlibtargetversioned_func)) |
|
325 |
endif # ifneq ($(DEFFILE),) |
|
326 |
endif # ifneq ($(EXPORTUNFROZEN),) |
|
327 |
endif # ifneq ($(IMPORTLIBTARGET_DSO),) |
|
328 |
||
329 |
# ABIv1 .lib |
|
330 |
ifneq ($(IMPORTLIBTARGETVERSIONED_LIB),) # check that we haven't tried to specify this target already |
|
331 |
||
26
96670e6a4bfd
Try to cope with the iscapi implib problem.
timothy.murphy@nokia.com
parents:
9
diff
changeset
|
332 |
# By Now we're committed to producing a target for this DSO so it's safe to |
96670e6a4bfd
Try to cope with the iscapi implib problem.
timothy.murphy@nokia.com
parents:
9
diff
changeset
|
333 |
# set the marker that will prevent any further targets from being made. |
96670e6a4bfd
Try to cope with the iscapi implib problem.
timothy.murphy@nokia.com
parents:
9
diff
changeset
|
334 |
$(eval $(BUILDMARKER_IMPORTLIBTARGET_LIB):=1) |
96670e6a4bfd
Try to cope with the iscapi implib problem.
timothy.murphy@nokia.com
parents:
9
diff
changeset
|
335 |
|
3 | 336 |
define abiv1_generatelib |
337 |
||
338 |
ifeq ($(EXPLICITVERSION),) |
|
339 |
LIBRARY:: $(IMPORTLIBTARGETVERSIONED_LIB) $(IMPORTLIBTARGET_LIB) |
|
340 |
||
341 |
else |
|
342 |
LIBRARY:: $(IMPORTLIBTARGETVERSIONED_LIB) |
|
343 |
||
344 |
endif |
|
345 |
||
346 |
# If frozen, a prepped .def file is used as the basis for .lib creation |
|
347 |
# If unfrozen, .lib files are based on the .def file generated by the final postlink |
|
348 |
$(IMPORTLIBTARGETVERSIONED_LIB): $(if $(EXPORTUNFROZEN),$(E32TARGET),$(PREPPEDDEFFILE)) |
|
349 |
$(call startrule,importlibversioned_abiv1) \ |
|
350 |
if [ -f "$(EPOCROOT)/epoc32/tools/def2dll.pl" -a -f "$(if $(EXPORTUNFROZEN),$(call dblquote,$(GENERATED_DEFFILE)),$(PREPPEDDEFFILE))" ]; then \ |
|
351 |
$(PERL) $(EPOCROOT)/epoc32/tools/def2dll.pl \ |
|
352 |
--path=$(IMPORTLIBPATH) \ |
|
353 |
--bldpath=$(INTERMEDIATEPATH) \ |
|
354 |
--import=$(notdir $(basename $(IMPORTLIBTARGETVERSIONED_LIB))) \ |
|
355 |
--deffile="$(if $(EXPORTUNFROZEN),$(call dblquote,$(GENERATED_DEFFILE)),$(PREPPEDDEFFILE))" \ |
|
356 |
--linkAs=$(call dblquote,$(LINKASVERSIONED)) \ |
|
357 |
--inter ; fi \ |
|
358 |
$(call endrule,importlibversioned_abiv1) |
|
359 |
||
360 |
ifeq ($(EXPLICITVERSION),) |
|
361 |
$(IMPORTLIBTARGET_LIB): $(IMPORTLIBTARGETVERSIONED_LIB) |
|
362 |
$(call startrule,importlibtarget_abiv1) \ |
|
363 |
if [ -f $(EPOCROOT)/epoc32/tools/def2dll.pl ]; then $(GNUCP) "$$<" "$$@" ; fi \ |
|
364 |
$(call endrule,importlibtarget_abiv1) |
|
365 |
endif |
|
366 |
endef |
|
367 |
||
368 |
$(eval $(abiv1_generatelib)) |
|
369 |
endif # ifneq ($(IMPORTLIBTARGET_LIB),) |
|
370 |
endif # ($(or $(DEFFILE),$(EXPORTUNFROZEN)),) |
|
371 |
endif # ifneq ($(IMPORTLIBRARYREQUIRED),) |
|
372 |
||
373 |
||
374 |
## POSTLINK ################################################################## |
|
375 |
||
376 |
# Set up the name of the exports file if this is a customdll |
|
377 |
EXPTARGET:= |
|
378 |
ifneq ($(DOPOSTLINK),) |
|
379 |
ifneq ($(and $(or $(STATICLIBRARY),$(ARMLIBS),$(ARMRT)),$(DEFFILE)),) |
|
380 |
EXPTARGET:=$(INTERMEDIATE_PLATFORM_PATH)/$(notdir $(VER_E32IMPORTLIBBASE)).exp |
|
381 |
endif |
|
382 |
endif |
|
383 |
||
384 |
# Generating the import library is enough if TARGETTYPE=implib ############# |
|
385 |
||
386 |
ifneq ($(DOPOSTLINK),) |
|
387 |
include $(FLMHOME)/e32postlink.mk |
|
388 |
endif # ifneq ($(DOPOSTLINK),) |
|
389 |
||
390 |
ifneq ($(TARGETTYPE),implib) |
|
391 |
||
392 |
## CUSTOM DLLS ############################################################### |
|
393 |
# exp file |
|
394 |
# |
|
395 |
# This tends to help getting exported objects |
|
396 |
# out of the arm libs and into custom dlls. |
|
397 |
||
398 |
ifneq ($(EXPTARGET),) |
|
399 |
ifeq ($(TARGET_$(EXPTARGET)),) |
|
400 |
# We only need one of these exptargets for UDEB and UREL |
|
401 |
TARGET_$(EXPTARGET):=1 |
|
402 |
||
403 |
EXPTARGETASMFILE:=$(INTERMEDIATE_PLATFORM_PATH)/$(notdir $(VER_E32IMPORTLIBBASE)).s |
|
404 |
||
405 |
define e32expgen_func |
|
406 |
$(EXPTARGET): $(DEFFILE) $(ELF2E32) |
|
407 |
$(call startrule,expgen) \ |
|
408 |
$(ELF2E32) \ |
|
409 |
--definput=$$(call dblquote,$(DEFFILE)) \ |
|
410 |
--dump=a \ |
|
411 |
--output=$(call dblquote,$(EXPTARGETASMFILE)) && \ |
|
412 |
$(ASM) $(TARGET_ARCH_OPTION) $(AAPCS_OPTION) $(ASM_OUTPUT_OPTION) $$(call dblquote, $$@) $(EXPTARGETASMFILE) \ |
|
413 |
$(call endrule,expgen) |
|
414 |
endef |
|
415 |
||
416 |
$(eval $(e32expgen_func)) |
|
417 |
CLEANTARGETS:=$(CLEANTARGETS) $(EXPTARGET) $(EXPTARGETASMFILE) |
|
418 |
endif |
|
419 |
endif |
|
420 |
||
421 |
||
422 |
||
423 |
||
424 |
## SOURCE FILES ############################################################## |
|
425 |
||
426 |
# Source files can be either C++ files (.cpp) or Assmbler-in-C++ files (.cia) |
|
427 |
# We have to split the two because they have the same link stage, the compile |
|
428 |
# stage is different for each. |
|
429 |
||
430 |
CPPFILEEXTENSIONS:=.cpp .CPP .Cpp .CPp .CpP .cPP .cpP .cPp .cc .CC \ |
|
431 |
.Cc .c++ .C++ .cxx .CXX .Cxx .cXx .CxX .CXx .cC .cXX .cxX |
|
432 |
CFILEEXTENSIONS:=.c .C |
|
433 |
CIAFILEEXTENSIONS:=.CIA .cia .Cia .cIa .cIA .ciA .CIa .CiA |
|
434 |
ASMFILEEXTENSIONS:=.s .S |
|
435 |
||
436 |
||
437 |
# Extract the CPP files from our sources |
|
438 |
CPPFILES:=$(call extractfilesoftype,$(CPPFILEEXTENSIONS),$(SOURCE)) |
|
439 |
CFILES:=$(call extractfilesoftype,$(CFILEEXTENSIONS),$(SOURCE)) |
|
440 |
ASMFILES:=$(call extractfilesoftype,$(ASMFILEEXTENSIONS),$(SOURCE)) |
|
441 |
||
442 |
# Find out what assember-in-c files there are |
|
443 |
# If appropriate, work out what CPP files will be created from the assembler files |
|
444 |
CIAFILES:=$(call extractfilesoftype,$(CIAFILEEXTENSIONS),$(SOURCE)) |
|
445 |
CIA_CPPFILES:= |
|
446 |
ifeq ($(TRANSFORM_CIA),1) |
|
447 |
CIA_CPPFILES:=$(call relocatefiles,$(INTERMEDIATEPATH),$(call extractandmap,$(CIAFILEEXTENSIONS),_.cpp,$(CIAFILES))) |
|
448 |
else |
|
449 |
||
450 |
endif |
|
451 |
||
452 |
## LINK ###################################################################### |
|
453 |
# Bring together all the .o files compiled from .cpp, .c, .s and .cia files. |
|
454 |
# These files are stored in the "non-releasable" output diretory. |
|
455 |
||
456 |
define mapcpp2object |
|
457 |
$(call relocatefiles,$(INTERMEDIATEPATH),$(call extractandmap,$(CPPFILEEXTENSIONS),.o,$1)) |
|
458 |
endef |
|
459 |
||
460 |
define mapc2object |
|
461 |
$(call relocatefiles,$(INTERMEDIATEPATH),$(call extractandmap,$(CFILEEXTENSIONS),.o,$1)) |
|
462 |
endef |
|
463 |
||
464 |
define mapasm2object |
|
465 |
$(call relocatefiles,$(INTERMEDIATEPATH),$(call extractandmap,$(ASMFILEEXTENSIONS),.o,$1)) |
|
466 |
endef |
|
467 |
||
468 |
define mapcia2object |
|
469 |
$(call relocatefiles,$(INTERMEDIATEPATH),$(call extractandmap,$(CIAFILEEXTENSIONS),_.o,$1)) |
|
470 |
endef |
|
471 |
||
472 |
# Determine what object files will be linked by using the source files. |
|
473 |
CPPFILES_LINKOBJECTS:=$(call mapcpp2object,$(CPPFILES)) |
|
474 |
CFILES_LINKOBJECTS:=$(call mapc2object,$(CFILES)) |
|
475 |
ifeq ($(TRANSFORM_CIA),1) |
|
476 |
CIAFILES_LINKOBJECTS:=$(patsubst %_.cpp,%_.o,$(CIA_CPPFILES)) |
|
477 |
else |
|
478 |
CIAFILES_LINKOBJECTS:=$(call mapcia2object,$(CIAFILES)) |
|
479 |
endif |
|
480 |
ASMFILES_LINKOBJECTS:=$(call mapasm2object,$(ASMFILES)) |
|
481 |
||
482 |
# Try to link object files in the order in which the source files were specified. |
|
483 |
# This makes BC comparisons with non-Raptor builds easier. |
|
484 |
# Use the order of the source list to establish the order of the object files: |
|
485 |
LINKOBJECTS:=$(call relocatefiles,$(INTERMEDIATEPATH),$(SOURCE)) |
|
486 |
# Replace the file extensions of the Source files with .o (or _.o for cia files) now |
|
487 |
# the list will contain the object files in the same order as the list of source files. |
|
488 |
LINKOBJECTS:=$(foreach FILE,$(LINKOBJECTS),$(basename $(FILE))$(if $(filter $(addprefix %,$(CIAFILEEXTENSIONS)),$(FILE)),_).o) |
|
489 |
||
490 |
ifneq ($(MULTIFILE_ENABLED),) |
|
491 |
MULTIFILEOBJECT:=$(INTERMEDIATEPATH)/$(TARGET).$(POSTLINKFILETYPE)_$(VARIANTTYPE)_multifileobject.o |
|
492 |
MULTIFILE_VIAFILE:=$(INTERMEDIATEPATH)/$(TARGET)_$(VARIANTTYPE)_multifile.via |
|
493 |
endif |
|
494 |
||
495 |
## Via file #################################### |
|
496 |
# list of all objects to be linked |
|
497 |
# |
|
498 |
VIAFILE:=$(INTERMEDIATEPATH)/$(TARGET)_$(VARIANTTYPE)_objects.via |
|
499 |
ifneq ($(GENERATELINKERFEEDBACK),) |
|
500 |
FEEDBACKFILE:=$(INTERMEDIATEPATH)/$(TARGET)_$(VARIANTTYPE)_feedback.fdb |
|
501 |
endif |
|
502 |
||
503 |
# The groupin10 macro allows us to construct a via file, 10 objects at a time |
|
504 |
# to avoid limits on argument lengths and sizes on Windows. |
|
505 |
# It expands to a list of commands, each of which is on a separate line. |
|
506 |
# This causes the shell to be invoked once for each line but each line should |
|
507 |
# be shorter than the maximum allowed by windows. |
|
508 |
define groupin10 |
|
509 |
$(if $1,@echo -e $(foreach L,$(wordlist 1,10,$1),"$(L)\\n") >>$(VIAFILE),) |
|
510 |
$(if $1,$(call groupin10,$(wordlist 11,$(words $1),$1)),@true) |
|
511 |
endef |
|
512 |
||
513 |
################################################ |
|
514 |
||
515 |
||
516 |
## Link-type selection: |
|
517 |
# runtime static libraries link via AR |
|
518 |
ifneq ($(ARTARGET),) |
|
519 |
# Assuming that there are no libdeps in this case because this is probably one of the |
|
520 |
# Runtime libraries which has no deps. |
|
521 |
||
522 |
define artarget_func |
|
523 |
$(ARTARGET): $(if $(MULTIFILE_ENABLED),$(MULTIFILEOBJECT),$(LINKOBJECTS)) $(STDCPPTAGFILE) |
|
524 |
$(if $(MULTIFILE_ENABLED),,@echo "$(STDCPPTAGFILE)" > $(VIAFILE); |
|
525 |
$(call groupin10,$(LINKOBJECTS)) ;) |
|
526 |
$(call startrule,ar,FORCESUCCESS) \ |
|
527 |
$$(call dblquote,$(AR)) $(ARCHIVER_CREATE_OPTION) $$@ $(if $(MULTIFILE_ENABLED),$(MULTIFILEOBJECT),$(COMMANDFILE_OPTION)$(VIAFILE)) \ |
|
528 |
$(if $(DUMPBCINFO),&& $(FROMELF) -v $$@ > $$@.elfdump,) \ |
|
529 |
$(call endrule,ar) |
|
530 |
endef |
|
531 |
$(eval $(artarget_func)) |
|
532 |
||
5 | 533 |
CLEANTARGETS:=$(CLEANTARGETS) $(VIAFILE) $(if $(DUMPBCINFO),$(ARTARGET).elfdump,) |
3 | 534 |
endif |
535 |
||
536 |
||
537 |
||
538 |
# Targettype is some type of DLL or EXE (or derivative) |
|
539 |
ifneq ($(LINK_TARGET),) |
|
540 |
||
541 |
escaped_located_ARMLIBS:=$(foreach L,$(ARMLIBS),$(call ruleEscape,$(wildcard $(subst $(CHAR_SPACE),?,$(RVCTLIB)/*/$(L))))) |
|
542 |
quoted_located_ARMLIBS:=$(foreach L,$(ARMLIBS),$(call dblquoteitem,$(wildcard $(RVCTLIB)/*/$(L)))) |
|
543 |
located_STATICLIBRARIES:=$(foreach L,$(STATICLIBRARY),$(STATIC_LIBRARY_DIR)/$(L).lib) |
|
544 |
e32abiv2_LIBS:=$(EXPTARGET) $(LINKER_STUB_LIBRARY) $(if $(STATIC_RUNTIME_LIB),$(STATIC_RUNTIME_DIR)/$(STATIC_RUNTIME_LIB),) $(located_STATICLIBRARIES) |
|
545 |
# DLLS and EXEs - These objects are linked by a linker |
|
546 |
ifeq ($(ARMRT),) |
|
547 |
# Some of the runtime libraries do not set ARMRT because of a circular reference |
|
548 |
# problem; we need to stop these from linking to their own dso and not link to |
|
549 |
# the STATIC_LIBS_LIST. |
|
550 |
ifneq ($(findstring $(TARGET).dso,$(RUNTIME_LIBS_LIST)),) |
|
551 |
# (almost) ARM RUNTIME LIBS |
|
552 |
REDUCED_RUNTIME_LIBS_LIST:=$(subst $(TARGET).dso,,$(RUNTIME_LIBS_LIST)) |
|
553 |
||
554 |
ifeq ($(VARIANTTYPE),udeb) |
|
555 |
e32abiv2_LIBS:=$(e32abiv2_LIBS) $(addprefix $(IMPORTLIBPATH)/,$(LIBRARY_DEBUG)) $(addprefix $(RUNTIME_LIBS_PATH)/,$(REDUCED_RUNTIME_LIBS_LIST)) |
|
556 |
else |
|
557 |
e32abiv2_LIBS:=$(e32abiv2_LIBS) $(addprefix $(IMPORTLIBPATH)/,$(LIBRARY)) $(addprefix $(RUNTIME_LIBS_PATH)/,$(REDUCED_RUNTIME_LIBS_LIST)) |
|
558 |
endif |
|
559 |
quoted_e32abiv2_LIBS=$(e32abiv2_LIBS) $(quoted_located_ARMLIBS) |
|
560 |
escaped_e32abiv2_LIBS=$(e32abiv2_LIBS) $(escaped_located_ARMLIBS) |
|
561 |
||
562 |
else |
|
563 |
# NORMAL |
|
564 |
# |
|
565 |
ifeq ($(VARIANTTYPE),udeb) |
|
566 |
e32abiv2_LIBS:=$(e32abiv2_LIBS) $(addprefix $(IMPORTLIBPATH)/,$(LIBRARY_DEBUG)) |
|
567 |
else |
|
568 |
e32abiv2_LIBS:=$(e32abiv2_LIBS) $(addprefix $(IMPORTLIBPATH)/,$(LIBRARY)) |
|
569 |
endif |
|
570 |
ifeq ($(HAS_DEDICATED_OP_NEWDEL_LIB),1) |
|
571 |
e32abiv2_LIBS:=$(e32abiv2_LIBS) $(addprefix $(RUNTIME_LIBS_PATH)/,$(NEWLIB)) |
|
572 |
endif |
|
573 |
quoted_e32abiv2_LIBS:=$(e32abiv2_LIBS) $(addprefix $(RUNTIME_LIBS_PATH)/,$(RUNTIME_LIBS_LIST)) $(call addquotedprefix,$(STATIC_LIBS_PATH)/,$(STATIC_LIBS_LIST)) $(quoted_located_ARMLIBS) |
|
574 |
escaped_e32abiv2_LIBS:=$(e32abiv2_LIBS) $(addprefix $(RUNTIME_LIBS_PATH)/,$(RUNTIME_LIBS_LIST)) $(addprefix $(call ruleEscape,$(STATIC_LIBS_PATH)/),$(STATIC_LIBS_LIST)) $(escaped_located_ARMLIBS) |
|
575 |
||
576 |
endif |
|
577 |
else |
|
578 |
# ARM RUNTIME LIBS |
|
579 |
ifeq ($(VARIANTTYPE),udeb) |
|
580 |
e32abiv2_LIBS:=$(e32abiv2_LIBS) $(addprefix $(IMPORTLIBPATH)/,$(LIBRARY_DEBUG)) |
|
581 |
else |
|
582 |
e32abiv2_LIBS:=$(e32abiv2_LIBS) $(addprefix $(IMPORTLIBPATH)/,$(LIBRARY)) |
|
583 |
endif |
|
584 |
quoted_e32abiv2_LIBS=$(e32abiv2_LIBS) $(quoted_located_ARMLIBS) |
|
585 |
escaped_e32abiv2_LIBS=$(e32abiv2_LIBS) $(escaped_located_ARMLIBS) |
|
586 |
endif |
|
587 |
||
588 |
# NOTE: the groupin10 macro must be used before a call to the "startrule" macro |
|
589 |
# because the code between startrule and endrule is packaged up into one |
|
590 |
# commandline which would defeat the purpose of groupin10. |
|
591 |
# This is undesirable because viafile generation commands appear |
|
592 |
# outside the relevant tags but it is also unavoidable. |
|
593 |
define linktarget_func |
|
594 |
## The actual link target, dependencies and build step |
|
595 |
$(LINK_TARGET): $(if $(MULTIFILE_ENABLED),$(MULTIFILEOBJECT) $(CIAFILES_LINKOBJECTS),$(LINKOBJECTS)) $(escaped_e32abiv2_LIBS) $(LINKER_ENTRYPOINT_LIBDEP) $(if $(SUPPORTS_STDCPP_NEWLIB),$(CHECKLIB)) $(if $(LINKERFEEDBACK_STAGE2),$(FEEDBACKFILE),) |
|
596 |
$(if $(MULTIFILE_ENABLED),,@echo -n "" > $(VIAFILE); |
|
597 |
$(call groupin10,$(LINKOBJECTS)) ;) |
|
598 |
$(call startrule,link) \ |
|
599 |
$(if $(PERTURBSTARTTIME),$(RANSLEEP) $(PERTURBMSECS) ;,) \ |
|
600 |
$(if $(SUPPORTS_STDCPP_NEWLIB),$(if $(located_STATICLIBRARIES),$(CHECKLIB) $(CHECKLIB_TYPE) --elf $(call dblquote,$(located_STATICLIBRARIES)) &&,),) \ |
|
601 |
$(LD) $(LINKER_MISC_FLAGS) $(LINKER_DEFAULT_LIB_PATHS) $(SYMBIAN_LINK_FLAGS) $(if $(DEBUG_INFO),$(LINKER_DEBUG_OPTION),$(LINKER_NODEBUG_OPTION)) \ |
|
602 |
$(if $(ARMLIBS),$(LD_WARNINGS_SUPPRESSION_ARMLIBS),) \ |
|
603 |
$(SHARED_OBJECT_OPTION) $(SPLIT_OPTION) \ |
|
22 | 604 |
$(RW_BASE) \ |
3 | 605 |
$(LINKER_ARCH_OPTION) \ |
22 | 606 |
$(SYMVER_OPTION) $(SO_NAME_OPTION)=$(call dblquote,$(LINKASVERSIONED)) \ |
3 | 607 |
$(LINKER_ENTRYPOINT_SETTING) \ |
608 |
-o $$(call dblquote,$$@) \ |
|
609 |
$(if $(LTCG),$(LTCG_OPTION),) \ |
|
22 | 610 |
$(LINKER_SYMBOLS_OPTION) $(LINKER_SYMBOLS_FILE_OPTION)=$(call dblquote,$(MAPFILE)) \ |
3 | 611 |
$(LINKEROPTION) \ |
612 |
$(if $(MULTIFILE_ENABLED),$(call dblquote,$(MULTIFILEOBJECT) $(CIAFILES_LINKOBJECTS)),$(COMMANDFILE_OPTION)$(call dblquote,$(VIAFILE))) \ |
|
613 |
$(if $(GENERATELINKERFEEDBACK),$(FEEDBACK_OPTION)$(call dblquote,$(FEEDBACKFILE))) \ |
|
614 |
$(if $(LINKER_ADD_STATIC_RUNTIME),$(if $(STATIC_RUNTIME_LIB),$(LINKER_GROUP_START_OPTION) $(STATIC_RUNTIME_DIR)/$(STATIC_RUNTIME_LIB) $(LINKER_GROUP_END_OPTION),)) \ |
|
615 |
$(quoted_e32abiv2_LIBS) $(LINKER_DEFAULT_LIBS)\ |
|
616 |
$(call endrule,link) |
|
617 |
||
618 |
$(MAPFILE): $(LINK_TARGET) |
|
619 |
endef |
|
620 |
$(eval $(linktarget_func)) |
|
621 |
||
5 | 622 |
CLEANTARGETS:=$(CLEANTARGETS) $(VIAFILE) $(if $(GENERATELINKERFEEDBACK),$(FEEDBACKFILE)) $(if $(MULTIFILE_ENABLED),$(MULTIFILEOBJECT)) |
3 | 623 |
WHATRELEASE:=$(WHATRELEASE) $(MAPFILE) |
624 |
||
625 |
endif # if TARGETTYPE lib |
|
626 |
||
627 |
||
628 |
## Run trace compiler ############################################## |
|
629 |
ifeq ($(UID3),) |
|
630 |
ifeq ($(UID2),) |
|
631 |
USE_TRACE_COMPILER:= |
|
632 |
else |
|
633 |
UID_TC:=$(UID2) |
|
634 |
endif |
|
635 |
else |
|
636 |
UID_TC:=$(UID3) |
|
637 |
endif |
|
638 |
||
639 |
# USE_TRACE_COMPILER defaults to blank in Raptor config. |
|
640 |
# Users can turn TC on by setting it to 1 in user config. |
|
641 |
ifneq ($(USE_TRACE_COMPILER),) |
|
642 |
include $(FLMHOME)/tracecompiler.mk |
|
643 |
endif |
|
644 |
||
645 |
CC_CPPONLY_ARGS:=$(SYMBIAN_CCFLAGS) $(if $(DEBUG_INFO),-g) $(DEBUG_FORMAT) \ |
|
646 |
$(RUNTIME_SYMBOL_VISIBILITY_OPTION) $(EXCEPTIONS) \ |
|
647 |
$(CC_WARNINGS_CONTROL_OPTION) $(CC_ERRORS_CONTROL_OPTION) \ |
|
648 |
$(TARGET_ARCH_OPTION) $(ENUM_OPTION) $(OWN_LIBRARY_OPTION) $(FPMODE_OPTION) \ |
|
649 |
$(EXPORT_VTBL_OPTION) $(NO_UNALIGNED_ACCESS) $(VFE_OPTION) $(AAPCS_OPTION) \ |
|
650 |
$(CPPONLYOPTION) $(INSTRUCTION_SET) \ |
|
651 |
$(if $(ALWAYS_BUILD_AS_ARM),$(ARM_INSTRUCTION_SET),$(THUMB_INSTRUCTION_SET) $(call makemacrodef,-D,$(COMPILER_THUMB_DEFINES))) \ |
|
9 | 652 |
$(COMPILER_FPU_OPTION)$(if $(ARMFPU),$(ARMFPU),$(COMPILER_FPU_DEFAULT)) |
3 | 653 |
|
654 |
## COMPILE CPP Files ################################################################# |
|
655 |
||
656 |
# For ARMCC we can compile all sourcefiles with one invocation |
|
657 |
# The pathprep macro is used to make sure that forward slashes in options |
|
658 |
# are not interpreted as being paths by CYGWIN on Windows. On windows |
|
659 |
# pathprep makes a forward slash into two. |
|
660 |
||
661 |
# The majority of ARMCC arguments are common across all compiler invocations |
|
662 |
# Order is significant here in that OPTION_REPLACE here and in ABLD should |
|
663 |
# have the same impact |
|
664 |
CC_CORE_ARGS:=$(SYMBIAN_CCFLAGS) $(if $(DEBUG_INFO),-g) $(DEBUG_FORMAT) \ |
|
665 |
$(RUNTIME_SYMBOL_VISIBILITY_OPTION) $(EXCEPTIONS) \ |
|
666 |
$(CC_WARNINGS_CONTROL_OPTION) $(CC_ERRORS_CONTROL_OPTION) \ |
|
667 |
$(TARGET_ARCH_OPTION) $(ENUM_OPTION) $(OWN_LIBRARY_OPTION) $(FPMODE_OPTION) \ |
|
668 |
$(EXPORT_VTBL_OPTION) $(NO_UNALIGNED_ACCESS) $(VFE_OPTION) $(AAPCS_OPTION) \ |
|
669 |
$(COMPILE_ONLY_OPTION) $(INSTRUCTION_SET) \ |
|
670 |
$(if $(ALWAYS_BUILD_AS_ARM),$(ARM_INSTRUCTION_SET),$(THUMB_INSTRUCTION_SET) $(call makemacrodef,-D,$(COMPILER_THUMB_DEFINES))) \ |
|
9 | 671 |
$(COMPILER_FPU_OPTION)$(if $(ARMFPU),$(ARMFPU),$(COMPILER_FPU_DEFAULT)) |
3 | 672 |
|
673 |
ifeq ($(STDCPP),1) |
|
674 |
SYSTEMINCLUDE:=$(SYSTEMINCLUDE) $(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$(call dblquote,$(STDCPP_INCLUDE))) |
|
675 |
endif |
|
676 |
||
677 |
define option_replace |
|
678 |
# Process a single, combined, item of the form 'search<->replace' in order to modify the command line tool call |
|
679 |
# We split this into its component arguments for use in substitutions |
|
680 |
# Spaces will have been escaped elsewhere to maintain distinct words, so we resurrect these |
|
681 |
# after the split. |
|
682 |
SEARCH:=$(subst %20,$(CHAR_SPACE),$(word 1,$(subst <->,$(CHAR_SPACE),$(1)))) |
|
683 |
REPLACE:=$(subst %20,$(CHAR_SPACE),$(word 2,$(subst <->,$(CHAR_SPACE),$(1)))) |
|
684 |
||
685 |
# Depending on whether there's a wildcard in the search, we may require either a normal $(subst) or a $(patsubst) |
|
686 |
PATSUBST:=$$(if $$(findstring %,$$(SEARCH)),1,) |
|
687 |
||
688 |
ifeq ($$(PATSUBST),1) |
|
689 |
CC_CORE_ARGS:=$$(patsubst $$(SEARCH),$$(REPLACE),$$(CC_CORE_ARGS)) |
|
690 |
else |
|
691 |
CC_CORE_ARGS:=$$(subst $$(SEARCH),$$(REPLACE),$$(CC_CORE_ARGS)) |
|
692 |
endif |
|
693 |
endef |
|
694 |
$(foreach ITEM,$(OPTION_REPLACE_COMPILER),$(eval $(call option_replace,$(ITEM)))) |
|
695 |
||
696 |
define e32abiv2_compile |
|
697 |
||
698 |
$(eval DEPENDFILENAME:=$(1).d) |
|
699 |
$(eval DEPENDFILE:=$(wildcard $(DEPENDFILENAME))) |
|
700 |
||
701 |
# $4 is for language specific options (e.g. C++ vs C) |
|
702 |
$(1): $(2) $(PROJECT_META) $(if $(MULTIFILE_ENABLED),,$(if $(DEPENDFILE),,RESOURCE BITMAP EXPORT)) $(if $(USE_TRACE_COMPILER),$(TRACE_MARKER),) $(if $(LINKERFEEDBACK_STAGE2),$(FEEDBACKFILE),) |
|
703 |
$(call startrule,compile,,$(2)) \ |
|
704 |
$(if $(PERTURBSTARTTIME), $(RANSLEEP) $(PERTURBMSECS) ;,) \ |
|
705 |
$(if $(MULTIFILE_ENABLED), echo $(2) $(3) > $(MULTIFILE_VIAFILE) ;,) \ |
|
706 |
$(CC) $(LICENSERETRY_OPTION) \ |
|
707 |
$(CC_CORE_ARGS) \ |
|
708 |
$(OPTION_COMPILER) $(if $(MULTIFILE_ENABLED),$(4),$(3)) \ |
|
709 |
$(if $(LTCG),$(LTCG_OPTION),) \ |
|
710 |
$(if $(USE_PROFILER_FEEDBACK),--profile=$(call dblquote,$(ARM_PROFILER_FILE)),) \ |
|
711 |
$(call makemacrodef,-D,$(COMPILER_INTERWORK_DEFINES) $(CDEFS)) \ |
|
712 |
$(if $(PREINCLUDE),$(PREINCLUDE_OPTION) ,)$(call concat, $(PREINCLUDE_OPTION) ,$(call dblquote,$(PREINCLUDE)))\ |
|
713 |
$(if $(SET_ARMINC),$(if $(RVCTINC),$(COMPILER_SYSTEM_INCLUDE_OPTION)$(call dblquoteitem,$(RVCTINC)),),) \ |
|
714 |
$(COMPILER_SYSTEM_INCLUDE_OPTION)$$(call dblquote,$$(<D)) \ |
|
715 |
$(if $(USERINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$(call dblquote,$(USERINCLUDE))) \ |
|
716 |
$(if $(SYSTEMINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$(call dblquote,$(SYSTEMINCLUDE))) \ |
|
717 |
$(if $(NOHIDEALL),--no_hide_all,) \ |
|
718 |
$(DEPEND_OPTION) $(call dblquote,$(1).d) \ |
|
719 |
$(if $(LINKERFEEDBACK_STAGE2),$(FEEDBACK_OPTION)$(call dblquote,$(FEEDBACKFILE))) \ |
|
720 |
$(if $(MULTIFILE_ENABLED),--multifile $(OUTPUT_OPTION) $(MULTIFILEOBJECT) \ |
|
721 |
--via $$(call dblquote, $(MULTIFILE_VIAFILE)),$(OUTPUT_OPTION) $$@ $$(call dblquote, $$<)) \ |
|
722 |
$(call endrule,compile) |
|
723 |
||
724 |
CLEANTARGETS:=$$(CLEANTARGETS) $(DEPENDFILENAME) |
|
725 |
ifneq "$(DEPENDFILE)" "" |
|
726 |
ifeq ($(NO_DEPEND_INCLUDE),) |
|
727 |
ifeq "$(filter %CLEAN,$(call uppercase,$(MAKECMDGOALS)))" "" |
|
728 |
-include $(DEPENDFILE) |
|
729 |
endif |
|
730 |
endif |
|
731 |
endif |
|
732 |
||
733 |
# individual source file compilation |
|
734 |
SOURCETARGET_$(call sanitise,$(2)): $(1) |
|
735 |
||
736 |
endef |
|
737 |
||
738 |
# Evaluate .cpp and .c files in one go for multifile, cannot do in separate steps since we have the same target. |
|
739 |
# This implementation means the .c files will always get put at the end of the .via file. Maybe there is a better way to do this? |
|
740 |
$(if $(MULTIFILE_ENABLED),$(eval $(call e32abiv2_compile,$(MULTIFILEOBJECT),$(CPPFILES),$(CFILES),$(CPP_LANG_OPTION))),$(foreach F,$(CPPFILES),$(eval $(call e32abiv2_compile,$(call mapcpp2object,$(F)),$(F),$(CPP_LANG_OPTION))))) |
|
741 |
$(if $(MULTIFILE_ENABLED),,$(foreach F,$(CFILES),$(eval $(call e32abiv2_compile,$(call mapc2object,$(F)),$(F),$(C_LANG_OPTION))))) |
|
742 |
ifneq ($(TRANSFORM_CIA),1) |
|
743 |
$(if $(MULTIFILE_ENABLED),,$(foreach F,$(CIAFILES),$(eval $(call e32abiv2_compile,$(call mapcia2object,$(F)),$(F),$(CPP_LANG_OPTION) $(COMPILER_CIA_FLAGS))))) |
|
744 |
endif |
|
745 |
||
746 |
CLEANTARGETS:=$(CLEANTARGETS) $(if $(MULTIFILE_ENABLED),$(MULTIFILE_VIAFILE) $(MULTIFILEOBJECT),$(CPPFILES_LINKOBJECTS) $(CFILES_LINKOBJECTS) $(CIAFILES_LINKOBJECTS)) $(if $(GENERATELINKERFEEDBACK),$(FEEDBACKFILE)) |
|
747 |
||
748 |
## Listing target ################################################### |
|
749 |
# Very similar to compile, apart from the extra flags passed to the |
|
750 |
# compile and different output options |
|
751 |
||
752 |
define map2listfile |
|
753 |
$(call relocatefiles,$(INTERMEDIATEPATH),$(call extractandmap,$(CPPFILEEXTENSIONS) $(CFILEEXTENSIONS),.lis,$1)) |
|
754 |
endef |
|
755 |
||
756 |
||
757 |
define e32abiv2_cpponly |
|
758 |
# $1 is the sourcefile |
|
759 |
||
760 |
$(eval CPPONLYTARGET:=$(strip $(call extractandmap,$(CPPFILEEXTENSIONS) $(CFILEEXTENSIONS),.$(subst _,.,$(call sanitise,$(FULLVARIANTPATH))).pre,$1))) |
|
761 |
||
762 |
CPPONLY:: $(CPPONLYTARGET) |
|
763 |
||
764 |
$(CPPONLYTARGET): $(1) $(PROJECT_META) $(if $(DEPENDFILE),,RESOURCE BITMAP EXPORT) |
|
765 |
$(call startrule,e32cpponly,,$(1)) \ |
|
766 |
$(if $(PERTURBSTARTTIME), $(RANSLEEP) $(PERTURBMSECS) ;,) \ |
|
767 |
$(CC) $(LICENSERETRY_OPTION) $(SYMBIAN_CCFLAGS) \ |
|
768 |
$(CC_CPPONLY_ARGS) \ |
|
769 |
$(OPTION_COMPILER) \ |
|
770 |
$(call makemacrodef,-D,$(COMPILER_INTERWORK_DEFINES) $(CDEFS)) \ |
|
771 |
$(if $(PREINCLUDE),$(PREINCLUDE_OPTION) ,)$(call concat, $(PREINCLUDE_OPTION) ,$(call dblquote,$(PREINCLUDE)))\ |
|
772 |
$(if $(SET_ARMINC),$(if $(RVCTINC),$(COMPILER_SYSTEM_INCLUDE_OPTION)$(call dblquote,$(RVCTINC)),),) \ |
|
773 |
$(COMPILER_SYSTEM_INCLUDE_OPTION)$$(call dblquote,$$(<D)) \ |
|
774 |
$(if $(USERINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$(call dblquote,$(USERINCLUDE))) \ |
|
775 |
$(if $(SYSTEMINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$(call dblquote,$(SYSTEMINCLUDE))) \ |
|
776 |
$(if $(NOHIDEALL),--no_hide_all,) \ |
|
777 |
$$(call dblquote, $$<) $(OUTPUT_OPTION) $$(@) \ |
|
778 |
$(call endrule,e32cpponly) |
|
779 |
||
780 |
CLEANTARGETS:=$$(CLEANTARGETS) $(CPPONLYTARGET) |
|
781 |
endef |
|
782 |
||
783 |
ifneq ($(filter CPPONLY,$(call uppercase,$(MAKECMDGOALS))),) |
|
784 |
$(foreach F,$(CPPFILES) $(CFILES),$(eval $(call e32abiv2_cpponly,$(F)))) |
|
785 |
endif |
|
786 |
||
787 |
define e32abiv2_listing |
|
788 |
# $1 is the sourcefile |
|
789 |
||
790 |
$(eval LISTINGTARGET:=$(strip $(call extractandmap,$(CPPFILEEXTENSIONS) $(CFILEEXTENSIONS),.$(subst _,.,$(call sanitise,$(FULLVARIANTPATH))).$(TARGET).$(if $(REQUESTEDTARGETEXT),$(REQUESTEDTARGETEXT),$(POSTLINKFILETYPE)).lst,$1))) |
|
791 |
$(eval DEPENDFILENAME:=$(call map2listfile,$1).d) |
|
792 |
$(eval DEPENDFILE:=$(wildcard $(DEPENDFILENAME))) |
|
793 |
||
794 |
||
795 |
LISTING:: $(LISTINGTARGET) |
|
796 |
||
797 |
$(LISTINGTARGET): $(1) $(PROJECT_META) $(if $(DEPENDFILE),,RESOURCE BITMAP EXPORT) |
|
798 |
$(call startrule,e32listing,,$(1)) \ |
|
799 |
$(if $(PERTURBSTARTTIME), $(RANSLEEP) $(PERTURBMSECS) ;,) \ |
|
800 |
$(CC) $(LICENSERETRY_OPTION) $(SYMBIAN_CCFLAGS) \ |
|
801 |
$(CC_CORE_ARGS) \ |
|
802 |
$(LISTING_OPTION) \ |
|
803 |
$(OPTION_COMPILER) \ |
|
804 |
$(call makemacrodef,-D,$(COMPILER_INTERWORK_DEFINES) $(CDEFS)) \ |
|
805 |
$(if $(PREINCLUDE),$(PREINCLUDE_OPTION) ,)$(call concat, $(PREINCLUDE_OPTION) ,$(call dblquote,$(PREINCLUDE)))\ |
|
806 |
$(if $(SET_ARMINC),$(if $(RVCTINC),$(COMPILER_SYSTEM_INCLUDE_OPTION)$(call dblquoteitem,$(RVCTINC)),),) \ |
|
807 |
$(COMPILER_SYSTEM_INCLUDE_OPTION)$$(call dblquote,$$(<D)) \ |
|
808 |
$(if $(USERINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$(call dblquote,$(USERINCLUDE))) \ |
|
809 |
$(if $(SYSTEMINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$(call dblquote,$(SYSTEMINCLUDE))) \ |
|
810 |
$(if $(NOHIDEALL),--no_hide_all,) \ |
|
811 |
$(DEPEND_OPTION) $(call dblquote,$(DEPENDFILENAME)) \ |
|
812 |
$$(call dblquote, $$<) $(OUTPUT_OPTION) $$(@) \ |
|
813 |
$(call endrule,e32listing) |
|
814 |
||
815 |
CLEANTARGETS:=$$(CLEANTARGETS) $(LISTINGTARGET) |
|
816 |
||
817 |
CLEANTARGETS:=$$(CLEANTARGETS) $(DEPENDFILENAME) |
|
818 |
ifneq "$(DEPENDFILE)" "" |
|
819 |
ifeq ($(NO_DEPEND_INCLUDE),) |
|
820 |
ifeq "$(filter %CLEAN,$(call uppercase,$(MAKECMDGOALS)))" "" |
|
821 |
-include $(DEPENDFILE) |
|
822 |
endif |
|
823 |
endif |
|
824 |
endif |
|
825 |
||
826 |
endef |
|
827 |
||
828 |
# No point at all in generating listing targetsif we aren't going to make them |
|
829 |
ifneq ($(filter LISTING,$(call uppercase,$(MAKECMDGOALS))),) |
|
830 |
$(foreach F,$(CPPFILES) $(CFILES),$(eval $(call e32abiv2_listing,$(F)))) |
|
831 |
endif |
|
832 |
||
833 |
||
834 |
||
835 |
# Function to execute FREEZE ########################################### |
|
836 |
ifneq ($(SUPPORT_FREEZE),) |
|
837 |
||
838 |
# Fivespaces variable created to ensure a suitable gap of space characters |
|
839 |
# Is placed between the separate arguments. This fixes a problem in Cygwin, where |
|
840 |
# separate arguments are interpreted as a single argument when passed to bash |
|
841 |
FIVESPACES=$(BLANK) $(BLANK) |
|
842 |
||
843 |
FREEZEGUARD:=TARGET_$(TARGET)_$(if $(REQUESTEDTARGETEXT),$(REQUESTEDTARGETEXT),$(POSTLINKFILETYPE))_$(IMPORTLIBPATH)_EFREEZE |
|
844 |
||
845 |
define e32freeze |
|
846 |
||
847 |
FREEZE:: $(1) |
|
848 |
$(call startrule,freeze,,$(RESOLVED_DEFFILE)) \ |
|
849 |
$(EFREEZE) $(EFREEZE_REMOVE_OPTION) "$(RESOLVED_DEFFILE)" $(FIVESPACES) $(call dblquote,$(GENERATED_DEFFILE)) \ |
|
850 |
$(call endrule,freeze) |
|
851 |
endef |
|
852 |
||
853 |
# Only freeze once - udeb and urel cannot differ |
|
854 |
ifeq ($($(FREEZEGUARD)),) |
|
855 |
# For most freezing activity we need the temporary .def file generated in the final post-link |
|
856 |
# that lists the current exports - FREEZE can therefore be dependent on the final post-linked binary, |
|
857 |
# with the side-effect that a build is triggered if someone tries to freeze without having built. |
|
858 |
# |
|
859 |
# However, there's one case where we don't want to be dependent on the post-linked binary in this way, |
|
860 |
# and that's when (a) there are missing exports, (b) the user's aware of them and (c) they're deliberately freezing to |
|
861 |
# remove them using EFREEZE's remove option. Being dependent on the post-linked binary in this case, where ELF2E32 |
|
862 |
# actually fails to generate a final binary, would mean that the freeze would never happen and post-linking would |
|
863 |
# just be continually re-attempted (to fail each time). |
|
864 |
# |
|
865 |
# So, as a special case, if the user is explicitly attempting to freeze and perform removals, we make FREEZE dependent |
|
866 |
# on the temporary .def file instead. This has no rule to actually make it, but gives a hint as to what is wrong if |
|
867 |
# the users performs a freeze with remove without having explicitly built previously. |
|
868 |
# |
|
869 |
ifneq ($(EFREEZE_REMOVE_OPTION),) |
|
870 |
$(eval $(call e32freeze,$(GENERATED_DEFFILE))) |
|
871 |
else |
|
872 |
$(eval $(call e32freeze,$(E32TARGET))) |
|
873 |
endif |
|
874 |
$(FREEZEGUARD):=1 |
|
875 |
endif |
|
876 |
||
877 |
endif |
|
878 |
||
879 |
CLEANTARGETS:=$(CLEANTARGETS) $(if $(MULTIFILE_ENABLED),$(MULTIFILEOBJECT),$(CPPFILES_LINKOBJECTS) $(CFILES_LINKOBJECTS)) |
|
880 |
||
881 |
## ASSEMBLER FILES ################################################################### |
|
882 |
# CIA VERSION ############################################ |
|
883 |
define mapcia2xxx |
|
884 |
$(call relocatefiles,$(INTERMEDIATEPATH),$(call extractandmap,$(CIAFILEEXTENSIONS),$2,$1)) |
|
885 |
endef |
|
886 |
||
887 |
define e32abiv2_CIA2CPP |
|
888 |
||
889 |
$(eval e32abiv2_OFILE:=$(call mapcia2xxx,$(1),_.o)) |
|
890 |
$(eval e32abiv2_PREFILE:=$(call mapcia2xxx,$(1),_.pre)) |
|
891 |
$(eval e32abiv2_CPPFILE:=$(call mapcia2xxx,$(1),_.cpp)) |
|
892 |
$(eval CLEANTARGETS:=$(CLEANTARGETS) $(e32abiv2_OFILE) $(e32abiv2_CPPFILE) $(e32abiv2_PREFILE)) |
|
893 |
||
894 |
$(e32abiv2_OFILE): $(e32abiv2_CPPFILE) $(PROJECT_META) |
|
895 |
$(call startrule,cia2cpp2o,,$(e32abiv2_CPPFILE)) \ |
|
896 |
$(if $(PERTURBSTARTTIME),$(RANSLEEP) $(PERTURBMSECS) ;,) \ |
|
897 |
$(CC) $(LICENSERETRY_OPTION) \ |
|
898 |
$(CC_CORE_ARGS) \ |
|
899 |
$(if $(LTCG),$(LTCG_OPTION),) \ |
|
900 |
$(OPTION_COMPILER) \ |
|
901 |
$(call makemacrodef,-D,$(COMPILER_INTERWORK_DEFINES) $(CDEFS) $(CIADEFS)) $(CPP_LANG_OPTION) \ |
|
902 |
$(if $(USERINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$$(call dblquote,$(USERINCLUDE))) \ |
|
903 |
$(if $(SYSTEMINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$$(call dblquote,$(SYSTEMINCLUDE))) \ |
|
904 |
$$(call dblquote, $$<) $(OUTPUT_OPTION) $$@ \ |
|
905 |
$(call endrule,cia2cpp2o) |
|
906 |
||
907 |
||
908 |
# preprocessed CIA file to a CPP file |
|
909 |
$(e32abiv2_CPPFILE): $(e32abiv2_PREFILE) |
|
910 |
$(call startrule,tranasm) \ |
|
911 |
$(if $(CPPFILT),CPPFILT="$(CPPFILT)",) \ |
|
912 |
$(TRANASM) --suppress-check --output="$$@" $$^ \ |
|
913 |
$(call endrule,tranasm) |
|
914 |
||
915 |
$(eval DEPENDFILENAME:=$(e32abiv2_PREFILE).d) |
|
916 |
$(eval DEPENDFILE:=$(wildcard $(DEPENDFILENAME))) |
|
917 |
||
918 |
# preprocess the cia file |
|
919 |
$(eval e32abiv2_PREFILE_OPTIONS:= $(LICENSERETRY_OPTION) $(PREPROCESSOR_OPTION) $(CPP_OPTION) \ |
|
920 |
$(SYMBIAN_CCFLAGS) $(call makemacrodef,-D,$(COMPILER_INTERWORK_DEFINES) $(CDEFS) $(CIADEFS)) $(CPP_LANG_OPTION) \ |
|
921 |
$(if $(PREINCLUDE),$(PREINCLUDE_OPTION) ,)$$(call concat, $(PREINCLUDE_OPTION) ,$$(call dblquote,$(PREINCLUDE))) \ |
|
922 |
$(if $(USERINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$$(call dblquote,$(USERINCLUDE))) \ |
|
923 |
$(if $(SYSTEMINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$$(call dblquote,$(SYSTEMINCLUDE))) \ |
|
924 |
$(if $(ARMINC),$(if $(RVCTINC), $(COMPILER_SYSTEM_INCLUDE_OPTION)$$(call dblquoteitem,$(RVCTINC)),),) ) |
|
925 |
||
926 |
||
927 |
$(e32abiv2_PREFILE): $1 $(PROJECT_META) $(if $(DEPENDFILE),,RESOURCE BITMAP EXPORT) |
|
928 |
$(call startrule,cia2cpp,,$1) \ |
|
929 |
$(if $(PERTURBSTARTTIME),$(RANSLEEP) $(PERTURBMSECS) ;,) \ |
|
930 |
$(CC) $(e32abiv2_PREFILE_OPTIONS) $(OUTPUT_OPTION) $$@ $$(call dblquote,$1) && \ |
|
931 |
$(CC) -M $(e32abiv2_PREFILE_OPTIONS) --depend_format=unix \ |
|
932 |
$(OUTPUT_OPTION) $$@ $$(call dblquote,$1) > $(call dblquote,$(e32abiv2_PREFILE).d) \ |
|
933 |
$(call endrule,cia2cpp) |
|
934 |
||
935 |
CLEANTARGETS:=$$(CLEANTARGETS) $(DEPENDFILENAME) |
|
936 |
ifneq "$(DEPENDFILE)" "" |
|
937 |
ifeq ($(NO_DEPEND_INCLUDE),) |
|
938 |
ifeq "$(filter %CLEAN,$(call uppercase,$(MAKECMDGOALS)))" "" |
|
939 |
-include $(DEPENDFILE) |
|
940 |
endif |
|
941 |
endif |
|
942 |
endif |
|
943 |
||
944 |
endef |
|
945 |
||
946 |
# Create a rule for each cia file |
|
947 |
ifeq ($(TRANSFORM_CIA),1) |
|
948 |
$(eval $(foreach e32abiv2_RULE,$(CIAFILES),$(call e32abiv2_CIA2CPP,$(e32abiv2_RULE)))) |
|
949 |
endif |
|
950 |
||
951 |
# Pure assembler (.s files) ################################ |
|
952 |
||
953 |
e32abiv2_asm_OPTIONS:=$(LICENSERETRY_OPTION) \ |
|
954 |
$(CC_CORE_ARGS) \ |
|
955 |
$(OPTION_COMPILER) \ |
|
956 |
$(call makemacrodef,-D,$(COMPILER_INTERWORK_DEFINES) $(CDEFS)) \ |
|
957 |
$(if $(USERINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$$(call dblquote,$(USERINCLUDE))) \ |
|
958 |
$(if $(SYSTEMINCLUDE),$(COMPILER_SYSTEM_INCLUDE_OPTION),)$$(call concat, $(COMPILER_SYSTEM_INCLUDE_OPTION),$$(call dblquote,$(SYSTEMINCLUDE))) |
|
959 |
||
960 |
# note that the --no_rtti option cannot be passed with the -M option |
|
961 |
# so forcibly remove it when generating ASM dependencies. |
|
962 |
# |
|
963 |
define e32abiv2_asm |
|
964 |
||
965 |
$(eval DEPENDFILENAME:=$(1).d) |
|
966 |
$(eval DEPENDFILE:=$(wildcard $(DEPENDFILENAME))) |
|
967 |
||
968 |
$(1): $(2) $(PROJECT_META) $(if $(DEPENDFILE),,RESOURCE BITMAP EXPORT) |
|
969 |
$(call startrule,asmcompile,,$(2)) \ |
|
970 |
$(if $(PERTURBSTARTTIME),$(RANSLEEP) $(PERTURBMSECS) ;,) \ |
|
971 |
$(CC) $(e32abiv2_asm_OPTIONS) \ |
|
972 |
$(DEPEND_OPTION) $(call dblquote,$(DEPENDFILENAME)) \ |
|
973 |
$$(call dblquote, $$<) $(OUTPUT_OPTION) $$@ \ |
|
974 |
$(call endrule,asmcompile) |
|
975 |
$(call startrule,asmdependencies) \ |
|
976 |
$(CC) -M $(subst --no_rtti,,$(e32abiv2_asm_OPTIONS)) --depend_format=unix \ |
|
977 |
$(OUTPUT_OPTION) $$@ $$(call dblquote,$2) > $(call dblquote,$(DEPENDFILENAME)) \ |
|
978 |
$(call endrule,asmdependencies) |
|
979 |
||
980 |
CLEANTARGETS:=$$(CLEANTARGETS) $(DEPENDFILENAME) |
|
981 |
ifneq "$(DEPENDFILE)" "" |
|
982 |
ifeq ($(NO_DEPEND_INCLUDE),) |
|
983 |
ifeq "$(filter %CLEAN,$(call uppercase,$(MAKECMDGOALS)))" "" |
|
984 |
-include $(DEPENDFILE) |
|
985 |
endif |
|
986 |
endif |
|
987 |
endif |
|
988 |
||
989 |
CREATABLEPATHS:=$$(CREATABLEPATHS) $(INTERMEDIATEPATH) |
|
990 |
||
991 |
endef |
|
992 |
||
993 |
$(eval $(foreach F,$(ASMFILES), $(call e32abiv2_asm,$(call mapasm2object,$(F)),$(F)))) |
|
994 |
CLEANTARGETS:=$(CLEANTARGETS) $(ASMFILES_LINKOBJECTS) |
|
995 |
||
996 |
endif # ifneq ($(TARGETTYPE),implib) |
|
997 |
||
998 |
||
999 |
########################## Build ROMFILE target ############################ |
|
1000 |
EPOC_ROOT:=$(patsubst %/,%,$(EPOCROOT)) |
|
1001 |
TOBLDINF:=$(dir $(subst :,,$(subst $(EPOC_ROOT)/,,$(COMPONENT_META)))) |
|
1002 |
||
1003 |
# Only build ROMFILE if asked |
|
1004 |
ifneq ($(filter ROMFILE,$(call uppercase,$(MAKECMDGOALS))),) |
|
1005 |
ifeq ($(ROMFILE_$(call sanitise,$(TARGET).$(REQUESTEDTARGETEXT))),) |
|
1006 |
ROMFILE_$(call sanitise,$(TARGET).$(REQUESTEDTARGETEXT)):=1 |
|
1007 |
ROMDIR:=$(EPOC_ROOT)/epoc32/rom/$(TOBLDINF) |
|
1008 |
||
1009 |
# Default values |
|
1010 |
ROMFILETYPE:=file |
|
1011 |
ROMFILE:=$(TARGET).$(REQUESTEDTARGETEXT) |
|
1012 |
ROMPATH:=sys/bin/ |
|
1013 |
ROMDECORATIONS:= |
|
1014 |
ROMFILETYPE_RAM:=data |
|
1015 |
ROMFILE_RAM:=$(TARGET).$(REQUESTEDTARGETEXT) |
|
1016 |
ROMPATH_RAM:=sys/bin/ |
|
1017 |
BUILDROMTARGET:=1 |
|
1018 |
ABIDIR:=MAIN |
|
1019 |
||
1020 |
$(eval $(call DoRomSet)) |
|
1021 |
||
1022 |
ifneq ($(EPOCFIXEDPROCESS),) |
|
1023 |
ROMDECORATIONS:=$(ROMDECORATIONS) fixed |
|
1024 |
endif |
|
1025 |
ifeq ($(PAGED),1) |
|
1026 |
ROMDECORATIONS:=$(ROMDECORATIONS) paged |
|
1027 |
endif |
|
1028 |
ifeq ($(PAGED),0) |
|
1029 |
ROMDECORATIONS:=$(ROMDECORATIONS) unpaged |
|
1030 |
endif |
|
1031 |
||
1032 |
||
1033 |
ifeq ($(TESTCODE),TRUE) |
|
1034 |
# Add 'TEST' to the .iby filename |
|
1035 |
ROMTEST:=test |
|
1036 |
ifeq ($(TEST_OPTION),BOTH) |
|
1037 |
DATATEXT:="data=/epoc32/data/z/test/$(MODULE)/$(VARIANTPLATFORM).auto.bat test/$(MODULE).auto.bat"\n"data=/epoc32/data/z/test/$(MODULE)/$(VARIANTPLATFORM).manual.bat test/$(MODULE).manual.bat" |
|
1038 |
else |
|
1039 |
ifneq ($(TEST_OPTION),NONE) |
|
1040 |
DATATEXT:="data=/epoc32/data/z/test/$(MODULE)/$(VARIANTPLATFORM).$(TEST_OPTION).bat test/$(MODULE).$(TEST_OPTION).bat" |
|
1041 |
endif |
|
1042 |
endif |
|
1043 |
else |
|
1044 |
DATATEXT:= |
|
1045 |
endif |
|
1046 |
||
1047 |
# ROMTARGET |
|
1048 |
ifneq ($(ROMTARGET),) |
|
1049 |
ifneq ($(words $(ROMTARGET)),1) |
|
1050 |
ROMTARGETALL:=$(ROMTARGET) |
|
1051 |
ROMTARGET:=$(word 1,$(ROMTARGET)) |
|
1052 |
endif |
|
1053 |
||
1054 |
ifeq ($(ROMTARGET),<none>) |
|
1055 |
BUILDROMTARGET:= |
|
1056 |
else |
|
1057 |
ifneq ($(ROMTARGET),+) |
|
1058 |
ifneq ($(notdir $(ROMTARGET)),) |
|
1059 |
ROMFILE:=$(notdir $(ROMTARGET)) |
|
1060 |
endif |
|
1061 |
ifneq ($(dir $(ROMTARGET)),./) |
|
1062 |
ROMPATH:=$(dir $(ROMTARGET)) |
|
1063 |
endif |
|
1064 |
endif |
|
1065 |
endif |
|
1066 |
endif |
|
1067 |
endif |
|
1068 |
||
1069 |
ROMFILENAME:=$(ROMDIR)$(PLATFORM)$(ROMTEST).iby |
|
1070 |
||
1071 |
# RAMTARGET |
|
1072 |
ifneq ($(RAMTARGET),) |
|
1073 |
ROMDECORATIONS_RAM:=" attrib=r" |
|
1074 |
ifneq ($(RAMTARGET),+) |
|
1075 |
ifneq ($(notdir $(RAMTARGET)),) |
|
1076 |
ROMFILE_RAM:=$(notdir $(RAMTARGET)) |
|
1077 |
endif |
|
1078 |
ifneq ($(dir $(RAMTARGET)),./) |
|
1079 |
ROMPATH_RAM:=$(dir $(RAMTARGET)) |
|
1080 |
endif |
|
1081 |
endif |
|
1082 |
endif |
|
1083 |
||
1084 |
define BuildRomfileTarget |
|
1085 |
$(ALLTARGET)::ROMFILE |
|
1086 |
ROMFILE:: |
|
1087 |
$(call startrule,rombuild) \ |
|
1088 |
$(GNUMKDIR) -p $(ROMDIR) \ |
|
1089 |
$(if $(ROMFILE_CREATED_$(TOBLDINF)),,&& echo -e "// $(subst $(EPOC_ROOT)/,,$(ROMFILENAME))\n//\n$(DATATEXT)" > $(ROMFILENAME)) \ |
|
1090 |
$(if $(BUILDROMTARGET),&& echo "$(ROMFILETYPE)=/epoc32/release/##$(ABIDIR)##/##BUILD##/$(TARGET).$(REQUESTEDTARGETEXT) $(1)$(ROMDECORATIONS)" >> $(ROMFILENAME)) \ |
|
1091 |
$(if $(RAMTARGET),&& echo "$(ROMFILETYPE_RAM)=/epoc32/release/##$(ABIDIR)##/##BUILD##/$(TARGET).$(REQUESTEDTARGETEXT) $(ROMPATH_RAM)$(ROMFILE_RAM)$(ROMDECORATIONS_RAM)" >> $(ROMFILENAME)) \ |
|
1092 |
$(call endrule,buildromfiletarget) |
|
1093 |
endef |
|
1094 |
||
1095 |
# When VARIANTTYPE changes, romfile is finished, |
|
1096 |
# apart from if this is a new component...... |
|
1097 |
ifneq ($(PREVIOUSVARIANTTYPE),) |
|
1098 |
ifneq ($(VARIANTTYPE),$(PREVIOUSVARIANTTYPE)) |
|
1099 |
ifneq ($(ROMFILE_CREATED_$(TOBLDINF)),) |
|
1100 |
ROMFILEFINISHED:=1 |
|
1101 |
else |
|
1102 |
ROMFILEFINISHED:= |
|
1103 |
endif |
|
1104 |
endif |
|
1105 |
endif |
|
1106 |
||
1107 |
# When romfile is finished, don't continue to add to it |
|
1108 |
ifeq ($(ROMFILEFINISHED),) |
|
1109 |
$(eval $(call BuildRomfileTarget,$(ROMPATH)$(ROMFILE))) |
|
1110 |
endif |
|
1111 |
||
1112 |
# Don't allow romfile to be recreated for every MMP |
|
1113 |
ifeq ($(ROMFILE_CREATED_$(TOBLDINF)),) |
|
1114 |
ROMFILE_CREATED_$(TOBLDINF):=1 |
|
1115 |
endif |
|
1116 |
||
1117 |
# Build other ROMTARGETs if there is more than one |
|
1118 |
ifneq ($(ROMTARGETALL),) |
|
1119 |
RAMTARGET:= |
|
1120 |
$(foreach ROMTARGET,$(wordlist 2,$(words $(ROMTARGETALL)),$(ROMTARGETALL)),$(eval $(call BuildRomfileTarget,$(ROMTARGET)))) |
|
1121 |
ROMTARGETALL:= |
|
1122 |
endif |
|
1123 |
||
1124 |
# Keep track of variant type while romfile is being created |
|
1125 |
PREVIOUSVARIANTTYPE:=$(VARIANTTYPE) |
|
1126 |
||
1127 |
WHATRELEASE:=$(WHATRELEASE) $(ROMFILENAME) |
|
1128 |
endif |
|
1129 |
||
1130 |
# Deal with test code batch files generation. |
|
1131 |
ifneq ($(TESTPATH),) |
|
1132 |
||
1133 |
CREATABLEPATHS:=$(CREATABLEPATHS) $(EPOCROOT)/epoc32/data/z/test/ |
|
1134 |
$(eval $(call MakeTestBatchFiles,$(TARGET),$(EPOCROOT)/epoc32/data/z/test/$(MODULE)/$(VARIANTPLATFORM).$(TESTPATH))) |
|
1135 |
BATCHFILE_CREATED_$(EPOCROOT)/epoc32/data/z/test/$(MODULE)/$(VARIANTPLATFORM).$(TESTPATH):=1 |
|
1136 |
TARGET_CREATED_$(EPOCROOT)/epoc32/data/z/test/$(MODULE)/$(VARIANTPLATFORM).$(TESTPATH)_$(TARGET):=1 |
|
1137 |
WHATRELEASE:=$(WHATRELEASE) $(EPOCROOT)/epoc32/data/z/test/$(MODULE)/$(VARIANTPLATFORM).$(TESTPATH) |
|
1138 |
endif |
|
1139 |
||
1140 |
###################### End of Build ROMFILE target ###################### |
|
1141 |
||
1142 |
# Feature Variation requires a .vmap file to be created for each binary |
|
1143 |
# |
|
1144 |
ifneq ($(FEATUREVARIANTNAME),) |
|
1145 |
ifneq ($(E32TARGET),) |
|
1146 |
||
1147 |
OUTPUTVMAP:=$(E32TARGET).vmap |
|
1148 |
WHATRELEASE:=$(WHATRELEASE) $(OUPUTVMAP) |
|
1149 |
||
1150 |
TARGET:: $(OUTPUTVMAP) |
|
1151 |
VMAPNEEDS:=$(E32TARGET) $(SOURCE) $(PROJECT_META) |
|
1152 |
||
1153 |
BV_SOURCELIST:=$(addprefix -s ,$(SOURCE) $(PROJECT_META)) |
|
1154 |
BV_FEATURELIST:=$(addprefix -f ,$(FEATURELISTFILES)) |
|
1155 |
BV_USER_INCLUDES:=$(addprefix -u ,$(USERINCLUDE)) |
|
1156 |
BV_SYSTEM_INCLUDES:=$(addprefix -x ,$(SYSTEMINCLUDE)) |
|
1157 |
||
1158 |
# translate double quoted macros because $(shell) messes them up in some make engines |
|
1159 |
BV_MACROLIST:=$(COMPILER_INTERWORK_DEFINES) $(CDEFS) $(if $(ALWAYS_BUILD_AS_ARM),,$(COMPILER_THUMB_DEFINES)) |
|
1160 |
BV_DEFINES:=$(call makemacrodef,-D,$(subst ",__SBS__QUOTE__,$(BV_MACROLIST))) |
|
1161 |
||
1162 |
# the script to generate our .vmap file and hash value |
|
1163 |
VMAPCOMMAND:=$(CREATEVMAP) -o $(OUTPUTVMAP) $(BV_FEATURELIST) $(BV_DEFINES) -p $(PREINCLUDE) $(BV_SOURCELIST) $(BV_USER_INCLUDES) $(BV_SYSTEM_INCLUDES) -c $(CREATEVMAPCPP) |
|
1164 |
||
1165 |
# a recipe to create the .vmap from the "sources" with the createvmap script |
|
1166 |
$(call raptor_recipe,createvmap,$(OUTPUTVMAP),$(VMAPNEEDS),$(VMAPCOMMAND)) |
|
1167 |
||
1168 |
endif # E32TARGET != "" |
|
1169 |
endif # FEATUREVARIANTNAME != "" |
|
1170 |
||
1171 |
########################### CONCLUSION ################################### |
|
1172 |
||
1173 |
# make the output directories while reading makefile - some build engines prefer this |
|
1174 |
$(call makepath,$(CREATABLEPATHS)) |
|
1175 |
||
1176 |
## Clean up |
|
5 | 1177 |
$(call raptor_clean,$(CLEANTARGETS)) |
3 | 1178 |
|
5 | 1179 |
# For the --what option and the log file |
1180 |
$(call raptor_release,$(filter-out %.sym,$(WHATRELEASE))) |
|
3 | 1181 |
|
1182 |
endif # FEATUREVARIANTNAME=="" or FEATUREVARIANT==1 |
|
1183 |
||
1184 |
## The End |
|
1185 |