当前位置: 首页 > article >正文

AXI总线协议实战:手把手教你用Verilog模拟关键信号波形(附代码)

AXI总线协议实战手把手教你用Verilog模拟关键信号波形附代码在FPGA和数字电路设计中AXI总线协议已经成为事实上的标准接口。作为AMBA协议家族中最重要的一员AXI协议以其高性能、高带宽和灵活性著称。但对于初学者来说AXI协议的握手机制和时序关系往往令人困惑。本文将带你从零开始用Verilog语言模拟AXI总线中最关键的信号波形通过代码实现和仿真分析让你真正掌握AXI协议的精髓。1. AXI协议基础与信号解析AXI协议采用点对点的主从架构基于VALID/READY握手机制实现数据传输。这种设计使得主从设备可以独立控制传输节奏实现真正的全双工通信。协议定义了五个独立通道写地址通道传输写操作的地址信息写数据通道传输实际写入的数据写响应通道从设备返回写操作状态读地址通道传输读操作的地址信息读数据通道返回读取的数据每个通道都采用相同的握手机制由VALID和READY两个信号控制。只有当VALID和READY同时为高时传输才会真正发生。这种设计带来了极高的灵活性但也增加了时序控制的复杂度。以下是AXI协议中最关键的信号及其作用信号名称方向描述AWVALID主→从写地址有效表示主设备正在驱动有效的写地址和控制信息AWREADY从→主写地址就绪表示从设备已准备好接收地址和控制信息WVALID主→从写数据有效表示主设备正在驱动有效的写数据WREADY从→主写数据就绪表示从设备已准备好接收数据BVALID从→主写响应有效表示从设备已驱动有效的写响应BREADY主→从写响应就绪表示主设备已准备好接收写响应ARVALID主→从读地址有效表示主设备正在驱动有效的读地址和控制信息ARREADY从→主读地址就绪表示从设备已准备好接收地址和控制信息RVALID从→主读数据有效表示从设备正在驱动有效的读数据RREADY主→从读数据就绪表示主设备已准备好接收读数据2. 搭建Verilog测试环境在开始模拟AXI信号之前我们需要搭建一个基本的Verilog测试环境。这个环境包括AXI主设备模块模拟AXI主设备行为AXI从设备模块模拟AXI从设备响应测试平台生成时钟、复位信号并实例化主从设备timescale 1ns/1ps module axi_tb; // 时钟和复位信号 reg clk; reg resetn; // 时钟生成 initial begin clk 0; forever #5 clk ~clk; end // 复位信号生成 initial begin resetn 0; #100 resetn 1; end // 实例化AXI主设备 axi_master master ( .aclk(clk), .aresetn(resetn), // 主设备接口信号连接 // ... ); // 实例化AXI从设备 axi_slave slave ( .aclk(clk), .aresetn(resetn), // 从设备接口信号连接 // ... ); // 测试用例 initial begin // 等待复位完成 wait(resetn 1); // 执行测试案例 // ... // 仿真结束 #1000 $finish; end endmodule这个测试平台提供了基本的时钟和复位信号并预留了主从设备的接口。接下来我们将重点实现AXI主设备和从设备的关键信号控制逻辑。3. 写事务波形模拟与实现AXI写事务包含三个独立的通道写地址、写数据和写响应。这三个通道可以并行工作提高了总线利用率。让我们先来看一个典型的写事务时序地址阶段主设备置位AWVALID从设备在准备好后置位AWREADY数据阶段主设备置位WVALID并驱动数据从设备在准备好后置位WREADY响应阶段从设备完成写操作后置位BVALID主设备在准备好接收响应后置位BREADY以下是实现写地址通道的Verilog代码示例// AXI主设备写地址通道控制 always (posedge aclk or negedge aresetn) begin if (!aresetn) begin awvalid 1b0; awaddr 32h0; end else begin // 主设备决定何时发起写地址 if (!awvalid || (awvalid awready)) begin awvalid write_req; // write_req来自主设备内部逻辑 awaddr next_write_addr; end end end // AXI从设备写地址通道控制 always (posedge aclk or negedge aresetn) begin if (!aresetn) begin awready 1b0; end else begin // 从设备根据自己的处理能力决定何时准备好接收地址 if (awvalid !awready internal_ready) begin awready 1b1; end else begin awready 1b0; end end end写数据通道的实现类似但需要考虑突发传输和WLAST信号// AXI主设备写数据通道控制 always (posedge aclk or negedge aresetn) begin if (!aresetn) begin wvalid 1b0; wdata 32h0; wlast 1b0; write_beat_count 0; end else begin if (write_active) begin if (!wvalid || (wvalid wready)) begin wvalid (write_beat_count burst_length); wdata next_write_data; wlast (write_beat_count burst_length - 1); write_beat_count write_beat_count 1; end end else begin wvalid 1b0; write_beat_count 0; end end end注意在实际设计中突发长度(burst_length)应根据AXI协议规范设置通常为1-16个beat。同时要确保WLAST信号在突发传输的最后一个数据beat时置位。4. 读事务波形模拟与实现AXI读事务包含两个通道读地址和读数据。与写事务相比读事务少了响应通道但时序控制同样重要。一个完整的读事务流程如下地址阶段主设备置位ARVALID从设备在准备好后置位ARREADY数据阶段从设备置位RVALID并驱动数据主设备在准备好接收数据后置位RREADY以下是读地址通道的Verilog实现// AXI主设备读地址通道控制 always (posedge aclk or negedge aresetn) begin if (!aresetn) begin arvalid 1b0; araddr 32h0; end else begin if (!arvalid || (arvalid arready)) begin arvalid read_req; // read_req来自主设备内部逻辑 araddr next_read_addr; end end end // AXI从设备读数据通道控制 always (posedge aclk or negedge aresetn) begin if (!aresetn) begin rvalid 1b0; rdata 32h0; rlast 1b0; read_beat_count 0; end else begin if (read_active) begin if (!rvalid || (rvalid rready)) begin rvalid (read_beat_count burst_length); rdata read_mem[read_addr read_beat_count]; rlast (read_beat_count burst_length - 1); read_beat_count read_beat_count 1; end end else begin rvalid 1b0; read_beat_count 0; end end end为了更直观地理解读事务的时序我们来看一个典型的波形图描述时钟周期1主设备置位ARVALID地址出现在ARADDR上时钟周期2从设备置位ARREADY地址传输完成时钟周期3从设备开始准备数据时钟周期4从设备置位RVALID第一个数据出现在RDATA上时钟周期5主设备置位RREADY第一个数据传输完成时钟周期6-8后续数据传输假设突发长度为4时钟周期8从设备置位RLAST表示最后一个数据5. 常见问题与调试技巧在实际工程中AXI接口的调试往往是最耗时的环节之一。以下是一些常见问题及其解决方案问题1死锁情况症状仿真挂起VALID信号置位但READY信号永远不响应。可能原因主设备等待从设备的READY但从设备又在等待主设备的其他信号握手信号之间的依赖关系形成循环解决方案检查所有握手信号的依赖关系确保没有循环等待添加超时机制防止永久等待问题2数据丢失症状部分数据传输失败特别是在高频率下。可能原因VALID和READY信号的建立/保持时间不满足跨时钟域问题未正确处理解决方案// 添加寄存器级改善时序 always (posedge aclk) begin wdata_reg wdata; wvalid_reg wvalid; end assign wdata_to_slave wdata_reg; assign wvalid_to_slave wvalid_reg;问题3突发传输不完整症状突发传输提前终止或者WLAST/RLAST信号位置不正确。可能原因突发计数器错误状态机设计缺陷调试技巧在仿真中打印突发计数器值检查状态机是否覆盖所有可能的状态转换性能优化建议流水线设计将AXI接口逻辑分成多个流水线阶段提高工作频率读写并行充分利用AXI协议的独立通道特性同时进行读写操作outstanding传输支持多个未完成事务提高总线利用率// outstanding传输示例 parameter MAX_OUTSTANDING 4; reg [1:0] outstanding_counter; always (posedge aclk or negedge aresetn) begin if (!aresetn) begin outstanding_counter 0; end else begin case ({arvalid arready, rvalid rready rlast}) 2b10: outstanding_counter outstanding_counter 1; 2b01: outstanding_counter outstanding_counter - 1; default: ; // 无变化 endcase end end // 控制新的读请求 assign allow_new_read (outstanding_counter MAX_OUTSTANDING);在完成AXI接口设计后建议使用SystemVerilog Assertions(SVA)添加协议检查自动捕获违反AXI协议的行为// 检查AWVALID置位后不能改变直到AWREADY响应 property awvalid_stable; (posedge aclk) disable iff (!aresetn) $rose(awvalid) |- (awvalid throughout awready[-1]); endproperty assert property (awvalid_stable) else $error(AWVALID changed before AWREADY!);

