rt-thread在IAR环境编译时,.icf文件编写注意事项
[复制链接]
最近折腾RT-Thread系统,因我的MCU为LPC1778,并且个人倾向使用IAR环境,于是查看源码有LPC1768的IAR工程.拷贝1768下面的IAR工程文件,然后用IAR打开做适当的修改.然后编译通过.项目中加了LWIP,下载测试,程序跑飞!
经过单步跟踪,发现初始化lwip到memp_init()时程序跑飞,跑飞问题竟然是RT创建线程时申请的内存在lwip静态分配的内存池中,导致memp_init初始化RAM时将RT创建的线程给冲了,诡异!!查看了多个RT的IAR工程,其中的rt_system_heap_init写法都是如下:
那也就是说代码执行蓝色部分,再将IAR的map文件开启,查看map文件,内存使用顺序是:.data CSTACK HEAP .bss,原来如此??那也就是IAR的.icf文件的问题,查看.icf文件(从LPC1768下拷贝,并做修改),没啥问题:是按:readwrite, block CSTACK, block HEAP的顺序分配的,也就是说RAM的最后是HEAP区,map文件显示怎么有问题呢?实际单步跟踪也是有问题,RT的HEAP就在.icf文件的HEAP之后,后来搜网络,看到有人提问怎么将HEAP放置于.bss之后,于是找到了以下写法,也就是分开来写,经过试验分3行写可行,是按书写的先后顺序分配.将后两行合并也行,并且后面两个的内容前后换位,map文件中的顺序也会跟着换位,但就是3个一起写不行.我使用的IAR版本是7.60.2,不知是我IAR版本的问题还是.icf文件写法有误,反正导致的结果就是有问题.特此记录,那天你也不幸来到这,但愿能提供点参考.
|