这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » FPGA » CMD文件的编写

共2条 1/1 1 跳转至

CMD文件的编写

助工
2014-12-21 10:44:01     打赏
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。

高工
2014-12-21 23:41:03     打赏
2楼

这个可以直接在例程文件中修改使用


共2条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]