<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/64884>64884</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
copysign of select derived from sign comparison can fold into sign operand
</td>
</tr>
<tr>
<th>Labels</th>
<td>
llvm:optimizations,
missed-optimization,
floating-point
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
arsenm
</td>
</tr>
</table>
<pre>
This can be folded to better use the sign argument to copysign
```
float copysign_conditional(bool cond, float x, float val) {
return __builtin_copysignf(val, cond && x < 0.0f ? -1.0f : 1.0f);
}
```
Produces this IR:
```
define dso_local float @copysign_conditional(i1 noundef zeroext %0, float noundef %1, float noundef %2) local_unnamed_addr #0 {
%4 = fcmp olt float %1, 0.000000e+00
%5 = and i1 %4, %0
%6 = select i1 %5, float -1.000000e+00, float 1.000000e+00
%7 = tail call float @llvm.copysign.f32(float %2, float %6)
ret float %7
}
```
This can be optimized to:
```
define dso_local float @copysign_conditional(i1 noundef zeroext %0, float noundef %1, float noundef %2) local_unnamed_addr #0 {
%4 = select i1 %0, float %1, float 1.000000e+00
%5 = tail call float @llvm.copysign.f32(float %2, float %4)
ret float %5
}
```
Pattern appears here: https://github.com/RadeonOpenCompute/ROCm-Device-Libs/blob/46939af92ad91238c878a82aad2220822073ffa1/ocml/src/powF_base.h#L68
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzUVU1v4zYQ_TXjy8AGNfqwdNAhiSGgwAJbLHo3KHFks6BIgaTS7P76grJje4uk2EMvDQKbnnl8mnmPI8oQ9Mkyt1A-Q3nYyCWenW-lD2ynTe_U9_aPsw44SIs94-iMYoXRYc8xssclMMYzY2JB6U_LxDam_ODm72sQxAHEE1Ti-r_-HI2T8YY5Ds4qHbWz0gDVvXMGUwjoBS_It_vyNWEahP3zhQoR0XNcvMXjsV-0iToRXphHoHrd8LISIlAFVOEbQv6CYidGhLzDbXZZPWFaADWQX8lhf7guPuri8vm7d2oZOGBMQv32DfKP0YpHbRlVcEfjBmmu_UAhPtFBZ2jdYhWP-IO947eIQKW4S_GeBSqzD6OUlFofdlyslROro1TKI1AuHhUEKguE_IDjMM3oTHyv7UosdmL9Y6BnIR52lesuaRXqbGVJ6LXIO6ZaMYEND_EKK-_VJu0fuW-J7LNn7le-KLXBQZoHGY15nXbvWu7GnIDqWx90Z041JZOvlJ4f2t3_iu-PE-HmqCf9Yx2K_7PzP_kjfhIr-wVTyv_AlOIzU8p_mvLRGF6HUabXkkU5zyx9wDN7ToN9jnEOyR_qgLqTjuel3w1uAuq-ScXOfp3ZvrhpXiKn2NeXaXvgVz3w9ovuA1DXG9cDdUXV5I0cG5KqySivh3pfy5qkVEQkaiKxz8dRZkCdGyYD1AU_AHWz-6s79jLw7gyUf6nqjWpzlbg23GZVQ1XZNEJszm1NZZkJmVWiGvaqqEslCqqUyqjPs6IRG92SoFzUlFGe1SR2qlF7VRV5ISWrcsigEDxJbXar-M6fNjqEhduqqOtiY2TPJqwvfKKEgPzpeoplOoEBKPkCRJMOgdX2MXnLreZoe9rOTtuYwuVh49vEt-2XU0jW6xDDvYaoo-H2di-48f3MKfb6lRWO3k2Xi2Rw0yy9Ds6uY5ZuHdQ2ukvWzeylVZvFm_ZffF1bu3xtZ-_-5CECdasSyc9VjL8DAAD__25cE0Q">