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。
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