AXI Quad SPI IP核中的STARTUPEn原语参数

news2024/11/24 3:24:38

启动STARTUPEn Primitive (原语)参数在 FPGA的主 SPI模式下非常有用。当你启用这个参数时,对于 7 系列设备,STARTUPE2 原语会被包含在设计中;而对于 UltraScale™ 设备,则是 STARTUPE3 原语。这些原语在 FPGA 配置后成为IP核的一部分。

1 启用STARTUPEn 原语参数

STARTUPEn(如STARTUPE2STARTUPE3)原语在FPGA设计中起着关键的作用,特别是在与FPGA的SPI配置接口相关时。

FPGA内部的一个输出端口SCK_O(即SPI的时钟输出)会与STARTUPEn原语连接。这个连接允许FPGA在配置过程中与外部的SPI从设备(通常是配置存储器)进行通信。在FPGA配置之前,STARTUPEn也可以用于预配置过程,其中外部SPI从设备会被预先配置。这个过程确保了FPGA在上电时可以立即从已知的状态开始工作。

在FPGA配置完成后,SCK_O端口会驱动STARTUPEn原语的USRCCLK0端口。这个信号在FPGA IP核外部是不可见的,因为它是内部连接的一部分。

实例化STARTUPEn原语会影响ext_spi_clk(外部SPI时钟)的最大频率。这是因为STARTUPEn原语的性能会限制SPI接口可以支持的最大时钟速率。如下图所示:

注:对于xip和标准模式,ext_spi_clk可能被限制为60 MHz。

       UltraScale™设备的频率数字预计与7系列相似。

      上表中提到的频率特定于传统的SPI x 1模式。如果我们改变模式和其他设置,它们会发生变         化。 

2 使用双通道四通道模式

启用Dual Quad模式这个参数仅在UltraScale™及未来系列的设备中,在特定的IP核配置下才有效。

  1. Master mode:IP核工作在主模式下,即它是SPI通信的发起者和控制者。

  2. STARTUP enabled

  3. SPI mode is QUAD

  4. Number of slaves is 2:IP核配置为与两个SPI从设备通信。

当“Enable Dual Quad Mode”参数被启用时,IP核将拥有两个SPI接口。这意味着它可以同时与两个flash存储器或其他SPI从设备通信,如图3-2所示。这提高了数据传输的效率和灵活性,允许IP核在单个时钟周期内与两个从设备交换数据。

在SPI通信中,当涉及到多个从设备时,数据流量的控制是通过从设备选择寄存器(SPISSR)来控制实现的。

3 不启用STARTUPEn 原语参数

SCK_O 和 IO1_I 端口是IP核的一部分,但由于它们不是IP核内部实例化的原语,这些端口作为IP核的外部端口存在,并被放置在用户配置位置的输入输出块(IOB, Input/Output Block)中。

(1) 在传统和增强非XIP模式下

无论是否选择了Enable Performance Mode,都设置该模式。这时,不选择Enable XIP Mode。AXI Quad SPI IP核支持Winbond、Micron、Spansion和Macronix存储器。当使用AXI Quad SPI IP核测试不同的存储器时,确实需要检查不同存储器所需的命令是否相同。如果不同存储器的命令、地址和数据行为都相同,那么可以选择其中一个设备作为基准存储器来测试IP核。

IP核通过内部逻辑了解目标内存的命令及其预期行为。当IP核尝试执行一个不被存储器设备支持的命令时,它会设置一个命令错误标志。一旦命令错误被设置,IP核将不会执行与该命令相关的SPI事务,并生成一个命令错误中断。这允许系统识别并响应不支持的命令,从而避免潜在的错误或数据损坏。

在命令阶段之后,如果包含地址相位,则根据地址模式位定义的模式,在SPI事务中传输下一个DTR(数据/地址/寄存器传输)内容。地址相位通常用于指定存储器中要访问的具体位置(例如,读取或写入的起始地址)。

如果特定命令包含数据相位,则根据读或写操作以及数据模式位设置的模式来执行数据相位。数据相位涉及数据的实际传输,无论是从存储器读取数据还是向存储器写入数据。

