バックナンバーはこちら。
https://www.simulationroom999.com/blog/In-vehicle-external-storage-backnumber/
はじめに
SDカードの通信について。
登場人物
博識フクロウのフクさん
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
SDカードの通信種別
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
じゃ、そろそろSDカードの通信の具体的な話に入っていこう。
data:image/s3,"s3://crabby-images/24837/248372c77b96f9cc4b042154784ce48c8fe1e345" alt="太郎くん"
おー!
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
これはSPIモード、SDモード共通なんだけど、SDカードとの通信は大きく以下の種類に分けられる。
- No data Operation
- (Multiple) Block Read Operation
- (Multiple) Block Write Operation
ま、commandの大半がNo data Operationなんだけどねー。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
察するにNo data Operation以外の2つは読み書きする時だけ使用するものってことかな?
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
その認識でOKだね。
よって、頻度としてはNo data Operation以外のこの2つが圧倒的に多いともいえる。
SDカードのNo data Operation(SPIモード)
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まずはSPIモードのNo data Operationを見てみよう。
data:image/s3,"s3://crabby-images/5aea0/5aea03d99584a84f21c0d61ea528f9fdef52a1db" alt="SDカードNo data Operation(SPIモード)"
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
command送ってresponseを受け取るって感じだね。
commnadについて
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
commandのフォーマットは以下になる。
Bit position | 47 | 46 | 45:40 | 39:08 | 7:1 | 0 |
Width(bits) | 1 | 1 | 6 | 32 | 7 | 1 |
Value | ‘0’ | ‘1’ | x | x | x | ‘1’ |
Description | start bit | transmission bit | command index | argument | CRC7 | end bit |
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
6byte固定って感じなんだねー。
busyについて
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
さっきのcommandとresponseの画像の中の2つ目のやり取りのbusyってのは?
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
responseにも種類があって、
busy付きのresponseってのがあるんだよ。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
まぁもう少し説明すると、レスポンスもバリエーションがある。
SPIモードに限定すると以下が存在する。
- R1
- R1b(STOP_TRANSMISSION,SET_WRITE_PROT,CLR_WRITE_PROT,ERASEのresponse)
- R2(SEND_STATUSのresponse)
- R3(READ_OCRのresponse)
- R7(SEND_IF_CONDのresponse)
busy付きがR1bってやつになる。
data:image/s3,"s3://crabby-images/57173/57173c22a9926dc375e9aba2a2701ee383ee12f9" alt="太郎くん"
なんかややこしくなってきたぞ。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
R1、R1b以外は特定commandに対するresponseなんで、一旦説明は省略して、
R1、R1bに特化して説明しよう。
SDカード SPIモード R1フォーマット
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
ほとんどのcommandに対するresponseになるのがR1。
フォーマットは以下になる。
data:image/s3,"s3://crabby-images/ab193/ab193f1ff782e73b701047a2f59202ee0f7f6076" alt="SDカード SPIモード R1フォーマット"
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
内容的にはエラー通知って感じかなー。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
そうだね。
in idle stateはエラーってわけでは無いが、
電源の瞬断等で初期状態に戻った場合の判定で使うことが多いから
まぁエラー的な意味合いにはなるかな。
SDカード SPIモード R1bフォーマット
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
次はR1bフォーマットだけど、
response自体はR1と同一。
違いは、R1の後にbusy指定が付く。
data:image/s3,"s3://crabby-images/294f2/294f2f45eed21736006281f54fe58d6f81d99826" alt="太郎くん"
そのbusy指定ってのはどうなものなの?
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
0値が出力され続ける。
data:image/s3,"s3://crabby-images/0f4a3/0f4a3412b4e6b4c485d018cd2f8825371049af7c" alt="太郎くん"
ほう。
ということは0値が受信され続けている間はSDカード側はbusyってことになるのか。
data:image/s3,"s3://crabby-images/e3d65/e3d65e93595459b9f1054227fd7a788442a20b1b" alt="フクさん"
そういうこと。
data:image/s3,"s3://crabby-images/ebc9c/ebc9ca6dafb1ae82606cceaa3c40e0f2d33a96fd" alt="太郎くん"
responseについてはなんとなくわかった気がするよ。
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まぁ他のresponseは必要に応じて説明だね。
まとめ
data:image/s3,"s3://crabby-images/373a5/373a5af068fed54e9e584c2fa60af90b1d08e098" alt="フクさん"
まとめだよ。
- SDカードの通信の種類は大きく3種類。
- No data Operationはcommandとresponseだけで成り立つもの。
- responseパターンはR1,R1b,R2,R3,R7の5種類。
- R1bがbusy付きresponse。
- busyはresponseの直後に0値出力が続いている間。
バックナンバーはこちら。
コメント