大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是在FDCB里使能串行NOR Flash的QPI/OPI模式

  我们知道 Flash 读时序里有五大子序列 CMD + ADDR + MODE + DUMMY + READ,前面的文章中痞子衡讲过《串行NOR Flash的Continuous read模式》,Continuous read 模式是为了在适当的情况下精简掉连续读访问里的后续 CMD 子序列,它可以进一步提高 Flash 访问性能,这已经是极限了吗?其实没有,还差最后一招,那就是痞子衡今天要讲的 QPI/OPI 模式。

一、什么是QPI/OPI模式?

  截至到目前为止,不管是四线 Flash 还是 八线 Flash,痞子衡讲的所有 Flash 传输时序中的 CMD 子序列都是以 1 线形式发送的(即只通过 IO0 来发送),我想你肯定也曾经觉得奇怪过,为何其他子序列都有 1/2/4/8 线模式可选,偏偏这个 CMD 子序列总是 1 线模式?其实这也不能怨 CMD,毕竟所有的 Flash 传输时序都从 CMD 子序列开始的,后续子序列的 Pad 模式都是靠 CMD 命令码来区分的,为了保证 CMD 值能被正确获取,只能牺牲 CMD 序列的灵活性,就固定以 1 线形式发送,这也就是所谓的 SPI 模式。

  为了不让 CMD 子序列太委屈,Flash 厂商也为了它单独做了设计,四线 Flash 可以切换到 4 线模式来发送 CMD 子序列(即 QPI 模式),八线 Flash 可以切换到 8 线模式来发送 CMD 子序列(即 OPI 模式),默认上电是 SPI 模式,然后在 SPI 模式下做指定设置可以切换到 QPI/OPI 模式,在 QPI/OPI 模式下做指定设置或者复位也能再回到 SPI 模式。

1.1 四线Flash的QPI模式

  下面是一款典型的四线 Flash(芯成 IS25WP128) 在 QPI 模式下的 Fast Read Quad I/O 传输时序,此时 CMD 子序列仅在 2 个 CLK 内就完成了传输,因为 IO[3:0] 均参与了 CMD 发送,效率是 SPI 模式下的 4 倍。后面的子序列与 SPI 模式下一模一样。

1.2 八线Flash的OPI模式

  下面是一款典型的八线 Flash(旺宏 MX25UM51345) 在 OPI 模式下的 OCTA Read 传输时序,此时 CMD 子序列仅在 1 个 CLK 内就完成了传输,因为 SIO[7:0] 均参与了 CMD 发送,效率是 SPI 模式下的 8 倍。后面的子序列与 SPI 模式下一模一样。

二、不同Flash厂商关于QPI/OPI切换设计

  现在跟着痞子衡去看几家主流Flash厂商关于 QPI/OPI 模式切换的设计(如果你想快速确认某一款型号Flash是否支持这个特性,找到其数据手册搜索"QPI/OPI"看有没有结果):

2.1 四线 Flash 上切换设计

  QPI 模式是四线 Flash 上一个性能模式特性,并不是所有 Flash 都支持这个特性。而对于支持 QPI 模式的 Flash,不同厂商的切换设计也不太相同,不过大部分厂商都是选择发一个 CMD 命令时序来切换,比如芯成 IS25WP128 就是如下的时序进入和退出 QPI 模式:

  痞子衡找了几家市面上比较常见的四线 Flash,并整理了它们进出 QPI 模式命令码如下:

Flash型号 进入QPI模式命令码 退出QPI模式命令码
Adesto AT25SL系列 0x38 0xFF
芯成IS25WP系列 0x35 0xF5
华邦W25QxxJV-DTR系列 0x38 0xFF
兆易创新GD25Q系列 不支持 不支持

  当然也有一些厂商不是发一个 CMD 命令时序来切换的设计,而是通过设置 Flash 内部寄存器的方式来做切换,比如赛普拉斯 S25FS-S 系列就是设置如下的寄存器来进入和退出 QPI 模式:

2.2 八线 Flash 上切换设计

  对于八线 Flash,即使 OPI 模式也算性能模式特性,但是基本上所有 Flash 都能支持这个特性(毕竟目前生产 8 线 Flash 的厂商并不多)。这些厂商都是提供设置 Flash 内部寄存器的方式来做切换:

  如下是旺宏 MX25UM51345 切换 OPI 模式的寄存器定义:

  如下是镁光 MT35X 系列切换 OPI 模式(即 Octal 模式)的寄存器定义:

