如何在20分钟内建立一个NIOS II开发环境

最新更新时间:2011-11-02来源: 互联网关键字:NIOSII 手机看文章 扫描二维码
随时随地手机看文章

一、 软件安装
1. 首先,安装NIOS II 开发包。采用虚拟光驱软件,如DAEMON 等将NIOS II V1.0 BUILD316E.ISO 文件映射到虚拟光驱上;
点击光驱图标,会自动运行安装程序
 
选择第一个选项,Install;
选择 Next 按钮;
询问是否接收协议的时候,选择 Yes,下一个也按Yes,继续;
 
如果是初学者,最后一个选项可以不选, Examples 可以选择自己熟悉的语言,其他选项建议都选上;
 
选择 QuartusII 的安装目录,如果不是C:盘,那么从Browse 选项中指定。如e:alterakits ios2;
接下来是选择一个程序组,一般情况按 Next 就可以了;
开始安装,大约需要几分钟时间拷贝文件;
点击 Finish,弹出一个IE 格式的说明文档,建议大家仔细看看Example Designs 选项,可以对NIOS II CPU 的配置和例程有更多的了解,对于以后的调试会很有帮助;
这样,开发软件就安装完毕了,赶快运行我们的第一个程序吧。

二、 Hello LED 程序调试
1. 首先,备份Example 目录。因为我们要对目录中的文件进行修改,所以还是保留一份更好一些,一旦改坏了,还可以回复。进入目录 E:alterakits ios2(我的QuartusII 安装在E:盘了),备份example 目录,命名为example_old。
2. 进入 E:alterakits ios2examplesverilog iosII_cyclone_1c20,删除low_cost 目录,同时将我们提供的low_cost.rar 文件拷贝过来,同时加压缩,解出来一个同名的low_cost 目录。
3. 启动 QuartusII 4.1;选择File-》Open Project,或者Cntl+J,打开low cost 项目。
 
打开工程后,可以看到一个命名为 low_cost_1c20 的系统。通过View 菜单的最后一个选项可以选择是否显示管脚分配信息。
选择合适的芯片型号(EFA-CY1C6 为EP1C6Q240C8,EFA-CY1C6为EP1C12Q240C8):
A.选择菜单的 Assignments 菜单,然后选择第一项:Device。
 
 
B.

在Available device 中选择板上芯片的型号
 
出现以上对话框,一定要选择否,否则管脚分配就会丢失掉。
C.设置其他无用管脚。
首先选择Device & Pin Options,看到以下画面。
 
打开Unused Pins 标签,
 
选择第一项,所有无用的管脚置为输入状态,置为三态。
经过以上处理,就可以编译和下载程序了。
编译项目
从 Processing 菜单选Start compilation,或者Cntl+L,开始编译。出现警告信息可以不管,等待编译结束。

配置 FPGA
从Tools 菜单选择Programmer,选择JTAG 模式和对应的sof 文件,点击Start,
开始下载,如果成功,那么开始进入软件调试环境。

启动 NIOS II IDE 环境
关闭 Programmer,打开顶层文件。快捷方法就是点图标
 
双击 low_cost_1C20 系统模块,进入SOPC Builder。
 
选择 Run Nios II IDE,进入IDE 开发环境。

建立软件工程文件
选择 File-》New -》Project 选项。
 
选择 C/C++ Application, 点击Next。
 
从模板中选择 Hello LED,其他设置按默认设置,点击Finish。

编译工程文件
选中 hello_led_0,按右键,选择 Build Project
 ,
结束后,右下方的控制台会提示编译结束。

运行程序
从菜单中选择 Run-》Run…,弹出对话框
  
点击 New,会自动生成一个系统配置。
 
点击 Apply,然后点击Run。
开始下载程序到 SDRAM,并运行起来。
 
