Android系統Recovery工作原理之使用update.zip升級過程分析(三)---Android系統的三種啓動模式

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

一、       系統更新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系統啓動後可能進入的模式有以下幾種:

       (一) 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模式工作原理,以及其在更新中的重要作用。

發佈了11 篇原創文章 · 獲贊 6 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章