讯为4412开发板嵌入式学习(十)uboot源代码结构

2023-11-03 07:00

本文主要是介绍讯为4412开发板嵌入式学习(十)uboot源代码结构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 三、uboot源代码结构
      • (一)、各文件/文件夹说明
    • 四、编译脚本build_uboot.sh分析

上一篇:讯为4412开发板嵌入式学习(九)uboot启动过程
下一篇:讯为4412开发板嵌入式学习(十一)Makefile代码分析

三、uboot源代码结构

uboot目录下文件列表如下:

在这里插入图片描述

(一)、各文件/文件夹说明

  • COPYING:版权相关的说明文档。
  • CREDITS:工作人员的名单。
  • E4212:和4212板子相关的文件。
  • E4412_N.bl1.bin:三星提供的BL1二进制文件。
  • MAINTAINERS:维护者名单
  • MAKEALL:编译相关文件。
  • Makefile:编译脚本。
  • README和readme.txt:项目说明文档。
  • System.map:
  • all00_padding.bin:用0补全的二进制文件。
  • api:常用的接口。
  • board:常用的主板文件,这里只保留4412开发板的主板相关目录/board/samsung/smdkc210。
  • build_uboot.sh:编译脚本。
  • common:与架构无关的通用文件。
  • config.mk:配置文件。
  • cpu:cpu相关的文件,可根据所使用的cpu选择。这里只保留和4412相关的文件夹arm_cortexa9。
  • disk:实现磁盘分区的接口。
  • doc:uboot相关说明文档。
  • drivers:uboot中的驱动文件,如外设iic、spi、gpio、usb、watchdog、dma和mmc等。
  • examples:uboot上可运行的例程
  • fs:操作系统内的文件系统,和文件系统格式化相关,如fat、ext2、ubifs、yaffs2、jffs2等文件系统。
  • include:包含通用的头文件以及与架构相关的文件,这里删除除asm-arm以外的以asm- 为前缀的文件夹。
  • lib前缀的文件:库相关的文件。只保留lib_arm、lib_generic和libfdt,删除其他以lib_为前缀的文件。可执行下列操作删除文件sudo rm -rf lib_avr32 lib_blackfin lib_i386 lib_m68k lib_microblaze lib_mips lib_nios lib_nios2 lib_ppc lib_sh lib_sparc
  • mkbl2:编译相关文件。
  • mkconfig:编译配置文件。
  • mkuboot:编译uboot脚本文件。
  • nand_spl和onenand_ipl:eMMC相关,可删除。sudo rm -rf and_spl onenand_ipl
  • net:网络驱动文件。
  • paddingaa:补丁文件。
  • post:自检文件。
  • rules.mk:脚本编译的说明文件。
  • sdfuse和sdfuse_q:sd卡烧写相关
  • tc4_cmm.cmm和uboot_readme.txt:三星tc4开发板相关文档。
  • tools:编译烧写等工具。
  • CodeSign4SecureBoot_POP和CodeSign4SecureBoot_SCP:安全启动相关的加密文件。

四、编译脚本build_uboot.sh分析

