历史上的今天
返回首页

历史上的今天

今天是:2024年10月11日(星期五)

正在发生

2021年10月11日 | 谈谈汽车芯片信息安全-上篇

2021-10-11

1. 背景简介


汽车芯片信息安全的必要性


1. 早期由于ECU本身设计的资源有限,信息安全考虑的也比较少,导致自身的防护能力很弱,容易导致黑客攻击。随着智能车技术的发展,虽然芯片的数据处理能力不断提升,如果芯片自身的安全防护能力过于薄弱,将导致芯片运行的固件也很容易受到攻击,比如固件篡改,敏感信息(如密钥等)泄露.


2. 随着智能车技术的不断发展,越来越多的政府,行业组织的最佳实践也明确提出智能车的安全需要构建在安全的芯片基础上,比如EVITA、GSMA关于汽车安全的要求,HSM已成为智能车的安全基础,成为行业默认的标准。


3. 智能车功能安全(Safety)和信息安全(Security)在设计阶段也有冲突的地方,比如过度基于软件实现的安全特性,会导致控制指令的延时,影响功能安全特性的实现。因此为了提升产品的性能,以及Safety和Secuirty的强隔离,也必然会要求将更多的信息安全特性集成到芯片里,或者基于芯片的能力来实现。


2. 芯片安全知识图谱


芯片安全图谱的两个维度:


1. 一个维度是芯片自身的安全防护能力,比如能抵抗物理侵入式、半侵入式物理攻击;能检测和防御故障注入攻击;以及耳濡目染的侧信道攻击。这就像是一辆坦克自身厚重的钢板,能抵挡普通子弹和炸弹的攻击。物理攻击需要较强的专业能力,比如借助专用的测试仪器,以及可以近距离接触的物理设备。


2. 另外一个维度是基于芯片的安全服务,比如芯片直接固化的密码类算法,密钥管理机制,真随机数生成器,PUF等机制。


汽车芯片信息安全知识图谱V1.0


3. 常见的芯片攻击手段


3.1 侧信道攻击


a)概念:利用设备的接口对芯片进行电磁和功耗的分析,无需对芯片进行破坏


b)常见测评、攻击类型:时间分析、功耗分析,电磁辐射分析,光子分析


c)适用对象:集成电路/芯片、智能卡、智能门锁、物联网终端、车载电子等产品


下面是一个针对手机的侧信道攻击(电磁分析攻击),作为一个简单的样例。



d)防护原理:消除和降低侧信道信息与密钥的相关性,常用手段:


- 掩码技术:引入随机掩码,平衡“0”和“1”分布。


- 隐藏技术:平均化侧信道信息,降低数据的可区分度


- 混淆技术:降低信噪比(有效侧信道信息)如使用随机时钟等,增加侧信道分析难度。


3.2 故障注入攻击


利用故障(电压、时钟等)引起电路出现异常,根据异常信息分析芯片内部的敏感信息;或者直接利用引起电路的异常来改变程序运行等。


常用测评/攻击类型:电压注入、时钟注入、电磁注入、温度注入,激光注入。


案例:故障注入攻击导致安全启动被成功绕开


(参考Source:乐鑫发布关于故障注入和安全启动的安全性公告 (CVE-2019-15894))


故障注入攻击的防护技术:


- 传感器:专用传感器(电压、频率、温度等)对电压、时钟故障可以起到检测和告警作用


- 逻辑&时钟冗余:逻辑冗余分为面积冗余和时间冗余。面积冗余是指多分计算逻辑各计算一次,最终对比各个计算逻辑的结果来检查是否有故障注入;时间冗余是指一份计算逻辑计算多次,比较多次的结果来检查是否有故障注入。


- 金属外壳&特殊封装:通过金属外壳,可以对激光故障注入,电磁故障注入等手段具有一定的抑制作用


- 逻辑深埋:将关键电路逻辑部署在芯片内层,而不是直接部署在芯片表层,使得故障注入的难度增加


- CRC校验


3.3 物理攻击


a)概念:去除芯片封装,对内部电路进行电接触,结合其他攻击手段获取保存在芯片内部的敏感信息


b)常见攻击类型:FIB电路修改/探针攻击、单板级走线篡改/探听、整机攻击。


c)防护技术:


- Passive shield:被动屏蔽层,例如在芯片表面构建钝化层,金属屏蔽层,增加攻击者解封装难度


- Active shield:主动屏蔽层构建一个电路检测网,覆盖在关键电路表面检测电路一旦有损坏,就会发出告警


- 特殊封装:对电路(芯片)采用特殊封装


- 信号完整性、机密性保护等: 针对单板走线篡改&窃听总线探针窃听&篡改等,通过对信号完整性和机密性进行保护来应对此类攻击


4. 验证辅助的安全特性


