blob: a820cc5df48828c3b080f773f3cea7b21ce5c287 [file] [log] [blame]
Mayank Grover16bb2902017-04-21 12:43:53 +05301/* Copyright (c) 2013-2014, 2015, 2017 The Linux Foundation. All rights reserved.
Dinesh K Garg6bbbb702015-01-30 11:13:31 -08002 *
3 * Redistribution and use in source and binary forms, with or without
4 * modification, are permitted provided that the following conditions are
5 * met:
6 * * Redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer.
8 * * Redistributions in binary form must reproduce the above
9 * copyright notice, this list of conditions and the following
10 * disclaimer in the documentation and/or other materials provided
11 * with the distribution.
12 * * Neither the name of The Linux Foundation nor the names of its
13 * contributors may be used to endorse or promote products derived
14 * from this software without specific prior written permission.
15 *
16 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
20 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
23 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
24 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
25 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
26 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29#ifndef __QSEECOMI_LK_H_
30#define __QSEECOMI_LK_H_
31
32#include <qseecom_lk.h>
33
34#define QSEECOM_KEY_ID_SIZE 32
35
36#define QSEOS_RESULT_FAIL_UNSUPPORTED_CE_PIPE -63
37#define QSEOS_RESULT_FAIL_KS_OP -64
38#define QSEOS_RESULT_FAIL_KEY_ID_EXISTS -65
39#define QSEOS_RESULT_FAIL_MAX_KEYS -66
40#define QSEOS_RESULT_FAIL_SAVE_KS -67
41#define QSEOS_RESULT_FAIL_LOAD_KS -68
42#define QSEOS_RESULT_FAIL_KS_ALREADY_DONE -69
43#define QSEOS_RESULT_FAIL_KEY_ID_DNE -70
44#define QSEOS_RESULT_FAIL_INCORRECT_PSWD -71
45#define QSEOS_RESULT_FAIL_MAX_ATTEMPT -72
46
Parth Dixite58fce02015-10-15 11:58:30 +053047#define QSEOS_VERSION_14 0x14
48#define QSEE_VERSION_00 0x400000
49#define QSEE_VERSION_20 0x800000
50#define QSEE_VERSION_40 0x1000000 /* TZ.BF.4.0 */
51
Dinesh K Garg6bbbb702015-01-30 11:13:31 -080052enum qseecom_command_scm_resp_type {
53 QSEOS_APP_ID = 0xEE01,
Mayank Grover16bb2902017-04-21 12:43:53 +053054 QSEOS_LISTENER_ID,
55 QSEE_RESERVED = INT_MAX /**< Required to make the enum 4 bytes. */
Dinesh K Garg6bbbb702015-01-30 11:13:31 -080056};
57
58typedef enum
59{
60 QSEE_APP_START_COMMAND = 0x01,
61 QSEE_APP_SHUTDOWN_COMMAND,
62 QSEE_APP_LOOKUP_COMMAND,
63 QSEE_REGISTER_LISTENER,
64 QSEE_DEREGISTER_LISTENER,
65 QSEE_CLIENT_SEND_DATA_COMMAND,
66 QSEE_LISTENER_DATA_RSP_COMMAND,
67 QSEE_LOAD_EXTERNAL_ELF_COMMAND,
68 QSEE_UNLOAD_EXTERNAL_ELF_COMMAND,
69 QSEE_GET_APP_STATE_COMMAND,
70 QSEE_LOAD_SERV_IMAGE_COMMAND,
71 QSEE_UNLOAD_SERV_IMAGE_COMMAND,
72 QSEE_APP_REGION_NOTIFICATION,
73 QSEE_REGISTER_LOG_BUF_COMMAND,
74 QSEE_RPMB_PROVISION_KEY_COMMAND,
75 QSEE_RPMB_ERASE_COMMAND,
76 QSEE_KS_GEN_KEY_COMMAND,
77 QSEE_KS_DEL_KEY_COMMAND,
78 QSEE_KS_GET_MAX_KEYS_COMMAND,
79 QSEE_KS_SET_PIPE_KEY_COMMAND,
80 QSEE_KS_UPDATE_KEY_COMMAND,
81 QSEE_GP_OPEN_SESSION,
82 QSEE_GP_INVOKE_COMMAND,
83 QSEE_GP_CLOSE_SESSION,
84}qsee_smc_command_type;
85
86enum qseecom_qceos_cmd_status {
87 QSEOS_RESULT_SUCCESS = 0,
88 QSEOS_RESULT_INCOMPLETE,
89 QSEOS_RESULT_FAILURE = 0xFFFFFFFF
90};
91
92enum qseecom_pipe_type {
93 QSEOS_PIPE_ENC = 0x1,
94 QSEOS_PIPE_ENC_XTS = 0x2,
95 QSEOS_PIPE_AUTH = 0x4,
96 QSEOS_PIPE_ENUM_FILL = 0x7FFFFFFF
97};
98
99struct __attribute__ ((packed)) qsee_apps_region_info_ireq {
100 uint32_t qsee_cmd_id;
101 uint32_t addr;
102 uint32_t size;
103};
104
105struct __attribute__ ((packed)) qseecom_check_app_ireq {
106 uint32_t qsee_cmd_id;
107 char app_name[MAX_APP_NAME_SIZE];
108};
109
110struct __attribute__ ((packed)) qseecom_load_app_ireq {
111 uint32_t qsee_cmd_id;
112 uint32_t mdt_len; /* Length of the mdt file */
113 uint32_t img_len; /* Length of .bxx and .mdt files */
114 uint32_t phy_addr; /* phy addr of the start of image */
115 char app_name[MAX_APP_NAME_SIZE]; /* application name*/
116};
117
118struct __attribute__ ((packed)) qseecom_unload_app_ireq {
119 uint32_t qsee_cmd_id;
120 uint32_t app_id;
121};
122
123struct __attribute__ ((packed)) qseecom_load_lib_image_ireq {
124 uint32_t qsee_cmd_id;
125 uint32_t mdt_len;
126 uint32_t img_len;
127 uint32_t phy_addr;
128};
129
130struct __attribute__ ((packed)) qseecom_unload_lib_image_ireq {
131 uint32_t qsee_cmd_id;
132};
133
134struct __attribute__ ((packed)) qseecom_register_listener_ireq {
135 uint32_t qsee_cmd_id;
136 uint32_t listener_id;
137 uint32_t sb_ptr;
138 uint32_t sb_len;
139};
140
141struct __attribute__ ((packed)) qseecom_unregister_listener_ireq {
142 uint32_t qsee_cmd_id;
143 uint32_t listener_id;
144};
145
146struct __attribute__ ((packed)) qseecom_client_send_data_ireq {
147 uint32_t qsee_cmd_id;
148 uint32_t app_id;
149 uint32_t req_ptr;
150 uint32_t req_len;
151 uint32_t rsp_ptr;/* First 4 bytes should be the return status */
152 uint32_t rsp_len;
153};
154
155struct __attribute__ ((packed)) qseecom_reg_log_buf_ireq {
156 uint32_t qsee_cmd_id;
157 uint32_t phy_addr;
158 uint32_t len;
159};
160
161/* send_data resp */
162struct __attribute__ ((packed)) qseecom_client_listener_data_irsp {
163 uint32_t qsee_cmd_id;
164 uint32_t listener_id;
165 uint32_t status;
166};
167
168/*
169 * struct qseecom_command_scm_resp - qseecom response buffer
170 * @cmd_status: value from enum tz_sched_cmd_status
171 * @sb_in_rsp_addr: points to physical location of response
172 * buffer
173 * @sb_in_rsp_len: length of command response
174 */
175struct __attribute__ ((packed)) qseecom_command_scm_resp {
176 uint32_t result;
177 enum qseecom_command_scm_resp_type resp_type;
178 unsigned int data;
179};
180
181struct qseecom_rpmb_provision_key {
182 uint32_t key_type;
183};
184
185struct __attribute__ ((packed)) qseecom_client_send_service_ireq {
186 uint32_t qsee_cmd_id;
187 uint32_t key_type; /* in */
188 unsigned int req_len; /* in */
189 uint32_t rsp_ptr; /* in/out */
190 unsigned int rsp_len; /* in/out */
191};
192
193struct __attribute__ ((packed)) qseecom_key_generate_ireq {
194 uint32_t qsee_command_id;
195 uint32_t flags;
196 uint8_t key_id[QSEECOM_KEY_ID_SIZE];
197 uint8_t hash32[QSEECOM_HASH_SIZE];
198};
199
200struct __attribute__ ((packed)) qseecom_key_select_ireq {
201 uint32_t qsee_command_id;
202 uint32_t ce;
203 uint32_t pipe;
204 uint32_t pipe_type;
205 uint32_t flags;
206 uint8_t key_id[QSEECOM_KEY_ID_SIZE];
207 uint8_t hash32[QSEECOM_HASH_SIZE];
208};
209
210struct __attribute__ ((packed)) qseecom_key_delete_ireq {
211 uint32_t qsee_command_id;
212 uint32_t flags;
213 uint8_t key_id[QSEECOM_KEY_ID_SIZE];
214 uint8_t hash32[QSEECOM_HASH_SIZE];
215
216};
217
218struct __attribute__ ((packed)) qseecom_key_userinfo_update_ireq {
219 uint32_t qsee_command_id;
220 uint32_t flags;
221 uint8_t key_id[QSEECOM_KEY_ID_SIZE];
222 uint8_t current_hash32[QSEECOM_HASH_SIZE];
223 uint8_t new_hash32[QSEECOM_HASH_SIZE];
224};
225
226struct __attribute__ ((packed)) qseecom_key_max_count_query_ireq {
227 uint32_t flags;
228};
229
230struct __attribute__ ((packed)) qseecom_key_max_count_query_irsp {
231 uint32_t max_key_count;
232};
233
234struct __attribute__ ((packed)) qseecom_qteec_ireq {
235 uint32_t qsee_cmd_id;
236 uint32_t app_id;
237 uint32_t req_ptr;
238 uint32_t req_len;
239 uint32_t resp_ptr;
240 uint32_t resp_len;
241};
242
243struct __attribute__ ((packed)) qseecom_client_send_fsm_key_req {
244 uint32_t qsee_cmd_id;
245 uint32_t req_ptr;
246 uint32_t req_len;
247 uint32_t rsp_ptr;
248 uint32_t rsp_len;
249};
250
251
252/********** ARMV8 SMC INTERFACE TZ MACRO *******************/
253
254#define TZ_SVC_APP_MGR 1 /* Application management */
255#define TZ_SVC_LISTENER 2 /* Listener service management */
256#define TZ_SVC_EXTERNAL 3 /* External image loading */
257#define TZ_SVC_RPMB 4 /* RPMB */
258#define TZ_SVC_KEYSTORE 5 /* Keystore management */
259#define TZ_SVC_ES 16 /* Enterprise Security */
260
261/*----------------------------------------------------------------------------
262 * Owning Entity IDs (defined by ARM SMC doc)
263 * -------------------------------------------------------------------------*/
264#define TZ_OWNER_ARM 0 /** ARM Architecture call ID */
265#define TZ_OWNER_CPU 1 /** CPU service call ID */
266#define TZ_OWNER_SIP 2 /** SIP service call ID */
267#define TZ_OWNER_OEM 3 /** OEM service call ID */
268#define TZ_OWNER_STD 4 /** Standard service call ID */
269
270/** Values 5-47 are reserved for future use */
271
272/** Trusted Application call IDs */
273#define TZ_OWNER_TZ_APPS 48
274#define TZ_OWNER_TZ_APPS_RESERVED 49
275/** Trusted OS Call IDs */
276#define TZ_OWNER_QSEE_OS 50
277#define TZ_OWNER_MOBI_OS 51
278#define TZ_OWNER_OS_RESERVED_3 52
279#define TZ_OWNER_OS_RESERVED_4 53
280#define TZ_OWNER_OS_RESERVED_5 54
281#define TZ_OWNER_OS_RESERVED_6 55
282#define TZ_OWNER_OS_RESERVED_7 56
283#define TZ_OWNER_OS_RESERVED_8 57
284#define TZ_OWNER_OS_RESERVED_9 58
285#define TZ_OWNER_OS_RESERVED_10 59
286#define TZ_OWNER_OS_RESERVED_11 60
287#define TZ_OWNER_OS_RESERVED_12 61
288#define TZ_OWNER_OS_RESERVED_13 62
289#define TZ_OWNER_OS_RESERVED_14 63
290
291#define TZ_SVC_INFO 6 /* Misc. information services */
292
293/** Trusted Application call groups */
294#define TZ_SVC_APP_ID_PLACEHOLDER 0 /* SVC bits will contain App ID */
295
296/** General helper macro to create a bitmask from bits low to high. */
297#define TZ_MASK_BITS(h, l) ((0xffffffff >> (32 - ((h - l) + 1))) << l)
298
299/**
300 Macro used to define an SMC ID based on the owner ID,
301 service ID, and function number.
302*/
303#define TZ_SYSCALL_CREATE_SMC_ID(o, s, f) \
304 ((uint32_t)((((o & 0x3f) << 24) | (s & 0xff) << 8) | (f & 0xff)))
305
306#define TZ_SYSCALL_PARAM_NARGS_MASK TZ_MASK_BITS(3, 0)
307#define TZ_SYSCALL_PARAM_TYPE_MASK TZ_MASK_BITS(1, 0)
308
309#define TZ_SYSCALL_CREATE_PARAM_ID(nargs, p1, p2, p3, \
310 p4, p5, p6, p7, p8, p9, p10) \
311 ((nargs&TZ_SYSCALL_PARAM_NARGS_MASK)+ \
312 ((p1&TZ_SYSCALL_PARAM_TYPE_MASK)<<4)+ \
313 ((p2&TZ_SYSCALL_PARAM_TYPE_MASK)<<6)+ \
314 ((p3&TZ_SYSCALL_PARAM_TYPE_MASK)<<8)+ \
315 ((p4&TZ_SYSCALL_PARAM_TYPE_MASK)<<10)+ \
316 ((p5&TZ_SYSCALL_PARAM_TYPE_MASK)<<12)+ \
317 ((p6&TZ_SYSCALL_PARAM_TYPE_MASK)<<14)+ \
318 ((p7&TZ_SYSCALL_PARAM_TYPE_MASK)<<16)+ \
319 ((p8&TZ_SYSCALL_PARAM_TYPE_MASK)<<18)+ \
320 ((p9&TZ_SYSCALL_PARAM_TYPE_MASK)<<20)+ \
321 ((p10&TZ_SYSCALL_PARAM_TYPE_MASK)<<22))
322
323/**
324 Macros used to create the Parameter ID associated with the syscall
325 */
326#define TZ_SYSCALL_CREATE_PARAM_ID_0 0
327#define TZ_SYSCALL_CREATE_PARAM_ID_1(p1) \
328 TZ_SYSCALL_CREATE_PARAM_ID(1, p1, 0, 0, 0, 0, 0, 0, 0, 0, 0)
329#define TZ_SYSCALL_CREATE_PARAM_ID_2(p1, p2) \
330 TZ_SYSCALL_CREATE_PARAM_ID(2, p1, p2, 0, 0, 0, 0, 0, 0, 0, 0)
331#define TZ_SYSCALL_CREATE_PARAM_ID_3(p1, p2, p3) \
332 TZ_SYSCALL_CREATE_PARAM_ID(3, p1, p2, p3, 0, 0, 0, 0, 0, 0, 0)
333#define TZ_SYSCALL_CREATE_PARAM_ID_4(p1, p2, p3, p4) \
334 TZ_SYSCALL_CREATE_PARAM_ID(4, p1, p2, p3, p4, 0, 0, 0, 0, 0, 0)
335#define TZ_SYSCALL_CREATE_PARAM_ID_5(p1, p2, p3, p4, p5) \
336 TZ_SYSCALL_CREATE_PARAM_ID(5, p1, p2, p3, p4, p5, 0, 0, 0, 0, 0)
337#define TZ_SYSCALL_CREATE_PARAM_ID_6(p1, p2, p3, p4, p5, p6) \
338 TZ_SYSCALL_CREATE_PARAM_ID(6, p1, p2, p3, p4, p5, p6, 0, 0, 0, 0)
339#define TZ_SYSCALL_CREATE_PARAM_ID_7(p1, p2, p3, p4, p5, p6, p7) \
340 TZ_SYSCALL_CREATE_PARAM_ID(7, p1, p2, p3, p4, p5, p6, p7, 0, 0, 0)
341#define TZ_SYSCALL_CREATE_PARAM_ID_8(p1, p2, p3, p4, p5, p6, p7, p8) \
342 TZ_SYSCALL_CREATE_PARAM_ID(8, p1, p2, p3, p4, p5, p6, p7, p8, 0, 0)
343#define TZ_SYSCALL_CREATE_PARAM_ID_9(p1, p2, p3, p4, p5, p6, p7, p8, p9) \
344 TZ_SYSCALL_CREATE_PARAM_ID(9, p1, p2, p3, p4, p5, p6, p7, p8, p9, 0)
345#define TZ_SYSCALL_CREATE_PARAM_ID_10(p1, p2, p3, p4, p5, p6, p7, p8, p9, p10) \
346 TZ_SYSCALL_CREATE_PARAM_ID(10, p1, p2, p3, p4, p5, p6, p7, p8, p9, p10)
347
348/**
349 Macro used to obtain the Parameter ID associated with the syscall
350 */
351#define TZ_SYSCALL_GET_PARAM_ID(CMD_ID) CMD_ID ## _PARAM_ID
352
353#define TZ_SYSCALL_PARAM_TYPE_VAL 0x0 /** type of value */
354#define TZ_SYSCALL_PARAM_TYPE_BUF_RO 0x1 /** type of buffer read-only */
355#define TZ_SYSCALL_PARAM_TYPE_BUF_RW 0x2 /** type of buffer read-write */
356
357#define TZ_OS_APP_START_ID \
358 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x01)
359
360#define TZ_OS_APP_START_ID_PARAM_ID \
361 TZ_SYSCALL_CREATE_PARAM_ID_3( \
362 TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_VAL, \
363 TZ_SYSCALL_PARAM_TYPE_VAL)
364
365#define TZ_OS_APP_SHUTDOWN_ID \
366 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x02)
367
368#define TZ_OS_APP_SHUTDOWN_ID_PARAM_ID \
369 TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
370
371#define TZ_OS_APP_LOOKUP_ID \
372 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x03)
373
374#define TZ_OS_APP_LOOKUP_ID_PARAM_ID \
375 TZ_SYSCALL_CREATE_PARAM_ID_2( \
376 TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
377
378#define TZ_OS_APP_GET_STATE_ID \
379 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x04)
380
381#define TZ_OS_APP_GET_STATE_ID_PARAM_ID \
382 TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
383
384#define TZ_OS_APP_REGION_NOTIFICATION_ID \
385 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x05)
386
387#define TZ_OS_APP_REGION_NOTIFICATION_ID_PARAM_ID \
388 TZ_SYSCALL_CREATE_PARAM_ID_2( \
389 TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
390
391#define TZ_OS_REGISTER_LOG_BUFFER_ID \
392 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x06)
393
394#define TZ_OS_REGISTER_LOG_BUFFER_ID_PARAM_ID \
395 TZ_SYSCALL_CREATE_PARAM_ID_2( \
396 TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
397
398#define TZ_OS_LOAD_SERVICES_IMAGE_ID \
399 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x07)
400
401#define TZ_OS_LOAD_SERVICES_IMAGE_ID_PARAM_ID \
402 TZ_SYSCALL_CREATE_PARAM_ID_3( \
403 TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_VAL, \
404 TZ_SYSCALL_PARAM_TYPE_VAL)
405
406#define TZ_OS_UNLOAD_SERVICES_IMAGE_ID \
407 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x08)
408
409#define TZ_OS_UNLOAD_SERVICES_IMAGE_ID_PARAM_ID \
410 TZ_SYSCALL_CREATE_PARAM_ID_0
411
412#define TZ_OS_REGISTER_LISTENER_ID \
413 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x01)
414
415#define TZ_OS_REGISTER_LISTENER_ID_PARAM_ID \
416 TZ_SYSCALL_CREATE_PARAM_ID_3( \
417 TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
418 TZ_SYSCALL_PARAM_TYPE_VAL)
419
420#define TZ_OS_DEREGISTER_LISTENER_ID \
421 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x02)
422
423#define TZ_OS_DEREGISTER_LISTENER_ID_PARAM_ID \
424 TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
425
426#define TZ_OS_LISTENER_RESPONSE_HANDLER_ID \
427 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x03)
428
429#define TZ_OS_LISTENER_RESPONSE_HANDLER_ID_PARAM_ID \
430 TZ_SYSCALL_CREATE_PARAM_ID_2( \
431 TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_VAL)
432
433#define TZ_OS_LOAD_EXTERNAL_IMAGE_ID \
434 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_EXTERNAL, 0x01)
435
436#define TZ_OS_LOAD_EXTERNAL_IMAGE_ID_PARAM_ID \
437 TZ_SYSCALL_CREATE_PARAM_ID_3( \
438 TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_VAL, \
439 TZ_SYSCALL_PARAM_TYPE_VAL)
440
441#define TZ_APP_QSAPP_SEND_DATA_ID \
442 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_TZ_APPS, \
443 TZ_SVC_APP_ID_PLACEHOLDER, 0x01)
444
445
446#define TZ_APP_QSAPP_SEND_DATA_ID_PARAM_ID \
447 TZ_SYSCALL_CREATE_PARAM_ID_5( \
448 TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
449 TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
450 TZ_SYSCALL_PARAM_TYPE_VAL)
451
452#define TZ_OS_UNLOAD_EXTERNAL_IMAGE_ID \
453 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_EXTERNAL, 0x02)
454
455#define TZ_OS_UNLOAD_EXTERNAL_IMAGE_ID_PARAM_ID \
456 TZ_SYSCALL_CREATE_PARAM_ID_0
457
458#define TZ_INFO_IS_SVC_AVAILABLE_ID \
459 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_SIP, TZ_SVC_INFO, 0x01)
460
461#define TZ_INFO_IS_SVC_AVAILABLE_ID_PARAM_ID \
462 TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
463
464#define TZ_INFO_GET_FEATURE_VERSION_ID \
465 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_SIP, TZ_SVC_INFO, 0x03)
466
467#define TZ_INFO_GET_FEATURE_VERSION_ID_PARAM_ID \
468 TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
469
470#define TZ_OS_RPMB_PROVISION_KEY_ID \
471 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_RPMB, 0x01)
472
473#define TZ_OS_RPMB_PROVISION_KEY_ID_PARAM_ID \
474 TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
475
476#define TZ_OS_RPMB_ERASE_ID \
477 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_RPMB, 0x02)
478
479#define TZ_OS_RPMB_ERASE_ID_PARAM_ID \
480 TZ_SYSCALL_CREATE_PARAM_ID_0
481
482#define TZ_OS_KS_GEN_KEY_ID \
483 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x01)
484
485#define TZ_OS_KS_GEN_KEY_ID_PARAM_ID \
486 TZ_SYSCALL_CREATE_PARAM_ID_2( \
487 TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
488
489#define TZ_OS_KS_DEL_KEY_ID \
490 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x02)
491
492#define TZ_OS_KS_DEL_KEY_ID_PARAM_ID \
493 TZ_SYSCALL_CREATE_PARAM_ID_2( \
494 TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
495
496#define TZ_OS_KS_GET_MAX_KEYS_ID \
497 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x03)
498
499#define TZ_OS_KS_GET_MAX_KEYS_ID_PARAM_ID \
500 TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
501
502#define TZ_OS_KS_SET_PIPE_KEY_ID \
503 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x04)
504
505#define TZ_OS_KS_SET_PIPE_KEY_ID_PARAM_ID \
506 TZ_SYSCALL_CREATE_PARAM_ID_2( \
507 TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
508
509#define TZ_OS_KS_UPDATE_KEY_ID \
510 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x05)
511
512#define TZ_OS_KS_UPDATE_KEY_ID_PARAM_ID \
513 TZ_SYSCALL_CREATE_PARAM_ID_2( \
514 TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
515
516#define TZ_ES_SAVE_PARTITION_HASH_ID \
517 TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_SIP, TZ_SVC_ES, 0x01)
518
519#define TZ_ES_SAVE_PARTITION_HASH_ID_PARAM_ID \
520 TZ_SYSCALL_CREATE_PARAM_ID_3( \
521 TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
522 TZ_SYSCALL_PARAM_TYPE_VAL)
523
524#endif /* __QSEECOMI_LK_H_ */