1. 提取zImage
1.1 下載rom,找到boot.img
1.2. 使用unpackbootimg或者其他工具解壓boot.img
data:image/s3,"s3://crabby-images/1071d/1071ddfcdd9d119a2e8545ed1b5bbee58e67d65e" alt="CVE-2015-1805 iovyroot 查詢核心地址"
1.3. out目錄下檔案如下:
data:image/s3,"s3://crabby-images/97fc1/97fc1f7701c61c4702458db424951695b01aa3db" alt="CVE-2015-1805 iovyroot 查詢核心地址"
1.4 binwalk boot.img-zImage -e提取被gzip壓縮的zImage
data:image/s3,"s3://crabby-images/68d7a/68d7afba310590c822b60f9bf1c13f3fb19a1ff5" alt="CVE-2015-1805 iovyroot 查詢核心地址"
2. 32位rom獲取符號的核心地址
data:image/s3,"s3://crabby-images/14135/1413572d8dd0d7380168ee9afa63421857b900d2" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/959f7/959f743452db65279f7661bba9e6911d4dc123d6" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/6aed4/6aed40e6015139f9053e37323bebd5ae6e2285a0" alt="CVE-2015-1805 iovyroot 查詢核心地址"
2.1 使用kallsymsprint可以獲取以上5個符號的地址
data:image/s3,"s3://crabby-images/ea5af/ea5afe6a49f9974d28db98cf242abadb5a8d67f7" alt="CVE-2015-1805 iovyroot 查詢核心地址"
2.2 新增offset
data:image/s3,"s3://crabby-images/a7351/a735170ec86caa1464026b4959729f7992406c4f" alt="CVE-2015-1805 iovyroot 查詢核心地址"
2.3 使用kallsymsprint無法獲取到5個符號的地址
data:image/s3,"s3://crabby-images/9e8e6/9e8e6e63605270834f3f1e2978fbfe5c723e10c4" alt="CVE-2015-1805 iovyroot 查詢核心地址"
2.4 IDA載入32位的zImage
data:image/s3,"s3://crabby-images/cdc1b/cdc1b9c090e8cd29305d808afe0b14d9b1d4c35c" alt="CVE-2015-1805 iovyroot 查詢核心地址"
使用32位的IDA載入zImage時,Processer Type選擇ARM,勾選Manual load, 點選Ok
data:image/s3,"s3://crabby-images/5dffa/5dffa808e08edd67be3bef82e01b30da1ada9048" alt="CVE-2015-1805 iovyroot 查詢核心地址"
在ROM start address和Loading address填寫0xc0008000,這個是核心.text段的起始地址,通常都為0xc0008000,點選OK等待IDA載入完成。
如果你不確定是不是這個地址, 你可以使用如下命令直接從手機中獲取
data:image/s3,"s3://crabby-images/831b3/831b32ef5770ba9c7593f8b74ef250cf6634f745" alt="CVE-2015-1805 iovyroot 查詢核心地址"
往上檢視dmesg的輸出資訊可以找到
data:image/s3,"s3://crabby-images/7b0db/7b0db9de385680735bb36415a8dd6c74410ebce4" alt="CVE-2015-1805 iovyroot 查詢核心地址"
2.5 尋找 ptmx_fops 地址
在小米核心原始碼中搜尋,直接在github中搜尋的ptmx_fops
data:image/s3,"s3://crabby-images/efb48/efb48e46a81dea6e77b0e53b739c4400699eba77" alt="CVE-2015-1805 iovyroot 查詢核心地址"
由上圖可以看到ptmx_fops僅在pty.c檔案中被引用了兩次,隨便選一處引用
data:image/s3,"s3://crabby-images/3f595/3f5954b9ff442cbdd1b68a005d8f333c9560be6a" alt="CVE-2015-1805 iovyroot 查詢核心地址"
再次搜尋tty_default_fops發現就只有一處呼叫該函式,那就用這個tty_default_fops函式去找到ptmx_fops吧
data:image/s3,"s3://crabby-images/6c40f/6c40fc9eced7d95b0c7fb99cb87986677523b971" alt="CVE-2015-1805 iovyroot 查詢核心地址"
IDA跳轉到地址c03fb21c(按g,輸入地址,即可跳轉到指定地址),把c03fb21c重新命名為tty_default_fops(按n, 輸入名稱,即可修改別名)
IDA查詢tty_default_fops的引用(按x,可以找到所有引用該函式的地址),由於從原始碼知道只有一次引用該函式,就直接跳轉到應用tty_default_fops的地方
data:image/s3,"s3://crabby-images/09208/09208960c4e55f13551b129df87ae9565d1a3401" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/47daa/47daabbb9e029d2067b46e4d50255caf28bd3537" alt="CVE-2015-1805 iovyroot 查詢核心地址"
那麼就找到了ptmx_fops的地址為0xC12D5298
2.6 尋找 sidtab 地址
原始碼中搜尋sidtab,找到很多處引用,發現在services.c 中有個靜態的結構體變數,
data:image/s3,"s3://crabby-images/6d3c6/6d3c67bd0e6bab82bf5740e15b06cf82aee08287" alt="CVE-2015-1805 iovyroot 查詢核心地址"
進入services.c中,找引用sidtab的地方,找啊找啊找朋友~~~,找到一個好朋友
什麼是好朋友呢,就是引數越少的函式,引用越少的函式,這種函式方便分析,
data:image/s3,"s3://crabby-images/cddd4/cddd483e6ab4409654c6d5645dd9f8ed707e64ad" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/a39b2/a39b21fd3974ad48b6be70be5d8ab9af6c590fe1" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/0e935/0e935ccbc44c83a2ac2a6e1b98cfd3fa06e9d0a0" alt="CVE-2015-1805 iovyroot 查詢核心地址"
sidtab的地址為0xC12BC530
2.7 尋找 policydb 地址
data:image/s3,"s3://crabby-images/a1123/a11230373e05d80554866e684ec7ccff0c942b28" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/dc4da/dc4da746369f07f204816149156d0bd48111acab" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/c6f97/c6f979c2a0104d827e24da17bacb45bbd7828efc" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/f309e/f309e13258b8ca72020508d9ea84e6b2abebaf6e" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/a2143/a2143dfea13da326bd05d6c2dcf3678dc80be72e" alt="CVE-2015-1805 iovyroot 查詢核心地址"
policydb地址0xC12BC420
2.8 尋找 selinux_enabled 地址
data:image/s3,"s3://crabby-images/01868/01868dce947c04e1884c719b08e77fe058dcd1c0" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/4c076/4c076fe4f91a9a947423ec149ae7d98cabd62cde" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/8d6ed/8d6ed474d22da4c48e8a2b151471e800c967e420" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/c16bd/c16bd7f1c3628837e70baf905e296fb53204ecf8" alt="CVE-2015-1805 iovyroot 查詢核心地址"
selinux_enabled地址0xC0F5332C
2.9 尋找 selinux_enforcing 地址
data:image/s3,"s3://crabby-images/2c6c7/2c6c73fb58d6c7c35437f7fe30341bacf6c115a7" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/e3636/e3636b260029a7b6e4e4dcad2f74fd6ba1124de2" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/a41f3/a41f3b83e13d36b54dbe135a894f66ee306cf5a9" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/8308c/8308c826fc6b28e4d2ebf506ccff7e01974fc871" alt="CVE-2015-1805 iovyroot 查詢核心地址"
data:image/s3,"s3://crabby-images/e31de/e31dec9c44d6b900c8c9fa479f897c6747876843" alt="CVE-2015-1805 iovyroot 查詢核心地址"
selinux_enforcing地址0xC12BA9D0
2.10 offset
data:image/s3,"s3://crabby-images/e7307/e730746b2e3215b47258db65f57d0402120b08a5" alt="CVE-2015-1805 iovyroot 查詢核心地址"
2.11 演示結果
data:image/s3,"s3://crabby-images/96973/96973c66b8f861e46dbf96100011fef370ff1606" alt="CVE-2015-1805 iovyroot 查詢核心地址"
A.附錄:
data:image/s3,"s3://crabby-images/adf5f/adf5f9ad40b5bdf880b9dddf52b9cf31844f31c8" alt="CVE-2015-1805 iovyroot 查詢核心地址"
B.參考連結
data:image/s3,"s3://crabby-images/ab21e/ab21e208f22aa383b4853f9cad4a6f6ca0af3f5a" alt="CVE-2015-1805 iovyroot 查詢核心地址"
本文作者:Imyang(看雪ID)
原文連結:https://bbs.pediy.com/thread-246448.htm
轉載請註明:轉自看雪論壇
看雪推薦閱讀:
1、[原創]剖析2018騰訊遊戲安全競賽題目(上)-『CrackMe』-看雪安全論壇
2、[原創]GSLab2018-第一題標準版分析-『軟體逆向』-看雪安全論壇
3、[原創]網鼎杯第一場預選 babyheap
4、[原創]Android通用脫殼機FUPK3-『Android安全』-看雪安全論壇
5、[原創] 分析了個簡單的病毒, 熟悉一下16位彙編