2.3.3 Limitregister zum Speicherschutz

[gesichtete Version][gesichtete Version]
Keine Bearbeitungszusammenfassung
Keine Bearbeitungszusammenfassung
Zeile 5: Zeile 5:
Insbesondere muss sichergestellt werden, dass ein Prozess nicht auf Speicherzellen im Hauptspeicher zugreift, die einem anderen Prozess zugeordnet sind. Dies kann durch Einsatz des {{#index:Limitregister|Speicherschutz}}Limitregisters erreicht werden.
Insbesondere muss sichergestellt werden, dass ein Prozess nicht auf Speicherzellen im Hauptspeicher zugreift, die einem anderen Prozess zugeordnet sind. Dies kann durch Einsatz des {{#index:Limitregister|Speicherschutz}}Limitregisters erreicht werden.
</p>
</p>
<p>
<p>
<loop_area type="definition">'''Definition: Limitregister'''
<br />
==== Definition: Limitregister ====
<loop_area type="definition">
<p>
<p>
Das '''Limitregister''' befindet sich auf der CPU. Es enthält als Wert die Größe des '''zusammenhängenden''' Speicherbereichs des aktiven Prozesses im Hauptspeicher.
Das '''Limitregister''' befindet sich auf der CPU. Es enthält als Wert die Größe des '''zusammenhängenden''' Speicherbereichs des aktiven Prozesses im Hauptspeicher.
Zeile 37: Zeile 40:
Auf die genauen Abläufe beim Auftreten von Interrupts geht das Kapitel [[Interrupt-Controller]] näher ein.
Auf die genauen Abläufe beim Auftreten von Interrupts geht das Kapitel [[Interrupt-Controller]] näher ein.
</p>
</p>
<p>
<p>
<br />
==== Aufgabe 1 ====
<loop_area type="task">
<loop_area type="task">
<loop_task title="Aufgabe 1">
<loop_task title="Zugriff auf freien Speicherbereich">
<p>
<p>
Im Video wird erläutert, wie mit Hilfe des Limitregisters verhindert wird, dass Prozess A auf einen Speicherbereich zugreift, der Prozess B zugeordnet ist. Prozess A wird bei auftreten dieser Speicherschutzverletzung beendet.
Im Video wird erläutert, wie mit Hilfe des Limitregisters verhindert wird, dass Prozess A auf einen Speicherbereich zugreift, der Prozess B zugeordnet ist. Prozess A wird bei auftreten dieser Speicherschutzverletzung beendet.

Version vom 14. Oktober 2013, 15:52 Uhr

Dass es nun möglich ist, mehrere Prozesse gleichzeitig im Hauptspeicher zu verwalten, bringt nicht nur Vorteile. Es erfordert auch eine Berücksichtigung von Sicherheitsbelangen.

Insbesondere muss sichergestellt werden, dass ein Prozess nicht auf Speicherzellen im Hauptspeicher zugreift, die einem anderen Prozess zugeordnet sind. Dies kann durch Einsatz des {{#index:Limitregister|Speicherschutz}}Limitregisters erreicht werden.


Definition: Limitregister

Definition

Das Limitregister befindet sich auf der CPU. Es enthält als Wert die Größe des zusammenhängenden Speicherbereichs des aktiven Prozesses im Hauptspeicher.

Wie aus folgender Abbildung ersichtlich, ist das Limitregister auf der CPU angesiedelt. In vorangegangenen Bildern zur CPU war an dieser Stelle das Register R2 angesiedelt. Man kann sich gerne vorstellen, dass das Register R2 weiterhin auf der CPU existiert, nur eben aus Platzgründen nicht mehr eingezeichnet ist.

Cpu12-limit.jpg

Das folgende Video erläutert die Zusammenhänge:

video

Im Video wird erläutert, dass das Steuerwerk mit Hilfe des Limitregisters in die Lage versetzt wird, Zugriffe auf fremde Speicherbereiche zu bemerken, bevor sie vollzogen werden. Als Reaktion darauf erzeugt das Steuerwerk einen Interrupt, der die Ausführung des aktuellen Prozesses abbricht.

Auf die genauen Abläufe beim Auftreten von Interrupts geht das Kapitel Interrupt-Controller näher ein.


Aufgabe 1

Aufgabe

Im Video wird erläutert, wie mit Hilfe des Limitregisters verhindert wird, dass Prozess A auf einen Speicherbereich zugreift, der Prozess B zugeordnet ist. Prozess A wird bei auftreten dieser Speicherschutzverletzung beendet.

Wie sollte reagiert werden, wenn Prozess A stattdessen auf den noch freien Bereich im Hauptspeicher zugreift? Den Bereich also, der keinem Prozess zugeordnet ist?



Diese Seite steht unter der Creative Commons Namensnennung 3.0 Unported Lizenz http://i.creativecommons.org/l/by/3.0/80x15.png