ARM匯編指令MCR/MRC學習
指令的語法格式:
本文引用地址:http://www.104case.com/article/201611/319290.htmMCR{} p15, 0, , , {,}
MCR2 p15, 0, , , {,}
其中,為指令執行的條件碼。當忽略時指令為無條件執行。MCR2中,為Ob1111,指令為無條件執行指令。
為協處理器將執行的操作的操作碼。對于CP15協處理器來說,永遠為0b000,當不為0b000時,該指令操作結果不可預知。
作為元寄存器的ARM寄存器,其值被傳送到得協處理器寄存器中。
不能為PC,當其為PC時,指令操作結果不可預知。
作為目標寄存器的協處理器寄存器,其編號可能為C0,C1....C15。附加的目標寄存器或者原操作數寄存器,用于區分同一個編號的不同物理寄存器。當指令中不需要提供附加信息時,將C0指定為,否則指令操作結果不可預知。提供附加信息,用于區別同一個編號的不同物理寄存器。當指令中指定附加信息時,省略或者將其指定為0,否則指令操作結果不可預知。
MRC指令將協處理器的寄存器中數值傳送到ARM處理器的寄存器中。如果協處理器不能成功地執行該操作,將產生未定義的指令異常中斷。
指令的語法格式:
MRC{} p15, 0, , , {,}
MRC2 p15, 0, , , {,}
評論