【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制

IoT 4个月前 admin
41 0 0

5月26日,奇安信天工实验室安全研究员赵海,出席国际知名极客大会GEEKCON 2024 Singapore,发表《TI C2000 DSP Chip Hacking》议题演讲,现场展示并成功破解了使用德州仪器TMS320F28375D芯片开发的”安全U盘”,绕过CSM/DCSM保护机制读取其中存储的文件。


议题分享了德州仪器TMS320F28x芯片的CSM/DCSM安全保护机制突破,同时披露了TI C2000 DSP芯片下隐藏了20多年之久的CSM/DCSM锁密机制绕过漏洞。


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制
【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制
【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制

左右滑动查看更多

 * 议题涉及漏洞已报送厂商并沟通细节




芯片介绍

DSP芯片(Digital Signal Processing Chip)是一种专门用于数字信号处理的微处理器或微控制器。C2000™产品作为TI乃至业界最为悠久的MCU产品线之一,至今已有25年历史,从高铁到电动汽车、从数控机床到机械臂、从逆变器到服务器,哪里都有C2000的身影。TMS320F28x是C2000系列中最新的一批芯片,目前广泛使用。

【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


CSM保护机制

代码安全模块(CSM)是C2000芯片内置的一种数据访问保护机制,开发者在芯片指定位置刷入CSM密码给芯片上锁,可以防止内部flash中的固件被UnSecureZone(JTAG调试器、BOOTROM等)读取。


TMS320F28x系列CSM密码为128位(8个16位字),分别是KEY0、KEY1、KEY2、KEY3到KEY7,映射到 FLASH 的地址中,这一地址位置是由 TI 设计的时候设计好的,使用者不能改变,如果加密位置都为 1,那么该芯片为非加密状态,可以访问用户存储区,如果加密位在全 0 的状态,该芯片就处于锁死状态,无法继续使用。


在芯片处于加密状态,无论是使用硬件的 JTAG 调试还是软件指令去读取加密区,得到的结果都是 0。如下使用JTAG调试器查看内存数据,此处看似是空数据,实际上这里是被CSM保护的内存区域,在不知道密码的情况下无法被读取。

【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


使用CSM密码解锁后,可以正常读取到数据:

【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


CSM机制的流程如图所示,如果要访问SecureZone区,则需要使用CSM密码进unlockunlock过程是在硬件中实现的,用户只需要对相关硬件寄存器传入密码即可自动进行。为了防止在运行时调试器附加提取数据,CSM机制规定了UnsecureZone无需解锁可以直接执行SecureZone中的代码,因此BOOTROM在启动固件时,也不需要知道密码。


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


DCSM保护机制

双代码安全模块(DCSM)存在于C2000系列中一些新推出的型号产品,该功能支持将芯片中的memory划为两个独立区域(SecureZone1、SecureZone2),并设置各自独立的的128位CSM密码进行保护。


通过烧写DCSM相关寄存器,可以对内存区域进行划分保护,例如将Flash Sector A、Sector C、RAMLS01划分到SecureZone1,Flash Sector B、Sector D、RANLS02、RAMLS03划分到SecureZone2。


带有DCSM机制的芯片还具有SecureROM,这是内置于芯片中的一段代码,提供了一些对DCSM保护区操作的API函数,例如SafeCrc函数可以在无需解锁CSM的情况下被UnSecureZone中的代码调用计算一个SecureZone中数据的CRC。


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


CSM/DCSM解锁

知道了CSM的加锁方式,对研究CSM解锁思路就有两条。第一,想办法得到128位密码,如果拥有了密码,那么就可以访问用户存储区;第二,在无法得到的情况下如何让芯片编程不加密状态呢?前面提到如果是全为 1 就为不加密状态,那么就想办法让该位置全变为 1,只要达到了这个状态,就破解掉了DSP的加密。


市面上的芯片解密公司使用的是第二种方法:将芯片开盖,使用高精密仪器修改 OTP 存储区的电路,让加密位全部置 1 达到解密的状态。


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制

图片来源:参考链接[1]


这种解锁方式造价高且流程复杂容易毁坏芯片。我们研究发现CSM/DCSM在软件层面上存在漏洞,保护区的数据可以利用漏洞间接访问。


CSM/DCSM安全漏洞

前面在介绍CSM时提到可以在无需解锁的情况下去执行SecureZone中的代码,漏洞在于可以执行SecureZone中任意地址的代码即使该地址不是一个函数的开头位置


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


SecureZone内部的代码是有权限直接访问这个SecureZone本身的数据的,因此可以调用内部的一些ROP Gadgets去间接读写这个SecureZone。如图所示,调用了MOVL ACC,*+XAR5[0]这样的一个内存加载的gadget,可以读取SecureZone中4字节数据到ACC寄存器中。而MOVL *+XAR4[0], ACC这样的数据存储的gadget则可以被用于写SecureZone


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


