mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 20:23:11 +01:00
[GlobalISel] fix crash in IRTranslator, MachineIRBuilder when translating @llvm.dbg.value intrinsic and using -debug
Summary: Fix crash when using -debug caused by the GlobalISel observer trying to print an incomplete DBG_VALUE instruction. This was caused by the MachineIRBuilder using buildInstr, which immediately inserts the instruction causing print, instead of using BuildMI to first build up the instruction and using insertInstr when finished. Add RUN-line to existing debug-insts.ll test with -debug flag set to make sure no crash is happening. Also fixed a missing %s in the 2nd RUN-line of the same test. Reviewers: t.p.northover, aditya_nandakumar, aemerson, dsanders, arsenm Reviewed By: arsenm Subscribers: wdng, arsenm, rovka, hiraditya, volkan, llvm-commits Tags: #llvm Differential Revision: https://reviews.llvm.org/D76934
This commit is contained in:
parent
4b05c4f8f0
commit
ee796cf5c1
@ -97,7 +97,7 @@ MachineInstrBuilder MachineIRBuilder::buildConstDbgValue(const Constant &C,
|
||||
assert(
|
||||
cast<DILocalVariable>(Variable)->isValidLocationForIntrinsic(getDL()) &&
|
||||
"Expected inlined-at fields to agree");
|
||||
auto MIB = buildInstr(TargetOpcode::DBG_VALUE);
|
||||
auto MIB = buildInstrNoInsert(TargetOpcode::DBG_VALUE);
|
||||
if (auto *CI = dyn_cast<ConstantInt>(&C)) {
|
||||
if (CI->getBitWidth() > 64)
|
||||
MIB.addCImm(CI);
|
||||
@ -110,7 +110,8 @@ MachineInstrBuilder MachineIRBuilder::buildConstDbgValue(const Constant &C,
|
||||
MIB.addReg(0U);
|
||||
}
|
||||
|
||||
return MIB.addImm(0).addMetadata(Variable).addMetadata(Expr);
|
||||
MIB.addImm(0).addMetadata(Variable).addMetadata(Expr);
|
||||
return insertInstr(MIB);
|
||||
}
|
||||
|
||||
MachineInstrBuilder MachineIRBuilder::buildDbgLabel(const MDNode *Label) {
|
||||
|
@ -1,5 +1,6 @@
|
||||
; RUN: llc -global-isel -mtriple=aarch64 %s -stop-after=irtranslator -o - | FileCheck %s
|
||||
; RUN: llc -mtriple=aarch64 -global-isel --global-isel-abort=0 -o /dev/null
|
||||
; RUN: llc -mtriple=aarch64 -global-isel --global-isel-abort=0 %s -o /dev/null
|
||||
; RUN: llc -mtriple=aarch64 -global-isel --global-isel-abort=0 %s -o /dev/null -debug
|
||||
|
||||
; CHECK-LABEL: name: debug_declare
|
||||
; CHECK: stack:
|
||||
|
Loading…
Reference in New Issue
Block a user