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

相关文章

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

python运用requests模拟浏览器发送请求过程

《python运用requests模拟浏览器发送请求过程》模拟浏览器请求可选用requests处理静态内容,selenium应对动态页面,playwright支持高级自动化,设置代理和超时参数,根据需... 目录使用requests库模拟浏览器请求使用selenium自动化浏览器操作使用playwright

Mysql中设计数据表的过程解析

《Mysql中设计数据表的过程解析》数据库约束通过NOTNULL、UNIQUE、DEFAULT、主键和外键等规则保障数据完整性,自动校验数据,减少人工错误,提升数据一致性和业务逻辑严谨性,本文介绍My... 目录1.引言2.NOT NULL——制定某列不可以存储NULL值2.UNIQUE——保证某一列的每一

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

Spring Boot Actuator应用监控与管理的详细步骤

《SpringBootActuator应用监控与管理的详细步骤》SpringBootActuator是SpringBoot的监控工具,提供健康检查、性能指标、日志管理等核心功能,支持自定义和扩展端... 目录一、 Spring Boot Actuator 概述二、 集成 Spring Boot Actuat

Linux下在线安装启动VNC教程

《Linux下在线安装启动VNC教程》本文指导在CentOS7上在线安装VNC,包含安装、配置密码、启动/停止、清理重启步骤及注意事项,强调需安装VNC桌面以避免黑屏,并解决端口冲突和目录权限问题... 目录描述安装VNC安装 VNC 桌面可能遇到的问题总结描js述linux中的VNC就类似于Window

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

java内存泄漏排查过程及解决

《java内存泄漏排查过程及解决》公司某服务内存持续增长,疑似内存泄漏,未触发OOM,排查方法包括检查JVM配置、分析GC执行状态、导出堆内存快照并用IDEAProfiler工具定位大对象及代码... 目录内存泄漏内存问题排查1.查看JVM内存配置2.分析gc是否正常执行3.导出 dump 各种工具分析4.