Android rom移植知識(shí)
最近接到很多兄弟們的求助,也回答過無數(shù)個(gè)和下面這個(gè)問題類似的問題:
如何編譯android 原生代碼得到一個(gè)rom,然后跑到某某手機(jī)上。
鑒于很多兄弟對(duì)這塊不清楚,我這里一并簡(jiǎn)單回答之。
1 ROM包含兩個(gè)基本的image,一個(gè)是boot.image,這個(gè)image中主要是kernel和文件系統(tǒng)/目錄下的一些東西。kernel我就不說了,/目錄下主要是init和相關(guān)的配置文件
system.image是android系統(tǒng)的userpace的核心,包括/system/bin,system/lib,system/app下的一些東西。
2 手機(jī),不同手機(jī),其內(nèi)部使用的芯片,配置等等都不同。另外,android源碼中并不包含硬件相關(guān)的代碼。也就是說拿標(biāo)準(zhǔn)源碼編譯出來的僅僅在模擬器上跑跑還可以,
拿到真機(jī)上,跑也許能跑起來,但也就把手機(jī)當(dāng)個(gè)模擬器使,電話,audio,wifi等等和硬件相關(guān)的都不能用。沒有什么為什么會(huì)這樣,硬件相關(guān)的驅(qū)動(dòng)是廠商的閉源代碼,
絕對(duì)不可能放出來。 不過,android中自帶一些htc/sumsing的二進(jìn)制HAL層so,也是在編譯對(duì)應(yīng)device的時(shí)候拷貝到system.image中去的。
所以,基于上面的認(rèn)識(shí),兄弟們就不要想著拿標(biāo)準(zhǔn)源碼搞出一個(gè)能正兒八經(jīng)跑的rom了。除此之外,手機(jī)還有AP/BP之分,BP的代碼是另外一套,相當(dāng)于另外一個(gè)OS,用于
modem通信的。即使你能搞定AP,BP也不要想了
3 CM是怎么搞出來的?CM不是神仙,它的工作我估計(jì)分下面幾個(gè)來完成:
1 boot.image,有可能是直接基于廠商的。例如在HTC G7移植中,直接使用了G7官方的ROM
2 system,image中,跟硬件無關(guān)的(也就是非HAL層代碼),愛怎么改怎么改。
3 system.image中,跟硬件相關(guān)的,先通過adb pull把官方的so弄出來,然后放到自己的ROM中。這里的工作比較難,但理論上是可以做到二進(jìn)制兼容的。
從上面可知,如果官方?jīng)]有提供4.0的ROM,CM也歇菜。(我個(gè)人覺得其實(shí)是可以在4.0中使用2.3的so的,方法可以通過dlopen方式加載,中間再做一層隔離。但如果
依賴的頭文件發(fā)生變化了,那工作量就大了去了)
4 MIUI,點(diǎn)心OS,是CM之上的二次開發(fā)。國(guó)人的拿來主義造就了MIUI和點(diǎn)心等其叫囂著做ROM的公司。
綜上,兄弟們不要想著憑一己之力搞個(gè)牛叉的ROM了,沒必要,沒意義。
1 想搞rom的,建議在CM基礎(chǔ)上做二次開發(fā),和硬件相關(guān)的統(tǒng)統(tǒng)都不要?jiǎng)印?/p>
2 想改ui的,也可以基于現(xiàn)有的system.image,換換圖片,然后再打包成image。這個(gè)網(wǎng)上有很多做法。技術(shù)含量不高,玩玩可以了。
ANY WAY,謝謝兄弟們的信任。歡迎高手就上述知識(shí)點(diǎn)和大家argue。