master
 1//! parity - if number of bits set is even => 0, else => 1
 2//! - pariytXi2_generic for big and little endian
 3
 4const std = @import("std");
 5const builtin = @import("builtin");
 6const common = @import("common.zig");
 7
 8pub const panic = common.panic;
 9
10comptime {
11    @export(&__paritysi2, .{ .name = "__paritysi2", .linkage = common.linkage, .visibility = common.visibility });
12    @export(&__paritydi2, .{ .name = "__paritydi2", .linkage = common.linkage, .visibility = common.visibility });
13    @export(&__parityti2, .{ .name = "__parityti2", .linkage = common.linkage, .visibility = common.visibility });
14}
15
16pub fn __paritysi2(a: i32) callconv(.c) i32 {
17    return parityXi2(i32, a);
18}
19
20pub fn __paritydi2(a: i64) callconv(.c) i32 {
21    return parityXi2(i64, a);
22}
23
24pub fn __parityti2(a: i128) callconv(.c) i32 {
25    return parityXi2(i128, a);
26}
27
28inline fn parityXi2(comptime T: type, a: T) i32 {
29    var x: std.meta.Int(.unsigned, @typeInfo(T).int.bits) = @bitCast(a);
30    // Bit Twiddling Hacks: Compute parity in parallel
31    comptime var shift: u8 = @bitSizeOf(T) / 2;
32    inline while (shift > 2) {
33        x ^= x >> shift;
34        shift = shift >> 1;
35    }
36    x &= 0xf;
37    return (@as(u16, 0x6996) >> @intCast(x)) & 1; // optimization for >>2 and >>1
38}
39
40test {
41    _ = @import("paritysi2_test.zig");
42    _ = @import("paritydi2_test.zig");
43    _ = @import("parityti2_test.zig");
44}