【ARM】【FPGA】【硬件开发】Chapter.1 AXI4总线协议

article/2025/9/8 21:05:25

Chapter.1 AXI4总线协议

作者:齐花Guyc(CAUC)


一、总线介绍

AXI4总线

AXI4总线就像是SoC内部的“高速公路”,负责在不同硬件模块之间高效传输数据。

在这里插入图片描述
在这里插入图片描述

AXI4协议通过 5个独立通道 传输数据和控制信号,每个通道都有自己的信号线,互不干扰。

  1. 写地址通道(Write Address Channel, AW)
    主设备(Master)告诉从设备(Slave)要写入数据的地址和相关信息(如突发长度、数据大小等)。
    信号:
    AWVALID:主设备表示写地址有效。
    AWREADY:从设备表示准备好接收写地址。
    AWADDR:写操作的目标地址。
    AWLEN:突发长度(0表示1次传输,1表示2次,依次类推,最多255)。
    AWSIZE:每次传输的字节数(如2表示4字节)。
    AWBURST:突发类型(固定、递增、环绕)。

  2. 写数据通道(Write Data Channel, W)
    主设备通过这个通道将数据发送到从设备。
    信号:
    WVALID:主设备表示写数据有效。
    WREADY:从设备表示准备好接收数据。
    WDATA:写数据内容。
    WSTRB:字节选通信号,指示哪些字节有效。
    WLAST:表示当前数据是突发传输的最后一个。

  3. 写响应通道(Write Response Channel, B)
    从设备告诉主设备写操作是否成功。
    信号:
    BVALID:从设备表示写响应有效。
    BREADY:主设备表示准备好接收响应。
    BRESP:响应状态(如OKAY、ERROR)。

  4. 读地址通道(Read Address Channel, AR)
    主设备告诉从设备要读取数据的地址和相关信息。
    信号:
    ARVALID:主设备表示读地址有效。
    ARREADY:从设备表示准备好接收读地址。
    ARADDR、 ARLEN、 ARSIZE、 ARBURST:类似写地址通道。

  5. 读数据通道(Read Data Channel, R)
    从设备将读取的数据返回给主设备。
    信号:
    RVALID:从设备表示读数据有效。
    RREADY:主设备表示准备好接收数据。
    RDATA:读数据内容。
    RRESP:响应状态。
    RLAST:表示当前数据是突发传输的最后一个。

AXI4总线时序

1.AXI4写操作时序

突发写操作(burst write),一次写操作传输4个数据 [D(A0)、D(A1)、D(A2)、D(A3)]

AXI4写操作使用3个通道:

  • 写地址通道(AW):AWADDR、AWVALID、AWREADY
  • 写数据通道(W):WDATA、WLAST、WVALID、WREADY
  • 写响应通道(B):BRESP、BVALID、BREADY
    在这里插入图片描述
2.时序图信号解读

时钟(ACLK)
ACLK 是一个周期性的时钟信号,从T0到T10,每周期一个上升沿,用于同步所有信号。

写地址通道(AW)
AWADDR:在T1到T2,主设备(Master)设置写地址为 A,表示目标地址。地址信号在 AWVALID 有效期间保持不变。
AWVALID:在T1,主设备将 AWVALID 置高,表示写地址有效。一直保持高电平直到T2,因为地址传输完成。
AWREADY:在T2,从设备(Slave)将 AWREADY 置高,表示准备好接收地址。
握手:在T2的时钟上升沿,AWVALID 和 AWREADY 同时为高,地址传输完成。

握手机制
VALID:由发送端(主设备或从设备)置高,表示数据或地址有效。
READY:由接收端置高,表示准备好接收数据或地址。
数据传输只有在 VALID 和 READY 同时为高 时才会发生。

