<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/63813>63813</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
[AArch64] Cannot select `AArch64ISD::SRAD_MERGE_OP1` for `srem` with vector of -1's
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
HazyFish
</td>
</tr>
</table>
<pre>
## Description
When enabling `sve` feature on AArch64, the following code crashes with `LLVM ERROR: Cannot select: t25: nxv16i8 = AArch64ISD::SRAD_MERGE_OP1 t24, t21, TargetConstant:i32<0>`.
This problem is similar to a previously fixed issue #59647 but with different cause.
## Minimal Reproduction
https://godbolt.org/z/1jqa7eqK6
### Code
```ll
define void @test(ptr %0) {
%V1 = load <8 x i8>, ptr %0
%V2 = srem <8 x i8> %V1, <i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1>
store <8 x i8> %V2, ptr %0
ret void
}
```
### Stack Trace
```console
LLVM ERROR: Cannot select: t25: nxv16i8 = AArch64ISD::SRAD_MERGE_OP1 t24, t21, TargetConstant:i32<0>
t24: nxv16i1 = AArch64ISD::PTRUE TargetConstant:i32<8>
t23: i32 = TargetConstant<8>
t21: nxv16i8 = insert_subvector undef:nxv16i8, t5, Constant:i64<0>
t20: nxv16i8 = undef
t5: v8i8,ch = load<(load (s64) from %ir.0)> t0, t2, undef:i64
t2: i64,ch = CopyFromReg t0, Register:i64 %0
t1: i64 = Register %0
t4: i64 = undef
t19: i64 = Constant<0>
t22: i32 = TargetConstant<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-assertions-trunk/bin/llc -o /app/output.s -x86-asm-syntax=intel -mtriple=aarch64 -mattr=+v9a <source>
1. Running pass 'Function Pass Manager' on module '<source>'.
2. Running pass 'AArch64 Instruction Selection' on function '@test'
#0 0x0000557c07b7a15f llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x354b15f)
#1 0x0000557c07b778b4 SignalHandler(int) Signals.cpp:0:0
#2 0x00007faa7e7ba420 __restore_rt (/lib/x86_64-linux-gnu/libpthread.so.0+0x14420)
#3 0x00007faa7e28700b raise (/lib/x86_64-linux-gnu/libc.so.6+0x4300b)
#4 0x00007faa7e266859 abort (/lib/x86_64-linux-gnu/libc.so.6+0x22859)
#5 0x0000557c04e09a66 llvm::RISCVISAInfo::updateImplication() (.cold) RISCVISAInfo.cpp:0:0
#6 0x0000557c0793702d llvm::SelectionDAGISel::CannotYetSelect(llvm::SDNode*) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x330802d)
#7 0x0000557c07938f6a llvm::SelectionDAGISel::SelectCodeCommon(llvm::SDNode*, unsigned char const*, unsigned int) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x3309f6a)
#8 0x0000557c05175f0b (anonymous namespace)::AArch64DAGToDAGISel::Select(llvm::SDNode*) AArch64ISelDAGToDAG.cpp:0:0
#9 0x0000557c07933630 llvm::SelectionDAGISel::DoInstructionSelection() (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x3304630)
#10 0x0000557c07940e44 llvm::SelectionDAGISel::CodeGenAndEmitDAG() (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x3311e44)
#11 0x0000557c079444c8 llvm::SelectionDAGISel::SelectAllBasicBlocks(llvm::Function const&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x33154c8)
#12 0x0000557c07946192 llvm::SelectionDAGISel::runOnMachineFunction(llvm::MachineFunction&) (.part.0) SelectionDAGISel.cpp:0:0
#13 0x0000557c06e196ce llvm::MachineFunctionPass::runOnFunction(llvm::Function&) (.part.0) MachineFunctionPass.cpp:0:0
#14 0x0000557c073b37f1 llvm::FPPassManager::runOnFunction(llvm::Function&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x2d847f1)
#15 0x0000557c073b3a39 llvm::FPPassManager::runOnModule(llvm::Module&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x2d84a39)
#16 0x0000557c073b42b2 llvm::legacy::PassManagerImpl::run(llvm::Module&) (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x2d852b2)
#17 0x0000557c04ec6634 compileModule(char**, llvm::LLVMContext&) llc.cpp:0:0
#18 0x0000557c04e0ef06 main (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x7dff06)
#19 0x00007faa7e268083 __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x24083)
#20 0x0000557c04ebca1e _start (/opt/compiler-explorer/clang-assertions-trunk/bin/llc+0x88da1e)
Program terminated with signal: SIGSEGV
Compiler returned: 139
```
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzEWN1y4yoSfhpyQ9mFQELSRS4cO85J7WQnZc_O1l65kIRsziDQAZRxztNvgWRH8nh-dk9qt2rGdqD5-usfdbdg1oq94vwWJHcgWd2wzh20uf2N_fm6FvZwU-jq9RZgAjCBK25LI1ontAJoBdCi__zngSvIFSukUHsIKLIvHFAEa85cZzjUCi4WpjzQGOAldAcOay2l_uqlS11xWBpmD9zCr8Id_PkPHz4_wfvN5uMGkAVcMqW0g5ZLXjq_4HDiv9TxJaIig4CsTviP2xUgC0AW281itXu63zzc7z4-R9DhXjWO_NcnZvbcLbWyjimPKAgGZIkAuQcUzcemfToIC1ujC8kbKCy0ohGSGeg0ZLA1_EXozspXWIsjr6CwtuMQYJLkNE5h0bnepErUNTdcOViyzvKJhsG1T0KJhkm44a3RVVde-vjgXGu9bXgN8Hqvq0JLN9dmD_D6T4DX0e9_sJT_8Tf6LbaHX-qKT3Yo6v9J2S9UvBaKwxctKghi5Lh1AGetMxDgBAGcQ5De9aLQL32Ogt-lZhUEZJnBIxSZdyBewvOpkTgO4tbwZiLeQ_lDgCxFBmfh91_5Qe5Paq3Thn-rDV-jaLgLtg_eSVcXbrru1a1j5Rf4ybDyunNLrayWw97_MakHI_2Bs4roqornT5t_3H8PKxtheTTi0QTpQ3t5ZiLtOV4YJ5Tlxu1sV7zw0mkDO1XxGpDFIBRMS_znmAeNL2zy2OgSu4d6kwiefckCaHk4Jy4gS4CzPoVxZn15ymFtdONTQ5i5T3ufNQ71fvafJ5aeyVmBJxF8ESrcoGGp29e10c2G7weEDd8L67jpj4_zz0XD8XDyJDfJ0KAlHotdWhnl491RJKY5gH8YtTfZRwXrTvWFyOenrwhh4_nD_WJ7D21XNMJBBotuDw1vtXG-LF4UKuEOXTEvdQPwWsqX09esNfp3n_l4HYqmBXgNmaqgUKXsKh66RGgLsGDlF-cfsaFs9g9d1TWt1xKWfM3On43eG9ZAZvZdw5XzJCDAa916LaVuWiG5mfFjK7Xhxq9JpvYzZn0iCq3szJlOfQF4XQgVeJZwpj0Ea1sP1Lm2c3MLZ8eMzphtZvZVOXYEZCWU4xLOGmdEKzkgK8bCcwVnDXPOALIC-O4lZ74aWd2Zkp_dHHnum04p3w1bZi0EOF0PjofPfuGJKbb3jFPfShtdddJ3mXQChtPBP_ga4PCcw0dlnem7C9yG2uPD2wOfoh2gTy0gHRIHYIIgOiKEUJKkJUqLlEVJDUNMQ-mwr3aoIUYoF6LUV0acvQkZ9nWnrTOcNQDTULWVC90FZ38xVgDfoSNJ4iJKav_gnnlHF7zTrIjhVuwVk78xVUmPnw00-mU7L1ufXSj8PwPhASitGUt5WrAYI7jbGR46zc64wQopCoDXx4zuaDyTQnXH2V51_UbrDoazam61Ly936BjFMUYTvmSiBmcpQgU0TFj-C_ilR6YBOSYIFRPkeIpMaZbkkBX6l5iPkDHOknyCnIx9HHOUM0pHubF53C4_P24Xj6rW_UrXVszxx6aVomR9EmZDHsxLLSv_e3zqekToJLQ5SRGuRmrPGb5aPDxuuexX-9b7L-767Ul-bld_95MSXrxnThKUIVxN_JVeEM9qyn5KvF_1o9xSN01w2VXmvkuFob6C5YEZ6McQd7nzzs8dQXlN2cTGbGxjEqVJjQqvjymtXhvdWahYw20bakTeWzHUqdXi4ZO-Yvv3Y3UeZLg8Hb6eMvmF5wkl6KeeX-lR4RzVzex9XRhT8lYKfOWaltw8RjyOf57fuuIPXC1Udd8It1o8vDfPKOJxPOEZXfCM4zL7xXReSHnHrCjvpC6_2EmAz11wSGD6vlYkcZlNrMAXVtAoxz-1wnTqo3pi5UEofiI8seKbvZMZ85YZF4ZMeAn9bep6fmTMj_IopyWH31XkR4cRxavcfkjqCt51XvHEb6QgaR2NeK2f_dHTEPMfM3qPaOMqi9M6mkQ7uWTNSP4LrJ_C-DWN8LD03owZySeM6QXjGBfj_JR8z8rXYQZ74-577Jn__4J3ggs84Z1Oh4OSUhLDQcfZnb5ThVoe2tQbSf_avNTK8eOpAkhZXs_D7GII4TWisGFCvZdxaVXXiE5syy9GqgxlBO52fl7aWceM240I_Op4FaOMjLVgNLWsKFnEYY__XrZlWcUiftZ6epty3DRCMcer_irLhgHZv1ptHx-29w-fe_HloBga7jqjeOUlIpJfXIjcVLekyknObvhtRLM8ilJKyM3hNk85zXES04QUrCpozVlV1DVNeUppUlc34hYjTFAaRd4dhMzTuqgpw5iiGGcRK0GMeMOEnPvUmWuzvwkvlreUZBG5kazg0oY7TowV_9pf1QGMQbK6MbfhlbTo9hbESArr7BuKE06Gy9HTFWayml7eQEDRj29qwl2oNuFm1PDG_xl8OVx86DpcYKX2pjPy9r9_fw6W_jsAAP__995wcw">