TrustZone之与非安全虚拟化交互

到目前为止,我们在示例中忽略了非安全状态中可能存在的虚拟化程序。当存在虚拟化程序时,虚拟机与安全状态之间的许多通信将通过虚拟化程序进行。

例如,在虚拟化环境中,SMC用于访问固件功能和可信服务。固件功能包括诸如电源管理之类的内容,虚拟化程序通常不希望允许虚拟机直接访问这些功能。

虚拟化程序可以截获来自EL1的SMC,这使得虚拟化程序可以检查请求是用于固件服务还是用于可信服务。如果请求是用于固件服务,虚拟化程序可以模拟接口而不是转发调用。虚拟化程序可以将可信服务请求转发到EL3。您可以在以下图表中看到这一点:

相关推荐
日晨难再2 天前
AMBA:APB的历史(从APB1到APB5)
arm开发·arm·硬件工程·fpga·数字ic
TeYiToKu3 天前
笔记整理—linux进程部分(6)进程间通信、alarm和pause
linux·运维·c语言·笔记·嵌入式硬件·arm
秦伟杰12 天前
mac M1,M2,M3芯片踩坑 nodejs ruby brew
arm·nodejs·ruby·mac·nvm·m2·brew·m1·rvm·m3·苹果芯片
Mr.Cssust14 天前
【研发日记】嵌入式处理器技能解锁(六)——ARM的Cortex-M4内核
ai·arm·cortex-m4·芯片·指令集·嵌入式软件·处理器
Liii40317 天前
【ARM】中断的处理
arm开发·arm
我相遇拾年17 天前
硬件基础知识
嵌入式硬件·arm·硬件工程
送南阳马生序20 天前
Cubieboard2(一) 官方镜像使用与配置
linux·debian·arm
科技互联人生1 个月前
ARM V2处理器微架构分析
系统架构·硬件架构·arm
码狂☆1 个月前
github 工作流自动编译 ffmpeg for windows on arm
windows·ffmpeg·github·arm
时光飞逝的日子1 个月前
C语言调用子函数时入/出栈(保护/恢复现场)全过程分析:以Cortex-M3为例
arm·cortex-m3·出栈·入栈·保护现场·恢复现场