相关文章:

AXI总线协议实战:手把手教你用Verilog模拟关键信号波形(附代码)

AXI总线协议实战:手把手教你用Verilog模拟关键信号波形(附代码) 在FPGA和数字电路设计中,AXI总线协议已经成为事实上的标准接口。作为AMBA协议家族中最重要的一员,AXI协议以其高性能、高带宽和灵活性著称。但对于初学者…...

5个高效图像压缩技巧:MozJPEG优化实践指南

5个高效图像压缩技巧:MozJPEG优化实践指南 【免费下载链接】mozjpeg Improved JPEG encoder. 项目地址: https://gitcode.com/gh_mirrors/mo/mozjpeg MozJPEG作为一款优秀的开源压缩库,是网页开发者和图像优化工作者的必备图像优化工具。它基于li…...

深度解析猫抓浏览器扩展资源嗅探机制与性能优化策略

深度解析猫抓浏览器扩展资源嗅探机制与性能优化策略 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 猫抓(Cat Catch)作为一…...

低成本GPU算力方案:MT5中文文本增强镜像在RTX3060上高效部署实录

低成本GPU算力方案:MT5中文文本增强镜像在RTX3060上高效部署实录 你是不是也遇到过这样的烦恼?手头有一些中文文本数据,想用来训练模型,但数量太少,模型总是学不好。或者,你写了一段文案,想看看…...

