IAR下载算法制作

IAR下载算法制作

作者 Lucas
时间 2020-12-06 17:06:18

摘要

本文档主要介绍如何在IAR环境下制作QSPI下载算法。
本文使用到的硬件、软件如下

编译器:IAR 8.32
单片机:STM32H750VBT6
外部Flash:W25Q64

背景

我们为什么需要下载算法,下载算法是在哪里使用的?这是我们首先需要了解的问题。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8XuKbJzv-1607255762238)(./Pic/IAR下载流程.png)]

如上图所示,我们想通过C-SPY将固件直接下载到Flash是不被允许的,那我们怎么才能实现将固件下载进Flash呢?IAR官方文档《FlashLoaderGuide.ENU.pdf》告诉我们说,我们需要先将固件放在RAM缓存里面,然后通过一个名叫"Flash Loader"的小程序,将代码不断的从RAM搬运到Flash(这里的Flash可以是内部Flash,也是可以是外部Flash)。
上文中提到的"Flash Loader"就是需要我们针对不同的硬件去分别实现的代码,也就是所谓的Flash下载算法。

知识介绍

IAR下载算法一共包括4个文件(.out文件、.flash文件、.board文件、.mac文件)。

  1. .out文件是由"Flash Loader"代码生成的,里面包含了我们对QPSI管脚的定义,函数FlashInit()、函数FlashWrite()、函数FlashErase()的实现。
  2. .flash文件是一个XML文件,里面包含了一些必要的元素和一些不必要的元素,仅针对必要元素做一个简单介绍
  • exe:指向.out文件
  • flash_base:Flash的基础地址
  • page:Flash每页的大小
  • block:对应Flash有多少个扇区,每个扇区多大。(block元素对应Flash的扇区还是块,待考证)
  1. .board文件同样也是一个XML文件。可以由<pass> *** </pass>进行多个.flash文件设置。每个pass内包含了两个必要的属性
  • range:表面了Flash的起始地址及结束地址
  • loader:当前pass调用那个下载算法的路径
  1. IAR每次仿真下载完程序是从当前工程的main函数开始运行的。如果我们将代码下载到了0x90000000地址处,我们并没有开启内存映射,是不可以仿真的。这时候就需要采样.mac文件作为一个启动脚本,当程序仿真下载完成后,跳转到0x08000000处开始运行。在0x08000000处进行内存映射,然后马上跳转到0x90000000处,就可以进行仿真了。

制作思想

  1. 下载"Flash Loader"开源代码
  2. 创建一个空工程,将"Flash Loader"开源代码里面的文件添加到工程
  3. 完成函数FlashInit()、函数FlashWrite()、函数FlashErase()。
  4. 生成.out文件
  5. 制作.flash文件
  6. 制作.borad文件
  7. 根据需要制作.mac文件

制作流程

上面已经介绍了下载算法制作的一些基础知识及制作思想,下面我们正式开始动手制作下载算法。

  1. 下载FlashLoder开源代码,传送门。下载后的文件内容如下图所示
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DfFXNotZ-1607255762240)(./Pic/FlashLoader源码.png)]

“flash_loader.c”、“flash_loader.h”、“flash_loader_asm.s”、"flash_loader_extra.h"四个文件是供C-SPY调用的,我们不应该去修改文件内容。真正需要我们去修改的内容是"template"文件夹下的"flash_loader_ram.c"文件。

  1. 为了方便,我找到IAR安装路径(“C:\Program Files (x86)\IAR Systems\Embedded Workbench 8.3\arm\src\flashloader\ST”)下的"FlashSTM32H7xx_QSPI"文件夹,对这个文件内容进行更改。我们将"FlashLoder"代码添加进去,并添加相应的路径。(注:“flash_loader_ram.c"文件当前工程下被改名为"FlashSTM32H7xx_QSPI.c”)。

    • 补充FlashInit函数内容
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TpEk9nUY-1607255762243)(./Pic/FlashInit_C.png)]

    • 补充FlashWrite函数内容
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-LuPOf1vq-1607255762245)(./Pic/FlashWrite_C.png)]

    • 补充FlashErase函数内容
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-12uN4Idv-1607255762247)(./Pic/FlashErase_C.png)]

  2. 生成.out文件由三个需要注意的地方

    • 我们需要将代码下载到RAM里面执行,IAR->Option->Linker->Config配置如下
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uALPFKDF-1607255762248)(./Pic/Config配置.png)]

    • IAR->Option->Linker->Output配置的是输出.out文件的内容
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Mpu0mp3u-1607255762249)(./Pic/output.png)]

    • 当前工程没有main函数,程序运行的第一个函数将是FlashInit函数,对IAR->Option->Linker->Library配置如下
      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pzsQeSPk-1607255762249)(./Pic/library.png)]

  3. 制作.flash文件,如下图
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mQpCmTmK-1607255762250)(./Pic/FlashXml.png)]

  4. 制作.board文件,如下图
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-VAnRTsnJ-1607255762251)(./Pic/board.png)]

  5. 对于H750内存映射外部Flash还需要制作.mac文件,内容如下
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8lv7FdqU-1607255762252)(./Pic/MacXml.png)]

    文件内容就很好理解了,下载完成后,pc指针指向中断向量表的Reset_Handler函数,堆栈指针指向程序运行的首地址。这样每次程序仿真下载完成后,就从0x08000000处开始运行。我们可以把Boot程序放在这个地址,Boot程序里面进行内存映射,然后跳转到0x90000000处。

效果展示

我们制作好上诉四个文件过后,创建一个工程(该工程要运行在0x90000000处),对这个工程进行简单配置。

  • IAR->Option->Debugger->Download下,配置如下
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-MkuqUuKy-1607255762253)(./Pic/BoardUse.png)]

  • IAR->Option->Debugger->Setup下,配置如下
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AtH3xHSv-1607255762254)(./Pic/MacUse.png)]

  • IAR->Option->Linker->Edit下,配置如下
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SqaBtpjL-1607255762254)(./Pic/LinkUse.png)]

  • 在代码初始的地址,还需要加上中断向量表地址SCB->VTOR = 0x90000000;

做完上诉配置后,我们进行仿真下载,如下图所示,我们可以看到main函数已经存在与0x90003588处,并且可以进行仿真,说明我们配置是正确的。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JQ3pz2Oz-1607255762255)(./Pic/Main.png)]

将代码全速运行,可以看见串口显示正式我们程序设置的输出。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3rsBioAH-1607255762256)(./Pic/UsartShow.png)]

至此,关于IAR下下载算法的制作与验证就全部介绍完了。

参考资料

  • FlashLoaderGuide.ENU.pdf
  • EWARM_DebuggingGuide.ENU.pdf
  • FlashLoader源码

资料获取

链接:https://pan.baidu.com/s/1g69nFW3aUg2MKzLy1TtZBQ
提取码:4w2w
复制这段内容后打开百度网盘手机App,操作更方便哦–来自百度网盘超级会员V3的分享

评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Lucas_zgp

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值