迅为iTOP-STM32MP157开发板编译U-Boot
uboot 是一段裸机代码,它的实现非常复杂,主要是初始化一些硬件,部署整个计算机系统,将内核读到内存,根据环境变量去启动内核,并向内核传递参数。它的目标就是启动内核,内核启动后它的生命也随之结束。
u-boot 是 SourceForge 上的开源项目,由一个人发起,然后由整个世界所有感兴趣的人共同维护发展而来的一个 bootloader,bootloader 是用来引导和加载内核,向内核传递参数的,是内核引导程序的统称,bootloader 除了 u-boot 还有 bios,LilO,redboot,vivi 等。Uboot 的源码存放路径为“iTOP-STM32MP157 开发板光盘资料\04_TF-A、uboot 和内核源码\uboot”,如下图所示:
<ignore_js_op>
Uboot 源码的编译器和编译 TF-A 的编译器相同为 gcc-arm-10.3-2021.07-x86_64-arm-none-linux-gnueabihf。将源码拷贝源码到“/home/topeet”目录下,使用如下命令解压:tar -vxf u-boot-stm32mp-2020.01-r0_20210817.tar.gz(注意,日期后缀名可能会更新)解压源码压缩包,解压完成之后得到“u-boot-stm32mp-2020.01-r0”文件夹。
使用命令进入 uboot 的源码如下图所示:cd u-boot-stm32mp-2020.01-r0/
<ignore_js_op>
三个个文件分别为编译的 makefile 文件和 EMMC 和 TF 卡编译的源码。
我们以 EMMC 源码编译为例(TF 卡的 uboot 镜像编译步骤相同),使用命令
cd emmc_u-boot-stm32mp-2020.01/
进入到对应的源码目录下,如下图所示:
<ignore_js_op>
然后使用命令“./create.sh”进行编译,如下图所示:
<ignore_js_op>
编译过程如下图所示:
<ignore_js_op>
编译完成如下图所示:
<ignore_js_op>
编译完成之后会在上一级目录产生 build-trusted 目录,用来存放编译生成的文件。而我们所需要的文件为 u-boot.stm32 如下图所示:
<ignore_js_op>
至此我们的 uboot 编译就完成了。然后在 build-trusted 目录下使用以下命令cp u-boot.stm32 /home/image/uboot/emmc_emmc_u-boot.stm32
来替换掉烧写文件中关于 emmc 的 uboot 即可(每个人 image 的路径都不同,要根据自己的情况来完善命令)。
<ignore_js_op>
核心板参数
尺寸: 46mm*58mm
CPU: STM32MP157A
主频: 650M
内存: 1G
存储: 8G
工作电压: 直流5V供电
系统支持: 流畅运行最小Linux系统、Buildroot、QT5.12.10、ubuntu_base_20.04、Debian系统
引角扩展: 引出脚多达240个,满足用户各类扩展需求
底板参数:
尺寸: 190mm*125mm
POWER: 电直流电源输入接口,12V/3A+电源输入
SWITCH: 电源开关
DIP: SWITCH 4位拨码开关
ADC电位器: 1路
SDIO接口: 1个
JTAG: 1个
CAMERA接口: 1个
CAN接口: 1路CAN
User Key: 5个功能按键
MIC: 支持MIC输入
PHONE: 支持耳机输出
串口: 3路
USB Host: 2路 USB Host,支持USB2.0协议
TF Card: 1个标准TF卡接口
网口: 1路千兆以太网口
LED: 3个(1个电源指示灯,2个可控LED)
HDMI接口: 1路
LCD接口: 1路LVDS9(HDMI口输出LVDS信号),1路RGB
USB OTG: 2路 USB OTG2.0
RTC: 1个
RS485接口: 1路
WIFI/蓝牙芯片: 1路
4G模组选配: 1个
六轴传感器: 1个
蜂鸣器: 1个
红外传感器: 1个
光环境传感器: 1个
温湿度传感器: 1个
SPDIF接口: SPDIF输入、SPDIF输出