| /* SPDX-License-Identifier: MIT */ |
| /* |
| * Copyright (C) 2019,2021 Advanced Micro Devices, Inc. |
| * |
| * Author: Rijo Thomas <Rijo-john.Thomas@amd.com> |
| * Author: Devaraj Rangasamy <Devaraj.Rangasamy@amd.com> |
| * |
| */ |
| |
| /* This file describes the TEE communication interface between host and AMD |
| * Secure Processor |
| */ |
| |
| #ifndef __TEE_DEV_H__ |
| #define __TEE_DEV_H__ |
| |
| #include <linux/device.h> |
| #include <linux/mutex.h> |
| |
| #define TEE_DEFAULT_TIMEOUT 10 |
| #define MAX_BUFFER_SIZE 988 |
| |
| /** |
| * enum tee_ring_cmd_id - TEE interface commands for ring buffer configuration |
| * @TEE_RING_INIT_CMD: Initialize ring buffer |
| * @TEE_RING_DESTROY_CMD: Destroy ring buffer |
| * @TEE_RING_MAX_CMD: Maximum command id |
| */ |
| enum tee_ring_cmd_id { |
| TEE_RING_INIT_CMD = 0x00010000, |
| TEE_RING_DESTROY_CMD = 0x00020000, |
| TEE_RING_MAX_CMD = 0x000F0000, |
| }; |
| |
| /** |
| * struct tee_init_ring_cmd - Command to init TEE ring buffer |
| * @low_addr: bits [31:0] of the physical address of ring buffer |
| * @hi_addr: bits [63:32] of the physical address of ring buffer |
| * @size: size of ring buffer in bytes |
| */ |
| struct tee_init_ring_cmd { |
| u32 low_addr; |
| u32 hi_addr; |
| u32 size; |
| }; |
| |
| #define MAX_RING_BUFFER_ENTRIES 32 |
| |
| /** |
| * struct ring_buf_manager - Helper structure to manage ring buffer. |
| * @ring_start: starting address of ring buffer |
| * @ring_size: size of ring buffer in bytes |
| * @ring_pa: physical address of ring buffer |
| * @wptr: index to the last written entry in ring buffer |
| */ |
| struct ring_buf_manager { |
| struct mutex mutex; /* synchronizes access to ring buffer */ |
| void *ring_start; |
| u32 ring_size; |
| phys_addr_t ring_pa; |
| u32 wptr; |
| }; |
| |
| struct psp_tee_device { |
| struct device *dev; |
| struct psp_device *psp; |
| void __iomem *io_regs; |
| struct tee_vdata *vdata; |
| struct ring_buf_manager rb_mgr; |
| }; |
| |
| /** |
| * enum tee_cmd_state - TEE command states for the ring buffer interface |
| * @TEE_CMD_STATE_INIT: initial state of command when sent from host |
| * @TEE_CMD_STATE_PROCESS: command being processed by TEE environment |
| * @TEE_CMD_STATE_COMPLETED: command processing completed |
| */ |
| enum tee_cmd_state { |
| TEE_CMD_STATE_INIT, |
| TEE_CMD_STATE_PROCESS, |
| TEE_CMD_STATE_COMPLETED, |
| }; |
| |
| /** |
| * enum cmd_resp_state - TEE command's response status maintained by driver |
| * @CMD_RESPONSE_INVALID: initial state when no command is written to ring |
| * @CMD_WAITING_FOR_RESPONSE: driver waiting for response from TEE |
| * @CMD_RESPONSE_TIMEDOUT: failed to get response from TEE |
| * @CMD_RESPONSE_COPIED: driver has copied response from TEE |
| */ |
| enum cmd_resp_state { |
| CMD_RESPONSE_INVALID, |
| CMD_WAITING_FOR_RESPONSE, |
| CMD_RESPONSE_TIMEDOUT, |
| CMD_RESPONSE_COPIED, |
| }; |
| |
| /** |
| * struct tee_ring_cmd - Structure of the command buffer in TEE ring |
| * @cmd_id: refers to &enum tee_cmd_id. Command id for the ring buffer |
| * interface |
| * @cmd_state: refers to &enum tee_cmd_state |
| * @status: status of TEE command execution |
| * @res0: reserved region |
| * @pdata: private data (currently unused) |
| * @res1: reserved region |
| * @buf: TEE command specific buffer |
| * @flag: refers to &enum cmd_resp_state |
| */ |
| struct tee_ring_cmd { |
| u32 cmd_id; |
| u32 cmd_state; |
| u32 status; |
| u32 res0[1]; |
| u64 pdata; |
| u32 res1[2]; |
| u8 buf[MAX_BUFFER_SIZE]; |
| u32 flag; |
| |
| /* Total size: 1024 bytes */ |
| } __packed; |
| |
| int tee_dev_init(struct psp_device *psp); |
| void tee_dev_destroy(struct psp_device *psp); |
| |
| #endif /* __TEE_DEV_H__ */ |