diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-01-29 13:43:10 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-01-29 13:43:10 +0000 |
commit | 91e5c50dc434293dc778919d35f2d8a1c961d1b4 (patch) | |
tree | cd6949d16a48843585adbbf831c07cfd666a81ab /src/libcryptobox/cryptobox.c | |
parent | c723bb1f30267bd670db6843a9526c2fd28f49cd (diff) | |
download | rspamd-91e5c50dc434293dc778919d35f2d8a1c961d1b4.tar.gz rspamd-91e5c50dc434293dc778919d35f2d8a1c961d1b4.zip |
Properly detect avx set.
Diffstat (limited to 'src/libcryptobox/cryptobox.c')
-rw-r--r-- | src/libcryptobox/cryptobox.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/src/libcryptobox/cryptobox.c b/src/libcryptobox/cryptobox.c index 00ba237f0..4b4cd4da1 100644 --- a/src/libcryptobox/cryptobox.c +++ b/src/libcryptobox/cryptobox.c @@ -104,10 +104,9 @@ rspamd_explicit_memzero(void * const pnt, const gsize len) static void rspamd_cryptobox_cpuid (gint cpu[4], gint info) { - guint32 eax, ecx, ebx, edx; + guint32 eax, ecx = 0, ebx = 0, edx = 0; eax = info; - ecx = 0; #if defined(__GNUC__) && (defined(__x86_64__) || defined(__i386__)) # if defined( __i386__ ) && defined ( __PIC__ ) @@ -205,6 +204,7 @@ struct rspamd_cryptobox_library_ctx* rspamd_cryptobox_init (void) { gint cpu[4], nid; + const guint32 osxsave_mask = (1 << 27); const guint32 fma_movbe_osxsave_mask = ((1 << 12) | (1 << 22) | (1 << 27)); const guint32 avx2_bmi12_mask = (1 << 5) | (1 << 3) | (1 << 8); gulong bit; @@ -251,14 +251,15 @@ rspamd_cryptobox_init (void) } /* OSXSAVE */ - if ((cpu[2] & fma_movbe_osxsave_mask) == fma_movbe_osxsave_mask) { + if ((cpu[2] & osxsave_mask) == osxsave_mask) { if ((cpu[2] & ((guint32)1 << 28))) { if (rspamd_cryptobox_test_instr (CPUID_AVX)) { cpu_config |= CPUID_AVX; } } - if (nid >= 7) { + if (nid >= 7 && + (cpu[2] & fma_movbe_osxsave_mask) == fma_movbe_osxsave_mask) { rspamd_cryptobox_cpuid (cpu, 7); if ((cpu[1] & avx2_bmi12_mask) == avx2_bmi12_mask) { @@ -950,7 +951,7 @@ gboolean rspamd_cryptobox_decrypt_nm_inplace (guchar *data, gsize len, const rspamd_nonce_t nonce, const rspamd_nm_t nm, const rspamd_sig_t sig) { - gsize r; + gsize r = 0; gboolean ret = TRUE; void *enc_ctx, *auth_ctx; |