nios II--实验7——数码管IP硬件部分

时间:2022-09-22 10:33:37

数码管

硬件开发

新建原理图

  1. 打开Quartus II 11.0,新建一个工程,File -> New Project Wizard…,忽略Introduction,之间单击 Next> 进入下一步。分别设置工程工作目录、工程名称。这里需要注意的是工程工作目录中请使用英文,不要含有空格等,否则在后面使用Nios II IDE的时候会出现问题。设置好后如图1所示。然后进行下一步。这里工程命名为lab6_seg

nios II--实验7——数码管IP硬件部分

2、添加已经存在的文件,这里没有需要添加的文件,直接单击 Next> 进入下一步。进行器件设置。使用的 是Cyclone IV家族的 EP4CE6E22C8芯片,选择好后直接进入下一步。进行EDA工具设置,由于工程中不进行仿真等,故不进行设置,如果需要进行ModelSim仿真,则在Simulation行中,选择Tool Name 为ModelSim-Altera(这里根据所安装的ModelSim版本进行选择),Format(s)选择为Verilog HDL(这里也是根据所掌握的硬件描述语言进行选择)。点击 Next> ,进入了Summary(摘要)页面,然后单击 Finish 完成即可。

nios II--实验7——数码管IP硬件部分

3、新建 Block Diagram/Schematic File (方块图/原理图文件)。单击 File -> New..,选择Design Files中的Block Diagram/Schematic File,单击OK即可。

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

QSys调用模块

  1. 启动Qsys 工具,进行IP模块的调用。单击 Tools -> Qsys nios II--实验7——数码管IP硬件部分 ,进入Qsys设置界面。系统已经默认添加了时钟模块,名称为 clk_0 ,这里选中 clk_0,右击,选择Rename,将其名称更改为clk。以下再添加任何模块,都进行类似的名称更改,更改名称的方法类似,就不在重复叙述了。

nios II--实验7——数码管IP硬件部分

  1. 添加软核处理器的各部分模块。总共需要添加

Nios II Processor、

JTAG UART、

System ID Peripheral

EPCS Serial Flash Controller

Sdram controller

Pio

timer

这7个模块。首先熟悉一下 Qsys 的界面。左面Component Library,是系统提供的元件库,里面有一些构成处理器的常用模块。右面是已经添加到系统的模块,也就是说,Nios II 软核处理器是可以定制的,根据具体需要来。在Component Library中搜索Nios II Processor,双击即可进行配置。首先需要选择的是Nios II 核心的类型。Nios II 软核的核心共分成三种,为e型、s型以及f型。e型核占用的资源最少,功能也最简单,速度最慢。s型核占用资源其次,功能和速度较前者都有所提升,f型核的功能最多,速度最快,相应的占用资源也最多,选择的时候根据需求和芯片资源来决定,这里选择s核。然后单击 Finish,结束当前配置。

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

  1. 添加SDRAM Controller,这里使用的SDRAM芯片,大小为64M      B = 1M x 16Bit x 4Banks,具体的其他内容大家可以查看其datesheet。

nios II--实验7——数码管IP硬件部分nios II--实验7——数码管IP硬件部分

重命名为sdram;

nios II--实验7——数码管IP硬件部分

  1. 添加EPCS/EPCQx1 Serial Flash Controller,这里不用进行任何设置,直接单击Finish完成即可。

    nios II--实验7——数码管IP硬件部分

    nios II--实验7——数码管IP硬件部分

    nios II--实验7——数码管IP硬件部分

  2. 添加Jtag下载调试接口。在元件库中搜索 jtag uart。双击进行设置。由于系统没有特殊要求,因此这里选择默认配置即可。单击 Finish 结束当前配置。

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

  1. 添加系统ID模块。系统ID是系统与其他系统区别的唯一标识。在元件库中搜索 system id peripheral,双击进行设置。这里随便进行设置,如设置为123。单击 Finish,结束当前配置。

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

  1. 添加PIO,作为数码管的段选信号。双击打开后,根据实际需要选择位宽(Width)和方向(Direction),所以Width设置为8,Direction设置为Output。单击Finish完成设置。

    nios II--实验7——数码管IP硬件部分nios II--实验7——数码管IP硬件部分

    重命名如下:

    nios II--实验7——数码管IP硬件部分

  2. 添加PIO,作为数码管的位选信号。双击打开后,根据实际需要选择位宽(Width)和方向(Direction),所以Width设置为4,Direction设置为Output。单击Finish完成设置。

    nios II--实验7——数码管IP硬件部分nios II--实验7——数码管IP硬件部分

  3. 添加定时器模块timer

    nios II--实验7——数码管IP硬件部分

  4. 连线,即将右面 Connections栏目中的相关线通过设置节点进行连接。首先所有模块的clk连接起来。

