nios ii小实验——第一个demo指导书

简介: nios ii小实验——第一个demo指导书

1.新建工程:打开Quartus II 13.0,点击File->New Project Wizard,点击Next后可以看到如图2所示的对话框,选择工程路径给工程命名(注意:工程名必须和顶层模块名一致,否则编译会报错)。这里我们将工程名命名为lights。

b1c1f3d2491c31ea7aef3c64faecb68d_SouthEast.jpg

2.选择器件:这里我们选择Cyclone II里头的EP2C35F672C6这个芯片。直接点击finish。至此我们完成了quartus II工程的建立。

a44cd762dc61c08c5f0bb8dc0730030a_SouthEast.jpg

3.添加nios II 处理器:点击Tool->Qsys,Qsys综合了之前的SOPCbuilder,打开后自动有时钟模块在里面了。在左上角的搜索栏中输入nios,点击Add(或双击)将nios II处理器添加到系统中,如图4所示,这里我们选择Nios II/e。Nios Ⅱ系列包括3种产品,分别是:Nios Ⅱ/f(快速)——最高的系统性能,中等FPGA使用量;Nios Ⅱ/s(标准)——高性能,低FPGA使用量;Nios Ⅱ/e(经济)——低性能,最低的FPGA使用量。

6536399ff7388313616fb1ffc6ef145f_SouthEast.jpg

4.添加on-chip memory:在左上角的搜索栏输入on-chip memory,点击Add添加,如图5所示,将Total memory size修改为8192Bytes。点击finish完成设置。On-chip memory用来跑软核程序的,太小的话可能会出现各种error,比如程序放不下了。

da842682d71f3c176a483d948e658902_SouthEast.jpg

5.添加PIO:与上两步类似,加两组PIO,一组为output,一组为input,如图6所示。PIO负责这个软核的输入输出管脚。

82441c0bbe6ad4b3e7a1a56f73b6e581_SouthEast.jpg

6.添加JTAG UART:步骤同上,使用默认设置。负责烧录软件程序到单片机里。

65280eb96bb11fe8041ac42225852bf1_SouthEast.jpg

7.连线,这地方比较复杂

clk与所有添加的组件都连上;

clk_reset和所有的reset和reset_n都相互连接到一起;

data_master与on-chip memory,pio0,pio1,jtag都连上;

instruction_masteron-chip memory连上;

此处连线规则:如果是存储器这类的IP核,需要将其Slave端口同Nios II的data_master和instruction_master相连,而其他非存储器IP核则只需连接到Nios II的data_master即可;

再将IRQ连上,IRQ应该是中断等级;

将pio0(输入)重命名为Switches(右键rename),pio1改为LEDs(输出)。双击Switches和LEDs的external_connection,将其接到片外

连线完成后如下图。此时下面会报一堆错,不用急。

278184829545182c305462efc4929ecd_SouthEast.png

8.双击nios2,将reset vector和exception vector指向onchip_memory,这样程序复位从RAM中走,便于调试,若是添加了epcs模块,则从flash中重启,最终程序完成后选择则可。

6b51707da9dc0ae088d9daa96fb01a5d_SouthEast.jpg

9.分配地址:点击system->assignbase addresses给各个接口及组件分配地址。

b7bc5c355d81f856f54fbd657573783a_SouthEast.png

10.保存并生成系统(.v文件)

点击file->save,命名为nios。

保证messages里头没有错误后,点击工具栏里头的generation生成搭建的系统。至此,我们完成了NIOSS II系统的搭建。


11.将系统添加到工程中:选择project navigator中的Files,右键添加上一节中的文件到工程中。将nios\sythesis下的所有文件添加入工程中(或者只添加.Qsys经过试验也是可以的)。

619e1ab858809907bf15b5e9459fdc29_SouthEast.jpg

12.实例化:点击file->new,如图11所示,新建顶层模块对系统实例化。点击保存。

5ca7ec746648eee4df26c470109c1a0a_SouthEast.jpg

2f1c1a1bb97ea237c65d638d94c1a2f8_SouthEast.jpg

