craig.topper created this revision. craig.topper added reviewers: scanon, MaskRay, efriedma. Herald added a project: Sanitizers. Herald added a subscriber: Sanitizers. craig.topper requested review of this revision.
No point in making __parityti2 go through 2 calls to get to __paritysi2. Repository: rG LLVM Github Monorepo https://reviews.llvm.org/D87218 Files: compiler-rt/lib/builtins/paritydi2.c compiler-rt/lib/builtins/parityti2.c Index: compiler-rt/lib/builtins/parityti2.c =================================================================== --- compiler-rt/lib/builtins/parityti2.c +++ compiler-rt/lib/builtins/parityti2.c @@ -18,8 +18,14 @@ COMPILER_RT_ABI int __parityti2(ti_int a) { twords x; + dwords x2; x.all = a; - return __paritydi2(x.s.high ^ x.s.low); + x2.all = x.s.high ^ x.s.low; + su_int x3 = x2.s.high ^ x2.s.low; + x3 ^= x3 >> 16; + x3 ^= x3 >> 8; + x3 ^= x3 >> 4; + return (0x6996 >> (x3 & 0xF)) & 1; } #endif // CRT_HAS_128BIT Index: compiler-rt/lib/builtins/paritydi2.c =================================================================== --- compiler-rt/lib/builtins/paritydi2.c +++ compiler-rt/lib/builtins/paritydi2.c @@ -17,5 +17,9 @@ COMPILER_RT_ABI int __paritydi2(di_int a) { dwords x; x.all = a; - return __paritysi2(x.s.high ^ x.s.low); + su_int x2 = x.s.high ^ x.s.low; + x2 ^= x2 >> 16; + x2 ^= x2 >> 8; + x2 ^= x2 >> 4; + return (0x6996 >> (x2 & 0xF)) & 1; }
Index: compiler-rt/lib/builtins/parityti2.c =================================================================== --- compiler-rt/lib/builtins/parityti2.c +++ compiler-rt/lib/builtins/parityti2.c @@ -18,8 +18,14 @@ COMPILER_RT_ABI int __parityti2(ti_int a) { twords x; + dwords x2; x.all = a; - return __paritydi2(x.s.high ^ x.s.low); + x2.all = x.s.high ^ x.s.low; + su_int x3 = x2.s.high ^ x2.s.low; + x3 ^= x3 >> 16; + x3 ^= x3 >> 8; + x3 ^= x3 >> 4; + return (0x6996 >> (x3 & 0xF)) & 1; } #endif // CRT_HAS_128BIT Index: compiler-rt/lib/builtins/paritydi2.c =================================================================== --- compiler-rt/lib/builtins/paritydi2.c +++ compiler-rt/lib/builtins/paritydi2.c @@ -17,5 +17,9 @@ COMPILER_RT_ABI int __paritydi2(di_int a) { dwords x; x.all = a; - return __paritysi2(x.s.high ^ x.s.low); + su_int x2 = x.s.high ^ x.s.low; + x2 ^= x2 >> 16; + x2 ^= x2 >> 8; + x2 ^= x2 >> 4; + return (0x6996 >> (x2 & 0xF)) & 1; }
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits