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

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

3天内不再提示

i.MXRTxxx里FLEXSPI_MCR0寄存器保留位会造成IP CMD读写异常?

痞子衡嵌入式 来源:痞子衡嵌入式 2024-03-11 10:28 次阅读

一、引出NAND访问问题

痞子衡最近需要在恩智浦无线系列 SoC(RW612)上调试串行 NAND Flash 驱动,简单理解这颗芯片其实就是 RT600 + 多模无线 SIP 到一起,但是其 MCU 部分对 RT600 做了精简以及魔改。因为痞子衡对 i.MX RT 特别熟,所以自然想到先在 RT500/600 上调通串行 NAND Flash,然后再做简单移植就大功告成了,没想到被这么个想法坑惨了。

痞子衡手里早就有成熟的 RT1050 系列串行 NAND Flash 驱动(并不是基于官方 SDK 底层驱动),单从 FlexSPI 外设角度来看,RT1xxx 和 RTxxx 差异不太大,基本是兼容的,所以痞子衡很快就将代码从 RT1050 移植到了 RT500 上,工程编译几乎是一把过,然而在 RT500 上实测时却连 NAND 的 JEDEC ID 都无法正常读取,IP CMD 获取到的值永远是 0x0。

由于串行 NAND Flash 驱动代码在 RT1050 上得到过验证,所以其本身不存在逻辑问题,大概率问题还是出在 FlexSPI 外设配置上,于是痞子衡经过 RT1050 vs RT500 各种单元对比测试(此处耗费时间较长),最终发现是由 FLEXSPI_MCR0[7:6] 的配置值不同引起的。

二、关于LEXSPI_MCR0寄存器保留位

在 RT500 参考手册(Rev.2)以及 RT600 参考手册(Rev1.5)里查看 FlexSPI 模块的 MCR0 寄存器描述,会发现 MCR0[7:6] 是保留位,且复位默认值为 1。

1. RT500 手册描述来看,这两个保留位可读不建议写,且读回值应该是 0
2. RT600 手册对这两个保留位描述是 both bits must be written with ones.
d9558714-dddf-11ee-a297-92fbcf53809c.png

作为对比我们再查看一下 RT 四位数系列(如 RT1050)上相关描述,这两个位并不是保留位,其具体功能是决定访问 IP TX/RX FIFO 数据的方式是 AHB bus 还是 IP bus。默认值 1 表明只能从 AHB bus 访问 IP TX/RX FIFO,这个初始值设置其实稍微有点不合理,毕竟 AHB bus 已经有专用的 AHB TX/RX Buffer 传输数据了。

d95e827e-dddf-11ee-a297-92fbcf53809c.png

三、FLEXSPI_MCR0寄存器保留位测试

在 RT500/600 上 FLEXSPI_MCR0[7:6] 是保留位,那这个保留位到底是什么意思?到底是没有这个 ATDFEN/ARDFEN 相应功能,还是单纯不对用户开放而已,这里就需要做一个实验来验证。

痞子衡在 RT500-EVK 上用连在 FlexSPI PortA 上的那颗四线 NOR 做测试,我们尝试用 IP CMD 发 Read JEDEC ID 命令读取 2byte 数据,在 FLEXSPI_MCR0[7:6] 为默认 2'b11 的情况下,可以看到 FLEXSPI_RFDRx 寄存器全是 0,这意味着 IP bus 根本就没有触发 IP RX FIFO 工作。

d96eb090-dddf-11ee-a297-92fbcf53809c.png

将 FLEXSPI_MCR0[7:6] 设为 2'b00 再测一次,这时可以看到 FLEXSPI_RFDRx 寄存器里开始有数据了,IP bus 触发 IP RX FIFO 干活了。

d9735dd4-dddf-11ee-a297-92fbcf53809c.png

现在我们知道了,RT500/600 上 FLEXSPI_MCR0[7:6] 虽然是保留位,但是其 ATDFEN/ARDFEN 功能仍然是存在的。

四、SDK驱动处理方法

在官方 SDK 2.14 的 fsl_flexspi 驱动 FLEXSPI_Init() 函数里对于 MCR0 寄存器采取得是忽略初值直接整体赋值的初始化方式,其关于 ATDFEN/ARDFEN 位操作根据特性宏来做条件编译。这样的处理导致 RT500/600 上 FLEXSPI_MCR0[7:6] 永远被重置为 2'b00。例程测试结果上来看似乎没有问题,但是这里存在一定不合理的地方。

1. 在 RTxxx 头文件 FlexSPI 模块寄存器定义里没有 ATDFEN/ARDFEN 位信息,但有如下特性宏定义
  #define FSL_FEATURE_FLEXSPI_HAS_NO_MCR0_ARDFEN (1)
  #define FSL_FEATURE_FLEXSPI_HAS_NO_MCR0_ATDFEN (1)
2. 在 RT1xxx 头文件 FlexSPI 模块寄存器定义里有 ATDFEN/ARDFEN 位信息,无上述特性宏定义
d9801236-dddf-11ee-a297-92fbcf53809c.png

五、经验与教训

回到文章开头,痞子衡推荐的 MCU 外设寄存器谨慎赋值法在这个案例里就完全失效了。我们知道 MCU 外设寄存器有保留位是业界常规做法,但是保留位到底是无功能还是功能不开放,这个要看具体情况。如果应用代码是基于官方 SDK 底层驱动,那么可能不会遇到问题。如果你需要重写底层驱动,想手撕寄存器,那就要特别小心了,关于寄存器保留位的处理是值得深思的。




审核编辑:刘清

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

    关注

    146

    文章

    16022

    浏览量

    343676
  • 驱动器
    +关注

    关注

    51

    文章

    7319

    浏览量

    142984
  • 寄存器
    +关注

    关注

    30

    文章

    5036

    浏览量

    117762
  • SoC芯片
    +关注

    关注

    1

    文章

    535

    浏览量

    34478
  • Nand flash
    +关注

    关注

    6

    文章

    233

    浏览量

    39500

原文标题:是谁说MCU寄存器一定要谨慎赋值来着?

文章出处:【微信号:pzh_mcu,微信公众号:痞子衡嵌入式】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    芯片I2C通信异常无法读写寄存器破解

    时钟芯片PCF2129在批量生产过程中,有客户反馈出现PCF2129有0.2%左右芯片I2C通信异常,无法读写寄存器
    的头像 发表于 09-20 16:14 1.3w次阅读

    MCU外设寄存器谨慎赋值法

    今天给大家介绍的是改动i.MXRT1xxx里IOMUXC_GPR寄存器保留位可能会造成系统异常
    的头像 发表于 12-12 09:14 371次阅读
    MCU外设<b class='flag-5'>寄存器</b>谨慎赋值法

    ARM寄存器的总结

    ,CPSR,SPSR_und 0b11111 系统 PC,R14~R0,CPSR 3)其他 程序状态寄存器的其他
    发表于 07-19 21:20

    ARM寄存器的总结

    ,这些决定处理的工作模式,如表所示。3)其他程序状态寄存器的其他保留,用作以后的ARM核
    发表于 05-13 11:46

    关于RN8209寄存器读写相关问题

    关于RN8209寄存器读写相关问题
    发表于 07-12 16:33

    为什么改动i.MXRT1xxxIOMUXC_GPR寄存器保留造成系统异常

    为什么改动i.MXRT1xxxIOMUXC_GPR寄存器保留
    发表于 11-29 06:34

    i.MX RTxxx系列MCU的OTP介绍

    ) 痞子衡提到了OTP,部分Boot配置都存储在OTP memory,但是对OTP的介绍仅仅浅尝辄止,没有深入,今天痞子衡就为大家再进一步介绍OTP。  OTP是i.MXRTxxx
    发表于 12-16 07:49

    为什么调试NRF24L01时SPI读写寄存器失败呢

    为什么调试NRF24L01时SPI读写寄存器失败呢?是什么原因造成的?怎样去解决呢?
    发表于 12-17 06:21

    i.MXRTxxx系列ROM中灵活的串行NOR Flash启动硬复位引脚选择

    今天痞子衡给大家介绍的是i.MXRTxxx系列ROM中灵活的串行NOR Flash启动硬复位引脚选择。  关于 i.MXRT 系列 BootROM 中串行 NOR Flash 启动流程,痞子衡写过一
    发表于 12-21 06:34

    STM32F0 SPI寄存器读写操作问题都有哪些呢

    STM32F0 SPI 寄存器读写操作问题最近使用STM32F0做nRF芯片的读写,一如既往的HAL库+
    发表于 01-05 07:26

    在ARM嵌入式系统中访问CP15寄存器的指令

    在基于ARM的嵌入式应用系统中,存储系统通常是通过系统控制协处理CP15完成的。CP15包含16个32寄存器,其编号为0~15。访问CP15
    发表于 05-17 14:38

    CMPA/CFPA寄存器保留的值是强制的吗?

    我有一个关于如何在以下寄存器DCFG_CC_SOCU_NS_PIN 中设置保留的问题( 14:10,和DCFG_CC_SOCU_NS_DFLT(
    发表于 03-29 07:16

    痞子衡嵌入式:改动i.MXRT1xxx里IOMUXC_GPR寄存器保留位可能会造成系统异常

      大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是改动i.MXRT1xxx里IOMUXC_GPR寄存器保留位可能会造成系统异常。  痞子衡的嵌入式技术交流群里有一位非
    发表于 12-04 17:36 8次下载
    痞子衡嵌入式:改动i.MXRT1xxx里IOMUXC_GPR<b class='flag-5'>寄存器</b><b class='flag-5'>保留</b>位可能会<b class='flag-5'>造成</b>系统<b class='flag-5'>异常</b>

    CS,IP和PC寄存器

    CS寄存器IP寄存器:首先强调一下,这两个寄存器非常非常重要,CS的全拼为“Code segment”,即代码段寄存器,对应于内存中的存放
    发表于 12-17 18:31 2次下载
    CS,<b class='flag-5'>IP</b>和PC<b class='flag-5'>寄存器</b>

    一文了解i.MXRTxxx系列片内SRAM分区电源控制

    大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是从功耗测试角度了解i.MXRTxxx系列片内SRAM分区电源控制。
    的头像 发表于 07-07 09:58 720次阅读
    一文了解<b class='flag-5'>i.MXRTxxx</b>系列片内SRAM分区电源控制