三、在i.MXRT1170-EVK上实战(IS25WP128)

  了解了上面关于 QPI/OPI 模式知识后,我们在恩智浦 i.MXRT1170-EVK 板子上实践一下。默认连接的 Flash 是IS25WP128,这款 Flash 是支持 QPI 模式的,我们随便在SDK包里找一个 XIP 例程,修改工程里 evkmimxrt1170_flexspi_nor_config.c 文件里的 FDCB 启动头如下,改完下载程序进 Flash 运行,代码执行效率应该会有所提升。

#define CMD_LUT_SEQ_IDX_ENTER_QPI 7
const flexspi_nor_config_t qspiflash_config = {
.memConfig =
{
// ... 默认设置省略 // 使能 QPI 配置操作
.deviceModeCfgEnable = 1u,
.deviceModeType = kDeviceConfigCmdType_Spi2Xpi,
.waitTimeCfgCommands = 1,
.deviceModeSeq =
{
.seqNum = 1,
.seqId = CMD_LUT_SEQ_IDX_ENTER_QPI,
.reserved = 0,
},
.deviceModeArg = 0,
.lookupTable =
{
// Fast Read Quad I/O LUTs (将 CMD_SDR 的 Pad 模式由 FLEXSPI_1PAD 改为 FLEXSPI_4PAD)
[0] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_4PAD, 0xEB, RADDR_SDR, FLEXSPI_4PAD, 0x18),
[1] = FLEXSPI_LUT_SEQ(MODE8_SDR, FLEXSPI_4PAD, 0x00, DUMMY_SDR, FLEXSPI_4PAD, 0x04),
[2] = FLEXSPI_LUT_SEQ(READ_SDR, FLEXSPI_4PAD, 0x04, 0, 0, 0),
// 增加 Enter QPI 命令序列
[4*CMD_LUT_SEQ_IDX_ENTER_QPI] = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_1PAD, 0x35, 0, 0, 0),
},
},
// ... 默认设置省略
};

  关于 OPI 模式使能的例子可以直接参考 MIMXRT500/600 SDK,因为其配套 EVK 使用的是旺宏 MX25UM51345,所以官方 SDK 里启动头 FDCB 都是包含开启 OPI 模式的配置代码的。

  和使能 Continuous read 模式一样,使能 QPI/OPI 模式后,对项目最大的影响是考虑软复位后芯片再次启动的问题,具体可以参考痞子衡的旧文 《深扒i.MXRT系列ROM中集成的串行NOR Flash启动SW Reset功能及其应用场合》

  至此,在FDCB里使能串行NOR Flash的QPI/OPI模式痞子衡便介绍完毕了,掌声在哪里~~~

欢迎订阅

文章会同时发布到我的 博客园主页CSDN主页知乎主页微信公众号 平台上。

微信搜索"痞子衡嵌入式"或者扫描下面二维码,就可以在手机上第一时间看了哦。

