一乐电子

 找回密码
 请使用微信账号登录和注册会员

QQ登录

只需一步,快速开始

微信扫码登录

搜索
查看: 10017|回复: 3

SOPC技术应用

[复制链接]
发表于 2009-1-23 14:04 | 显示全部楼层 |阅读模式
第1节 SOPC开发流程和开发工具
3 ?, q+ p+ a& M9 u% k6 [SOPC设计包括硬件和软件两部分。
& v5 m8 J6 p' N2 L% P* q- S硬件设计:主要基于Quartus II和 SOPC Builder。
# J' i" T+ X+ v4 v软件设计:基于Nios II IDE。$ `6 K; K2 ^) Q" V. x
http://www.eefocus.com/data/08-09/4155_1221817002/1223185828.jpg9 n0 A5 I. R, v/ {
流程见图解析:0 ]9 z8 }" W! G- O. h3 Y1 c
分析系统需求: 在进行SOPC开发之前,首先必须确定系统的需求,如应用系统需求的计算性能、需要的带宽和吞吐量、需求的接口类型以及是否需求多线程的软件等。
' Y! g5 T, X0 [' D4 C建立Quartus II工程:每个开发过程开始时都应建立一个工程,Quartus II是以工程的方式对设计过程进行管理。在工程中建立顶层模块文件.bdf相当于传统电路设计中的电路板(PCB)。
2 I( B" }+ q1 S定义和生成系统:在SOPC Builder中添加需要的功能模块(Nios II及其标准外设模块),完成后生成一个系统模块。& h  E/ ~. R' \) @2 F8 z
定制指令&定制外设逻辑:如果需要,用户可以定制指令和外设逻辑。(可参考第8章) 1 Z: r6 k9 k# w9 l- \) f
自定义的功能模块:当设计中现有模块不能满足设计要求时,可设计自己的功能模块。并在顶层模块中使用;
/ e! G/ |7 g5 Q% q" N集成SOPC生成的系统到Quartus II工程 :在顶层模块中,分别将SOPC Builder生成的系统模块、LPM功能模块以及用户自定义功能模块添加到顶层模块中; 8 a5 [2 k# H" h6 j6 `) ]# w& x" }
连接各功能模块:然后将各个功能模块用连线连起来组成系统功能原理图* U+ }& R9 |% j& \* }) B0 ~7 Y
Altera的LPM模块 :在Quartus II软件中包含了大量的Altera公司提供的LPM功能模块,相当与传统设计中除处理器以外的逻辑芯片(如74系列);
% k+ U5 V- m( Z8 U8 c; ?8 }9 M选择FPGA型号并进行管脚分配 :为系统功能原理图选择芯片载体并为各个输入输出信号分配芯片的管脚; 7 F* Y  A0 k! {9 y
进行编译选项设置:设置编译选项,从而让编译器按照用户设定来进行编译;
1 s5 K- `7 b8 j9 `编译硬件系统生成配置文件sof :编译系统生成硬件系统的配置文件*.sof和*.pof。编译系统是一个非常复杂的过程,包括优化逻辑的组合、综合逻辑、适配FPGA、布线以及时序分析等步骤。
. b2 a$ J/ N8 G( C! g下载配置文件到FPGA器件:将配置文件.sof下载到FPGA,将可执行文件.elf下载到RAM。
1 w0 a) s- [% \$ P9 ?& C& h设置软件运行硬件环境属性:设置好软件运行的硬件环境属性后,便可进行编译、链接和调试、运行程序。
1 O3 ?5 m' b2 O* j( S编译软件:对用户程序进行编译,生成可执行文件*.elf。 5 _( z! P0 T( {8 B, c0 u. F3 s
ISS运行/调试 :接下来在IDE的指令集仿真器(ISS)上仿真软件和运行/调试软件。 2 {- i4 a% y  X) l3 _, t
在目标板上运行/调试软件 :在目标板上反复调试软件。   y! v5 x2 ?  D( }" K' h6 _
使用IDE编程工具 烧写配置文件和软件代码 :最后利用IDE的编程工具将配置文件烧写到FPGA的配置芯片或Flash,将可执行文件*.elf编程到Flash中。
& T& E5 o; o! O: A. K' i; p5 {1 z8 D2 S
(1)硬件开发 ( ~7 ]. j+ w" i+ S7 R0 D0 [( _) l
        用SOPC Builder软件从NiosII处理器内核和NiosII开发套件提供的外设列表中选取合适的CPU、存储器以及各外围器件,并定制和配置它们的功能; 分配外设地址及中断号; 设定复位地址;用户也可以添加用户自身定制指令逻辑到NiosII内核以加速CPU性能; 添加用户自己设计的IP模块。编译Quartus II工程,对HDL文件进行布局布线,从HDL源文件综合生成一个适合目标器件网表,生成FPGA配置文件(.sof);
2 X2 A# z2 G" T用下载电缆(如 ByteBlaster II),将配置文件下载到目标板上。硬件校验完成后,可将新的硬件配置文件下载到目标板上的非易失存储器(如EPCS器件)。
$ s' y' j. J2 h4 K9 k0 |http://www.eefocus.com/data/08-09/4155_1221817002/1223550096.jpg
5 W& q3 ?0 `: U(2)软件开发
, H6 o* |8 S6 |9 G        软件开发使用Nios II IDE,它是一个基于Eclipse IDE架构的集成开发环境,它包括: - ?* Q( R% s+ U% [8 u3 v8 R) [
        GNU开发工具(标准GCC编译器,连接器,汇编器和makefile工具等); 4 x/ }' ^1 D6 w% H3 q/ ^4 z$ B
        基于GDB的调试器,包括软件仿真和硬件调试; ! ^0 o: o; I0 X8 F6 g/ z; r0 t
        提供用户一个硬件抽象层HAL;
% z5 i2 P: t8 g: [1 L1 A$ W) M        提供嵌入式操作系统MicroC/OS-II和LwTCP/IP协议栈的支持; 7 J# ?5 `' w  h
        提供帮助用户快速入门的软件模板;   Q5 V1 [& b/ s  L7 w
        提供Flash下载支持(Flash Progrmmer 和QuartusII Programmer) / Q  W1 T+ q. I" w# H  {0 W: M
        使用SOPC Builder生成系统后,可以直接使用Nios II IDE开始设计C/C++应用程序代码。Altera提供外设驱动程序和硬件抽象层(HAL),使用户能够快速编写与低级硬件细节无关的Nios II程序; 除了应用代码,用户还可以在Nios II IDE 工程中设计和重新使用定制库。 + E0 s( y# E7 U) M
3 y2 T% t2 t0 X+ W- D
 楼主| 发表于 2009-1-23 14:07 | 显示全部楼层
第2节 SOPC硬件开发实例
5 f( z: Q; E* f. f. P, F4 ySOPC硬件开发实例  H" `4 A; V( ?) m/ x6 R
第一步是要进行需求分析,根据这个要求来建立硬件系统。 2 X5 y  g0 Y* n* w
电子钟的设计要求: # i' K! ?$ A" J/ i
在液晶屏上显示日期、时间;
& L% N3 V. |6 W  A% n. x# h9 C可以设置日期、时间;
7 t# b& U$ g) m8 F0 `$ U" R
8 \. l+ j! s* y3 r8 W. m' c根据系统要求实现的功能,电子钟的设计要用到的外围器件有:
" g. k  I8 I0 z7 W+ g& jLCD:电子钟显示屏幕; + R0 b# ~# n. Y) ], |: @) e
按键:电子钟设置功能键;
1 K0 D5 Q2 D" V1 P* xFlash存储器:存储软、硬件程序;
$ B& Y' ^$ \6 `3 wSRAM存储器:程序运行时将其导入SRAM。
* c  t9 w/ a# I8 r5 r1 G: }根据所要用到的外设、要实现的功能以及开发板的配置,在SOPC Builder中建立系统要添加的模块包括:Nios II CPU、定时器、按键PIO、LCD控制器、AVALON三态桥、外部RAM接口、外部Flash接口。5 a8 H3 G' X% A- q3 c$ X; `
使用的开发环境如下:
4 X- l) E% S) S5 x' s  f& ^WinXP操作系统
- t2 T9 @- _7 e; YNios II 6.0嵌入式处理器 , h/ V* e0 [7 H5 X+ ~( N& p
Quartus II 6.0
8 F% E& d. y, \2 ^基于Cyclone II 的SOPC开发板 2 _7 {" E0 Y5 ^+ m6 \8 V! B2 Z
2.2.1 创建工程
$ Z, m6 J2 V. |. l+ V) P$ E* _+ `进行完需求分析之后,进行硬件系统的创建。 / d# X* c, Z. h# v$ @& g" a/ d
首先必须建立一个Quartus II 的工程, 7 o/ Y3 j9 l9 Y6 s: G0 o' c  I* C
步骤如下:
* x" z! G" C9 C4 e( Y8 m1. 开始程序AlteraQuartus II 6.1Quartus II 6.1(32 bit),启动Quartus II软件;
, b7 J: U6 E- T$ ~4 p; ]
4 E4 A# }- n0 c1 h4 {2.选择File菜单New Project Wizard,出现Introduction页面,该页面介绍所要完成的具体任务,点击next。
$ j- L1 [- j* t4 g* h& ?; S. _' i9 P
* m' u# P$ v$ ^
3. 进行项目名称的设定、工作目录的选择。指定工程存放的目录,工程名和顶层实体名,工程名和顶层实体名要求相同,工程目录可以随意设置,但必须是英文的目录,工程名和顶层实体名也要求是英文名字,我们的工程名和顶层实体名为clock,选择Next。
3 Z$ H2 D9 ^- }7 `- i5 ?
4.可以为工程添加先期已经输入的设计文件,指定用户自定义的元件库的路径,这里我们没有事先输入好的文件,也没有自定义的元件库,点击Next进入下一步。
3 [" F; F- N; `; S7 `
5. 用户指定目标器件,根据开发板的所使用的器件来选择,实际开发中,通过查看核心板的参考手册来获取所使用的器件具体型号,可以使用窗口右边的Filters来加快器件的选择,选择完毕点击Next。
! v4 x+ \* C: t& l1 n" F6 B: @+ I8 v
6. 指定在Quartus II 之外的用于,设计输入、综合、仿真、时序分析的第三方EDA工具,Quartus II对第三方工具的支持比较完善。这里我们不做选择,直接点击Next。
          所见新工程的信息,确认所创建工程的主要信息,点击Finish完成工程的建立,在开发的过程中,还可以通过菜单assignmentSettings来对这些配置进行修改。 点击Finish按钮,Quartus II自动会打开这个工程,可以看到顶层实体名出现在工程导航窗口中。   V. ~9 T, Y9 B6 M5 ^
回复

使用道具 举报

 楼主| 发表于 2009-1-23 14:09 | 显示全部楼层
创建完成工程之后,需要创建顶层实体。创建完顶层设计文件之后,使用SOPC Builder创建NIOS II 嵌入式处理器,添加、配置系统的外设IP,组成Nios II系统模块。 Nios II 系统模块设计完成之后要加入到该顶层实体中,然后进行其他片上逻辑的开发。
9 d$ v9 ^5 u; i. w$ ~2.3.1 创建顶层实体* \3 n6 t3 a$ r
(1)新建的工程窗口中,选择FileNew;
- o, d% @1 o( J9 c- d; \(2)在Device Design File页中,选择Block Diagram/Schematic File,即原理图文件,也可以选择硬件描述语言的文件形式。单击OK。 4 T2 u  g& ]* ^- G3 Y
(3)出现一个模块编辑窗口。: F/ Y) x/ w2 m7 K( P
(4) 选择FileSave As,出现Save As对话框,显示的目录为之前设置的工程目录,文件名为之前设置的顶层实体名(由于这是工程的第一个文件,系统会默认为顶层设计实体的名字)。确定Add to Current Project选项被选中,点击Save文件被保存并被加入到工程中。 , ?+ p- i1 C4 ?3 d
- @8 q8 t% i8 {2 o6 C: t7 g
2.3.2 创建Nios II系统模块
# O, B4 e( T, Z* q! W        创建NIOS II系统模块需要使用SOPC Builder,它是Quartus II中的一个工具,使用SOPC Builder可以创建一个Nios II 系统模块,或者创建多主设备SOPC模块。一个完整Nios II的系统模块包括Nios II处理器和相关的系统外设。所以创建系统模块的流程是先创建一个系统,然后添加Nios II CPU和外设IP,然后进行相应的设置,最后生成实例,然后将其加入到工程的顶层实体中去。 0 f1 Y- K/ s  D) R* `
一、创建系统 3 P4 ?0 l8 B/ A' @; Z  T! j
启动SOPC Builder,选择ToolsSOPC Builder,出现图2-10的Create New System对话框。键入系统的名字,选择硬件描述语言Verilog或者是VHDL。
6 {2 c" ~- B0 F  z( m/ [
+ R5 Q* n" [+ W; n. U, Y5 G! O+ U/ M9 ~9 N/ k" E; }
6 K/ h# p6 \. a. ^
二 、设置系统主频和指定目标FPGA 3 @% f) R3 U3 B  R9 D8 h
        在Target栏中的Board部分指定我们这本书使用的核心开发板——Cyclone II (EP2C35)。也可以在Board部分选择Unspecified,然后在Device Family选择Cyclone II。 / F- F$ _, P9 r2 p" s
用户需要设置系统的时钟频率,该频率用于计算硬件和软件开发中的定时,比如时钟分频或波特率。这里我们设成85MHz,还可以选择是否选用流水线。
; [( W4 S$ Y7 }) f. _# A三、加入Nios II CPU和 IP模块 - k3 o& {- E! O3 |2 L
        首先加入Nios II软核,Nios II 是软核CPU,共有三种类型的CPU可供选择:Nios II/e(经济型)、Nios II/s(标准型)和Nios II/f(快速型)。用户可以根据实际的情况进行选择。Nios II是一个用户可以自行进行定制的CPU,用户可以增加新的外设、新的指令等。 2 x& }  z) \4 Z5 P, X% u
添加Nios II CPU的步骤如下:   S  x2 ~$ J) u% G( d
1. Avalon Components 下面选择Nios II Processor; : t- x0 _# ~2 p8 K( V' B
2. 点击 Add,出现Nios II CPU的配置向导,共有三种类型的CPU可供选择;
6 a8 F- V0 w& W, Z. o9 d# p0 z
        根据需要选择相应的一种Nios II核,我们选择标准型的Nios II核,Hardware Multiply选择none,不选择Hardware Divide点击Next,进入Caches & Tightly Coupled Memories设置窗口; * R6 R+ {+ r3 z, o# k* X7 E9 m
         设置Nios II的Cache和与CPU直接相连的存储器端口(不通过Avalon总线),选择Instruction Cache为4Kbytes,不选中Include tightly coupled instruction master port(s) ,点击Next进入Advanced Features设置页面。
) c  M: A; M" `0 Q- P: @
         Advanced Features的设置页面是Quartus II 6.1 版本才有的设置,这里不选择Include cpu_resetrequest and cpu_resettaken signals点击Next进入JTAG Debug Module设置。
http://www.eefocus.com/data/08-09/4155_1221817002/1223437930.jpg
        共有4个调试级别可供选择,这里选择Level1即可,该级别支持软件的断点调试。JTAG调试模块要占用较多的逻辑资源,如果整个系统调试完毕了可以选用No Debugger以减少系统占用资源点击Next进入自定义指令的设置。   O: G/ G) H3 P0 V
        因为本例不用到任何的自定义指令,这里不作任何的设置,点击Finish完成CPU模块的添加。 . K/ n- q' V, {1 x- w
5 a5 ~, |  R/ O5 u. S8 ?" Q
除了Nios II CPU,电子钟设计需要添加的IP模块包括:
0 y# s0 L$ }, f4 L2 ZTimer 2 b2 x7 D  c. U7 G
Button PIO
; e8 K" B: u# \; H& RLCD控制器 4 X! n" e8 _' Z
External RAM Bus
; n, z- ]" H7 dExternal Flash Bus 2 u; P, N6 S  O' v0 F
External RAM interface
4 z6 G2 O7 H6 ^3 c) [4 gExternal Flash Interface
" n7 t3 a5 N3 Q5 j' b" W1. 添加定时器 2 Y9 S8 D9 b. J# Q+ g( @
定时器和Nios II CPU一样,用户可以对其进 行定制。添加定时器的步骤如下: ( S% @6 i8 X* _  T  o/ E
(1)在Avalon components下的other库中选 择Interval Timer并单击Add,Avalon_Timer-timer_0的向导窗口出现; ( R; a3 j1 V% J/ a8 M
(2)配置定时器,点击Finish,完成定时器的添加。 4 h/ o0 e) D+ ?4 e" C
(3)可以对Timer进行重命名,我们这里取缺省的名字。 1 `* S; Q! F, `. n9 X& _
2. 添加Button PIO : u2 ^) o: r8 X7 \+ h6 T
(1)在 Avalon components下的other下选择PIO,单击Add,出现Avalon PIO-PIO_0的向导; 5 I  ]0 o. t+ u
(2)在Basic Settings页中,设置width=4bits,direction为Input Ports Only;
" j5 r  X- \2 L: D% c4 t2 S(3)在Input Options页中,在Edge Capture Register下选中Synchronously Capture,然后选择Either Edge; 6 d# ~  ~3 y5 w* W. y
(4)在Interrupt下选中Generate IRQ,然后选择Edge; ( y) S2 j, J9 C3 P% B/ v, ?( Q
(5)点击Finish,返回到Altera SOPC Builder NIOS2的窗口;   g, [! y* X9 y. E
(6)右键单击Module Name下的pio_0,从菜单选择rename,重命名为button_pio.
9 z3 O+ Y. |* W1 }. p3. 添加LCD控制器 1 u. s' s# e' e- `0 t
(1)在图2-11的窗口中的左侧的Avalon components下的display库中选择Character LCD(162, Optrex 16027),单击Add;
" x! r9 X. _% R. |. u6 {9 Y2 J7 b(2)Module Name下出现,lcd_16027_0;
& t+ ?( L7 y6 X1 P2 B1 a. }) F(3)将其重命名lcd_display。 . C% k( p" j6 [2 v5 B
4.添加外部RAM接口 4 L9 o2 b4 p& Z# N& L/ X
(1)Avalon components下的Memory下面选择Cypress CY7C1380C SSRAM,单击Add,出现SSRAM (Cypress CY7C1380C)-ext_ssram的向导;
% V+ `& O" \) s' m: `1 `(2)在Timing Parameters下面设置Read Latency 为2 clocks,在SSRAM下面设置Memory Size为2Mbytes ) w. F# p# M0 n4 R! A
(3)单击Finish,返回到Altera SOPC Builder NIOS2的窗口;
' Y0 n/ p: i% c; o3 \( }(4)右键单击Module Name下的ssram_0,从菜单选择rename,重命名为ext-ssram。 5 l' P( x3 J0 J
5. 添加外部闪存接口 9 o: E# L& F2 [+ y' H
(1)在Avalon components下的Memory下面选择Flash Memory(Common Flash Interface),单击Add,出现外部闪存接口向导;
" j' e8 b$ K3 V- h(2)在Attributes页中,可以在Presets列表中选择相应的闪存的接口,这些闪存的接口都是经过测试的,如果列表中没有,用户可以自己定义闪存的Size和Data Width;
; U0 W' F  q: K7 H) k# f' e/ [
(3)在timing页中,可以设置闪存的读写时序要求,可以设置Setup, Waite, hold时间等参数,通常保留缺省的设置;
& ?& ~9 f% w4 z1 b6 q- {(4)如应用选择的闪存接口不在列表中,需要自己定义Size和Data Width,和时序要求;
3 Q+ n" A( L0 P  [(5)点击Finish,返回到Altera SOPC Builder NIOS2的窗口,Module Name出现cfi_flash_0,对其重命名为ext_flash。 : b8 c2 m9 J5 U+ O: X

; z: s" d3 ~* R4 z9 z2 C' V
6. 添加外部RAM总线和外部flash总线(Avalon三态总线桥6 }8 n; ~9 \1 ]; `: t- D, p
为了使Nios II 系统能与开发板上的外部存储器通信,必须在Avalon总线和外部存储器之间加入Avalon三态桥。 2 J. b* M. v% @5 Z4 `
步骤如下:
2 D2 f. S( K# {% J9 j' o# {(1) 在Bridge下,选择Avalon Tri-State Bridge,点击Add,出现Avalon Tri-State Bridge – tri_state_bridge_0向导; 7 x$ |! N& c+ ?& r" T2 Q
(2) Registered选项默认为选中; & s3 m% ^% L* x
(3)单击Finish,返回到Altera SOPC Builder NIOS2的窗口;
3 _, x+ I' i3 A. a& Q
(4) 将其重命名为ext_ssram_bus;
( U! J: l# v$ X& m4 g* [(5) 重复前三个步骤,在添加一个Avalon三态总线桥,并重命名为ext_flash_bus. ! H" ?- S$ d+ D) U+ a8 a, G( |! H: e
7.添加JTAG UART
- N1 P) G! h# c1 o4 M" ?
(1)在Avalon components下的Communication下选择 JTAG UART,点击ADD,出现添加向导。 ! m9 I. U1 X  V" k8 x
(2)按照缺省设置,点击Finish。
7 x2 S) I% }0 e6 }$ K(3) 将其重命名为JTAG_UART.
, A" h# O7 b# M# v8. Nios II系统的连接
8 w" r8 L; d' g+ A4 p) l& @3 ^        主要是外部RAM接口要和RAM的三态桥连接,外部的Flash接口要和flash的三态桥连接。所有添加的IP连接都是系统自动完成的,除了上面提到的三态桥和外部存储器的接口的连接之外,其它的连接用户不用修改,但对于三态桥和外部存储器接口的连接,系统的自动连接可能和用户的开发板不匹配,用户需要进行手动的更改。针对我们所用的开发板的情况进行的设置,因为本书用到的开发板外部的SRAM和外部的Flash没有使用共用的数据线和地址线,所以必须为它们分别添加一个三态桥。
4 n" @; B$ z4 O4 T* @  p
2.3.3分配IP模块的地址和中断号
        在以上添加IP的过程中,SOPC Builder为各个IP模块分配了一个默认的基地址,用户可以改变这些默认的分配。如果用户自己分配的地址出现冲突,SOPC Builder会给出警告,用户可以按照下面的步骤来进行分配和解决地址冲突问题。 : m! F) l& q9 J8 R1 w  D, v5 V  e5 h
下面我们给出一种自定义的地址分配实例,将闪存的基地址设定为0x00000000,步骤如下: 7 n1 `4 P3 j- h: _" {3 d& R
(1)单击Flash外设的Base栏,将地址改为0x0,然后回车,这时SOPC Builder的消息框中出现错误的提示信息,这是因为闪存的地址和其它的外设地址发生了冲突。 ( }! p9 `: \/ |& O8 A
(2)选择Module菜单中的Lock Base Address操作,一个挂锁的图标出现在闪存基地址的旁边。 - r3 X5 F  L: y. y. ^. f, C
(3)选择System菜单中的Auto Assign Base Address操作,来解决外设的地址分配冲突问题,SOPC Builder调整其它外设的地址来避开与闪存地址的冲突,错误提示的消息就会消失了。 1 F8 P5 O& Y) ]) Q0 ^/ }7 B
(4)用户可以手动修改各个外设的中断号,中断号越低,中断优先级越高,用户也可以采用自动分配中断号,选择System菜单中的Auto Assign IRQs,但SOPC Builder不处理软件操作,采用自动分配中断的策略不一定是最优的,用户最好是根据自己的应用来确定外设的中断优先级,采用手动的分配。
; {/ d9 ]* j0 i# S) M7 ?9 ?2.3.4 配置NIOS II 系统
系统的IP模块添加完成之后,还需要对系统进行配置。点击Nios II More “cpu_0” Settings 页,用户可以进行如下的设置: # j, }5 }$ k9 J$ K
Reset Address:可以选择存放Boot Loader的存储器和设置Boot Loader在存储器中的偏移,我们这里选择ext_flash,偏移选择默认;
; C' O8 H- m& l0 m4 H/ kException Address:可以选择存放异常向量表的存放的存储器和设置异常向量表在存储器中的偏移,我们选择ext_ssram,偏移选择默认; ' T" h, F0 I( O$ Y! H& \3 k+ D/ v! `. d
Break Location:如果NIOS II 包含有一个JTAG Debug模块,SOPC Builder会显示这项内容。其Memory Module总是JTAG Debug Module,Offset 固定为0x20, 地址由JTAG debug module基地址决定。用户不能修改Break Location的各个域的内容。
0 _0 g9 U8 T# j* }1 I  }1 M0 K2.3.5 生成NIOS II并加入到工程中
NIOS II系统是工程的一部分,我们首先是生成它,然后加入到工程中去,然后将整个工程下载到FPGA芯片中去。单击System Generation,在Option下进行如下的设置: ' y. P  k$ n! u' O1 s8 r; @
选中 HDL,会生成系统模块的硬件语言文件。   F+ Z# u# n; @( t/ A- G
选中 Simulation,如果安装了ModelSim软件,会生成用于仿真的相应的文件。 # A' I  d# B3 c  b' Z8 ?
单击 Generate,SOPC Builder会提示生成系统的进程,系统生成完成时会提示”SUCCESS: SYSTEM GENERATION COMPLETED”。单击exit 退出SOPC Builder。 4 \- o* W; {' o( P
        系统生成完成之后,SOPC Builder为这个定制的NIOS II系统模块创建了一个符号,要把Nios II系统加入到工程中去,遵循如下的步骤: * O4 K3 f- y1 _6 ~& k7 M, J0 a
(1)在 Quartus II软件中,打开顶层实体(BDF格式),在BDF窗口中任意处双击,出现 Symbol对话框; " V/ ?% n; c" W+ \# d& P
(2)在Symbol对话框中单击Project来展开工程目录,其下出现NIOS2(本例采用的系统名),选中它,右侧出现了系统的符号表示;
9 ?, b) j7 \  V! a# _0 |(3)单击OK,Symbol对话框关闭,NIOS2的符号轮廓被附着在鼠标的指针上。 ; `% o1 @5 e( E- }! S4 v# }
(4)BDF窗口中任意空白处单击一下,NIOS2的符号出现在BDF窗口中,这样我们创建的系统已经被加入到工程中了。 6 \" L9 W, b; X+ x1 R; J% G/ Q