1. Hardware Trust Anchor(HTA)


- 以软件无法操作的方式保护敏感数据


- 提供加解密功能


2. HTA不同标准:


- SHE


- HSM


- TPM


3. Evita Full-Medium-Light与SHE差异


以下为详细的案例介绍。


4.1 NXP高级加解密引擎


(1)架构与功能描述:



(2)核心能力:


1) 满足HSM Full等级;


2) 芯片内支持4个并发加解密任务(job),每个任务带有资源ID、TZ(Trustzone标记)和任务ID,并能和Trustzone机制配合使用,具有很强的权限控制能力。


4.2 专用算法密码引擎


(1)NXP针对Flash读写直接加解密引擎-Bus Encryption Engine, BEE


BEE 逻辑架构图


总线加密引擎(BEE)被实现为实时解密引擎,用于CPU直接读取并同时解密Flash(FlexSPI接口)中的数据。BEE的主要功能是:


- 即时AES-128解密,支持ECB和CTR模式


- 别名内存空间支持。重新映射最多两个单独的区域


- 针对这两个区域的独立AES密钥管理


- 基于安全标签的非安全访问的过滤


- 非法访问检查和过滤


(2)NXP 针对RAM在线加解密引擎-Inline Encryption Engine



支持的功能:


- AES-XTS模式下的DDR加密和解密


- QSPI闪存解密,在AES-CTR模式下


- /O DMA直接加密的存储和检索(AES CTR 128)


- 多核资源域分离


- 使用专用总线安全地加载片上密钥


- 差分功率分析(DPA)电阻


- 检测物理篡改并响应


4.3 小结


1. SHE规范奠定了汽车安全基础,引入了汽车可配置的安全子系统概念


2. EVITA的HSM规范扩展了SHE,并采用了Full,Medium、Light三种规格,从而满足更多场景的要求


3. 如今,OEM正在创建自己的技术规范,包括SHE、EVITA和FIPS 140-2的某些方面,以及区域/行业性特殊要求(比如支持国密算法)


4. 还有一些厂商定义特定的轻量级加密引擎,比如NXP的IEE、BEE、PRINCE算法等


5. 启动安全


先讲一个概念:信任链 (chain of trust)


在可信计算体系中,建议信任需要先拥有可信根(Root of Trust),然后建立一条可信链(chain of Trust),再将信任传递到系统的各个模块,之后就能建立整个系统的可信。


安全启动的原理就是硬件信任锚+信任链。


网络设备的安全性严重依赖设备上运行软件的完整性,通常使用信任链确保软件完整性,启动期间每个阶段在执行前检查下一个阶段,如下图所示,这个过程有一个特例,这一步之前没有任何东西可以进行任何检查,此阶段称为信任根(Root of Trust)。


5.1 安全启动


安全启动(Secure Boot):安全启动也叫Verify boot,就是在启动过程中,前一个部件验证后一个部件的数字签名,验证通过后,运行后一个部件。



目前安全启动基本上是对安全要求比较高的场景下,芯片必备功能。


5.2 可信启动


可信启动(Trusted Boot):也称为Measure boot,就是在启动过程中,前一个部件度量(计算HASH)后一个部件,然后把度量值安全保存下来,比如放到一个集中的部件(或云端),设备启动后的一致性(完整性)的校验由集中的部件负责完成。



扩展:在IoT领域,以微软为主推出了轻量级的类TPM技术-DICE,就使用了基于硬件信任锚的可信启动方式。


5.3 加密启动


顾名思义,就是存储在flash中的image是密文,启动过程中会解密在启动,下图是NXP加密启动的流程图:



注:


  1. 加密启动过程本身没有信任链的构建过程


  2. 安全启动(Secure boot)、可信启动(Trusted boot)和加密启动(Encryptedboot)三种启动方式并不是互斥的,可以结合实际应用场景、性能要求结合起来使用。比如安全启动(Secure Boot)和加密启动(Encrypted boot)相结合,既可以确保启动过程系统软件的一致性(没有加载被篡改过的软件系统),又能确保Flash中的软件image不被逆向破解(因为image已被加密)


  3. 需要注意的,如采用加密启动,可以借助前面讲的IEE硬件加密引擎,就可以显著提升解密性能,从而提升启动启动。



推荐阅读

史海拾趣

ERNI Electronics公司的发展小趣事

为了进一步扩大市场份额和提高品牌影响力,ERNI Electronics与全球多家分销商建立了紧密的合作关系。其中,与Digi-Key Electronics等知名分销商的合作尤为引人瞩目。通过这些合作关系,ERNI的产品能够接触到更多的新客户,并通过分销商的渠道实现更广泛的销售。这种合作模式不仅提高了公司的销售业绩,还进一步巩固了ERNI在电子行业中的领先地位。

Ametherm公司的发展小趣事

