X-Git-Url: http://wien.tomnetworks.com/gitweb/?p=savezelda.git;a=blobdiff_plain;f=batman%2Fexploit.s;fp=batman%2Fexploit.s;h=ced21342514e86be73b3401d81d1af4db83e5580;hp=0000000000000000000000000000000000000000;hb=da886e2a723e5990d209d8fc141dc9bab7bf0424;hpb=4d980dfebbc6faf212cf41a09240104118d8889f diff --git a/batman/exploit.s b/batman/exploit.s new file mode 100644 index 0000000..ced2134 --- /dev/null +++ b/batman/exploit.s @@ -0,0 +1,45 @@ +# Copyright 2008-2009 Segher Boessenkool +# Copyright 2011 Bernhard Urban +# This code is licensed to you under the terms of the GNU GPL, version 2; +# see file COPYING or http://www.gnu.org/licenses/old-licenses/gpl-2.0.txt + + .section .start,"ax" + retadr = 0x90394140 + + # The return addr for the nintendo loader is a bit different as for 3rd + # party loaders. In fact, it depends which value is set by the apploader at + # 0x8000002c: + # - 0x0: return address is 0x90394140 (some 3rd party loader, e.g. gecko os) + # - 0x23: return address is 0x90394000 (set by the sysmenu loader by nintendo) + # 0B ver: 0x90394100 + # to make both work, we insert some no op's here + .fill (0x140/0x4), 4, 0x60000000 + +start: + # Set up a stack frame. + lis 1,0x8080 ; li 0,0 ; stwu 0,-64(1) + + # Stop audio and video. + lis 0,audio_stop@h ; ori 0,0,audio_stop@l ; mtctr 0 ; bctrl + lis 0,video_stop@h ; ori 0,0,video_stop@l ; mtctr 0 ; bctrl + + # Move code into place; a generous 32kB, starting at 64kB in + # the save file. + + lis 3,main@h ; ori 3,3,main@l ; addi 5,3,-4 + lis 4,(retadr-4)@h ; ori 4,4,(retadr-4)@l + # Calculate proper offset for the loader in memory +0: lbzu 0,4(4); cmpwi 0,0x60 ; beq 0b + addi 4,4,-4; addi 4,4,end-start + + li 0,0x2000 ; mtctr 0 +0: lwzu 0,4(4) ; stwu 0,4(5) ; bdnz 0b + + # Sync caches on it. + li 0,0x0400 ; mtctr 0 ; mr 5,3 +0: dcbst 0,5 ; sync ; icbi 0,5 ; addi 5,5,0x20 ; bdnz 0b + sync ; isync + + # Go for it! + mtctr 3 ; bctr +end: