關(guān)于A(yíng)RM系統的堆棧
從棧頂的定義來(lái)看,棧頂的位置是可變的??諚r(shí),棧頂和棧底重合;滿(mǎn)棧時(shí),棧頂離棧底最遠。ARM為堆棧提供了硬件支持,它使用一個(gè)專(zhuān)門(mén)的寄存器(堆棧指針)指向堆棧的棧頂。而且7種模式都有各自獨立的堆棧指針,也就是有各自獨立的堆??臻g。但這里的堆棧和uC/OS操作系統的任務(wù)堆棧又有區別,uC/OS的每個(gè)任務(wù)都有自己的堆棧,要是把uC/OS移植到ARM上,可以借助ARM的堆棧指針來(lái)實(shí)現。存儲器堆??煞譃閮煞N:
向上生長(cháng):向高地址方向生長(cháng),稱(chēng)為遞增堆棧
向下生長(cháng):向低地址方向生長(cháng),稱(chēng)為遞減堆棧
堆棧指針指向最后壓入的堆棧的有效數據項,稱(chēng)為滿(mǎn)堆棧;堆棧指針指向下一個(gè)要放入的空位置,稱(chēng)為空堆棧。這樣就有4中類(lèi)型的堆棧表示遞增和遞減的滿(mǎn)堆棧和空堆棧的各種組合。
滿(mǎn)遞增:堆棧通過(guò)增大存儲器的地址向上增長(cháng),堆棧指針指向內含有效數據項的最高地址。指令如LDMFA,STMFA等。
空遞增:堆棧通過(guò)增大存儲器的地址向上增長(cháng),堆棧指針指向堆棧上的第一個(gè)空位置。指令如LDMEA,STMEA等。
滿(mǎn)遞減:堆棧通過(guò)減小存儲器的地址向下增長(cháng),堆棧指針指向內含有效數據項的最低地址。指令如LDMFD,STMFD等。
空遞減:堆棧通過(guò)減小存儲器的地址向下增長(cháng),堆棧指針指向堆棧下的第一個(gè)空位置。指令如LDMED,STMED等。
有一點(diǎn)需要注意的是,雖然ARM處理器核對于兩種生長(cháng)方式的堆棧均支持,但ADS的C語(yǔ)言編譯器僅支持一種方式,即從上往下長(cháng),并且必須是滿(mǎn)遞減堆棧。所以STMFD等指令用的最多。
評論