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