diff options
Diffstat (limited to 'src/crypto/crypto_ops_builder/ref10/fe_isnonzero.c')
-rw-r--r-- | src/crypto/crypto_ops_builder/ref10/fe_isnonzero.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/src/crypto/crypto_ops_builder/ref10/fe_isnonzero.c b/src/crypto/crypto_ops_builder/ref10/fe_isnonzero.c new file mode 100644 index 000000000..47568001c --- /dev/null +++ b/src/crypto/crypto_ops_builder/ref10/fe_isnonzero.c @@ -0,0 +1,19 @@ +#include "fe.h" +#include "crypto_verify_32.h" + +/* +return 1 if f == 0 +return 0 if f != 0 + +Preconditions: + |f| bounded by 1.1*2^26,1.1*2^25,1.1*2^26,1.1*2^25,etc. +*/ + +static const unsigned char zero[32]; + +int fe_isnonzero(const fe f) +{ + unsigned char s[32]; + fe_tobytes(s,f); + return crypto_verify_32(s,zero); +} |