commit d764636d21f9aafa1e9a33f625156a829cc5d747 (tree)
parent b30a765b95cf666409c1e5324718a7c8c60af4af
Author: Frank Denis <github@pureftpd.org>
Date: Tue, 3 Nov 2020 02:01:48 +0100
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.
Diffstat:
1 file changed, 5 insertions(+), 27 deletions(-)
diff --git 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;