阅读APP书源完全指南:3种快速导入方法与问题解决方案

阅读APP书源完全指南:3种快速导入方法与问题解决方案 【免费下载链接】Yuedu 📚「阅读」自用书源分享 项目地址: https://gitcode.com/gh_mirrors/yu/Yuedu 「阅读」APP书源开源项目为小说爱好者提供了一个强大的解决方案,让您能够在一…...

实战指南:基于快马AI生成贴合业务场景的问卷系统,超越通用opencode

在开发一个在线问卷调查系统时,很多开发者会直接使用现成的opencode或开源组件。但实际业务中,通用方案往往难以完全匹配特定需求。最近我在InsCode(快马)平台上尝试了一个实战项目,通过AI生成高度定制化的问卷系统后台API,效果远…...

LoRaFi库详解:面向SX1272/SX1273的Arduino LoRa通信开发指南

1. 项目概述LoRaFi 是一款面向 Arduino 平台的 LoRa 无线通信库,专为基于 Semtech SX1272/SX1273 射频芯片的硬件平台设计,核心适配对象为 LoRaFi 开发板(含配套扩展板/模块)。该库并非通用 LoRa 协议栈,而是聚焦于物理…...

基于潜在扩散模型的高分辨率图像合成-CVPR2022

期刊:Conference on Computer Vision and Pattern Recognition (CVPR) 论文链接:[2112.10752] High-Resolution Image Synthesis with Latent Diffusion Models 年份:2022 关键词:扩散模型,图像生成 从像素空间走向…...

Comfy UI Docker 镜像构建实战:从零到部署的完整指南

