diff options
Diffstat (limited to 'llvm/lib/CodeGen/MIRParser')
| -rw-r--r-- | llvm/lib/CodeGen/MIRParser/MIParser.cpp | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/MIRParser/MIParser.cpp b/llvm/lib/CodeGen/MIRParser/MIParser.cpp index b3fd16f1588..8937ee81c6a 100644 --- a/llvm/lib/CodeGen/MIRParser/MIParser.cpp +++ b/llvm/lib/CodeGen/MIRParser/MIParser.cpp @@ -973,14 +973,18 @@ bool MIParser::parseRegisterOperand(MachineOperand &Dest, TiedDefIdx = Idx; } } else if (consumeIfPresent(MIToken::lparen)) { + MachineRegisterInfo &MRI = MF.getRegInfo(); + // Virtual registers may have a size with GlobalISel. if (!TargetRegisterInfo::isVirtualRegister(Reg)) return error("unexpected size on physical register"); + if (MRI.getRegClassOrRegBank(Reg).is<const TargetRegisterClass *>()) + return error("unexpected size on non-generic virtual register"); + unsigned Size; if (parseSize(Size)) return true; - MachineRegisterInfo &MRI = MF.getRegInfo(); MRI.setSize(Reg, Size); } else if (PFS.GenericVRegs.count(Reg)) { // Generic virtual registers must have a size. |

