FPGA(现场可编程门阵列)笔记

*编程语言

**- Verilog:硬件描述语言,语法风格类似于C语言,用于数字电路的设计。

  • SystemVerilog:扩展自Verilog,增加了面向对象编程等特性,语法更接近于C++,适用于复杂系统设计。
  • VHDL:另一种硬件描述语言,其语法结构与Pascal相似。**

*与软件的区别

- 软件使用语言写流程,主要关注算法和流程控制,FPGA用语言写逻辑电路。

*FPGA厂商

**- Altera(Intel):提供Quartus开发环境。

  • Xilinx (AMD):提供Vivado开发环境。
  • 国产有易灵思等等。**

*FPGA分为时序电路和组合电路

**- 时序电路是由时钟边沿触发。

  • 组合电路由逻辑门与真值表组合而成,经过组合电路后需要重新进行时钟同步。**

*CDC(Clock Domain Cross)

**- 跨时钟域问题通常涉及如何安全地在不同的时钟域之间传输数据,避免亚稳态。使用多级触发器(如打两拍或三拍)是一种常见解决方案。

  • 对于数据总线,低速信号先产生握手信号,然后发布数据到寄存器,等待一段时间后读取。
  • 对于高速信号,使用异步FIFO和双口RAM进行同步。**

*RTC步骤

1. 编写RTL代码,寄存器传输语言。
2. 逻辑综合(synthesis),只有RTL可以被综合,将RTL代码转换成门级网表。
3. 布局布线(implementation)将网表变成芯片上的电路实现。
4. 生成配置文件烧录到FPGA。

*仿真软件

**- Synopsis,VCS,Verdi

  • Mentor,ModelSim -> QuestaSim**

*仿真流程

1. 首先编写test bench,test bench不局限于RTL语句。
2. 综合电路,将DUT(Design Under Test)和TB(Test Bench)变成网表。
3. 将网表变成可执行程序。
4. 运行仿真产生波形,test bench不仅用于生成测试激励,还可以包含检查机制来自动判断仿真的结果是否符合预期。

*电路调试

**- 可以在电路中插入内置的逻辑分析仪,使用JTAG设置trigger看波形。

  • 使用虚拟输入输出(VIO)模块,可以实时监控FPGA内部信号变化,辅助调试过程。**
相关推荐
xuhaoyu_cpp_java33 分钟前
项目学习(三)代码生成器
java·经验分享·笔记·学习
my_daling1 小时前
松下伺服驱动器参数保存流程(已在松下A5上验证)
笔记
森旺电子1 小时前
Vivado使用心得
fpga开发
FPGA小徐1 小时前
AI 浪潮下,FPGA 如何实现自我重塑与行业变革
人工智能·fpga开发
智者知已应修善业2 小时前
【51单片机初始化D5-D8亮,每按键按下D1到D4全亮,再按下恢复,如此循环】2024-3-26
c++·经验分享·笔记·算法·51单片机
FPGA小徐2 小时前
[FPGA IP系列] FPGA常用存储资源大全(RAM、ROM、CAM、SRAM、DRAM、FLASH
fpga开发
juesdo2 小时前
青岑CTF之 EZPHP系列
笔记·web安全·php
踏着七彩祥云的小丑2 小时前
嵌入式测试第 32 天:升级测试:固件OTA升级、断点续传、回滚测试
单片机·嵌入式硬件·学习
小陈phd2 小时前
Text2SQL智能体学习笔记(二)——NL2SQL落地的隐形基石:元数据库
数据库·笔记·学习
sramdram3 小时前
基于MCU微控制器的电子血压计应用解决方案
单片机·嵌入式硬件·mcu·mcu微控制器