diff --git a/lib/std/math/big.zig b/lib/std/math/big.zig index c7fc0b17f5..c0d8e74eb2 100644 --- a/lib/std/math/big.zig +++ b/lib/std/math/big.zig @@ -13,7 +13,6 @@ pub const Log2Limb = std.math.Log2Int(Limb); comptime { assert(std.math.floorPowerOfTwo(usize, limb_info.bits) == limb_info.bits); - assert(limb_info.bits <= 64); // u128 set is unsupported assert(limb_info.signedness == .unsigned); } diff --git a/lib/std/math/big/int.zig b/lib/std/math/big/int.zig index d222d6913b..21f5015c6c 100644 --- a/lib/std/math/big/int.zig +++ b/lib/std/math/big/int.zig @@ -30,7 +30,7 @@ pub fn calcLimbLen(scalar: anytype) usize { } const w_value = std.math.absCast(scalar); - return @divFloor(@intCast(Limb, math.log2(w_value)), limb_bits) + 1; + return @intCast(usize, @divFloor(@intCast(Limb, math.log2(w_value)), limb_bits) + 1); } pub fn calcToStringLimbsBufferLen(a_len: usize, base: u8) usize { @@ -238,10 +238,7 @@ pub const Mutable = struct { var i: usize = 0; while (true) : (i += 1) { self.limbs[i] = @truncate(Limb, w_value); - - // TODO: shift == 64 at compile-time fails. Fails on u128 limbs. - w_value >>= limb_bits / 2; - w_value >>= limb_bits / 2; + w_value >>= limb_bits; if (w_value == 0) break; } @@ -258,9 +255,7 @@ pub const Mutable = struct { comptime var i = 0; inline while (true) : (i += 1) { self.limbs[i] = w_value & mask; - - w_value >>= limb_bits / 2; - w_value >>= limb_bits / 2; + w_value >>= limb_bits; if (w_value == 0) break; }