搜索
bottom↓
回复: 66

【原创】i.MXRT1050 从外部QSPI Nor Flash启动

  [复制链接]

出0入0汤圆

发表于 2018-3-13 23:50:00 | 显示全部楼层 |阅读模式
本帖最后由 FSL_FAE_JiCheng 于 2018-3-13 23:55 编辑

作者:  Ji Cheng
日期:  2018年1月 北京

版本历史:
V1.0(2018.01)  
初始版本,描述了RT105x从外部SPI Nor Flash启动的流程和基于官方EVK板载自带的Hyper Flash和QSPI Flash的IAR工程配置方法,最后给出了一种常用实例即代码跑在SPI Flash里,数据跑在SDRAM里;
V1.1(2018.02)  
加入Keil下对常用的GD和Winbond QSPI的Flash算法支持和工程配置;
V1.2(2018.03)
修正了1.0版本QSPI只能单线或者双线启动问题,最新的配置文件支持QSPI 4线制启动和XIP执行,另外新更新了IAR的Flashloader和Keil的Flash算法,可以同时支持ISSI QSPI和GD/Winbond QSPI Flash下载和调试.
         
      2018新年伊始,I.MXRT105x已经推向市场有一段儿时间了,以其极高的性价比引起了不少工业和消费领域客户的兴趣,毕竟相比于目前市场上已有的多数“高价低配”的高端ARM Cortex-M7产品,RT105x最高600MHz主频、极丰富的外设和3美金起步的定位着实算是业界良心了(还有马上要面世的LQFP封装I.MXRT1020更是让人期待),只是当然这种“低价高配”是有代价的,其内部不自带Flash需要外挂串行SPI Nand/Nor Flash或者并行的Nand/Nor Flash(貌似一下子给不少心动的人泼了凉水,呵呵),不过这一消息倒是有人欢喜有人忧,对欢喜的客户来说,他们的应用代码本身内部Flash就装不下需要外扩,这一下反倒好了,省的内心纠结了再也不用担心老板整天催自己优化代码精简应用看看能不能只用内部Flash搞定了,哈哈,而且动则几Mb或者几十Mb的外部SPI Flash价格便宜以后升级也是绰绰有余,而对忧的客户来说,外部Flash启动方式带来的启动配置复杂、代码安全性问题和对系统性能的影响等都是潜在的棘手问题。
       关于外部Flash的代码安全问题和代码在外部执行对整个系统性能的影响,RT105x的加密启动(HAB)功能和32KB的L1  ICache/DCache是可以解决的,只是本文先从RT105x的启动配置问题着手,毕竟系统如果都Boot不起来,其他的问题都是空谈了,呵呵。另外,如上面所说,RT105x支持的启动方式有不少,不过个人觉着外部串行SPI Flash启动会是大多数人的折中选择。由于RT105x的官方EVK板上是带有两块串行SPI Nor Flash(一个是Cypress高性能8线高速的Hyper Flash S26KS512SDPBHI02,一个是ISSI物美价廉的4线QSPI Flash IS25WP064AJBLE),所以咱就手上有啥来啥,以板载的Hyper Flash和QSPI Flash为例详细说明下串行SPI Nor Flash的启动流程和具体使用方法。
1. 串行SPI Nor Flash启动流程
    当RT105x EVK板载的Boot模式选择开关SW7设定为如下Table1-1所示的前两者时(其他BOOT_CFG 管脚默认被下拉到地,即OFF状态),系统会通过片上的FlexSPI接口执行外部串行SPI Nor Flash的启动,其启动地址为Table1-2所示的0x6000_0000(如果是从并行的Nor Flash启动则启动地址为0x8000_0000),关于其他Boot pin对启动模式的配置影响,见RT105x的RM手册8.6章节,这里就不细说了。

      如图1所示为完整的SPI Nor Flash启动流程图,当RT105x的片上ROM在检测到启动模式为FlexSPI接口后,会根据Boot Pin的配置信息配置该模式下需要使用的FlexSPI接口管脚的复用模式并将FlexSPI的时钟配置成默认的低速30MHz,然后会以0x6000_0000为首地址读取前512个字节作为外部Flash的配置信息(即Flash Configuration Parameters,包括几线制的SPI Flash,SPI的时钟频率,LUT查找表,DDR/SDR模式以及片选CS管脚的Hold/Setup Time等信息,见RM8.6.3章节)并以此来配置FlexSPI模块以满足外部Flash的特性,待配置完毕后,RT105x CPU以后即会以AHB总线读取数据和指令的方式(虽然从外部来看仍然是FlexSPI接口,但是由于LUT查找表读取数据的指令已经配置好,CPU只是通过AHB总线发送读取指令即可触发LUT以操作外部Flash,也就是说在内部对CPU来讲已经屏蔽掉了FlexSPI的底层)来读取接下来的跟用户Image相关的几个关键信息,即IVT(Image Vector Table),Boot Data和DCD(Device configuration data)如图2,其中IVT需要放在外部Flash的固定偏移地址(如图3,对Nor Flash来说其需要存储在基地址 + 4KB的偏移地址,比如0x60000000+4*1024)供ROM读取以便让系统知道用户Image的第一条可执行指令放在了哪里以及BootData和DCD的存放地址,BootData则保存了完整Image的首地址和整个image所占的空间大小,而DCD则包含了一些配置命令以便在跳到用户程序入口之前供ROM调用配置内部外设以更好的匹配外部IC,一般如果系统外挂了SDRAM的情况则需要配置好DCD(因为有时需要主程序在跑起来之前,外部SDRAM就得处在ready状态,以供CPU把data或者code copy到SDRAM里时不会出错)。