1. 环境准备与基础配置 在Windows 11上通过WSL搭建Comfy UI开发环境,首先要确保系统版本支持WSL 2。打开PowerShell输入wsl --version检查,如果显示版本低于2.0,需要执行wsl --install进行升级。我推荐使用Ubuntu 22.04作为子系统&#xff0c…...

自动化智能体生成+外接MCP,我用 ModelEngine Nexent 5分钟手搓了一个小红书爆款收割机

前言:别让“工作流”困住了你的想象力 在 AI Agent 爆发的这一年,作为开发者,我们采用过“工作流(Workflow)”开发,提示词开发。 最近体验了 ModelEngine Nexent,它打出的 Slogan 是 “Your n…...

如何快速掌握Subtitle Edit:新手也能上手的完整实战指南

如何快速掌握Subtitle Edit:新手也能上手的完整实战指南 【免费下载链接】subtitleedit the subtitle editor :) 项目地址: https://gitcode.com/gh_mirrors/su/subtitleedit 你是不是经常遇到下载的字幕与视频不同步?或者想要为自制视频添加专业…...

IDM注册表权限控制技术深度解析:突破30天试用期的终极方案

IDM注册表权限控制技术深度解析:突破30天试用期的终极方案 【免费下载链接】IDM-Activation-Script IDM Activation & Trail Reset Script 项目地址: https://gitcode.com/gh_mirrors/id/IDM-Activation-Script 核心技术原理:Windows注册表权…...

自然语言理解在AI原生应用领域的关键作用

自然语言理解在AI原生应用领域的关键作用关键词:自然语言理解(NLU)、AI原生应用、大语言模型、多模态交互、意图识别、情感分析、智能交互摘要:本文将深入探讨自然语言理解(NLU)如何成为AI原生应用的“大脑…...

intv_ai_mk11实战手册:构建AI增强型Confluence知识库——自动打标签+关联推荐

intv_ai_mk11实战手册:构建AI增强型Confluence知识库——自动打标签关联推荐 1. 项目背景与价值 在现代企业知识管理中,Confluence作为广泛使用的知识库平台,面临着内容组织效率低下的挑战。传统手动分类和标签管理方式存在三个核心痛点&am…...

【PCIE系列】深入解析接收端检测:从电路原理到实战验证

1. PCIE接收端检测机制的核心原理 当你把一根USB线插入电脑时,系统瞬间就能识别到设备连接——这种看似简单的操作背后,隐藏着PCIE接收端检测的精妙机制。作为硬件工程师,我经常需要调试这种看似简单实则复杂的链路检测问题。接收端检测本质上…...

多模态实践:OpenClaw+千问3.5-27B分析截图中的图表数据

多模态实践:OpenClaw千问3.5-27B分析截图中的图表数据 1. 为什么需要自动化图表分析 作为一名数据分析师,我每天需要处理大量来自股票、销售报表的截图。传统做法是手动录入数据到Excel,既耗时又容易出错。直到我发现OpenClaw与千问3.5-27B…...

从零到上线:手把手教你调试若依(RuoYi) + 微信小程序登录的全流程(附排错清单)

若依框架与微信小程序登录集成实战指南 在当今移动互联网时代,微信小程序已成为企业服务用户的重要入口。本文将深入探讨如何基于若依(RuoYi)这一流行的Java快速开发框架,实现与微信小程序的一键登录功能集成,并重点解决开发过程中可能遇到的…...

实战指南:利用快马平台为不同项目类型智能定制idea开发环境与工具链

今天想和大家分享一个实战经验:如何根据不同项目类型,快速定制专属的IDEA开发环境。作为开发者,我们经常需要切换不同技术栈,每次手动安装插件、配置SDK的过程实在太费时间。最近发现用InsCode(快马)平台可以智能解决这个问题&…...

万象视界灵坛部署案例:边缘设备(Jetson Orin)轻量化CLIP推理部署

万象视界灵坛部署案例:边缘设备(Jetson Orin)轻量化CLIP推理部署 1. 项目概述 万象视界灵坛(Omni-Vision Sanctuary)是一款基于OpenAI CLIP模型的高级多模态智能感知平台。该平台通过创新的像素风格界面设计&#xf…...

