Linux Audio

Check our new training course

Loading...
v6.8
  1/* SPDX-License-Identifier: MIT */
  2
  3/*
  4 * Copyright 2019 Advanced Micro Devices, Inc.
  5 */
  6
  7#ifndef AMDTEE_PRIVATE_H
  8#define AMDTEE_PRIVATE_H
  9
 10#include <linux/mutex.h>
 11#include <linux/spinlock.h>
 12#include <linux/tee_drv.h>
 13#include <linux/kref.h>
 14#include <linux/types.h>
 15#include "amdtee_if.h"
 16
 17#define DRIVER_NAME	"amdtee"
 18#define DRIVER_AUTHOR   "AMD-TEE Linux driver team"
 19
 20/* Some GlobalPlatform error codes used in this driver */
 21#define TEEC_SUCCESS			0x00000000
 22#define TEEC_ERROR_GENERIC		0xFFFF0000
 23#define TEEC_ERROR_BAD_PARAMETERS	0xFFFF0006
 24#define TEEC_ERROR_OUT_OF_MEMORY	0xFFFF000C
 25#define TEEC_ERROR_COMMUNICATION	0xFFFF000E
 26
 27#define TEEC_ORIGIN_COMMS		0x00000002
 28
 29/* Maximum number of sessions which can be opened with a Trusted Application */
 30#define TEE_NUM_SESSIONS			32
 31
 32#define TA_LOAD_PATH				"/amdtee"
 33#define TA_PATH_MAX				60
 34
 35/**
 36 * struct amdtee - main service struct
 37 * @teedev:		client device
 38 * @pool:		shared memory pool
 39 */
 40struct amdtee {
 41	struct tee_device *teedev;
 42	struct tee_shm_pool *pool;
 43};
 44
 45/**
 46 * struct amdtee_session - Trusted Application (TA) session related information.
 47 * @ta_handle:     handle to Trusted Application (TA) loaded in TEE environment
 48 * @refcount:      counter to keep track of sessions opened for the TA instance
 49 * @session_info:  an array pointing to TA allocated session data.
 50 * @sess_mask:     session usage bit-mask. If a particular bit is set, then the
 51 *                 corresponding @session_info entry is in use or valid.
 52 *
 53 * Session structure is updated on open_session and this information is used for
 54 * subsequent operations with the Trusted Application.
 55 */
 56struct amdtee_session {
 57	struct list_head list_node;
 58	u32 ta_handle;
 59	struct kref refcount;
 60	u32 session_info[TEE_NUM_SESSIONS];
 61	DECLARE_BITMAP(sess_mask, TEE_NUM_SESSIONS);
 62	spinlock_t lock;	/* synchronizes access to @sess_mask */
 63};
 64
 65/**
 66 * struct amdtee_context_data - AMD-TEE driver context data
 67 * @sess_list:    Keeps track of sessions opened in current TEE context
 68 * @shm_list:     Keeps track of buffers allocated and mapped in current TEE
 69 *                context
 70 */
 71struct amdtee_context_data {
 72	struct list_head sess_list;
 73	struct list_head shm_list;
 74	struct mutex shm_mutex;   /* synchronizes access to @shm_list */
 75};
 76
 77struct amdtee_driver_data {
 78	struct amdtee *amdtee;
 79};
 80
 81struct shmem_desc {
 82	void *kaddr;
 83	u64 size;
 84};
 85
 86/**
 87 * struct amdtee_shm_data - Shared memory data
 88 * @kaddr:	Kernel virtual address of shared memory
 89 * @buf_id:	Buffer id of memory mapped by TEE_CMD_ID_MAP_SHARED_MEM
 90 */
 91struct amdtee_shm_data {
 92	struct  list_head shm_node;
 93	void    *kaddr;
 94	u32     buf_id;
 95};
 96
 97/**
 98 * struct amdtee_ta_data - Keeps track of all TAs loaded in AMD Secure
 99 *			   Processor
100 * @ta_handle:	Handle to TA loaded in TEE
101 * @refcount:	Reference count for the loaded TA
102 */
103struct amdtee_ta_data {
104	struct list_head list_node;
105	u32 ta_handle;
106	u32 refcount;
107};
108
109#define LOWER_TWO_BYTE_MASK	0x0000FFFF
110
111/**
112 * set_session_id() - Sets the session identifier.
113 * @ta_handle:      [in] handle of the loaded Trusted Application (TA)
114 * @session_index:  [in] Session index. Range: 0 to (TEE_NUM_SESSIONS - 1).
115 * @session:        [out] Pointer to session id
116 *
117 * Lower two bytes of the session identifier represents the TA handle and the
118 * upper two bytes is session index.
119 */
120static inline void set_session_id(u32 ta_handle, u32 session_index,
121				  u32 *session)
122{
123	*session = (session_index << 16) | (LOWER_TWO_BYTE_MASK & ta_handle);
124}
125
126static inline u32 get_ta_handle(u32 session)
127{
128	return session & LOWER_TWO_BYTE_MASK;
129}
130
131static inline u32 get_session_index(u32 session)
132{
133	return (session >> 16) & LOWER_TWO_BYTE_MASK;
134}
135
136int amdtee_open_session(struct tee_context *ctx,
137			struct tee_ioctl_open_session_arg *arg,
138			struct tee_param *param);
139
140int amdtee_close_session(struct tee_context *ctx, u32 session);
141
142int amdtee_invoke_func(struct tee_context *ctx,
143		       struct tee_ioctl_invoke_arg *arg,
144		       struct tee_param *param);
145
146int amdtee_cancel_req(struct tee_context *ctx, u32 cancel_id, u32 session);
147
148int amdtee_map_shmem(struct tee_shm *shm);
149
150void amdtee_unmap_shmem(struct tee_shm *shm);
151
152int handle_load_ta(void *data, u32 size,
153		   struct tee_ioctl_open_session_arg *arg);
154
155int handle_unload_ta(u32 ta_handle);
156
157int handle_open_session(struct tee_ioctl_open_session_arg *arg, u32 *info,
158			struct tee_param *p);
159
160int handle_close_session(u32 ta_handle, u32 info);
161
162int handle_map_shmem(u32 count, struct shmem_desc *start, u32 *buf_id);
163
164void handle_unmap_shmem(u32 buf_id);
165
166int handle_invoke_cmd(struct tee_ioctl_invoke_arg *arg, u32 sinfo,
167		      struct tee_param *p);
168
169struct tee_shm_pool *amdtee_config_shm(void);
170
171u32 get_buffer_id(struct tee_shm *shm);
172#endif /*AMDTEE_PRIVATE_H*/
v5.9
  1/* SPDX-License-Identifier: MIT */
  2
  3/*
  4 * Copyright 2019 Advanced Micro Devices, Inc.
  5 */
  6
  7#ifndef AMDTEE_PRIVATE_H
  8#define AMDTEE_PRIVATE_H
  9
 10#include <linux/mutex.h>
 11#include <linux/spinlock.h>
 12#include <linux/tee_drv.h>
 13#include <linux/kref.h>
 14#include <linux/types.h>
 15#include "amdtee_if.h"
 16
 17#define DRIVER_NAME	"amdtee"
 18#define DRIVER_AUTHOR   "AMD-TEE Linux driver team"
 19
 20/* Some GlobalPlatform error codes used in this driver */
 21#define TEEC_SUCCESS			0x00000000
 22#define TEEC_ERROR_GENERIC		0xFFFF0000
 23#define TEEC_ERROR_BAD_PARAMETERS	0xFFFF0006
 
 24#define TEEC_ERROR_COMMUNICATION	0xFFFF000E
 25
 26#define TEEC_ORIGIN_COMMS		0x00000002
 27
 28/* Maximum number of sessions which can be opened with a Trusted Application */
 29#define TEE_NUM_SESSIONS			32
 30
 31#define TA_LOAD_PATH				"/amdtee"
 32#define TA_PATH_MAX				60
 33
 34/**
 35 * struct amdtee - main service struct
 36 * @teedev:		client device
 37 * @pool:		shared memory pool
 38 */
 39struct amdtee {
 40	struct tee_device *teedev;
 41	struct tee_shm_pool *pool;
 42};
 43
 44/**
 45 * struct amdtee_session - Trusted Application (TA) session related information.
 46 * @ta_handle:     handle to Trusted Application (TA) loaded in TEE environment
 47 * @refcount:      counter to keep track of sessions opened for the TA instance
 48 * @session_info:  an array pointing to TA allocated session data.
 49 * @sess_mask:     session usage bit-mask. If a particular bit is set, then the
 50 *                 corresponding @session_info entry is in use or valid.
 51 *
 52 * Session structure is updated on open_session and this information is used for
 53 * subsequent operations with the Trusted Application.
 54 */
 55struct amdtee_session {
 56	struct list_head list_node;
 57	u32 ta_handle;
 58	struct kref refcount;
 59	u32 session_info[TEE_NUM_SESSIONS];
 60	DECLARE_BITMAP(sess_mask, TEE_NUM_SESSIONS);
 61	spinlock_t lock;	/* synchronizes access to @sess_mask */
 62};
 63
 64/**
 65 * struct amdtee_context_data - AMD-TEE driver context data
 66 * @sess_list:    Keeps track of sessions opened in current TEE context
 
 
 67 */
 68struct amdtee_context_data {
 69	struct list_head sess_list;
 
 
 70};
 71
 72struct amdtee_driver_data {
 73	struct amdtee *amdtee;
 74};
 75
 76struct shmem_desc {
 77	void *kaddr;
 78	u64 size;
 79};
 80
 81/**
 82 * struct amdtee_shm_data - Shared memory data
 83 * @kaddr:	Kernel virtual address of shared memory
 84 * @buf_id:	Buffer id of memory mapped by TEE_CMD_ID_MAP_SHARED_MEM
 85 */
 86struct amdtee_shm_data {
 87	struct  list_head shm_node;
 88	void    *kaddr;
 89	u32     buf_id;
 90};
 91
 92struct amdtee_shm_context {
 93	struct list_head shmdata_list;
 
 
 
 
 
 
 
 
 94};
 95
 96#define LOWER_TWO_BYTE_MASK	0x0000FFFF
 97
 98/**
 99 * set_session_id() - Sets the session identifier.
100 * @ta_handle:      [in] handle of the loaded Trusted Application (TA)
101 * @session_index:  [in] Session index. Range: 0 to (TEE_NUM_SESSIONS - 1).
102 * @session:        [out] Pointer to session id
103 *
104 * Lower two bytes of the session identifier represents the TA handle and the
105 * upper two bytes is session index.
106 */
107static inline void set_session_id(u32 ta_handle, u32 session_index,
108				  u32 *session)
109{
110	*session = (session_index << 16) | (LOWER_TWO_BYTE_MASK & ta_handle);
111}
112
113static inline u32 get_ta_handle(u32 session)
114{
115	return session & LOWER_TWO_BYTE_MASK;
116}
117
118static inline u32 get_session_index(u32 session)
119{
120	return (session >> 16) & LOWER_TWO_BYTE_MASK;
121}
122
123int amdtee_open_session(struct tee_context *ctx,
124			struct tee_ioctl_open_session_arg *arg,
125			struct tee_param *param);
126
127int amdtee_close_session(struct tee_context *ctx, u32 session);
128
129int amdtee_invoke_func(struct tee_context *ctx,
130		       struct tee_ioctl_invoke_arg *arg,
131		       struct tee_param *param);
132
133int amdtee_cancel_req(struct tee_context *ctx, u32 cancel_id, u32 session);
134
135int amdtee_map_shmem(struct tee_shm *shm);
136
137void amdtee_unmap_shmem(struct tee_shm *shm);
138
139int handle_load_ta(void *data, u32 size,
140		   struct tee_ioctl_open_session_arg *arg);
141
142int handle_unload_ta(u32 ta_handle);
143
144int handle_open_session(struct tee_ioctl_open_session_arg *arg, u32 *info,
145			struct tee_param *p);
146
147int handle_close_session(u32 ta_handle, u32 info);
148
149int handle_map_shmem(u32 count, struct shmem_desc *start, u32 *buf_id);
150
151void handle_unmap_shmem(u32 buf_id);
152
153int handle_invoke_cmd(struct tee_ioctl_invoke_arg *arg, u32 sinfo,
154		      struct tee_param *p);
155
156struct tee_shm_pool *amdtee_config_shm(void);
157
158u32 get_buffer_id(struct tee_shm *shm);
159#endif /*AMDTEE_PRIVATE_H*/