注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

小明砸乱弹琴

一个工程师的日常

 
 
 

日志

 
 
关于我

喜欢哲学、几何学、心理学、物理学、音乐、简单的文字及一切有趣的事物。热爱幻想,追求思想和学术自由,热衷简单平凡的生活和发现美好的事物。

网易考拉推荐
 
 

【转载】CMD文件的编写  

2012-09-06 17:31:04|  分类: DSP技术 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

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。

  评论这张
 
阅读(282)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017