1757cc3e9SRijo Thomas /* SPDX-License-Identifier: MIT */
2757cc3e9SRijo Thomas 
3757cc3e9SRijo Thomas /*
4757cc3e9SRijo Thomas  * Copyright 2019 Advanced Micro Devices, Inc.
5757cc3e9SRijo Thomas  */
6757cc3e9SRijo Thomas 
7757cc3e9SRijo Thomas #ifndef AMDTEE_PRIVATE_H
8757cc3e9SRijo Thomas #define AMDTEE_PRIVATE_H
9757cc3e9SRijo Thomas 
10757cc3e9SRijo Thomas #include <linux/mutex.h>
11757cc3e9SRijo Thomas #include <linux/spinlock.h>
12757cc3e9SRijo Thomas #include <linux/tee_drv.h>
13757cc3e9SRijo Thomas #include <linux/kref.h>
14757cc3e9SRijo Thomas #include <linux/types.h>
15757cc3e9SRijo Thomas #include "amdtee_if.h"
16757cc3e9SRijo Thomas 
17757cc3e9SRijo Thomas #define DRIVER_NAME	"amdtee"
18757cc3e9SRijo Thomas #define DRIVER_AUTHOR   "AMD-TEE Linux driver team"
19757cc3e9SRijo Thomas 
20757cc3e9SRijo Thomas /* Some GlobalPlatform error codes used in this driver */
21757cc3e9SRijo Thomas #define TEEC_SUCCESS			0x00000000
22757cc3e9SRijo Thomas #define TEEC_ERROR_GENERIC		0xFFFF0000
23757cc3e9SRijo Thomas #define TEEC_ERROR_BAD_PARAMETERS	0xFFFF0006
24*9f015b37SRijo Thomas #define TEEC_ERROR_OUT_OF_MEMORY	0xFFFF000C
25757cc3e9SRijo Thomas #define TEEC_ERROR_COMMUNICATION	0xFFFF000E
26757cc3e9SRijo Thomas 
27757cc3e9SRijo Thomas #define TEEC_ORIGIN_COMMS		0x00000002
28757cc3e9SRijo Thomas 
29757cc3e9SRijo Thomas /* Maximum number of sessions which can be opened with a Trusted Application */
30757cc3e9SRijo Thomas #define TEE_NUM_SESSIONS			32
31757cc3e9SRijo Thomas 
32757cc3e9SRijo Thomas #define TA_LOAD_PATH				"/amdtee"
33757cc3e9SRijo Thomas #define TA_PATH_MAX				60
34757cc3e9SRijo Thomas 
35757cc3e9SRijo Thomas /**
36757cc3e9SRijo Thomas  * struct amdtee - main service struct
37757cc3e9SRijo Thomas  * @teedev:		client device
38757cc3e9SRijo Thomas  * @pool:		shared memory pool
39757cc3e9SRijo Thomas  */
40757cc3e9SRijo Thomas struct amdtee {
41757cc3e9SRijo Thomas 	struct tee_device *teedev;
42757cc3e9SRijo Thomas 	struct tee_shm_pool *pool;
43757cc3e9SRijo Thomas };
44757cc3e9SRijo Thomas 
45757cc3e9SRijo Thomas /**
46757cc3e9SRijo Thomas  * struct amdtee_session - Trusted Application (TA) session related information.
47757cc3e9SRijo Thomas  * @ta_handle:     handle to Trusted Application (TA) loaded in TEE environment
48757cc3e9SRijo Thomas  * @refcount:      counter to keep track of sessions opened for the TA instance
49757cc3e9SRijo Thomas  * @session_info:  an array pointing to TA allocated session data.
50757cc3e9SRijo Thomas  * @sess_mask:     session usage bit-mask. If a particular bit is set, then the
51757cc3e9SRijo Thomas  *                 corresponding @session_info entry is in use or valid.
52757cc3e9SRijo Thomas  *
53757cc3e9SRijo Thomas  * Session structure is updated on open_session and this information is used for
54757cc3e9SRijo Thomas  * subsequent operations with the Trusted Application.
55757cc3e9SRijo Thomas  */
56757cc3e9SRijo Thomas struct amdtee_session {
57757cc3e9SRijo Thomas 	struct list_head list_node;
58757cc3e9SRijo Thomas 	u32 ta_handle;
59757cc3e9SRijo Thomas 	struct kref refcount;
60757cc3e9SRijo Thomas 	u32 session_info[TEE_NUM_SESSIONS];
61757cc3e9SRijo Thomas 	DECLARE_BITMAP(sess_mask, TEE_NUM_SESSIONS);
62757cc3e9SRijo Thomas 	spinlock_t lock;	/* synchronizes access to @sess_mask */
63757cc3e9SRijo Thomas };
64757cc3e9SRijo Thomas 
65757cc3e9SRijo Thomas /**
66757cc3e9SRijo Thomas  * struct amdtee_context_data - AMD-TEE driver context data
67757cc3e9SRijo Thomas  * @sess_list:    Keeps track of sessions opened in current TEE context
68ff1f8558SRijo Thomas  * @shm_list:     Keeps track of buffers allocated and mapped in current TEE
69ff1f8558SRijo Thomas  *                context
70757cc3e9SRijo Thomas  */
71757cc3e9SRijo Thomas struct amdtee_context_data {
72757cc3e9SRijo Thomas 	struct list_head sess_list;
73ff1f8558SRijo Thomas 	struct list_head shm_list;
74be353be2SRijo Thomas 	struct mutex shm_mutex;   /* synchronizes access to @shm_list */
75757cc3e9SRijo Thomas };
76757cc3e9SRijo Thomas 
77757cc3e9SRijo Thomas struct amdtee_driver_data {
78757cc3e9SRijo Thomas 	struct amdtee *amdtee;
79757cc3e9SRijo Thomas };
80757cc3e9SRijo Thomas 
81757cc3e9SRijo Thomas struct shmem_desc {
82757cc3e9SRijo Thomas 	void *kaddr;
83757cc3e9SRijo Thomas 	u64 size;
84757cc3e9SRijo Thomas };
85757cc3e9SRijo Thomas 
86757cc3e9SRijo Thomas /**
87757cc3e9SRijo Thomas  * struct amdtee_shm_data - Shared memory data
88757cc3e9SRijo Thomas  * @kaddr:	Kernel virtual address of shared memory
89757cc3e9SRijo Thomas  * @buf_id:	Buffer id of memory mapped by TEE_CMD_ID_MAP_SHARED_MEM
90757cc3e9SRijo Thomas  */
91757cc3e9SRijo Thomas struct amdtee_shm_data {
92757cc3e9SRijo Thomas 	struct  list_head shm_node;
93757cc3e9SRijo Thomas 	void    *kaddr;
94757cc3e9SRijo Thomas 	u32     buf_id;
95757cc3e9SRijo Thomas };
96757cc3e9SRijo Thomas 
97*9f015b37SRijo Thomas /**
98*9f015b37SRijo Thomas  * struct amdtee_ta_data - Keeps track of all TAs loaded in AMD Secure
99*9f015b37SRijo Thomas  *			   Processor
100*9f015b37SRijo Thomas  * @ta_handle:	Handle to TA loaded in TEE
101*9f015b37SRijo Thomas  * @refcount:	Reference count for the loaded TA
102*9f015b37SRijo Thomas  */
103*9f015b37SRijo Thomas struct amdtee_ta_data {
104*9f015b37SRijo Thomas 	struct list_head list_node;
105*9f015b37SRijo Thomas 	u32 ta_handle;
106*9f015b37SRijo Thomas 	u32 refcount;
107*9f015b37SRijo Thomas };
108*9f015b37SRijo Thomas 
109757cc3e9SRijo Thomas #define LOWER_TWO_BYTE_MASK	0x0000FFFF
110757cc3e9SRijo Thomas 
111757cc3e9SRijo Thomas /**
112757cc3e9SRijo Thomas  * set_session_id() - Sets the session identifier.
113757cc3e9SRijo Thomas  * @ta_handle:      [in] handle of the loaded Trusted Application (TA)
114757cc3e9SRijo Thomas  * @session_index:  [in] Session index. Range: 0 to (TEE_NUM_SESSIONS - 1).
115757cc3e9SRijo Thomas  * @session:        [out] Pointer to session id
116757cc3e9SRijo Thomas  *
117757cc3e9SRijo Thomas  * Lower two bytes of the session identifier represents the TA handle and the
118757cc3e9SRijo Thomas  * upper two bytes is session index.
119757cc3e9SRijo Thomas  */
set_session_id(u32 ta_handle,u32 session_index,u32 * session)120757cc3e9SRijo Thomas static inline void set_session_id(u32 ta_handle, u32 session_index,
121757cc3e9SRijo Thomas 				  u32 *session)
122757cc3e9SRijo Thomas {
123757cc3e9SRijo Thomas 	*session = (session_index << 16) | (LOWER_TWO_BYTE_MASK & ta_handle);
124757cc3e9SRijo Thomas }
125757cc3e9SRijo Thomas 
get_ta_handle(u32 session)126757cc3e9SRijo Thomas static inline u32 get_ta_handle(u32 session)
127757cc3e9SRijo Thomas {
128757cc3e9SRijo Thomas 	return session & LOWER_TWO_BYTE_MASK;
129757cc3e9SRijo Thomas }
130757cc3e9SRijo Thomas 
get_session_index(u32 session)131757cc3e9SRijo Thomas static inline u32 get_session_index(u32 session)
132757cc3e9SRijo Thomas {
133757cc3e9SRijo Thomas 	return (session >> 16) & LOWER_TWO_BYTE_MASK;
134757cc3e9SRijo Thomas }
135757cc3e9SRijo Thomas 
136757cc3e9SRijo Thomas int amdtee_open_session(struct tee_context *ctx,
137757cc3e9SRijo Thomas 			struct tee_ioctl_open_session_arg *arg,
138757cc3e9SRijo Thomas 			struct tee_param *param);
139757cc3e9SRijo Thomas 
140757cc3e9SRijo Thomas int amdtee_close_session(struct tee_context *ctx, u32 session);
141757cc3e9SRijo Thomas 
142757cc3e9SRijo Thomas int amdtee_invoke_func(struct tee_context *ctx,
143757cc3e9SRijo Thomas 		       struct tee_ioctl_invoke_arg *arg,
144757cc3e9SRijo Thomas 		       struct tee_param *param);
145757cc3e9SRijo Thomas 
146757cc3e9SRijo Thomas int amdtee_cancel_req(struct tee_context *ctx, u32 cancel_id, u32 session);
147757cc3e9SRijo Thomas 
148757cc3e9SRijo Thomas int amdtee_map_shmem(struct tee_shm *shm);
149757cc3e9SRijo Thomas 
150757cc3e9SRijo Thomas void amdtee_unmap_shmem(struct tee_shm *shm);
151757cc3e9SRijo Thomas 
152757cc3e9SRijo Thomas int handle_load_ta(void *data, u32 size,
153757cc3e9SRijo Thomas 		   struct tee_ioctl_open_session_arg *arg);
154757cc3e9SRijo Thomas 
155757cc3e9SRijo Thomas int handle_unload_ta(u32 ta_handle);
156757cc3e9SRijo Thomas 
157757cc3e9SRijo Thomas int handle_open_session(struct tee_ioctl_open_session_arg *arg, u32 *info,
158757cc3e9SRijo Thomas 			struct tee_param *p);
159757cc3e9SRijo Thomas 
160757cc3e9SRijo Thomas int handle_close_session(u32 ta_handle, u32 info);
161757cc3e9SRijo Thomas 
162757cc3e9SRijo Thomas int handle_map_shmem(u32 count, struct shmem_desc *start, u32 *buf_id);
163757cc3e9SRijo Thomas 
164757cc3e9SRijo Thomas void handle_unmap_shmem(u32 buf_id);
165757cc3e9SRijo Thomas 
166757cc3e9SRijo Thomas int handle_invoke_cmd(struct tee_ioctl_invoke_arg *arg, u32 sinfo,
167757cc3e9SRijo Thomas 		      struct tee_param *p);
168757cc3e9SRijo Thomas 
169757cc3e9SRijo Thomas struct tee_shm_pool *amdtee_config_shm(void);
170757cc3e9SRijo Thomas 
171757cc3e9SRijo Thomas u32 get_buffer_id(struct tee_shm *shm);
172757cc3e9SRijo Thomas #endif /*AMDTEE_PRIVATE_H*/
173