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

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

3天内不再提示

关于Segger J-Flash在Micron Flash固定区域下载校验失败的故事

痞子衡嵌入式 来源:痞子衡嵌入式 作者:痞子衡 2022-10-31 11:02 次阅读

痞子衡最近在支持一个 i.MXRT1170 欧美客户,客户项目里选用了来自 Micron 的四线 NOR Flash - MT25QL256ABA8E12-0AAT 作为启动设备,一般读写倒是没有问题,但是在 Segger J-Flash 下烧写遇到了特定区域内校验失败的问题。

从痞子衡过往丰富的 Flash 支持经验来看,亚太区客户一般选用 ISSI(芯成)/Winbond(华邦)/MXIC(旺宏)/GigaDevices(兆易创新) 的 Flash 比较多,痞子衡对这些厂商 Flash 可以说是门清了。这个欧美客户选用的是痞子衡不太熟的 Micron(镁光) 产品,借着这个问题,痞子衡带大家一起稍微深入地了解下 Micron Flash 产品:

一、引出客户问题

首先是复现下客户的问题,痞子衡找了块 MIMXRT1170-EVK 开发板,将板载其他厂商 Flash 换成这颗 MT25QL256ABA8E12-0AAT(因为是 T-PBGA24 封装,所以需要放到原来的 OctalFlash 位置 - U21),然后将 SDK_2.11.1_MIMXRT1170-EVKoardsevkmimxrt1170driver_examplesflexspi orpolling_transfer 例程稍作适配性修改,主要是将 customLUT 里的命令表按 Micron 数据手册命令表做调整(全用了四字节地址命令),然后跑了一下例程发现基本的 Flash 读写擦操作没有问题(默认操作的是 0x14000 处的 Sector),这表明硬件修改没有问题。

constuint32_tcustomLUT[CUSTOM_LUT_LENGTH]={
/*Fastreadquadmode-SDR*/
[4*NOR_CMD_LUT_SEQ_IDX_READ_FAST_QUAD]=
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_SDR,kFLEXSPI_1PAD,0xEC,kFLEXSPI_Command_RADDR_SDR,kFLEXSPI_4PAD,0x20),
[4*NOR_CMD_LUT_SEQ_IDX_READ_FAST_QUAD+1]=
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_DUMMY_SDR,kFLEXSPI_4PAD,0x0a,kFLEXSPI_Command_READ_SDR,kFLEXSPI_4PAD,0x04),

/*EraseSector*/
[4*NOR_CMD_LUT_SEQ_IDX_ERASESECTOR]=
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_SDR,kFLEXSPI_1PAD,0xDC,kFLEXSPI_Command_RADDR_SDR,kFLEXSPI_1PAD,0x20),

/*PageProgram-quadmode*/
[4*NOR_CMD_LUT_SEQ_IDX_PAGEPROGRAM_QUAD]=
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_SDR,kFLEXSPI_1PAD,0x34,kFLEXSPI_Command_RADDR_SDR,kFLEXSPI_1PAD,0x20),
[4*NOR_CMD_LUT_SEQ_IDX_PAGEPROGRAM_QUAD+1]=
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_WRITE_SDR,kFLEXSPI_4PAD,0x04,kFLEXSPI_Command_STOP,kFLEXSPI_1PAD,0x00),
};

接下来就是按客户操作流程来复现 Segger J-Flash 烧写校验失败问题,客户其实是尝试烧写全部 32MB 数据来查看 J-Flash 及其配套下载算法能否适用这颗 Flash,这里痞子衡就用 《超级下载算法RT-UFL v1.0》,经过测试,确实复现了客户的问题。

经过反复测试,定位了问题是这颗 Micron 32MB 的 Flash 前 3/4 区域(0x0 - 0x17FFFFF)是没问题的,但是在后 1/4 区域(0x1800000 - 1FFFFFF)均会出现校验错误(J-Flash软件里看擦写操作是能进行的,但后面发现其实根本没有正常擦写)。

6212c498-5783-11ed-a3b6-dac502259ad0.png

二、Micron QuadSPI NOR Flash有什么不同?

在分析客户问题之前,我们先来简单认识一下这颗 Micron NOR Flash,痞子衡浏览了 Micron 的官网以及这颗 Flash 的数据手册,发现它确实跟其他厂商的 NOR Flash 设计有点区别。

