浅析Keil MDK下串行Flash的下载算法设计

浅析Keil MDK下串行Flash的下载算法设计-电子发烧友网

今天给大家介绍的是 Keil MDK 工具下 i.MXRT 的串行 NOR Flash 下载算法设计。

在 i.MXRT 硬件那些事系列之《在串行 NOR Flash XIP 调试原理》一文中,痞子衡简单提了一下串行 NOR Flash 下载算法的概念,并没有介绍具体设计细节,关于 NOR Flash 下载算法每个 IDE/ 工具都有自己的一套设计,虽然基本设计理念是一样的,但是细节方面还是有区别。上一篇痞子衡介绍了《J-Link 下算法设计》,今天痞子衡就来细聊 Keil MDK 下的 NOR Flash 下载算法:

一、Keil MDK5 对 i.MXRT 的支持

Keil μVision 可以说是 MCU 开发者最熟悉的 IDE 了,大部分人刚开始入行嵌入式学 MCS-51 系列单片机应该都是用得 Keil C51 环境(Keil μVision2),早期的 Keil 还只是一个小型的独立软件公司。2005 年 ARM 收购了 Keil,并于 2006 年集成了 RealView 编译器开始支持 ARM Cortex-M 处理器,这便是后来的 Keil MDK(Keil μVision3)。

2013 年 Keil μVision5 发布,与 Keil MDK4 及之前版本不同,Keil MDK5 分成 MDK Core 和 Software Packs 两部分。MDK Core 主要包含 uVision5 IDE 集成开发环境和 ARM Compiler5。Software Packs 则可以在不更换 MDK Core 的情况下,单独管理(下载、更新、移除)设备支持包和中间件更新包。

因此首次安装的 Keil MDK5 并没有直接支持 i.MXRT,需要通过 Software Packs 组件来单独安装 i.MXRT 的相关软件支持包。

二、使用 Pack Installer 添加新 i.MXRT 型号支持

Keil MDK5 里默认集成了 Pack Installer,在 IDE 里可以直接打开其界面,手动添加所需的 MCU 主控相关软件包。软件包主要有两个:Device Family Pack (DFP)和 Board Support Pack (BSP) ,前者是对 MCU 芯片本身的支持,后者是对 MCU 开发板的支持。

如果你不主动安装 MCU 软件包也行,当你打开 SDK 里的任何一个例程(以 i.MXRT1060 为例),如果该例程对应的 MCU 软件包没有安装,IDE 会自动触发 Pack 的安装。DFP 是必须要安装的,BSP 要看你具体使用哪块板卡,痞子衡用得官方 i.MXRT1060-EVK,因此还需要再手动安装 NXP::EVK-MIMXRT1060_BSP:

安装完 MCU 软件包后,便可以正常编译 SDK 工程,然后在 Flash 下载和调试了。痞子衡使用的是恩智浦官方 EVK,板子上自带了 DAPLink 调试器,当然除了板载调试器,我们也可以外接 J-Link 调试器,在 MDK 工程选项里无论选择哪种调试器,其默认 Flash 下载算法是一样的,都来自于 DFP 包(/Keil_Packs/NXP/MIMXRT1062_DFP/12.2.0/arm/MIMXRT106x_QSPI_4KB_SEC.FLM)

如果默认选择的 Flash 下载算法文件不适用你的板子,那么你需要自己提供合适的算法文件(.FLM),并将其放入 MDK 安装目录下(/Keil_v5/ARM/Flash),重新打开工程选项,新增的算法会自动刷新到待选算法列表(还有另一种添加方式,即做一个完整的 DFP 包,包里包含下载算法,虽然 ARM 写了详尽的文档,但这种方式更适合芯片原厂去做):

搞定了合适的下载算法文件,最后还需要检查下两个地址范围,一个是 Flash 对应的实际映射地址空间,另一个是下载算法文件运行 RAM 地址空间。这点跟上一篇介绍的 J-Link 算法 JLinkDevices.xml 文件里需要填的两个地址空间设计是一致的。

