日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Yocto基本概念及介绍

發布時間:2025/3/21 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Yocto基本概念及介绍 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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的使用實例

  • 假設我們的項目名稱叫imx6_avi,那么進入我們的項目目錄,查看,其結構為
注意:該目錄省略了很多不必要的細節,只把重要的文件顯示了出來 imx6_avi_super|__Makefile|__build| |__cache| |__conf| |__bblayers.conf| |__local.conf ||__sources|__base|__cache| |__conf| |__bblayers.conf(和build目錄中的一樣)| |__local.conf(和build目錄中的一樣)|||__meta-avi(放硬件無關的內容,主要和文件系統相關的東西)| |__classes| |__conf| | |__distro| | | |__imx6.conf| | |__layer.conf| || |__recipes-core| | |__busybox| | |__images| | | |__avi-common-package.inc| | | |__avi-image-core.inc| | | |__avi-image-core.bb| | | |__avi-image.inc| | |__ifupdown| | |__openssh-keys| || |__recipes-qt| |__recipes-graphics| |__recipes-devtools| ||__meta-imx6-avi| |__conf| | |__machine| | |__layer.conf| | |__include| | |__imx6-avi-super.conf| | |__imx6-avi_mini.conf| | | |__recipes-bsp| | |__u-boot| | |__u-boot-imx6-avi.bb| || |__recipes-core| | |__images| | |__avi-image-core.bbappend| || |__recipes-kernel | |__linux | |__linux-imx6-avi/ | | |__defconfig | |__linux-imx6-avi.bb |||__meta-Exynos-avi|__meta-qt5-avi|__meta-fsl-arm|__meta-openembedded|__meta-qt5|__poky|__meta-skeketon|__meta-yocto|__meta|__classes|__conf|__recipes-bsp||__recipes-connectivity| |__dhcp| |__nfs-utils||__recipes-devtools|__recipes-core
  • 首先來分析一下目錄結構,不難發現主要有三級構成:meta-xxx->recipes-yyy->zzz/ttt.bb。比如:meta-avi-> recipes-core->openssh-keys
  • meta-xxx就是layer(菜譜的分類如川菜譜、粵菜譜),recipes-yyy就是Metadata(具體某一本菜譜),zzz就是菜譜上具體的一個配方
  • 從目錄中不難看出,主要有這么幾個layer

    • meta-avi:由我們創建并維護。和avi有關的項目需要的配方。可以認為這個目錄中的配方都是通用的、與平臺無關的內容
    • meta-imx6-avi:由我們創建并維護。imx6平臺avi項目需要的配方
    • meta-Exynos-avi:由我們創建并維護。Exynos平臺avi項目需要的配方
    • meta-qt5-avi:由我們創建并維護。avi項目中qt5需要的配方
    • meta-fsl-arm:飛思卡爾官方推出的配方大全
    • meta-openembedded:openembedded推出的配方大全
    • meta-qt5:qt5官方推出的qt5配方大全
    • poky中的一堆meta:yocto官方推出的參考配方。雖然這些meta被放在了poky里面,但是還是不影響使用的,他們具有和上面那些meta相同的地位,如下圖

    不難看出,這里面很多的layer只是我們照搬過來的,目的是為了借用里面現成的配方(可以認為這些layer充當了“庫”),而真正由我們維護的僅僅是幾個名字中帶有avi的layer,而且它們是依賴于那些充當“庫”的layer的。如下圖?

  • 介紹完了layer,那么問題來了,那么是否可以認為,這些layer全部被enable了呢?答案固然是否定的,我們的項目是imx6_avi_super,顯然不可能去包含meta-Exynos-avi這個三星平臺專用的layer
  • 具體的layer選擇由imx6_avi_super/sources/conf/bblayers.conf負責,直觀位置在前面目錄中可以體現。仔細觀察該文件,重點在BBLAYERS這個變量,里面有一些layer,這些layer就被enable了。不難發現這里面并沒有meta-Exynos-avi,這也恰好印證了我們建立開發環境(repo sync)時,從git倉庫中拉的是imx6_avi_super這個項目對應的Poky。
LCONF_VERSION = "6"BBPATH = "${TOPDIR}" BSPDIR := "/home/username/yocto/imx6_avi_super" BBFILES ?= "" BBLAYERS = " \ ${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 \

  • 這些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是如何配置我們的項目,這一節開始分析具體的配置文件

  • local.conf:

總結

以上是生活随笔為你收集整理的Yocto基本概念及介绍的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。