#!/bin/sh
#上面这句话用于指定脚本的解释器路径#$1代表传入的第一个参数,($0表示脚本文件名)-z是判断后面的参数是否为零
if [ -z $1 ]
then	
#如果无传入参数,则输出错误信息并退出脚本echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"echo "Please use correct make config.for example make SCP_1GDDR for SCP 1G DDR CoreBoard linux,android OS"echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"exit 0
fi
#如果输入参数$1的值是字符串"SCP_1GDDR"|"SCP_2GDDR"|"SCP_1GDDR_Ubuntu"|"SCP_2GDDR_Ubuntu"则执行下一步
if   [ "$1" = "SCP_1GDDR" ] ||   [ "$1" = "SCP_2GDDR" ] || [ "$1" = "SCP_1GDDR_Ubuntu" ] ||   [ "$1" = "SCP_2GDDR_Ubuntu" ]
then #根据传入参数设置对应的sec路径和核心板类型,这部分程序是三星提供的加密相关的文件sec_path="../CodeSign4SecureBoot_SCP/"CoreBoard_type="SCP"elif [ "$1" = "POP_1GDDR" ] || [ "$1" = "POP_1GDDR_Ubuntu" ]
thensec_path="../CodeSign4SecureBoot_POP/"CoreBoard_type="POP"elif [ "$1" = "POP_2GDDR" ] ||  [ "$1" = "POP_2GDDR_Ubuntu" ]
thensec_path="../CodeSign4SecureBoot_POP/"CoreBoard_type="POP2G"
elseecho "make config error,please use correct params......"exit 0
fi#获取CPU的核心数
#指令grep processor /proc/cpuinfo 输出
#processor	: 0
#processor	: 1
#processor	: 2
#processor	: 3
#$NF表示最后一个列(field),即输出最后一个字段的内容,即field=3,然后打印field+1
CPU_JOB_NUM=$(grep processor /proc/cpuinfo | awk '{field=$NF};END{print field+1}')
#获取当前目录
ROOT_DIR=$(pwd)
# '##*/'指的是ROOT_DIR目录最右面的/,即当前路径名。 另外'#/'指的是最左面的/
CUR_DIR=${ROOT_DIR##*/}#清除所有生成的文件
make distclean#删除板子和CPU相关的链接文件
rm ${ROOT_DIR}/board/samsung/smdkc210/lowlevel_init.S	
rm ${ROOT_DIR}/cpu/arm_cortexa9/s5pc210/cpu_init.S#判断传入参数$1是哪种情况
case "$1" in
#执行清除指令clean)#删除大多数的编译生成文件,但是会保留内核的配置文件.configecho make clean#删除所有的编译生成文件、内核配置文件(.config文件)和各种备份文件make mrproper;;
#除了clean以外	*)#判断是否存在三星提供的加密解密目录(directory)$sec_pathif [ ! -d $sec_path ]#不存在该目录thenecho "**********************************************"echo "[ERR]please get the CodeSign4SecureBoot first"echo "**********************************************"return#存在该目录fi#判断是何种输入参数,从而执行相关编译配置指令if [ "$1" = "SCP_1GDDR" ]thenmake itop_4412_android_config_scp_1GDDRelif [ "$1" = "SCP_2GDDR" ]thenmake itop_4412_android_config_scp_2GDDRelif [ "$1" = "POP_1GDDR" ]thenmake itop_4412_android_config_pop_1GDDRelif [ "$1" = "POP_2GDDR" ]thenmake itop_4412_android_config_pop_2GDDRelif [ "$1" = "SCP_1GDDR_Ubuntu" ]	thenmake itop_4412_ubuntu_config_scp_1GDDRelif [ "$1" = "SCP_2GDDR_Ubuntu" ]thenmake itop_4412_ubuntu_config_scp_2GDDRelif [ "$1" = "POP_1GDDR_Ubuntu" ]thenmake itop_4412_ubuntu_config_pop_1GDDRelif [ "$1" = "POP_2GDDR_Ubuntu" ]thenmake itop_4412_ubuntu_config_pop_2GDDRfi	#这部分使用上面获取的最大cpu核心数进行编译(最快速度)make -j$CPU_JOB_NUM#判断是否存在文件(file)BL2校验和文件if [ ! -f checksum_bl2_14k.bin ]thenecho "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"echo "There are some error(s) while building uboot, please use command make to check."echo "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!"exit 0fi#复制BL2校验和文件、u-boot文件cp -rf checksum_bl2_14k.bin $sec_pathcp -rf u-boot.bin $sec_path#删除BL2校验和文件rm checksum_bl2_14k.bin#进入安全启动文件目录cd $sec_path#./codesigner_v21 -v2.1 checksum_bl2_14k.bin BL2.bin.signed.4412 Exynos4412_V21.prv -STAGE2#gernerate the uboot bin file support trust zone#cat E4412.S.BL1.SSCR.EVT1.1.bin E4412.BL2.TZ.SSCR.EVT1.1.bin all00_padding.bin u-boot.bin E4412.TZ.SSCR.EVT1.1.bin > u-boot-iTOP-4412.bin#根据核心板类型,将几个二进制文件连接起来 BL1+BL2+padding+u-boou.bin+TZSW = u-boot-iTOP-4412.binif  [ "$CoreBoard_type" = "SCP" ]thencat E4412_N.bl1.SCP2G.bin bl2.bin all00_padding.bin u-boot.bin tzsw_SMDK4412_SCP_2GB.bin > u-boot-iTOP-4412.binelif [ "$CoreBoard_type" = "POP" ]thencat E4412.S.BL1.SSCR.EVT1.1.bin E4412.BL2.TZ.SSCR.EVT1.1.bin all00_padding.bin u-boot.bin E4412.TZ.SSCR.EVT1.1.bin > u-boot-iTOP-4412.binelif [ "$CoreBoard_type" = "POP2G"  ]thencat bl2.bin u-boot.bin E4412.TZ.SSCR.EVT1.1.bin > u-boot-iTOP-4412.binelseecho  "make uboot image error......" fi#移动u-boot-iTOP-4412.bin文件到uboot目录下mv u-boot-iTOP-4412.bin $ROOT_DIR#移除校验和文件和u-boot.bin文件rm checksum_bl2_14k.bin#rm BL2.bin.signed.4412rm u-boot.binecho echo ;;
esac

参考资料:
ARM 中断状态和SVC状态的堆栈切换 (异常)

ARM官方手册

IRAM IROM 区别

Linux grep 命令

Linux awk 命令

makefile下$^,$@,$?定义使用详解

Linux sed 命令

Shell 传递参数

makefile中的:BUILD_DIR解释

cat <<EOF

Tcsh脚本编程

makefile之findstring函数

$(origin variable)详解

uboot笔记之makefile分析

u-boot.lds链接文件详解

x86 Assembly Language Reference Manual

ARM Assembly Language Programming

这篇关于讯为4412开发板嵌入式学习(十)uboot源代码结构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/336425

相关文章

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

SpringBoot利用树形结构优化查询速度

《SpringBoot利用树形结构优化查询速度》这篇文章主要为大家详细介绍了SpringBoot利用树形结构优化查询速度,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一个真实的性能灾难传统方案为什么这么慢N+1查询灾难性能测试数据对比核心解决方案:一次查询 + O(n)算法解决

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、