U-Boot 烧写与启动

这篇具有很好参考价值的文章主要介绍了U-Boot 烧写与启动。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1.uboot 编译好以后就可以烧写到板子上使用了,这里我们跟前面裸机例程一样,将 uboot 烧写到 SD 卡中,然后通过 SD 卡来启动来运行 uboot。使用 imxdownload 软件烧写,命令如 下:

 chmod 777 imxdownload   //给予 imxdownload 可执行权限
 sudo fdisk -l   //查看挂载设备
 ./imxdownload u-boot.bin /dev/sdb  //烧写到SD卡
 

2.等待烧写完成,完成以后将 SD 卡插到 I.MX6U-ALPHA 开发板上,BOOT 设置从 SD 卡启 动,使用 USB 线将 USB_TTL 和电脑连接,也就是将开发板的串口 1 连接到电脑上。打开 MobaXterm,设置好串口参数并打开,最后复位开发板。在 MobaXterm 上出现“Hit any key to stop autoboot: ”倒计时的时候按下键盘上的回车键,默认是 3 秒倒计时,在 3 秒倒计时结束以 后如果没有按下回车键的话 uboot 就会使用默认参数来启动 Linux 内核了。如果在 3 秒倒计时 结束之前按下回车键,那么就会进入 uboot 的命令行模式

U-Boot 烧写与启动

 从图  可以看出,当进入到 uboot 的命令行模式以后,左侧会出现一个“=>”标志。 uboot 启动的时候会输出一些信息,这些信息如下所示:

1 U-Boot 2016.03 (Apr 19 2023 - 12:43:21 +0800)

2

3 CPU:   Freescale i.MX6ULL rev1.1 792 MHz (running at 396 MHz)
4 CPU: Industrial temperature grade (-40C to 105C) at 51C 

5 Reset cause: POR

6 Board: I.MX6U ALPHA|MINI

7 I2C: ready

8 DRAM: 512 MiB

9 MMC: FSL_SDHC: 0, FSL_SDHC: 1

10 Display: ATK-LCD-7-1024x600 (1024x600)

11 Video: 1024x600x24

12 In: serial

13 Out: serial

14 Err: serial

15 switch to partitions #0, OK

16 mmc1(part 0) is current device

17 Net: FEC1

18 Error: FEC1 address not set.

19

20 Normal Boot

21 Hit any key to stop autoboot: 0

22=>

第 1 行是 uboot 版本号和编译时间,可以看出,当前的 uboot 版本号是 2016.03,编译时 间是 2020 年 8 月 7 日凌晨 20 点 47 分。

第 3 和第 4 行是 CPU 信息,可以看出当前使用的 CPU 是飞思卡尔的 I.MX6ULL(I.MX 以 前属于飞思卡尔,然而飞思卡尔被 NXP 收购了),频率为 792MHz,但是此时运行在 396MHz。 这颗芯片是工业级的,结温为-40°C~105°C。

第 5 行是复位原因,当前的复位原因是 POR。I.MX6ULL 芯片上有个 POR_B 引脚,将这 个引脚拉低即可复位 I.MX6ULL。

第 6 行是板子名字,当前的板子名字为“I.MX6U ALPHA|MINI”。

第 7 行提示 I2C 准备就绪。

第 8 行提示当前板子的 DRAM(内存)为 512MB,如果是 NAND 版本的话内存为 256MB。 第 9 行提示当前有两个 MMC/SD 卡控制器:FSL_SDHC(0)和 FSL_SDHC(1)。I.MX6ULL 支持两个 MMC/SD,正点原子的 I.MX6ULL EMMC 核心板上 FSL_SDHC(0)接的 SD(TF)卡, FSL_SDHC(1)接的 EMMC。

第 10 和第 11 行是 LCD 型号,当前的 LCD 型号是 ATK-LCD-7-1024x600 (1024x600),分 辨率为 1024x600,格式为 RGB888(24 位)。

第 12~14 是标准输入、标准输出和标准错误所使用的终端,这里都使用串口(serial)作为终 端

第 15 和 16 行是切换到 emmc 的第 0 个分区上,因为当前的 uboot 是 emmc 版本的,也就 是从 emmc 启动的。我们只是为了方便将其烧写到了 SD 卡上,但是它的“内心”还是 EMMC 的。所以 uboot 启动以后会将 emmc 作为默认存储器,当然了,你也可以将 SD 卡作为 uboot 的 存储器,这个我们后面会讲解怎么做。

第 17 行是网口信息,提示我们当前使用的 FEC1 这个网口,I.MX6ULL 支持两个网口。 第 18 行提示 FEC1 网卡地址没有设置,后面我们会讲解如何在 uboot 里面设置网卡地址。 第 20 行提示正常启动,也就是说 uboot 要从 emmc 里面读取环境变量和参数信息启动 Linux 内核了。