图1 SPI Nor Flash启动流程
  
图2 完整Image组成元素

图3 IVT针对不同存储介质的存放地址
    综上所述,我们实际上就可以得出结论来,如果要让系统能正常Boot起来,则烧写到外部串行SPI Flash里面的完整image必须要包括五个重要元素,即Flash Configuration Parameters,IVT,Boot Data,DCD和用户image,而其中Flash Configuration Parameters和IVT是存放在固定的地址的,而后三者则由IVT的内容来决定,无论是直接编译生成或者通过辅助工具手动添加,只要我们最后形成的image里面包含了这几个元素,CPU就会认可这个image并执行(先不谈安全加密的事)。所以我们只要搞清楚这个基本原理了,无论是什么方法,最后都是殊途同归,下面就可以放心大胆地去解决RT105x的FlesSPI启动问题了。
2. SPI Nor Flash启动配置方法
      前面提到如果想要RT105x能正常从外部串行SPI Nor Flash启动的话,待烧写的image是必须要集成五个元素的(Flash Configuration Parameters, IVT, Boot Data, DCD and User Image, 重要事情要多说几遍 呵呵),那具体的实现方法我目前想到的无非两种,一种是在编译链接过程中直接把这几个元素和应用代码链接到一块,并将这几个元素指定好链接地址,最后通过IDE的Flashloader下载到SPI Flash里,第二种则是通过辅助工具在编译链接好的裸应用代码前面手动的添加一个信息头(头里面包含这几个元素),然后通过单独的下载工具或者MCU内部的ROM Bootloader ISP下载进去。这两种各有优劣势,前者比较适合在前期调试的时候使用,这样在IDE里面编辑修改应用代码后做印证测试的时候可以直接在线download和debug(比如单步,断点,查看寄存器和Memory等等),我相信这也是目前大家比较迫切需要的,但是缺点的话则是前期配置过程稍微复杂些且需要对Boot过程和外部SPI Flash的Spec有一定了解(当然这些配置是一劳永逸的,配置一次即可),而后者则是客户不需要关心其他几个元素的配置只专注用户应用的开发,待开发完毕后通过辅助工具生成最终的Image用于小批测试或者量产,缺点是前期调试的话会比较麻烦,每次修改完重新编译生成用户image还需要用辅助工具手动添加信息头然后再通过Bootloader下载进去验证(我想想都有点累的慌。。。这种情况workaround只能是前期先在RAM里调试,待成熟了之后再走这个流程)。
      第二种使用辅助工具的方法,官方已经提供了一整套工具链(可以从RT105x官方主页的”Flashloader i.MX-RT1050”软件包里找到)且有了相应的AN应用笔记介绍其具体操作步骤,这里就不再赘述了。本次我们重点介绍第一种方法,即在IDE环境里通过对工程的配置达到生成并下载调试完整image的目的,说到这里我再啰嗦几句,实际上这种方法做下来不只方便了在线download和debug,好处也不少,一是所有的这几个元素配置信息都以C语言的常量形式体现在应用工程文件里面,会加深我们对Boot的理解程度不说,这样的话如果更换外部SPI Flash也可以很方便的更改适配信息,第二呢则是这种方式形成的image文件会是通用的image格式(比如.bin, .hex和.S19),也会兼容市面上大多数可以直接烧写SPI Flash的量产工具的批量烧写。好了,不再多说了,再说就有点话痨了,呵呵,因为板载有Hyper Flash和QSPI Flash两种,下面就分别详细说明下这两种Flash在IDE环境下的配置方法(我使用的IAR,Keil的可以参考第四章节自行配置,需要添加的几个文件是IAR,Keil和GCC三个环境兼容的)。
开发测试环境:
Hardware Platform: MIMRT1050-EVK (SCH-29538 REV A1)
Software Package: SDK_2.3.0_EVK-MIMXRT1050(mcuxpresso.nxp.com)
IDE: IAR_v8.20.1
Debugger: On-Board CMSIS-DAP
2.1 Cypress 1.8v Hyper Flash启动
       RT105x的EVK板子默认是使用Hyper Flash启动的,所以硬件不需要改动,只需要将SW7启动模式修改成Table1-1第一行配置使能Hyper Flash启动即可,如下图4,然后我们以SDK2.3中的hello world为例介绍具体配置方法。实际上在最新的SDK2.3里面Keil和MCUXpresso版本已经有针对Hyper Flash启动的hello_world_xip的样例了,只是IAR反倒是没有,不过这下正好我们来走一遍完整的配置过程,这样也可以为下一小节的QSPI启动打下基础(官方例程里是没有QSPI XIP例程的),毕竟大多数客户估计还是会倾向于选择QSPI的。

