Server IP : 15.235.198.142 / Your IP : 216.73.216.144 Web Server : Apache/2.4.58 (Ubuntu) System : Linux ballsack 6.8.0-45-generic #45-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 30 12:02:04 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 8.3.6 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /usr/src/linux-headers-6.8.0-45/include/crypto/internal/ |
Upload File : |
/* SPDX-License-Identifier: GPL-2.0 */ /* * Shared crypto simd helpers */ #ifndef _CRYPTO_INTERNAL_SIMD_H #define _CRYPTO_INTERNAL_SIMD_H #include <linux/percpu.h> #include <linux/types.h> /* skcipher support */ struct simd_skcipher_alg; struct skcipher_alg; struct simd_skcipher_alg *simd_skcipher_create_compat(const char *algname, const char *drvname, const char *basename); struct simd_skcipher_alg *simd_skcipher_create(const char *algname, const char *basename); void simd_skcipher_free(struct simd_skcipher_alg *alg); int simd_register_skciphers_compat(struct skcipher_alg *algs, int count, struct simd_skcipher_alg **simd_algs); void simd_unregister_skciphers(struct skcipher_alg *algs, int count, struct simd_skcipher_alg **simd_algs); /* AEAD support */ struct simd_aead_alg; struct aead_alg; struct simd_aead_alg *simd_aead_create_compat(const char *algname, const char *drvname, const char *basename); struct simd_aead_alg *simd_aead_create(const char *algname, const char *basename); void simd_aead_free(struct simd_aead_alg *alg); int simd_register_aeads_compat(struct aead_alg *algs, int count, struct simd_aead_alg **simd_algs); void simd_unregister_aeads(struct aead_alg *algs, int count, struct simd_aead_alg **simd_algs); /* * crypto_simd_usable() - is it allowed at this time to use SIMD instructions or * access the SIMD register file? * * This delegates to may_use_simd(), except that this also returns false if SIMD * in crypto code has been temporarily disabled on this CPU by the crypto * self-tests, in order to test the no-SIMD fallback code. This override is * currently limited to configurations where the extra self-tests are enabled, * because it might be a bit too invasive to be part of the regular self-tests. * * This is a macro so that <asm/simd.h>, which some architectures don't have, * doesn't have to be included directly here. */ #ifdef CONFIG_CRYPTO_MANAGER_EXTRA_TESTS DECLARE_PER_CPU(bool, crypto_simd_disabled_for_test); #define crypto_simd_usable() \ (may_use_simd() && !this_cpu_read(crypto_simd_disabled_for_test)) #else #define crypto_simd_usable() may_use_simd() #endif #endif /* _CRYPTO_INTERNAL_SIMD_H */