找回密码
 注册
搜索
查看: 468|回复: 1

[讨论] DSP中CMD文件的编写.rar 如何进行DSP开发.rar

[复制链接]
发表于 2009-3-11 17:13:42 | 显示全部楼层 |阅读模式
【文件名】:09311@52RD_如何进行DSP开发.rar
【格 式】:rar
【大 小】:269K
【简 介】:
【目 录】:
[UseMoney=1]

[/UseMoney]

               


        

 
! "#$% &'()*+,-./012
345678 9:
;<=>?@ABCDEFGHIJKL
M&N+O <=>PQ 
3RS

&'TU48
WX <=>
3564YZC[H\]^_
8`a?Q4bcdefdgh i bcdjk4l!
8PQDmn56o4
8p(qL
r,        
s 
3truv]^,
3wxUyz2
{]^,|}8

CMD文件的编写
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。
发表于 2009-3-11 18:08:37 | 显示全部楼层
pdf
打开提示错误?
点评回复

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

Archiver|手机版|小黑屋|52RD我爱研发网 ( 沪ICP备2022007804号-2 )

GMT+8, 2024-11-28 00:50 , Processed in 0.047569 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表