我有一个项目,在其中我得到一个 32 位 ARM 指令的向量,并且需要将部分指令(偏移值)读取为有符号(二进制补码)数字而不是无符号数字。
我使用了uint32_t
向量,因为所有操作码和寄存器都被读取为无符号并且整个指令是 32 位的。
例如:
我有这个 32 位 ARM 指令编码:
uint32_t addr = 0b00110001010111111111111111110110
最后 19 位是我需要读取为有符号整数分支位移的分支的偏移量。 本部分:1111111111111110110
我有这个函数,其中参数是整个 32 位指令:我向左移动 13 位,然后再次向右移动 13 位,以仅具有偏移值并移动指令的另一部分。
我已经尝试将此函数转换为不同的签名变量,使用不同的转换方式和使用其他 c++ 函数,但它会打印未签名的数字。
int getCat1BrOff(uint32_t inst)
{
uint32_t temp = inst << 13;
uint32_t brOff = temp >> 13;
return (int)brOff;
}
我得到十进制数524278 而不是 -10。
我认为最后一个选项不是最好的,但它可能有效的是在字符串中设置所有二进制值。反转位并加 1 以转换它们,然后将新的二进制数转换回十进制。正如我在论文中所做的那样,但这不是一个好的解决方案。