痞子衡嵌入式:借助Serial Plot软件测量i.MXRT系列FlexSPI驱动Flash页编程执行时间
大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是i.MXRT系列FlexSPI驱动Flash页编程执行时间。
痞子衡之前写过一篇文章 《串行NOR Flash的页编程模式对于量产效率的影响》,简要分析了 NOR Flash 的 Page Program 命令不同模式对于整体量产时间的影响,文章仅从理论计算角度做了分析,假定了 Flash 中所有 Page 擦写表现都是一致的,但是每个 Page 的表现真的是完全一致吗?今天我们从一个客户问题出发来探讨下这个话题:
一、引入客户问题
最近有一个 i.MXRT1170 客户反馈,他们的应用程序里 IAP 功能代码对于 Flash 擦写表现不稳定。他们的 IAP 代码就是移植的 \SDK_2.10.0_MIMXRT1170-EVK\boards\evkmimxrt1170\driver_examples\flexspi\nor\polling_transfer 例程,Flash 选用得跟官方 EVK 上一样的型号 IS25WP128-JBLE,测试代码会把整个 Flash 的 16MB 循环擦除写入,反复进行测试,在测试过程中发现的部分区域表现速度较慢,这个慢的定义是在部分 256 字节(一个 Page)写入时,写入 API 返回时间较长(因为是轮询模式),但是返回状态是正确的。
由于客户并没有进一步给出 Page 写入快慢时间分别是多少,痞子衡只能先盲猜。既然写入 API 返回状态是正确的,那说明 FlexSPI 驱动是能正常工作的,先排除板级硬件设计问题。那么只剩下两种可能:一、FlexSPI 软件驱动执行稳定性问题;二、Flash 本身 Page 表现一致性问题。这两个问题都可以通过观察统计全部 Page 的写入时间来进一步确认。对于第二个可能性,从 Flash 手册里我们可以得知 Page 写入命令的等待时间典型值是 0.2ms,最大值是 0.8ms,但这个表述并没有明确这是针对不同 Flash 芯片而言,还是针对同一 Flash 内不同 Page 而言。
二、确定测量方案
带着上述疑问,痞子衡决定在官方 MIMXRT1170-EVK 上实测一下,我们仅需简单改造一下 \SDK_2.10.0_MIMXRT1170-EVK\boards\evkmimxrt1170\driver_examples\flexspi\nor\polling_transfer 例程,在 flexspi_nor_polling_transfer.c 源文件中 main() 函数里加入计时代码统计 flexspi_nor_flash_page_program() 函数执行时间即可,其中计时实现可用 https://github.com/JayHeng/microseconds 项目,具体用法参考 《通用微秒(microseconds)计时函数框架设计与实现》 一文。
// 保存 65536 个 Page 的写入 API 执行时间
uint16_t timeRes[65536];
int main(void)
{
// 省略原 Flash 初始化、擦除代码
microseconds_init();
#if !(defined(XIP_EXTERNAL_FLASH))
uint32_t startAddr = 0;
#else
uint32_t startAddr = 0x8000;
#endif
uint32_t endAddr = 0x1000000;
while (startAddr < endAddr)
{
// 计时开始
uint64_t startTicks = microseconds_get_ticks();
uint64_t endTicks = startTicks;
uint64_t deltaTicks = 0;
status_t status = flexspi_nor_flash_page_program(FLEXSPI1, startAddr, (void *)s_nor_program_buffer);
if (status == kStatus_Success)
{
// 计时结束
endTicks = microseconds_get_ticks();
deltaTicks = endTicks - startTicks;
uint16_t costMicroseconds = microseconds_convert_to_microseconds(deltaTicks);
timeRes[startAddr / 256] = costMicroseconds;
}
startAddr += 256;
}
for (uint32_t i = 0; i < sizeof(timeRes) /sizeof(uint16_t); i++)
{
PRINTF("%d\r\n", timeRes[i]);
}
while (1)
{
}
}
三、选一款串口波形显示软件
上一节代码中,我们把所有 Page 的写入时间都通过串口打印了出来,现在需要一款串口波形显示软件,来直观地看这 65536 个时间结果的差异。痞子衡试用了好几款软件:Serial Plot v0.12.0、Serial Chart V034、Serial Hunter V31,发现做得最完善的是 Serial Plot 软件,推荐给大家:
- Serial Plot 软件源码:https://github.com/hyOzd/serialplot
- Serial Plot 软件安装包:https://serialplot.ozderya.net/downloads/serialplot-0.12.0-win32-setup.exe
Serial Plot 软件做得最好的地方是对串口接收数据格式的完善支持,既可以是 Binary(单通道字节长度可设),也可以是 ASCII 码(通道间隔符可设),还可以是自定义数据帧(帧头、帧格式可设),通道数也可以任意设,基本上可以满足大部分串口波形显示需求了。
四、测试结果分析
准备就绪,给板卡通上电,将测试程序下载进去跑起来,打开 Serial Plot 设置好串口接收参数后观测结果,我们发现波形显示是一条直线,即 65536 个 Page 写入时间是稳定的,都是 271us(测试工程选择的是 debug build),这个结果推翻了我们之前的两个猜测,写入 API 执行时间是稳定的,Flash 的各 Page 表现也是一致的。后来跟客户进一步沟通,客户反馈他们是在 ThreadX 的 LevelX 中发现的,所以看起来客户问题和 ThreadX 系统调度有关,那就是另外一个话题了,以后再展开。
至此,i.MXRT系列FlexSPI驱动Flash页编程执行时间痞子衡便介绍完毕了,掌声在哪里~~~
欢迎订阅
文章会同时发布到我的 博客园主页、CSDN主页、知乎主页、微信公众号 平台上。
微信搜索"痞子衡嵌入式"或者扫描下面二维码,就可以在手机上第一时间看了哦。

