Android 刷機原理及ROM定製解析

一、刷機原理

記得第一次刷機,哪個心理緊張啊。其實緊張什麼呢?就是因爲不明白原理啊,只看到一堆的教程來依葫蘆畫瓢,生怕錯了一步將手機變磚。真正使我對刷機 原理有一些理解的是看了這一篇文章:點擊查看

說起來,刷機就是兩種方法:

一是recovery方法,就是我們平時將update.zip入到SD卡,然後alt-s的方法,這種方法是調用了recovery的方法將各種 img或文件進行復制等操作。想了解recovery的工作原理嗎?我也沒找到好的資料,就在這看了看recovery的一些源碼:點擊查看

二是fastboot方法,這個方法其實是比較酷的方法,說白點,fastboot就是將已有的各分區映象文件(img文件,意義上類似我們對光盤 做的映象文件)直接覆蓋寫到指定分區中,有點暴力,也有點類似我們平時操作系統的Ghost還原。

這兩種方法哪種更好,這就不好比高低了,總的來說:

Recovery方法更簡單,只需要傻瓜式的將update.zip放到SD卡的要目錄下,然後進入Recovery模式alt-s就可以了,但和 任何傻瓜式東西一樣,他的靈活度就很小了,而且出錯了也都不知道如何解決。一般來說做Rom的高手爲了保證Rom的可靠性,在安裝程序中都會對一些安裝環 境進行一些確定,而各位的手機環境又是千變萬化的,Rom高手也很難考慮周全,另外,Recovery程序本身也有一些環境驗證。

fastboot方法更靈活,功能也更強大,fastboot方法不需要依賴於recovery,甚至linux底層刷壞了 recovery模式都進不了的情況下也可以通過fastboot方工刷回來。fastboot模式其實是調用spl進行刷機的,所以如果刷spl壞 了,fastboot模式應該也進不了,也就是磚了。fastboot方法需要各位電腦上有fastboot程序,同時手機要進入fastboot模式才 可以操作,關於這些知識,請參見Google *^_^*
二、回頭再來說說Android系統中的各分區(可能分區這個說法不太準確)

我瞭解到的Android系統中的分區有:

hboot(我們刷的SPL就是這玩意),這個分區是最基本的引導分區(類似電腦中的BIOS),這個區壞了,差不多就變磚了,所以我們刷SPL時 纔要如此小心啊。

boot,這個分區應該是linux操作系統的引導分區。

radio,這個分區是手機的一些底層設備相關的驅動或功能程序吧,如打電話和發短信等,不同的系統版本會有不同的radio配套,我們平時刷了高 版本的ROM後,如果不刷高版本的Radio就有可能導致打電話不正常之類的。

recovery,這個分區裝的就是前面提到的recovery程序了,這個刷不同的recovery版本可以帶來不同的功能,有興趣的同學可以基 於recovery的源碼自己編譯出一個自己的recovery出來。但一般來說,刷recovery最主要的就是提Root權限。

system,是一般發佈的ROM的主要功能程序分區了,我們說的ROM功能和自帶程序的定製應該就是基於這個分區的修改和編譯了。

userdata,用戶數據,不說了。

cache,緩存,一般是用來OTA升級時的緩存,我們說刷SPL可以增加程序區的空間大小就是主要將這個區的大小縮水瞭然後加 大了程序區的分區大小。

三、一個典型ROM的剖析

我們平時升級的Rom都是打包成適合Recovery方式刷機的包。能夠被Recovery程序識別並處理的包應該有一個固定的格式,我理解的一些 重要的約束如下:

1)必須是標準的zip壓縮包;

2)recovery腳本必須存入在META-INF\com\google\android\update-script;

3)其它的一些證書和簽名信息應該都放在\META-INF\下。

四、我們有沒有可能自己定製ROM呢

理論上我們是可以自己定製的。

最簡單的定製應該就是拿一個現有的認爲還不錯的基礎ROM,替換一些資源,加一些系統自帶程序,然後打包發佈;

再玩高級一點,就應該自己去修改一些系統自帶的程序,如漢化一些系統原始程序;

還玩高級一點,就應該自己到android官方站點去下載android系統的源碼來編譯,並基於系統級的定製和移植了,如現在火熱的 android2.0源碼編譯系統移植。

如果是簡單一點的自制ROM,主要應該會要解決如下幾個問題:

1)選定一個比較好和穩定的內核和基礎,就是update.zip包中的哪個boot.img,另外,system目錄中大部分也是直接可用的,就 可以作爲自定義Rom的基礎。

2)修改系統。例如可以這樣來定製的東西:system\etc\apns-conf.xml,這是設置APN接入點的;system\etc \hosts,這是設置Host文件的,現在有很多人用的包綁定不了GMail,就可以在這個Host文件中增加一條:74.125.93.113 android.clients.google.com (當然,這個地址能用多久也不好說)...還有什麼東西要自己去定製就自己去翻看瞧瞧。

3)Rom的重新打包簽名。前文已經介紹了一個Rom包的基本結構,但完全按照這個結構打包還是不能被Recovery安裝的,因爲沒有籤 名!Rom簽名可以下載一個自動簽名工具Auto-sign,具體到哪下,請Google。(注:Rom簽名工具需要Java1.6支持,所以系統還得有 JRE1.6的環境)。

再往下就有點高深了,目前只留心一下這些基礎的東西,錯誤在所難免,歡迎指正,拍磚輕些。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章