Xilinx官方文档学习之7系列CLB资源解读(UG474)

  • 一、写在前面
  • 二、CLB
    • 2.1 Slice(SliceM and SliceL)
      • 2.1.1 LUT
      • 2.2.2 触发器(Flip-Flop)
      • 2.1.2 DRAM(分布式RAM)
      • 2.1.3 移位寄存器
      • 2.1.4多路复用器
        • 4:1 MUX
        • 8:1 MUX
        • 16:1 MUX
      • 2.1.5进位逻辑
  • 三、写在后面

一、写在前面

  FPGA(Filed Programmable Gata Array)现场可编程门阵列,可以看作是一个积木套件,在这个积木套件里面,我们有很多种的基本模块,我们可以根据自己的想法去组装出来不同的物品,比如:别墅、轮船、飞机等。那么,不同的人根据自己想法组装出来的物品,即使是同一个东西,可能用的基础模块数量也不一致,但是我们依然可以看出两个人组装出来的物品是同一种物品。这时,用更少的基本模块搭建出来同一物品且可靠性一致的人,我们认为他积木玩的更好。

  那么,FPGA也是一样的,内部有很多基本单元构成,我们可以通过编写代码来告诉EDA软件,来组装能够实现我们所需要功能的硬件电路。而对于不同人,实现一个功能所用到的基本单元数量不一致,而使用更少的基本单元且时序上一致,我们认为这个更好。那么,FPGA的基本单元是什么?对于Xilinx公司的FPGA,其基本构成单元是可配置逻辑块(configurable Logic Block,CLB)。

二、CLB

  可配置逻辑块(Configurable Logic Block,CLB)是Xilinx FPGA中实现时序电路和组合逻辑电路的主要逻辑资源,每个CLB单元连接到一个交换矩阵,通过交换矩阵来选择CLB单元中的Slice单元。每个CLB单元由2个Slice单元组成,如下图。

  对于FPGA中的Slice单元,又分为SliceL和SliceM。有些CLB单元由两个SliceL单元组成,有些CLB单元则由1个SliceM和1个SliceL单元组成。SliceM除了基本的组合逻辑和时序逻辑功能以外,还可以用于实现RAM和移位寄存器。(Spartan-6系列FPGA中还有SliceX)。

2.1 Slice(SliceM and SliceL)

  每个Slice包含以下资源:

  • 4个LUT(Look-Up Table)
  • 8个触发器(Flip-Flop)
  • 宽多路复用器
  • 进位逻辑

  所有的Slice都有这些基本单元来提供逻辑、算术和ROM功能,另外,一些Slice还支持两个附加功能:构建分布式RAM和32-bit移位寄存器,这些Slice称为SliceM,其余的Slice称为SliceL。每个CLB单元有两个SliceL单元组成或者由1个SliceL和1个SliceM单元组成。SliceM和SliceL如下图所示。


2.1.1 LUT

  7系列的FPGA搭载的LUT为六输入的LUT,每个Slice中的4个LUT(可以作为函数生成器,输出A、B、C、D)各自有6个独立的输入(A1 ~ A6)和两个独立的输出(O5 ~ O6)。

  • 一个任意的6输入布尔函数
  • 两个任意的5输入布尔函数,只要这两个函数共享输入
  • 两个任意的3输入或者2输入甚至更小的布尔函数

  另外,对于Slice中的LUT单元,Slice还提供了3种多路复用器(F7AMUX、F7BMUX和F8MUX),这些多路复用器用于组合最多4个LUT,以在片中提供7输入的函数或者8输入的LUT。

  • F7AMUX:用于将Slice中的LUT A和LUT B组成1个7输入的函数(8输入的查找表);
  • F7BMUX:用于将Slice中的LUT C和LUT D组成1个7输入的函数(8输入的查找表);
  • F8MUX:用于将Slice中的所有LUT(LUT A、LUT B、LUT C、LUT D)组成一个8输入的函数(8输入的查找表);

  如果需要实现超过8个输入的LUT,可以通过多个Slice单元实现,但是在Slice之间没有像Slice内部一样,有固定的连线用于生成更大的LUT,这在FPGA布局布线时会根据设计进行布线。

2.2.2 触发器(Flip-Flop)

  每个Slice上有8个触发器,其中4个可以配置为边沿触发的D触发器或者电平敏感的锁存器。剩余的4个存储单元只能配置为边沿触发的D触发器。这里需要注意:当一个Slice中的4个触发器被配置为锁存器时,剩余的4个触发器将不能使用。也就是说,一个Slice中的触发器虽然支持配置为D触发器,也支持配置为锁存器Latch,但是并不能将一个Slice中的4个触发器配置为D触发器,4个触发器配置为锁存器Latch,一个Slice中的触发器只能配置为同一类型的器件,要么8个全部配置为D触发器,要么4个配置为锁存器,而剩余的4个不用。

