buildroot教程
Buildroot是Linux平台上一个开源的嵌入式Linux系统自动构建框架。
可以从http://buildroot.org/downloads/获得发行包。
也可通过github仓库获取:
git clone git://git.busybox.net/buildroot
解压buildroot源码目录如下:
arch: CPU架构相关的配置脚本
board: 在构建系统时,board默认的boot和Linux kernel配置文件,以及一些板级相关脚本
boot: uboot配置脚本目录
configs: 板级配置文件,该目录下的配置文件记录着该机器平台或者方案使用的工具链,boot, kernel,各种应用软件包的配置
dl: download的简写,下载一些开源包。第一次下载后,下次就不会再去从官网下载了,而是从dl/目录下拿开源包,以节约时间
docs:
fs: 各种文件系统的自动构建脚本
linux: 存放Linux kernel的自动构建脚本
package: 第三方开源包的自动编译构建脚本,用来配置编译dl目录下载的开源包
support:
system: 存放文件系统目录的和设备节点的模板,这些模板会被拷贝到output/目录下,用于制作根文件系统rootfs
toolchain/ 目录中存放着各种制作工具链的脚本
images/存储所有映像(内核映像,引导加载程序和根文件系统映像)的位置。这些是您需要放在目标系统上的文件。
build/构建所有组件的位置(包括主机上Buildroot所需的工具和针对目标编译的软件包)。该目录为每个组件包含一个子目录。
host/包含为主机构建的工具和目标工具链。
staging/是到内部目标工具链host/的符号链接
target/它几乎包含了目标的完整根文件系统。除了设备文件/dev/(Buildroot无法创建它们,因为Buildroot不能以root身份运行并且不想以root身份运行)之外,所需的一切都存在。
Buildroot为交叉编译工具链提供了两种解决方案:
*make help: 可以看到buildroot下make的使用细节,包括对package、uclibc、busybox、linux以及文档生成等配置。
make menuconfig(make linux-menuconfig...):进行图形化配置
make:编译
make命令通常将执行以下步骤:
make clean:delete all build products (including build directories, host, staging and target trees, the images and the toolchain)
make distclean: 等于make clean+删除配置
make show-targets:显示出本次配置所要编译所有的目标
make pkg-target:单独编译某个pkg模块
make pkg-rebuild:重新编译pkg
make pkg-extract:只下载解压pkg,不编译,pkg解压后放在 output/build/对应的pkg-dir目录下
make pkg-source:只下载某pkg,然后不做任何事情
Buildroot提供了函数框架和变量命令框架,采用它的框架编写的app_pkg.mk这种Makefile格式的自动构建脚本,将被package/pkg-generic.mk 这个核心脚本展开填充到buildroot主目录下的Makefile中去。
最后make all执行Buildroot主目录下的Makefile,生成你想要的image。 package/pkg-generic.mk中通过调用同目录下的pkg-download.mk、pkg-utils.mk文件,已经帮你自动实现了下载、解压、依赖包下载编译等一系列机械化的流程。
你只要需要按照格式写app_pkg.mk,填充下载地址,链接依赖库的名字等一些特有的构建细节即可。 总而言之,Buildroot本身提供构建流程的框架,开发者按照格式写脚本,提供必要的构建细节,配置整个系统,最后自动构建出你的系统。
添加如下语句:
menu "myown(fuzidage) package"
source "package/helloworld/Config.in"
为自己的软件包添加入口,这样在make menuconfig的时候就可以找到自己的软件包的Config.in,如果在make menuconfig的时候选中helloworld,那么‘BR2_PACKAGE_HELLOWORLD=y’也会同步到.config中去。
在package中新增目录helloworld,并在里面添加Config.in和helloworld.mk
1)Config.in
config BR2_PACKAGE_HELLOWORLD
bool "helloworld"
help
This is a demo to add myown(fuzidage) package.
helloworld/Config.in文件,可以通过make menuconfig可以对helloworld进行选择。只有在BR2_PACKAGE_HELLOWORLD=y条件下,才会调用helloworld.mk进行编译
2)helloworld.mk
################################################################################
#
# helloworld
#
################################################################################
HELLOWORLD_VERSION:= 1.0.0
HELLOWORLD_SITE:= $(CURDIR)/work/helloworld
HELLOWORLD_SITE_METHOD:=local
HELLOWORLD_INSTALL_TARGET:=YES
define HELLOWORLD_BUILD_CMDS
( M A K E ) C C = < s p a n c l a s s = " h l j s − s t r i n g " > " (MAKE) CC=" (MAKE)CC=<spanclass="hljs−string">"(TARGET_CC)" LD="$(TARGET_LD)" -C $(@D) all
endef
define HELLOWORLD_INSTALL_TARGET_CMDS
$(INSTALL) -D -m 0755 $(@D)/helloworld $(TARGET_DIR)/bin
endef
define HELLOWORLD_PERMISSIONS
/bin/helloworld f 4755 0 0 - - - - -
endef
$(eval $(generic-package))
helloworld.mk包括源码位置、安装目录、权限设置等。
通过上面对package/Config.in入口的配置, 我们可以通过make menuconfig,进入Target packages可以看见多了一个"myown(fuzidage) package"入口,选中helloworld。
然后make savedefconfig,对helloworld的配置就会保存到xxx_defconfig中.
可以和整个平台一起编译APP;或者make helloworld单独编译。
这两个文件在选中此APP之后,都会被拷贝到output/build/helloworld-1.0.0文件夹中。
然后生成的bin文件拷贝到output/target/bin/helloworld,这个文件会打包到文件系统中。
如果需要清空相应的源文件,通过make helloworld-dirclean。
经过第一次完整编译后,如果我们需要对源码包重新配置,我们不能直接在buildroot上的根目录下直接make,buildroot是不知道你已经对源码进行重新配置,它只会将第一次编译出来的文件,再次打包成根文件系统镜像文件。
那么可以通过以下2种方式重新编译:
直接删除源码包,然后make all
例如我们要重新编译helloworld,那么可以直接删除output/build/helloworld目录,那么当你make的时候,就会自动从dl文件夹下,解压缩源码包,并重新安装。这种效率偏低
进行xxx-rebuild,然后make all
也是以helloworld为例子,我们直接输入make helloworld-rebuild,即可对build/helloworld/目录进行重新编译,然后还要进行make all(或者make world 或者 make target-post-image)
如果要重新配置编译安装:
make <package>-reconfigure; make all
make O=/home/lyb/output
效果如下:可以看见编译产生的output目录在/home/lyb下了:
具体的build训练教程点击如下链接.
buildroot官方训练教程
转自:buildroot教程