嵌入式系統(tǒng)基礎(chǔ)第4章-ARM指令系統(tǒng)_第1頁
嵌入式系統(tǒng)基礎(chǔ)第4章-ARM指令系統(tǒng)_第2頁
嵌入式系統(tǒng)基礎(chǔ)第4章-ARM指令系統(tǒng)_第3頁
嵌入式系統(tǒng)基礎(chǔ)第4章-ARM指令系統(tǒng)_第4頁
嵌入式系統(tǒng)基礎(chǔ)第4章-ARM指令系統(tǒng)_第5頁
已閱讀5頁,還剩143頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、 第四章 ARM指令系統(tǒng)1 一.ARM處理器尋址方式 二.ARM指令集 ARM指令集 Thumb指令集 三.ARM匯編程序設(shè)計2主要內(nèi)容3ARM指令集概述ARM指令集是32位的,程序的啟動都是從ARM指令集開始。所有的ARM指令集都可以是有條件執(zhí)行的。ARM指令集是以32位二進(jìn)制編碼的方式給出的,大部分的指令編碼中定義了第一操作數(shù)、第二操作數(shù)、目的操作數(shù)、條件標(biāo)志影響位以及每條指令所對應(yīng)的不同功能實現(xiàn)的二進(jìn)制位。4 每條32位ARM指令都具有不同的二進(jìn)制編碼方式,和不同的指令功能相對應(yīng) 尋址方式就是處理器根據(jù)指令中給出的地址碼字段來實現(xiàn)尋找真實操作數(shù)地址的方式。56 ARM指令長度 指令集可以

2、是以下任一種 32 bits 長 (ARM狀態(tài)) 16 bits 長 (Thumb 狀態(tài)) 支持3種數(shù)據(jù)類型 字節(jié) (8-bit) 半字 (16-bit) 字 (32-bit)1x“雙字”(DWORD)=2x“字”(WORD)4x“字節(jié)”(Byte)=32x“位”(Bit) 字必須被排成4個字節(jié)邊界對齊,半字必須被排列成2個字節(jié)邊界對齊7說明一 ARM指令長度 向后兼容:新版本增加指令,并保持指令向后兼容; Load-store(加載/存儲型) 結(jié)構(gòu)*uload/store 從存儲器中讀某個值,操作完后再將其放回存儲器中u只對存放在寄存器的數(shù)據(jù)進(jìn)行處理u對于存儲器中的數(shù)據(jù),只能使用load/s

3、tore指令進(jìn)行存取8說明二 ARM指令長度9q1.ARM處理器尋址方式q2.ARM指令集 ARM指令集 Thumb指令集q3.ARM匯編程序設(shè)計 簡介10簡介 ARM處理器是基于精簡指令集計算機(jī)(RISC)原理設(shè)計的,指令集和相關(guān)譯碼機(jī)制較為簡單。ARM7TDMI(-S)具有32位ARM指令集和16位Thumb指令集,ARM指令集效率高,但是代碼密度低;而Thumb指令集具有較高的代碼密度,卻仍然保持ARM的大多數(shù)性能上的優(yōu)勢,它是ARM指令集的子集。所有的ARM指令都是可以有條件執(zhí)行的,而Thumb指令僅有一條指令具備條件執(zhí)行功能。ARM程序和Thumb程序可相互調(diào)用,相互之間的狀態(tài)切換開

4、銷幾乎為零。 ARM指令集與Thumb指令集的關(guān)系11第4章 ARM指令系統(tǒng)Thumb指令集具有靈活、小巧的特點ARM指令集支持ARM核所有的特性,具有高效、快速的特點 尋址方式分類124.1 ARM處理器尋址方式 尋址方式是根據(jù)指令中給出的地址碼字段來實現(xiàn)尋找真實操作數(shù)地址的方式。ARM處理器具有9種基本尋址方式。1.寄存器尋址;2.立即尋址;3.寄存器移位尋址;4.寄存器間接尋址;5.基址尋址;6.多寄存器尋址;7.堆棧尋址;8.塊拷貝尋址;9.相對尋址。 操作數(shù)的值在寄存器中,指令中的地址碼字段指出的是寄存器編號,指令執(zhí)行時直接取出寄存器值來操作。寄存器尋址指令舉例如下: MOV R1,

5、R2 ;將R2的值存入R1 SUB R0,R1,R2 ;將R1的值減去R2的值,結(jié)果保存到R0 134.1 ARM處理器尋址方式 尋址方式分類寄存器尋址140 xAA0 x55R2R1MOV R1,R20 xAA 立即尋址也叫立即數(shù)尋址,這是一種特殊的尋址方立即尋址也叫立即數(shù)尋址,這是一種特殊的尋址方式,操作數(shù)本身就在指令中給出,只要取出指令也式,操作數(shù)本身就在指令中給出,只要取出指令也就取到了操作數(shù),這個操作數(shù)被稱為立即數(shù),對應(yīng)就取到了操作數(shù),這個操作數(shù)被稱為立即數(shù),對應(yīng)的尋址方式也就叫做立即尋址。的尋址方式也就叫做立即尋址。 立即尋址指令中的操作碼字段后面的地址碼部分即是操作數(shù)本身,也就是

6、說,數(shù)據(jù)就包含在指令當(dāng)中,取出指令也就取出了可以立即使用的操作數(shù)(這樣的數(shù)稱為立即數(shù))。立即尋址指令舉例如下: SUBSR0,R0,#1 ;R0減1,結(jié)果放入R0,并且影響標(biāo)志位 MOVR0,#0 xFF000 ;將立即數(shù)0 xFF000裝入R0寄存器 154.1 ARM處理器尋址方式 尋址方式分類立即尋址160 x55R0MOV R0,#0 xFF00程序存儲MOV R0,#0 xFF000 xFF00從代碼中獲得數(shù)據(jù) 寄存器移位尋址是ARM指令集特有的尋址方式。當(dāng)?shù)?個操作數(shù)是寄存器移位方式時,第2個寄存器操作數(shù)在與第1個操作數(shù)結(jié)合之前,選擇進(jìn)行移位操作。寄存器移位尋址指令舉例如下: MO

