常见IO接口标准之FPGA

                                           常见IO接口标准之FPGA

0 引言

        最近准备采用Xilinx FPGA进行多机通信,即主FPGA芯片将采集到的不同层的图像数据流分别输出给对应的4块从FPGA芯片中,主从FPGA之间的连接机制采用星形拓扑结构。经计算,图像数据流接口速率需要数百兆比特/秒,因此需要调研FPGA支持的常见IO接口标准,及每种接口的应用场合。现在项目使用的FPGA芯片为Spartan6系列,故参考的user guide为UG381,《Spartan-6 FPGA SelectIO Resources》。

1 常见IO接口标准

        Xilinx FPGA提供和支持高性能、可配置、多样化的接口标准。主要的可配置属性为On-chip termination(输入端/输出端的内置片上端接电阻),output strength(输出驱动器的电流驱动能力),slew rate(电压压摆率)等。

        常见IO接口可分为单端IO接口和差分IO接口,详细的IO标准参见下图1。单端IO接口和差分IO接口均满足高速接口传输,区别在于应用场合不同。

Xilinx FPGA芯片不同的Bank支持的IO接口标准范围略有所不同,但是同一Bank必须使用同一output drive voltage (VCCO)。

 

1.1 端接电阻

由上图2可知,当使用高速IO接口时,在接收端通常需要匹配的端接电阻,有利于高低电平的转换和提高信号的完整性,且端接电阻尽可能的放置在接收端。

(a)差分输入端接电阻

        通常需要在差分输入端并行端接100Ω的电阻,FPGA在差分输入接收器提前内置了端接电阻,其阻值R为100Ω,为可选项optional。设计者也可以采用外接端接电阻来进行电阻匹配,阻值选择更灵活。采用片上内置的端接电阻可以节省无聊和缩小PCB面积。

                    

 

通过UCF文件进行约束,是否使用差分输入端接电阻,语法规则如下:NET <I/O_NAME> DIFF_TERM = "<TRUE/FALSE>" 。

(b)单端输入端接电阻

        由上图可知,一些单端IO接口也需要输入端接电阻来匹配信号的完整性,例如HSTL,SSTL。SSTL电平通常应用在DDR SRAM中,例如SSTL18应用在DDR2,SSTL15_II应用在DDR3中。详见下图所示。

                               

通过UCF文件进行约束,是否使用单端输入端接电阻,语法规则如下:

NET <NET NAME> IN_TERM = <NONE / UNTUNED_SPLIT_25 / UNTUNED_SPLIT_50  /  UNTUNED_SPLIT_75>;

(c)输出端接电阻

        由上图可知,输出端(也称为源端)也可以配置输出端接电阻,以减少信号的反射,应用在高速单端信号场合,例如FPGA输出驱动DDR3芯片。输出端接电阻也是optional可选项,常见阻值R为none,25Ω,50Ω,75Ω。通过UCF文件进行约束,是否使用单端输出端接电阻,语法规则如下:

NET <NET NAME> OUT_TERM = <NONE/ UNTUNED_25 / UNTUNED_50 / UNTUNED_75>;

说明:由上图可知,FPGA作为输出端,其端接电阻可以通过内置端接电阻配置完成,但如果DDR SRAM作为后一级的输入端,该芯片没有片上端接电阻,故需要外接50Ω的输入匹配电阻。

 

1.2 设置IO接口属性

    常见IO接口属性包括:电平标准,输出压摆率,输出驱动能力,上/下拉。详细设置参考下文。

 

 

 

2  常见IO接口标准&应用

        当今大厂家会基于其IO接口的总线应用场合提出新的IO接口标准,随后被其他厂家所使用。每一种IO接口标准均有其特有的电压、电流、输入输出缓冲和端接匹配技术要求。Xilinx User Guide详细列出了常见的各种IO接口的种类,定义及应用场合,详见下文。

   

 

3   高速IO接口应用举例

        基于FPGA的高速IO接口应用的常见例子有两种,详见下文。

        第一种: 采用SSTL15_II接口标准,应用于DDR3 SRAM,属于single-end IO standard;

        第二种: 采用LVDS33/25接口标准,应用于IOSERDES的高速串行通信,属于differential  IO standard;

3.1  DDR3 SRAM接口驱动

        FPGA驱动DDR3 SRAM芯片时,FPGA作为输出源端,SRAM芯片作为终端,故FPGA需要配置output driver 的相关属性参数attributes。SRAM作为input receiver,需要进行端接电阻匹配,由于没有内置片上端接电阻,故需要在SRAM输入管脚外接匹配电阻,由于数据端口是双向端口,故输入端是高阻状态,无需匹配。而地址总线接口和差分时钟输入接口需要匹配对应阻值的电阻。

(a)FPGA输出端IO Standard在UCF文件中参数配置如下:

NET  "mcb3_dram_dq[*]"      IOSTANDARD  =   SSTL15_II   |    IN_TERM = NONE   |   OUT_TERM = UNTUNED_50;

压摆率和上下拉采用默认参数,SLOW slew rate, 12mA  output drive。

(b)SRAM输入端IO standard,地址管脚和数据管脚尽可能均匀分配在某一个或多个Bank中。

地址总线输入端(单端接口)需匹配50Ω端接电阻,差分时钟输入端(差分接口)需要匹配100Ω的端接电阻,见下图所示。

                        地址总线输入接口                                                                                          差分时钟输入接口