随着产品质量的提升和市场口碑的积累,Ametherm公司开始积极拓展国内外市场。他们与多家知名企业建立了合作关系,将产品应用于各种电子设备中。同时,公司还积极参加国际电子展会,与全球客户进行交流与合作。这些举措使得Ametherm的品牌影响力逐渐扩大,市场份额也稳步提升。

功得(CONQUER)公司的发展小趣事

在追求经济效益的同时,功得公司也积极履行社会责任。他们关注环保问题,采用环保材料和工艺生产产品;关注员工福利,为员工提供良好的工作环境和福利待遇;关注社会公益事业,积极参与各种慈善活动。这些举措使得功得公司在社会上树立了良好的形象,也为公司的长远发展提供了有力保障。

维峰电子(WCON)公司的发展小趣事

质量是企业的生命线。维峰电子始终将质量管理作为公司发展的重中之重。公司建立了完善的质量管理体系,从原材料采购、生产过程到产品检验等各个环节都进行严格把控。同时,公司还引入了先进的检测设备和技术,确保产品的质量和性能达到最高标准。这些措施的实施不仅提升了产品的竞争力,也赢得了客户的信任和好评。

意瑞(COSEMITECH)公司的发展小趣事

随着业务的不断发展和市场的不断扩大,意瑞半导体也积极寻求外部投资和战略合作。公司先后获得了得彼投资、架桥投资、深创投等机构超2亿元的股权投资,为公司的持续发展提供了有力的资金保障。此外,意瑞半导体还积极参与各种行业活动和展览,与业界同仁进行深入交流和合作,共同推动半导体行业的发展。

以上五个故事素材可以根据需要进一步扩展和细化,以形成完整的、具有吸引力的电子行业意瑞半导体公司的发展故事。

帝特(DTECH)公司的发展小趣事

2007年,帝特成功获得迪士尼形象授权(泰国),这一里程碑事件标志着帝特品牌在国际市场上的认可度和影响力得到了显著提升。随后,帝特又获得了国内悠嘻猴授权,进一步丰富了其产品线。2008年,帝特荣获“守合同、重信用企业”荣誉称号,这一荣誉不仅是对帝特过去努力的肯定,也为公司的未来发展奠定了坚实基础。

问答坊 | AI 解惑

motorola 锁相环PLL教材

很不错的资料,拿出来分享一下,回帖我再发新的内容…

查看全部问答>

我看IC:现在最想玩LPC11XX 和EFM32

lpc11xx就不用说,咱论坛也做过类似的讲座:https://bbs.eeworld.com.cn/thread-91994-1-1.html 且说说EFM32: 一个运行电流为50nA的32kHz实时计数器,一个运行电流为100nA的、可达9600bps的通用异步收发传输器。感觉超NB 很希望可以用用,大家 ...…

查看全部问答>

关于wince5 串口中断服务函数SerialDispatchThread的疑问

在SerialDispatchThread函数中有下面语句,请问: /* Wait for the event that any serial port action creates.      */     while ( !pSerialHead->KillRxThread ) {         DEB ...…

查看全部问答>

对ldr指令的疑惑

(1) adr         r0, _start                   /* 把_start的相对地址移到r0       */ ldr       & ...…

查看全部问答>

串口驱动只能接收16字节,16字节后的数据丢失问题?

用wince下的串口驱动移植的。 写完测试的时候都是在16字节以内进行的,收发正常。现在PC端每次发送超过16字节的数据,我的WINCE设备这边只能收到16字节,每次发送超过16字节的就丢失了。 芯片用得是16554. 这个可能是什么原因啊? 很奇怪我把FIFO ...…

查看全部问答>

C指针学习,求指点!

本人菜鸟一个,指针不是很好,是应该去好好研究《C与指针》呢,还是去边读代码边学习呢???望高手指点一二!在此谢过…

查看全部问答>

MSP430f149技术讨论贴

本帖最后由 paulhyde 于 2014-9-15 04:05 编辑 欢迎各位在本贴讨论msp430f149使用的相关经验,需要149的相关资料,可以留言。LCD1602,1CD12864,ADC12,DAC7512,TTF2.4,PID,资料很多,  …

查看全部问答>

UART1串口只能接收16个字节的数据,超过16个字节的数据全部丢失

void uart1IsrInit(void) {     INT16U usFdiv;         U1LCR  = 0x87;                           & ...…

查看全部问答>

有木有做电力线载波的

有木有做过电力线载波的,我用的是ST7538的modem,想请教一些关于ST7538控制的问题,麻烦有愿意指教的朋友加我QQ:664228347…

查看全部问答>

继续 代码大全(2)

上一个代码大全的帖子 已经到了8页了,有点长。 于是决定写一个新帖。 同样希望以后写的更简洁,更有说服力。…

查看全部问答>