Feuertaufe von Rust

Zu den vielen Experimenten in Redox gehört auch die Übernahme von Konzepten aus anderen Betriebssystemen. Der aus Anwendersicht wahrscheinlich noch auffälligste Unterschied zu anderen Systemen ist das von Plan 9 übernommene System, alles über das Dateisystem abzubilden. Redox OS erweitert allerdings die Pfade im Dateisystem um sogenannte Schemas, wodurch sie zu einer URL werden. Dies ermöglicht im gesamten System auch nicht dateisystemartige Zugriffe ähnlich wie im Web.

Stellenmarkt
  1. Anwendungsberaterin / Anwendungsberater (w/m/d) SAP-Lösungsplanung und Projektkoordination
    Berliner Stadtreinigungsbetriebe (BSR), Berlin
  2. IT-Systemadministrator (m/w/d)
    Triology GmbH, Braunschweig
Detailsuche

Zum Beispiel bildet die URL file:/home/README.md den Pfad im Dateisystem zur README-Datei von Redox OS ab. Der Redox-OS-Kernel fungiert dabei als zentraler Verwalter der Schemas, jeder Treiber oder jedes Programm, das ein Schema bereitstellen möchte, muss dieses zuerst beim Kernel registrieren, der es dann für alle anderen Programme und Treiber bekanntmacht.

Klein, kleiner, mikro

Im Gegensatz zu Linux, das einen monolithischen Kernel hat, bei dem alle Treiber im Kernel-Modus laufen, setzt Redox OS auf einen Mikrokernel. Bei diesem Kernel-Design laufen nur die wichtigsten Funktionen, wie Speichermanagement, Scheduler und ein Dienst für die Kommunikation zwischen den Prozessen, im Kernel-Modus. Da alle Treiber als normale Prozesse ausgeführt werden, ergibt sich theoretisch eine höhere Stabilität und Sicherheit, weil abgestürzte Gerätetreiber vom Mikrokernel einfach neu gestartet werden können und nur ein minimaler Codeanteil auf den kompletten Speicher Zugriff hat.

In der Praxis hat sich jedoch trotz einiger Versuche mit Minix und GNU Hurd noch kein reiner Mikrokernel durchgesetzt. Ein Grund dafür dürfte die Schwierigkeit sein, einen performanten Mikrokernel zu entwickeln, da dieser prinzipbedingt sehr oft zwischen Kernel-Modus und Benutzermodus wechseln muss. Bei diesem Kontextwechsel müssen alle Register im RAM gesichert und für den neuen Modus wiederhergestellt werden, was auf den meisten Prozessoren zum Leeren der Befehlspipeline führt und somit wertvolle Taktzyklen verbraucht.

Ein (fast) sicheres Betriebssystem

Golem Akademie
  1. Webentwicklung mit React and Typescript: virtueller Fünf-Halbtage-Workshop
    6.–10. Dezember 2021, Virtuell
  2. Kubernetes Dive-in-Workshop: virtueller Zwei-Tage-Workshop
    16.–17. November 2021, Virtuell
Weitere IT-Trainings

Redox setzt überall auf Rust, vom Kernel über den auch unter Linux nutzbaren Speicher-Allocator Ralloc bis hin zu den Anwendungsprogrammen. Fast alles davon ist in Safe-Rust geschrieben, also dem Teil der Sprache, der einige typische Fehler von C und C++ vermeiden und dadurch sicher sein soll.

Im Kernel und bei der Speicherzuweisung muss jedoch prinzipbedingt des Öfteren auf Unsafe-Rust zurückgegriffen werden. Zum Beispiel lassen sich keine Gerätetreiber für Memory-Mapped-IO-Geräte schreiben, ohne mit Raw-Pointern zu arbeiten, da der Rust Compiler diese Adressen nicht überprüfen kann.

Um den so geschriebenen Unsafe-Code minimal zu halten, wird in Redox OS nach dem Motto "Race to safety" gearbeitet. Das bedeutet, dass nur der minimal mögliche Teil in Unsafe Rust geschrieben und versucht wird, so schnell wie möglich die Kontrolle über Speicherzugriffe an den Compiler zurückzugeben.

Auch bei der Speicherzuweisung wird viel Wert auf Sicherheit und Zuverlässigkeit gelegt, nicht nur in Ralloc selbst, sondern auch für darauf aufbauende Programme. So bietet Ralloc beispielsweise Debug-Optionen, um häufige Fehler in der Speicherverwaltung von Programmen aufzuzeigen wie Double-Free, Speicherlecks oder eine falsche Speicherausrichtung.

Redox wird zum modernen Unix

