Benutzer-Werkzeuge

Webseiten-Werkzeuge


softwarebausteine:spi-interface
no way to compare when less than two revisions

Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen angezeigt.


Vorhergehende Überarbeitung
softwarebausteine:spi-interface [2014/09/01 12:34] (aktuell) – Externe Bearbeitung 127.0.0.1
Zeile 1: Zeile 1:
 +==== SPI-Interface ====
 +Das SPI-Modul (spiD_master.c) ist auf Port D als Master implementiert.
 +
 +=== Prinzipieller Ablauf ===
 +
 +Es können sich beliebig viele Device-Treiber als Master anmelden, da sie jeder ein eigenes Datenpaket verwalten. Auch können unterschiedliche Kontrollstrukturen, wie SPI-Mode und Clock-Frequenz parametriert werden. Während des Sendens einer SPI-Datenstroms wird kein zweites Senden zugelassen.
 +
 +Das Senden wird per Aufruf gestartet und via Interrupt-Serviceroutine fortgesetzt. Beim Start wird das definierte SlaveSelect-Signal (CE) aktiviert.
 +
 +Anschließend wird dem SPI-Modul des Prozessors das erste Datenbyte übergeben. Dadurch startet der Prozessor den Taktgenerator (CLK) mit der parametrierten Frequenz für genau dieses eine Byte, das auf der MOSI-Leitung erscheint. Zeitgleich - unter Nutzung des CLK-Signals - sendet das angeschlossene Device auf der MISO-Leitung ein entsprechenden Datum als Antwort an das SPI-Modul des Prozessors. Die CLK-Leitung ist immer nur während des Sendens auf MOSI- und MISO-Leitung aktiv.
 +
 +Ist ein Byte vollständig gesendet, erzeugt der Prozessor einen Interrupt, in dessen Service-Routine das vom Device gesendete Datum gelesen werden kann. Jetzt wird geprüft, ob noch weitere Daten zu schreiben sind. Ist das der Fall, wiederholt sich der Sende-/Empfangszyklus (Tranceiving) wie beschrieben.
 +
 +Nach dem Senden aller gewünschten Daten wird die SlaveSelect-Leitung deaktiviert. Damit ist die Operation abgeschlossen.
 +
 +Zu beachten ist, dass der Empfang von Daten aus einem Device immer nur nach Senden von Informationen erfolgt.
 +
 +=== Softwaredetails ===
 +
 +Das SPI-Modul wird initialisiert und liefert eine SPI-Master-Struktur zurück, die die einzelnen Device-Treiber verwenden müssen. Hier am Beispiel des OneControl-AddOns mit den Devices L9822 und MCP23S08:
 +{{codehilfe:oc_initspi_1.jpg|}}
 +
  
softwarebausteine/spi-interface.txt · Zuletzt geändert: 2014/09/01 12:34 von 127.0.0.1

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki