【SoC FPGA】HPS启动过程

SoC HPS启动流程

    • Boot ROM
    • Preloader
    • Boot Loader

HPS的启动是一个多阶段的过程,每一个阶段都会完成对应的工作并且将下一个阶段的执行代码引导起来。每个阶段均负责加载下一个阶段。第一个软件阶段是引导 ROM,引导 ROM 代码查找并且执行称为预加载器的第 2 个阶段软件。预加载器如果找到下一个阶段软件,那么对其执行。预加载器和接下来的引导阶段 ( 如果存在 )统称为用户软件。用户软件位于 HPS 的外部并且由用户提供。引导 ROM 代码仅知道预加载器,但不知道接下来任何可能存在的引导阶段。

当处理器从复位(比如上电)释放并且CPU执行内部引导ROM(Boot ROM)中的复位异常处理代码时(通过指定复位向量指定Boot ROM区域实现自动执行Boot ROM),HPS开始进行引导;当引导ROM(Boot ROM)中的代码跳到引导软件的下一个阶段时,引导程序结束。引导软件的下一个阶段被称为预加载器,预加载器可以定制并且通常存储在HPS外部的基于闪存的非易失性存储器。
图1 典型引导流程
处理器可以从以下资源进行引导:

  • NAND闪存
  • SD/MMC闪存
  • Quad SPI闪存
  • FPGA内核逻辑

Boot ROM

Boot ROM是HPS内核上一段ROM中固化的可执行程序,作用是系统复位之后,执行引导preloader并且将CPU使用权交给preloader进行后续工作的过程。
Boot ROM完成的具体工作还有:

  • 使能指令缓存,branch predictor,浮点单元,NEON 向量单元
  • 设定看门狗定时器,Boot ROM保留适用
  • 根据CLKSEL设定配置MainPLL和外设PLL
  • 根据BOOTSEL设定配置I/O引脚的复用(此处只是完成了QSPI or SPI Flash or SD/MMC controller 的引脚的复用,更多的引脚的复用需要根据preloader才能够完成设定)
  • 初始化FLASH Controller 到默认设置

图2 Boot ROM执行过程
Boot ROM引导的preloader来源分为3类:

  1. 片上RAM热启动(对应图2框图①)
    如果之前执行过一次preloader,preloader会留在on-chip RAM中,按下热复位按键后,会首先选择从on-chip RAM启动,此过程具有最高优先级,但是从on-chip RAM 启动时会对遗留的preloader代码进行CRC校验(具体是否校验用户可以通过warmramgrp配置决定),校验成功才会执行。这样做防止了用户对on-chip RAM里的内容进行更改!如校验失败,会选择从Flash中启动preloader(对应图2框图③)。
  2. 从FPGA部分冷启动(对应图2框图②)
    此方式具有第二优先级,如果用户设定了bootsel从FPGA启动,则会等待FPGA配置成功(通过FPGA manager获取FPGA的状态),HPS会通过 HPS-to-FPGA bridge执行位于 0xC0000000(相对于HPS-to-FPGAbridge偏移地址为0)的memory中的指令。
  3. 从FLASH存储器冷启动(对应图2框图④)
    如果在找不到preloader的话,则会检验FPGA处的回调镜像(callback image),等待复位。对应图2框图⑤、⑥。
    说明:
    (1)只有冷启动才会选择从FPGA 引导
    (2)不论热启动还是FPGA冷启动,如不成功都会进入到了红色框的QSPI启动中
    (3)图2框图②中的yes 和 no 由bootsel 决定,图2框图③、④中最后具体是使用哪个FLASH存储器也由bootsel管脚决定。
    补充:
    (1)以上的冷、热分别表示上电时和已上电。
    (2)从断电状态到上电自动产生的复位成为冷复位,冷复位用英文表示Restart。已经通电的情况下给一个复位信号称为热复位,热复位用英文表示Reset。
    (3)热启动和冷启动区别:从断电到上电启动成为冷启动;上电的状态下重启系统成为热启动。
    (4)热复位和热启动区别:二者既有相同之处又有不同之处,不同在于热复位是复位相关存储器,热启动是重新启动相关设备。

