Armv8-M的TrustZone技术之在安全状态和非安全状态之间切换

 Armv8-M安全扩展允许在安全和非安全软件之间直接调用。

Armv8-M处理器提供了几条指令来处理状态转换:

4f1b437105bf4fef8bc27429c63ad225.png

下图显示了安全状态转换。

0825f8228bde456d9ff97e77e2aff63d.png

如果入口点的第一条指令是SG且位于非安全可调用内存位置中,则允许从非安全到安全软件的直接API函数调用。

e34a55fb5e714935b695edc171e068c1.png

当非安全程序调用安全API时,API通过使用BXNS指令返回到非安全状态。如果非安全程序尝试分支或调用安全程序地址而不使用有效的入口点,则会生成故障事件。在Armv8-M体系结构中,Secure状态下的HardFault处理故障事件。在具有Main Extension的Armv8-M体系结构中,使用SecureFault异常类型。

Armv8-M安全扩展还允许安全程序调用非安全软件。在这种情况下,安全程序使用BLXNS指令调用非安全程序。在状态转换期间,将返回地址和一些处理器状态信息推送到安全栈,而链接寄存器(LR)上的返回地址设置为称为FNC_RETURN的特殊值。函数地址的最低有效位(LSB)必须为0。

下图显示了在安全程序调用非安全函

相关推荐

  1. Armv8-MTrustZone技术解决安全需求

    2024-01-30 09:26:01       68 阅读
  2. Armv8-MTrustZone技术简介

    2024-01-30 09:26:01       67 阅读
  3. ARMTrustZone技术

    2024-01-30 09:26:01       148 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-30 09:26:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-30 09:26:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-30 09:26:01       82 阅读
  4. Python语言-面向对象

    2024-01-30 09:26:01       91 阅读

热门阅读

  1. flutter制作APP的学习

    2024-01-30 09:26:01       55 阅读
  2. ES6 Reflect详解

    2024-01-30 09:26:01       52 阅读
  3. 使用Redis LIst 实现数据库分页快速查询的方法

    2024-01-30 09:26:01       54 阅读
  4. C Primer Plus(第六版)14.18 编程练习 第5题

    2024-01-30 09:26:01       49 阅读
  5. 代码随想录算法训练营|day20

    2024-01-30 09:26:01       66 阅读
  6. C#设置程序开机启动

    2024-01-30 09:26:01       56 阅读
  7. 基于 MATLAB 语言的 BP 神经网络的改进算法

    2024-01-30 09:26:01       53 阅读