首先是 Flash 容量,其他厂商一般都是能够提供从 512Kb 到 2Gb 全范围的 Flash 产品,但是 Micron 串行 NOR Flash 最小容量就是 128Mb,果然是国际 Memory 大厂,设计就是豪横。但是从 Flash 作为 XIP 启动设备角度而言,128Mb 其实挺多的,普通的嵌入式项目没有这么大的代码存储需求。

62a7172e-5783-11ed-a3b6-dac502259ad0.png

其次是 NOR Flash 里的高频问题 《QE bit 设计》,一般 Flash 的 IO2/3 引脚复用功能都是通过内部状态寄存器里的 QE 位来控制,QE 关闭则 IO2/3 是 RESET#/HOLD#/WP# 功能:如果 QE 开启则 IO2/3 用于数据传输(这种情况下才可以用 Quad I/O 相关命令)。

然而 Micron Flash 根本就没有 QE 位控制,IO2/3 功能主要靠当前命令类型来决定:如果是 Single SPI 或者 Dual I/O SPI 命令,则 IO2/3 是 RESET#/HOLD#/WP# 功能;如果是 Quad I/O SPI 命令,则 IO2/3 用于传输数据。

其它设计上的区别就不再详细展开了,等用到具体功能查看数据手册再去了解对比。

三、找到问题原因

现在来分析客户问题,Flash 后 1/4 区域在 J-Flash 下校验错误,那我们先修改 polling_transfer 例程去操作 0x1800000 之后的 Sector,发现确实跑不过。如果不是 Flash 介质问题,也不是读写擦命令问题,那只能有一种解释,那就是 Flash 里这个区域被保护了,Flash 里是有非易失寄存器可以设置软件保护的,但是默认应该是全部区域不保护,而第一小节里我们先跑了 polling_transfer 例程验证 Flash 读写,那大概率这个例程里有修改 Flash 内部寄存器操作,经过排查痞子衡定位到了 flexspi_nor_enable_quad_mode() 函数。

#defineFLASH_QUAD_ENABLE0x40U

constuint32_tcustomLUT[CUSTOM_LUT_LENGTH]={
/*EnableQuadmode*/
[4*NOR_CMD_LUT_SEQ_IDX_WRITESTATUSREG]=
FLEXSPI_LUT_SEQ(kFLEXSPI_Command_SDR,kFLEXSPI_1PAD,0x01,kFLEXSPI_Command_WRITE_SDR,kFLEXSPI_1PAD,0x04),
};

intmain(void)
{
//代码省略

/*Enterquadmode.*/
status=flexspi_nor_enable_quad_mode(EXAMPLE_FLEXSPI);
if(status!=kStatus_Success)
{
returnstatus;
}

//代码省略
}

第二小节介绍里我们知道 Micron Flash 是没有 QE 位设计的,因此 flexspi_nor_enable_quad_mode() 函数在这里是多余的,这个函数是将 0x40 写入到了命令标号为 0x01 的 Status Register(这个操作适用于 ISSI Flash),我们在数据手册里找到这个寄存器定义,发现被置位的 bit 6 是块保护控制位 BP[3:0] 里的最高位,并且 BP[3:0] 设置是非易失性的(断电不丢失)。

62d29106-5783-11ed-a3b6-dac502259ad0.png

再进一步往下找 BP[3:0] 设置与 Flash 空间对应关系,发现 4'b1000 设置就是保护后 1/4 区域里的所有 block,至今似乎真相大白了。为了验证发现,我们需要将 Status Register 重设为 0x00,然后再用 J-Flash 烧写一次,这时候校验失败问题消失了,一切恢复正常。

6319ae38-5783-11ed-a3b6-dac502259ad0.png

回顾这个故事,如果痞子衡事先不用 polling_transfer 例程去操作一次 Flash,或者即使跑了例程但事先意识到了 Micron Flash 没有 QE 设计而删除 flexspi_nor_enable_quad_mode() 函数,也就无法复现客户问题了,这也是本次故事里最神奇的地方,客户和痞子衡犯了同样的失误,也许这就是缘分?






审核编辑:刘清

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

    关注

    31

    文章

    5336

    浏览量

    120230
  • SPI
    SPI
    +关注

    关注

    17

    文章

    1706

    浏览量

    91502
  • NOR flash
    +关注

    关注

    2

    文章

    90

    浏览量

    23003

原文标题:J-Flash在Micron Flash固定区域下载校验失败的故事

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

