xref: /optee_os/core/arch/arm/include/ffa.h (revision 1868eb206733e931b6c6c2d85d55e646bc8a2496)
1 /* SPDX-License-Identifier: BSD-3-Clause */
2 /*
3  * Copyright (c) 2020, Linaro Limited
4  * Copyright (c) 2018-2024, Arm Limited. All rights reserved.
5  */
6 
7 #ifndef __FFA_H
8 #define __FFA_H
9 
10 /* This is based on the FF-A 1.0 EAC specification */
11 
12 #include <smccc.h>
13 #include <stdint.h>
14 #include <util.h>
15 
16 /* Error codes */
17 #define FFA_OK			0
18 #define FFA_NOT_SUPPORTED	-1
19 #define FFA_INVALID_PARAMETERS	-2
20 #define FFA_NO_MEMORY		-3
21 #define FFA_BUSY		-4
22 #define FFA_INTERRUPTED		-5
23 #define FFA_DENIED		-6
24 #define FFA_RETRY		-7
25 #define FFA_ABORTED		-8
26 #define FFA_NO_DATA		-9
27 
28 /* FFA_VERSION helpers */
29 #define FFA_VERSION_MAJOR		U(1)
30 #define FFA_VERSION_MAJOR_SHIFT		U(16)
31 #define FFA_VERSION_MAJOR_MASK		U(0x7FFF)
32 #define FFA_VERSION_MINOR		U(1)
33 #define FFA_VERSION_MINOR_SHIFT		U(0)
34 #define FFA_VERSION_MINOR_MASK		U(0xFFFF)
35 #define MAKE_FFA_VERSION(major, minor)	\
36 	((((major) & FFA_VERSION_MAJOR_MASK) << FFA_VERSION_MAJOR_SHIFT) | \
37 	 ((minor) & FFA_VERSION_MINOR_MASK))
38 
39 #define FFA_VERSION_1_0			MAKE_FFA_VERSION(1, 0)
40 #define FFA_VERSION_1_1			MAKE_FFA_VERSION(1, 1)
41 
42 /* Function IDs */
43 #define FFA_ERROR			U(0x84000060)
44 #define FFA_SUCCESS_32			U(0x84000061)
45 #define FFA_SUCCESS_64			U(0xC4000061)
46 #define FFA_INTERRUPT			U(0x84000062)
47 #define FFA_VERSION			U(0x84000063)
48 #define FFA_FEATURES			U(0x84000064)
49 #define FFA_RX_RELEASE			U(0x84000065)
50 #define FFA_RXTX_MAP_32			U(0x84000066)
51 #define FFA_RXTX_MAP_64			U(0xC4000066)
52 #define FFA_RXTX_UNMAP			U(0x84000067)
53 #define FFA_PARTITION_INFO_GET		U(0x84000068)
54 #define FFA_ID_GET			U(0x84000069)
55 #define FFA_SPM_ID_GET			U(0x84000085)
56 #define FFA_MSG_WAIT			U(0x8400006B)
57 #define FFA_MSG_YIELD			U(0x8400006C)
58 #define FFA_RUN				U(0x8400006D)
59 #define FFA_MSG_SEND2			U(0x84000086)
60 #define FFA_MSG_SEND			U(0x8400006E)
61 #define FFA_MSG_SEND_DIRECT_REQ_32	U(0x8400006F)
62 #define FFA_MSG_SEND_DIRECT_REQ_64	U(0xC400006F)
63 #define FFA_MSG_SEND_DIRECT_RESP_32	U(0x84000070)
64 #define FFA_MSG_SEND_DIRECT_RESP_64	U(0xC4000070)
65 #define FFA_MSG_POLL			U(0x8400006A)
66 #define FFA_MEM_DONATE_32		U(0x84000071)
67 #define FFA_MEM_DONATE_64		U(0xC4000071)
68 #define FFA_MEM_LEND_32			U(0x84000072)
69 #define FFA_MEM_LEND_64			U(0xC4000072)
70 #define FFA_MEM_SHARE_32		U(0x84000073)
71 #define FFA_MEM_SHARE_64		U(0xC4000073)
72 #define FFA_MEM_RETRIEVE_REQ_32		U(0x84000074)
73 #define FFA_MEM_RETRIEVE_REQ_64		U(0xC4000074)
74 #define FFA_MEM_RETRIEVE_RESP		U(0x84000075)
75 #define FFA_MEM_RELINQUISH		U(0x84000076)
76 #define FFA_MEM_RECLAIM			U(0x84000077)
77 #define FFA_MEM_FRAG_RX			U(0x8400007A)
78 #define FFA_MEM_FRAG_TX			U(0x8400007B)
79 #define FFA_NORMAL_WORLD_RESUME		U(0x8400007C)
80 #define FFA_NOTIFICATION_BITMAP_CREATE	U(0x8400007D)
81 #define FFA_NOTIFICATION_BITMAP_DESTROY	U(0x8400007E)
82 #define FFA_NOTIFICATION_BIND		U(0x8400007F)
83 #define FFA_NOTIFICATION_UNBIND		U(0x84000080)
84 #define FFA_NOTIFICATION_SET		U(0x84000081)
85 #define FFA_NOTIFICATION_GET		U(0x84000082)
86 #define FFA_NOTIFICATION_INFO_GET_32	U(0x84000083)
87 #define FFA_NOTIFICATION_INFO_GET_64	U(0xC4000083)
88 #define FFA_SECONDARY_EP_REGISTER_64	U(0xC4000087)
89 #define FFA_MEM_PERM_GET_32		U(0x84000088)
90 #define FFA_MEM_PERM_GET_64		U(0xC4000088)
91 #define FFA_MEM_PERM_SET_32		U(0x84000089)
92 #define FFA_MEM_PERM_SET_64		U(0xC4000089)
93 #define FFA_CONSOLE_LOG_32		U(0x8400008A)
94 #define FFA_CONSOLE_LOG_64		U(0xC400008A)
95 
96 #define FFA_FEATURES_FUNC_ID_MASK	BIT32(31)
97 #define FFA_FEATURES_FEATURE_ID_MASK	GENMASK_32(7, 0)
98 
99 /* Flags used in calls to FFA_NOTIFICATION_GET interface  */
100 #define FFA_NOTIF_FLAG_BITMAP_SP	BIT(0)
101 #define FFA_NOTIF_FLAG_BITMAP_VM	BIT(1)
102 #define FFA_NOTIF_FLAG_BITMAP_SPM	BIT(2)
103 #define FFA_NOTIF_FLAG_BITMAP_HYP	BIT(3)
104 
105 /* Flags used in calls to FFA_NOTIFICATION_INFO_GET interface */
106 #define FFA_NOTIF_INFO_GET_MORE_FLAG		BIT(0)
107 #define FFA_NOTIF_INFO_GET_ID_LIST_SHIFT	12
108 #define FFA_NOTIF_INFO_GET_ID_COUNT_SHIFT	7
109 #define FFA_NOTIF_INFO_GET_ID_COUNT_MASK	0x1F
110 
111 /* Feature IDs used with FFA_FEATURES */
112 #define FFA_FEATURE_NOTIF_PEND_INTR	U(0x1)
113 #define FFA_FEATURE_SCHEDULE_RECV_INTR	U(0x2)
114 #define FFA_FEATURE_MANAGED_EXIT_INTR	U(0x3)
115 
116 /* Special value for traffic targeted to the Hypervisor or SPM */
117 #define FFA_TARGET_INFO_MBZ		U(0x0)
118 
119 #define FFA_MSG_FLAG_FRAMEWORK		BIT(31)
120 #define FFA_MSG_TYPE_MASK		GENMASK_32(7, 0)
121 #define FFA_MSG_PSCI			U(0x0)
122 #define FFA_MSG_SEND_VM_CREATED		U(0x4)
123 #define FFA_MSG_RESP_VM_CREATED		U(0x5)
124 #define FFA_MSG_SEND_VM_DESTROYED	U(0x6)
125 #define FFA_MSG_RESP_VM_DESTROYED	U(0x7)
126 #define FFA_MSG_VERSION_REQ		U(0x8)
127 #define FFA_MSG_VERSION_RESP		U(0x9)
128 
129 /*
130  * Flag used as parameter to FFA_PARTITION_INFO_GET to return partition
131  * count only.
132  */
133 #define FFA_PARTITION_INFO_GET_COUNT_FLAG	BIT(0)
134 
135 /* Memory attributes: Normal memory, Write-Back cacheable, Inner shareable */
136 #define FFA_NORMAL_MEM_REG_ATTR		U(0x2f)
137 
138 /* Memory access permissions: Read-write */
139 #define FFA_MEM_ACC_RW			BIT(1)
140 
141 /* Memory access permissions: executable */
142 #define FFA_MEM_ACC_EXE			BIT(3)
143 
144 /* Memory access permissions mask */
145 #define FFA_MEM_ACC_MASK		0xf
146 
147 /* Clear memory before mapping in receiver */
148 #define FFA_MEMORY_REGION_FLAG_CLEAR		BIT(0)
149 /* Relayer may time slice this operation */
150 #define FFA_MEMORY_REGION_FLAG_TIME_SLICE	BIT(1)
151 /* Clear memory after receiver relinquishes it */
152 #define FFA_MEMORY_REGION_FLAG_CLEAR_RELINQUISH	BIT(2)
153 
154 /* Share memory transaction */
155 #define FFA_MEMORY_REGION_TRANSACTION_TYPE_SHARE SHIFT_U32(1, 3)
156 /* Relayer must choose the alignment boundary */
157 #define FFA_MEMORY_REGION_FLAG_ANY_ALIGNMENT	0
158 
159 #define FFA_MEM_PERM_DATA_PERM		GENMASK_32(1, 0)
160 #define FFA_MEM_PERM_RW			U(0x1)
161 #define FFA_MEM_PERM_RO			U(0x3)
162 
163 #define FFA_MEM_PERM_INSTRUCTION_PERM	BIT(2)
164 #define FFA_MEM_PERM_NX			BIT(2)
165 #define FFA_MEM_PERM_X			U(0)
166 
167 #define FFA_MEM_PERM_RESERVED		GENMASK_32(31, 3)
168 
169 /* Special value for MBZ parameters */
170 #define FFA_PARAM_MBZ			U(0x0)
171 
172 /*
173  * The W1 register in FFA_INTERRUPT and FFA_RUN interfaces contains the target
174  * information. This value has two parts, the SP ID and vCPU ID. The SP ID
175  * identifies the SP to resume and the vCPU ID identifies the vCPU or execution
176  * context to resume (FF-A v1.1 section 4.8).
177  */
178 #define FFA_TARGET_INFO_SET(sp_id, vcpu_id)	(((sp_id) << 16) | (vcpu_id))
179 #define FFA_TARGET_INFO_GET_SP_ID(info)		(((info) >> 16) & 0xffff)
180 #define FFA_TARGET_INFO_GET_VCPU_ID(info)	((info) & 0xffff)
181 
182 /*
183  * Flags used for the FFA_PARTITION_INFO_GET return message:
184  * BIT(0): Supports receipt of direct requests
185  * BIT(1): Can send direct requests
186  * BIT(2): Can send and receive indirect messages
187  * BIT(3): Supports receipt of notifications
188  * BIT(4-5): Partition ID is a PE endpoint ID
189  */
190 #define FFA_PART_PROP_DIRECT_REQ_RECV	BIT(0)
191 #define FFA_PART_PROP_DIRECT_REQ_SEND	BIT(1)
192 #define FFA_PART_PROP_INDIRECT_MSGS	BIT(2)
193 #define FFA_PART_PROP_RECV_NOTIF	BIT(3)
194 #define FFA_PART_PROP_IS_PE_ID		SHIFT_U32(0, 4)
195 #define FFA_PART_PROP_IS_SEPID_INDEP	SHIFT_U32(1, 4)
196 #define FFA_PART_PROP_IS_SEPID_DEP	SHIFT_U32(2, 4)
197 #define FFA_PART_PROP_IS_AUX_ID		SHIFT_U32(3, 4)
198 #define FFA_PART_PROP_NOTIF_CREATED	BIT(6)
199 #define FFA_PART_PROP_NOTIF_DESTROYED	BIT(7)
200 #define FFA_PART_PROP_AARCH64_STATE	BIT(8)
201 
202 #define FFA_MEMORY_HANDLE_HYPERVISOR_BIT	BIT64(63)
203 #define FFA_MEMORY_HANDLE_SECURE_BIT		BIT64(45)
204 #define FFA_MEMORY_HANDLE_NON_SECURE_BIT	BIT64(44)
205 /*
206  * Codes the OP-TEE partition/guest ID into a cookie in order to know which
207  * partition to activate when reclaiming the shared memory. This field is 0
208  * unless CFG_NS_VIRTUALIZATION is enabled.
209  */
210 #define FFA_MEMORY_HANDLE_PRTN_SHIFT		16
211 #define FFA_MEMORY_HANDLE_PRTN_MASK		GENMASK_32(16, 0)
212 
213 
214 #define FFA_BOOT_INFO_NAME_LEN		U(16)
215 
216 /* Boot Info descriptors type */
217 #define FFA_BOOT_INFO_TYPE_IMDEF	BIT(7)
218 #define FFA_BOOT_INFO_TYPE_ID_MASK	GENMASK_32(6, 0)
219 #define FFA_BOOT_INFO_TYPE_ID_FDT	U(0)
220 #define FFA_BOOT_INFO_TYPE_ID_HOB	U(1)
221 
222 /* Boot Info descriptors flags */
223 #define FFA_BOOT_INFO_FLAG_NAME_FORMAT_MASK	GENMASK_32(1, 0)
224 #define FFA_BOOT_INFO_FLAG_NAME_FORMAT_STRING	U(0)
225 #define FFA_BOOT_INFO_FLAG_NAME_FORMAT_UUID	U(1)
226 
227 /** Bits [3:2] encode the format of the content field in ffa_boot_info_desc. */
228 #define FFA_BOOT_INFO_FLAG_CONTENT_FORMAT_SHIFT U(2)
229 #define FFA_BOOT_INFO_FLAG_CONTENT_FORMAT_MASK	GENMASK_32(3, 2)
230 #define FFA_BOOT_INFO_FLAG_CONTENT_FORMAT_VALUE	U(1)
231 #define FFA_BOOT_INFO_FLAG_CONTENT_FORMAT_ADDR	U(0)
232 
233 #define FFA_BOOT_INFO_SIGNATURE		U(0xFFA)
234 #define FFA_BOOT_INFO_VERSION		U(0x10001)
235 
236 #define FFA_CONSOLE_LOG_CHAR_COUNT_MASK	GENMASK_32(7, 0)
237 #define FFA_CONSOLE_LOG_32_MAX_MSG_LEN	U(24)
238 #define FFA_CONSOLE_LOG_64_MAX_MSG_LEN	U(48)
239 
240 /* Memory transaction type in FFA_MEM_RETRIEVE_RESP flags */
241 #define FFA_MEMORY_TRANSACTION_TYPE_MASK	GENMASK_32(4, 3)
242 #define FFA_MEMORY_TRANSACTION_TYPE_SHARE	SHIFT_U32(1, 3)
243 #define FFA_MEMORY_TRANSACTION_TYPE_LEND	SHIFT_U32(2, 3)
244 #define FFA_MEMORY_TRANSACTION_TYPE_DONATE	SHIFT_U32(3, 3)
245 
246 #ifndef __ASSEMBLER__
247 /* Constituent memory region descriptor */
248 struct ffa_address_range {
249 	uint64_t address;
250 	uint32_t page_count;
251 	uint32_t reserved;
252 };
253 
254 /* Composite memory region descriptor */
255 struct ffa_mem_region {
256 	uint32_t total_page_count;
257 	uint32_t address_range_count;
258 	uint64_t reserved;
259 	struct ffa_address_range address_range_array[];
260 };
261 
262 /* Memory access permissions descriptor */
263 struct ffa_mem_access_perm {
264 	uint16_t endpoint_id;
265 	uint8_t perm;
266 	uint8_t flags;
267 };
268 
269 /* Endpoint memory access descriptor */
270 struct ffa_mem_access {
271 	struct ffa_mem_access_perm access_perm;
272 	uint32_t region_offs;
273 	uint64_t reserved;
274 };
275 
276 /* Lend, donate or share memory transaction descriptor */
277 struct ffa_mem_transaction_1_0 {
278 	uint16_t sender_id;
279 	uint8_t mem_reg_attr;
280 	uint8_t reserved0;
281 	uint32_t flags;
282 	uint64_t global_handle;
283 	uint64_t tag;
284 	uint32_t reserved1;
285 	uint32_t mem_access_count;
286 	struct ffa_mem_access mem_access_array[];
287 };
288 
289 struct ffa_mem_transaction_1_1 {
290 	uint16_t sender_id;
291 	uint16_t mem_reg_attr;
292 	uint32_t flags;
293 	uint64_t global_handle;
294 	uint64_t tag;
295 	uint32_t mem_access_size;
296 	uint32_t mem_access_count;
297 	uint32_t mem_access_offs;
298 	uint8_t reserved[12];
299 };
300 
301 /*
302  * The parts needed from struct ffa_mem_transaction_1_0 or struct
303  * ffa_mem_transaction_1_1, used to provide an abstraction of difference in
304  * data structures between version 1.0 and 1.1. This is just an internal
305  * interface and can be changed without changing any ABI.
306  */
307 struct ffa_mem_transaction_x {
308 	uint16_t sender_id;
309 	uint8_t mem_reg_attr;
310 	uint8_t flags;
311 	uint8_t mem_access_size;
312 	uint8_t mem_access_count;
313 	uint16_t mem_access_offs;
314 	uint64_t global_handle;
315 	uint64_t tag;
316 };
317 
318 #define FFA_UUID_SIZE		16
319 
320 /* Partition information descriptor */
321 struct ffa_partition_info_x {
322 	uint16_t id;
323 	uint16_t execution_context;
324 	uint32_t partition_properties;
325 	/*
326 	 * The uuid field is absent in FF-A 1.0, and an array of 16
327 	 * (FFA_UUID_SIZE) from FF-A 1.1
328 	 */
329 	uint8_t uuid[];
330 };
331 
332 /* Descriptor to relinquish a memory region (FFA_MEM_RELINQUISH) */
333 struct ffa_mem_relinquish {
334 	uint64_t handle;
335 	uint32_t flags;
336 	uint32_t endpoint_count;
337 	uint16_t endpoint_id_array[];
338 };
339 
340 /* FF-A v1.0 boot information name-value pairs */
341 struct ffa_boot_info_nvp_1_0 {
342 	uint32_t name[4];
343 	uint64_t value;
344 	uint64_t size;
345 };
346 
347 /* FF-A v1.0 boot information descriptor */
348 struct ffa_boot_info_1_0 {
349 	uint32_t magic;
350 	uint32_t count;
351 	struct ffa_boot_info_nvp_1_0 nvp[];
352 };
353 
354 /* FF-A v1.1 boot information descriptor */
355 struct ffa_boot_info_1_1 {
356 	char name[FFA_BOOT_INFO_NAME_LEN];
357 	uint8_t type;
358 	uint8_t reserved;
359 	uint16_t flags;
360 	uint32_t size;
361 	uint64_t contents;
362 };
363 
364 /* FF-A v1.1 boot information header */
365 struct ffa_boot_info_header_1_1 {
366 	uint32_t signature;
367 	uint32_t version;
368 	uint32_t blob_size;
369 	uint32_t desc_size;
370 	uint32_t desc_count;
371 	uint32_t desc_offset;
372 	uint64_t reserved;
373 };
374 
375 #endif /*__ASSEMBLER__*/
376 #endif /* __FFA_H */
377