[llvm-bugs] [Bug 28005] New: SimplifyCFG/SimplifyCleanupReturn: Use still stuck around after Def is destroyed: cleanupret from %cleanuppad2

via llvm-bugs llvm-bugs at lists.llvm.org
Sat Jun 4 12:44:05 PDT 2016


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

            Bug ID: 28005
           Summary: SimplifyCFG/SimplifyCleanupReturn: Use still stuck
                    around after Def is destroyed:  cleanupret from
                    %cleanuppad2
           Product: libraries
           Version: trunk
          Hardware: PC
                OS: Linux
            Status: NEW
          Severity: normal
          Priority: P
         Component: Transformation Utilities
          Assignee: unassignedbugs at nondot.org
          Reporter: arielb1 at mail.tau.ac.il
                CC: llvm-bugs at lists.llvm.org
    Classification: Unclassified

Created attachment 16474
  --> https://llvm.org/bugs/attachment.cgi?id=16474&action=edit
code that asserts when touched

Running the SimplifyCFG pass on the above IR causes an LLVM assertion to be
triggered.

I am trying to compile code that works with SEH exceptions on Windows. I am
cross-compiling from my Linux but it is broken in a similar way on Windows.

Expected Result:
Optimization Succeeds

Actual Result:
$ opt -version
LLVM (http://llvm.org/):
  LLVM version 3.8.0
  Optimized build with assertions.
  Built May 21 2016 (13:09:50).
  Default target: x86_64-unknown-linux-gnu
  Host CPU: broadwell
$ opt simplify-cfg-assert.ll -simplifycfg -S
While deleting: token %cleanuppad2
Use still stuck around after Def is destroyed:  cleanupret from %cleanuppad2
unwind label %bb18
Use still stuck around after Def is destroyed:  cleanupret from %cleanuppad2
unwind label %bb18
opt: /opt/llvm/lib/IR/Value.cpp:82: virtual llvm::Value::~Value(): Assertion
`use_empty() && "Uses remain when a value is destroyed!"' failed.
0  opt             0x0000000001826fe5
llvm::sys::PrintStackTrace(llvm::raw_ostream&) + 37
1  opt             0x0000000001824956 llvm::sys::RunSignalHandlers() + 54
2  opt             0x0000000001824b6a
3  libpthread.so.0 0x00007f91f3127d30
4  libc.so.6       0x00007f91f230e478 gsignal + 56
5  libc.so.6       0x00007f91f230f8fa abort + 362
6  libc.so.6       0x00007f91f23073a7
7  libc.so.6       0x00007f91f2307452
8  opt             0x00000000017c33fb
9  opt             0x00000000015caaa7
10 opt             0x0000000001659b2c llvm::BasicBlock::~BasicBlock() + 140
11 opt             0x0000000001659dbb llvm::BasicBlock::eraseFromParent() + 139
12 opt             0x00000000005c1594
13 opt             0x00000000013c1d76
14 opt             0x00000000013c2d31 llvm::SimplifyCFG(llvm::BasicBlock*,
llvm::TargetTransformInfo const&, unsigned int, llvm::AssumptionCache*) + 65
15 opt             0x00000000013c0f02
16 opt             0x00000000013c2d31 llvm::SimplifyCFG(llvm::BasicBlock*,
llvm::TargetTransformInfo const&, unsigned int, llvm::AssumptionCache*) + 65
17 opt             0x00000000005c4e2c
18 opt             0x00000000013c1dcd
19 opt             0x00000000013c2d31 llvm::SimplifyCFG(llvm::BasicBlock*,
llvm::TargetTransformInfo const&, unsigned int, llvm::AssumptionCache*) + 65
20 opt             0x00000000011d6ff9
21 opt             0x0000000001796ca3
llvm::FPPassManager::runOnFunction(llvm::Function&) + 643
22 opt             0x0000000001796db9
llvm::legacy::FunctionPassManagerImpl::run(llvm::Function&) + 137
23 opt             0x0000000001796f04
llvm::legacy::FunctionPassManager::run(llvm::Function&) + 36
24 opt             0x00000000005d5d09 main + 7321
25 libc.so.6       0x00007f91f22fb610 __libc_start_main + 240
26 opt             0x0000000000615129 _start + 41
Stack dump:
0.      Program arguments: opt simplify-cfg-assert.ll -simplifycfg -S -O3 
1.      Running pass 'Simplify the CFG' on function
'@_ZN4core4iter8iterator8Iterator4fold17h0471ccca27326883E'
Aborted

Backtrace on less-minified code:
#0  0x00007faab0f6f478 in __GI_raise (sig=sig at entry=6) at
../sysdeps/unix/sysv/linux/raise.c:55
#1  0x00007faab0f708fa in __GI_abort () at abort.c:89
#2  0x00007faab0f683a7 in __assert_fail_base (fmt=<optimized out>, 
    assertion=assertion at entry=0x7faaabbf0628 "use_empty() && \"Uses remain when
a value is destroyed!\"", 
    file=file at entry=0x7faaabbefe40 "llvm/lib/IR/Value.cpp", line=line at entry=82, 
    function=function at entry=0x7faaabbf29b0
<llvm::Value::~Value()::__PRETTY_FUNCTION__> "virtual llvm::Value::~Value()")
at assert.c:92
#3  0x00007faab0f68452 in __GI___assert_fail (assertion=0x7faaabbf0628
"use_empty() && \"Uses remain when a value is destroyed!\"", 
    file=0x7faaabbefe40 "llvm/lib/IR/Value.cpp", line=82, 
    function=0x7faaabbf29b0 <llvm::Value::~Value()::__PRETTY_FUNCTION__>
"virtual llvm::Value::~Value()") at assert.c:101
#4  0x00007faaaaf18f6b in llvm::Value::~Value() ()
   from librustc_llvm-fe3cdf61.so
#5  0x00007faaa9c03237 in llvm::FuncletPadInst::~FuncletPadInst
(this=0x7faaa3ef7af8, __in_chrg=<optimized out>)
    at llvm//include/llvm/IR/InstrTypes.h:1117
#6  llvm::CleanupPadInst::~CleanupPadInst (this=0x7faaa3ef7af8,
__in_chrg=<optimized out>)
    at llvm//include/llvm/IR/Instructions.h:4030
#7  llvm::CleanupPadInst::~CleanupPadInst (this=0x7faaa3ef7af8,
__in_chrg=<optimized out>)
    at llvm//include/llvm/IR/Instructions.h:4030
#8  0x00007faaaada3e4c in llvm::BasicBlock::~BasicBlock() ()
   from librustc_llvm-fe3cdf61.so
#9  0x00007faaaada40db in llvm::BasicBlock::eraseFromParent() ()
   from librustc_llvm-fe3cdf61.so
#10 0x00007faaa9bad62e in (anonymous
namespace)::SimplifyCFGOpt::SimplifyCleanupReturn(llvm::CleanupReturnInst*)
[clone .isra.636] [clone .constprop.703] ()
   from librustc_llvm-fe3cdf61.so
#11 0x00007faaaaacb226 in (anonymous
namespace)::SimplifyCFGOpt::run(llvm::BasicBlock*) [clone .constprop.691] ()
   from librustc_llvm-fe3cdf61.so
#12 0x00007faaaaacc1e1 in llvm::SimplifyCFG(llvm::BasicBlock*,
llvm::TargetTransformInfo const&, unsigned int, llvm::AssumptionCache*) ()
   from librustc_llvm-fe3cdf61.so
#13 0x00007faaaaaca3b2 in (anonymous
namespace)::SimplifyCFGOpt::run(llvm::BasicBlock*) [clone .constprop.691] ()
   from librustc_llvm-fe3cdf61.so
#14 0x00007faaaaacc1e1 in llvm::SimplifyCFG(llvm::BasicBlock*,
llvm::TargetTransformInfo const&, unsigned int, llvm::AssumptionCache*) ()
   from librustc_llvm-fe3cdf61.so
#15 0x00007faaa9bb0ec6 in (anonymous
namespace)::SimplifyCFGOpt::SimplifySwitch(llvm::SwitchInst*,
llvm::IRBuilder<true, llvm::ConstantFolder,
llvm::IRBuilderDefaultInserter<true> >&) [clone .constprop.693] () from
librustc_llvm-fe3cdf61.so
#16 0x00007faaaaacb27d in (anonymous
namespace)::SimplifyCFGOpt::run(llvm::BasicBlock*) [clone .constprop.691] ()
   from librustc_llvm-fe3cdf61.so
#17 0x00007faaaaacc1e1 in llvm::SimplifyCFG(llvm::BasicBlock*,
llvm::TargetTransformInfo const&, unsigned int, llvm::AssumptionCache*) ()
   from librustc_llvm-fe3cdf61.so
#18 0x00007faaaa916ed9 in simplifyFunctionCFG(llvm::Function&,
llvm::TargetTransformInfo const&, llvm::AssumptionCache*, int) [clone
.constprop.113] ()
   from librustc_llvm-fe3cdf61.so
#19 0x00007faaaaeec4d3 in llvm::FPPassManager::runOnFunction(llvm::Function&)
()
   from librustc_llvm-fe3cdf61.so
#20 0x00007faaaaeec5e9 in
llvm::legacy::FunctionPassManagerImpl::run(llvm::Function&) ()
   from librustc_llvm-fe3cdf61.so
#21 0x00007faaaaeec734 in
llvm::legacy::FunctionPassManager::run(llvm::Function&) ()
   from librustc_llvm-fe3cdf61.so

-- 
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/20160604/009c05d8/attachment.html>


More information about the llvm-bugs mailing list