バックナンバーはこちら。
https://www.simulationroom999.com/blog/diagnostic-communication-backnumber/
はじめに
ISO14229ことUDSの話。
TesterPresentサービスのメッセージについて。
登場人物
博識フクロウのフクさん
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt=""
イラストACにて公開の「kino_k」さんのイラストを使用しています。
https://www.ac-illust.com/main/profile.php?id=iKciwKA9&area=1
エンジニア歴8年の太郎くん
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt=""
イラストACにて公開の「しのみ」さんのイラストを使用しています。
https://www.ac-illust.com/main/profile.php?id=uCKphAW2&area=1
TesterPresentサービスのリクエストメッセージ
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
じゃ、TesterPresentサービスのメッセージを見てみよう。
data:image/s3,"s3://crabby-images/24837/248372c77b96f9cc4b042154784ce48c8fe1e345" alt="太郎くん"
見てみよう!
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
リクエストメッセージはこんなん。
Position | Parameter Name | Value |
---|---|---|
1 | TesterPresent Request SID | 0x3E |
2 | sub-function = [ zeroSubFunction ] | 0x00,0x80 |
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
ん?
sub-functionは0x00か0x80?
なんかずいぶん間が飛んでるね。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
あー。
0x80はsuppressPosRspMsgIndicationBitが立ってる状態だね。
suppressPosRspMsgIndicationBit
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
suppressPosRspMsgIndicationBit?
なにそれ?
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
suppressPosRspMsgIndicationBitは別にTesterPresentサービス限定の仕様ではない。
sub-functionのパラメータを持っているサービス全てに適用される仕様。
効能は、PositiveResponse応答抑制。
sub-functionの最上位bitに位置するんで、通常のsub-functionと0x80でORを取ったものになるね。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
PositiveResponse応答抑制?
なんでそんなのがあるの?
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
TesterPresentサービスとかだと割と顕著なんだけど、
「メンドクサイから応答しなくていいよ」
って感じ。
data:image/s3,"s3://crabby-images/57173/57173c22a9926dc375e9aba2a2701ee383ee12f9" alt="太郎くん"
メンドクサイって・・・。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
TesterPresentサービス自体は特に処理とか無くて、
S3時間の維持だけのために使われることが多い。
data:image/s3,"s3://crabby-images/b09d6/b09d62a6515b535a90d9c9cbf0462f374e32a747" alt="フクさん"
例えば、CANネットワークに8台のECUが居て、
機能アドレスでTesterPresentを送るとどうなると思う?
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
全員が応答してくる?
data:image/s3,"s3://crabby-images/b09d6/b09d62a6515b535a90d9c9cbf0462f374e32a747" alt="フクさん"
suppressPosRspMsgIndicationBitがあると?
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
全員応答してこない!
data:image/s3,"s3://crabby-images/0f4a3/0f4a3412b4e6b4c485d018cd2f8825371049af7c" alt="太郎くん"
なるほど!
S3時間の延長だけを考えると
機能アドレス且つsuppressPosRspMsgIndicationBit付きが効率が良いのか!
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
そういうこと。
TesterPresentサービスだと無いけど、
他のサービスでsuppressPosRspMsgIndicationBitを付けた場合、
NegativeResponseは普通に応答が来る。
あと、NRC$78も返信して、そのあとのPositiveResponseも返す。
って仕様になってる。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
あれ?
PositiveResponseは返さないんじゃないの?
data:image/s3,"s3://crabby-images/fbd59/fbd59e10d2d275de81bc55e14a87b4db7952116c" alt="フクさん"
NRC$78を一回返してるからね。
PositiveResponseを返さないとタイムアウトとしてハンドリングされるんで、
この場合はPositiveResponse返す必要がある。
って感じ。
data:image/s3,"s3://crabby-images/0f4a3/0f4a3412b4e6b4c485d018cd2f8825371049af7c" alt="太郎くん"
なるほど。
言われてみればそうかも。
TesterPresentサービスのレスポンスメッセージ
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
そして、レスポンスメッセージはこう
Position | Parameter Name | Value |
---|---|---|
1 | TesterPresent Response SID | 0x7E |
2 | sub-function = [ zeroSubFunction ] | 0x00 |
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
これは予想付いてたな。
sub-functionで0x80はsuppressPosRspMsgIndicationBitの場合で、
TesterPresentの場合はNegativeResponseも無い想定だからだね。
data:image/s3,"s3://crabby-images/2e5ef/2e5ef1a2a154cdb66566de4434a08eca0b5a22e7" alt="フクさん"
正解!
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
TesterPresentサービスについてはこんなもんかな。
まとめ
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まとめだよ。
- TesterPresentサービスのメッセージについて説明。
- suppressPosRspMsgIndicationBitについて説明。
- PositiveResponse抑制。
- NegativeResponseは返す。
- NRC$78後のPositiveResponseも返す。
バックナンバーはこちら。
コメント