aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/src/crypto/zinc/curve25519
diff options
context:
space:
mode:
authorJason A. Donenfeld <Jason@zx2c4.com>2018-09-18 02:18:47 +0200
committerJason A. Donenfeld <Jason@zx2c4.com>2018-09-18 04:21:16 +0200
commit7905a1f5dff38cc30af873461f083f30893adcbe (patch)
tree44e5b8aec599b509df0df1dc99d13d5e68d54022 /src/crypto/zinc/curve25519
parentchacha20-x86_64: more limited cascade (diff)
downloadwireguard-monolithic-historical-7905a1f5dff38cc30af873461f083f30893adcbe.tar.xz
wireguard-monolithic-historical-7905a1f5dff38cc30af873461f083f30893adcbe.zip
crypto: allow for disabling simd in zinc modules
Diffstat (limited to 'src/crypto/zinc/curve25519')
-rw-r--r--src/crypto/zinc/curve25519/curve25519.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/crypto/zinc/curve25519/curve25519.c b/src/crypto/zinc/curve25519/curve25519.c
index fca327f..a02070e 100644
--- a/src/crypto/zinc/curve25519/curve25519.c
+++ b/src/crypto/zinc/curve25519/curve25519.c
@@ -88,13 +88,16 @@ EXPORT_SYMBOL(curve25519_generate_secret);
#include "../selftest/curve25519.h"
+static bool nosimd __initdata = false;
+
#ifndef COMPAT_ZINC_IS_A_MODULE
int __init curve25519_mod_init(void)
#else
static int __init mod_init(void)
#endif
{
- curve25519_fpu_init();
+ if (!nosimd)
+ curve25519_fpu_init();
#ifdef DEBUG
if (!curve25519_selftest())
return -ENOTRECOVERABLE;
@@ -107,6 +110,7 @@ static void __exit mod_exit(void)
{
}
+module_param(nosimd, bool, 0);
module_init(mod_init);
module_exit(mod_exit);
MODULE_LICENSE("GPL v2");