图4 Hyper Flash启动模式
(1)打开SDK2.3的hello world例程\boards\evkmimxrt1050\demo_apps\hello_world\iar,在Workspace下可以看到默认是有8种配置的,包括在SDRAM调试,OCRAM调试和spi nor Flash调试,原始的flexspi_nor_debug配置是没有其他几种元素的,所以这种配置下当把代码下进去外部Hyper Flash上的时候可以在线debug但是当重新上电或者外部复位后系统是Boot不起来的,因为没有其他元素信息RT1050启动的时候识别不了它的。接下来我们在此配置基础上新建一个配置出来然后在新的工程配置上添加文件和修改配置,点击IAR菜单栏Project->Edit Configurations,然后在打开的窗口下选择New,在新的工程配置下起一个新的名字“HyperFlash_bootok”,Base on Configuration则选择原有的flexspi_nor_debug以最大限度的保留原有的配置,改好之后点击Ok即当前工程会进入新添加的HyperFlash_bootok配置状态;



(2)在此工程配置下,新添加一个Group(右键工程->Add->Add Group)并命名为“xip”,然后右键该Group->Add->Add Files,找到根目录\devices\MIMXRT1052\xip路径下的四个文件,将该四个文件都添加到当前工程上来,如下所示,我们可以打开这两个.c文件即可看到除了User Image之外的其他四个元素信息都以常量的方式被定义在指定的段地址内,以便在编译链接之后将这几个元素配置信息分配到指定的地址上以保存在最终的Image上,且这四个文件是可以兼容IAR,Keil和GCC三大编译器的所以可以随意Porting,当然不要忘了在工程配置中头文件搜索路径上添加那两个头文件的路径,另外如果没有XIP_EXTERNAL_FLASH这个宏的话也要加上;


(3)由于四个元素被分别定义到指定的段内,但是默认的原始工程里面的链接文件是没有这几个段的定义的(Keil和MCUXpresso由于有xip的样例,它们是定义好的了),所以还需要在原始的链接文件基础上添加这几个段的定义并分配好地址,我们将原来的链接文件MIMXRT1052xxxxx_flexspi_nor.icf复制一份重命名为MIMXRT1052xxxxx_hyperflash_nor_bootok.icf(名字倒是无所谓),然后打开该文件,添加这几个段的定义和地址分配如下(修改好的源文件见随本文档附带的压缩包),然后在工程配置Options->Linker里选择新修改的链接文件,最后点击确认;



(4)不要以为这样就结束了,呵呵,我们这两步说到几个重要的元素信息是以常量的形式通过链接文件保存在指定的地址段内,不过我们的应用工程却没有调用它们,在编译的时候编译器会默认把他们又给优化掉了搞的最后没有体现在Image里面,前面的工作白搭了,所以还需要额外一步告诉编译器把这几个常量给Keep住,具体配置如下图,然后点击确认;

(5)这样工程配置就结束了,我们重新编译整个工程,然后在生成的.map文件里即可看到如下这四个元素信息都已经正确的分配到指定地址了,这样就万事俱备,就差IDE IAR的Flashloader这个“东风”了;

(6)在IAR v8.20.1以上的版本已经有HyperFlash的Flashloader了,我们在Options->Debugger选项下选择CMSIS-DAP,然后接下来需要注意的是在Options->CMSIS-DAP选项下,Reset类型需要选择Core Reset(CMSIS-DAP默认的Reset方式会导致调试的时候打不了断点,J-link倒是没有这个问题),然后点击Ok保持配置,最后开始Debug即可完美的把带有几个重要元素信息的配置数据都下载到外部Hyper Flash里面并进入Debug模式,正常单步或者断点,并且按键复位或者重新给板子上电都可以让RT105x正常Boot起来,最后有图有真相,发个串口打印的结果“hello world”, Enjoy it…


2.2 ISSI 1.8v QSPI启动
       上面说完Hyper Flash的启动方法,接下来继续说说QSPI启动。由于板子上的Hyper Flash和QSPI时钟、片选和部分数据线是共用的,所以在测试QSPI启动的时候需要把Hyper Flash焊掉(跟板子硬件设计有关系,不焊掉会影响时序,稍微有点心疼,毕竟Hyper Flash比较贵而且又是BGA的焊下来就焊不上去了,当然,如果是客户自己设计的板子只会有一种SPI Nor Flash,那就没这个问题了),然后将下图中DNP的0欧姆电阻焊上,最后特别注意的是需要在QSPI Flash的第7脚和3脚即Reset和WP管脚上拉4.7k的电阻到电源Flash_VCC。因为我发现有个别型号的QSPI Flash,比如板子用的ISSI这个,在系统启动的时候Reset和WP这两个脚是悬空态,而QSPI Flash默认上电都是单线方式,这样的话Reset和WP如果是低电平则QSPI一直处于复位和写保护状态,从而造成系统RT1050读取QSPI信息失败进而导致启动失败,所以需要在这两个脚上加个上拉电阻给它有效的高电平,后来我测试的QD和Winbond的QSPI这两个脚里面是有上拉电阻的,系统启动后是固定的高电平就没有问题了,不过我的建议是最好外部再加一个保证可靠,也不会影响后续的4线通信。另外,别忘了SW7启动模式需要修改成Table1-1第二行配置使能QSPI Flash启动,如下图5:


