HENkaku - Stage 2
Stage 2's payload is composed by another ROP chain and data.
It creates two userland threads (each one with it's own
ROP chain), that take care of leaking kernel pointers (by issuing
devctl commands to "sdstor0:") and breaking the userland sandbox (by
exploiting sceNet functions).
Stage 2 leverages a bug in sceIoDevctl in order to leak
2 distinct kernel pointers. These 2 pointers refer, respectively, to
SceSysmem module's base address and SceIoFilemgr(?) thread's stack address:
- // Store leaked kernel pointer 1
// Comes from devctl_outbuf + 0x3D4scesysmem_base = 0x00(x_stack + 0x00007308) + 0xFFFFA8B9// Store leaked kernel pointer 2// Comes from devctl_outbuf + 0x3C4sceiofilemgr_stack_base = 0x00(x_stack + 0x000072F8) + 0xFFFFF544
When preparing to write the kernel ROP chain, we can see a few pointers being set. These translate to:
- // Kernel ROP inside sceiofilemgr
// This is where our ROP chain gets copied to inside the SceIoFilemgr modulekern_rop = sceiofilemgr_stack_base + 0x000006F8// Encrypted kernel codekern_code = kern_rop + 0x300
Now we write down our kernel ROP chain in the stack, but we can see that some values only get written afterwards.
This is because these values are directly related to
the decryption of the next kernel level stage! Team molecule likely only
writes them into the ROP chain later so they can easily update the
encrypted stage without having to change the kernel ROP chain directly.
So:
- // Overwrite specific NULLs in the ROP chain
0x00(x_stack + 0x00008C04) = 0x00(x_stack + 0x00008EAC) // kern_code0x00(x_stack + 0x00008B48) = 0x000000900x00(x_stack + 0x00008CC0) = 0x000002400x00(x_stack + 0x00008D58) = 0x000002000x00(x_stack + 0x00008D14) = 0x00008FC0 // kern_next_payload
And our final ROP chain should look like this:
Now we copy the chain from the stack into the buffer that's being sent through sceIoDevctl:
- // Copy kernel ROP chain
memcpy(x_stack + 0x00007448, x_stack + 0x00008A8C, 0x300);// Copy the first 0x400 bytes of "obfuscated" data// and append them at the bottom of the ROP chainmemcpy(x_stack + 0x00007744, x_stack + 0x00008EB8, 0x400);
And so, the final input buffer will look like this:
- // SceSysmem address
// Unknown pointer written right on top of the input buffer0x00(x_stack + 0x00007444) = scesysmem_base + 0x0001E460// Kernel ROP chain0x00(x_stack + 0x00007448) = 0xXXXXXXXX;...0x00(x_stack + 0x00007734) = 0xXXXXXXXX;// A few NULLs for padding0x00(x_stack + 0x00007738) = 0x00000000;0x00(x_stack + 0x0000773C) = 0x00000000;0x00(x_stack + 0x00007740) = 0x00000000;// Encrypted kernel code// Only the first 0x100 bytes will fit in the buffer0x00(x_stack + 0x00007744) = 0xXXXXXXXX;...0x00(x_stack + 0x00007B44) = 0xXXXXXXXX;
Finally, we must craft a buffer that will have our ROP chain's SP and PC. This is the buffer we feed the SceNet exploit with:
- // Set kernel thread SP, PC, UNK
0x00(x_stack + 0x0000884C) = sceiofilemgr_stack_base + 0x000006F8 + 0x00000004 // SP0x00(x_stack + 0x00008850) = scesysmem_base + 0x00000347 // PC0x00(x_stack + 0x00008858) = sceiofilemgr_stack_base + 0x000006DC // UNK
When the SceNet exploit finishes, we should have
hijacked a kernel thread inside the SceNetPs module and overwritten it's
stack contents with our own.
This results in the kernel jumping to scesysmem_base + 0x00000347 (which
is very likely a POP {PC} gadget) and executing our ROP chain at
sceiofilemgr_stack_base + 0x000006F8 + 0x00000004 (which translates to
kern_rop + 0x04).
To further reverse the exploit, one must dump the
target kernel modules, rebuild the kernel ROP and deobfuscate/decrypt
the rest of HENkaku's code.
Next up, stage 3!
Hello, I need a contact to you and a few other people, which you know quiet well. I don't know, what I can write here, so I will not write anything about the reason, until you or one of the people which I mean, tell me something like a safe channel (not because of me, but because of you, and I would accept every kind of), where you would allow me, to tell you the reason why I need a contact to you. I please you just to listen/read a few moments and then maybe to reply me something. I really please you for that. Kind regards
ReplyDelete스포츠토토
ReplyDelete안전놀이터
I’m not sure why but this blog is loading incredibly slow for me.
Is anyone else having this issue or is it a problem on my end?
I’ll check back later and see if the problem still exists.
ReplyDeleteVery useful information shared in this article, nicely written`
I simply wish to give you a huge thumbs up for your excellent info
ReplyDeleteYour article has answered the question I was wondering about!
ReplyDeleteThere are articles and photos on these topics on my homepage, so please visit and share your opinions.
ReplyDeleteI hope we can do it together next time.
ReplyDeletewow, awesome blog post. Much thanks again.
ReplyDeleteHave you thought about another topic to post?
ReplyDeletePretty! This has been an extremely wonderful post. Many thanks for providing this info.
ReplyDeleteIt looks like you spend a lot of effort and time on your blog.
ReplyDeleteI’m really glad I have found this information.
ReplyDeleteNice site you got here, very awesome and good content.
ReplyDeleteYou know how to get your readers' attention. 바카라사이트
ReplyDeleteThanks for this blog, I really enjoyed reading your post. 파워볼사이트
ReplyDelete
ReplyDeleteFantastic article. I like your writing style. It’s inspiring and I am truly grateful for the writing style
This is a fascinating explanation of how Stage 2 works.
ReplyDelete