Abo
  • Services:
Anzeige
Damit Linux auf den meisten ARM-Rechnern bootet, braucht es Device Trees.
Damit Linux auf den meisten ARM-Rechnern bootet, braucht es Device Trees. (Bild: flickr.com, osde8info/CC-BY 2.0)

Linux: Kernel-Hacker wollen Yaml zur Hardware-Beschreibung nutzen

Damit Linux auf den meisten ARM-Rechnern bootet, braucht es Device Trees.
Damit Linux auf den meisten ARM-Rechnern bootet, braucht es Device Trees. (Bild: flickr.com, osde8info/CC-BY 2.0)

Device Tree Sources (DTS) werden im Linux-Kernel zum Beschreiben von Hardware genutzt und sollen sich künftig auch im Yaml-Format definieren lassen. Das bringe einige Vorteile, sagen Kernel-Entwickler.

Das Konzept Device Trees wird im Linux-Kernel genutzt, um Hardware zu beschreiben, die andernfalls nicht entdeckt würde. Die Informationen zu dieser Hardware landen dann in einer Baumstruktur. Wichtig ist das zum Beispiel für ARM-Boards. Auf dem Kernel Summit in Prag stellte nun die amerikanische Consulting-Gruppe Konsulko ihren Vorschlag zur Diskussion, das Format für diese Device Trees auf Yaml zu ändern. Das sei eine radikale Änderung, die sich aber aufgrund einige Vorteile durchaus lohnen könne.

Anzeige

Status Quo ist kompliziert

Der Umgang mit Device Trees folgt auf Linux-Systemen üblicherweise einem festen Schema. Aus den sogenannten Device Tree Source Files generiert ein Compiler dynamisch einen In-Memory Tree. Diese Baumstruktur im Speicher wird dann serialisiert ("flatten"), um ein Device Tree Blob zu erzeugen (DTB). Diese Datei landet auf dem entsprechenden Gerät selbst. Zugleich erfährt der Bootloader, wo er es findet, etwa auf einem Dateisystem oder im nichtflüchtigen Speicher.

Der Bootloader holt das DTB und reicht es entweder unverändert an das Betriebssystem weiter oder nimmt davor kleine Änderungen vor. Er modifiziert etwa die Boot-Kommandozeile. Das Betriebssystem deserialisiert das Binärobjekt wieder und verwendet dafür ein für diesen Zweck geschaffenes Interface. Es erzeugt einen weiteren In-Memory Tree, unter Umständen mit den Änderungen des Bootloaders.

Der gestartete Kernel nutzt diese Baumstruktur, die dann auch als "live-tree" bezeichnet wird. Das Betriebssystem scannt die Struktur, initialisiert und konfiguriert das zugehörige Gerät. Dazu muss es alle Nodes und Eigenschaften des aktiven Nodes kennen, weil die Zugriffsmethoden diese Informationen brauchen. Das ist aber ein Punkt, an dem potenziell Fehler ins Spiel kommen, weil etwa die Type-Informationen verloren gehen.

Wo es hakt

Das eben beschriebene Szenario gilt hauptsächlich für einzelne Maschinen. Kommt etwa ein einzelnes Image für verschiedene, aber sehr ähnliche Plattformen zum Einsatz, müssen dennoch für jede unterstützte Plattform eigene Device Tree Blobs (DTB) her. Auch wenn die Änderungen nur minimal ausfallen. FPGAs oder Expansion Boards brauchen Änderungen am Device Tree zur Laufzeit und nutzen dafür Device Tree Overlays. Die funktionieren subtil anders als die In-Memory Trees.

Damit Device Trees reibungslos funktionieren, müssen am Ende zudem verschiedene Komponenten (Compiler, Bootloader, Betriebssystem) ohne Fehler zusammenarbeiten. Dass dies nicht immer funktioniert, liegt unter anderem am bisher genutzten Format, das noch einige Ungereimtheiten in sich trägt. Werden Eigenschaften zum Beispiel als einzelne Werte oder Sequenz von Werten definiert, gehen ihre Type-Informationen verloren. Fehler im Umgang mit Device Trees fallen aber erst spät auf, nämlich wenn der Rechner versucht, das System zu booten. Dann hängt es sich in der Regel einfach auf, ohne einen Hinweis auf die Ursache zu geben.

Yaml soll helfen

Das Yaml-Format soll hier laut Konsulko Abhilfe schaffen. Es decke nicht nur alle DTS-Eigenschaften ab, sondern sei von Menschen leichter lesbar, einfach zu parsen und nachträglich zu verändern. Yaml ist außerdem weit verbreitet, ausgereift und hat deshalb eine gute Unterstützung in verschiedenen Werkzeugen. Es unterstützt Referenzen, Anker sowie Typen für Eigenschaften und begleitet den kompletten Kompiliervorgang mit nützlichen Fehlermeldungen. Auch lasse sich Yaml wie Object Files als Zwischenformat verwenden, um das finale Linken auf einen späteren Zeitpunkt zu vertagen. Nicht zuletzt sei Yaml zukunftssicher, denn die Daten lassen sich einfach in künftige Formate konvertieren.

