use crate::{BLOCK_SIZE, STATE_WORDS};
const K: [u32; BLOCK_SIZE] = [
0xd76aa478, 0xe8c7b756, 0x242070db, 0xc1bdceee, 0xf57c0faf, 0x4787c62a, 0xa8304613, 0xfd469501,
0x698098d8, 0x8b44f7af, 0xffff5bb1, 0x895cd7be, 0x6b901122, 0xfd987193, 0xa679438e, 0x49b40821,
0xf61e2562, 0xc040b340, 0x265e5a51, 0xe9b6c7aa, 0xd62f105d, 0x02441453, 0xd8a1e681, 0xe7d3fbc8,
0x21e1cde6, 0xc33707d6, 0xf4d50d87, 0x455a14ed, 0xa9e3e905, 0xfcefa3f8, 0x676f02d9, 0x8d2a4c8a,
0xfffa3942, 0x8771f681, 0x6d9d6122, 0xfde5380c, 0xa4beea44, 0x4bdecfa9, 0xf6bb4b60, 0xbebfbc70,
0x289b7ec6, 0xeaa127fa, 0xd4ef3085, 0x04881d05, 0xd9d4d039, 0xe6db99e5, 0x1fa27cf8, 0xc4ac5665,
0xf4292244, 0x432aff97, 0xab9423a7, 0xfc93a039, 0x655b59c3, 0x8f0ccc92, 0xffeff47d, 0x85845dd1,
0x6fa87e4f, 0xfe2ce6e0, 0xa3014314, 0x4e0811a1, 0xf7537e82, 0xbd3af235, 0x2ad7d2bb, 0xeb86d391,
];
#[allow(clippy::inline_always)] #[allow(clippy::too_many_lines)] #[allow(clippy::many_single_char_names)] #[allow(clippy::cast_ptr_alignment)] #[inline(always)]
pub(crate) fn transform(state: &mut [u32; STATE_WORDS], block: &[u8; BLOCK_SIZE]) {
let m = block.as_ptr().cast::<u32>();
let mi = |i: usize| -> u32 {
u32::from_le(unsafe { m.add(i).read_unaligned() })
};
let (a0, b0, c0, d0) = (state[0], state[1], state[2], state[3]);
let (mut a, mut b, mut c, mut d) = (a0, b0, c0, d0);
macro_rules! ror {
($x:expr, $r:expr) => {{
let mut v: u32 = $x;
unsafe {
core::arch::asm!(
"ror {v:w}, {v:w}, #{n}",
v = inout(reg) v,
n = const (32u32 - $r),
options(pure, nomem, nostack),
);
}
v
}};
}
macro_rules! f {
($a:ident, $b:ident, $c:ident, $d:ident, $m:expr, $k:expr, $r:expr) => {
$a = $a
.wrapping_add($d ^ ($b & ($c ^ $d)))
.wrapping_add($m)
.wrapping_add($k);
$a = ror!($a, $r).wrapping_add($b);
};
}
macro_rules! g {
($a:ident, $b:ident, $c:ident, $d:ident, $m:expr, $k:expr, $r:expr) => {
$a = $a
.wrapping_add((!$d & $c).wrapping_add($d & $b))
.wrapping_add($m)
.wrapping_add($k);
$a = ror!($a, $r).wrapping_add($b);
};
}
macro_rules! h {
($a:ident, $b:ident, $c:ident, $d:ident, $m:expr, $k:expr, $r:expr) => {
$a = $a
.wrapping_add($b ^ $c ^ $d)
.wrapping_add($m)
.wrapping_add($k);
$a = ror!($a, $r).wrapping_add($b);
};
}
macro_rules! i {
($a:ident, $b:ident, $c:ident, $d:ident, $m:expr, $k:expr, $r:expr) => {
$a = $a
.wrapping_add($c ^ ($b | !$d))
.wrapping_add($m)
.wrapping_add($k);
$a = ror!($a, $r).wrapping_add($b);
};
}
f!(a, b, c, d, mi(0), K[0], 7);
f!(d, a, b, c, mi(1), K[1], 12);
f!(c, d, a, b, mi(2), K[2], 17);
f!(b, c, d, a, mi(3), K[3], 22);
f!(a, b, c, d, mi(4), K[4], 7);
f!(d, a, b, c, mi(5), K[5], 12);
f!(c, d, a, b, mi(6), K[6], 17);
f!(b, c, d, a, mi(7), K[7], 22);
f!(a, b, c, d, mi(8), K[8], 7);
f!(d, a, b, c, mi(9), K[9], 12);
f!(c, d, a, b, mi(10), K[10], 17);
f!(b, c, d, a, mi(11), K[11], 22);
f!(a, b, c, d, mi(12), K[12], 7);
f!(d, a, b, c, mi(13), K[13], 12);
f!(c, d, a, b, mi(14), K[14], 17);
f!(b, c, d, a, mi(15), K[15], 22);
g!(a, b, c, d, mi(1), K[16], 5);
g!(d, a, b, c, mi(6), K[17], 9);
g!(c, d, a, b, mi(11), K[18], 14);
g!(b, c, d, a, mi(0), K[19], 20);
g!(a, b, c, d, mi(5), K[20], 5);
g!(d, a, b, c, mi(10), K[21], 9);
g!(c, d, a, b, mi(15), K[22], 14);
g!(b, c, d, a, mi(4), K[23], 20);
g!(a, b, c, d, mi(9), K[24], 5);
g!(d, a, b, c, mi(14), K[25], 9);
g!(c, d, a, b, mi(3), K[26], 14);
g!(b, c, d, a, mi(8), K[27], 20);
g!(a, b, c, d, mi(13), K[28], 5);
g!(d, a, b, c, mi(2), K[29], 9);
g!(c, d, a, b, mi(7), K[30], 14);
g!(b, c, d, a, mi(12), K[31], 20);
h!(a, b, c, d, mi(5), K[32], 4);
h!(d, a, b, c, mi(8), K[33], 11);
h!(c, d, a, b, mi(11), K[34], 16);
h!(b, c, d, a, mi(14), K[35], 23);
h!(a, b, c, d, mi(1), K[36], 4);
h!(d, a, b, c, mi(4), K[37], 11);
h!(c, d, a, b, mi(7), K[38], 16);
h!(b, c, d, a, mi(10), K[39], 23);
h!(a, b, c, d, mi(13), K[40], 4);
h!(d, a, b, c, mi(0), K[41], 11);
h!(c, d, a, b, mi(3), K[42], 16);
h!(b, c, d, a, mi(6), K[43], 23);
h!(a, b, c, d, mi(9), K[44], 4);
h!(d, a, b, c, mi(12), K[45], 11);
h!(c, d, a, b, mi(15), K[46], 16);
h!(b, c, d, a, mi(2), K[47], 23);
i!(a, b, c, d, mi(0), K[48], 6);
i!(d, a, b, c, mi(7), K[49], 10);
i!(c, d, a, b, mi(14), K[50], 15);
i!(b, c, d, a, mi(5), K[51], 21);
i!(a, b, c, d, mi(12), K[52], 6);
i!(d, a, b, c, mi(3), K[53], 10);
i!(c, d, a, b, mi(10), K[54], 15);
i!(b, c, d, a, mi(1), K[55], 21);
i!(a, b, c, d, mi(8), K[56], 6);
i!(d, a, b, c, mi(15), K[57], 10);
i!(c, d, a, b, mi(6), K[58], 15);
i!(b, c, d, a, mi(13), K[59], 21);
i!(a, b, c, d, mi(4), K[60], 6);
i!(d, a, b, c, mi(11), K[61], 10);
i!(c, d, a, b, mi(2), K[62], 15);
i!(b, c, d, a, mi(9), K[63], 21);
state[0] = a0.wrapping_add(a);
state[1] = b0.wrapping_add(b);
state[2] = c0.wrapping_add(c);
state[3] = d0.wrapping_add(d);
}