深入浅出AXI协议(5)——数据读写结构读写响应结构

news2024/11/17 16:00:40

目录

一、前言

二、写选通(Write strobes)

三、窄传输(Narrow transfers)

1、示例1

2、示例2 

四、字节不变性(Byte invariance) 

五、未对齐的传输(Unaligned transfers)

六 、读写响应结构

七、总结

一、前言

        在之前的文章中,我们介绍了AXI协议的猝发传输,AXI协议是基于猝发的,主机通过将控制信息和传输中第一个字节的地址驱动到从机,开始每一次猝发传输。随着猝发的进行,从机必须计算突发中后续传输的地址。一次猝发不能跨越4KB的地址边界。

        在这篇文章中,我们将介绍AXI协议的数据读写结构和读写响应结构。主要描述了 AXI 读写数据总线传输的不同大小和接口如何用字节不变endian 去握手混合 endian 传输,之后我们简单介绍关于AXI的读写响应操作。

二、写选通(Write strobes)

        当写选通信号 WSTRB[n:0] 为高时,指定包含有效信息的数据总线的字节通道。写数据总线的每8位都有一个写选通,因此 WSTRB[n] 对应于 WDATA[ (8n+7) : (8n) ] 。

        主机必须确保写选通仅对包含有效数据的字节通道是高的。

        当WVALID为低时,写选通可以取任何值,不过还是建议它们要么是驱动的低,要么保持在它们以前的值。

三、窄传输(Narrow transfers)

        主机产生的数据宽度小于数据总线宽度时,地址和控制信息决定哪一个 字节通道(byte lanes)为有效的数据:

(1)在递增或回卷模式时,对猝发的每个节拍使用不同的字节通道

(2)在固定模式时,每个节拍都使用相同的字节通道

下面给出了两个窄传输的例子(阴影单元格表示未传输的字节):

1、示例1

  • 猝发有5个传输
  • 起始地址是0
  • 每个传输是8位
  • 传输是在一个位宽为32位总线上
  • 突发类型是INCR(递增猝发)

2、示例2 

  • 猝发有三个传输
  • 起始地址是4
  • 每个传输是32位
  • 传输是在一个位宽为64位总线上

四、字节不变性(Byte invariance) 

        为了访问单个内存空间中的混合数据结构,AXI协议使用字节不变的方案。大多数小端元件可以直接连接到字节不变接口。只支持大端传输的元件需要一个字节不变操作的转换函数。字节不变性确保了大端结构和小结构可以在单个内存空间中共存而不损坏。

        下面是一个数据不变性存取需求的数据结构的例子。他包含头信息,例如source、destination identifiers 这些信息是采用 little-endian 格式,但是 payload 是big-endian字节流,具体情况如下图:

        字节不变性确保在数据结构中 little-endian 存取头信息的部分不会破坏其他 big-endian 数据。

五、未对齐的传输(Unaligned transfers)

        AXI支持非对齐的传输。对于任何由大于一个字节的数据传输组成的猝发,被访问的第一个字节可能与自然地址边界不对齐。例如,从0x1002的字节地址开始的32位数据包与自然的32位地址边界不对齐。

        主机可以:使用低阶地址行去标示一个不对齐的起始地址。低阶地址行的信息必须包含 byte lane strobes 信息。

        下图显示了在32位总线上使用对齐和未对齐的32位传输的递增猝发的示例。图中的每一行表示一个传输,阴影单元格表示未传输的字节;

        下图显示了在64位总线上使用对齐和未对齐的32位传输的递增突发的示例。图中的每一行表示一个传输,阴影单元格表示未传输的字节:

        下图显示了一个在64位总线上使用对齐的32位传输的包装突发的例子。图中的每一行表示一个传输,阴影单元格表示未传输的字节:

六 、读写响应结构

        AXI协议为读和写事务提供响应信令:

(1)对于读事务,来自从机的响应信息在读数据信道上;

