編輯:關於Android編程
android在啟動時uboot判斷有沒有組合健按下或者cache分區的升級文件來決定進入哪個系統(可能還有別的判斷方式)
有組合健按下或者cache分區有升級文件,則加載recovery.img進入升級系統。否則加載boot.img進入正常系統
此次記錄3個要點:
1:boot.img的結構
2:如何作成boot.img
3:uboot 如何尋找boot.img
一:boot.img的結構如下:
+-----------------+
|boot header | 1 page
+-----------------+
|kernel | n pages
+-----------------+
|ramdisk | m pages
+-----------------+
|second stage | o pages
+-----------------+
其中:
boot header記錄了boot.img的一些信息,
kernel即內核壓縮文件zImage,
ramdisk即根文件系統,
second stage備用
boot header一共占了一頁,默認2K。
前面的數據是struct boot_img_hdr,後面拿0補齊,湊齊2K。
結構體如下:
struct boot_img_hdr
{
unsigned char magic[BOOT_MAGIC_SIZE];
unsigned kernel_size; /* 內核大小*/
unsigned kernel_addr; /* 內核位置*/
unsigned ramdisk_size; /* root根文件系統大小*/
unsigned ramdisk_addr; /* 根文件系統位置*/
unsigned second_size; /* 擴展,備用*/
unsigned second_addr; /* 擴展,備用*/
unsigned tags_addr; /*傳參數用的物理內存地址,它作用是把bootloader中的參數傳遞給kernel*/
unsigned page_size; /* 頁大小,默認2K*/
unsigned unused[2]; /* 擴展,備用*/
unsigned char name[BOOT_NAME_SIZE]; /* 產品名*/
unsigned char cmdline[BOOT_ARGS_SIZE]/* 啟動參數*/;
unsigned id[8]; /*可以重用,如時間戳,校驗位*/
};
二:boot.img的制作
mkbootimg命令制作boot.img,命令路徑:~/out/host/linux-x86/bin/mkbootimg,代碼路徑:~/system/core/mkbooting
三:uboot加載 boot.img
mkbootimg命令參數如下:
kernel : zImage的路徑
ramdisk: ramdisk.img的路徑
second : 備用文件路徑
cmdline : 內核參數
board : 產品名
base : base地址
pagesize : 頁大小
output: 輸出路徑
其中kernel,ramdisk,output是必須要傳入的參數,其它都是可選的
示例:
mkbootimg --kernel zImage --ramdisk ramdisk.img --base 0x10800000 --output boot.img
uboot在加載boot.img時使用booti 命令,例如:booti mmc2 ,表示設備假如有幾個SD卡,或者emmc時,去第二個資源尋找,boot.img
uboot會去第二個資源設備上的第一個分區讀取boot.img
首先讀取boot.img中的boot header,從中獲取需要的信息
這樣就確定了內核和根文件系統在 boot.img中的位置,剩下的就是加載到內存中了
其中內核加載到內存的位置是由base參數決定的,默認是0x10800000
現象是:Windows下Eclipse可以連接Device裡能顯示設備名稱,但是在Mac OS X下的Eclipse Device始終不能顯示連接。解決方法:1.把And
好吧,先給大家展示效果圖:xml文件:<LinearLayout xmlns:android=http://schemas.android.com/apk/res/
前言隨著音視頻領域的火熱,在很多領域(教育,游戲,娛樂,體育,跑步,餐飲,音樂等)嘗試做音視頻直播/點播功能,那麼作為開發一個小白,如何快速學習音視頻基礎知識,了解音視頻
安卓系統的刷機包分線刷包和卡刷包兩種,一般後綴為ROM的是線刷包,卡刷包的後綴名是ZIP壓縮文件,本身ROM的格式上就有區別,那麼用刷機精靈的rom可以卡刷