Issue 134624
Summary [LoongArch] `Cannot select: t14: ch = Prefetch<(load (s8) from `ptr null`)> t13, Constant:i64<0>, TargetConstant:i32<0>, TargetConstant:i32<0>, TargetConstant:i32<0>`
Labels new issue
Assignees
Reporter alexrp
    ```llvm
target datalayout = "e-m:e-p:64:64-i64:64-i128:128-n32:64-S128"
target triple = "loongarch64-unknown-linux5.19.0-musl"

define fastcc i16 @"prefetch.test.@prefetch()"() {
Entry:
  %0 = alloca [8 x i8], i32 0, align 4
  %1 = load i64, ptr null, align 8
  %2 = insertvalue { ptr, i64 } zeroinitializer, ptr %0, 0
  %3 = insertvalue { ptr, i64 } zeroinitializer, i64 1, 1
  call void @llvm.prefetch.p0(ptr null, i32 0, i32 0, i32 0)
  call void @llvm.prefetch.p0(ptr null, i32 0, i32 1, i32 0)
  call void @llvm.prefetch.p0(ptr null, i32 0, i32 0, i32 0)
  ret i16 0
}

; Function Attrs: nocallback nofree nosync nounwind willreturn memory(argmem: readwrite, inaccessiblemem: readwrite)
declare void @llvm.prefetch.p0(ptr nocapture readonly, i32 immarg, i32 immarg, i32 immarg) #0

; uselistorder directives
uselistorder ptr @llvm.prefetch.p0, { 2, 1, 0 }

attributes #0 = { nocallback nofree nosync nounwind willreturn memory(argmem: readwrite, inaccessiblemem: readwrite) }
```

```console
❯ llc --version | head -n2
LLVM (http://llvm.org/):
  LLVM version 20.1.2
❯ llc reduced.ll -march loongarch64
LLVM ERROR: Cannot select: t14: ch = Prefetch<(load (s8) from `ptr null`)> t13, Constant:i64<0>, TargetConstant:i32<0>, TargetConstant:i32<0>, TargetConstant:i32<0>
  t1: i64 = Constant<0>
  t9: i32 = TargetConstant<0>
  t9: i32 = TargetConstant<0>
  t9: i32 = TargetConstant<0>
In function: prefetch.test.@prefetch()
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0.      Program arguments: llc reduced.ll -march loongarch64
1.      Running pass 'Function Pass Manager' on module 'reduced.ll'.
2.      Running pass 'LoongArch DAG->DAG Pattern Instruction Selection' on function '@"prefetch.test.@prefetch()"'
 #0 0x000074f041d80e02 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) /home/alexrp/Source/llvm-project/llvm/lib/Support/Unix/Signals.inc:803:3
 #1 0x000074f041d7e7af llvm::sys::RunSignalHandlers() /home/alexrp/Source/llvm-project/llvm/lib/Support/Signals.cpp:105:20
 #2 0x000074f041d7eb3d SignalHandler(int) /home/alexrp/Source/llvm-project/llvm/lib/Support/Unix/Signals.inc:415:1
 #3 0x000074f040645330 (/lib/x86_64-linux-gnu/libc.so.6+0x45330)
 #4 0x000074f04069eb2c __pthread_kill_implementation ./nptl/pthread_kill.c:44:76
 #5 0x000074f04069eb2c __pthread_kill_internal ./nptl/pthread_kill.c:78:10
 #6 0x000074f04069eb2c pthread_kill ./nptl/pthread_kill.c:89:10
 #7 0x000074f04064527e raise ./signal/../sysdeps/posix/raise.c:27:6
 #8 0x000074f0406288ff abort ./stdlib/abort.c:81:7
 #9 0x000074f041a93cf9 (/opt/llvm-20/bin/../lib/libLLVM.so.20.1+0xc93cf9)
#10 0x000074f0429aef9c llvm::SDNode::getOperand(unsigned int) const /home/alexrp/Source/llvm-project/llvm/include/llvm/CodeGen/SelectionDAGNodes.h:993:5
#11 0x000074f0429aef9c llvm::SDNode::getConstantOperandVal(unsigned int) const /home/alexrp/Source/llvm-project/llvm/include/llvm/CodeGen/SelectionDAGNodes.h:1724:61
#12 0x000074f0429aef9c llvm::SelectionDAGISel::CannotYetSelect(llvm::SDNode*) /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:4424:44
#13 0x000074f0429b77d3 llvm::SelectionDAG::getEntryNode() const /home/alexrp/Source/llvm-project/llvm/include/llvm/CodeGen/SelectionDAG.h:581:41
#14 0x000074f0429b77d3 llvm::SelectionDAGISel::SelectCodeCommon(llvm::SDNode*, unsigned char const*, unsigned int) /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:4014:42
#15 0x000074f04597366d llvm::TrackingMDRef::untrack() /home/alexrp/Source/llvm-project/llvm/include/llvm/IR/TrackingMDRef.h:89:9
#16 0x000074f04597366d llvm::TrackingMDRef::~TrackingMDRef() /home/alexrp/Source/llvm-project/llvm/include/llvm/IR/TrackingMDRef.h:55:29
#17 0x000074f04597366d llvm::TypedTrackingMDRef<llvm::MDNode>::~TypedTrackingMDRef() /home/alexrp/Source/llvm-project/llvm/include/llvm/IR/TrackingMDRef.h:106:26
#18 0x000074f04597366d llvm::DebugLoc::~DebugLoc() /home/alexrp/Source/llvm-project/llvm/include/llvm/IR/DebugLoc.h:33:9
#19 0x000074f04597366d llvm::SDLoc::~SDLoc() /home/alexrp/Source/llvm-project/llvm/include/llvm/CodeGen/SelectionDAGNodes.h:1182:7
#20 0x000074f04597366d llvm::LoongArchDAGToDAGISel::Select(llvm::SDNode*) /home/alexrp/Source/llvm-project/llvm/lib/Target/LoongArch/LoongArchISelDAGToDAG.cpp:162:1
#21 0x000074f0429ab031 llvm::SmallVectorTemplateCommon<llvm::SDNode*, void>::isSmall() const /home/alexrp/Source/llvm-project/llvm/include/llvm/ADT/SmallVector.h:143:39
#22 0x000074f0429ab031 llvm::SmallVectorImpl<llvm::SDNode*>::~SmallVectorImpl() /home/alexrp/Source/llvm-project/llvm/include/llvm/ADT/SmallVector.h:603:23
#23 0x000074f0429ab031 llvm::SmallVector<llvm::SDNode*, 4u>::~SmallVector() /home/alexrp/Source/llvm-project/llvm/include/llvm/ADT/SmallVector.h:1203:3
#24 0x000074f0429ab031 llvm::SelectionDAGISel::DoInstructionSelection() /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:1354:5
#25 0x000074f0429bbfc7 llvm::TimeRegion::~TimeRegion() /home/alexrp/Source/llvm-project/llvm/include/llvm/Support/Timer.h:160:9
#26 0x000074f0429bbfc7 llvm::NamedRegionTimer::~NamedRegionTimer() /home/alexrp/Source/llvm-project/llvm/include/llvm/Support/Timer.h:168:8
#27 0x000074f0429bbfc7 llvm::SelectionDAGISel::CodeGenAndEmitDAG() /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:1123:3
#28 0x000074f0429c0555 llvm::SelectionDAGISel::SelectAllBasicBlocks(llvm::Function const&) /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:1904:33
#29 0x000074f0429c1c19 llvm::SelectionDAGISel::runOnMachineFunction(llvm::MachineFunction&) /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:616:22
#30 0x000074f0429b2547 llvm::OptLevelChanger::~OptLevelChanger() /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:269:11
#31 0x000074f0429b2547 llvm::SelectionDAGISelLegacy::runOnMachineFunction(llvm::MachineFunction&) /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:376:1
#32 0x000074f0429b2547 llvm::SelectionDAGISelLegacy::runOnMachineFunction(llvm::MachineFunction&) /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp:347:6
#33 0x000074f0422fa58f llvm::MachineFunctionPass::runOnFunction(llvm::Function&) (.part.0) /home/alexrp/Source/llvm-project/llvm/lib/CodeGen/MachineFunctionPass.cpp:94:33
#34 0x000074f041f453a4 llvm::FPPassManager::runOnFunction(llvm::Function&) /home/alexrp/Source/llvm-project/llvm/lib/IR/LegacyPassManager.cpp:1416:7
#35 0x000074f041f455c1 llvm::ilist_detail::node_base_prevnext<llvm::ilist_node_base<true, void>, true>::getNext() const /home/alexrp/Source/llvm-project/llvm/include/llvm/ADT/ilist_node_base.h:42:38
#36 0x000074f041f455c1 llvm::ilist_node_impl<llvm::ilist_detail::node_options<llvm::Function, true, false, void, false, void>>::getNext() /home/alexrp/Source/llvm-project/llvm/include/llvm/ADT/ilist_node.h:117:66
#37 0x000074f041f455c1 llvm::ilist_iterator<llvm::ilist_detail::node_options<llvm::Function, true, false, void, false, void>, false, false>::operator++() /home/alexrp/Source/llvm-project/llvm/include/llvm/ADT/ilist_iterator.h:187:25
#38 0x000074f041f455c1 llvm::FPPassManager::runOnModule(llvm::Module&) /home/alexrp/Source/llvm-project/llvm/lib/IR/LegacyPassManager.cpp:1451:22
#39 0x000074f041f45e0d runOnModule /home/alexrp/Source/llvm-project/llvm/lib/IR/LegacyPassManager.cpp:1528:7
#40 0x000074f041f45e0d llvm::legacy::PassManagerImpl::run(llvm::Module&) /home/alexrp/Source/llvm-project/llvm/lib/IR/LegacyPassManager.cpp:539:55
#41 0x00005757f1f1e9df compileModule(char**, llvm::LLVMContext&) /home/alexrp/Source/llvm-project/llvm/tools/llc/llc.cpp:753:34
#42 0x00005757f1f13057 main /home/alexrp/Source/llvm-project/llvm/tools/llc/llc.cpp:411:35
#43 0x000074f04062a1ca __libc_start_call_main ./csu/../sysdeps/nptl/libc_start_call_main.h:74:3
#44 0x000074f04062a28b call_init ./csu/../csu/libc-start.c:128:20
#45 0x000074f04062a28b __libc_start_main ./csu/../csu/libc-start.c:347:5
#46 0x00005757f1f13de5 _start (/opt/llvm-20/bin/llc+0x12de5)
```
_______________________________________________
llvm-bugs mailing list
llvm-bugs@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-bugs

Reply via email to