UBoot初次编译

1.U-Boot初次编译
首先在Ubuntu中安装ncurses库,否则编译会报错,安装命令如下:
sudo apt-get install libncurses5-dev

在Ubuntu中创建存放uboot的目录然后在此目录下新建一个名为“alientek_uboot”的文件夹用于存放正点原子提供的uboot源码。alientek_uboot文件夹创建成功以后使用FileZilla软件将正点原子提供的uboot源码拷贝到此目录中,正点原子提供的uboot源码已经放到了开发板光盘中,路径为:开发板光盘->1、例程源码->3、正点原子Uboot和Linux出厂源码-> uboot-imx-2016.03-2.1.0-ge468cdc-v1.5.tar.bz2。

在这里插入图片描述

将uboot拷贝到Ubuntu中
使用如下命令对其进行解压缩:
tar -vxjf uboot-imx-2016.03-2.1.0-g8b546e4.tar.bz2

在这里插入图片描述

 除了uboot-imx-2016.03-2.1.0-g8b546e4.tar.bz2这个正点原子提供的uboot源码压缩包以外,其他的文件和文件夹都是解压出来的uboot源码。
1、512MB(DDR3)+8GB(EMMC)核心板
如果使用的是512MB+8GB的EMMC核心板,使用如下命令来编译对应的uboot:
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- distclean
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- (加空格)
mx6ull_14x14_ddr512_emmc_defconfig
make V=1 ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- -j12
这三条命令中ARCH=arm设置目标为arm架构,CROSS_COMPILE指定所使用的交叉编译器。第一条命令相当于“make distclean”,目的是清除工程,一般在第一次编译的时候最好清理一下工程。第二条指令相当于“make mx6ull_14x14_ddr512_emmc_defconfig”,用于配置uboot,配置文件为mx6ull_14x14_ddr512_emmc_defconfig。最后一条指令相当于 “make -j12”也就是使用12核来编译uboot。当这三条命令执行完以后uboot也就编译成功了。

在这里插入图片描述

编译完成以后的alentek_uboot文件夹:

在这里插入图片描述

编译后的uboot源码
可以看出,编译完成以后uboot源码多了一些文件,其中u-boot.bin就是编译出来的uboot二进制文件。uboot是个裸机程序,因此需要在其前面加上头部(IVT、DCD等数据)才能在I.MX6U上执行,图30.2.4中的u-boot.imx文件就是添加头部以后的u-boot.bin,u-boot.imx就是我们最终要烧写到开发板中的uboot镜像文件。
每次编译uboot都要输入一长串命令,为了简单起见,我们可以新建一个shell脚本文件,将这些命令写到shell脚本文件里面,然后每次只需要执行shell脚本即可完成编译工作。新建名为mx6ull_alientek_emmc.sh的shell脚本文件,然后在里面输入如下内容:

1 #!/bin/bash
2 make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- distclean
3 make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- (加空格)            mx6ull_14x14_ddr512_emmc_defconfig
4 make V=1 ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- -j12

U-Boot烧写与启动
uboot编译好以后就可以烧写到板子上使用了,这里我们跟前面裸机例程一样,将uboot烧写到SD卡中,然后通过SD卡来启动来运行uboot。使用imxdownload软件烧写,命令如下:
chmod 777 imxdownload //给予imxdownload可执行权限,一次即可
./imxdownload u-boot.bin /dev/sdd //烧写到SD卡,不能烧写到/dev/sda或sda1设备里面!
等待烧写完成,完成以后将SD卡插到I.MX6U-ALPHA开发板上,BOOT设置从SD卡启动,使用USB线将USB_TTL和电脑连接,也就是将开发板的串口1连接到电脑上。打开MobaXterm,设置好串口参数并打开,最后复位开发板。在MobaXterm上出现“Hit any key to stop autoboot: ”倒计时的时候按下键盘上的回车键,默认是3秒倒计时,在3秒倒计时结束以后如果没有按下回车键的话uboot就会使用默认参数来启动Linux内核了。如果在3秒倒计时结束之前按下回车键,那么就会进入uboot的命令行模式
在这里插入图片描述

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
hi3536uboot是海思公司(Hisilicon)的一款基于ARM架构的嵌入式开发板使用的启动引导程序。要配置和编译hi3536uboot,需要按照以下步骤进行: 1. 下载并安装交叉编译工具链:在海思官方网站上下载适用于hi3536uboot的交叉编译工具链,并将其解压到合适的目录中。然后将该目录添加到系统环境变量中,以便在命令行中可以直接使用交叉编译命令。 2. 获取hi3536uboot源码:从海思官方网站上下载最新版本的hi3536uboot源码,并将其解压到工作目录中。 3. 配置编译选项:进入hi3536uboot源码目录,在命令行中执行"make menuconfig"命令。这将打开一个菜单配置界面,用于选择编译选项。根据实际需求进行配置,例如选择启动方式、设备驱动支持等。 4. 进行编译:在命令行中执行"make"命令,开始编译hi3536uboot编译过程可能需要一段时间,视电脑性能和源码大小而定。 5. 生成uboot镜像文件:编译完成后,将生成的uboot镜像文件保存到合适的位置。通常情况下,uboot镜像文件的名称为"u-boot.bin"。 6. 烧录uboot镜像文件:将生成的uboot镜像文件通过JTAG或串口等方式烧录到hi3536开发板上。确保开发板电源正常供电,并按照官方文档或板载接口定义正确连接烧录工具。 7. 验证uboot功能:烧录完成后,重启hi3536开发板,并使用串口终端连接到开发板。通过终端界面可以验证uboot的功能和正确性,例如执行命令、加载内核等。 配置和编译hi3536uboot需要一定的嵌入式开发和Linux系统操作经验,同时需要参考海思官方提供的文档和资料。以上步骤仅为简要介绍,具体操作可能会因个人环境和需求而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值