バックナンバーはこちら。
https://www.simulationroom999.com/blog/diagnostic-communication-backnumber/
はじめに
ISO14229ことUDSの話。
PositiveResponseとNegativeResponseについて
登場人物
博識フクロウのフクさん
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
PositiveResponseとNegativeResponse
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
UDSのレスポンスのタイプは以下がある。
- PositiveResponse
- NegativeResponse
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
前回、そういうこと言ってたね。
PositiveResponse
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まずPositiveResponseの方だけど、
これはまぁ特に説明は無くて、通常の応答の事を指す。
data:image/s3,"s3://crabby-images/57173/57173c22a9926dc375e9aba2a2701ee383ee12f9" alt="太郎くん"
いきなり通常と言われても
何をもって通常と判断するかわからないんだけど。
data:image/s3,"s3://crabby-images/8792e/8792ef94c226c7b43a602553c630f8d63eae03cf" alt="フクさん"
なるほど!
言われてみればそうだね。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
前回も言ったけど、以下のルールがあるよ。
- レスポンスメッセージの先頭1byteは必ずResponse SID
- Response SIDはRequest SIDに0x40とORを取ったものをセットする。
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
前回はRequest SIDが0x10だったから0x40でORを取って0x50になってたね。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
これがポジティブレスポンス
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
え?これだけ?
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
これだけ。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
厳密には各サービスによって必須なレスポンスパラメータが合ったりするんで、
共通するルールとしてはこれだけだね。
data:image/s3,"s3://crabby-images/0f4a3/0f4a3412b4e6b4c485d018cd2f8825371049af7c" alt="太郎くん"
ほー。
NegativeResponse
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
次はNegativeResponse。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
これはどういうルールになるの?
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
こんな感じになるよ。
Position | Parameter Name | Value |
---|---|---|
1 | Negative Response SID | 0x7F |
2 | <Service Name> Request SID | 0x00 – 0xFF |
3 | responseCode | 0x00 – 0xFF |
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
先頭のNegative Response SIDは0x7F固定なんだ。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
あれ?
ポジティブレスポンスのルールで「Request SIDに0x40とORを取ったもの」ってのがあったけど、
あれと衝突しないのかな?
例えば、Request SIDが0x3Fのサービスとか?
data:image/s3,"s3://crabby-images/8792e/8792ef94c226c7b43a602553c630f8d63eae03cf" alt="フクさん"
中々鋭いね。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
でも、ご心配なく。
0x3Fのサービスは無いよ。
ISO14229-1にそう明記されてる。
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
じゃー問題無いね。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
<Service Name> Request SIDは
例えば、前回の0x10だったら、ここにも0x10ってなる感じ?
data:image/s3,"s3://crabby-images/2e5ef/2e5ef1a2a154cdb66566de4434a08eca0b5a22e7" alt="フクさん"
その通り。いいね。
data:image/s3,"s3://crabby-images/57173/57173c22a9926dc375e9aba2a2701ee383ee12f9" alt="太郎くん"
最後のresponseCodeはちょっと分からないなー。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
これはまだ全く教えてないからねー。
代表的な物を表にしたよ。
NRC | Description | Detail |
---|---|---|
0x12 | sub-functionNotSupported | サポートされていないsub-function要求された。 |
0x13 | incorrectMessageLengthOrInvalidFormat | リクエストメッセージ長は間違っている。 |
0x22 | conditionsNotCorrect | 条件があっていない。 |
0x31 | requestOutOfRange | パラメータが想定の範囲外。 |
0x33 | securityAccessDenied | セキュリティロックが掛かっている。 |
0x78 | requestCorrectlyReceived-ResponsePending | レスポンス保留。P2*時間待つこと |
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
結構番号が飛び地だけど、実際はすべての番号が定義されてる感じなのかな?
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
すべての番号が定義ってことはないけど
確かに今回の代表例から見たらもっと大量にある。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
requestCorrectlyReceived-ResponsePendingって、
もしかして前回言ってたP2*時間がどうのってやつ?
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
そうそう。
これは次回説明するよ。
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
うーん、まとめるとNegativeResponseでこんな感じになるのか?
0x7F 0x10 0x12
SID 0x10に於いて、sub-functionがサポート外だった場合。
data:image/s3,"s3://crabby-images/2e5ef/2e5ef1a2a154cdb66566de4434a08eca0b5a22e7" alt="フクさん"
大正解。
data:image/s3,"s3://crabby-images/24837/248372c77b96f9cc4b042154784ce48c8fe1e345" alt="太郎くん"
よっしゃ!
分かってしまえばどうってことは無い!
まとめ
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まとめだよ。
- PositiveResponseの説明。
- Response SIDはRequest SIDに0x40とORを取ったものをセットする。
- NegativeResponseの説明。
- 0x7F 0x10 0x12のような感じ。
- ResponsePendingのような特殊なものは次回説明。
バックナンバーはこちら。
コメント