20分钟建立一个NIOSII开发环境.doc_第1页
20分钟建立一个NIOSII开发环境.doc_第2页
20分钟建立一个NIOSII开发环境.doc_第3页
20分钟建立一个NIOSII开发环境.doc_第4页
20分钟建立一个NIOSII开发环境.doc_第5页
已阅读5页,还剩8页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

20分钟建立一个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;选择FileOpen Project,或者CntlJ,打开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,或者CntlL,开始编译。出现警告信息可以不管,等待编译结束。配置 FPGA从Tools 菜单选择Programmer,选择JTAG 模式和对应的sof 文件,点击Start,开始下载,如果成功,那么开始进入软件调试环境。启动 NIOS II IDE 环境关闭 Programmer,打开顶层文件。快捷方法就是点图标双击 low_cost_1C20 系统模块,进入SOPC Builder。选择 Run Nios II IDE,进入IDE 开发环境。建立软件工程文件选择 FileNew Project 选项。选择 C/C+ Application, 点击Next。从模板中选择 Hello LED,其他设置按默认设置,点击Finish。编译工程文件选中 hello_led_0,按右键,选择 Build Project,结束后,右下方的控制台会提示编译结束。运行程序从菜单中选择 RunRun,弹出对话框 点击 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;elseled = 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; i200000; i+);* can cause problems when it is stepped through using a softwaredebugger.* The while loop below produces the same

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论