写数据通道(W)
WDATA:从T3到T8,主设备依次发送4个数据:D(A0)、D(A1)、D(A2)、D(A3)。每个数据在一个时钟周期内传输。
WLAST:在T8,发送最后一个数据 D(A3) 时,主设备将 WLAST 置高,表示这是突发传输的最后一个数据。
WVALID:从T3到T8,主设备将 WVALID 置高,表示数据有效。每次数据传输都需要 WVALID 和 WREADY 同时为高。
WREADY:从T3到T4,从设备将 WREADY 置高,表示准备好接收数据。但在T5,WREADY 变低,表示从设备暂时未准备好(可能是处理延迟)。在T6到T8,WREADY 再次变高,继续接收数据。
握手:在T3、T4、T6、T7、T8的时钟上升沿,WVALID 和 WREADY 同时为高,数据传输完成。

写响应通道(B)
BRESP:在T9,从设备设置响应状态为 OKAY,表示写操作成功。
BVALID:在T9,从设备将 BVALID 置高,表示响应有效。
BREADY:在T2到T9,主设备将 BREADY 置高,表示准备好接收响应。
握手:在T9的时钟上升沿,BVALID 和 BREADY 同时为高,响应传输完成。

写操作流程

  1. 写地址传输(T1-T2):
    主设备发送地址 A(通过 AWADDR),并通过 AWVALID 和 AWREADY 握手完成地址传输。
  2. 写数据传输(T3-T8):
    主设备发送4个数据 D(A0) 到 D(A3)。
    数据传输在T3、T4、T6、T7、T8完成(因为T5时 WREADY 为低,数据传输暂停了一个周期)。
    在最后一个数据 D(A3) 时,WLAST 置高,表示突发传输结束。
  3. 写响应(T9):
    从设备返回 OKAY 响应,表示写操作成功。
    通过 BVALID 和 BREADY 握手完成响应传输。
2.AXI4读操作时序

突发读操作(burst length=4),主设备(Master)请求4个连续的数据。

AXI4读操作使用2个通道:
读地址通道(AR):ARADDR、ARVALID、ARREADY
读数据通道(R):RDATA、RLAST、RVALID、RREADY

在这里插入图片描述

2.时序图信号解读

时钟(ACLK)
ACLK 是一个周期性的时钟信号,从T0到T13,每周期一个上升沿,用于同步所有信号。

读地址通道(AR)
ARADDR:在T1到T2,主设备设置读地址为 A,表示起始读取地址。地址信号在 ARVALID 有效期间保持不变。
ARVALID:在T1,主设备将 ARVALID 置高,表示读地址有效。一直保持高电平直到T2,因为地址传输完成。
ARREADY:在T2,从设备将 ARREADY 置高,表示准备好接收读地址。
握手:在T2的时钟上升沿,ARVALID 和 ARREADY 同时为高,地址传输完成。

读数据通道(R)
RDATA:从T6到T13,从设备依次返回4个数据:D(A0)、D(A1)、D(A2)、D(A3)。每个数据在一个时钟周期内传输。
RLAST:在T13,发送最后一个数据 D(A3) 时,从设备将 RLAST 置高,表示这是突发传输的最后一个数据。
RVALID:从T6到T13,从设备将 RVALID 置高,表示数据有效。每次数据传输都需要 RVALID 和 RREADY 同时为高。
RREADY:从T4到T6,主设备将 RREADY 置高,表示准备好接收数据。在T7,RREADY 变低,表示主设备暂时未准备好(可能是处理延迟)。在T8到T11,RREADY 再次变高,继续接收数据。在T12,RREADY 变低。在T13,RREADY 再次变高。
握手:RVALID 和 RREADY 同时为高,数据传输完成。

读操作流程

  1. 读地址传输(T1-T2):
    主设备发送地址 A(通过 ARADDR),并通过 ARVALID 和 ARREADY 握手完成地址传输。
  2. 读数据传输(T4-T13):
    从设备在T6到T13返回4个数据 D(A0) 到 D(A3)。
    数据传输在T6、T9、T10、T13完成。
    在最后一个数据 D(A3) 时,RLAST 置高,表示突发传输结束。

http://www.hkcw.cn/article/NGdZNimkaM.shtml

