[IoT安全][翻译]ARM芯片FLASH读出保护机制RDP的绕过策略

Shedding too much Light on a Microcontroller’s Firmware Protection中文翻译

ARM芯片的FLASH读出保护机制(RDP)分为三个等级,分别是 Level 0/Level 1/Level 2。数字越大,代表保护级别越高。

其中,

Level 0:是原始配置,不施加任何限制。 调试接口处于激活状态,允许完全访问设备。 通常,此级别仅用于开发调试期间。

Level 1:使调试接口保持激活状态,但限制对FLASH的访问。 连接调试器后,FLASH将被锁定。 它既不能通过DMA直接读取也不能间接读取,也不能由CPU执行代码。 保护可以升级到Level 2,但也可以降级到RDP级别0,但代价是丢失所有FLASH内容。

Level 2:是最高的也是最严格的等级。调试接口被严格地永久地禁止使用,也就是说JATG/SWD接口全部关闭。同时在该级别不可能降级,也就是不可能降到Level 1或是Level 0.这是因为设置为level 2之后,芯片会自己烧掉Jtag保险丝的。

虽然Level 2是保护最为严密的,但是Level 1依然有存在的意义,这是因为经验表明,开发公司不喜欢完全锁定设备,因为这样就阻碍了后期维护和修复设备故障。此外,例如,STM32F1系列缺乏对RDP Level 2的支持。总而言之,这导致设备设置为 RDP Level 1。

Cold-Boot Stepping(CBS)攻击

芯片手册中保证,如果设置为Level 1,那么芯片在调试期间是开启FLASH读出保护的。人们可能很容易忽视,这个陈述仅涉及FLASH(ROM),而不涉及SRAM和外设。 Level 1中没有涉及这些组件行为信息的描述。

为了搞清楚上述的没有被定义的行为,把微控制器的protection level设置为RDP Level 1。这样我们一旦连接调试器,微控制器就会暂停,因为内核无法再从FLASH中获取任何指令。这样的行为符合datasheet中的描述。 然而,SRAM完全可读,附加调试器不会触发归零或触发任何保护机制。因此,问题在于SRAM中暴露的数据在多大程度上对系统安全构成威胁。

可读SRAM可被视为冷启动场景。 系统已停止运行,但数据仍驻留在内存RAM中。 存在一些简单的情况,其中SRAM中的秘密数据直接暴露。 这种情况不需要再说明了,因为威胁是不言而喻的。

这种通用的CBS方法可以通过使用几个技巧来控制代码执行和SRAM数据冻结。
主要步骤是:

1.重启系统,每一轮迭代前,先重启系统使系统处于初始状态。有以下几种方法重启系统

(a)关闭电源:完全复位(上电复位)只能通过电源循环执行。 它将允许系统再次从其闪存中访问和执行。

(b)置位复位:必须在系统上电之前置位,具体操作是把芯片的nrst引脚电平置低。 这允许芯片在启动时不开始执行代码。
(c)上电:系统在复位时上电。 内部电路准备开始执行,但被复位信号还是低的。

此时相当于一个冷启动过程。

2.运行系统(n·T),控制固件运行的精确时间(n·T)。

(a)取消复位:nrst引脚置高,开始执行固件代码/指令。
(b)等待(n·T):该软件在(n·T)的时间跨度内执行。 我们感兴趣的代码将被执行。
(c)置位复位:一旦时间结束,再次置位复位,操作同1(b)。 这会停止代码执行并重置CPU,但SRAM中的数据是持久的并且会被冻结。

3.转储内存,读出系统存储器(通常为SRAM)并写入上位机某个文件中。

(a)启动调试器,调试器在复位时连接到微控制器, 调试器控制(halt指令)并强制STM32进入永久停止模式。

(b)取消复位,操作同2(a),允许cpu核访问AHB系统总线和SRAM。 SRAM状态仍然保留,因为STM32在2(a)中被调试器暂停,既不启动也不继续执行。

(c)转储内存,调试器读取SRAM(xx命令)并将其数据写入上位机某个文件中。

4.n=n+1,完成这些步骤后,系统将准备下一次迭代。 因此,(n·T)的时间跨度增加一步到(n + 1)·T。

