|
|
這一段時間刷了一堆ROM,安卓係列、CM、Hero、OldMos、隔壁新出的Android2.0,反正都嘗了一下鮮,手機的照相機也刷得再也啓不來了(不知道什麽原因,杯具)。有話說:"久病成良醫",想我們折騰了這麽久的刷機,也得總結總結不是,小弟不才,遠沒成"良醫",但還是想把自己的一些認識和心得寫出來,以期拋磚引玉...$ U% d- Y0 q: g/ m* [, a
1 C" p- Q$ K$ ~; H0 y/ b8 ` y2 k& J! [ |0 x# L+ j( q
8 y% Q! r# @$ t% I4 H' u
一、刷機原理
0 M g: @. Q* @
7 j/ y; G! a4 b5 ]記得第一次刷機,哪個心理緊張啊。其實緊張什麽呢?就是因爲不明白原理啊,只看到一堆的教程來依葫蘆畫瓢,生怕錯了一步將手機變磚。真正使我對刷機原理有一些理解的是看了這一篇文章:點擊查看8 ]$ v6 D+ ]* Z; I9 a9 O
7 z' j2 j6 q4 }
說起來,刷機就是兩種方法:8 j& R* i5 s* Y2 J- Q# H
6 ]: U; c) Z; e. u: J. s
一是recovery方法,就是我們平時將update.zip入到SD卡,然後alt-s的方法,這種方法是調用了recovery的方法將各種img或檔進行複制等操作。想瞭解recovery的工作原理嗎?我也沒找到好的資料,就在這看了看recovery的一些源碼:點擊查看
7 w% p. Q& H9 g8 G+ ~) ^9 S9 R% z2 t1 U
二是fastboot方法,這個方法其實是比較酷的方法,說白點,fastboot就是將已有的各分區映象檔(img檔,意義上類似我們對光盤做的映象檔)直接覆蓋寫到指定分區中,有點暴力,也有點類似我們平時操作係統的Ghost還原。
? `8 J0 R) j1 C
. r' ?" B0 G; @/ `! U t這兩種方法哪種更好,這就不好比高低了,總的來說:" Q0 _& M$ {, N, t
1 z+ U$ y9 Q. i( jRecovery方法更簡單,只需要傻瓜式的將update.zip放到SD卡的要目錄下,然後進入Recovery模式alt-s就可以了,但和任何傻瓜式東西一樣,他的靈活度就很小了,而且出錯了也都不知道如何解決。一般來說做Rom的高手爲了保證Rom的可靠性,在安裝程式中都會對一些安裝環境進行一些確定,而各位的手機環境又是千變萬化的,Rom高手也很難考慮周全,另外,Recovery程式本身也有一些環境驗證。
" a! J- P+ m w0 o: A
( f4 ~% C a2 W$ }% s0 c6 K, nfastboot方法更靈活,功能也更強大,fastboot方法不需要依賴於recovery,甚至linux底層刷壞了recovery模式都進不了的情況下也可以通過fastboot方工刷回來。fastboot模式其實是調用spl進行刷機的,所以如果刷spl壞了,fastboot模式應該也進不了,也就是磚了。fastboot方法需要各位電腦上有fastboot程式,同時手機要進入fastboot模式才可以操作,關於這些知識,請參見Google *^_^*
% a7 ?& u' y5 C! M+ F: w, }, `3 c" Y9 ^; ~. f5 K: z8 @" H- a
% ? D/ Y6 t* S0 `, [/ n- u二、回頭再來說說Android係統中的各分區(可能分區這個說法不太準確)/ k' \) @0 y2 C) I2 l% t
% l" J1 m* D% U* U3 Y4 a/ K* g我瞭解到的Android係統中的分區有:7 h: ?3 T5 F$ U8 Q! n
( k, T7 Y7 ~5 C% a" f8 Fhboot(我們刷的SPL就是這玩意),這個分區是最基本的引導分區(類似電腦中的BIOS),這個區壞了,差不多就變磚了,所以我們刷SPL時才要如此小心啊。
! J0 z' m( ^! Y" h) ]" _
' ^. |$ |- A: \4 ]boot,這個分區應該是linux操作係統的引導分區。- `0 }( d$ L1 z2 A4 I
* }4 J5 b( y0 E9 R, d; q( Y/ k/ M6 B
radio,這個分區是手機的一些底層設備相關的驅動或功能程式吧,如打電話和發短信等,不同的係統版本會有不同的radio配套,我們平時刷了高版本的ROM後,如果不刷高版本的Radio就有可能導致打電話不正常之類的。
$ ?; W& _ Q# U. q% R! @
# ?$ t% T. J+ j; q0 x6 F% Hrecovery,這個分區裝的就是前面提到的recovery程式了,這個刷不同的recovery版本可以帶來不同的功能,有興趣的同學可以基於recovery的源碼自己編譯出一個自己的recovery出來。但一般來說,刷recovery最主要的就是提Root權限。) x8 Y: o# J9 z. [# w) R7 _4 h5 G( N
* ? r! b* X+ `2 b# N
system,是一般發布的ROM的主要功能程式分區了,我們說的ROM功能和自帶程式的定制應該就是基於這個分區的修改和編譯了。; A! I4 P( R0 Z2 ^
0 Q: L: ?$ d" Z5 z, B8 \! l& ^! |
userdata,用戶數據,不說了。; l/ U" i e, R/ z4 t
- o$ |6 Z8 W) w
cache,緩存,一般是用來OTA升級時的緩存,我們說刷SPL可以增加程式區的空間大小就是主要將這個區的大小縮水了然後加大了程式區的分區大小。
- I" W: Q& B; x/ I
; L+ b6 K& x! ^
' J. D. G4 ^" [9 O三、一個典型ROM的剖析* d3 Z1 \9 U; K
. v8 S/ Z8 L$ y
我們平時升級的Rom都是打包成適合Recovery方式刷機的包。能夠被Recovery程式識別並處理的包應該有一個固定的格式,我理解的一些重要的約束如下:
% s9 v K- r! a" q \
8 B5 B. H9 J- p' L3 \$ ^/ d1)必須是標準的zip壓縮包;3 \" l/ w, O& R, o- d5 h
6 ^6 M* K; [5 G7 [6 t/ M: q
2)recovery腳本必須存入在META-INF\com\google\android\update-script;' H* d; i+ r5 W/ u+ s
5 n! z' w% w5 B/ j6 k# j2 L& ^3)其他的一些證書和簽名資訊應該都放在\META-INF\下。- {- B" u R: R, `6 k
! K% Z& h; T; F& P E* o! x四、我們有沒有可能自己定制ROM呢0 O* ?7 @6 `( x1 |1 I: U
- R* O# D* h. f& }$ x) k% ? S
理論上我們是可以自己定制的。
; h, E* h# e8 o! E# P0 v
+ l8 q9 L5 _' U! b% Y! Z7 P Q: E: z最簡單的定制應該就是拿一個現有的認爲還不錯的基礎ROM,替換一些資源,加一些係統自帶程式,然後打包發布;
8 z3 L, m4 F( x( {6 y+ u, h$ ]1 ]
) Z# Y( }" N5 Q2 A再玩高級一點,就應該自己去修改一些係統自帶的程式,如漢化一些係統原始程式;# p4 W2 x" Q. B
( g( U# I3 ?1 n5 @0 G8 l; j5 `
還玩高級一點,就應該自己到android官方站點去下載android係統的源碼來編譯,並基於係統級的定制和移植了,如現在火熱的android2.0源碼編譯係統移植。! X% Y, T" X1 j& N" r) [8 j8 E6 Y
2 r0 ~0 J/ r& P3 S8 S9 J
如果是簡單一點的自製ROM,主要應該會要解決如下幾個問題:! M8 c: x4 Y0 S. s/ x' ~
1 C, k- q* z6 u8 G4 `
1)選定一個比較好和穩定的內核和基礎,就是update.zip包中的哪個boot.img,另外,system目錄中大部分也是直接可用的,就可以作爲自定義Rom的基礎。% C# K2 z7 i, J
/ ]: i8 y# X# t8 y- L5 R
2)修改係統。例如可以這樣來定制的東西:system\etc\apns-conf.xml,這是設置APN接入點的;system\etc\hosts,這是設置Host文件的,現在有很多人用的包綁定不了GMail,就可以在這個Host檔中增加一條:74.125.93.113 android.clients.google.com (當然,這個地址能用多久也不好說)...還有什麽東西要自己去定制就自己去翻看瞧瞧。
3 t9 e5 d B' v% F/ u. E3 D# B3 u1 W2 n: S: l3 n
3)Rom的重新打包簽名。前文已經介紹了一個Rom包的基本結構,但完全按照這個結構打包還是不能被Recovery安裝的,因爲沒有簽名!Rom簽名可以下載一個自動簽名工具Auto-sign,具體到哪下,請Google。(注:Rom簽名工具需要Java1.6支援,所以係統還得有JRE1.6的環境)。% h, G) ~; J: ~
9 K& b" ~$ K# M- Z" v) t7 G
再往下就有點高深了,目前只留心一下這些基礎的東西,錯誤在所難免,歡迎指正,拍磚輕些。" U% [$ p! j" k) ^& E
; e# o0 P0 x% w! u9 y1 y6 j原文作者: happylo |
|