NIOS II EPCQ FLASH启动过程要点 NIOS II BOOT LOADER/COPIER

2023-12-05 02:32

本文主要是介绍NIOS II EPCQ FLASH启动过程要点 NIOS II BOOT LOADER/COPIER,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

从EPCQ FLASH启动nios,并自动运行应用程序(以hello_world为例),按照bootloader(altera称之为boot copier)是否为自定义的,分为两种方法:

一,bootloader不是自定义的,是通过nios SBT软件自动生成的,该方法即 intel altera Embedded Design Handbook中5.2.3.4所述方法。 

二,由于需要在多个应用程序之间跳转,或者在多个应用程序之间选择某一个镜像启动,因此修改bootloader的.c文件,自定义boot loader,并指定多个应用程序镜像地址。该方法可在Embedded Design Handbook 5.3章节基础上修改而来。

NIOS II启动流程

上电后,硬件sof首先完成配置,将NIOS软核CPU及其外设,还有逻辑设计IP等硬件电路在FPGA内配置完毕。随后,跳转到QSYS搭建过程中为CPU指定的reset地址,执行该地址内的代码。该地址通常存放着bootloader文件,格式为hex。方法一中,该地址在QSYS中设置为epcq controller (此处存疑,bootloader是存放在epcq flash中,还是存放在epcq controller ip 核的片上ROM中,看文档似乎是在flash中,那片上ROM的作用是什么?)。方法二中,该地址被设置为onchip ram1(QSYS系统中添加了2个on chip ram组件)。执行bootloader时,根据bootloader的设计,bootloader程序到指定的flash地址去拷贝应用程序的镜像,到onchip ram2,然后跳转到onchipram2执行应用程序代码。至于拷贝多少?拷贝到何处?应用程序的头若干字节存放了这两个信息。

方法一介绍(该方法尚未实验)

1.QSYS搭建系统时,cpu reset地址指向epcq controller。上电完成sof硬件配置后,系统跳转至epcq flash的0X1E00000地址,执行bootloader,该bootloader到紧随其后的某flash地址,复制应用程序镜像,到onchipram的系统地址。是否要复制到onchipram,onchipram的地址在何处,都在hello_world软件工程的bsp editor 中 的linker script中设置。

2.最终烧录进epcq的是jic文件,jic = rtl.sof+hex. hex = bootloader+hello_world。hex文件可在hello world工程中,选中hello world文件夹,右键make target->build->mem->ini_generate生成。烧录时,sof文件地址为0,hex文件地址为0x1e00000e.

方法二介绍

1.qsys中添加两个onchip ram.ram1存放运行bootloader,ram2存放运行hello world.

2.新建bootloader软件工程,修改Embedded Design Handbook 5.3例程的源代码advanced_boot_copoier.c,替换读epcq函数,并将boot_image直接指定为1,不让程序检验应用程序镜像头。bsp linker script 中,heap text stack等均设置为onchipram1.

3.编译bootlaoder工程,并make target,得到几个hex,将onchipram1.hex及相关的memini,qip,.spd,添加进quartus工程中,全编译,生成的sof文件,包含了bootloader,会在配置硬件sof时,将boot loader初始化进onchipram1中。

4.qsys中,cpu从onchipram1 reset. 

5.新建hello world工程,bsp editor linker script中,可设置的均设置为onchip ram2。

6. nios command shell 中,将hello world.elf转换为hex

7.最终烧录jic,jic = sof(with bootloader) + hex。hex仅含hello world.添加hex时,选择relative adress(4000000),big endian.绝对地址应为4300000.advanced_boot_copoier.c中hello world镜像地址也应为0x4300000。

8烧录jic,断电重启,看led灯,得知进入bootlaoder,打开nios command shell,执行nios2-terminal,串口打印bootloader的复制镜像,跳转等信息,并打印hello world,led灯也相应地亮灭。说明跳转进了应用程序。(为何不打开串口,就不自动跳转?因为我的bootloader中使用了printf函数库,导致jtag uart没有打印信息时,bootloader会停止,可以不用printf函数,改用my_jtag_write()函数,原始版本的bootloader是没用printf函数的,或者在bootloader内取消JTAG_UART)。

9.调试方法:sof不含bootloader时,flash中可烧录sof(without bootloader)+hello_world.hex。然后在eclipse bootloader界面,以debug方式,运行bootlaoder,使其实行拷贝,跳转等动作,启动helloworld应用。同样,flash中仅正确位置(0x4300000)有hello world.hex,也可通过jtag烧录sof(with bootloader),然后就会自动运行应用程序(或者打开串口后会执行)。 

这篇关于NIOS II EPCQ FLASH启动过程要点 NIOS II BOOT LOADER/COPIER的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/455822

相关文章

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

深度解析Spring Boot拦截器Interceptor与过滤器Filter的区别与实战指南

《深度解析SpringBoot拦截器Interceptor与过滤器Filter的区别与实战指南》本文深度解析SpringBoot中拦截器与过滤器的区别,涵盖执行顺序、依赖关系、异常处理等核心差异,并... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.