第三節(jié)arm指令集2_第1頁
第三節(jié)arm指令集2_第2頁
第三節(jié)arm指令集2_第3頁
第三節(jié)arm指令集2_第4頁
第三節(jié)arm指令集2_第5頁
已閱讀5頁,還剩47頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

ARM指令小節(jié)目錄1.指令格式2.條件碼3.存儲器訪問指令4.數(shù)據(jù)處理指令5.乘法指令6.ARM分支指令7.協(xié)處理器指令8.雜項(xiàng)指令9.偽指令4.2指令集介紹ARM指令集——乘法指令

ARM7TDMI具有三種乘法指令,分別為:32×32位乘法指令;32×32位乘加指令;32×32位結(jié)果為64位的乘/乘加指令。ARM指令——乘法指令乘法指令編碼指令執(zhí)行的條件碼Opcode乘法指令操作碼S設(shè)置條件碼,與指令中的S位對應(yīng)Rm為被乘數(shù)寄存器Rd/RdLo為MLA指令相加的寄存器或64位乘法指令的目標(biāo)寄存器(低32位)Rn/RdHi為目標(biāo)寄存器或64位乘法指令的目標(biāo)寄存器(高32位)Rs為乘數(shù)寄存器64位有符號乘加指令SMLAL11164位有符號乘法指令SMULL11064位無符號乘加指令UMLAL10164位無符號乘法指令UMULL10032位乘加指令MLA00132位乘法指令MUL000說明指令助記符操作碼opcode操作碼功能表助記符說明操作條件碼位置MULRd,Rm,Rs32位乘法指令Rd←Rm*Rs(Rd≠Rm)MUL{cond}{S}MLARd,Rm,Rs,Rn32位乘加指令Rd←Rm*Rs+Rn(Rd≠Rm)MLA{cond}{S}UMULLRdLo,RdHi,Rm,Rs64位無符號乘法指令(RdLo,RdHi)←Rm*Rs

UMULL{cond}{S}UMLALRdLo,RdHi,Rm,Rs64位無符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)UMLAL{cond}{S}SMULLRdLo,RdHi,Rm,Rs64位有符號乘法指令(RdLo,RdHi)←Rm*RsSMULL{cond}{S}SMLALRdLo,RdHi,Rm,Rs64位有符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)SMLAL{cond}{S}ARM指令——乘法指令助記符說明操作條件碼位置MULRd,Rm,Rs32位乘法指令Rd←Rm*Rs(Rd≠Rm)MUL{cond}{S}MLARd,Rm,Rs,Rn32位乘加指令Rd←Rm*Rs+Rn(Rd≠Rm)MLA{cond}{S}UMULLRdLo,RdHi,Rm,Rs64位無符號乘法指令(RdLo,RdHi)←Rm*Rs

UMULL{cond}{S}UMLALRdLo,RdHi,Rm,Rs64位無符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)UMLAL{cond}{S}SMULLRdLo,RdHi,Rm,Rs64位有符號乘法指令(RdLo,RdHi)←Rm*RsSMULL{cond}{S}SMLALRdLo,RdHi,Rm,Rs64位有符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)SMLAL{cond}{S}ARM指令——乘法指令

32位乘法指令——MUL指令將Rm和Rs中的值相乘,結(jié)果的低32位保存到Rd中。指令格式如下:MUL{cond}{S}Rd,Rm,Rs

應(yīng)用示例:

MULR1,R2,R3

;R1=R2×R3

MULSR0,R3,R7;R0=R3×R7,同時影響CPSR中的N位和Z位助記符說明操作條件碼位置MULRd,Rm,Rs32位乘法指令Rd←Rm*Rs(Rd≠Rm)MUL{cond}{S}MLARd,Rm,Rs,Rn32位乘加指令Rd←Rm*Rs+Rn(Rd≠Rm)MLA{cond}{S}UMULLRdLo,RdHi,Rm,Rs64位無符號乘法指令(RdLo,RdHi)←Rm*Rs

UMULL{cond}{S}UMLALRdLo,RdHi,Rm,Rs64位無符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)UMLAL{cond}{S}SMULLRdLo,RdHi,Rm,Rs64位有符號乘法指令(RdLo,RdHi)←Rm*RsSMULL{cond}{S}SMLALRdLo,RdHi,Rm,Rs64位有符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)SMLAL{cond}{S}ARM指令——乘法指令