nios II--实验7——数码管IP硬件部分

然后片内存储器sdram的s1和处理器nios2的data_master和instruction_master相连。

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

JTAG调试模块jtag_uart的avalon_jtag_slave和处理器nios2的data_master相连。

nios II--实验7——数码管IP硬件部分

系统ID模块sysid_qsys的control_slave和处理器nios2的data_master相连。

nios II--实验7——数码管IP硬件部分

  1. Seg_duan模块的S1连接处理器nios2的data_master;

    nios II--实验7——数码管IP硬件部分

    设置Seg_duan的输出端口,并重命名端口名;

    nios II--实验7——数码管IP硬件部分

  2. Seg_wei模块的S1连接处理器nios2的data_master;

    nios II--实验7——数码管IP硬件部分

    设置Seg_wei的输出端口,并重命名端口名;

    nios II--实验7——数码管IP硬件部分

  3. timer模块的S1连接处理器nios2的data_master;

    nios II--实验7——数码管IP硬件部分

  4. 设置复位信号。

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

  1. 处理器nios2的中断和jtag_uart的中断、epcs_flash的中断、定时器中断相连接。

nios II--实验7——数码管IP硬件部分

  1. epcs_flash后面的小锁单击,将其锁上。

    nios II--实验7——数码管IP硬件部分

  2. 进行软核的相关设置。首先双击nios2,进入处理器设置模块。在Core Nios II标签下,Reset vector memory设置为epcs_flash.epcs_control_port,Exception vector memory设置为sdram.s1,然后单击Finish完成设置。

nios II--实验7——数码管IP硬件部分

  1. 单击 System -> Assign Base Addresses,这时候会发现下部Messages窗口中原先的错误全部没有了,变为0 Errors,0 Warnings。如果不是这个结果,返回去按步骤检查。

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分

  1. 单击 File -> Save,进行保存,这里保存文件名为lab6_seg。
  2. 最后,选择Generation选项卡,设置Create simulation model为None,然后单击下面的Generate,进行生成。时间较长,大家耐心等待。

    nios II--实验7——数码管IP硬件部分

    nios II--实验7——数码管IP硬件部分

  3. 完成后单击close即可,然后关闭Qsys回到Quartus II界面。

原理图添加IP模块

参照实验二(led),重新调用脚本对引脚进行配置

nios II--实验7——数码管IP硬件部分

每日推送不同科技解读,原创深耕解读当下科技,敬请关注微信公众号“科乎”。

nios II--实验7——数码管IP硬件部分

