From b6b3e8d436f9e990713c10b2a32b7a12ca5bd0e5 Mon Sep 17 00:00:00 2001 From: Tony Arcieri Date: Thu, 11 Jan 2024 18:51:54 -0700 Subject: [PATCH] p521: simplify `FieldElement::from_uint_unchecked` Uses the newly added `const fn`-friendly version of `Uint::to_le_bytes` --- Cargo.lock | 3 +-- Cargo.toml | 3 +++ p521/src/arithmetic/field.rs | 27 ++++----------------------- 3 files changed, 8 insertions(+), 25 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 4c783557..4ee54b46 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -318,8 +318,7 @@ dependencies = [ [[package]] name = "crypto-bigint" version = "0.6.0-pre.10" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "12979c1e0771d68f02c2fb93fb0ad54e597f82d608fb569db792d99ebd0bb3c5" +source = "git+https://github.com/RustCrypto/crypto-bigint.git#313505f9e748ad462033c957bf0cdad1715934b8" dependencies = [ "hybrid-array", "num-traits", diff --git a/Cargo.toml b/Cargo.toml index 126bda12..aaaa7645 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -17,3 +17,6 @@ members = [ [profile.dev] opt-level = 2 + +[patch.crates-io.crypto-bigint] +git = "https://github.com/RustCrypto/crypto-bigint.git" diff --git a/p521/src/arithmetic/field.rs b/p521/src/arithmetic/field.rs index ba658514..c8d32915 100644 --- a/p521/src/arithmetic/field.rs +++ b/p521/src/arithmetic/field.rs @@ -44,9 +44,6 @@ use elliptic_curve::{ Error, FieldBytesEncoding, }; -#[cfg(target_pointer_width = "32")] -use super::util; - /// Field modulus: p = 2^{521} − 1 pub(crate) const MODULUS: U576 = U576::from_be_hex("00000000000001ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"); @@ -107,34 +104,18 @@ impl FieldElement { pub(crate) const fn from_uint_unchecked(w: U576) -> Self { // Converts the saturated representation used by `U576` into a 66-byte array with a // little-endian byte ordering. - // // TODO(tarcieri): use `FieldBytesEncoding::encode_field_bytes` when `const impl` is stable - #[cfg(target_pointer_width = "32")] - let words = util::u32x18_to_u64x9(w.as_words()); - #[cfg(target_pointer_width = "64")] - let words = w.as_words(); + let le_bytes_wide = w.to_le_bytes(); let mut le_bytes = [0u8; 66]; let mut i = 0; - while i < words.len() - 1 { - let word = words[i].to_le_bytes(); - let start = i * 8; - le_bytes[start] = word[0]; - le_bytes[start + 1] = word[1]; - le_bytes[start + 2] = word[2]; - le_bytes[start + 3] = word[3]; - le_bytes[start + 4] = word[4]; - le_bytes[start + 5] = word[5]; - le_bytes[start + 6] = word[6]; - le_bytes[start + 7] = word[7]; + // Extract the first 66-bytes of the 72-byte (576-bit) little endian serialized value + while i < le_bytes.len() { + le_bytes[i] = le_bytes_wide[i]; i += 1; } - let last_word = words[8].to_le_bytes(); - le_bytes[i * 8] = last_word[0]; - le_bytes[(i * 8) + 1] = last_word[1]; - // Decode the little endian serialization into the unsaturated big integer form used by // the fiat-crypto synthesized code. Self(fiat_p521_from_bytes(&le_bytes))