-
Notifications
You must be signed in to change notification settings - Fork 17
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit da9ac74
Showing
7 changed files
with
3,037 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
language: objective-c | ||
compiler: clang | ||
os: osx | ||
script: make |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
MIT License | ||
|
||
Copyright (c) 2017 cocoahuke | ||
|
||
Permission is hereby granted, free of charge, to any person obtaining a copy | ||
of this software and associated documentation files (the "Software"), to deal | ||
in the Software without restriction, including without limitation the rights | ||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
copies of the Software, and to permit persons to whom the Software is | ||
furnished to do so, subject to the following conditions: | ||
|
||
The above copyright notice and this permission notice shall be included in all | ||
copies or substantial portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
SOFTWARE. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
CC=clang | ||
CFLAGS=-fobjc-arc -fobjc-link-runtime -lreadline -framework Foundation src/libcapstone.a | ||
|
||
build/ioskextdump: | ||
mkdir -p build; | ||
$(CC) $(CFLAGS) src/*.m -o $@ | ||
|
||
.PHONY:install | ||
install:build/ioskextdump | ||
mkdir -p /usr/local/bin | ||
cp build/ioskextdump /usr/local/bin/ioskextdump | ||
|
||
.PHONY:uninstall | ||
uninstall: | ||
rm /usr/local/bin/ioskextdump | ||
|
||
.PHONY:clean | ||
clean: | ||
rm -rf build |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
# ioskextdump | ||
Dump Kext information from iOS kernel cache. Applicable to the kernel of dump from kernel. The disassembly framework used is [Capstone](http://www.capstone-engine.org/) | ||
|
||
[data:image/s3,"s3://crabby-images/2c0c4/2c0c4a7eb160286ba25247ed9708d34a4e5132dc" alt="Contact"](https://twitter.com/cocoahuke) [data:image/s3,"s3://crabby-images/7962c/7962cc74f61fd88db11121d299303fc97d854ad7" alt="build"](https://travis-ci.org/cocoahuke/coBlue) [data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="license"](https://github.com/cocoahuke/ioskextdump/blob/master/LICENSE) [data:image/s3,"s3://crabby-images/e0220/e02209da46028209c63ddb1dc3bae5631592d6e2" alt="paypal"](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=EQDXSYW8Z23UY) | ||
|
||
<br> | ||
|
||
Analyze kernel extension information from iOS kernel cache with arm instructions and extract information, information including the basic IOKit classes construction parameters, inheritance relationship of the IOKit class and subclass methods override. | ||
|
||
I finished this dirty project a year ago. Have been tested at iOS8& (32bit iOS9) kernel cache, Does not support iOS10, iOS10 Kext format has some changing, For example, sections of kernel cache is changed `__DATA -> __DATA_CONST`. I haven't studied the kernel of iOS10 yet because I spend time to learn something else | ||
|
||
The project will begin from `__DATA.__ mod_init_func` as start point. Get all basic IOKit class construction functions first, and then export Kexts from `__PRELINK_TEXT.__text` one by one. According to basic IOKit classes’s VM address get a different inheritance relationship of IOKit classes of Kexts so this program could analyze different table and compare to its superclass, The result obtained is determine which functions this IOKit class override. | ||
So it needs to execute twice to get the inheritance order of all classes, first time was record information | ||
|
||
And also will determine structure of `IOExternalMethodDispatch` if its a Userclient class, but many classes implements their own externalMethod, didn’t use any `IOExternalMethodDispatch`, `IOExternalMethod` or `IOExternalTrap` | ||
So still need lots of manual analysis to find interface of Kext | ||
|
||
# How to use | ||
|
||
**Download** | ||
```bash | ||
git clone https://github.com/cocoahuke/ioskextdump.git | ||
&& cd ioskextdump | ||
``` | ||
**Compile and install** to /usr/local/bin/ | ||
|
||
```bash | ||
make | ||
make install | ||
``` | ||
**Usage** | ||
``` | ||
Usage: ioskextdump [-e] [-p <access directory path>] <kernelcache> | ||
``` | ||
`-e` Specify the export mode | ||
`-p` Specifiy a folder path that contains the data file or export data file to there | ||
<br> | ||
**Example to use** | ||
I left a sample iOS8.3 kernelcache in the test directory, try to run this command | ||
``` | ||
ioskextdump -e -p test test/iPhone6p_8.3_kernel.arm | ||
``` | ||
You will see all Inheritance relationship is empty and `allClass_relation.plist saved success` should be at end of program print | ||
``` | ||
Inheritance relationship: | ||
``` | ||
<br> | ||
|
||
Then try same command removes `-e` | ||
``` | ||
ioskextdump -p test test/iPhone6p_8.3_kernel.arm | ||
``` | ||
ioskextdump will print contain lists of inheritance and override functions: | ||
``` | ||
******** 3:com.apple.iokit.IOAcceleratorFamily2 ******* | ||
(0xffffff801ce66998)->OSMetaClass:OSMetaClass call 4 args list | ||
x0:0xffffff801ce93588 | ||
x1:IOAccelCLContext2 | ||
x2:0xffffff801ce935d8 | ||
x3:0xfc8 | ||
vtable start from addr 0xffffff801ce8bb70 | ||
Inheritance relationship: IOAccelContext2->IOAccelSubmitter2->IOUserClient->IOService->IORegistryEntry->OSObject | ||
overwrite: IOUserClient_IOUserClient loc:0xffffff801ce8bb70 imp:0xffffff801ce66818 | ||
overwrite: IOUserClient_~IOUserClient loc:0xffffff801ce8bb78 imp:0xffffff801ce6681c | ||
overwrite: IOUserClient_getMetaClass loc:0xffffff801ce8bba8 imp:0xffffff801ce66834 | ||
overwrite: IOUserClient_free loc:0xffffff801ce8bbd8 imp:0xffffff801ce68618 | ||
... | ||
``` |
Binary file not shown.
Oops, something went wrong.