<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/63868>63868</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
Splat of not could be canonicalised
</td>
</tr>
<tr>
<th>Labels</th>
<td>
llvm:instcombine
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
lukel97
</td>
</tr>
</table>
<pre>
Alive link: https://alive2.llvm.org/ce/z/4KIIpC
If we have a scalar value that we want negate and then splat, we can either:
1) negate the scalar, then splat
2) splat it, then negate the vector
```llvm
define <2 x i32> @src(i32 %x, <2 x i32> %y) {
%not.x = xor i32 %x, -1
%not.x.head = insertelement <2 x i32> poison, i32 %not.x, i64 0
%not.x.splat = shufflevector <2 x i32> %not.x.head, <2 x i32> poison, <2 x i32> zeroinitializer
%res = and <2 x i32> %not.x.splat, %y
ret <2 x i32> %res
}
define <2 x i32> @tgt(i32 %x, <2 x i32> %y) {
%x.head = insertelement <2 x i32> poison, i32 %x, i64 0
%x.splat = shufflevector <2 x i32> %x.head, <2 x i32> poison, <2 x i32> zeroinitializer
%not.x.splat = xor <2 x i32> %x.splat, shufflevector (<2 x i32> insertelement (<2 x i32> poison, i32 -1, i32 0), <2 x i32> poison, <2 x i32> zeroinitializer)
%res = and <2 x i32> %not.x.splat, %y
ret <2 x i32> %res
}
```
InstCombine doesn't seem to canonicalise it, but I think it could be beneficial to transform to the former.
This would aid in instruction selection for some instructions like [`vandn.vx`](https://github.com/riscv/riscv-crypto/blob/master/doc/vector/insns/vandn.adoc) on RISC-V
(Excuse the gratuitous splatting: this originally came from an example on scalable vectors, but I had to convert it to fixed for it to work on Alive)
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJy8VUGP6jYQ_jXmMgKFSQjJIQcevEiot76qd8eZEBfHRrbDsvvrKzuwC2xf1a6qSojE9sw3M98433Dn5EETVWz1ja12Mz763thKjUdS5XrWmPa12ih5JlBSH1m6gd77k2PphmHNsObhDBdKnYeFsQeGtSCG9RvDOvtlvz9tWbJjyWb633fwQtDzMwEHJ7jiFs5cjQS-5z6cvXDtQdOBewKuW_A9aXAnxT3DbTAQXANJ35MNKUTUJcPy5uN7ugIH-zvvaInBMq5B-neDO9czCW_sfcosT6ZfqHDaaqmTmoClW4QLyBRZ-h1YljgrGBYyRWC4ugT4JxNcvYYE2PrbBARhSxu_uABLd3AxFu6958ur2c1q0RNvo6nUjqwnRQNp_xTmZKQzOgBcwaJvXOcZJM-YEx0B1PVj1ymaOPic-0cKn0v7iPm4_0bWSC295Eq-kb0r25KLQUOTfxLqve2RuKurped6J7Brt9a7--b9rFP-4P9lp4LdF-n_RP0E9o95_-84f2745a_DvfP-lBgWj8ZPLDwfPxIxX97eEobl16vB8n-8RLdv_0HDtPNbMzThYrWGnGa49uCIBvAmyJPRUnAlHV01phk97MH3Uh9BehBmVC00BA1p6qSQXAVHb7l2nbERJUhReCe7mIL-1ksHL9GTyxakDuR7OwovjQZHiqa3zlhwZqD7YwdKHgmCvufJmetWL86XUNRqx7B4VPOD9P3YLIQZGNZWOnG-PefCvp68YVg3yjQM64E7H_pRt0YwrK_KibXUTruwESPxeFqC0fDr_sd2_vuDtmLx_SJGN2nvwXI_Sm9GN0m0l_oQ5o0PtRsrD1JzpV5B8IGgs2aAMAoufDgpCvhR9ht1E3H3wX3P29gbo89kg_SHVScv1EbCpvWLsccAE4cdw3LWVmlbpiWfUbXMizJdYVFks75quUgQiwZzohWlyEtsS8GJpw0VTVnOZIUJpsl6mS3zbInZommLvGm6LOFlLopVx7KEBi7V-9ScSedGqvK0yIuZ4g0pF-cxYpw66Sa0U0yXjiGGOW2rcDRvxoNjWaKk8-4DzkuvqPoRP3TTgTZ31-7-hraz0arqb65ADD895idr_iDhQ4tDtqHHMeE_AwAA__8nZn48">