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

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

3天内不再提示

什么是QPI/OPI模式

恩智浦MCU加油站 来源:恩智浦MCU加油站 作者:恩智浦MCU加油站 2022-09-22 09:21 次阅读

我们知道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模式下一模一样。

bb410dce-3a12-11ed-9e49-dac502259ad0.png

1.2 八线Flash的OPI模式

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

bb9bc304-3a12-11ed-9e49-dac502259ad0.png

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

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

2.1 四线 Flash 上切换设计

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

bbd35b84-3a12-11ed-9e49-dac502259ad0.png

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

bc07bf3c-3a12-11ed-9e49-dac502259ad0.png

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

bc392c52-3a12-11ed-9e49-dac502259ad0.png

2.2 八线 Flash 上切换设计

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

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

bd96a96c-3a12-11ed-9e49-dac502259ad0.png

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

bdd3fec0-3a12-11ed-9e49-dac502259ad0.png

三、在i.MXRT1170-EVK上实战

了解了上面关于QPI/OPI模式知识后,我们在恩智浦i.MX RT1170-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模式的配置代码的。

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

    关注

    30

    文章

    5020

    浏览量

    117630
  • 数据
    +关注

    关注

    8

    文章

    6509

    浏览量

    87557
  • SPI
    SPI
    +关注

    关注

    17

    文章

    1610

    浏览量

    89539

原文标题:在i.MX RT启动头FDCB里使能串行NOR Flash的QPI/OPI模式

文章出处:【微信号:NXP_SMART_HARDWARE,微信公众号:恩智浦MCU加油站】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    【orangepi zero试用体验】之二:给OPI配合个壳,加装散热风扇

    这几天鼓捣了下OPI,开始安装了Debian,配置wifi,不太好使,温度也挺高的,后来下载了armbian,安装试用了一下,还可以。温度也不太高。这两天陆续安装了几个软件,先练练手,nmtui配置
    发表于 01-03 23:43

    一种低成本的 高速SRAM 替代解决方案

    就更贵了。这里介绍一种IPUS公司的串行PSRAM,由SPI/SQPI接口和OPI接口。 SPI/QPI接口最多6个信号脚,速度最高可达400Mbps或50MB/s OPI接口的由8个数据I/O,总共
    发表于 07-05 22:08

    如何在服务板上使用QPI总线的FPGA接口?

    嗨,我的项目想要研究在服务器主板上点击QPI信号的可能性。我注意到Xilinx 7系列有QPI接口解决方案,可能符合我的要求,尽管这可能是QPI接口的常用用途。我的问题是:如何在服务板上使用Q
    发表于 03-13 10:05

    art_pi_bootloader例程为什么启动时直接QPI模式

    各位前辈好,ART_PI 的 art_pi_bootloader 例程,为什么启动时直接QPI模式? W25Q64手册上是先进SPI模式谢谢
    发表于 09-02 11:31

    QPI模式下轮询NOR闪存的SR时HAL_QSPI_AutoPolling()失败了怎么处理?

    我正在使用带有 NOR 闪存(Winbond 的 W25128 芯片)的 STM32H750B。当芯片配置为QPI模式时。如果使用自动轮询功能轮询 SR1,则会抛出错误。但是直接读取 SR 并检查这些位是否有效。有什么帮助吗?谢谢。
    发表于 01-09 08:50

    STM32L476VGT6在QPI模式下发送命令的问题如何解决?

    我在 QPI 模式下使用带有外部闪存的 STM32L476VGT6 设备。一切正常,直到我尝试发送一个没有地址和数据的命令字节。例如,当我尝试发送命令 0xF5(退出 QPI 模式)时
    发表于 01-09 08:11

    OPI812-OP1815电路原理电路图

    OPI812-OP1815电路原理电路图
    发表于 07-01 11:21 1292次阅读
    <b class='flag-5'>OPI</b>812-OP1815电路原理电路图

    OPI812-OP1815开关时序电路及波形电路图

    OPI812-OP1815开关时序电路及波形电路图
    发表于 07-01 11:22 969次阅读
    <b class='flag-5'>OPI</b>812-OP1815开关时序电路及波形电路图

    Optekinc推出2Mbd传输速率的光隔离器OPI1268

    Optekinc推出2Mbd传输速率的光隔离器OPI1268 OPI1268高电压光隔离器数据传输速率高达2Mbd,以及具有2 kV的隔离。该器件将850nm的峰值波长GaAlAs LED光耦合到输出IC上光
    发表于 03-30 10:38 1246次阅读

    有源EMI输入滤波器 (QPI系列)

    有源EMI输入滤波器 (QPI系列) 的PDF
    发表于 01-06 18:03 0次下载

    QPI有源EMI输入滤波器

    QPI有源EMI输入滤波器 的 PDF 。
    发表于 01-06 18:00 0次下载

    有源EMI输入滤波器 (QPI系列)

    Avago Technologies有源EMI输入滤波器 (QPI系列)
    发表于 06-02 15:17 25次下载

    32mb串行闪存133mhz多I/O SPI和四I/O QPI DTR接口数据手册

    32mb串行闪存133mhz多I/O SPI和四I/O QPI DTR接口数据手册
    发表于 01-30 14:37 20次下载

    QPI-21LZ有源EMI滤波器的数据手册免费下载

    QPI-21有源EMI滤波器在150 kHz至30 MHz的CISPR22频率范围内衰减传导共模(cm)和差模(dm)噪声。该产品设计用于48伏直流母线(36-76伏直流)系统,具有100伏直流电
    发表于 09-19 08:00 3次下载
    <b class='flag-5'>QPI</b>-21LZ有源EMI滤波器的数据手册免费下载

    什么是开放平台逆变器(OPI)?

    什么是开放平台逆变器(OPI)? 功能强大、通用性强的逆变器硬件平台,配以灵活配置的即插即用软件
    发表于 09-06 15:14 194次阅读
    什么是开放平台逆变器(<b class='flag-5'>OPI</b>)?