nios II--实验7——数码管IP硬件部分的更多相关文章

  1. nios II--实验7——数码管IP软件部分

    软件开发 首先,在硬件工程文件夹里面新建一个software的文件夹用于放置软件部分:打开toolsàNios II 11.0 Software Build Tools for Eclipse,需要进 ...

  2. DE1-SOC开发板上搭建NIOS II处理器运行UCOS II

    DE1-SOC开发板上搭建NIOS II处理器运行UCOS II   今天在DE1-SOC的开发板上搭建NIOS II软核运行了UCOS II,整个开发过程比较繁琐,稍微有一步做的不对,就会导致整个过 ...

  3. 【小梅哥SOPC学习笔记】NIOS II处理器运行UC/OS II

    SOPC开发流程之NIOS II 处理器运行 UC/OS II 这里以在芯航线FPGA学习套件的核心板上搭建 NIOS II 软核并运行 UCOS II操作系统为例介绍SOPC的开发流程. 第一步:建 ...

  4. FPGA回忆记事(一):基于Nios II的LED实验

    实验一:基于Nios II的LED实验 一.    创建Quartus II工程 1.打开Quartus II环境.开始->程序->Altera->Quartus II 9.1. 2 ...

  5. 给NIOS II CPU添加一颗澎湃的心——sysclk的使用

    给NIOS II CPU添加一颗澎湃的心——系统时钟的使用 本实验介绍如何在Qsys中添加一个定时器作为NIOS II的心跳定时器,并在NIOS II中软件编程使用该定时器. 将上一个实验watchd ...

  6. 初探NIOS II之hello_world

    平台背景: 操作系统:win7  64bit 开发板:DE2-115 Quartus ii:15.0及配套的NIOS ii开发平台 一.硬件系统的建立 1.在Quartus里新建工程,这是很基本的就不 ...

  7. 给NIOS II CPU增加看门狗定时器并使用

    给NIOS II CPU增加看门狗定时器并使用   配置看门狗定时器: 设置计时溢出时间为1秒 计数器位宽为32位 勾选No Start/Stop control bits 勾选Fixed perio ...

  8. 【推荐图书】+ 基于Nios II的嵌入式SoPC系统设计与Verilog开发实例+C#入门经典等

    [推荐图书]+ 基于Nios II的嵌入式SoPC系统设计与Verilog开发实例+C#入门经典等 3赞 发表于 2016/7/4 21:14:12 阅读(1921) 评论(3) 初次接触FPGA,到 ...

  9. Nios ii调试问题集

    如果定义了一个类的.hpp,而在相应的.cpp中定义其中的函数时,根本找不到定义的类,这说明类在定义时出错,要注意类括号后的冒号. 2. 问题1:NiosII/Eclipse 中遇到“Launchin ...

随机推荐

  1. Extjs 回车查询

    listeners: { afterRender: function (thisForm, options) { this.keyNav = Ext.create('Ext.util.KeyNav', ...

  2. Oracle VM Virtual

    版本5.xx不能导入 要用旧版的4.3.10

  3. mac 安装使用 webp 来压缩图片

    学习性网站: https://developers.google.com/speed/webp/docs/cwebp http://www.w3ctech.com//topic/1672 https: ...

  4. use selenium in scrapy webdriver

    https://pypi.python.org/pypi/selenium from selenium import webdriver from selenium.webdriver.common. ...

  5. iOS获取webview高度

    int webHeight = [[webView stringByEvaluatingJavaScriptFromString:@"document.documentElement.scr ...

  6. gentoo装X服务器时显卡选择

    前面装X服务器一直装不成功,每个步骤都按hand book上的进行,编译完成后,重启就是启动不了X服务器,最终才知道由于我是用的是 开源显卡nvidia,换成集成显卡inter后X启动成功,顺便说句, ...

  7. MySQL自增长的bug?

    实验环境: mysql> status--------------mysql Ver 14.14 Distrib 5.7.14, for Linux (x86_64) using EditLin ...

  8. bootstrap日期选择

    <input type="text" class="form-control datepicker" style="padding: 0.375 ...

  9. JSP&lpar;7&rpar;—EL和JSTL

    一.EL表达式: 1.简介:EL全称为Expression Language,原本是JSTL1.0为方便存储数据所定义的语言,当时只能在JSTL标签中 使用,到了JSTL2.0之后,EL已经成为正式纳 ...

  10. &period;NET 黑魔法 - asp&period;net core 身份认证 - Policy

    身份认证几乎是每个项目都要集成的功能,在面向接口(Microservice)的系统中,我们需要有跨平台,多终端支持等特性的认证机制,基于token的认证方式无疑是最好的方案.今天我们就来介绍下在.Ne ...