mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 18:18:19 +01:00 
			
		
		
		
	This patch adds support for the SHA-256 Secure Hash Algorithm for CPUs that have support for the SHA-256 part of the ARM v8 Crypto Extensions. It greatly improves sha-256 based operations, about 17x faster on iMX8M evk board. ~12ms vs ~208ms for a 20MiB kernel sha-256 verification. asm implementation is a simplified version of the Linux version (from Ard Biesheuvel). Signed-off-by: Loic Poulain <loic.poulain@linaro.org>
		
			
				
	
	
		
			22 lines
		
	
	
		
			509 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
		
			509 B
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0-only
 | |
| /*
 | |
|  * sha256_ce_glue.c - SHA-256 secure hash using ARMv8 Crypto Extensions
 | |
|  *
 | |
|  * Copyright (C) 2022 Linaro Ltd <loic.poulain@linaro.org>
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| #include <u-boot/sha256.h>
 | |
| 
 | |
| extern void sha256_armv8_ce_process(uint32_t state[8], uint8_t const *src,
 | |
| 				    uint32_t blocks);
 | |
| 
 | |
| void sha256_process(sha256_context *ctx, const unsigned char *data,
 | |
| 		    unsigned int blocks)
 | |
| {
 | |
| 	if (!blocks)
 | |
| 		return;
 | |
| 
 | |
| 	sha256_armv8_ce_process(ctx->state, data, blocks);
 | |
| }
 |