TI的CMD文件

 

CMD 它是用来分配rom和ram空间用的,告诉链接程序怎样计算地址和分配空间……

TI DSP .CMD 文件的编写

CMD 它是用来分配rom和ram空间用的,告诉链接程序怎样计算地址和分配空间.

所以不同的芯片就有不同大小的rom和ram.放用户程序的地方也不尽相同.所以要根据你的

芯片进行修改.

分两部分.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 */

............

............

..........

}

例子:

/****************************************************************************/

/* LINKER COMMAND FILE - MEMORY SPECIFICATION for C240/243

*/

/*

*/

/****************************************************************************/

/****************************************************************************/

/******** 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

}

在《TMS320C6000DSPs原理与应用》看到这样一句话,也许大家心里轻松一点:

连接命令文件很容易写错,建议使用者以cx000cgtoolsliblnk.cmd文件为模板,并在此文件基础上加以修改。”

关于连接命令文件的更详细信息参考文献请大家参考相关的assembly language tools user's guide.使用6000系列的朋友需要参考的文献号是spru186I.pdf

#################################

 

 

CMD 它是用来分配rom和ram空间用的,告诉链接程序怎样计算地址和分配空间……

TI DSP .CMD 文件的编写

CMD 它是用来分配rom和ram空间用的,告诉链接程序怎样计算地址和分配空间.

所以不同的芯片就有不同大小的rom和ram.放用户程序的地方也不尽相同.所以要根据你的

芯片进行修改.

分两部分.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 */

............

............

..........

}

例子:

/****************************************************************************/

/* LINKER COMMAND FILE - MEMORY SPECIFICATION for C240/243

*/

/*

*/

/****************************************************************************/

/****************************************************************************/

/******** 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

}

在《TMS320C6000DSPs原理与应用》看到这样一句话,也许大家心里轻松一点:

“连接命令文件很容易写错,建议使用者以cx000cgtoolsliblnk.cmd文件为模板,并在此文件基础上加以修改。”

关于连接命令文件的更详细信息参考文献请大家参考相关的assembly language tools user's guide.使用6000系列的朋友需要参考的文献号是spru186I.pdf

#################################

CMD文件有两种产生方式:一种是手写,一种是由DSP/BIOS配置工具产生。CMD的作用很多,但它的最基本的功能就是实现对存储空间的说明和配置。

如下关于CMD配置的例程主要完成的功能有:
1. 说明系统有片内静态RAM(ISRAM,256KB)和片外动态RAM(SDRAM,32MB)组成,其起始地址和长度分别为...
2. 构建一个C工程需要多个段,SECTIONS中说明如何分配这些段。都放在ISRAM里当然快,但是工程大了肯定放不下,如何权衡自己考虑了。
3. 指明系统的堆和栈的大小



-heap  0x800000
-stack 0x8000

MEMORY {
   ISRAM       : origin = 0x0,         len = 0x40000
   SDRAM       : origin = 0x80000000,  len = 0x2000000
}

SECTIONS
{
        .vectors > ISRAM
        .text    > ISRAM
        .satext  > ISRAM
        .wjpdata > ISRAM
        .sadata  > ISRAM
        .bss     > ISRAM
        .cinit   > ISRAM
        .const   > ISRAM
        .far     > ISRAM
        .stack   > ISRAM
        .cio     > SDRAM
        .switch  > SDRAM
        .sysmem  > SDRAM
        .wjpout  > ISRAM
}

这里各段(包括程序区,静态数据和动态数据区)注释为:

.vectors 中断向量表所在的段;
.text     程序代码所在的段;
.satext   非标准段,放置线性汇编程序代码;
.bss      非初始化变量段
.cinit    程序初始化段,经常放置一些没有用const说明的带初值变量的初始化值。
.const    使用const声明的变量和数组
.far      不可使用DP指针而必须使用全地址访问的变量所在的段,与far关键字和编译选项有关
.stack    系统栈使用的段
.cio      printf等输入输出函数使用的缓冲区所在的段
.switch   程序中switch语句的跳转地址表
.system   系统堆,内存的动态开辟即使用这个段

转载于:https://my.oschina.net/alphajay/blog/95053

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值