【FPGA篇章一】FPGA工作原理:详细介绍FPGA实现编程逻辑的机理
欢迎大家关注我的微信公众账号,支持程序媛写出更多优秀的文章

FPGA(Field Programmable Gate Array),即现场可编程逻辑门阵列,它是作为专用集成电路(ASIC)领域中一种半定制电路而出现的,既解决了定制电路的不足,又克服了原有可编程器件门电路数有限的缺点。
FPGA优势
(1)运行速度快
(2)FPGA引脚多,适合大规模的系统设计
(3)FPGA内部程序并行执行,工作效率高
(4)FPGA包含大量的IP核,方便开发
(5)FPGA设计灵活
FPGA开发流程
(1)设计规范
(2)设计输入:设计输入可以是原理图、可以是描述电路逻辑的代码(Verilog HDL或者VHDL)
(3)RTL仿真:又称为功能仿真,主要用来检查代码中的错误和代码行为的正确性
(4)综合仿真:将输入的文件转换成具体的门电路
(5)布局和布线
(6)门级仿真:RTL级别的仿真主要用来检查代码的语法错误并验证设计的组合逻辑是不是和理想中的一致,不考虑门电路之间的延时和连线上的延时;但是门级仿真是考虑的,主要用来验证设计的数字逻辑电路的实际工作情况是不是符合设计要求。
(7)时序分析
(8)上系统验证
FPGA内部结构
(1)
FPGA的内部结构主要包含六大部分,分别是:可编程的输入输出IO口、可编程的逻辑单元、底层嵌入式功能单元、嵌入式块RAM、布线资源和硬核。以下是具体的介绍。
1 可编程的输入输出IO口:可以使用软件配置成不用的电气标准和物理特性,比如可以调整上下拉电阻、匹配电阻等特性,使用灵活。
2 可编程逻辑单元:是可编程逻辑的主体,可以根据设计灵活地改变内部连接与配置,从而完成不同的逻辑功能,FPGA一般都是基于SRAM工艺,可编程逻辑单元基本都是基于查找表LUT(Look-Up-Table)和一些寄存器(主要是D触发器)组成。
3 底层嵌入功能单元:指的是在FPGA内部集成的一些通用程度较高的嵌入式功能模块,比如锁相环、DSP等。
4 布线资源:链接FPGA的内部所有单元,在实际FPGA布局布线时,布局布线的好坏会对设计的功能产生直接的影响。
5 硬核:这一部分比较少用,因为硬核的功能比较单一,在实际开发中使用的不多。
(2)
补充说明:实际开发中可以从这四个方面认识FPGA的内部结构,分别是:可配置逻辑块(CLB)、输入输出块(IOB)、布线通道(Routing Channels )、可编程开关(PSW)。
实际中,主要用CLB用来衡量FPGA的可使用资源数。
CLB主要包含查找表(LUT)和D触发器,分别组成FPGA的组合逻辑单元和时序单元,为数字电子系统设计做资源准备。
CLB在芯片内部以二维阵列的形式存在,这也是FPGA称之为现场可编程门阵列的原因。
CLB在实际生成数字电路的时候,使用布线资源进行连接,当需要输出或者是输入时,可以将CLB连接到输入输出模块。
FPGA的工作原理
注:在以下,EDA工具作为Quartus II、ISE、Vivado等。
FPGA的内部结构主要包含可配置的逻辑块(CLB)、输入输出块、布线资源和可编程开关。其中可配置的逻辑块是FPGA的主要资源指标,在芯片内部以二维阵列的形式排布。
在CLB中包含查找表和D触发器,查找表(LUT)负责给芯片提供组合逻辑,D触发器负责提供时序逻辑,为设计数字电子系统提供资源。
例如LUT-4查找表,近似是一个16*1的RAM,具有RAM的物理结构,但是在作用上是类似ROM,负责存储EDA工具综合生成的逻辑电路的各种可能的运行结果,在FPGA工作的时候,依据端口输入的数据流或者是逻辑流,在RAM中索引得出结果,配合D触发器可以完成数字电子系统需要的组合逻辑和时序逻辑。
设计者在进行软件设计的时候,依据设计目标,将电路功能以代码的形式描述出来,EDA工具负责对代码进行编译和综合,得到设计电路的各种可能结果,下载到FPGA的时候,这些数据都存储在CLB的查找表中。系统开始工作时,在数据流或者是逻辑流的驱动下,在查找表中取出对应的数字逻辑,然后和D触发器配合完成数字电子系统的组合逻辑设计和时序逻辑设计。
所以,有些地方说,基于LUT技术的FPGA,其实我们基于SRAM技术的FPGA就是这个基于LUT技术的FPGA的本质。
一旦SRAM单元被载入数据后,他将保持不放电,但如果整个供电系统断了的话,器件配置的数据将会丢失,这就是说这种器件在系统上电时需要重新配置。但是这种器件的特点是可迅速反复的编程,这就是当时选中SRAM技术实现FPGA的很大原因。
【FPGA篇章一】FPGA工作原理:详细介绍FPGA实现编程逻辑的机理的更多相关文章
- Unity3d 发动机原理详细介绍
Unity3d 发动机原理详细介绍 www.MyException.Cn 发布于:2013-10-08 16:32:36 浏览:46次 0 Unity3d 引擎原理详细介绍 体系结构 ...
- 单片机的基本构成、工作原理 LET′S TRY“嵌入式编程”: 1 of 6
单片机的基本构成.工作原理 LET′S TRY“嵌入式编程”: 1 of 6 本连载讲解作为嵌入式系统开发技术人员所必需具备的基础知识.这些基础知识是硬件和软件技术人员都应该掌握的共通技术知识.有了电 ...
- 初学Kafka工作原理流程介绍
Apache kafka 工作原理介绍 消息队列技术是分布式应用间交换信息的一种技术.消息队列可驻留在内存或磁盘上, 队列存储消息直到它们被应用程序读走.通过消息队列,应用程序可独立地执行--它们不需 ...
- hibernate篇章五--Hibernage工作原理
Hibernage工作原理: 1.配置hibernate对象关系映射文件.启动服务器 2.服务器通过实例化Configuration对象,读取hibernate.cfg.xml文件的配置内容,并根据相 ...
- HashMap工作原理的介绍!
HashMap的工作原理是近年来常见的Java面试题.几乎每个Java程序员都知道HashMap,都知道哪里要用HashMap,知道HashTable和HashMap之间的区别,那么为何这道面试题如此 ...
- Unity3d 引擎原理详细介绍
体系结构 为了更好地理解游戏的软件架构和对象模型,它获得更好的外观仅有一名Unity3D的游戏引擎和编辑器是非常有用的,它的主要原则. Unity3D 引擎 Unity3D的是一个屡获殊荣的工具,用于 ...
- Unity3d 引擎原理详细介绍、Unity3D引擎架构设计
体系结构 为了更好地理解游戏的软件架构和对象模型,它获得更好的外观仅有一名Unity3D的游戏引擎和编辑器是非常有用的,它的主要原则. Unity3D 引擎 Unity3D的是一个屡获殊荣的工具,用于 ...
- Unity3d 引擎原理详细介绍、Unity3D引擎架构设计 - zhibolife
时间 2014-03-24 11:18:00 博客园-所有随笔区原文 http://www.cnblogs.com/zhibolife/p/3620440.html 体系结构 为了更好地理解游戏的 ...
- jsonp实现原理详细介绍
主要是浏览器的同源同域(协议相同,域名相同及端口相同)策略需要使用跨域获取数据,故需要jsonp跨域获取数据.重点:img的src,link的href及script的src不遵循浏览器的同源同域策略, ...
随机推荐
- Alpha-release 总结
因组员一周来事情较多,因此博客更新停滞了一个星期.这周我们已经开始了第二个release的相关工作,首先先对上一个release的工作进行简短总结. 团队在上个星期进行了alpha-release版本 ...
- Spring5:事务管理【整合Mybatis】
Spring 整合Mybatis 1:导入依赖 <dependencies> <!--测试依赖--> <dependency> <groupId>jun ...
- Elasticsearch 集群部署
本文部署环境 $ cat /etc/redhat-release CentOS Linux release (Core) 部署前系统优化 $ /etc/security/limits.conf roo ...
- 杂园日记-获取URL参数
function getUrlParams(name, url){ var locationUrl = window.location.search; if(url){ var s =url.inde ...
- 22.Java面试学习平台-整合OSS对象存储
SpringCloud实战项目全套学习教程连载中 PassJava 学习教程 简介 PassJava-Learning项目是PassJava(佳必过)项目的学习教程.对架构.业务.技术要点进行讲解. ...
- netcore 下的policy授权自定义返回结果
目前一直在用policy做权限校验,但是好像组里需要将返回结果统一,之前用的都是直接继承AuthorizationHandler然后调用context.Fail(),但是这样会导致没办法自定义返回结果 ...
- VideoView--简单获取进度条的方法
使用MediaController类就可以简单的把视频中的进度条加进去 实例: 现在布局哪里放一个VideoView,然后: videoView = (VideoView) findViewById( ...
- think--数据库的设置
1.在项目下的Common下的Conf下的config.php 配置: 'DB_TYPE' => 'mysql', // 数据库类型 'DB_HOST' => 'localhost', / ...
- linux抓包的实现
工具: wireshark tcpdump 在这里仅仅介绍后者: 在网络问题的调试中,tcpdump应该说是一个必不可少的工具,和大部分linux下优秀工具一样,它的特点就是简单而强大. 默认情况下, ...
- Decision tree——决策树
基本流程 决策树是通过分次判断样本属性来进行划分样本类别的机器学习模型.每个树的结点选择一个最优属性来进行样本的分流,最终将样本类别划分出来. 决策树的关键就是分流时最优属性$a$的选择.使用所谓信息 ...