观察板上的 4 个LED,大概没隔4 秒,LED 会轮流闪烁一次。
恭喜您,第一个 C 程序在NIOSII CPU 上已经运行起来了。
如果感兴趣,可以修改源文件,然后在编译,运行,看看 LED 有什么变化
以下是一个让 LED 闪烁更频繁的例子:
int main (void) __attribute__ ((weak, alias ("alt_main")));
/*
* Use alt_main as entry point for this free-standing application
*/
int alt_main (void)
{
alt_u8 led = 0x2;
alt_u8 dir = 0;
volatile int i;
/*
* Infinitly shift a variable with one bit set back and forth, and write
* it to the LED PIO. Software loop provides delay element.
*/
while (1)
{
if (led & 0x09) // 我们板上只有4个LED,所以当led的Bit3和Bit0有效的时候,
//就改变方向;
{
dir = (dir ^ 0x1);
}
if (dir)
{
led = led >> 1;
}
else
{
led = led << 1;
}
IOWR_ALTERA_AVALON_PIO_DATA(LED_PIO_BASE, led);
/*
* The delay element in this design has been written as a while loop
* to avoid confusing the software debugger. A tight, one line software
* delay loop such as:
* for(i=0; i<200000; i++);
* can cause problems when it is stepped through using a software
debugger.
* The while loop below produces the same behavior as the for loop shown
* above, but without causing potential debugger problems.
*/
i = 0;
while (i<100000) //加快闪烁间隔
i++;
}
return 0;
}

关键字:NIOSII 编辑:神话 引用地址:如何在20分钟内建立一个NIOS II开发环境

上一篇:电子仿真软件MultiSIM使用方法及技巧
下一篇:易懂的modelsim学习笔记

推荐阅读最新更新时间:2023-10-12 20:31