32位乘加指令——MLA指令將Rm和Rs中的值相乘,再將乘積加上第3個操作數(shù),結(jié)果的低32位保存到Rd中。指令格式如下:MLA{cond}{S}Rd,Rm,Rs,Rn

應(yīng)用示例:

MLAR1,R2,R3,R0

;R1=R2×R3+R0助記符說明操作條件碼位置MULRd,Rm,Rs32位乘法指令Rd←Rm*Rs(Rd≠Rm)MUL{cond}{S}MLARd,Rm,Rs,Rn32位乘加指令Rd←Rm*Rs+Rn(Rd≠Rm)MLA{cond}{S}UMULLRdLo,RdHi,Rm,Rs64位無符號乘法指令(RdLo,RdHi)←Rm*Rs

UMULL{cond}{S}UMLALRdLo,RdHi,Rm,Rs64位無符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)UMLAL{cond}{S}SMULLRdLo,RdHi,Rm,Rs64位有符號乘法指令(RdLo,RdHi)←Rm*RsSMULL{cond}{S}SMLALRdLo,RdHi,Rm,Rs64位有符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)SMLAL{cond}{S}ARM指令——乘法指令

64位無符號乘法指令——UMULL指令將Rm和Rs中的值作無符號數(shù)相乘,結(jié)果的低32位保存到RdLo中,而高32位保存到RdHi中。指令格式如下:UMULL{cond}{S}RdLo,RdHi,Rm,Rs

應(yīng)用示例:

UMULLR0,R1,R5,R8 ;(R1、R0)=R5×R8助記符說明操作條件碼位置MULRd,Rm,Rs32位乘法指令Rd←Rm*Rs(Rd≠Rm)MUL{cond}{S}MLARd,Rm,Rs,Rn32位乘加指令Rd←Rm*Rs+Rn(Rd≠Rm)MLA{cond}{S}UMULLRdLo,RdHi,Rm,Rs64位無符號乘法指令(RdLo,RdHi)←Rm*Rs

UMULL{cond}{S}UMLALRdLo,RdHi,Rm,Rs64位無符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)UMLAL{cond}{S}SMULLRdLo,RdHi,Rm,Rs64位有符號乘法指令(RdLo,RdHi)←Rm*RsSMULL{cond}{S}SMLALRdLo,RdHi,Rm,Rs64位有符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)SMLAL{cond}{S}ARM指令——乘法指令

64位無符號乘加指令——UMLAL指令將Rm和Rs中的值作無符號數(shù)相乘,64位乘積與RdHi、RdLo相加,結(jié)果的低32位保存到RdLo中,而高32位保存到RdHi中。指令格式如下:UMLAL{cond}{S}RdLo,RdHi,Rm,Rs

應(yīng)用示例:

UMLALR0,R1,R5,R8 ;(R1、R0)=R5×R8+(R1、R0)助記符說明操作條件碼位置MULRd,Rm,Rs32位乘法指令Rd←Rm*Rs(Rd≠Rm)MUL{cond}{S}MLARd,Rm,Rs,Rn32位乘加指令Rd←Rm*Rs+Rn(Rd≠Rm)MLA{cond}{S}UMULLRdLo,RdHi,Rm,Rs64位無符號乘法指令(RdLo,RdHi)←Rm*Rs

UMULL{cond}{S}UMLALRdLo,RdHi,Rm,Rs64位無符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)UMLAL{cond}{S}SMULLRdLo,RdHi,Rm,Rs64位有符號乘法指令(RdLo,RdHi)←Rm*RsSMULL{cond}{S}SMLALRdLo,RdHi,Rm,Rs64位有符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)SMLAL{cond}{S}ARM指令——乘法指令

64位有符號乘法指令——SMULL指令將Rm和Rs中的值作有符號數(shù)相乘,結(jié)果的低32位保存到RdLo中,而高32位保存到RdHi中。指令格式如下:SMULL{cond}{S}RdLo,RdHi,Rm,Rs

應(yīng)用示例:

SMULL R2,R3,R7,R6

;(R3、R2)=R7×R6

