forked from OSchip/llvm-project
Revert r281895 "Add @llvm.dbg.value entries for the phi node created by -mem2reg"
(And follow-up r281964.) It caused PR30468. llvm-svn: 282077
This commit is contained in:
parent
903859c0e4
commit
1049085c78
|
@ -32,7 +32,6 @@ class BranchInst;
|
||||||
class Instruction;
|
class Instruction;
|
||||||
class CallInst;
|
class CallInst;
|
||||||
class DbgDeclareInst;
|
class DbgDeclareInst;
|
||||||
class DbgValueInst;
|
|
||||||
class StoreInst;
|
class StoreInst;
|
||||||
class LoadInst;
|
class LoadInst;
|
||||||
class Value;
|
class Value;
|
||||||
|
@ -49,8 +48,6 @@ class LazyValueInfo;
|
||||||
|
|
||||||
template<typename T> class SmallVectorImpl;
|
template<typename T> class SmallVectorImpl;
|
||||||
|
|
||||||
typedef SmallVector<DbgValueInst *, 1> DbgValueList;
|
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Local constant propagation.
|
// Local constant propagation.
|
||||||
//
|
//
|
||||||
|
@ -258,19 +255,14 @@ Value *EmitGEPOffset(IRBuilderTy *Builder, const DataLayout &DL, User *GEP,
|
||||||
|
|
||||||
/// Inserts a llvm.dbg.value intrinsic before a store to an alloca'd value
|
/// Inserts a llvm.dbg.value intrinsic before a store to an alloca'd value
|
||||||
/// that has an associated llvm.dbg.decl intrinsic.
|
/// that has an associated llvm.dbg.decl intrinsic.
|
||||||
void ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
bool ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
||||||
StoreInst *SI, DIBuilder &Builder);
|
StoreInst *SI, DIBuilder &Builder);
|
||||||
|
|
||||||
/// Inserts a llvm.dbg.value intrinsic before a load of an alloca'd value
|
/// Inserts a llvm.dbg.value intrinsic before a load of an alloca'd value
|
||||||
/// that has an associated llvm.dbg.decl intrinsic.
|
/// that has an associated llvm.dbg.decl intrinsic.
|
||||||
void ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
bool ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
||||||
LoadInst *LI, DIBuilder &Builder);
|
LoadInst *LI, DIBuilder &Builder);
|
||||||
|
|
||||||
/// Inserts a llvm.dbg.value intrinsic after a phi of an alloca'd value
|
|
||||||
/// that has an associated llvm.dbg.decl intrinsic.
|
|
||||||
void ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
|
||||||
PHINode *LI, DIBuilder &Builder);
|
|
||||||
|
|
||||||
/// Lowers llvm.dbg.declare intrinsics into appropriate set of
|
/// Lowers llvm.dbg.declare intrinsics into appropriate set of
|
||||||
/// llvm.dbg.value intrinsics.
|
/// llvm.dbg.value intrinsics.
|
||||||
bool LowerDbgDeclare(Function &F);
|
bool LowerDbgDeclare(Function &F);
|
||||||
|
@ -278,9 +270,6 @@ bool LowerDbgDeclare(Function &F);
|
||||||
/// Finds the llvm.dbg.declare intrinsic corresponding to an alloca, if any.
|
/// Finds the llvm.dbg.declare intrinsic corresponding to an alloca, if any.
|
||||||
DbgDeclareInst *FindAllocaDbgDeclare(Value *V);
|
DbgDeclareInst *FindAllocaDbgDeclare(Value *V);
|
||||||
|
|
||||||
/// Finds the llvm.dbg.value intrinsics corresponding to an alloca, if any.
|
|
||||||
void FindAllocaDbgValues(DbgValueList &DbgValues, Value *V);
|
|
||||||
|
|
||||||
/// Replaces llvm.dbg.declare instruction when the address it describes
|
/// Replaces llvm.dbg.declare instruction when the address it describes
|
||||||
/// is replaced with a new value. If Deref is true, an additional DW_OP_deref is
|
/// is replaced with a new value. If Deref is true, an additional DW_OP_deref is
|
||||||
/// prepended to the expression. If Offset is non-zero, a constant displacement
|
/// prepended to the expression. If Offset is non-zero, a constant displacement
|
||||||
|
|
|
@ -1053,27 +1053,9 @@ static bool LdStHasDebugValue(DILocalVariable *DIVar, DIExpression *DIExpr,
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// See if there is a dbg.value intrinsic for DIVar for the PHI node.
|
|
||||||
static bool PhiHasDebugValue(DILocalVariable *DIVar,
|
|
||||||
DIExpression *DIExpr,
|
|
||||||
PHINode *APN) {
|
|
||||||
// Since we can't guarantee that the original dbg.declare instrinsic
|
|
||||||
// is removed by LowerDbgDeclare(), we need to make sure that we are
|
|
||||||
// not inserting the same dbg.value intrinsic over and over.
|
|
||||||
DbgValueList DbgValues;
|
|
||||||
FindAllocaDbgValues(DbgValues, APN);
|
|
||||||
for (auto DVI : DbgValues) {
|
|
||||||
assert (DVI->getValue() == APN);
|
|
||||||
assert (DVI->getOffset() == 0);
|
|
||||||
if ((DVI->getVariable() == DIVar) && (DVI->getExpression() == DIExpr))
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Inserts a llvm.dbg.value intrinsic before a store to an alloca'd value
|
/// Inserts a llvm.dbg.value intrinsic before a store to an alloca'd value
|
||||||
/// that has an associated llvm.dbg.decl intrinsic.
|
/// that has an associated llvm.dbg.decl intrinsic.
|
||||||
void llvm::ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
bool llvm::ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
||||||
StoreInst *SI, DIBuilder &Builder) {
|
StoreInst *SI, DIBuilder &Builder) {
|
||||||
auto *DIVar = DDI->getVariable();
|
auto *DIVar = DDI->getVariable();
|
||||||
auto *DIExpr = DDI->getExpression();
|
auto *DIExpr = DDI->getExpression();
|
||||||
|
@ -1114,18 +1096,19 @@ void llvm::ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
||||||
} else if (!LdStHasDebugValue(DIVar, DIExpr, SI))
|
} else if (!LdStHasDebugValue(DIVar, DIExpr, SI))
|
||||||
Builder.insertDbgValueIntrinsic(SI->getOperand(0), 0, DIVar, DIExpr,
|
Builder.insertDbgValueIntrinsic(SI->getOperand(0), 0, DIVar, DIExpr,
|
||||||
DDI->getDebugLoc(), SI);
|
DDI->getDebugLoc(), SI);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Inserts a llvm.dbg.value intrinsic before a load of an alloca'd value
|
/// Inserts a llvm.dbg.value intrinsic before a load of an alloca'd value
|
||||||
/// that has an associated llvm.dbg.decl intrinsic.
|
/// that has an associated llvm.dbg.decl intrinsic.
|
||||||
void llvm::ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
bool llvm::ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
||||||
LoadInst *LI, DIBuilder &Builder) {
|
LoadInst *LI, DIBuilder &Builder) {
|
||||||
auto *DIVar = DDI->getVariable();
|
auto *DIVar = DDI->getVariable();
|
||||||
auto *DIExpr = DDI->getExpression();
|
auto *DIExpr = DDI->getExpression();
|
||||||
assert(DIVar && "Missing variable");
|
assert(DIVar && "Missing variable");
|
||||||
|
|
||||||
if (LdStHasDebugValue(DIVar, DIExpr, LI))
|
if (LdStHasDebugValue(DIVar, DIExpr, LI))
|
||||||
return;
|
return true;
|
||||||
|
|
||||||
// We are now tracking the loaded value instead of the address. In the
|
// We are now tracking the loaded value instead of the address. In the
|
||||||
// future if multi-location support is added to the IR, it might be
|
// future if multi-location support is added to the IR, it might be
|
||||||
|
@ -1134,22 +1117,7 @@ void llvm::ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
||||||
Instruction *DbgValue = Builder.insertDbgValueIntrinsic(
|
Instruction *DbgValue = Builder.insertDbgValueIntrinsic(
|
||||||
LI, 0, DIVar, DIExpr, DDI->getDebugLoc(), (Instruction *)nullptr);
|
LI, 0, DIVar, DIExpr, DDI->getDebugLoc(), (Instruction *)nullptr);
|
||||||
DbgValue->insertAfter(LI);
|
DbgValue->insertAfter(LI);
|
||||||
}
|
return true;
|
||||||
|
|
||||||
/// Inserts a llvm.dbg.value intrinsic after a phi
|
|
||||||
/// that has an associated llvm.dbg.decl intrinsic.
|
|
||||||
void llvm::ConvertDebugDeclareToDebugValue(DbgDeclareInst *DDI,
|
|
||||||
PHINode *APN, DIBuilder &Builder) {
|
|
||||||
auto *DIVar = DDI->getVariable();
|
|
||||||
auto *DIExpr = DDI->getExpression();
|
|
||||||
assert(DIVar && "Missing variable");
|
|
||||||
|
|
||||||
if (PhiHasDebugValue(DIVar, DIExpr, APN))
|
|
||||||
return;
|
|
||||||
|
|
||||||
Instruction *DbgValue = Builder.insertDbgValueIntrinsic(
|
|
||||||
APN, 0, DIVar, DIExpr, DDI->getDebugLoc(), (Instruction *)nullptr);
|
|
||||||
DbgValue->insertBefore(&*APN->getParent()->getFirstInsertionPt());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Determine whether this alloca is either a VLA or an array.
|
/// Determine whether this alloca is either a VLA or an array.
|
||||||
|
@ -1219,16 +1187,6 @@ DbgDeclareInst *llvm::FindAllocaDbgDeclare(Value *V) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// FindAllocaDbgValues - Finds the llvm.dbg.value intrinsics describing the
|
|
||||||
/// alloca 'V', if any.
|
|
||||||
void llvm::FindAllocaDbgValues(DbgValueList &DbgValues, Value *V) {
|
|
||||||
if (auto *L = LocalAsMetadata::getIfExists(V))
|
|
||||||
if (auto *MDV = MetadataAsValue::getIfExists(V->getContext(), L))
|
|
||||||
for (User *U : MDV->users())
|
|
||||||
if (DbgValueInst *DVI = dyn_cast<DbgValueInst>(U))
|
|
||||||
DbgValues.push_back(DVI);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void DIExprAddDeref(SmallVectorImpl<uint64_t> &Expr) {
|
static void DIExprAddDeref(SmallVectorImpl<uint64_t> &Expr) {
|
||||||
Expr.push_back(dwarf::DW_OP_deref);
|
Expr.push_back(dwarf::DW_OP_deref);
|
||||||
}
|
}
|
||||||
|
|
|
@ -907,8 +907,6 @@ NextIteration:
|
||||||
|
|
||||||
// The currently active variable for this block is now the PHI.
|
// The currently active variable for this block is now the PHI.
|
||||||
IncomingVals[AllocaNo] = APN;
|
IncomingVals[AllocaNo] = APN;
|
||||||
if (DbgDeclareInst *DDI = AllocaDbgDeclares[AllocaNo])
|
|
||||||
ConvertDebugDeclareToDebugValue(DDI, APN, DIB);
|
|
||||||
|
|
||||||
// Get the next phi node.
|
// Get the next phi node.
|
||||||
++PNI;
|
++PNI;
|
||||||
|
|
|
@ -1,76 +0,0 @@
|
||||||
; RUN: opt -mem2reg -S < %s | FileCheck %s
|
|
||||||
|
|
||||||
; Test that a @llvm.dbg.value node is created to describe the value returned by a phi node when
|
|
||||||
; lowering a @llvm.dbg.declare node
|
|
||||||
|
|
||||||
; Created from the C code, compiled with -O0 -g:
|
|
||||||
;
|
|
||||||
; int func(int a)
|
|
||||||
; {
|
|
||||||
; int c = 1;
|
|
||||||
; if (a < 0 ) {
|
|
||||||
; c = 12;
|
|
||||||
; }
|
|
||||||
; return c;
|
|
||||||
; }
|
|
||||||
|
|
||||||
; Function Attrs: nounwind
|
|
||||||
define i32 @func(i32 %a) #0 !dbg !8 {
|
|
||||||
entry:
|
|
||||||
%a.addr = alloca i32, align 4
|
|
||||||
%c = alloca i32, align 4
|
|
||||||
store i32 %a, i32* %a.addr, align 4
|
|
||||||
call void @llvm.dbg.declare(metadata i32* %a.addr, metadata !12, metadata !13), !dbg !14
|
|
||||||
call void @llvm.dbg.declare(metadata i32* %c, metadata !15, metadata !13), !dbg !16
|
|
||||||
store i32 1, i32* %c, align 4, !dbg !16
|
|
||||||
%0 = load i32, i32* %a.addr, align 4, !dbg !17
|
|
||||||
%cmp = icmp slt i32 %0, 0, !dbg !19
|
|
||||||
br i1 %cmp, label %if.then, label %if.end, !dbg !20
|
|
||||||
|
|
||||||
if.then: ; preds = %entry
|
|
||||||
store i32 12, i32* %c, align 4, !dbg !21
|
|
||||||
br label %if.end, !dbg !23
|
|
||||||
|
|
||||||
if.end: ; preds = %if.then, %entry
|
|
||||||
%1 = load i32, i32* %c, align 4, !dbg !24
|
|
||||||
; CHECK: [[PHI:%.*]] = phi i32 [ 12, {{.*}} ], [ 1, {{.*}} ]
|
|
||||||
; CHECK-NEXT: call void @llvm.dbg.value(metadata i32 [[PHI]], i64 0, metadata !15, metadata !13), !dbg !16
|
|
||||||
ret i32 %1, !dbg !25
|
|
||||||
}
|
|
||||||
|
|
||||||
; Function Attrs: nounwind readnone
|
|
||||||
declare void @llvm.dbg.declare(metadata, metadata, metadata) #1
|
|
||||||
|
|
||||||
attributes #1 = { nounwind readnone }
|
|
||||||
|
|
||||||
!llvm.dbg.cu = !{!0}
|
|
||||||
!llvm.module.flags = !{!3, !4, !5, !6}
|
|
||||||
!llvm.ident = !{!7}
|
|
||||||
|
|
||||||
!0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, producer: "clang", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !2)
|
|
||||||
!1 = !DIFile(filename: "a.c", directory: "/tmp")
|
|
||||||
!2 = !{}
|
|
||||||
!3 = !{i32 2, !"Dwarf Version", i32 4}
|
|
||||||
!4 = !{i32 2, !"Debug Info Version", i32 3}
|
|
||||||
!5 = !{i32 1, !"wchar_size", i32 4}
|
|
||||||
!6 = !{i32 1, !"min_enum_size", i32 4}
|
|
||||||
!7 = !{!"clang"}
|
|
||||||
!8 = distinct !DISubprogram(name: "func", scope: !1, file: !1, line: 1, type: !9, isLocal: false, isDefinition: true, scopeLine: 2, flags: DIFlagPrototyped, isOptimized: false, unit: !0, variables: !2)
|
|
||||||
!9 = !DISubroutineType(types: !10)
|
|
||||||
!10 = !{!11, !11}
|
|
||||||
!11 = !DIBasicType(name: "int", size: 32, align: 32, encoding: DW_ATE_signed)
|
|
||||||
!12 = !DILocalVariable(name: "a", arg: 1, scope: !8, file: !1, line: 1, type: !11)
|
|
||||||
!13 = !DIExpression()
|
|
||||||
!14 = !DILocation(line: 1, column: 14, scope: !8)
|
|
||||||
!15 = !DILocalVariable(name: "c", scope: !8, file: !1, line: 3, type: !11)
|
|
||||||
!16 = !DILocation(line: 3, column: 6, scope: !8)
|
|
||||||
!17 = !DILocation(line: 4, column: 6, scope: !18)
|
|
||||||
!18 = distinct !DILexicalBlock(scope: !8, file: !1, line: 4, column: 6)
|
|
||||||
!19 = !DILocation(line: 4, column: 8, scope: !18)
|
|
||||||
!20 = !DILocation(line: 4, column: 6, scope: !8)
|
|
||||||
!21 = !DILocation(line: 5, column: 5, scope: !22)
|
|
||||||
!22 = distinct !DILexicalBlock(scope: !18, file: !1, line: 4, column: 14)
|
|
||||||
!23 = !DILocation(line: 6, column: 2, scope: !22)
|
|
||||||
!24 = !DILocation(line: 7, column: 9, scope: !8)
|
|
||||||
!25 = !DILocation(line: 7, column: 2, scope: !8)
|
|
||||||
|
|
Loading…
Reference in New Issue