corte-m3中的pc值的問題
在Cortex-M3中指令是3級(jí)流水線,出于對(duì)Thumb代碼的兼容的考慮,讀取pc時(shí),會(huì)返回當(dāng)前指令地址+4的值。但是在進(jìn)入中斷服務(wù)程序后,壓入棧的地址是pc,而返回時(shí)也是用作pc,那么pc的值如果是當(dāng)前指令加4的話就有可能返回后就漏掉一條指令。
但是事實(shí)上中斷服務(wù)程序可以完美的返回。那么這中間就一定存在著某些詭異的地方。
下面來看一段測(cè)試代碼:
我們可看出,pc總是指向下一條指令,那么書中的“出于對(duì)Thumb代碼的兼容的考慮,讀取pc時(shí),會(huì)返回當(dāng)前指令地址+4的值”的關(guān)鍵在于“讀取”2字,如果我們使用指令(如mov)讀了PC,那么返回給我們地址就是當(dāng)前地址+4,如果是單片機(jī)自動(dòng)壓棧那么就不屬于使用指令讀取的范疇,也就是說壓入棧中的PC值就真正的值。