[llvm-bugs] [Bug 46472] New: Optimize some bit magic into a faster pattern when nand is not available

via llvm-bugs llvm-bugs at lists.llvm.org
Fri Jun 26 16:45:48 PDT 2020


https://bugs.llvm.org/show_bug.cgi?id=46472

            Bug ID: 46472
           Summary: Optimize some bit magic into a faster pattern when
                    nand is not available
           Product: libraries
           Version: trunk
          Hardware: PC
                OS: Linux
            Status: NEW
          Severity: enhancement
          Priority: P
         Component: Scalar Optimizations
          Assignee: unassignedbugs at nondot.org
          Reporter: gabravier at gmail.com
                CC: llvm-bugs at lists.llvm.org

int f(int a, int b, int c)
{
    return (a & ~c) | (b & c);
}

Unless the target architecture has a nand intruction available (such as x86
with BMI) this can be optimized to `return ((b ^ a) & c) ^ a;`. This
transformation is done by GCC (though sadly it also does it when nand is
available), but not by LLVM

-- 
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/20200626/9d0582be/attachment.html>


More information about the llvm-bugs mailing list