/** * 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;
};
/** * 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);
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.