{ARM_EXT_V6T2, 0xf3ef8000, 0xffeff0ff, "mrs\t%8-11r, %20?CSPSR"},
{ARM_EXT_V6T2, 0xf3af8100, 0xffffffe0, "cps\t#%0-4d"},
{ARM_EXT_V6T2, 0xe8d0f000, 0xfff0fff0, "tbb\t[%16-19r, %0-3r]"},
- {ARM_EXT_V6T2, 0xe8d0f010, 0xfff0fff0, "tbh\t[%16-19r, %0-3r]"},
+ {ARM_EXT_V6T2, 0xe8d0f010, 0xfff0fff0, "tbh\t[%16-19r, %0-3r, lsl #1]"},
{ARM_EXT_V6T2, 0xf3af8500, 0xffffff00, "cpsie\t%7'a%6'i%5'f, #%0-4d"},
{ARM_EXT_V6T2, 0xf3af8700, 0xffffff00, "cpsid\t%7'a%6'i%5'f, #%0-4d"},
{ARM_EXT_V6T2, 0xf3de8f00, 0xffffff00, "subs\tpc, lr, #%0-7d"},
unsigned int imm12 = 0;
imm12 |= (given & 0x000000ffu);
imm12 |= (given & 0x00007000u) >> 4;
- imm12 |= (given & 0x04000000u) >> 12;
+ imm12 |= (given & 0x04000000u) >> 15;
func (stream, "#%u\t; 0x%x", imm12, imm12);
}
break;
offset = -i8;
break;
- case 0xB: /* 8-bit + preindex with wb */
+ case 0xF: /* 8-bit + preindex with wb */
offset = i8;
writeback = TRUE;
break;
- case 0x9: /* 8-bit - preindex with wb */
+ case 0xD: /* 8-bit - preindex with wb */
offset = -i8;
writeback = TRUE;
break;
- case 0xF: /* 8-bit + postindex */
+ case 0xB: /* 8-bit + postindex */
offset = i8;
postind = TRUE;
break;
- case 0xD: /* 8-bit - postindex */
+ case 0x9: /* 8-bit - postindex */
offset = -i8;
postind = TRUE;
break;