Aktuell befindet sich Redox OS gerade in einer großen Umbauphase, in der der Kernel neu gestaltet und entwickelt wird. Damit bekommt Redox OS eine Reihe von elementaren neuen Funktionen. Unter anderem wird mit dem neuen Kernel nicht mehr die Shell direkt gestartet, sondern wie bei modernen Unix-Plattformen ein Init-Daemon, der die Initialisierung übernimmt. Außerdem werden mit dem neuen Kernel erstmals Berechtigungen und ein Login-System implementiert.

Ein weiteres sehr interessantes neues Konzept sind sogenannte Bulk Syscalls. Sie werden eingeführt, um den Leistungsnachteil eines Mikrokernels auszugleichen. Mit Hilfe dieser Funktion können mehrere unabhängige Systemaufrufe zu einem Paket zusammengefasst werden. Mit diesem Paket führt der Kernel dann nur einmal einen Kontextwechsel aus statt für jeden Aufruf einzeln und spart somit Rechenzeit sowie das unnötige Leeren der Befehlspipeline ein. Diese Funktion hat vor allem für einen Mikrokernel ein hohes Potenzial, die Leistungsfähigkeit zu erhöhen.

Redox OS ist ganz eindeutig ein Projekt, das noch ganz am Anfang steht. Es zeigt allerdings schon jetzt eindrucksvoll die Möglichkeiten der ebenfalls noch jungen Programmiersprache Rust auf. Denn obwohl Redox OS erst etwas älter als ein Jahr alt ist, wurde bereits alles vom Kernel bis zur grafischen Oberfläche in Rust neu entwickelt. Dass in dieser kurzen Zeit kein komplett neues Betriebssystem entstehen kann, das mit den etablierten Größen wie Linux, Mac OS und Windows mithalten kann, dürfte die wenigsten verwundern. So muss man Redox OS einfach als Demonstration der Programmiersprache Rust und Experiment in der Betriebssystementwicklung sehen, was eigentlich sehr gut gelungen ist.

Bitte aktivieren Sie Javascript.
Oder nutzen Sie das Golem-pur-Angebot
und lesen Golem.de
  • ohne Werbung
  • mit ausgeschaltetem Javascript
  • mit RSS-Volltext-Feed
 Redox OS: Wer nicht rustet, rostet
  1.  
  2. 1
  3. 2


skade 13. Dez 2016

Das stimmt so nicht. Das Typsystem verhindert bestimmte Konstrukte, zum Beispiel...

SelfEsteem 13. Dez 2016

Vielen Dank soweit fuer die Infos.

Akaruso 13. Dez 2016

Mir ist dieser Widerspruch auch sofort aufgefallen und musste drüber lachen. Aber mal...

Marentis 10. Dez 2016

Danke, davor ziehe ich den Hut. Kein "wir sind besser", sondern ein klares: "wir...



Aktuell auf der Startseite von Golem.de
Apple
Notch des Macbook Pro legt sich über Inhalte

Erste Käufer des neuen Macbook Pro berichten von einer schlechten Software-Anpassung. So legt sich die Notch über Menüs oder den Mauszeiger.

Apple: Notch des Macbook Pro legt sich über Inhalte
Artikel
  1. Impfnachweise: Covid-Zertifikat für Adolf Hitler aufgetaucht
    Impfnachweise
    Covid-Zertifikat für Adolf Hitler aufgetaucht

    Im Internet sind gefälschte, aber korrekt signierte QR-Codes mit Covid-Impfnachweisen aufgetaucht.

  2. Windows XP: Das Drehbuch für Dune wurde mit MS-DOS-Programm geschrieben
    Windows XP
    Das Drehbuch für Dune wurde mit MS-DOS-Programm geschrieben

    Eric Roth verwendet seit Jahren den Movie Master für MS-DOS. Auch Dune schrieb er mit dem 30 Jahre alten Editor - und einer IBM Model M.

  3. Precobs: Polizei verzichtet auf Prognose-Software gegen Einbrecher
    Precobs
    Polizei verzichtet auf Prognose-Software gegen Einbrecher

    Nach sieben Jahren beendet die Polizei in Bayern die Nutzung einer Prognose-Software. Die Ergebnisse waren am Ende zu schlecht.

Du willst dich mit Golem.de beruflich verändern oder weiterbilden?
Zum Stellenmarkt
Zur Akademie
Zum Coaching
  • Schnäppchen, Rabatte und Top-Angebote
    Die besten Deals des Tages
    Daily Deals • Samsung 4K-Monitore & TVs günstiger (u. a. 50" QLED 2021 749€) • Seagate Exos 18TB 319€ • Alternate (u. a. Asus B550-Plus Mainboard 118€) • Switch OLED 369,99€ • Neues Xiaomi 11T 256GB 549,90€ • Ergotron LX Desk Mount Monitorhalterung 124,90€ • Speicherprodukte von Sandisk & WD [Werbung]
    •  /