admin 管理员组

文章数量: 887021

继续阅读lib/main.sh

275 # Compile u-boot if packed .deb does not exist
276 if [[ ! -f $DEST/debs/${CHOSEN_UBOOT}_${REVISION}_${ARCH}.deb ]]; then
277         if [[ -n $ATFSOURCE ]]; then
278                 compile_atf
279         fi
280         compile_uboot
281 fi
282 
283 # Compile kernel if packed .deb does not exist
284 if [[ ! -f $DEST/debs/${CHOSEN_KERNEL}_${REVISION}_${ARCH}.deb ]]; then
285         compile_kernel
286 fi

这一章节我们解析compile_uboot,在分析compile_uboot之前,先来简单说一下comiple_atf,有些ARM CPU其启动过程会复杂一点,ARM公司 为 Armv7 Armv8-A 安全引导提供参考应用。各半岛体厂家为其CPU进行定制,如支持固件加密功能。如下为NXP LS1043A的引导过程。

接下来我们再来分析一下

285行 compile_kernel

在lib/compilation.sh:253 有针对compile_kernel()的实现,代码量有点多,我们不贴出来了。

总结一下其流程流程:

  1. 针对内核进行打补丁

  2. 编译内核

  3. 制作针对内核的deb包。

这些都比较简单不再详细分析。

其实我们还少讲一点,就是补丁的生成,补丁不是使用git diff/svn diff生成的。

diff –uNr org_dir change_dir > xxxx.patch

然后将其生成的补丁放到:

patch/kernel/XXXX-default/XXXXX.patch

uboot的补丁也是这样生成的。

继续阅读lib/main.sh

302 # create board support package
303 [[ -n $RELEASE && ! -f $DEST/debs/$RELEASE/${CHOSEN_ROOTFS}_${REVISION}_${ARCH}.deb ]] && create_board_package
304 
305 # create desktop package
306 [[ -n $RELEASE && ! -f $DEST/debs/$RELEASE/${CHOSEN_DESKTOP}_${REVISION}_all.deb ]] && create_desktop_package
307 
308 # build additional packages
309 [[ $EXTERNAL_NEW == compile ]] && chroot_build_packages

在这里首先要了解debootstrap,可以再回顾一下前面的两篇博文,如下:

learning armbian steps(4) ----- armbian 技术内幕

learning armbian steps(5) ----- armbian 构建arm rootfs

比较容易理解接下来要讲解的这几个函数。

如下这几个SHELL函数,包含了armbian在debootstrap基础上的一些私有定制及文件系统打包及系统镜象的制作。

create_board_package

chroot_build_packages

create_desktop_package

debootstrap_ng

至此整个armbian的编译过程已大体分析完毕,分析源代码的主要过程是更好的定制镜像,找到点,找到位置,整体把握其设计的思路。

当时在使用armbian 构建文件系统时,相关的资料比较少,本系列博文记录本人学习armbian的过程,希望对各位有益!

本文标签: 源码 Armbian learning steps