2012-12-22 22:01:52
from http://blog./uid-9112803-id-3447923.html
(solve "the stack pointer for stack is outside the stack range")
摘要: 本文给出IAR设置堆栈合理大小的详细方法,并分享一些好博文(icf及map讲解)。 最近在MSP430-169LCD(MSP430F169,RAM为2KB)调试一些ucos演示例子,IAR for MSP430默认的堆栈大小是80字节,编译可以通过,运行结果不确定性,调试过程会提示"the stack pointer for stack is outside the stack range",堆栈溢出。那么,到底设置多大的堆栈够用且不浪费呢。 一、合理设置堆栈大小 首先,查看程序共需要多大的堆栈,生成map文件,方法如下: 图1 生成map文件 生成的map文件在项目目录下的/Debug/List,打开map文件在CALL GRAPH找到找到栈的最大使用量(我的理解是main主函数,用栈最多,所以直接拉到文件末尾,靠近SEGMENTS IN ADDRESS ORDER的地方),如下图所示: 图2 最大栈使用 由上图可知,最大栈使用量是00000076(注意这里是16进制),即118字节。 接着,设置堆栈大小,方法如下,可以设置比最大栈稍微大一些:-) 图3 设置栈大小 二、一点小心得 通过上述方法,设置堆栈后,再编译有可能会报如下连接错误(受限的内存远不够使用): 图4 内存不够用链接错误
此时,唯一的办法就是重新设计程序了。在单片机上跑uC/OS,可以通过以下方法来减少内存使用: (1)如果是跑uC/OS,可以在os_cfg.h文件配置系统,如将最大任务数(OS_MAX_TASKS)设小一些,关掉一些扩展功能(以EN结尾的变量) (2)将一些局部变量数组设成全局变量(我就遇到这个问题,我想在MSP430-169LCD完成类似printf功能,难免需要一些字符数组) 三、我的疑问 在实际调试过程中,尽管我把堆栈设得比查看map文件堆栈要大得多(map文件是0x76,即118,我设成250),调试的时候,依然有这个问题,如下:
很费解,求指点Jelline@126.com
四、一些好资料 [1] 博文《IAR常见段名含义》 [2] 博文《深入剖析之通过IAR MAP文件查看目标文件内存分配》 [3] 博文《写在"五一"之解析IAR的ILINK链接器icf配置文件》 [4] 博文《IAR堆栈分配原则》 |
|