0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

ZYNQ架构知识

OpenFPGA 来源:开源FPGA 2020-08-27 14:35 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

ZYNQ架构

双核ARM Cortex-A9 处理器:ARM Cortex-A9 是一个应用级的处理器,能运行完整的像Linux 这样的操作系统

传统的现场可编程门阵列(Field Programmable Gate Array,FPGA)逻辑部件:基于Xilinx 7 系列的FPGA 架构

这个架构实现了工业标准的AXI 接口,在芯片的两个部分之间实现了高带宽、低延迟的连接。

这意味着处理器和逻辑部分各自都可以发挥最佳的用途,而不会有在两个分立的芯片之间的那种接口开销。

外设是处理器之外的功能部件,一般从事三种功能之一:(一)协处理器—— 辅助主处理器的单元,往往是被优化用于特定任务;(二)与外部接口交互的核心,如连接到LED 和开关、编解码器等等;(三)额外的存储器单元。

PS具有固定的架构,承载了处理器和系统存储区

而PL完全是灵活的,给了设计者一面“ 空白画布” 来创建定制的外设,或重用标准外设。

ZYNQ的SoC设计流基本模型

ZYNQ芯片

处理器系统(PS)

ARM是一颗“硬”处理器,硬件处理器以外的另一种方案,就像Xilinx 的MicroBlaze这样的“软”处理器,这是由可编程逻辑部分的单元组合而成的。也就是说,一个软处理器的实现和部署在FPGA 的逻辑结构里的任何其他IP 包是等价的。要求不高的任务可以从主的ARM Cortex-A9 处理器上脱离出来,分配给软处理器,软处理器与ARM协同工作,提升整体性能

PS里并非只有ARM 处理器,还有一组相关的处理资源,形成了一个应用处理器单元(Application Processing Unit,APU),另外还有扩展外设接口、cache 存储器、存储器接口、互联接口和时钟发生电路

处理器系统外部接口——PS 和外部接口之间的通信主要是通过复用的输入/ 输出(Multiplexed Input/Output,MIO)实现的。这样的连接也可以通过扩展EMIO (ExtendedMIO,EMIO)来实现,EMIO 并不是PS 和外部连接之间的直接通路,而是通过共用了PL 的I/O 资源来实现的。

可用的I/O 包括标准通信接口(SPI,I2C,USB,SD,CAN,UART,GigE)和通用输入/ 输出(General Purpose Input/Output,GPIO)

可编程逻辑(PS)

LUT-查找表(https://www.cnblogs.com/lbf-19940424/p/6564885.html)

FF-触发器,一个实现1 位寄存的时序电路,带有复位功能。FF 的一种用处是实现锁存。

CLB-可配置编程逻辑块

IOB-输入/ 输出块(Input/Output Blocks,IOB)-实现了PL 逻辑资源之间的对接,并且提供物理设备“ 焊盘” 来连接外部电路。每个IOB 可以处理一位的输入或输出信号。IOB 通常位于芯片的周边。

除了通用的部分,还有两个特殊用途的部件:满足密集存储需要的块RAM和用于高速算术的DSP48E1片

通用输入输出IOB

通信接口--包括PCIExpress、串行RapidIO、SCSISATA

其他可编程逻辑扩展接口--XADC,时钟,编程与调试

处理器系统与可编程逻辑的接口

1、AXI标准--Advanced eXtensible Interface

有三类AXI4总线协议

• AXI4 [2] — 用于存储映射链接,它支持最高的性能:通过一簇高达256 个数据字(或“ 数据拍(data beats)”)的数据传输来给定一个地址。
• AXI4-Lite [2] — 一种简化了的链接,只支持每次连接传输一个数据(非批量)。AXI4-Lite也是存储映射的:这种协议下每次传输一个地址和单个数据。

• AXI4-Stream [1] — 用于高速流数据,支持批量传输无限大小的数据。没有地址机制,这种总线类型最适合源和目的地之间的直接数据流(非存储器映射)

互联(Interconnect)— 互联实际上是一个开关,管理并直接传递所连接的AXI 接口之间的通信。在PS 内有几个互联,其中有些还直接连接到PL (如图2.9),而另一些是只用于内部连接的。这些互联之间的连接也是用AXI 接口所构成的。
接口(Interface)— 用于在系统内的主机和从机之间传递数据、地址和握手信号的点对点连接。(M-主机,S-从机)

• 通用AXI(General Purpose AXI) — 一条32 位数据总线,适合PL 和PS 之间的中低速通信。接口是透传的不带缓冲。总共有四个通用接口:两个PS 做主机,另两个PL 做主机。
• 加速器一致性端口Accelerator Coherency Port) — 在PL 和APU 内的SCU之间的单个异步连接,总线宽度为64 位。这个端口用来实现APU cache 和PL的单元之间的一致性。PL 是做主机的。
• 高性能端口(High Performance Ports) — 四个高性能AXI 接口,带有FIFO缓冲来提供“ 批量” 读写操作,并支持PL 和PS 中的存储器单元的高速率通信。数据宽度是32 或64 位,在所有四个接口中PL 都是做主机的。

