欢迎来到天天文库
浏览记录
ID:39638881
大小:653.50 KB
页数:12页
时间:2019-07-08
《如何实现微控制器与FPGA的接口设计》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、如何实现微控制器与FPGA的接口设计将近一半的嵌入式设计用到FPGA,仅次于微控制器。FPGA可用于执行任何胶合逻辑、自定义IP、计算密集型算法加速器。通过采取一些处理任务,FPGA可以帮助提高系统性能,从而使单片机从周期密集的任务中腾出部分时间。FPGA还提供优良的性能特点和更的灵活性,以适应不断变化的标准。基于FPGA的MCU设计有两种基本实现方式:一种是在FPGA逻辑结构中内置MCU软核;一种是使用基于离散FPGA的标准MCU产品。FPGA内置软核有效果,但与标准MCU相比,该方式实现一个微控制器是比较昂贵和耗电的。尤其是使用基于32位ARM的内核。结果
2、,基于FPGA内置软核的FPGAMCU设计只占三分之一。其余的三分之二是基于离散FPGA的标准微控制器产品。标准微控制器产品和FPGA都没有有效的发展两者之间的通信,甚至使用不同的语言。因此,它们之间的接口将是一种挑战。FPGA的没有任何专门的逻辑电路来与微控制器通讯。首先,这种逻辑模块的设计必须从零开始。其次,微控制器和FPGA之间的通信是异步的。特别是需要使单片机与FPGA时钟域同步。最后,无论是接口,还是微控制器总线,都存在瓶颈问题。MCU和FPGA之间的信息传递通常需要在MCU总线上循环,且通常占用资源(PIOorEBI)影响传递速度。因此必须注意避免
3、与外部SRAM或闪存和微控制器总线的瓶颈问题。MCU的FPGA接口基本上有三种硬件选择:可编程的I/O(PIO);外部总线接口(EBI的),如果有的话;最后,MCU之间的一个专门的接口,先进的高速总线(AHB)和FPGA。该方法的使用依赖于高端应用和市场期望。PIO接口通过PIO连接MCU和FPGA相对简单数据传输来说比较简单,包括传输32位的地址,32位数据,还有一些控制信号的控制。这就需要一个32位的PIO和一个2位PIO(图1)。图1PIO连接FPGA为了将数据传输到FPGA,PIO中的双向缓冲器方向必须设置为输出。数据传输到FPGA的软件算法实现如下:
4、PIO_DATA=ADDRESS;//PasstheaddresstowritePIO_CTROL=START
5、WR;//SendstartofaddresscyclePIO_CTROL=CLEAR;//ClearPIOctrl,thisendstheaddresscyclePIO_DATA=DATA;//SetdatatotransferPIO_CTROL=START;//DataisreadyinPIOPIO_CTROL=CLEAR;//Thisendsthedatacycle从FPGA读取数据的方法相似。同样,PIO中的缓冲区首先必须设置为输出,然后改变
6、方向为输入从FPGA读取数据,下面是执行代码:PIO_DATA=ADDRESS;//SettheaddresstoreadPIO_CTROL=START
7、RD;//SendstartofaddresscyclePIO_CTROL=CLEAR;//ClearPIOctrl,thisendstheaddresscyclePIO_DATA_DIR=INPUT;//SetPIO-DatadirectionasinputtoreceivethedataDELAY(WAIT_FOR_FPGA);//waitfortheFPGAtosendthedataDATA_FROM_
8、FPGA=*PIO_DATA;//ReaddatafromFPGA上述算法是一个基本的传输,更先进的算法是必要在ARM微控制器和FPGA之间建立适当的通信。特别要注意的是,确保数据的可靠性,例如没有因高速或等待周期造成资料遗失等。访问时间计算的总和:T访问-PIO=t1+处理阶段+t2+数据阶段使用最大优化的GCC编译器,系统大约需要55个AHB周期向FPGA执行写操作(图2)。图2PIO向FPGA写数据假设t2(FPGA的等待响应时间)也大约是25个AHB周期,系统大约需要85个AHB周期从FPGA进行读操作(图3)。图3PIO从FPGA读取数据MCU自身接
9、口连接非常简单和直截了当。然而,在FPGA里必须用特殊的逻辑来解码所有的由PIO生成的业务流。在大多数情况下,微控制器的业务流是完全异步。因此,FPGA必须能够从微控制器中过采样控制信号;否则,FPGA将错过时间窗口且业务流将不会最终到达FPGA内。因为处理器专门负责维持PIO工作,所以处理时间消耗很大。虽然CPU是从事数据传输,它还是不能做别的事了。因此,这一解决方案有可能使系统处理陷入瘫痪。DMA不可能使用的PIO接口,所以程序员必须限制的数据带宽,以便其他任务能够与MCU进行通讯。例如,如果有一个常规的进程要求100%的处理器运行周期,同时又要与FPGA
10、进行串行(SPI,USART或TWI)
此文档下载收益归作者所有