FreeCalypso > hg > fc-selenite
diff 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 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/gpf/ccd/ccddata.mk Sun Jul 15 08:11:07 2018 +0000 @@ -0,0 +1,278 @@ +#----------------------------------------------------------------------------- +# Project : +# Modul : ccddata.mk +#----------------------------------------------------------------------------- +# Copyright 2002 Texas Instruments Berlin, AG +# All rights reserved. +# +# This file is confidential and a trade secret of Texas +# Instruments Berlin, AG +# The receipt of or possession of this file does not convey +# any rights to reproduce or disclose its contents or to +# manufacture, use, or sell anything it may describe, in +# whole, or in part, without the specific written consent of +# Texas Instruments Berlin, AG. +#----------------------------------------------------------------------------- +# Purpose : Building Ccddata Dll/Lib. +#----------------------------------------------------------------------------- + +ifndef TARGET + TARGET=win32 +endif + +ifeq ($(TARGET), nuc) + override TARGET=arm7 +endif +PLATFORM=$(TARGET) + +COFILES= + +include ccd_base.mk + +ifeq ($(PROST), g23net) + CDGINCDIR=$(TESTROOT)/Cdginc + PROSTCFLAGS= #??? -DOPTION_MULTITHREADED -DSHARED_CCD +endif + +ifeq ($(PROST), g23m) + CDGINCDIR=$(TESTROOT)/ms/CDGINC +endif + +ifeq ($(PROST), gsm) + CDGINCDIR=$(TESTROOT)/ms/CDGINC +endif + +ifeq ($(PROST), gprs) + ifeq ($(TARGET), arm7) + CDGINCDIR=$(TESTROOT)/cdginc/cdginc_vo + else + CDGINCDIR=$(TESTROOT)/ms/CDGINC + endif +endif + +ifeq ($(PROST), generic) + ifndef CDGINCDIR + CDGINCDIR=$(GPF)/util/teststack/inc/cdginc/ + endif +endif + +ifndef CCDDATADIR + CCDDATADIR=$(GPFPRJDIR) +endif +override CCDDATADIR:=$(subst \,/,$(CCDDATADIR)) + +CCDDATA_OBJECTS=ccddata_ccd.obj ccddata_mconst.obj ccddata_ccdmtab.obj\ + ccddata_cdemval.obj ccddata_ccdent.obj +CCDDATA_OBJFILES=$(patsubst %.obj,$(OBJDIR)/%.obj,$(CCDDATA_OBJECTS)) + +CCDDATA_EXE_OBJECTS=cdt.obj +CCDDATA_EXE_OBJFILES=$(patsubst %.obj,$(OBJDIR)/%.obj,$(CCDDATA_EXE_OBJECTS)) + +LNTFILES=$(patsubst %.obj,%.lto,$(CCDDATA_OBJECTS)) + +# win32 +ifeq ($(TARGET),win32) + +include ccddata_version.h + +ifeq ($(LOAD),1) + PART=load + DLL_PREFIX= + CCDDATA_OBJECTS = ccddata_load.obj + COFILES+=$(CCDDATA_LIB) + LDFLAGS_DLL+=/IMPLIB:$(CCDDATA_IMPLIB) + DEFINES+=-DCCDDATA_LOAD +else + PART=dll + DLL_PREFIX=cddl_ + LDFLAGS_DLL+=/COMMENT:CCDDATA_$(CCDDATA_VERSION) + CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj \ + ccddata_cdemstr.obj ccddata_cdepval.obj \ + ccddata_tap_priv.obj ccddata_alias.obj \ + ccddata_version.obj ccddata_eg.obj ccddata_pdi.obj +endif + + include ccddata_exp.mk + + CCDDATA_LIB=$(GPFBINDIR)/ccddata_$(PART).dll + CCDDATA_IMPLIB=$(subst win32,WIN32,$(GPFLIBDIR)/ccddata_$(PART).lib) + CCDDATA_IMPLIB_LOCAL=$(OBJDIR)/ccddata_$(PART).lib + COFILES+=$(CCDDATA_IMPLIB) + + CCDEDIT_LIB=$(GPFLIBDIR)/ccdedit.lib + CCD_LIB=$(GPFLIBDIR)/ccd.lib + PCON_LIB=$(GPFLIBDIR)/pcon.lib + FRAME_LIB=$(GPFLIBDIR)/frame.lib + + CCDDATA_EXE=$(GPFBINDIR)/cdt.exe + + INCLUDES+=-I"$(CDGINCDIR)" + DEFINES+=-DCCDDATA_DABSTR + LDFLAGS_DLL+=/nologo /dll $(PROSTLDFLAGS) $(CCDEDIT_LIB) + ifneq ($(LOAD),1) + LDFLAGS_DLL+=/IMPLIB:$(CCDDATA_IMPLIB_LOCAL) + else + LINK_EXPORTS+=/EXPORT:ccddata_init /EXPORT:ccddata_exit\ + /EXPORT:ccddata_dllname /SECTION:.shared,RWS + endif + LDFLAGS_DLL+=/OUT:"$@" $(LINK_EXPORTS) + LDFLAGS_DLL+= $(PCON_LIB) $(CCD_LIB) $(FRAME_LIB) + + LDFLAGS_EXE=/nologo /OUT:"$@" $(PROSTLDFLAGS) + + ifeq ($(DEBUG), 1) + LDFLAGS_EXE += /DEBUG /incremental:no /pdb:none + endif + + ccddata: all + + $(CCDDATA_LIB): $(CCDDATA_OBJECTS) + $(LINK) $(LDFLAGS_DLL) $(CCDDATA_OBJFILES) + + cdt: $(CCDDATA_EXE) + + $(CCDDATA_EXE): $(CCDDATA_EXE_OBJECTS) + -cleartool co -nda -nc $@ + $(LINK) $(LDFLAGS_EXE) $(CCDDATA_EXE_OBJFILES) $(CCDDATA_IMPLIB) + +else + CCDDATA_OBJECTS += ccd_config.obj +endif # target == win32 + +# nucwin +ifeq ($(TARGET),nucwin) + CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib + INCLUDES+=-I"$(CDGINCDIR)" + LDFLAGS+=/OUT:"$(CCDDATA_LIB)" + # currently for all nucwin: put the p* info for PCON in the lib + CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj + # and for the concept of synchronous frame with the tap inside + # of the protocol stack include also most of the rest of ccddata; it + # should not matter even without the tap + CCDDATA_OBJECTS += ccddata_cdemstr.obj ccddata_cdepval.obj \ + ccddata_tap_priv.obj ccddata_alias.obj + + $(CCDDATA_LIB): $(CCDDATA_OBJECTS) + $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) + +endif # target == nucwin + +# nuc +ifeq ($(TARGET),arm7) + CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj + ifeq ($(CCD_SYMBOLS), 1) + CCDDATA_OBJECTS += ccddata_alias.obj + endif + CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib + override CCDDATA_LIB:=$(subst \,/,$(CCDDATA_LIB)) + INCLUDES+=-I"$(CDGINCDIR)" + LDFLAGS+=-rq $@ + $(CCDDATA_LIB): $(CCDDATA_OBJECTS) + $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) +endif # target == arm7 + +# arm9 +ifeq ($(TARGET),arm9) + CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj + ifeq ($(CCD_SYMBOLS), 1) + CCDDATA_OBJECTS += ccddata_alias.obj + endif + CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib + INCLUDES+=-I"$(CDGINCDIR)" + LDFLAGS+=-rq $@ + $(CCDDATA_LIB): $(CCDDATA_OBJECTS) + $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) +endif # target = arm9 + +# arm_b16 +ifeq ($(TARGET),arm_b16) + CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib + INCLUDES+=-I"$(CDGINCDIR)" + LDFLAGS+=-rv $@ + $(CCDDATA_LIB): $(CCDDATA_OBJECTS) + $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) +endif # target == arm_b16 + +# arm_b32 +ifeq ($(TARGET),arm_b32) + CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib + INCLUDES+=-I"$(CDGINCDIR)" + LDFLAGS+=-rv $@ + $(CCDDATA_LIB): $(CCDDATA_OBJECTS) + $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) +endif # target == arm_b32 + +# psos +ifeq ($(TARGET),psos) + CCDDATA_LIB=$(CCDDATADIR)/ccddata.lib + INCLUDES+=-I"$(CDGINCDIR)" + LDFLAGS+=$@ + $(CCDDATA_LIB): $(COPTS_FILE) $(CCDDATA_OBJECTS) + $(MKLIB) $(LDFLAGS) $(CCDDATA_OBJFILES) + $(RM) $(COPTS_FILE) + +$(COPTS_FILE): + @echo $(_CFLAGS) > c.opt + @echo $(INCLUDES) >> c.opt + @echo $(DEFINES) >> c.opt + +endif # target == psos + +# sus environments +ifeq ($(OSENV), sus) + CCDDATA_LIB=$(CCDDATADIR)/libccddata.a + INCLUDES+=-I$(CDGINCDIR) + # currently for all emulations: put the p* info for PCON in the lib + CCDDATA_OBJECTS += ccddata_pconst.obj ccddata_ccdptab.obj + # and for the concept of synchronous frame with the tap inside + # of the protocol stack include also most of the rest of ccddata; it + # should not matter even without the tap + CCDDATA_OBJECTS += ccddata_cdemstr.obj ccddata_cdepval.obj \ + ccddata_tap_priv.obj ccddata_alias.obj + + $(CCDDATA_LIB): $(CCDDATA_OBJECTS) + $(MKLIB) $(CCDDATA_LIB) $(CCDDATA_OBJFILES) + $(RANLIB) $(CCDDATA_LIB) + +endif # sus + +all: $(CCDDATA_LIB) + +exe: $(CCDDATA_EXE) + +$(CCDDATA_OBJECTS) $(CCDDATA_EXE_OBJECTS):\ + %.obj: %.c $(OBJDIR) + $(CC) $(CFLAGS) "$<" + +CCDDATA_LIBDIR=$(subst \,/,$(dir $(CCDDATA_LIB))). + +$(CCDDATA_LIB): $(CCDDATA_LIBDIR) $(CCDEDIT_LIB) + +$(OBJDIR) $(CCDDATA_LIBDIR): + @$(MKDIR) -p $@ + +clean: + $(RM) $(OBJDIR)/ccddata* $(OBJDIR)/ccd_config* $(OBJDIR)/cdt.obj \ + $(CCDDATA_LIB) + +help: + @echo Usage: gnumake -f ccddata.mk [ DEBUG=1 ] TARGET=target + @echo with target: arm7, arm9, arm_b16, arm_b32, nucwin, win32, or psos + @echo further options: + @echo CCDENT=0 when the file ccdent.cdg does not exist in the\ + cdginc directory + @echo CCDALIAS=0 when the files malias.cdg and palias.cdg do not exist\ + in the cdginc directory + @echo CDEMSTR=0 when the file cdemstr.cdg.cdg does not exist\ + in the cdginc directory + @echo CDGINCDIR=path with the path to the cdginc directory + @echo CCDDATA_LIB=path with the path to the ccddata lib to be built + +ci: + -cleartool ci -nc $(COFILES) + +co: + -cleartool co -nda -nc $(COFILES) + +-include ccd_lnt.mk +include ccddata_dep.mk