AMBA:AXI/AHB/APB学习笔记

news2025/1/22 17:45:55

AMBA、AXI、AHB、APB学习笔记

  • AMBA总线:各模块之间的连接
  • AHB
    • 特性:
    • 组成部分:
  • AXI
  • APB

AMBA总线:各模块之间的连接

advanced microcontroller bus architecture高级微控制器总线架构
在这里插入图片描述

AHB

Advanced High-performance Bus 高级高性能总线

AHB总线用于高性能,高时钟工作频率模块。AHB在AMBA架构中为系统的高性能运行起到了基石作用。AHB为高性能处理器,片上内存,片外内存提供接口,同时桥接慢速外设。高速总线,高性能,数据传输,
多总线主设备控制器,(最多16个)
burst传输(一串数据,效率更高),分步传输。
支持多种高性能总线主控制器

特性:

a 突发连续传输
b 分步传输
c 支持多个主控制器、单周期内主控制器处理
d 单时钟边沿操作
e 非三态操作
f 支持8bits,16位,32位,64位,128位总线带宽
g 支持字节,半字节和字的传输。
h 二级流水线pipeline操作(一个地址周期,一个数据周期)
i 上升沿触发操作
j 会造成性能瓶颈

APB能干的AHB都能干,但是AHB能干的APB不一定能干。新设计一般用AHB。

AHB总线通过DMA和DSP,允许在总线上存在一个或多个主控制器。虽然APB总线上可以挂接慢速外设,但是也允许在AHB上挂接一些慢速外设作为从设备,不过它们通常还是挂接在APB总线上。

AHB总线通常设计时包含以下几个设备:

组成部分:

a AHB主控制器master:主控制器可以通过地址和控制信息,可以进行初始化,读,写操作。在同一时间,总线上只能有一个主控制器。初始化一次读/写操作(发起人)。
CPU、DMA、DSP、LCDC可以作为master。产生地址、数据,获取读的数据。
b AHB从设备slave:从设备通常是指在其地址空间内,响应主控制器发出的读写控制操作的被动设备。通过操作的成功与否反馈给其主控制器,完成数据的传输控制。每个slave都有地址的map。通过地址映射来选择使用哪个从设备。Slave=HSEL(必要条件)&hready
包括有外部存储器控制器EMI,APB bridge、、

c AHB仲裁器arbiter:仲裁器根据用户的配置,确保在总线上同一时间只允许有一个主控制器拥有总线控制权限。AHB总线上只能有一个仲裁器。在AMBA协议中没有定义仲裁算法(排序)。对master请求做仲裁,选择master行为发送到slave。
Master发送一个request信号给arbiter,arbiter同意会发送一个GNT,才可以使用总线。

d AHB译码器decoder:译码器解析在总线上传输的地址和控制信息。AHB总线上只能有一个译码器。通过地址译码来决定选择哪一个从设备
在这里插入图片描述
HRSETn加n 表示低电平有效。等于0的时候reset,等于1的时候不会reset。
HADDR[31:0] 32位系统地址总线
HWDATA[31:0] 写数据总线,从主设备写到从设备。一次写4个byte。0 4 8 C
HTRANS是指当前传输的状态:NONSEQ(开始新的写或读,和之前的地址无关)、SEQ(和之前的地址连续)、IDLE、BUSY(addr data是无效的)
HWRITE=1是写,=0是read
HSIZE[2:0]是bus width传输的大小,000的时候是8bits,001是16bits,010是32bits
有多少个slave就有多少个HSELx(选中的那个拉高,其他的不会拉高)
HSEL:由AHB decoder通过地址映射给出。相当于查找表
HRESP(slave output)从设备发送给主设备的总线传输状态:OKAY、ERROR、RETRY(不影响master优先级)、SPLIT(arbiter把master的优先级降低)
HREADY 高电平:从设备指出传输结束,低:从设备需延长传输周期。最多等待16个cycle。短时间无法响应就拉低,长时间无法响应发送retry。
HBURST[2:0]共有八种类型。0的话一次只传输一个,可以地址累加的运行,效率更高
=0:SINGLE,=1:INCR地址累加(看hsize是多少,若hsize=2,每次传输4个byte,上一次的传输地址+4;若hsize=0,每次传输1个byte,地址+1),INCR 4 beat指的是累加4次byte该burst结束,INCR 8 beat,INCR 16 beat。Wrapping回环:如果起始地址是倍数,可以整除,和INCR没有区别。如4beat的4byte,16byte=0x10,碰到0x10的倍数就要回弹。
Burst传输不能超过1kb(1x210,10 000 000 000;0x400)的边界。在1k的边界重启一次burst,HTRANS为NONSEQ模式。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
Retry不影响优先级(轮流的策略)。
在这里插入图片描述
三态0,1,Z
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
每个Master都有一个HBUSREQx,有几个Master就有几个HBUSREQ。
HLOCKx直到做完这次传输再放开。
每个HGRANTx对应一个HBUSREQx,如果某一个master发了HBUSRE后,又HGRANT回来了,才可以把总线拿到手,去控制总线。
HMASTER指现在正在操作的是哪一个总线。最多16个master
HMASTLOCK表示同意master发出的HLOCK信号,同意锁定总线,直到传输完成。
HSPLITx的x表示用的哪一个slave,[15:0]16bit表示master。假设x=2,表示slave 2发出,假设[15:0]=2,0…010代表master1,master1来要求slave2响应命令,这次split掉,影响了master1的优先级。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
通过5个寄存器就能控制DMA。
Dma也可以做master帮助cpu做数据搬移,cpu剩下的时间可以做更复杂的运算。别的IP都是做slave。 地址=base_addr + offset(基地址加偏移)
在这里插入图片描述
在这里插入图片描述
查询模式的工作原理

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