Preloader

preloader(预加载器)的命名相对于BootLoader,其作用类似于PC主板上的BIOS,BIOS在系统启动之前控制着主板上的硬件设备,引导系统启动程序。preloader在HPS中完成的功能主要有系统时钟配置、引脚的复用配置、存储器初始化以及引导用户软件,下一步用户软件可以直接是用户的baremental 程序,也可以不需要bootloader的系统程序,如ucos,或者是操作系统的引导程序,如u-boot(开源引导加载器)。

预加载器被允许从 HPS 可用的任何器件加载下一个阶段引导软件。典型源头包括含有预加载器的同一闪存器件,一个不同的闪存器件或一个如 EMAC 的通信接口。

引导加载器:引导加载器加载操作系统并且将软件控制传递到操作系统。

HPS启动过程中三大典型用户软件架构:
(1)preloader+baremental code
(2)preloader+无bootloader的操作系统(如ucos)+用户定义软件
(3)preloader+bootloader code(如u-boot)+操作系统(如linux)+用户定义软件

preloader具体完成的工作:

  • 初始化SDRAM接口
  • 配置 remap 寄存器,把on-chip RAM 映射至地址0x0,异常会被preloader处理
  • on-chip RAM 可以被读写,初始地址从0x0对齐
  • 通过scan manager配置HPS I/O
  • 通过system manager配置引脚复用
  • 通过clock manager配置HPS时钟
  • 初始化包含了下一阶段启动代码的FLASH控制器(NAND, SD/MMC, or quad SPI)
  • 启动下一阶段或者将用户代码引导入SDRAM,并把CPU控制权交至下一段代码

Boot Loader

Boot loader(系统引导程序),操作系统内核运行之前运行的一段程序。它首先完成系统硬件的初始化,包括时钟的设置、存储区的映射等,设置堆栈指针等;然后把操作系统内核从flash区拷贝带ram区,并跳转到内核的入口,将系统的控制权交给操作系统,从此系统的运行和Boot loader再无任何关系。

BootLoader启动方式:

大多数BootLoader都有两种操作模式:启动加载模式和下载模式,BootLoader的组最终目的都是启动内核。

1.启动加载模式(boot loading)
上电后,BootLoader从板子的某个固态存储设备上将操作系统加载到RAM中运行,整个过程没有用户介入。这种模式是BootLoader的正常工作模式,产品发布时候,BootLoader就工作在这种模式下。

2.下载模式(down loading)
这种模式下,开发人员使用各种命令,通过串口连接或者网络连接从主机上下载文件,将他们直接放在内存运行或者烧入flash类固态存储设备中。以后的系统更新也会使用 Boot Loader 的这种工作模式。工作于这种模式下的 Boot Loader 通常都会向它的终端用户提供一个简单的命令行接口。

参考文章:
https://blog.csdn.net/qq_51118175/article/details/122052285
http://m.eeworld.com.cn/bbs_thread-454675-1-1.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/132568.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据挖掘实战(3):如何对比特币走势进行预测?

⭐️⭐️⭐️⭐️⭐️欢迎来到我的博客⭐️⭐️⭐️⭐️⭐️ 🐴作者:秋无之地 🐴简介:CSDN爬虫、后端、大数据领域创作者。目前从事python爬虫、后端和大数据等相关工作,主要擅长领域有:爬虫、后端、大数据…

203、RabbitMQ 之 使用 direct 类型的 Exchange 实现 消息路由 (RoutingKey)

