From f0ba073f7f41ba2fb3170d824c3b0d8abd475f08 Mon Sep 17 00:00:00 2001 From: Russell Currey Date: Fri, 30 Jul 2021 18:33:42 +1000 Subject: [PATCH] bigint: Use the asm bn_mul_mont() on powerpc64 Signed-off-by: Russell Currey --- src/arithmetic/bigint.rs | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/src/arithmetic/bigint.rs b/src/arithmetic/bigint.rs index 2d01a1f76f..c66701fc50 100644 --- a/src/arithmetic/bigint.rs +++ b/src/arithmetic/bigint.rs @@ -1221,7 +1221,8 @@ fn limbs_mont_mul(r: &mut [Limb], a: &[Limb], m: &[Limb], n0: &N0, _cpu_features target_arch = "aarch64", target_arch = "arm", target_arch = "x86_64", - target_arch = "x86" + target_arch = "x86", + target_arch = "powerpc64" ))] unsafe { bn_mul_mont( @@ -1238,7 +1239,8 @@ fn limbs_mont_mul(r: &mut [Limb], a: &[Limb], m: &[Limb], n0: &N0, _cpu_features target_arch = "aarch64", target_arch = "arm", target_arch = "x86_64", - target_arch = "x86" + target_arch = "x86", + target_arch = "powerpc64" )))] { let mut tmp = [0; 2 * MODULUS_MAX_LIMBS]; @@ -1278,7 +1280,8 @@ fn limbs_from_mont_in_place(r: &mut [Limb], tmp: &mut [Limb], m: &[Limb], n0: &N target_arch = "aarch64", target_arch = "arm", target_arch = "x86_64", - target_arch = "x86" + target_arch = "x86", + target_arch = "powerpc64" )))] fn limbs_mul(r: &mut [Limb], a: &[Limb], b: &[Limb]) { debug_assert_eq!(r.len(), 2 * a.len()); @@ -1316,7 +1319,8 @@ fn limbs_mont_product( target_arch = "aarch64", target_arch = "arm", target_arch = "x86_64", - target_arch = "x86" + target_arch = "x86", + target_arch = "powerpc64" ))] unsafe { bn_mul_mont( @@ -1333,7 +1337,8 @@ fn limbs_mont_product( target_arch = "aarch64", target_arch = "arm", target_arch = "x86_64", - target_arch = "x86" + target_arch = "x86", + target_arch = "powerpc64" )))] { let mut tmp = [0; 2 * MODULUS_MAX_LIMBS]; @@ -1350,7 +1355,8 @@ fn limbs_mont_square(r: &mut [Limb], m: &[Limb], n0: &N0, _cpu_features: cpu::Fe target_arch = "aarch64", target_arch = "arm", target_arch = "x86_64", - target_arch = "x86" + target_arch = "x86", + target_arch = "powerpc64" ))] unsafe { bn_mul_mont( @@ -1367,7 +1373,8 @@ fn limbs_mont_square(r: &mut [Limb], m: &[Limb], n0: &N0, _cpu_features: cpu::Fe target_arch = "aarch64", target_arch = "arm", target_arch = "x86_64", - target_arch = "x86" + target_arch = "x86", + target_arch = "powerpc64" )))] { let mut tmp = [0; 2 * MODULUS_MAX_LIMBS]; @@ -1402,7 +1409,8 @@ prefixed_extern! { target_arch = "aarch64", target_arch = "arm", target_arch = "x86_64", - target_arch = "x86" + target_arch = "x86", + target_arch = "powerpc64" )) ))] prefixed_extern! {