久久ER99热精品一区二区-久久精品99国产精品日本-久久精品免费一区二区三区-久久综合九色综合欧美狠狠

新聞中心

EEPW首頁 > 嵌入式系統 > 設計應用 > ARM裸機開發筆記5ARM指令集

ARM裸機開發筆記5ARM指令集

作者: 時間:2016-11-19 來源:網絡 收藏
跳轉指令:最簡單的這屆修改PC的值

以下指令中可以完成從當前指令向前或向后的32M的地址空間的跳轉

本文引用地址:http://cqxgywz.com/article/201611/318206.htm

B{條件} 目標地址 ;花括號表示條件,可以省略

最簡單的跳轉指令,一旦遇到一個B指令,ARM處理器將立即跳轉到給定的目標地址,從那里繼續執行

CMP R!,#0

BEQ Label ;EQ相等

當CPSR寄存器中的Z條件碼位置時,程序跳轉到標號Label處執行


BL

BL{條件} 目標地址

跳轉之前,會在寄存器R14中保存PC當前值。因此可以通過將R14的內容重新加載到PC中,來返回到跳轉指令之后的那個指令處執行。該指令是實現子程序調用的一個基本但常用的手段。

BLX

X表示跳轉到指定地址的同時,將工作狀態從ARM狀態切換到Thumb狀態,該指令同時將PC的當前內容保存到R14中

因此當子程序使用Thumb指令集,而調用者使用ARM指令集時,可以通過BLX指令實現子程序的調用和處理器工作狀態,同時,子程序的返回可以通過將寄存器R14值到PC中來完成。

BX 跳轉并切換狀態

數據處理指令

MOV指令

MOV{條件}{S} 目標寄存器,源操作數 ----------》S加上可能會影響CPSR中的標志位。不加指令不更新CPSR。一般都不加。源操作數不可以是內存

MVN{條件}{S} 在傳送之前把源操作數按位取反

CMP指令

TST指令 測試某一個位是否被設置了

TST R1,#%1 結果 ;用于測試在寄存器R1中是否設置了最低位(%表示二進制數)對操作數1與操作數2進行按位的與運算,結果為0 ,EQ位將被設置

LDR R5,=0xffffffff
TST R5,#(1<<23) ;當bit23位為1時,CPSR EQ位被設置

MOVEQ R5,#0x00 ---->不執行詞語據,不滿足EQ
MOVNE R5,#0x01

ADD指令 加

SUB指令 減

AND 邏輯與

ORR 邏輯或

BIC Rd,Rn,operand2 用于將Rn中的某些位清零。并把結果存放在Rd中,操作數operand2為32位的掩碼,如果掩碼設置了某一位為1,則清除這一位。

BIC R0,R0,#%1011 ;將R0的0,1,3位清零,其余位保持不變。

MUL乘法指令

程序狀態字的訪問指令

MRS{條件} 通用寄存器,程序狀態寄存器(CPSR/SPSR)

將程序狀態寄存器的內容傳送到通用寄存器中

1.當需要改變程序狀態寄存器內容時,可用MRS將程序狀態寄存器的內容讀入通用寄存器,修改后再寫回程序狀態寄存器。

2.當在異常處理或進程切換時,需要保存程序狀態寄存器的值,可先用該指令讀出程序狀態寄存器的值,然后保存。

MRS R0,SPSR ;傳送CPSR的內容到R0

MSR指令

MSR 程序狀態寄存器(CPSR/SPSR)_<域> ,操作數

將操作數的內容傳送到程序狀態寄存器或其特定域中。其中操作數可以是通用寄存器或立即數。<域>用于設置程序狀態寄存器中需要操作的位,32位的程序狀態寄存器可以分為4個域

位為條件標志位,用f表示。位為狀態域位,用s表示。為為擴展位域,用x表示。為為控制位域,用c表示

該指令通常用于或改變程序狀態寄存器的內容,在使用時,一般要在MSR指令中指明將要操作的域。

MSR CPSR,R0

MSR SPSR,R0 ;傳送R0內容帶SPSR

MSR CPSR_c,R0 ;傳送R0到CPSR,但僅僅修改CPSR中的控制位域

訪問內存

寄存器和存儲器之間傳送數據

加載和存儲指令

LDR 目地寄存器,<存儲器地址>

從存儲器中將一個32位數據傳送到目地寄存器中

LDRB 目的寄存器,<存儲器地址>

LDRB用于從存儲器中將一個8位的字節數據傳送到目的寄存器中,同時將寄存器的高24位清零。該指令通常用于從存儲器中讀取8位的字節數據到通用寄存器,然后對數據進行處理。

LDRH

和LDRB操作類似,是取一個16位的數據

STR 源寄存器,<存儲器地址>

STR從源寄存器中將一個32為的字數據傳到存儲器中

批量加載存儲指令

LDM

STM

數據交換指令

SWP

SWPB

移位指令(邏輯移位不考慮正負號,算數移位考慮正負號)

LSL  邏輯左移

ASL 算數左移

LSR 邏輯右移

ASR 算數右移

ROR 循環右移

異常產生指令

ARM支持的異常產生指令有如下兩條

SWI:軟件中斷指令

BKPT:斷點中斷指令



關鍵詞: ARM裸機開發指令

評論


技術專區

關閉