三、NOR Flash 下载算法设计

Keil MDK 下 Flash 下载算法是开源的,有较详细的文档,文档在 arm-software 的 github 主页,根据这些文档,我们基本可以了解其下载算法设计细节。

算法主页:https://arm-software.github.io/CMSIS_5/Pack/html/flashAlgorithm.html

3.1 下载算法模板工程

Keil MDK 提供了一个 Flash 下载算法的基础模板工程,工程在 /Keil_v5/ARM/Flash/_Template/NewDevice.uvprojx,该工程仅支持 MDK(不支持 MDK-Lite)编译,除了工程设置外,该模板工程仅包含四个文件:

/Keil_v5/ARM/Flash/FlashOS.h
/Keil_v5/ARM/Flash/_Template/FlashDev.c
/Keil_v5/ARM/Flash/_Template/FlashPrg.c
/Keil_v5/ARM/Flash/_Template/Target.lin

拿到基础模板工程,我们需要根据目标 MCU 内核类型在工程选项里将默认的 ARMCM0 内核改掉,然后在 FlashDev.c 和 FlashPrg.c 里将算法 API 函数全部实现(默认是空的),最后编译工程生成 .FLM 即是我们要的算法文件(最终 .FLM 其实是通过 After Build 里的脚本命令将 .axf 直接改名的,FLM 文件本质上就是 axf 格式文件)。

3.2 下载算法结构设计

算法本身结构其实很简单,在 FlashDev.c 文件中有一个名为 FlashDevice 的结构体常量,其原型定义在 FlashOS.h 中。该结构体主要给 IDE 提供必要的 Flash 信息,其值必须根据实际板卡情况填写正确。

structFlashDeviceconstFlashDevice={
FLASH_DRV_VERS,//DriverVersion,donotmodify!
"NewDevice256kBFlash",//DeviceName
ONCHIP,//DeviceType
0x00000000,//DeviceStartAddress
0x00040000,//DeviceSizeinBytes(256kB)
1024,//ProgrammingPageSize
0,//Reserved,mustbe0
0xFF,//InitialContentofErasedMemory
100,//ProgramPageTimeout100mSec
3000,//EraseSectorTimeout3000mSec//SpecifySizeandAddressofSectors
0x002000,0x000000,//SectorSize8kB(8Sectors)
0x010000,0x010000,//SectorSize64kB(2Sectors)
0x002000,0x030000,//SectorSize8kB(8Sectors)
SECTOR_END
};

除了 FlashDevice 之外,最核心当然是 FlashPrg.c 里的 7 个 API 函数,这些 API 函数提供了实际的 Flash 擦写验功能,IDE 会自动按需调用这些 API 去实现在线下载。这些 API 原型是固定的,但具体函数实现是因板卡而异的。

关于算法工程还有一个不得不提的设计,那就是工程选项 C/C++(包括 Asm)下都勾选了 Read-Only Position Independent 和 Read-Write Position Independent,表明下载算法本身不是使用固定地址链接,而是位置无关链接(也叫相对地址链接),算法代码机器码是可以被放到任意地址去执行的,这也是为什么你可以在例程选项里去指定 RAM for Algorithm。

3.3 下载算法 API 调用流程

当在 IDE 里启动在线下载时,IDE 会先将算法文件 .FLM 里的可执行机器码加载进指定的 RAM 空间,然后组合调用来实现最重要的 Flash 擦除和写入,只要用户 App 被正确写入 Flash,IDE 就能正常读取 Flash 里代码指令进行单步调试了。

下一篇文章,痞子衡将带大家继续探究 IAR EWARM 下的下载算法设计,让我们把主流 Cortex-M 集成开发环境的算法设计思路全部撸一遍,看看哪家更巧妙。

至此,Keil MDK 工具下 i.MXRT 的串行 NOR Flash 下载算法设计痞子衡便介绍完毕了,掌声在哪里~~~

