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