mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 3c44d31cb3
			
		
	
	
		3c44d31cb3
		
	
	
	
	
		
			
			Algorithm registration is usually carried out during module init, where as little work as possible should be carried out. The SIMD code violated this rule by allocating a tfm, this then triggers a full test of the algorithm which may dead-lock in certain cases. SIMD is only allocating the tfm to get at the alg object, which is in fact already available as it is what we are registering. Use that directly and remove the crypto_alloc_tfm call. Also remove some obsolete and unused SIMD API. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* 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(struct skcipher_alg *ialg,
 | |
| 						      const char *algname,
 | |
| 						      const char *drvname,
 | |
| 						      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;
 | |
| 
 | |
| 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 */
 |