learning armbian steps(12) ----- armbian 源码分析(七)

继续阅读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

高级一点的CPU,其启动过程会复杂一点,ARM公司 为 Armv7 Armv8-A 安全引导提供参考应用。各半岛体厂家为其CPU进行定制,如支持固件加密功能。如下为NXP LS1043A的引导过程。

接下来我们再来分析一下

285行 compile_kernel

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

总结一下其流程

要主要的流程:

  针对内核进行打补丁

  编译内核

  制作针对内核的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

原文地址:https://www.cnblogs.com/lianghong881018/p/12145979.html