ZYNQ MicroBlaze AXI总线连接注意事项

2024-03-14 18:20

本文主要是介绍ZYNQ MicroBlaze AXI总线连接注意事项,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

 

一、AMBA总线协议概述

1.ASB

2.AHB

3.APB

4.AXI

(1)AXI4

(2)AXI4-Lite

(3)AXI4-Stream

二、ZYNQ MicroBlaze连接AXI总线注意事项

三、解决方法


一、AMBA总线协议概述

AMBA是指先进的微控制器总线体系结构,主要由系统总线和外围总线两部分组成,它的演进如下:

根据 AMBA标准定义了多种不同的总线,下面列出了四种核心的总线作以简介:

高级系统总线    [Advanced System Bus](ASB);

高级高性能总线 [Advanced High-performance Bus](AHB);

高级外设总线    [Advanced Peripheral Bus](APB);

高级扩展接口    [Advanced eXtensible Interface](AXI)。

1.ASB

    ASB是第一代AMBA系统总线,同AHB相比,它数据宽度要小一些,它支持的典型数据宽度为8位、16位、32位。

2.AHB

    AHB应用于高性能、高时钟频率的系统模块,它构成了高性能的系统骨干总线( back-bone bus )。

3.APB

   APB是本地二级总线(local secondary bus ),通过桥和AHB/ASB相连。它主要是为了满足不需要高性能流水线接口或不需要高带宽接口的设备的互连,主要用来实现操作片上低速外设。

4.AXI

    AXI是在AMBA3.0总线中提出来的,为AXI3.0版本,AMBA 4是最新增添到 AMBA 系列中的规范,增加了三个新接口协议:AXI4 有助于最大化性能和能效;AXI4-Lite 和 AXI4-Stream 是 FPGA 中实现的理想选择。

(1)AXI4

AXI4 协议是对 AXI3 的更新,在用于多个主接口时,可提高互连的性能和利用率。它包括以下增强功能:

1)对于突发长度,最多支持 256 位

2)支持多区域接口

(2)AXI4-Lite

AXI4-Lite 是 AXI4 协议的子协议,适用于与组件中更简单且更小的控件寄存器式的接口通信。AXI4-Lite 接口的主要功能如下:

1)所有事务的突发长度均为 1

2)所有数据存取的大小均与数据总线的宽度相同

3)不支持独占访问

(3)AXI4-Stream

AXI4-Stream 协议可用于从主接口到辅助接口的单向数据传输,可显著降低信号路由速率。该协议的主要功能如下:

1)使用同一组共享线支持单数据流和多数据流

2)在同一互连内支持多个数据宽度

3)FPGA 中实现的理想选择

二、ZYNQ MicroBlaze连接AXI总线注意事项

外设必须接到外设总线上,否则处理器会访问不到(不接让处理器怎么访问),很多人会问为什么会不接,请看下面的原理图,这张图是Vivado帮我们自动连接的:

我们在来看看地址分配图,其实Vivado自动生成的电路图吧EMC接到了IC上和DC总线上,Vivado会以为用户会接内存,来运行程序用的:

Vivado总的分配图:

三、解决方法

在自动生成原理图的时候,需要核对AXI类型IP核是需要接到哪个总线上,外设需要接到外设总线上,内存是需要接到内存总线上,如下图修改,选种点击OK即可:

这篇关于ZYNQ MicroBlaze AXI总线连接注意事项的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java 方法重载Overload常见误区及注意事项

《Java方法重载Overload常见误区及注意事项》Java方法重载允许同一类中同名方法通过参数类型、数量、顺序差异实现功能扩展,提升代码灵活性,核心条件为参数列表不同,不涉及返回类型、访问修饰符... 目录Java 方法重载(Overload)详解一、方法重载的核心条件二、构成方法重载的具体情况三、不构

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2