From: Hans Wennborg Date: Wed, 30 Aug 2017 22:41:27 +0000 (+0000) Subject: Revert r312139 "Verifier: Verify the correctness of fragment expressions attached... X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2ccb804727bf4a8e282963496976423d4a67438d;p=llvm Revert r312139 "Verifier: Verify the correctness of fragment expressions attached to globals." This caused PR34390. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@312182 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/IR/Verifier.cpp b/lib/IR/Verifier.cpp index e62daeeb539..e28644a081c 100644 --- a/lib/IR/Verifier.cpp +++ b/lib/IR/Verifier.cpp @@ -507,10 +507,6 @@ private: void verifySiblingFuncletUnwinds(); void verifyFragmentExpression(const DbgInfoIntrinsic &I); - template - void verifyFragmentExpression(const DIVariable &V, - DIExpression::FragmentInfo Fragment, - ValueOrMetadata *Desc); void verifyFnArgs(const DbgInfoIntrinsic &I); /// Module-level debug info verification... @@ -1182,11 +1178,8 @@ void Verifier::visitDIExpression(const DIExpression &N) { void Verifier::visitDIGlobalVariableExpression( const DIGlobalVariableExpression &GVE) { AssertDI(GVE.getVariable(), "missing variable"); - if (auto *Expr = GVE.getExpression()) { + if (auto *Expr = GVE.getExpression()) visitDIExpression(*Expr); - if (auto Fragment = Expr->getFragmentInfo()) - verifyFragmentExpression(*GVE.getVariable(), *Fragment, &GVE); - } } void Verifier::visitDIObjCProperty(const DIObjCProperty &N) { @@ -4495,7 +4488,7 @@ void Verifier::visitDbgIntrinsic(StringRef Kind, DbgIntrinsicTy &DII) { verifyFnArgs(DII); } -static uint64_t getVariableSize(const DIVariable &V) { +static uint64_t getVariableSize(const DILocalVariable &V) { // Be careful of broken types (checked elsewhere). const Metadata *RawType = V.getRawType(); while (RawType) { @@ -4534,7 +4527,7 @@ void Verifier::verifyFragmentExpression(const DbgInfoIntrinsic &I) { if (!V || !E || !E->isValid()) return; - // Nothing to do if this isn't a DW_OP_LLVM_fragment expression. + // Nothing to do if this isn't a bit piece expression. auto Fragment = E->getFragmentInfo(); if (!Fragment) return; @@ -4548,24 +4541,17 @@ void Verifier::verifyFragmentExpression(const DbgInfoIntrinsic &I) { if (V->isArtificial()) return; - verifyFragmentExpression(*V, *Fragment, &I); -} - -template -void Verifier::verifyFragmentExpression(const DIVariable &V, - DIExpression::FragmentInfo Fragment, - ValueOrMetadata *Desc) { // If there's no size, the type is broken, but that should be checked // elsewhere. - uint64_t VarSize = getVariableSize(V); + uint64_t VarSize = getVariableSize(*V); if (!VarSize) return; - unsigned FragSize = Fragment.SizeInBits; - unsigned FragOffset = Fragment.OffsetInBits; + unsigned FragSize = Fragment->SizeInBits; + unsigned FragOffset = Fragment->OffsetInBits; AssertDI(FragSize + FragOffset <= VarSize, - "fragment is larger than or outside of variable", Desc, &V); - AssertDI(FragSize != VarSize, "fragment covers entire variable", Desc, &V); + "fragment is larger than or outside of variable", &I, V, E); + AssertDI(FragSize != VarSize, "fragment covers entire variable", &I, V, E); } void Verifier::verifyFnArgs(const DbgInfoIntrinsic &I) { diff --git a/test/Verifier/fragment.ll b/test/Verifier/fragment.ll deleted file mode 100644 index ed5df89cb31..00000000000 --- a/test/Verifier/fragment.ll +++ /dev/null @@ -1,19 +0,0 @@ -; RUN: not opt -S <%s 2>&1| FileCheck %s - -; CHECK: fragment is larger than or outside of variable -; CHECK: !DIGlobalVariableExpression(var: ![[VAR:[0-9]+]], -; CHECK-SAME: expr: !DIExpression(DW_OP_LLVM_fragment, 0, 64)) -; CHECK: ![[VAR]] = !DIGlobalVariable(name: "g" - -@g = common global i32 0, align 4, !dbg !0 - -!llvm.dbg.cu = !{!1} -!llvm.module.flags = !{!6, !7} - -!0 = !DIGlobalVariableExpression(var: !3, expr: !DIExpression(DW_OP_LLVM_fragment, 0, 64)) -!1 = distinct !DICompileUnit(language: DW_LANG_C99, file: !2, emissionKind: FullDebug) -!2 = !DIFile(filename: "a.c", directory: "/") -!3 = !DIGlobalVariable(name: "g", scope: !1, file: !2, line: 1, type: !5, isLocal: false, isDefinition: true) -!5 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed) -!6 = !{i32 2, !"Dwarf Version", i32 4} -!7 = !{i32 2, !"Debug Info Version", i32 3}