FPGA设计的抽象层级

设计的抽象层级

在我们了解 Verilog 语言的更多细节之前,最好先了解芯片设计中的不同抽象层级。

顶层是系统级架构,它定义了各种子模块并根据功能对它们进行分组。例如,处理器集群具有多个核、高速缓存和高速缓存一致性逻辑。所有这些都将被封装为具有输入输出信号的单个模块。

在下一个级别中,每个子模块都用硬件描述语言编写,以准确描述每个独立模块的功能。在此阶段,将忽略较低级别的实现细节,例如电路原理图、技术库等。例如,控制器模块最终将包含多个 Verilog 文件,每个文件来描述实现其功能的细化的组件。

然后,HDL 被转换为门级原理图,其中还涉及表征触发器等数字元件的技术库。例如,D锁存器的数字电路包含以某种方式排列的与非门,使得D和E输入的所有组合产生由真值表给出的输出Q。

真值表本质上给出了所有输入信号电平的排列和最终的输出电平,下面给出的例子是带有使能引脚的 D 锁存器。硬件原理图也可以使用布尔逻辑和卡诺图从真值表中导出。然而,对于处理器和控制器等更复杂的数字模块,使用这种方法就有点不切实际了。

NAND 门的实现是通过以特定格式连接 CMOS 晶体管来完成的。在这个层级上,设计过程中会考虑晶体管沟道宽度、Vdd和驱动输出电容负载的能力。

最后一步是使用 EDA 工具在硅中布局这些晶体管,以便大规模制造。在这个层级,需要一些设备和技术知识,因为不同的布局最终会具有不同的物理属性,例如电阻和电容等。

设计风格

其次,数字模块的设计主要遵循两种风格,即自上而下(top-down)和自下而上(bottom-up)的方法。

自上而下

在这种风格中,首先定义顶层模块以及构建顶层模块所需的子模块的标识。类似地,每个子模块将被进一步划分为更小的组件,该过程可以继续进行,直到到达叶单元(leaf cell)或无法进一步划分的阶段。

自下而上

在这种情况下,第一个任务是识别可用的构建模块。然后将它们放在一起并以某种方式连接以构建更大的单元,以用于拼凑出顶层模块。

实践中通常这两种流程都会用到。架构师定义设计的系统级视图,设计人员实现每个功能模块的逻辑并将其综合到门中。到目前为止,一直遵循自上而下的风格。然而,这些门是按照自下而上的流程构建的,从尽可能的最佳面积、性能和功耗的最小模块的物理布局开始。这些标准单元还具有硬件原理图,可用于获取各种信息,例如上升和下降时间、功率和其他延迟等。这些单元可供综合工具使用,综合工具会在需要时挑选并实例化它们。

相关推荐
brave and determined13 小时前
可编程逻辑器件学习(day24):异构计算:突破算力瓶颈的未来之路
人工智能·嵌入式硬件·深度学习·学习·算法·fpga·asic
海涛高软1 天前
yolov8目标检测训练在rk3588上部署
fpga开发
第二层皮-合肥1 天前
USB3.0专题-硬件的测试
fpga开发
hexiaoyan8271 天前
高速数据采集卡设计方案:886-基于RFSOC的8路5G ADC和8路9G的DAC PCIe卡
fpga开发·高速数据采集卡·光纤pcie卡·通用pcie卡·xc7a100t板卡
坏孩子的诺亚方舟1 天前
FPGA系统架构设计实践7_时序收敛作业概述
fpga·xilinx·时序收敛·作业流程
嵌入式软硬件攻城狮1 天前
2.FPGA板卡通过电脑映射连接上网
fpga开发·电脑
brave and determined2 天前
可编程逻辑器件学习(day22):“让ARM穿上FPGA的马甲“:赛灵思Zynq的命名哲学与技术革命
arm开发·嵌入式硬件·fpga开发·zynq·fpga设计·嵌入式设计·fpga开发流程
Eloudy2 天前
GPU-Initiated Networking (GIN)及其核心硬件基础 SCI
ic·gpu
FPGA_小田老师2 天前
FPGA语法基础(二):SystemVerilog 数组清零方法详解
fpga开发·systemverilog·数组清零·systemverilog数组·systemverilog语法
jiushun_suanli2 天前
FPGA(现场可编程门阵列)详解
经验分享·学习·fpga开发