7、VR0,R2,LSL #3 ;R2的值左移3位,結(jié)果放入R0, ;即是R0=R28 ANDSR1,R1,R2,LSL R3 ;R2的值左移R3位,然后和R1相 ;“與”操作,結(jié)果放入R1174.1 ARM處理器尋址方式 尋址方式分類寄存器移位尋址180 x55R0R20 x01MOV R0,R2,LSL #30 x080 x08邏輯左移3位 寄存器間接尋址指令中的地址碼給出的是一個通用寄存器的編號,所需的操作數(shù)保存在寄存器指定地址的存儲單元中,即寄存器為操作數(shù)的地址指針。寄存器間接尋址指令舉例如下: LDRR1,R2;將R2指向的存儲單元的數(shù)據(jù)讀出;保存在R1中 SWPR1,R1,R2;將寄存

8、器R1的值和R2指定的存儲;單元的內(nèi)容交換 194.1 ARM處理器尋址方式 尋址方式分類寄存器間接尋址200 x55R0R2 0 x400000000 xAA0 x40000000LDR R0,R20 xAA 基址尋址就是將基址寄存器的內(nèi)容與指令中給出的偏移量(4K)相加/減,形成操作數(shù)的有效地址?;穼ぶ酚糜谠L問基址附近的存儲單元,常用于查表、數(shù)組操作、功能部件寄存器訪問等。寄存器間接尋址是偏移量為0的基址加偏移尋址。 基址尋址指令舉例如下(前索引尋址): LDRR2,R3,#0 x0C ;讀取R3+0 x0C地址上的存儲單元的內(nèi)容,放入R2 STRR1,R0,#-4! ;先R0=R0-4

9、,然后把R0的值寄存到保存到R1指定的存儲單元 214.1 ARM處理器尋址方式 尋址方式分類基址尋址220 x55R2R3 0 x400000000 xAA0 x4000000CLDR R2,R3,#0 x0C0 xAA將R3+0 x0C作為地址裝載數(shù)據(jù) 多寄存器尋址一次可傳送幾個寄存器值,允許一條指令傳送16個寄存器的任何子集或所有寄存器。多寄存器尋址指令舉例如下: LDMIAR1!,R2-R7,R12 ;將R1指向的單元中的數(shù)據(jù)讀出到R2R7、R12中(R1自動加4) STMIAR0!,R2-R7,R12 ;將寄存器R2R7、R12的值保存到R0指向的存儲; 單元中(R0自動加4)234

10、.1 ARM處理器尋址方式 尋址方式分類多寄存器尋址240 x40000000R1R20 x?0 x010 x400000000 x?R3R40 x?R60 x?0 x020 x030 x040 x400000040 x400000080 x4000000C存儲器LDR R1!,R2-R4,R6 0 x010 x020 x030 x040 x40000010 尋址方式分類堆棧尋址25 堆棧是一個按特定順序進(jìn)行存取的存儲區(qū),操作順序為“后進(jìn)先出” 。堆棧尋址是隱含的,它使用一個專門的寄存器(堆棧指針)指向一塊存儲區(qū)域(堆棧),指針?biāo)赶虻拇鎯卧词嵌褩5臈m?。存儲器堆棧可分為兩種: 向上生長:

11、向高地址方向生長,稱為遞增堆棧向下生長:向低地址方向生長,稱為遞減堆棧4.1 ARM處理器尋址方式 尋址方式分類堆棧尋址26棧底棧頂棧區(qū)SP堆棧存儲區(qū)棧頂棧底棧區(qū)SP向下增長向上增長0 x123456780 x12345678堆棧壓棧堆棧壓棧4.1 ARM處理器尋址方式 尋址方式分類堆棧尋址27棧頂SP棧頂SP棧底空堆棧棧底滿堆棧 堆棧指針指向最后壓入的堆棧的有效數(shù)據(jù)項,稱為滿堆棧;堆棧指針指向下一個待壓入數(shù)據(jù)的空位置,稱為空堆棧。 0 x123456780 x12345678棧頂SP0 x12345678棧頂SP壓棧壓棧4.1 ARM處理器尋址方式 尋址方式分類堆棧尋址28所以可以組合出四種

12、類型的堆棧方式:滿遞增:堆棧向上增長,堆棧指針指向內(nèi)含有效數(shù)據(jù)項的最高地址。指令如LDMFA、STMFA等; 空遞增:堆棧向上增長,堆棧指針指向堆棧上的第一個空位置。指令如LDMEA、STMEA等; 滿遞減:堆棧向下增長,堆棧指針指向內(nèi)含有效數(shù)據(jù)項的最低地址。指令如LDMFD、STMFD等;空遞減:堆棧向下增長,堆棧指針向堆棧下的第一個空位置。指令如LDMED、STMED等。 4.1 ARM處理器尋址方式 尋址方式分類塊拷貝尋址29 多寄存器傳送指令用于將一塊數(shù)據(jù)從存儲器的某一位置拷貝到另一位置。 如:STMIAR0!,R1-R7;將R1R7的數(shù)據(jù)保存到存儲器中。;存儲指針R0在保存第一個值之

13、后增加,;增長方向為向上增長。STMIBR0!,R1-R7;將R1R7的數(shù)據(jù)保存到存儲器中。;存儲指針R0在保存第一個值之前增加,;增長方向為向上增長。 4.1 ARM處理器尋址方式 尋址方式分類相對尋址30 相對尋址是基址尋址的一種變通。由程序計數(shù)器PC提供基準(zhǔn)地址,指令中的地址碼字段作為偏移量,兩者相加后得到的地址即為操作數(shù)的有效地址。相對尋址指令舉例如下:BLSUBR1;調(diào)用到SUBR1子程序BEQLOOP;條件跳轉(zhuǎn)到LOOP標(biāo)號處.LOOPMOVR6,#1.SUBR1. 4.1 ARM處理器尋址方式31q1.ARM處理器尋址方式q2.ARM指令集 ARM指令集 Thumb指令集q3.A

14、RM匯編程序設(shè)計 簡單的ARM程序32;文件名:TEST1.S ;功能:實現(xiàn)兩個寄存器相加 ;說明:使用ARMulate軟件仿真調(diào)試 AREAExample1,CODE,READONLY ;聲明代碼段Example1 ENTRY ;標(biāo)識程序入口 CODE32 ;聲明32位ARM指令START MOVR0,#0 ;設(shè)置參數(shù) MOVR1,#10LOOPBLADD_SUB ;調(diào)用子程序ADD_SUB BLOOP ;跳轉(zhuǎn)到LOOPADD_SUB ADDSR0,R0,R1 ;R0 = R0 + R1 MOVPC,LR ;子程序返回 END ;文件結(jié)束 使用“;”進(jìn)行注釋標(biāo)號頂格寫實際代碼段聲明文件結(jié)束