图5 QSPI Flash启动模式
(1)我们仍然以上面的hello world工程为例,有前面章节打基础,本章说起来就轻松不少了,在当前工程下,点击IAR菜单栏Project->Edit Configurations继续新建一个工程配置并以HyperFlash_bootok为蓝本将新的配置命名为“Qspi_nor_bootok”如下图,然后点击Ok进入该配置模式下;

(2)此时xip的Group文件组仍然有效,不过由于Boot的Flash类型发生了变化,所以需要修改外部SPI Flash的前512字节的Flash Configuration Parameters元素信息(其他几个元素无需修改)。打开fsl_flexspi_nor_flash.c文件,然后在hyperflash_config常量前面添加如下图Qspiflash_config的常量(修改后的源文件见随本文档附带的压缩包),实际上只是修改了外部SPI Flash的Pads类型、SPI时钟频率、Flash的大小(包括总大小以及page和sector的大小)和最重要的LUT查找表指令,这里我使用了外部QSPI Flash的四线Quad I/O Read模式(即0xEB),此模式下SPI的时钟频率可以跑到133MHz,总带宽可以达到532Mbps即66.5MByte/s(实际上很多MCU片内的Flash时钟也差不多这个频率甚至比这个低,不过内部的Flash线宽会大些),这个速度虽然相比于CPU 600MHz的主频慢很多,但是实际上RT1050的一级缓存ICache和DCache各有32KB且在程序里默认是打开的,实测下来对大部分代码来说外部SPI Flash的带宽几乎不会拖累CPU性能,针对特定应用的复杂代码留待大家自行测试(实测Opus音频编解码,跑在外部QSPI Flash上的性能大概为跑在内部SRAM上的70%~80%);

(3)上一步通过预编译QSPI_BOOT宏来使能QspiFlash的配置信息主要是为方便跟前面HyperFlash启动兼容,只需在当前工程配置下添加QSPI_BOOT宏即可,如下图所示,这样即使再跳回HyperFlash_bootok工程时也不必麻烦地来回修改Flash Configuration Parameters元素信息了,同时该工程配置下的链接文件由于各个段地址没有变化则不用修改,只是需要Keep的常量记得替换成Qspiflash_config,然后点击确认保存;


(4)此时整个工程的配置工作就完成了,点击Build完成对整个工程的编译和链接,查看.map文件也可以看到其他4个主要元素配置信息也都链接到整个image里了。不过接下来需要解决的是QSPI Flash的Flashloader问题了。在IAR For ARM v8.20.2以上的版本的Flashloader里已经加入了对QSPI Flash的支持了,但是该Flashloader只支持ISSI的QSPI Flash,我在此基础上做了修改和优化加入了对GD和Winbond QSPI Flash的支持,该新的Flashloader见随本文档附带的压缩包文件,将压缩包路径Firmware\IAR_8.20_Flashloader下的四个文件copy到IAR安装目录下C:\Program Files (x86)\IAR Systems\Embedded Workbench 8.0\arm\config\flashloader\NXP并覆盖源文件。此外,该修改后的Flashloader同时支持HyperFlash和QSPI Flash的download和debug(通过查询外部Boot模式来切换这两种烧写算法);

(5)一切准备就绪,在点击debug之前记得确认options->debugger下选择好CMSIS-DAP并且确保Reset类型必须要选择Core Reset,然后点击确认保存,最后debug将代码下载到外部QSPI Flash里并调试或者重新上电测试,hello world仍然让人激动不已,不容易啊不容易。

      上述两种外部SPI Nor Flash的启动配置方式仅仅是以hello world工程为例了,实际上大家可以参照如上几个步骤任意porting到SDK的其他工程实例里面去,而且由于SDK_2.3.0_EVK-MIMXRT1050\devices\MIMXRT1052\xip目录是共享的文件(包括Flashloader也是共享的),所以添加的那四个文件内容不需要再修改了,只需要手动添加文件到工程和配置IAR相关选项即可,操作起来还是比较快的。
