mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-28 19:31:58 +00:00
[inline asm] Fix a crasher for an invalid value type/register class.
rdar://13731657 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@180226 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
034f4be273
commit
2871ba90a3
@ -6171,10 +6171,17 @@ void SelectionDAGBuilder::visitInlineAsm(ImmutableCallSite CS) {
|
||||
MatchedRegs.RegVTs.push_back(RegVT);
|
||||
MachineRegisterInfo &RegInfo = DAG.getMachineFunction().getRegInfo();
|
||||
for (unsigned i = 0, e = InlineAsm::getNumOperandRegisters(OpFlag);
|
||||
i != e; ++i)
|
||||
MatchedRegs.Regs.push_back
|
||||
(RegInfo.createVirtualRegister(TLI.getRegClassFor(RegVT)));
|
||||
|
||||
i != e; ++i) {
|
||||
if (const TargetRegisterClass *RC = TLI.getRegClassFor(RegVT))
|
||||
MatchedRegs.Regs.push_back(RegInfo.createVirtualRegister(RC));
|
||||
else {
|
||||
LLVMContext &Ctx = *DAG.getContext();
|
||||
Ctx.emitError(CS.getInstruction(), "inline asm error: This value"
|
||||
" type register class is not natively supported!");
|
||||
report_fatal_error("inline asm error: This value type register "
|
||||
"class is not natively supported!");
|
||||
}
|
||||
}
|
||||
// Use the produced MatchedRegs object to
|
||||
MatchedRegs.getCopyToRegs(InOperandVal, DAG, getCurDebugLoc(),
|
||||
Chain, &Flag, CS.getInstruction());
|
||||
|
Loading…
Reference in New Issue
Block a user