[总线]AMBA总线架构的发展历程

目录

引言

发展历程

第一代AMBA(AMBA 1)

第二代AMBA(AMBA 2)

第三代AMBA(AMBA 3)

第四代AMBA(AMBA 4)

第五代AMBA(AMBA 5)

AMBA协议简介

ASB(Advanced System Bus)

APB(Advanced Peripheral Bus)

AHB(AMBA High-performance Bus)

AXI(Advanced eXtensible Interface)

AHB-Lite

AXI4

AXI4-Lite

AXI4-Stream

ACE(AXI Coherency Extensions)

ACE-Lite

CHI(Coherent Hub Interface)

结语


引言

        高级微控制器总线架构(AMBA)是一种免费提供、开放的标准,用于在系统级芯片(SoC)中连接和管理功能模块。它促进了多处理器设计的一次性正确开发,支持大量控制器和外围设备。

        AMBA规范免费且平台独立,可以与任何处理器架构一起使用。由于其广泛的采用,AMBA拥有一个强大的合作伙伴生态系统,确保了来自不同设计团队和供应商的IP组件之间的兼容性和可扩展性。

        近三十年来,AMBA一直是一个基础性的开放标准,并已在数十亿设备中出货。

发展历程

第一代AMBA(AMBA 1)

  • 发布时间:1997年
  • 特点:包括ASB(Advanced System Bus)和APB(Advanced Peripheral Bus)两种总线协议。ASB作为高性能总线,支持流水线操作和多主设备操作。APB作为低速总线,满足外设与微处理器的通信需求。
  • 应用:主要应用于低带宽的外设,如UART、I2C等。

第二代AMBA(AMBA 2)

  • 发布时间:1999年
  • 特点:引入了AHB(AMBA High-performance Bus)协议,用于高性能数据传输。AHB支持burst传输和split事务处理,逐渐取代了ASB总线。
  • 应用:广泛应用于ARM7、ARM9设计中,并持续应用于Cortex-M系列设计。

第三代AMBA(AMBA 3)

  • 发布时间:2003年
  • 特点:引入了AXI(Advanced eXtensible Interface)协议,支持点对点连接,克服了共享总线协议在可连接的agent数量方面的限制。同时,AHB协议缩减为AHB-lite,APB协议增加了PREADY和PSLVERR信号。
  • 应用:AXI协议的引入是高性能系统设计的转折点,为系统性能的提升奠定了基础。

第四代AMBA(AMBA 4)

  • 发布时间:2010年
  • 特点:AXI协议得到增强,引入了QOS(Quality of Service)和long burst支持。根据应用不同,可选AXI4、AXI4-lite、AXI4-stream。同时,为满足复杂SoC的操作一致性,引入了ACE(AXI Coherency Extensions)和ACE-lite协议。
  • 应用:适应了多核处理器和一致性缓存集成的需求,推动了SoC设计的进一步发展。

第五代AMBA(AMBA 5)

  • 发布时间:2013年
  • 特点:引入了CHI(Coherent Hub Interface)协议,作为对AXI/ACE协议的重新设计。CHI是基于数据包的通信协议,支持分层通信,包括协议层、链路层和物理层的实现,并支持基于QoS的流控制和重试机制。
  • 应用:适应了HPC和数据中心市场异构计算的需求,为集成更多处理器核心、GPU、DSP、FPGAs、内存控制器和IO子系统提供了有效支持。

AMBA协议简介

ASB(Advanced System Bus)

  • 第一代AMBA协议的一部分,主要作为高性能总线,支持多主设备操作和流水线操作。

APB(Advanced Peripheral Bus)

  • 低速总线协议,设计用于连接低带宽外设,如I2C、UART等,不支持burst传输。

AHB(AMBA High-performance Bus)

  • 高性能总线协议,支持burst传输和split事务处理,适用于连接高性能处理器、RAM、NAND FLASH等。

AXI(Advanced eXtensible Interface)

  • 点对点连接协议,支持高带宽和低延迟的数据传输,适用于构建复杂的SoC设计。

AHB-Lite

  • AHB的简化版本,适用于连接不需要burst传输和split事务处理的组件。

