Part Number: TMS320F28379D
Other Parts Discussed in Thread: UNIFLASH, SYSCONFIG
Tool/software:
I am working on TMS320F28379D. I am having two .out files for CPU1 and CPU2. I want to secure my flash from reading by third party. I have attached my command file of CPU1 and CPU2. Please have a look and let me know what modifications needed to secure my code of CPU1 and CPU2. I am using UNIFLASH to burn code in flash.
/* Command file for CPU2*/
MEMORY
{
PAGE 0 :
/* BEGIN is used for the "boot to SARAM" bootloader mode */
BEGIN : origin = 0x080000, length = 0x000002
RAMM0 : origin = 0x0000A2, length = 0x00035E
RAMD0 : origin = 0x00B000, length = 0x000800
RAMLS0 : origin = 0x008000, length = 0x000800
RAMLS1 : origin = 0x008800, length = 0x000800
RAMLS2 : origin = 0x009000, length = 0x000800
RAMLS3 : origin = 0x009800, length = 0x000800
RAMLS4 : origin = 0x00A000, length = 0x000800
RAMGS14 : origin = 0x01A000, length = 0x001000 /* Only Available on F28379D, F28377D, F28375D devices. Remove line on other devices. */
RAMGS15 : origin = 0x01B000, length = 0x000FF8 /* Only Available on F28379D, F28377D, F28375D devices. Remove line on other devices. */
// RAMGS15_RSVD : origin = 0x01BFF8, length = 0x000008 /* Reserve and do not use for code as per the errata advisory "Memory: Prefetching Beyond Valid Memory" */
RESET : origin = 0x3FFFC0, length = 0x000002
/* Flash sectors */
FLASHG : origin = 0x098000, length = 0x008000 /* on-chip Flash */
FLASHH : origin = 0x0A0000, length = 0x008000 /* on-chip Flash */
FLASHI : origin = 0x0A8000, length = 0x008000 /* on-chip Flash */
FLASHJ : origin = 0x0B0000, length = 0x008000 /* on-chip Flash */
FLASHK : origin = 0x0B8000, length = 0x002000 /* on-chip Flash */
FLASHL : origin = 0x0BA000, length = 0x002000 /* on-chip Flash */
FLASHM : origin = 0x0BC000, length = 0x002000 /* on-chip Flash */
FLASHN : origin = 0x0BE000, length = 0x001FF0 /* on-chip Flash */
// FLASHN_RSVD : origin = 0x0BFFF0, length = 0x000010 /* Reserve and do not use for code as per the errata advisory "Memory: Prefetching Beyond Valid Memory" */
PAGE 1 :
BOOT_RSVD : origin = 0x000002, length = 0x0000A0 /* Part of M0, BOOT rom will use this for stack */
RAMM1 : origin = 0x000400, length = 0x0003F8 /* on-chip RAM block M1 */
// RAMM1_RSVD : origin = 0x0007F8, length = 0x000008 /* Reserve and do not use for code as per the errata advisory "Memory: Prefetching Beyond Valid Memory" */
RAMD1 : origin = 0x00B800, length = 0x000800
RAMLS5 : origin = 0x00A800, length = 0x000800
RAMGS0 : origin = 0x00C000, length = 0x001000
RAMGS1 : origin = 0x00D000, length = 0x001000
RAMGS2 : origin = 0x00E000, length = 0x001000
RAMGS3 : origin = 0x00F000, length = 0x001000
RAMGS4 : origin = 0x010000, length = 0x001000
RAMGS5 : origin = 0x011000, length = 0x001000
RAMGS6 : origin = 0x012000, length = 0x001000
RAMGS7 : origin = 0x013000, length = 0x001000
RAMGS8 : origin = 0x014000, length = 0x001000
RAMGS9 : origin = 0x015000, length = 0x001000
RAMGS10 : origin = 0x016000, length = 0x001000
CPU2TOCPU1RAM : origin = 0x03F800, length = 0x000400
CPU1TOCPU2RAM : origin = 0x03FC00, length = 0x000400
GPIOMUX: origin = 0x007C00, length = 0x000180 /* GPIO mux registers */
GPIODAT: origin = 0x007F00, length = 0x000030 /* GPIO data registers */
IpcRegs : origin = 0x00050000, length = 0x000024 /* IPC Registers */
PieVectRegs : origin = 0x00000D00, length = 0x000200 /* PieVect Registers */
PieCtrlRegs : origin = 0x00000CE0, length = 0x000020 /* PieVect Registers */
WdRegs : origin = 0x00007000, length = 0x00003F
}
SECTIONS
{
/* Allocate program areas: */
.cinit : > FLASHN PAGE = 0, ALIGN(8)
.text : >> FLASHH | FLASHI | FLASHJ | FLASHK | FLASHL | FLASHM PAGE = 0, ALIGN(8)
codestart : > BEGIN PAGE = 0, ALIGN(8)
/* Allocate uninitalized data sections: */
.stack : > RAMM1 PAGE = 1
/* Initalized sections go in Flash */
.switch : > FLASHG PAGE = 0, ALIGN(8)
.reset : > RESET, PAGE = 0, TYPE = DSECT /* not used, */
#if defined(__TI_EABI__)
.init_array : > FLASHG, PAGE = 0, ALIGN(8)
.bss : >> RAMLS1 | RAMLS2 | RAMLS3 | RAMLS4 | RAMD0 PAGE = 0
.bss:output : > RAMLS3, PAGE = 0
.bss:cio : > RAMLS5, PAGE = 1
.data : > RAMLS5, PAGE = 1
.sysmem : > RAMLS5, PAGE = 1
/* Initalized sections go in Flash */
.const : > FLASHG, PAGE = 0, ALIGN(8)
#else
.pinit : > FLASHG, PAGE = 0, ALIGN(8)
.ebss : >> RAMLS5 | RAMGS3 | RAMGS4, PAGE = 1
.esysmem : > RAMLS5, PAGE = 1
.cio : > RAMLS5, PAGE = 1
/* Initalized sections go in Flash */
.econst : >> FLASHG PAGE = 0, ALIGN(8)
#endif
/*SHARERAMGS0 : > RAMGS0, PAGE = 1
SHARERAMGS1 : > RAMGS1, PAGE = 1
SHARERAMGS2 : > RAMGS2, PAGE = 1*/
#ifdef __TI_COMPILER_VERSION__
#if __TI_COMPILER_VERSION__ >= 15009000
#if defined(__TI_EABI__)
.TI.ramfunc : {} LOAD = FLASHG,
RUN = RAMLS0,
LOAD_START(RamfuncsLoadStart),
LOAD_SIZE(RamfuncsLoadSize),
LOAD_END(RamfuncsLoadEnd),
RUN_START(RamfuncsRunStart),
RUN_SIZE(RamfuncsRunSize),
RUN_END(RamfuncsRunEnd),
PAGE = 0, ALIGN(8)
#else
.TI.ramfunc : {} LOAD = FLASHG,
RUN = RAMLS0,
LOAD_START(_RamfuncsLoadStart),
LOAD_SIZE(_RamfuncsLoadSize),
LOAD_END(_RamfuncsLoadEnd),
RUN_START(_RamfuncsRunStart),
RUN_SIZE(_RamfuncsRunSize),
RUN_END(_RamfuncsRunEnd),
PAGE = 0, ALIGN(8)
#endif
#else
ramfuncs : LOAD = FLASHG,
RUN = RAMLS0,
LOAD_START(_RamfuncsLoadStart),
LOAD_SIZE(_RamfuncsLoadSize),
LOAD_END(_RamfuncsLoadEnd),
RUN_START(_RamfuncsRunStart),
RUN_SIZE(_RamfuncsRunSize),
RUN_END(_RamfuncsRunEnd),
PAGE = 0, ALIGN(8)
#endif
#endif
/* The following section definitions are required when using the IPC API Drivers */
GROUP : > CPU2TOCPU1RAM, PAGE = 1
{
PUTBUFFER
PUTWRITEIDX
GETREADIDX
}
GROUP : > CPU1TOCPU2RAM, PAGE = 1
{
GETBUFFER : TYPE = DSECT
GETWRITEIDX : TYPE = DSECT
PUTREADIDX : TYPE = DSECT
}
GpioMuxRegsFile: load = GPIOMUX PAGE = 1
GpioDataRegsFile: load = GPIODAT PAGE = 1
IpcRegsFile: load = IpcRegs PAGE = 1
PieVectRegsFile: load = PieVectRegs PAGE = 1
PieCtrlRegsFile: load = PieCtrlRegs PAGE = 1
SHARERAMGS0: load = RAMGS0 PAGE = 1
SHARERAMGS1: load = RAMGS1 PAGE = 1
SHARERAMGS2: load = RAMGS2 PAGE = 1
WdRegsFile: load = WdRegs PAGE = 1
}
/*
//===========================================================================
// End of file.
//===========================================================================
*/
/* Command file for CPU 1*/
MEMORY
{
PAGE 0 : /* Program Memory */
/* Memory (RAM/FLASH) blocks can be moved to PAGE1 for data allocation */
/* BEGIN is used for the "boot to Flash" bootloader mode */
BEGIN : origin = 0x080000, length = 0x000002
RAMM0 : origin = 0x000123, length = 0x0002DD
RAMD0 : origin = 0x00B000, length = 0x000800
//RAMLS0 : origin = 0x008000, length = 0x000800
//RAMLS1 : origin = 0x008800, length = 0x000800
//RAMLS2 : origin = 0x009000, length = 0x000800
RAMLS_COMBINED : origin = 0x00008000, length = 0x00001800 /* total 8 KB from LS0–LS2 */
RAMLS3 : origin = 0x009800, length = 0x000800
RAMLS4 : origin = 0x00A000, length = 0x000800
RAMGS14 : origin = 0x01A000, length = 0x001000 /* Only Available on F28379D, F28377D, F28375D devices. Remove line on other devices. */
RAMGS15 : origin = 0x01B000, length = 0x000FF8 /* Only Available on F28379D, F28377D, F28375D devices. Remove line on other devices. */
// RAMGS15_RSVD : origin = 0x01BFF8, length = 0x000008 /* Reserve and do not use for code as per the errata advisory "Memory: Prefetching Beyond Valid Memory" */
RESET : origin = 0x3FFFC0, length = 0x000002
/* Flash sectors */
FLASHA : origin = 0x080002, length = 0x001FFE /* on-chip Flash */
FLASHB : origin = 0x082000, length = 0x002000 /* on-chip Flash */
FLASHC : origin = 0x084000, length = 0x002000 /* on-chip Flash */
FLASHD : origin = 0x086000, length = 0x002000 /* on-chip Flash */
//FLASHE : origin = 0x088000, length = 0x008000 /* on-chip Flash */
FLASHF : origin = 0x090000, length = 0x008000 /* on-chip Flash */
// FLASHN_RSVD : origin = 0x0BFFF0, length = 0x000010 /* Reserve and do not use for code as per the errata advisory "Memory: Prefetching Beyond Valid Memory" */
Z1OTP_LINKPOINTER : origin = 0x078000, length = 0x000002
Z1OTP_ZSB : origin = 0x078020, length = 0x000008 /* First 4 fields only */
Z1OTP_CSMPSWD : origin = 0x078028, length = 0x000008 /* Password fields */
Z2OTP_LINKPOINTER : origin = 0x078200, length = 0x000002
Z2OTP_ZSB : origin = 0x078220, length = 0x000008 /* First 4 fields only */
Z2OTP_CSMPSWD : origin = 0x078228, length = 0x000008 /* Password fields */
PAGE 1 : /* Data Memory */
/* Memory (RAM/FLASH) blocks can be moved to PAGE0 for program allocation */
BOOT_RSVD : origin = 0x000002, length = 0x000121 /* Part of M0, BOOT rom will use this for stack */
RAMM1 : origin = 0x000400, length = 0x0003F8 /* on-chip RAM block M1 */
// RAMM1_RSVD : origin = 0x0007F8, length = 0x000008 /* Reserve and do not use for code as per the errata advisory "Memory: Prefetching Beyond Valid Memory" */
RAMD1 : origin = 0x00B800, length = 0x000800
RAMLS5 : origin = 0x00A800, length = 0x000800
RAMGS0 : origin = 0x00C000, length = 0x001000
RAMGS1 : origin = 0x00D000, length = 0x001000
RAMGS2 : origin = 0x00E000, length = 0x001000
RAMGS3 : origin = 0x00F000, length = 0x001000
RAMGS4 : origin = 0x010000, length = 0x001000
RAMGS5 : origin = 0x011000, length = 0x001000
RAMGS6 : origin = 0x012000, length = 0x001000
RAMGS7 : origin = 0x013000, length = 0x001000
RAMGS8 : origin = 0x014000, length = 0x001000
RAMGS9 : origin = 0x015000, length = 0x001000
RAMGS10 : origin = 0x016000, length = 0x001000
GPIOMUX: origin = 0x007C00, length = 0x000180 /* GPIO mux registers */
GPIODAT: origin = 0x007F00, length = 0x000030 /* GPIO data registers */
EPWM1: origin = 0x004000, length = 0x000100 /* epwm1 registers */
EPWM2: origin = 0x004100, length = 0x000100 /* epwm1 registers */
EPWM3: origin = 0x004200, length = 0x000100 /* epwm1 registers */
CAP1: origin = 0x005000, length = 0x000020 /* ecap1 registers */
// RAMGS11 : origin = 0x017000, length = 0x000FF8 /* Uncomment for F28374D, F28376D devices */
// RAMGS11_RSVD : origin = 0x017FF8, length = 0x000008 /* Reserve and do not use for code as per the errata advisory "Memory: Prefetching Beyond Valid Memory" */
RAMGS11 : origin = 0x017000, length = 0x001000 /* Only Available on F28379D, F28377D, F28375D devices. Remove line on other devices. */
RAMGS12 : origin = 0x018000, length = 0x001000 /* Only Available on F28379D, F28377D, F28375D devices. Remove line on other devices. */
RAMGS13 : origin = 0x019000, length = 0x001000 /* Only Available on F28379D, F28377D, F28375D devices. Remove line on other devices. */
CPU2TOCPU1RAM : origin = 0x03F800, length = 0x000400
CPU1TOCPU2RAM : origin = 0x03FC00, length = 0x000400
IpcRegs : origin = 0x00050000, length = 0x000024 /* IPC Registers */
PieVectRegs : origin = 0x00000D00, length = 0x000200 /* PieVect Registers */
PieCtrlRegs : origin = 0x00000CE0, length = 0x000020 /* PieVect Registers */
WD_REG : origin = 0x00007000, length = 0x0000003F
}
SECTIONS
{
/* Allocate program areas: */
.cinit : > FLASHF PAGE = 0, ALIGN(8)
.text : >> FLASHB | FLASHC | FLASHD PAGE = 0, ALIGN(8)
codestart : > BEGIN PAGE = 0, ALIGN(8)
/* Allocate uninitalized data sections: */
.stack : > RAMM1 PAGE = 1
.switch : > FLASHB PAGE = 0, ALIGN(8)
.reset : > RESET, PAGE = 0, TYPE = DSECT
#if defined(__TI_EABI__)
.init_array : > FLASHB, PAGE = 0, ALIGN(8)
.bss : > RAMLS5, PAGE = 1
.bss:output : > RAMLS3, PAGE = 0
.bss:cio : > RAMLS5, PAGE = 1
.data : > RAMLS5, PAGE = 1
.sysmem : > RAMLS5, PAGE = 1
/* Initialized sections in Flash */
.const : > FLASHF, PAGE = 0, ALIGN(8)
#else
.pinit : > FLASHB, PAGE = 0, ALIGN(8)
.ebss : >> RAMLS5 | RAMGS3 | RAMGS4, PAGE = 1
.esysmem : > RAMLS5, PAGE = 1
.cio : > RAMLS5, PAGE = 1
/* Initialized sections go in Flash */
.econst : >> FLASHF PAGE = 0, ALIGN(8)
#endif
/*SHARERAMGS0 : > RAMGS0, PAGE = 1
SHARERAMGS1 : > RAMGS1, PAGE = 1
SHARERAMGS2 : > RAMGS2, PAGE = 1*/
/* Section for RAM functions */
/* This section will be used by functions marked with __attribute__((ramfunc)) */
.TI.ramfunc : {}
LOAD = FLASHD,
RUN = RAMLS_COMBINED,
LOAD_START(RamfuncsLoadStart),
LOAD_SIZE(RamfuncsLoadSize),
LOAD_END(RamfuncsLoadEnd),
RUN_START(RamfuncsRunStart),
RUN_SIZE(RamfuncsRunSize),
RUN_END(RamfuncsRunEnd),
PAGE = 0, ALIGN(8)
/* The following sections are for shared memory between CPU1 and CPU2 */
GROUP : > CPU1TOCPU2RAM, PAGE = 1
{
PUTBUFFER
PUTWRITEIDX
GETREADIDX
}
GROUP : > CPU2TOCPU1RAM, PAGE = 1
{
GETBUFFER : TYPE = DSECT
GETWRITEIDX : TYPE = DSECT
PUTREADIDX : TYPE = DSECT
}
GpioMuxRegsFile: load = GPIOMUX PAGE = 1
GpioDataRegsFile: load = GPIODAT PAGE = 1
ePWM1RegsFile: load = EPWM1 PAGE = 1
ePWM2RegsFile: load = EPWM2 PAGE = 1
ePWM3RegsFile: load = EPWM3 PAGE = 1
cap1RegsFile: load = CAP1 PAGE = 1
cap1RegsFile: load = CAP1 PAGE = 1
IpcRegsFile: load = IpcRegs PAGE = 1
PieVectRegsFile: load = PieVectRegs PAGE = 1
PieCtrlRegsFile: load = PieCtrlRegs PAGE = 1
SHARERAMGS0: load = RAMGS0 PAGE = 1
SHARERAMGS1: load = RAMGS1 PAGE = 1
SHARERAMGS2: load = RAMGS2 PAGE = 1
WdRegsFile: load = WD_REG PAGE = 1
Z1_LINKPOINTER : load = Z1OTP_LINKPOINTER PAGE = 0
Z1_ZSB : load = Z1OTP_ZSB PAGE = 0
Z1_CSMPSWD : load = Z1OTP_CSMPSWD PAGE = 0
Z2_LINKPOINTER : load = Z2OTP_LINKPOINTER PAGE = 0
Z2_ZSB : load = Z2OTP_ZSB PAGE = 0
Z2_CSMPSWD : load = Z2OTP_CSMPSWD PAGE = 0
/* Debugging symbols for CPU1 */
/*.debug_CPU1 : > RAMM0, PAGE = 1
.debug_data : > RAMD0, PAGE = 1*/
}
--retain="*(Z1_LINKPOINTER)"
--retain="*(Z1_ZSB)"
--retain="*(Z1_CSMPSWD)"
--retain="*(Z2_LINKPOINTER)"
--retain="*(Z2_ZSB)"
--retain="*(Z2_CSMPSWD)"