(2)对于写事务,响应信息在写响应信道上。

        AXI 协议对读事务和写事务都有响应。对于读事务,读响应与读数据一起发送给主机,而写事务将写响应通过写响应通道传送。AXI 协议的响应类型有 OKAY、EXOKAY、SLVERR、DECERR。
        通过信号 RRESP[1:0] BRESP[1:0] 来编码响应信号,具体如下图:
        协议规定请求的需要传输的数据数量必须被执行,即使有错误报告。在一次突发式读写的剩余数据不会被取消传输,即使有单个错误报告。
        AXI 协议的四种响应类型:正常存取成功(OKEY)、独占式存取(EXOKEY)、设备错误(SLVERR)、译码错误(DECERR)。AXI 协议要求,在一个传输事务中的所有数据必须传输完成,即使有错误状态发生。

七、总结

        本文介绍的主要内容是AXI协议的数据读写结构和读写响应结构,主要讲述了当遇到各种特殊情况时,AXI如何完成数据的读写操作,最后介绍了读写响应的4种类型。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/972468.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

网络版五子棋C++实现

目录 1.项目介绍 2.开发环境 3.核心技术 4.环境搭建 5.WebSocketpp介绍 5.1WebSocketpp是什么 5.2为什么使用WebSocketpp 5.3原理解析: 5.4WebSocketpp主要特性 6.WebSocketpp使用 7.JsonCpp使用 8.MySQL API 9.项目模块设计以及流程图 10.封装日志宏…

基于单片机的太阳能热水器控制器设计

一、项目介绍 随着环保意识的逐渐增强,太阳能热水器作为一种清洁能源应用得越来越广泛。然而,传统的太阳能热水器控制器通常采用机械式或电子式温控器,存在精度低、控制不稳定等问题。为了解决这些问题,本项目基于单片机技术设计…

Qt鼠标点击事件处理:按Escape键退出程序

创建项目 Qt 入门实战教程(目录) 首先,创建一个名称为QtKeyEscape的Qt默认的窗口程序。 参考 :Qt Creator 创建 Qt 默认窗口程序 Qt响应键盘Escape事件 打开Qt Creator >>编辑 >> 项目 >> Headers>> …

服务运营 | MS文章精读:基于强化学习和可穿戴设备的帕金森治疗方案

作者信息:庞硕,李舒湉 编者按 帕金森疾病的治疗是一个备受关注的医疗问题。本文通过患者的可穿戴传感器收集数据,提出了一个基于强化学习的帕金森药物治疗方案。这是第一篇关于可穿戴治疗设备在慢性疾病管理中的应用研究。原文于2023年4月发…

如何在你的Android工程中启用K2编译器?

如何在你的Android工程中启用K2编译器? K2编译器是用于Kotlin代码编译的最新、高效编译器,你现在可以尝试使用了。 Kotlin编译器正在为Kotlin 2.0进行重写,新的编译器实现(代号K2)带来了显著的构建速度改进&#xff…

K210-调用自定义py库

调用自定义py库 导入py库文件调用py库 用过Python的朋友应该知道,Python是支持将自定义py库(或者第三方py库)放到同一个目录下调用的,MicroPython也是支持调用自定义py库的。在调用自定义py库之前,需要提前将py库文件导…

期货基础知识

一、期货是什么?  期货是与现货相对应,并由现货衍生而来。期货通常指期货合约,期货与现货完全不同,现货是实实在在可以交易的货(商品),期货主要不是货,而是以某种大众产品如棉花、大…

影响Windows 和 macOS平台,黑客利用 Adobe CF 漏洞部署恶意软件

FortiGuard 实验室的网络安全研究人员发现了几个影响 Windows 和 Mac 设备的 Adobe ColdFusion 漏洞。 远程攻击者可利用Adobe ColdFusion 2021中的验证前RCE漏洞,获取受影响系統的控制权力。Adobe 已发布安全补丁来解决这些漏洞,但攻击者仍在利用这些漏…

leetcode:1941. 检查是否所有字符出现次数相同(python3解法)

难度:简单 给你一个字符串 s ,如果 s 是一个 好 字符串,请你返回 true ,否则请返回 false 。 如果 s 中出现过的 所有 字符的出现次数 相同 ,那么我们称字符串 s 是 好 字符串。 示例 1: 输入:s…

鼠标悬停阴影的效果被旁边div挡住的解决办法

