原创 “汽车人”眼中的网络安全 ---关于AUTOSAR E2E及测试开发实践

2022-10-14 10:49 3239 10 2 分类: 汽车电子


1.E2E概念介绍


1.1 E2E是什么?


E2E全称为End to End,代表的是AUTOSAR中的一种数据保护机制,从名称中可以看出,这是一个终端到终端的逻辑那么这里的终端是指ECU吗?

答案是否定的。在AUTOSAR的架构中,最上层为包含SW-C(Software Component)的应用层,类似于手机应用程序中的各种APP。对于E2E来说,数据的传递不是针对ECU到ECU的层级而是SW-C到SW-C层级


1 AUTOSAR软件概貌


在车载网络中,信息交换通常是从一个ECU发送信号,另一个ECU接收信号。对E2E而言,通常是从SW-C生成信号,经过RTE(Run-Time Environment)、BSW(Basic Software)并在物理总线上传输后到达目标SW-C。在这个过程中,信号的传递可能由于一些故障情况(比如软件运行错误)无法到达目标终端,或是信号本身被干扰/损坏,尤其对于安全相关的信号(车速、档位、车辆/电源模式等)来说,这种情况会带来很大的隐患。而E2E正是通过一些机制,使发送终端和接收终端的数据保持一致,保证信息的完整性


2 错误来源的示意

 

1.2 E2E的适用范围


E2E可适用各种总线通信,北汇信息参与项目为例,E2E机制应用于CAN、CAN FDLIN、FlexRay总线通信中对于以太网当然可应用E2E机制但是需考虑和留意如下的问题:

不同于上文介绍的发送端/接收端的通信模式,以太网中将会广泛应用基于SoA客户端/服务器的通信模式,涉及诸如客户端及其操作的序列号变化、超时检测等问题,对此应该如何定义E2E机制?

在TSN网络中Follow_Up报文每次经过交换机后都会更新其内容,此时的E2E机制又应该做何种变化?


1.3关于E2E与SecOC


除了E2E保护机制外,AUTOSAR还定义了针对PDU(Protocol Data Unit)的保护策略SecOC(Secure Onboard Communication)。关于SecOC更多细节后续将有专门文章介绍,先对SecOC与E2E两者进行简要对比如下图3,供大家参考。


图3 SecOC与E2E简要对比图


2.E2E的机制介绍


E2E策略的整体思路是CRC校验和计数,在原始数据的基础上增加控制形成E2E报头,AUTOSAR提供了多种E2E的配置来适用各种场景,本文以E2E Profile 1这种配置为例来说明。

4 E2E报头


在E2E Profile 1中,发送到RTE的数据需要包含3个部分:4个bit的Counter,1个字节的CRC以及需要被保护的原数据。其中Counter为计数器,每发送一次值就增加;CRC按照E2E Profile 1的计算方式,对Data ID、Counter和原数据进行CRC计算,并将结果填入CRC字节


5 E2E Profile 1配置示意图


Data ID是一个预先定义的密钥,不会被发送到总线上。整个E2E的过程为:

1. SW-C生成原数据

2. 将Counter和原数据组成待校验数据

3. 使用Data ID进行CRC的校验

4. 将原数据、Counter和CRC值发送给RTE

5. 经过诸如总线通信等路径,原数据、Counter和CRC传递到目标RTE

6. 将接收的数据拆包,校验Counter和CRC

7. 目标SW-C接收到原数据


6 E2E流程示例


当然,与数据发送方相比,数据接收方需要处理的内容就显得更加复杂。包含序列丢失处理、序列无效处理、序列重复处理、超时处理


7 E2E接收行为示例


E2E本身有很大的灵活性,除了本文示例外(本文示例使用了E2E Protection Wrapper),还有多种使用方式(比如COM E2E Callouts)感兴趣的小伙伴可以参考AUTOSAR规范。


3.E2E测试实践


对于网络中的ECU而言,E2E测试包含E2E发送测试和E2E接收测试。

典型的E2E发送测试是将ECU发送的包含E2E信息的数据源按照E2E Profile 1方式,计算一个CRC,如果与原始发送的CRC相等则验证通过,反之亦然

E2E接收测试包括正向和逆向测试,逆向测试主要是验证ECU在接收到错误的E2E时的行为如丢弃该数据信息,记录E2E错误DTC等)以及再次接收到正确E2E时的行为测试,此类测试需软件层面的支持,比如定义相关的DTC方可实现黑盒测试,或提供相关的内部数据的访问接口和方法,或与功能测试相结合,总之依赖特定的条件


本文主要介绍E2E发送测试。以CAN总线为例,当接收到总线上发送的一帧包含E2E信息的报文时,首先获取该E2E对应的所有信号的值,然后将信号组成数据位流进行CRC计算,在这个过程需要注意以下几点:

> 信号打包

> 信号排序方式(取决于OEM需求)

> 信号位置排序规则(取决于OEM需求),本例中的规则在ARXML做了属性定义,包括CRC信号和Counter信号位置


图8 信号位置的排序规则在ARXML属性定义