5.重复步骤:每次迭代都以增加的执行的持续时间。 执行迭代直到涵盖整个我们感兴趣的时间跨度。

设置原理图如图1所示。左侧的笔记本电脑协调了攻击。 它使用ST-LINK调试器连接到受攻击设备的调试接口。 笔记本电脑与攻击控制板有UART连接。 攻击控制板上的微控制器处理受攻击设备的复位线和电源。 接通和断开电源可能是困难的,因为受攻击的设备中的微控制器通常是较大设备的一部分,例如AC供电系统。 因此,我们采用了一个继电器,使攻击控制微控制器能够切换高电压和电流。

CBS要求具有微秒精度的精确计时,这是普通计算机系统无法提供的。即使使用RT-patched Linux内核,高时序抖动和可重复性也不尽如人意。因此,调试器无法控制执行的持续时间,因为计算机系统及其USB接口都不能保证实时操作。
因此,采用如图1所示的攻击控制板。其微控制器提供低抖动定时源,因为该系统主要用于连续控制。产生抖动的模块(例如,中断)被禁用,从而实现完全确定的定时行为。在每次迭代开始时,计算机系统将期望的执行持续时间发送到攻击控制板。接下来,它会自动启动受攻击的设备,等待配置的持续时间并再次停止设备。因此,时间关键任务由攻击控制板专门处理。这提供了亚微秒的精度。通过使用电路板,精确地步入选择的时刻变得可行。

