NORFLASH启动UBOOT

NORFLASH启动UBOOT

将uboot存储在norflash中启动,主要流程是硬件初始化,设置栈,完成重定位,赋值uboot到ddr中运行,初始化外设,最后进入main_loop循环或引导操作系统启动内核。

uboot启动流程:

第一阶段:

​ 从地址0x00000000处取出第一条指令。

​ 当运行C语言时,形参和局部变量需要入栈,栈顶设置SRAM的顶端,为C程序提供运行环境。

​ 完成对gd_t*gd_ptr赋值(存储着uboot镜像的长度,重定位地址等信息)。

第二阶段:

​ 将uboot镜像赋值到SDRAM中控功能(重定位地址由gd_t*gd_ptr提供),根据重定位偏移量得到新的PC指针值,在DDR中继续运行uboot。

第三阶段:

​ 在DDR中继续运行的uboot完成对ARM处理器以及各外围硬件的初始化(例如:SPI、I2C、网卡等)。

​ 最终uboot进入main_loop,阻塞等待串口中断输入命令或者去启动内核。

总结:uboot的作用就是通过Flash和Sram初始化时钟和DDR(arm最小系统),最终是要在ddr中运行裸机调试或者引导操作系统启动内核。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
u-boot 是一种开源的引导加载程序,常用于嵌入式系统中进行启动和初始化操作。SPI NOR(Serial Peripheral Interface NOR Flash) 是一种非易失性存储器,被广泛应用于嵌入式系统中作为主要的启动设备或存储设备。 uboot spi nor驱动是为了支持u-boot引导加载程序与SPI NOR Flash之间的通信和数据传输而开发的驱动程序。 SPI NOR驱动的主要功能包括: 1. 初始化SPI控制器:SPI控制器是与SPI NOR Flash进行通信的关键硬件模块。驱动程序需要初始化SPI控制器,配置寄存器以设置通信速率、数据位宽和模式等参数。 2. Flash识别与配置:SPI NOR Flash可以有不同型号和制造商,每个Flash设备有自己的规格和特征。驱动程序需要通过与Flash设备进行通信,识别设备型号和容量,并根据设备规格进行相应的配置,如设置Flash的页大小、块大小和扇区大小等。 3. 读取和写入数据:驱动程序提供读取和写入函数,通过SPI总线与Flash设备进行数据传输。读取数据时,驱动程序可以根据设备规格进行读取优化,如使用硬件FIFO缓冲区提高读取速度。写入数据时,驱动程序需要进行写入状态检查和等待操作,确保数据正确写入Flash设备。 4. 擦除操作:SPI NOR Flash存储数据时需要先进行擦除操作才能写入新的数据。驱动程序需要提供擦除函数,可按页、块或整个芯片进行擦除。 通过支持SPI NOR驱动,u-boot可以实现从SPI NOR Flash启动、读取和写入数据,为嵌入式系统提供了更灵活的存储和扩展选项。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值