| Issue |
172603
|
| Summary |
[MLIR] A crash bug during dialect lowering
|
| Labels |
mlir
|
| Assignees |
|
| Reporter |
RJerrica
|
Hi, I found a crash bug during using MLIR to lower programs. See the minimized code exampel below:
[input.mlir]
```llvm
module attributes {gpu.container_module} {
func.func @f(%arg0: tensor<4x4xf32>) {
%c128_i64 = llvm.mlir.constant(128 : i64) : i64
%c1_i64 = llvm.mlir.constant(1 : i64) : i64
%c128 = builtin.unrealized_conversion_cast %c128_i64 : i64 to index
%c1 = builtin.unrealized_conversion_cast %c1_i64 : i64 to index
%wait_token = gpu.wait async
%launch_token = gpu.launch_func async [%wait_token] @k::@k
blocks in (%c1, %c1, %c1)
threads in (%c1, %c1, %c1)
args(%c128 : index)
return
}
gpu.module @k {
gpu.func @k(%arg0: index) kernel attributes {known_block_size = array<i32: 1, 1, 1>} {
gpu.return
}
}
}
```
I used the command `mlir-opt input.mlir -test-symbol-uses -convert-gpu-to-nvvm -convert-scf-to-cf` to compile it, and got the following crash log:
```bash
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace and instructions to reproduce the bug.
Stack dump:
0. Program arguments: /mnt/raid/home/username/bin/mlir/bin/mlir-opt input.mlir -test-symbol-uses -convert-gpu-to-nvvm -convert-scf-to-cf
#0 0x0000560da26e8508 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x1b3f508)
#1 0x0000560da26e5c35 llvm::sys::RunSignalHandlers() (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x1b3cc35)
#2 0x0000560da26e9611 SignalHandler(int, siginfo_t*, void*) Signals.cpp:0:0
#3 0x00007f4d92045330 (/lib/x86_64-linux-gnu/libc.so.6+0x45330)
#4 0x00007f4d9209eb2c __pthread_kill_implementation ./nptl/pthread_kill.c:44:76
#5 0x00007f4d9209eb2c __pthread_kill_internal ./nptl/pthread_kill.c:78:10
#6 0x00007f4d9209eb2c pthread_kill ./nptl/pthread_kill.c:89:10
#7 0x00007f4d9204527e raise ./signal/../sysdeps/posix/raise.c:27:6
#8 0x00007f4d920288ff abort ./stdlib/abort.c:81:7
#9 0x00007f4d924df90d (/lib/x86_64-linux-gnu/libstdc++.so.6+0xdf90d)
#10 0x0000560da2eae289 mlir::WalkResult llvm::function_ref<mlir::WalkResult (mlir::Operation*)>::callback_fn<(anonymous namespace)::SymbolUsesPass::runOnOperation()::'lambda'(mlir::Operation*)>(long, mlir::Operation*) TestSymbolUses.cpp:0:0
#11 0x0000560da27a18d7 mlir::WalkResult mlir::detail::walk<mlir::ForwardIterator>(mlir::Operation*, llvm::function_ref<mlir::WalkResult (mlir::Operation*)>, mlir::WalkOrder) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x1bf88d7)
#12 0x0000560da2ead2aa (anonymous namespace)::SymbolUsesPass::runOnOperation() TestSymbolUses.cpp:0:0
#13 0x0000560da9957bc1 mlir::detail::OpToOpPassAdaptor::run(mlir::Pass*, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x8daebc1)
#14 0x0000560da9958c07 mlir::detail::OpToOpPassAdaptor::runPipeline(mlir::OpPassManager&, mlir::Operation*, mlir::AnalysisManager, bool, unsigned int, mlir::PassInstrumentor*, mlir::PassInstrumentation::PipelineParentInfo const*) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x8dafc07)
#15 0x0000560da99601a3 mlir::PassManager::runPasses(mlir::Operation*, mlir::AnalysisManager) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x8db71a3)
#16 0x0000560da995f7b2 mlir::PassManager::run(mlir::Operation*) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x8db67b2)
#17 0x0000560da278d603 performActions(llvm::raw_ostream&, std::shared_ptr<llvm::SourceMgr> const&, mlir::MLIRContext*, mlir::MlirOptMainConfig const&) MlirOptMain.cpp:0:0
#18 0x0000560da278c864 llvm::LogicalResult llvm::function_ref<llvm::LogicalResult (std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, llvm::MemoryBufferRef const&, 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::MemoryBufferRef const&, llvm::raw_ostream&) MlirOptMain.cpp:0:0
#19 0x0000560da9c94928 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::MemoryBufferRef const&, llvm::raw_ostream&)>, llvm::raw_ostream&, llvm::StringRef, llvm::StringRef) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x90eb928)
#20 0x0000560da2781dac mlir::MlirOptMain(llvm::raw_ostream&, std::unique_ptr<llvm::MemoryBuffer, std::default_delete<llvm::MemoryBuffer>>, mlir::DialectRegistry&, mlir::MlirOptMainConfig const&) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x1bd8dac)
#21 0x0000560da27820e6 mlir::MlirOptMain(int, char**, llvm::StringRef, llvm::StringRef, mlir::DialectRegistry&) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x1bd90e6)
#22 0x0000560da27822f2 mlir::MlirOptMain(int, char**, llvm::StringRef, mlir::DialectRegistry&) (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x1bd92f2)
#23 0x0000560da26d024f main (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x1b2724f)
#24 0x00007f4d9202a1ca __libc_start_call_main ./csu/../sysdeps/nptl/libc_start_call_main.h:74:3
#25 0x00007f4d9202a28b call_init ./csu/../csu/libc-start.c:128:20
#26 0x00007f4d9202a28b __libc_start_main ./csu/../csu/libc-start.c:347:5
#27 0x0000560da26cfd75 _start (/mnt/raid/home/username/bin/mlir/bin/mlir-opt+0x1b26d75)
Aborted
```
My MLIR version is:
```bash
LLVM (http://llvm.org/):
LLVM version 22.0.0git
Optimized build with assertions.
```
_______________________________________________
llvm-bugs mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-bugs