15、簡單的ARM程序33;文件名:TEST1.S ;功能:實現(xiàn)兩個寄存器相加 ;說明:使用ARMulate軟件仿真調(diào)試 AREAExample1,CODE,READONLY ;聲明代碼段Example1 ENTRY ;標(biāo)識程序入口 CODE32 ;聲明32位ARM指令START MOVR0,#0 ;設(shè)置參數(shù) MOVR1,#10LOOPBLADD_SUB ;調(diào)用子程序ADD_SUB BLOOP ;跳轉(zhuǎn)到LOOPADD_SUB ADDSR0,R0,R1 ;R0 = R0 + R1 MOVPC,LR ;子程序返回 END ;文件結(jié)束 34ARM指令小節(jié)目錄q 1.指令格式q 2.條件碼q 3.存儲器訪問

16、指令q 4.數(shù)據(jù)處理指令q 5.乘法指令q 6.ARM分支指令q 7.雜項指令q 8.偽指令35ARM指令小節(jié)1.指令格式2.條件碼3.存儲器訪問指令4.數(shù)據(jù)處理指令5.乘法指令6.ARM分支指令7.雜項指令8.偽指令 ARM指令集基本指令格式36 ARM是三地址指令格式,指令的基本格式如下: S , 其中號內(nèi)的項是必須的,號內(nèi)的項是可選的。各項的說明如下:opcode:指令助記符;cond:執(zhí)行條件;S:是否影響CPSR寄存器的值;Rd:目標(biāo)寄存器; Rn:第1個操作數(shù)的寄存器;operand2:第2個操作數(shù);指令語法目標(biāo)寄存器(Rd) 源寄存器1(Rn)源寄存器2(Rm)ADD r3,r1

17、,r2r3r1r2例:4.2 ARM指令集介紹u編碼格式編碼格式lARM指令集的指令編碼格式是三操作數(shù)指令格式:包括操作碼、指令集的指令編碼格式是三操作數(shù)指令格式:包括操作碼、第一操作數(shù)(源操作數(shù))、第二操作數(shù)、目的操作數(shù)、條件標(biāo)第一操作數(shù)(源操作數(shù))、第二操作數(shù)、目的操作數(shù)、條件標(biāo)志位等部分。志位等部分。 PUWLABSNR#的位含義:在尋址方式中,的位含義:在尋址方式中,P=1表表示前變址,示前變址,P=0表示后變址;在長乘法中,表示后變址;在長乘法中,U=1表示無符號;在非長乘法中,表示無符號;在非長乘法中,U=1表示地址遞增,表示地址遞增,U=0表示地址遞減;表示地址遞減;W=1表示回

18、寫修改基址寄存表示回寫修改基址寄存器,器,W=0表示不回寫修改基址寄存器;在分支指表示不回寫修改基址寄存器;在分支指令中,令中,L=1表示帶鏈接的轉(zhuǎn)移;表示帶鏈接的轉(zhuǎn)移;37l在非分支指令中在非分支指令中L=1表示是表示是Load指令,指令,L=0表示是表示是Store指令;指令;A表示累加器;表示累加器;B=1表示字節(jié);在多寄存器表示字節(jié);在多寄存器操作中,操作中,S=1表示有符號;在非多寄存器操作中,表示有符號;在非多寄存器操作中,S=1表表示更新條件碼;示更新條件碼;N=1表示協(xié)處理器;表示協(xié)處理器;R=1表示是表示是SPSR,R=0表示是表示是CPSR;#=1表示立即數(shù)。表示立即數(shù)。3

19、8394.2 ARM指令集介紹n ARM指令集指令格式40ARM指令小節(jié)1.指令格式2.條件碼3.存儲器訪問指令4.數(shù)據(jù)處理指令5.乘法指令6.ARM分支指令7.雜項指令8.偽指令 ARM指令集條件碼41 ARM指令的基本格式如下: S , 使用條件碼“cond”可以實現(xiàn)高效的邏輯操作(節(jié)省跳轉(zhuǎn)和條件語句),提高代碼效率。 所有的ARM指令都可以條件執(zhí)行,而Thumb指令只有B(跳轉(zhuǎn))指令具有條件執(zhí)行 功能。如果指令不標(biāo)明條件代碼,將默認(rèn)為無條件(AL)執(zhí)行。4.2 ARM指令集介紹操作碼條件助記符標(biāo)志含義0000EQZ=1相等0001NEZ=0不相等0010CS/HSC=1無符號數(shù)大于或等于

20、0011CC/LOC=0無符號數(shù)小于0100MIN=1負(fù)數(shù)0101PLN=0正數(shù)或零0110VSV=1溢出0111VCV=0沒有溢出1000HIC=1,Z=0無符號數(shù)大于1001LSC=0,Z=1無符號數(shù)小于或等于1010GEN=V有符號數(shù)大于或等于1011LTN!=V有符號數(shù)小于1100GTZ=0,N=V有符號數(shù)大于1101LEZ=1,N!=V有符號數(shù)小于或等于1110AL任何無條件執(zhí)行 (指令默認(rèn)條件)1111NV任何從不執(zhí)行(不要使用)指令條件碼表 ARM指令集條件碼43C代碼:If(a b)a+;Elseb+;對應(yīng)的匯編代碼:CMPR0,R1 ;R0(a)與R1(b)比較ADDHI R

21、0,R0,#1 ;若R0R1,則R0=R0+1ADDLS R1,R1,#1 ;若R01,則R1=R1+1示例:4.2 ARM指令集介紹uARM指令集是指令集是Load/Store(加載(加載/存儲)型的。存儲)型的。l只能通過只能通過Load/Store指令對存儲器訪問;指令對存儲器訪問;l其它類型的指令只能基于處理器內(nèi)部寄存器進(jìn)行操作。其它類型的指令只能基于處理器內(nèi)部寄存器進(jìn)行操作。u指令分類指令分類lA R M 指 令 集 可 分 為指 令 集 可 分 為 6 大 類 型 : 數(shù) 據(jù) 處 理 類 指 令 、大 類 型 : 數(shù) 據(jù) 處 理 類 指 令 、LOAD/STORE類指令、跳轉(zhuǎn)類指令

