0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

【CDD】诊断数据库创建速成班-课堂(二)

北汇信息POLELINK 2022-08-01 14:20 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

上一堂课已经有给大家介绍关于CANdelaStudio创建CDD文件的部分分享,本堂课我们将继续上次的内容给大家分享CDD文件的创建。

一、Sessions & Security Access编辑介绍

1. Sessions (0x10)

0x10服务包含3个常用的子功能,0x01 Default默认会话,0x02 Programming编程会话,0x03 Extended扩展会话。为什么设计三个会话模式呢?因为权限问题。默认会话权限最小,可操作的服务少;扩展模式通常用于解锁高权限诊断服务,例如写入数据/参数;编程模式用于解锁bootloader相关的诊断服务,即程序烧录。

poYBAGLmQ7mARlItAABhxKYUr0E396.png

上图为会话模式的一个跳转关系式:

a.控制器上电会处于默认会话模式;

b.在默认会话模式下收到默认会话服务的请求

c.在默认会话模式下收到非默认会话服务的请求,会话模式进入编程或者扩展模式

d.在非默认会话模式下收到默认会话服务的请求,或者S3时间超时自动跳回默认会话模式

e.在扩展会话模式下收到编程会话服务的请求或者编程会话模式下收到编程会话服务的请求

f.在编程会话模式下收到扩展会话服务的请求或者扩展会话模式下收到扩展会话服务的请求

需要注意的是如果S3时间内没有收到任何诊断请求,但是又想ECU保持在当前会话模式,这个时候可以周期性的发送0x3E服务,告诉ECU诊断仪在线,不要实现会话模式跳转,0x3E服务是周期性发送的,来时刻刷新S3时间值。

在CANdelaStudio中如何新建一个会话模式?

步骤一:选择New Session新建一个会话模式

pYYBAGLmQ7mAHMsBAACeI-D5d8Y441.png

步骤二:编辑参数

pYYBAGLmQ7mAIkQuAACOOiLo2dE586.png

步骤三:选择新的会话模式支持的服务和设置解锁机制

poYBAGLmQ7mAF83oAAC5e50kwl8377.png

步骤四:完成会话模式的新建

pYYBAGLmQ7mAfn6ZAACSNzKCs6A032.png

新建完成后,在Sessions和State Groups下可以看到新建的会话模式

poYBAGLmQ7mAQqtQAAAd3ZwFV7M194.png

poYBAGLmQ7qAK1akAAFZK66oN0s902.png

前面有提到诊断服务对会话模式是有要求的,这就需要在CDD文件里面根据诊断需求定义去设置。在States->Dependencies->Editing下,可以对会话跳转模式进行编辑,里面定义诊断数据库所有的诊断服务。根据诊断需求定义,服务在某个会话模式下执行,支持的话表示“yes”,在该会话模式下不能支持的表示“No”。针对Default、Programming、Extended,这些表示执行了诊断服务后,对会话模式有变化的,需要设置为相应的会话模式。

pYYBAGLmQ7uAU0mwAAJ52NWxTjY589.png

编辑完成后,可以States->Dependencies->State diagram下查看整个会话模式跳转示意图(首次使用CANdelaStudio需要根据提示去下载插件):

poYBAGLmQ7qARCJCAAGeOb5p3g0352.png

2. Security Access (0x27)

Security Access就是安全访问,通过采用种子与密钥的方式为ECU提供了一种保护机制,针对一些服务进行访问限制来保护数据。

安全访问过程如下图所示:

pYYBAGLmQ7qAO5fkAABnVQO2KYI101.png

如果需要新建安全等级,在CDD文件中也是可以的:

步骤一:选择New Security Level新建一个安全等级

poYBAGLmQ7qAbwHRAADEB2IXVRQ791.png

步骤二:请求种子服务参数编辑

pYYBAGLmQ7qAAFncAAB1fYmKAos605.png

步骤三:发送密钥参数编辑

poYBAGLmQ7yAOOWmAACBhdjhy_8221.png

步骤四:安全访问数据记录参数编辑

poYBAGLmQ7yAL32GAACBS4t9zz8742.png

步骤五:完成安全等级的新建

pYYBAGLmQ7yAV_9jAAClJ1AsG2U458.png

新建完成后,在Security Access和State Groups下可以看到新建的安全等级

