DSP的CMD文件详解(整理版).docx

上传人:p** 文档编号:865165 上传时间:2024-03-24 格式:DOCX 页数:18 大小:42.45KB
下载 相关 举报
DSP的CMD文件详解(整理版).docx_第1页
第1页 / 共18页
DSP的CMD文件详解(整理版).docx_第2页
第2页 / 共18页
DSP的CMD文件详解(整理版).docx_第3页
第3页 / 共18页
DSP的CMD文件详解(整理版).docx_第4页
第4页 / 共18页
DSP的CMD文件详解(整理版).docx_第5页
第5页 / 共18页
DSP的CMD文件详解(整理版).docx_第6页
第6页 / 共18页
DSP的CMD文件详解(整理版).docx_第7页
第7页 / 共18页
DSP的CMD文件详解(整理版).docx_第8页
第8页 / 共18页
DSP的CMD文件详解(整理版).docx_第9页
第9页 / 共18页
DSP的CMD文件详解(整理版).docx_第10页
第10页 / 共18页
亲,该文档总共18页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《DSP的CMD文件详解(整理版).docx》由会员分享,可在线阅读,更多相关《DSP的CMD文件详解(整理版).docx(18页珍藏版)》请在第壹文秘上搜索。

1、DSP的CMD文件详解CMD是用来分配ROM和RAM空间用的,告诉链接程序若何计算地址和分配空间。所以不同的芯片就有不同大小的ROM和RAM,存放用户程序的地方也不尽一样。所以要根据芯片进展修改,分为MEMORY和SECTIONS两个局部。MEMORY(PAGE0PAGE1)SECTIONS(.vectors.reset)MEMORY是用来指定芯片的ROM和RAM的大小和划分出几个区间。PAGEO对应RoM,PAGEl对应RAM。PAGE里包含的区间名字与其后面的参数反映了该区间的起始地址和长度。SECTIONS:(在程序里添加下面的段名,如.vectors。用来指定该段名以下,另一个段名以上

2、的程序(属于PAGEO)或数据(属于PAGEl)放到“符号后的空间名字所在的地方。)SECTIONS.vectors:VECSPAGE0.reset:VECSPAGE0eg:MEMORY(PAGE0:VECS:origin=00000h,length=00040h1.OW:origin=00040h,length=03FC0hSARAM:origin=04000h,length=00800hBO:origin=OFFOOh,length=OOlOOhPAGE1:BO:origin=00200h,length=001OOhB1:origin=00300h,length=001OOhB2:orig

3、in=00060h,length=00020hSARAM:origin=08000h,length=00800hSECTIONS.text:LOWPAGE0.cinit:LOWPAGE0.switch:LOWPAGE0.const:SARAMPAGE1.data:SARAMPAGE1.bss:SARAMPAGE1.stack:SARAMPAGE1.sysmem:SARAMPAGE1)由三局部组成:输入/输出定义:这一局部,可以通过ccs的“BuildOption菜单设置:.obj(链接的目标文件)、.lib(链接的库文件)、.map(生成的穿插索引文件)、.out(生成的可执行代码)。MEMO

4、RY命令:描述系统实际的硬件资源SECTloN命令:描述“段若何定位例子:d文件-C-Ohello.out-mhello.map-stack100-1rts2xx.libMEMORYPAGE0:VECT:origin=0x8000,length0x040PAGE0:PROG:origin=0x8040,length0x6000PAGE1:DATA:origin=0x8000,length0x400)SECTIONS.vextorsVECTPAGE0.textPROGPAGE0.bssDATAPAGE1.constDATAPAGE1)存储模型:C程序的代码和数据若何定位系统定义:.cinit存放

5、程序中的变量初值和常量.const存放程序中的字符常量、浮点常量和用ConSt声明的常量.switch存放程序中SWitCh语句的跳转地址表.text存放程序代码.bss为程序中的全局和静态变量保存存储空间.far为程序中用far声明的全局和静态变量保存空间.stack为程序系统堆栈保存存储空间,用于保存返回地址、函数间的参数传递、存储局部变量和保存中间结果.sysmem用于程序中的ma11oc、calloc、和realoc函数动态分配存储空间CMD的专业名称叫链接器配置文件,是存放链接器的配置信息的,我们简称为命令文件,其中比较关键的就是MEMORY和SECTloNS两个伪指令的使用,常常令

6、人困惑,系统出现的问题也经常与它们的不当使用有关。CCS是DSP软件对DOS系统继承的开发环境,CCS的命令文件经过DOS命令文件长时间的引申开展,已经变得非常简洁(不知道Tl文档有没有详细CMD配置说明)。我学CMD是从DOS里的东西开场的,所以也从DC)S环境下的CMD说起:1、命令文件的组成命令文件的开头局部是要链接的各个子目标文件的名字,这样链接器就可以根据子目标文件名,将相应的目标文件链接成一个文件;接下来就是链接器的操作指令,这些指令用来配置链接器,接下来就是MEMORY和SECTIONS两个伪指令的相关语句,必须大写。MEMORY,用来配置目标存储器,SECTIONS用来指定段的