相关文章

.NET 7 AOT 使用及 .NET 与 Go 语言互操作详解

.NET 7 AOT 使用及 .NET 与 Go 语言互操作详解 目录 .NET 7 AOT 使用及 .NET 与 Go 语言互操作详解 一、背景与技术概述 1.1 AOT 编译技术简介 1.2 Go 语言与 .NET 的互补性 二、.NET 7 AOT 编译实践 2.1 环境准备 2.2 创建 AOT 项目 2.3 AOT 编译流程 2.4 调试信息处…

Shortest path 代码

Project https://graphics.cs.utah.edu/research/projects/shortest-path-to-boundary/ Build and Debug Fork:(在Win10上) https://github.com/chunleili/Shortest-Path-to-Boundary-for-Self-Intersecting-Meshes commit hash d3160168d2b6a58188d12e6cd959da…

Spring框架学习day1--基础概念

Spring基础部分**轻量级的**IOC:控制反转(对象由自己管理变成交给框架管理)AOP:面向切面编程一站式BaenSpring体系结构 Spring Hello World 搭建 Spring基础部分 Spring是一个轻量级的IOC、AOP的一站式java开发框架,为…

立志成为一名优秀测试开发工程师(第九天)——使用fiddler工具、request库进行接口测试

接口测试学习 目录 一、接口测试的介绍 二、抓包软件Fiddler的使用 三、使用Python的Request库发送get、post请求: 1.get请求 2.post请求 四、总结 登录接口实现 认证请求处理 异常处理 高级配置 接口测试工具类封装 测试用例设计规范 Cookie处理方案 …

【面板数据】各地区新型数字基础设施数据集(2002-2025年)

新型数字基础设施是利用新一代信息技术(如5G、人工智能、物联网、大数据、区块链等)构建的基础设施体系,主要服务于信息传输、计算存储、智能分析和融合应用等环节。新型数字基础设施作为引领经济社会数字化转型的重要支撑,在各地…

小程序 - 视图与逻辑

个人简介 👨‍💻‍个人主页: 魔术师 📖学习方向: 主攻前端方向,正逐渐往全栈发展 🚴个人状态: 研发工程师,现效力于政务服务网事业 🇨🇳人生格言: “心有多大,舞台就有多大。” 📚推荐学习: 🍉Vue2 🍋Vue3 🍓Vue2/3项目实战 🥝Node.js实战 🍒T…

zynq ad7616 调试笔记

环境 zynq7020 ps端的spi外接硬件的ad7616模块(非ip核) 1 下载 https://github.com/analogdevicesinc/no-OS/blob/2019_R1/ad7616-sdz/ad7616_sdz.c 2 在zynq的sdk中新建ad7616的app程序,将上图方框中的文件拷贝过来并编译 3 移植 ad7616…

如何轻松将 iPhone 备份到外部硬盘

当您的iPhone和电脑上的存储空间有限时,您可能希望将iPhone备份到外部硬盘上,这样可以快速释放iPhone上的存储空间,而不占用电脑上的空间,并为您的数据提供额外的安全性。此外,我们还提供 4 种有效的解决方案&#xff…

从Homebrew找到openssl.cnf文件并拷贝到Go项目下使用

安装OpenSSL 在 macOS 上下载和安装 OpenSSL 最常见和推荐的方式是使用 Homebrew,这是一个 macOS 缺失的包管理器。 如果您还没有安装 Homebrew,请先安装它。安装 Homebrew 后,安装 OpenSSL 只需要一条命令。 步骤 1:安装 Home…

Socket编程基础

这篇博客我们主要用来讲解TCP和UDP的socket编程。 概念 大多数网络协议都是由软件实现的(特别是协议栈中的高层协议),而且绝大多数计算机系统都将运输层以下的网络协议在操作系统的内核中进行实现。应用程序要想执行网络操作,必…

什么是物化视图(Materialized View)?

