以前一直使用CCS3.3,因为软件太容易导致蓝屏、死机,用虚拟机又严重影响仿真器速度。所以改用了CCS5.2。
CCS5使用的ECLIPS架构,跟以前的CCS3.3几乎完全接不上茬……DSP/BIOS也升了级,好多函数都改了名字。甚至以前的gel文件也被包裹成别的样子……
好不容易把程序改到可以仿真运行了,等下载到SPIFLASH启动的时候又出现了问题,程序没能正常启动。
后来测试波形发现程序已经完成了加载,但无法正确运行。经过几翻周折,终于找到了原因。发现编译后的.map文件有两个.cinit段和两个.pinit段。而且其中一个显示长度为0,并且处于UNINITIALIZED状态: SECTION ALLOCATION MAP
output attributes/
section page origin length input sections
-------- ---- ---------- ---------- ----------------
.pinit 0 e0400000 00000000 UNINITIALIZED
.cinit 0 e0300000 00000000 UNINITIALIZED
.pinit 0 00a10000 00000000 UNINITIALIZED ……
.cinit 0 e15840b0 0000148c
经过查看“TI SYS/BIOS v6.33 Real-timeOperating System User's Guide”文档,发现内存配置工作已经由新的.cfg文件自动生成为linker.cmd文件,用户自定义另外的.cmd文件不能与其冲突。文档建议不要使用用户自定义的cmd文件,如果需要自己配置空间的话,可以修改.cfg或linker.cmd文件。
而之前我延用以前CCS3.3的习惯,使用了自己定义的.cmd文件,所以出现了两个.cinit段和两个.pinit段。于是导致自加载时变量不能得到初始化,程序不能正常运行。
……
.vecs> IRAM_Code
.text > IRAM_Code /* Common Code */
.bss > IRAM_Data /* 变量 */
.cinit > DDR2 _Code
.switch> IRAM_Data
.far > IRAM_Data /* 数组 */
.const > IRAM_Data/*DDR2_L2Shadow IRAM3*/
.bootload> IRAM_Code
.printf> IRAM_Data
.pinit > IRAM_Data /* Common Code */
.cio > IRAM_Data
.data > IRAM_Data
.system> IRAM_Data
……
将自定义的.cmd文件内的相关段删掉,编译后.map文件中只有一组.cinit和.pinit,烧写到SPI FLASH后能程序正常加载运行。
……
.vecs> IRAM_Code
.text > IRAM_Code /* Common Code */
.bss > IRAM_Data /* 变量 */
.switch> IRAM_Data
.far > IRAM_Data /* 数组 */
.const > IRAM_Data/*DDR2_L2Shadow IRAM3*/
.bootload> IRAM_Code
.printf> IRAM_Data
.cio > IRAM_Data
.data > IRAM_Data
.system> IRAM_Data
……
|