助記符說明操作條件碼位置MULRd,Rm,Rs32位乘法指令Rd←Rm*Rs(Rd≠Rm)MUL{cond}{S}MLARd,Rm,Rs,Rn32位乘加指令Rd←Rm*Rs+Rn(Rd≠Rm)MLA{cond}{S}UMULLRdLo,RdHi,Rm,Rs64位無符號乘法指令(RdLo,RdHi)←Rm*Rs

UMULL{cond}{S}UMLALRdLo,RdHi,Rm,Rs64位無符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)UMLAL{cond}{S}SMULLRdLo,RdHi,Rm,Rs64位有符號乘法指令(RdLo,RdHi)←Rm*RsSMULL{cond}{S}SMLALRdLo,RdHi,Rm,Rs64位有符號乘加指令(RdLo,RdHi)←Rm*Rs+(RdLo,RdHi)SMLAL{cond}{S}ARM指令——乘法指令

64位有符號乘加指令——SMLAL指令將Rm和Rs中的值作有符號數(shù)相乘,64位乘積與RdHi、RdLo相加,結(jié)果的低32位保存到RdLo中,而高32位保存到RdHi中。指令格式如下:SMLAL{cond}{S}RdLo,RdHi,Rm,Rs

應(yīng)用示例:

SMLAL R2,R3,R7,R6 ;(R3、R2)=R7×R6+(R3、R2)ARM指令小節(jié)目錄1.指令格式2.條件碼3.存儲器訪問指令4.數(shù)據(jù)處理指令5.乘法指令6.ARM分支指令7.協(xié)處理器指令8.雜項(xiàng)指令9.偽指令指令集介紹ARM指令集——分支指令

在ARM中有兩種方式可以實(shí)現(xiàn)程序的跳轉(zhuǎn),一種是使用分支指令直接跳轉(zhuǎn),另一種則是直接向PC寄存器賦值實(shí)現(xiàn)跳轉(zhuǎn)。分支指令有以下三種:分支指令B;帶鏈接的分支指令BL;帶狀態(tài)切換的分支指令BX。ARM分支指令——指令編碼分支指令B/BL指令編碼格式指令執(zhí)行的條件碼L區(qū)別B指令(L為0)和BL指令(L為1)24位有符號立即數(shù)(偏移量)分支指令BX指令編碼格式指令執(zhí)行的條件碼Rm目標(biāo)地址寄存器,該寄存器裝載跳轉(zhuǎn)地址助記符說明操作條件碼位置Blabel分支指令PC←labelB{cond}BLlabel帶鏈接的分支指令LR←PC-4,PC←labelBL{cond}BXRm帶狀態(tài)切換的分支指令PC←label,切換處理器狀態(tài)BX{cond}ARM指令——分支指令助記符說明操作條件碼位置Blabel分支指令PC←labelB{cond}BLlabel帶鏈接的分支指令LR←PC-4,PC←labelBL{cond}BXRm帶狀態(tài)切換的分支指令PC←label,切換處理器狀態(tài)BX{cond}ARM指令——分支指令

分支指令——B指令,該指令跳轉(zhuǎn)范圍限制在當(dāng)前指令的±32M字節(jié)地址內(nèi)(ARM指令為字對齊,最低2位地址固定為0)。指令格式如下:B{cond}Label

應(yīng)用示例:

B WAITA ;跳轉(zhuǎn)到WAITA標(biāo)號處

B 0x1234 ;跳轉(zhuǎn)到絕對地址0x1234處BLLabelxxxxxxLabelxxxMOVPC,LRAddr1Addr2xxxxxxLRPC助記符說明操作條件碼位置Blabel分支指令PC←labelB{cond}BLlabel帶鏈接的分支指令LR←PC-4,PC←labelBL{cond}BXRm帶狀態(tài)切換的分支指令PC←label,切換處理器狀態(tài)BX{cond}ARM指令——分支指令帶鏈接的分支指令——BL指令適用于子程序調(diào)用,使用該指令后,下一條指令的地址被拷貝到R14(即LR)連接寄存器中,然后跳轉(zhuǎn)到指定地址運(yùn)行程序。跳轉(zhuǎn)范圍限制在當(dāng)前指令的±32M字節(jié)地址內(nèi)。指令格式如下:BL{cond}LabelAddr1+8LabelAddr2Addr21.當(dāng)程序執(zhí)行到BL跳轉(zhuǎn)指令時,硬件將下一條指令的地址Addr2裝入LR寄存器,并把跳轉(zhuǎn)地址裝入程序計數(shù)器(PC)2.程序跳轉(zhuǎn)到目標(biāo)地址Label繼續(xù)執(zhí)行,當(dāng)子程序執(zhí)行結(jié)束后,將LR寄存器內(nèi)容存入PC,返回調(diào)用函數(shù)繼續(xù)執(zhí)行助記符說明操作條件碼位置Blabel分支指令PC←labelB{cond}BLlabel帶鏈接的分支指令LR←PC-4,PC←labelBL{cond}BXRm帶狀態(tài)切換的分支指令PC←label,切換處理器狀態(tài)BX{cond}ARM指令——分支指令

