接下來準(zhǔn)備把以前寫的Android編譯系統(tǒng)方面的資料整理成MarkDown.
這次Android編譯系統(tǒng)的代碼基于Android 6.0.
在整體來看Android編譯系統(tǒng)的時候狂丝,有兩個概念必須要十分清楚:Product和Device.
Product產(chǎn)品
不同的人對于產(chǎn)品的理解不一樣但绕,對于設(shè)計人員來講仿野,不同的產(chǎn)品對應(yīng)著不同的外觀所袁,不同的尺寸监婶,不同的材質(zhì)屉佳。但是對于Android來講览芳,產(chǎn)品就是不同模塊的組合斜姥。每一個模塊由一個Android.mk編譯。模塊分為三類:
- 基礎(chǔ)模塊
比如AMS沧竟,PMS和Binder等都是基礎(chǔ)模塊铸敏,這些模塊都是必須要編譯的,否則Android無法啟動
-
可選的基礎(chǔ)模塊
比如packages/apps下面的應(yīng)用
項目私有模塊
大部分是和硬件特性相關(guān)的模塊悟泵,比如雙攝像頭搞坝,指紋識別等。
我們一般都是根據(jù)足以讓用戶區(qū)分的硬件特性來定義產(chǎn)品魁袜,比如小米5和小米6是兩款產(chǎn)品桩撮,他們擁有不同的外觀設(shè)計,不同的硬件規(guī)格峰弹,比如小米5是單攝像頭店量,小米6是雙攝像頭,他們的CPU也不一樣鞠呈,他們的外觀和材質(zhì)也不一樣融师。這些不同的硬件feature軟件上就對應(yīng)不同的模塊,模塊的不同構(gòu)成了產(chǎn)品的不同蚁吝。
Device設(shè)備
同一個產(chǎn)品可能有不同的設(shè)備旱爆,比如小米5會有全網(wǎng)通版本,移動版本窘茁,電信版本等怀伦。這些不同的版本在軟件概念上就對應(yīng)不同的Device。雖然他們都叫小米5山林,但是由于硬件板級上的不同房待,造成了不同的Device.
我們編譯出來的img,最終都要燒到對應(yīng)的板子上驼抹,也就是對應(yīng)的Device上桑孩。那么我們在編譯過程中怎么確定我們正在編譯的這個Rom是對應(yīng)哪個Device呢?答案就是Target_Device這個變量框冀,這是在編譯過程中非常重要的一個變量流椒,該變量決定了我們的img最終可以燒寫到哪個Device上。
所以總結(jié)如下:
- Product決定了這編譯過程中都有哪些模塊需要編譯
- Device決定了我們編譯出來的img可以燒寫到哪些設(shè)備上明也。
既然Target_Device這么重要宣虾,我們就來看一下編譯系統(tǒng)是如何確定Target_Device的值得惯裕。
根據(jù)Android編譯規(guī)范,我們的編譯過程是從 source build/envsteup.sh
開始的安岂。
我們看一下這個envsetup.sh都做了哪些事情:
定義了很多函數(shù)轻猖,比如mm,lunch等域那,也就是說只有在執(zhí)行完這一步之后咙边,這些函數(shù)才可以使用
-
然后執(zhí)行
for f in `test -d device && find -L device -maxdepth 4 -name 'vendorsetup.sh' 2> /dev/null | sort` \ `test -d vendor && find -L vendor -maxdepth 4 -name 'vendorsetup.sh' 2> /dev/null | sort`
去device和vendor目錄下的4層文件夾之內(nèi)尋找vendorsetup.sh這個文件。
這個vendorsetup.sh這個文件是做什么用的呢次员?
所有的vendorsetup.sh幾乎都有這么一句類似的話
add_lunch_combo aosp_deb-userdebug
,這句話的作用是把aosp_deb-userdebug加入到lunch菜單中败许。
我們在輸入lunch命令之后,會出現(xiàn)一個編譯菜單淑蔚,比如:
- aosp_x86_64-eng
- aosp_deb-userdebug
- aosp_flo-userdebug
一般這個編譯菜單格式固定:ProductName_DeviceName-BuildVarient
比如aosp_deb-userdebug,ProductName是aosp,DeviceName是deb市殷,BuildVarient是userdebug。
在我印象中刹衫,在2.3之前必須按照這種格式定義lunch菜單醋寝,系統(tǒng)會根據(jù)這個這里的定義來推斷Target_Device的值。但是由于現(xiàn)在我們可以在Makefile中指定Product_Device這個變量的值带迟,然后會根據(jù)Product_Device的值去推斷Target_Device的值音羞,所以現(xiàn)在也可以不按照這種格式來定義lunch菜單了。
還有一個tips就是:
在Makefile中仓犬,類似Target_XXX這種格式的變量嗅绰,都是編譯框架根據(jù)別的變量自動生成的,所以一般我們不要再Makefile中更改Target_XXX這種形式的變量
Product_XXX這種形式的變量是編譯系統(tǒng)提供給我們來修改的搀继,我們可以對Prodcut_XXX這種形式的變量賦值窘面。比如Product_Device := flo,編譯框架會根據(jù)Product_Device的值來生成Target_Device的值。