Abo
  • Services:

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. Holl Flachdachbau GmbH & Co. KG Isolierungen, Fellbach bei Stuttgart
  2. Controlware GmbH, München, Ingolstadt

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

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.

 Redox OS: Wer nicht rustet, rostet
  1.  
  2. 1
  3. 2


Anzeige
Hardware-Angebote
  1. bei Alternate vorbestellen
  2. 194,90€ + Versand mit Gutschein: RYZEN20 (Bestpreis!)
  3. ab 399€

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...


Folgen Sie uns
       


BMW stellt seinen Formel-E-Rennwagen vor - Bericht

BMW setzt auf elektrischen Motorsport: Die Münchener treten als zweiter deutscher Autohersteller in der Rennserie Formel E an. BMW hat in München das Fahrzeug für die Saison 2018/19 vorgestellt.

BMW stellt seinen Formel-E-Rennwagen vor - Bericht Video aufrufen
iPhone Xs, Xs Max und Xr: Wer unterstützt die eSIM in den neuen iPhones?
iPhone Xs, Xs Max und Xr
Wer unterstützt die eSIM in den neuen iPhones?

Apples neue iPhones haben neben dem Nano-SIM-Slot eine eingebaute eSIM, womit der Konzern erstmals eine Dual-SIM-Lösung in seinen Smartphones realisiert. Die Auswahl an Netzanbietern, die eSIMs unterstützen, ist in Deutschland, Österreich und der Schweiz aber eingeschränkt - ein Überblick.
Von Tobias Költzsch

  1. Apple Das iPhone Xr macht's billiger und bunter
  2. Apple iPhone Xs und iPhone Xs Max sind bierdicht
  3. Apple iPhones sollen Stiftunterstützung erhalten

SpaceX: Milliardär will Künstler mit zum Mond nehmen
SpaceX
Milliardär will Künstler mit zum Mond nehmen

Ein japanischer Milliardär ist der mysteriöse erste Kunde von SpaceX, der um den Mond fliegen will. Er will eine Gruppe von Künstlern zu dem Flug einladen. Die Pläne für das Raumschiff stehen kurz vor der Fertigstellung.
Von Frank Wunderlich-Pfeiffer

  1. Mondwettbewerb Niemand gewinnt den Google Lunar X-Prize

iOS 12 im Test: Auch Apple will es Nutzern leichter machen
iOS 12 im Test
Auch Apple will es Nutzern leichter machen

Apple setzt mit iOS 12 weniger auf aufsehenerregende Funktionen als auf viele kleine Verbesserungen für den Alltag. Das erinnert an Google und Android 9, was nicht zwingend schlecht ist.
Ein Test von Tobias Költzsch

  1. Apple iOS 12.1 verrät neues iPad Pro
  2. Apple Siri-Kurzbefehle-App für iOS 12 verfügbar

    •  /