- IEEE 1275
-
Open Firmware (kurz OFW oder OF – genormt in IEEE-1275) ist ein offener, plattformunabhängiger Standard, der eine Bootumgebung für Betriebssysteme von Rechnersystemen definiert (offene Firmware für den Bootprozess).
Die Funktionalität geht dabei weit über ein typisches PC-BIOS hinaus. Zum Einsatz kommt IEEE-1275 jedoch meist außerhalb der x86-Welt. Im PC-Bereich mit x86-kompatiblen CPUs konnte sich OFW trotz ihrer Vorteile bislang nicht durchsetzen – dort besteht die Firmware (BIOS, in Zukunft EFI) seit jeher meist aus reinem x86-Maschinencode und ist daher auch nicht portabel.
Inhaltsverzeichnis
Funktionsweise
Open Firmware bietet eine Kommandozeile als optionalen Bootprompt und unterstützt programmierbare Kommandos in der hardwareunabhängigen, assemblernahen Programmiersprache Forth. Über Open Firmware können Hersteller von Zusatzgeräten (z. B. Grafikkarten) deren Einbindung so gestalten, dass sie unabhängig von der CPU sind. Dazu definiert Open Firmware eine Forth-Variante, die in einem Zwischencode-Format namens FCode auf einem Festwertspeicher auf dem Zusatzgerät gespeichert werden kann.
OFW definiert eine Umgebung, die unabhängig von verwendetem Prozessor und System als eine Art Kernel fungiert (siehe virtuelle Maschine). Einsteckbare Geräte können dabei eigene Routinen beim System anmelden, die prinzipiell auf jeder Open Firmware-Plattform ausgeführt werden können. Der Zugriff auf Geräte im System ist über eine Laufzeitumgebung möglich. Dort werden die Geräte in einer Baumstruktur verwaltet, deren Einträge eine dynamische Zahl von Attributen haben.
Der Zugriff auf die Geräte ist auch dem geladenen Betriebssystem möglich, sofern das Client Interface in der Open Firmware implementiert wurde. Da die Open Firmware-Umgebung enge Grenzen setzt, in denen FCode-Treiber zu arbeiten haben, sind diese oft nicht sehr performant und unterstützen nur die Funktionen der Hardware, die zum Start benötigt werden. Aus diesem Grund übernimmt das Betriebssystem in aller Regel relativ schnell selbst die Kontrolle. Die Terminalkonsole von Solaris auf der SPARC-Architektur greift zum Beispiel auf den Grafikkartentreiber in der Open Firmware zurück, wodurch die Konsole sehr langsam ist.
Des weiteren können rudimentäre Diagnosefunktionen vor dem eigentlichen Systemstart ausgeführt werden, oder es können verschiedene Einstellungen (Environment-Variablen) geändert werden – vergleichbar mit einem Linux-Bootprompt, jedoch wesentlich flexibler.
Geschichte
Die originale Spezifikation der OpenFirmware stammt von Sun Microsystems.
Open Firmware wurde zunächst in Sun Microsystems' SPARC-Architektur als OpenBootProm verwendet, und dann später mit der Einführung der PowerPC-Architektur für Apples Macintosh-Rechner übernommen.
Im PC-Bereich mit x86-kompatiblen CPUs konnte sich OFW bislang nicht durchsetzen, dort geht der Trend in Richtung EFI. Daher setzt seit dem Umstieg auf die Intel-Architektur auch Apple anstelle der Open Firmware nun Intels BIOS-Nachfolger EFI ein.
Einsatzgebiete
Open Firmware wird heutzutage auf einer Vielzahl von Plattformen, vom Einzelplatz- bis zum Großrechnersystem verwendet. Zum Einsatz kommt Open Firmware z. B. bei sämtlichen Systemen von Sun Microsystems – aber auch auf CHRP-Rechnern von Apple (PowerMacs) oder von Drittherstellern, die auf der PowerPC-Architektur basieren. Beispielsweise benutzen die Pegasos-I und II Rechner sowie die Efika-Mainboards der Firma Genesi eine Open Firmware.
Weblinks
- http://www.openfirmware.org – IEEE-1275 Standard: Open Firmware Homepage
- Drei Artikel über Open Firmware von der Apple Developer Connection
- http://www.forth.org – Forth: die Programmiersprache der OFW
- Eine Referenz
Open Source
- http://www.openbios.info – OpenBIOS eine Open-Source-Implementation von OFW
- http://sourceforge.net/projects/u-boot Das U-Boot – Universal Bootloader
Wikimedia Foundation.