22、、程序狀態(tài)寄存器處類指令、跳轉(zhuǎn)類指令、程序狀態(tài)寄存器處理類指令、協(xié)處理器類指令、異常產(chǎn)生類指令。理類指令、協(xié)處理器類指令、異常產(chǎn)生類指令。44u格式說明格式說明lS:可選后綴;若指定:可選后綴;若指定S,則根據(jù)指令執(zhí)行結(jié)果更新,則根據(jù)指令執(zhí)行結(jié)果更新CPSR的條件碼的條件碼NZCV;lRd:目標(biāo)操作數(shù)的寄存器,可以是:目標(biāo)操作數(shù)的寄存器,可以是R0R15中任意一個;中任意一個;lRn:源操作數(shù)的寄存器,可以是:源操作數(shù)的寄存器,可以是R0R15中任意一個;中任意一個;lOperand2:第二個操作數(shù);:第二個操作數(shù);l:表示:表示內(nèi)的部分是必須的,如內(nèi)的部分是必須的,如是指令助是指令助記符,記

23、符,Opcode是必須書寫的;是必須書寫的;l:表示:表示內(nèi)的部分是可選的;若不書寫,則使用默認(rèn)內(nèi)的部分是可選的;若不書寫,則使用默認(rèn)條件條件AL(無條件執(zhí)行);(無條件執(zhí)行);l、S之間沒有任何分隔符;之間沒有任何分隔符;l操作數(shù)之間可以用操作數(shù)之間可以用“,”、空格或、空格或Tab分割;分割;45u指令格式:指令格式:l S ,u格式說明格式說明lOpcode:操作碼助記符,如:操作碼助記符,如MOV、LDR、STR等;等;lCond:可選執(zhí)行條件助記符,如:可選執(zhí)行條件助記符,如EQ、NE等;等;4647ARM指令小節(jié)1.指令格式2.條件碼3.存儲器訪問指令4.數(shù)據(jù)處理指令5.乘法指令6

24、.ARM分支指令7.雜項指令8.偽指令 ARM指令集存儲器訪問指令48 ARM處理器是典型的RISC處理器,對存儲器的訪問只能使用加載和存儲指令實現(xiàn)。ARM7處理器是馮諾依曼存儲結(jié)構(gòu),RAM存儲空間及I/O映射空間統(tǒng)一編址,除對RAM操作以外,對外圍IO、程序數(shù)據(jù)的訪問均要通過加載/存儲指令進(jìn)行。 存儲器訪問指令分為單寄存器操作指令和多寄存器操作指令。4.2 ARM指令集介紹49助記符說明操作條件碼位置LDR Rd,addressing 加載字?jǐn)?shù)據(jù)Rdaddressing,addressing索引LDRcondLDRB Rd,addressing 加載無符號字節(jié)數(shù)據(jù)Rdaddressing,a

25、ddressing索引LDRcondBLDRT Rd,addressing以用戶模式加載字?jǐn)?shù)據(jù)Rdaddressing,addressing索引LDRcondTLDRBT Rd, addressing 以用戶模式加載無符號字節(jié)數(shù)據(jù)Rdaddressing,addressing索引LDRcondBTLDRH Rd, addressing 加載無符號半字?jǐn)?shù)據(jù)Rdaddressing,addressing索引LDRcondHLDRSB Rd, addressing 加載有符號字節(jié)數(shù)據(jù)Rdaddressing,addressing索引LDRcondSBLDRSH Rd, addressing加載有符號

26、半字?jǐn)?shù)據(jù) Rdaddressing,addressing索引 LDRcondSH ARM存儲器訪問指令單寄存器加載50助記符說明操作條件碼位置STR Rd, addressing 存儲字?jǐn)?shù)據(jù)addressingRd,addressing索引STRcondSTRB Rd,addressing 存儲字節(jié)數(shù)據(jù)addressingRd,addressing索引STRcondBSTRT Rd,addressing 以用戶模式存儲字?jǐn)?shù)據(jù)addressingRd, addressing索引STRcondTSTRBT Rd,addressing 以用戶模式存儲字節(jié)數(shù)據(jù)addressingRd,addressi

27、ng索引STRcondBTSTRH Rd,addressing 存儲半字?jǐn)?shù)據(jù)addressing Rd,addressing索引STRcondHARM存儲器訪問指令單寄存器存儲 LDR/STR指令用于對內(nèi)存變量的訪問、內(nèi)存緩沖區(qū)數(shù)據(jù)的訪問、查表、外圍部件的控制操作等。若使用LDR指令加載數(shù)據(jù)到PC寄存器,則實現(xiàn)程序跳轉(zhuǎn)功能,這樣也就實現(xiàn)了程序散轉(zhuǎn)。 所有單寄存器加載/存儲指令可分為“字和無符號字節(jié)加載存儲指令”和“半字和有符號字節(jié)加載存儲指令“。51LDR和STR字和無符號字節(jié)加載/存儲指令 LDR指令用于從內(nèi)存中讀取單一字或字節(jié)數(shù)據(jù)存入寄存器中,STR指令用于將寄存器中的單一字或字節(jié)數(shù)據(jù)保存

28、到內(nèi)存。指令格式如下:ARM存儲器訪問指令單寄存器存儲 LDRcondTRd, ;將指定地址上的字?jǐn)?shù)據(jù)讀入Rd STRcondTRd, ;將Rd中的字?jǐn)?shù)據(jù)存入指定地址 LDRcondBTRd, ;將指定地址上的字節(jié)數(shù)據(jù)讀入Rd STRcondBTRd, ;將Rd中的字節(jié)數(shù)據(jù)存入指定地址 其中,T為可選后綴。若指令有T,那么即使處理器是在特權(quán)模式下,存儲系統(tǒng)也將訪問看成是在用戶模式下進(jìn)行的。T在用戶模式下無效,不能與前索引偏移一起使用T。 52ARM存儲器訪問指令單寄存器存儲LDR和STR字和無符號字節(jié)加載/存儲指令編碼指令執(zhí)行的條件碼I為0時,偏移量為12位立即數(shù),為1時,偏移量為寄存器移位P

29、表示前/后變址U表示加/減B為1表示字節(jié)訪問,為0表示字訪問W表示回寫為指令的尋址方式Rd為源/目標(biāo)寄存器Rn為基址寄存器L用于區(qū)別加載(L為1)或存儲(L為0)53ARM存儲器訪問指令單寄存器存儲LDR和STR字和無符號字節(jié)加載/存儲指令 LDR/STR指令尋址非常靈活,它由兩部分組成,其中一部分為一個基址寄存器,可以為任一個通用寄存器;另一部分為一個地址偏移量。地址偏移量有以下3種格式: 立即數(shù)。立即數(shù)可以是一個無符號的數(shù)值。這個數(shù)據(jù)可以加到基址寄存器,也可以從基址寄存器中減去這個數(shù)值。 如:LDR R1,R0,#0 x12 ;R1-R0+0 x12寄存器。寄存器中的數(shù)值可以加到基址寄存器

