Issue 131139
Summary [MLIR] using ‘-test-ir-visitors' on 'async.coro.suspend' triggering LLVM ERROR: operation destroyed but still has uses
Labels mlir
Assignees
Reporter sweead
    Test commit: https://github.com/llvm/llvm-project/commit/9e91725fd4d4ee30e98ab2682f93b423590a4ade

Steps to reproduce:
```shell
mlir-opt test.mlir -test-ir-visitors
```
Test case:
```mlir
module {
  func.func private @async_execute_fn() -> !async.token attributes {passthrough = ["presplitcoroutine"]} {
    %0 = async.runtime.create : !async.token
    %1 = async.coro.id
    %2 = async.coro.begin %1
    %3 = async.coro.save %2
    async.runtime.resume %2
    async.coro.suspend %3, ^bb3, ^bb1, ^bb2
  ^bb1:  // pred: ^bb0
    cf.br ^bb2
  ^bb2:  // 2 preds: ^bb0, ^bb1
    cf.br ^bb3
  ^bb3:  // 2 preds: ^bb0, ^bb2
    return %0 : !async.token
  }
}
```
Crash trace:
```console
LLVM ERROR: operation destroyed but still has uses
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0.	Program arguments: /home/workdir/llvm-project/build/bin/./mlir-opt test.mlir -test-ir-visitors
 #0 0x0000562ad7d67228 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x12d1228)
 #1 0x0000562ad7d64d4e llvm::sys::RunSignalHandlers() (/home/workdir/llvm-project/build/bin/./mlir-opt+0x12ced4e)
 #2 0x0000562ad7d67c31 SignalHandler(int, siginfo_t*, void*) Signals.cpp:0:0
 #3 0x00007fd94b697520 (/lib/x86_64-linux-gnu/libc.so.6+0x42520)
 #4 0x00007fd94b6eb9fc pthread_kill (/lib/x86_64-linux-gnu/libc.so.6+0x969fc)
 #5 0x00007fd94b697476 gsignal (/lib/x86_64-linux-gnu/libc.so.6+0x42476)
 #6 0x00007fd94b67d7f3 abort (/lib/x86_64-linux-gnu/libc.so.6+0x287f3)
 #7 0x0000562ad7d8711c llvm::report_fatal_error(llvm::Twine const&, bool) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x12f111c)
 #8 0x0000562ad7d86f66 (/home/workdir/llvm-project/build/bin/./mlir-opt+0x12f0f66)
 #9 0x0000562adaffd29d mlir::Operation::~Operation() (/home/workdir/llvm-project/build/bin/./mlir-opt+0x456729d)
#10 0x0000562adaffdead llvm::ilist_traits<mlir::Operation>::deleteNode(mlir::Operation*) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x4567ead)
#11 0x0000562adaf3d828 mlir::Block::~Block() (/home/workdir/llvm-project/build/bin/./mlir-opt+0x44a7828)
#12 0x0000562adaf3dcfd mlir::Block::erase() (/home/workdir/llvm-project/build/bin/./mlir-opt+0x44a7cfd)
#13 0x0000562adaa40f9e void mlir::detail::walk<mlir::ForwardIterator>(mlir::Operation*, llvm::function_ref<void (mlir::Block*)>, mlir::WalkOrder) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x3faaf9e)
#14 0x0000562adaa40f83 void mlir::detail::walk<mlir::ForwardIterator>(mlir::Operation*, llvm::function_ref<void (mlir::Block*)>, mlir::WalkOrder) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x3faaf83)
#15 0x0000562adb4ee086 (anonymous namespace)::TestIRVisitorsPass::runOnOperation() TestVisitors.cpp:0:0
#16 0x0000562adae5dcd3 mlir::detail::OpToOpPassAdaptor::run(mlir::Pass*, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x43c7cd3)
#17 0x0000562adae5e572 mlir::detail::OpToOpPassAdaptor::runPipeline(mlir::OpPassManager&, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int, mlir::PassInstrumentor*, mlir::PassInstrumentation::PipelineParentInfo const*) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x43c8572)
#18 0x0000562adae60d4e mlir::PassManager::run(mlir::Operation*) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x43cad4e)
#19 0x0000562adae592cb performActions(llvm::raw_ostream&, std::shared_ptr<llvm::SourceMgr> const&, mlir::MLIRContext*, mlir::MlirOptMainConfig const&) MlirOptMain.cpp:0:0
#20 0x0000562adae58f23 llvm::LogicalResult llvm::function_ref<llvm::LogicalResult (std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, llvm::raw_ostream&)>::callback_fn<mlir::MlirOptMain(llvm::raw_ostream&, std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, mlir::DialectRegistry&, mlir::MlirOptMainConfig const&)::$_0>(long, std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, llvm::raw_ostream&) MlirOptMain.cpp:0:0
#21 0x0000562adaf04475 mlir::splitAndProcessBuffer(std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, llvm::function_ref<llvm::LogicalResult (std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, llvm::raw_ostream&)>, llvm::raw_ostream&, llvm::StringRef, llvm::StringRef) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x446e475)
#22 0x0000562adae52b82 mlir::MlirOptMain(llvm::raw_ostream&, std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, mlir::DialectRegistry&, mlir::MlirOptMainConfig const&) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x43bcb82)
#23 0x0000562adae52e33 mlir::MlirOptMain(int, char**, llvm::StringRef, llvm::StringRef, mlir::DialectRegistry&) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x43bce33)
#24 0x0000562adae53042 mlir::MlirOptMain(int, char**, llvm::StringRef, mlir::DialectRegistry&) (/home/workdir/llvm-project/build/bin/./mlir-opt+0x43bd042)
#25 0x0000562ad7d469af main (/home/workdir/llvm-project/build/bin/./mlir-opt+0x12b09af)
#26 0x00007fd94b67ed90 (/lib/x86_64-linux-gnu/libc.so.6+0x29d90)
#27 0x00007fd94b67ee40 __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x29e40)
#28 0x0000562ad7d46505 _start (/home/workdir/llvm-project/build/bin/./mlir-opt+0x12b0505)
```
_______________________________________________
llvm-bugs mailing list
llvm-bugs@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-bugs

Reply via email to