HW_AHB steht für "Hardware Advanced High-performance Bus"[1] und ist Teil der Advanced Microcontroller Bus Architecture (AMBA) von ARM Limited (ARM).

HW_AHB-Zugriff

Wenn die HW_AHB-Protection (HW_AHBPROT, intern ACRBUSPROT genannt[2]) deaktiviert wird, wird voller Zugriff auf die gesamte Hardware der Wii gewährt. Dafür wird kein cIOS benötigt; der Homebrewkanal deaktiviert HW_AHBPROT und diese Deaktivierung bleibt bestehen, wenn eine Homebrew das IOS nicht neu lädt.

Fälschlicherweise wird oft von einer "Aktivierung von HW_AHBPROT" gesprochen, was faktisch aber unsinnig ist, da der Schutz deaktiviert werden soll.

MEMPROT

Mit deaktivierter HW_AHBPROT ist es möglich, MEMPROT (Memory Protection) zu deaktivieren. Das IOS reserviert den oberen Teil von MEM2 für seine eigene Nutzung[3] - dadurch können temporäre Patches auf das IOS angewendet werden, inklusive Signatur-, NAND- und ES-Patches.

Geschichte

Auf der Suche nach einer Lösung für ein Problem innerhalb von BootMii, bei dem die Buttons in BootMii/IOS nicht funktionierten, stieß bushing von Team Twiizers auf das "Access Rights" Bit in der TMD einer WAD, die am Ende der Herstellung einer Wii verwendet wird.[4] Wird dieses Bit gesetzt, so wird der komplette Zugriff auf die gesamte Hardware direkt vom PPC aus gewährt. Bushing vermutete, dass dies das Testen der Hardware vereinfacht haben soll. Der Homebrewkanal hat ebenfalls dieses Bit ab v1.0.8 gesetzt und ermöglicht es so jeder Applikation, die über den HBC gestartet wird, HW_AHBPROT zu deaktivieren. Dies hat den Vorteil, dass kein gepatchtes IOS mehr benötigt wird, da jede Anwendung das aktuelle IOS selbst temporär patchen kann.

In früheren Versionen des Homebrewkanals führte die Deaktivierung von HW_AHBPROT zu Abstürzen, wenn die Internetverbindung noch nicht initialisiert war. Dieses Problem wurde später mit einem neuen Patch "ES_SET_AHBPROT" behoben - wird ein IOS (üblicherweise das IOS36 und IOS236) mit diesem Patch geladen, wird HW_AHBPROT auch für jedes weitere geladene IOS deaktiviert.

Einzelnachweise