当前位置: 首页 > article >正文

详解ZYNQ中的 RC 和 EP

详解ZYNQ中的 RC 和 EP

一、ZYNQ FPGA 开发板基础( ZC706 )

1. 核心特点

  • 双核大脑 + 灵活积木
    ZC706 集成了 ARM Cortex-A9 双核处理器(相当于电脑 CPU)和 FPGA 可编程逻辑单元(相当于可自定义的硬件积木)。ARM 负责运行操作系统、处理复杂软件任务(如网络通信、数据存储),FPGA 则擅长高速数据处理、实时信号采集等硬件加速任务(如视频解码、传感器数据处理)。两者协同工作,既能像电脑一样运行程序,又能像专用芯片一样高效处理特定任务。

  • 低功耗与高集成
    相比传统 “FPGA + 独立 CPU” 的方案,ZYNQ 将两者集成在一颗芯片上,减少了芯片间通信损耗和电路板面积,功耗更低、成本更划算。

  • 丰富接口与扩展性
    ZC706 配备了 USB、以太网、HDMI、SD 卡、PCIe 等接口,可直接连接鼠标键盘、摄像头、显示器等设备。例如,通过 HDMI 接口输出 4K 视频,或通过 PCIe 接口连接高速固态硬盘(SSD)。

2. 开发流程

  • 软硬协同设计
    需要同时编写 ARM 端的软件代码(如 C 语言、Python)和 FPGA 端的硬件逻辑代码(如 Verilog、VHDL)。例如可用 ARM 控制摄像头采集图像,再用 FPGA 实时分析图像中的物体。

  • 工具链
    使用 Xilinx 官方工具 Vivado 进行硬件设计,Vitis 进行软件开发。开发完成后,将代码打包成 BOOT.bin 文件,通过 SD 卡、QSPI Flash 等介质烧录到开发板中运行。


二、先搞懂:什么是启动模式(Boot Mode)?

想象开发板是一台 “迷你电脑”,启动模式就像电脑选择从 U 盘、硬盘还是光驱 启动系统。
ZYNQ 启动时需要从外部存储设备(如 SD 卡、Flash 芯片等)读取程序和配置数据,RC 和 EP 就是两种不同的 “读取方式”,对应不同的存储接口和速度。

三、RC 模式:快速稳定的 “固态硬盘” 模式

通俗理解
  • 存储设备:板载的 QSPI Flash 芯片(类似小型固态硬盘,速度快、体积小)。
  • 工作原理
    • 通过 4 根数据线并行传输数据(“四线模式”),比传统 “单线模式” 快 4 倍,就像高速公路上的 4 车道同时通车。
    • ZYNQ 启动时,直接从 QSPI Flash 中读取预先烧录好的程序(如 ARM 的引导程序、FPGA 的配置文件)。
  • 特点
    • 速度快适合需要快速启动的场景(如工业设备上电后立即工作)。
    • 数据永久保存:断电后程序不会丢失,适合量产产品(不用每次上电都重新加载数据)。
  • 应用场景
    • 最终产品定型后,通常选择 QSPI 模式启动,就像电脑把系统装在固态硬盘里,开机快又稳定。
    • 例如:智能摄像头、工业控制器、嵌入式服务器。

四、EP 模式:灵活通用的 “U 盘” 模式

通俗理解
  • 存储设备:外部的 并行 Flash 芯片(类似老式 U 盘,通过并行接口连接)。
  • 工作原理
    • 通过 多根数据线并行传输数据(如 8 位或 16 位总线),一次能传更多数据,就像多条车道同时运货,但接口复杂一些。
    • ZYNQ 启动时,从并行 Flash 中读取程序,适合需要大容量存储的场景(并行 Flash 通常容量更大)。
  • 特点
    • 容量大:适合存储大型程序或需要频繁更新的数据(如操作系统、高清视频文件)。
    • 灵活性高:可以通过并行接口扩展更多存储设备,但硬件设计较复杂(需要更多引脚连接)。
  • 应用场景
    • 开发阶段或需要大存储的项目,比如:
      • 运行 Linux 系统的 ZYNQ 开发板(系统文件较大,需要大容量存储)。
      • 多媒体设备(如视频监控系统,需要存储大量视频数据)。


