use nist384::big::NLEN;
use super::super::arch::Chunk;
use types::{ModType, CurveType, CurvePairingType, SexticTwist, SignOfX};
pub const MODULUS: [Chunk; NLEN] = [
0xFFFFFFFF,
0xFFFF0000000000,
0xFFFFFFFFFEFFFF,
0xFFFFFFFFFFFFFF,
0xFFFFFFFFFFFFFF,
0xFFFFFFFFFFFFFF,
0xFFFFFFFFFFFF,
];
pub const R2MODP: [Chunk; NLEN] = [
0xFE000000010000,
0xFFFFFF,
0x2,
0xFFFFFFFE00,
0x1000000020000,
0x0,
0x0,
];
pub const MCONST: Chunk = 0x100000001;
pub const CURVE_COF_I: isize = 1;
pub const CURVE_A: isize = -3;
pub const CURVE_B_I: isize = 0;
pub const CURVE_COF: [Chunk; NLEN] = [0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0];
pub const CURVE_B: [Chunk; NLEN] = [
0x85C8EDD3EC2AEF,
0x398D8A2ED19D2A,
0x8F5013875AC656,
0xFE814112031408,
0xF82D19181D9C6E,
0xE7E4988E056BE3,
0xB3312FA7E23E,
];
pub const CURVE_ORDER: [Chunk; NLEN] = [
0xEC196ACCC52973,
0xDB248B0A77AEC,
0x81F4372DDF581A,
0xFFFFFFFFC7634D,
0xFFFFFFFFFFFFFF,
0xFFFFFFFFFFFFFF,
0xFFFFFFFFFFFF,
];
pub const CURVE_GX: [Chunk; NLEN] = [
0x545E3872760AB7,
0xF25DBF55296C3A,
0xE082542A385502,
0x8BA79B9859F741,
0x20AD746E1D3B62,
0x5378EB1C71EF3,
0xAA87CA22BE8B,
];
pub const CURVE_GY: [Chunk; NLEN] = [
0x431D7C90EA0E5F,
0xB1CE1D7E819D7A,
0x13B5F0B8C00A60,
0x289A147CE9DA31,
0x92DC29F8F41DBD,
0x2C6F5D9E98BF92,
0x3617DE4A9626,
];
pub const MODBYTES: usize = 48;
pub const BASEBITS: usize = 56;
pub const MODBITS: usize = 384;
pub const MOD8: usize = 7;
pub const MODTYPE: ModType = ModType::NOT_SPECIAL;
pub const SH: usize = 8;
pub const CURVETYPE: CurveType = CurveType::WEIERSTRASS;
pub const CURVE_PAIRING_TYPE: CurvePairingType = CurvePairingType::NOT;
pub const SEXTIC_TWIST: SexticTwist = SexticTwist::NOT;
pub const ATE_BITS: usize = 0;
pub const SIGN_OF_X: SignOfX = SignOfX::NOT;
pub const HASH_TYPE: usize = 48;
pub const AESKEY: usize = 24;