6 c6 ^8 I3 \0 c! K! a2 d7 T1 u0 _
2.3.6 加入引脚和嵌入式锁相环
除了NIOS II系统之外,可能还要有其它的硬件逻辑,我们这里加入一个嵌入式锁相环,嵌入式锁相环有两个时钟输出,一个输出SSRAM提供时钟,另一个时钟的输出为NIOS II CPU提供时钟,然后添加输入、输出、双向引脚,以实现和FPGA外部的外设进行通信。
; l+ N, A9 `; t加入嵌入式锁相环的步骤如下: - C$ F8 V3 Y' i9 @2 G1 D
(1) 点击ToolsMegaWizard Plug-In Manager,出现MegaWizard Plug-In Manager向导Page1窗口,点击next
在MegaWizard Plug-In Manager Page2 窗口中的IO下面选择ALTPLL,器件选择Cyclone II,输出文件类型选择VHDL,文件名为ssram_pll,选中Return to this page for another create operation,然后点击Next,出现MegaWizard Plug-In Manager-ALTPLL [Page 3of 9]; ! P% P( k1 [/ f+ G# M
在MegaWizard Plug-In Manager-ALTPLL [Page 4 of 10]窗口中,不做任何选择,点击next; 3 R: H8 o2 q# V, F- u
在MegaWizard Plug-In Manager-ALTPLL [Page 5 of 10]窗口中,单击next; 4 m" i9 \) J* n4 C: o0 Q8 `
在MegaWizard Plug-In Manager-ALTPLL [Page 6 of 10]窗口中,设置c0输出时钟,首先选中Use this clock选项,设置时钟频率为85MHz,占空比为50%。点击Next会进入c1输出时钟的设置;
  n9 V; ^& C9 k1 c
         嵌入式PLL可提供3个输出时钟,我们使用其中的两个,MegaWizard Plug-In Manager-ALTPLL [Page 7 of 10]窗口中,在c1时钟的设置页面上,选中Use this clock选项,设置时钟频率为85MHz,点击Next;
