赞
踩
<big><font color="red">
可编程输入输出单元、可编程逻辑单元、布线资源 </font></big>
FPGA的IOB是输入/输出块(Input/Output Block)的简称,它是FPGA内部实现复杂逻辑的关键部分,负责处理输入输出信号。IOB内部包含了一系列的逻辑单元,用以完成信号的缓冲、驱动、映射等功能。
在Xilinx的FPGA中,IOB内部结构可以简化为以下几个主要部分:
FPGA IO命名与Bank划分
FPGA I/O之差分信号
在FPGA中,CLB是实现逻辑功能的基本单元,一个CLB由2个slice组成,slice可以分成以下的两类:SliceM(Memory)和SliceL(Logic)。这两种slice的区别在于它们的LUT不同。
SliceL和SliceM内部都包含
4个6输入查找表(LUT6)
3个数据选择器(MUX)
1个进位链(Carry Chain)
进位链CARRY在FPGA中本质上就是解决加减法进位问题的元器件
8个触发器(Flip-Flop)
CLB的sliceM中LUT形成的RAM可以同步写异步读,而BRAM形成的RAM只能同步写同步读。**
补充:
区域(Region):每个FPGA器件被分为多个区域,不同的型号的器件区域数量不同。时钟资源
FPGA时钟资源主要有三大类:时钟管理单元、时钟IO、时钟布线资源。
DCM(数字时钟管理器,Digital Clock Manager)
通过 FPGA 芯片提供的DCM 功能, 可灵活地控制时钟频率、相位转换和时钟脉冲相位差。
zynq
器件延时 T C O T_{CO} TCO大概0.2ns
建立时间大概0.01ns
保持时间大概0.12ns
为什么要时序约束?——综合工具是以时序约束为驱动的进行布局布线的策略,即时序约束是综合工具进行综合的参考点
同步系统的要求
Xilinx 7系列FPGA的bram最小大小为36Kb,可配置为两个18Kb,也可级联成更大的RAM,另外每个bram内封有寄存器,可作为输出缓冲,好处便是不需要利用CLB的触发器(这样会加大延时
FPGA中的布局布线资源主要包括三部分:CB、SB和行列连线。布线资源的目的是为了能够让位于不同位置的逻辑资源块、时钟处理单元、BLOCK RAM、DSP和接口模块等资源能够相互通信,从而协调合作,完成所需功能。FPGA中的布线资源,就好比绘制PCB板时的连线资源一样,虽然器件A和器件B的位置和连接关系没有任何改变,但很可能因为周边电路的布局、布线的一些变化,使得前后两次A、B之间的连线形态发生很大的变化。因此,与采用固定长度的金属线将所有宏单元连接在一起的CPLD不同,FPGA中任意两点之间的线延迟是无法预测的,必须等到布局、布线完成之后才能确定。这也是为什么在FPGA的开发中,时序约束和时序分析这两样工作是必不可少的。
布线资源连通FPGA内部的所有单元,而连线的长度和工艺决定着信号在连线上的驱动能力和传输速度。主要分为四类:全局布线资源、长线资源、短线资源、分布式布线资源。
Xilinx FPGA中可用的最复杂的计算块是下图所示的DSP48块
DSP48块是嵌入FPGA结构中的算术逻辑单元(ALU),由三个不同的块组成的链。DSP48中的计算链包含一个加/减单元,连接到一个乘法器,再连接到最后的加/减/累加引擎。这条链允许单个DSP48单元实现如下形式的函数:P=Bx(A+D)+C or P+=Bx(A+D)
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。