一、CMD文件
CMD文件,全名连接命令文件(linkercommand files),以后缀.cmd结尾。它是用来分配rom和ram空间用的,告诉链接程序怎样计算地址和分配空间,所以不同的芯片就有不同大小的rom和ram,放用户程序的地方也不尽相同。所以要根据芯片进行修改。分两部分:MEMORY和SECTIONS.
(1):存储器(MEMORY)伪指令,用来定义目标系统的存储器空间。MEMORY可以定义存储器的区域,并指定起始地址和长度。
(2):段(SECTOINS)伪指令,告诉链接器如何将输入段结合成输出段并告诉链接器将输出段放在存储器的何处。
C28x的编译器把存储空间划分为两个部分进行管理,包括:
1. 程序存储空间:包含可执行的代码,初始化的记录和switch-case使用的表。
2. 数据存储空间:包含外部变量,静态变量以及系统的栈;一般情况下,各个寄存器对应的存储空间也归类在数据空间里。
为了方便管理,不同种类的代码、变量等往往又被分别分配到不同的段(section)之中,然后对存储空间的划分就变成了对段的地址分配问题了。例如,在下面的代码中,就规定了.text这个段会存放在RAM中Page0下面的RAML1中,RAML1的起始地址是0x009000,长度是0x001000。
MEMORY
{
/* 省略不在此显示的代码 */
PAGE 0 :
RAML1 : origin = 0x009000, length = 0x001000
RAML2 : origin = 0x00A000, length = 0x001000
/* 省略不在此显示的代码 */
}
SECTIONS
{
/* 省略不在此显示的代码 */
.text : > RAML1, PAGE = 0
/* 省略不在此显示的代码 */
}
一般情况下,我们的代码不会大到无法存储,但是也有可能因为代码特别多导致无法存储,产生.text的实际大小是size xxx,但是RAML1的size只有yyy这样的链接错误,以至于无法生成输出文件。此时我们可以把上面对应的RAML1的长度,即length增大,使得.text段所分配的地址空间变多。但是RAML1地址空间扩大之后,挤占了RAML2的空间,导致地址重叠,此时RAML2的起始位置要后移,其长度也要相应地缩减,才能不产生地址覆盖错误;修改之后可以为:
RAML1 : origin = 0x009000, length = 0x001500
RAML2 : origin = 0x00A500, length = 0x000500
还有一个解决方法则是把.text给分配到其它更长的地址空间里去;如果没有现成的地址范围比较长的段,也可以合并现有的段,修改方法比如把RAML2删除,把它的地址全部合并到RAML1中去,而.text还是分配在RAML1,就没有问题了。删除RAML2的时候要注意,它在没有被任何段使用的情况下才能操作,否则编译、链接的时候又提示其它的段找不到对应的存储单元了。
在DSP28335工程文件里&