Skip to content

Commit

Permalink
sha2: Implement slightly more efficient construction of W.
Browse files Browse the repository at this point in the history
  • Loading branch information
briansmith committed Jan 16, 2025
1 parent 0223acb commit ba0243b
Showing 1 changed file with 18 additions and 6 deletions.
24 changes: 18 additions & 6 deletions src/digest/sha2/fallback.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,12 +41,11 @@ where

// FIPS 180-4 {6.2.2, 6.4.2} Step 1
//
// TODO: Use `let W: [S::ZERO; S::ROUNDS]` instead of allocating
// `MAX_ROUNDS` items and then slicing to `K.len()`; depends on
// TODO(MSRV): Use `let W: [S::from(0); S::ROUNDS]` instead; depends on
// https://github.com/rust-lang/rust/issues/43408.
let mut W = [S::ZERO; MAX_ROUNDS];
let mut W = S::zero_w();
let W: &[S] = {
let W = &mut W[..S::K.len()];
let W = W.as_mut();
for (W, M) in W.iter_mut().zip(M) {
let bytes: &S::InputBytes = M.into();
*W = S::from_be_bytes(*bytes);
Expand Down Expand Up @@ -152,11 +151,12 @@ pub(super) trait Sha2: Word + BitXor<Output = Self> + Shr<usize, Output = Self>
const SMALL_SIGMA_0: (u32, u32, usize);
const SMALL_SIGMA_1: (u32, u32, usize);

type W: AsMut<[Self]>;
fn zero_w() -> Self::W;

const K: &'static [Self];
}

const MAX_ROUNDS: usize = 80;

impl Word for Wrapping<u32> {
const ZERO: Self = Self(0);
type InputBytes = [u8; 4];
Expand All @@ -180,6 +180,12 @@ impl Sha2 for Wrapping<u32> {
const SMALL_SIGMA_0: (u32, u32, usize) = (7, 18, 3);
const SMALL_SIGMA_1: (u32, u32, usize) = (17, 19, 10);

// FIPS 180-4 {6.2.2} Step 1
type W = [Self; 64];
fn zero_w() -> Self::W {
[Wrapping(0); 64]
}

// FIPS 180-4 4.2.2
const K: &'static [Self] = &[
Self(0x428a2f98),
Expand Down Expand Up @@ -272,6 +278,12 @@ impl Sha2 for Wrapping<u64> {
const SMALL_SIGMA_0: (u32, u32, usize) = (1, 8, 7);
const SMALL_SIGMA_1: (u32, u32, usize) = (19, 61, 6);

// FIPS 180-4 {6.4.2} Step 1
type W = [Self; 80];
fn zero_w() -> Self::W {
[Wrapping(0); 80]
}

// FIPS 180-4 4.2.3
const K: &'static [Self] = &[
Self(0x428a2f98d728ae22),
Expand Down

0 comments on commit ba0243b

Please sign in to comment.