日拱一卒之FPGA学习计划

日拱一卒之FPGA学习计划

Alex Forencich 的代码库(主要是 verilog-axis​, verilog-ethernet​, verilog-pcie 等)是 FPGA 开源界的一座宝库。

死记硬背或者逐行阅读所有代码("一个个代码看")是非常低效且令人崩溃的 ,因为他的以太网和 PCIe 库非常庞大。反之,如果只是"拿来主义"("只要学会了就可以") ,你虽然能完成项目,但错失了提升自己 Verilog 编码水平和架构设计能力的绝佳机会。

有道理的东西,那么就有价值,不论如何,可以先进行尝试。下面就总体框架进行一个梳理看看效果。

第一阶段:掌握核心"骨架" (AXI Stream 基础设施)

Alex 的所有代码都建立在 AXI4-Stream 接口之上。如果你看不懂他对流控的处理,看复杂的 Ethernet 模块就是看天书。

重点阅读模块(在 verilog-axis库中):

  1. axis_register.v (必看): 一个极其基础的流水线寄存器。 也就是所谓的 Skid BufferPipeline Register 。看如何处理 tvalidtready 的握手时序,如何在不丢失数据(不 bubble,不 drop)的情况下打断时序路径。这是 FPGA 高频设计的基石。
  2. axis_fifo.v: 标准的同步 FIFO。 这种通用 FIFO 的指针逻辑和满/空标志生成,以及如何将其转换为 AXI Stream 接口。
  3. axis_async_fifo.v (必看): 跨时钟域处理。看他如何使用格雷码(Gray Code) 指针,以及如何在两个不同频率的时钟域之间安全地传递 AXI Stream 握手信号。

第二阶段:学习"胶水"逻辑 (仲裁与分发)

  1. axis_arbiter.v (仲裁器): 多个数据源想发给同一个接口(比如 4 个传感器想把数据发给 1 个串口)。 轮询(Round Robin)算法的 Verilog 实现,以及如何锁定(Lock)当前通道直到一个 Packet 传输结束。
  2. axis_demux.v (解复用器): 1 个接口的数据根据 TDEST 或 TID 分发给多个下游模块。 如何解析 Header 或 Sideband 信号来决定数据流向。

第三阶段:深入"协议栈" (以太网/UDP 处理)

verilog-ethernet库中,重点看:

  1. udp_complete.v udp_ip_tx.v : 状态机设计。 如何组包。先发以太网头,再发 IP 头,再发 UDP 头,最后发数据。Checksum(校验和)的计算。TCP/UDP 的校验和需要在数据流传输的过程中实时计算,看他是如何利用流水线加法树来实现零延迟校验和计算的。

第四阶段:不仅看代码,更要跑仿真 (Simulation)

这是学习 Alex 库最快的方法。Alex 非常推崇 Cocotb(基于 Python 的验证框架)或者简单的 Python 脚本配合 Icarus Verilog。

做实验: 故意修改代码里的一个逻辑(比如把 prescale 减 1 改成减 2),看看仿真波形会怎么报错。这种"破坏性学习"能让你秒懂代码的鲁棒性在哪里。

第五阶段:模仿与内化 (Copy the Style)

当你自己写代码时,尝试模仿他的风格:

  1. 参数化: 永远不要写死位宽,用 parameter
  2. 无复位逻辑: 你会发现他的数据路径(Data Path)寄存器通常不复位(if (rst) 下只复位控制信号如 tvalidptr)。这能节省大量的全局复位布线资源,有助于时序收敛。
  3. 隐式状态机: 像UART 那样,尝试用计数器代替复杂的状态跳转。
相关推荐
不吃橘子的橘猫9 天前
《集成电路设计》复习资料2(设计基础与方法)
学习·算法·fpga开发·集成电路·仿真·半导体
不吃橘子的橘猫9 天前
《集成电路设计》复习资料4(Verilog HDL概述)
学习·算法·fpga开发·集成电路·仿真·半导体
不吃橘子的橘猫10 天前
《集成电路设计》复习资料3(电路模拟与SPICE)
学习·算法·集成电路·仿真·半导体
Ulyanov16 天前
基于Python的单脉冲雷达导引头回波生成技术
python·算法·仿真·单脉冲雷达、
Ulyanov17 天前
高保真单脉冲雷达导引头回波生成:Python建模与实践
开发语言·python·仿真·系统设计·单脉冲雷达
康谋自动驾驶21 天前
2026年,3DGS和世界模型,在自动驾驶仿真中的组合应用
人工智能·3d·自动驾驶·仿真·3dgs·世界模型
加点油。。。。1 个月前
【UAV避障-3D VFH+】
matlab·机器人·无人机·仿真·机器人仿真
anscos1 个月前
【无标题】
仿真·软件·marc
Wishell20151 个月前
FPGA教程系列- 存储结构与参数化
仿真
Wishell20151 个月前
FPGA教程系列-流水线中的一些概念
仿真