[unmarkierte Version] | [gesichtete Version] |
Keine Bearbeitungszusammenfassung |
|||
Zeile 1: | Zeile 1: | ||
=Allgemeiner Aufbau eines Controllers= | =Allgemeiner Aufbau eines Controllers= | ||
<p> | |||
<loop_index>Aufbau, Controller|Controller, Aufbau</loop_index> | |||
Genau wie die CPU besitzt auch der Controller eines Peripheriegeräts verschiedene Register. Üblich sind: | |||
* <loop_index>Steuerregister, Controller|Controller, Steuerregister</loop_index>'''Steuerregister'''<br />Hier kann über das Bussystem ein Steuerbefehl an den Controller übergeben werden (ähnlich dem Befehlsregister auf der CPU). | |||
* <loop_index>Datenregister, Controller|Controller, Datenregister</loop_index>'''Datenregister'''<br />Hier kann ein Datenwort hinterlegt, oder ein vom Peripheriegerät über den Controller bereitgestelltes Datenwort ausgelesen werden. | |||
* <loop_index>Zustandsregister, Controller|Controller, Zustandsregister</loop_index>'''Zustandsregister'''<br />Hier hinterlegt der Controller jeweils Werte, die über den aktuellen Zustand des Controllers (oder Peripheriegeräts) Auskunft geben. | |||
</p> | |||
<br /> | |||
<p> | |||
<loop_index>Ready, Controller|Controller, Ready|Busy, Controller|Controller, Busy|Read Error, Controller|Controller, Read Error|Write Error, Controller|Controller, Write Error|Out of paper, Controller|Controller, Out of paper</loop_index> | |||
<loop_area type="annotation">In dem (oder den) Zustandsregister(n) können verschiedene Zustände angezeigt werden, beispielsweise | |||
* '''Ready''': Controller ist bereit für den nächsten Steuerbefehl. | |||
* '''Busy''': Controller ist noch mit der Ausführung des aktuellen Steuerbefehls beschäftigt. | |||
* '''Read Error''': Das angeforderte Datenwort kann nicht vom Peripheriegerät gelesen werden. | |||
* '''Write Error''': Das im Datenregister befindliche Datenwort kann nicht auf dem Peripheriegerät gespeichert werden. | |||
* '''Out of paper''': Der an diesen Controller angeschlossene Drucker hat kein Papier mehr. | |||
* etc. | |||
</loop_area> | |||
</p> | |||
<br /> | |||
<p> | |||
Die folgende Abbildung zeigt den allgemeinen Aufbau eines Controllers. Dabei ist von jeder Registerart nur ein einziges eingezeichnet, es ist jedoch auch denkbar, dass der Controller über mehrere Register je Art verfügt. | |||
</p> | |||
<p> | |||
<loop_figure title="Allgemeiner Aufbau eines Controllers" description="" copyright="CC-BY" index=true show_copyright=true>[[Datei:Controller1.jpg|700px]]</loop_figure> | |||
</p> | |||
<br /> | |||
<p> | |||
Die bislang betrachtete Menge an Peripheriegeräten verfügt jeweils über einen eigenen Controller, wobei jeder Controller mit dem entsprechenden <loop_index>Registersatz</loop_index>Registersatz ausgestattet ist: | |||
</p> | |||
<p> | |||
<loop_figure title="Verschiedene Controller mit eigenen Registersätzen" description="" copyright="CC-BY" index=true show_copyright=true>[[Datei:Controller3.jpg|700px]]</loop_figure> | |||
</p> | |||
<br /> | |||
== Aufgabe 1 == | |||
<p> | |||
<loop_area type="task"> | |||
<loop_task title="Lesen und/oder schreiben?"> | |||
<p> | |||
Auf das Datenregister eines Controllers kann die CPU sowohl lesend, als auch schreibend zugreifen. Wie verhält es sich aber beim Steuer- und beim Zustandsregister? Ist der Zugriff hier ''nur lesend'', ''nur schreibend'' oder ''lesend und schreibend'' möglich? | |||
</p> | |||
</loop_task> | |||
</loop_area> | |||
</p> | |||
<div class="autoit_do_not_print"> | |||
<br /> | |||
<hr /> | |||
<sub>Diese Seite steht unter der [http://creativecommons.org/licenses/by/3.0/deed.de Creative Commons Namensnennung 3.0 Unported Lizenz] [http://creativecommons.org/licenses/by/3.0/deed.de http://i.creativecommons.org/l/by/3.0/80x15.png] | |||
</sub> | |||
</div> |
Genau wie die CPU besitzt auch der Controller eines Peripheriegeräts verschiedene Register. Üblich sind:
In dem (oder den) Zustandsregister(n) können verschiedene Zustände angezeigt werden, beispielsweise
Die folgende Abbildung zeigt den allgemeinen Aufbau eines Controllers. Dabei ist von jeder Registerart nur ein einziges eingezeichnet, es ist jedoch auch denkbar, dass der Controller über mehrere Register je Art verfügt.
Die bislang betrachtete Menge an Peripheriegeräten verfügt jeweils über einen eigenen Controller, wobei jeder Controller mit dem entsprechenden Registersatz ausgestattet ist:
Auf das Datenregister eines Controllers kann die CPU sowohl lesend, als auch schreibend zugreifen. Wie verhält es sich aber beim Steuer- und beim Zustandsregister? Ist der Zugriff hier nur lesend, nur schreibend oder lesend und schreibend möglich?
Diese Seite steht unter der Creative Commons Namensnennung 3.0 Unported Lizenz http://i.creativecommons.org/l/by/3.0/80x15.png