AMBA-APB协议

2024-01-02 20:58
文章标签 协议 amba apb

本文主要是介绍AMBA-APB协议,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 简介
  • 传输时序
  • Signal Descriptions
  • Transfers
    • Write transfer with no wait states
    • Write transfer with wait states
    • Read transfer with no wait states
    • Read transfer with wait states
    • Example failing write transfer
    • Example failing read transfer

简介

APB主要用在低速且低功率的外围,可针对外围设备做功率消耗及复杂接口的最佳化。APB在AHB和低带宽的外围设备之间提供了通信的桥梁,所以APB是AHB的二级拓展总线。

  1. 它的架构不像AHB总线是多主设备的架构,主要应用在低带宽的外设上,如UART、I2C。
  2. APB总线的唯一主设备是APB桥(与AXI或APB相连),因此不需要仲裁一些request/grant信号。
  3. APB的协议十分简单,甚至不是流水的操作,固定两个时钟周期完成一次读或写的操作,支持最大32-bit的数据位宽。。
  4. 其特性包括:两个时钟周期传输,无需等待周期和回应信号,控制逻辑简单,只有四个控制信号。由于APB的两个通道没有自己的握手信号,因此两个通道不会同时使用,即不支持读写并行操作 。
    在这里插入图片描述

传输时序

在这里插入图片描述

从状态机看,APB 对每一笔数据的传送,均需花2 个周期的时间,且APB 的数据传递不适用在有流水线架构的模块设计中。

在这里插入图片描述

Signal Descriptions

在这里插入图片描述

  • APB协议有两个独立的数据总线,一个用于读数据,一个用于写数据。总线可达32位宽。由于总线没有各自的握手信号,因此数据传输不可能同时发生在两个总线上。
  • PREADY和PSLVERR两个信号是在APB3版本中添加的。
  • PPORT和PSTRB两个信号是在APB4版本中添加的。

Transfers

Write transfer with no wait states

在这里插入图片描述

  • 在T1,一个写传输开始,地址PADDR,写数据PWDATA,写信号PWRITE,选择信号PSEL,在PCLK上升沿注册。这称为写传输的设置阶段。
  • 在T2处,PCLK上升沿登记使能信号PENABLE和准备信号PREADY。
  • 当断言时,PENABLE表示传输的Access阶段的开始。PREADY表示slave可以在PCLK的下一个上升沿完成传输。
  • 地址PADDR、写数据PWDATA和控制信号都保持有效,直到传输在T3完成,即Access阶段的结束。
  • 使能信号PENABLE在传输结束时拉低。所选择的信号PSEL也拉低,除非传输是紧随其后的另一个传输到同一外设。

Write transfer with wait states

在这里插入图片描述

  • 当Access阶段开始时,如果PENABLE拉高时,PREADY为低,那么传输会一直等待,直到PREADY拉高为止。
  • 当PREADY保持低位时,以下信号应保持不变:PADDR,PWRITE,PSEL,PENABLE,PWDATA,PSTRB,PPROT。
  • 当PENABLE拉低时,PREADY可以取任何值。
  • 建议地址和写信号在传输后不要立即改变,而是保持稳定,直到另一个访问发生。这样可以降低功耗。

Read transfer with no wait states

在这里插入图片描述

  • 类似于写操作,当PENABLE拉高进入ACCESS状态时,如果PREADY保持为高,传输会立即进行,在一个时钟周期内完成传输。

Read transfer with wait states

在这里插入图片描述

  • 类似于写操作,如果PENABLE拉高时,PREADY为低,那么传输会一直等待,直到PREADY拉高为止。
  • 当PREADY保持低位时,以下信号应保持不变: PADDR, PWRITE, PSEL, PENABLE, PPROT。

Example failing write transfer

在这里插入图片描述

  • 可以使用PSLVERR来指示APB传输中的错误条件。在读和写操作上都可能发生错误条件。当PSEL、PENABLE和PREADY都为高时,PSLVERR仅在APB传输的最后一个周期被认为是有效的。
  • 建议在不采样时将PSLVERR拉低。

Example failing read transfer

在这里插入图片描述

  • 读操作也可能在完成时出现错误响应,表示没有有效的读数据可用。

这篇关于AMBA-APB协议的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/563630

相关文章

【Linux】应用层http协议

一、HTTP协议 1.1 简要介绍一下HTTP        我们在网络的应用层中可以自己定义协议,但是,已经有大佬定义了一些现成的,非常好用的应用层协议,供我们直接使用,HTTP(超文本传输协议)就是其中之一。        在互联网世界中,HTTP(超文本传输协议)是一个至关重要的协议,他定义了客户端(如浏览器)与服务器之间如何进行通信,以交换或者传输超文本(比如HTML文档)。

