危害9億安卓設(shè)備高通漏洞細(xì)節(jié)曝光(CVE-2016-3842,含POC) |
||||||||
來源:聚銘網(wǎng)絡(luò) 發(fā)布時間:2016-08-13 瀏覽次數(shù): | ||||||||
信息來源:安全客
(一)、前言
就在幾天之前,安全研究專家在高通芯片內(nèi)發(fā)現(xiàn)了一系列嚴(yán)重的Android安全漏洞,受這些漏洞影響的Android智能手機和平板電腦數(shù)量將會超過九億臺。更可怕的是,大部分受漏洞影響的Android設(shè)備可能永遠(yuǎn)都不會被修復(fù)。
據(jù)了解,安全研究專家此次曝光了四個漏洞,這一組漏洞代號為“Quadrooter”。這些漏洞存在于配備了高通芯片的Android設(shè)備中,受影響的Android系統(tǒng)版本為Android 6.0(Marshmallow)及其以下版本。攻擊者可以利用這些漏洞來獲取到目標(biāo)設(shè)備(配備了高通芯片)的完整訪問權(quán)限。
這四個安全漏洞分別為:
1. CVE-2016-2503:該漏洞存在于高通芯片的GPU驅(qū)動程序中,谷歌公司在2016年7月份的安卓安全公告中正式宣布成功修復(fù)了此漏洞。
2. CVE-2016-2504:該漏洞存在于高通芯片的GPU驅(qū)動程序中,谷歌公司在2016年8月份的安卓安全公告中正式宣布成功修復(fù)了此漏洞。
3. CVE-2016-2059:該漏洞存在于高通芯片的內(nèi)核模塊中,公司于今年四月份就已經(jīng)修復(fù)了該漏洞。
4. CVE-2016-5340:該漏洞同樣存在于高通芯片的GPU驅(qū)動程序中,該漏洞目前已成功修復(fù)。
攻擊者只需要開發(fā)一個簡單的惡意軟件,然后將惡意軟件發(fā)送給目標(biāo)用戶。一旦惡意軟件成功安裝,攻擊者就能夠直接獲取到感染設(shè)備的root訪問權(quán)限。
我們在下面這份列表中列出了當(dāng)前較為熱門的幾款受影響設(shè)備,雖然還有很多其他的移動設(shè)備同樣會受到上述漏洞的影響,但是由于相關(guān)設(shè)備的數(shù)量過于龐大,所以我們在此無法一一列舉。
-Samsung Galaxy S7、Samsung S7 Edge
-Sony Xperia Z Ultra
-OnePlus One、OnePlus 2、OnePlus 3
-Google Nexus 5X、Nexus 6、Nexus 6P
-Blackphone 1、Blackphone 2
-HTC One、HTC M9、HTC 10
-LG G4、LG G5、LG V10
-New Moto X(Motorola)
-BlackBerry Priv
(二)、漏洞概述
2016年8月份的Nexus安全公告對這一漏洞(CVE-2016-3842)進行了評估,感興趣的讀者可以點擊這里閱讀這份安全公告。
細(xì)心的讀者可能已經(jīng)發(fā)現(xiàn)了,這個漏洞似乎分配到了兩個CVE編號。這也就意味著,將會出現(xiàn)一個修復(fù)補丁將會同時修復(fù)兩個漏洞的情況,請大家不要驚訝。
另外一個漏洞就是前言所提到的CVE-2016-2504,該漏洞的發(fā)現(xiàn)者是Adam Donenfeld。
我對漏洞CVE-2016-2504進行了分析,但是我無法找出這兩個CVE漏洞之間的區(qū)別,所以我推測這兩個漏洞描述的是同一個問題。所以在這篇文章中,我只會對我上報給谷歌公司的那個初始漏洞進行描述。
(三)、技術(shù)細(xì)節(jié):
ioctl是設(shè)備驅(qū)動程序中對設(shè)備的I/O通道進行管理的函數(shù),所謂對I/O通道進行管理,指的就是對設(shè)備的一些特性進行控制。ioctl函數(shù)是文件結(jié)構(gòu)中的一個屬性分量,如果你的驅(qū)動程序提供了對ioctl的支持,用戶就能在用戶程序中使用ioctl函數(shù)控制設(shè)備的I/O通道。
高通的MSM GPU驅(qū)動程序(也被稱為kgsl驅(qū)動)提供了一個ioctl命令-IOCTL_KGSL_GPUMEM_ALLOC,這條控制命令可以允許用戶態(tài)的應(yīng)用程序分配得到GPU與主存共享的那一部分內(nèi)存空間。
在這個函數(shù)中,驅(qū)動程序?qū)?chuàng)建一個名為“kgsl_mem_entry”的結(jié)構(gòu)體來標(biāo)識被分配出去的那塊內(nèi)存空間。
當(dāng)某一線程向kgsl驅(qū)動程序發(fā)送了IOCTL_KGSL_GPUMEM_ALLOC命令之后,函數(shù)“kgsl_mem_entry_attach_process”將會通過調(diào)用“idr_alloc”函數(shù)來為“kgsl_mem_entry”對象分配一個id。
但是在這個時候,可能有其他的線程會在函數(shù)“kgsl_ioctl_gpumem_alloc”的結(jié)果值還沒正常返回的情況下,就發(fā)送IOCTL_KGSL_GPUMEM_FREE_ID命令去釋放剛剛分配的結(jié)構(gòu)體對象(kgsl_mem_entry)。
這也就意味著,函數(shù)“kgsl_ioctl_gpumem_alloc”將會繼續(xù)使用這個已經(jīng)被釋放了的“kgsl_mem_entry”對象。
正如技術(shù)人員在補丁文件中寫到的那樣:
“如果我們過早地在idr和rb進程樹中添加了kgsl_mem_entry指針,那么其他的線程就可以在這一對象得到創(chuàng)建函數(shù)的返回值之前,通過猜測對象ID或者GPU地址來操作這個結(jié)構(gòu)體對象了?!?/span>
實際上,“kgsl_mem_entry”對象的ID其實是非常好猜測的。你在內(nèi)核中分配的第一個entry其ID永遠(yuǎn)都為1。
(四)、概念驗證POC
所以,你可以通過下列操作代碼來觸發(fā)這個漏洞:
運行結(jié)果:
Poison Overwritten:
(五)、漏洞利用
在我看來,雖然攻擊者可以利用這個漏洞來進行攻擊,但是針對該漏洞的利用技術(shù)非常不穩(wěn)定。
我很想跟大家分享一些關(guān)于這一漏洞的利用技術(shù),但是說實話,我自己也沒能夠完全掌握該漏洞的利用技巧。
對于我自己而言,只有穩(wěn)定且通用的漏洞利用技術(shù)才值得花時間去開發(fā),所以我就不打算在這個漏洞上花費太多的時間和精力了。
為了避免在漏洞利用的過程中出現(xiàn)內(nèi)核崩潰的情況,你需要在短時間內(nèi)重新為系統(tǒng)分配一個新的“mem_entry”對象(因為之前的對象已經(jīng)被清空了),而且至少要在分配進程訪問“msm_iommu_map_range”地址之前完成你的對象分配操作。
在這一過程中不得不提到一項技術(shù),即堆噴射技術(shù)。在計算機安全領(lǐng)域中,如果想要實現(xiàn)任意代碼執(zhí)行,那么堆噴射技術(shù)(Heap Spraying)就是一種較為容易的技術(shù)實現(xiàn)手段了。在一般情況下,堆噴射代碼會試圖將自身大面積地填充至進程的堆??臻g中,并以正確的方式將命令寫滿這部分內(nèi)存區(qū)域,以實現(xiàn)在目標(biāo)進程的內(nèi)存中預(yù)留位置,并寫入任意的控制指令。
為了實現(xiàn)這一步操作,我嘗試了多種方法,包括采用堆噴射技術(shù)來填充內(nèi)核空間。但是我在測試之后發(fā)現(xiàn),我所采用的最佳方法其成功率也只有40%,大部分情況下內(nèi)核都會發(fā)生崩潰。我所采用的方法就是通過seccomp-bpf程序配合堆噴射技術(shù),迅速將數(shù)據(jù)內(nèi)容填充堆內(nèi)存空間。谷歌的Project Zero團隊曾在去年的一篇文章中介紹過這項技術(shù),感興趣的讀者可以點擊這里進行閱讀。需要注意的是,seccomp-bpf只能用于對版本為3.10的內(nèi)核進行堆噴操作。如果我們能夠重新填充之前被意外釋放的那部分內(nèi)存空間,那么控制目標(biāo)計算機的注冊表也就是一件很簡單的事情了。
在“kgsl_mem_entry”結(jié)構(gòu)體中,存在一個名為“kgsl_memdesc_ops”的結(jié)構(gòu)體指針,它可以被攻擊者完全控制:
通過重寫“kgsl_memdesc_ops”指針,并讓它指向你的ROP/JOP鏈,你就可以成功實現(xiàn)內(nèi)核代碼執(zhí)行了。
(六)、修復(fù)補?。?/span>
https://android.googlesource.com/kernel/msm/+/973f4134d9deb396415846f902848f0a32cb4cfa
(七)、漏洞時間軸
2016年4月25日:將該漏洞提交給谷歌公司;
2016年5月5日:谷歌公司對該漏洞進行了評估,并將該漏洞的評級設(shè)置為“高危漏洞”;
2016年6月29日:該漏洞分配到了編號CVE-2016-3842;
2016年8月1日:2016年8月份的Nexus安全公告正式披露了該漏洞的內(nèi)容
(八)、總結(jié)
Android系統(tǒng)的安全問題真是令人頭疼的問題。再加上近期高通公司的處理器芯片頻爆漏洞,無疑是在給Android手機目前的安全現(xiàn)狀雪上加霜。
高通(Qualcomm)是一家美國的無線電通信技術(shù)研發(fā)公司,成立于1985年7月,在以技術(shù)創(chuàng)新推動無線通訊向前發(fā)展方面扮演著重要的角色。目前,高通公司所生產(chǎn)的CPU芯片和GPU芯片已經(jīng)被廣泛應(yīng)用于各大廠商的安卓智能手機上了,考慮到如此大的用戶群體,高通公司是不是應(yīng)該加強產(chǎn)品的安全監(jiān)管呢?
當(dāng)然了,無論產(chǎn)品做得多么優(yōu)秀,安全問題永遠(yuǎn)都會存在。沒有折不斷的茅,也沒有攻不破的盾。也許這就是信息安全吧!
(九)、參考鏈接
1.kgsl驅(qū)動程序中的另一個漏洞(已于2016年6月修復(fù)):
http://retme.net/index.php/2016/06/12/CVE-2016-2468.html
2.2016年8月份的Nexus安全公告:
https://source.android.com/security/bulletin/2016-08-01.html
3.Project Zero項目團隊于2015年1月份發(fā)表的技術(shù)文章(涉及seccomp-bpf):
http://googleprojectzero.blogspot.jp/2015/01/exploiting-nvmap-to-escape-chrome.html
4.漏洞修復(fù)補?。?/span>
https://android.googlesource.com/kernel/msm/+/973f4134d9deb396415846f902848f0a32cb4cfa
5.“Quadrooter”漏洞報告(The Hacker News):
http://thehackernews.com/2016/08/hack-android-phone.html
本文由 安全客 原創(chuàng)發(fā)布,如需轉(zhuǎn)載請注明來源及本文地址。 |
||||||||