实验二-基于NIOS-II的流水灯设计


一、基于 NIOSII 软核的流水灯实验

建立新项目,进行 Qsys 系统设计,点击 Tools 下拉菜单下的 Platform Designer 工具
请添加图片描述
鼠标放在 clk_0 处点击右键 Edit 或是双击 clk_0 元件,对 Clock 进行时钟设置,设
为为 50M请添加图片描述
添加 CPU 和外围器件。从 PD 的元件池中选择以下元件加入到当前设计的系统中:
Nios II 32-bit CPU、jtag uart、片上存储器、PIO、system ID。
添加 Nios II 32-bit CPU
在“component library”标签栏中找到“Nios II Processor”后点击 Add(在查找窗口
输出 nios 即可)
请添加图片描述在 Nios Core 栏中选择 Nios II/f 选项,其他保持默认选项
请添加图片描述在”Caches and Memory Interfaces”标签栏中保持默认设置(Instruction Cache 选择
4Kbytes)请添加图片描述

在”Advanced Features”标签栏中保持默认设置
请添加图片描述在”MMU and MPU Settings”标签栏中保持默认设置

请添加图片描述在”JTAG Debug Module”标签栏中保持默认设置(注意勾选 Include JTAG Debug)
请添加图片描述

点击 Finish 回到 PD 界面。
将 nios2_qsys_0 重命名为 cpu,点击”Rename”即可重新命名
将 cpu 的 clk 和 reste_n 分别与系统时钟 clk_0 的 clk 和 clk_reset 相连
请添加图片描述

从下图左侧”Component Library”标签栏中的查找窗口输入 jtag 找到”JTAG UART ”,
然后点击 Add
请添加图片描述
在 JTAG UART-jtag-uart_0 的设置向导中保持默认选项,点击 Finish
在”Name”列中将 jtag-uart_0 重命名为 jtag-uart。
进行 clk、reset 以及 master-slave 的连线
进行中断 irq 连线。
请添加图片描述
从下图左侧”Component Library”标签栏中的查找窗口输入 On Chip 找到”On-Chip
Memory(RAM or ROM)”后点击 Add。
请添加图片描述
在”Size”栏中的”Total memory size”窗口中输入 40960(即片上内存的大小为 40KB),
其余选项保持默认,点击 Finish
请添加图片描述
返回”System Contents”标签栏可以看到新加入的”On-Chip Memory”核。在”Name”
列中将 onchip_memory2_0 改名为 onchip_ram。
进行时钟、数据端口、指令端口的连接
请添加图片描述
从下图左侧”Component Library”标签栏中的查找窗口输入 pio 找到”PIO”后点击
Add
请添加图片描述
确定以下选项:Width 为 8bits,Direction 选择 output,其余选项保持默认,点击
Finish请添加图片描述
返回”System Contents”标签栏可以看到新加入的”PIO”核。在”Name”列中将
pio_0 改名为 pio_led。并在在 Export 栏处双击,把输出口引出来,并命名为 out_led。
进行时钟、数据端口、指令端口的连接
请添加图片描述从下图左侧”Component Library”标签栏中的查找窗口输入 sys 找到” System ID
Peripheral”后点击 Add
请添加图片描述

返回”System Contents”标签栏可以看到新加入的” System ID Peripheral”核。在”Name”
列中将 sysid_qsys_0 改名为 sysid。
进行时钟、数据端口的连接
请添加图片描述
基地址分配:点击 PD 主界面菜单栏中的”System”下的”Assign Base Addresses”
请添加图片描述分配中断号:在”IRQ”标签栏下点选”Avalon_jtag_slave”和 IRQ 的连接点就会
为”jtag_uart”核添加一个值为 0 的中断号
请添加图片描述

指定 NIos II 的复位和异常地址:从”System Contents”标签栏
双击建立好的 cpu 进入 Nios II Processor 的配置界面,配置 Reset Vector 和 Exception
Vector 为””onchip_ram.s1”,点击 Finish。
请添加图片描述
生成 Qsys 系统:点选”Generation HDL”标签栏中 Generate 按
钮生成 Qsys 系统
请添加图片描述
在原理图(BDF)文件中添加 PD 生成的系统符号,如图 1.36 在空白处双击将已生
成的 kernel
请添加图片描述
菜单里选择 Device…——>Device and pin options进行 unused pin 设置,可能会收到外部信号的干扰,将未用引脚设置为 As input tri-stated
请添加图片描述
请添加图片描述进行物理引脚配置并再次进行编译
在这里插入图片描述
启动Nios II SBT
菜单栏中Tools-> Nios II Software Build Tools for Eclipse,在弹出来的窗口中选择当前工程的目录为工作空间
在这里插入图片描述
创建工程
在SOPC Information File name窗口中选择 kernel.sopcinfo文件,以便将生成硬件配置信息和软件应用关联
在这里插入图片描述
给程序命名
在这里插入图片描述
在自动生成的.c文件中加入代码

#include "system.h"
#include "altera_avalon_pio_regs.h"
#include "alt_types.h"
const alt_u8
led_data[8]={0x01,0x03,0x07,0x0F,0x1F,0x3F,0x7F,0xFF};
int main (void)
{
 int count=0;
 alt_u8 led;
 volatile int i;
 while (1)
 { if (count==7)
 {count=0;}
 else
 {count++;}
 led=led_data[count];
 IOWR_ALTERA_AVALON_PIO_DATA(PIO_LED_BASE, led);
 i = 0;
 while (i<500000)
 i++;
 }
 return 0;
}

在这里插入图片描述
编译
在这里插入图片描述
运行结果
运行前确认板子连接正确,驱动安装成功,然后点击【Quartus Prime Programmer】

在这里插入图片描述
点击【Run】→【Run Configurations…】
在这里插入图片描述
点击右侧的【Refresh Connections】将 USB-Blaster 加入,再点击【Apply】后点击【Run】在这里插入图片描述
结果
在这里插入图片描述
请添加图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值