Pra*_*k P 2 service diagnostics sid protocols automotive
SID2E和SID22中是否存在整个帧长度超过7个字节的情况?
如果是,那么它将如何发送或写入数据字节?
是的,UDS 中的常见用例是对 SID 0x22(ReadDataByIdentifier) 的响应或对 SID (WriteDataByIdentifier) 的请求0x2E长度超过 7 个字节。为此,利用传输层(ISO-TP、ISO 15765-2)发送由多个 CAN 帧组成的消息。
考虑一个普通的单帧消息,其中第一个字节的高半字节是0x0ie
0x7E0 0x03 0x22 0xF1 0x90
0x7E8 0x04 0x62 0xF1 0x90 0x01
Run Code Online (Sandbox Code Playgroud)
这里的有效负载在 7 个字节以内(在请求和响应中),因此第一个字节的低半字节告诉我们确切的长度(0x03在请求中,0x04在响应中)。由于完整的消息适合单个 CAN 帧,因此不需要其他任何东西。但要发送较长的诊断消息,需要将其拆分为多个 CAN 帧(分段)。为此,需要 3 种不同类型的消息:
0x1指示该消息是第一帧。0x3指示该消息是流量控制帧。0x2表示该消息是一个连续帧。现在考虑以下场景:测试器应用程序0x7E0 0x03 0x22 0xF1 0x90作为请求发送单个帧。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
0x7E8 0x21 0x04 0x05 0x00 0x00 0x00 0x00 0x00
对于 SID 0x2E(WriteDataByIdentifier) 来说,它非常相似,只是角色颠倒了,因为通常测试仪应用程序希望在请求中发送长消息,而 ECU 将回复流量控制消息。IE
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
Run Code Online (Sandbox Code Playgroud)
如果需要多个连续帧,则第一个字节将简单地从0x21up增加到0x2F,然后再次从0x20to 开始计数。
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
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3809 次 |
| 最近记录: |