一、 软件装置
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; i200000; 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 (i100000) //加速闪耀距离
i++;
}
return 0;
}