从底层结构开始学习FPGA(0)----FPGA的硬件架构层次(BEL Site Tile FSR SLR Device)

系列目录与传送门

《从底层结构开始学习FPGA》目录与传送门


Xilinx的FPGA,从硬件架构的角度可以划分为6个层次,从底层到顶层依次是:

  • BEL(最底层单元)
  • Site
  • Tile
  • FSR
  • SLR
  • Device(FPGA芯片)

image-20240316211630377

接下来我们从最底层开始依次了解下各个层级。

BEL

BEL(Basic Element of Logic),即基本逻辑元素,是FPGA的最底层原子单元(atomic unit)。BEL分为两类:

  • Logic BEL(逻辑BEL)
  • Routing BEL(布线BEL)

image-20240316220558041

逻辑BEL就是常用的底层逻辑资源,比如触发器FF和查找表LUT。而布线BEL则主要是底层用来选择不同走线的MUX。我们可以在工程综合好了以后,先打开综合后的设计:

image-20240317121253439

接着,右侧就会出现FPGA的器件视图Device,如果没有弹出来,可以自己点击Windows,然后点击Device,

image-20240317121530174

在这个视图下(你可以自由缩放来调整),我们可以看到所选型号FPGA的所有底层资源,比如这是一个Slice里面的所有触发器FF、进位链CARRY4和查找表LUT:

image-20240317121942530

这些基本的底层资源都可以用来实现FPGA的逻辑功能(包括时序功能),所以它们是逻辑BEL。而布线BEL则不实现逻辑功能,而只用来实现布线功能。要看到布线EBL,首先需要把模式改成Routing Resource这个选项勾上:

image-20240317122153255

这样就可以在Device视图下看到布线资源和布线BEL了:

image-20240317122443247

接下来随便选择一个布线BEL,把鼠标悬停在它上面就会出现一些基本信息,如果点击选中它则会在左下角出现更详细的信息,比如它的输入/输出管脚分别连接到哪里,它属于哪个时钟区域,它是什么类型的BEL等等。

image-20240317122957290

那么这个名为“D5FFMUX”的布线BEL是如何工作的,我们首先来看看它的输出连到哪里–同一个Slice里的触发器FF。

image-20240317123821257

而两个输入则分别是:输入A来自同一个Slice里的查找表LUT;输入B则来自SLICE的Switch Box。

image-20240317123916535

image-20240317124146864

Switch Box可以理解成一个“中转站“,附近的各种资源的输出都到这里完成转接,所以这个布线BEL的输出B可能是来自相邻的FF,也可能是来自相邻的LUT,具体都根据实际的RTL代码来决定。

布线BEL的功能就呼之欲出了–用来实现各种输入的选取,从而实现底层资源间的灵活互联!正是有了这些布线资源和布线BEL,FPGA才可以做到这么灵活。

在Vivado综合或实现的Design中,都可以看到在每一个模块下会有Nets和Leaf Cells。

image-20240317124701981

Leaf Cells就是FPGA中真实存在的底层模块,Vivado中place_design做的工作就是把这些Leaf Cells放到合适的BEL上去。

Site

一系列相关的元素和互联线则组成了Site,Site中主要包含下面三种元素:

  • BEL(包括逻辑BEL和布线BEL)
  • Site的输入管脚/输出管脚
  • Site内部的互连线

image-20240317124959095

最典型的Site就是Slice,一个Slice由4个LUT,8个FF、1个CARRY4、一系列的布线BEL以及它的对外管脚组成。每一个SITE都有一个独一无二的坐标**_X#Y#,下图中的SLICE的坐标为X21Y276**,这个坐标就是经典的X轴/Y轴坐标系,这样标记出来就可以很方便地在视图中定位它们。

image-20240317125509524

此外,像BRAM、DSP48、PLL等这些资源都算是一个Site。

image-20240317125600228

image-20240317125836576

image-20240317130003400

Tile

Tile是比Site更高抽象级的概念,一个Tile由多个Site组成。经典的Tile就是由两个Slice组成的的CLB(Configurable Logic Block,可配置逻辑块)。

image-20240317145724462

同Site一样,每个Tile也都有一个独立的坐标。

FSR

Fabric Sub Region(我不知道该怎么翻译,架构子区域?) ,FSR由一片Tile组成,其实就是特指Clock Region(时钟区域)。时钟区域是Xilinx FPGA对时钟的一种划分结构,它把整个芯片根据不同的IO BANK内的所有资源和连线都划定到不同的各个时钟区域下,这样对在同一时钟区域下的时钟信号就方便管理,同时也方便各种时钟资源走线和互联。

