DSP

cmd文件编写

2019-07-13 16:21发布

DSP的CMD文件写法综述

 首先,编写cmd文件时必须熟悉你的DSP的存储器的地址范围。CMD是主要是根据那个来编写的,还有要注意MP/MC,PON以及DON这些位,它们都在PMST中,PMST的值可以在I/0的映射地址FFE4H中手动修改。     CMD 它是用来分配rom和ram空间用的,告诉链接程序怎样计算地址和分配空间.所以不同的芯片就有不同大小的rom和ram.放用户程序的地方也不尽相同.所以要根据你的芯片进行修改.cmd文件分两部分.MEMORY和SECTIONS. MEMORY {   PAGE 0 ..........     PAGE 1......... }   SECTIONS {SECTIONS { .vectors ................. .reset ................. ................   } MEMORY是用来指定芯片的rom和ram的大小和划分出几个区间. PAGE 0 对应rom;PAGE 1对应ram PAGE 里包含的区间名字与其后面的参数反映了该区间的起始地址和长度. 如: PAGE 0 : VECS(区间名字): origin(起始地址) = 0h , length (长度) =040h /*VECTORS*/   SECTIONS:(在程序里添加下面的段名如.vectors.用来指定该段名以下,另一个段名以上 的程序(属于PAGE0)或数据(属于PAGE1)放到“>”符号后的空间名字所在的地方。 如引用字段名“.vectors ”的程序或数据将被放到VECS ,VECS是PAGE0即是ROM空间 00H 至40H的地方   SECTIONS { .vectors : { } > VECS PAGE 0 /* Interrupt vector table */ .reset :   { } > VECS PAGE 0 /* Reset code */ ............ }   注:1..vectors,.reset都是段名。  加不加“.”随你便,即.vectors表示名为  “.vectors”的段。
         2.{}表示段的全部,{}> VECS PAGE 0表示将段的全部放入名为 VECS PAGE 0的内存区。
例子:  
/****************************************************************************/ /******** Specify the memory configuration **********************************/ /****************************************************************************/ MEMORY { PAGE 0: VECS: origin = 00000h, length = 00040h LOW: origin = 00040h, length = 03FC0h SARAM: origin = 04000h, length = 00800h B0: origin = 0FF00h, length = 00100h   PAGE 1: B0: origin = 00200h, length = 00100h B1: origin = 00300h, length = 00100h B2: origin = 00060h, length = 00020h SARAM: origin = 08000h, length = 00800h }   /*--------------------------------------------------------------------------*/ /* SECTIONS ALLOCATION  */ /*--------------------------------------------------------------------------*/   SECTIONS { .text : { } > LOW PAGE 0 .cinit : { } > LOW PAGE 0 .switch : { } > LOW PAGE 0   .const : { } > SARAM PAGE 1 .data : { } > SARAM PAGE 1 .bss : { } > SARAM PAGE 1 .stack : { } > SARAM PAGE 1 .sysmem : { } > SARAM PAGE 1 }    ps: PAGE就是对一个存储空间进行标记,最多可以有255个PAGE,不同PAGE上的存储器区间可以取相同的名字 origin 写成 org、 o都可以 length 写成len、 l 都可以 其实SECTIONS中:和>中间的{}可以省略的.  

MEMORY
{
PAGE 0: VECS : origin = 0h,length = 40h /* 程序复位 */
               PVECS : origin = 40h,length = 70h /* 外围模块中断向量 */
               PROG : origin = 0b0h,length = 7F50h   /* 在片FLASH */
PAGE 1: MMRS : origin = 0h ,length = 05Fh   /* MMRS */
               B2  : origin = 0060h ,length = 020h   /* DARAM B2 块 */
               B0  : origin = 0200h , length = 100h   /* DARAM B0 块 */
               B1  : origin = 0300h , length = 100h   /* DARAM B1 块 */
              SARAM : origin = 0800h , length = 0800h /* SARAM 块 */
              EXT  : origin = 8000h , length = 8000h   /* 外部存储器 */
}
/*--------------------------------------------------------*/
/* SECTIONS ALLOCATION */
/*---------------------------------------------------------*/
SECTIONS
{
 .reset : { } > VECS PAGE 0   /* 复位中断向量表 */
 .vectors : { } > VECS PAGE 0  /* 中断向量表 */
 .pvecs : { } > PVECS PAGE 0  /* 外围模块中断向量表   */
 .text : { } > PROG PAGE 0  /* 代码 */
 .cinit : { } > PROG PAGE 0
 .bss : { } > SARAM PAGE 1  /* 块 B2 */
 .const : { } > SARAM PAGE 1  /* 块 B2 */   
 .stack : { } > B1 PAGE 1  /* 堆栈-40个单元 */
}
I
整个文件分为MEMORY和SECTIONS两部分,MEMORY部分又分为
PAGE0,PAGE1等,分别代表程序存储,数据存储单元,
MEMORY区的语法结构是:
Block Name : origin = Start Address ,length = Length
其中,Block Name 使用户定义的,用于SECTIONS区的名称,可以自己命名
Start Address是区段开始地址,Length是区段长度。
II
SECTIONS区的语法结构是:
 segment : { } > Name PAGE n
其中segment 为程序区段,例如.text段,.bss段等等,
Name为MEMORY区定义的Block Name,也就是
segment对应的代码,将要放置在Block Name区段。
PAGE n是Block Name对应的PAGE。

http://blog.sina.com.cn/s/blog_4d90492b01000d1k.html