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. Luogu3871 [TJOI2010]中位数 (平衡树)

    "#define int long long" 导致100pts \(\rightarrow\) 80pts #include <iostream> #include ...

  2. 基础1:JS的原型和原型链究竟

    JS的原型和原型链究竟是什么? 1. 从JS创建一个对象开始说起: 1.1 工厂模式创建对象 (缺点是无法知道创建出来的对象是一个什么类型的对象) function createPerson(name ...

  3. [CF1500C] Matrix Sorting (模拟)

    场上最后十几秒交上去过掉了耶! 题面 这里有两个 N ∗ M N*M N∗M 的 E x c e l \rm Excel Excel 表格 A A A 和 B B B. 我们知道 E x c e l ...

  4. java方法---可变参数

    可变参数 在方法的声明中,在指定参数类型后面加一个...(省略号) 一个方法中只能指定一个可变参数,它必须是方法的最后一个参数,任何普通参数必须在它之前声明:

  5. 【java】学习路径17-用户注册登录实例(Scanner)

    要学会使用接口.继承.多态.构造方法.包等知识编写出一个用户登录注册的事例.

  6. 第七十一篇:Vue组件的私有和全局注册

    好家伙, 1.组件的父子关系 我们封装三个组件,分别为left组件,right组件和App组件 在封装时: 在封装时,彼此的关系是独立的,并不存在父子关系 在使用时: 在使用时,根据彼此的嵌套关系,形 ...

  7. C#winform中使用Cef的ChromiumWebBrowser内嵌谷歌内核,调用前端js方法

    1.在winform中调用js方法: --调js中的方法无 入参形式 webBrowser1.ExecuteJavascript("logout()"); --调js中的方法给js ...

  8. [报错]-NameError: name 'NAN' is not defined

    部分数据输出为NaN,处理这部分异常数据使用isnan()函数 from math import isnan isnan(z) 参考: https://www.cnblogs.com/itdyb/p/ ...

  9. SpringBoot 配置文件使用详解

    一.创建一个SpringBoot项目 创建 SprintBoot 项目的 2 种方式: 在 https://start.spring.io/ 上创建一个 SpringBoot 项目,然后导入到 IDE ...

  10. .NET静态代码织入——肉夹馍(Rougamo) 发布1.2.0

    肉夹馍(https://github.com/inversionhourglass/Rougamo)通过静态代码织入方式实现AOP的组件,其主要特点是在编译时完成AOP代码织入,相比动态代理可以减少应 ...