You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
743 lines
24 KiB
743 lines
24 KiB
/*
|
|
* Copyright (c) 2013-2020, The Linux Foundation. All rights reserved.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 and
|
|
* only version 2 as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*/
|
|
|
|
#ifndef __QSEECOMI_H_
|
|
#define __QSEECOMI_H_
|
|
|
|
#include <linux/qseecom.h>
|
|
|
|
#define QSEECOM_KEY_ID_SIZE 32
|
|
|
|
#define QSEOS_RESULT_FAIL_SEND_CMD_NO_THREAD -19 /*0xFFFFFFED*/
|
|
#define QSEOS_RESULT_FAIL_UNSUPPORTED_CE_PIPE -63
|
|
#define QSEOS_RESULT_FAIL_KS_OP -64
|
|
#define QSEOS_RESULT_FAIL_KEY_ID_EXISTS -65
|
|
#define QSEOS_RESULT_FAIL_MAX_KEYS -66
|
|
#define QSEOS_RESULT_FAIL_SAVE_KS -67
|
|
#define QSEOS_RESULT_FAIL_LOAD_KS -68
|
|
#define QSEOS_RESULT_FAIL_KS_ALREADY_DONE -69
|
|
#define QSEOS_RESULT_FAIL_KEY_ID_DNE -70
|
|
#define QSEOS_RESULT_FAIL_INCORRECT_PSWD -71
|
|
#define QSEOS_RESULT_FAIL_MAX_ATTEMPT -72
|
|
#define QSEOS_RESULT_FAIL_PENDING_OPERATION -73
|
|
|
|
enum qseecom_command_scm_resp_type {
|
|
QSEOS_APP_ID = 0xEE01,
|
|
QSEOS_LISTENER_ID
|
|
};
|
|
|
|
enum qseecom_qceos_cmd_id {
|
|
QSEOS_APP_START_COMMAND = 0x01,
|
|
QSEOS_APP_SHUTDOWN_COMMAND,
|
|
QSEOS_APP_LOOKUP_COMMAND,
|
|
QSEOS_REGISTER_LISTENER,
|
|
QSEOS_DEREGISTER_LISTENER,
|
|
QSEOS_CLIENT_SEND_DATA_COMMAND,
|
|
QSEOS_LISTENER_DATA_RSP_COMMAND,
|
|
QSEOS_LOAD_EXTERNAL_ELF_COMMAND,
|
|
QSEOS_UNLOAD_EXTERNAL_ELF_COMMAND,
|
|
QSEOS_GET_APP_STATE_COMMAND,
|
|
QSEOS_LOAD_SERV_IMAGE_COMMAND,
|
|
QSEOS_UNLOAD_SERV_IMAGE_COMMAND,
|
|
QSEOS_APP_REGION_NOTIFICATION,
|
|
QSEOS_REGISTER_LOG_BUF_COMMAND,
|
|
QSEOS_RPMB_PROVISION_KEY_COMMAND,
|
|
QSEOS_RPMB_ERASE_COMMAND,
|
|
QSEOS_GENERATE_KEY = 0x11,
|
|
QSEOS_DELETE_KEY,
|
|
QSEOS_MAX_KEY_COUNT,
|
|
QSEOS_SET_KEY,
|
|
QSEOS_UPDATE_KEY_USERINFO,
|
|
QSEOS_TEE_OPEN_SESSION,
|
|
QSEOS_TEE_INVOKE_COMMAND,
|
|
QSEOS_TEE_INVOKE_MODFD_COMMAND = QSEOS_TEE_INVOKE_COMMAND,
|
|
QSEOS_TEE_CLOSE_SESSION,
|
|
QSEOS_TEE_REQUEST_CANCELLATION,
|
|
QSEOS_CONTINUE_BLOCKED_REQ_COMMAND,
|
|
QSEOS_RPMB_CHECK_PROV_STATUS_COMMAND = 0x1B,
|
|
QSEOS_CLIENT_SEND_DATA_COMMAND_WHITELIST = 0x1C,
|
|
QSEOS_TEE_OPEN_SESSION_WHITELIST = 0x1D,
|
|
QSEOS_TEE_INVOKE_COMMAND_WHITELIST = 0x1E,
|
|
QSEOS_LISTENER_DATA_RSP_COMMAND_WHITELIST = 0x1F,
|
|
QSEOS_SOTA_NOTIFICATION_CHECK_STATUS = 0x20,
|
|
QSEOS_FSM_LTEOTA_REQ_CMD = 0x109,
|
|
QSEOS_FSM_LTEOTA_REQ_RSP_CMD = 0x110,
|
|
QSEOS_FSM_IKE_REQ_CMD = 0x203,
|
|
QSEOS_FSM_IKE_REQ_RSP_CMD = 0x204,
|
|
QSEOS_FSM_OEM_FUSE_WRITE_ROW = 0x301,
|
|
QSEOS_FSM_OEM_FUSE_READ_ROW = 0x302,
|
|
QSEOS_FSM_ENCFS_REQ_CMD = 0x403,
|
|
QSEOS_FSM_ENCFS_REQ_RSP_CMD = 0x404,
|
|
|
|
QSEOS_CMD_MAX = 0xEFFFFFFF
|
|
};
|
|
|
|
enum qseecom_qceos_cmd_status {
|
|
QSEOS_RESULT_SUCCESS = 0,
|
|
QSEOS_RESULT_INCOMPLETE,
|
|
QSEOS_RESULT_BLOCKED_ON_LISTENER,
|
|
QSEOS_RESULT_FAILURE = 0xFFFFFFFF
|
|
};
|
|
|
|
enum qseecom_pipe_type {
|
|
QSEOS_PIPE_ENC = 0x1,
|
|
QSEOS_PIPE_ENC_XTS = 0x2,
|
|
QSEOS_PIPE_AUTH = 0x4,
|
|
QSEOS_PIPE_ENUM_FILL = 0x7FFFFFFF
|
|
};
|
|
|
|
/* QSEE Reentrancy support phase */
|
|
enum qseecom_qsee_reentrancy_phase {
|
|
QSEE_REENTRANCY_PHASE_0 = 0,
|
|
QSEE_REENTRANCY_PHASE_1,
|
|
QSEE_REENTRANCY_PHASE_2,
|
|
QSEE_REENTRANCY_PHASE_3,
|
|
QSEE_REENTRANCY_PHASE_MAX = 0xFF
|
|
};
|
|
|
|
struct qsee_apps_region_info_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t addr;
|
|
uint32_t size;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qsee_apps_region_info_64bit_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint64_t addr;
|
|
uint32_t size;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_check_app_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
char app_name[MAX_APP_NAME_SIZE];
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_load_app_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t mdt_len; /* Length of the mdt file */
|
|
uint32_t img_len; /* Length of .bxx and .mdt files */
|
|
uint32_t phy_addr; /* phy addr of the start of image */
|
|
char app_name[MAX_APP_NAME_SIZE]; /* application name*/
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_load_app_64bit_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t mdt_len;
|
|
uint32_t img_len;
|
|
uint64_t phy_addr;
|
|
char app_name[MAX_APP_NAME_SIZE];
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_unload_app_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t app_id;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_load_lib_image_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t mdt_len;
|
|
uint32_t img_len;
|
|
uint32_t phy_addr;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_load_lib_image_64bit_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t mdt_len;
|
|
uint32_t img_len;
|
|
uint64_t phy_addr;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_unload_lib_image_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_register_listener_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t listener_id;
|
|
uint32_t sb_ptr;
|
|
uint32_t sb_len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_register_listener_64bit_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t listener_id;
|
|
uint64_t sb_ptr;
|
|
uint32_t sb_len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_unregister_listener_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t listener_id;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_client_send_data_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t app_id;
|
|
uint32_t req_ptr;
|
|
uint32_t req_len;
|
|
uint32_t rsp_ptr;/* First 4 bytes should be the return status */
|
|
uint32_t rsp_len;
|
|
uint32_t sglistinfo_ptr;
|
|
uint32_t sglistinfo_len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_client_send_data_64bit_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t app_id;
|
|
uint64_t req_ptr;
|
|
uint32_t req_len;
|
|
uint64_t rsp_ptr;
|
|
uint32_t rsp_len;
|
|
uint64_t sglistinfo_ptr;
|
|
uint32_t sglistinfo_len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_reg_log_buf_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t phy_addr;
|
|
uint32_t len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_reg_log_buf_64bit_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint64_t phy_addr;
|
|
uint32_t len;
|
|
} __attribute__((__packed__));
|
|
|
|
/* send_data resp */
|
|
struct qseecom_client_listener_data_irsp {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t listener_id;
|
|
uint32_t status;
|
|
uint32_t sglistinfo_ptr;
|
|
uint32_t sglistinfo_len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_client_listener_data_64bit_irsp {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t listener_id;
|
|
uint32_t status;
|
|
uint64_t sglistinfo_ptr;
|
|
uint32_t sglistinfo_len;
|
|
} __attribute__((__packed__));
|
|
|
|
/*
|
|
* struct qseecom_command_scm_resp - qseecom response buffer
|
|
* @cmd_status: value from enum tz_sched_cmd_status
|
|
* @sb_in_rsp_addr: points to physical location of response
|
|
* buffer
|
|
* @sb_in_rsp_len: length of command response
|
|
*/
|
|
struct qseecom_command_scm_resp {
|
|
uint32_t result;
|
|
enum qseecom_command_scm_resp_type resp_type;
|
|
unsigned int data;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_rpmb_provision_key {
|
|
uint32_t key_type;
|
|
};
|
|
|
|
struct qseecom_client_send_service_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t key_type; /* in */
|
|
unsigned int req_len; /* in */
|
|
uint32_t rsp_ptr; /* in/out */
|
|
unsigned int rsp_len; /* in/out */
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_client_send_service_64bit_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t key_type;
|
|
unsigned int req_len;
|
|
uint64_t rsp_ptr;
|
|
unsigned int rsp_len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_key_generate_ireq {
|
|
uint32_t qsee_command_id;
|
|
uint32_t flags;
|
|
uint8_t key_id[QSEECOM_KEY_ID_SIZE];
|
|
uint8_t hash32[QSEECOM_HASH_SIZE];
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_key_select_ireq {
|
|
uint32_t qsee_command_id;
|
|
uint32_t ce;
|
|
uint32_t pipe;
|
|
uint32_t pipe_type;
|
|
uint32_t flags;
|
|
uint8_t key_id[QSEECOM_KEY_ID_SIZE];
|
|
uint8_t hash32[QSEECOM_HASH_SIZE];
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_key_delete_ireq {
|
|
uint32_t qsee_command_id;
|
|
uint32_t flags;
|
|
uint8_t key_id[QSEECOM_KEY_ID_SIZE];
|
|
uint8_t hash32[QSEECOM_HASH_SIZE];
|
|
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_key_userinfo_update_ireq {
|
|
uint32_t qsee_command_id;
|
|
uint32_t flags;
|
|
uint8_t key_id[QSEECOM_KEY_ID_SIZE];
|
|
uint8_t current_hash32[QSEECOM_HASH_SIZE];
|
|
uint8_t new_hash32[QSEECOM_HASH_SIZE];
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_key_max_count_query_ireq {
|
|
uint32_t flags;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_key_max_count_query_irsp {
|
|
uint32_t max_key_count;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_qteec_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t app_id;
|
|
uint32_t req_ptr;
|
|
uint32_t req_len;
|
|
uint32_t resp_ptr;
|
|
uint32_t resp_len;
|
|
uint32_t sglistinfo_ptr;
|
|
uint32_t sglistinfo_len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_qteec_64bit_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t app_id;
|
|
uint64_t req_ptr;
|
|
uint32_t req_len;
|
|
uint64_t resp_ptr;
|
|
uint32_t resp_len;
|
|
uint64_t sglistinfo_ptr;
|
|
uint32_t sglistinfo_len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_client_send_fsm_key_req {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t req_ptr;
|
|
uint32_t req_len;
|
|
uint32_t rsp_ptr;
|
|
uint32_t rsp_len;
|
|
} __attribute__((__packed__));
|
|
|
|
struct qseecom_continue_blocked_request_ireq {
|
|
uint32_t qsee_cmd_id;
|
|
uint32_t app_or_session_id; /*legacy: app_id; smcinvoke: session_id*/
|
|
} __attribute__((__packed__));
|
|
|
|
/********** ARMV8 SMC INTERFACE TZ MACRO *******************/
|
|
|
|
#define TZ_SVC_APP_MGR 1 /* Application management */
|
|
#define TZ_SVC_LISTENER 2 /* Listener service management */
|
|
#define TZ_SVC_EXTERNAL 3 /* External image loading */
|
|
#define TZ_SVC_RPMB 4 /* RPMB */
|
|
#define TZ_SVC_KEYSTORE 5 /* Keystore management */
|
|
#define TZ_SVC_ES 16 /* Enterprise Security */
|
|
#define TZ_SVC_MDTP 18 /* Mobile Device Theft */
|
|
|
|
/** SIP service call groups */
|
|
#define TZ_SVC_FUSE 8 /* Fuse services. */
|
|
|
|
/*----------------------------------------------------------------------------
|
|
* Owning Entity IDs (defined by ARM SMC doc)
|
|
* ---------------------------------------------------------------------------
|
|
*/
|
|
#define TZ_OWNER_ARM 0 /** ARM Architecture call ID */
|
|
#define TZ_OWNER_CPU 1 /** CPU service call ID */
|
|
#define TZ_OWNER_SIP 2 /** SIP service call ID */
|
|
#define TZ_OWNER_OEM 3 /** OEM service call ID */
|
|
#define TZ_OWNER_STD 4 /** Standard service call ID */
|
|
|
|
/** Values 5-47 are reserved for future use */
|
|
|
|
/** Trusted Application call IDs */
|
|
#define TZ_OWNER_TZ_APPS 48
|
|
#define TZ_OWNER_TZ_APPS_RESERVED 49
|
|
/** Trusted OS Call IDs */
|
|
#define TZ_OWNER_QSEE_OS 50
|
|
#define TZ_OWNER_MOBI_OS 51
|
|
#define TZ_OWNER_OS_RESERVED_3 52
|
|
#define TZ_OWNER_OS_RESERVED_4 53
|
|
#define TZ_OWNER_OS_RESERVED_5 54
|
|
#define TZ_OWNER_OS_RESERVED_6 55
|
|
#define TZ_OWNER_OS_RESERVED_7 56
|
|
#define TZ_OWNER_OS_RESERVED_8 57
|
|
#define TZ_OWNER_OS_RESERVED_9 58
|
|
#define TZ_OWNER_OS_RESERVED_10 59
|
|
#define TZ_OWNER_OS_RESERVED_11 60
|
|
#define TZ_OWNER_OS_RESERVED_12 61
|
|
#define TZ_OWNER_OS_RESERVED_13 62
|
|
#define TZ_OWNER_OS_RESERVED_14 63
|
|
|
|
#define TZ_SVC_INFO 6 /* Misc. information services */
|
|
|
|
/** Trusted Application call groups */
|
|
#define TZ_SVC_APP_ID_PLACEHOLDER 0 /* SVC bits will contain App ID */
|
|
|
|
/** General helper macro to create a bitmask from bits low to high. */
|
|
#define TZ_MASK_BITS(h, l) ((0xffffffff >> (32 - ((h - l) + 1))) << l)
|
|
|
|
/*
|
|
* Macro used to define an SMC ID based on the owner ID,
|
|
* service ID, and function number.
|
|
*/
|
|
#define TZ_SYSCALL_CREATE_SMC_ID(o, s, f) \
|
|
((uint32_t)((((o & 0x3f) << 24) | (s & 0xff) << 8) | (f & 0xff)))
|
|
|
|
#define TZ_SYSCALL_PARAM_NARGS_MASK TZ_MASK_BITS(3, 0)
|
|
#define TZ_SYSCALL_PARAM_TYPE_MASK TZ_MASK_BITS(1, 0)
|
|
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID(nargs, p1, p2, p3, \
|
|
p4, p5, p6, p7, p8, p9, p10) \
|
|
((nargs&TZ_SYSCALL_PARAM_NARGS_MASK)+ \
|
|
((p1&TZ_SYSCALL_PARAM_TYPE_MASK)<<4)+ \
|
|
((p2&TZ_SYSCALL_PARAM_TYPE_MASK)<<6)+ \
|
|
((p3&TZ_SYSCALL_PARAM_TYPE_MASK)<<8)+ \
|
|
((p4&TZ_SYSCALL_PARAM_TYPE_MASK)<<10)+ \
|
|
((p5&TZ_SYSCALL_PARAM_TYPE_MASK)<<12)+ \
|
|
((p6&TZ_SYSCALL_PARAM_TYPE_MASK)<<14)+ \
|
|
((p7&TZ_SYSCALL_PARAM_TYPE_MASK)<<16)+ \
|
|
((p8&TZ_SYSCALL_PARAM_TYPE_MASK)<<18)+ \
|
|
((p9&TZ_SYSCALL_PARAM_TYPE_MASK)<<20)+ \
|
|
((p10&TZ_SYSCALL_PARAM_TYPE_MASK)<<22))
|
|
|
|
/*
|
|
* Macros used to create the Parameter ID associated with the syscall
|
|
*/
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_0 0
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_1(p1) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(1, p1, 0, 0, 0, 0, 0, 0, 0, 0, 0)
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_2(p1, p2) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(2, p1, p2, 0, 0, 0, 0, 0, 0, 0, 0)
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_3(p1, p2, p3) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(3, p1, p2, p3, 0, 0, 0, 0, 0, 0, 0)
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_4(p1, p2, p3, p4) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(4, p1, p2, p3, p4, 0, 0, 0, 0, 0, 0)
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_5(p1, p2, p3, p4, p5) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(5, p1, p2, p3, p4, p5, 0, 0, 0, 0, 0)
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_6(p1, p2, p3, p4, p5, p6) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(6, p1, p2, p3, p4, p5, p6, 0, 0, 0, 0)
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_7(p1, p2, p3, p4, p5, p6, p7) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(7, p1, p2, p3, p4, p5, p6, p7, 0, 0, 0)
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_8(p1, p2, p3, p4, p5, p6, p7, p8) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(8, p1, p2, p3, p4, p5, p6, p7, p8, 0, 0)
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_9(p1, p2, p3, p4, p5, p6, p7, p8, p9) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(9, p1, p2, p3, p4, p5, p6, p7, p8, p9, 0)
|
|
#define TZ_SYSCALL_CREATE_PARAM_ID_10(p1, p2, p3, p4, p5, p6, p7, p8, p9, p10) \
|
|
TZ_SYSCALL_CREATE_PARAM_ID(10, p1, p2, p3, p4, p5, p6, p7, p8, p9, p10)
|
|
|
|
/*
|
|
* Macro used to obtain the Parameter ID associated with the syscall
|
|
*/
|
|
#define TZ_SYSCALL_GET_PARAM_ID(CMD_ID) CMD_ID ## _PARAM_ID
|
|
|
|
/** Helper macro to extract the owning entity from the SMC ID. */
|
|
#define TZ_SYSCALL_OWNER_ID(r0) ((r0 & TZ_MASK_BITS(29, 24)) >> 24)
|
|
|
|
/** Helper macro for checking whether an owning entity is of type trusted OS. */
|
|
#define IS_OWNER_TRUSTED_OS(owner_id) \
|
|
(((owner_id >= 50) && (owner_id <= 63)) ? 1:0)
|
|
|
|
#define TZ_SYSCALL_PARAM_TYPE_VAL 0x0 /* type of value */
|
|
#define TZ_SYSCALL_PARAM_TYPE_BUF_RO 0x1 /* type of buffer RO */
|
|
#define TZ_SYSCALL_PARAM_TYPE_BUF_RW 0x2 /* type of buffer RW */
|
|
|
|
#define TZ_OS_APP_START_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x01)
|
|
|
|
#define TZ_OS_APP_START_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_3( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_VAL, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_APP_SHUTDOWN_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x02)
|
|
|
|
#define TZ_OS_APP_SHUTDOWN_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_APP_LOOKUP_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x03)
|
|
|
|
#define TZ_OS_APP_LOOKUP_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_2( \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_APP_GET_STATE_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x04)
|
|
|
|
#define TZ_OS_APP_GET_STATE_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_APP_REGION_NOTIFICATION_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x05)
|
|
|
|
#define TZ_OS_APP_REGION_NOTIFICATION_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_2( \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_REGISTER_LOG_BUFFER_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x06)
|
|
|
|
#define TZ_OS_REGISTER_LOG_BUFFER_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_2( \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_LOAD_SERVICES_IMAGE_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x07)
|
|
|
|
#define TZ_OS_LOAD_SERVICES_IMAGE_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_3( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_VAL, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_UNLOAD_SERVICES_IMAGE_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_APP_MGR, 0x08)
|
|
|
|
#define TZ_OS_UNLOAD_SERVICES_IMAGE_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_0
|
|
|
|
#define TZ_OS_REGISTER_LISTENER_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x01)
|
|
|
|
#define TZ_OS_REGISTER_LISTENER_SMCINVOKE_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x06)
|
|
|
|
#define TZ_OS_REGISTER_LISTENER_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_3( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_DEREGISTER_LISTENER_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x02)
|
|
|
|
#define TZ_OS_DEREGISTER_LISTENER_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_LISTENER_RESPONSE_HANDLER_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x03)
|
|
|
|
#define TZ_OS_LISTENER_RESPONSE_HANDLER_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_2( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_LOAD_EXTERNAL_IMAGE_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_EXTERNAL, 0x01)
|
|
|
|
#define TZ_OS_LOAD_EXTERNAL_IMAGE_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_3( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_VAL, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_APP_QSAPP_SEND_DATA_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_TZ_APPS, \
|
|
TZ_SVC_APP_ID_PLACEHOLDER, 0x01)
|
|
|
|
|
|
#define TZ_APP_QSAPP_SEND_DATA_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_5( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_UNLOAD_EXTERNAL_IMAGE_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_EXTERNAL, 0x02)
|
|
|
|
#define TZ_OS_UNLOAD_EXTERNAL_IMAGE_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_0
|
|
|
|
#define TZ_INFO_IS_SVC_AVAILABLE_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_SIP, TZ_SVC_INFO, 0x01)
|
|
|
|
#define TZ_INFO_IS_SVC_AVAILABLE_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_INFO_GET_FEATURE_VERSION_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_SIP, TZ_SVC_INFO, 0x03)
|
|
|
|
#define TZ_INFO_GET_FEATURE_VERSION_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_RPMB_PROVISION_KEY_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_RPMB, 0x01)
|
|
|
|
#define TZ_OS_RPMB_PROVISION_KEY_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_RPMB_ERASE_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_RPMB, 0x02)
|
|
|
|
#define TZ_OS_RPMB_ERASE_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_0
|
|
|
|
#define TZ_OS_RPMB_CHECK_PROV_STATUS_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_RPMB, 0x03)
|
|
|
|
#define TZ_OS_RPMB_CHECK_PROV_STATUS_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_0
|
|
|
|
#define TZ_SOTA_UPDATE_NOTIFICATION_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_SIP, TZ_SVC_FUSE, 0x07)
|
|
|
|
#define TZ_SOTA_UPDATE_NOTIFICATION_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_0
|
|
|
|
#define TZ_OS_KS_GEN_KEY_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x01)
|
|
|
|
#define TZ_OS_KS_GEN_KEY_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_2( \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_KS_DEL_KEY_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x02)
|
|
|
|
#define TZ_OS_KS_DEL_KEY_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_2( \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_KS_GET_MAX_KEYS_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x03)
|
|
|
|
#define TZ_OS_KS_GET_MAX_KEYS_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_KS_SET_PIPE_KEY_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x04)
|
|
|
|
#define TZ_OS_KS_SET_PIPE_KEY_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_2( \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_KS_UPDATE_KEY_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_KEYSTORE, 0x05)
|
|
|
|
#define TZ_OS_KS_UPDATE_KEY_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_2( \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_ES_SAVE_PARTITION_HASH_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_SIP, TZ_SVC_ES, 0x01)
|
|
|
|
#define TZ_ES_SAVE_PARTITION_HASH_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_3( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_APP_GPAPP_OPEN_SESSION_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_TZ_APPS, \
|
|
TZ_SVC_APP_ID_PLACEHOLDER, 0x02)
|
|
|
|
#define TZ_APP_GPAPP_OPEN_SESSION_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_5( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_APP_GPAPP_CLOSE_SESSION_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_TZ_APPS, \
|
|
TZ_SVC_APP_ID_PLACEHOLDER, 0x03)
|
|
|
|
#define TZ_APP_GPAPP_CLOSE_SESSION_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_5( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_APP_GPAPP_INVOKE_COMMAND_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_TZ_APPS, \
|
|
TZ_SVC_APP_ID_PLACEHOLDER, 0x04)
|
|
|
|
#define TZ_APP_GPAPP_INVOKE_COMMAND_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_5( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_APP_GPAPP_REQUEST_CANCELLATION_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_TZ_APPS, \
|
|
TZ_SVC_APP_ID_PLACEHOLDER, 0x05)
|
|
|
|
#define TZ_APP_GPAPP_REQUEST_CANCELLATION_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_5( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_MDTP_CIPHER_DIP_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_SIP, TZ_SVC_MDTP, 0x1)
|
|
|
|
#define TZ_MDTP_CIPHER_DIP_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_5( \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RO, TZ_SYSCALL_PARAM_TYPE_VAL, \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_CONTINUE_BLOCKED_REQUEST_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x04)
|
|
|
|
#define TZ_OS_CONTINUE_BLOCKED_REQUEST_SMCINVOKE_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x07)
|
|
|
|
#define TZ_OS_CONTINUE_BLOCKED_REQUEST_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_1(TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_APP_QSAPP_SEND_DATA_WITH_WHITELIST_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_TZ_APPS, \
|
|
TZ_SVC_APP_ID_PLACEHOLDER, 0x06)
|
|
|
|
#define TZ_APP_QSAPP_SEND_DATA_WITH_WHITELIST_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_7( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_APP_GPAPP_OPEN_SESSION_WITH_WHITELIST_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_TZ_APPS, \
|
|
TZ_SVC_APP_ID_PLACEHOLDER, 0x07)
|
|
|
|
#define TZ_APP_GPAPP_OPEN_SESSION_WITH_WHITELIST_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_7( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_APP_GPAPP_INVOKE_COMMAND_WITH_WHITELIST_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_TZ_APPS, \
|
|
TZ_SVC_APP_ID_PLACEHOLDER, 0x09)
|
|
|
|
#define TZ_APP_GPAPP_INVOKE_COMMAND_WITH_WHITELIST_ID_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_7( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_BUF_RW, \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
#define TZ_OS_LISTENER_RESPONSE_HANDLER_WITH_WHITELIST_ID \
|
|
TZ_SYSCALL_CREATE_SMC_ID(TZ_OWNER_QSEE_OS, TZ_SVC_LISTENER, 0x05)
|
|
|
|
#define TZ_OS_LISTENER_RESPONSE_HANDLER_WITH_WHITELIST_PARAM_ID \
|
|
TZ_SYSCALL_CREATE_PARAM_ID_4( \
|
|
TZ_SYSCALL_PARAM_TYPE_VAL, TZ_SYSCALL_PARAM_TYPE_VAL, \
|
|
TZ_SYSCALL_PARAM_TYPE_BUF_RW, TZ_SYSCALL_PARAM_TYPE_VAL)
|
|
|
|
|
|
|
|
#endif /* __QSEECOMI_H_ */
|
|
|