mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-26 23:24:34 +00:00
[X86] Fix diassembler crash on AVX512 cmpps/cmppd with immediate that doesn't fit in 5-bits. Fixes PR22743.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@230924 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -392,8 +392,10 @@ static void translateImmediate(MCInst &mcInst, uint64_t immediate,
|
||||
case X86::VCMPPSYrri: NewOpc = X86::VCMPPSYrri_alt; break;
|
||||
case X86::VCMPPDZrmi: NewOpc = X86::VCMPPDZrmi_alt; break;
|
||||
case X86::VCMPPDZrri: NewOpc = X86::VCMPPDZrri_alt; break;
|
||||
case X86::VCMPPDZrrib: NewOpc = X86::VCMPPDZrrib_alt; break;
|
||||
case X86::VCMPPSZrmi: NewOpc = X86::VCMPPSZrmi_alt; break;
|
||||
case X86::VCMPPSZrri: NewOpc = X86::VCMPPSZrri_alt; break;
|
||||
case X86::VCMPPSZrrib: NewOpc = X86::VCMPPSZrrib_alt; break;
|
||||
case X86::VCMPSDZrm: NewOpc = X86::VCMPSDZrmi_alt; break;
|
||||
case X86::VCMPSDZrr: NewOpc = X86::VCMPSDZrri_alt; break;
|
||||
case X86::VCMPSSZrm: NewOpc = X86::VCMPSSZrmi_alt; break;
|
||||
|
@ -1559,6 +1559,11 @@ multiclass avx512_cmp_packed<RegisterClass KRC, RegisterClass RC,
|
||||
(outs KRC:$dst), (ins RC:$src1, RC:$src2, u8imm:$cc),
|
||||
!strconcat("vcmp", suffix,
|
||||
"\t{$cc, $src2, $src1, $dst|$dst, $src1, $src2, $cc}"), [], d>;
|
||||
def rrib_alt: AVX512PIi8<0xC2, MRMSrcReg,
|
||||
(outs KRC:$dst), (ins RC:$src1, RC:$src2, u8imm:$cc),
|
||||
!strconcat("vcmp", suffix,
|
||||
"\t{{sae}, $cc, $src2, $src1, $dst|$dst, $src1, $src2, $cc, {sae}}"),
|
||||
[], d>, EVEX_B;
|
||||
let mayLoad = 1 in
|
||||
def rmi_alt : AVX512PIi8<0xC2, MRMSrcMem,
|
||||
(outs KRC:$dst), (ins RC:$src1, x86memop:$src2, u8imm:$cc),
|
||||
|
@ -136,3 +136,6 @@
|
||||
|
||||
# CHECK: vpcmpd $8, %zmm10, %zmm25, %k5
|
||||
0x62 0xd3 0x35 0x40 0x1f 0xea 0x8
|
||||
|
||||
# CHECK: vcmppd {sae}, $127, %zmm27, %zmm11, %k4
|
||||
0x62 0x91 0xa5 0x58 0xc2 0xe3 0x7f
|
||||
|
Reference in New Issue
Block a user