#![allow(clippy::arithmetic_side_effects)]
use crate::U256;
use elliptic_curve::{
bigint::cpubits,
ff::PrimeField,
subtle::{Choice, ConstantTimeEq, CtOption},
};
cpubits! {
32 => {
#[path = "field/bignp256_32.rs"]
#[allow(
dead_code,
clippy::cast_possible_truncation,
clippy::cast_possible_wrap,
clippy::cast_sign_loss,
clippy::identity_op,
clippy::needless_lifetimes,
clippy::too_many_arguments,
clippy::unnecessary_cast
)]
mod field_impl;
}
64 => {
#[path = "field/bignp256_64.rs"]
#[allow(
dead_code,
clippy::cast_possible_truncation,
clippy::cast_possible_wrap,
clippy::cast_sign_loss,
clippy::identity_op,
clippy::needless_lifetimes,
clippy::too_many_arguments,
clippy::unnecessary_cast
)]
mod field_impl;
}
}
use self::field_impl::*;
const MODULUS_HEX: &str = "ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff43";
primefield::monty_field_params! {
name: FieldParams,
modulus: MODULUS_HEX,
uint: U256,
byte_order: primefield::ByteOrder::LittleEndian,
multiplicative_generator: 2,
doc: "Montgomery parameters for the bign-curve256v1 field modulus p = 2^{256} − 189"
}
primefield::monty_field_element! {
name: FieldElement,
params: FieldParams,
uint: U256,
doc: "Element in the bign-curve256v1 finite field modulo p = 2^{256} − 189"
}
primefield::fiat_monty_field_arithmetic! {
name: FieldElement,
params: FieldParams,
uint: U256,
non_mont: fiat_bignp256_non_montgomery_domain_field_element,
mont: fiat_bignp256_montgomery_domain_field_element,
from_mont: fiat_bignp256_from_montgomery,
to_mont: fiat_bignp256_to_montgomery,
add: fiat_bignp256_add,
sub: fiat_bignp256_sub,
mul: fiat_bignp256_mul,
neg: fiat_bignp256_opp,
square: fiat_bignp256_square,
divstep_precomp: fiat_bignp256_divstep_precomp,
divstep: fiat_bignp256_divstep,
msat: fiat_bignp256_msat,
selectnz: fiat_bignp256_selectznz
}
#[cfg(test)]
mod tests {
use super::{FieldElement, U256};
use super::{
FieldParams, fiat_bignp256_montgomery_domain_field_element, fiat_bignp256_msat,
fiat_bignp256_non_montgomery_domain_field_element, fiat_bignp256_to_montgomery,
};
primefield::test_primefield!(FieldElement, U256);
primefield::test_fiat_monty_field_arithmetic!(
name: FieldElement,
params: FieldParams,
uint: U256,
non_mont: fiat_bignp256_non_montgomery_domain_field_element,
mont: fiat_bignp256_montgomery_domain_field_element,
to_mont: fiat_bignp256_to_montgomery,
msat: fiat_bignp256_msat
);
}