From d764636d21f9aafa1e9a33f625156a829cc5d747 Mon Sep 17 00:00:00 2001 From: Frank Denis Date: Tue, 3 Nov 2020 02:01:48 +0100 Subject: [PATCH] Another big-endian fix for Gimli We read and write bytes directly from the state, but in the init function, we potentially endian-swap them. Initialize bytes in native format since we will be reading them in native format as well later. Also use the public interface in the "permute" test rather than an internal interface. The state itself is not meant to be accessed directly, even in tests. --- lib/std/crypto/gimli.zig | 32 +++++--------------------------- 1 file changed, 5 insertions(+), 27 deletions(-) diff --git a/lib/std/crypto/gimli.zig b/lib/std/crypto/gimli.zig index 6f8613e87f..9b0f1d4f22 100644 --- a/lib/std/crypto/gimli.zig +++ b/lib/std/crypto/gimli.zig @@ -33,7 +33,7 @@ pub const State = struct { var data: [BLOCKBYTES / 4]u32 = undefined; var i: usize = 0; while (i < State.BLOCKBYTES) : (i += 4) { - data[i / 4] = mem.readIntLittle(u32, initial_state[i..][0..4]); + data[i / 4] = mem.readIntNative(u32, initial_state[i..][0..4]); } return Self{ .data = data }; } @@ -184,27 +184,11 @@ pub const State = struct { test "permute" { // test vector from gimli-20170627 - var state = State{ - .data = blk: { - var input: [12]u32 = undefined; - var i = @as(u32, 0); - while (i < 12) : (i += 1) { - input[i] = i * i * i + i *% 0x9e3779b9; - } - testing.expectEqualSlices(u32, &input, &[_]u32{ - 0x00000000, 0x9e3779ba, 0x3c6ef37a, 0xdaa66d46, - 0x78dde724, 0x1715611a, 0xb54cdb2e, 0x53845566, - 0xf1bbcfc8, 0x8ff34a5a, 0x2e2ac522, 0xcc624026, - }); - break :blk input; - }, - }; + var input: [48]u8 = undefined; + try std.fmt.hexToBytes(input[0..], "00000000ba79379e7af36e3c466da6da24e7dd781a6115172edb4cb566558453c8cfbbf15a4af38f22c52a2e264062cc"); + var state = State.init(input); state.permute(); - testing.expectEqualSlices(u32, &state.data, &[_]u32{ - 0xba11c85a, 0x91bad119, 0x380ce880, 0xd24c2c68, - 0x3eceffea, 0x277a921c, 0x4f73a0bd, 0xda5a9cd8, - 0x84b673f0, 0x34e52ff7, 0x9e2bef49, 0xf41bb8d6, - }); + htest.assertEqual("5ac811ba19d1ba9180e80c38682c4cd2eaffce3e1c927a27bda0734fd89c5adaf073b684f72fe53449ef2b9ed6b81bf4", state.toSliceConst()); } pub const Hash = struct { @@ -269,9 +253,6 @@ pub fn hash(out: *[Hash.digest_length]u8, in: []const u8, options: Hash.Options) } test "hash" { - // https://github.com/ziglang/zig/issues/5127 - if (std.Target.current.cpu.arch == .mips) return error.SkipZigTest; - // a test vector (30) from NIST KAT submission. var msg: [58 / 2]u8 = undefined; try std.fmt.hexToBytes(&msg, "000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C"); @@ -423,9 +404,6 @@ pub const Aead = struct { }; test "cipher" { - // https://github.com/ziglang/zig/issues/5127 - if (std.Target.current.cpu.arch == .mips) return error.SkipZigTest; - var key: [32]u8 = undefined; try std.fmt.hexToBytes(&key, "000102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F"); var nonce: [16]u8 = undefined;