Skip to content

Commit

Permalink
arithmetic: Have a single place where we define limb length limits.
Browse files Browse the repository at this point in the history
  • Loading branch information
briansmith committed Jan 19, 2025
1 parent 74387d6 commit 18495f7
Show file tree
Hide file tree
Showing 5 changed files with 25 additions and 21 deletions.
14 changes: 12 additions & 2 deletions src/arithmetic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@
// OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
// CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

use crate::limb::LIMB_BITS;

mod constant;

#[cfg(feature = "alloc")]
Expand All @@ -22,7 +24,15 @@ pub mod montgomery;

mod n0;

#[allow(dead_code)]
const BIGINT_MODULUS_MAX_LIMBS: usize = 8192 / crate::limb::LIMB_BITS;
// The minimum number of limbs allowed for any `&[Limb]` operation.
//
// This must be at least 4 for bn_mul_mont to work, at least on x86.
//
// TODO: Use `256 / LIMB_BITS` so that the limit is independent of limb size.
#[allow(dead_code)] // XXX: Presently only used by `bigint`.
pub const MIN_LIMBS: usize = 4;

// The maximum number of limbs allowed for any `&[Limb]` operation.
pub const MAX_LIMBS: usize = 8192 / LIMB_BITS;

pub use self::{constant::limbs_from_hex, inout::InOut};
8 changes: 4 additions & 4 deletions src/arithmetic/bigint.rs
Original file line number Diff line number Diff line change
Expand Up @@ -38,11 +38,11 @@
use self::boxed_limbs::BoxedLimbs;
pub(crate) use self::{
modulus::{Modulus, OwnedModulus, MODULUS_MAX_LIMBS},
modulus::{Modulus, OwnedModulus},
modulusvalue::OwnedModulusValue,
private_exponent::PrivateExponent,
};
use super::{montgomery::*, InOut};
use super::{montgomery::*, InOut, MAX_LIMBS};
use crate::{
bits::BitLength,
c, error,
Expand Down Expand Up @@ -96,7 +96,7 @@ fn from_montgomery_amm<M>(limbs: BoxedLimbs<M>, m: &Modulus<M>) -> Elem<M, Unenc
debug_assert_eq!(limbs.len(), m.limbs().len());

let mut limbs = limbs;
let mut one = [0; MODULUS_MAX_LIMBS];
let mut one = [0; MAX_LIMBS];
one[0] = 1;
let one = &one[..m.limbs().len()];
limbs_mul_mont(
Expand Down Expand Up @@ -201,7 +201,7 @@ pub fn elem_reduced<Larger, Smaller>(
// `limbs_from_mont_in_place` requires this.
assert_eq!(a.limbs.len(), m.limbs().len() * 2);

let mut tmp = [0; MODULUS_MAX_LIMBS];
let mut tmp = [0; MAX_LIMBS];
let tmp = &mut tmp[..a.limbs.len()];
tmp.copy_from_slice(&a.limbs);

Expand Down
9 changes: 0 additions & 9 deletions src/arithmetic/bigint/modulus.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,15 +21,6 @@ use crate::{
};
use core::marker::PhantomData;

/// The x86 implementation of `bn_mul_mont`, at least, requires at least 4
/// limbs. For a long time we have required 4 limbs for all targets, though
/// this may be unnecessary. TODO: Replace this with
/// `n.len() < 256 / LIMB_BITS` so that 32-bit and 64-bit platforms behave the
/// same.
pub const MODULUS_MIN_LIMBS: usize = 4;

pub const MODULUS_MAX_LIMBS: usize = super::super::BIGINT_MODULUS_MAX_LIMBS;

/// The modulus *m* for a ring ℤ/mℤ, along with the precomputed values needed
/// for efficient Montgomery multiplication modulo *m*. The value must be odd
/// and larger than 2. The larger-than-1 requirement is imposed, at least, by
Expand Down
8 changes: 4 additions & 4 deletions src/arithmetic/bigint/modulusvalue.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
// CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

use super::{
modulus::{MODULUS_MAX_LIMBS, MODULUS_MIN_LIMBS},
super::{MAX_LIMBS, MIN_LIMBS},
BoxedLimbs, Modulus, PublicModulus,
};
use crate::{
Expand Down Expand Up @@ -41,11 +41,11 @@ impl<M: PublicModulus> Clone for OwnedModulusValue<M> {
impl<M> OwnedModulusValue<M> {
pub(crate) fn from_be_bytes(input: untrusted::Input) -> Result<Self, error::KeyRejected> {
let n = BoxedLimbs::positive_minimal_width_from_be_bytes(input)?;
if n.len() > MODULUS_MAX_LIMBS {
if n.len() > MAX_LIMBS {
return Err(error::KeyRejected::too_large());
}
const _MODULUS_MIN_LIMBS_AT_LEAST_2: () = assert!(MODULUS_MIN_LIMBS >= 2);
if n.len() < MODULUS_MIN_LIMBS {
const _MODULUS_MIN_LIMBS_AT_LEAST_2: () = assert!(MIN_LIMBS >= 2);
if n.len() < MIN_LIMBS {
return Err(error::KeyRejected::unexpected_error());
}
// The above implies n >= 3, so we don't need to check it.
Expand Down
7 changes: 5 additions & 2 deletions src/arithmetic/montgomery.rs
Original file line number Diff line number Diff line change
Expand Up @@ -150,14 +150,16 @@ prefixed_export! {
n0: &N0,
num_limbs: c::size_t,
) {
use super::MAX_LIMBS;

// The mutable pointer `r` may alias `a` and/or `b`, so the lifetimes of
// any slices for `a` or `b` must not overlap with the lifetime of any
// mutable for `r`.

// Nothing aliases `n`
let n = unsafe { core::slice::from_raw_parts(n, num_limbs) };

let mut tmp = [0; 2 * super::BIGINT_MODULUS_MAX_LIMBS];
let mut tmp = [0; 2 * MAX_LIMBS];
let tmp = &mut tmp[..(2 * num_limbs)];
{
let a: &[Limb] = unsafe { core::slice::from_raw_parts(a, num_limbs) };
Expand Down Expand Up @@ -269,6 +271,7 @@ pub(super) fn limbs_square_mont(r: &mut [Limb], n: &[Limb], n0: &N0, _cpu: cpu::

#[cfg(test)]
mod tests {
use super::super::MAX_LIMBS;
use super::*;
use crate::limb::Limb;

Expand All @@ -290,7 +293,7 @@ mod tests {
];

for (i, (r_input, a, w, expected_retval, expected_r)) in TEST_CASES.iter().enumerate() {
let mut r = [0; super::super::BIGINT_MODULUS_MAX_LIMBS];
let mut r = [0; MAX_LIMBS];
let r = {
let r = &mut r[..r_input.len()];
r.copy_from_slice(r_input);
Expand Down

0 comments on commit 18495f7

Please sign in to comment.