表 2.2 给出给出了每个接口的简述,标出了主机和从机 (按照惯例,主机是控制总线并发起会话的,而从机是做响应的)。注意接口命名的规范(在表 2.2 的第一列)是表示了 PS 的角色的,也就是说,第一个字母 “M” 表示 PS 是主机,而第一个字母 “S” 表示 PS 是从机。

2、EMIO接口

3、其他PL-PS信号

跨越PS-PL 边界的其他信号包括看门狗定时器、重启信号、中断和DMA 接口信号。

安全

总结

附议:

本人觉得除了整体架构的创新,灵活的IO也是ZYNQ成为受欢迎的一部分:

Multiplexed I/O (MIO):PS端外设IO复用,这是什么概念呢?前面介绍了ZYNQ主要分PS/PL两大组成模块,PS端前面介绍的外设如USB/CAN/GPIO/UART等都必要需要引脚与外界打交道,这里所谓的复用与常见的单片机、处理器里引脚复用的概念一样。但是(这里划重点),ZYNQ具有高达54个PS引脚支持MIO,MIO具有非常高的灵活度以达到灵活配置,这给硬件设计、PCB布板带来了极大的便利!,MIO的配置利用vivado软件可以实现灵活配置,如下图所示。

硬件工程师往往发现对一个复杂的系统的布局布线,常常会很困难,也常因为不合理的布局布线而陷入EMC深坑。ZYNQ的IO引脚高度灵活性,无疑在电路设计方面提供极大的方便,可实现非常灵活的PCB布局布线。从而在EMC性能改善方面带来了很大便利。

灵活的PS-PL互连接口

Extended Multiplexed I/O (EMIO):扩展MIO,如果想通过PS来访问PL又不想浪费AXI总线时,就可以通过EMIO接口来访问PL。54个I/O中,其中一部分只能用于MIO,大部分可以用于MIO或EMIO,少量引脚只能通过EMIO访问。

如上图,比如I2C0则可以通过EMIO映射到PL端的引脚输出,这无疑又增加了更多的灵活性!

PS-PL接口HP0-HP3:如上架构图中AXI high-performance slave ports (HP0-HP3) 实现了PS-PL的接口

可配置的32位或64位数据宽度

只能访问片上存储器OCM(On chip memory)和DDR

AXI FIFO接口(AFI)利用1KB FIFOs来缓冲大数据传输

PS-PL接口GP0-GP1:如上架构图中AXI general-purpose ports

两个PS主接口连接到PL的两个从设备

32位数据宽度

一个连接到CPU内存的64位加速器一致端口(ACP)AXI从接口,ACP 是 SCU (一致性控制单元)上的一个 64 位从机接口,实现从 PL 到 PS 的异步 cache 一致性接入点。ACP 是可以被很多 PL 主机所访问的,用以实现和 APU 处理器相同的方式访问存储子系统。这能达到提升整体性能、改善功耗和简化软件的效果。ACP 接口的表现和标准的 AXI 从机接口是一样的,支持大多数标准读和写的操作而不需要在 PL 部件中加入额外的一致性操作。

DMA, 中断, 事件信号:

处理器事件总线信号事件信息到CPU

PL外设IP中断到PS通用中断控制器(GIC)

四个DMA通道RDY/ACK信号

扩展多路复用I/O (EMIO)允许PS外设端口访问PL逻辑和设备I/O引脚。

时钟以及复位信号:

四个PS时钟带使能控制连接到PL

四个PS复位信号连接到PL

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 处理器
    +关注

    关注

    68

    文章

    20332

    浏览量

    254943
  • 芯片
    +关注

    关注

    463

    文章

    54422

    浏览量

    469285
  • Zynq
    +关注

    关注

    10

    文章

    633

    浏览量

    49571

原文标题:ZYNQ架构

