X86: Implement the bswap instruction.
This commit is contained in:
parent
919c3e7fb6
commit
3c5988b86c
|
@ -915,7 +915,11 @@
|
||||||
default: Inst::UD2();
|
default: Inst::UD2();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
0x19: bswap_B();
|
0x19: decode OPSIZE {
|
||||||
|
4: Inst::BSWAP_D(Bd);
|
||||||
|
8: Inst::BSWAP_Q(Bq);
|
||||||
|
default: Inst::UD2();
|
||||||
|
}
|
||||||
0x1A: decode LEGACY_DECODEVAL {
|
0x1A: decode LEGACY_DECODEVAL {
|
||||||
// no prefix
|
// no prefix
|
||||||
0x0: decode OPCODE_OP_BOTTOM3 {
|
0x0: decode OPCODE_OP_BOTTOM3 {
|
||||||
|
|
|
@ -53,7 +53,25 @@
|
||||||
#
|
#
|
||||||
# Authors: Gabe Black
|
# Authors: Gabe Black
|
||||||
|
|
||||||
microcode = ""
|
microcode = '''
|
||||||
|
def macroop BSWAP_D_R
|
||||||
|
{
|
||||||
|
roli reg, reg, 8, dataSize=2
|
||||||
|
roli reg, reg, 16, dataSize=4
|
||||||
|
roli reg, reg, 8, dataSize=2
|
||||||
|
};
|
||||||
|
|
||||||
|
def macroop BSWAP_Q_R
|
||||||
|
{
|
||||||
|
roli reg, reg, 8, dataSize=2
|
||||||
|
roli reg, reg, 16, dataSize=4
|
||||||
|
roli reg, reg, 8, dataSize=2
|
||||||
|
roli reg, reg, 32, dataSize=8
|
||||||
|
roli reg, reg, 8, dataSize=2
|
||||||
|
roli reg, reg, 16, dataSize=4
|
||||||
|
roli reg, reg, 8, dataSize=2
|
||||||
|
};
|
||||||
|
'''
|
||||||
#let {{
|
#let {{
|
||||||
# class BSWAP(Inst):
|
# class BSWAP(Inst):
|
||||||
# "GenFault ${new UnimpInstFault}"
|
# "GenFault ${new UnimpInstFault}"
|
||||||
|
|
Loading…
Reference in a new issue