AMBA总线协议(4)——AHB(二)

目录

一、前言

二、AHB操作概述

三、AHB 基本传输

1、简单传输        

2、带有等待的传输

3、多重传输

四、AHB传输类型

五、小结


一、前言

         在之前的文章中对于AMBA AHB做了一个简单的介绍,AHB 主要用于高性能模块(如 CPU、DMA 和 DSP 等)之间的连接,是Soc所经常采用的一种总线协议,AHB可以支持多主机多从机结构。设备之间的互联使用一个中央多路选择器互联方案。本文中我们将讲述AMBA AHB传输的详细操作。

二、AHB操作概述

        (1)在开始一个AMBA AHB传输前,主机必须得到访问总线的授权。主机向仲裁器发出请求信号,然后仲裁器会指示这个主机何时能够得到授权,开始对总线的访问。

        (2)主机得到访问授权后,驱动地址和控制信号,开始一次AHB传输。这些信号提供传送地址,传送方向,传送带宽,这次传送是否是 burst(猝发传输)传送等信息。AHB支持两种类型的猝发传输:增量猝发(地址递增)和回卷猝发(地址达到边界后回卷)。

        (3)在 AHB 上,一次传送包括给出地址、控制信号周期与数据周期。地址与控制信号周期最少需要一个周期,但是会因为数据的原因多出几个周期。数据周期可以通过 HREADY 信号来延迟。地址不长期有效,所以所有从机必须在传输地址时采样地址。然而,通过 HREADY 信号可以延长数据。当该信号为低时导致在传输中插入等待状态同时允许从机有额外的时间提供或者采样数据。

        (4)在传输中从机通过使用响应信号HRESP[1:0]来表示状态:

OKAY :OKAY 响应用来表示传输进展正常并且当 HREADY 变高时表示传输成功完成。

ERROR :ERROR 响应表示发生了一个传输错误并且传输失败。

RETRY 和 SPLIT: RETRY 和 SPLIT 两个传输响应都表示传输不能立刻完成,但是总线主机应该继续尝试传输。

        在正常操作下,在仲裁器授权其他主机访问总线前,允许一个主设备以一个特定的猝发方式完成所有的传输操作。然而,为了避免过多的仲裁延时,仲裁器可能会把一个猝发进行分解。在这种情况下,主机必须重新获得仲裁器授权。

三、AHB 基本传输

        一个AHB传输由2个不同的部分组成:

        (1)地址周期,持续一个时钟周期

        (2)数据周期,可能要求几个周期,通过使用 HREADY信号实现

1、简单传输        

        下图给出了一个简单传输的例子,没有等待状态:

​​​​​​​

       在读图的时候首先要注意:图中的HWDATA和HRDATA分别表示写数据总线和读数据总线,这两个信号出现在同一张图中,不是因为在一次传输中这两个信号同时起作用,这只是为了方便读者能在一张图中同时看到读操作和写操作,但是具体分析读操作和写操作时,应该忽略另一个信号的存在,基本AMBA所有的手册都有类似的性质。

        在一个无等待状态的简单传输中:

        (1)图中①处,在第一个HCLK的上升沿,进入地址周期(Address phase)主机会将地址和控制信息准备好,驱动到总线上。

        (2)图中②处,在第二个HCLK的上升沿,从机采样到地址和控制信息。此时进入数据模式,从机在完成地址和控制信息的采样后会驱动正确的响应信号。

        (3)图中③处,在第三个HCLK的上升沿,主机采样到从机给出的响应信号。

        这个简单的例子就说明了在不同的时钟周期,如何产生地址周期和时钟周期。实际上,任何传输的地址周期可以发生在前一个传输的数据周期。这就是我们常说的流水线结构,允许更高性能的操作,同时为一个从设备提供了充足的时间,用于对一个传输的响应。

