2020年,这个给大家一种很漫长的恍惚感的一年,终于是过去了。这一年我们很多新的人生第一次就这么被发生了,第一次居家办公这么长时间(很多人肥膘都长了不少,我却瘦了2斤,不知是工作太积极了还是被家里小怪兽给折磨的),第一次戴口罩这么长时间(大大超过了前两年北方雾霾严重的时候),第一次大家见面打招呼可以调侃一句"核酸"了没(北京人回答:“阴着呢”),第一次学生和老师这两个角色在非培训班的时候要上网课(此处家长两行泪),第一次在外留学生这么想回国,第一次这么多国人吃瓜看美国大选(现在大家对美国的选举制度了解的比咱自己国家的还清楚),临末了(liao)还第一次听说于正和郭敬明知道道歉了(这上哪儿说理去,呵呵)。。。不管怎样,这个不平凡的一年算是过去了,未来可期,2021希望我们都能拨云见日看到风雨后的彩虹,对我个人来讲,期望新的一年家人身体健康最重要。下面且谈本篇正题(文末有新消息跟大家说):

在阅读此文之前强烈建议先通读一遍我在AllinOne Flash Alorigthm for IAR项目里的Readme以了解AllinOne的初衷以及原理机制,J-Flash的flash算法实现在原理上跟IAR下是一致的。此次把J-Flash和Keil下的flash算法也更新完之后,此AllinOne项目算是告一段落了,后面会在有需要的时候更新些功能或者修正用户反馈的bug,望大家在RT Design的路上无此忧,偶心足矣。。。

测试平台

Board: i.MXRT1021_EVK, i.MXRT1050_EVK

SPI Flash: IS25LP64, GD25Q32, S26KS512(HyperFlash)

Tool: J-Link_v9, J-Flash_v6.90, Keil_v5.31, Segger Embeded Studio_v5.4

使用方法:

(1)在AllinOne Flash Algorithm for J-Flash项目中我创建了两个算法工程,其中一个为Keil版本的CMSIS标准flash算法(生成.FLM算法文件),另外一个为Segger公司提供的Segger Embeded Studio版本的快速Flash算法(.elf算法文件),J-Flash两种算法都可以支持,只是道理大家都明白,毕竟J-Flash一套都是Segger自家亲儿子,Segger提供的那一套快速Flash算法模板,我移植过去之后亲测速度非常快,尤其是Verify过程(唰的一下,飞一般的感觉~),它使用了CRC校验的方法而非标准CMSIS的回读比对方式校验,效率提高了几倍不止,只是CRC校验方法Segger只提供了Segger Embeded Studio版本编译的静态库(Segger好心机啊。。。),所以我不得不单独创建了一个Embeded Studio算法工程;