帶鏈接的分支指令——BL指令適用于子程序調(diào)用,使用該指令后,下一條指令的地址被拷貝到R14(即LR)連接寄存器中,然后跳轉(zhuǎn)到指定地址運(yùn)行程序。跳轉(zhuǎn)范圍限制在當(dāng)前指令的±32M字節(jié)地址內(nèi)。指令格式如下:BL{cond}Label

應(yīng)用示例:

BL DELAY ;調(diào)用子程序DELAY助記符說明操作條件碼位置Blabel分支指令PC←labelB{cond}BLlabel帶鏈接的分支指令LR←PC-4,PC←labelBL{cond}BXRm帶狀態(tài)切換的分支指令PC←label,切換處理器狀態(tài)BX{cond}ARM指令——分支指令

帶狀態(tài)切換的分支指令——BX指令,該指令可以根據(jù)跳轉(zhuǎn)地址(Rm)的最低位來切換處理器狀態(tài)。其跳轉(zhuǎn)范圍限制在當(dāng)前指令的±32M字節(jié)地址內(nèi)(ARM指令為字對齊,最低2位地址固定為0)。指令格式如下:BX{cond}Rm跳轉(zhuǎn)地址Rm[0]跳轉(zhuǎn)后CPSR標(biāo)志T位處理器狀態(tài)00ARM11Thumb助記符說明操作條件碼位置Blabel分支指令PC←labelB{cond}BLlabel帶鏈接的分支指令LR←PC-4,PC←labelBL{cond}BXRm帶狀態(tài)切換的分支指令PC←label,切換處理器狀態(tài)BX{cond}ARM指令——分支指令

帶狀態(tài)切換的分支指令——BX指令,該指令可以根據(jù)跳轉(zhuǎn)地址(Rm)的最低位來切換處理器狀態(tài)。其跳轉(zhuǎn)范圍限制在當(dāng)前指令的±32M字節(jié)地址內(nèi)(ARM指令為字對齊,最低2位地址固定為0)。指令格式如下:BX{cond}Rm

應(yīng)用示例:

ADRLR0,ThumbFun+1;將Thumb程序的入口地址加1存入R0BXR0 ;跳轉(zhuǎn)到R0指定的地址,

;并根據(jù)R0的最低位來切換處理器狀態(tài)ARM指令小節(jié)目錄1.指令格式2.條件碼3.存儲器訪問指令4.數(shù)據(jù)處理指令5.乘法指令6.ARM分支指令7.協(xié)處理器指令8.雜項(xiàng)指令9.偽指令指令集介紹ARM指令集——協(xié)處理器指令

ARM內(nèi)核支持協(xié)處理器操作,協(xié)處理器的控制要通過協(xié)處理器命令實(shí)現(xiàn)。ARM內(nèi)核與協(xié)處理器的關(guān)系A(chǔ)RM內(nèi)核協(xié)處理器A協(xié)處理器B握手信號數(shù)據(jù)地址總線…助記符說明操作條件碼位置CDPcoproc,opcode1,CRd,CRn,CRm{,opcode2}協(xié)處理器數(shù)據(jù)操作指令取決于協(xié)處理器CDP{cond}LDC{L} coproc,CRd,<地址>

