【总线】AXI第九课时:介绍AXI响应信号 (Response Signaling):RRESP和 BRESP

 大家好,欢迎来到今天的总线学习时间!如果你对电子设计、特别是FPGA和SoC设计感兴趣,那你绝对不能错过我们今天的主角——AXI4总线。作为ARM公司AMBA总线家族中的佼佼者,AXI4以其高性能和高度可扩展性,成为了现代电子系统中不可或缺的通信桥梁。

        上课时我们讲了AXI的 "原子访问" :独占访问(Exclusive Access)和锁定访问(Locked Access),本章节讲解AXI响应信号 (Response Signaling):RRESP和 BRESP,理解这一章节,有助于设计和调试基于AXI协议的系统,确保系统能够正确地响应和处理各种事务状态。

        这里会有一系列的课程,和大家分享AMBA总线家族,欢迎大家一起学习,收藏点赞。

  系列文章

【总线】AMBA总线架构的发展历程-CSDN博客

【总线】设计fpga系统时,为什么要使用总线?-CSDN博客

【总线】AXI总线:FPGA设计中的通信骨干-CSDN博客

【总线】AMBA总线家族的明星成员:AXI协议简介-CSDN博客

【总线】AXI4第一课时:揭秘AXI4总线的五大独立通道-CSDN博客

【总线】AXI4第二课时:深入AXI4总线的基础事务-CSDN博客

【总线】AXI4第三课时:握手机制-CSDN博客

【总线】AXI4第五课时:信号描述-CSDN博客

【总线】AXI4第六课时:寻址选项深入解析-CSDN博客

【总线】AXI4第七课时:AXI的额外的控制信息(PROT和CACHE)-CSDN博客

【总线】AXI4第八课时:介绍AXI的 “原子访问“ :独占访问(Exclusive Access)和锁定访问(Locked Access)-CSDN博客

【总线】AXI第九课时:介绍AXI响应信号 (Response Signaling):RRESP和 BRESP-CSDN博客 


9.1 关于响应信号 (About Response Signaling)

AXI协议允许对读写事务进行响应信号的传递。对于读事务,从设备会将响应信息与读数据一起传递;对于写事务,响应信息则通过写响应通道来传递。

AXI协议定义了以下响应类型:

  • OKAY:正常访问成功,或者独占访问失败。
  • EXOKAY:独占访问成功。
  • SLVERR:从设备错误。
  • DECERR:解码错误。

表9-1 RRESP[1:0] 和 BRESP[1:0] 编码 (Table 7-1 RRESP[1:0] and BRESP[1:0] encoding)

对于写事务,整个突发传输期间只给出一个响应,而不是每个数据传输都给出响应。在读事务中,从设备可以在突发传输中的不同传输上给出不同的响应。例如,在16次读传输的突发中,从设备可能对15次传输返回OKAY响应,而对一次传输返回SLVERR响应。

协议规定即使报告了错误,也必须执行所要求数量的数据传输。例如,如果从设备在请求8次传输的读操作中遇到错误,那么它必须执行8次数据传输,每次都带有错误响应。如果从设备给出了单个错误响应,突发传输的其余部分不会取消。

这种协议对能够发出多个未完成地址的主设备施加了限制,这些主设备还必须支持精确的错误信号传递。这样的主设备必须能够在早期传输已经出错的情况下,处理后续传输。

9.2 响应类型 (Response Types)

本节描述了AXI协议中的四种响应类型:

• Normal access success
• Exclusive access
• Slave error
• Decode error.
 

9.2.1 正常访问成功 (Normal Access Success)

OKAY响应表示:

  • 正常访问的成功。
  • 独占访问的失败。
  • 对于不支持独占访问的从设备进行的独占访问。

OKAY是大多数事务的响应。

9.2.2 独占访问 (Exclusive Access)

EXOKAY响应表示独占访问的成功。第八章 "原子访问" 描述了这种响应。

9.2.3 从设备错误 (Slave Error)

SLVERR响应表示事务未能成功完成。从设备错误条件的例子包括:

  • FIFO/缓冲区溢出或下溢。
  • 尝试的传输大小不受支持。
  • 尝试向只读位置进行写访问。
  • 从设备中的超时条件。
  • 尝试访问不存在寄存器的地址。
  • 尝试访问已禁用或已关闭功能的地址。

为了简化系统的监控和调试,建议仅在出现错误条件时使用错误响应,而不是用于信号正常、预期的事件。

9.2.4 解码错误 (Decode Error)

在没有完全解码的地址映射系统中,可能存在没有从设备响应事务的地址。在这种情况下,互联组件必须提供合适的错误响应,以标记访问为非法,并防止系统因尝试访问不存在的从设备而锁定。

当互联组件无法成功解码从设备访问时,它实际上将访问路由到默认从设备,并且默认从设备返回DECERR响应。实现选项是让默认从设备还记录解码错误的详细信息,以便稍后确定错误的发生方式。通过这种方式,默认从设备可以大大简化调试过程。

AXI协议要求即使出现错误条件,也必须完成事务的所有数据传输。因此,任何给出DECERR响应的组件都必须满足此要求。

请注意,以上翻译是根据您提供的PDF文件内容进行的。如果需要进一步的整合或详细解释,请告知。

总结

  1. 响应信号的作用:在AXI协议中,响应信号用于指示一个事务是否成功完成,或者在执行过程中遇到了什么类型的错误。这对于确保数据的一致性和系统的稳定性至关重要。

  2. 响应类型:AXI定义了四种基本的响应类型:

    • OKAY:表示事务正常完成。如果事务是独占访问但失败了,也会返回OKAY。
    • EXOKAY:表示独占访问事务成功完成。独占访问是一种特殊的事务类型,其中总线不会被其他事务抢占。
    • SLVERR(Slave Error):表示从设备在接收到事务后,由于某些原因(如FIFO溢出、不支持的传输大小等)无法完成该事务。
    • DECERR(Decode Error):通常由互联组件发出,表示没有找到与事务地址匹配的从设备。
  3. 响应信号的编码:响应信号通过RRESP[1:0]BRESP[1:0]来编码。这些信号是2位宽的,每种响应类型对应一个特定的编码组合。

  4. 事务的完成:即使在报告错误的情况下,AXI协议也要求完成事务所需的所有数据传输。这意味着,即使从设备返回了错误响应,它也必须完成整个突发传输。

  5. 多主设备系统中的响应:在多主设备系统中,主设备可能同时发出多个事务。AXI协议要求这些主设备能够处理早期事务的错误响应,同时已经开始后续事务。

  6. 错误处理:系统设计者需要根据返回的响应类型进行相应的错误处理。例如,对于SLVERR,可能需要重试事务或报告错误;对于DECERR,则可能需要检查地址映射或从设备的配置。

  7. 响应信号的设计意图:响应信号的设计旨在提供足够的信息,以便系统能够优雅地处理错误情况,同时确保事务的顺序性和数据的完整性。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

28.【C语言】库函数

1.函数定义 在计算机科学中,子程序是一个大型程序中的某部分代码,由一个或多个语句块组成。它负责完成某项特定任务,而且相较于其他代码,具备相对的独立性。一般会有输入参数并有返回值,提供对过程的封装和细节的隐藏…

AC修炼计划(AtCoder Regular Contest 180) A~C

A - ABA and BAB A - ABA and BAB (atcoder.jp) 这道题我一开始想复杂了,一直在想怎么dp,没注意到其实是个很简单的规律题。 我们可以发现我们住需要统计一下类似ABABA这样不同字母相互交替的所有子段的长度,而每个字段的的情况有&#xff…

目标检测基本标注工具-labelImg安装与使用

🍉一、安装 1.1 打开conda创建虚拟环境🎈 conda create -n labelImg python3.8 -y 1.2 激活labelImg虚拟环境🎈 activate labelImg1.3 安装labelImg🎈 pip install -i https://pypi.tuna.tsinghua.edu.cn/simple lab…

Rust vs Go: 特点与应用场景分析

目录 介绍Rust的特点Go的特点Rust的应用场景Go的应用场景总结 介绍 Rust和Go(Golang)是现代编程语言中两个非常流行的选择。凭借各自的独特优势和广泛的应用场景,吸引了大量开发者的关注。本文将详细介绍Rust和Go的特点,并探讨它…

golang程序性能提升改进篇之文件的读写---第一篇

背景:接手的项目是golang开发的(本人初次接触golang)经常出现oom。这个程序是计算和io密集型,调用流量属于明显有波峰波谷,但是因为各种原因,当前无法快速通过serverless或者动态在高峰时段调整资源&#x…

python的简单爬取

需要的第三方模块 requests winr打开命令行输入cmd 简单爬取的基本格式(爬取百度logo为例) import requests url"http://www.baidu.com/img/PCtm_d9c8750bed0b3c7d089fa7d55720d6cf.png" resprequests.get(url)#回应 #保存到本地 with open(&…

C语言之指针的奥秘(三)

一、字符指针变量 在指针的类型中&#xff0c;有字符指针char*&#xff0c;一般使用&#xff1a; #include<stdio.h> int main() {char ch w;char* p &ch;*p w;return 0; } 还有一种方式&#xff1a; #include<stdio.h> int main() {const char* p &qu…

[Vulnhub] Sedna BuilderEngine-CMS+Kernel权限提升

信息收集 IP AddressOpening Ports192.168.8.104TCP:22, 53, 80, 110, 111, 139, 143, 445, 993, 995, 8080, 55679 $ nmap -p- 192.168.8.104 --min-rate 1000 -sC -sV PORT STATE SERVICE VERSION 22/tcp open ssh OpenSSH 6.6.1p1 Ubuntu 2ubuntu2 …

强化学习编程实战-5 基于时间差分的方法

