Yocto詳解
參考:http://www.yoctoproject.org/docs/2.1/mega-manual/mega-manual.html#creating-a-general-layer-using-the-yocto-layer-script這篇文章第五章不錯
1.名詞解釋
- Yocto:Yocto是這個開源項目的名稱,該項目旨在幫助我們自定義Linux系統
- Poky:Poky有兩個含義。第一個含義是用來構建Linux的構建系統,值得注意的該Poky僅僅是一個概念,而非一個實體:它包含了BitBake工具、編譯工具鏈、BSP、諸多程序包或層,可以認為Poky即是Yocto的本質;此外Poky還有另外一層意思,使用Poky系統得到的默認參考Linux 發行版也叫Poky(當然,我們可以對此發行版隨意命名)。Poky的兩個含義千萬不能混淆
- Metadata:元數據集,所謂元數據集就是發行版內各基本元素的描述與來源
- Recipes:.bb/.bbappend文件,配方文件,描述了從哪獲取軟件源碼,如何配置,如何編譯。bbappend和bb的區別主要在於bbappend是基於bb的,功能是對相應的bb文件作補充和覆蓋,有點類似於“重寫”的概念
- Class:.bbclass文件
- Configuration:.conf文件,即配置文件,我們可以用它來改變構建方式
- Layers:即各種meta-xxx目錄,將Metadata按層進行分類,有助於項目的維護
- Bitbake:一個任務執行引擎,用來解析並執行Metadata
Output:即各種輸出image
總結:假如用烹飪一桌酒席來形容構建發行版,則Yocto就是飯店名,Poky就是廚房(以及提供作為參考的菜的搭配套餐),Metadata就是烹飪資源(.bb/.bbappend表示配方/配方上的貼士,.conf表示廚房裡的管事的小組長),Layers就是菜譜的分類(如川菜譜、粵菜譜),Bitbake就是廚師,Output就是得到的一桌酒席
2.Yocto的架構
假設現在有一個已經構建好的Yocto環境。有關Yocto的具體操作和環境構建詳見Yocto的使用實例
注意:该目录省略了很多不必要的细节,只把重要的文件显示了出来
| |__bblayers.conf(和build目录中的一样)
| |__local.conf(和build目录中的一样)
|__meta-avi(放硬件无关的内容,主要和文件系统相关的东西)
| | | |__avi-common-package.inc
| | | |__avi-image-core.inc
| | | |__avi-image-core.bb
| | |__imx6-avi-super.conf
| | |__imx6-avi_mini.conf
| | |__u-boot-imx6-avi.bb
| | |__avi-image-core.bbappend
- 假設我們的項目名稱叫imx6_avi,那麼進入我們的項目目錄,查看,其結構
BSPDIR := "/home/username/yocto/imx6_avi_super"
${BSPDIR}/sources/poky/meta \
${BSPDIR}/sources/poky/meta-yocto \
${BSPDIR}/sources/meta-openembedded/meta-oe \
${BSPDIR}/sources/meta-openembedded/meta-multimedia \
${BSPDIR}/sources/meta-qt5 \
${BSPDIR}/sources/meta-qt5-avi \
${BSPDIR}/sources/meta-fsl-arm \
${BSPDIR}/sources/meta-avi \
${BSPDIR}/sources/meta-imx6-avi \
本文来自 杨YX 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/yanghanxing110/article/details/77737471?utm_source=copy

- 這些layer目前是被enable了,那麼是否可以認為,這些layer中的配方也全部被使能了呢?答案固然是否定的,我們的發行版中不可能把所有的軟件包放進去。在Yocto中,這個選擇配置操作是由好多個conf、bb文件協同完成的,並不存在一個總的大綱,這也是和buildroot最大的不同之處(buildroot是由menuconfig來進行大綱式的配置)。可以理解為Yocto是“分封制”,皇帝說的不一定能落實,具體還是各種大小地方官說了算;而buildroot是“中央集權制”,皇帝一人說了算

- 如何理解Yocto的配置方法?這要從發行版的定制流程說起。我們的目的很簡單,是要得到uboot、kernel、rootfs這三個image;Yocto的目的也很簡單,它要經過一級一級配置,逐步縮小配方,直至得到uboot、kernel、rootfs這三個image 。每一級需要哪些配方,由該級對應的配置文件(conf/bb)決定。越上級的配置是越籠統的,越下級的配置越細緻。如果下級的配置項相對於上級有補充或者衝突,則以下級的內容為準,可以認為下級會對上級進行“重寫”。這其實有點類似交通法規


有關構建的路線和流程:對於整個發行版構建,雖然每一級的配方由(conf/bb)決定,但是每一級路線和方向的選擇,是由我們最終bitbake的對象決定的,比如我們最終bitbake avi-image-core,我們想要獲得rootfs.img,那麼:
- 第一步Poky就會從local.conf開始,一路向下,一級一級配置,直到配置到和rootfs有關的那一堆bb,最終形成完整完全的配方
- 然後獲取配方需要的資源,比如各種軟件包,比如kernel的源碼
- 最後把所有的資源編譯出我們需要的鏡像

最後說一下bitbake,比如我們要選擇編譯rootfs.img,那麼使用bitbake avi-image-core即可,但是很多時候並不直接採用這種做法。大多數情況下我們會在項目目錄下寫一個Makefile,裡麵包含各種各樣的功能,內部以bitbake指令實現
3.配置文件詳解
上一節簡單介紹了Yocto是如何配置我們的項目,這一節開始分析具體的配置文件
沒有留言:
張貼留言