五、如何在开发板上设置 RC/EP 模式?

  1. 硬件设置:通过 DIP 开关(拨码开关) 选择启动模式。例如:
    • 具体引脚定义需要参考开发板手册
    • 拨码开关设置为 0010 表示 QSPI 模式(RC),0100 表示并行 Flash 模式(EP)。
  2. 软件烧录:用 Xilinx 工具(如 Vivado、SDK)将程序打包成 BOOT.bin 文件,通过 JTAG 或 SD 卡先烧录到目标存储设备(QSPI Flash 或并行 Flash)。
  3. 启动验证:上电后,ZYNQ 会按设置的模式从对应设备读取数据,就像电脑按 BIOS 设置从 U 盘或硬盘启动一样。

六、其他常见启动模式

除了 RC 和 EP,ZYNQ 还有:

  • JTAG 模式:通过调试器直接下载程序(开发阶段用,断电数据丢失),类似电脑用 U 盘装系统时的 “PE 模式”。
  • SD 卡模式:从 SD 卡启动(方便调试和修改程序),类似电脑用 U 盘临时启动系统。
  • EMMC 模式:从板载 EMMC 芯片启动(速度和容量介于 QSPI 和并行 Flash 之间),类似电脑的内置小容量固态硬盘。

相关文章:

详解ZYNQ中的 RC 和 EP