痞子衡嵌入式:在i.MXRT启动头FDCB里使能串行NOR Flash的QPI/OPI模式的更多相关文章

  1. 痞子衡嵌入式:在i.MXRT启动头FDCB里使能串行NOR Flash的Continuous read模式

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是在FDCB里使能串行NOR Flash的Continuous read模式. 前面关于串行Flash传输时序的文章 <Fast R ...

  2. 痞子衡嵌入式:在i.MXRT启动头FDCB里使能串行NOR Flash的DTR模式

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是在FDCB里使能串行NOR Flash的DTR模式. 前两篇文章 <IS25WP系列Dummy Cycle设置> 与 < ...

  3. 痞子衡嵌入式:从头开始认识i.MXRT启动头FDCB里的lookupTable

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT启动头FDCB里的lookupTable. 一个MCU内部通常有很多外设模块,这些外设模块是各MCU厂商做差异化产品的本质, ...

  4. 痞子衡嵌入式:在i.MXRT启动头FDCB里调整Flash工作频率也需同步设Dummy Cycle

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是Flash工作频率与Dummy Cycle的联系. 上一篇文章 <从头开始认识i.MXRT启动头FDCB里的lookupTable ...

  5. 痞子衡嵌入式:串行NOR Flash的Continuous read模式下软复位后i.MXRT无法启动问题解决方案之RESET#

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT上使能NOR Flash的Continuous read模式在软复位后无法正常启动问题的解决经验. 前一篇文章 <在i ...

  6. 痞子衡嵌入式:在串口波特率识别实例里逐步展示i.MXRT上提升代码执行性能的十八般武艺

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是在串口波特率识别实例里逐步展示i.MXRT上提升代码执行性能的十八般武艺. 恩智浦 MCU SE 团队近期一直在加班加点赶 SBL 项目 ...

  7. 痞子衡嵌入式:i.MXRT连接特殊Octal Flash时(OPI DTR模式下反转字节序)下载与启动注意事项(以MX25UM51245为例)

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是OPI DTR模式下反转字节序的Octal Flash在i.MXRT下载与启动注意事项. 在恩智浦官方参考设计板 MIMXRT595-E ...

  8. 痞子衡嵌入式:i.MXRT中FlexSPI外设对AHB Burst Read特性的支持

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是FlexSPI外设对AHB Burst Read特性的支持. 痞子衡之前写过一篇关于FlexSPI LUT的文章 <从头开始认识i ...

  9. 痞子衡嵌入式:i.MXRT中FlexSPI外设不常用的读选通采样时钟源 - loopbackFromSckPad

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是i.MXRT中FlexSPI外设不常用的读选通采样时钟源 - loopbackFromSckPad. 最近碰到一个客户,他们在 i.MX ...

随机推荐

  1. Typora配置阿里云图床

    一.Typora安装PicGo 更新typora到最新版,打开文件-->偏好设置-->图像-->上传服务选择PicGo-Core-->下载或更新   二.注册并配置阿里云 1. ...

  2. 技术分享 | app自动化测试(Android)--高级定位技巧

    原文链接 XPath高级定位技巧 XPath 简介 XPath 的英文全称为:XML Path Language,意旨对 XML 中的元素进行路径定位的一种语言,它可适用 XML 标记语言,Html ...

  3. Node.js精进(2)——异步编程

    虽然 Node.js 是单线程的,但是在融合了libuv后,使其有能力非常简单地就构建出高性能和可扩展的网络应用程序. 下图是 Node.js 的简单架构图,基于 V8 和 libuv,其中 Node ...

  4. 在jupyter中配置c++内核

    安装 xeus-cling conda install xeus-cling -c conda-forg xeus-cling 是一个用于编译解释于C++的Jupyter内核目前,支持Mac与Linu ...

  5. WPF中Popup控件的使用

    一.Popup控件的主要属性 Popup表示具有内容的弹出窗口,其主要属性为: Child:获取或设置 Popup控件的内容. IsOpen:获取或设置一个值,该值指示Popup 是否可见 Place ...

  6. Web开发小妙招:巧用ThreadLocal规避层层传值

    摘要:我们可以在处理每次请求的过程中,无需从Controller以及Service中的方法层层传值,只需要直接通过该局部变量取值即可. 本文分享自华为云社区<拦截器中巧用ThreadLocal规 ...

  7. Java学习dayo4

    分支结构和循环语句 1.包的概念 包就是文件夹 包的命名规范:全小写,域名倒置,不能以点开头或结尾,可以包含点,每存在一个点表示一个子目录 举例:com.baidu.demo 定义包后,包中的java ...

  8. centos更改mac

    centos 6更改mac vim /etc/udev/rules.d/70-persistent-net.rules

  9. 绿色安装MySQL5.7版本----配置my.ini文件注意事项

    前言 由于前段时间电脑重装,虽然很多软件不在C盘,但是由于很多注册表以及关联文件被删除,很多软件还需要重新配置甚至卸载重装. 使用MySQL时就遇到了这种情况,在修改配置文件无效的情况下选择了重新安装 ...

  10. 你有没有想过用电子表格也能做MES、WMS、SRM和MRP

    曾几何时,小微企业多半选择excel和WPS等电子表格,中小企业更喜欢选择用友金蝶和浪潮这样的国产大品牌软件,而大型企业则偏爱SAP.oracle这样的国外大品牌. 时至今日,风向却变了,品牌软件已不 ...