13.导入管脚配置文件:点击assignment->importassignment将管脚配置文件导入。

bbaeb41cc5fb3e1b5066ab6798ad22eb_SouthEast.jpg

14.编译和配置:编译工程,通过后就可以将其配置到DE2开发板上了。至此,我们完成了硬件设计部分。


15.打开Nios II Eclips:tools->Nios II software build tools for Eclipse,workspace选择你建立的quartus project的路径。

eeddf934e3a6fcee1860671b3f156aaa_SouthEast.jpg

16.新建工程:点击files->new->Nios IIApplication and BSP from Template,如图15所示。选择quartus II工程目录下的nios.sopcinfo文件。命名工程名为lights,使用默认设置点击finish。

d6bf59c425df48b550de446fb5401528_SouthEast.jpg

17.添加C代码:选择lights目录下的hello_world.c下的主函数main():int,将其内容修改为如图16所示,其中宏定义Switches和LEDs的地址到Qsys的system contents里头的base查找。

986d36e64be6dc661256cbc73893079f_SouthEast.jpg

4f629619dace62de300368788b3b226d_SouthEast.jpg

18.修改设置:选中lights_bsp,右键选择properties->Nios II BSPProperties,将Reduced device drivers和Small C library选中,取消Support C++。点击OK。

7fd26930f47db5b110fe7a37768805dd_SouthEast.jpg

19.生成BSP:点击工具栏里头的NIOS II->BSPEditor->generate完成BSP的生成。

11bb95614038f24642a74e4fed04e2ab_SouthEast.jpg

20.建立工程:右击lights->Build Project,完成工程建立。

21.运行:选择RUN->run as->Nios IIHardware。


相关文章
|
Android开发 异构计算
nios ii FIFO读取FPGA数据交互实验1
nios ii FIFO读取FPGA数据交互实验1
243 0
nios ii FIFO读取FPGA数据交互实验1
|
异构计算
nios ii小实验——SDRAM读写
nios ii小实验——SDRAM读写
214 0
nios ii小实验——SDRAM读写
|
4月前
【Qt 学习笔记】使用QtCreator创建及运行项目 | 项目初始代码解释
【Qt 学习笔记】使用QtCreator创建及运行项目 | 项目初始代码解释
732 1
Cadence仿真出现Cannot Initialize Profile错误的解决方法和步骤
元器件和器件PSpice模型都准备好了,仿真原理图也画好了,但是在新建仿真配置文件的时候,提示Cannot Initialize Profile的错误。当时忘了截图了,问题解决了也没有出现这个错误。重启软件、重启电脑都没有再出现。
521 0
|
4月前
|
前端开发 测试技术
测Nuxt.js入坑,配置dev、test、pro三种环境的变量env
先下载一个cross-env模块,比较好控制环境
141 5
|
2月前
|
Serverless API 监控
函数计算操作报错合集之部署了SD,但是OpenPose报错,是什么导致的
在使用函数计算服务(如阿里云函数计算)时,用户可能会遇到多种错误场景。以下是一些常见的操作报错及其可能的原因和解决方法,包括但不限于:1. 函数部署失败、2. 函数执行超时、3. 资源不足错误、4. 权限与访问错误、5. 依赖问题、6. 网络配置错误、7. 触发器配置错误、8. 日志与监控问题。
|
传感器 存储 Ubuntu
一步一步学会蓝牙开发之 ESP-IDF GATT Server 示例解析
学习蓝牙的 GATT 开发,我们从示例代码,一段代码一段代码进行详细分析说明
1729 1
一步一步学会蓝牙开发之 ESP-IDF GATT Server 示例解析
|
4月前
|
Ubuntu Linux 开发工具
Linux下的IMX6ULL——开发板的第一个APP和驱动实验(三)
Linux下的IMX6ULL——开发板的第一个APP和驱动实验(三)
159 0
Linux下的IMX6ULL——开发板的第一个APP和驱动实验(三)
|
4月前
报错:Keil5执行文件之后显示Target not created
报错:Keil5执行文件之后显示Target not created
719 0