UDS诊断(ISO14229-1) 28服务
2024-01-02 12:05:20
功能简介
28服务,即 CommunicationControl
(通信控制)服务,用来开启/关闭 ECU 报文的传输和/或接收
应用场景
常见场景:
- 存在某些特殊的测试场景,比如只希望接收或者发送对应的网络管理与应用报文;
- 绝大多数情况下应用在刷写ECU的过程中,即在预编程条件下执行28服务功能寻址便可以抑制总线应用报文与网络管理报文的发送与接收,以便减少网络总线负载,提高ECU下载效率,同时刷写结束后也要执行28服务使能对应控制报文的发送与接收,在此过程中一般会配合85服务一起使用
通信控制基本原理
28服务的通信控制过程会经过如下几个AUTOSAR BSW模块进行处理,然后完成最终的通信控制,具体步骤如下:
- Tester发送28通信控制服务请求给到Server,Server会将该诊断报文请求传递至DCM模块;
- DCM模块调用28服务对应的上层应用函数首先进行输入参数的基本校验,校验无误之后然后传递相关控制模式请求至BswM模块;
- BswM模块根据静态配置的规则来实现对应请求中的通道通信状态控制;(常见的模式控制为3X4 = 12种)
常见的12种的通信控制模式:
应用报文 | enableRxAndTx | enableRxAndDisableTx | disableRxAndEnableTx | disableRxAndTx |
---|---|---|---|---|
应用报文 | 28 00 01 | 28 01 01 | 28 02 01 | 28 03 01 |
网络管理报文 | 28 00 02 | 28 01 02 | 28 02 02 | 28 03 02 |
应用报文 + 网络管理报文 | 28 00 03 | 28 01 03 | 28 02 03 | 28 03 03 |
可以看到28诊断服务经过DCM,BswM,Com,NM完成整个上述12种通信模式的控制。其中蓝色表示的部分为最终完成通信控制的函数体。
请求和响应
1、请求
基本格式
归纳起来,诊断的request格式无非以下两种:
<SID> + <Sub-function> + <Parameter>
<SID> + <Parameter>
即有无sub-function的区别。Parameter可以是DID,可以是输入参数,可以是自定义的值,字节数视具体要求而定。
2、子功能
子功能参数定义(1字节数据):
- Bit7:抑制肯定响应消息指示位suppressPosRspMsgIndicationBit
- 0=False:需要肯定响应
- 1=True:禁止肯定响应
- Bit6-0:子功能参数值(0x00~0x7F)
3、肯定响应
基本格式:
<SID + 0x40> + <Sub-function> + <Parameter>
<SID + 0x40> + <Parameter>
要注意,第一个字节是由SID和0x40的和构成。这里的Parameter项是optional的,具体要看协议规定。
4、否定响应
基本格式:
<0x7F> + <SID> + <NRC>
看起来比较简单,格式比较固定,只要是Negative Response,第一字节就是0x7F,第二字节照抄原来的SID,第三个字节是错误响应码,指示具体错误响应的原因
报文示例
UDS中常用 NRC
参考
- https://zhuanlan.zhihu.com/p/454809936
文章来源:https://blog.csdn.net/m0_56208280/article/details/135213772
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!