目录 ★ 使用direct实现消息路由代码演示这个情况二ConstantUtil 常量工具类ConnectionUtil 连接RabbitMQ的工具类Publisher 消息生产者测试消息生产者 Consumer01 消息消费者01测试消费者结果: Consumer02 消息消费者02测试消费者结果: 完整代码&#x…

机器学习(22)---信息熵、纯度、条件熵、信息增益

文章目录 1、信息熵2、信息增益3、例题分析 1、信息熵 1. 信息熵(information entropy)是度量样本集合纯度最常用的一种指标。信息的混乱程度越大,不确定性越大,信息熵越大;对于纯度,就是信息熵越大,纯度越低。 2. 纯度…

Text-to-SQL小白入门(八)RLAIF论文:AI代替人类反馈的强化学习

学习RLAIF论文前,可以先学习一下基于人类反馈的强化学习RLHF,相关的微调方法(比如强化学习系列RLHF、RRHF、RLTF、RRTF)的论文、数据集、代码等汇总都可以参考GitHub项目:GitHub - eosphoros-ai/Awesome-Text2SQL: Cur…

论文阅读/写作扫盲

第一节:期刊科普 JCR分区和中科院分区是用于对期刊进行分类和评估的两种常见方法。它们的存在是为了帮助学术界和研究人员更好地了解期刊的学术质量、影响力和地位。 JCR分区(Journal Citation Reports):JCR分区是由Clarivate Ana…

android U广播详解(一)

概念介绍 进程队列 BroadcastQueueModernImpl 的设计围绕着为设备上的每个潜在进程维护一个单独的 BroadcastProcessQueue 实例。表明用于传送到特定进程的Pending {link BroadcastRecord} 条目队列。整个类都标记为 {code NotThreadSafe},因为调用者有责任始终与…

Excel往Word复制表格时删除空格

1.背景 在编写文档,经常需要从Excel往Word里复制表格 但是复制过去的表格前面会出现空格(缩进) 再WPS中试了很多方法,终于摆脱了挨个删除的困扰 2. WPS排版中删除 选择表格菜单栏-选在【开始】-【排版】选择【更多段落处理】-【段…

ROS-PX4仿真笔记_1

offbord模式测试 rosrun offboard_pkg position stablelize模式 lqr控制器实验 roslaunch px4 fast_test.launch 无人机起飞1.5-2m sh mybot_gazebo.sh#roslaunch px4 fast_racing.launch & sleep 20; roslaunch ego_planner single_run_in_gazebo.launch & sleep 1…

快速解决“找不到msvcr120.dll无法执行代码”问题,总结5解决方法

计算机已经成为我们生活和工作中不可或缺的一部分。然而,在使用计算机的过程中,我们常常会遇到各种问题,其中之一就是找不到msvcr120.dll文件。这个问题可能会可能导致计算机程序软件,游戏无法正常运行,影响到我们的工…

使用testMe自动生成单元测试用例

文章目录 1、testMe简介2、插件对比2.1 testMe2.2 Squaretest2.3 Diffblue 3、IDEA插件安装4、单测用例4.1 maven依赖4.2 生成用例 5、自定义模板6、使用自定义模板生成用例7、调试用例 1、testMe简介 公司对于系统单元测试覆盖率有要求,需要达到50%或80%以上才可以…

身份证号码,格式校验:@IdCard(自定义注解)

目标 自定义一个用于校验 身份证号码 格式的注解IdCard,能够和现有的 Validation 兼容,使用方式和其他校验注解保持一致(使用 Valid 注解接口参数)。 校验逻辑 有效格式 符合国家标准。 公民身份号码按照GB11643-…

使用 Eziriz .NET Reactor 对c#程序加密

我目前测试过好几个c#加密软件。效果很多时候是加密后程序执行错误,或者字段找不到的现象 遇到这个加密软件用了一段时间都很正常,分享一下使用流程 破解版本自行百度。有钱的支持正版,我用的是 Eziriz .NET Reactor 6.8.0 第一步 安装 Ezi…