3. 代码跑在SPI Flash数据跑在SDRAM的使用方法
      前面比较详细的讲了HyperFlash和QSPI Flash的启动方式,趁着兴致尚在我们再加点餐。我相信在很多客户开发RT105x过程中,将code跑在外部SPI Flash里,而数据存放在外部SDRAM里面会是比较常用的一种选择(比如一些会用到高分辨率的GUI显示方面,内部RAM不够用了)。虽然前面提到的xip那四个文件(两个.c和两个.h)里面的fsl_flexspi_nor_boot.c文件有定义dcd_sdram这个常量,不过很快就会发现这个常量数组里面的数据很大且看不出什么意义来(看不出意义就意味着不知道怎么修改),这是因为这个常量数组里面是编译后的可执行命令,它是根据不同的SDRAM编译后的结果,也就意味着不同的SDRAM这个数组是不一样的,这就尴尬了,客户如果不是使用EVK板载的SDRAM的话该怎么搞呢?哈哈,这个倒是不用担心,官方很快会推出一个辅助工具来生成不同SDRAM的DCD常量数组,不过在此之前我们也不能干等着吧,所以本章节的“加餐”就是提出一种workaround先提前解决下这个问题。
      我们要知道,在系统上电前无论代码还是数据都是存在SPI Flash这些非易失存储介质里面的,待上电后程序会有一个Copy过程将数据或者想要在RAM里执行的代码copy到RAM里面去,对内部RAM来讲无所谓(因为一上电内部的SRAM就已经初始化完成了)而对外部SDRAM来说是需要事先初始化RT105x的SDRAM控制器才能往该SDRAM可寻址的空间copy内容的。幸运的是在Copy之前我们是有段缓冲时间的,恰恰就是这段缓冲时间给了我们有可以不使用DCD配置的机会(实际上DCD也是ROM在跳到应用代码之前读取其内容对SDRAM进行初始化)。以IAR的启动代码为例,打开startup_MIMXRT1052.s文件找到CPU的起始入口Reset_Handler如下图,执行的Copy过程实际上是在__iar_program_start这个函数里面实现的(具体内容使用的是IAR自己的库),而在该函数之前(即在SystemInit函数里面)我们只需要将SDRAM初始化好让其Ready了就不会影响后续数据的copy和使用,所以下面我就简单介绍下具体操作方法。

(1)仍然是在当前hello world工程下,点击IAR菜单栏Project->Edit Configurations继续新建一个工程配置并以上面的HyperFlash_bootok为蓝本将新的配置命名为“flexspi_code_sdram_data”如下图,然后点击Ok进入该配置模式下;

(2)打开system_MIMXRT1052.c系统配置文件,也就是SystemInit函数所在的文件里面添加如下图所示SDRAM初始化相关的函数并在SystemInit的最后调用就可以在使用SDRAM之前将其初始化(具体修改后的源文件见随文档附带的压缩包),而且初始化函数均是以C语言形式读写配置SDRAM相关寄存器,这样的话即使SDRAM更换了也可以随时修改初始化寄存器配置以适配不同的SDRAM了,俗话说未知是最可怕的,而一旦都是开放的话就没那么难了。至于SDRAM这块的初始化是怎么找到的呢,实际上就是将SDRAM的预处理文件(当前目录下的evkmimxrt1050_sdram_init.mac)里面的命令用C语言实现了而已;


(3)由于仍然是为了兼容性问题,上面使用了预编译命令判断HYBERFLASH_SDRAM宏来决定是否初始化SDRAM,所以在当前工程配置下需要添加HYBERFLASH_SDRAM宏声明以使在当前工程配置下SDRAM初始化生效;

(4)然后需要修改下链接文件,将数据都分配到SDRAM地址范围内,将MIMXRT1052xxxxx_hyperflash_nor_bootok.icf复制后重命名为MIMXRT1052xxxxx_flexspi_code_sdram_data.icf,打开该文件,添加data3相关信息之后保存该链接文件,并在Options->Linker文件里选择新的链接文件(源文件见随文档附带的压缩包),点击确定保存配置;




(5)一切都修改完毕之后,点击编译链接,再打开.map文件即可看到所有的数据变量已经被分配到外部SDRAM的寻址空间里面了,最后再点击debug将代码下载到外部SPI Flash里面(注意SW7启动模式记得修改成HyperFlash启动,因为本例子演示的是code跑在HyperFlash里,数据跑在SDRAM里),这样就完美实现代码在SPI Flash里执行而数据跑在SDRAM里。当然,hello world本身没多少数据,大家可以把该功能照本宣科的poring到复杂一点的应用里面或者在当前工程里面自己memory alloc一段足够大的数据区,然后读修改写的去操作以测试该方法的可靠性,我这里就不多说了。

4. GD和Winbond 3.3v QSPI Flash启动
       在第2.2章节里我已经介绍了RT1050 EVK板载1.8v ISSI的QSPI Flash的启动方法,不过经过一段时间客户的反馈,实际上市面上常用的QSPI Flash目前以GD和Winbond的3.3v产品居多,物美价廉且采购渠道丰富,所以我特意增加了第4章用来专门介绍下GD和Winbond 3.3v QSPI Flash启动方法并修改优化了Keil下对这两家QSPI Flash的烧写算法供客户在keil下擦写和debug。