2、带有等待的传输

        传送完成时间因等待而延迟,这是由于寻址到较慢的从机所造成。当 HREADY 被从机拉低时(也就是从机告知主机,自己还没有准备好)会发生等待状态。需要延迟传送的周期时,就会在数据期间将 HREADY 拉低,此时地址与数据都必须延伸。

        其实很好理解,在刚才的简单传输中,主机(也就是我们的数据传输的发起者)要向从机(数据传输的接收者)发送数据,主机给出地址和控制信号,双方一拍即合,从机很果断地收下了地址和控制信息,并迅速给主机回应了。一次愉快的传输结束了。

        在此时的等待传输过程中,主机给出了地址和控制信息,但是从机不乐意了,从机表示自己还有其他事情要忙,直接在自己大门上的挂上了暂停营业的信息(HREADY拉低),主机吃了闭门羹,但是又不想放弃这一次传输,那没办法只能等了,等从机忙完,终于撤下了暂停营业的信息(HREADY 拉高),给了主机需要的回应,一次有等待的传输就结束了。

        好了言归正传,我们来看一个有等待的传输具体是怎么进行的:

        (1) 图中①处,在第一个HCLK的上升沿,进入地址周期(Address phase)主机会将地址和控制信息准备好,驱动到总线上。

        (2)图中②处,在第二个HCLK的上升沿,从机采样到地址和控制信息。此时进入数据模式,但是从机并没有准备好数据,在紧连着的下一个HCLK的上升沿处,主机发现从机没有给出HREADY高的信息,所以只能进行等待。

        (3)图中③处,此时从机准备好了数据,拉高了HREADY信号,主机顺利拿到了想要的回应,传输结束。

        这里我们分别看以下读写操作,在进行写操作的时候,由于从机始终没有准备好,所以主机必须保持HWDATA数据是有效的。在读操作的时候,从机就比较随意了,自己准备好了就拉高HREADY信号,只要保证在主机第一次采样到HREADY高的那一个瞬间,自己的数据HRDATA有效就可以了,其他时间无所谓。

3、多重传输

        当传输以这样的方式扩展时,在随后传输的地址周期中有副作用。下图说明了传输3个无关的地址A,B,C。

        (1)传输地址A,C都是零等待状态 

        (2)传输地址B时一个等待周期

        (3)传输的数据周期扩展到地址B,传输的扩展地址周期影响到地址C

四、AHB传输类型

        AHB总共有4种不同的传输类型,用HTRAN[1:0]表示:

HTRAN[1:0]类型描述
00IDLE(空闲)
        表示没有数据传输的要求。此时主机得到了使用总线的授权,但是没有数据要进行传输。
        从机必须总是提供一个零等待状态 OKAY 来回应主机,并且该传输应该被从机忽略。
01BUSY(忙)
        忙传输类型。允许总线主机在突发传输中间插入空闲周期。这种传输类型表示总线主机正在连续执行一个猝发传输,但是下一次传输不能立即发生。当一个主机使用忙传输类型时地址和控制信号必须反映突发中的下一次传输。
        这种传输应该被从机忽略。从机必须总是提供一个零等待状态 OKAY 响应,和从机响应空闲传输一样的方式。
10NONSEQ(非连续)
        表示一次猝发的第一个传输或者一个单一传输。地址和控制信号和前一次传输无关。
        总线上的单一传输被视为(数据量为)一个猝发。因此传输类型是不连续的。
11SEQ(连续)
        在一个猝发中剩下的传输是连续传输并且地址是和前一次传输有关的。控制信息和前一次传输一样。地址等于前一次传输的地址加上传输大小(字节)。在回环突发的情况下传输地址在地址边界处回环,回环值等于传输大小乘以传输的次数(4 8 或者 16 其中之一)。
        (注:这里回环指从传输的结束地址边界跳回到传输的起始地址边界。)

         我们一直有反复提到一个词叫做猝发,这其实是应为burst的翻译,burst 传输是非常常见的,指的是一种连续传输,地址逐步递增(也有一种回环猝发:这里回环指从传输的结束地址边界跳回到传输的起始地址边界)。

五、小结

        本文中我们详细讲述了关于AHB的基本操作流程,主机要先从仲裁器获得授权,然后进行总线的访问,这样可以避免总线冲突,获得授权后,主机给出地址和控制信号,从机根据自身情况进行响应,可以分成有等待的情况和无等待的情况,这主要通过从机控制HREADY信号实现。AHB传输共分成4种类型,由主机通过HTRANS体现。在后面的文章中我们将讲述AHB的猝发传输,这也是AHB中广泛使用的一种情况。

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

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

