|  | /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
|  | /* | 
|  | * OP-TEE STM32MP BSEC PTA interface, used by STM32 ROMEM driver | 
|  | * | 
|  | * Copyright (C) 2022, STMicroelectronics - All Rights Reserved | 
|  | */ | 
|  |  | 
|  | #if IS_ENABLED(CONFIG_NVMEM_STM32_BSEC_OPTEE_TA) | 
|  | /** | 
|  | * stm32_bsec_optee_ta_open() - initialize the STM32 BSEC TA | 
|  | * @ctx: the OP-TEE context on success | 
|  | * | 
|  | * Return: | 
|  | *	On success, 0. On failure, -errno. | 
|  | */ | 
|  | int stm32_bsec_optee_ta_open(struct tee_context **ctx); | 
|  |  | 
|  | /** | 
|  | * stm32_bsec_optee_ta_close() - release the STM32 BSEC TA | 
|  | * @ctx: the OP-TEE context | 
|  | * | 
|  | * This function used to clean the OP-TEE resources initialized in | 
|  | * stm32_bsec_optee_ta_open(); it can be used as callback to | 
|  | * devm_add_action_or_reset() | 
|  | */ | 
|  | void stm32_bsec_optee_ta_close(void *ctx); | 
|  |  | 
|  | /** | 
|  | * stm32_bsec_optee_ta_read() - nvmem read access using TA client driver | 
|  | * @ctx: the OP-TEE context provided by stm32_bsec_optee_ta_open | 
|  | * @offset: nvmem offset | 
|  | * @buf: buffer to fill with nvem values | 
|  | * @bytes: number of bytes to read | 
|  | * | 
|  | * Return: | 
|  | *	On success, 0. On failure, -errno. | 
|  | */ | 
|  | int stm32_bsec_optee_ta_read(struct tee_context *ctx, unsigned int offset, | 
|  | void *buf, size_t bytes); | 
|  |  | 
|  | /** | 
|  | * stm32_bsec_optee_ta_write() - nvmem write access using TA client driver | 
|  | * @ctx: the OP-TEE context provided by stm32_bsec_optee_ta_open | 
|  | * @lower: number of lower OTP, not protected by ECC | 
|  | * @offset: nvmem offset | 
|  | * @buf: buffer with nvem values | 
|  | * @bytes: number of bytes to write | 
|  | * | 
|  | * Return: | 
|  | *	On success, 0. On failure, -errno. | 
|  | */ | 
|  | int stm32_bsec_optee_ta_write(struct tee_context *ctx, unsigned int lower, | 
|  | unsigned int offset, void *buf, size_t bytes); | 
|  |  | 
|  | #else | 
|  |  | 
|  | static inline int stm32_bsec_optee_ta_open(struct tee_context **ctx) | 
|  | { | 
|  | return -EOPNOTSUPP; | 
|  | } | 
|  |  | 
|  | static inline void stm32_bsec_optee_ta_close(void *ctx) | 
|  | { | 
|  | } | 
|  |  | 
|  | static inline int stm32_bsec_optee_ta_read(struct tee_context *ctx, | 
|  | unsigned int offset, void *buf, | 
|  | size_t bytes) | 
|  | { | 
|  | return -EOPNOTSUPP; | 
|  | } | 
|  |  | 
|  | static inline int stm32_bsec_optee_ta_write(struct tee_context *ctx, | 
|  | unsigned int lower, | 
|  | unsigned int offset, void *buf, | 
|  | size_t bytes) | 
|  | { | 
|  | return -EOPNOTSUPP; | 
|  | } | 
|  | #endif /* CONFIG_NVMEM_STM32_BSEC_OPTEE_TA */ |