分析师和工程师经常面临一个共同的困境:随着数据量激增,查询性能急剧下降。一个看似简单的多表联合查询可能需要耗时数分钟甚至数小时,一个常规的实时大屏可能因数据处理缓慢而失去时效价值。当数据规模从 GB 级增长到 TB 甚至 PB 级时&#…

USB Redirector对比国产USB Server方案:软硬之争与技术突围

在远程设备共享领域,‌USB Redirector‌以其轻量级跨平台特性长期占据国际主流市场,支持Windows/Linux系统下的无缝USB设备网络共享。然而,随着国产化替代需求的爆发,以‌朝天椒USB Server‌为代表的软硬一体化方案,凭…

PP-OCRv5 C++封装DLL C#调用源码分享

目录 说明 效果 C#调用效果 项目 C# C 头文件 源文件 C#调用 下载 说明 C封装DLL&#xff0c;C#调用源码分享 效果 C#调用效果 项目 C# C 头文件 #include <windows.h> #include <iostream> #include <opencv2/opencv.hpp> #include <stri…

RISC-V PMA、PMP机制深入分析

1 PMA PMA&#xff08;Physical Memory Attributes&#xff09;&#xff0c;物理内存属性&#xff0c;顾名思义就是用来设置物理内存属性的&#xff0c;但这里说“设置”&#xff0c;并不合理&#xff0c;因为一般情况下各存储的属性&#xff0c;在芯片设计时就固定了&#xf…

桂花网体育运动监测方案:开启幼儿园运动健康管理新篇章

在幼儿教育领域&#xff0c;运动能力的培养与健康监测始终是备受关注的核心环节。随着科技的飞速发展&#xff0c;如何科学、有效地监测幼儿的运动状态&#xff0c;成为了幼儿园教育者面临的一大挑战。桂花网体育运动监测方案凭借其高效、精准、智能化的特性&#xff0c;为幼儿…

第6讲、 Odoo 18 `tools` 模块深度分析

Odoo 18 中的 odoo/tools 目录是核心工具模块的集合&#xff0c;封装了大量通用功能&#xff0c;包括数据处理、安全校验、缓存优化、文件处理、时间转换、国际化、多线程处理等。这些工具模块在整个 Odoo 框架中被频繁引用&#xff0c;是系统高效运行和代码解耦的重要基础。 &…

如何在矩池云实例上开启应用服务的访问端口

AI 应用开发越来越火热&#xff0c;矩池云平台上也相应出现了越来越多的 AI 应用开发者&#xff0c;这里详细介绍下大家在使用过程中经常遇到的一个问题&#xff1a;在矩池云的实例上&#xff0c;如何为应用服务开启外部可访问的端口&#xff1f; 根据开发者有没有启动实例&…

首发支持! 基于昇腾MindIE玩转InternVL3多模态理解最新模型

2025年4月16日&#xff0c;上海人工智能实验室&#xff08;上海AI实验室&#xff09;升级并开源了通用多模态大模型书生万象3.0&#xff08;InternVL3&#xff09;。通过采用创新的多模态预训练和后训练方法&#xff0c;InternVL3 多模态基础能力全面提升&#xff0c;在专家级基…

深入解析Java8核心新特性(Optional、新的日期时间API、接口增强)

文章目录 前言一、Optional&#xff1a;优雅处理null1.1 Optional设计哲学1.2 Optional基础操作1.3 Optional链式操作1.4 高级应用1.5 Optional实战案例 二、新的日期时间API&#xff1a;解决历史痛点2.1 java.time 设计哲学与核心架构2.2 核心类详解与使用基本日期时间类时区相…

深入理解C#中的委托与事件:从基础到高级应用

在C#编程语言中&#xff0c;委托和事件是两个强大且独特的特性&#xff0c;它们为方法封装、回调机制和事件驱动编程提供了语言级别的支持。作为.NET框架的核心组件&#xff0c;委托和事件广泛应用于Windows Forms、WPF、ASP.NET等各类应用程序中。本文将全面探讨委托与事件的概…