協(xié)處理器數(shù)據(jù)讀取指令取決于協(xié)處理器LDC{cond}{L}STC{L}coproc,CRd,<地址>協(xié)處理器數(shù)據(jù)寫入指令取決于協(xié)處理器STC{cond}{L}MCRcoproc,opcode1,Rd,CRn,CRm{,opcode2}ARM寄存器到協(xié)處理器寄存器的數(shù)據(jù)傳送指令取決于協(xié)處理器MCR{cond}MRCcoproc,opcode1,Rd,CRn,CRm{,opcode2}協(xié)處理器寄存器到ARM寄存器到的數(shù)據(jù)傳送指令取決于協(xié)處理器MCR{cond}ARM指令——協(xié)處理器指令A(yù)RM指令小節(jié)目錄1.指令格式2.條件碼3.存儲器訪問指令4.數(shù)據(jù)處理指令5.乘法指令6.ARM分支指令7.協(xié)處理器指令8.雜項(xiàng)指令9.偽指令指令集介紹ARM指令集——雜項(xiàng)指令

ARM指令集中有三條指令作為雜項(xiàng)指令,實(shí)際上這三條指令非常重要。它們?nèi)缦滤荆褐浄f明操作條件碼位置SWIimmed_24軟中斷指令產(chǎn)生軟中斷,處理器進(jìn)入管理模式SWI{cond}MRSRd,psr讀狀態(tài)寄存器指令Rd←psr,psr為CPSR或SPSRMRS{cond}MSRpsr_fields,Rd/#immed_8r寫狀態(tài)寄存器指令psr_fields←Rd/#immed_8r,psr為CPSR或SPSRMSR{cond}ARM雜項(xiàng)指令——狀態(tài)寄存器讀指令在ARM處理器中,只有MRS指令可以對狀態(tài)寄存器CPSR和SPSR進(jìn)行讀操作。通過讀CPSR可以了解當(dāng)前處理器的工作狀態(tài)。讀SPSR寄存器可以了解到進(jìn)入異常前的處理器狀態(tài)。MRS{cond}Rd,psrMRS指令格式指令對應(yīng)編碼指令執(zhí)行的條件碼目標(biāo)寄存器,不能為R15區(qū)別CPSR(為0)和SPSR(為1)寄存器ARM雜項(xiàng)指令——狀態(tài)寄存器讀指令在ARM處理器中,只有MRS指令可以對狀態(tài)寄存器CPSR和SPSR進(jìn)行讀操作。通過讀CPSR可以了解當(dāng)前處理器的工作狀態(tài)。讀SPSR寄存器可以了解到進(jìn)入異常前的處理器狀態(tài)。MRS{cond}Rd,psrMRS指令格式

應(yīng)用示例:

MRSR1,CPSR ;將CPSR狀態(tài)寄存器讀取,保存到R1中

MRSR2,SPSR ;將SPSR狀態(tài)寄存器讀取,保存到R2中ARM雜項(xiàng)指令——狀態(tài)寄存器寫指令在ARM處理器中,只有MSR指令可以對狀態(tài)寄存器CPSR和SPSR進(jìn)行寫操作。與MRS配合使用,可以實(shí)現(xiàn)對CPSR或SPSR寄存器的讀-修改-寫操作,可以切換處理器模式、或者允許/禁止IRQ/FIQ中斷等。MSR{cond}psr_fields,#immed_8rMSR指令格式1MSR{cond}psr_fields,RmMSR指令格式2指令執(zhí)行的條件碼CPSR或SPSR指定傳送的區(qū)域,可以為以下字母(必須小寫)的一個或者組合:c控制域屏蔽字節(jié)(psr[7..0])x擴(kuò)展域屏蔽字節(jié)(psr[15..8])s狀態(tài)域屏蔽字節(jié)(psr[23..16])f標(biāo)志域屏蔽字節(jié)(psr[31..24])保存要傳送到狀態(tài)寄存器指定域數(shù)據(jù)的源寄存器要傳送到狀態(tài)寄存器指定域的立即數(shù)保存要傳送到狀態(tài)寄存器指定域數(shù)據(jù)的源寄存器ARM雜項(xiàng)指令——狀態(tài)寄存器寫指令在ARM處理器中,只有MSR指令可以對狀態(tài)寄存器CPSR和SPSR進(jìn)行寫操作。與MRS配合使用,可以實(shí)現(xiàn)對CPSR或SPSR寄存器的讀-修改-寫操作,可以切換處理器模式、或者允許/禁止IRQ/FIQ中斷等。指令執(zhí)行的條件碼CPSR或SPSR指定傳送的區(qū)域,可以為以下字母(必須小寫)的一個或者組合:c控制域屏蔽字節(jié)(psr[7..0])x擴(kuò)展域屏蔽字節(jié)(psr[15..8])s狀態(tài)域屏蔽字節(jié)(psr[23..16])f標(biāo)志域屏蔽字節(jié)(psr[31..24])要傳送到狀態(tài)寄存器指定域的立即數(shù)MSR指令1編碼MSR指令2編碼Rotate:立即數(shù)對齊8_bit_immediate:8位立即數(shù)(1)(2)(3)(4)ARM雜項(xiàng)指令——狀態(tài)寄存器寫指令在ARM處理器中,只有MSR指令可以對狀態(tài)寄存器CPSR和SPSR進(jìn)行寫操作。與MRS配合使用,可以實(shí)現(xiàn)對CPSR或SPSR寄存器的讀-修改-寫操作,可以切換處理器模式、或者允許/禁止IRQ/FIQ中斷等。