说明: 1.  SRAM输入管脚的端接电阻尽可能靠近管脚,以保证信号的完整性;

             2.  每一组bank均有独立的Vcco和Vref,便于配置variable IO standard;

             3. 为减少SSO(simultaneous switching output)的大量输出管脚电平同一方向切换的干扰,可以增加virtual                          

                 VCC/GND pins,即将该bank未用到的管脚在FPGA程序中设置为GND或VCC;

 

3.2   LVDS差分IO接口驱动

        LVDS:低压差差分信号,每位数据需要一对差分信号线,相较于单端接口,差分接口可以抑制共模噪声,电压摆幅约350mV,因此信号传输功耗较低。LVDS接口传输速率上限可达3.125Gbit/s,如果配合相应的编码规则(如8b/10b)和使用SERDES技术,可以保证常用高速信号通信。

        差分信号输入端需要端接匹配电阻,如果输入端为FPGA管脚,可以通过配置,使能其内置端接电阻,阻值默认为100Ω。UCF配置LVDS接口如下:

说明: 1.  压摆率越快,电平转换时间越短,时间性能越优;

             2.  Spartan6 FPGA所有Bank均支持LVDS差分输入,但只有Bank0和Bank2支持LVDS差分输出;

 

  • 18
    点赞
  • 110
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: FPGA IO相位移是指FPGA芯片上的输入输出端口信号在传输过程中发生的相对时间延迟。当信号从FPGA的输入端口送入到输出端口时,由于信号需要在内部逻辑电路中经过一定的处理和传播,所以会引起相位的延迟。 FPGA芯片中的IO资源通常由输入寄存器和输出缓冲器组成。输入端口的信号通过输入寄存器进行采样后,再经过内部逻辑电路处理后发送到输出缓冲器,最后输出到外部设备中。在这个过程中,信号需要在内部逻辑电路中传播,会经过许多逻辑门、数据通路等,而这些组件都会引入一定的延迟,从而导致信号的相位发生变化。 由于FPGA的内部逻辑电路会根据设计需要进行优化和布局,不同的逻辑电路组件的延迟也会有所差异。因此,FPGA IO相位移通常是一个不确定的值,需要在设计和布局阶段进行综合和优化,以确保信号的稳定性和正确性。 针对FPGA IO相位移问题,设计者可以采取一些方法来减小其影响。比如,可以采用合适的布局和布线规则,将相关的输入输出端口尽量靠近,减少信号的传播路径和延迟;可以合理设置时钟和数据的时序关系,以确保信号在传输过程中不会出现冲突和干扰;可以使用FPGA芯片自带的时序分析和优化工具,对设计进行综合和布局分析,找出潜在的相位问题并进行优化。 总之,FPGA IO相位移是一个需要设计者重视和解决的问题,通过综合布局和优化设计,可以有效减小相位移的影响,提高FPGA设计的性能和可靠性。 ### 回答2: FPGAIO相位移是指通过FPGA芯片来改变输入输出信号的相位。在FPGA中,IO相位移可以用于调整时钟信号的相位,从而实现对输入输出信号的同步或延迟控制。 首先,FPGAIO相位移可以用于时钟信号的同步。在FPGA设计中,不同模块之间通常需要使用同一时钟信号进行数据传输和处理。然而,由于信号路径的长度和电路延迟等因素的影响,时钟信号可能会出现相位不一致的情况。通过使用FPGAIO相位移功能,可以对时钟信号进行微调,以实现各个模块之间的同步,确保数据的准确传输。 其次,FPGAIO相位移还可以用于延迟控制。在某些应用中,需要对输入信号进行延迟处理,以满足系统对时间精度的要求。通过FPGAIO相位移功能,可以对输入信号进行微调,从而实现对信号延迟的控制。这在一些音频、视频处理等需要对信号进行同步处理的场景中非常常见。 总而言之,FPGAIO相位移是一种通过调整时钟信号相位来实现输入输出信号同步和延迟控制的功能。它对于保证信号的稳定传输和满足系统对时间精度的要求非常重要。FPGA作为可编程的硬件平台,可以根据具体应用需求通过配置IO相位移参数,以实现更灵活、高效的信号处理和传输。 ### 回答3: FPGA(可编程逻辑门阵列)的IO(输入/输出)相位移是指在FPGA芯片内部对输入和输出信号进行延时控制,以达到满足特定设计需求的目的。 首先,FPGA芯片的IO延时可以通过调整时钟边沿来实现。在FPGA设计中,时钟信号用于同步各个逻辑元件,对于需要通过IO接口传输的信号,可以通过控制输入输出寄存器(IOB)的时钟边沿来实现输入输出相位的调整。例如,可以选择上升沿或下降沿作为IO的采样点,从而调整信号被采样的时机,以改变信号的相位。 其次,FPGA芯片还提供了专门的相位锁定环(PLL)或延迟锁定环(DLL)等硬件资源,用于实现更精确的IO相位移。通过对这些资源的配置和控制,可以对输入输出信号的时钟进行细粒度的延时和相位调整。这些锁定环通常采用反馈环路或计数器的方式,通过调整内部时钟的相位来实现IO信号的相位控制。 最后,FPGA芯片通常提供了硬件描述语言(如Verilog或VHDL)来描述设计的逻辑电路,并能够通过工具链进行综合、布局和布线等操作。在这个过程中,可以使用特定的语法和指令来指定IO信号的延时和相位移。通过合理地设定延时和相位参数,可以满足各类设计需求,如时序要求、时钟分频、数据同步等。 综上所述,FPGA芯片的IO相位移是通过控制时钟边沿、使用专门的PLL或DLL资源以及合理使用硬件描述语言等手段来实现的。具体的相位移控制方法会根据设计需求和FPGA芯片的资源而有所不同,需要结合具体的设计和技术手段来实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值