yocto构建
前言:
本次使用著名的yocto
在Ubuntu上构建一个最小的Linux发行版,yocto使用起来非常灵活方便,所以本次使用它来构建。
yocto可以为嵌入式硬件开发板构建自己的发行版,这次构建一个运行在QEMU
上的最小化Linux,并在QEMU上实际运行
步骤:
实际开发中,一般是远程登录Linux系统,所以本次使用ssh登录Ubuntu16.04,在Ubuntu16.04上打开ssh登录的指令是
sudo apt-get install openssh-server
在SecureCRT或xshell等其他软件中新建连接,选择SSH登录方式,在Connection选项中,填入Ubuntu的主机名称,选择SSH2协议。SSH2选项中,在Hostname中填入Ubuntu的IP地址,端口号选择22,Friewall选择None,用户名按照实际的Ubuntu登入用户名填写即可。SecureCRT设置完成后,在VMWare软件中启动Ubuntu,在Windows下打开SecureCRT连接登录Ubuntu。
安装前建议先切换到国内镜像源,方法是更改sources.list配置文件更改软件源
sudo gedit /etc/apt/sources.list
打开后加入如下内容,保存
# 默认注释了源码镜像以提高 apt update 速度,如有需要可自行取消注释
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal main restricted universe multiverse
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-updates main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-updates main restricted universe multiverse
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-backports main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-backports main restricted universe multiverse
deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-security main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-security main restricted universe multiverse
# 预发布软件源,不建议启用
# deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-proposed main restricted universe multiverse
# deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ focal-proposed main restricted universe multiverse
当然也可以使用Ubuntu自带的软件更新器更换软件源,打开软件和更新,然后选择自己需要的软件源,关闭,就会重新载入。
执行完后,在终端输入指令更新本地软件包,升级本地软件包(不升级不输入第二个指令)
sudo apt update
sudo apt upgrade
install prerequisites for Yocto:在创建Linux发行版之前先下载下面的包,下载最新的yocto稳定分支(Poky是其最小开发环境)。
apt-get install wget git-core unzip make gcc g++ build-essential subversion sed autoconf automake texi2html texinfo coreutils diffstat python-pysqlite2 docbook-utils libsdl1.2-dev libxml-parser-perl libgl1-mesa-dev libglu1-mesa-dev xsltproc desktop-file-utils chrpath groff libtool xterm gawk fop
开发环境要安装的软件包将近 1GB 大小。
接下来克隆poky
的morty
稳定分支
git clone -b morty git://git.yoctoproject.org/poky.git
进入poky目录,然后运行下面的命令为yocto开发环境设置/导出环境变量
source oe-init-build-env
在运行了open embedded (oe) 的构建环境脚本之后,终端里的路径会自动切换到 build
目录,以便进行之后行发行版的的配置和构建。
conf
目录下创建的文件 local.conf
是 Yocto 用来设置目标机器细节和 SDK 的目标架构的配置文件。在文件中可知,我们这里设置的目标机器为qemux86-64
。在 local.conf
中取消下面参数的注释符号
Configure local.conf file
-
DL_DIR ?= "${TOPDIR}/downloads"
Set SSTATE_DIR
-
SSTATE_DIR ?= "${TOPDIR}/sstate-cache"
Set TMPDIR
-
TMPDIR ?= "${TOPDIR}/tmp"
Set PACKAGE_CLASSES and SDKMACHINE
-
PACKAGE_CLASSES ?= "package_rpm"
-
SDKMACHINE ?= "i686"
Set debug-tweaks option
-
EXTRA_IMAGE_FEATURES ?= "debug-tweaks"
我们并不使用任何图形化工具来创建 Linux OS,比如 toaster
(hob
已经不再支持了)。
现在运行下面的bitbake
工具命令开始为选定的目标及其下载和编译软件包
bitbake core-image-minimal
要在普通Linux用户下运行上面的指令,而不是root用户,在root用户下运行会报错:“Do not use Bitbake asroot.”
再运行一次导出环境变量的脚本,重新执行相同的命令启动下载和编译过程
source oe-init-build-env
bitbake core-image-minimal
构建脚本组件第一步是解析配置recipe
。在下载了 SDK 和必要的库之后,下一步工作是下载并编译软件包。这一步将会执行 2-3 小时,因为首先要下载需要的软件包,然后还要为新的 Linux 发行版编译这些软件包。
为目标机器类型 qemux86-64
编译好的新镜像位于 build/tmp/deploy/images/qemux86-64
重启虚拟机后,执行这一步报错找不到命令,需要重新拉取环境变量
runqemu qemux86-64
上面的命令如果运行在 Putty
上会产生一个错误
......
Could not initlalize SDL(No available video device) - exiting
......
通过rdp
在 Ubuntu 平台上再次运行上面的命令。
runqemu qemux86-64
可以看到,为运行基于yocto的Linux发行版的qemu打开了一个新屏幕。
默认的用户名是 root
,密码为空
在这个最小版本Linux上运行命令date
、ifconfig
、uname
,结果正常。
以上就是使用yocto创建新的Linux发行版的过程。
via: https://www.howtoforge.com/tutorial/how-to-create-your-own-linux-distribution-with-yocto-on-ubuntu/
教程:B站嵌入式孙工:iMX6ULL采用Yocto构建嵌入式Linux系统 - 第1讲 Yocto开发环境介绍(上)_哔哩哔哩_bilibili