前言:
本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM(MX6U)裸机篇”视频的学习笔记,在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。
引用:
正点原子IMX6U仓库 (GuangzhouXingyi) - Gitee.com
《【正点原子】I.MX6U嵌入式Linux驱动开发指南V1.5.2.pdf》第 8.1 章
《正点原子资料_A盘/02开发板原理图/IMX6ULL_MINI_V2.2(Mini底板原理图).pdf》
-
资料盘
开发板资料链接: https://pan.baidu.com/s/1j5Jzbdx9i-g0cWIi3wf2XA 提取码:ag1u
正文:
本文是 “正点原子[第二期]Linux之ARM(MX6U)裸机篇--第6.5讲” 的读书笔记。
本文是根据正点原子可成Linux之ARM裸机开发的第6.4讲,第6.5 讲的内容,第一次在正点原子 I.MX6ULL Mini 开发板上,通过ARM汇编 led.s 程序第一次成功的点亮开发板上的LED灯。
也记录一下遇到的第一个裸机 ARM 的开发 led.s 遇到的 Bug。裸机 ARM 汇编开发的bug与C语言相比还是难以调试和找出Bug原因的,应为都是一个以寄存器,每一个寄存器的bit位反应的是对应物理 IO 接口的特性,不直观。
1. 视频 6.4讲和6.5讲 编写并编译汇编 led.s
根据正点原子视频 6.4讲和6.5讲 编写并编译汇编 led.s,然后进行编译,在第6.4 讲中说从汇编 led.s 源码编译出 led.elf,之后需要使用 objcopy 把 led.elf 文件从 ELF 格式转换为 .bin格式,然后.bin 格式还不能直接烧录到 SD 卡中。
第 6.5 讲详细的讲了 I.MX6U 芯片的从上电开始进行 BOOT 模式选择,和 BOOT Device 设备选择的配置,在 I.MX6U 的参数考手册里说明了 I.MX6U 上电之后通过 BOOT_MODE1, BOOT_MODE0 选择串口启动,还是芯片内部 boot Rom启动。如果是选择I.MX6U 芯片内部 boot ROM启动,参考手册又说明了如何根据 BOOT_CFG6[7:0], BOOT_CFG2[7:0], BOOT_CFG1[7:0] 通过GPIO来配置BOOT启动设备,通过不同的GPIO配置来选择 I.MX6U 上电启动之后 boot ROM 是从 SD, MMC, NAND Flash, NOR Flahs 这些那种外部存储设别中拷贝复制 .bin 文件到外部 DDR RAM中,然后到RAM中执行。
2. 视频6.5 讲接收了 I.MX6U 的 .bin 为什么要加上一个Header
从 led.s 汇编源码编译出来的 led.elf文件,然后使用 objecopy 把 led.elf 文件转换为 .bin 格式文件。然后 .bin 格式文件并不能直接烧录到SD卡中,然后让 I.MX6U 直接上电从SD卡中拷贝到DDR RAM中执行。I.MX6U 参考手册对于每一种 Boot Device 启动设备,都有要求 .bin 文件格式应该烧录到存储设备的哪个位置,在.bin文件的头部应该附加上哪些额外的header信息。
正点原子团队,根据NXP I.MX6U 的官方文档手册和NXP提供的 boot.bin 文件反推出了,烧录到不同的存储设备 SD卡,MMC, NAND Flash, NOR Flash中,需要附加的 header 信息有:
header = IVT + Boot Data + DCD
- IVT: Image Vector Table
- Boot Data: Boot Data
- DCD: Device Config Data
并且 IVT, Boot Data, DCD 这些数据 NXP I.MX6U 芯片都规定定义了数据的格式,需要严格按照这些数据格式来填写数据header部分。
只有把需要的 IVT + Boot Data + DCD 组成的header部分添加到 led.bin,并且把重组之后的文件烧录到指定的 SD 某个起始偏移位置的扇区,才能在 I.MX6U 上电启动之后,芯片内部 boot ROM 从选择启动模式