持续更新《Cortex-M0内核MCU的IAP升级》
来源:互联网 发布:js动态控制div的边框 编辑:程序博客网 时间:2024/06/05 04:01
这里给出基于Keil的工程源码,分为Bootloader和App两个工程,主要实现基于UART的IAP升级功能,升级过程中通信中断,重新上电后Bootloader仍可运行,再次执行升级即可。实现平台:STM32F030R8 + STLink + SecureCrt + CubeLL库
IAP的英文直译的意思是,在应用中编程,而不是传统的采用SWD/JTAG下载的方式;通讯方式只要MCU支持即可,这里用UART外设,或者说用两个GPIO口模拟个I2C通讯也不是不可;主要分为以下几个步骤:
1. 先给Flash地址分区,如下表:
中间的1KB是作为标志位的,这里采用Flash的一个Page,有点浪费,一定还有其他方法。
2. 编写Bootloader代码工程,MCU上电首先运行的代码;文件传输协议采用:Ymodem - 1024Bytes,为节省RAM空间,每接收1包数据,立即写入Flash中,接收完成后,跳转到App代码区运行;
3. 编写App代码工程,这里有三点需要注意:
keil工程配置,让编译器把代码编译的起始地址放在0x08002000而不是默认的0x08000000;中断向量表偏移,Cortex-M0内核不支持直接偏移(与Cortex-M3的具体区别,如下),这里把中断向量表的内容写到RAM的起始地址的48*4个字节,配置芯片从内部RAM启动;配置KEIL工程生成bin格式代码文件。
4. 完毕
欢迎下载,不足还请指出,cs86zhao@foxmail.com 谢谢!
附件:链接: https://pan.baidu.com/s/1skEnD05 密码: e9t2
- 持续更新《Cortex-M0内核MCU的IAP升级》
- Cortex-M0(+)内核的处理器架构简介
- 基于ARM Cortex-M0+内核的bootloader程序升级原理及代码解析
- Cortex m0+内核架构笔记
- stm32 cortex M0+内核 程序权限
- cortex M0
- ARM Cortex-M3,Cortex-M0,Cortex-A8的主要区别
- ARM Cortex-M3,Cortex-M0,Cortex-A8的主要区别
- Cortex-M的M0,M+,M3,M4,M7几种内核的简单区别
- 基于Cortex-M0的UCOS移植
- cortex M0与msp430的比较
- 基于Cortex M0+的STM32L0系列简介
- MCU新趋势—Cortex M0/M3/M4 行业应用主题研讨会
- 基于Fujitsu FM3 32-bit ARM Cortex-M3 内核的MCU 开发
- 基于Fujitsu FM3 32-bit ARM Cortex-M3 内核的MCU 开发(第二篇)
- 【Cortex-M0】3 ARM Cortex-M0
- Cortex内核拿下大半江山,MCU市场之争渐入高潮
- 【Cortex-M0】13看门狗
- 快速浮点数exp算法
- for循环
- ZOJ 3981 && 2017CCPC秦皇岛 A:Balloon Robot
- 20171102
- Jetty使用教程(一)——开始使用Jetty
- 持续更新《Cortex-M0内核MCU的IAP升级》
- 将单链表的每k个节点之间逆序
- Network Mess UVA
- post获取网页post用法
- 【分享】regsvr32 不是内部或外部命令,也不是可运行的程序或批处理文件
- Php7 安装(linux)
- Luogu 3378(堆)
- Digits用于深度学习
- linux安装redis