收藏 人收藏

    评论

    相关推荐

    如何使用J-Flash调试

    如何使用J-Flash调试
    发表于 11-08 17:29

    STM32入门系列教程之三《如何使用J-Flash调试》

    对初学者来说,要进行STM32 的程序下载调试,一般有三种方法:(1)使用SEGGER J-FlashJ-Link)下载程序到闪存中运行;
    发表于 11-04 15:17

    请问IAR下载程序与J-FLASH ARM的差别是什么?

    我发现IAR仿真程序与用J-FLASH ARM下载程序不同。之前我程序初始化时死循环起不了机,且其它参数都变化,用J-FLASH ARM重新下载
    发表于 03-12 08:08

    如何使用J-Flash软件烧录程序

    固件文件。Segger J-Link Plus以上版本仿真器或Flasher系列编程器产品的用户可免费使用该软件。本文将介绍如何使用J-Flash软件来烧录程序。1、打开J-Flash
    发表于 01-17 11:11

    J-flash arm是什么

    J-flash arm是单独的Flash ISP烧写软件,把单独的bin文件或者hex文件烧写到单片机的flash里面去,开发ARM9、ARM11的时候,对于已经批量生产的产品,在下
    发表于 07-16 06:02

    STM32单片机是怎样使用SEGGER J-Flash进行烧录的呢

    STM32单片机使用SEGGER J-Flash 烧录的方法1. 烧录环境需求硬件需求:电脑: 装有Windows 7 及以上的32位或64位操作系统的电脑烧录工具:J-Link V8 (硬件版本
    发表于 01-26 07:20

    AllinOne Flash Algorithm for J-Flash平台使用方法

    : J-Link_v9, J-Flash_v6.90, Keil_v5.31, Segger Embeded Studio_v5.4使用方法:(1)AllinOne
    发表于 09-28 16:07

    如何在Segger J-Flash中设置芯片初始化序列?

    许多微控制器烧录之前需要一个自定义的初始化序列来初始化目标硬件,例如初始化PLL时钟,关闭看门狗或定义Flash的等待状态。使用这些对初始化过程有特殊要求的芯片时,
    发表于 01-05 13:54

    STM32入门系列教程之三《如何使用J-Flash调试》

    对初学者来说,要进行STM32 的程序下载调试,一般有三种方法: (1)使用SEGGER J-FlashJ-Link)下载程序到闪存中运行
    发表于 06-01 14:54 1435次下载
    STM32入门系列教程之三《如何使用<b class='flag-5'>J-Flash</b>调试》

    jlink驱动下载SEGGER J-FlASH ARM应用程序免费下载

    segger j-flash arm是jlink调试工具的新驱动。本驱动J-link ARM V4.08l适合山寨版jlink v7 v8使用 ,不锁机不死机,xpwin7通用!SEGGER
    发表于 04-12 17:30 508次下载
    jlink驱动<b class='flag-5'>下载</b><b class='flag-5'>SEGGER</b> <b class='flag-5'>J-FlASH</b> ARM应用程序免费<b class='flag-5'>下载</b>

    如何使用J-Flash实现调试

    本文档讲述如何在芯达STM32 开发板上使用SEGGER J-Flash 下载HEX 文件。而其他两种方法,我们将在文档《如何使用MDK + J-Link 调试》、以及《如何使用STM
    发表于 04-21 13:08 9次下载
    如何使用<b class='flag-5'>J-Flash</b>实现调试

    STM32单片机使用SEGGER J-Flash 烧录的方法

    STM32单片机使用SEGGER J-Flash 烧录的方法
    发表于 12-02 10:21 20次下载
    STM32单片机使用<b class='flag-5'>SEGGER</b> <b class='flag-5'>J-Flash</b> 烧录的方法

    Segger J-Flash下烧写遇到特定区域校验失败的问题

    最近在支持一个i.MX RT1170欧美客户,客户项目里选用了来自Micron的四线NOR Flash - MT25QL256ABA8E12-0AAT作为启动设备,一般读写倒是没有问题,但是
    的头像 发表于 10-27 09:02 5380次阅读

    一个关于Segger J-FlashMicron Flash固定区域下载校验失败故事

    接下来就是按客户操作流程来复现 Segger J-Flash 烧写校验失败问题,客户其实是尝试烧写全部 32MB 数据来查看 J-Flash
    的头像 发表于 11-01 11:28 982次阅读

    如何在Segger J-Flash中设置芯片初始化序列?

    许多微控制器烧录之前需要一个自定义的初始化序列来初始化目标硬件,例如初始化PLL时钟,关闭看门狗或定义Flash的等待状态。使用这些对初始化过程有特殊要求的芯片时,
    的头像 发表于 12-12 10:56 2278次阅读