30、,也可以從基址寄存器中減去這個數(shù)值。 如:LDR R1,R0,R2 ; R1-R0+R2 LDR R1,R0,-R2 ; R1-R0-R2寄存器及移位常數(shù)。寄存器移位后的值可以加到基址寄存器,也可以從基址寄存器中減去這個數(shù)值。 如:LDR R1,R0,R2,LSL #2 ;R1-R0+R2*4 54ARM存儲器訪問指令單寄存器存儲 從尋址方式的地址計算方法分,加載/存儲指令有以下4種格式: 零偏移。如:LDR Rd,Rn 前索引偏移。如:LDR Rd,Rn,#0 x04!程序相對偏移。如:LDR Rd,labe1 后索引偏移。如:LDR Rd,Rn,#-0 x04注意:必須保證字?jǐn)?shù)據(jù)操作的地址

31、是32位對齊的。LDR和STR字和無符號字節(jié)加載/存儲指令55LDR和STR半字和有符號字節(jié)加載/存儲指令 這類LDR/STR指令可加載有符號半字或字節(jié),可加載/存儲無符號半字。偏移量格式、尋址方式與加載/存儲字和無符號字節(jié)指令相同。 ARM存儲器訪問指令單寄存器存儲 LDRcondSB Rd, ;將指定地址上的有符號字節(jié)讀入Rd LDRcondSH Rd, ;將指定地址上的有符號半字讀入Rd LDRcondH Rd, ;將指定地址上的半字?jǐn)?shù)據(jù)讀入Rd STRcondH Rd, ;將Rd中的半字?jǐn)?shù)據(jù)存入指定地址注意:1.有符號位半字/字節(jié)加載是指用符號位加載擴(kuò)展到32位,無符號半字加載是指用零

32、擴(kuò)展到32位;2.半字讀寫的指定地址必須為偶數(shù),否則將產(chǎn)生不可靠的結(jié)果;56ARM存儲器訪問指令單寄存器存儲LDR和STR半字和有符號字節(jié)加載/存儲指令編碼指令執(zhí)行的條件碼I為0時,偏移量為12位立即數(shù),為1時,偏移量為寄存器移位P表示前/后變址U表示加/減W表示回寫為指令的尋址方式Rd為源/目標(biāo)寄存器Rn為基址寄存器L用于區(qū)別加載(L為1)或存儲(L為0)S為1表示有符號訪問,為0表示無符號訪問H為1表示半字訪問,為0表示字節(jié)訪問57LDR和STR指令應(yīng)用示例:1.加載/存儲字和無符號字節(jié)指令LDRR2,R5;將R5指向地址的字?jǐn)?shù)據(jù)存入R2STRR1,R0,#0 x04;將R1的數(shù)據(jù)存儲到R

33、0+0 x04地址LDRBR3,R2,#-1 ;將R2指向地址的字節(jié)數(shù)據(jù)存入R3,R2R21STRBR0,R3,-R8 ASR 2 ;R0-R3-R8/4,存儲R0的最低有效字節(jié)2.加載/存儲半字和有符號字節(jié)指令LDRSB R1,R0,R3;將R0+R3地址上的字節(jié)數(shù)據(jù)存入R1,;高24位用符號擴(kuò)展LDRH R6,R2,#2;將R2指向地址的半字?jǐn)?shù)據(jù)存入R6,高16位用0擴(kuò)展;讀出后,R2=R2+2STRH R1,R0,#2!;將R1的半字?jǐn)?shù)據(jù)保存到R0+2地址,;只修改低2字節(jié)數(shù)據(jù),然后R0=R0+2ARM存儲器訪問指令單寄存器存儲3.LDR3.LDR和和STR -STR -雙字:雙字:加載

34、/存儲兩個相鄰的寄存器,64位雙字。其句法有4種:Op cond D Rd,Rn 零偏移Op cond D Rd,Rn,offset ! 前索引偏移Op cond D Rd,label 程序相對偏移Op cond D T Rd,Rn,offset 后索引偏移 58ARM存儲器訪問指令單寄存器存儲其中:其中: Rd 加載/存儲寄存器中的一個,另一個是R(d+1)。Rd必須是偶數(shù)寄存器,且不是R14。 Rn 除非指令為零偏移,或不帶寫回的前索引,否則,Rn不允許與Rd和R(d+1)相同。label label必須是在當(dāng)前指令的上下252字節(jié)范圍內(nèi)。例如:例如:LDRD R6,R11 ;R6R11,

35、R7R11+4STRD R4,R9,#24 ;R4R9+24,R5R9+2859ARM存儲器訪問指令單寄存器存儲60助記符說明操作條件碼位置LDMmode Rn!,reglist 多寄存器加載reglistRn.,Rn回寫等LDMcondmodeSTMmode Rn!,reglist 多寄存器存儲Rn.reglist,Rn回寫等STMcondmodeARM存儲器訪問指令多寄存器存取 多寄存器加載/存儲指令可以實現(xiàn)在一組寄存器和一塊連續(xù)的內(nèi)存單元之間傳輸數(shù)據(jù)。LDM為加載多個寄存器;STM為存儲多個寄存器。允許一條指令傳送16個寄存器的任何子集或所有寄存器。它們主要用于現(xiàn)場保護(hù)、數(shù)據(jù)復(fù)制、常數(shù)傳

36、遞等。61ARM存儲器訪問指令多寄存器存取 多寄存器加載/存儲指令格式如下: LDMcond Rn!,reglist STMcond Rn!,reglistcond:指令執(zhí)行的條件;模式:控制地址的增長方式,一共有8種模式;!:表示在操作結(jié)束后,將最后的地址寫回Rn中;reglist :表示寄存器列表,可以包含多個寄存器,它們使用“,”隔開,如R1,R2,R6-R9,寄存器由小到大排列;:可選后綴。允許在用戶模式或系統(tǒng)模式下使用。它有以下兩個功能:1)若op是LDM且寄存器列表包含R15時,那么除了正常的多寄存器傳送外,還將SPSR也復(fù)制到CPSR中。這用于異常處理返回,僅在異常模式下使用。2

