シリアル・ペリフェラル・インタフェース(英: serial peripheral interface、SPI)は、コンピュータ内部で使われるデバイス同士を接続するバスである。パラレルバスに比べて接続端子数が少なくて済むシリアルバス規格の一種で、比較的低速なデータ転送を行うデバイスに利用される。 従来のデータバス、アドレスバス、制御信号による周辺デバイスの接続には、少なくとも十数本の信号を接続する必要があった。メインメモリなどの高速アクセスが要求されるデバイスを除いて、それほど速度を必要とされないデバイスに関しては、ICのパッケージも小型化できることから、省ピンで接続できる形態が望まれた。 このような背景から、いくつかのシリアルバス規格が提唱された。(I2C、SPI、MicroWireなど) SPIは省ピンで接続できるバスとして、モトローラ(現在はNXPセミコンダクターズ)が提唱した規格である。 マスター(親機)とスレーブ(子機)の間は4本の信号線で接続される。 ※MISO、MOSI、SS を CIPO(コントローラー・イン・ペリフェラル・アウト)、COPI(コントローラー・アウト・ペリフェラル・イン)、CS(チップ・セレクト)と言い換える動きもある。 1つのマスターに対し、複数のスレーブデバイスをつなぐ際に、SCK、MISO、MOSIの3線は共通にできる。SSのみスレーブごと独立であるが、マスタにスレーブを区別させる必要がなければその限りでない。スレーブデバイスが1つのみ、ないしは区別の必要がない場合にはSSを省略し3本で接続できる。その場合はスレーブ側SSをアクティブ(大抵はLOW)に常時接続とする。 SPIバスは、単一のマスタと、1つ以上のスレーブの装置で操作することができる。 もし、スレーブの装置が単一であり、スレーブの装置が許可するなら、SSピンは論理レベルをLに固定してもよい。ただし、ある種のスレーブは、SS信号の立下りのエッジを、動作開始のために必要とするので、固定できない場合がある。例えば、Maxim ほとんどのスレーブ装置は、トライ・ステートの出力状態を持ち、デバイスが選択されていない時のMISO信号は、高インピーダンス(電気的に切断された状態)になる。トライ・ステート出力を持たない装置は、外部トライ・ステート・バッファを用いない限り、SPIを他の装置と共用する事ができない。 通信を始めるために、マスタは、スレーブがサポートする周波数(典型的には数MHz)のクロック信号を生成する。その後、マスタは該当するスレーブのSS線の論理レベルを0にして、スレーブを選択する。もし、待ち時間がスレーブから要求されているなら(例えばアナログからディジタルへの変換のため)、マスタは、クロック信号を発信する前に、少なくとも要求されている時間は待たなければならない。 SPIの各クロックの間に、全二重データ送信が行われる。マスタはMOSI線上で1ビットを送信し、スレーブがそれを読み込む。その間、スレーブはMISO線上で1ビット送信し、マスタがそれを読み込む。この一連の処理は、たとえ一方通行のデータ送信を目的としていても維持される。 通常、送信には、8ビットなど、特定のワードサイズの2つのシフトレジスタが用いられる。1つはマスターに、もう1つはスレーブに配置される。これらのレジスタは、仮想的なリング状に接続される。データは通常、最上位ビットが最初にシフトアウトされます。クロックエッジで、マスターとスレーブの両方がビットをシフトアウトし、伝送ライン上で向かい合う相手に出力します。次のクロックエッジで、各レシーバーで伝送ラインからビットがサンプリングされ、シフトレジスタの新しい最下位ビットとして設定されます。レジスタの全ビットがシフトインおよびシフトアウトされた後には、マスターとスレーブはレジスタ値を交換した状態になります。さらにデータを交換する必要がある場合、シフトレジスタがリロードされ、この一連の処理が繰り返されます。送信は、任意の数のクロックサイクルにわたって継続できます。完了すると、マスターはクロック信号のLとHの切り替えを停止し、通常はスレーブの選択を解除します。 多くの場合、送信は8ビットワードで構成されます。ただし、他のワードサイズも一般的です。たとえば、テキサス・インスツルメンツのTSC2101などのタッチスクリーンコントローラまたはオーディオコーデック用の16ビットワード、または多くのデジタルからアナログへのコンバーターまたはアナログからデジタルへのコンバーターなどの12ビットワードです。 SS線を使用してアクティブにされていないバス上のすべてのスレーブは、入力クロックとMOSI信号を無視する必要があり、MISOを駆動してはならない(つまり、トライステート出力が必要です)。ですが、いくつかのデバイスは、これを実装するには外部トライステートバッファーが必要です。 クロック周波数の設定に加えて、マスターはデータに対するクロックの極性と位相も設定する必要があります。Motorola SPI Block Guideは、これら2つのオプションをそれぞれCPOLおよびCPHA(クロック極性「polarity」およびクロック位相「phase」)と命名しています。これは、ほとんどのベンダーが採用している規約です。 タイミング図を右に示します。タイミングの詳細は以下に記述される通りです。このタイミングは、マスタとスレーブの両方のデバイスに適用されます。
概要
接続仕様
SCK
シリアル・クロック
MOSI
マスター・アウト・スレーブ・イン
MISO
マスター・イン・スレーブ・アウト
SS
スレーブ・セレクト
動作仕様
データ転送典型的なハードウェア構成。2つのシフトレジスタが、チップ間のリングバッファを形成する
クロックの極性と位相A timing diagram showing clock polarity and phase. Red lines denote clock leading edges, and blue lines, trailing edges.
CPOLはクロックの極性を決定します。極性は単純なNOTゲート
CPOL=0 はアイドル状態では0で、各サイクルは1のパルスで構成される。つまり、パルスの先端エッジは立ち上がりエッジであり、末尾エッジは立ち下がりエッジである。
CPOL=1 はアイドル状態では1で、各サイクルは0のパルスで構成される。つまり、パルスの先端エッジは立ち下がりエッジであり、末尾エッジは立ち上がりエッジである。
CPHAは、データビットの、クロックパルスに対するタイミングを決定する。これら2つの間の変換は簡単ではありません。
CPHA=0 では"出力"側はデータを前のクロックサイクルの末尾のエッジで変更します。一方、"入力"側はデータを現時点のクロックサイクルの先端エッジでキャプチャします。出力側は現時点のクロックサイクルの末尾のエッジまでデータが有効になるように保持します。送信の最初のサイクルでは、先端のエッジの前に、最初のビットがMOSI線上に出力されていなければならない。
CPHA=1 では"出力"側はデータを現時点のクロックサイクルの先端のエッジで変更します。一方、"入力"側は現時点のクロックサイクルの末尾のエッジでキャプチャします。出力側は、次のクロックサイクルの先端エッジまでデータが有効になるように保持します。送信の最後のサイクルでは、スレーブ側はSS線が無効の出力になるまで、MISOを保持する。
MOSIおよびMISO信号は、通常、次のクロックでの遷移まで、半サイクルの間(受信ポイントで)安定しています。SPIマスタおよびスレーブデバイスは、その半サイクルにおいて、異なるポイントでデータをサンプリングする可能性があります。
これにより、マスターとスレーブ間の通信チャネルの柔軟性が向上します。 極性と位相の組み合わせは、多くの場合、次の規則に従って番号が付けられたモードと呼ばれます。モード番号は、2つのビットで定義され、CPOLが上位ビット、CPHAが下位ビットとして使用されます。 ModeCPOLCPHA "Microchip PIC
モード番号
0
101
210
31
SPI modeClock polarity
(CPOL/CKP)Clock phase
(CPHA)Clock edge
(CKE/NCPHA)
001
1010
2101
310
PIC32MXの場合: SPIモードは、CKP, CKEとSMP ビットから構成されます。
その他に一般に使われている表記法は、モードを(CPOL, CPHA)のような組で表記する方法です。 つまり、(0, 1) は CPOL=0 かつ CPHA=1を示します。
アーキテクチャおよび通信タイミング.mw-parser-output .ambox{border:1px solid #a2a9b1;border-left:10px solid #36c;background-color:#fbfbfb;box-sizing:border-box}.mw-parser-output .ambox+link+.ambox,.mw-parser-output .ambox+link+style+.ambox,.mw-parser-output .ambox+link+link+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+style+.ambox,.mw-parser-output .ambox+.mw-empty-elt+link+link+.ambox{margin-top:-1px}html body.mediawiki .mw-parser-output .ambox.mbox-small-left{margin:4px 1em 4px 0;overflow:hidden;width:238px;border-collapse:collapse;font-size:88%;line-height:1.25em}.mw-parser-output .ambox-speedy{border-left:10px solid #b32424;background-color:#fee7e6}.mw-parser-output .ambox-delete{border-left:10px solid #b32424}.mw-parser-output .ambox-content{border-left:10px solid #f28500}.mw-parser-output .ambox-style{border-left:10px solid #fc3}.mw-parser-output .ambox-move{border-left:10px solid #9932cc}.mw-parser-output .ambox-protection{border-left:10px solid #a2a9b1}.mw-parser-output .ambox .mbox-text{border:none;padding:0.25em 0.5em;width:100%;font-size:90%}.mw-parser-output .ambox .mbox-image{border:none;padding:2px 0 2px 0.5em;text-align:center}.mw-parser-output .ambox .mbox-imageright{border:none;padding:2px 0.5em 2px 0;text-align:center}.mw-parser-output .ambox .mbox-empty-cell{border:none;padding:0;width:1px}.mw-parser-output .ambox .mbox-image-div{width:52px}html.client-js body.skin-minerva .mw-parser-output .mbox-text-span{margin-left:23px!important}@media(min-width:720px){.mw-parser-output .ambox{margin:0 10%}}が望まれています。
⇒SafeSPIは、自動車の安全アプリケーションで使用するためのSPIを標準化している。
主な利用例
EEPROM
93C46/93C56/93C66
A/Dコンバータ、D/Aコンバータ
リアルタイムクロック
スイッチやLEDなどを接続するGPIO、ヒューマン・インタフェースデバイス
通信インタフェース
マルチメディアカード、SDメモリーカード
関連項目
バス
シリアルバス
I2C 2線式
マイクロワイヤ 3線式(3-Wire)
シフトレジスタ
1-Wire
外部リンク
⇒SPIについて(個人のwebページ)
Using the Serial Peripheral Interface to Communicate Between Multiple Microcomputers (NXP/Application Note AN991)
.mw-parser-output .asbox{position:relative;overflow:hidden}.mw-parser-output .asbox table{background:transparent}.mw-parser-output .asbox p{margin:0}.mw-parser-output .asbox p+p{margin-top:0.25em}.mw-parser-output .asbox{font-size:90%}.mw-parser-output .asbox-note{font-size:90%}.mw-parser-output .asbox .navbar{position:absolute;top:-0.90em;right:1em;display:none}