2.1.2 DRAM(分布式RAM)

  SliceM中的LUT可以配置为分布式RAM,一个SliceM中的LUT可以以各种方式进行组合,从而实现更大的存储空间。1个SliceM可以通过配置实现以下规格的分布式RAM:

  • Single-Port 32 x 1-bit RAM
  • Dual-Port 32 x 1-bit RAM
  • Quad-Port 32 x 2-bit RAM
  • Simple Dual-Port 32 x 6-bit RAM
  • Single-Port 64 x 1-bit RAM
  • Dual-Port 64 x 1-bit RAM
  • Quad-Port 64 x 1-bit RAM
  • Simple Dual-Port 64 x 3-bit RAM
  • Single-Port 128 x 1-bit RAM
  • Dual-Port 128 x 1-bit RAM
  • Single-Port 256 x 1-bit RAM

      分布式RAM配置包括以下几种:
    (1)单端口(Single Port):只有1个端口,既用于同步写,也用于异步读;
    (2)双端口(Dual Port):1个端口用于同步写和异步读,1个端口用于异步读;
    (3)简单双端口(Simple Dual Port):1个端口用于同步写,1个端口用于异步读;
    (4)四端口(Quad Port):1个端口用于同步写和异步读,3个端口用于异步读;
      在这里需要注意的是,上面列举一个SliceM可以构造的所有规格的DRAM,其中最大深度为256,如果要实现深度大于256的分布式RAM,则需要多个SliceM来形成更大的分布式RAM。

2.1.3 移位寄存器

  暂不做介绍。

2.1.4多路复用器

  7系列的每个Slice中提供3个固定的二选一数据选择器:F7AMUX、F7BMUX和F8MUX,另外,7系列中的单个Slice可以还可以实现以下几种规格的宽多路复用器:
(1)4选1数据选择器(4:1 MUX):使用1个LUT,每个Slice可以生成4个4选1数据选择器;
(2)8选1数据选择器(8:1 MUX):使用2个LUT,每个Slice可以生成2个8选1数据选择器;
(3)16选1数据选择器(16:1 MUX):使用4个LUT,每个Slice可以生成1个16选1数据选择器;

4:1 MUX

  Slice中的每个LUT可以配置为1个4:1的MUX,一个Slice单元最多可以实现4个4:1的MUX,如下图所示。

8:1 MUX

  每个Slice单元中有1个F7AMUX和1个F7BMUX,这两个二选一数据选择器和两个LUT组合可以构造1个8:1 MUX,一个Slice单元最多可以构造2个8:1 MUX,如下图所示。

16:1 MUX

  每个Slice单元中都有1个F8MUX,结合另外两个二选一数据选择器F7AMUX、F7BMUX和4个LUT,可以构造1个16选1数据选择器,如下图所示。

  对于大于16:1的数据选择器,可以通过多个Slice之间的LUT和二选一数据选择器进行构建,但是每个Slice之间没有固定的连线,需要根据设计在布局布线阶段进行布线。

2.1.5进位逻辑

  在7系列FPGA的Slice中,还提供了专用的超前进位逻辑,用于执行快速的加减法运算。每个Slice单元中的进位链有4级,对于每一级,都有1个进位多路复用器MUXCY和1一个异或门相连,用于选择加/减法操作的进位,如下图所示。

三、写在后面

  在这里,我们学习了CLB单元的基本构造,CLB单元主要由Slice单元组成,由于Slice分为SliceM和SliceL,所以CLB可以分为两种:

  • CLB(1):由2个SliceL组成;
  • CLB(2):由1个SliceL和1个SliceM组成;

  Slice均由4个LUT、8个Flip-Flop、多路复用器和进位逻辑组成,而SliceM和SliceL的主要区别在于LUT,SliceM的LUT支持配置为DRAM,SliceL的LUT则不支持。可以用一张图总结本节的知识,如下图。

  好了,上面就是关于Xilinx FPGA中CLB资源的一些学习笔记,如果有疑义的地方欢迎评论区友好探讨学习!!!!!