硬件上仍然是以我们官方RT1050的EVK板子为调试平台,在2.2章节的硬件改动基础上焊掉ISSI的QSPI Flash,换成GD的GD25Q32CSIG 3.3v QSPI Flash(3脚和7脚仍然上拉电阻到VDD),然后将下图中EVK板子R49的0欧姆电阻去掉,R301用0欧姆电阻短接,即将Flash电源由之前的1.8v改成3.3v,其他部分硬件与2.2章节保持一致,接下来我介绍Keil环境下的配置方法(前面的示例用的IAR,这次用keil让大家对IAR和keil下的开发配置都熟悉一遍):

(1)首先打开Keil下SDK开发包的hello_world_xip工程(路径demo_apps\hello_world_xip\mdk,Keil自带xip的工程),默认只有hello_world_xip Flexspi_nor_debug和hello_world_xip Flexspi_nor_release两个跑在板载HyperFlash的工程配置,点击Keil菜单栏Project->Manage->Project Items,我们新添加一个工程配置hello_world_xip Qspi_nor_debug如下图,然后选择该工程配置为当前工程,最后点击OK确认:

(2)在新建的工程配置里,右键工程Options->C/C++,添加QSPI_BOOT和XIP_EXTERNAL_FLASH这两个宏如下图1,然后打开工程目录下xip->fsl_flexspi_nor_flash.c文件,参考2.2章节中(2)点,手动添加QSPI的Flash Configuration Parameters元素信息如下图2,有一点不同的是我们官方板子的ISSI QSPI Flash的最高时钟可以到133MHz,而Winbond的QSPI最高到80MHz,GD QSPI最高到120MHz,我板子上自己焊了一块GD的GD32Q32CSIG QSPI Flash,所以将serialClkFreq设定为kFlexSpiSerialClk_100MHz,然后sflashA1Size改成4M Bytes;


(3)由于keil下自带了xip的工程,所以我们就直接复用其现成的.scf链接文件即可不用做修改,如下图Options->Linker。而且keil下也已经添加了Keep变量以防止xip这几个元素信息因为程序里没有调用而自动被编译器优化掉(注意:下图显示窗口有限,实际上要keep的信息段包括.boot_hdr.ivt,.boot_hdr.boot_data,.boot_hdr.dcd_data和.boot_hdr.conf,格式参考下图);

(4)至此我们编译整个工程,最后打开生成的.map文件如下图可以看到我们想要的几个QSPI启动必须的元素信息头都已经正确的分配到image文件里了;

(5)支持QSPI启动的完整image文件通过以上几步我们已经解决了,接下来要解决keil下download、Erase和debug需要的QSPI Flash烧写算法问题,本文档附带的压缩包文件里路径Firmware\Keil_Algorithm下MIMXRT_QSPIFLASH.FLM文件为我已经优化修改好的可以支持ISSI,GD和Winbond烧写的Flash算法,将其copy到keil安装路径下C:\Keil_v5\ARM\Flash即可,然后右键工程options->Debug-> CMSIS-DAP debugger,进入settings->Flash Download,点击Add找到如下图所示的MIMXRT_QSPIFLASH(4KB Sec),另外建议给Flash算法预留的RAM空间大一些否则可能会导致算法运行失败,因为这个flash算法比较占空间,我这里修改成了0x4000大小是没有问题的;

(6)设置完毕之后,我们再次重新编译整个工程,然后点击F8或者keil菜单栏Flash->Download即可完成对外部QSPI的擦除和写入,待烧写完毕之后我们点击debug即可正常调试(建议:如果程序做了修改,在编译之后进入debug之前先Download一次,再点debug),重新断电之后程序也可以正常启动运行。


写在最后:图片显示的有点大了,每个图片格式调整起来比较麻烦,本文最后的附件里我除了把文中提到的资料上传也放了一份PDF格式的文档供大家学习参考之,我一直秉承授人以鱼不如授人以渔,希望大家能对i.MXRT有更深的理解。

资料压缩包:

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

月入3000的是反美的。收入3万是亲美的。收入30万是移民美国的。收入300万是取得绿卡后回国,教唆那些3000来反美的!

出140入8汤圆

发表于 2018-3-14 00:01:09 | 显示全部楼层
楼主辛苦了,感谢楼主分享。

出140入8汤圆

发表于 2018-3-14 00:01:43 | 显示全部楼层
本帖最后由 leiyitan 于 2018-3-14 00:04 编辑

1050估计还要过一阵子,很多核心板才会出来。A0刚更新到A1,坐等大神们先找BUG…

出0入0汤圆

发表于 2018-3-14 00:33:57 来自手机 | 显示全部楼层
火前留名,楼主分析得很到位,学习了。

出70入145汤圆

发表于 2018-3-14 07:38:08 来自手机 | 显示全部楼层
谢谢楼主分享。

出0入0汤圆

发表于 2018-3-14 08:24:42 来自手机 | 显示全部楼层
收藏了,多谢楼主慷慨分享

出0入0汤圆

发表于 2018-3-14 09:01:22 | 显示全部楼层
飞思卡尔又回来了

出0入0汤圆

