3.3添加用户自定义逻辑[4] 在图形用户界面SOPC Builder中,左栏有一项是添加用户逻辑。选择后,在Bus Userface Type 选中Avlaon Register Slave,设置为静态地址对齐方式。加入用户编写的源代码文件,同时指定Verilog代码中各个信号的类型。nios_clk指定为“clk”类型, nios_read_n等指定为“read_n ”类型,nios_write_data[7..0]指定为“writedata” 类型,nios_address指定为“address ”类型,与SL811HS直接相连信号线的都指定为“export”类型。点击Instantiation选择Simulate user logic。再点击Timing,根据SL811HS的时序要求,Setup设置为2,Wait设置为65,Hold设置为5,Unit设置为ns。点击Finish Editing之后,回到主界面,在System Generation中选择SDK和HDL,最后点击Generate。 当SOPC Builder生成一个Nios II处理器设计时,会完成以下工作: 1) 系统存储器映像一致性检查。对外设地址和中断优先级进行唯一性验证,检查其是否在CPU的有效访问范围之内。 2) 为Nios II系统生成一个定制的软件开发包SDK。 生成Nios II处理器系统的硬件设计文件*.ptf,可以用这些文件来创建Nios II系统硬件。 3.4 SL811HS读写函数的实现 读写操作是Nios II与SL811HS最基本的通信方式,Nios II读SL811HS缓冲区数据的时候,先用IOWR函数把所读缓冲区的地址发送给SL811HS,然后调用IORD函数,得到的返回值就是缓冲区的数据。Nios II往SL811HS缓冲区写数据的时候,先发地址,然后调用IOWR函数把数据发送到SL811HS缓冲区的指定地址。在用户工程中的inc/excalibur.h可以找到USB模块对应地址,根据这个地址来实现SL811HS寄存器的读写操作。Nios II每个寄存器占32位,而地址按字节分配,所以每个寄存器使用4个地址,USB模块对应的地址寄存器地址为0x00900c00,数据寄存器地址为0x00900c04。 #define ADDR_REG 0x00900c00 #define DATA_REG 0x00900c04
sl811_read(u8 reg) {IOWR(ADDR_REG,0,reg); return IORD(DATA_REG,0); } sl811_write(u8 reg, u8 val) {IOWR(ADDR_REG,0,reg); IOWR(DATA_REG,0,val); } 4.总结 本文作者创新点:用verilog编写Nios II用户自定义逻辑模块,实现AVALON总线时序与USB控制器SL811HS的时序转换。同时给出了该模块的底层读写函数。本模块已成功在FPGA上实现视频传输功能。 SOPC技术利用库,可以快速生成嵌入式系统。同时,可以方便地把用户自定义的逻辑加入到系统中,体现了用设计嵌入式系统的灵活性。此外,还可以通过SOPC Builder向处理器中添加用户自定义的指令,扩充了Nios II指令集。对于原型机的开发,是一种很好的开发方法,且能够快速地生成最终产品,有效地缩短了开发周期。 参考文献 [1] Altera Corporation. Nios Embedded Processor 32-bit Programmer's Reference Manual [EB/OL].http://www.altera.com/literature/lit-nio.html [2] 马伟. 计算机USB系统原理及其主/从机设计[M]. 北京:北京航天航空大学出版社,2004.123-128. [3] 彭保,范婷婷,马建国. 基于Verilog HDL语言的FPGA设计[J].微计算机信息,2004,20(10):80-82. [4]彭澄廉. 挑战SOC[M].北京:清华大学出版社,2004.84-92. |