Yocto的使用实例
本文以往rootfs中添加一个软件包为例,阐述使用Yocto定制发行版的大致流程。
有关Yocto的功能和结构介绍,详见Yocto详解
1.开发环境构建
一般有两种情况:一种是公司服务器中已有了Yocto,我们只需在个人账户下简单复制Yocto开发环境即可。另一种情况是什么都没有,在服务器或个人电脑上从零搭建Yocto开发环境。
在这里我们假设已经有了Yocto需要的基本依赖库,如果真的要从零开始配各种依赖库,可以参考https://www.ibm.com/developerworks/cn/linux/l-yocto-linux/
首先最重要的是得到Repo工具,Repo 工具为 Git 的封装,底层是使用 Git 命令进行下载的,我们将使用它来获取Poky。我们假设服务器中已经有了一个repo,那么很简单,直接复制到自己账户目录下
#在服务器中登录自己的账号
mkdir ~/bin
cp /xxx/bin/repo ~/bin/repo
chmod a+x ~/bin/repo
echo "export PATH=~/bin:$PATH" >> ~/.bashrc
~/.bashrc
如果服务器中没有呢?可以这样子,具体的我也没试过,应该是可以的
git clone https://gerrit.googlesource.com/git-repo
cd git-repo/
git checkout v1.12.4
cp ../git-repo/repo ~/bin/repo
- 创建不同的项目路径,如果公司有多个项目在使用Yocto和git进行维护的话,那么这一步是必须的,因为repo将要从公司的git仓库中获取不同版本的Poky,我们必须在正确的项目目录下工作。
比如我们目前正要操作的项目,叫imx6_avi:
mkdir imx6_avi
cd imx6_avi
- 然后利用repo来获取Poky,对于有git仓库的公司来说,一般会把数个metaLayer放git服务器中维护,每个metaLayer具有数个branch,一个branch就对应一个项目,我们只要在刚刚创建的路径名为项目名的路径中使用repo,即可获取该项目对应的数个metaLayer,即Poky:
repo init -u xxx@gitxxx.xxx.org:xxx/xxx.git -b "xxx"
repo sync
如果服务器中没有的话,那就要从其他地方获取了,比如原厂提供的:
repo init -u git://git.freescale.com/imx/fsl-arm-yocto-bsp.git -b imx-3.10.17-1.0.0_ga
repo sync
- 创建输出路径,中间文件和生成的image都将被放在该目录中
mkdir ~/imx6_avi/build
chmod 777 ~/imx6_avi/build
- 对sources目录进行初始化构建环境,通过这一步才能在sources目录下使用bitbake等命令,通过传参来指定环境,比如下面就用imx6来指定了目标环境为imx6,注意这种脚本程序尽量用source指令执行,很多时候用./来执行是不行的
source xxx-init-build-env sources imx6