<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/61644>61644</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
Generate better code for absl::bit_ceil
</td>
</tr>
<tr>
<th>Labels</th>
<td>
llvm:instcombine,
missed-optimization
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
kazutakahirata
</td>
</tr>
</table>
<pre>
Compile:
```
// clang -std=c++20 -march=skylake -O3
#include "absl/numeric/bits.h"
unsigned foo(unsigned x) {
return absl::bit_ceil<unsigned>(x);
}
```
I get:
```
%2 = tail call i32 @llvm.ctpop.i32(i32 %0)
%3 = icmp eq i32 %2, 1
%4 = tail call i32 @llvm.ctlz.i32(i32 %0, i1 false)
%5 = select i1 %3, i32 31, i32 32
%6 = sub nsw i32 %5, %4
%7 = shl nuw i32 1, %6
ret i32 %7
```
```
f3 0f b8 c7 popcnt %edi,%eax
31 c9 xor %ecx,%ecx
83 f8 01 cmp $0x1,%eax
0f 94 c1 sete %cl
f3 0f bd c7 lzcnt %edi,%eax
01 c1 add %eax,%ecx
f7 d9 neg %ecx
b8 01 00 00 00 mov $0x1,%eax
c4 e2 71 f7 c0 shlx %ecx,%eax,%eax
```
We could generate the identical code as in https://github.com/llvm/llvm-project/issues/60802:
```
%dec = add i32 %x, -1
%ctlz = tail call i32 @llvm.ctlz.i32(i32 %dec, i1 false)
%sub = sub nsw i32 0, %ctlz
%and = and i32 %1, 31
%sel = shl nuw i32 1, %and
ret i32 %sel
```
https://alive2.llvm.org/ce/z/7aqxmc
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJykVctu6zYQ_RpqM7BBDfXyQovEroquuuyyoMixxYaifEUq9fXXF5TlXMfXMVpUEPRIzpk58ziW9N4cHFHN8leW7xI5hW4Y6zd5noJ8k50ZZZBJO-jv9Xboj8YSEy-M7xi_Xgu-nJdXbBg2oKx0B1j5oJnYKYavDF-Rw6qXo-qY2Pm371a-Eax-F1eeME7ZSRMwRNl6y7BxU0-jUQyb1gS_7hjiberJzdo17IeBYfXxemK4AVa-XlAAI4VpdDAHFS9MvLQm_KnIWCa2VxITvzCsIpOJhcjK3eMS5-tvcKDwvBcADHMEJnYQpLGgpLVgBALLuLXv_VqF43BcG4EMq_nvmPOo4AdbzGyj-iPQN1gwyHAL6Q0qe5rDnn9KsQWTwl5aT5_T5XMgT5ZUiJCoYEYLBJF-POENpbhQphac__uqMI_QKOwGWF6AnQU3XYDpgipuBnWNUD5p_U9t3gvge2grUCXcHcfhqFyIEUkbhtv4IE8LUaSgNveMy3EaxniLcHVaeOrKg0rAvgKeQhzMDMv4Kb0PH0VtMlDpg_ieAl3iK3tXho5l2HOU_YXuOfOjqAAgtYYFfK96X4L-olxHh5tyF3w7l8j5cvbD-5NaVQaEUKYxi-Kfa-3s6XMn5emO_3DOfxCoYbIaDuRolIEgdARGkwtGSQtq0ATSg3HQhXD00Y3zz8_BhG5q12roGTbRBcttdRyHv0gFho3xfiLPsCl4xfFf-FiTmhc49nfZ0VgErG6NGM32n7yoST12I8M8eureW3yxTIx0k1c6fRHnPsTN5hK34jzZLy0onX5gQk_2yXg-91xa8064nuscxgPDRhHD5sywKeW3U68SXQu9ERuZUJ0W5SbPs7Kskq7GotB5gaLAvMJKU1ZUqUKBXGstU5UmpkaOggsUvMg3olpv0k1JFaXUZkWpULCMUy-N_ciezOOti7TIssTKlqyfP3CI8zaIF-N8UEPfGkfxoxKXEXvjPenVcAymN2cZzODi__JdMtbz9rTTwcdRGh_8j1TBBEv1r9cVbSkEGi-7uR_GB1-dZBpt_T8WNhb1TwAAAP__4CcMfA">