Xilinx官方文档学习之7系列CLB资源解读(UG474)相关推荐

  1. HarmonyOS(一) 快速开始学习鸿蒙开发,官方文档学习路线解析

    系列文章目录 HarmonyOS(一):快速开始学习鸿蒙开发,官方文档学习路线解析 HarmonyOS(二):应用开发环境搭建准备 HarmonyOS(三):创建你的第一个HelloWorld应用 文 ...

  2. ZooKeeper官方文档学习笔记03-程序员指南03

    我的每一篇这种正经文章,都是我努力克制玩心的成果,我可太难了,和自己做斗争. ZooKeeper官方文档学习笔记04-程序员指南03 绑定 Java绑定 客户端配置参数 C绑定 陷阱: 常见问题及故障 ...

  3. ZooKeeper官方文档学习笔记01-zookeeper概述

    纠结了很久,我决定用官方文档学习 ZooKeeper概述 学习文档 学习计划 ZooKeeper:分布式应用程序的分布式协调服务 设计目标 数据模型和分层名称空间 节点和短命节点 有条件的更新和监视 ...

  4. Spring Framework 官方文档学习(四)之Validation、Data Binding、Type Conversion(二)

    接前一篇 Spring Framework 官方文档学习(四)之Validation.Data Binding.Type Conversion(一) 本篇主要内容:Spring Type Conver ...

  5. Spring Boot 官方文档学习(一)入门及使用

    Spring Boot 官方文档学习(一)入门及使用 个人说明:本文内容都是从为知笔记上复制过来的,样式难免走样,以后再修改吧.另外,本文可以看作官方文档的选择性的翻译(大部分),以及个人使用经验及问 ...

  6. R语言reshape2包-官方文档学习

    R语言reshape2包-官方文档学习 简介 核心函数 长数据与宽数据 宽数据 长数据 melt函数 meltarray meltdataframe meltdefault meltlist cast ...

  7. Spring Data Commons 官方文档学习

    Spring Data Commons 官方文档学习   -by LarryZeal Version 1.12.6.Release, 2017-07-27 为知笔记版本在这里,带格式. Table o ...

  8. Spring Framework 官方文档学习(四)之Validation、Data Binding、Type Conversion

    本篇太乱,请移步: Spring Framework 官方文档学习(四)之Validation.Data Binding.Type Conversion(一) 写了删删了写,反复几次,对自己的描述很不 ...

  9. jsTree 组件官方文档学习

    jsTree 组件官方文档学习 什么是 jsTree 根据jsTree官网的解释:jsTree 是一个jquery 插件, 提供交互式树.它是完全免费的,开源的,并根据MIT许可进行分发.jsTree ...

  10. Open3D官方文档学习笔记

    Open3D官方文档学习笔记 第一部分--点云 1 可视化点云 2 体素降采样 3 顶点法线评估 4 访问顶点法线 补充:Numpy在Open3D中的应用 5 裁剪点云 补充1:获取点云坐标 补充2: ...

最新文章

  1. [ASP.NET]状态管理[摘自C#入门经典]
  2. 【 NLS 】Newton – Raphson Iteration Procedure of TOA - Based Positioning
  3. 动态链表增删改查及排序功能
  4. fasttext简单理解及应用
  5. 算法(5)-leetcode-explore-learn-数据结构-字符串
  6. 日志框架介绍(SLF4J及其使用)
  7. Epic:把虚幻引擎推向所有游戏平台
  8. Linux下内存使用率、CPU使用率、以及运行原理-转
  9. 微信支付开发(3) 对账单
  10. 操作系统安装教程之图解Ubuntu Server 14.04安装
  11. 挑战性题目DSCT101:硬币找换问题
  12. Quartus II破解出现的问题
  13. 使用XMind编写测试用例
  14. 验证账号的服务器失败是怎么回事,服务器安全验证失败怎么回事
  15. adb 连接逍遥游模拟器搭配monkey命令 抓取 logcat日志
  16. 关于安装jdk后为什么要配置环境变量的那些事
  17. android微信第三方登陆混淆,Android 第三方应用接入微信平台研究情况分享(二)
  18. 个人介绍静态网页【附源码】初学者的期中作业
  19. Linux下删除特殊字符的文件或文件夹
  20. 廉价交换机走俏的原因以及使用中的风险

热门文章

  1. matlab卡方拟合优度检验,卡方拟合优度检验在教学中的应用及Matlab实现_刘泽显.pdf...
  2. 软件工程毕业设计 SSM考研信息搜集分享管理系统(源码+论文)
  3. Spring事务的那些坑
  4. 一个简单易用的二维码条形码解析及生成工具(完美支持中文、英文编解码)
  5. EXCLE学习第7课:EXCEL与PPT联动
  6. 专业的收费艺术二维码设计网站
  7. 联想拯救者y700 2023参数 评测
  8. Android应用开发之所有动画使用详解,android软件开发计算器
  9. 来自ARM TechCon大会的十项有趣技术成果
  10. java 零钱拼凑,2017腾讯校招笔试编程题-拼凑零钱