为了对工程的资源利用率进行优化,我们首先需要知道当前工程对资源的利用率情况。在Vivado下,我们可以查看工程的资源利用率情况,在下面这张图中,其罗列出了整个工程所使用的资源情况。首先,下面我们需要一一对LUT/LUTRAM/FF/DSP/IO/BUFG/MMCM这些英文所代表的含义作出解释:

LUT:Look-Up-Table,即查找表。

LUTRAM

-资源利用率中的LUT是指设计中消耗的所有LUT,包括用做逻辑函数发生器的LUT(SLICEL中的LUT),也包括用做存储单元的LUT(SLICEM中的LUT)

-资源利用率报告中的LUTRAM是指设计中消耗的SLICEM中的LUT(用做分布式RAM/ROM或移位寄存器)

FF:Flip-Flops,触发器

BRAM:Block RAM,储存单元

DSP:运算单元(DSP48E1)

IO:输入输出管脚

BUFG: BUFG是把局部时钟转为全局时钟,减少时钟延迟。.它可以驱动所有的IO和逻辑,

MMCM:(Mixed-Mode Clock Manager)混合模式时钟管理器

IBUFDS

IBUFDS原语用于将差分输入信号转化成标准单端信号,且可加入可选延迟。在IBUFDS原语中,输入信号为I、IB,一个为主,一个为从,二者相位相反。

MUX:F7AMUX, F7BMUX和 F8MUX三种复用器

为了更好的理解以上英文概念,我们先要知道FPGA中其内部结构。参考:xilinx官方文档UG474《7 Series FPGAs Configurable Logic Block》和White Paper《Xilinx 7 Series FPGAs:The Logical Advantage》。下表是一张Artix-7 FPGA CLB资源表:

在Xilinx 7系列的FPGA芯片中,其组成的基本单元为CLB(Configurable Logic Block)。CLB是实现时序逻辑组合逻辑电路的主要逻辑单元。一个CLB由两个Slice组成,每个Slice由4个6输入LUT、8个FF、复用器和算术进位单元组成。

同时SLICE有区分为二:SLICEL和SLICEM(没有看到缩写L/M全程,个人认为是Logic和Multiple缩写,从下面定义可以看出)。大约2/3的是SLICEL(只能用于logic),剩下的是SLICEM(还可以用于distributed RAMs/SRLs32/SRLs16)。

通过以上的分析,每个CLBs具体的资源配置如下:

好了,有了以上对Xilinx 7系列的FPGA芯片内部结构的基础认识。我们再来看看Vivado下那张资源利用率的图:

LUT:Look-Up-Table,即查找表。

LUT的作用是实现所有的逻辑函数,也就是类似于计算Y=A&B+C+D之类的算式结果! 下图是一个查找表功能表:

LUT的一个重要功能是逻辑函数发生器。本质上,逻辑函数发生器存储的是真值表(Truth Table)的内容,而真值表则是通过布尔表达式获得。在vivado中,打开网表文件,选择相应的LUT,在property窗口中可以看到真值表。

下图是一个6输入查找表内部结构:

6输入查找表内部结构

例子:对于4输入的LUT而言,实际上就是4位地址位,一位数据位的存储器,能够存储16位数据,所以我们在FPGA设计中可以用LUT组建分布式的RAM。

LUTRAM

-资源利用率中的LUT是指设计中消耗的所有LUT,包括用做逻辑函数发生器的LUT(SLICEL中的LUT),也包括用做存储单元的LUT(SLICEM中的LUT)

-资源利用率报告中的LUTRAM是指设计中消耗的SLICEM中的LUT(用做分布式RAM/ROM或移位寄存器)

FF:Flip-Flops,触发器

BRAM:Block RAM,储存单元

每个BRAM大小为36KB(RAMB36E1),由两个独立的18KB BRAM(RAMB18E1)构成。BRAM与查找表构成的分布式RAM的差异如表1.3所示。尽管BRAM可支持更多的功能,但这并不表明BRAM在任何场合都具有优势。对于一些小规模的数据存储,分布式RAM可获得与BRAM相媲美甚至比BRAM更好的性能(从功耗和速度两方面比较)。

DSP:运算单元(DSP48E1),7系列FPGA中运算单元为DSP48E1,它不仅可以实现逻辑运算,如与、或、异或,也可以实现算术运算,如加法、乘法、乘累加等。

IBUFDS

IBUFDS原语用于将差分输入信号转化成标准单端信号,且可加入可选延迟。在IBUFDS原语中,输入信号为I、IB,一个为主,一个为从,二者相位相反。

如iserdes.v模块中

IBUFDS #(

.DIFF_TERM("TRUE"), // Differential Termination

.IBUF_LOW_PWR("FALSE"), // Low power="TRUE", Highest performance="FALSE"