发表于 2018-3-14 09:02:01 | 显示全部楼层
收藏了,多谢楼主慷慨分享

出0入8汤圆

发表于 2018-3-14 09:04:39 | 显示全部楼层
FSL 又复活了?

出0入0汤圆

 楼主| 发表于 2018-3-14 10:59:30 | 显示全部楼层

灵魂依在。。。

出0入0汤圆

发表于 2018-3-14 17:01:39 | 显示全部楼层
1050的资料多起来了

出0入0汤圆

发表于 2018-3-14 17:03:08 | 显示全部楼层
收藏了,多谢楼主慷慨分享

出0入25汤圆

发表于 2018-3-14 17:11:20 | 显示全部楼层


虽然是NXP收购了FSL,,但似乎NXP现在主推FSL的单片机,,看下图Kinetis在LPC前面,,

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

出50入58汤圆

发表于 2018-3-14 18:13:27 来自手机 | 显示全部楼层
XIVN1987 发表于 2018-3-14 17:11
虽然是NXP收购了FSL,,但似乎NXP现在主推FSL的单片机,,看下图Kinetis在LPC前面,,

...

nxp不是被高通收购了吗

出0入0汤圆

发表于 2018-3-14 18:24:01 | 显示全部楼层
更想知道实测性能损失了多少呢?

出0入0汤圆

发表于 2018-3-14 19:02:00 来自手机 | 显示全部楼层
RT的设计者估计不懂啥叫用户体验,坐等大家玩熟这个片子

出0入114汤圆

发表于 2018-3-14 21:15:28 来自手机 | 显示全部楼层
加一个内部的flash就厉害了

出0入0汤圆

发表于 2018-3-15 08:51:40 | 显示全部楼层
为了看这个帖子,硬是开了会员

出0入0汤圆

发表于 2018-3-15 08:55:54 | 显示全部楼层
你好,请问您的v1.0版本哪里可以看到

出0入0汤圆

发表于 2018-3-16 14:07:28 | 显示全部楼层
为什么RT1052有些例程只能debug,有些可以load呢????这个是由什么决定的啊??????

出0入53汤圆

发表于 2018-3-17 05:34:12 来自手机 | 显示全部楼层
坐等你们玩的成熟了

出0入147汤圆

发表于 2018-3-17 14:44:31 来自手机 | 显示全部楼层
这种方式CPU还能跑到600Mhz?

出0入0汤圆

 楼主| 发表于 2018-3-17 16:18:37 | 显示全部楼层
yangxijun 发表于 2018-3-16 14:07
为什么RT1052有些例程只能debug,有些可以load呢????这个是由什么决定的啊??????
...

目前官方SDK的代码,大部分的demo代码只添加的RAM里调试,所以这些只能debug,而比如hello world的demo添加了在外部SPI Nor Flash的配置,可以load。可以参照helloworld代码的配置在其他代码里添加外部Flash的配置就可以load了。

出0入0汤圆

 楼主| 发表于 2018-3-17 16:22:41 | 显示全部楼层
dreampet 发表于 2018-3-17 14:44
这种方式CPU还能跑到600Mhz?

CPU都有cache的啊,即使内部有Flash的芯片,CPU主频一两百MHz的,其Flash的时钟也是几十M而已,都是通过cache的啊(叫法不一样,有些叫闪存加速器),不然L1,L2的cache是干啥的,手机CPU动则2个GHz的,DDR或者EMMC主频也跟不上。

出0入0汤圆

 楼主| 发表于 2018-3-17 16:23:15 | 显示全部楼层
zishan 发表于 2018-3-14 18:24
更想知道实测性能损失了多少呢?

文中有提到

出0入0汤圆

发表于 2018-3-17 16:56:11 | 显示全部楼层

楼主辛苦了,感谢楼主分享。

出0入0汤圆

发表于 2018-3-17 21:07:24 | 显示全部楼层
正需要此资料,楼主雪中送炭,谢谢

出0入0汤圆

发表于 2018-3-22 14:04:27 | 显示全部楼层
好贴,必须收藏

出0入16汤圆

发表于 2018-3-29 16:31:54 | 显示全部楼层
按照说明改了之后使用 IAR板载的DAP下载器,想实现在hyperflash运行但是调试时显示 Flash loader: Failed to setup call to 'FlashInit'" 错误是什么原因,查了好久找不到问题所在。

出0入0汤圆

发表于 2018-3-29 17:07:25 | 显示全部楼层
1052资料越来越多了,期待

出0入0汤圆

发表于 2018-4-2 09:12:39 | 显示全部楼层
建议楼主高亮一个事情,就是EVKB的板子,已经不再需要把Hyper Flash吹掉了,只需要在板子上切换电阻了。

出180入85汤圆

发表于 2018-4-2 10:51:10 | 显示全部楼层
感谢楼主的用心了,真的很及时。

出0入0汤圆

发表于 2018-4-4 15:58:31 | 显示全部楼层
楼主用心, 请教一下附件中的"MIMXRT_QSPIFLASH.FLM"是如何生成的,可否提供相应的工程源文件.