痞子衡嵌入式:借助Serial Plot软件测量i.MXRT系列FlexSPI驱动Flash页编程执行时间的更多相关文章
- 痞子衡嵌入式:利用i.MXRT1060,1010上新增的FlexSPI地址重映射(Remap)功能可安全OTA
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是i.MXRT部分型号上新增的FlexSPI Remap功能. OTA升级设计几乎是每个量产客户都绕不开的话题,产品发布后免不了要做固件( ...
- 痞子衡嵌入式:在i.MXRT1170上启动含DQS的Octal Flash可不严格设Dummy Cycle (以MT35XU512为例)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是Octal或Hyper Flash上DQS信号与Dummy Cycle联系. 关于在 i.MXRT 上启动 NOR Flash 时如何设 ...
- 痞子衡嵌入式:在i.MXRT启动头FDCB里使能串行NOR Flash的QPI/OPI模式
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是在FDCB里使能串行NOR Flash的QPI/OPI模式. 我们知道 Flash 读时序里有五大子序列 CMD + ADDR + MO ...
- 痞子衡嵌入式:飞思卡尔i.MX RT系列MCU启动那些事(3)- Serial Downloader模式(sdphost/MfgTool)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RT系列MCU的Serial Downloader模式. 在上一篇文章 Boot配置(BOOT Pin, eFUSE) ...
- 痞子衡嵌入式:串口调试工具Jays-PyCOM诞生记(5)- 软件优化
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是串口调试工具Jays-PyCOM诞生之软件优化. 前面痞子衡已经初步实现了Jays-PyCOM的串口功能,并且通过了最基本的测试,但目前 ...
- 痞子衡嵌入式:飞思卡尔i.MX RT系列MCU启动那些事(13)- 从Serial(1-bit SPI) EEPROM/NOR恢复启动
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RT系列MCU的Serial EEPROM/NOR恢复启动. 在前几篇里痞子衡介绍的Boot Device都属于主动启 ...
- 痞子衡嵌入式:开源软件协议(MIT/BSD/Apache/LGPL/MPL/GPL)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家讲的是关于开源软件协议基本知识. 牛顿曾说过:"如果我比别人看得更远,那是因为我站在巨人的肩上".在软件开发中如果说也存在巨 ...
- 痞子衡嵌入式:恩智浦i.MX RTxxx系列MCU启动那些事(3)- Serial ISP模式(blhost)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是恩智浦i.MX RTxxx系列MCU的Serial ISP模式. 在上一篇文章 Boot配置(ISP Pin, OTP) 里痞子衡为大家 ...
- 痞子衡嵌入式:恩智浦i.MX RTxxx系列MCU启动那些事(8)- 从Serial(1-bit SPI) NOR恢复启动
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是恩智浦i.MX RTxxx系列MCU的1-bit SPI NOR恢复启动. 在前几篇里痞子衡介绍的Boot Device都属于主动启动的 ...
随机推荐
- 深入学习Composer原理(二)
本系列的第二篇文章,这次我们聊聊:spl_autoload_register()函数 PHP的SPL库作为扩展库,已经于5.3.0版本后默认保持开启,成为PHP的一组强大的核心扩展库.大家有时间可以多 ...
- 安装VM-TOOLS,解压tar包时提示目录磁盘空间不足
在虚拟机里安装了ubuntu-18.04.4-desktop-amd64,安装VM-TOOLS,解压tar包时提示目录磁盘空间不足. 解决方法一: 打开terminal,输入:sudo apt ins ...
- 整理常用的 vim 命令
vim 是一款功能强大的文本编辑器,它是Linux下常用的编辑器之一,对于熟练掌握了 vim 的人来说,用它编辑文件,方便又快捷,能极大的提高工作效率 vim 功能强大,对应的命令也非常的多,对于初学 ...
- Win10环境下多JDK切换以及could not find java.dll异常解决
备注:主要为JDK1.7和JDK1.8之间进行切换 1.每次进行JDK切换时,都需要修改JAVA_HOME 2.编辑path环境变量,如图所示,将%JAVA_HOME%\jre\bin和%JAVA_H ...
- Docker安装ElasticSearch5.6.8
前言 因实验室项目需要,准备docker安装个ES , 使用TransportClient练练手,然后死活连接不上 环境准备 系统:centos7 软件:docker ElasticSearch版本: ...
- 被校园网限速限流的日子 | 路由代理ipv6访问的操作手册
一 前 言 你是否还在为校园网的收费而小心翼翼?你是否还在为网速不够快而影响科研进程? 你是否还在为处理舍友关系而费经心思? 你是否还在为不能给舍友提供价值而苦恼? 那么,叶子团队或许能够帮助到你解决 ...
- 【C++ Primer Plus】编程练习答案——第12章
1 // chapter12_1_cow.h 2 3 4 #ifndef LEARN_CPP_CHAPTER12_1_COW_H 5 #define LEARN_CPP_CHAPTER12_1_COW ...
- JAVA 150道笔试题知识点整理
JAVA 笔试题 整理了几天才整理的题目,都是在笔试或者面试碰到的,好好理解消化下,对你会有帮助,祝你找工作顺利,收到满意的 offer . 1.Java 基础知识 1.1 Java SE 语法 &a ...
- 【原创】SystemVerilog中的typedef前置声明方式
SystemVerilog中,为了是代码简洁.易记,允许用户根据个人需要使用typedef自定义数据类型名,常用的使用方法可参见"define和typedef区别".但是在Syst ...
- Linux7安装redis6
首先下载软件包并解压 cd /opt wget https://download.redis.io/releases/redis-6.2.5.tar.gz tar -zxvf redis-6.2.5. ...