出现的问题 需求要求鼠标悬停某个图片上有阴影效果,但阴影被旁边相邻的div挡住了,如图所示 解决方案 给悬停的这块div增加2个css属性 $(this).css(position, relative); $(this).css(z-index, 200);新的效果如图所示 一直写后端,前端的…

国际网页短信软件平台搭建定制接口说明|移讯云短信系统

国际网页短信软件平台搭建定制接口说明|移讯云短信系统 通道路由功能介绍 支持地区通道分流,支持关键字,关键词通道分流,支持白名单独立通道,支持全网通道分流,支持通道可发地区设置,通道路由分组&#x…

redis 数据结构(二)

整数集合 整数集合是 Set 对象的底层实现之一。当一个 Set 对象只包含整数值元素,并且元素数量不时,就会使用整数集这个数据结构作为底层实现。 整数集合结构设计 整数集合本质上是一块连续内存空间,它的结构定义如下: typed…

QT C++ 实现网络聊天室

一、基本原理及流程 1&#xff09;知识回顾&#xff08;C语言中的TCP流程&#xff09; 2&#xff09;QT中的服务器端/客户端的操作流程 二、代码实现 1&#xff09;服务器 .ui .pro 在pro文件中添加network库 .h #ifndef WIDGET_H #define WIDGET_H#include <QWidget>…

春秋云镜 CVE-2018-12530

春秋云镜 CVE-2018-12530 Metinfo 6.0.0任意文件删除 靶标介绍 Metinfo 6.0.0任意文件删除。后台密码&#xff1a;f2xWcke5KN6pfebu 启动场景 漏洞利用 /admin进入管理后台&#xff0c;admin/f2xWcke5KN6pfebu /admin/app/batch/csvup.php?fileFieldtest-1&fliename…

目标检测框架MMDetection训练自定义数据集实验记录

在上一篇博文中&#xff0c;博主完成了MMDetection框架的环境部署与推理过程&#xff0c;下面进行该框架的训练过程&#xff0c;训练的入口文件为tools/train.py&#xff0c;我们需要配置的内容如下&#xff1a; parser.add_argument(--config,default"/home/ubuntu/prog…

算法通关村16关 | 滑动窗口最长字串专题

1. 最长字串专题 1.1 无重复字符的最长字串 题目 LeetCode3 给定一个字符串s&#xff0c;请你找出其中不含有重复字符的最长字串的长度。 思路 找最长字串&#xff0c;需要知道所有无重复字串的首和尾&#xff0c;找出其中最长的&#xff0c;最少两个指针才可以完成&#xff…

冠达管理:创业板是二板市场吗?二板市场起什么作用?

说到股市的各买卖板块&#xff0c;适当一部分投资者简单被主板、二板、三板这些词绕晕&#xff0c;其中二板商场一词关于有些投资者来说是比较生疏的&#xff0c;但面对创业板这一个不是主板但也没有说明是哪个层级的板块却熟悉许多&#xff0c;那么&#xff0c;创业板是不是便…

MySQL忘记密码了怎么办?如何重置修改密码?(Windows图文教程)

1. 如果服务在启动中&#xff0c;先停止MySQL服务 打开cmd&#xff0c;在命令窗口中输入net stop mysql 2. 跳过密码登录MySQL服务 mysqld --console --skip-grant-tables --shared-memory 输入以上代码 再次打开一个新的cmd窗口&#xff0c;原来的窗口不能关闭 在新的cmd窗口中…

冠达管理:股票隔夜挂单是怎么回事?股票挂单规则?

股票的买卖时刻是周一至周五上午9:30-11:30&#xff0c;下午13:00-15:00&#xff0c;一般投资者都是买卖日早上挂单&#xff0c;但也有一些投资者会在晚上隔夜挂单.那么&#xff0c;股票隔夜挂单是怎么回事&#xff1f;股票挂单规矩是什么&#xff1f;冠达管理为我们准备了相关…

C语言malloc函数学习

malloc的全称是memory allocation&#xff0c;中文叫动态内存分配&#xff0c;用于申请一块连续的指定大小的内存块区域&#xff0c;以void*类型返回分配的内存区域地址&#xff1b; 函数原型为void *malloc(unsigned int size)&#xff0c;在内存的动态存储区中分配一个长度为…