找回密码
 注册
关于网站域名变更的通知
查看: 154|回复: 1
打印 上一主题 下一主题

基于FPGA片上PowerPC和VxWorks的TCP/IP通信

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2020-6-9 18:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x

摘??? 要:本文以Xilinx公司Virtex-II Pro器件为开发平台,介绍了其内嵌PowerPC405处理器设计的原理和软硬件协同设计方法。结合典型的TCP/IP通信实验,文中详细描述了系统设计方法以及VxWorks系统下BSP的开发和移植过程,并给出了实验结果。
5 ~, ^6 P$ K8 Z, }- c! C5 ]2 U  关键词:PowerPC405;EDK;BSP;TCP/IP通信

引言+ v/ Z1 n& E+ f' _, L& [' Z
  随着应用的不断普及和深入,在设计嵌入式系统时,往往需要同时优化众多因素,如成本、功率、尺寸、性能、灵活性、产品上市时间、设计开发周期,以及可靠性等。Xilinx 公司推出的嵌入式处理器设计平台Virtex-II Pro和Virtex-4系列器件可以满足上述要求,其高性能的设计工具为设计者提供了完善的软硬件协同设计能力。本文以Virtex-II Pro P20 芯片内嵌PowerPC405硬核为处理器,选用目前广泛使用的VxWorks操作系统,阐述了内嵌PowerPC嵌入式设计的过程和要点,详细介绍了TCP/IP实时传输的整个设计过程,实验结果表明这种构架模式具有很好的应用前景。