(2)从我的[Github repo](https://github.com/jicheng0622/All-in-One-Flash-Algorithm-for-RT1050-RT1020)下载AllinOne Flash Algorithm for J-Flash两个代码工程(Keil版本和Segger Embeded Studio版本),看个人喜好选择其中一种(个人推荐后者,Embeded Studio虽然是后来之秀,但是我一直很盲目的崇拜和相信Segger,用起来的确很舒爽),选择分别选择FlashRT1020_SPINor和FlashRT1050_SPINor编译通过,此时可以在工程目录下生成FlashIMXRT1020_SPINor.FLM和FlashIMXRT1050_SPINor.FLM算法文件(Keil版本,路径根目录)或者FlashIMXRT1020_SPINor.elf和FlashIMXRT1050_SPINor.elf算法文件(Segger版本,路径\Output\FlashIMXRT1050_SPINor\Exe);

注意:Keil下的FLM算法文件与J-Flash下的FLM算法文件不能通用

(3)将Flash算法文件分别对应地拷贝到J-link安装目录下\SEGGER\JLink_V690\Devices\NXP\iMXRT102x和\SEGGER\JLink_V690\Devices\NXP\iMXRT105x文件夹里;

(4)回到J-link安装目录\SEGGER\JLink_V690路径下,用文本编辑工具(e.g Notepad++)打开JLinkDevices.xml文件,将RT1020和RT1050的flash算法路径信息添加到该文件里如下图(在Jlink_v6.90的xml文件里默认有RT1050的路径信息,只需要参考下图修改flash算法的名字即可,而RT1020的路径信息没有,它包含在Jlink的DLL动态链接库里,所以需要完整添加下图中关于RT1020的所有信息以覆盖DLL里的内容),为了方便大家拷贝添加信息我也把Jlink_v6.90里修改过的JLinkDevices.xml源文件一并上传到github代码仓库里(路径All-in-One-Flash-Algorithm-for-RT1050-RT1020/J-Flash);

重要提示:如果是Segger版本的话,记得把下图中的所有FlashIMXRT1050_SPINor.FLM和FlashIMXRT1020_SPINor.FLM后缀都改为FlashIMXRT1050_SPINor.elf和FlashIMXRT1020_SPINor.elf

(5)打开J-Flash工具创建新Project,在Target Device列表里选择RT1021或者RT1052,另外要注意的是i.MXRT系列默认的调试端口为SWD而非JTAG(使能JTAG调试需要提前烧eFuse配置才可以)。工程创建完毕之后,我们上述新添加的Flash烧写算法实际上已经被J-Flash先load进去了,此时如果是官方RT1021/RT1052_EVK默认板载Flash的话,我们把待烧写的bin/hex/srec文件拖到J-Flash工具里之后就可以点击菜单栏Target->Connect或者直接点击Target->Production Programming触发J-Link烧写image到目标芯片上了。

如何给J-Flash Flash烧写算法传入命令配置字

如我在AllinOne Flash Algorithm for IAR项目里的详细解释,该算法可以支持符合JEDEC-216A及以后版本直接烧写,因为QE bit即4线使能位可以通过SFDP命令读取出来,这样算法可以解析命令并自动把QE bit置位,而对于老版本的JEDEC216 SPI Flash(市面上很多常用的QSPI Flash仍然是该版本),flash算法无法自动获取QE的位置和对应的使能命令,此时就需要手动地给Flash算法输入一个Option0命令告诉它怎么去使能QE(至于如何获取不同JEDEC216 QSPI Flash的Option0命令请参考AllinOne Flash Algorithm for IAR项目里面的说明),此外如果外部QSPI Flash挂在RT1050的Secondary pinmux组上作为启动设备的话还要另外输入Option1命令。那在J-Flash里如何给Flash算法输入这两个参数呢?

我这里给了一种解决方案,点击J-Flash菜单栏Options->Project settings,在里面找到Init. steps,在里面添加如下图的4条命令,即在指定的memory address(0x20201000~0x20201010 RT1020/1050的OCRAM寻址空间)里输入Option0和Option1的标志和参数(0x4F707430位Opt0的ASCII码,另外之所以加标志判断是确保Opt0/1的value是我们输入的而不是OCRAM本身的不确定的值),然后在flash算法里添加对应的判断和解析处理,这样即可完成外部参数的输入了。

至此我们就完全实现了AllinOne Flash Algorithm for J-Flash的功能了,此时我们再点击Target->Connect或者Target->Production Programming即可触发J-Link对目标芯片的烧写了。实际上相比于IAR里的区别,J-Flash只是需要解决Option0和Option1的外部参数输入问题,下面我也是给出了几个常用的QSPI Norflash配置字的示例供大家参考。

常用QSPI Norflash配置字示例

当然如果是用户片外的SPI Flash型号固定不变的话,最简单的方式就是直接打开Keil Flash算法工程然后修改默认的Option0和Option1的配置,重新编译生成你想要的FLM算法文件之参考上面提到第(2)和第(3)步去做即可。

至此本篇文章算是结束了,大家如果针对此项目在使用过程中如果遇到什么问题可以到我的github respo.下提交issue或者发邮件给我交流(github项目里有我邮箱)。此外,此前一直坚守在AET博客里不愿动弹(jicheng0622-电子技术应用-AET-中国科技核心期刊-最丰富的电子设计资源平台),从此篇文章开始,我除了像以往一样继续会把我的文章发布在AET上之外,也会同步在CSDN博客和博客园上发布,希望在CSDN和CNBLOGs舞台上能把自己的knowledge分享给更多的人,谢谢大家。未完待续~

【原创】All in One i.MXRT1050/RT1020 SPI Flash Algorithm for J-Flash的更多相关文章

  1. 痞子衡嵌入式:深入i.MXRT1050系列ROM中串行NOR Flash启动初始化流程

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家分享的是深入i.MXRT1050系列ROM中串行NOR Flash启动初始化流程. 从外部串行NOR Flash启动问题是i.MXRT系列开发最 ...

  2. 【原创】i.MXRT J-Flash烧写算法使能eFuse熔丝位写入

    ​       临近年底,终于又憋了一篇文章出来,本来年初的时候是有计划把去年总结的一些东西整理下发布出来的,结果还是被工作和生活上各种琐事给耽搁了.哎,今年刚过了自己35岁的生日,眼瞅着这个人生节点 ...

  3. SPI总线

    一.概述. SPI, Serial Perripheral Interface, 串行外围设备接口, 是 Motorola 公司推出的一种同步串行接口技术. SPI 总线在物理上是通过接在外围设备微控 ...

  4. SPI协议及工作原理分析

    说明.文章摘自:SPI协议及其工作原理分析 http://blog.csdn.net/skyflying2012/article/details/11710801 一.概述. SPI, Serial ...

  5. STM32学习笔记(八) SPI总线(操作外部flash)

    1. SPI总线简介 SPI全称串行外设接口,是一种高速,全双工,同步的外设总线:它工作在主从方式,常规需要至少4根线才能够正常工作.SPI作为基本的外设接口,在FLASH,EPPROM和一些数字通讯 ...

  6. linux内核SPI总线驱动分析(一)(转)

    linux内核SPI总线驱动分析(一)(转) 下面有两个大的模块: 一个是SPI总线驱动的分析            (研究了具体实现的过程) 另一个是SPI总线驱动的编写(不用研究具体的实现过程) ...

  7. SPI协议及其工作原理详解

    一.概述. SPI, Serial Perripheral Interface, 串行外围设备接口, 是 Motorola 公司推出的一种同步串行接口技术. SPI 总线在物理上是通过接在外围设备微控 ...

  8. SPI协议及其工作原理浅析

    转载自:http://bbs.chinaunix.net/thread-1916003-1-1.html一.概述. SPI, Serial Perripheral Interface, 串行外围设备接 ...

  9. STM32F10X SPI操作flash MX25L64读写数据(转)

    源:STM32F10X SPI操作flash MX25L64读写数据 前一段时间在弄SPI,之前没接触过嵌入式外围应用,就是单片机也只接触过串口通信,且也是在学校的时候了.从离开手机硬件测试岗位后,自 ...

随机推荐

  1. Spring 04: IOC控制反转 + DI依赖注入

    Spring中的IOC 一种思想,两种实现方式 IOC (Inversion of Control):控制反转,是一种概念和思想,指由Spring容器完成对象创建和依赖注入 核心业务:(a)对象的创建 ...

  2. KingbaseES 如何查看应用执行的SQL的执行计划

    通过explain ,我们可以获取特定SQL 的执行计划.但对于同一条SQL,不同的变量.不同的系统负荷,其执行计划可能不同.我们要如何取得SQL执行时间点的执行计划?KingbaseES 提供了 a ...

  3. lombok Builder注解

    使用了@Builder 将会失去无参构造函数 可以通过 @Tolerate 来添加构造函数

  4. Linux云主机安全入侵排查步骤

    导语 经常有用户报障系统被植入恶意程序,如挖矿软件.ddos攻击病毒.syn映射攻击病毒等,可以按照以下流程为用户排查入侵病毒类型: 一.定位病毒进程 对于用户反馈云主机性能卡顿,CPU和内存占用较高 ...

  5. Sync包

    sync同步包 Mutex互斥锁: 能够保证在同一时间段内仅有一个goroutine持有锁,有且仅有一个goroutine访问共享资源,其他申请锁的goroutine将会被阻塞直到锁被释放.然后重新争 ...

  6. null和undefined的区别、数组和伪数组的区别

    null和undefined的区别 undefined: 字面意思是未定义的值,语义是希望表示一个变量最原始的状态,而非人为操作的结果.这种原始状态会在以下四个场景中出现: 声明了一个变量但没有赋值 ...

  7. ESX添加过时的硬件

    昨天遇到了个ESX上有旧的qlogic的FC卡无法识别的问题.无法识别也就无法连接存储,整个ESX就基本无法使用了.所以,需要检查硬件.一开始,在查了很多资料各种命令检查,走了很多弯路.这里我总结一下 ...

  8. 人脸识别、活体检测(眨眼、摇头、张嘴动作)clmtrackr

    人脸识别.活体检测(眨眼.摇头.张嘴动作)项目总结 项目需求 / 步骤实现描述: 1.申请摄像头权限,开始识别面部信息.同时开始录像 : 2.随机顺序生成面部检验动作: 3.并开始倒计时,需10s内完 ...

  9. 在Ubuntu 主机上使用 Cockpit 管理容器

    如果你管理着一台 Linux 服务器,那么你可能正在寻找一个可靠的管理工具.为了这个你可能已经看了 Webmin 和 cPanel 这类软件.但是,如果你正在寻找一种简单的方法来管理还包括了 Dock ...

  10. Keepalived + Nginx 实现高可用 Web 负载均衡

    一.Keepalived 简要介绍 Keepalived 是一种高性能的服务器高可用或热备解决方案, Keepalived 可以用来防止服务器单点故障的发生,通过配合 Nginx 可以实现 web 前 ...