Вот кодировка MOV T2 (из Справочное руководство по архитектуре ARM )
11110 i 0 0010 S 1111 0 imm3 rd imm8
d = UInt(Rd);
setflags = (S == ‘1’);
(imm32, carry) = ThumbExpandImm_C(i:imm3:imm8, APSR.C);
if d IN {13,15} then UNPREDICTABLE;
Поскольку ваш шаблон
i S imm3 rd imm8
11110 1 0 0010 0 1111 0 111 0001 11110000
У вас естьi=1, S=0, imm3=111, imm8=11110000
Проверяя , что ThumbExpandImm_C () делает , вы поймете, как значения стали 0x1e0
// ThumbExpandImm_C()
// ==================
(bits(32), bit) ThumbExpandImm_C(bits(12) imm12, bit carry_in)
if imm12<11:10> == ‘00’ then
case imm12<9:8> of
when ‘00’
imm32 = ZeroExtend(imm12<7:0>, 32);
when ‘01’
if imm12<7:0> == ‘00000000’ then UNPREDICTABLE;
imm32 = ‘00000000’ : imm12<7:0> : ‘00000000’ : imm12<7:0>;
when ‘10’
if imm12<7:0> == ‘00000000’ then UNPREDICTABLE;
imm32 = imm12<7:0> : ‘00000000’ : imm12<7:0> : ‘00000000’;
when ‘11’
if imm12<7:0> == ‘00000000’ then UNPREDICTABLE;
imm32 = imm12<7:0> : imm12<7:0> : imm12<7:0> : imm12<7:0>;
carry_out = carry_in;
else
unrotated_value = ZeroExtend(‘1’:imm12<6:0>, 32); <--- a
(imm32, carry_out) = ROR_C(unrotated_value, UInt(imm12<11:7>)); <--- b
return (imm32, carry_out);
Наши imm12 = i:imm3:imm8 (1:111:11110000) = 1111 1111 0000
Наши значения будут проходить через строки (a) и (b), поскольку старшие 2 бита [11,10] равны '11'
ZeroExtend ('1': imm12 <6: 0>, 32) означает, что вы должны добавить «1» к [6..0] битам.Таким образом, значение становится 1:1110000 = 11110000
(a)
ROR_C (unrotated_value, UInt (imm12 <11: 7>)) вращается вправо на [11: 7] = 11111 = 31, что является same as rotate left by 1
.(б)
Таким образом, полученное значение равно 1 1110 0000 (a shifted by b) = 0x1e0