| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 |
- /* 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 */
|