BallonsTranslator:深度学习驱动的漫画翻译自动化工具

BallonsTranslator:深度学习驱动的漫画翻译自动化工具 【免费下载链接】BallonsTranslator 深度学习辅助漫画翻译工具, 支持一键机翻和简单的图像/文本编辑 | Yet another computer-aided comic/manga translation tool powered by deeplearning 项目地址: https:…...

别再手动另存为了!用Python脚本5分钟搞定上百个Excel文件的格式转换(附完整代码)

别再手动另存为了!用Python脚本5分钟搞定上百个Excel文件的格式转换(附完整代码) 你是否曾经面对过这样的场景:电脑里堆积着上百个老旧的.xls格式Excel文件,每次需要使用时都得手动一个个"另存为"xlsx格式&a…...

实战演练:基于快马平台开发结合openclaw配置模型的工业分拣模拟系统

最近在做一个工业分拣系统的模拟项目,尝试用openclaw配置模型来实现对不同形状物体的智能抓取。整个过程在InsCode(快马)平台上完成,发现这个工具特别适合快速搭建这类机器人控制原型。记录下具体实现过程: 场景搭建 首先用三维引擎创建了一个…...

VCNL4020 proximity与环境光传感器集成设计指南

1. VCNL4020传感器技术解析:面向嵌入式系统的 proximity 与环境光一体化解决方案VCNL4020 是 Vishay 公司推出的高集成度光学传感芯片,专为资源受限的嵌入式系统设计。其核心价值在于将红外发射器(IRED)、接近检测光电二极管、环境…...

ssh远程登录的时候同一个秘钥可以用于多个不同服务器

可以看到:这2台服务器使用了同一个秘钥,现在都可以正常登录:可以看出来第二个云服务器有安全更新没有激活赶快要更新了。...

无需手动安装jdk,在快马平台快速构建你的第一个java程序原型

最近在尝试学习Java开发,发现传统方式需要先折腾JDK安装和环境变量配置,对新手特别不友好。好在发现了InsCode(快马)平台,可以直接在线写Java代码,连环境都不用配,特别适合快速验证想法。今天就用它来演示如何快速构建…...

C++11避坑指南:auto类型推导的7个常见错误及如何避免

C11避坑指南:auto类型推导的7个常见错误及如何避免 在C11标准中,auto关键字的引入极大地简化了代码编写过程,让开发者从繁琐的类型声明中解放出来。然而,这种便利性也带来了新的陷阱——类型推导的隐式规则可能导致意料之外的行为…...

wordpress数据迁移---没有验证

迁移 WordPress 完整数据(文章、页面、媒体、主题、插件、设置、评论、用户),核心是 备份旧站文件 数据库 → 新服务器配置环境 → 上传文件 导入数据库 → 修改配置 替换域名 / URL → 测试。下面分 插件一键迁移(新手推荐&am…...

新手福音:在快马平台上零配置完成你的第一个openclaw交互实验

作为一个刚接触AI的新手,想要在本地电脑上跑通openclaw这样的多模态模型,光是环境配置就能劝退一大波人。最近我在InsCode(快马)平台上发现了一个超友好的入门项目,完全不需要折腾环境,打开浏览器就能直接体验openclaw的核心功能。…...

2026年AI工具全面爆发:从ChatGPT到DeepSeek,谁在重塑下一代生产力?

还记得2023年ChatGPT刚出来时,大家都在惊叹"AI能聊天了"。但到了2026年,情况完全变了——AI不再是个炫技的玩具,而是实实在在地变成了"生产力工具"。程序员用它写代码,设计师用它做图,运营人用它写…...

ESP8266上玩转MicroPython:四角按钮控制LED的3种接线方案对比

ESP8266上玩转MicroPython:四角按钮控制LED的3种接线方案对比 在物联网和智能硬件开发中,ESP8266凭借其出色的性价比和丰富的功能接口,成为了创客和开发者的首选。而MicroPython的出现,更是让Python开发者能够轻松上手硬件编程。本…...