37、)數(shù)據(jù)傳入或傳出的是用戶模式下的寄存器,而不是當(dāng)前模式的寄存器。62ARM存儲器訪問指令多寄存器存取LDM和STM多寄存器加載/存儲指令編碼指令執(zhí)行的條件碼S 對 應(yīng) 于 指 令 中的”符號P表示前/后變址U表示加/減W表示回寫寄存器列表Rn為基址寄存器L用于區(qū)別加載(L為1)或存儲(L為0)63ARM存儲器訪問指令多寄存器存取 多寄存器加載/存儲指令的8種模式如下表所示,右邊四種為堆棧操作、左邊四種為數(shù)據(jù)傳送操作。模式說明模式說明IA每次傳送后地址加4FD滿遞減堆棧IB每次傳送前地址加4ED空遞減堆棧DA每次傳送后地址減4FA滿遞增堆棧DB每次傳送前地址減4EA空遞增堆棧數(shù)據(jù)塊傳送操作堆棧操

38、作 進(jìn)行數(shù)據(jù)復(fù)制時,先設(shè)置好源數(shù)據(jù)指針和目標(biāo)指針,然后使用塊拷貝尋址指令LDMIA/STMIA、LDMIB/STMIB、LDMDA/STMDA、LDMDB/STMDB進(jìn)行讀取和存儲 。 進(jìn)行堆棧操作操作時,要先設(shè)置堆棧指針(SP),然后使用堆棧尋址指令STMFD/LDMFD 、STMED/LDMED、STMFA/LDMFA和STMEA/LDMEA實現(xiàn)堆棧操作。64ARM存儲器訪問指令多寄存器存取數(shù)據(jù)塊傳送指令操作過程如右圖所示,其中R1為指令執(zhí)行前的基址寄存器,R1則為指令執(zhí)行后的基址寄存器。R5R6R7R1 R1 指令STMIA R1!,R5-R74008H4004H4000H4014H40

39、10H400CHR5R6R7R1 R1 指令STMDA R1!,R5-R74008H4004H4000H4014H4010H400CHR5R6R7R1 R1 指令STMIB R1!,R5-R74008H4004H4000H4014H4010H400CHR5R6R7R1 R1 指令STMDB R1!,R5-R74008H4004H4000H4014H4010H400CH65ARM存儲器訪問指令多寄存器存取數(shù)據(jù)塊傳送存儲堆棧操作壓棧說明數(shù)據(jù)塊傳送加載堆棧操作出棧說明STMDASTMED空遞減LDMDALDMFA滿遞減STMIASTMEA空遞增LDMIALDMFD滿遞增STMDBSTMFD滿遞減LD

40、MDBLDMEA空遞減STMIBSTMFA滿遞增LDMIBLDMED空遞增;使用數(shù)據(jù)塊傳送指令進(jìn)行堆棧操作STMDAR0!,R5-R6. . .LDMIBR0!,R5-R6;使用堆棧指令進(jìn)行堆棧操作STMEDR13!,R5-R6. . .LDMEDR13!,R5-R6 兩段代碼的執(zhí)行結(jié)果是一樣的,但是使用堆棧指令的壓棧和出棧操作編程很簡單(只要前后一致即可),而使用數(shù)據(jù)塊指令進(jìn)行壓棧和出棧操作則需要考慮空與滿、加與減對應(yīng)的問題。 堆棧操作(詳見“3.1 尋址方式堆棧尋址”)和數(shù)據(jù)塊傳送指令類似,也有4種模式,它們之間的關(guān)系如下表所示:66助記符說明操作條件碼位置SWP Rd,Rm,Rn 寄存器

41、和存儲器字?jǐn)?shù)據(jù)交換RdRn,RnRm (RnRd或Rm)SWPcondSWPB Rd,Rm,Rn 寄存器和存儲器字節(jié)數(shù)據(jù)交換RdRn,RnRm (RnRd或Rm)SWPcondBARM存儲器訪問指令寄存器和存儲器交換指令 SWP指令用于將一個內(nèi)存單元(該單元地址放在寄存器Rn中)的內(nèi)容讀取到一個寄存器Rd中,同時將另一個寄存器Rm的內(nèi)容寫入到該內(nèi)存單元中。使用SWP可實現(xiàn)信號量操作。 指令格式如下:SWPcondB Rd,Rm,Rn 其中,B為可選后綴,若有B,則交換字節(jié),否則交換32位字;Rd用于保存從存儲器中讀入的數(shù)據(jù);Rm的數(shù)據(jù)用于存儲到存儲器中,若Rm與Rd相同,則為寄存器與存儲器內(nèi)容

42、進(jìn)行互換;Rn為要進(jìn)行數(shù)據(jù)交換的存儲器地址,Rn不能與Rd和Rm相同。 67ARM存儲器訪問指令寄存器和存儲器交換指令SWP和SWPB寄存器和存儲器交換指令編碼指令執(zhí)行的條件碼B用于區(qū)別無符號字節(jié)(B為1)或字(B為0)Rm源寄存器Rd目標(biāo)寄存器Rn為基址寄存器SWP指令應(yīng)用示例:SWPR1,R1,R0;將R1的內(nèi)容與R0指向的存儲單元的內(nèi)容進(jìn)行互換 SWPBR1,R2,R0;將R0指向的存儲單元低字節(jié)數(shù)據(jù)讀取到R1中;(高24位清零),并將R2的內(nèi)容寫入到該內(nèi)存單元中;(最低字節(jié)有效) 68ARM指令小節(jié)1.指令格式2.條件碼3.存儲器訪問指令4.數(shù)據(jù)處理指令5.乘法指令6.ARM分支指令7

43、.雜項指令8.偽指令 ARM指令集ARM數(shù)據(jù)處理指令69 數(shù)據(jù)處理指令大致可分為3類: 數(shù)據(jù)傳送指令;算術(shù)邏輯運算指令;比較指令。 數(shù)據(jù)處理指令只能對寄存器的內(nèi)容進(jìn)行操作,而不能對內(nèi)存中的數(shù)據(jù)進(jìn)行操作。所有ARM數(shù)據(jù)處理指令均可選擇使用S后綴,以使指令影響狀態(tài)標(biāo)志。 4.2 ARM指令集介紹70ARM數(shù)據(jù)處理指令指令編碼指令執(zhí)行的條件碼I用于區(qū)別立即數(shù)(I為1)和寄存器移位(I為0)opcode數(shù)據(jù)處理指令操作碼第二操作數(shù)Rd目標(biāo)寄存器Rn第一操作數(shù)寄存器S設(shè)置條件碼,與指令中的S位對應(yīng)帶進(jìn)位加法ADC0101帶進(jìn)位減法指令SBC0110帶進(jìn)位逆向減法指令RSC0111位測試指令TST1000