Der Plan der Ideengeber scheint zu sein, traditionelle DTS-Dateien nach und nach durch Yaml-Dateien abzulösen. Ob alle Kernel-Entwickler mit dem Vorschlag einverstanden sind, muss sich zeigen. In dem Workshop schien es aber keine grundlegenden Vorbehalte zu geben. Json und XML als Formate lehnten die Entwickler im Workshop ab. XML sei zu sperrig. Json unterstütze Yaml nicht, während Yaml aber Json unterstützt. Offene Fragen werfen aber unter anderem noch das Diffing und die Versionierung auf.


eye home zur Startseite
Hello_World 07. Nov 2017

Das bezweifle ich. Angenommen, ich will den Inhalt des -Elements im namespace http://bar...

daydreamer42 01. Nov 2017

Beim Start: "usb 3-2: device descriptor read/64, error -71" "usb usb3-port2: unable to...

Thaodan 30. Okt 2017

Als um das Umstrukturierren. Verstehe nicht ganz wieso man das so kompliziert macht also...



Anzeige

Stellenmarkt
  1. LuK GmbH & Co. KG, Bühl
  2. Qimia GmbH, Köln
  3. Deutsche Leasing AG, Bad Homburg v. d. Höhe bei Frankfurt
  4. über Hanseatisches Personalkontor Frankfurt, Frankfurt am Main


Anzeige
Top-Angebote
  1. 129,99€ (219,98€ für zwei)
  2. 49,99€ + 5,99€ Versand (Vergleichspreis 65,87€)

Folgen Sie uns
       


  1. Facebook Messenger

    Bug lässt iPhone-Nutzer nur wenige Wörter tippen

  2. Multi-Shot-Kamera

    Hasselblad macht 400-Megapixel-Fotos mit 2,4 GByte Größe

  3. Mitsubishi

    Rückkamera identifiziert Verkehrsteilnehmer

  4. Otherside Entertainment

    Underworld Ascendant soll mehr Licht ins Dunkle bringen

  5. Meltdown und Spectre

    "Dann sind wir performancemäßig wieder am Ende der 90er"

  6. Google Play Services

    Update gegen Chromecast-WLAN-Blockade kommt bald

  7. Cars 3 und Coco in HDR

    Die ersten Pixar-Filme kommen als Ultra-HD-Blu-ray

  8. Überwachungstechnik

    EU-Parlament fordert schärfere Ausfuhrregeln

  9. Loki

    App zeigt Inhalte je nach Stimmung des Nutzers an

  10. Spielebranche

    Fox kündigt Studiokauf und Alien-MMORPG an



Haben wir etwas übersehen?

E-Mail an news@golem.de


Anzeige
Security: Das Jahr, in dem die Firmware brach
Security
Das Jahr, in dem die Firmware brach
  1. Wallet Programmierbare Kreditkarte mit ePaper, Akku und Mobilfunk
  2. Fehlalarm Falsche Raketenwarnung verunsichert Hawaii
  3. Asynchronous Ratcheting Tree Facebook demonstriert sicheren Gruppenchat für Apps

Computerforschung: Quantencomputer aus Silizium werden realistisch
Computerforschung
Quantencomputer aus Silizium werden realistisch
  1. Tangle Lake Intel zeigt 49-Qubit-Chip
  2. Die Woche im Video Alles kaputt
  3. Q# und QDK Microsoft veröffentlicht Entwicklungskit für Quantenrechner

Netzsperren: Wie Katalonien die spanische Internetzensur austrickste
Netzsperren
Wie Katalonien die spanische Internetzensur austrickste

  1. Re: Kein verstellen von Spiegeln nötig

    Jensus777 | 15:12

  2. Re: Verstehe ich nicht

    ecv | 15:11

  3. Re: Grüner Populisten Bullshit

    tunnelblick | 15:11

  4. Re: Endlich mal eine sinnvolle Kombination

    Nullmodem | 15:10

  5. Re: Weiter warten

    countzero | 15:09


  1. 13:15

  2. 13:00

  3. 12:45

  4. 12:30

  5. 12:00

  6. 11:58

  7. 11:48

  8. 11:27


  1. Themen
  2. A
  3. B
  4. C
  5. D
  6. E
  7. F
  8. G
  9. H
  10. I
  11. J
  12. K
  13. L
  14. M
  15. N
  16. O
  17. P
  18. Q
  19. R
  20. S
  21. T
  22. U
  23. V
  24. W
  25. X
  26. Y
  27. Z
  28. #
 
    •  / 
    Zum Artikel