【Go】go连接clickhouse使用TCP协议

离开你是傻是对是错 是看破是软弱 这结果是爱是恨或者是什么 如果是种解脱 怎么会还有眷恋在我心窝 那么爱你为什么                      🎵 黄品源/莫文蔚《那么爱你为什么》 package mainimport ("context""fmt""log""time""github.com/ClickHouse/clickhouse-go/v2")func main(

2024.9.8 TCP/IP协议学习笔记

1.所谓的层就是数据交换的深度,电脑点对点就是单层,物理层,加上集线器还是物理层,加上交换机就变成链路层了,有地址表,路由器就到了第三层网络层,每个端口都有一个mac地址 2.A 给 C 发数据包,怎么知道是否要通过路由器转发呢?答案:子网 3.将源 IP 与目的 IP 分别同这个子网掩码进行与运算****,相等则是在一个子网,不相等就是在不同子网 4.A 如何知道,哪个设备是路由器?答案:在 A

Modbus-RTU协议

一、协议概述 Modbus-RTU(Remote Terminal Unit)是一种基于主从架构的通信协议,采用二进制数据表示,消息中的每个8位字节含有两个4位十六进制字符。它主要通过RS-485、RS-232、RS-422等物理接口实现数据的传输,传输距离远、抗干扰能力强、通信效率高。 二、报文结构 一个标准的Modbus-RTU报文通常包含以下部分: 地址域:单个字节,表示从站设备

网络原理之TCP协议(万字详解!!!)

目录 前言 TCP协议段格式 TCP协议相关特性 1.确认应答 2.超时重传 3.连接管理(三次握手、四次挥手) 三次握手(建立TCP连接) 四次挥手(断开连接)  4.滑动窗口 5.流量控制 6.拥塞控制 7.延迟应答 8.捎带应答  9.基于字节流 10.异常情况的处理 小结  前言 在前面,我们已经讲解了有关UDP协议的相关知识,但是在传输层,还有

DNS协议基础笔记

1.定义 DNS(Domain Name System,域名系统)是互联网的一项核心服务,它作为将域名和 IP 地址相互映射的一个分布式数据库,能够使人更方便地访问互联网。 2.域名解析过程 当用户在浏览器中输入一个域名,浏览器首先会检查自己的缓存中是否有该域名对应的 IP 地址。本地 DNS 服务器收到查询请求后,首先会检查自己的缓存中是否有该域名对应的 IP 地址。根域名服务器收到查询请

4G模块、WIFI模块、NBIOT模块通过AT指令连接华为云物联网服务器(MQTT协议)

MQTT协议概述 MQTT(Message Queuing Telemetry Transport)是一种轻量级的消息传输协议,它被设计用来提供一对多的消息分发和应用之间的通讯,尤其适用于远程位置的设备和高延迟或低带宽的网络。MQTT协议基于客户端-服务器架构,客户端可以订阅任意数量的主题,并可以发布消息到这些主题。服务器(通常称为MQTT Broker)则负责接受来自客户端的连接请求,并转发消

HTTP协议 HTTPS协议 MQTT协议介绍

目录 一.HTTP协议 1. HTTP 协议介绍 基本介绍: 协议:  注意: 2. HTTP 协议的工作过程 基础术语: 客户端: 主动发起网络请求的一端 服务器: 被动接收网络请求的一端 请求: 客户端给服务器发送的数据 响应: 服务器给客户端返回的数据 HTTP 协议的重要特点: 一发一收,一问一答 注意: 网络编程中,除了一发一收之外,还有其它的模式 二.HTT

CAMediaTiming协议

今天看下下CALayer这个类,里面的属性是实现CAMediaTiming这个协议的,这里简单介绍一下CAMediaTiming协议里面的属性。官网链接 如下 beginTime:开始时间(和父类相关) timeOffset:动态的本地时间t,tp是父类事件。t = (tp - begin) * speed + offset.用于暂停一个layer。  fillMode:layer完成后的

浏览器工作原理(3)-TCP协议文件如何从服务器到浏览器

浏览器工作原理-TCP协议,文件如何从服务器到浏览器 本周继续学习浏览器工作原理及实践,本次内容来看一下TCP协议确保文件完整的送到至浏览器 First Page 是指页面加载到首次开始绘制的时长,而影响这个性能指标的一个重要原因是网络加载速度,网络传输协议无论使用http还是websocket,都是基于TCP/IP的,所以有必要了解一下TCP/IP,对于web的性能调优和问题定位都有很