forked from OSchip/llvm-project
Fix another batch of VLD/VST decoding crashes discovered by randomized testing.
llvm-svn: 138255
This commit is contained in:
parent
1d887499c4
commit
721c3704da
|
@ -2769,8 +2769,11 @@ static DecodeStatus DecodeVLD1LN(llvm::MCInst &Inst, unsigned Insn,
|
||||||
}
|
}
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
||||||
Inst.addOperand(MCOperand::CreateImm(align));
|
Inst.addOperand(MCOperand::CreateImm(align));
|
||||||
if (Rm != 0xF && Rm != 0xD) {
|
if (Rm != 0xF) {
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
if (Rm != 0xD)
|
||||||
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
||||||
|
else
|
||||||
|
Inst.addOperand(MCOperand::CreateReg(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
||||||
|
@ -2819,8 +2822,11 @@ static DecodeStatus DecodeVST1LN(llvm::MCInst &Inst, unsigned Insn,
|
||||||
}
|
}
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
||||||
Inst.addOperand(MCOperand::CreateImm(align));
|
Inst.addOperand(MCOperand::CreateImm(align));
|
||||||
if (Rm != 0xF && Rm != 0xD) {
|
if (Rm != 0xF) {
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
if (Rm != 0xD)
|
||||||
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
||||||
|
else
|
||||||
|
Inst.addOperand(MCOperand::CreateReg(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
||||||
|
@ -2876,8 +2882,11 @@ static DecodeStatus DecodeVLD2LN(llvm::MCInst &Inst, unsigned Insn,
|
||||||
}
|
}
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
||||||
Inst.addOperand(MCOperand::CreateImm(align));
|
Inst.addOperand(MCOperand::CreateImm(align));
|
||||||
if (Rm != 0xF && Rm != 0xD) {
|
if (Rm != 0xF) {
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
if (Rm != 0xD)
|
||||||
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
||||||
|
else
|
||||||
|
Inst.addOperand(MCOperand::CreateReg(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
||||||
|
@ -2931,8 +2940,11 @@ static DecodeStatus DecodeVST2LN(llvm::MCInst &Inst, unsigned Insn,
|
||||||
}
|
}
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
||||||
Inst.addOperand(MCOperand::CreateImm(align));
|
Inst.addOperand(MCOperand::CreateImm(align));
|
||||||
if (Rm != 0xF && Rm != 0xD) {
|
if (Rm != 0xF) {
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
if (Rm != 0xD)
|
||||||
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
||||||
|
else
|
||||||
|
Inst.addOperand(MCOperand::CreateReg(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
||||||
|
@ -2989,8 +3001,11 @@ static DecodeStatus DecodeVLD3LN(llvm::MCInst &Inst, unsigned Insn,
|
||||||
}
|
}
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
||||||
Inst.addOperand(MCOperand::CreateImm(align));
|
Inst.addOperand(MCOperand::CreateImm(align));
|
||||||
if (Rm != 0xF && Rm != 0xD) {
|
if (Rm != 0xF) {
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
if (Rm != 0xD)
|
||||||
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
||||||
|
else
|
||||||
|
Inst.addOperand(MCOperand::CreateReg(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
||||||
|
@ -3043,8 +3058,11 @@ static DecodeStatus DecodeVST3LN(llvm::MCInst &Inst, unsigned Insn,
|
||||||
}
|
}
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
||||||
Inst.addOperand(MCOperand::CreateImm(align));
|
Inst.addOperand(MCOperand::CreateImm(align));
|
||||||
if (Rm != 0xF && Rm != 0xD) {
|
if (Rm != 0xF) {
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
if (Rm != 0xD)
|
||||||
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
||||||
|
else
|
||||||
|
Inst.addOperand(MCOperand::CreateReg(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
||||||
|
@ -3103,8 +3121,11 @@ static DecodeStatus DecodeVLD4LN(llvm::MCInst &Inst, unsigned Insn,
|
||||||
}
|
}
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
||||||
Inst.addOperand(MCOperand::CreateImm(align));
|
Inst.addOperand(MCOperand::CreateImm(align));
|
||||||
if (Rm != 0xF && Rm != 0xD) {
|
if (Rm != 0xF) {
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
if (Rm != 0xD)
|
||||||
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
||||||
|
else
|
||||||
|
Inst.addOperand(MCOperand::CreateReg(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
||||||
|
@ -3158,8 +3179,11 @@ static DecodeStatus DecodeVST4LN(llvm::MCInst &Inst, unsigned Insn,
|
||||||
}
|
}
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rn, Address, Decoder));
|
||||||
Inst.addOperand(MCOperand::CreateImm(align));
|
Inst.addOperand(MCOperand::CreateImm(align));
|
||||||
if (Rm != 0xF && Rm != 0xD) {
|
if (Rm != 0xF) {
|
||||||
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
if (Rm != 0xD)
|
||||||
|
CHECK(S, DecodeGPRRegisterClass(Inst, Rm, Address, Decoder));
|
||||||
|
else
|
||||||
|
Inst.addOperand(MCOperand::CreateReg(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
CHECK(S, DecodeDPRRegisterClass(Inst, Rd, Address, Decoder));
|
||||||
|
|
|
@ -1848,4 +1848,6 @@
|
||||||
|
|
||||||
0x0 0xc 0xa0 0xf4
|
0x0 0xc 0xa0 0xf4
|
||||||
# CHECK: vld1.8 {d0[]}, [r0], r0
|
# CHECK: vld1.8 {d0[]}, [r0], r0
|
||||||
|
0x0d 0x03 0x80 0xf4
|
||||||
|
# CHECK: vst4.8 {d0[0], d1[0], d2[0], d3[0]}, [r0]!
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue