<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/64179>64179</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[AArch64] Cannot select: i32 = setcc [...], ConstantFP:bf16<APFloat(0)>, setune:ch
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
oakrc
</td>
</tr>
</table>
<pre>
[Demo on Compiler Explorer](https://godbolt.org/z/Krhcscs1j)
Minimal reproduction:
```
@G1 = global <8 x bfloat> zeroinitializer
@G2 = global <8 x i1> zeroinitializer
define void @test() {
%A = load <8 x bfloat>, ptr @G1, align 16
%B = fcmp une <8 x bfloat> zeroinitializer, %A
store <8 x i1> %B, ptr @G2, align 1
ret void
}
```
Crash backtrace:
```
LLVM ERROR: Cannot select: 0x8a49940: i32 = setcc 0x8a49320, ConstantFP:bf16<APFloat(0)>, setune:ch
0x8a49320: bf16,ch = load<(dereferenceable load (s16) from @G1 + 12, align 4, basealign 16)> 0x89af640, 0x8a48f30, undef:i64
0x8a48f30: i64 = add 0x8a46020, Constant:i64<12>
0x8a46020: i64 = AArch64ISD::LOADgot TargetGlobalAddress:i64<ptr @G1> 0 [TF=16]
0x8a45680: i64 = TargetGlobalAddress<ptr @G1> 0 [TF=16]
0x8a49b00: i64 = Constant<12>
0x8a453e0: i64 = undef
0x8a454c0: bf16 = ConstantFP<APFloat(0)>
In function: test
PLEASE submit a bug report to https://github.com/llvm/llvm-project/issues/ and include the crash backtrace.
Stack dump:
0. Program arguments: /opt/compiler-explorer/clang-trunk/bin/llc -o /app/output.s -x86-asm-syntax=intel -march=aarch64 <source>
1. Running pass 'Function Pass Manager' on module '<source>'.
2. Running pass 'AArch64 Instruction Selection' on function '@test'
#0 0x0000000003069058 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/opt/compiler-explorer/clang-trunk/bin/llc+0x3069058)
#1 0x0000000003066c1c SignalHandler(int) Signals.cpp:0:0
#2 0x00007f9a64206420 __restore_rt (/lib/x86_64-linux-gnu/libpthread.so.0+0x14420)
#3 0x00007f9a63cc900b raise (/lib/x86_64-linux-gnu/libc.so.6+0x4300b)
#4 0x00007f9a63ca8859 abort (/lib/x86_64-linux-gnu/libc.so.6+0x22859)
#5 0x000000000069dd50 llvm::RISCVISAInfo::updateImplication() (.cold) RISCVISAInfo.cpp:0:0
#6 0x0000000002e51f14 llvm::SelectionDAGISel::CannotYetSelect(llvm::SDNode*) (/opt/compiler-explorer/clang-trunk/bin/llc+0x2e51f14)
#7 0x0000000002e575a5 llvm::SelectionDAGISel::SelectCodeCommon(llvm::SDNode*, unsigned char const*, unsigned int) (/opt/compiler-explorer/clang-trunk/bin/llc+0x2e575a5)
#8 0x0000000000a094dd (anonymous namespace)::AArch64DAGToDAGISel::Select(llvm::SDNode*) AArch64ISelDAGToDAG.cpp:0:0
#9 0x0000000002e4f577 llvm::SelectionDAGISel::DoInstructionSelection() (/opt/compiler-explorer/clang-trunk/bin/llc+0x2e4f577)
#10 0x0000000002e5be35 llvm::SelectionDAGISel::CodeGenAndEmitDAG() (/opt/compiler-explorer/clang-trunk/bin/llc+0x2e5be35)
#11 0x0000000002e5e889 llvm::SelectionDAGISel::SelectAllBasicBlocks(llvm::Function const&) (/opt/compiler-explorer/clang-trunk/bin/llc+0x2e5e889)
#12 0x0000000002e60f56 llvm::SelectionDAGISel::runOnMachineFunction(llvm::MachineFunction&) (.part.0) SelectionDAGISel.cpp:0:0
#13 0x0000000002446f70 llvm::MachineFunctionPass::runOnFunction(llvm::Function&) (.part.0) MachineFunctionPass.cpp:0:0
#14 0x0000000002929352 llvm::FPPassManager::runOnFunction(llvm::Function&) (/opt/compiler-explorer/clang-trunk/bin/llc+0x2929352)
#15 0x00000000029294d1 llvm::FPPassManager::runOnModule(llvm::Module&) (/opt/compiler-explorer/clang-trunk/bin/llc+0x29294d1)
#16 0x000000000292b040 llvm::legacy::PassManagerImpl::run(llvm::Module&) (/opt/compiler-explorer/clang-trunk/bin/llc+0x292b040)
#17 0x0000000000767810 compileModule(char**, llvm::LLVMContext&) llc.cpp:0:0
#18 0x00000000006a8a32 main (/opt/compiler-explorer/clang-trunk/bin/llc+0x6a8a32)
#19 0x00007f9a63caa083 __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24083)
#20 0x000000000075f75e _start (/opt/compiler-explorer/clang-trunk/bin/llc+0x75f75e)
Program terminated with signal: SIGSEGV
Compiler returned: 139
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJy0WF1z26rW_jX4hrEHgT4vcqHYcd7M255m6k5nzlUGIWSzg0ADaNfprz8Dkh3JdU-y255O7VjAetazPlgLQa0Ve8X5DUhuQbJZ0N4dtLnR9NmwRaXrFz-x4a2GWsG1bjshuYF3x05qww1INgDnB-c6C0gJ8Bbg7V7XlZZupc0e4O13gLf_bw7MMhv9BXAB0Aagcvj-KJRoqYSGd0bXPXNCKw8zLEnR-H94jNF9BAHZwL3UFZUQkHUOj7BqpKYOkDv4nRstlHCCSvGdm1cxfEVMRD8XCd81b4Ti8G8taghi5Lh1AOcAFxBkt8MSCAFOygAuNa1_YATwGnbOwEDdP1Ap9gpG6UT8Nog3rO1gr_jbRuF1UHpCsE4bPrfJg04144nmk5jhLlg2Gpxtrrs8fK8NtQdYUfbsDGX8Z_H58OHrR3j3-fOnz4CUcE2V0g5aLjlzfgAdcxoXRYz8gyBDSCx3jI1TBCNPdK2VdVS57SMgZdVEKSDr8nEb3IFz5BNocKzlrleeDTuMVr3ikBIGUbxmh3N4AFkDnNfc8IYbrhinleRj4HBu_fICNka3cEw1fAujifNi_7Oilp-jGLh4tQVt0jjQDxzyhoSHXtW8AaQUaXxyPJys8I5I48CP1vUwkaK5G0Zpso6wt_uMAifLJzhladghjR92Gx8mUn74VG722sEv1Oy5uw87oKxrw609I79mqDcGguT2yxaQTZT6vT1ROKpM0nym8ir0u0GHmFVoBvlq_KXZAwPCZ8sHN49rhhUxOyfBDNFn1ZV0CrIPCja9OtUgGDZ8mHj8cFfu7qDtq1Y4SGHV733F0sZBp-FF7RPu0FcrpluAt1L-ffqz7Iz-y28FvBXW9twCvIVU1VAoJvuaQ3fgkM132mpQv3OUPcO6b7vz1kMrgIpHo_eGtpCafd9y5TwJCPBWd14LGyv1kp8qNd4ySdV-6UyvngHeVkIFcgwutZejXeele9f1bmXh8pinS2rbpX1Rjh4B2QjluITLlhp2AGRDacg1X3ys7o2vDKMnI0_vc6-UUHvYUWshwNl29C189AMfqaJ7TyrzbaXVdS-5XzUDw9noAnwNcMx1-KCsM0PvgLtQb3wEB-BTQAP0qYhnY64ATBBER3T6R1BaoCSHIWxh-9gXO_x4NEK5EIgvoQbi_HWRod-etHWG0xZgX3OgUC70Cd8u_nk4AL5Fx5HLuV96stEF2ZRFDO7EXlH5f1TV0oPmo-5h2K5Y57MGhc8ZCI9AWVPQNMbIf-DTk-GhmzwZN1KXogJ4e8zTpzReSqH643Kv-mGicwfDab2yeoUC4yiOMZrxJVM1hLECoQoaKix_Bz7zyGlAjglC1Qw5niPTPE8KSCv9LuYTZIzzpJghJ1Mfo7So6wRNEuLzw2799WFXPqhGDyN9V1PHH9pOCkaHzMvH4K-YlrX_PZW6HpF0qhbzJGqieKL2nNab8v5hx-UwOvTYf3M3TM-Scrf5l645wOXvJuJIZuak7IJtltDkTbbD6FrXfK3bNvjpKl3fNsOJtIbsQA1kvnRfzvyBHTbynhmWz6JPURHX4XBAlVYvre4tVLTltgsloBioj2VoU95_0VcM_nlUzr2ay5Pw9eQo5u6OmyTL3nT3Rk_q4qQs5r_vt0Dg9SSPSYQuEqLi5O2E8Klwz1Wp6rtWuE15_0fIBd0zctEFOZ7nxTuztZTyllrBbqVmz3YWynM7G_Mz_QPUPbMZdTynnqImSd-kbnr1SX2k7CAUP7GcUf9h7sR91VHjfDkv4CX0j5np-ZEZvzhOm2xaLS8U-cY_oXiV238ldQXvOq94xqvABUnwhNf20YuejiD_mNGvh3hgMgtxckk1rqN3UP0YTkzzsI5Df4RmXEczmukFzQrF00hLvqfsZTwrvRL2bfFM-n9G1nOZkZ31J5SlWR4hOAKfHeebS6jEobO8MvPvsWutHD-edrWU7HqazdtFSnNKMGypUL9l0YAzM6i4OO9QlBP49OQPM0_WUeOeJlrfe_aJUU6mWjCauy1psoTDAf-3DBqQzqpO7y2Om1Yo6ngNvwl3gDYcWf1LzO7hfnd3_3W8fjhdORnueqN47VdEpLi4hFjUN6QuSEEX_CZKCxQXBcryxeEm4VmDcFxwkpEqSdOoyDKGiwTXLM8pqRfiBiNMUIYzTFBM8lUV84KQnDdV1WRpkYAY8ZYKufJJstJmvwivcDdpHGXFQtKKSxtuzzBW_BsMkwBjkGwW5ia8_FX93oIYSWGdfUVxwslw7TaeBECy-fHeZH5VApLb1WoVLt1-7apk0Rt58-uvrMHk_wQAAP__QVDk5A">