审核编辑 黄昊宇

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/68103.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用词袋模型(BoW)测试提取图像的特征点和聚类中心

文章目录 环境配置代码测试 环境配置 (1) 导入opencv,参考链接 https://blog.csdn.net/Aer_7z/article/details/132612369(2) 安装numpy 激活虚拟环境的前提下,输入: pip install numpy(3) 安装sklearn 激活虚拟环境的前提下,输…

数据结构前言

一、什么是数据结构? 数据结构是计算机存储、组织数据的方式。数据结构是指相互之间存在一种或多种特定关系的数据元素的集合。 上面是百度百科的定义,通俗的来讲数据结构就是数据元素集合与数据元素集合或者数据元素与数据元素之间的组成形式。 举个…

vs中git提交合并分支的步骤记录

vs打开终端 PS D:\project\et_lower4_driver> git pull Already up to date. PS D:\project\et_lower4_driver> git branch * kiyun_usb7851 master PS D:\project\et_lower4_driver> git checkout master Switched to branch master Your branch is up to date wit…

MySQL与postgreSQL数据库的区别

MySQL 是一个流行的开源关系型数据库管理系统,具有以下优势: 开源和免费:MySQL 是一个开源软件,允许用户免费下载、使用和修改。它的免费版本(Community Edition)提供了广泛的功能,适用于大多数…

操作系统(OS)与系统进程

操作系统(OS)与系统进程 冯诺依曼体系结构操作系统(Operator System)进程基本概念进程的描述(PCB)查看进程通过系统调用获取进程标示符(PID)通过系统调用创建进程(fork)进程状态&…

小程序进阶-env(safe-area-inset-bottom)的使用

一、简介 env(safe-area-inset-bottom)和env(safe-area-inset-top)是CSS中的变量,用于获取设备底部和顶部安全区域的大小。 所谓的安全区域就是指在iPhone X及以上的设备中,为避免被屏幕的“刘海”和“Home Indicator”所遮挡或者覆盖的有效区域区域&am…

UICollectioView 使用集合

文章目录 一、前言二、UICollectionView基础知识2.1多个对象协作而成2.2 DataSource与Delegate三、UICollectionView 常用操作3.1 允许cell多选、 设置默认选中、选中与取消选中控制3.2 显示编辑按钮3.3 layouts 布局之间的转场3.4 插入、删除、移动 sections 和 items3.5 更新…

解决解析maven依赖加载卡住问题

首先找到用户设置文件的位置&#xff1a; 根据位置查找文件&#xff0c;没有则创建。 修改maven的默认镜像为阿里云镜像。 <mirror><id>alimaven</id><name>aliyun maven</name><url>http://maven.aliyun.com/nexus/content/groups/pub…

实训笔记9.4

实训笔记9.4 git一、本地版本控制1.1 建立仓库1.2 添加到暂存区1.3 提交到历史区1.4 查看1.4.1 查看当前版本库状态1.4.2 查看版本日志信息1.4.3 查看版本的变更历史 1.5 撤销1.5.1 撤销工作区的修改1.5.2 撤销暂存1.5.3 历史穿梭 二、代码托管2.1 将本地仓库推送到远程平台2.2…

【C++】STL-函数对象 + 谓词

1.函数对象使用 #include <iostream> using namespace std;//STL-函数对象&#xff08;仿函数&#xff09;class MyAdd { public:int operator()(int v1, int v2){return v1 v2;} }; //1、函数对象在使用时&#xff0c;可以像普通函数那用调用&#xff0c;可以有参数&am…

视频汇聚/视频云存储/视频监控管理平台EasyCVR接入海康SDK协议后无法播放该如何解决?

开源EasyDarwin视频监控/安防监控/视频汇聚EasyCVR能在复杂的网络环境中&#xff0c;将分散的各类视频资源进行统一汇聚、整合、集中管理&#xff0c;在视频监控播放上&#xff0c;视频安防监控汇聚平台可支持1、4、9、16个画面窗口播放&#xff0c;可同时播放多路视频流&#…

