jicheng0622

【原创】All in One i.MXRT1050/RT1020 SPI Flash Algorithm for J-Flash

1
阅读(270) 评论(0)

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

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

测试平台

开发板:i.MXRT1021_EVK, i.MXRT1050_EVK

SPI Flash: IS25LP64, GD25Q32, S26KS512(HyperFlash)

Tool: J-Link_v9, J-Flash_v6.90, Keil_v5.31

使用方法:

(1)从我的Github repo(https://github.com/jicheng0622/All-in-One-Flash-Algorithm-for-RT1050-RT1020)下载AllinOne Flash Algorithm for J-Flash代码工程并在Keil环境下分别选择FlashRT1020_SPINor和FlashRT1050_SPINor编译通过,此时可以在工程根目录下生成FlashIMXRT1020_SPINor.FLM和FlashIMXRT1050_SPINor.FLM算法文件(一个是针对RT1020系列,一个是针对RT1050系列);

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

(2)将两个Flash算法文件分别对应的拷贝到J-link安装目录下\SEGGER\JLink_V690\Devices\NXP\iMXRT102x和\SEGGER\JLink_V690\Devices\NXP\iMXRT105x文件夹里如下图:

RT102x_JlinkPath.JPG

RT105x_JlinkPath.JPG

(3)回到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);

(4)打开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配置字示例

image.png

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

DefaultOptions.png

       至此本篇文章算是结束了,大家如果针对此项目在使用过程中如果遇到什么问题可以到我的github respo.下提交issue或者发邮件给我交流(github项目里有我邮箱)。此外,这里跟AET博友说个事,从此篇文章开始,我除了像以往一样继续会把我的文章发布在AET上之外,也会同步在我的CSDN博客上发布,我不会跟AET主动说再见,但是需要开拓一个更大的平台去分享给更多的人,谢谢大家。未完待续~