出0入54汤圆

发表于 2018-4-13 19:41:09 | 显示全部楼层
请教楼主
我现在拿周立功的板子调试,SDRAM的debug和release可以的,但现在Nor的不行,会停在flashloader画面,目前他们板子上用的是MXIC的芯片,IAR8.20是默认不支持这个芯片吗?试过J-link V9不行,再特地买了个DAP,还是不行。

出0入0汤圆

发表于 2018-4-21 09:59:23 | 显示全部楼层
现在i.mxrt火的一塌糊涂

出0入18汤圆

发表于 2018-4-21 11:15:20 | 显示全部楼层
真的 不明白 放点 flash 会死呀,真的 很麻烦,从LPC4330 走过来!巨坑!

出0入0汤圆

发表于 2018-4-21 11:47:48 来自手机 | 显示全部楼层
辛苦了,继续加油,我还有很多不会的

出0入0汤圆

发表于 2018-4-21 13:07:11 | 显示全部楼层
下来试试

出0入0汤圆

发表于 2018-4-21 13:54:55 来自手机 | 显示全部楼层
fsl商业论坛又回来了?

出0入0汤圆

发表于 2018-4-21 15:30:18 | 显示全部楼层
好东西,准备买一个正点原子的玩玩。

出0入0汤圆

发表于 2018-4-23 20:26:17 | 显示全部楼层
好东西,绝对是精品级别

出0入0汤圆

发表于 2018-5-12 17:41:53 | 显示全部楼层
学习了谢谢!

出0入0汤圆

发表于 2018-5-13 08:19:48 来自手机 | 显示全部楼层
现在rt1052系列的开发板似乎火了起来,还是这个单片机便宜?

出0入0汤圆

发表于 2018-5-26 21:45:01 | 显示全部楼层
内部只有512K的RAM还要进行指令、数据分配,真的很麻烦!

出0入0汤圆

发表于 2018-5-27 21:30:55 | 显示全部楼层
顶,学习一下

出0入10汤圆

发表于 2018-5-29 13:19:42 | 显示全部楼层
望楼主多现身,多发这样的有用帖子

出0入0汤圆

发表于 2018-5-29 15:14:34 | 显示全部楼层
要是再来个“中兴事件”,会咋整啊?

出0入0汤圆

发表于 2018-6-4 14:25:47 | 显示全部楼层
一直在关注rt1050,说这个可以跑linux?不知道是不是真的

出0入0汤圆

发表于 2018-6-26 10:37:09 | 显示全部楼层
好帖,期待更多精品

出0入0汤圆

发表于 2018-6-26 14:18:09 | 显示全部楼层
楼主 请问一下 如何使用 MCUxpresso 通过jlink 烧写 挂载在 rt1052  qspi上的 w25q64

出0入25汤圆

发表于 2018-6-30 17:12:04 | 显示全部楼层
好帖,,感谢楼主!!

出0入0汤圆

发表于 2018-7-3 09:27:06 | 显示全部楼层

你好,请问那个Qspi flash的算法怎么写出来的???

出0入0汤圆

发表于 2018-7-3 17:15:56 | 显示全部楼层
可以发一个写Qspi flash 算法的源码给我吗?

出0入0汤圆

发表于 2018-7-4 10:04:01 | 显示全部楼层
收藏了,感谢分享。

出0入0汤圆

发表于 2018-9-15 15:07:39 | 显示全部楼层
支持一下,不错的文章。

出0入0汤圆

发表于 2018-9-15 19:46:45 | 显示全部楼层
记录一下

出0入8汤圆

发表于 2018-9-27 22:13:54 | 显示全部楼层
最近正在做FLASH加载的东西,刚需,谢谢分享

出0入0汤圆

发表于 2018-9-27 23:33:43 | 显示全部楼层

收藏了,多谢楼主慷慨分享

出0入0汤圆

发表于 2018-10-4 17:18:52 | 显示全部楼层
学习了!

出0入0汤圆

发表于 2018-11-3 16:43:09 | 显示全部楼层
成哥威武,FSL的崛起靠你了

出0入0汤圆

发表于 2019-1-4 16:23:39 | 显示全部楼层
rt1050的低功耗问题如何解决?

出100入0汤圆

发表于 2019-1-4 21:13:52 | 显示全部楼层
mark mark mark

出0入0汤圆

发表于 2020-2-28 10:07:39 | 显示全部楼层
mark  留着参考

出0入0汤圆

发表于 2020-3-28 20:50:31 | 显示全部楼层
非常感谢

出0入0汤圆

发表于 2020-4-13 13:49:33 | 显示全部楼层
谢谢楼主分享。

出0入0汤圆

发表于 2022-4-23 18:25:53 | 显示全部楼层
收藏了,感谢

出0入31汤圆

发表于 2022-8-7 13:46:23 | 显示全部楼层
似乎都是XIP,Non XIP是太简单还是怎么其它什么原因几乎找不到文档,
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-24 14:58

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表