vue 设置全局鼠标移动事件

要设置全局鼠标移动事件&#xff0c;可以使用 Vue 的 mixin 实现。在 mixin 中&#xff0c;我们可以使用 $on 方法监听 mousemove 事件&#xff0c;并在组件销毁时使用 $off 方法移除监听器&#xff0c;以避免内存泄漏。以下是一个例子&#xff1a; // 在全局中注册一个 mixin…

基于nRF52840 Dongle配合Wireshark对Mesh网络抓包并解析(Nordic)

Mesh网络抓包解析 准备说明配置过滤解密分析 准备 1&#xff09;nRF52840 Dongle 2&#xff09;Mesh节点 3&#xff09;手机作为配网器&#xff08;苹果手机安装nRF Mesh APP&#xff09; 说明 1&#xff09;节点使用的例程目录&#xff1a;nrf5sdkformeshv500src\examples\…

java八股文面试[多线程]——阻塞队列

阻塞队列大纲&#xff1a; 什么是阻塞队列 阻塞队列&#xff1a;从名字可以看出&#xff0c;他也是队列的一种&#xff0c;那么他肯定是一个先进先出&#xff08;FIFO&#xff09;的数据结构。与普通队列不同的是&#xff0c;他支持两个附加操作&#xff0c;即阻塞添加和阻塞删…

HZOJ#236. 递归实现组合型枚举

题目描述 ​ 从 1−n 这 n 个整数中随机选取 m个&#xff0c;每种方案里的数从小到大排列&#xff0c;按字典序输出所有可能的选择方案。 输入 ​ 输入两个整数 n,m。&#xff08;1≤m≤n≤10&#xff09; 输出 ​ 每行一组方案&#xff0c;每组方案中两个数之间用空格分隔…

【校招VIP】产品分析之活动策划宣传

考点介绍&#xff1a; 产品的上线运营是非常重要的。应该来说好的产品都是运营出来的&#xff0c;在一运营过程中难免会依靠策划活动来提高产品知名度、用户数。用户粘度等等指标一&#xff0c;如何策划一个成功的活动就显得非常重要。 产品分析之活动策划宣传-相关题目及解析…

存储数据恢复- raid5多块硬盘出现坏道的数据恢复案例

存储数据恢复环境&#xff1a; 某单位一台存储&#xff0c;1个机头4个扩展柜&#xff0c;有两组分别由27块和23块硬盘组建的RAID5阵列。其中由27块磁盘组建的那一组RAID5阵列崩溃&#xff0c;这组RAID5阵列存放是Oracle数据库文件。存储系统上层共划分了11个卷。 存储故障&…

爬虫到底难在哪里?

目录 爬虫到底难在哪里 怎么学习爬虫 注意事项 爬虫工具 总结 学习Python爬虫的难易程度因人而异&#xff0c;对于具备编程基础的人来说&#xff0c;学习Python爬虫并不困难。Python语言本身比较简单易学&#xff0c;适合初学者使用。 爬虫到底难在哪里 爬虫的难点主要包…

DevOps理念:开发与运维的融合

在现代软件开发领域&#xff0c;DevOps 不仅仅是一个流行的词汇&#xff0c;更是一种文化、一种哲学和一种方法论。DevOps 的核心理念是通过开发和运维之间的紧密合作&#xff0c;实现快速交付、高质量和持续创新。本文将深入探讨 DevOps 文化的重要性、原则以及如何在团队中实…

Vue中的指令

指令 指令 (Directives) 是带有 v- 前缀的特殊 attribute。指令 attribute 的值预期是单个 JavaScript 表达式。指令的职责是&#xff0c;当表达式的值改变时&#xff0c;将其产生的连带影响&#xff0c;响应式地作用于 DOM。 常用指令预期简短介绍v-showany显示隐藏元素&…