dummy bytes(虚拟字节)是在与某些存储器通信时,特别是在执行某些指令时,为了符合特定时序要求而插入的额外字节。这些虚拟字节并不包含实际的数据或地址信息,但它们对于确保命令的正确执行至关重要。

在SPI通信中,DTR(Data/Address/Register Transfer)是数据传输的基本单元,它可能包含地址、数据、控制信号或其他信息。当执行某些指令时,除了需要传输的实际数据字节数外,还需要在DTR中包含一定数量的dummy bytes。

对于读取命令,在传输地址位之后,IP核立即切换到输入模式,并开始在DRR中存储数据。因此,请注意有多少虚拟字节在DRR中被忽略。例如,对于Winbond存储器中的快速读取双输出命令,DTR应填充一个命令字节加三个地址字节加上dummy cycle(虚拟周期的两个虚拟字节加上要从存储器中读取的虚拟字节数。命令和地址在标准SPI模式下传输,之后IP核切换到输入模式并开始存储数据。数据在IO0_I和IO_1线上传输,并存储在SPI DRR中,包括两个虚拟循环加上有效数据。因此,在读取SPI DRR时,忽略掉SPI DRR的前6个字节。FIFO中可用的有效数据从第七个字节开始。这也适用到其他双读取或四读取命令。

对于每个新事务,必须清除SPI DTR FIFO。SPI DTR中的第一个条目始终被视为命令条目,它与所选SPI模式的相应存储器的内置逻辑进行交叉检查。

(2)在XIP模式下

当“Enable Performance Mode”和“Enable XIP Mode”都被选中时,IP核将支持标准模式、双模式和四模式,具体设置和配置如下:

  • 标准模式(Standard mode):设置“Mode”为“Standard”,“Slave Device”设置为Winbond、Micron、Macronix或Spansion等支持的存储器设备。
  • 双通道模式(Dual mode):设置“Mode”为“Dual”,“Slave Device”同样需要设置为Winbond、Micron、Macronix或Spansion等支持的存储器设备。在双模式下,SPI通信将使用两条数据线(如IO0和IO1)同时进行数据传输。
  • 四通道模式(Quad mode):设置“Mode”为“Quad”,“Slave Device”也需要是Winbond、Micron、Macronix或Spansion等支持四模式的存储器设备。在四模式下,SPI通信将使用四条数据线(如IO0、IO1、IO2和IO3)同时进行数据传输。

此模式的假设为:

Winbond存储器
在每次上电复位状态后,会执行一个高性能模式命令,以确保Winbond存储器被配置在高性能模式下。随后,可能会执行DIOFR(0xBBh)或QIOFR(0xEBh)这样的命令来进一步操作该存储器。
当设置Quad模式时,对于Winbond存储器,确实需要预先通过向状态寄存器写入来设置QE(Quad Enable)位为1。
如果IP核不负责向状态寄存器写入任何内容来配置Quad模式,那么这项工作就需要由外部系统或初始化代码来完成。在XIP模式下,预配置存储器的责任在于系统设计者或初始化代码。

当IP核在执行DIOFR或QIOFR命令之前被配置为双模式或四模式时,IP核会在上电复位(POR)后在AXI4接口接收事务之前向存储器写入高性能模式(HPM)命令。这个HPM命令需要一个命令周期和三个dummySPI周期来完成。这个HPM命令在存储器中的写入仅在系统上电时执行一次。当HPM命令成功写入后,Winbond存储器就被配置为高性能模式(HPM — 0xA3h),并允许DIOFR或QIOFR命令在相应的模式下进行操作。

Micron Memory

在Micron存储器中,无论是易失性配置寄存器还是非易失性配置寄存器,其关于dummy周期的字段(VCR[7:4]和NVCR[15:12])在出厂时都被设置为默认值,即1111。IP核特征是基于这些dummy周期寄存器的默认设置(即1111)来设计的。这意味着,当这些寄存器保持默认设置时,IP核可以预期按照特定的行为模式来工作。

建议:不要更改默认的易失性配置寄存器(VCR)和非易失性配置寄存器(NVCR)配置。

在每个新事务开始时,IP核发送相应的命令、地址和所需要的dummy周期,然后接收数据。

Spansion 存储器

当IP核不直接写入状态寄存器,并假定在执行XIP模式之前已经完成这一配置时,这通常意味着系统设计师或开发者需要在系统启动或初始化阶段进行必要的配置。

当设置四通道模式时,Spansion内存必须预先通过写入配置寄存器来设置QUAD位为1。这一步骤是为了确保内存能够按照四通道模式进行工作,以提供更高的数据传输速率和吞吐量。

Macronix 存储器

在Macronix存储器中,配置寄存器负责处理虚拟周期的信息。虚拟周期的配置因配置寄存器中的bit6和bit7(DC0和DC1)的设置而异。默认情况下,bit6和bit7的值为00。

根据Macronix的数据手册,DC0和DC1的不同设置会对应不同的虚拟周期数量。

推荐:不要改变默认的配置寄存器配置。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1806474.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

时隔很久运行苍穹外卖项目,出现很多错误

中途运行了很多其他项目,maven的配置文件还被我修改了一次。导致再次运行苍穹外卖项目出现很多错误。 发现没有办法,把本地的仓库删了个干干净净。然后点击clean发现报错: Cannot access alimaven (http://mavejavascript:void(0);n.aliyun.…

线性代数|机器学习-P11方程Ax=b求解研究

文章目录 1. 变量数和约束条件数大小分类2. 最小二乘法和Gram-schmidt变换2.1 Gram-schmidt变换2.2 最小二乘法2.2.1 损失函数-Lasso 和regression2.2.2 损失函数-Lasso2.2.3 损失函数-regression2.2.4 Regression岭回归-矩阵验证2.2.5 Regression岭回归-导数验证 3. 迭代和随机…

牛客网刷题 | BC119 最高分与最低分之差

目前主要分为三个专栏,后续还会添加: 专栏如下: C语言刷题解析 C语言系列文章 我的成长经历 感谢阅读! 初来乍到,如有错误请指出,感谢! 描述 输入n个成绩&#…

STM32F103C8T6 HAL库串口重定向

前言: 这里仅用做个人记录,实现USART1串口通信,并通过printf重定向输出“串口打印测试” 正文开始: 首先在STM32CubeMX上对串口进行配置,其实方法也非常简单。 按照箭头顺序,先点击Connectivity找到USART1…

NineData云原生智能数据管理平台新功能发布|2024年5月版

重点发布​ 数据库 DevOps - 表分组查询​ 在企业用户规模达到一定程度后,分库分表成为一种常见的数据库架构选择。在这种情况下,查询和维护数据需要高效的解决方案,以避免手动逐一查询、变更和汇总多个分库和分表的繁琐操作。 库分组变更…

泛微开发修炼之旅--13通过Ecology拦截器(注解的方式),拦截后端接口,实现接口执行成功后或执行前操作源码示例

文章链接:泛微开发修炼之旅--13通过Ecology拦截器(注解的方式),拦截后端接口,实现接口执行成功后或执行前操作源码示例

[个人感悟] Java基础问题应该考察哪些问题?

前言 “一切代码无非是数据结构和算法流程的结合体.” 忘了最初是在何处看见这句话了, 这句话, 对于Java基础的考察也是一样. 正如这句话所说, 我们对于基础的考察主要考察, 数据结构, 集合类型结构, 异常类型, 已经代码的调用和语法关键字. 其中数据结构和集合类型结构是重点…

牛客网刷题 | BC117 逆序输出

目前主要分为三个专栏,后续还会添加: 专栏如下: C语言刷题解析 C语言系列文章 我的成长经历 感谢阅读! 初来乍到,如有错误请指出,感谢! 描述 输入10个整数&…

ssm629基于SSM的二手交易平台设计与开发+jsp【已测试】

前言:👩‍💻 计算机行业的同仁们,大家好!作为专注于Java领域多年的开发者,我非常理解实践案例的重要性。以下是一些我认为有助于提升你们技能的资源: 👩‍💻 SpringBoot…

安装windows11系统跳过微软账号登录,使用本地账号登录方法

在安装win11系统,进行到如图下所示界面的时候,暂停下 我们可以按下键盘的ShiftF10按键(部分电脑是FnShiftF10),这时屏幕会出现命令行窗口,如图下所示 我们需要在命令行内输入代码oobe\bypassnro.cmd然后回车…

Linxu: Dynamic debug 简介

文章目录 1. 前言2. 什么是 Dynamic debug (dyndbg) ?3. Dynamic debug (dyndbg) 的使用3.1 开启 Dynamic debug (dyndbg) 功能3.2 使用 Dynamic debug (dyndbg) 功能 4. Dynamic debug (dyndbg) 的实现4.1 内核接口 dynamic_pr_debug() 的实现4.2 debugfs 导出控制节点 contr…

嵌入式中C语言经典的面试题分享

#error的作用是什么? #error 指令让预处理器发出一条错误信息,并且会中断编译过程。下面我们从Linux代码中抽取出来一小段代码并做修改得到示例代码: 这段示例代码很简单,当RX_BUF_IDX宏的值不为0~3时,在预处理阶段就会通过 #error 指令输出一条错误提示信息: "…

spring boot +Scheduled 动态定时任务配置

通常情况下我们设定的定时任务都是固定的,有时候需要我们动态的配置定时任务,下面看代码 import com.mybatisflex.core.query.QueryWrapper; import com.yzsec.dsg.web.modules.exportpwd.entity.ExportPwd; import com.yzsec.dsg.web.modules.exportpwd.entity.table.Export…

嵌入式单片机产品微波炉拆解分享

在厨房电器中,微波炉可以说是最具技术含量的电器,它的工作原理不像其他电器那样一眼就能看个明白,于是拆解了一个微波炉,分析内部电路。 微波炉的结构 微波炉由箱体、磁控管、变压器、高压电容器、高压二极管、散热风扇、转盘装置及一系列控制保护开关组成,大多数微波炉还…

人工智能和物联网如何结合

欢迎来到 Papicatch的博客 文章目录 🍉引言 🍉AI与IoT的结合方式 🍈数据处理和分析 🍍实例 🍈边缘计算 🍍实例 🍈自动化和自主操作 🍍实例 🍈安全和隐私保护 &…

【Python】探索 One-Class SVM:异常检测的利器

我已经从你的 全世界路过 像一颗流星 划过命运 的天空 很多话忍住了 不能说出口 珍藏在 我的心中 只留下一些回忆 🎵 牛奶咖啡《从你的全世界路过》 在数据科学和机器学习领域,异常检测(Anomaly Detection)是…

使用 Vue 官方脚手架初始化 Vue3 项目

Vite 官网:https://cn.vitejs.dev/ Vue 官网:https://vuejs.org/ Vue 官方文档:https://cn.vuejs.org/guide/introduction.html Element Plus 官网:https://element-plus.org/ Tailwind CSS 官网:https://tailwindcss.…

DS:堆的结构与实现

欢迎来到Harper.Lee的学习世界!博主主页传送门:Harper.Lee的博客主页想要一起进步的uu可以来后台找我哦! 一、堆的概念与结构 1.1 堆的概念 堆(Heap)是完全二叉树中的一种,分为大根堆和小根堆。 特点&#…

【RAG入门教程03】Langchian框架-文档加载

Langchain 使用文档加载器从各种来源获取信息并准备处理。这些加载器充当数据连接器,获取信息并将其转换为 Langchain 可以理解的格式。 LangChain 中有几十个文档加载器,可以在这查看https://python.langchain.com/v0.2/docs/integrations/document_lo…

BabylonJS 6.0文档 Deep Dive 动画(四):通过动画排序制作卡通片

一种最为直接的方法是为每个动画剪辑(Animatin Clip)指定开始时间,最终形成一个卡通动画(Cartoon)。 1. 设计 1.1 概述 动画的脚本如下: 摄像机显示了一栋带门的建筑物。摄像机靠近门并停止。门打开&am…