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設(shè)置堆棧合理大小的詳細(xì)方法,并分享一些好博文(icf及map講解)。 最近在MSP430-169LCD(MSP430F169,RAM為2KB)調(diào)試一些ucos演示例子,IAR for MSP430默認(rèn)的堆棧大小是80字節(jié),編譯可以通過,運(yùn)行結(jié)果不確定性,調(diào)試過程會(huì)提示"the stack pointer for stack is outside the stack range",堆棧溢出。那么,到底設(shè)置多大的堆棧夠用且不浪費(fèi)呢。 一、合理設(shè)置堆棧大小 首先,查看程序共需要多大的堆棧,生成map文件,方法如下: 圖1 生成map文件 生成的map文件在項(xiàng)目目錄下的/Debug/List,打開map文件在CALL GRAPH找到找到棧的最大使用量(我的理解是main主函數(shù),用棧最多,所以直接拉到文件末尾,靠近SEGMENTS IN ADDRESS ORDER的地方),如下圖所示: 圖2 最大棧使用 由上圖可知,最大棧使用量是00000076(注意這里是16進(jìn)制),即118字節(jié)。 接著,設(shè)置堆棧大小,方法如下,可以設(shè)置比最大棧稍微大一些:-) 圖3 設(shè)置棧大小 二、一點(diǎn)小心得 通過上述方法,設(shè)置堆棧后,再編譯有可能會(huì)報(bào)如下連接錯(cuò)誤(受限的內(nèi)存遠(yuǎn)不夠使用): 圖4 內(nèi)存不夠用鏈接錯(cuò)誤
此時(shí),唯一的辦法就是重新設(shè)計(jì)程序了。在單片機(jī)上跑uC/OS,可以通過以下方法來(lái)減少內(nèi)存使用: (1)如果是跑uC/OS,可以在os_cfg.h文件配置系統(tǒng),如將最大任務(wù)數(shù)(OS_MAX_TASKS)設(shè)小一些,關(guān)掉一些擴(kuò)展功能(以EN結(jié)尾的變量) (2)將一些局部變量數(shù)組設(shè)成全局變量(我就遇到這個(gè)問題,我想在MSP430-169LCD完成類似printf功能,難免需要一些字符數(shù)組) 三、我的疑問 在實(shí)際調(diào)試過程中,盡管我把堆棧設(shè)得比查看map文件堆棧要大得多(map文件是0x76,即118,我設(shè)成250),調(diào)試的時(shí)候,依然有這個(gè)問題,如下:
很費(fèi)解,求指點(diǎn)Jelline@126.com
四、一些好資料 [1] 博文《IAR常見段名含義》 [2] 博文《深入剖析之通過IAR MAP文件查看目標(biāo)文件內(nèi)存分配》 [3] 博文《寫在"五一"之解析IAR的ILINK鏈接器icf配置文件》 [4] 博文《IAR堆棧分配原則》 |
|