由于事先不知道SecureZone的内容,那么如何获取gadget的地址是一个问题。将思路转变为CTF的盲打题,我们可以直接从一块未知内容区爆破出想要的ROP Gadget


如下图流程所示,我们使用BOOTROM的下载模式上传我们的代码到RAM执行,想要爆破出数据加载到寄存器的gadget,先在一个地址处存入数据,例如在0x100地址处存入一个Magic Value,接着设置寄存器XAR4XAR5寄存器(这两个寄存器出现在内存读写的指令中比较频繁)为地址0x100,清空其他寄存器,然后从SecureZone开始的位置进行函数调用执行,如果执行错误没有成功返回,则说明当前地址不是我们需要的,下一轮对函数地址增1继续调用;如果函数调用成功返回,则检查哪一个寄存器中的值变成了Magic Value,如果有,说明我们成功找到一个能够从内存加载数据到寄存器的gadget,利用这个gadget可以把数据全部读取,然后反汇编后寻找内存写的gadget


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


CSM/DCSM保护机制都可以使用这种方式来绕过读写保护,由于DCSM增加了SecureROMSecureROM拥有对SecureZone的读写权限,我们也可以去调用SecureROM中的gadgetsSecureROM无法被JTAG提取但是可以在TI官方的C2000Wave SDK包中找到二进制文件,可以对其进行逆向提取需要的ROP gadgets,这样无需爆破,且适配多种产品而不依赖于flash中的代码变化。


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


EXEONLY保护绕过

如果对DCSM中的EXEONLY寄存器进行烧写,可以对指定内存进行只可执行保护,例如设置Flash Sector A、RAMLS01为EXEONLY,开了该保护,即使同一个SecureZone的代码也不能对EXEONLY保护区进行读写,因此上面的绕过方法就失效了。


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


翻阅德州仪器官方的文档,SecureROM提供了两个API可以对EXEONLY区进行读写,但是参数有很严格的限制,也不能被利用。


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


通过对SecureROM的逆向分析,我们发现内部的关键代码:

【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制

这里地址计算一下,实际上是对0x5f022地址处写入了一个标志位 1,然后就可以正常的进行读写了。经过测试,写入标志位和读写数据必须由SecureROM中的代码来完成才能成功,并且两个操作中途不能返回到UnSecureZone中否则也会失败。我们可以使用ROP来完成这个操作。


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


我们找到了合适的gadgets,先用VMOV32 *+XAR5[0], VCC来设置标志位,然后ROP到数据拷贝的gadget处。


Flash刷写保护绕过

对于开了CSM保护的芯片,我们可以利用漏洞读取位于Sector A中的CSM密码,然后进行解锁即可直接刷写flash。对于DCSM,密码在OTP中不可被读取,但是可以在不解锁的情况下刷写flash:在同一个SecureZone中的代码,如果设置了DcsmCommonRegs.FLSEM.all = 0xA501;这个特殊的寄存器,则后续代码可以直接刷写flash。


我们可以先利用漏洞绕过DCSM的读写保护,将flash刷写代码写入到SecureZone中的RAM区,然后再去执行RAM中的代码即可对同一个SecureZone中的flash sector进行刷写。


写在最后

C2000的CSM/DCSM漏洞究其原因是UnSecureZone可以调用SecureZone中任意位置的代码,这是保护机制实现上的缺陷。相比之下,ARM在SecureZone的实现中加入了NSC(Non-secure Callable)这个中间跳板,UnsecureZone只能通过中间跳板进入SecureZone。


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制


相关链接

[1] PSIRT Notification C2000 DCSM ROM Gadget/ROP Vulnerability

[2] Understanding Security Features for C2000 Real-Time Control MCUs

[3] DCSM模块使用说明

[4] TRUSTZONE TECHNOLOGY  

[5] MCU芯片加密历程






【版权说明】

本作品著作权归ha1vk所有

未经作者同意,不得转载

【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制

ha1vk


二进制安全研究员,BlackHat USA 2022 WASM演讲者,专注IOT、硬件、内核等方面的研究。


往期回顾

01
Openfind Mail2000 认证前RCE漏洞分析
02
Docker逃逸中被忽略的 pid namespace
03
关于C++ 迭代器失效特性的研究
04
【BlackHat 2024】SystemUI As EvilPiP: 针对现代移动设备的劫持攻击


【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制
每周三更新一篇技术文章  点击关注我们吧!

原文始发于微信公众号(破壳平台):【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制

版权声明:admin 发表于 2024年5月29日 上午11:32。
转载请注明:【GeekCon 2024】TI C2000 DSP Chip Hacking: 绕过德州仪器C2000芯片的安全保护机制 | CTF导航

相关文章