系列文章合集:AMBA总线协议(0)——目录与传送门

目录

一、前言

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

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

五、小结

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