[llvm-bugs] [Bug 27133] New: clang-cl: LLVM lib/Transforms/Scalar/IndVarSimplify.cpp WidenIV::widenIVUse: dereference getFirstInsertionPt() == end()

via llvm-bugs llvm-bugs at lists.llvm.org
Wed Mar 30 09:11:40 PDT 2016


https://llvm.org/bugs/show_bug.cgi?id=27133

            Bug ID: 27133
           Summary: clang-cl: LLVM
                    lib/Transforms/Scalar/IndVarSimplify.cpp
                    WidenIV::widenIVUse: dereference getFirstInsertionPt()
                    == end()
           Product: clang
           Version: trunk
          Hardware: All
                OS: All
            Status: NEW
          Severity: normal
          Priority: P
         Component: -New Bugs
          Assignee: unassignedclangbugs at nondot.org
          Reporter: stephan.bergmann.secondary at googlemail.com
                CC: llvm-bugs at lists.llvm.org
    Classification: Unclassified

At least on recent trunk r264857, attached (non-reduced) reproducer crashes
clang-cl, as

  IRBuilder<> Builder(&*WidePhi->getParent()->getFirstInsertionPt());

in WidenIV::widenIVUse (LLVM lib/Transforms/Scalar/IndVarSimplify.cpp)
dereferences an at-the-end iterator.

With

> --- a/lib/Transforms/Scalar/IndVarSimplify.cpp
> +++ b/lib/Transforms/Scalar/IndVarSimplify.cpp
> @@ -1287,7 +1287,10 @@ Instruction *WidenIV::widenIVUse(NarrowIVDefUse DU, SCEVExpander &Rewriter) {
>            PHINode::Create(DU.WideDef->getType(), 1, UsePhi->getName() + ".wide",
>                            UsePhi);
>          WidePhi->addIncoming(DU.WideDef, UsePhi->getIncomingBlock(0));
> -        IRBuilder<> Builder(&*WidePhi->getParent()->getFirstInsertionPt());
> +auto bb = WidePhi->getParent();
> +auto i = bb->getFirstInsertionPt();
> +assert(i != bb->end());
> +        IRBuilder<> Builder(&*i);
>          Value *Trunc = Builder.CreateTrunc(WidePhi, DU.NarrowDef->getType());
>          UsePhi->replaceAllUsesWith(Trunc);
>          DeadInsts.emplace_back(UsePhi);

the assertion fires at

> __GI___assert_fail at assert.c:101
> (anonymous namespace)::WidenIV::widenIVUse at llvm/lib/Transforms/Scalar/IndVarSimplify.cpp:1292
> (anonymous namespace)::WidenIV::createWideIV at llvm/lib/Transforms/Scalar/IndVarSimplify.cpp:1474
> (anonymous namespace)::IndVarSimplify::simplifyAndExtend at llvm/lib/Transforms/Scalar/IndVarSimplify.cpp:1561
> (anonymous namespace)::IndVarSimplify::runOnLoop at llvm/lib/Transforms/Scalar/IndVarSimplify.cpp:2168
> llvm::LPPassManager::runOnFunction at llvm/lib/Analysis/LoopPass.cpp:198
> llvm::FPPassManager::runOnFunction at llvm/lib/IR/LegacyPassManager.cpp:1550
> (anonymous namespace)::CGPassManager::RunPassOnSCC at llvm/lib/Analysis/CallGraphSCCPass.cpp:150
> (anonymous namespace)::CGPassManager::RunAllPassesOnSCC at llvm/lib/Analysis/CallGraphSCCPass.cpp:419
> (anonymous namespace)::CGPassManager::runOnModule at llvm/lib/Analysis/CallGraphSCCPass.cpp:474
> (anonymous namespace)::MPPassManager::runOnModule at llvm/lib/IR/LegacyPassManager.cpp:1627
> llvm::legacy::PassManagerImpl::run at llvm/lib/IR/LegacyPassManager.cpp:1730
> llvm::legacy::PassManager::run at llvm/lib/IR/LegacyPassManager.cpp:1761
> (anonymous namespace)::EmitAssemblyHelper::EmitAssembly at llvm/tools/clang/lib/CodeGen/BackendUtil.cpp:702
> clang::EmitBackendOutput at llvm/tools/clang/lib/CodeGen/BackendUtil.cpp:719
> clang::BackendConsumer::HandleTranslationUnit at llvm/tools/clang/lib/CodeGen/CodeGenAction.cpp:178
> clang::ParseAST at llvm/tools/clang/lib/Parse/ParseAST.cpp:168
> clang::ASTFrontendAction::ExecuteAction at llvm/tools/clang/lib/Frontend/FrontendAction.cpp:557
> clang::CodeGenAction::ExecuteAction at llvm/tools/clang/lib/CodeGen/CodeGenAction.cpp:822
> clang::FrontendAction::Execute at llvm/tools/clang/lib/Frontend/FrontendAction.cpp:457
> clang::CompilerInstance::ExecuteAction at llvm/tools/clang/lib/Frontend/CompilerInstance.cpp:873
> clang::ExecuteCompilerInvocation at llvm/tools/clang/lib/FrontendTool/ExecuteCompilerInvocation.cpp:241
> cc1_main at llvm/tools/clang/tools/driver/cc1_main.cpp:116
> ExecuteCC1Tool at llvm/tools/clang/tools/driver/driver.cpp:301
> main at llvm/tools/clang/tools/driver/driver.cpp:366

-- 
You are receiving this mail because:
You are on the CC list for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-bugs/attachments/20160330/56de5be9/attachment.html>


More information about the llvm-bugs mailing list