7 T" z. {: @; \  n" Q+ [. {
基于FPGA片上PowerPC
0 V( s7 f; m+ E3 u4 i: y, T的嵌入式系统开发4 Z) Q( p/ V+ _. n+ K3 S
  随着嵌入式技术的发展,针对当前嵌入式处理器的应用,Xilinx公司推出了两款基于FPGA的32位嵌入式处理器内核。一种是采用先进IP植入技术实现的嵌入在Virtex-II Pro和Virtex-4器件中的PowerPC405处理器内核(这是业界目前唯一的嵌入式硬核),另一种是MicroBlaze 32位嵌入式处理器软核。硬核的好处是能够提供更快的数据处理能力,而软核则具有更好的灵活性,在目标器件中可以进行任意配置。由于硬核在速度和资源上具有优势,因此本文采用了PowerPC405处理器,它支持复杂嵌入式的应用模式。由于同时需要嵌入式RTOS VxWorks,而FPGA内部的BlockRAM往往不能满足提供较大存储空间的要求,因而一般要由外部的存储器阵列实现。3 q+ h& f( z  H

# U8 |+ ?# ^, \, j2 I* r  该体系结构主要应用于需要RTOS支持的数据处理、软件、控制等实时系统以及以FPGA为核心的复杂应用中。Virtex-II Pro系列器件采用IBM CoreConnect总线技术,该总线包括:处理器局部总线(PLB)、片上外设总线(OPB)和设备控制寄存器总线(DCR)。PLB总线为片内的高速数据通道,通常连接高速外设、DMA存储控制器等,OPB总线则通常用于连接速率较低的片上外设,二者通过总线桥接器与处理器总线连接,从而保证PLB总线的高速特性。DCR总线用于实现PowerPC405的通用寄存器与逻辑设备控制寄存器的数据通信。

  针对基于PowerPC405的平台FPGA设计,Xilinx公司推出了完整的软硬件协同设计工具EDK (Embedded Development Kit),它是一个专用于FPGA内部32位嵌入式处理器的集成化开发工具包,并提供硬件和软件协同设计的能力,从而极大地缩短了设计周期。在软硬件协同设计开发平台上,嵌入式软件工程师仍然可以独立地进行软件设计,硬件逻辑工程师也就可以继续采用过去的设计方法。& I( o8 o6 {9 D# z. L5 B' b
7 b0 ~! W2 }$ D- X+ g; a+ O# w0 B
  在实际的软硬件协同开发时,如果不使用嵌入式RTOS,PowerPC405可以起到类似单片机的作用,软件开发就变得相对简单。而在一些大型项目的开发过程中,嵌入式RTOS往往是必需的,因此,研究嵌入式RTOS应用开发及其BSP的移植具有关键意义。

基于PowerPC405的
7 }- q/ _9 d* V6 Y6 T) J$ j7 KVxWorks下的TCP/IP通信9 y8 c& N9 N; A$ r: n) H" G
整体系统设计??0 b: h& z7 g% d
  VxWorks提供了丰富而标准的socket编程接口,可以方便地实现TCP/IP通信,同时,其多任务机制可以高效地完成实时任务的产生、调度、资源分配机制。本文在Virtex-II Pro开发平台上利用PowerPC405内嵌处理器和PC机进行TCP/IP通信,在底层使用100Mbps以太网作为传输媒介,实现了Vxworks嵌入式系统控制的文件实时传输。
: _  o) T. e" d6 |* c4 d# f+ U$ C; ~  e' B) n/ V" k
  可以利用EDK中的BaseSystem BuilderWizard来快速构建基于PowerPC405的系统。首先设定参考时钟频率、处理器时钟、总线时钟,如果在设计中包含有100M网口,那么总线时钟必须选择100M以上的频率。然后选取相应的外设, RS232串口、100M以太网口、SDRAM等,其中plb_bram_if_cntrl外设是必选的,该控制器完成对BlockRAM的控制,保持CPU处于一个确定的状态。系统设计架构如图3所示,这里用到了EDK内带的Ethernet MAC LogiCore(图中的EMAC)。
! D4 `* k9 }+ q4 \$ H; z  ^
+ k# d6 [9 Z- E4 q. PBSP开发和移植
' X, y. K7 h5 ]( B  嵌入式操作系统开发中一项非常重要的任务,就是BSP (板级支持包)的开发。这是一项非常复杂而繁琐的工作,Xilinx公司提供的EDK套件,可以在很大程度上减轻开发者的工作。EDK中的BSP生成器(BSPgen)可以根据不同的微处理器、外设和RTOS组合自动产生用户可裁剪的BSP。它包含了系统所必需的支持软件,包括Boot代码、设备驱动和RTOS的初始化。利用BSPgen可以把Xilinx器件驱动打包到BSP的子目录下,并且把Xilinx器件驱动与VxWorks及其Tornado集成开发环境无缝集成,充分减少开发周期。! Y1 z. H! u$ d+ C1 f

  @0 d* Y/ p/ y  但是,BSPgen生成的BSP只是一个固定的BSP模板文件,不能自动设置RAM/ROM的存储器映射,不支持用户通过BSPgen流程自定义的核/驱动,不能自动集成总线错误检测,而且,Caches在缺省情况下被禁止的。8 b2 ?6 _0 ?3 P; G
7 T  W5 S, L" u. ]
  对于BSP开发人员来讲,借助EDK的BSPgen,还必须要做以下几项工作:: U4 |0 I0 y  a, S- z, N- `
1) 准确定义RAM/ROM边界地址,修改configure.h和makefile文件(两者的地址定义必须相匹配);% Y0 `* i  f% f! H
9 r& S9 p) N5 X5 |# p9 \
2) 增加不能与VxWorks无缝集成的其他器件的驱动文件,如总线错误检测及报告、关键性中断、GPIO接口、I2C接口、SPI接口等;
3 K* C+ G' B3 t' H: u0 @0 z
. f7 S" S5 C% E2 d3) 配置以太网参数,设置缺省的IP地址、MAC地址(sysNet.c文件中);
$ G* z- C6 f# C' n- @# K6 k+ Z2 Z) k4 O9 Z0 E5 |$ D  P
4) 配置内核服务选项,禁止/使能Cache和RAM,设置TCP/UDP/IP参数等;
7 O7 x. o% V2 E4 T3 y4 n' e5 a) F* K' V% o0 ]8 N( O: J$ p
5) 增加总线错误检测报告和关键中断支持文件。
4 f  y7 D1 ^. c; m0 o5 g& U1 X6 t4 ?1 K2 C
  经过以上修改之后,将BSPgen产生的BSP放在Tornado的安装目录…\target\config下,在Tornado集成环境下生成Bootloader,然后就可以进行一般的嵌入式操作系统开发过程了。在这里,对BSP的修改只有config.h和makefile文件的RAM/ROM地址定义,修改如下:
: Q& y& M# ]+ {. R7 M#define ROM_BASE_ADRS?? 0xff800000?????????( [/ S1 V) ^" r, b& X# F3 D4 d
?? #define ROM_TEXT_ADRS?? (ROM_BASE_ADRS)????* z2 B4 t( z3 P7 \6 f
?? #define ROM_WARM_ADRS?? (ROM_TEXT_ADRS+8)??
  h* v* t! Z" I?? #define ROM_SIZE??????? 0x00400000?????????
0 F% i* ~  s$ z6 [* m?? #define RAM_HIGH_ADRS?? 0x00200000?????????/ z0 \/ \0 Y6 I; t; Y5 n
?? #define RAM_LOW_ADRS??? 0x00100000???????
/ n, _4 L# V& I, C
1 T' X3 J& `" y. o  i8 Z& y# hTCP/IP通信实验
( x( X2 r- q. B0 ]. b% V) h  本文建立的实验环境包括:一块Virtex-II Pro开发板DS-BD-2VP20-FF1152(客户端),一台Pentium4计算机主机(服务器端),一根RS232串口线、网线,parallel IV下载线。基于TCP/IP的Socket应用框架原理如图4所示,经过实际测试得知,网络吞吐效率可超过30%。????????9 ?; ^* P1 ~5 I" \
客户端程序:
7 Y) k  \+ D; M$ n, ^) [; nsFd=socket (AF_INET, SOCK_STREAM,0);: }2 O' ~) N3 X! C  o
optval = 60000;
) @* {: ^  \8 l1 g: t% y) |setsockopt (sFd, SOL_SOCKET, SO_SNDBUF, (char *)&optval, sizeof (optval));! d. T- r3 B3 _5 I  c, d: o; {
sockAddrSize=sizeof (struct sockaddr_in);0 u2 N) X& Y7 K9 L8 M$ I7 j
bzero((char *)&serverAddr , sockAddrSize);
8 z% B: @& O; `- n/ s+ LserverAddr.sin_family=AF_INET;  serverAddr.sin_len=(u_char) sockAddrSize;
! w' Q' p, S4 ?4 B! I3 Z# UserverAddr.sin_port=htons (SERVER_PORT_NUM);
' T. _5 a- i, ?+ WserverAddr.sin_addr.s_addr = inet_addr ("128.0.43.102");
% U; D) k2 l# h, O+ Iconnect(sFd, (struct sockaddr *)&serverAddr,sockAddrSize);* d6 _" @4 Y) e) h
send (sFd ,(char *)&myrequest. message, REQUEST_MSG_SIZE,0);
4 e& Q7 f" r/ |2 V/ L3 S8 M服务器端的程序可以由VC类库来实现,这里就不再给出。

结语, G# ^: x' u. O
  开发基于FPGA的嵌入式系统是迈向最终SoC的必由之路,传统的FPGA厂商纷纷涉足嵌入式领域,FPGA所具有的低成本、低功耗、小尺寸、高性能、开发周期短等优势,必将使其在当今嵌入式开发的热潮中具有广阔的应用前景。


* w9 w8 C" W% G. }& Y0 e

该用户从未签到

2#
发表于 2020-6-9 19:21 | 只看该作者
Xilinx 公司推出的嵌入式处理器设计平台Virtex-II Pro和Virtex-4系列器件可以满足上述要求,其高性能的设计工具为设计者提供了完善的软硬件协同设计能力。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-8-21 15:23 , Processed in 0.125000 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

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