AXI

只需要首地址,传输地址和数据都保持valid和ready同时为高时有效。
为AMBA3.0
ACLK全局时钟信号,ARESETn全局复位信号,低电平有效
五个channel:写地址,写数据,写响应,读地址,读数据
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
设备可以在ARVALID出现的时候再给出ARREADY信号,也可以先给出ARREADY信号,再等待ARVALID信号。
但是设备必须等待ARVALID和ARREADY信号都有效才能给出RVALID信号,开始数据传输。
在这里插入图片描述
等待信号AWVALID或WVALID信号有效或者两个信号都有效之后再给出AWREADY/WREADY信号。

读数据必须总是跟在与其数据相关联的地址之后,写响应必须在跟其相关联的写事务的最后出现。

AXI总线介绍:https://max.book118.com/html/2017/0526/109191708.shtm

APB

1.低速总线,低功耗(clock慢了翻转少了),
2.接口简单,
3.在bridge中锁存地址信号和控制信号(缓存一下再转换发出来,转换成APB的master型号发出)
4.适用于多种外设
5.上升沿触发

组成部分:
1.AHB2APB Bridge
可以锁存所有的地址、数据和控制信号。
进行二级译码来产生APB从设备选择信号。
2.APB总线上的所有其他模块都是APB从设备 APB Slave
作为AHB的slave,在APB这端的话做master

E课网:
如果A发出一个Valid,能收到的话B回复ready,将其拉高。不能收到将ready拉低。只有valid和ready同时拉高数据才能有效传输。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
AHB给出一个地址,一级一级往下找。二级译码
在这里插入图片描述
PENABLE比PSEL晚一拍拉高。APB最快每2个cycle才能读/写一个数据。将大范围的地址翻译成小范围的地址,将AHB的时序转换为APB的时序,同时产生PSEL信号,对读的data做一个选择到HRDATA上去。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
HREADY = PSEL & PENABLE
在这里插入图片描述
基于CPU读取APB上外设的寄存器需要3个周期,对于AHB上的slave需要2个周期。
HREADY读就是为低,写就是为高。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
CPU接受到中断信号,等有空去看IP的状态寄存器,才能看到是什么请求。作为slave不能直接给cpu写数据,只能写中断让CPU主动读slave
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

微信小程序|搭建一个博客小程序

文章目录一、文章前言二、创建小程序三、功能开发(1)首页(2)领域页(3)博客详情页(4)个人中心页一、文章前言 此文主要通过小程序搭建一个博客系统,实现博客的一些基础功能…

AD环境下域用户的离线缓存登录

缓存登录主要是为了解决当公司域控制器发生故障联系不上DC或用户拿笔记本电脑回家不拔VPN的情况下,依然能够登录到系统,进行办公。如果用户登录的时候联系不到DC,那么就凭用户登录时输入的用户名和密码去缓存中校验,如果能联系上D…

如果在学习spring的时候没看过这份学习笔记+源码剖析,真的亏大了!

Spring 是一个开源的设计层面框架,它解决的是业务逻辑层和其他各层的松耦合问题,因此它将面向接口的编程思想贯穿整个系统应用。包括在此基础上衍生的 Spring MVC、 Spring Boot 、Spring Cloud 等,在现在企业中的应用越来越广泛。因此对于 S…

YOLOv7移植经验分享

目录 一、背景 二、环境 2.1 服务器环境 2.2 SDK环境 2.3 docker环境 三、移植开发 3.1 模型迁移 3.2 算法迁移 四、部署 一、背景 YOLOv7在 5 FPS 到 160 FPS 范围内的速度和准确度都超过了所有已知的目标检测器,并且在 GPU V100 上 30 FPS 或更高的所有…

python基于OCR深度学习实现商品配料表识别

1、概述 当前人民和国家对食品安全十分重视,但商家为了保证食品长时间储存,味道鲜美,在食品中添加超量或对人有严重危害得食品添加剂,严重危害到人民的安全,我们以方便面为例,一包方便面最多可有25种食品添…

十年开发老手,深度解析企业用人标准为何越来越高?!

