mirror of
https://github.com/ziglang/zig.git
synced 2026-02-13 04:48:20 +00:00
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.
This commit is contained in:
parent
b30a765b95
commit
d764636d21
@ -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;
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user