/ b# v/ V: s, G# N* r" X
在MegaWizard Plug-In Manager-ALTPLL [Page 8 of 10]窗口中,不选中Use this clock选项,即我们不使用c2时钟,点击Next; * u7 W  d- R! V. @
在MegaWizard Plug-In Manager-ALTPLL [Page 9 of 10]窗口中,给出了用于仿真必须要产生的文件,点击Next; * R5 f& r4 G( {& ]: n; }
在MegaWizard Plug-In Manager-ALTPLL [Page 10 of 10]窗口中,给出了用户选择要产生的文件,不做改变,采用默认配置,点击Finish完成PLL的生成。 ' r# P2 p# }- f) O
在顶层实体的bdf窗口中双击鼠标,出现Symbol添加窗口,在project下面选择刚才建立的ssram_pll,点击OK。ssram_pll的轮廓会附着在鼠标上,点击bdf窗口的空白处,将嵌入式锁相环加入到了工程中。
2 V+ s( n% I  Y+ j$ L! p4 t引脚添加的步骤如下:
1 s  l5 z3 A% f+ ?' ?# r3 ~2 J(1)在顶层实体的bdf窗口的空白处双击鼠标,出现Symbol添加窗口,在altera/quartus/libraries下面选择primitives,再在其下选择pin,在其中有三种类型的引脚,有bidir,input,output,分别为双向、输入和输出引脚,选择相应类型的引脚,点击OK。 * d, C. x- i- w0 I5 B8 m9 w
(2)点击bdf窗口的空白处,即将引脚加入到了工程中。
( b" Z/ C2 z& g  ?0 m# ~+ z. M(3)重复上面的步骤添加为各个端口添加相应类型的引脚。
1 `! O6 L; _# A& v
连接引脚和命名引脚
/ r# N1 T3 u/ f( k5 n- T) N第一个加入的引脚的名称缺省为pin_name,之后加入的引脚名称依次为pin_name1,pin_name2向上递增,为了便于理解和记忆,需要对引脚重新命名,使其和其传输的信号联系起来。 & B8 ?; M% g9 ^' k- [6 {8 `
命名引脚的方法如下:
(1) 双击引脚的“pin_namen”部分,pin_namen的文字变成高亮,可以对其编辑。
6 X6 w: q1 L' [; K" G5 b(2) 对其他的引脚重复以上的操作,修改成具有意义的名字。
) z  j* |+ m8 V(3) 对于总线型的引脚,引脚名称之后要标识出总线的位数,如ddr_a[12..0],在引脚名称之后加上方括号,然后写上最高位和最低位,用两个..隔开。 & f7 v- b4 j8 f6 V% A
(4)将嵌入式锁相环和系统模块等连接起来,并将引脚连接到相应的端口上。 ! s8 {+ `0 F4 p+ y1 K" v& f3 `! z
+ e) I9 A$ g8 R/ N6 F$ y- |* i" x

. P5 V6 L  R( K! a* Q4 ], ?
' b4 G/ `  V% f6 @9 S/ V[ 本帖最后由 kenson 于 2009-1-23 14:17 编辑 ]
回复

使用道具 举报

 楼主| 发表于 2009-1-23 14:22 | 显示全部楼层
第4节 设计优化
9 |1 {7 J/ ^- @% M 设计优化主要包括节省占用FPGA的面积和提高设计系统运行速度两个方面。这里的“面积”是指一个设计所消耗的FPGA的逻辑资源的数量,一般以设计占用的等价逻辑门数来衡量。“速度”是指设计的系统在目标芯片上稳定运行时能够达到的最高频率,它与设计的时钟周期、时钟建立时间、时钟保持时间、时钟到输出端口的延迟时间等诸多因素有关。8 z" u3 D; t! G! ]
2.4.1 面积与速度的优化
3 R2 V. ?- R3 b4 r+ l: x1 M- B; L打开我们刚才的工程——clock,然后选择Assignment菜单下的Settings命令,弹出设置窗口。在对话框的左边的Category栏下,列出了很多可设置的对象,包括EDA Tools Settings、Compilation Process Settings、Analysis & Synthesis Settings、Fitter Settings、Timing Settings、Simulation Settings等等,选中要设置的项目,窗口的右边显示供设置的选项和参数。
& ^" {' P* h; o( s2 m在Analysis & Synthesis Settings页面,用于对设计在分析与综合时的优化设置。在该页面的Optimization Techniques栏中,提供了Speed、Balanced和Area3种优化选择,其中Balanced是软件缺省的优化选择。如果对Speed或Area有特殊的要求,则选中相应的选项。
# J  V3 {0 z5 Q9 M
1 L3 S" t9 J2 l. q( w- x2.4.2 时序约束与设置
0 X( B2 U9 c; \8 M选择Settings下面的Timing Analysis Settings,然后选择Classic Timing Analyzer Settings。在此页面中,可以对设计的延迟约束、时钟频率等做设置。延迟约束(Delay Requirements)设置包括tsu(建立时间)、tco(时钟到输出的延迟)、tpd(传输延迟)和th(保持时间)的设置。一般来说,用户要根据目标芯片的特性及PCB板走线的实际情况,给出设计需要满足的时钟频率、建立时间、保持时间和传输延迟时间等参数。对一些简单的应用,对时序要求不严格 ,可以不做设置。 ! T) S9 Q# Z1 P& f7 v

# S& F  ?: _2 {2 ?0 ?- P: ?2.4.3 Fitter设置
; w, q6 x) [4 X在Ssettings对话框中,用鼠标左键单击Category栏目中的Fitter Settings项,出现Fitter Settings设置页面。此页面用于布局布线器的控制。 7 h2 P  U+ X8 F9 y6 D) G
在这里需要设置的主要是布局布线的策略(Fitter Effort),有三种模式可供选择:标准模式(Standard Fit)、快速模式(Fast Fit)和自动模式(Auto Fit)。标准模式需要的时间比较长,但可以实现较高的最高频率(fmax);快速模式可以节省50%的编译时间,但会使最高频率有所降低;自动模式在达到设计要求的条件下,自动平衡最高频率和编译时间。 1 [: F# B& N( }

$ L1 I' ?4 f2 d( [
回复

使用道具 举报

本版积分规则

QQ|一淘宝店|手机版|商店|一乐电子 ( 粤ICP备09076165号 ) 公安备案粤公网安备 44522102000183号

GMT+8, 2025-8-20 12:04 , Processed in 0.038424 second(s), 21 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表