摘 要: 提出了一种 FPGA 远程动态重构的方法,结合 FPGA 动态重构技术和 GSM 通信技术来实现。利用 GSM 技术实现配置数据的无线传输,在单片机控制下将数据存储于 CF 卡中。在内嵌硬核微处理器 PowerPC405 控制下,FPGA 通过内部配置存取端口读取 CF 卡中新的配置数据,对可重构区进行配置以实现新的功能。
 

随着现场可编程门阵列的广泛应用,对其进行灵活的重新配置的研究也越来越多。目前绝大多数 FPGA 都是基于查找表 LUT(Look UP Table)的技术,采用 SRAM 工艺生产。这种工艺的 FPGA 有两层结构,上层为配置存储器,下层是硬件逻辑层。通过上层配置信息控制硬件层门电路的通断,改变芯片内基本逻辑块的布线,从而形成特定的功能。这种架构为动态重构技术实现提供了可能。一个 FPGA 大型数字系统总是由很多功能模块组合而成,这样各个系统模块的激活状态就可能在时间轴上产生分离,时间上分离的模块就可以共用一个硬件逻辑区,根据需要对这个逻辑区动态地改变配置,实现不同的功能,这就是局部动态重构[1]。FPGA 的动态重构使其应用更加灵活,减少了硬件的资源消耗,缩短了开发周期。但是对一些特殊场合,如深海数据采集或机器人野外勘探,开发者可以为某个系统模块设计几个功能,设备在自主运行过程中根据需要选择相应的配置数据进行配置。如果遇到特殊环境,事先设计的功能有可能不适合工作要求,需要增加新的功能。在目前硬件进化技术还无法进行实际应用的情况下,本文设计了一种远程动态重构的系统来解决上述问题。


1 远程动态重构系统的结构

远程动态重构系统有 PowerPC 处理器和 89C54 微控制器两个核心。VirtexII-Pro FPGA 内部集成有 2 个 PowerPC405 嵌入式处理器[2],本文系统使用其中一个,实现对动态重构进行控制和调配。FPGA 内部用于对局部重构区域 PRR 进行重新配置的硬件模块有 3 个,分别是嵌入式内核 PowerPC、系统高级配置环境 System ACE 和内部配置访问通道 ICAP。System ACE 是一种在系统编程的高级配置解决方案,它提供 CF(Compact Flash)、MPU 和 Test JTAG 等多个接口,本系统采用 CF 卡作为配置数据的来源,可以更方便地改变和存储配置数据。ICAP 的主要作用就是按照特定时序将配置数据重新配置到 PRR 中[3]。


远程数据传输通过外接控制器 89C54 完成,一方面控制器要通过 UART 接口接收 GSM 模块 TC35 传来的数据;另一方面要把接收到的配置数据写入 CF 卡中,以供 FPGA 系统读取。


System ACE 和 89C54 控制器共用 CF 卡的控制接口。为避免互相影响,本系使用多路复用器将 CF 卡端口做分时复用处理,即配置过程中与 System ACE 连接,而数据传输存储过程中与 89C54 进行连接。远程动态重构系统结构如图 1 所示。

 

 

2 远程动态重构的本地准备

以机械手臂的控制为例,采用 PID 控制、模糊控制和备用三种控制方案,每个控制算法经过验证综合生成独立的 bit 流模块。这三个模块共用一个可重构的区域 PRregion,根据具体情况,选用最适合的算法模块,动态地配置重构区域来控制机械手臂,其他静态逻辑区域则仍然正常运行。这样不仅提高了系统的灵活性,而且节省了配置时间、减少了不必要的消耗。FPGA 的设计流程一般包括设计、仿真、综合、实现过程,本文根据系统自身结构提出如图 2 所示的设计流程。

 

 

FPGA 重构系统综合使用 EDK(Embedded Development Kit)、ISE 和 PlanAhead 多种工具平台,采用分层化设计,以简化设计过程。其过程如下:


(1)利用嵌入式开发工具 EDK 设计一个基于 PowerPC405 的嵌入式控制系统[4],添加 SystemACE_CompactFlash 外设以支持从 CF 卡配置 FPGA;添加 IP 核 opb_hwicap 以支持嵌入式内核通过 ICAP 读取配置数据动态地配置 FPGA。


(2)EDK 包含有软件开发工具 SDK,因此利用 SDK 对 PowerPC405 进行软件编程和调试,最终生成应用程序二进制 executable.elf 文件;利用 EDK 外设创建向导,创建多个控制算法 IP 模块,在各自的 VHDL 文件中编写相应的算法;使用 ISE 工具对多个算法模块进行综合、创建顶层模块、实例化嵌入式系统和算法模块。综合产生 top 网表文件。


(3)创建 PlanAhead 工程,使用以上产生的网表文件和约束文件进行布局布线。其中最重要的是将算法模块设置为可重构模块,对其进行严格的区域约束[5],其约束代码如下:


AREA_GROUP "AL_PRregion" RANGE = SLICE_(minX)(minY):SLICE_(maxX)(maxY)
AREA_GROUP "AL_PRregion" RANGE = RAMB16_(minX)(minY):RAMB16(maxX)(maxY)


在 PlanAhead 工具中可以通过可视化方法进行区域约束,既直观又简单。可重构模块在运行过程中如果需要实现不同的控制算法,则需要在重构区中添加所有算法模块综合生成的网表文件、使用 PR Assemble 命令生成多个不同的算法 bit 流文件。除了动态 bit 流文件外,PlanAhead 还会产生一个静态完整的 bit 流文件 static_full.bit。可执行以下两个命令生成 ace 配置文件:


(1)data2mem -bm implementation/system_stub_bd -bt implementation/static_full.bit -bd TestApp/executable.elf tag ppc310_0 –o b implementation/static.bit。


(2)xmd -tcl genace.tcl -jprog -target ppc_hw -hw implementation/static.bit -elf TestApp/executable.elf -board ml310 -ace system.ace。


3 远程动态重构的实现

经过动态重构本地准备之后,得到如表 1 所示的 CF 卡配置文件列表。设置保留模块,是为了给新的控制算法保留一个接口(以一个空文件存储在 CF 卡中)。

 

 

传统的本地重构设计完成后,针对重构区域会得到几个不同的配置文件,如针对机械臂控制算法重构区得到两个初期设计的控制算法配置文件。在实际运行过程中,有些环境只需 PID 控制就可满足要求,而有些环境采用模糊控制更合适。如果采用这两种控制方法都不能满足工作要求时,必然要对初期设计进行升级,对复杂危险的工作现场进行远程动态重构。


本文提出的设计方法是:GSM 模块作为远程数据传输工具,与 89C54 单片机通过 UART 端口连接,单片机接收到一个扇区 512 B 的数据写入 CF 卡 reserved.bit 文件中。GSM 模块采用西门子公司的 TC35 模块,它支持 AT 指令,由 89C54 发送 AT 指令 ASCI 码对 TC35 进行控制[5]。本设计主要涉及到的 AT 指令如表 2 所示,TC35 以串行模式与 89C54 进行通信。