7、存放位置。结合下面的典型DOS环境的命令文件linkd来做一下说明:file.obj子目标文件名1file2.obj子目标文件名2file3.obj子目标文件名3-0PrOg.out/连接器操作指令,用来指定输出文件-mprog.m用来指定MAP文件MEMORY略SECTIONS略Otherlinkd本命令文件Iinkd要调用的OtherIinkd等其他命令文件,那么文件的名字要放到本命令文件最后一行,因为放开头的话,链接器是不会从被调用的其他命令文件中返回到本命令文件。2、MEMORY伪指令MEMORY用来建设目标存储器的模型,SECTIONS指令就可以根据这个模型来安排各个段的位置,MEM

8、ORY指令可以定义目标系统的各种类型的存储器及容量。MEMORY的语法如下:MEMORY(PAGE0:namel(attr):origin=constant,length=constantnameln(attr):origin=constant,length=constantPAGE1:name2(attr):origin=ConstantJength=constantname2n(attr):origin=constant,length=constantPAGEn:namen(attr):origin=constant,length=constantnamenn(attr):origin=c

9、onstant,length=constantPAGE关键词对独立的存储空间进展标记,页号n的最大值为255,实际应用中一般分为两页,PAGEO程序存储器和PAGEl数据存储器。name存储区间的名字,不超过8个字符,不同的PAGE上可以出现一样的名字(最好不用,免的搞混),一个PAGE内不许有一样的nameoattr的属性标识,为R表示可读;W可写X表示区间可以装入可执行代码;I表示存储器可以进展初始话,什么属性代码也不写,表示存储区间具有上述的四种属性,基本上我们都选择这种写法。Origin:略。Iength:略。下面是经常用的2407的简单写法大家参考,程序从0x060开场,要避开加密位

10、,不从OXO044开场更可靠一点,此例中的同名的页可以只写第一个,其后省略,但写上至少安全一点:MEMORY(PAGE0:VECS:origin=0x0000,length0x40PAGE0:PROG:origin=0x0060,length0x6000PAGE1:B0:origin=0x200,length0x100PAGE1:Bl:origin=0x300,length0x100PAGE1:DATA:origin=0x0860,length0x07803、SECrnoNS伪指令SECTIONS指令的语法如下:SECTIONS(.text:所有.text输入段名load=加载地址run二运行

11、地址.data:所有.data输入段名load=加载地址run二运行地址.bss:所有.bss输入段名load=加载地址run=运行地址.other:所有.other输入段名load=加载地址run二运行地址)SECTIONS必须用大写字母,其后的大括号里是输出段的说明性语句,每一个输出段的说明都是从段名开场,段名之后是若何对输入段进展组织和给段分配存储器的参数说明:以MXt段的属性语句为例,“所有MXt输入段名这段内容用来说明连接器输出段的.text段由哪些子目标文件的段组成,举例如下SECTIONS(.text:filel.obj(.text)file2(.text)file3(.text

12、,cinit)略)指明输出段.text要链接filel.obj的.text和file2的.text还有file3的.text和.cinit。在CCS的SECTIONS里通常只写一个中间没有内容的“就表示所有的目标文件的相应段。接下来说明“load=加载地址run=运行地址链接器为每个输出段都在目标存储器里分配两个地址:一个是加载地址,一个是运行地址。通常情况下两个地址是一样的,可以认为输出段只有一个地址,这时就可以不加“run=运行地址这条语句了;但有时需要将两个地址分开,比方将程序加载到FLASH,然后放到RAM中高速运行,这就用到了运行地址和加载地址的分别配置了,如下例所示:.const:

13、略load=PROGrun=0x0800,常量加载在程序存储区,配置为在RAM里调用。load=加载地址的几种写法需要说明一下,首先“load关键字可以省略,“=可以写成“,”加载地址可以是:地址值、存储区间的名字、PAGE关键词等,所以大家见到text0x0080这样的语句可千万不要奇怪。run=运行地址中的“=可以用“,其它的简化写法就没有了。大家不要乱用。4、CCS中的案例在CCS中的命令文件好似简化了不少,少了很多东西,语句也精简了好多,首先不用指定输入链接器的目标文件,CCS会自动默认处理,其次链接器的配置命令也和DOS的环境不同,需要了解的请找Tl文档吧!下面是刘和平书中的例子,大

14、家来看看是不是可以很准确的理解了呢!-stack40MEMORYPAGE0:VECS:origin=Oh,length=40hPVECS:origin=40h,length=70hPROG:origin=ObOh,length=7F50hPAGE1:MMRS:origin=Oh,length=05FhB2:origin=0060h,length=020hBO:origin=0200h,length=100hBl:origin=0300h,length=100hSARAM:origin=0800h,length=0800hEXT:origin=8000h,length=8000h)SECTION

15、S(.reset:VECSPAGEO.vectors:VECSPAGEO.pvecs:PVECSPAGE0.text:PROGPAGEO.cinit:PROGPAGEO.bss:SARAMPAGE1.const:SARAMPAGE1.stack:B1PAGE1第二章CMD文件的编写1、COFF格式1通用目标文件格式(CommonObjectFileFormat)是一种流行的二进制可执行文件格式,二进制可执行文件包括库文件UibL目标文件(Obj)最终可执行文件(OUt)o,现今PC机上的Windows95和NT4.0以后的操作系统的二进制文件格式(PE)就是在COFF格式根基上的进一步扩大。2COFF格式:详细的CoFF文件格式包括段头,可执行代码和初始化数据,可重定位信息,行号入口,符号表,字符串表等,这些

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 大学课件

copyright@ 2008-2023 1wenmi网站版权所有

经营许可证编号:宁ICP备2022001189号-1

本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。第壹文秘仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知第壹文秘网,我们立即给予删除!