You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
lokinet/crypto/libntrup/src/ntru.cpp

76 lines
1.6 KiB
C++

#include <libntrup/ntru.h>
#include <libntrup/ntru_api.h>
#ifdef __x86_64__
#include <cpuid.h>
#include <array>
bool
supports_avx2()
{
std::array< int, 4 > cpuinfo;
__cpuid(0, cpuinfo[0], cpuinfo[1], cpuinfo[2], cpuinfo[3]);
if (cpuinfo[0] < 7)
return false;
__cpuid_count(7, 0, cpuinfo[0], cpuinfo[1], cpuinfo[2], cpuinfo[3]);
return cpuinfo[1] & (1 << 5);
}
#else
bool
supports_avx2()
{
return false;
}
#endif
int (*__crypto_kem_enc)(unsigned char *cstr, unsigned char *k,
const unsigned char *pk);
int (*__crypto_kem_dec)(unsigned char *k, const unsigned char *cstr,
const unsigned char *sk);
int (*__crypto_kem_keypair)(unsigned char *pk, unsigned char *sk);
extern "C"
{
void
ntru_init(int force_no_avx2)
{
if(supports_avx2() && !force_no_avx2)
{
__crypto_kem_dec = &crypto_kem_dec_avx2;
__crypto_kem_enc = &crypto_kem_enc_avx2;
__crypto_kem_keypair = &crypto_kem_keypair_avx2;
}
else
{
__crypto_kem_dec = &crypto_kem_dec_ref;
__crypto_kem_enc = &crypto_kem_enc_ref;
__crypto_kem_keypair = &crypto_kem_keypair_ref;
}
}
int
crypto_kem_enc(unsigned char *cstr, unsigned char *k, const unsigned char *pk)
{
return __crypto_kem_enc(cstr, k, pk);
}
int
crypto_kem_dec(unsigned char *k, const unsigned char *cstr,
const unsigned char *sk)
{
return __crypto_kem_dec(k, cstr, sk);
}
int
crypto_kem_keypair(unsigned char *pk, unsigned char *sk)
{
return __crypto_kem_keypair(pk, sk);
}
}