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