基于NiosII的I2C总线接口的实现
本文提出采用"NiosⅡ+AT24C02"设计方案,在介绍AT24C02A芯片主要特性和分析I2C通信协议原理基础上,重点介绍Nios Ⅱ与AT24C02A之间接口电路的设计方法,包括接口电路的寄存器定义、逻辑功能模块设计和驱动程序的编写三个方而的内容,利用嵌入式逻辑分析仪(SigalTap Ⅱ Logic Analyzer)来分析接口信号时序,分析结果表,本接口所产生的读写时序满足I2C的通信协议要求,验证了设计的正确性。   1 AT24C02A芯片简介   AT24C02A芯片,是由ATMEL公司生产的基于I2C总线型的串行电可擦除的可编程存储器(EEPROM),内部含有2Kbit的存储单元,是通过二根线(SDL
[模拟电子]
基于<font color='red'>NiosII</font>的I2C总线接口的实现
基于NiosII的 低码率实时H.264视频编码器
    引 言   H.264标准作为新一代视频编码标准,是面向多比特率的视频编码标准,也称JVT/AVC标准,既可用于高码率的HDTV和数字存储系统,也可用于低码率的实时通信系统。在相同的图像质量情况下,H.264比H.263和MPEG一4可以节省20%~50%的码率。就其基本档次而言,编码器的复杂度是H.263的10倍左右。H.264良好的网络亲和性和优异的压缩性能使其成为视频应用的首选,但其巨大的运算量成为许多应用的瓶颈。笔者基于NiosII设计了一种低码率实时应用的编码系统。该系统充分利用FPGA的并行设计结构,对视频数据采用高压缩比的H.264标准编码,能很好地满足低码率实时编码的要求。   1 H.264编码系统结构
[嵌入式]
NiosII的I2C控制IP及其在成像系统中的应用
摘要:详细介绍一种I2C控制IP的工作原理及其可编程寄存器,给出该IP在CMOS数字成像中的应用实例。该实例基于可编程片上系统(SOPC)技术设计,在NioslI IDE中通过编写程序来实现系统功能,并通过QuartusII软件自带的SignaITapII进行验证。结果表明,在CMOS成像领域选用该IP核,系统能充分利用SOPC技术的优势,具有扩展性好、控制灵活、开发周期短等特点。 关键词:SOPC;I2C控制IP;CMOS 1 IP的硬件结构及寄存器 1.1 IP硬件结构 IP内部结构如图1所示。主要由波特率时钟寄存器、寄存器组控制器、并行I/O接口、I2C可编程接口、I2C接口引擎5个模块组成。波特率时钟产生器
[工业控制]
<font color='red'>NiosII</font>的I2C控制IP及其在成像系统中的应用
基于Nios II的多生理参数处理系统的设计
  摘 要:以NiosⅡ软核处理器为核心的多生理参数系统数据处理平台的搭建,在FPGA中嵌入32位Nios II软核系统,用以控制信号的采集﹑处理﹑存储与显示等功能。NiosⅡ系统设计以NiosⅡ软核为核心,将全部的接口电路集成在同一片FPGA上,结构简单,易于修改,具有很高的性价比。   随着医疗仪器设备向智能化、微型化、系列化、数字化和多功能方向的发展,医疗设备中逻辑控制器件也由采用中、小规模的集成芯片发展到应用现场可编程门阵列FPGA(Field Programmable Gate Array)。使用FPGA器件可以大大缩短医疗设备的研制周期,减少开发成本,同时还可以很方便地对设计进行在线修改,因此FPGA在医疗设备中
[嵌入式]
基于Nios II的多生理参数处理系统的设计
基于Nios II 软核处理器的SD卡接口设计
  0 引言   Altera公司开发的Nios II是基于可编程片上系统SOPC(System on a Programmable Chip)技术的32 位嵌入式处理器软核。Altera 公司开发的Nios II软核,可以直接放在FPGA中,它体现了把实现产品的全部单元电路集成到一个芯片之内的片上系统SOPC的思想。作为一种具有竞争力的技术,在国外已经有大量的产品使用了这种技术,在国内使用Nios II处理器进行嵌入式系统设计的开发者也越来越多,但是离大规模应用还有距离,应该得到更加广泛的关注。本文在实际的项目中需要使用Nios II来开发存储系统,对于利用Nios II来进行嵌入式系统开发,还有许多工作需要去深入研究本文在
[嵌入式]
SOPC中NiosII的LCD显示驱动IP设计
  引言   NioslI嵌入式处理器是A1tera公司提出的SOPC解决方案,是一种用户可随意配置和构建的32位嵌入式处理器,结合丰富的外设可快速、灵活地构建功能强大的SOPC系统。Altera公司提供了一些通用的IP核,使得用户可轻松集成属于自己的专用功能;但对于一些特定的外设,没有现成可用的IP核,如液晶模块CBGl28064等。   用户可通过自定义逻辑的方法在SOPC设计中添加自定义IP核。在实际应用中,LCD液晶显示器凭借功耗低、体积小、轻薄及控制驱动简单等特点,在智能仪器、仪表和低功耗电子产品中得到了广泛应用。本文以深圳秋田视佳实业有限公司的液晶显示模块CBGl28064为例,在基于NioslI的SOP
[嵌入式]
SOPC中<font color='red'>NiosII</font>的LCD显示驱动IP设计
基于FPGA电火花加工脉冲电源的设计与研究
引 言       数控电火花(electrical discharge machining,EDM)机床是一种实现工件精密加工的特种加工工具。早期的电火花成型加工机床的脉冲电源电路是用分立元件组成,或者是用单片机来实现。分立元件电路设计复杂,电路调试困难,基于单片机或者是32位的嵌入式CPU的脉冲电源性能有了很大的提高,也具有了很高的智能性,但对于不同的处理器,其移植性不太好,而且如果硬件电路一旦完成就不能进行更改与升级。而采用现场可编程门阵列FPGA在很好的继承单片机或者是嵌入式CPU设计的电源的优点的同时,还拥有一些新的特点。本文提出的方案采用的是Altera公司的cylone II芯片,将Altera提供的NIOS II
[电源管理]
小广播
最新模拟电子文章
换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved