FreeCalypso > hg > fc-selenite
comparison src/gpf/ccd/ccddata.mk @ 5:1ea54a97e831
src/gpf: import of Magnetite src/gpf3
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sun, 15 Jul 2018 08:11:07 +0000 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
4:6e457872f745 | 5:1ea54a97e831 |
---|---|
1 #----------------------------------------------------------------------------- | |
2 # Project : | |
3 # Modul : ccddata.mk | |
4 #----------------------------------------------------------------------------- | |
5 # Copyright 2002 Texas Instruments Berlin, AG | |
6 # All rights reserved. | |
7 # | |
8 # This file is confidential and a trade secret of Texas | |
9 # Instruments Berlin, AG | |
10 # The receipt of or possession of this file does not convey | |
11 # any rights to reproduce or disclose its contents or to | |
12 # manufacture, use, or sell anything it may describe, in | |
13 # whole, or in part, without the specific written consent of | |
14 # Texas Instruments Berlin, AG. | |
15 #----------------------------------------------------------------------------- | |
16 # Purpose : Building Ccddata Dll/Lib. | |
17 #----------------------------------------------------------------------------- | |
18 | |
19 ifndef TARGET | |
20 TARGET=win32 | |
21 endif | |
22 | |
23 ifeq ($(TARGET), nuc) | |
24 override TARGET=arm7 | |
25 endif | |
26 PLATFORM=$(TARGET) | |
27 | |
28 COFILES= | |
29 | |
30 include ccd_base.mk | |
31 | |
32 ifeq ($(PROST), g23net) | |
33 CDGINCDIR=$(TESTROOT)/Cdginc | |
34 PROSTCFLAGS= #??? -DOPTION_MULTITHREADED -DSHARED_CCD | |
35 endif | |
36 | |
37 ifeq ($(PROST), g23m) | |
38 CDGINCDIR=$(TESTROOT)/ms/CDGINC | |
39 endif | |
40 | |
41 ifeq ($(PROST), gsm) | |
42 CDGINCDIR=$(TESTROOT)/ms/CDGINC | |
43 endif | |
44 | |
45 ifeq ($(PROST), gprs) | |
46 ifeq ($(TARGET), arm7) | |
47 CDGINCDIR=$(TESTROOT)/cdginc/cdginc_vo | |
48 else | |
49 CDGINCDIR=$(TESTROOT)/ms/CDGINC | |
50 endif | |
51 endif | |
52 | |
53 ifeq ($(PROST), generic) | |
54 ifndef CDGINCDIR | |
55 CDGINCDIR=$(GPF)/util/teststack/inc/cdginc/ | |
56 endif | |
57 endif | |
58 | |
59 ifndef CCDDATADIR | |
60 CCDDATADIR=$(GPFPRJDIR) | |
61 endif | |
62 override CCDDATADIR:=$(subst \,/,$(CCDDATADIR)) | |
63 | |
64 CCDDATA_OBJECTS=ccddata_ccd.obj ccddata_mconst.obj ccddata_ccdmtab.obj\ | |
65 ccddata_cdemval.obj ccddata_ccdent.obj | |
66 CCDDATA_OBJFILES=$(patsubst %.obj,$(OBJDIR)/%.obj,$(CCDDATA_OBJECTS)) | |
67 | |
68 CCDDATA_EXE_OBJECTS=cdt.obj | |
69 CCDDATA_EXE_OBJFILES=$(patsubst %.obj,$(OBJDIR)/%.obj,$(CCDDATA_EXE_OBJECTS)) | |
70 | |
71 LNTFILES=$(patsubst %.obj,%.lto,$(CCDDATA_OBJECTS)) | |
72 | |
73 # win32 | |
74 ifeq ($(TARGET),win32) | |
75 | |
76 include ccddata_version.h | |
77 | |
78 ifeq ($(LOAD),1) | |
79 PART=load | |
80 DLL_PREFIX= | |
81 CCDDATA_OBJECTS = ccddata_load.obj | |
82 COFILES+=$(CCDDATA_LIB) | |
83 LDFLAGS_DLL+=/IMPLIB:$(CCDDATA_IMPLIB) | |
84 DEFINES+=-DCCDDATA_LOAD | |
85 else | |
86 PART=dll | |
87 DLL_PREFIX=cddl_ | |
88 LDFLAGS_DLL+=/COMMENT:CCDDATA_$(CCDDATA_VERSION) | |
89 CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj \ | |
90 ccddata_cdemstr.obj ccddata_cdepval.obj \ | |
91 ccddata_tap_priv.obj ccddata_alias.obj \ | |
92 ccddata_version.obj ccddata_eg.obj ccddata_pdi.obj | |
93 endif | |
94 | |
95 include ccddata_exp.mk | |
96 | |
97 CCDDATA_LIB=$(GPFBINDIR)/ccddata_$(PART).dll | |
98 CCDDATA_IMPLIB=$(subst win32,WIN32,$(GPFLIBDIR)/ccddata_$(PART).lib) | |
99 CCDDATA_IMPLIB_LOCAL=$(OBJDIR)/ccddata_$(PART).lib | |
100 COFILES+=$(CCDDATA_IMPLIB) | |
101 | |
102 CCDEDIT_LIB=$(GPFLIBDIR)/ccdedit.lib | |
103 CCD_LIB=$(GPFLIBDIR)/ccd.lib | |
104 PCON_LIB=$(GPFLIBDIR)/pcon.lib | |
105 FRAME_LIB=$(GPFLIBDIR)/frame.lib | |
106 | |
107 CCDDATA_EXE=$(GPFBINDIR)/cdt.exe | |
108 | |
109 INCLUDES+=-I"$(CDGINCDIR)" | |
110 DEFINES+=-DCCDDATA_DABSTR | |
111 LDFLAGS_DLL+=/nologo /dll $(PROSTLDFLAGS) $(CCDEDIT_LIB) | |
112 ifneq ($(LOAD),1) | |
113 LDFLAGS_DLL+=/IMPLIB:$(CCDDATA_IMPLIB_LOCAL) | |
114 else | |
115 LINK_EXPORTS+=/EXPORT:ccddata_init /EXPORT:ccddata_exit\ | |
116 /EXPORT:ccddata_dllname /SECTION:.shared,RWS | |
117 endif | |
118 LDFLAGS_DLL+=/OUT:"$@" $(LINK_EXPORTS) | |
119 LDFLAGS_DLL+= $(PCON_LIB) $(CCD_LIB) $(FRAME_LIB) | |
120 | |
121 LDFLAGS_EXE=/nologo /OUT:"$@" $(PROSTLDFLAGS) | |
122 | |
123 ifeq ($(DEBUG), 1) | |
124 LDFLAGS_EXE += /DEBUG /incremental:no /pdb:none | |
125 endif | |
126 | |
127 ccddata: all | |
128 | |
129 $(CCDDATA_LIB): $(CCDDATA_OBJECTS) | |
130 $(LINK) $(LDFLAGS_DLL) $(CCDDATA_OBJFILES) | |
131 | |
132 cdt: $(CCDDATA_EXE) | |
133 | |
134 $(CCDDATA_EXE): $(CCDDATA_EXE_OBJECTS) | |
135 -cleartool co -nda -nc $@ | |
136 $(LINK) $(LDFLAGS_EXE) $(CCDDATA_EXE_OBJFILES) $(CCDDATA_IMPLIB) | |
137 | |
138 else | |
139 CCDDATA_OBJECTS += ccd_config.obj | |
140 endif # target == win32 | |
141 | |
142 # nucwin | |
143 ifeq ($(TARGET),nucwin) | |
144 CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib | |
145 INCLUDES+=-I"$(CDGINCDIR)" | |
146 LDFLAGS+=/OUT:"$(CCDDATA_LIB)" | |
147 # currently for all nucwin: put the p* info for PCON in the lib | |
148 CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj | |
149 # and for the concept of synchronous frame with the tap inside | |
150 # of the protocol stack include also most of the rest of ccddata; it | |
151 # should not matter even without the tap | |
152 CCDDATA_OBJECTS += ccddata_cdemstr.obj ccddata_cdepval.obj \ | |
153 ccddata_tap_priv.obj ccddata_alias.obj | |
154 | |
155 $(CCDDATA_LIB): $(CCDDATA_OBJECTS) | |
156 $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) | |
157 | |
158 endif # target == nucwin | |
159 | |
160 # nuc | |
161 ifeq ($(TARGET),arm7) | |
162 CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj | |
163 ifeq ($(CCD_SYMBOLS), 1) | |
164 CCDDATA_OBJECTS += ccddata_alias.obj | |
165 endif | |
166 CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib | |
167 override CCDDATA_LIB:=$(subst \,/,$(CCDDATA_LIB)) | |
168 INCLUDES+=-I"$(CDGINCDIR)" | |
169 LDFLAGS+=-rq $@ | |
170 $(CCDDATA_LIB): $(CCDDATA_OBJECTS) | |
171 $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) | |
172 endif # target == arm7 | |
173 | |
174 # arm9 | |
175 ifeq ($(TARGET),arm9) | |
176 CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj | |
177 ifeq ($(CCD_SYMBOLS), 1) | |
178 CCDDATA_OBJECTS += ccddata_alias.obj | |
179 endif | |
180 CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib | |
181 INCLUDES+=-I"$(CDGINCDIR)" | |
182 LDFLAGS+=-rq $@ | |
183 $(CCDDATA_LIB): $(CCDDATA_OBJECTS) | |
184 $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) | |
185 endif # target = arm9 | |
186 | |
187 # arm_b16 | |
188 ifeq ($(TARGET),arm_b16) | |
189 CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib | |
190 INCLUDES+=-I"$(CDGINCDIR)" | |
191 LDFLAGS+=-rv $@ | |
192 $(CCDDATA_LIB): $(CCDDATA_OBJECTS) | |
193 $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) | |
194 endif # target == arm_b16 | |
195 | |
196 # arm_b32 | |
197 ifeq ($(TARGET),arm_b32) | |
198 CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib | |
199 INCLUDES+=-I"$(CDGINCDIR)" | |
200 LDFLAGS+=-rv $@ | |
201 $(CCDDATA_LIB): $(CCDDATA_OBJECTS) | |
202 $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) | |
203 endif # target == arm_b32 | |
204 | |
205 # psos | |
206 ifeq ($(TARGET),psos) | |
207 CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib | |
208 INCLUDES+=-I"$(CDGINCDIR)" | |
209 LDFLAGS+=$@ | |
210 $(CCDDATA_LIB): $(COPTS_FILE) $(CCDDATA_OBJECTS) | |
211 $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) | |
212 $(RM) $(COPTS_FILE) | |
213 | |
214 $(COPTS_FILE): | |
215 @echo $(_CFLAGS) > c.opt | |
216 @echo $(INCLUDES) >> c.opt | |
217 @echo $(DEFINES) >> c.opt | |
218 | |
219 endif # target == psos | |
220 | |
221 # sus environments | |
222 ifeq ($(OSENV), sus) | |
223 CCDDATA_LIB=$(CCDDATADIR)/libccddata.a | |
224 INCLUDES+=-I$(CDGINCDIR) | |
225 # currently for all emulations: put the p* info for PCON in the lib | |
226 CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj | |
227 # and for the concept of synchronous frame with the tap inside | |
228 # of the protocol stack include also most of the rest of ccddata; it | |
229 # should not matter even without the tap | |
230 CCDDATA_OBJECTS += ccddata_cdemstr.obj ccddata_cdepval.obj \ | |
231 ccddata_tap_priv.obj ccddata_alias.obj | |
232 | |
233 $(CCDDATA_LIB): $(CCDDATA_OBJECTS) | |
234 $(MKLIB) $(CCDDATA_LIB) $(CCDDATA_OBJFILES) | |
235 $(RANLIB) $(CCDDATA_LIB) | |
236 | |
237 endif # sus | |
238 | |
239 all: $(CCDDATA_LIB) | |
240 | |
241 exe: $(CCDDATA_EXE) | |
242 | |
243 $(CCDDATA_OBJECTS) $(CCDDATA_EXE_OBJECTS):\ | |
244 %.obj: %.c $(OBJDIR) | |
245 $(CC) $(CFLAGS) "$<" | |
246 | |
247 CCDDATA_LIBDIR=$(subst \,/,$(dir $(CCDDATA_LIB))). | |
248 | |
249 $(CCDDATA_LIB): $(CCDDATA_LIBDIR) $(CCDEDIT_LIB) | |
250 | |
251 $(OBJDIR) $(CCDDATA_LIBDIR): | |
252 @$(MKDIR) -p $@ | |
253 | |
254 clean: | |
255 $(RM) $(OBJDIR)/ccddata* $(OBJDIR)/ccd_config* $(OBJDIR)/cdt.obj \ | |
256 $(CCDDATA_LIB) | |
257 | |
258 help: | |
259 @echo Usage: gnumake -f ccddata.mk [ DEBUG=1 ] TARGET=target | |
260 @echo with target: arm7, arm9, arm_b16, arm_b32, nucwin, win32, or psos | |
261 @echo further options: | |
262 @echo CCDENT=0 when the file ccdent.cdg does not exist in the\ | |
263 cdginc directory | |
264 @echo CCDALIAS=0 when the files malias.cdg and palias.cdg do not exist\ | |
265 in the cdginc directory | |
266 @echo CDEMSTR=0 when the file cdemstr.cdg.cdg does not exist\ | |
267 in the cdginc directory | |
268 @echo CDGINCDIR=path with the path to the cdginc directory | |
269 @echo CCDDATA_LIB=path with the path to the ccddata lib to be built | |
270 | |
271 ci: | |
272 -cleartool ci -nc $(COFILES) | |
273 | |
274 co: | |
275 -cleartool co -nda -nc $(COFILES) | |
276 | |
277 -include ccd_lnt.mk | |
278 include ccddata_dep.mk |