數(shù)據(jù)傳送指令之:?jiǎn)渭拇嫫鞯腖oad/Store指令
2.STR指令
(1)指令編碼格式
STR指令用于將一個(gè)32位的字?jǐn)?shù)據(jù)寫(xiě)入到指令中指定的內(nèi)存單元。
指令的編碼格式如圖5.4所示。
圖5.4 STR指令編碼格式
(2)指令的語(yǔ)法格式
STR{cond>} Rd>,addr_mode>
① cond>
為指令編碼中的條件域。它指示STR指令在什么條件下執(zhí)行。當(dāng)cond>忽略時(shí),指令為無(wú)條件執(zhí)行(cond=AL(Alway))。
② Rd>
確定使用哪個(gè)通用寄存器作為目標(biāo)寄存器。
③ addr_mode>
它確定了指令編碼中的I、P、U、W、Rn和addr_mode>位。所有的尋址模式中,都會(huì)確定一個(gè)基址寄存器Rn。
(3)指令操作的偽代碼
指令操作的偽代碼如下面程序段所示。
If ConditionPassed{cond} then
Memory[address,4]=Rd
(4)指令舉例
LDR/STR指令用于對(duì)內(nèi)存變量的訪問(wèn)、內(nèi)存緩沖區(qū)數(shù)據(jù)的訪問(wèn)、查表、外圍部件的控制操作等等,若使用LDR指令加載數(shù)據(jù)到PC寄存器,則實(shí)現(xiàn)程序跳轉(zhuǎn)功能,這樣也就實(shí)現(xiàn)了程序散轉(zhuǎn)。
① 變量訪問(wèn)
NumCount EQU 0x40003000 ;定義變量NumCount
LDR R0,=NumCount ;使用LDR偽指令裝載NumCount的地址到R0
LDR R1,[R0] ;取出變量值
ADD R1,R1,#1 ;NumCount=NumCount+1
STR R1,[R0] ;保存變量
② GPIO設(shè)置
GPIO—BASE EQU 0xe0028000 ;定義GPIO寄存器的基地址
……
LDR R0,=GPIO—BASE
LDR R1,=0x00ffff00 ;將設(shè)置值放入寄存器
STR R1,[R0,#0x0C] ;IODIR=0x00ffff00,IOSET的地址為0xE0028004
③ 程序散轉(zhuǎn)
…
MOV r2,r2,LSL #2 ;功能號(hào)乘以4,以便查表
LDR PC,[PC,r2] ;查表取得對(duì)應(yīng)功能子程序地址,并跳轉(zhuǎn)
NOP
FUN—TAB DCD FUN—SUB0
DCD FUN—SUB1
DCD FUN—SUB2
…
存儲(chǔ)器相關(guān)文章:存儲(chǔ)器原理
評(píng)論