Globalplatform TEE api介绍

文章目录


★★★ 友情链接 : 个人博客导读首页—点击此处 ★★★

1、TEE API介绍

TEE API分两种:

  • 一类是CA与TA通信的API,实现方式就是应用程序调用libteec.so库,libteec.so库是由optee_client编译出的,libteec.so中调用了dev/tee_priv节点陷入kernel
    mode,在kernel mode中调用smc同步异常指令陷入到ATF,ATF再跳出到TEE OS, TEE
    OS再将消息发送给相应的TA。
    该API在globalplatform中的TEE_Client_API_Specification-V1.0_c.pdf文档中有所规定,api的具体实现是在optee_client/libteec
  • 一类是TA系统调用TEE OS的API,这是的实现方式其实就是系统调用,调用SVC同步异常指令,进入kernel mode。
    该API在globalplatform中的GPD_TEE_Internal_Core_API_Specification_v1.1.pdf文档中有所规定,api的具体实现是在optee_os\lib\libutee

2、Client API : CA与TA通信的API介绍

这类api不到10个,如下所示

TEEC_Result TEEC_InitializeContext(const char *name, TEEC_Context *ctx)
TEEC_Result TEEC_OpenSession(TEEC_Context *ctx, TEEC_Session *session,
			const TEEC_UUID *destination,
			uint32_t connection_method, const void *connection_data,
			TEEC_Operation *operation, uint32_t *ret_origin)
TEEC_Result TEEC_InvokeCommand(TEEC_Session *session, uint32_t cmd_id,
			TEEC_Operation *operation, uint32_t *error_origin)
void TEEC_CloseSession(TEEC_Session *session)
TEEC_Result TEEC_RegisterSharedMemory(TEEC_Context *ctx, TEEC_SharedMemory *shm)
TEEC_Result TEEC_RegisterSharedMemoryFileDescriptor(TEEC_Context *ctx,
TEEC_Result TEEC_AllocateSharedMemory(TEEC_Context *ctx, TEEC_SharedMemory *shm)

3、TEE API : TA系统调用TEE OS的API

这类api就有很多了,也分好几类:
一般类api:

TEE_Result TEE_OpenTASession(const TEE_UUID *destination,
TEE_Result TEE_InvokeTACommand(TEE_TASessionHandle session,
void TEE_CloseTASession(TEE_TASessionHandle session)
TEE_Result TEE_CheckMemoryAcce***ights(uint32_t accessFlags, void *buffer,
TEE_Result TEE_Wait(uint32_t timeout)
TEE_Result TEE_GetTAPersistentTime(TEE_Time *time)
TEE_Result TEE_SetTAPersistentTime(const TEE_Time *time)
TEE_Result TEE_CacheClean(char *buf, size_t len)
TEE_Result TEE_CacheFlush(char *buf, size_t len)
TEE_Result TEE_CacheInvalidate(char *buf, size_t len)

除此之外,还有存储来、算法类…

上一篇:[答疑]-中断流程举例:在TEE侧时产生了FIQ,回到REE后为啥又产生了IRQ


下一篇:2021-2022学年英语周报八年级第7期答案及试题