AXI4

  • 第四代AMBA协议的一部分,增强了AXI协议,支持QOS和long burst,适用于更高性能的SoC设计。

AXI4-Lite

  • AXI4的简化版本,适用于连接不需要burst传输和乱序传输的组件。

AXI4-Stream

  • 针对以数据流为主导的传输,如视频流等应用,只支持数据从master流向slave。

ACE(AXI Coherency Extensions)

  • 针对多核处理器和一致性缓存集成的SoC设计,提供了缓存一致性管理。

ACE-Lite

  • ACE的简化版本,适用于那些没有自己的缓存但需要参与一致性域的组件。

CHI(Coherent Hub Interface)

  • 针对异构计算和高性能计算环境中的SoC设计,提供了基于数据包的通信协议,支持分层通信和QoS。

结语

        AMBA总线架构的发展历程体现了SoC设计对高性能、高带宽和低延迟通信需求的不断追求。随着技术的进步,AMBA总线将继续演进,以满足未来电子系统设计的新挑战。

参考资料:https://www.arm.com/en/architecture/system-architectures/amba

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

用 Kotlin 多平台开发构建跨平台应用程序:深入探索 KMP 模板工程

用 Kotlin 多平台开发构建跨平台应用程序:深入探索 KMP 模板工程 Kotlin 多平台开发 (KMP) 是一种强大的工具,可用于构建跨平台移动、桌面和 Web 应用程序。它提供了一种统一的代码基础,使开发人员能够高效地针对多个平台开发应用程序。 KM…

【工具】新手如何正确使用Pycharm?

1. 什么是JetBrains Toolbox JetBrains Toolbox是一个管理工具,用于安装、更新和管理JetBrains开发工具的所有版本。它可以简化多个IDE的管理,并确保你总是使用最新版本的软件。 2. 安装JetBrains Toolbox 步骤1:下载Toolbox 访问JetBrai…

演出门票小程序开发

一、实时票务信息更新的重要性 在演出票务市场,票务信息的实时性对于消费者来说至关重要。一旦票务信息出现滞后或错误,不仅可能导致消费者错过心仪的演出,还可能引发一系列不必要的纠纷和投诉。因此,演出门票小程序通过引入实时…

外汇天眼:跟单社区or资金盘 几招教你快速识别

今年有不少外汇跟单社区伙同黑平台收割投资人跑路事件,应天眼老粉要求,今天写一篇与跟单社区相关的内容,教大家如何辨别正规的外汇跟单社区与资金盘诈骗。 相信做过几年外汇的人,应该对跟单社区多少有所耳闻。但外汇跟单社区究竟…

物联网学习小记

https://www.cnblogs.com/senior-engineer/p/10045658.html GOSP: 提供类似Qt的API接口,仅需要几百KB的硬件资源(比Qt小的多),能运行在Qt不支持的低配置硬件上(对Qt生态形成补充),适用于嵌入式…

python-找第一个只出现一次的字符

[题目描述] 给定一个只包含小写字母的字符串,请你找到第一个仅出现一次的字符。如果没有,输出 no。输入: 一个字符串,长度小于 1100。输出: 输出第一个仅出现一次的字符,若没有则输出 no。样例输入1 abcabd…

数字影像产业园:打造数字经济高地,赋能未来产业

成都国际数字影像产业园凭借其得天独厚的区位优势、完善的配套设施、先进的产业定位和便捷的交通条件,逐步成为成都市乃至全国数字影像、文创、媒体产业的重要聚集地。 成都国际数字影像产业园位于成都市金牛区的核心地带,其主导产业为数字影像、文创、媒…

模型的手工下载技巧-代码自动批量下载模型文件

之前分享过通过镜像网站手工下载模型文件的技巧(见这里模型的手工下载技巧-镜像网站的使用)。但有的时候,模型文件数量较多,一个个​手工下载非常不便。比如著名的“麦橘写实”模型。 有没有什么好办法可以把整个目录都下载下来呢…

vulhub之httpd篇

Apache 换行解析漏洞(CVE-2017-15715) Apache HTTPD是一款HTTP服务器,它可以通过mod_php来运行PHP网页。其2.4.0~2.4.29版本中存在一个解析漏洞,在解析PHP时,1.php\x0A将被按照PHP后缀进行解析,导致绕过一…

