xref: /aosp_15_r20/external/vboot_reference/firmware/2lib/2stub_hwcrypto.c (revision 8617a60d3594060b7ecbd21bc622a7c14f3cf2bc)
1*8617a60dSAndroid Build Coastguard Worker /* Copyright 2020 The ChromiumOS Authors
2*8617a60dSAndroid Build Coastguard Worker  * Use of this source code is governed by a BSD-style license that can be
3*8617a60dSAndroid Build Coastguard Worker  * found in the LICENSE file.
4*8617a60dSAndroid Build Coastguard Worker  *
5*8617a60dSAndroid Build Coastguard Worker  * Stub hwcrypto API implementations which should be implemented by the caller.
6*8617a60dSAndroid Build Coastguard Worker  */
7*8617a60dSAndroid Build Coastguard Worker 
8*8617a60dSAndroid Build Coastguard Worker #include "2api.h"
9*8617a60dSAndroid Build Coastguard Worker 
10*8617a60dSAndroid Build Coastguard Worker #if !defined(X86_SHA_EXT) && !defined(ARMV8_CRYPTO_EXT)
11*8617a60dSAndroid Build Coastguard Worker __attribute__((weak))
vb2ex_hwcrypto_digest_init(enum vb2_hash_algorithm hash_alg,uint32_t data_size)12*8617a60dSAndroid Build Coastguard Worker vb2_error_t vb2ex_hwcrypto_digest_init(enum vb2_hash_algorithm hash_alg,
13*8617a60dSAndroid Build Coastguard Worker 				       uint32_t data_size)
14*8617a60dSAndroid Build Coastguard Worker {
15*8617a60dSAndroid Build Coastguard Worker 	return VB2_ERROR_EX_HWCRYPTO_UNSUPPORTED;
16*8617a60dSAndroid Build Coastguard Worker }
17*8617a60dSAndroid Build Coastguard Worker 
18*8617a60dSAndroid Build Coastguard Worker __attribute__((weak))
vb2ex_hwcrypto_digest_extend(const uint8_t * buf,uint32_t size)19*8617a60dSAndroid Build Coastguard Worker vb2_error_t vb2ex_hwcrypto_digest_extend(const uint8_t *buf, uint32_t size)
20*8617a60dSAndroid Build Coastguard Worker {
21*8617a60dSAndroid Build Coastguard Worker 	return VB2_ERROR_SHA_EXTEND_ALGORITHM;  /* Should not be called. */
22*8617a60dSAndroid Build Coastguard Worker }
23*8617a60dSAndroid Build Coastguard Worker 
24*8617a60dSAndroid Build Coastguard Worker __attribute__((weak))
vb2ex_hwcrypto_digest_finalize(uint8_t * digest,uint32_t digest_size)25*8617a60dSAndroid Build Coastguard Worker vb2_error_t vb2ex_hwcrypto_digest_finalize(uint8_t *digest,
26*8617a60dSAndroid Build Coastguard Worker 					   uint32_t digest_size)
27*8617a60dSAndroid Build Coastguard Worker {
28*8617a60dSAndroid Build Coastguard Worker 	return VB2_ERROR_SHA_FINALIZE_ALGORITHM;  /* Should not be called. */
29*8617a60dSAndroid Build Coastguard Worker }
30*8617a60dSAndroid Build Coastguard Worker #endif
31*8617a60dSAndroid Build Coastguard Worker 
32*8617a60dSAndroid Build Coastguard Worker __attribute__((weak))
vb2ex_hwcrypto_rsa_verify_digest(const struct vb2_public_key * key,const uint8_t * sig,const uint8_t * digest)33*8617a60dSAndroid Build Coastguard Worker vb2_error_t vb2ex_hwcrypto_rsa_verify_digest(const struct vb2_public_key *key,
34*8617a60dSAndroid Build Coastguard Worker 					     const uint8_t *sig, const uint8_t *digest)
35*8617a60dSAndroid Build Coastguard Worker {
36*8617a60dSAndroid Build Coastguard Worker 	return VB2_ERROR_EX_HWCRYPTO_UNSUPPORTED;
37*8617a60dSAndroid Build Coastguard Worker }
38*8617a60dSAndroid Build Coastguard Worker 
39*8617a60dSAndroid Build Coastguard Worker #if !defined(VB2_X86_RSA_ACCELERATION) && !defined(ARM64_RSA_ACCELERATION)
40*8617a60dSAndroid Build Coastguard Worker __attribute__((weak))
vb2ex_hwcrypto_modexp(const struct vb2_public_key * key,uint8_t * inout,void * workbuf,size_t workbuf_size,int exp)41*8617a60dSAndroid Build Coastguard Worker vb2_error_t vb2ex_hwcrypto_modexp(const struct vb2_public_key *key, uint8_t *inout,
42*8617a60dSAndroid Build Coastguard Worker 				  void *workbuf, size_t workbuf_size, int exp)
43*8617a60dSAndroid Build Coastguard Worker {
44*8617a60dSAndroid Build Coastguard Worker 	return VB2_ERROR_EX_HWCRYPTO_UNSUPPORTED;
45*8617a60dSAndroid Build Coastguard Worker }
46*8617a60dSAndroid Build Coastguard Worker #endif
47