根据属性定义和计算规则得到待校验的数据为04 00 00 01 00 00 01 81 04h然后,ARXML中获取该E2E的DATA ID=34;最后,使用AUTOSAR_SWS_E2ELibrary定义的算法,计算得到CRC的值为0xE6,与发送的CRC一致,则该E2E发送是正确的。

根据上面的描述可以了解E2E验证的具体过程但是,当网络中有多个ECU,每个ECU又有多个E2E时,手动测试验证显然不是明智之举。那么,如何进行自动化测试呢?首先需要解决以下技术难点:


E2E测试对象的提取


ARXML文件中定义了ECU的E2E发送和E2E接收集合,其中包含了每个E2E的详细信息,可以询该E2E原型对应的真实载体。为此,我们专门开发了ARXML文件解析软件,通过软件来提取E2E测试对象。


9 ARXML文件E2E信息


数据库兼容性问题

E2E属性信息是在ARXML中定义的,为了实现测试环境的仿真可能需加载DBC、LDF、FIBEX等不同格式通信数据库此时,不同数据库之间信号名称的一致性问题就突显出来。为此,开发了“位流”解析方案,解决数据库的兼容问题。

技术难点已被攻克,自动化测试不再是难事。我们基于Vector CANoe软件,开发了一套自动化在线测试脚本,已经支持CAN、LIN、CAN FD、FlexRay总线E2E测试


10 CANoe E2E测试工程和自动生成报告


自动化在线测试有很多优点,比如可以实时监控ECU报文发送状态,可以模拟故障注入等场景.

但是,在线测试也有无法解决的场景:

并行分析,发现潜在的或偶发的问题

针对OEM而言,ECU尚未交样的情况提前验证,或同时交样时多样件同时测试时的资源占用问题

针对以上问题,我们专门开发了一套完整的离线测试软件工具链,通过ECU通信的log数据或者实车GL记录仪存储的log数据,就可以完成E2E离线测试,过程如下。


11 E2E离线测试流程


E2E测试对象的提取

通过ARXML

文件解析软件,提取出E2E测试对象,作为E2E测试的输入文件。


Log文件解析和通道映射

该离线工具支持CAN、CAN FD、LIN、FlexRay等报文的解析,实现对BLF文件的解析,同时支持多总线多ECU同时测试,根据实车记录的数据,在软件中进行通道和总线的映射,实现一次性测试。


12 E2E离线测试配置

测试执行

导入E2E测试对象文件、通道映射文件和实车BLF log文件,执行测试。该离线软件支持高并发处理,1GB的log数据可在几分钟内完成测试


13 E2E离线测试执行及测试结果分析


测试结果分析

从测试执行结果分析,该ECU有两个E2E计算错误,经分析为DATA ID配置错误;1个E2E对应的报文未发送,定位为Com层问题;1个E2E对应的信号组的Update Bit始终未置1与功能触发有关引起


5.总结

道路千万条,安全第一条。AUTOSAR所定义的安全机制较容易落地,目前在国内主流OEM中已经得到了应用,北汇也有幸参与其中。愿与各位共同努力,分享经验,提供专业的网络安全测试解决方案

注:文中部分图片来源于AUTOSAR


参考文献

[1] AUTOSAR_SWS_E2ELibrary

[2] AUTOSAR_SWS_SecureOnboardCommunication

作者: 北汇信息, 来源:面包板社区

链接: https://mbb.eet-china.com/blog/uid-me-3998886.html

版权声明:本文为博主原创,未经本人允许,禁止转载!

文章评论1条评论)

登录后参与讨论

自做自受 2022-10-16 15:34

是啊,人类始终在安全第一上下功夫。也联想,但也不是所有人类,非洲人在安全第一上下了什么功夫?
相关推荐阅读
北汇信息 2024-11-27 13:38
AI 助力汽车电子测试:落地应用的六大挑战
引言:AI 的机遇与挑战自从 ChatGPT 横空出世以来,人工智能似乎一夜之间变得无处不在。在日常使用中,我们常常在惊艳与失望之间徘徊:它有时能展现出令人惊叹的能力,洞察深刻、对答如流,有时却又犯下...
北汇信息 2024-11-20 11:09
舱驾融合一体化测试解决方案
舱驾融合通过软硬件的深度整合,实现了架构简化、成本优化和性能提升,是智能汽车发展的必然趋势。然而,这种融合也带来诸多测试挑战:ASIL B/D不同安全等级的功能共存、跨域资源协同调度、系统复杂度显著提...
北汇信息 2024-11-14 16:48
“亦”真“亦”假?——MXsteerWheel与DYNA4的强强联手
高性能力反馈方向盘MXsteerWheel作为线控转向开发的新帮手,在北汇信息的展台上一直是大家关注的焦点。由于它简练出众的外表与真实阻尼的手感,吸引参展的朋友都乐此不疲地进行尝试。而后又不禁感叹,亦...
北汇信息 2024-11-12 14:09
代码静态测试工具Klocwork 2024.3新版发布:Validate平台改进编码标准CC++
Klocwork 2024.3 为 C/C++ 分析引擎和构建上传流程引入了新功能和性能改进。此版本还附带了增强的安全性和用户体验改进,包括用于 SAML/OIDC 身份验证的 IDE 插件中更好的用...
我要评论
1
10
关闭 站长推荐上一条 /2 下一条