應(yīng)用示例1:;子程序:使能IRQ中斷ENABLE_IRQMRSR0,CPSRBICR0,R0,#0x80MSRCPSR_c,R0MOVPC,LR

應(yīng)用示例2:;子程序:禁能IRQ中斷DISABLE_IRQMRSR0CPSRORRR0,R0,#0x80MSRCPSR_c,R0MOVPC,LR

1.將CPSR寄存器內(nèi)容讀出到R0;2.修改對應(yīng)于CPSR中的I控制位;3.將修改后的值寫回CPSR寄存器的對應(yīng)控制域;4.返回上一層函數(shù);ARM雜項(xiàng)指令——軟中斷指令

SWI指令用于產(chǎn)生軟中斷,從而實(shí)現(xiàn)在從戶模式變換到管理模式,并且將CPSR保存到管理模式的SPSR中,然后程序跳轉(zhuǎn)到SWI異常入口。在其它模式下也可使用SWI指令,處理器同樣地切換到管理模式。該指令主要用于用戶程序調(diào)用操作系統(tǒng)的系統(tǒng)服務(wù),操作系統(tǒng)在SWI異常處理程序中進(jìn)行相應(yīng)的系統(tǒng)服務(wù)。SWI{cond} immed_24SWI指令格式SWI指令編碼指令執(zhí)行的條件碼指令傳遞的參數(shù)(24位立即數(shù))ARM雜項(xiàng)指令——軟中斷指令

根據(jù)SWI指令傳遞的參數(shù)SWI異常處理程序可以作出相應(yīng)的處理。SWI指令傳遞參數(shù)有以下兩種方法,指令中的24位立即數(shù)指定了用戶請求的服務(wù)類型,參數(shù)通過通用寄存器傳遞。MOVR0,#34

;設(shè)置子功能號為34SWI12

;調(diào)用12號軟中斷指令中的24位立即數(shù)被忽略,用戶請求的服務(wù)類型由寄存器R0的值決定,參數(shù)通過其它的通用寄存器傳遞。MOVR0,#12

;調(diào)用12號軟中斷MOVR1,#34

;設(shè)置子功能號為34SWI0

ARM雜項(xiàng)指令——軟中斷指令

在SWI異常中斷處理程序中,取出SWI指令中立即數(shù)的步驟為:首先確定引起軟中斷的SWI指令是ARM指令還是Thumb指令,這可通過對SPSR訪問得到;然后取得該SWI指令的地址,這可通過訪問LR寄存器得到;接著讀出該SWI指令,分解出立即數(shù)。

SWI_HandlerSTMFDSP!,{R0-R3,R12,LR} ;現(xiàn)場保護(hù)

MRSR0,SPSR ;讀取SPSRSTMFDSP!,{R0} ;保存SPSRTSTR0,#0x20 ;測試T標(biāo)志位