详解ZYNQ中的 RC 和 EP 一、ZYNQ FPGA 开发板基础( ZC706 ) 1. 核心特点 双核大脑 灵活积木: ZC706 集成了 ARM Cortex-A9 双核处理器(相当于电脑 CPU)和 FPGA 可编程逻辑单元(相当于可自定义的硬件积木…...

CSP信奥赛C++常用系统函数汇总

# CSP信奥赛C常用系统函数汇总## 一、输入输出函数### 1. cin / cout&#xff08;<iostream>&#xff09; cpp int x; cin >> x; // 输入 cout << x << endl;// 输出 优化&#xff1a;ios::sync_with_stdio(false); 可提升速度 2. scanf() /…...

Qt Quick Dialogs模块功能及架构

Qt Quick Dialogs 是 Qt Quick 的一个附加模块&#xff0c;提供了一套用于创建和使用系统对话框的 QML 类型。在 Qt 6.0 中&#xff0c;这个模块经过了重构和增强。 一、主要功能和特点 1. 对话框类型 Qt Quick Dialogs 在 Qt 6.0 中提供了以下标准对话框类型&#xff1a; …...

Unity基础-Mathf相关

Unity基础-Mathf相关 一、Mathf数学工具 概述 Mathf是Unity中封装好用于数学计算的工具结构体&#xff0c;提供了丰富的数学计算方法&#xff0c;特别适用于游戏开发场景。它是Unity开发中最常用的数学工具之一&#xff0c;能够帮助我们处理各种数学计算和插值运算。 Mathf…...

STM32CubeMX-H7-19-ESP8266通信(中)--单片机控制ESP8266实现TCP地址通信

前言 上篇文章我们已经能够使用串口助手实现esp8266的几种通信&#xff0c;接下来我们使用单片机控制实现。这篇文章会附带教程&#xff0c;增加.c和,.h&#xff0c;把串口和定时器放到对应的编号&#xff0c;然后调用初始化就可以使用了。 先讲解&#xff0c;然后末尾再放源码…...

ubuuntu24.04 编译安装 PostgreSQL15.6+postgis 3.4.2 + pgrouting 3.6.0 +lz4

文章目录 下载基础包下载源码包编译 PG编译 postgis编译安装 pgrouting下载源码包配置编译参数编译安装 初始化数据库建表并检查列是否使用了 lz4 压缩算法检查 postgis 与 pgrouting 是否可以成功创建 下载基础包 sudo apt update && sudo apt upgrade -y sudo apt i…...

【汇编逆向系列】四、函数调用包含单个参数之Double类型-mmword,movsd,mulsd,addsd指令,总结汇编的数据类型

一、汇编代码 上一节开始&#xff0c;讲到了很多debug编译独有的汇编方式&#xff0c;为了更好的区分release的编译器优化和debug的区别&#xff0c;从本章节开始将会提供debug和release的汇编用作对比 Debugb编译 single_double_param:00000000000000A0: F2 0F 11 44 24 08…...

【AI学习】wirelessGPT多任务无线基础模型摘要

收看了关于WirelessGPT多任务无线基础模型的演讲视频&#xff0c;边做一个记录。 应该说&#xff0c;在无线通信大模型的探索方面&#xff0c;有一个非常有益的尝试。 在沈学明院士带领下开展 https://www.chaspark.com/#/live/1125484184592834560...

docker 部署redis集群 配置

docker的网络模式 网桥模式每次重启容器都有可能导致容器ip地址变化&#xff0c;需要固定ip的自己自定义网络&#xff0c;这里介绍的是默认网络模式 docker创建容器 docker run --name redis6379 -p 6379:6379 -p 16379:16379 -v /etc/redis/redis6379:/etc/redis -d --r…...

Ansys Maxwell:线圈和磁体的静磁 3D 分析

本博客展示了如何在 Ansys Maxwell 中执行静磁 3D 分析&#xff0c;以计算载流线圈和永磁体之间相互作用产生的扭矩。在这个例子中&#xff0c;线圈中的电流产生一个沿 Y 轴指向的磁场&#xff0c;而永磁体沿 X 轴被磁化。这种配置导致围绕 Z 轴的扭矩。分步工作流程包括构建几…...

android 之 KeyguardService

一、功能定位与核心作用 KeyguardService 是 Android 锁屏功能的核心服务&#xff0c;负责管理设备锁屏界面&#xff08;如密码、图案、指纹等验证流程&#xff09;&#xff0c;并协调系统安全策略与用户交互。主要职责包括&#xff1a; 锁屏状态管理 控制锁屏界面的显示/隐藏…...

compose 组件 ---无ui组件

在 Jetpack Compose 中&#xff0c;确实存在不直接参与 UI 渲染的组件&#xff0c;它们主要用于逻辑处理、状态管理或副作用控制。这些组件虽然没有视觉界面&#xff0c;但在架构中扮演重要角色。以下是常见的非 UI 组件及其用途&#xff1a; 1. 无 UI 的 Compose 组件分类 (…...

【计算机网络】SDN

SDN这种新型网络体系结构的核心思想&#xff1a;把网络的控制层面与数据层面分离&#xff0c;而让控制层面利用软件来控制数据层面中的许多设备。 OpenFlow协议可以被看成是SDN体系结构中控制层面与数据层面之间的通信接口。 在SDN中取代传统路由器中转发表的是“流表”&…...

HTMLCSS 学习总结

目录 ​​​一、HTML核心概念​​ ​​三大前端技术作用​​ ​​HTML基础结构​​ 开发工具&#xff1a;VS Code 专业配置​​​​安装步骤​​&#xff1a; ​​二、HTML标签大全&#xff08;含表格&#xff09;​​ ​​三、CSS核心技术​​ 1. 三种引入方式对比 2.…...

【设计模式】1.简单工厂、工厂、抽象工厂模式

every blog every motto: You can do more than you think. https://blog.csdn.net/weixin_39190382?typeblog 0. 前言 以下是 简单工厂模式、工厂方法模式 和 抽象工厂模式 的 Python 实现与对比&#xff0c;结合代码示例和实际应用场景说明&#xff1a; 1. 简单工厂模式&a…...

成工fpga(知识星球号)——精品来袭

&#xff08;如需要相关的工程文件请关注知识星球&#xff1a;成工fpga&#xff0c;https://t.zsxq.com/DMeqH&#xff0c;关注即送200GB学习资料&#xff0c;链接已置顶&#xff01;&#xff09; 《孩子都能学会的FPGA》系列是成工完成的第一个系列&#xff0c;也有一年多的时…...

spring中的@KafkaListener 注解详解

KafkaListener 是 Spring Kafka 提供的一个核心注解&#xff0c;用于标记一个方法作为 Kafka 消息的消费者。下面是对该注解的详细解析&#xff1a; 基本用法 KafkaListener(topics "myTopic", groupId "myGroup") public void listen(String message)…...

C#调用Rust动态链接库DLL的案例

C#调用Rust动态链接库DLL的案例 项目概述 这是一个演示C#调用Rust动态链接库DLL的项目&#xff0c;包含&#xff1a; C#主程序 (Program.cs)Rust动态链接库 (rust_to_csharp目录) 使用C#创建一个net9的控制台项目&#xff0c;不使用顶级语句 dotnet new console --framewo…...

win11部署suna

参考链接 项目链接 沙盒链接 数据库链接 本文介绍 本文只为项目的辅助&#xff0c;手把手太麻烦 执行步骤 1.下载代码 git clone https://github.com/kortix-ai/suna.git cd suna2.配置环境&#xff08;在Anaconda Prompt上执行&#xff09; python setup.py3.运行代码 …...

Kafka深度解析与原理剖析

文章目录 一、Kafka核心架构原理1. **分布式协调与选举**2. **ISR、OSR与HW机制**3. **高性能存储设计**4. **刷盘机制 (Flush)**5. **消息压缩算法**二、高可用与消息可靠性保障1. **数据高可用策略**2. **消息丢失场景与规避**3. **顺序消费保证**三、Kafka高频面试题精析1. …...

NoSQL——Redis配置与优化

目录 关系型&非关系型数据库 一、核心原理对比‌ ‌二、核心特性对比‌ ‌三、关键区别剖析‌ ‌四、典型产品示例‌ ‌总结‌ Redis Redis核心原理 核心特性 技术意义 配置文件解析 1. 基础配置 2. 持久化配置 3. 内存管理 4. 高可用配置 5. 性能调优 6.…...

CKA考试知识点分享(2)---ingress

CKA 版本&#xff1a;1.32 第二题是涉及ingress相关。本文不是题目&#xff0c;只是为了学习相关知识点做的实验。 1. 环境准备 需要准备一套K8S集群。 1.1 安装ingress-nginx 下载deploy文件&#xff1a; wget -O controller-v1.12.2.yaml https://raw.githubusercontent…...

动态生成element-plus的scss变量;SCSS中实现动态颜色变体生成

文章目录 一、动态css变量1.生成内容2.动态生成css变量2.1新增_color-utils.scss&#xff08;不推荐&#xff09;2.2新增_color-utils.scss&#xff08;推荐&#xff09;2.3theme.scss引入使用 一、动态css变量 1.生成内容 在我们修改element-plus主题色时候&#xff0c;会自…...

Clickhouse统计指定表中各字段的空值、空字符串或零值比例

下面是一段Clickhouse SQL代码&#xff0c;用于统计指定数据库中多张表的字段空值情况。代码通过动态生成查询语句实现自动化统计&#xff0c;处理逻辑如下&#xff1a; 从系统表获取指定数据库&#xff08;替换your_database&#xff09;中所有表的字段元数据根据字段类型动态…...

Linux 内核内存管理子系统全面解析与体系构建

一、前言: 为什么内存管理是核心知识 内存管理是 Linux 内核最核心也最复杂的子系统之一&#xff0c;其作用包括&#xff1a; 为软件提供独立的虚拟内存空间&#xff0c;实现安全隔离分配/回收物理内存资源&#xff0c;维持系统稳定支持不同类型的内存分配器&#xff0c;最优…...

Tableau for mac 驱动

Tableau 驱动程序安装指南 对于希望在 Mac OS 上使用 Tableau 进行数据分析的用户来说&#xff0c;确保正确安装相应的驱动程序至关重要。Tableau 支持多种数据库连接方式&#xff0c;并提供官方文档指导如何设置这些连接。 安装适用于 Mac 的 JDBC 或 ODBC 驱动程序 为了使…...

fast-reid部署

配置设置&#xff1a; 官方库链接&#xff1a; https://github.com/JDAI-CV/fast-reid# git clone https://github.com/JDAI-CV/fast-reid.git 安装依赖&#xff1a; pip install -r docs/requirements.txt 编译&#xff1a;切换到fastreid/evaluation/rank_cylib目录下&a…...

Steam爬取相关游戏评测

## 因为是第一次爬取Steam。所以作为一次记录发出&#xff1b;有所错误欢迎指出。 无时间指定爬取 import requests import time import csv import osappid "553850" # 这里你也可以改成 #appid int(input()) max_reviews 10000 # 想爬多少条 # max_reviews…...

《开篇:课程目录》

大家好&#xff01;我是一名.NET技术开发者&#xff0c;长期以来积累了比较多的项目实战经验&#xff0c;现在把它分享给大家&#xff0c;希望能够帮助到大家&#xff0c;同时为.NET社区提供一份力量&#xff0c;让更多的开发者参与进来。 要讲解的课程如下&#xff1a; 《介绍…...

大陆4D毫米波雷达ARS548调试

本文介绍了大陆ARS548毫米波雷达的调试与测试流程&#xff0c;主要包括以下内容&#xff1a; 设备参数&#xff1a;最大检测距离301m&#xff08;可调93-1514m&#xff09;&#xff0c;支持gPTP时间同步。 接线调试&#xff1a; Windows需使用USB-RJ45转换器 Linux可直接连接网…...