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