LDRNEHR0,[LR,#-2] ;若是Thumb指令,讀取指令碼(16位)BICNER0,R0,#0xFF00 ;取得Thumb指令的8位立即數(shù)

LDREQR0,[LR,#-4] ;若是ARM指令,讀取指令碼(32位)BICEQR0,R0,#0xFF000000 ;取得ARM指令的24位立即數(shù)

...LDMFDSP!,{R0-R3,R12,PC}^ ;SWI異常中斷返回ARM指令小節(jié)目錄1.指令格式2.條件碼3.存儲器訪問指令4.數(shù)據(jù)處理指令5.乘法指令6.ARM分支指令7.協(xié)處理器指令8.雜項(xiàng)指令9.偽指令指令集介紹ARM偽指令

ARM偽指令不屬于ARM指令集中的指令,是為了編程方便而定義的。偽指令可以像其它ARM指令一樣使用,但在編譯時這些指令將被等效的ARM指令代替。ARM偽指令有四條,分別為ADR偽指令、ADRL偽指令、LDR偽指令、NOP偽指令。ARM偽指令——小范圍的地址讀取

ADR偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中。在匯編編譯器編譯源程序時,ADR偽指令被編譯器替換成一條合適的指令。通常,編譯器用一條ADD指令或SUB指令來實(shí)現(xiàn)該ADR偽指令的功能,若不能用一條指令實(shí)現(xiàn),則產(chǎn)生錯誤,編譯失敗。ADR{cond}register,exprADR偽指令格式指令執(zhí)行的條件碼加載的目標(biāo)寄存器地址表達(dá)式

地址表達(dá)式expr的取指范圍:當(dāng)?shù)刂分挡皇亲謱R時,其取指范圍為-255~255;當(dāng)?shù)刂分凳亲謱R時,其取指范圍為-1020~1020;當(dāng)?shù)刂分凳?6字節(jié)對齊時,其取指范圍將更大。ARM偽指令——小范圍的地址讀取

ADR偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中。在匯編編譯器編譯源程序時,ADR偽指令被編譯器替換成一條合適的指令。通常,編譯器用一條ADD指令或SUB指令來實(shí)現(xiàn)該ADR偽指令的功能,若不能用一條指令實(shí)現(xiàn),則產(chǎn)生錯誤,編譯失敗。

...

ADRR0,Delay...DelayMOVR0,r14...應(yīng)用示例(源程序):使用偽指令將程序標(biāo)號Delay的地址存入R0

...0x20ADDr1,pc,#0x3c......0x64MOVr0,r14...ARM偽指令——小范圍的地址讀取

ADR偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中。在匯編編譯器編譯源程序時,ADR偽指令被編譯器替換成一條合適的指令。通常,編譯器用一條ADD指令或SUB指令來實(shí)現(xiàn)該ADR偽指令的功能,若不能用一條指令實(shí)現(xiàn),則產(chǎn)生錯誤,編譯失敗。

...ADRLR0,Delay...DelayMOVR0,r14...應(yīng)用示例(源程序):編譯后的反匯編代碼:使用偽指令將程序標(biāo)號Delay的地址存入R0地址程序代碼ARM偽指令——小范圍的地址讀取

ADR偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中。在匯編編譯器編譯源程序時,ADR偽指令被編譯器替換成一條合適的指令。通常,編譯器用一條ADD指令或SUB指令來實(shí)現(xiàn)該ADR偽指令的功能,若不能用一條指令實(shí)現(xiàn),則產(chǎn)生錯誤,編譯失敗。

...ADRR0,Delay...DelayMOVR0,r14...應(yīng)用示例(源程序):

...0x20ADDr0,pc,#0x3c......0x64MOVr0,r14...編譯后的反匯編代碼:使用偽指令將程序標(biāo)號Delay的地址存入R0ADR偽指令被匯編成一條指令A(yù)RM偽指令——小范圍的地址讀取

ADR偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中。在匯編編譯器編譯源程序時,ADR偽指令被編譯器替換成一條合適的指令。通常,編譯器用一條ADD指令或SUB指令來實(shí)現(xiàn)該ADR偽指令的功能,若不能用一條指令實(shí)現(xiàn),則產(chǎn)生錯誤,編譯失敗。

應(yīng)用示例2(查表):

ADRR0,DISP_TAB ;加載轉(zhuǎn)換表地址

LDRBR1,[R0,R2] ;使用R2作為參數(shù),進(jìn)行查表

