1 /* SPDX-License-Identifier: MIT */
4 * Copyright 2019 Advanced Micro Devices, Inc.
7 #ifndef AMDTEE_PRIVATE_H
8 #define AMDTEE_PRIVATE_H
10 #include <linux/mutex.h>
11 #include <linux/spinlock.h>
12 #include <linux/tee_core.h>
13 #include <linux/kref.h>
14 #include <linux/types.h>
15 #include "amdtee_if.h"
17 #define DRIVER_NAME "amdtee"
18 #define DRIVER_AUTHOR "AMD-TEE Linux driver team"
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
27 #define TEEC_ORIGIN_COMMS 0x00000002
29 /* Maximum number of sessions which can be opened with a Trusted Application */
30 #define TEE_NUM_SESSIONS 32
32 #define TA_LOAD_PATH "/amdtee"
33 #define TA_PATH_MAX 60
36 * struct amdtee - main service struct
37 * @teedev: client device
38 * @pool: shared memory pool
41 struct tee_device
*teedev
;
42 struct tee_shm_pool
*pool
;
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.
53 * Session structure is updated on open_session and this information is used for
54 * subsequent operations with the Trusted Application.
56 struct amdtee_session
{
57 struct list_head list_node
;
60 u32 session_info
[TEE_NUM_SESSIONS
];
61 DECLARE_BITMAP(sess_mask
, TEE_NUM_SESSIONS
);
62 spinlock_t lock
; /* synchronizes access to @sess_mask */
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
71 struct 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 */
77 struct amdtee_driver_data
{
78 struct amdtee
*amdtee
;
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
91 struct amdtee_shm_data
{
92 struct list_head shm_node
;
98 * struct amdtee_ta_data - Keeps track of all TAs loaded in AMD Secure
100 * @ta_handle: Handle to TA loaded in TEE
101 * @refcount: Reference count for the loaded TA
103 struct amdtee_ta_data
{
104 struct list_head list_node
;
109 #define LOWER_TWO_BYTE_MASK 0x0000FFFF
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
117 * Lower two bytes of the session identifier represents the TA handle and the
118 * upper two bytes is session index.
120 static inline void set_session_id(u32 ta_handle
, u32 session_index
,
123 *session
= (session_index
<< 16) | (LOWER_TWO_BYTE_MASK
& ta_handle
);
126 static inline u32
get_ta_handle(u32 session
)
128 return session
& LOWER_TWO_BYTE_MASK
;
131 static inline u32
get_session_index(u32 session
)
133 return (session
>> 16) & LOWER_TWO_BYTE_MASK
;
136 int amdtee_open_session(struct tee_context
*ctx
,
137 struct tee_ioctl_open_session_arg
*arg
,
138 struct tee_param
*param
);
140 int amdtee_close_session(struct tee_context
*ctx
, u32 session
);
142 int amdtee_invoke_func(struct tee_context
*ctx
,
143 struct tee_ioctl_invoke_arg
*arg
,
144 struct tee_param
*param
);
146 int amdtee_cancel_req(struct tee_context
*ctx
, u32 cancel_id
, u32 session
);
148 int amdtee_map_shmem(struct tee_shm
*shm
);
150 void amdtee_unmap_shmem(struct tee_shm
*shm
);
152 int handle_load_ta(void *data
, u32 size
,
153 struct tee_ioctl_open_session_arg
*arg
);
155 int handle_unload_ta(u32 ta_handle
);
157 int handle_open_session(struct tee_ioctl_open_session_arg
*arg
, u32
*info
,
158 struct tee_param
*p
);
160 int handle_close_session(u32 ta_handle
, u32 info
);
162 int handle_map_shmem(u32 count
, struct shmem_desc
*start
, u32
*buf_id
);
164 void handle_unmap_shmem(u32 buf_id
);
166 int handle_invoke_cmd(struct tee_ioctl_invoke_arg
*arg
, u32 sinfo
,
167 struct tee_param
*p
);
169 struct tee_shm_pool
*amdtee_config_shm(void);
171 u32
get_buffer_id(struct tee_shm
*shm
);
172 #endif /*AMDTEE_PRIVATE_H*/