h1_key

當(dāng)前位置:首頁(yè) >新聞資訊 > 技術(shù)文章>ARM微處理器指令集合
ARM微處理器指令集合
2023-04-06 572次



主要介紹ARM微處理器指令集對(duì)應(yīng)的概念,與其一般編碼格式,可以為大家提供快速查詢的便利,但要注意的是本文整理的是ARMv5TE及以下版本的微處理器,對(duì)于更高級(jí)的版本,可能會(huì)有新的指令出現(xiàn),所以請(qǐng)注意查看自己使用的ARM處理器型號(hào)。

 

  一、跳轉(zhuǎn)指令

  1、B指令——跳轉(zhuǎn)指令

  指令格式:B{條件} 目標(biāo)地址

  2、BL指令——帶返回的跳轉(zhuǎn)指令

  指令格式:BL{條件} 目標(biāo)地址

  3、BLX指令——帶返回和狀態(tài)切換的跳轉(zhuǎn)指令

  指令格式:BLX 目標(biāo)地址

  4、BX指令——帶狀態(tài)切換的跳轉(zhuǎn)指令

指令格式:BX{條件} 目標(biāo)地址

 

  二、數(shù)據(jù)處理指令

  數(shù)據(jù)處理分為傳輸指令、算術(shù)邏輯指令和比較指令。

  1、MOV指令——數(shù)據(jù)傳輸指令

  指令格式:MOV{條件} {S} 目的寄存器,源操作數(shù)

  2、MVN指令——取反傳送指令

  指令格式:MVN{條件} {S} 目的寄存器,源操作數(shù)

  3、CMP指令——比較指令

  指令格式:CMP{條件} {S} 操作數(shù)1,操作數(shù)2

  4、CMN指令——反值比較指令

  指令格式:CMN{條件} 操作數(shù)1,操作數(shù)2

  5、TST指令——位測(cè)試指令

  指令格式:TST{條件} 操作數(shù)1,操作數(shù)2

  6、TEQ指令——相等測(cè)試指令

  指令格式:TEQ{條件} 操作數(shù)1,操作數(shù)2

  7、ADD指令——加法指令

  指令格式:ADD{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  8、ADC指令——帶進(jìn)位的加法指令

  指令格式:ADC{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  9、SUB指令——減法指令

  指令格式:SUB{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  10、SBC指令——帶借位的減法指令

  指令格式:SBC{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  11、RSB指令——逆向減法指令

  指令格式:RSB{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  12、RSC指令——帶借位的逆向減法指令

  指令格式:RSC{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  13、AND指令——邏輯“與”指令

  指令格式:AND{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  14、ORR指令——邏輯“或”指令

  指令格式:ORR{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  15、EOR指令——邏輯“異或”指令

  指令格式:EOR{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  16、BIC指令——位清除指令

  指令格式:BIC{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  

  三、乘法指令與乘加指令

  1、MUL指令——32位乘法指令

  指令格式:MUL{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2

  2、MLA指令——32位乘加指令

  指令格式:MLA{條件} {S} 目的寄存器,操作數(shù)1,操作數(shù)2,操作數(shù)3

  3、SMULL指令——64位有符號(hào)數(shù)乘法指令

  指令格式:SMULL{條件} {S} 目的寄存器Low,目的寄存器High,操作數(shù)1,操作數(shù)2

  4、SMLAL指令——64位有符號(hào)數(shù)乘加指令

  指令格式:SMLAL{條件} {S} 目的寄存器Low,目的寄存器High,操作數(shù)1,操作數(shù)2

  5、UMULL指令——64位無(wú)符號(hào)數(shù)乘法指令

  指令格式:UMULL{條件} {S} 目的寄存器Low,目的寄存器High,操作數(shù)1,操作數(shù)2

  6、UMLAL指令——64位無(wú)符號(hào)數(shù)乘加指令

指令格式:UMLAL{條件} {S} 目的寄存器Low,目的寄存器High,操作數(shù)1,操作數(shù)2

 

  四、程序狀態(tài)寄存器指令

  1、MRS指令——程序狀態(tài)寄存器到通用寄存器的數(shù)據(jù)傳輸指令

  指令格式:MRS{條件} 通用寄存器,程序狀態(tài)寄存器(CPSR或SPSR)

  2、MSR指令——通用寄存器到程序狀態(tài)寄存器的數(shù)據(jù)傳輸指令

指令格式:MSR{條件} 程序狀態(tài)寄存器(CPSR或SPSR)_<域>,操作數(shù)

 

  五、加載/存儲(chǔ)指令

  1、LDR指令——字?jǐn)?shù)據(jù)加載指令

  指令格式:LDR{條件} 目的寄存器,<存儲(chǔ)器地址>

  2、LDRB指令——字節(jié)數(shù)據(jù)加載指令

  指令格式:LDR{條件} B 目的寄存器,<存儲(chǔ)器地址>

  3、LDRH指令——半字?jǐn)?shù)據(jù)加載指令

  指令格式:LDR{條件}H 目的寄存器,<存儲(chǔ)器地址>

  4、STR指令——字?jǐn)?shù)據(jù)存儲(chǔ)指令

  指令格式:STR{條件} 源寄存器,<存儲(chǔ)器地址>

  5、STRB指令——字節(jié)數(shù)據(jù)存儲(chǔ)指令

  指令格式:STR{條件}B 源寄存器,<存儲(chǔ)器地址>

  6、STRH指令——半字?jǐn)?shù)據(jù)存儲(chǔ)指令

指令格式:STR{條件}H 源寄存器,<存儲(chǔ)器地址>

 

  六、批量數(shù)據(jù)加載/存儲(chǔ)指令

  1、LDM指令——批量數(shù)據(jù)加載指令

  指令格式:LDM{條件} {類型} 基址寄存器{!},寄存器列表{^}

  2、STM指令——批量數(shù)據(jù)存儲(chǔ)指令

指令格式:STM{條件} {類型} 基址寄存器{!},寄存器列表{^}

 

 七、數(shù)據(jù)交換指令

  1、SWP指令——字?jǐn)?shù)據(jù)交換指令

  指令格式:SWP{條件} 目的寄存器,源寄存器1,[源寄存器2]

  2、SWPB指令——字節(jié)數(shù)據(jù)交換指令

  指令格式:SWP{條件}B 目的寄存器,源寄存器1,[源寄存器2]

  八、移位指令

  1、LSL指令——對(duì)通用寄存器中的內(nèi)容進(jìn)行邏輯左移操作

  指令格式:通用寄存器,LSL 操作數(shù)

  2、ASL指令——對(duì)通用寄存器中的內(nèi)容進(jìn)行算術(shù)左移操作

  指令格式:通用寄存器,ASL 操作數(shù)

  3、LSR指令——對(duì)通用寄存器中的內(nèi)容進(jìn)行邏輯右移操作

  指令格式:通用寄存器,LSR 操作數(shù)

  4、ASR指令——對(duì)通用寄存器中的內(nèi)容進(jìn)行算術(shù)右移操作

  指令格式:通用寄存器,ASR 操作數(shù)

  5、ROR指令——對(duì)通用寄存器中的內(nèi)容進(jìn)行循環(huán)右移操作

  指令格式:通用寄存器,ROR 操作數(shù)

  6、RRX指令——對(duì)通用寄存器中的內(nèi)容進(jìn)行帶擴(kuò)展的循環(huán)右移操作

  指令格式:通用寄存器,RRX 操作數(shù)

 

  九、協(xié)處理器指令

  1、CDP指令——ARM處理器通知ARM協(xié)處理器執(zhí)行特定的操作,若協(xié)處理器不能成功完成特定操作,則產(chǎn)生未定義指令異常

  指令格式:CDP{條件}協(xié)處理器編碼,協(xié)處理器操作碼1,目的寄存器,源寄存器1,寄存器2,協(xié)處理器操作碼2

  2、LDC指令——將源寄存器所指向的存儲(chǔ)器中的字?jǐn)?shù)據(jù)傳送到目的寄存器中,若協(xié)處理器不能成功完成傳送操作,則產(chǎn)生未定義指令異常。

  指令格式:LDC{條件} {L} 協(xié)處理器編碼,目的寄存器,[源寄存器]

  3、STC指令——將源寄存器中的字?jǐn)?shù)據(jù)傳送到目的寄存器所指向的存儲(chǔ)器中,若協(xié)處理器不能成功完成傳送操作,則產(chǎn)生未定義指令異常。

  指令格式:STC{條件} {L} 協(xié)處理器編碼,源寄存器,[目的寄存器]

  4、MCR指令——將ARM處理器寄存器中的數(shù)據(jù)傳送到協(xié)處理器寄存器中,若協(xié)處理器不能完成此操作,則產(chǎn)生未定義指令異常。

  指令格式:MCR{條件}協(xié)處理器編碼,協(xié)處理器操作碼1,源寄存器,目的寄存器1,目的寄存器2,協(xié)處理器操作碼2

  5、MRC指令——將協(xié)處理器寄存器中的數(shù)據(jù)傳送到ARM處理器寄存器中,若協(xié)處理器不能成功完成操作,則產(chǎn)生未定義指令異常。

