Thumb指令集之: 單寄存器數(shù)據(jù)傳送指令
11.5.14字節(jié)存儲(chǔ)指令STRB(1)
(1)編碼格式
字節(jié)存儲(chǔ)加載指令STRB(1)的編碼格式如圖11.55所示。
圖11.55STRB(1)指令的編碼格式
STRB(1)字節(jié)數(shù)據(jù)存儲(chǔ)指令用于將一個(gè)8位的字節(jié)數(shù)據(jù)寫入到指令中指定的內(nèi)存單元,該字節(jié)數(shù)據(jù)為指令中存放源操作數(shù)寄存器的低8位。常用于結(jié)構(gòu)體的數(shù)據(jù)訪問。域的基地址放在Rn寄存器中。
(2)指令的語法格式
STRBRd>,[Rn>,#immed_5>]
①Rd>
目的寄存器。
②Rn>
指令的基址寄存器。
③immed_5>
5位立即數(shù)。用于與Rn>寄存器中的數(shù)值相加,形成內(nèi)存訪問地址。
(3)指令操作的偽代碼
address=Rn+immed_5
Memory[address,1]=Rd[7:0]
(4)對應(yīng)的ARM指令
STRBRd>,[Rn>,#immed_5>]
11.5.15寄存器存儲(chǔ)指令STRB(2)
(1)編碼格式
寄存器存儲(chǔ)指令STRB(2)的編碼格式如圖11.56所示。
圖11.56STRB(2)指令的編碼格式
寄存器存儲(chǔ)指令STRB(2)用于將一個(gè)8位的字節(jié)數(shù)據(jù)寫入到指令中指定的內(nèi)存單元。此種形式的LDRB指令常被用于訪問數(shù)組中的元素。
(2)指令的語法格式
STRBRd>,[Rn>,Rm>]
①Rd>
目的寄存器。
②Rn>
此寄存器存放內(nèi)存訪問基地址。
③Rm>
此寄存器存放內(nèi)存訪問偏移地址。
(3)指令操作的偽代碼
address=Rn+Rm
Memory[address,1]=Rd[7:0]
(4)對應(yīng)的ARM指令
STRBRd>,[Rn>,Rm>]
評論