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

相关文章

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines

【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报文通常包含以下部分: 地址域:单个字节,表示从站设备