指令格式:MRC{條件}協(xié)處理器編碼,協(xié)處理器操作碼1,目的寄存器,源寄存器1,源寄存器2,協(xié)處理器操作碼2

 

  十、異常中斷指令

  1、SWI指令——軟件中斷指令

  指令格式:SWI{條件}24位的立即數(shù)

  2、BKPT指令——斷點(diǎn)中斷指令

  指令格式:BKPT 16位的立即數(shù)

 

  • XILINX賽靈思 XC7K160T-2FBG484E
  • 賽靈思(XILINX)作為行業(yè)的領(lǐng)軍企業(yè),其推出的 XC7K160T-2FBG484E 更是一款備受矚目的產(chǎn)品。XC7K160T-2FBG484E 屬于賽靈思 7 系列 FPGA(現(xiàn)場(chǎng)可編程門陣列),具有強(qiáng)大的性能和豐富的功能。
    2024-09-25 183次
  • XILINX賽靈思 XCKU085-2FLVA1517E
  • 賽靈思(XILINX)作為全球領(lǐng)先的可編程邏輯器件供應(yīng)商,其推出的 XCKU085-2FLVA1517E 以卓越的性能和豐富的功能,成為眾多電子工程師和設(shè)計(jì)師的首選。XCKU085-2FLVA1517E 屬于賽靈思 UltraScale 架構(gòu)系列產(chǎn)品,采用先進(jìn)的 20 納米工藝技術(shù)制造。這一工藝不僅帶來(lái)了更高的性能,還實(shí)現(xiàn)了更低的功耗,為各種復(fù)雜的電子系統(tǒng)設(shè)計(jì)提供了理想的解決方案。
    2024-09-25 163次
  • XILINX賽靈思 XCKU060-1FFVA1517C
  • 賽靈思(XILINX)作為全球領(lǐng)先的可編程邏輯解決方案供應(yīng)商,其 XCKU060-1FFVA1517C 更是一款備受矚目的產(chǎn)品。XCKU060-1FFVA1517C 屬于賽靈思 UltraScale 架構(gòu)系列,采用了先進(jìn)的 16 納米 FinFET 工藝技術(shù)。這一工藝帶來(lái)了諸多優(yōu)勢(shì),如更高的性能、更低的功耗以及更小的芯片尺寸。
    2024-09-25 180次
  • XILINX賽靈思 XCKU060-2FFVA1517E
  • 賽靈思(XILINX)作為行業(yè)的領(lǐng)軍企業(yè),其推出的 XCKU060-2FFVA1517E 更是一款備受矚目的產(chǎn)品。XCKU060-2FFVA1517E 屬于賽靈思 UltraScale 架構(gòu)系列的 FPGA(現(xiàn)場(chǎng)可編程門陣列)。它融合了先進(jìn)的技術(shù)和強(qiáng)大的性能,為各種復(fù)雜的應(yīng)用場(chǎng)景提供了高度靈活且可靠的解決方案。
    2024-09-25 149次
  • XILINX賽靈思 XC7Z035-3FFG676E
  • 賽靈思(XILINX)作為全球領(lǐng)先的可編程邏輯解決方案供應(yīng)商,其 XC7Z035-3FFG676E 更是一款備受矚目的產(chǎn)品。XC7Z035-3FFG676E 屬于賽靈思 Zynq - 7000 系列,該系列將處理器系統(tǒng)(PS)和可編程邏輯(PL)完美結(jié)合,為用戶提供了高度靈活的解決方案。這款器件采用了先進(jìn)的 28 納米工藝技術(shù),在性能、功耗和成本之間實(shí)現(xiàn)了出色的平衡。
    2024-09-25 149次

    萬(wàn)聯(lián)芯微信公眾號(hào)

    元器件現(xiàn)貨+BOM配單+PCBA制造平臺(tái)
    關(guān)注公眾號(hào),優(yōu)惠活動(dòng)早知道!
    10s
    溫馨提示:
    訂單商品問(wèn)題請(qǐng)移至我的售后服務(wù)提交售后申請(qǐng),其他需投訴問(wèn)題可移至我的投訴提交,我們將在第一時(shí)間給您答復(fù)
    返回頂部