涛哥作为一个10多年的开发老手,经历过很多场面试,也面试过很多人,这么多年下来,切身体会到企业的用人标准越来越高,企业对开发工程师的要求也越来越"过分"。所以涛哥今天就借此机会,我们一起来分…

如何制定有效的项目计划,提高团队执行力

项目风险来源有很多,项目日程紧张,导致质量下降风险上升;甲方变更,管理者对变动控制不足;项目太大。 虽然从来不可能完全消除项目风险,但可以将危害减到最小。 一、确认项目计划 项目计划是一个项目启动…

SpringBoot读取properties中配置的List集合

实体类 Data NoArgsConstructor AllArgsConstructor Accessors(chain true) public class Person {private String name;private String age;private String content; } Component//将该类交由Spring管理 ConfigurationProperties(prefix "project") //自定义.pro…

【附源码】计算机毕业设计JAVA演唱会购票系统

【附源码】计算机毕业设计JAVA演唱会购票系统 目运行 环境项配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: JAVA myba…

听我一句劝好吗?放下那些老掉牙的性能优化笔记吧!又不是没有新的,跟不上时代的学了也没法直接用呀!

性能概述 公司投入人力物力成本开发出的程序,如果出现程序瘫痪、界面停顿、抖动、响应迟缓等问题,会大大降低用户体验,损失大量用户。对于上述问题,都是需要性能调优来解决的问题。 程序性能主要表现在代码的执行速度、软件系统…

数据结构之快速排序(重点)

快速排序 算法所需 一个基准点 左边是比其小的数,右边是比其大的数 先使所指的元素作为基准元素low 用一个piviot存储49 然后进行比遍历操作 就是high向左移动(high–),到第一个比piviot小的元素进行一个data[low]data[high] 然后进行low,找…

基于最低水平面的三维装箱问题的启发式算法

⭐️ 前言 小编之前写过一篇博文:求解三维装箱问题的启发式深度优先搜索算法(python),详述了基于空间选择的三维装箱算法。本文考虑了一个事实:在某些情况下,我们在摆放物品时,总是优先选择较低的平面,基于…

LIN通讯

LIN通讯 一、LIN通讯的背景与意义 随着汽车电子的发展,汽车上的电子零件正在逐渐地增加。而电子零件的增加也导致更多的设备(传感器、执行器、电子控制器)需要加入汽车的局部网络,这些零件的增加还会带来配线的增加,…

java-springboot基于机器学习得心脏病预测系统 的设计与实现-计算机毕业设计

项目介绍 基于机器学习得心脏病预测系统通过对机器学习心脏病数据大数据分析统计系统的建设以实现机器学习心脏病数据分析统计功能。通过对心脏疾病变化市场的充分研究,结合自身技术储备情况,设计并开发了一套基于SpringBoot后台框架、Mybaits数据库映射…

web课程设计网页规划与设计---公司网站(5页 带下拉菜单)

⛵ 源码获取 文末联系 ✈ Web前端开发技术 描述 网页设计题材,DIVCSS 布局制作,HTMLCSS网页设计期末课程大作业 | 公司官网网站 | 企业官网 | 酒店官网 | 等网站的设计与制 | HTML期末大学生网页设计作业,Web大学生网页 HTML:结构 CSS&#…

动态规划算法学习二:最长公共子序列

文章目录前言一、问题描述二、DP实现1、最优子结构性质*****2、状态表示*****3、状态递归方程*****4、计算最优值*****5、代码实现:输出最长公共子序列6、代码实现:输出最优解前言 一、问题描述 列举X的所有子序列,然后检查它是否也是Y的子序…

Java设计模式很难吗,这篇带你熟悉设计模式

3.1 概述 可以发现,设计模式好像都是类似的。越看越感觉都着不多。其实都是类似面向接口编程的一种体现,只不过侧重点不一样或者说要体现的结果不一样。 3.2 使用场景 问题一:应对可能变化的对象实现 方案:间接创建 模式&…

pycharm远程连接服务器

遇到的问题: 在服务器上配环境 流程: 先安装anaconda(去其官网下载个脚本文件到服务器上,然后启动脚本即可) bash Anaconda3-5.3.1-Linux-x86_64.sh然后创建 python环境 conda create -n pytorch python3.10去pyt…

【Linux】搞懂进程地址空间

文章目录1、从程序地址空间开始1.1 在C/C中看到的地址实际是?1.2 感性理解虚拟地址空间2、进程地址空间2.1 进程地址空间是怎样被描述的?2.2 进程地址空间和内存的关系2.3 为什么需要进程地址空间?1、从程序地址空间开始 1.1 在C/C中看到的地…

并发:线程状态

java的线程状态分为六种 新建 NEW 当一个线程对象被创建,但是还没有调用start方法时处于新建状态 此时未与操作系统底层线程关联 可运行 RUNNABLE 调用了start方法,就会由新建进入可运行状态 此时与底层线程关联,由操作系统调度执行 &…