第4章中&#xff0c;当模型未知时&#xff0c;由于状态转移概率P未知&#xff0c;动态规划中值函数的评估方法不再适用&#xff0c;用蒙特卡洛的方法聘雇值函数。 在蒙特卡洛方法评估值函数时&#xff0c;需要采样一整条轨迹&#xff0c;即需要从初始状态s0到终止状态的整个序列…

“论软件维护方法及其应用”写作框架,软考高级论文,系统架构设计师论文

论文真题 软件维护是指在软件交付使用后&#xff0c;直至软件被淘汰的整个时间范围内&#xff0c;为了改正错误或满足 新的需求而修改软件的活动。在软件系统运行过程中&#xff0c;软件需要维护的原因是多种多样的&#xff0c; 根据维护的原因不同&#xff0c;可以将软件维护…

DockerSecret+DockerConfig介绍及使用

DockerSecret 查看官网介绍&#xff0c;Secret是daemon API 1.25之后引入的&#xff0c;它运行在swarm上的命令。 生产环境下&#xff0c;为了安全&#xff0c;我们不能把各项目的配置密码写入到配置文件。 我们可以引入docker的secret方式保护密码。 场景&#xff1a; 用…

数据结构之链表操作详解与示例(反转链表,合并链表,旋转链表,对链表排序)

文章目录 1. 反转链表2. 合并链表3. 旋转链表4. 对链表排序总结 链表是一种常见的基础数据结构&#xff0c;它在内存中的存储方式非常灵活。本文将详细介绍反转链表、合并链表、旋转链表以及对链表排序这四种操作&#xff0c;并提供C和C的实现示例。 1. 反转链表 反转链表意味…

【数学建模】——【线性规划】及其在资源优化中的应用

目录 线性规划问题的两类主要应用&#xff1a; 线性规划的数学模型的三要素&#xff1a; 线性规划的一般步骤&#xff1a; 例1&#xff1a; 人数选择 例2 &#xff1a;任务分配问题 例3: 饮食问题 线性规划模型 线性规划的模型一般可表示为 线性规划的模型标准型&…

AI大模型探索之旅:深潜大语言模型的训练秘境

在人工智能的浩瀚星空中&#xff0c;大语言模型无疑是最耀眼的星辰之一&#xff0c;它们以无与伦比的语言理解与生成能力&#xff0c;引领着智能交互的新纪元。本文将带您踏上一场探索之旅&#xff0c;深入大语言模型的训练秘境&#xff0c;揭开其背后复杂而精妙的全景画卷。 …

免杀笔记 ----> 动态调用

前一段时间不是说要进行IAT表的隐藏吗&#xff0c;终于给我逮到时间来写了&#xff0c;今天就来先将最简单的一种方式 ----> 动态调用&#xff01;&#xff01;&#xff01; 1.静态查杀 这里还是说一下我们为什么要对他进行隐藏呢&#xff1f;&#xff1f;&#xff1…

CAN总线学习

can主要用于汽车、航空等控制行业&#xff0c;是一种串行异步通信方式&#xff0c;因为其相较于其他通信方式抗干扰能力更强&#xff0c;更加稳定。原因在于CAN不像其他通信方式那样&#xff0c;以高电平代表1&#xff0c;以低电平代表0&#xff0c;而是通过电压差来表示逻辑10…

STM32MP135裸机编程:唯一ID(UID)、设备标识号、设备版本

0 资料准备 1.STM32MP13xx参考手册1 唯一ID&#xff08;UID&#xff09;、设备标识号、设备版本 1.1 寄存器说明 &#xff08;1&#xff09;唯一ID 唯一ID可以用于生成USB序列号或者为其它应用所使用&#xff08;例如程序加密&#xff09;。 &#xff08;2&#xff09;设备…

使用Python和MediaPipe实现手势虚拟鼠标控制

概述 使用Python实现虚拟鼠标控制&#xff0c;利用手势识别来替代传统鼠标操作。这一实现依赖于计算机视觉库OpenCV、手势识别库MediaPipe以及其他辅助库如PyAutoGUI和Pynput。 环境配置 在开始之前&#xff0c;请确保已安装以下Python库&#xff1a; pip install opencv-p…

SadTalker数字人服务器部署

一、单独SadTalker部署 git clone https://github.com/OpenTalker/SadTalker.gitcd SadTalker conda create -n sadtalker python3.8conda activate sadtalkerpip install torch1.12.1cu113 torchvision0.13.1cu113 torchaudio0.12.1 --extra-index-url https://download.pyto…

RuoYi-后端管理项目入门篇1

目录 前提准备 下载若依前后端 Gitee 地址 准备环境 后端数据库导入 1 克隆完成 若依后端管理后端 Gitte 地址 :若依/RuoYi-Vue 2.1 创建Data Source数据源 2.2 填写好对应的数据库User 和 Password 点击Apply 2.3 新建一个Schema 2.4 填写对应数据库名称 这边演示写的…