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

这篇具有很好参考价值的文章主要介绍了AMBA总线协议(4)——AHB(二)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

系列文章合集: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、简单传输        

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

AMBA总线协议(4)——AHB(二),AMBA总线协议,fpga开发,arm开发,fpga,硬件架构,arm

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

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

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

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

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

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

2、带有等待的传输

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

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

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

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

AMBA总线协议(4)——AHB(二),AMBA总线协议,fpga开发,arm开发,fpga,硬件架构,arm

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

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

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

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

3、多重传输

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

AMBA总线协议(4)——AHB(二),AMBA总线协议,fpga开发,arm开发,fpga,硬件架构,arm

        (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中广泛使用的一种情况。文章来源地址https://www.toymoban.com/news/detail-662546.html

到了这里,关于AMBA总线协议(4)——AHB(二)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • AMBA总线协议(8)——AHB(六):分割传输

            在之前的文章中,我们重点介绍了AHB传输的仲裁,首先介绍了仲裁相关的信号,然后分别介绍了请求总线访问,授权总线访问,猝发提前终止,锁定传输和默认主机总线,在本文中我们将继续介绍AHB的分割传输。 系列文章合集:AMBA总线协议(0)——目录与传送门

    2024年02月11日
    浏览(27)
  • FPGA-AMBA协议、APB协议、AHB规范、AXI4协议规范概述及它们之间的关系

    笔记记录,AMBA协议、APB协议、AHB规范、AXI4协议规范概述,只是概述描述,具体详细的协议地址传输、数据传输等内容将在下一章节详细说明。 AMBA(Advanced Microcontroller Bus Architecture)是一种由ARM公司提出的处理器总线架构,它定义了处理器、内存和外设之间的通信标准 。

    2024年02月04日
    浏览(28)
  • 基于 VPX 总线的工件台运动控制系统研究与开发-DSP+FPGA硬件架构(一)

    作为光刻机核心单元之一,超精密工件台主要负责实现快速扫描、上下片、精密定位、调平调焦等功能。目前,较为成熟的方案大多采用 VME 并行总线架构来建立超精密工件台控制系统,由于随着系统性能要求的提升,VME 总线以及相应的处理器已无法满足需求,所以必须设计

    2024年02月03日
    浏览(29)
  • <AMBA总线篇> AXI总线协议介绍

    目录 01 AXI协议简介 AXI协议特性 AXI协议传输特性 02 AXI协议架构 AXI协议架构 write transaction(写传输) read tramsaction(读传输) Interface and interconnect 典型的AXI系统拓扑 03 文章总结 大家好,这里是程序员 杰克 。一名平平无奇的嵌入式软件工程师。 对于学习Xilinx FPGA(ZYNQ)而言,官方提

    2024年02月10日
    浏览(30)
  • AMBA总线协议AXI——学习笔记

    2023.3.25 2023.4.23 AXI :高级可拓展接口 高性能、高带宽、低延迟 单向通道体系结构 独立的地址和数据通道 支持多项数据交换。通过 并行执行burst操作 ,极大地提高了数据吞吐能力。 AXI4 :高性能内存映射需求(如读写DDR、使用BRAM控制器读写BRAM等),为了区别,有时候也叫这

    2023年04月23日
    浏览(34)
  • 【ARM AMBA5 CHI 入门 12 -- CHI 总线学习 】

    请阅读 【ARM AMBA 总线 文章专栏导读】

    2024年02月10日
    浏览(38)
  • 【数字IC精品文章收录】近500篇文章|学习路线|基础知识|接口|总线|脚本语言|芯片求职|安全|EDA|工具|低功耗设计|Verilog|低功耗|STA|设计|验证|FPGA|架构|AMBA|书籍|

    1.1 索引目的 本篇索引旨在 收藏CSDN全站中有关数字IC领域高价值文章 ,在数字芯片领域中,就算将架构,设计,验证,DFT,后端诸多岗位加在一起的数量,都不及软件类一个细分方向的岗位数量多,反映在社区氛围或是开源资料的丰富度而言,数字IC领域相较于软件/互联网领

    2024年02月03日
    浏览(108)
  • 【ARM AMBA AXI 入门 11 - AXI 总线 AWCACHE 和 ARCACHE 介绍】

    请阅读 【ARM AMBA AXI 总线 文章专栏导读】 转自:https:

    2024年02月09日
    浏览(40)
  • 「FPGA项目」—— 基于AMBA总线的流水灯控制系统

    本文将介绍一个完全用Verilog HDL手写的AMBA片上系统, 项目的主题是设计一个 基于AMBA总线的流水灯控制系统 , 项目中所有数字逻辑电路部分都不会通过调用成熟IP核的方式来实现,而是通过Verilog进行RTL设计, 然后利用Vivado平台对RTL模型进行仿真、综合与布线, 最后在FPGA开

    2023年04月25日
    浏览(36)
  • 【ARM AMBA AXI 入门 9 - AXI 总线 AxPROT 与安全之间的关系 】

    请阅读 【ARM AMBA AXI 总线 文章专栏导读】 上篇文章:ARM AMBA AXI 入门 8 - AXI 协议中 RID/ARID/AWID/WID 信号 ARMv8 架构中的AXI(Advanced eXtensible Interface)总线与NS(Non-Secure)位密切相关。NS位是指在ARM TrustZone安全扩展中定义的一种状态,用于区分安全和非安全的处理器执行环境。AXI总

    2024年02月11日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包