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
236 0
nios ii FIFO读取FPGA数据交互实验1
|
异构计算
nios ii小实验——SDRAM读写
nios ii小实验——SDRAM读写
206 0
nios ii小实验——SDRAM读写
|
21天前
|
Serverless API 监控
函数计算操作报错合集之部署了SD,但是OpenPose报错,是什么导致的
在使用函数计算服务(如阿里云函数计算)时,用户可能会遇到多种错误场景。以下是一些常见的操作报错及其可能的原因和解决方法,包括但不限于:1. 函数部署失败、2. 函数执行超时、3. 资源不足错误、4. 权限与访问错误、5. 依赖问题、6. 网络配置错误、7. 触发器配置错误、8. 日志与监控问题。
|
3月前
|
Ubuntu Linux 开发工具
Linux下的IMX6ULL——开发板的第一个APP和驱动实验(三)
Linux下的IMX6ULL——开发板的第一个APP和驱动实验(三)
141 0
Linux下的IMX6ULL——开发板的第一个APP和驱动实验(三)
|
存储 数据采集 编解码
PACS源码,三维医学图像处理系统(PACS)源码
它集影像存储服务器、影像诊断工作站及RIS报告系统于一身,主要有图像处理模块、影像数据管理模块、RIS报告模块、光盘存档模块、DICOM通讯模块、胶片打印输出等模块组成, 具有完善的影像数据库管理功能,强大的图像后处理功能,提高了临床诊断准确率。
PACS源码,三维医学图像处理系统(PACS)源码
|
编译器 异构计算
altera小实验——第一个demo指导书
altera小实验——第一个demo指导书
altera小实验——第一个demo指导书
|
异构计算
xilinx小实验——vivado纯逻辑编程第一个demo
xilinx小实验——vivado纯逻辑编程第一个demo
348 0
xilinx小实验——vivado纯逻辑编程第一个demo
|
传感器 编解码 5G
Unity配置Android开发环境与第一个Demo
ARFoundation之路-环境配置(Android)
493 0
Unity配置Android开发环境与第一个Demo
|
XML 算法 数据可视化
ur驱动包内容解释
ur驱动包内容解释