44、相等測試指令TEQ1001比較指令CMP1010負(fù)數(shù)比較指令CMN1011邏輯或操作指令ORR1100數(shù)據(jù)傳送MOV1101位清除指令BIC1110數(shù)據(jù)非傳送MVN1111加法運算指令A(yù)DD0100逆向減法指令RSB0011減法運算指令SUB0010邏輯異或操作指令EOR0001邏輯與操作指令A(yù)ND0000說明指令助記符操作碼opcode操作碼功能表71助記符說明操作條件碼位置MOV Rd,operand2數(shù)據(jù)傳送Rdoperand2 MOVcondSMVN Rd,operand2數(shù)據(jù)非傳送Rd(operand2)MVNcondSARM數(shù)據(jù)處理指令數(shù)據(jù)傳送注:當(dāng)后綴S時,這些指令根據(jù)結(jié)果更新標(biāo)

45、志N和Z,在計算Operand2時更新標(biāo)志C,不影響標(biāo)志V。72助記符說明操作條件碼位置MOV Rd,operand2MOV Rd,operand2數(shù)據(jù)傳送Rdoperand2 MOVcondSMVN Rd,operand2數(shù)據(jù)非傳送Rd(operand2)MVNcondSARM數(shù)據(jù)處理指令數(shù)據(jù)傳送 MOV指令將8位圖立即數(shù)或寄存器傳送到目標(biāo)寄存器(Rd),可用于移位運算等操作。指令格式如下: MOVcondS Rd,operand2 MOV指令舉例如下: MOVR1,#0 xF000000B;R1= 0 xF000000B MOVR0,R1;R0=R1 MOVSR3,R1,LSL #2;R3

46、=R12,并影響標(biāo)志位 MOVPC,LR;PC=LR,子程序返回 73助記符說明操作條件碼位置MOV Rd,operand2數(shù)據(jù)傳送Rdoperand2 MOVcondSMVN Rd,operand2MVN Rd,operand2數(shù)據(jù)非傳送Rd(operand2)MVNcondSARM數(shù)據(jù)處理指令數(shù)據(jù)傳送 MVN指令將8位圖立即數(shù)或寄存器(operand2)按位取反后傳送到目標(biāo)寄存器(Rd),因為其具有取反功能,所以可以裝載范圍更廣的立即數(shù)。指令格式如下: MVNcondS Rd,operand2 MVN指令舉例如下: MVNR1,#0 xFF;R1=0 xFFFFFF00 MVNR1,R2;

47、將R2按位取反,結(jié)果存到R174助記符說明操作條件碼位置ADD Rd, Rn, operand2加法運算指令RdRn+operand2ADDcondSSUB Rd, Rn, operand2減法運算指令RdRn-operand2SUBcondSRSB Rd, Rn, operand2逆向減法指令Rdoperand2-RnRSBcondSADC Rd, Rn, operand2帶進(jìn)位加法RdRn+operand2+CarryADCcondSSBC Rd, Rn, operand2帶進(jìn)位減法指令RdRn-operand2-(NOT)CarrySBCcondSRSC Rd, Rn, operand2

48、帶進(jìn)位逆向減法指令Rdoperand2-Rn-(NOT)CarryRSCcondSARM數(shù)據(jù)處理指令算術(shù)運算注:這些指令影響N,Z,C和V標(biāo)志位。75助記符說明操作條件碼位置ADD Rd, Rn, operand2ADD Rd, Rn, operand2加法運算指令RdRn+operand2ADDcondSSUB Rd, Rn, operand2減法運算指令RdRn-operand2SUBcondSRSB Rd, Rn, operand2逆向減法指令Rdoperand2-RnRSBcondSADC Rd, Rn, operand2帶進(jìn)位加法RdRn+operand2+CarryADCcondS

49、SBC Rd, Rn, operand2帶進(jìn)位減法指令RdRn-operand2-(NOT)CarrySBCcondSRSC Rd, Rn, operand2帶進(jìn)位逆向減法指令Rdoperand2-Rn-(NOT)CarryRSCcondSARM數(shù)據(jù)處理指令算術(shù)運算 加法運算指令A(yù)DD指令將operand2的值與Rn的值相加,結(jié)果保存到Rd寄存器。指令格式如下: ADDcondS Rd,Rn,operand2 應(yīng)用示例: ADDS R1,R1,#1020;R1=R1+1020,并影響標(biāo)志位 ADD R1,R1,R2,LSL #2;R1=R1+R22 76助記符說明操作條件碼位置ADD Rd,

50、Rn, operand2加法運算指令RdRn+operand2ADDcondSSUB Rd, Rn, operand2SUB Rd, Rn, operand2減法運算指令RdRn-operand2SUBcondSRSB Rd, Rn, operand2逆向減法指令Rdoperand2-RnRSBcondSADC Rd, Rn, operand2帶進(jìn)位加法RdRn+operand2+CarryADCcondSSBC Rd, Rn, operand2帶進(jìn)位減法指令RdRn-operand2-(NOT)CarrySBCcondSRSC Rd, Rn, operand2帶進(jìn)位逆向減法指令Rdopera

51、nd2-Rn-(NOT)CarryRSCcondSARM數(shù)據(jù)處理指令算術(shù)運算 減法運算指令SUB指令用寄存器Rn減去operand2,結(jié)果保存到Rd中。指令格式如下: SUBcondS Rd,Rn,operand2 應(yīng)用示例: SUBSR0,R0,#240;R0=R0-240 ,并影響標(biāo)志位 SUBSR2,R1,R2;R2=R1-R2 ,并影響標(biāo)志位 77助記符說明操作條件碼位置ADD Rd, Rn, operand2加法運算指令RdRn+operand2ADDcondSSUB Rd, Rn, operand2減法運算指令RdRn-operand2SUBcondSRSB Rd, Rn, ope

52、rand2RSB Rd, Rn, operand2逆向減法指令Rdoperand2-RnRSBcondSADC Rd, Rn, operand2帶進(jìn)位加法RdRn+operand2+CarryADCcondSSBC Rd, Rn, operand2帶進(jìn)位減法指令RdRn-operand2-(NOT)CarrySBCcondSRSC Rd, Rn, operand2帶進(jìn)位逆向減法指令Rdoperand2-Rn-(NOT)CarryRSCcondSARM數(shù)據(jù)處理指令算術(shù)運算 逆向減法運算指令RSB指令將operand2的值減去Rn,結(jié)果保存到Rd中。指令格式如下: RSBcondS Rd,Rn,o