pYYBAGLmQ7yAFeV9AAAa3Y0e25s903.png

poYBAGLmQ7yANWleAAEw9RykCkI234.png

同Session会话模式一样,诊断服务对安全访问状态是有要求的,所以需要对所有的诊断服务安全访问在States->Dependencies->Editing下进行编辑。针对诊断服务,如果在锁定或者解锁状态下执行,支持的话表示“Yes”,不支持的话表示“No”。针对Lock、Unlock这些表示执行了诊断服务后,导致控制器安全访问状态改变的,需要设置为相应的状态。

pYYBAGLmQ7yAKKeOAAThqm5Gc54175.png

编辑完成后,可以States->Dependencies->State diagram下查看安全访问的示意图:

poYBAGLmQ72AdotVAAC6GyJuRl8931.png

二、NRC码编辑

下图显示CDDT模板里面自带的NRC码

pYYBAGLmQ72AKu2_AAGUb9QzkNY303.png

如果NRC码不能满足需求,可以新建NRC码

pYYBAGLmQ72AWsXSAAGNgMkiv7Q135.png

针对单个的服务去编辑NRC码:

步骤一:在服务下把“Show Negative Responses”勾上

poYBAGLmQ72AQq40AAHrmNH1ets425.png

步骤二:在“Negative Response”页面编辑支持的NRC码

经过我们CDD创建速成班课堂的两次讲解,我想大家都清楚了如何去创建CDD文件了,这里再给大家总结一下:

CANdelaStudio可以基于CDDT模板生成诊断数据库CDD文件,统一诊断数据源、提高数据库编辑的效率。支持多种总线通信接口,如CAN/CAN FD、DoIP、K-Line、FlexRay。可以编辑诊断服务和诊断响应格式、DTC、DID等,可设定服务间的(会话模式、安全访问)依赖关系,支持状态机显示。生成的CDD文件可以导入其他Vector工具CANoe、CANape、Indigo等软件中进行诊断手动测试;也可以导入CANoe.DiVa生成自动化诊断测试用例,最终在CANoe中导入CANoe.DiVa生成的测试用例进行自动化测试。

Vector Informatik公司是全球领先的分布式系统设计开发工具、网络节点测试验证工具和嵌入式软件组件提供商,为汽车总线网络的设计、建模、仿真、分析、测试以及ECU的开发、测试、标定和诊断等过程提供一系列强有力的软硬件工具和组件,支持CAN、LIN、MOST、FlexRay、以太网、SAE J1939、OSEK和AUTOSAR等多种总线系统、协议和标准。在全球范围内,来自汽车、商用车、工程机械控制工程领域的客户都在应用Vector提供的解决方案和产品。

北汇信息作为Vector中国的合作伙伴,不仅提供相应的工具和技术支持服务及培训,还针对不同的应用提供相应的解决方案,助力中国客户的研发效率提升。欢迎联系北汇信息,为您答疑解惑!

