[llvm-bugs] [Bug 50094] New: (popcount(x) ^ popcount(y)) & 1 - > (popcount(x ^ y)) & 1
via llvm-bugs
llvm-bugs at lists.llvm.org
Fri Apr 23 06:04:06 PDT 2021
https://bugs.llvm.org/show_bug.cgi?id=50094
Bug ID: 50094
Summary: (popcount(x) ^ popcount(y)) & 1 - > (popcount(x ^ y))
& 1
Product: libraries
Version: trunk
Hardware: PC
OS: Linux
Status: NEW
Severity: enhancement
Priority: P
Component: Scalar Optimizations
Assignee: unassignedbugs at nondot.org
Reporter: david.bolvansky at gmail.com
CC: llvm-bugs at lists.llvm.org
Original pattern: (__builtin_parity(x) ^ __builtin_parity(y))
LLVM rewrites it as: (__builtin_popcount(x) ^ __builtin_popcount(y)) & 1
----------------------------------------
define i32 @src(i32 %0, i32 %1) noread nowrite nofree {
%2:
%3 = ctpop i32 %0
%4 = ctpop i32 %1
%5 = xor i32 %4, %3
%6 = and i32 %5, 1
ret i32 %6
}
=>
define i32 @tgt(i32 %0, i32 %1) noread nowrite nofree {
%2:
%3 = xor i32 %1, %0
%4 = ctpop i32 %3
%5 = and i32 %4, 1
ret i32 %5
}
Transformation seems to be correct!
parity_xor(unsigned int, unsigned int): #
@parity_xor(unsigned int, unsigned int)
popcnt ecx, edi
popcnt eax, esi
xor eax, ecx
and eax, 1
ret
tgt(unsigned int, unsigned int): # @tgt(unsigned
int, unsigned int)
xor edi, esi
popcnt eax, edi
and eax, 1
ret
https://godbolt.org/z/v3h361fz7
--
You are receiving this mail because:
You are on the CC list for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-bugs/attachments/20210423/669c122c/attachment.html>
More information about the llvm-bugs
mailing list