mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
Fix assembling of xchg %eax, %eax to not use the NOP encoding of 0x90. This was done by creating a new register group that excludes AX registers. Fixes PR10345. Also added aliases for flipping the order of the operands of xchg <reg>, %eax.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@141274 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
cf2adb945a
commit
7ea16b01fa
@ -1154,11 +1154,11 @@ def XCHG64rr : RI<0x87, MRMSrcReg, (outs GR64:$dst), (ins GR64:$val,GR64:$src),
|
||||
"xchg{q}\t{$val, $src|$src, $val}", []>;
|
||||
}
|
||||
|
||||
def XCHG16ar : I<0x90, AddRegFrm, (outs), (ins GR16:$src),
|
||||
def XCHG16ar : I<0x90, AddRegFrm, (outs), (ins GR16_NOAX:$src),
|
||||
"xchg{w}\t{$src, %ax|AX, $src}", []>, OpSize;
|
||||
def XCHG32ar : I<0x90, AddRegFrm, (outs), (ins GR32:$src),
|
||||
def XCHG32ar : I<0x90, AddRegFrm, (outs), (ins GR32_NOAX:$src),
|
||||
"xchg{l}\t{$src, %eax|EAX, $src}", []>;
|
||||
def XCHG64ar : RI<0x90, AddRegFrm, (outs), (ins GR64:$src),
|
||||
def XCHG64ar : RI<0x90, AddRegFrm, (outs), (ins GR64_NOAX:$src),
|
||||
"xchg{q}\t{$src, %rax|RAX, $src}", []>;
|
||||
|
||||
|
||||
@ -1714,3 +1714,8 @@ def : InstAlias<"xchgb $mem, $val", (XCHG8rm GR8 :$val, i8mem :$mem)>;
|
||||
def : InstAlias<"xchgw $mem, $val", (XCHG16rm GR16:$val, i16mem:$mem)>;
|
||||
def : InstAlias<"xchgl $mem, $val", (XCHG32rm GR32:$val, i32mem:$mem)>;
|
||||
def : InstAlias<"xchgq $mem, $val", (XCHG64rm GR64:$val, i64mem:$mem)>;
|
||||
|
||||
// xchg: We accept "xchgX <reg>, %eax" and "xchgX %eax, <reg>" as synonyms.
|
||||
def : InstAlias<"xchgw %ax, $src", (XCHG16ar GR16_NOAX:$src)>;
|
||||
def : InstAlias<"xchgl %eax, $src", (XCHG32ar GR32_NOAX:$src)>;
|
||||
def : InstAlias<"xchgq %rax, $src", (XCHG64ar GR64_NOAX:$src)>;
|
||||
|
@ -390,6 +390,23 @@ def GR64_NOREX : RegisterClass<"X86", [i64], 64,
|
||||
(GR32_NOREX sub_32bit)];
|
||||
}
|
||||
|
||||
// GR16_NOAX - GR16 registers except AX.
|
||||
def GR16_NOAX : RegisterClass<"X86", [i16], 16, (sub GR16, AX)> {
|
||||
let SubRegClasses = [(GR8 sub_8bit, sub_8bit_hi)];
|
||||
}
|
||||
|
||||
// GR32_NOAX - GR32 registers except EAX.
|
||||
def GR32_NOAX : RegisterClass<"X86", [i32], 32, (sub GR32, EAX)> {
|
||||
let SubRegClasses = [(GR8 sub_8bit, sub_8bit_hi), (GR16_NOAX sub_16bit)];
|
||||
}
|
||||
|
||||
// GR64_NOAX - GR64 registers except RAX.
|
||||
def GR64_NOAX : RegisterClass<"X86", [i64], 64, (sub GR64, RAX)> {
|
||||
let SubRegClasses = [(GR8 sub_8bit, sub_8bit_hi),
|
||||
(GR16_NOAX sub_16bit),
|
||||
(GR32_NOAX sub_32bit)];
|
||||
}
|
||||
|
||||
// GR32_NOSP - GR32 registers except ESP.
|
||||
def GR32_NOSP : RegisterClass<"X86", [i32], 32, (sub GR32, ESP)> {
|
||||
let SubRegClasses = [(GR8 sub_8bit, sub_8bit_hi), (GR16 sub_16bit)];
|
||||
|
@ -946,3 +946,19 @@ fsubp %st,%st(1)
|
||||
// CHECK: encoding: [0xde,0xe2]
|
||||
fsubp %st, %st(2)
|
||||
|
||||
// PR10345
|
||||
// CHECK: xchgl %eax, %eax
|
||||
// CHECK: encoding: [0x87,0xc0]
|
||||
xchgl %eax, %eax
|
||||
|
||||
// CHECK: xchgw %ax, %ax
|
||||
// CHECK: encoding: [0x66,0x87,0xc0]
|
||||
xchgw %ax, %ax
|
||||
|
||||
// CHECK: xchgl %ecx, %eax
|
||||
// CHECK: encoding: [0x91]
|
||||
xchgl %ecx, %eax
|
||||
|
||||
// CHECK: xchgl %ecx, %eax
|
||||
// CHECK: encoding: [0x91]
|
||||
xchgl %eax, %ecx
|
||||
|
@ -1170,3 +1170,24 @@ pclmullqhqdq (%rdi), %xmm1
|
||||
// CHECK: pclmulqdq $0, (%rdi), %xmm1
|
||||
// CHECK: encoding: [0x66,0x0f,0x3a,0x44,0x0f,0x00]
|
||||
pclmulqdq $0, (%rdi), %xmm1
|
||||
|
||||
// PR10345
|
||||
// CHECK: xchgq %rax, %rax
|
||||
// CHECK: encoding: [0x48,0x87,0xc0]
|
||||
xchgq %rax, %rax
|
||||
|
||||
// CHECK: xchgl %eax, %eax
|
||||
// CHECK: encoding: [0x87,0xc0]
|
||||
xchgl %eax, %eax
|
||||
|
||||
// CHECK: xchgw %ax, %ax
|
||||
// CHECK: encoding: [0x66,0x87,0xc0]
|
||||
xchgw %ax, %ax
|
||||
|
||||
// CHECK: xchgl %ecx, %eax
|
||||
// CHECK: encoding: [0x91]
|
||||
xchgl %ecx, %eax
|
||||
|
||||
// CHECK: xchgl %ecx, %eax
|
||||
// CHECK: encoding: [0x91]
|
||||
xchgl %eax, %ecx
|
||||
|
@ -256,12 +256,15 @@ static int X86TypeFromOpName(LiteralConstantEmitter *type,
|
||||
REG("GR8");
|
||||
REG("GR8_NOREX");
|
||||
REG("GR16");
|
||||
REG("GR16_NOAX");
|
||||
REG("GR32");
|
||||
REG("GR32_NOAX");
|
||||
REG("GR32_NOREX");
|
||||
REG("GR32_TC");
|
||||
REG("FR32");
|
||||
REG("RFP32");
|
||||
REG("GR64");
|
||||
REG("GR64_NOAX");
|
||||
REG("GR64_TC");
|
||||
REG("FR64");
|
||||
REG("VR64");
|
||||
|
@ -1064,6 +1064,9 @@ OperandType RecognizableInstr::typeFromString(const std::string &s,
|
||||
TYPE("offset32", TYPE_MOFFS32)
|
||||
TYPE("offset64", TYPE_MOFFS64)
|
||||
TYPE("VR256", TYPE_XMM256)
|
||||
TYPE("GR16_NOAX", TYPE_Rv)
|
||||
TYPE("GR32_NOAX", TYPE_Rv)
|
||||
TYPE("GR64_NOAX", TYPE_R64)
|
||||
errs() << "Unhandled type string " << s << "\n";
|
||||
llvm_unreachable("Unhandled type string");
|
||||
}
|
||||
@ -1205,6 +1208,9 @@ OperandEncoding RecognizableInstr::opcodeModifierEncodingFromString
|
||||
ENCODING("GR64", ENCODING_RO)
|
||||
ENCODING("GR16", ENCODING_Rv)
|
||||
ENCODING("GR8", ENCODING_RB)
|
||||
ENCODING("GR16_NOAX", ENCODING_Rv)
|
||||
ENCODING("GR32_NOAX", ENCODING_Rv)
|
||||
ENCODING("GR64_NOAX", ENCODING_RO)
|
||||
errs() << "Unhandled opcode modifier encoding " << s << "\n";
|
||||
llvm_unreachable("Unhandled opcode modifier encoding");
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user