注:文中部分图片来源于Vector。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    系统讲解MySQL数据库慢查询优化思路

    MySQL 是业务系统最常用的数据库,跑着跑着突然接口超时、数据库 CPU 飙升、连接数打满,这些问题排查思路是什么?本文从运维角度出发,讲清楚 MySQL 慢查询的分析方法、索引优化思路、配置参数
    的头像 发表于 05-30 13:53 129次阅读

    【米尔TI AM62L开发板试用】+数据库操作及功能测试

    )启用SQLite3 启用SQLite3的操作如图1所示,随后即可使用数据库指令进行操作。 图1 启用SQLite3 (2)创建数据库 创建数据库
    发表于 05-11 11:31

    生产环境数据库连接池耗尽的全流程排查与性能优化实战

    数据库连接池是应用程序与数据库之间的缓存连接组件。连接池在应用程序启动时创建一组数据库连接,应用程序从连接池获取连接,使用完毕后归还连接池而非关闭连接,避免反复建立和关闭连接的性能开销
    的头像 发表于 03-27 15:58 504次阅读

    Oracle数据库ASM实例无法挂载的数据恢复案例

    一个Oracle数据库故障表现为ASM磁盘组掉线,ASM实例无法挂载(mount)。数据库管理员自行进行简单修复,未能成功,随后联系北亚数据恢复中心恢复数据
    的头像 发表于 02-24 15:19 301次阅读
    Oracle<b class='flag-5'>数据库</b>ASM实例无法挂载的<b class='flag-5'>数据</b>恢复案例

    恒讯科技解析:如何安装MySQL并创建数据库

    安装和管理MySQL不必复杂。只需几分钟,你就能在Linux服务器上搭建MySQL,创建第一个数据库,甚至自动化备份——同时确保数据安全有序。 什么是 MySQL  MySQL 是一个关系型
    的头像 发表于 01-14 14:25 497次阅读

    ODX诊断数据的质量基石ODX Checker Rules详解

    在汽车诊断数据标准化的今天,诊断数据库在车辆生命周期的不同阶段扮演着重要的角色。例如:在代码开发阶段,会用到符合AUTOSAR标准的ARXML文件; 在控制器
    的头像 发表于 01-08 11:28 755次阅读

    国产数据库的AI战事

    国产数据库硝烟再起,Vastbase V100构筑企业智能基座
    的头像 发表于 10-24 20:45 4587次阅读
    国产<b class='flag-5'>数据库</b>的AI战事

    数据库性能优化指南

    作为一名在大厂摸爬滚打多年的运维老兵,我见过太多因为数据库性能问题导致的生产事故。今天分享一套完整的数据库优化方法论,从SQL层面到硬件配置,帮你彻底解决性能瓶颈!
    的头像 发表于 08-18 11:21 994次阅读

    数据库数据恢复—服务器异常断电导致Oracle数据库故障的数据恢复案例

    Oracle数据库故障: 某公司一台服务器上部署Oracle数据库。服务器意外断电导致数据库报错,报错内容为“system01.dbf需要更多的恢复来保持一致性”。该Oracle数据库
    的头像 发表于 07-24 11:12 965次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—服务器异常断电导致Oracle<b class='flag-5'>数据库</b>故障的<b class='flag-5'>数据</b>恢复案例

    Oracle数据恢复—格式化分区导致Oracle数据库报错的数据恢复案例

    完成后将所有硬盘按照原样还原到原服务器中,后续的数据分析和数据恢复操作基于镜像文件进行,避免对原始磁盘数据造成次破坏。基于镜像文件分析所有硬盘底层
    的头像 发表于 07-22 14:06 602次阅读
    Oracle<b class='flag-5'>数据</b>恢复—格式化分区导致Oracle<b class='flag-5'>数据库</b>报错的<b class='flag-5'>数据</b>恢复案例

    三款主流国产数据库的技术特点

    随着数字经济的快速发展和数据安全要求的提升,国产数据库正迎来前所未有的发展机遇。在信创浪潮推动下,达梦数据库、TiDB、华为高斯数据库等国产数据库
    的头像 发表于 07-14 11:08 1446次阅读

    数据库数据恢复—MongoDB数据库文件丢失的数据恢复案例

    MongoDB数据库数据恢复环境: 一台操作系统为Windows Server的虚拟机上部署MongoDB数据库。 MongoDB数据库故障: 工作人员在MongoDB服务仍
    的头像 发表于 07-01 11:13 904次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—MongoDB<b class='flag-5'>数据库</b>文件丢失的<b class='flag-5'>数据</b>恢复案例

    数据库数据恢复—SQL Server数据库被加密如何恢复数据

    SQL Server数据库故障: SQL Server数据库被加密,无法使用。 数据库MDF、LDF、log日志文件名字被篡改。
    的头像 发表于 06-25 13:54 947次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—SQL Server<b class='flag-5'>数据库</b>被加密如何恢复<b class='flag-5'>数据</b>?

    达梦数据库常用管理SQL命令详解

    达梦数据库常用管理SQL命令详解
    的头像 发表于 06-17 15:12 7900次阅读
    达梦<b class='flag-5'>数据库</b>常用管理SQL命令详解

    oracle数据恢复—oracle数据库误执行错误truncate命令如何恢复数据

    oracle数据库误执行truncate命令导致数据丢失是一种常见情况。通常情况下,oracle数据库误操作删除数据只需要通过备份恢复数据
    的头像 发表于 06-05 16:01 2061次阅读
    oracle<b class='flag-5'>数据</b>恢复—oracle<b class='flag-5'>数据库</b>误执行错误truncate命令如何恢复<b class='flag-5'>数据</b>?