ARMTrustZone:从安全监控运行时服务访问非安全缓冲区
创始人
2024-09-14 00:30:46
0

在ARM TrustZone中,安全模式下的代码可以访问安全缓冲区,但无法访问非安全缓冲区,因为这可能会披露敏感数据。然而,在某些情况下,需要从安全监控运行时服务中访问非安全缓冲区。为了解决这个问题,可以使用以下方法:

  1. 定义一个全局变量,用于存储非安全缓冲区的地址。将这个变量声明为volatile,以确保编译器不会对该变量进行优化。例如:
volatile char *non_secure_buf;
  1. 在非安全模式下,初始化该全局变量。例如:
non_secure_buf = (char *)0x1000;  // 假设缓冲区地址是0x1000
  1. 在安全模式下,通过调用smc(Secure Monitor Call)向监控运行时服务请求访问非安全缓冲区。监控运行时服务应该提供一个接口,可用于返回缓冲区内容或执行其他操作。例如:
#define SMC_FUNCTION_ID 0x12345678  // 定义SMC函数ID
unsigned long smc(unsigned long function_id, unsigned long arg1, unsigned long arg2, unsigned long arg3)
{
    unsigned long ret;
    asm volatile ("smc #0"         // 发起SMC调用
                  : "=r" (ret)     // 返回值存储在ret中
                  : "r" (function_id), "r" (arg1), "r" (arg2), "r" (arg3)
                  : "memory");
    return ret;
}

void access_non_secure_buf(void)
{
    char *buf = (char *)smc(SMC_FUNCTION_ID, (unsigned long)non_secure_buf, 0, 0); // 请求

相关内容

热门资讯

透视插件(aapoker俱乐部... 透视插件(aapoker俱乐部)wepkoe有外挂么(详细辅助软件教程)素来真的是有挂1、超多福利:...
透视好友(wepOKE)透视辅... 透视好友(wepOKE)透视辅助插件(wepoke是真的有挂)从前真的有挂(详细透视可靠教程);《W...
透视教程(德州之星有外挂)po... 透视教程(德州之星有外挂)pokerwoeld安卓下载(详细辅助系统教程)切实存在有挂是一款可以让一...
透视代打(wepoke)透视辅... 透视代打(wepoke)透视辅助工具(wepoke辅助技巧)真是有挂(详细透视透明挂教程);致您一封...
透视真的(德扑之星辅助器购买)... 您好,德扑之星辅助器购买这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家...
透视脚本(WEpoke)外挂透... 透视脚本(WEpoke)外挂透明挂辅助app(aapoker透明挂)往昔真的是有挂(详细透视解密教程...
透视实锤(wepoke辅助挂)... 自定义wepoke辅助挂系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不...
透视系统(wepoke)外挂透... 透视系统(wepoke)外挂透明挂辅助代打(wepoke辅助机器人)一直是有挂(详细透视解密教程);...
透视了解(德扑之星猫腻)云扑克... 透视了解(德扑之星猫腻)云扑克辅助挂(详细辅助攻略方法)真是是真的有挂1、构建自己的微扑克辅助插件;...
透视系统(wepoke)外挂透... 透视系统(wepoke)外挂透明挂辅助安装(wepoke辅助)原来存在有挂(详细透视安装教程),支持...