中电联系列三:rocket手把手教你理解中电联协议!

分享《慧哥的充电桩开源SAAS系统,支持汽车充电桩、二轮自行车充电桩。》 前 言 T/CEC102《电动汽车充换电服务信息交换》共分为四个部分: ——第1部分:总则; ——第2部分:公共信息交换规范; ——第3部分&a…

JavaScript的数据类型(基础数据类型和数据类型转换)

天行健,君子以自强不息;地势坤,君子以厚德载物。 每个人都有惰性,但不断学习是好好生活的根本,共勉! 文章均为学习整理笔记,分享记录为主,如有错误请指正,共同学习进步。…

【初阶数据结构】深入解析顺序表:探索底层逻辑

🔥引言 本篇将深入解析顺序表:探索底层逻辑,理解底层是如何实现并了解该接口实现的优缺点,以便于我们在编写程序灵活地使用该数据结构。 🌈个人主页:是店小二呀 🌈C语言笔记专栏:C语言笔记 &…

java:使用JSqlParser给sql语句增加tenant_id和deleted条件

# 示例代码 【pom.xml】 <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-core</artifactId><version>3.4.3.1</version> </dependency>【MyJSqlParserTest.java】 package com.chz.myJSqlParser;pu…

如何利用 Google 搜索结果页来引导?

在数据驱动的决策世界中&#xff0c;获取准确而全面的信息至关重要。Google 搜索结果抓取是一种强大的技术&#xff0c;可以让企业、调查人员和研究人员从搜索引擎结果中提取可靠的数据。本综合指南将深入研究 Google 搜索结果的最佳实践、工具和道德考量&#xff0c;以确定能够…

4、视觉里程计:特征点法、直接法和半直接法

先说一下我自己的总体理解&#xff1a; 特征点法&#xff0c;基于最小化重投影误。 提取特征点&#xff0c;计算描述子&#xff0c;匹配&#xff0c;运动估计。 计算描述子和匹配部分可以用光流法跟踪替代 总体上先知道像素之间的关系&#xff0c;在估计运动&#xff08;最…

铝合金板件加工迎来3D视觉新时代

在制造业的浩瀚星空中&#xff0c;铝合金板件加工一直以其轻质、高强度、耐腐蚀的特性&#xff0c;扮演着举足轻重的角色。然而&#xff0c;随着市场竞争的加剧和产品需求的多样化&#xff0c;传统的加工方式已难以满足现代制造业对高效率、高精度的追求。在这个关键时刻&#…

详细教学wps中公式如何居中,公式编号如何右对齐

废话少说&#xff0c;首先打开WPS&#xff0c;新建一个空白文档。 详细步骤如下&#xff1a; &#xff08;1&#xff09;新建一个模板样式&#xff0c;在开始一栏中&#xff0c;点击新建样式具体操作看下图&#xff1a; &#xff08;2&#xff09;设计样式 修改样式名称为公…

2024年制作AI问答机器人给企业带来的几大好处

引言 在当今数字化时代&#xff0c;企业需要不断寻求创新&#xff0c;以提升客户服务水平、降低成本&#xff0c;并改善用户体验。其中&#xff0c;AI问答机器人作为一种智能化解决方案&#xff0c;正在成为越来越多企业的首选。本文将探讨制作AI问答机器人给企业内外部带来的…

期权交易单位是什么?期权懂新手必看!

今天带你了解期权交易单位是什么&#xff1f;很多对期权还不太熟悉的朋友&#xff0c;不知道期权的单位是什么&#xff0c;下面小编就来告诉你期权的交易单位到底是什么&#xff1f; 期权交易单位是什么&#xff1f; 50ETF期权的交易单位&#xff0c;用大白话来说&#xff0c;…

5.2 模块之间的交互和通信方式方法总结

事件驱动通信&#xff1a; 事件驱动通信是一种通信模式&#xff0c;它基于事件的发生和相应来进行通信。在事件驱动通信中&#xff0c;各个组件之间通过发送事件来进行通信&#xff0c;而不是直接调用对方的方法。 事件驱动通信的基本原理是&#xff0c;当一个组件发生某个特…