- SDM指令功能描述(BSWAP)
总体描述:
以字节为单位,把32/64位寄存器的值按照低和高的字节交换(详见伪代码)。
此指令默认的operand size是32bit,如果要使用64位寄存器,那么需要使用前缀;如果需要使用寄存器R8-R15,那么需要使用前缀。
注意:BSWAP指令不支持16位模式
- 伪代码
TEMP = DEST;
if(64bit-mode and operandSize == 64)
{
DEST[7:0] = TEMP[63:56]
DEST[15:8] = TEMP[55:48]
DEST[23:16] = TEMP[47:40]
DEST[31:24] = TEMP[39:32]
DEST[39:32] = TEMP[31:24]
DEST[47:40] = TEMP[23:16]
DEST[55:48] = TEMP[15:8]
DEST[63:56] = TEMP[7:0]
}
else
{
DEST[7:0] = TEMP[31:24]
DEST[15:8] = TEMP[23:16]
DEST[23:16] = TEMP[15:8]
DEST[31:24] = TEMP[7:0]
}