原文地址:https://www.cnblogs.com/bianmu-dadan/p/10989412.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


  译序:JWMediaPlayer是开源的网页使用的Flash播放器。本文采摘于JWPlayer的官方文档,讲解了JWPlayer对于RTMP的使用方法,我们可以从JWPlayer客户端的角度来了解RTMP协议。以下是官方原文:      简介    RTMP(RealTimeMessagingProtocol
    Flash编程原理都是只能将1写为0,而不能将0写成1.所以在Flash编程之前,必须将对应的块擦除,而擦除的过程就是将所有位都写为1的过程,块内的所有字节变为0xFF.因此可以说,编程是将相应位写0的过程,而擦除是将相应位写1的过程,两者的执行过程完全相反.一、Nor和NandFlash
 上传setenvgatewayip192.168.1.1;setenvserverip192.168.1.7;setenvipaddr192.168.1.156;mw.b0x820000000xff0x1000000sfprobe0sfread0x8200000000x1000000tftp0x82000000test.bin0x1000000 下载mw.b82000000ff1000000tftp82000000test.bi
Error:FlashDownloadFailed-"Cortex-M3"出现一般有两种情况:1.SWD模式下,Debug菜单中,Reset菜单选项(Autodetect/HWreset/sysresetReq/Vectreset)默认是AutoDetect,改成SysResetReq即可。2.Jtag模式下,主要是芯片大小选错。Flash->ConfigureFalshTools配置窗口,切换到“Utilities"
jPlayer是一个用于控制和播放mp3文件的jQuery插件。它在后台使用Flash来播放mp3文件,前台播放器外观完全可以使用XHML/CSS自定义。支持:有一点比较好的是,在支持html5的浏览器上会使用html5的标签audio或者video,而不支持的浏览器上使用swf来播放选择需要播放的Mp3文件。播放、暂停
#ifndef__FONTUPD_H__#define__FONTUPD_H__#include"sys.h" //字库信息结构体定义33字节__packedtypedefstruct{u8fontok;//字库存在标志,0XAA,字库正常;其他,字库不存在u32ugbkaddr;//unigbk的地址u32ugbksize;//unigbk的大小u32f12addr;//gbk12地址u32g
ROM(ReadOnlyMemory)和RAM(RandomAccessMemory)指的都是半导体存储器。ROM在系统停止供电的时候仍然可以保持数据,而RAM通常都是在掉电之后就丢失数据,但是访问速度快。典型的RAM就是计算机的内存。RAM有两大类,一种称为静态RAM(StaticRAM/SRAM),SRAM速度非常快,是目前读写最快的存储
JSpc端和移动端实现复制到剪贴板功能实现在网页上复制文本到剪切板,一般是使用JS+Flash结合的方法,网上有很多相关文章介绍。随着HTML5技术的发展,Flash已经在很多场合不适用了,甚至被屏蔽。本文介绍的一款JS插件,实现了纯JS方法复制文本到剪切板。插件名是Clipboard.js,该插件不依
例子:R0=1R1=1R2=10R3=e000ed10R12=0LR=fffffff9(中断返回值)PC=0PSR=60000013或60000016或60000036(Z、C、EXCEPT_NUM:RTC_WKUP_IRQn、EXTI0_IRQn、USART2_IRQn)BFAR=e000ed38(不关心)CFSR=20000(INVSTATE:Invalidstateusagefault thePCvaluestackedf
 内存接口概念首先来分析下操作GPIO控制器和操作UART控制器两者的区别如图是S3C2440是个片上系统,有GPIO控制器(接有GPIO管脚),有串口控制器(接有TXDRXD引脚)配置GPIO控制器相应的寄存器,即可让引脚输出高低电平;配置UART控制器相应的寄存器,即可让引脚输出波形。前者相对简单,类
小编导语:    近几年来,网页游戏成为了游戏界关注的焦点,由于其制作简单,成本低并且收益率较高,因此成为了众多游戏厂商追逐的对象,但是除了商家夸张的炒作宣传外,很少有页游佳作出现。然而,随着Unity3D游戏引擎的出现,网页游戏的3D化成了页游冲出重围的杀手锏,那么在flash网页游戏称
1.指定数组到特定的Flash单元#pragmalocation=0x000FFF00 __rootconstcharFlash_config[]={0x0,0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x8,0x9,0xA,0xB,0xC,0xD,0xE,0xF,0x10,0x11,0x12,0x13,0x14,0x15,0x16,0x17,0x18,0x19,0x1A,0x1B,0x1C,0x1D,0x1E,0x1F,0x20,0x21,0x22,0x23,0
继续研究发现,计算机的固件真的很有趣。参考了一些重要的资料,比如http://donovan6000.blogspot.com/2013/06/insyde-bios-modding-advanced-and-power-tabs.html等,对于IDA的使用也了解了一些。最后,总结一下目前看来可行性的方案:0.基础知识储备,包括UEFIBIOS的概念,InsydeBIOS的
<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>navigator对象<itle></head><body><buttononclick="checkFlash()">检测</button>
修改网上流传的flash-marker.js(function(global,factory){typeofexports==='object'&&typeofmodule!=='undefined'?module.exports=factory():typeofdefine==='function'&&define.amd?define(factory
shareObject本地缓存存储位置:win7系统用户到C:\Users\[你的用户名]\AppData\Roaming\Macromedia\FlashPlayer\#SharedObjects\XP或2003用户到:C:\DocumentsandSettings\用户名\ApplicationData\Macromedia\FlashPlayer\#SharedObjects\ ---------------------作者:iteye_
安装谷歌浏览器之后经常遇到Flash崩溃或者浏览器在浏览Flash内容时卡死的情况。在网上查找资料大多都认为应该是浏览器自带的Flash插件工作模式引起的问题,解决方法如下:首先在地址栏输入chrome://plugins/显示浏览器使用的插件。点击右上角的详细信息,可以看到Flash插件为进程外
之前一直使用的W25Q16spiflash都没问题,换了一款W25Q80后发现工作不正常,经过测试,初步定位到问题在于初始化SPI后是否将CS拉高。于是又去查看了一下原厂代码:发现原厂的代码初始化SPI接口时是专门拉高CS的。结论:网上很多代码初始化SPI接口时没有专门拉高CS,对某些型号可能确实
======================================================NANDFlash最小存储单元:写数据操作:通过对控制闸(ControlGate)施加高电压,然后允许源极(SOURCE)和汲极(RRAIN)间的N信道(N-Channel)流入电子,等到电流够强,电子获得足够能量时,便会越过浮置闸(FloatingGate)底下的二氧化硅层(S
安装CnarioPlayer3.8.1.156或其他版本时,有时会出现如下提示:Warning4154.AdobeFlashPlayer13...notcorrectlyinstalled:请前往AdobeFlash网站,并选择下图示的版本下载安装: