Thumb指令集之: 單寄存器數(shù)據(jù)傳送指令
11.5.11寄存器存儲指令STR(1)
(1)編碼格式
寄存器存儲指令STR(1)的編碼格式如圖11.52所示。
圖11.52STR(1)指令的編碼格式
這種形式的STR指令將32位通用寄存器的數(shù)值存儲到內(nèi)存中。該指令常用于結(jié)構(gòu)體的數(shù)據(jù)訪問。域的基地址放在Rn寄存器中。
(2)指令的語法格式
STRRd>,[Rn>,#immed_5>*4]
①Rd>
目的寄存器。用于存放從內(nèi)存中取出的數(shù)據(jù)。
②Rn>
基址寄存器,用于存放所取數(shù)據(jù)的基地址。
③immed_5>
5位立即數(shù)。該立即數(shù)的4倍加上基址寄存器的值為目標(biāo)地址。
(3)指令操作的偽代碼
address=Rn+(immed_5*4)
ifaddress[1:0]==0b00
Memory[address,4]=Rd
Else
Memory[address,4]=UNPREDICTABLE
(4)對應(yīng)的ARM指令
STRRd>,[Rn>,#immed_5>*4]
評論