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系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

SpringBoot 整合 Grizzly的过程

《SpringBoot整合Grizzly的过程》Grizzly是一个高性能的、异步的、非阻塞的HTTP服务器框架,它可以与SpringBoot一起提供比传统的Tomcat或Jet... 目录为什么选择 Grizzly?Spring Boot + Grizzly 整合的优势添加依赖自定义 Grizzly 作为

mysql-8.0.30压缩包版安装和配置MySQL环境过程

《mysql-8.0.30压缩包版安装和配置MySQL环境过程》该文章介绍了如何在Windows系统中下载、安装和配置MySQL数据库,包括下载地址、解压文件、创建和配置my.ini文件、设置环境变量... 目录压缩包安装配置下载配置环境变量下载和初始化总结压缩包安装配置下载下载地址:https://d

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

springboot整合gateway的详细过程

《springboot整合gateway的详细过程》本文介绍了如何配置和使用SpringCloudGateway构建一个API网关,通过实例代码介绍了springboot整合gateway的过程,需要... 目录1. 添加依赖2. 配置网关路由3. 启用Eureka客户端(可选)4. 创建主应用类5. 自定

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b

SpringBoot集成SOL链的详细过程

《SpringBoot集成SOL链的详细过程》Solanaj是一个用于与Solana区块链交互的Java库,它为Java开发者提供了一套功能丰富的API,使得在Java环境中可以轻松构建与Solana... 目录一、什么是solanaj?二、Pom依赖三、主要类3.1 RpcClient3.2 Public

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Jenkins中自动化部署Spring Boot项目的全过程

《Jenkins中自动化部署SpringBoot项目的全过程》:本文主要介绍如何使用Jenkins从Git仓库拉取SpringBoot项目并进行自动化部署,通过配置Jenkins任务,实现项目的... 目录准备工作启动 Jenkins配置 Jenkins创建及配置任务源码管理构建触发器构建构建后操作构建任务