查看: 3261|回复: 1

[分享] 在i.MX RT启动头FDCB里使能串行NOR Flash的QPI/OPI模式

[复制链接]
  • TA的每日心情
    开心
    7 天前
  • 签到天数: 301 天

    连续签到: 2 天

    [LV.8]以坛为家I

    3868

    主题

    7472

    帖子

    0

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    39223
    最后登录
    2025-7-18
    发表于 2022-9-22 15:12:19 | 显示全部楼层 |阅读模式
    在i.MX RT启动头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子序列都是以单线形式发送的(即只通过IO0来发送),我想你肯定也曾经觉得奇怪过,为何其他子序列都有1/2/4/8线模式可选,偏偏这个CMD子序列总是1线模式?

    其实这也不能怨CMD,毕竟所有的Flash传输时序都从CMD子序列开始的,后续子序列的Pad模式都是靠CMD命令码来区分的,为了保证CMD值能被正确获取,只能牺牲CMD序列的灵活性,就固定以单线形式发送,这也就是所谓的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模式下一模一样。
    11.png
    1.2 八线Flash的OPI模式
    下面是一款典型的八线Flash(旺宏 MX25UM51345)在OPI模式下的OCTA Read传输时序,此时CMD子序列仅在1个CLK内就完成了传输,因为SIO[7:0]均参与了CMD发送,效率是SPI模式下的8倍。后面的子序列与SPI模式下一模一样。
    12.png
    二、不同Flash厂商关于QPI/OPI切换设计

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

    2.1 四线 Flash 上切换设计

    QPI模式是四线Flash上一个性能模式特性,并不是所有 Flash 都支持这个特性。而对于支持QPI模式的Flash,不同厂商的切换设计也不太相同,不过大部分厂商都是选择发一个CMD命令时序来切换,比如芯成IS25WP128就是如下的时序进入和退出QPI模式:
    14.png
    找了几家市面上比较常见的四线 Flash,并整理了它们进出QPI模式命令码如下:
    15.png
    当然也有一些厂商不是发一个CMD命令时序来切换的设计,而是通过设置Flash内部寄存器的方式来做切换,比如赛普拉斯S25FS-S系列就是设置如下的寄存器来进入和退出QPI模式:
    16.png
    2.2 八线 Flash 上切换设计

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

    如下是旺宏 MX25UM51345 切换 OPI 模式的寄存器定义:
    17.png
    如下是镁光 MT35X 系列切换 OPI 模式(即 Octal 模式)的寄存器定义:
    18.png
    三、在i.MXRT1170-EVK上实战

    了解了上面关于QPI/OPI模式知识后,我们在恩智浦i.MX RT1170-EVK板子上实践一下。

    默认连接的Flash是IS25WP128,这款Flash是支持QPI模式的,我们随便在SDK包里找一个XIP例程,修改工程里evkmimxrt1170_flexspi_nor_config.c文件里的FDCB启动头如下,改完下载程序进Flash运行,代码执行效率应该会有所提升。
    1. #define CMD_LUT_SEQ_IDX_ENTER_QPI 7
    2. const flexspi_nor_config_t qspiflash_config = {
    3.     .memConfig =
    4.         {
    5.             // ... 默认设置省略
    6.             
    7.             // 使能 QPI 配置操作
    8.             .deviceModeCfgEnable = 1u,
    9.             .deviceModeType = kDeviceConfigCmdType_Spi2Xpi,
    10.             .waitTimeCfgCommands = 1,
    11.             .deviceModeSeq =
    12.                 {
    13.                     .seqNum   = 1,
    14.                     .seqId    = CMD_LUT_SEQ_IDX_ENTER_QPI,
    15.                     .reserved = 0,
    16.                 },
    17.             .deviceModeArg = 0,
    18.             .lookupTable =
    19.                 {
    20.                     // Fast Read Quad I/O LUTs (将 CMD_SDR 的 Pad 模式由 FLEXSPI_1PAD 改为 FLEXSPI_4PAD)
    21.                     [0]               = FLEXSPI_LUT_SEQ(CMD_SDR, FLEXSPI_4PAD, 0xEB, RADDR_SDR, FLEXSPI_4PAD, 0x18),
    22.                     [1]               = FLEXSPI_LUT_SEQ(MODE8_SDR, FLEXSPI_4PAD, 0x00, DUMMY_SDR, FLEXSPI_4PAD, 0x04),
    23.                     [2]               = FLEXSPI_LUT_SEQ(READ_SDR, FLEXSPI_4PAD, 0x04, 0, 0, 0),
    24.                     // 增加 Enter QPI 命令序列
    25.                     [4*CMD_LUT_SEQ_IDX_ENTER_QPI]     = FLEXSPI_LUT_SEQ(CMD_SDR,   FLEXSPI_1PAD, 0x35, 0, 0, 0),
    26.                 },
    27.         },
    28.     // ... 默认设置省略
    29. };
    复制代码
    关于OPI模式使能的例子可以直接参考MIMXRT500/600 SDK,因为其配套EVK使用的是旺宏MX25UM51345,所以官方SDK里启动头FDCB都是包含开启OPI模式的配置代码的。

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



    qiandao qiandao
    回复

    使用道具 举报

  • TA的每日心情
    开心
    昨天 20:17
  • 签到天数: 707 天

    连续签到: 1 天

    [LV.9]以坛为家II

    14

    主题

    2251

    帖子

    0

    金牌会员

    Rank: 6Rank: 6

    积分
    4339
    最后登录
    2025-7-18
    发表于 2022-9-23 09:25:01 | 显示全部楼层
    感谢分享,学习了
    哎...今天够累的,签到来了~
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 注册/登录

    本版积分规则

    关闭

    站长推荐上一条 /3 下一条

    Archiver|手机版|小黑屋|恩智浦技术社区

    GMT+8, 2025-7-18 14:04 , Processed in 0.091238 second(s), 23 queries , MemCache On.

    Powered by Discuz! X3.4

    Copyright © 2001-2024, Tencent Cloud.

    快速回复 返回顶部 返回列表