XNU
XNU ist ein Kernel, der in dem freien Basisbetriebssystem (core operating system) Darwin verwendet wird. Darwin bildet die Grundlage von Apples Betriebssystem-Varianten macOS, iOS, iPadOS, tvOS und watchOS. XNU wird als freie Software unter Version 2 der Apple Public Source License (APSL) veröffentlicht. Seinen Ursprung hat der Kernel u. a. im Betriebssystem NeXTStep. NamensgebungXNU leitet sich einerseits von X is Not Unix[2] ab, in Anlehnung an GNU ebenfalls ein Akronym. Andererseits steht es vermutlich auch für Mac OS X NuKernel.[3] Der NuKernel war ein Mach-3.0-Kernel für das Projekt Copland, der zwischen 1994 und 1997 komplett neu geschrieben worden war. Copland sollte der Nachfolger des veralteten System 7 werden, doch es gelang Apple nicht, den Kernel zu stabilisieren. Die einzigen je veröffentlichten Entwicklerversionen von Copland zeigten ständige Abstürze aufgrund des instabilen NuKernel. Erst mit OPENSTEP der Firma NeXT hatte Apple einen stabilen Mach-2.5-Kernel in der Hand, auf dessen Grundlage ein stabiler Mach-3.0-Kernel für das Nachfolgebetriebssystem von Mac OS entwickelt werden konnte. Kernel-DesignXNU ist ein hybrider Kernel, bestehend aus Teilen des Mach3-Microkernels OSF MK und des monolithischen FreeBSD-Kernels, aber auch aus Teilen von MkLinux, NetBSD und OpenBSD.[3] Der XNU-Kernel von Darwin Version 7 entspricht dabei dem FreeBSD-Kernel in Version 5.[4] Im BSD-Teil wird das Mehrbenutzersystem (Benutzer-IDs, Rechte), der TCP/IP-Stack (auch die Firewall), die Synchronisierung und die Prozessaufteilung gesteuert. Der Mach-Teil ist verantwortlich für Multitasking, Speicherverwaltung und Fehlerbehandlung. Das I/O-Kit verwaltet Plug and Play, Hotplugging, Energiemanagement und Extensionsverwaltung.[4] Im Laufe der Entwicklung wurden diverse Sicherheitsmechanismen in den Kernel eingebaut. So wird in der Intel-Version von Mac OS X Tiger (XNU-Version 792.x, Anfang 2006) das NX-Bit unterstützt, um vor der Ausführung von böswillig überschriebenem Stack mit einer dort platzierten Schadfunktion zu schützen. Auch integriert wurde ab Mac OS X Leopard (XNU-Version 933.x, Ende 2007) und iOS 4.3 (XNU-Version 1735.x, Mitte 2011) Address Space Layout Randomization (ASLR) und seit iPhone OS 2.0 (XNU-Version 1228.x, Mitte 2008) auch Funktionen für Code Signing, damit keine unsignierten Treiber geladen werden können. Letzteres fand im Herbst 2012 als Gatekeeper auch in OS X Mountain Lion (XNU-Version 2050.x) Einzug und wurde auch in Mac OS X Lion 10.7.5 (XNU-Version 1699.x) rückportiert. GeschichteDer Kernel wurde ursprünglich von NeXT für deren Betriebssystem NeXTStep entwickelt. Bis Version 3.3 hieß das Betriebssystem NeXTStep (ab Version 3.1 in der Schreibweise NeXTSTEP und schließlich NEXTSTEP), ab Version 4.0 wurde es in OPENSTEP umbenannt und Ende 1996 von Apple aufgekauft. Da man dort nach einem Nachfolger für das als veraltet geltende System 7 suchte, wurde OPENSTEP im Projekt Rhapsody (Version 5.0 bis 5.6) zu einem Nachfolger für das klassische Mac OS weiterentwickelt. Dabei wurde die Grundlage von OPENSTEP, BSD4.3 und Mach 2.5, ebenfalls erneuert. Rhapsody wie auch Mac OS X bieten ein Unix-System, das auf BSD4.4-Lite und Mach 3.0 basiert – wie bei FreeBSD wurde jedoch aus Kompatibilitätsgründen auch bei XNU Mach 3.0 nicht zu 100 % umgesetzt. Während der Rhapsody-Entwicklung wurde der Unix-Teil als Darwin (ein BSD-Betriebssystem ähnlich FreeBSD) – mit XNU als dessen Kernel – zusammengefasst, die Darwin-Versionsnummer startete wieder bei 1.0 und wurde ab Version 5.1 (mit einem Sprung von Darwin 1.4.1 auf 5.1) mit der Build-Nummer von Mac OS X (ab Version 10.1.1, November 2001) synchronisiert. Darwin wurde zur Grundlage von Mac OS X, das ab 2012 OS X heißt (ohne „Mac“ im Namen) und ab 2016 in vereinheitlichter Schreibweise macOS. Darwin ist ebenfalls die Grundlage des seit 2007 verfügbaren iOS und dessen Abkömmlingen iPadOS, tvOS und watchOS. VersionsgeschichteXNU für macOS kann bei Apple angesehen und heruntergeladen werden, nicht aber jene Kernel für iOS.[5] Die Version folgt in keiner Weise der Version von Darwin, macOS oder iOS. Welche XNU-Version auf einem System läuft, kann mit Unter der ersten Developer Preview gibt der Mach-Kernel der Installations-CD im Einzelbenutzermodus (englisch Single User Mode, Tastenkombination ⌘ Befehl + S) folgende Version aus:
TriviaIn iOS 11 wurde auch eine Apple-eigene Umsetzung des L4-Mikrokernels für die Secure Enclave hinzugefügt. Dieser läuft auf einem im ARM-Prozessor Apple T1, S2 und S3 sowie der späteren A-Serie integrierten Koprozessor als Teil der Boot Chain und wird u. a. für Aktualisierungen, Touch ID / Face ID und Apple Pay genutzt. Dieser L4-Kernel ist jedoch nicht Teil von XNU oder Darwin.[6] Weblinks
Einzelnachweise
|