OP-TEE driver(一):OP-TEE驱动(OP-TEE driver)的工作流程

本文详细介绍了OP-TEE驱动在REE侧的加载和工作流程,包括设备号和class初始化、驱动加载、probe操作,以及安全监控模式调用等关键步骤。OP-TEE驱动作为REE与TEE交互的桥梁,通过共享内存与安全世界状态进行数据交换,并为libteec库和tee_supplicant创建独立设备。驱动加载涉及版本校验、内存配置和队列初始化等过程。

OP-TEE_driver(REE侧)

前面讲了TA和CA的通信,CA的建立,GP。知道了这个CA依赖GP定义的Client接口。TA通过tee-supplicant与REE进行资源操作,现在我们来看看这里面的TEE-driver。

在这里插入图片描述
OP-TEE驱动是REE侧与TEE侧之间进行交互的重要通道,在REE侧的CA接口以及RPC请求的接收和结果的返回最终都会被发送到驱动中,由驱动对数据做进一步的处理。

OP-TEE驱动通过解析传入的参数,重新组合数据,将需要被传入到TEE侧的数据载入到共享内存中,触发安全监控模式调用(smc)进入到Monitor模式或EL3中将数据发送给TEE。

1、OP-TEE_driver模块的编译保存

OP-TEE的驱动通过subsys_initcall和module_init宏来告知系统在初始化阶段的什么时候去加载OP-TEE驱动。

subsys_initcall定义在linux/include/init.h文件中,内容如下:

        #define __define_initcall(fn, id) \
        static initcall_t __initcall_##fn##id __used \
        __attribu
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TrustZone_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值