相关文章

ChatGPT和Claude的能力全测评

创造性思维/语言 提示:“写一首 4 行诗,每行只有 3 个词,描写重庆” ChatGPT写诗👇 Claude写诗👇 仁者见仁,您怎么看谁更强? 提示: "如果你随机选择这个问题的答案,…

致敬,“编辑器之神”Vim的开发者Bram Moolenaar去世

编辑器之神Vim之父Bram Moolenaar逝世,享年62岁。其家人称,因过去几周里病情迅速恶化,Bram Moolenaar于8月3日去世。Bram的一生将大部分时间都奉献给了Vim,甚至在一个月前,他还在对Vim做着更新、修改工作。 Vim 是一个…

Air780EG —— 合宙4G定位解决方案

定位模式: 外部单片机控制模式(常见于AT固件客户): 开机 -> 搜星 -> 定位成功 -> 上报 -> 关机 780E自行控制模式(常见于二次开发客户,AT用户也可以使用): 开机 -> 搜星 -> 定位成功 -> 模块休眠,关闭GP…

css 文字排版-平铺

序: 1、表格的宽度要有!!!!! 2、容器不能是display:inline 3、扩展---》node全栈框架 代码 text-align-last: justify; width: 70px; display: inline-block; 主要是用于表单左侧文字排序!

毛利率下滑至负数,但小鹏汽车仍有信心

KlipC报道:8月18日周五,港股盘后美股盘前,小鹏汽车公布截至2023年6月30日的二季度业绩,据数据显示本季度小鹏营收50.6亿人民币,略超预期。但受G3i的存货减值及存货购买合约损失拖累,毛利率下滑至-3.9&#…

使用Xshell7控制多台服务同时安装ZK最新版集群服务

一: 环境准备: 主机名称 主机IP 节点 (集群内通讯端口|选举leader|cline端提供服务)端口 docker0 192.168.1.100 node-0 2888 | 3888 | 2181 docker1 192.168.1.101 node-1 2888 | 388…

Unity C# 引用池 ReferencePool

Unity C# 引用池 ReferencePool 1.目的 对于多次创建的数据使用new 关键字是十分消耗性能的,使用完成后由GC去自动释放,当一个类型的数据频繁创建可以使用引用池进行管理。 2.实现 项目目录 IReference 接口 要放入引用池的数据只需要继承这个接口…

管家婆中了mallox勒索病毒该怎么办?勒索病毒解密数据恢复

管家婆是很多中小企业使用的财务软件,它的性价比高、操作简单,适用行业也非常广。这也是它能够赢得众多中小企业主欢迎的原因之一。俗话说的好,木秀于林风必摧之,正是因为管家婆有着非常庞大的使用群体,所以它才成为了…

测试框架pytest教程(8)失败重试-pytest-rerunfailures

pytest-rerunfailures是一个pytest插件,用于重新运行失败的测试用例。当测试用例在第一次运行时失败,该插件会自动重新运行指定次数的失败用例,以提高稳定性和减少偶发性错误的影响。 要使用pytest-rerunfailures插件,需要按照以…

C++ 网络编程项目fastDFS分布式文件系统(四)-fastCGI项目相关技术以及linux搜狗输入法相关问题。

目录 1. Nginx作为web服务器处理请求 2. http协议复习 Get方式提交数据 Post方式提交数据 3. fastCGI 3.1 CGI 3.2 fastCGI 3.3 fastCGI和spawn-fcgi安装 1. 安装fastCGI 2. 安装spawn-fcgi 3.4 nginx && fastcgi 4其他知识点 1. fastCGI环境变量 - fas…

课程项目设计--项目建立--宿舍管理系统--springboot后端

前要 项目设计–宿舍管理系统 文章目录 项目建立导入依赖配置文件配置目录结构config配置mybatis-plusswagger 生成实体、mapper和servicebaseEntity统一响应实例响应码接口响应码接口实现统一响应result统一分页响应 项目建立 太长了,修改一下 导入依赖 暂时先加…