バックナンバーはこちら。
https://www.simulationroom999.com/blog/diagnostic-communication-backnumber/
はじめに
ISO-TPのシミュレーションをしよう。のシリーズ。
Pythonの話がしばらく続く。
登場人物
博識フクロウのフクさん
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
python-canで頑張ればISO15765-2はできる?
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
PythonでCANの制御が出来たということは、
これを駆使すればトランスポート層とネットワーク層に相当するISO15765-2が実現できるってことで良いんだよね?
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
まぁ頑張れはできるんじゃん?
data:image/s3,"s3://crabby-images/57173/57173c22a9926dc375e9aba2a2701ee383ee12f9" alt="太郎くん"
なに?
その投げやりな感じは?
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
いや、もっと楽な方法があるんで。
data:image/s3,"s3://crabby-images/f064f/f064ffda71f3aff5f681e57119a2ace7aeb72f26" alt="太郎くん"
だったら、それを教えてよ!!
Pythonのcan-isotp
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
実はPythonのパッケージとしてISO15765-2ことISO-TPに相当するものが存在する。
その名もずばり、can-isotp。
data:image/s3,"s3://crabby-images/0f4a3/0f4a3412b4e6b4c485d018cd2f8825371049af7c" alt="太郎くん"
おー!
それを使えばOKってことか!!
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
あれ?
だったら、前回までのpytohn-canの話はなんだったの?
ISO-TP相当のパッケージがあるなら、
それでよかったのでは?
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
can-isotpの依存関係にpython-canがあるんだよ。
だからpython-canのインストール自体はどっちみち必要。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
使い方は省略しても良かったんじゃない?
data:image/s3,"s3://crabby-images/fbd59/fbd59e10d2d275de81bc55e14a87b4db7952116c" alt="フクさん"
まぁそれもアリな気はするけど、
私も現状としては手探りなんだよね。
それに、can-isotpの実験をする段階で結局はpython-canを使う予定なんで、
やはり、省略するべきではないかな?
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
まぁ、その実験ってのをやっていこうよ。
can-isotpのインストール
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
これは説明要らないかもしれないけど、pip使うだけ。
> pip install can-isotp
※プロキシ経由の場合、
> pip install --proxy=[プロキシ名]:[ポート番号] can-isotp
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
うん。
インストールできた。
can-isotpの送信テスト
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
じゃ、とりあえず一発送信テストをしてみるか。
スクリプトコードは以下になるよ。
ファイル名はisotpsndtest.pyとでもしておこうか。
import isotp
import time
from can.interfaces.vector import VectorBus
bus = VectorBus(channel=0, bitrate=500000)
addr = isotp.Address(isotp.AddressingMode.NormalFixed_29bits, source_address=0xF1, target_address=0x10)
stack = isotp.CanStack(bus, address=addr)
stack.send(b'\x01\x02\x03\x04\x05\x06\x07')
while stack.transmitting():
stack.process()
time.sleep(0.0001)
bus.shutdown()
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
can.loggerも起動しておいて、
上記スクリプトを実行
can.logger起動
> python -m can.logger -c 0 -i vector -f isotpsnd.asc
送信スクリプト実行
> python isotpsndtest.py
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
特にエラーなく終わったかな。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
そしてcan.loggerで計測したcan回線の情報。
Begin Triggerblock
0.000000 Start of measurement
0.000000 1 18DA10F1x Rx d 8 07 01 02 03 04 05 06 07
End TriggerBlock
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
7byteのメッセージだったから、
シングルフレーム送信になってるね。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
そうだね。
問題無く送信出来ていると言える。
そして、先ほどのスクリプトコードのsendメソッドの引数を変更してメッセージ長を伸ばしてみる。
stack.send(b'\x01\x02\x03\x04\x05\x06\x07')
↓
stack.send(b'\x01\x02\x03\x04\x05\x06\x07\x08\x09\x10\x01\x02\x03\x04\x05\x06\x07\x08\x09\x10\x01\x02\x03\x04\x05\x06\x07\x08\x09\x10')
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
あ、これだとマルチフレームになるやつだね。
実行してみるよ。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
あれ?
なんかエラーになった。
> python isotpsndtest.py
Reception of FlowControl timed out. Stopping transmission
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
ログを見てみよう。
Begin Triggerblock Sat
0.000000 Start of measurement
0.000000 1 18DA10F1x Rx d 8 10 1E 01 02 03 04 05 06
End TriggerBlock
data:image/s3,"s3://crabby-images/22248/222487c6a6bec90f406f108a5f7a982a5a014d15" alt="太郎くん"
これは・・・
FF(FirstFrame)しか出てないね・・・。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
だろうね。
data:image/s3,"s3://crabby-images/22248/222487c6a6bec90f406f108a5f7a982a5a014d15" alt="太郎くん"
そういえば、
FFを送信した後に送信先からFC(FlowControl)が一回送られてくるんだっけか・・・。
data:image/s3,"s3://crabby-images/2e5ef/2e5ef1a2a154cdb66566de4434a08eca0b5a22e7" alt="フクさん"
そうそう。正解。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
次回はこのFCをうまく対応してみよう。
まとめ
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まとめだよ。
- Pythonパッケージのcan-isotpでISO15765-2ことISO-TPの通信ができる。
- ただし、python-canも依存関係の都合上インストールされている必要がある。
- とりあえずSF(SingleFrame)の送信はできた。
- マルチフレーム送信はFF(FirstFrame)で止まってしまってエラー終了となった。
- FFのあとにFCを受信しないと次のシーケンスに進めないプロトコル上の仕様。
バックナンバーはこちら。
コメント