
Cet articlene cite pas suffisamment ses sources().
Si vous disposez d'ouvrages ou d'articles de référence ou si vous connaissez des sites web de qualité traitant du thème abordé ici, merci de compléter l'article en donnant lesréférences utiles à savérifiabilité et en les liant à la section « Notes et références ».
En pratique :Quelles sources sont attendues ?Comment ajouter mes sources ?Pour les articles homonymes, voirSPI.

Une liaisonSPI (pourSerial Peripheral Interface) est unbus de donnéessérie synchrone baptisé ainsi parMotorola, au milieu des années 1980 qui opère en modefull-duplex. Les circuits communiquent selon un schémamaître-esclave, où le maître contrôle la communication. Plusieurs esclaves peuvent coexister sur un même bus, dans ce cas, la sélection du destinataire se fait par une ligne dédiée entre le maître et l'esclave appelée « Slave Select (SS) ».

Le bus SPI utilise quatre signaux logiques :
Il existe d'autres noms qui sont souvent utilisés :
Dans le cas de la convention de nommage SDI/SDO, le SDO du maître doit être relié au SDI de l'esclave et vice versa. Pour éviter les confusions au moment du câblage, il est donc souvent recommandé d'utiliser les dénominations MISO-MOSI qui évitent une certaine ambiguïté ; pour exemple, unelibrairie graphique[1] écrite parAdafruit, prend en charge plusieurs références de contrôleurs d'écrans qui, malgré leurs actions similaires, ne possède pas toujours les mêmes noms de broches. Afin d'éviter ce"problème" les développeurs ont renommé les broches MISO/MOSI parRD etWR signifiant respectivementReaD (lire) etWRite (écrire) ; en conclusion, on se demande si la brocheLire permet auMicrocontroleur deLire leModuleLCD ou alors si elle permet auModule deLire et donc auMicrocontroleur de luiÉcrire une donnée ?
Une transmission SPI typique est une communication simultanée entre un maître et un esclave :
À chaque coup d'horloge le maître et l'esclave s'échangent un bit. Après huit coups d'horloges le maître a transmis un octet à l'esclave et vice versa. La vitesse de l'horloge est réglée selon des caractéristiques propres aux périphériques.

La configuration de la SPI est souvent nommée dans les documentations techniques sous forme de nombre ou decouple, où lebit de poids fort est CPOL (Clock Polarity) et lebit de poids faible CPHA (Clock Phase)
| Mode | CPOL | CPHA |
|---|---|---|
| 0 (0,0) | 0 | 0 |
| 1 (0,1) | 0 | 1 |
| 2 (1,0) | 1 | 0 |
| 3 (1,1) | 1 | 1 |
Les modes 0 et 3 sont identiques en transmission, seul change l'état de la ligne d'horloge au repos. C'est pour cette raison que de nombreux périphériques peuvent être capables de dialoguer soit en mode 0 et 3, soit en mode 1 et 2.
Il existe une grande variété d'instruments contrôlés par PC permettant d'agir comme maître et/ou analyseur de protocole SPI. Ces outils peuvent parfois être utilisés pour des protocoles série dérivant du protocole SPI, comme les protocoles sur 3 fils.
Un analyseur de protocole SPI est un outil échantillonnant un bus SPI et décodant les signaux numériques pour fournir un décodage haut niveau des transactions SPI. Ces analyseurs sont des instruments indépendants ou sont fournis comme extensions à certains modèles d'oscilloscope.
« SPI Signal Names - SparkFun Electronics », surwww.sparkfun.com(consulté le)