53、perand2 應(yīng)用示例: RSB R3,R1,#0 xFF00 ;R3=0 xFF00-R1 RSBS R1,R2,R2,LSL #2 ;R1=(R210, 則執(zhí)行本指令 88助記符說明操作條件碼位置CMP Rn, operand2比較指令標(biāo)志N、Z、C、VRn-operand2CMPcondCMN Rn, operand2CMN Rn, operand2負(fù)數(shù)比較指令標(biāo) 志 N 、 Z 、 C 、VRn+operand2CMNcondTST Rn, operand2位測試指令標(biāo)志N、Z、C、VRn & operand2TSTcondTEQ Rn, operand2相等測試指令標(biāo)志N、Z、C、

54、VRn operand2TEQcondARM數(shù)據(jù)處理指令比較指令 負(fù)數(shù)比較指令CMN指令使用寄存器Rn的值加上operand2的值,根據(jù)操作的結(jié)果更新CPSR中的相應(yīng)條件標(biāo)志位,以便后面的指令根據(jù)相應(yīng)的條件標(biāo)志來判斷是否執(zhí)行。指令格式如下: CMNcondRn, operand2 應(yīng)用示例: CMNR0,#1 ; R0+1,判斷R0是否為1的補碼;如果是,則設(shè)置Z標(biāo)志位89助記符說明操作條件碼位置CMP Rn, operand2比較指令標(biāo)志N、Z、C、VRn-operand2CMPcondCMN Rn, operand2CMN Rn, operand2負(fù)數(shù)比較指令標(biāo) 志 N 、 Z 、 C 、

55、VRn+operand2CMNcondTST Rn, operand2位測試指令標(biāo)志N、Z、C、VRn & operand2TSTcondTEQ Rn, operand2相等測試指令標(biāo)志N、Z、C、VRn operand2TEQcondARM數(shù)據(jù)處理指令比較指令 負(fù)數(shù)比較指令CMN指令使用寄存器Rn的值加上operand2的值,根據(jù)操作的結(jié)果更新CPSR中的相應(yīng)條件標(biāo)志位,以便后面的指令根據(jù)相應(yīng)的條件標(biāo)志來判斷是否執(zhí)行。指令格式如下: CMNcondRn, operand2注意:CMN指令與ADDS指令的區(qū)別在于CMN指令不保存運算結(jié)果。CMN指令可用于負(fù)數(shù)比較,比如CMN R0,#1指令則表

56、示R0與-1比較,若R0為-1(即1的補碼),則Z置位;否則Z復(fù)位。 90助記符說明操作條件碼位置CMP Rn, operand2比較指令標(biāo)志N、Z、C、VRn-operand2CMPcondCMN Rn, operand2負(fù)數(shù)比較指令標(biāo) 志 N 、 Z 、 C 、VRn+operand2CMNcondTST Rn, operand2TST Rn, operand2位測試指令標(biāo)志N、Z、C、VRn & operand2TSTcondTEQ Rn, operand2相等測試指令標(biāo)志N、Z、C、VRn operand2TEQcondARM數(shù)據(jù)處理指令比較指令 位測試指令TST指令將寄存器Rn的值與

57、operand2的值按位作邏輯“與”操作,根據(jù)操作的結(jié)果更新CPSR中的相應(yīng)條件標(biāo)志位,以便后面的指令根據(jù)相應(yīng)的條件標(biāo)志來判斷是否執(zhí)行。指令格式如下: TSTcond Rn, operand2 應(yīng)用示例: TSTR0,#0 x01; 判斷R0的最低位是否為0 TSTR1,#0 x0F; 判斷R1的低4位是否為0 91助記符說明操作條件碼位置CMP Rn, operand2比較指令標(biāo)志N、Z、C、VRn-operand2CMPcondCMN Rn, operand2負(fù)數(shù)比較指令標(biāo) 志 N 、 Z 、 C 、VRn+operand2CMNcondTST Rn, operand2TST Rn, op

58、erand2位測試指令標(biāo)志N、Z、C、VRn & operand2TSTcondTEQ Rn, operand2相等測試指令標(biāo)志N、Z、C、VRn operand2TEQcondARM數(shù)據(jù)處理指令比較指令 位測試指令TST指令將寄存器Rn的值與operand2的值按位作邏輯“與”操作,根據(jù)操作的結(jié)果更新CPSR中的相應(yīng)條件標(biāo)志位,以便后面的指令根據(jù)相應(yīng)的條件標(biāo)志來判斷是否執(zhí)行。指令格式如下: TSTcond Rn, operand2注意:TST指令與ANDS指令的區(qū)別在于TST指令不保存運算結(jié)果。TST指令通常與EQ、NE條件碼配合使用,當(dāng)所有測試位均為0時,EQ有效(Z=1),而只要有一個測

59、試位不為0,則NE有效(Z=0) 。 92助記符說明操作條件碼位置CMP Rn, operand2比較指令標(biāo)志N、Z、C、VRn-operand2CMPcondCMN Rn, operand2負(fù)數(shù)比較指令標(biāo) 志 N 、 Z 、 C 、VRn+operand2CMNcondTST Rn, operand2位測試指令標(biāo)志N、Z、C、VRn & operand2TSTcondTEQ Rn, operand2TEQ Rn, operand2相等測試指令標(biāo)志N、Z、C、VRn operand2TEQcondARM數(shù)據(jù)處理指令比較指令 相等測試指令TEQ指令將寄存器Rn的值與operand2的值按位作邏輯

60、“異或”操作,根據(jù)操作的結(jié)果更新CPSR中的相應(yīng)條件標(biāo)志位,以便后面的指令根據(jù)相應(yīng)的條件標(biāo)志來判斷是否執(zhí)行。指令格式如下: TEQcond Rn, operand2 應(yīng)用示例: TEQR0,R1; 比較R0與R1是否相等 (不影響V位和C位)93助記符說明操作條件碼位置CMP Rn, operand2比較指令標(biāo)志N、Z、C、VRn-operand2CMPcondCMN Rn, operand2負(fù)數(shù)比較指令標(biāo) 志 N 、 Z 、 C 、VRn+operand2CMNcondTST Rn, operand2位測試指令標(biāo)志N、Z、C、VRn & operand2TSTcondTEQ Rn, oper

溫馨提示

  • 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

提交評論