Verilog和FPGA的自学笔记1——FPGA

FPGA的一些事情

一点想说的话

在我自学Verilog和FPGA这段时间之前,我找了许多教程,可惜没有一个令自己满意的(大部分视频废话有点多,听着累,很多文本教程也无法站在初学者角度进行讲授)。

于是就结合手头现有的一些例程、仅有的一点资料,外加一个豆包,开始了这段Verilog自学之旅。

花了大量时间弄懂一些东西之后,担心自己遗忘掉花了这么多代价学会的东西,也希望帮助到更多想要学习FPGA的同学们(网上有言论学历低的就不该学FPGA,如果从找工作角度来说,可能有一定合理之处,但我认为,如果喜欢一件东西,应该是去主动追求那份美好的),同时也是记录自己现在这段经历的,对于时代尖端技术的纯粹的向往,初心与一点幼稚的勇气------

于是有了以下一些博文......

希望与大家共勉 (^_^)

什么是FPGA

我最早看到FPGA,相比于CPU、GPU,脑子里是这个:

????

于是求助一下:

看了以后,脑子里是这个:

?????????

额这什么鬼啊......

查了一些资料以后,加上看过一些自媒体的视频,最初的理解是这样的:

FPGA是一种半定制芯片,它可以根据用户的需要改变内部电路结构,从而做出更适合算法的硬件电路。

虽然看上去理解基本差不多,我想到的还是这个:

半定制?每次烧写程序还得改变硬件结构?怎么做到的?这个芯片用久了内部晶体管会不会接触不良?(捂脸)

直到我用vivado点亮了led灯,我才明白......哦~~~

FPGA内部其实只有查找表(LUT)、D触发器(Filp-flop)、进位链、块RAM组成。

那什么是查找表呢?

一开始我看见这个LUT,天真地认为是让用户对照一张表一个一个查二进制代码,然后发现zynq7020里有53,200个LUT......(再次捂脸)

其实是这样的:
虽然FPGA是可编程逻辑门阵列,但并不意味着FPGA的基本组成单元是与或非这些通用逻辑门,而是查找表

(如果有同学用EEPROM制作过7端数码管译码器就会恍然明白)

查找表本质上是一个ROM,存储着输入和输出之间所有可能的真值组合。

或者说,查找表是一个存储了包含所有可能的真值表的ROM。

FPGA用上万个存储所有可能真值表的ROM,替代了基本逻辑门,实现了更快的逻辑处理。

所以,LUT是一种资源。LUT越多,能够实现的硬件电路就越复杂。

(从一开始希望LUT少一点,到现在盼望LUT能再多一点......哈)

查找表能实现逻辑运算,触发器能实现数据寄存------FPGA能实现世界上几乎所有算法了。

我记得有个博主形容FPGA里面是一堆工程师的"积木",太恰当了。

MCU,CPU这些直接给出具体的"房子",我们只能根据自身需要调整每个房间的用途。而FPGA则给了我们一块块砖,我们能根据需要,盖出最符合需求的房子。

这样效率和速度自然就变得极高,在一些特定场景,FPGA所能提供的算法加速,远非CPU,GPU这些"PU"们能够企及的。

那怎样决定这些查找表、触发器之间的连接呢?

这就要靠大名鼎鼎的硬件描述语言------Verilog了。(当然硬件描述语言不止Verilog一种,就像有许多高级语言一样)

关于FPGA本身,就写到这里吧。如果有不明白或错误之处,也希望大家在评论区给出,帮助大家的同时也能再次提升自己对于FPGA和Verilog的理解,感谢大家!!

系列链接:

下一篇:Verilog和FPGA的自学笔记2------点亮LED

相关推荐
Devlive 开源社区几秒前
技术日报|开源搜索智能体MiroThinker登顶日增803星,Claude记忆插件claude-mem爆发破万二
笔记
YJlio1 分钟前
WinObj 学习笔记(15.7):看懂内核对象管理器与命名空间的“地图”
linux·服务器·网络·windows·笔记·学习·微信
我的golang之路果然有问题5 分钟前
linux 个人笔记导出之网络,防火墙,定时,权限,后台
linux·运维·服务器·网络·笔记·个人笔记
九成宫14 分钟前
计算机网络期末复习——第1章:计算机网络和因特网
笔记·计算机网络·软件工程
我的golang之路果然有问题15 分钟前
mysql 个人笔记导出之-数据库时间戳问题以及增删改查
数据库·笔记·学习·mysql·分享·个人笔记
JH307324 分钟前
我的笔记:怎么用 MySQL 的 EXPLAIN 来分析 SQL
笔记·sql·mysql
集芯微电科技有限公司36 分钟前
替代HT6310/KP3310离线式AC-DC无感线性稳压器
数据结构·人工智能·单片机·嵌入式硬件·fpga开发
Justice Young40 分钟前
Sqoop复习笔记
hadoop·笔记·sqoop
深蓝海拓1 小时前
PySide6从0开始学习的笔记(二十三)使用QRunnable在线程池中执行临时任务
笔记·python·qt·学习·pyqt
三档程序员1 小时前
适配龙芯笔记之 libthriftnb.so 链接libevent失败
笔记