Vivado 使用教程

Vivado 使用教程

目录

一、创建工程

二、创建文件

三、编写代码

四、仿真验证

五、配置管脚

六、生成Bitstream文件并烧录

一、创建工程

1.左边创建(或打开)工程,右侧可以快速打开最近打开过的工程。

2.来到这一步,命名工程并设置工程的存放路径(这里以D触发器为例)

3.选择RTL点击next。会来到添加文件环节(可以在这里添加.v等文件,不过后面再添加是一样的)直接点击next

4.选择芯片型号(根据开发板选,这里随便选的)完成后点next会弹出信息概要,finish完成。

       

二、创建文件

完成上述步骤会进入当前界面:

1.工程管理器add sourse添加(创建)设计文件,创建文件后选择Verilog语言并命名。

2.定义端口(可选),若在这定义后,文件会自动生成端口定义的代码,比自己敲省时间更方便。

(端口没有说明类型即默认wire类型,可根据情况定义reg类型:“output reg q”)

         

3.设计文件创建完成

三、编写代码

1.代码以D触发器为例:

`timescale 1ns / 1ps //timescale 时间单位/精度 module dff( //D触发器 input wire clk, //时钟信号 input wire d, //输入信号 output reg q, //输出信号 output reg q_n //输出信号取反 ); always@(posedge clk) begin q <= d; q_n <= !d; end endmodule

2.保存后编译(Run Synthesls),再修改报错直到通过。

        图示两处都是编译。点击后来到右图点OK,Number of Jobs 即 CPU 工作线程数,这个与电脑配置有关,配置越高可选数量越多(下图二片标注有误忽略,应该是工作线程数,我忘记改了)。编译的报错可在massage里面查看,尤其注意 error。

四、仿真验证

1.编译成功后创建仿真文件并完成代码编写,参考“步骤二”中设计文件的创建:

( 需选择 “add or create simulate sourse” 

  test bench 代码如下:

`timescale 1ns / 1ps //timescale 时间单位/精度 module dff_tb( ); //仿真一般无端口列表 reg clk_sim; reg d_sim; wire q_sim; wire q_n_sim; always #10 clk_sim = ~clk_sim; //每10个时间单位对clk进行翻转,即周期为20个单位 initial begin clk_sim = 0; d_sim = 0; #20; //延时20个时间单位(20ns) d_sim = 1; #40; d_sim = 0; #100; $stop; //停止仿真 end dff dff( //模块例化: 原模块名----在顶层文件中命名为 .clk (clk_sim), //原模块端口名----要连接的端口名 .d (d_sim), .q (q_sim), .q_n (q_n_sim) ); endmodule

2.保存后编译(Run Synthesls),再修改报错直到通过。

3.波形仿真 点击Run Simulation

(注意1:当有多个tb文件时,选中要仿真的tb文件 右键设为"active")

(注意2:vivado仿真上限时间在tool-setting-simulation中设置,仿真波形不全看看是否不够)

波形如图,每当clk上升沿到来时q输出d的值,说明代码实现D触发器的功能无误。

五、配置管脚

1.Run implement(跑成功后会解锁Run simulation里最后两个禁用的仿真选项,一般也用不到)

2.跑完后点击上图Open Implement Design文字,再到状态栏点击Window - I/O Ports

分配引脚(分配过的Fixed栏会自动打勾),设置相关参数(通常I/O standar 为LVCOMS33)。

3.ctrl+s保存,并完成命名后OK会生成XDC约束文件,约束文件打开位置见图二

六、生成Bitstream文件并烧录

1.生成bit流文件

2.如图示步骤点击,自动连接硬件,确保开发板已连接且通电否则识别不到。

3.烧录:连接开发板后会在这里出现芯片型号(对应新建工程时选择的型号),右键型号后点击“Program Device”再点Program烧录。

Read more

Tongweb8安装部署

Tongweb8安装部署

kylin10安装Tongweb8 文章目录 * kylin10安装Tongweb8 * 一、Tongweb8产品介绍 * 🧩 一、核心定位 * 🚀 二、主要特性 * 1. **标准兼容性强** * 2. **高性能与高可用** * 3. **安全能力突出** * 4. **云原生与 DevOps 集成** * 5. **多版本灵活授权** * 🖥️ 三、典型应用场景 * ⚙️ 四、技术生态集成 * 📦 五、部署与管理 * 🌐 六、最新动态(截至 2025 年) * ✅ 总结:TongWeb 8 的核心价值 * 二、安装 * 1.解压安装 * 2.启动 * 3.访问 * 上图说明没有配置信任ip 一、Tongweb8产品介绍 TongWeb 8 是由北京东方通科技股份有限公司(

Web 前端基础:HTML 核心语法和常用标签

HTML部分 * 一、HTML简介 * HTML是什么? * HTML骨架 * 二、HTML 标签语法 * 标签结构 * 标签嵌套关系(父子、兄弟) * HTML 注释和调试 * 三、HTML 文本排版标签 * 标题标签 h1~h6 * 段落标签 p * 换行 br、水平线 h * 文本格式化标签 * 块级元素 div & 行内元素 span * 四、HTML 图像与路径 * 相对路径与绝对路径 * 图像标签 img * 五、HTML 超链接 * 六、HTML 列表 * 无序列表` ul li` * 有序列表 `ol li`

Qt 配置Webassemble环境

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 * 前言 * 一、Webassemble是什么? * 二、下载并配置emsdk * 1.下载源代码 * 2.配置环境 * 1.用户变量 * 2.PATH路径 * 三、配置Qt环境 * 1.设置SDKS * 2.查看构建套件 * 四、测试Demo * 五、部署 * 1.部署nginx环境 * 2.部署Webassemble程序 * 总结 前言 之前一直知道有一个神奇的东西Webassemble,好几次都是由于环境配置不对导致不能正常使用,而且我也对于它的真正能力表示有兴趣。所以经过深入研究,终于在5.15.2和6.8.3两个版本上配置成功并使用。 一、Webassemble是什么? WebAssembly 是一种新的编码方式,可以在现代的 Web 浏览器中运行—

Phi-4-mini-reasoning Chainlit性能优化:前端懒加载与缓存策略

Phi-4-mini-reasoning Chainlit性能优化:前端懒加载与缓存策略 1. 项目背景与挑战 Phi-4-mini-reasoning是一个基于合成数据构建的轻量级开源模型,专注于高质量、密集推理的数据处理。作为Phi-4模型家族成员,它支持128K令牌的超长上下文处理能力,特别适合需要复杂逻辑推理的应用场景。 在实际部署中,我们使用vLLM作为推理引擎,并通过Chainlit构建交互式前端界面。但随着用户量增长,我们遇到了两个核心性能问题: 1. 前端加载缓慢:模型初始化时需要加载大量资源,导致首屏响应时间过长 2. 重复请求开销:用户频繁进行相似查询时,系统无法有效复用已有计算结果 2. 懒加载优化方案 2.1 基本原理与实现 懒加载(Lazy Loading)的核心思想是延迟非关键资源的加载,直到它们真正需要时才进行请求。在我们的Chainlit前端中,主要优化点包括: # 前端懒加载实现示例 async def load_model_resources(): # 先加载基础UI框架 await load_core_components(