AHB总线介绍

AHB(Advanced High Performance Bus)高级高性能总线,如同USB(Universal Serial Bus)一样,也是一种总线接口。

在这里插入图片描述

AHB主要用于高性能模块(如CPU、DMA和DSP等)之间的连接,作为SoC的片上系统总线,它包括以下特性:支持突发传输;支持分段传输;支持多个主控制器;可配置32位~128位总线宽度;支持字节、半字和字的传输。AHB 系统由主模块从模块和基础结构(Infrastructure)3部分组成,整个AHB总线上的传输都由主模块发出,由从模块负责回应。基础结构则由仲裁器(arbiter)、主模块到从模块的多路器、从模块到主模块的多路器、译码器(decoder)等。

本文主要介绍AHB总线的简化本本AHB-lite总线,相对于AHB总线的区别是他只有一个主机,结构相对AHB总线要简单一些,在很多实际应用中实际上也只有一个Master,因此可以简化设计。

AHB总线的结构如下:

在这里插入图片描述
当主机需要对从机进行操作时,首先会根据地址进行译码,选择要操作的从机,将SEL信号给到对应的从机。对于从机来说,只有当输入的片选信号有效时,才能够进行后续的一些操作。

AHB总线的信号
信号名位宽方向
(对于CPU)
说明
clk1IN总线时钟
rst_n1IN总线复位
Trans2OUT传输方式控制

0:总线空闲
1:总线忙
2:只传输一个数据
3:连续传输数据
Size3OUT数据大小控制
0:每次传输1字节
1:每次传输2字节
2:每次传输4字节
3:每次传输8字节
4:每次传输16字节
5:每次传输32字节
6:每次传输64字节
7:每次传输128字节
write1OUT传输方向控制
0:CPU读取设备
1:CPU像设备写数据
Port4OUT数据保护策略
bit0:表示传输数据类型。为0表示传输指令,为1表示传输数据;
bit1:表示数据权限。为0时表示使用普通用户权限,为1时表示使用特权;
bit2:是否允许数据被Buffer存储和延迟。为0时表示不允许,为1表示允许;
bit3:是否允许数据被Cache缓存,为0时表示不允许,为1表示允许。
Burst3OUTBurst传输策略。
0:只传一个数据;
1:不定长的Burst传输;
2:4次连续传输;
3:8次连续传输;
4:16次连续传输;
5:4次连续WRAP传输;
6:8次连续WRAP传输;
7:16次连续WRAP传输;
addr32OUT读写操作地址
wdata32OUT写数据
rdata32IN读数据
HRESP1IN设备状态反馈
0:传输成功;
1:传输中出现错误
HREADY1IN全部设备状态反馈。
0:总线上有设备在忙,需等到空闲时才能进行传输;
1:所有设备空闲

HSIZE指的是一次传输的数据宽度,而AHB读写数据线的宽度只有32位,因此其HSIZE只会出现0、1、2。

反馈信号HRESP 指的是设备是否处于错误状态,当传输中出现错误即HRESP为1时,表示设备无法满足CPU对其的读写要求,可能出现设备错误导致读写操作无法进行,亦或是设备的处理速度慢,读写存在一定的延时。

反馈信号HREADYOUT是设备内部有一定读写时延时来向CPU反馈的信号,当其 为1时表示总线上的所有设备都是空闲的,此时可以正常进行操作;当其为0时表示总线上有设备正在忙,无法写入数据,只有等待其为1时才能将上次要写入的数据写入设备。而HREADY信号是所有从机HREADYOUT信号相与后的结果

读写时序

AHB总线的读写时序分为两拍完成,分别成为地址阶段和数据阶段,其时序图如下:

在这里插入图片描述

在地址阶段,将所有的控制信号都给出,以便使设备能够获取必要的传输信息,主要包括地址等;

在数据阶段,如果为写数据,则主机将会在地址出现的下一拍将数据信号送到总线上;如果为读数据,那么被读设备将会在地址的下一拍将读地址对应的数据传输到总线上。 数据的传输是按照流水线的方式,也就是说在本轮地址给出的下一拍,下一轮的地址便可紧接着给出,此时也正是第一轮的数据被给出的时候。

上面的时序图是在反馈信号HREADY信号一直为1的情况下,当某个设备反应速度较慢并不能在下一拍立刻完成读写时,从机会将自己的HREADYOUT信号拉低,对于主机的HREADY信号也将同时变低,本次读写将不能正常进行,直至这个从机的HREADYOUT信号拉高,才能进行正常写入,时序图如下:

在这里插入图片描述

当传输发生错误时,操作地址对应设备的HRESP信号会拉高,此时的传输时序图如下:

在这里插入图片描述

AHB总线的优点

优点:

  1. 高性能:AHB总线采用分段和流水线设计,可实现高带宽、低延迟的数据传输,适用于高性能系统。
  2. 可扩展性:AHB总线允许多个主设备和多个从设备同时连接,通过地址映射和优先级控制实现对不同设备的访问管理,提供了灵活的系统扩展性。
  3. 多设备支持:通过优化的仲裁方案和属性控制线,AHB总线可以同时支持多个主设备和多个从设备,实现对系统资源的共享和并行访问。
  4. 可靠性和容错性:AHB总线支持错误检测和纠正机制,可以通过错误检查位和冗余数据传输进行数据完整性的验证和故障容错。

缺点:

  1. 复杂性:AHB总线的设计较为复杂,包括仲裁、地址映射、优先级控制等方面,需要相应的硬件和软件支持,并且需要清晰的总线协议来确保正确的通信。
  2. 功耗:AHB总线的高性能和复杂性可能会导致相对较高的功耗,特别是在高频率和大数据传输的情况下。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值