IMX6ULL启动过程详解

网上关于IMX6ULL启动过程分析的文章已经有很多了,都大同小异,但是有些细节的地方很多文章都没有提到,最近自己又梳理了一遍这款SoC的启动过程,写下来给自己巩固一下。

首先看一下IMX6ULL这款SoC的框图:

框图的右下角,可以看到这款SoC有内部ROM和RAM,这个ROM用户不可用,因为里面存放了NXP写好的Boot ROM代码,这个代码作用是对芯片进行上电以后的各种初始化。这128K的RAM是用户可以使用的。

芯片一上电,CPU会去0x00000000地址去取指令,这个地址就是内部ROM的起始地址。

我们知道,要运行一个程序,通常都是先把程序装载到RAM中去,然后CPU去RAM中取指令,最后在CPU内部译码执行。这里芯片可以直接从ROM中取指令,说明IMX6ULL这个内部ROM是Nor Flash,Nor Flash的特点就是支持XIP(芯片内执行),我们熟知的STM32把程序烧录到Flash中然后就可以执行,也是同样的原因,STM32的Flash是Nor Flash。

再多说一点,什么叫芯片内执行?

裸机能够直接运行的是bin文件,这是最纯净的二进制文件。我们在STM32中烧录的hex文件就是在bin文件中添加了地址信息得到的。而我们在Linux中使用gcc编译链接得到的是elf文件,elf文件的内容更杂了,包含了节头表,调试信息等一大堆信息。裸机能够直接执行的是bin文件&#

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值