.IOSTANDARD("LVDS_25") // Specify the input I/O standard

) Dclk_IBUFDS_inst (

.O(Adc_DCLK_p), // Buffer output

.I(Adc_DCLK_0_p_pin), // Diff_p buffer input (connect directly to top-level port)

.IB(Adc_DCLK_0_n_pin) // Diff_n buffer input (connect directly to top-level port)

);

参考文献:https://www.cnblogs.com/xiaoxuesheng993/p/9187499.html

全局时钟网络(BUFG、BUFH)、区域时钟网络(BUFR、BUFMR)和IO时钟网络(BUFIO)

BUFG:全局时钟缓存器

BUFH:水平时钟缓存器

BUFIO:IO时钟缓存器

BUFR:区域时钟缓存器

BUFMR:多区域时钟缓存器

MMCM:混合模式时钟管理器

PLL:锁相环

参考文献:

https://blog.csdn.net/weixin_46062412/article/details/114992793?utm_medium=distribute.pc_relevant.none-task-blog-2~default~BlogCommendFromBaidu~default-14.no_search_link&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2~default~BlogCommendFromBaidu~default-14.no_search_link

UG474的更多相关文章

  1. 基础002_V7-CLB

    一.综述 参考ug474.pdf: 7系列中,一个CLB包含两个slice: 每个CLB的资源: CLB可配置的主要功能: 二.主要功能 LUT是基本单元,例如选择器assign muxout =  ...

  2. FPGA基础学习(7) -- 内部结构之CLB

    目录 1. 总览 2. 可配置逻辑单元 2.1 6输入查找表(LUT6) 2.2 选择器(MUX) 2.3 进位链(Carry Chain) 2.4 触发器(Flip-Flop) 参考文献: 一直以来 ...

随机推荐

  1. CTT 总结

    Day 1 T1 肝 4 个半小时,主要是前面各种假,中途各种改.出来听说 T2 才是签子.但是 T2 只写了 15 分暴力.100+15+0=115. Day 2 T1 肝 4 个小时,但是 8 点 ...

  2. Promise的异常穿透和中断Promise的链式请求

    1.Promise的异常穿透 1==>当你使用Promise的then,进行链式调用的时候,可以在最后指定失败的回调 2==>前面任何操作出现了异常,都会传递到最后失败的回调中进行处理: ...

  3. elementui表格内容超出显示省略号

    有些时候表格的内容太长了: 但是elementui中的表格,会进行换行处理: 此时表格的高度就会发生变化 这样就不好看,此时就要进行省略号来出来这个问题: el-table是有这个控制属性的::sho ...

  4. 解决idea登录github出现的invalid authentication data 404 not found以及登录 token 失效

    0.错误提醒: Your token is invalid, please re-login github and get token again. 报错无效的用户名(invalid username ...

  5. 推荐系统[四]:精排-详解排序算法LTR (Learning to Rank)_ poitwise, pairwise, listwise相关评价指标,超详细知识指南。

    0.前言召回排序流程策略算法简介 推荐可分为以下四个流程,分别是召回.粗排.精排以及重排: 召回是源头,在某种意义上决定着整个推荐的天花板: 粗排是初筛,一般不会上复杂模型: 精排是整个推荐环节的重中 ...

  6. SSM项目创建步骤(随手记)

    一.mybatis项目创建 1:创建maven项目 2:导入pom坐标 3:resources下创建SqlMapConfig.xml配置文件(主配置文件,配置数据库信息,映射配置文件等) 4:创建包及 ...

  7. 1.29 深痛教训 关于 unsigned

    unsigned long long 无符号长长整型,常用于比 long long 大一倍的整数范围或自然溢出 \(\bmod 2^{64}\) unsigned long long 范围为 \(0\ ...

  8. Docker从认识到实践再到底层原理(四-2)|Docker镜像仓库实战案例

    前言 那么这里博主先安利一些干货满满的专栏了! 首先是博主的高质量博客的汇总,这个专栏里面的博客,都是博主最最用心写的一部分,干货满满,希望对大家有帮助. 高质量博客汇总 然后就是博主最近最花时间的一 ...

  9. [奶奶看了都会]ChatGPT接入企业微信成为聊天机器人

    1.聊天效果 上次给大家讲了ChatGPT接入个人微信的方法,但是个人微信容易被封号.这次就教大家接入企业微信,不会再被封号哦~ 话不多说,直接看机器人的聊天效果.基本能实现ChatGPT的聊天效果了 ...

  10. 安装TFA用于快速收集RAC各类日志

    TFA一般主要用于Oracle RAC环境一键收集需要的日志进行分析问题,解决传统人工收集集群.数据库等各类日志效率低下的问题.具体关于TFA的介绍,网上资料已经非常多,在此不再赘述. TFA的安装也 ...