IO BANK和时钟区域不同简单的画等号,比如的例子都来自芯片xc7k325tfbg676-3,它虽然有10个IO BANK,但是却不一定只有10个时钟区域

image-20240317150626260

和打开Device视图类似,也可以打开它的Package视图来观察它的管脚和BANK情况,如下所示,它有10个BANK。

image-20240317151610546

接着打开它的Device视图看看:

image-20240317151849543

可以看到它有两列,每列有7个时钟区域,所以一共有14个时钟区域。从下图也可以看到,时钟区域和BANK不是对应的。

image-20240317152427837

SLR

Super Logic Region,超级逻辑区域,这个概念仅针对使用了SSI(Stacked Silicon Interconnect)技术的FPGA,也就是包含多个die的芯片,这样每个die就被称为一个SLR。SSI是Xilinx发明的一种能把多个die封装到一起的技术,简单理解就是把多个FPGA芯片给堆到一起,以便扩大资源容量。用到这种技术的一般7系列芯片只有高端的V7芯片,例如xc7v2000tfhg1761-2。它看起来是这样的:

image-20240317152659038

从上到下依次排列着4个SLR,每个SLR都有6个时钟区域。其实每个SLR是可以看做独立的FPGA的,它是Xilinx用SSI技术给封装到一起的。不同的SLR之间做数据交互很麻烦,需要通过特殊的资源来布线–SLL,(Super Long Line,超级长线)。

image-20240317152937187

Device

。其实每个SLR是可以看做独立的FPGA的,它是Xilinx用SSI技术给封装到一起的。不同的SLR之间做数据交互很麻烦,需要通过特殊的资源来布线–SLL,(Super Long Line,超级长线)。

[外链图片转存中…(img-R6jWbsko-1710718103085)]

Device

显而易见,这个Device就是指单个的FPGA芯片了。


  • 📣您有任何问题,都可以在评论区和我交流📃!
  • 📣本文由 孤独的单刀 原创,首发于CSDN平台🐵,博客主页:wuzhikai.blog.csdn.net
  • 📣您的支持是我持续创作的最大动力!如果本文对您有帮助,还请多多点赞👍、评论💬和收藏⭐

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/467904.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

论文解析:V3D: Video Diffusion Models are Effective 3DGenerators

摘要: 自动三维生成最近引起了广泛关注。最近的方法大大加快了生成速度,但由于模型容量有限或三维数据,生成的物体通常不够精细。在视频扩散模型最新进展的推动下,我们引入了 V3D,利用预训练视频扩散模型的世界模拟能…

力扣17. 电话号码的字母组合

Problem: 17. 电话号码的字母组合 文章目录 思路及解法复杂度Code 题目描述 思路及解法 1.将电话号码和对应的数组存入数组中创建映射关系; 2.编写,并调用回溯函数,当决策阶段等于digits的长度时,将当前的决策路径添加到结果集合中…

自学Python第二十九天-feapder框架创建爬虫

自学Python第二十九天-feapder框架创建爬虫 安装feapder 的设计架构feapder 框架的简单使用简单创建爬虫简单爬取数据简单的数据保存 中间件校验浏览器渲染使用浏览器渲染获取接口数据 feapder是一款上手简单,功能强大的 Python爬虫框架,内置 AirSpide…

linux安装WordPress问题汇总,老是提示无法连接到FTP服务器解决方案

最近在做一些建站相关的事情,遇到一些大大小小的问题都整理在这里 1.数据库密码和端口,千万要复杂一点,不要使用默认的3306端口 2.wordpress算是一个php应用吧,所以安装流程一般是 apache http/nginx——php——mysql——ftp &…

嵌入式学习第二十九天!(数据结构的概念、单向链表)

数据结构: 1. 定义: 一组用来保存一种或者多种特定关系的数据的集合(组织和存储数据) 1. 程序设计: 将现实中大量而复杂的问题以特定的数据类型和特定的数据结构存储在内存中,并在此基础上实现某个特定的功…

Python深度学习技术教程

原文链接:Python深度学习技术教程https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247597949&idx4&sn65c0d353d02b060fec98ec799f217ae1&chksmfa823e9acdf5b78cd71cfcb060e3b60125b17afbe3e19ef423d4709d2df7fc93d90ce3097253&token14787…

【K8S】docker和K8S(kubernetes)理解?docker是什么?K8S架构、Master节点 Node节点 K8S架构图

docker和K8S理解 一、docker的问世虚拟机是什么?Docker的问世?docker优点及理解 二、Kubernetes-K8SK8S是什么?简单了解K8S架构Master节点Node节点K8S架构图 一、docker的问世 在LXC(Linux container)Linux容器虚拟技术出现之前,业…

