跳到主要内容
极客日志极客日志面向AI+效率的开发者社区
首页博客GitHub 精选镜像工具UI配色美学隐私政策关于联系
搜索内容 / 工具 / 仓库 / 镜像...⌘K搜索
注册
博客列表
编程语言

Vivado 项目 Git 版本管理实战指南:FPGA 工程师必读

在 FPGA 开发中,掌握 Git 等源码管理工具已经是必备技能。 在使用 Vivado 时,我们不仅需要处理源代码控制,还需要处理以 IP 为中心的设计产品。Vivado 的工程通常是 IP 为中心的设计,包含: IP Integrator Block Diagram 各类 IP 实例(独立 IP 或 BD 内 IP) 自动生成的包装文件与工程产物 这让很多 FPGA 工程师一开始会觉得: 'V…

接口猎人发布于 2026/4/6更新于 2026/5/2239K 浏览

在 FPGA 开发中,掌握 Git 等源码管理工具已经是必备技能。

在使用 Vivado 时,我们不仅需要处理源代码控制,还需要处理以 IP 为中心的设计产品。Vivado 的工程通常是 IP 为中心的设计,包含:

  • IP Integrator Block Diagram
  • 各类 IP 实例(独立 IP 或 BD 内 IP)
  • 自动生成的包装文件与工程产物

这让很多 FPGA 工程师一开始会觉得:

'Vivado 项目到底该怎么和 Git 一起用?'

好消息是,从 Vivado 2022.1 开始,这一切已经变得非常清晰、也非常容易。

Vivado 2022.1 之后最重要的变化:源文件与生成文件分离

在 Vivado 2022.1 之前:

源文件和生成文件全部混在同一个 .srcs 目录中。

文章配图

而从 Vivado 2022.1 起,工程目录被明确拆分为:

  • .srcs:源文件
  • .gen:生成文件

这一点非常关键。

这意味着:

只要我们保存 .srcs 目录 + .xpr 工程文件,就可以在任何地方完整重建 Vivado 工程。

示例工程说明

示例使用 Vivado 2024.1 创建了一个新工程,目标板卡为 Avnet ZU Board。

IP Integrator 设计包含:

  • Zynq MPSoC Processing System
  • Smart Interconnect
  • AXI BRAM Controller

此外还加入了 自定义 RTL 文件,通过 UART 提供 AXI 访问,用来演示 自定义 RTL 与 IP 设计共存 的情况。

完成后的 Block Diagram 如下:

文章配图

Vivado 工程目录结构解析

1️⃣ .srcs 目录

文章配图

imports/ 下是用户添加的 VHDL / Verilog 源文件

文章配图

bd/ 下是 IP Integrator 的 Block Diagram

文章配图

ip/ 下是各个 IP 的 .xci 配置文件

文章配图

这些都是必须纳入 Git 管理的内容

2️⃣ .gen 目录

.gen 中包含:

  • 自动生成的顶层 wrapper
  • IP 的生成文件
  • 综合与仿真所需的中间文件

这些文件不需要提交到 Git

将 Vivado 工程加入 Git 仓库

假设你已经在 GitHub 上创建了一个空仓库,下面是核心的步骤。

初始化仓库

git init

添加 Vivado 工程文件

只需要添加两部分:

git add git_demo.srcs/* git_demo.xpr

提交到本地仓库

提交这些文件并附带一条消息。

git commit -m "initial issue"

你会看到:

  • .xpr
  • RTL / VHDL 文件
  • IP .xci 文件

都已经被 Git 跟踪。

文章配图

绑定远程仓库并推送

git remote add origin <url>
git push -u origin master

此时在 GitHub 网页上,就可以看到完整的 Vivado 工程源文件了。

文章配图

从 Git 仓库重建 Vivado 工程

为了验证流程是否正确,我们新建一个文件夹:

文章配图

git clone <repo_url>

然后直接打开 .xpr 文件。

文章配图

我们需要重新生成顶层 wrapper,重新生成 IP,正常完成综合与实现即可。

整个流程无需额外脚本,运行非常顺利。

文章配图

小结

  • Vivado 2022.1 之后,工程结构已经非常适合 Git 管理
  • 只需管理 .srcs + .xpr
  • IP、BD、RTL 都能自然融入 Git 流程
  • Vivado 工程终于可以像软件工程一样被'正常管理'

目录

  1. Vivado 2022.1 之后最重要的变化:源文件与生成文件分离
  2. 示例工程说明
  3. Vivado 工程目录结构解析
  4. 1️⃣ .srcs 目录
  5. 2️⃣ .gen 目录
  6. 将 Vivado 工程加入 Git 仓库
  7. 初始化仓库
  8. 添加 Vivado 工程文件
  9. 提交到本地仓库
  10. 绑定远程仓库并推送
  11. 从 Git 仓库重建 Vivado 工程
  12. 小结
  • 💰 8折买阿里云服务器限时8折了解详情
  • Magick API 一键接入全球大模型注册送1000万token查看
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志V2」,在微信中扫描左侧二维码关注。展示文案:极客日志V2 zeeklog

更多推荐文章

查看全部
  • Spatial Joy 2025 全球 AR&AI 开发大赛参赛指南与避坑攻略
  • 前端 dist 目录详解:概念、配置与部署实践
  • 源支付 V7 支付系统开源版 v1.8.9 核心架构与运行逻辑
  • 基于STM32的智能家居安防系统设计与实现
  • StructBERT 中文相似度 WebUI 部署与故障排查指南
  • 多 AI 模型并行内容生成与对比分析工作流构建
  • 高效邮件发送系统设计与实现:基于Python和SQLAlchemy的实践
  • Python 爬虫基础:原理、流程与类型详解
  • 消息队列核心面试题:应用场景与可靠性保障
  • 基于 OpenClaw 架构构建 C++ 量化交易引擎 QuantClaw 实战
  • 全面解析 Coze 工作流与 AI Agent 实例搭建
  • GPEN 批量处理断点续传功能设计与实现
  • 本地 AI 图像抠图工具:支持 JPG/PNG/WebP 一键处理
  • OpenClaw vs Coze/Dify/n8n AI Agent 工具选型对比
  • 高通音频架构:从 AHAL adev_open 到 PAL XML 解析的调用链追踪
  • DeepSeek-R1 大模型基于 MS-Swift 框架部署/推理/微调实践
  • 基于 NVIDIA DGX Spark 部署 Stable Diffusion 3.5 及 ComfyUI
  • 手机端 Stable Diffusion 开源工具使用指南
  • TRAE 与 VSCode 中的 Git 项目管理实战
  • OpenClaw 网络搜索与抓取:web_search + web_fetch 最佳实践速查

相关免费在线工具

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online

  • Markdown转HTML

    将 Markdown(GFM)转为 HTML 片段,浏览器内 marked 解析;与 HTML转Markdown 互为补充。 在线工具,Markdown转HTML在线工具,online

  • HTML转Markdown

    将 HTML 片段转为 GitHub Flavored Markdown,支持标题、列表、链接、代码块与表格等;浏览器内处理,可链接预填。 在线工具,HTML转Markdown在线工具,online

  • JSON 压缩

    通过删除不必要的空白来缩小和压缩JSON。 在线工具,JSON 压缩在线工具,online

  • JSON美化和格式化

    将JSON字符串修饰为友好的可读格式。 在线工具,JSON美化和格式化在线工具,online