4、线程运行时资源的使用关系
这个部分就是对上部分的利用,这个在我们自己去实现一些需求的时候,也很有参考意义。
使用线程来处理CA对TA的调用请求时都会使用到上一节中的所有资源。
如果调用的是动态TA,还会使用到该TA的user_ta_ctx的内容,线程的运行与上述资源的关系如图15-2所示。
(如果不是动态TA,那么这些运行可能就在内核态完成了,用不到用户空间)
线程切换到用户空间之前,使用thread_ctx实体中的stack_va_end(stack_va_end是线程在内核态的栈底地址,当线程切换到用户空间时需要重新设置栈空间。)作为该线程运行时的内核栈空间,并且通过UUID从tee_open_session链表中查找到需要被调用的TA的tee_ta_session实体。
TA的tee_ta_session实体会保存TA的操作上下文信息,该上下文信息是在CA调用创建会话操作时被分配和初始化的。保存在user_ta_ctx(OP-TEE使用user_ta_ctx结构体变量保存该调用在用户空间的所有信息,其中就包括了线程在用户空间运行时的栈信息)的tee_ta_ctx结构体( 这是该TA运行时的context信息,在opensession时会被加入到tee_ctxes链表中)成员中,通过tee_ta_ctx实体就能够找到在用户空间使用的user