…DISP_TABDCB0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8ARM偽指令——中等范圍的地址讀取

ADRL偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中,比ADR偽指令可以讀取更大范圍的地址。在匯編編譯器編譯源程序時,ADRL偽指令被編譯器替換成兩條合適的指令。若不能用兩條指令實(shí)現(xiàn),則產(chǎn)生錯誤,編譯失敗。ADRL{cond}register,exprADRL偽指令格式指令執(zhí)行的條件碼加載的目標(biāo)寄存器地址表達(dá)式

地址表達(dá)式expr的取指范圍:當(dāng)?shù)刂分挡皇亲謱R時,其取指范圍為-64K~64K;當(dāng)?shù)刂分凳亲謱R時,其取指范圍為-256K~256K;當(dāng)?shù)刂分凳?6字節(jié)對齊時,其取指范圍將更大。ARM偽指令——中等范圍的地址讀取

ADRL偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中,比ADR偽指令可以讀取更大范圍的地址。在匯編編譯器編譯源程序時,ADRL偽指令被編譯器替換成兩條合適的指令。若不能用兩條指令實(shí)現(xiàn),則產(chǎn)生錯誤,編譯失敗。

...ADRLR0,Delay...DelayMOVR0,r14...應(yīng)用示例(源程序):使用偽指令將程序標(biāo)號Delay的地址存入R0ARM偽指令——中等范圍的地址讀取

ADRL偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中,比ADR偽指令可以讀取更大范圍的地址。在匯編編譯器編譯源程序時,ADRL偽指令被編譯器替換成兩條合適的指令。若不能用兩條指令實(shí)現(xiàn),則產(chǎn)生錯誤,編譯失敗。

...ADRLR0,Delay...DelayMOVR0,r14...應(yīng)用示例(源程序):

...0x20ADDr0,pc,#400x24ADDr0,r0,#0...0x68MOVr0,r14...編譯后的反匯編代碼:使用偽指令將程序標(biāo)號Delay的地址存入R0地址程序代碼ARM偽指令——中等范圍的地址讀取

ADRL偽指令將基于PC相對偏移的地址值或基于寄存器相對偏移的地址值讀取到寄存器中,比ADR偽指令可以讀取更大范圍的地址。在匯編編譯器編譯源程序時,ADRL偽指令被編譯器替換成兩條合適的指令。若不能用兩條指令實(shí)現(xiàn),則產(chǎn)生錯誤,編譯失敗。

...ADRLR0,Delay...DelayMOVR0,r14...應(yīng)用示例(源程序):

...0x20ADDr1,pc,#400x24ADDr1,r1,#0...0x68MOVr0,r14...編譯后的反匯編代碼:使用偽指令將程序標(biāo)號Delay的地址存入R0ADRL偽指令被匯編成兩條指令,盡管第2條指令并沒有意義ARM偽指令——大范圍的地址讀取

LDR偽指令用于加載32位的立即數(shù)或一個地址值到指定寄存器。在匯編編譯源程序時,LDR偽指令被編譯器替換成一條合適的指令。若加載的常數(shù)未超出MOV或MVN的范圍,則使用MOV或MVN指令代替該LDR偽指令,否則匯編器將常量放入文字池,并使用一條程序相對偏移的LDR指令從文字池讀出常量。LDR{cond}register,=exprLDR偽指令格式指令執(zhí)行的條件碼加載的目標(biāo)寄存器基于PC的地址表達(dá)式或外部表達(dá)式ARM偽指令——大范圍的地址讀取

LDR偽指令用于加載32位的立即數(shù)或一個地址值到指定寄存器。在匯編編譯源程序時,LDR偽指令被編譯器替換成一條合適的指令。若加載的常數(shù)未超出MOV或MVN的范圍,則使用MOV或MVN指令代替該LDR偽指令,否則匯編器將常量放入文字池,并使用一條程序相對偏移的LDR指令從文字池讀出常量。應(yīng)用示例(源程序):

...LDRR1,=InitStack...InitStack

MOVR0,LR...使用偽指令將程序標(biāo)號InitStack的地址存入R1ARM偽指令——大范圍的地址讀取

LDR偽指令用于加載32位的立即數(shù)或一個地址值到指定寄存器。在匯編編譯源程序時,LD

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論