文章出处:【微信号:Open_FPGA,微信公众号:OpenFPGA】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    ZYNQ核心板原理图讲解

    ZYNQ系列的FPGA设计方法大同小异,都是PL+PS架构,只需要理清楚有多少个BANK,哪些BANK支持多少V供电和功耗,上电时序,那些BANK是PS端那些是PL端即可。目前网上有很多原理图可以参考,可以根据自己的设计需求和习惯更换连接器或者电源芯片。
    的头像 发表于 04-09 15:45 5051次阅读
    <b class='flag-5'>ZYNQ</b>核心板原理图讲解

    FPGA硬件设计之ZYNQ外围DDR介绍

    由于ZYNQ-PS端的BANK502基本就是为DDR设计的,所以原理图设计非常简单:几乎就是PIN TO PIN连接。
    的头像 发表于 03-25 15:30 347次阅读
    FPGA硬件设计之<b class='flag-5'>ZYNQ</b>外围DDR介绍

    如何在Zynq UltraScale+ MPSoC平台上通过JTAG启动嵌入式Linux镜像

    在之前文章中,我们介绍了如何使用 XSCT 工具通过 JTAG 在 Zynq SoC 上启动嵌入式 Linux 镜像(从 JTAG 启动 Zynq-7000 嵌入式 Linux:使用 XSCT 全
    的头像 发表于 01-13 11:45 5005次阅读

    如何在ZYNQ本地部署DeepSeek模型

    一个将最小号 DeepSeek 模型部署到 AMD Zynq UltraScale+ MPSoC 处理系统的项目。
    的头像 发表于 12-19 15:43 7821次阅读
    如何在<b class='flag-5'>ZYNQ</b>本地部署DeepSeek模型

    Linux驱动开发的必备知识

    内核基础知识: 1、熟悉 Linux 内核的架构、模块系统、进程管理、内存管理等。 了解内核的编译和加载过程。 2、C编程技能: 精通 C 语言编程,包括指针操作、内存管理、结构体等
    发表于 12-04 07:58

    芯源MCU架构是不是基本都是ARM架构?还有其他的架构吗?

    芯源MCU架构是不是基本都是ARM架构?还有其他的架构吗?
    发表于 11-20 06:21

    【VPX650 】青翼凌云科技基于 VPX 系统架构的 VU13P FPGA+ZYNQ SOC 超宽带信号处理平台

    VPX650 是一款基于 6U VPX 系统架构的 VU13P FPGA + XC7Z100 SOC 超宽带信号处理平台,该平台采用一片 Xilinx 的 Virtex UltraScale+
    的头像 发表于 10-16 10:48 819次阅读
    【VPX650 】青翼凌云科技基于 VPX 系统<b class='flag-5'>架构</b>的 VU13P FPGA+<b class='flag-5'>ZYNQ</b> SOC 超宽带信号处理平台

    ZYNQ PS与PL数据交互方式

    ZYNQ SoC 的 PS (Processing System) 和 PL (Programmable Logic) 之间的数据交互是系统设计的核心。
    的头像 发表于 10-15 10:33 1340次阅读
    <b class='flag-5'>ZYNQ</b> PS与PL数据交互方式

    RTthread怎么加载zynq的支持包?

    RTthread有xilinx zynq的芯片支持包了么,SDK管理器里面怎么下载ZYNQ的支持包呢?求助
    发表于 09-23 06:05

    Zynq7100 BSP移植,MSH终端不能正确显示是为什么?

    由于新版本的RT Thread的BSP不再提供Zynq7000的支持。所以同事从RT Thread(4.0.3)中的Zynq7000移植了一份Zynq 7100的BSP。但是MSH终端和串口输出
    发表于 09-19 06:26

    ZYNQ UltraScalePlus RFSOC QSPI Flash固化常见问题说明

    璞致 ZYNQ UltraScalePlus RFSOC QSPI Flash 固化常见问题说明
    发表于 08-08 15:49 0次下载

    【PZ-ZU15EG-KFB】——ZYNQ UltraScale + 异构架构下的智能边缘计算标杆

    璞致电子推出PZ-ZU15EG-KFB异构计算开发板,搭载Xilinx ZYNQ UltraScale+ XCZU15EG芯片,整合四核ARM Cortex-A53、双核Cortex-R5F
    的头像 发表于 07-22 09:47 1305次阅读
    【PZ-ZU15EG-KFB】——<b class='flag-5'>ZYNQ</b> UltraScale + 异构<b class='flag-5'>架构</b>下的智能边缘计算标杆

    A21:分立元件知识与应用专题--电阻知识及应用案例

    )、数码类PACK(C1)、小动力类PACK(C2)、储能类PACK(C3)、光储充系统(D1)、IPD研发流程(E1)等十个子知识体系,并以 L1 知识架构、L2 划重点、L3 原理及经验案例、L4 实战性训练和 Kill(
    的头像 发表于 07-15 19:17 817次阅读
    A21:分立元件<b class='flag-5'>知识</b>与应用专题--电阻<b class='flag-5'>知识</b>及应用案例

    CH367连接zynq问题

    通过四线SPI连接CH367和zynq时,CH367使用CH367StreamSPI函数设置为四线模式,然后设置SDI为MISO,SDX为MOSI,SCS和SCL为片选和时钟
    发表于 07-03 10:10

    知识分享 | 评估模型架构——如何实现?

    确保良好的模型架构对于开发安全和可靠的软件非常重要。本文为您介绍MES Model Examiner® (MXAM)如何优化模型架构,简化复杂度管理步骤,并最终提升软件质量。
    的头像 发表于 06-05 11:46 762次阅读
    <b class='flag-5'>知识</b>分享 | 评估模型<b class='flag-5'>架构</b>——如何实现?