バックナンバーはこちら。
https://www.simulationroom999.com/blog/In-vehicle-network-backnumber/
はじめに
BLFに埋まっていたEthernetFrameをIPフラグメントの断片化位置に着目して解析する。
登場人物
博識フクロウのフクさん
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
2つ目のEthernetFrame
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
じゃ、2つ目のEthernetFrameを見てみよう。
// Ehternetヘッダ
0x01,0x00,0x5e,0x00,0x01,0x01,
0x10,0x6f,0x3f,0x0f,0xd6,0xdd,
0x08,0x00,
// IPヘッダ
0x45,
0x00,
0x05,0xdc,
0x6a,0xdc,
0x20,0xb9,// (フラグ=001b=継続,断片化位置=0xb9=1480[byte])
0xff,
0x11,
0x69,0x56,
0xc0,0xa8,0x0A,0x0B,
0xec,0x00,0x01,0x03,
// UDPデータの続き
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,…
data:image/s3,"s3://crabby-images/8b2a5/8b2a54ca7b298ef273ed6115e3d80a8a8fb15814" alt="太郎くん"
あー、UDPデータの続きだから、UDPヘッダは居ないのね。
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
んー、今回のフレームも継続bitが1だからまだ続くのか。
まぁUDPのデータ長が10861[byte]だったから、2,3フレームじゃ終わらないよね。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
あれ?
断片化位置=0xb9=1480[byte]
ってのはどういうこと?
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
0xb9が1480[byte]を意味するってことなんだろうけど、
どういう表現方法になってるんだ???
断片化位置の表現方法
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
なかなかいい感じに疑問にぶち当たってくれて
ホント有難い。
data:image/s3,"s3://crabby-images/f064f/f064ffda71f3aff5f681e57119a2ace7aeb72f26" alt="太郎くん"
それは皮肉なのか?!
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
いやいや、疑問に思えるってことは一個一個精査している証拠だからね。
良いことだよ。
data:image/s3,"s3://crabby-images/3f6c1/3f6c111daa4585ac9e7d31692d634ea181037952" alt="太郎くん"
わーい、褒められたー。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
(扱いやすいな。)
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
話はシンプルで、
8[byte]単位の数値ってことになってるだけ。
0xb9=185
185を8倍して
185×8=1480
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
ほー。
そんなルールなのか。
8byte境界ルール
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
あれ?
ということはIPフラグメントって必ず8byte境界で分割されるってこと?
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
冴えてるね。
その通り。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
UDPのデータ長って10861[byte]で8byte境界じゃないんだけど、
この場合どうなるんだろ???
最後のフレームは0パディングされるとか???
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
さぁどーなるんだろうねー。
data:image/s3,"s3://crabby-images/57173/57173c22a9926dc375e9aba2a2701ee383ee12f9" alt="太郎くん"
(これは次回に続くパターン!)
まとめ
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まとめだよ。
- 2フレーム目を確認。
- これもIPヘッダのフラグは継続。
- 断片化位置の値は、その値×8が実際のデータオフセット位置となる。
- よって、IPフラグメントは8byte境界の仕様が暗黙的に発生する。
バックナンバーはこちら。
コメント