Issue 132161
Summary AArch64 Instruction Selection crashed: undef: nxv4bf16
Labels
Assignees
Reporter penpornk
    cc: @paulwalker-arm, @banach-space

Error message:
```
fatal error: error in backend: Cannot select: 0xc6124c8ed260: nxv4bf16 = AArch64ISD::UINT_TO_FP_MERGE_PASSTHRU 0xc6124c8ea8a0, 0xc6124c8ea980, undef:nxv4bf16
  0xc6124c8ea8a0: nxv4i1 = AArch64ISD::PTRUE TargetConstant:i32<31>
    0xc6124c8e7b20: i32 = TargetConstant<31>
 0xc6124c8ea980: nxv4i32,ch = load<(invariant load (<vscale x 1 x s32>) from %ir.28, !noalias !5), zext from nxv4i8> 0xc6124c8b6450, 0xc6124c8e7180, undef:i64
    0xc6124c8e7180: i64 = add nuw 0xc6124c8e99f0, 0xc6124c8e2980
 0xc6124c8e99f0: i64 = add nuw 0xc6124c8eb160, 0xc6124c8e32b0
 0xc6124c8eb160: i64 = add nuw 0xc6124c8e7730, 0xc6124c8f03a0
 0xc6124c8e7730: i64,ch = CopyFromReg 0xc6124c8b6450, Register:i64 %0
 0xc6124c8e7340: i64 = Register %0
          0xc6124c8f03a0: i64 = mul nuw nsw 0xc6124c8efae0, Constant:i64<10000>
            0xc6124c8efae0: i64,ch = CopyFromReg 0xc6124c8b6450, Register:i64 %3
 0xc6124c8e9980: i64 = Register %3
            0xc6124c8eff40: i64 = Constant<10000>
        0xc6124c8e32b0: i64 = mul nuw nsw 0xc6124c8e9830, Constant:i64<100>
          0xc6124c8e9830: i64,ch = CopyFromReg 0xc6124c8b6450, Register:i64 %4
            0xc6124c8e9050: i64 = Register %4
          0xc6124c8e3320: i64 = Constant<100>
      0xc6124c8e2980: i64,ch = CopyFromReg 0xc6124c8b6450, Register:i64 %8
        0xc6124c8e2de0: i64 = Register %8
    0xc6124c8ec8c0: i64 = undef
  0xc6124c8e9360: nxv4bf16 = undef
In function: convert.2_kernel
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace, preprocessed source, and associated run script.
Stack dump:
0.	Program arguments: clang -c convert.ll --target=aarch64-unknown-linux-gnu -mcpu=neoverse-v2
1.	Code generation
2.	Running pass 'Function Pass Manager' on module 'convert.ll'.
3.	Running pass 'AArch64 Instruction Selection' on function '@convert.2_kernel'
Stack dump without symbol names (ensure you have llvm-symbolizer in your PATH or set the environment var `LLVM_SYMBOLIZER_PATH` to point to it):
0  libLLVM.so.20.1 0x0000e48a27a03ab8 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) + 80
1  libLLVM.so.20.1      0x0000e48a27a01c70 llvm::sys::RunSignalHandlers() + 112
2  libLLVM.so.20.1      0x0000e48a27950e98
3  libLLVM.so.20.1 0x0000e48a27950e44
4  libLLVM.so.20.1      0x0000e48a279fe7a0 llvm::sys::Process::Exit(int, bool) + 48
5  clang 0x0000c6121b3b19b4
6  libLLVM.so.20.1      0x0000e48a2795f674 llvm::report_fatal_error(llvm::Twine const&, bool) + 248
7  libLLVM.so.20.1 0x0000e48a28223990 llvm::SelectionDAGISel::isOrEquivalentToAdd(llvm::SDNode const*) const + 0
8 libLLVM.so.20.1      0x0000e48a28222ee8 llvm::SelectionDAGISel::SelectCodeCommon(llvm::SDNode*, unsigned char const*, unsigned int) + 14136
9  libLLVM.so.20.1      0x0000e48a297b2d90
10 libLLVM.so.20.1      0x0000e48a2821b754 llvm::SelectionDAGISel::DoInstructionSelection() + 344
11 libLLVM.so.20.1 0x0000e48a2821af84 llvm::SelectionDAGISel::CodeGenAndEmitDAG() + 932
12 libLLVM.so.20.1      0x0000e48a2821a730 llvm::SelectionDAGISel::SelectAllBasicBlocks(llvm::Function const&) + 4608
13 libLLVM.so.20.1      0x0000e48a28218d00 llvm::SelectionDAGISel::runOnMachineFunction(llvm::MachineFunction&) + 352
14 libLLVM.so.20.1      0x0000e48a28217600 llvm::SelectionDAGISelLegacy::runOnMachineFunction(llvm::MachineFunction&) + 196
15 libLLVM.so.20.1      0x0000e48a27dd76b0 llvm::MachineFunctionPass::runOnFunction(llvm::Function&) + 580
16 libLLVM.so.20.1      0x0000e48a27b55c50 llvm::FPPassManager::runOnFunction(llvm::Function&) + 520
17 libLLVM.so.20.1 0x0000e48a27b5b2d0 llvm::FPPassManager::runOnModule(llvm::Module&) + 60
18 libLLVM.so.20.1      0x0000e48a27b5623c llvm::legacy::PassManagerImpl::run(llvm::Module&) + 916
19 libclang-cpp.so.20.1 0x0000e48a30b91364 clang::emitBackendOutput(clang::CompilerInstance&, clang::CodeGenOptions&, llvm::StringRef, llvm::Module*, clang::BackendAction, llvm::IntrusiveRefCntPtr<llvm::vfs::FileSystem>, std::unique_ptr<llvm::raw_pwrite_stream, std::default_delete<llvm::raw_pwrite_stream>>, clang::BackendConsumer*) + 2576
20 libclang-cpp.so.20.1 0x0000e48a30edc86c clang::CodeGenAction::ExecuteAction() + 1544
21 libclang-cpp.so.20.1 0x0000e48a318e8c28 clang::FrontendAction::Execute() + 60
22 libclang-cpp.so.20.1 0x0000e48a31876bf0 clang::CompilerInstance::ExecuteAction(clang::FrontendAction&) + 984
23 libclang-cpp.so.20.1 0x0000e48a31965568 clang::ExecuteCompilerInvocation(clang::CompilerInstance*) + 520
24 clang 0x0000c6121b3b1614 cc1_main(llvm::ArrayRef<char const*>, char const*, void*) + 5228
25 clang                0x0000c6121b3aeb2c
26 libclang-cpp.so.20.1 0x0000e48a3156017c
27 libLLVM.so.20.1 0x0000e48a27950e1c llvm::CrashRecoveryContext::RunSafely(llvm::function_ref<void ()>) + 152
28 libclang-cpp.so.20.1 0x0000e48a3155fa90 clang::driver::CC1Command::Execute(llvm::ArrayRef<std::optional<llvm::StringRef>>, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char>>*, bool*) const + 340
29 libclang-cpp.so.20.1 0x0000e48a3152e9b4 clang::driver::Compilation::ExecuteCommand(clang::driver::Command const&, clang::driver::Command const*&, bool) const + 464
30 libclang-cpp.so.20.1 0x0000e48a3152eb60 clang::driver::Compilation::ExecuteJobs(clang::driver::JobList const&, llvm::SmallVectorImpl<std::pair<int, clang::driver::Command const*>>&, bool) const + 132
31 libclang-cpp.so.20.1 0x0000e48a3154650c clang::driver::Driver::ExecuteCompilation(clang::driver::Compilation&, llvm::SmallVectorImpl<std::pair<int, clang::driver::Command const*>>&) + 364
32 clang                0x0000c6121b3ae27c clang_main(int, char**, llvm::ToolContext const&) + 5076
33 clang                0x0000c6121b3b99dc main + 88
34 libc.so.6            0x0000e48a268773fc
35 libc.so.6 0x0000e48a268774cc __libc_start_main + 152
36 clang 0x0000c6121b3acb30 _start + 48
clang: error: clang frontend command failed with exit code 70 (use -v to see invocation)
Ubuntu clang version 20.1.1 (++20250318083326+1cfbb9f33436-1~exp1~20250318203456.81)
Target: aarch64-unknown-linux-gnu
Thread model: posix

```
clang version: 20
Command to reproduce:
```
clang  -c convert.ll --target=aarch64-unknown-linux-gnu -mcpu=neoverse-v2
```

Input file: https://gist.github.com/penpornk/ca9d86e5e91348dc4019cbaf7fda513d

_______________________________________________
llvm-bugs mailing list
llvm-bugs@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-bugs

Reply via email to