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。

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

    评论

    相关推荐

    数据库数据恢复—通过拼接数据库碎片恢复SQLserver数据库

    一个运行在存储上的SQLServer数据库,有1000多个文件,大小几十TB。数据库每10天生成一个NDF文件,每个NDF几百GB大小。数据库包含两个LDF文件。 存储损坏,数据库
    的头像 发表于 10-31 13:21 155次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—通过拼接<b class='flag-5'>数据库</b>碎片恢复SQLserver<b class='flag-5'>数据库</b>

    数据库数据恢复—SQL Server数据库出现823错误的数据恢复案例

    SQL Server数据库故障: SQL Server附加数据库出现错误823,附加数据库失败。数据库没有备份,无法通过备份恢复数据库
    的头像 发表于 09-20 11:46 300次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—SQL Server<b class='flag-5'>数据库</b>出现823错误的<b class='flag-5'>数据</b>恢复案例

    华纳云:MySQL初始化操作如何创建新的数据库

    要在MySQL中创建一个新的数据库,可以按照以下步骤进行操作: 登录到MySQL数据库管理系统中。可以使用MySQL命令行客户端或者图形化工具,如phpMyAdmin。 使用CREATE
    的头像 发表于 09-04 14:30 227次阅读

    恒讯科技分析:sql数据库怎么用?

    。 2、安装数据库软件: 在您的服务器或本地计算机上安装所选的数据库软件。 3、配置数据库服务器: 根据需要配置数据库服务器设置,包括内存分配、存储位置、网络配置等。 4、
    的头像 发表于 07-15 14:40 325次阅读

    7月15日开班啦! | Cadence 高速项目设计暑假速成班

    一年一度暑假季高考结束,暑假已至!在这一年一度的暑假季里,机遇与成长相伴。李老师满怀热忱,计划安排一次Cadence高速项目设计速成班,本次培训将带领大家完成高速实例项目设计。课程介绍本项
    的头像 发表于 07-06 08:12 284次阅读
    7月15日开班啦! | Cadence 高速项目设计暑假<b class='flag-5'>速成班</b>

    数据库数据恢复—raid5阵列上层Sql Server数据库数据恢复案例

    数据库数据恢复环境: 5块硬盘组建一组RAID5阵列,划分LUN供windows系统服务器使用。windows系统服务器内运行了Sql Server数据库,存储空间在操作系统层面划分了三个逻辑分区
    的头像 发表于 05-08 11:43 486次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—raid5阵列上层Sql Server<b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复案例

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

    oracle数据库ASM磁盘组掉线,ASM实例不能挂载。数据库管理员尝试修复数据库,但是没有成功。
    的头像 发表于 02-01 17:39 494次阅读
    【<b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复】Oracle<b class='flag-5'>数据库</b>ASM实例无法挂载的<b class='flag-5'>数据</b>恢复案例

    mysql怎么新建一个数据库

    mysql怎么新建一个数据库 如何新建一个数据库在MySQL中 创建一个数据库是MySQL中的基本操作之一。下面将详细介绍在MySQL中如何新建一个
    的头像 发表于 12-28 10:01 865次阅读

    无模式数据库的利与弊

    数据管理需求日益多样,无论是金融服务、游戏还是社交媒体行业,都要求支持实时数据处理和快速迭代,无模式数据库因其灵活性和易用性而逐渐成为开发者的新选择。那么,无模式数据库到底有哪些特性呢
    的头像 发表于 12-16 08:04 491次阅读
    无模式<b class='flag-5'>数据库</b>的利与弊

    数据库数据恢复—未开启binlog的Mysql数据库数据恢复案例

    mysql数据库数据恢复环境: 本地服务器,windows server操作系统 ,部署有mysql单实例,数据库引擎类型为innodb,独立表空间,无数据库备份,未开启binlog
    的头像 发表于 12-08 14:18 1108次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—未开启binlog的Mysql<b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复案例

    关于JSON数据库

    如何理解JSON数据库?作为NoSQL数据库的一种类型,JSON数据库有哪些优势呢?JSON数据库如何运作,它为应用程序开发者带来了哪些价值呢?
    的头像 发表于 12-06 13:46 846次阅读
    关于JSON<b class='flag-5'>数据库</b>

    mysql数据库基础命令

    使用以下命令: mysql -u -p 其中,username是您的MySQL用户名。执行此命令后,系统会提示您输入密码。成功输入密码后,您将登录到MySQL命令行界面。 创建数据库 创建数据
    的头像 发表于 12-06 10:56 560次阅读

    oracle数据库的基本操作

    创建表、插入数据、查询数据、更新数据和删除数据等。 首先,连接到Oracle数据库是进行任何操
    的头像 发表于 12-06 10:14 670次阅读

    oracle数据库的使用方法

    Oracle数据库是一种关系型数据库管理系统,它由Oracle公司开发和维护。它提供了安全、可靠和高性能的数据库管理解决方案,被广泛应用于企业级应用和大型数据库环境中。本文将详细介绍O
    的头像 发表于 12-06 10:10 1190次阅读

    oracle数据库alert日志作用

    Oracle数据库的alert日志是数据库引擎和实例的核心组件之一,它记录着数据库的运行状况和事件。该日志对于数据库的性能调优、问题排查和安全管理起着重要作用。本文将详尽、详实、细致地
    的头像 发表于 12-06 10:08 1210次阅读