汽车功能安全整体方法

摘 要 ISO26262道路车辆功能安全标准已经制定实践了多年,主要目标是应对车辆的电子和电气(E/E)系统失效。该方法践行至今,有些系统功能安全方法已经成熟,例如电池管理系统(BMS),并且…

Javaweb学习记录(三)请求响应案例

下面为一个请求响应案例,postman发送请求,服务器响应将一个xml文件中的数据通过读取解析,将其用Result类标准的格式返回前端,在前端用json的方式显示 后端Controller代码 1、通过本类的字节码文件得到类加载器并寻找到需要解析的…

vue2使用webSocket双向通讯

基于webSocket实现双向通信,使用webworker保持心跳。 由于浏览器的资源管理策略会暂停或限制某些资源的消耗,导致前端心跳包任务时效,后端接收不到webSocket心跳主动断开,因此需要使用webworker保持心跳 引入webworker npm insta…

【Ubuntu】Ubuntu的安装和配置

下载ubuntu镜像 https://releases.ubuntu.com/22.04.4/ubuntu-22.04.4-desktop-amd64.iso 一、Ubuntu安装 1.新建虚拟机 1.1按照它的提示创建用户;后面一直下一步就好 2.启动Ubuntu虚拟机 2.1设置为中文键盘 2.2默认即可;若是有低需求也可以选择最小…

Coursera上Golang专项课程3:Concurrency in Go 学习笔记(完结)

Concurrency in Go 本文是 Concurrency in Go 这门课的学习笔记,如有侵权,请联系删除。 文章目录 Concurrency in GoMODULE 1: Why Use Concurrency?Learning Objectives M1.1.1 - Parallel ExecutionM1.1.2 - Von Neumann BottleneckM1.1.3 - Power W…

Python基础(六)之数值类型元组

Python基础(六)之数值类型元组 1、简介 元组: 在Python中是内置的数据结构之一,是一个不可变的序列,切可以是任何类型数据。元组的元素放在()小括号内。一般我们希望数据不改变的时候使用 不可变与可变的…

Day69:WEB攻防-Java安全JWT攻防Swagger自动化算法签名密匙Druid泄漏

目录 Java安全-Druid监控-未授权访问&信息泄漏 黑盒发现 白盒发现 攻击点 Java安全-Swagger接口-导入&联动批量测试 黑盒发现 白盒发现 自动化发包测试 自动化漏洞测试 Java安全-JWT令牌-空算法&未签名&密匙提取 识别 JWT 方式一:人工识…

web渗透测试漏洞复现:Elasticsearch未授权漏洞复现

web渗透测试漏洞复现 Elasticsearch未授权漏洞复现Elasticsearch简介Elasticsearch复现Elasticsearch漏洞修复和加固措施 Elasticsearch未授权漏洞复现 Elasticsearch简介 Elasticsearch 是一款 Java 编写的企业级搜索服务,它以分布式多用户能力和全文搜索引擎为特…

使用jenkins-pipeline进行利用项目文件自动化部署到k8s上

Discard old builds:丢弃旧的构建,目的是管理存储空间、提升性能以及保持环境整洁 Do not allow concurrent builds: 禁止并发构建是指同一时间内只允许一个构建任务执行,避免多个构建同时运行可能带来的问题 Do not allow the pipeline to resume if the controller resta…

RPC学习笔记一

什么是RPC RPC(Remote Procedure Call,远程过程调用)是一种用于实现分布式系统中不同计算机或进程之间进行通信和调用的技术和模式。 在传统的过程调用中,当一个程序需要调用另一个程序的函数或方法时,通常是在同一台…

ChatGPT4的Dalle-3 生成电影海报及升级教程

引言 首先DALL E3首先需要升级为ChatGPT4才能使用,接下来从以下几个方面进行介绍: 一、ChatGPT4中的DALL E3 的电影海报二、ChatGPT4下的DALL E3的实例三、ChatGPT4的升级教程 一、ChatGPT4中的DALL E3 的电影海报 DALLE 3可以直接在画面中识别和生成…

【Qt图形界面引擎(一)】:第一个Qt程序

跨平台图形界面引擎,接口简单,易上手,一定程度简化内存。 Qt发展史 1991年由Qt Company开发的跨平台C图形用户界面应用程序开发框架2008年,Qt Company科技被诺基亚公司收购,Qt也因此成为诺基亚旗下的编程语言工具2012…

【vue elementUI】修改el-dropdown样式

实现效果如下&#xff1a; 代码如下&#xff1a; <el-dropdown trigger"click" command"handleCommand" active-text-color"#606266"><span class"product-card">{{getCategoryName(categoryId)}}</span><el-dro…