第 21 行是倒计时提示,默认倒计时 3 秒,倒计时结束之前按下回车键就会进入 Linux 命令 行模式。如果在倒计时结束以后没有按下回车键,那么 Linux 内核就会启动,Linux 内核一旦启 动,uboot 就会寿终正寝。 这个就是 uboot 默认输出信息的含义,NAND 版本的 uboot 也是类似的,只是 NAND 版本 的就没有 EMMC/SD 相关信息了,取而代之的就是 NAND 的信息,比如 NAND 容量大小信息。 uboot 是来干活的,我们现在已经进入 uboot 的命令行模式了,进入命令行模式以后就可以 给 uboot 发号施令了。当然了,不能随便发号施令,得看看 uboot 支持哪些命令,然后使用这些 uboot 所支持的命令来做一些工作。文章来源地址https://www.toymoban.com/news/detail-425707.html

到了这里,关于U-Boot 烧写与启动的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 新唐NUC980使用记录(5.10.y内核):u-boot & linux & rootfs 编译与烧录测试(基于SD1位置SD卡)

    从去年(2022)开始新塘官方的NUC980 5.10.y内核的项目开始展开,这篇文章将测试在NUC980上使用5.10.y内核。 这篇文章中内容均在下面的开发板上进行测试: 《新唐NUC980使用记录:自制开发板(基于NUC980DK61YC)》 对于NUC980芯片本身的一些内容可以参考: 《新唐NUC980使用记录:基

    2024年02月03日
    浏览(59)
  • U-Boot移植

    我们知道uboot就是一个bootloader,但是ARM不像我们的PC机一样,并不是用U盘随便下一个Windows镜像就可以安装了。我们的uboot对应的就是一个U盘里面刷的引导程序。虽然uboot支持很多架构以及很多不同厂商的板子,但是UBOOT并不具备通用性。跟我们的电脑不一样,无论是华为、小

    2024年02月09日
    浏览(38)
  • u-boot详解

    1、uboot是一个裸机程序,比较复杂。我们需要先将其编译生成bin文件,然后添加头文件,然后将其烧写进去,最后通过他来启动Linux。 2、uboot就是一个bootloader(启动加载器),作用就是用于 启动Linux 或其他系统和初始化DDR。 uboot首先初始化ddr,然后将Linux镜像zImage(uImage)+设备

    2024年02月14日
    浏览(34)
  • U-boot常用命令(二)

    有时候需要在uboot中对SD卡或EMMC中存储的文件进行操作,这时候就要用到文件操作命令。跟文件操作相关的命令有:fatinfo、fatls、fstype、fatload 和 fatwrite,但是这些文件操作命令只支持 FAT 格式的文件系统!! 对于I.MX6U来说,SD/EMMC分为三个分区。 存放uboot 存放Linux zImage,dtb设

    2024年02月04日
    浏览(31)
  • U-boot(四):start_armboot

            本文主要探讨210的uboot启动的第二阶段,主要函数为start_armboot。 uboot     一阶段初始化SoC内部部件(看门狗、时钟等),初始化DDR,重定位     二阶段初始化其余硬件(iNand、网卡芯片···)以及命令、环境变量等···     启动打印硬件信息,进入bootdelay,读秒完后执行bootc

    2024年02月04日
    浏览(43)
  • VSCode gdb 调试 qemu u-boot 的方法

    最近使用 VS Code GDB 调试 qemu,有了一点收获,u-boot 编译后生成了一个 elf 文件:u-boot,是否也可以调试一下? 为何需要 VS Code GDB 调试,直接 gdb 调试不就可以了吗?答案就是:VS Code 可以界面调试,命令行调试会枯燥很多 使用 qemu,就是不需要板子 win10 64位 VMware Workstation P

    2024年02月11日
    浏览(42)
  • U-Boot移植 (2)- LCD 驱动修改和网络驱动修改

    链接: C/C++Linux服务器开发/后台架构师【零声教育】-学习视频教程-腾讯课堂 一般 uboot 中修改驱动基本都是在 xxx.h 和 xxx.c 这两个文件中进行的, xxx 为板子名称,即 board/freescale/mx6ull_myboard/mx6ull_myboard.c 和 include/configs/mx6ull_myboard.h 这两个文件。 一般修改 LCD 驱动重点注意以下

    2024年02月12日
    浏览(56)
  • uboot源码下载以及编译

    环境:ubuntu 20.04 uboot官网在进入之后如下所示: 我们可以直接选择Obtaining the source进入到获取源码的网址 在点击Obtaining the source进入到新的网址之后就会看到下面提示去获取uboot的源码: The source of the U-Boot project is maintained in a Git repository. You can download the source via A mirror of th

    2024年02月02日
    浏览(48)
  • 详细讲解移植u-boot.2022.10版本移植到开发板基本方法

     大家好,我是ST​。​ 今天给大家讲一讲如何将u-boot.2022.10版本移植到imx6ull开发板上。 环境 选项 内容 编译主机 UbuntuLTS 18.04 目标板 ATK I.MX6ULL(512MB DDR3 + 8GB EMMC) u-boot版本 2022.10 交叉编译工具链 gcc-linaro-7.5.0-2019.12-i686_arm-linux-gnueabihf 一、u-boot编译环境准备 1.u-boot源码包下载

    2024年02月11日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包