天天看點

Android OTA更新原理和流程分析(三)---Android系統的三種啟動模式

轉載自:http://blog.chinaunix.net/uid-22028566-id-3533851.html

        以下的篇幅開始分析我們在上兩個篇幅中生成的update.zip包在具體更新中所經過的過程,并根據源碼分析每一部分的工作原理。

Android OTA更新原理和流程分析(三)---Android系統的三種啟動模式

一、       系統更新update.zip包的兩種方式

    1.  通過上一個文檔,我們知道了怎樣制作一個update.zip更新包用于更新系統。Android在更新系統時獲得update.zip包的方式有兩種。一種是離線更新,即手動拷貝更新包到SD卡(或NAND)中,通過settings-->About phone-->System Update-->選擇從SD卡更新。另一種是線上更新,即OTA  Install(over  the  air)。使用者通過線上下載下傳更新包到本地,然後更新。這種方式下的update.zip包一般被下載下傳到系統的/CACHE分區下。

     2.  無論将更新包放在什麼位置,在使用update.zip更新時都會重新開機并進入Recovery模式,然後啟動recovery服務(/sbin/recovery)來安裝我們的update.zip包。

    3.  為此,我們必須了解Recovery模式的工作原理以及Android系統重新開機時怎樣進入Recovery工作模式而不是其他模式(如正常模式)。

二、       Android系統中三種啟動模式

       首先我們要了解Android系統啟動後可能會進入的幾種工作模式。先看下圖:
Android OTA更新原理和流程分析(三)---Android系統的三種啟動模式
       由上圖可知Android系統啟動後可能進入的模式有以下幾種:

(一) MAGIC KEY(組合鍵):

       即使用者在啟動後通過按下組合鍵,進入不同的工作模式,具體有兩種:             

       ① camera + power:若使用者在啟動剛開始按了camera+power組合鍵則會進入bootloader模式,并可進一步進入fastboot(快速刷機模式)。

       ② home + power :若使用者在啟動剛開始按了home+power組合鍵,系統會直接進入Recovery模式。以這種方式進入Recovery模式時系統會進入一個簡單的UI(使用了minui)界面,用來提示使用者進一步操作。在tcc8800開發闆中提供了一下幾種選項操作:

                                “reboot system now”

                                “apply update from sdcard”

                                “wipe data/factory reset”

                                “wipe cache partition”

(二)正常啟動:

       若啟動過程中使用者沒有按下任何組合鍵,bootloader會讀取位于MISC分區的啟動控制資訊塊BCB(Bootloader Control Block)。它是一個結構體,存放着啟動指令command。根據不同的指令,系統又 可以進入三種不同的啟動模式。我們先看一下這個結構體的定義。

             struct bootloader_message{

                      char command[32];  //存放不同的啟動指令

                      char status[32];   //update-radio或update-hboot完成存放執行結果

                      char recovery[1024]; //存放/cache/recovery/command中的指令

             };

         我們先看command可能的值,其他的在後文具體分析。command可能的值有兩種,與值為空(即沒有指令)一起區分三種啟動模式。

         ①command=="boot-recovery"時,系統會進入Recovery模式。Recovery服務會具體根據/cache/recovery/command中的指令執行相應的操作(例如,更新update.zip或擦除cache,data等)。

         ②command=="update-radia"或"update-hboot"時,系統會進入更新firmware(更新bootloader),具體由bootloader完成。

         ③command為空時,即沒有任何指令,系統會進入正常的啟動,最後進入主系統(main system)。這種是最通常的啟動流程。

         Android系統不同的啟動模式的進入是在不同的情形下觸發的,我們從SD卡中更新我們的update.zip時會進入Recovery模式是其中一種,其他的比如:系統崩潰,或則在指令行輸入啟動指令式也會進入Recovery或其他的啟動模式。

        為了解我們的update.zip包具體是怎樣在Recovery模式中更新完成,并重新開機到主系統的,我們還要分析Android中Recovery模式的工作原理。下一篇幅開始看具體的Recovery模式工作原理,以及其在更新中的重要作用。

上一篇:Android OTA更新原理和流程分析(二)---update.zip差分包問題的解決

下一篇:Android OTA更新原理和流程分析(四)---Android系統Recovery模式的工作原理

繼續閱讀