admin管理员组文章数量:1122851
继续阅读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()的实现,代码量有点多,我们不贴出来了。
总结一下其流程流程:
-
针对内核进行打补丁
-
编译内核
-
制作针对内核的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的过程,希望对各位有益!
版权声明:本文标题:learning armbian steps(12) ----- armbian 源码分析(七) 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/biancheng/1725892016a1025902.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论