Service UDS SID2E&;SID22
在SID2E和SID22中,是否存在整个帧长度超过7字节的情况Service UDS SID2E&;SID22,service,protocols,diagnostics,sid,automotive,Service,Protocols,Diagnostics,Sid,Automotive,在SID2E和SID22中,是否存在整个帧长度超过7字节的情况 如果是,那么它将如何发送或写入数据字节?是,在UDS中,对SID0x22(ReadDataByIdentifier)的响应或对SID0x2E(WriteDataByIdentifier)的请求长度超过7字节是一种常见的用例。为此,需要一条由多个CAN帧组成的消息 已发送,使用传输层() 考虑一个普通的单帧消息,其中第一个字节的高半字节是0x0,即 0x7E0 0x03 0x22 0xF1 0x90 0x7E8 0x04 0x
如果是,那么它将如何发送或写入数据字节?是,在UDS中,对SID
0x22
(ReadDataByIdentifier)的响应或对SID0x2E
(WriteDataByIdentifier)的请求长度超过7字节是一种常见的用例。为此,需要一条由多个CAN帧组成的消息
已发送,使用传输层()
考虑一个普通的单帧消息,其中第一个字节的高半字节是0x0
,即
0x7E0 0x03 0x22 0xF1 0x90
0x7E8 0x04 0x62 0xF1 0x90 0x01
这里的有效负载在7个字节内(请求和响应中),因此第一个字节的低半字节告诉我们确切的长度(0x03
在请求中,0x04
在响应中)。由于完整的信息适合于单个CAN框架,因此不需要其他信息。但要发送更长的诊断信息,需要在多个CAN帧之间进行分割(分段)。为此,需要3种不同类型的消息:
0x1
第一个字节表示消息是第一帧0x3
表示该消息为
流量控制框架0x2
,表示消息为
连续的帧现在考虑以下场景:测试器应用程序发送单个帧<代码> 0x7e00x03 0x220xf10x90作为请求。ECU可能希望向测试仪应用程序发送响应
0x62 0xF1 0x90 0x01 0x02 0x03 0x04 0x05
(8字节有效负载)
0x7E8 0x10 0x08 0x62 0xF1 0x90 0x01 0x02 0x03
0x7E0 0x30 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00
0x7E8 0x21 0x04 0x05 0x00 0x00 0x00 0x00 0x00
对于SID0x2E
(WriteDataByIdentifier),它将非常类似,只是角色颠倒,因为测试仪应用程序通常希望在请求中发送长消息,ECU将使用流量控制消息进行回复。i、 e
0x7E0 0x10 0x08 0x2E 0xF1 0x90 0x01 0x02 0x03
0x7E8 0x30 0x00 0x00 0x00 0x00 0x00 0x00 0x00
0x7E0 0x21 0x04 0x05 0x00 0x00 0x00 0x00 0x00
0x7E8 0x03 0x6E 0xF1 0x90 0x00 0x00 0x00 0x00
如果需要多个连续帧,第一个字节将从0x21
增加到0x2F
,然后从0x20
重新开始计数
0x7E0 0x10 0x76 0x2E 0xF1 0x90 0x01 0x02 0x03
0x7E8 0x30 0x00 0x00 0x00 0x00 0x00 0x00 0x00
0x7E0 0x21 0x04 0x05 0x06 0x07 0x08 0x09 0x0A
0x7E0 0x22 0x0B 0x0C 0x0D 0x0E 0x0F 0x10 0x11
...
0x7E0 0x2F 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF
0x7E0 0x20 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF 0xFF