一、BootLoader的作用:BootLoader是固化在PFlash中的一个程序,其作用可以分为两部分:boot和load。

  (1)boot:MCU上电时首先会运行BootLoader程序(因为它一般位于PFlash最前面的启动区,接下来会谈到启动区Boot location的概念),BootLoader程序会初始化系统时钟、看门狗等以保证系统的正常运行,此外还会初始化CAN(也可以是串口、SPI等)以实现和上位机的通信。

  (2)load:系统初始化完成后,程序会进入等待状态,如果在预定时间内没有接收到上位机的程序下载请求信号(CAN帧),则跳转并执行MCU内部原有的用户应用程序(位于PFlash的其他启动区)。如果在预定时间内接收到来自上位机的程序下载请求信号,则BootLoader程序进入新程序下载状态。下载过程中,上位机与BootLoader程序之间采用一问一答的方式逐行的下载S19文件(用户应用程序的可执行文件)并进行解析,得到程序地址和程序数据,从而将每一行程序数据按照程序地址写入到PFlash中。程序下载完成后,清除RAM,关闭CAN等BootLoader用到的外设,跳转到新的用户应用程序并开始执行。

二、Boot location的概念:Boot location就是每次MCU复位后运行BAM(Boot Assist Module)时寻找合法复位配置半字RCHW(Reset Configuration Harf-Word)和应用程序开始地址(Application Start Address,也可以叫做应用程序复位向量地址(Reset Vector)的区域。复位后CPU将从Boot location0~7依次查找由正确Boot_ID--0x5A组成的合法复位配置半字和应用程序开始地址,从而执行用户应用程序。MPC5744P有8个Boot location,在Flash Memory Map中标明了哪些block可以作为Boot location,如下图:

Boot location的组成如下图所示:

Boot location的起始位置是复位配置半字(RCHW),其结构如下所示。

只有设置了真确的BootID,该Boot location才被识别为可启动的,如BootLoader程序和用户应用程序生成的S19文件:

  

在BootLoader程序的S19文件第二行中,0x00F98000为Boot location_0的起始地址,也就是RCHW的地址,其中存放的数据为0x01_5A,RCHW的VLE位置1,BOOT_ID为0x5A,即配置该Boot location为可启动的。reserve的16-31位默认为0x00

从用户应用程序的S19文件第三行可以看到,0x00FA0004为用户应用程序开始地址(应用程序复位向量地址),其中记录的数据0x0100000为应用程序的复位函数地址,也就是应用程序真正开始执行的地址。因此,一般用如下方法实现到用户应用程序的跳转:

#define APP_StartAddr (*(uint32_t*)0x00FA0004)
(*(void (*)(void))(APP_StartAddr))();

三、BootLoader程序和用户应用程序App在PFlash中的位置关系(Flash分配)

对BootLoader程序和用户应用程序的 link_file做如下设置:

MEMORY  //BootLoader
{ /*16 KB low flash memory block 2 (boot location 0) from 0x00F98000 to 0x00F9BFFF*/
/*16 KB low flash memory block 3 (boot location 1) from 0x00F9C000 to 0x00F9FFFF*/
/* use the low flash memory block 2 and 3(32KB in total) as bootloader area */ flash_rchw : org = 0x00F98000, len = 0x4
cpu0_reset_vec : org = 0x00F98004, len = 0x4 m_text : org = 0x00F99000, len = 28K /*code flash for bootloader interrupt vector table, startup and boot codes*/ m_data : org = 0x40000000, len = 384K /*system SRAM*/ local_dmem : org = 0x50800000, len = 64K /*CPU core data tightly coupled memory*/
}
MEMORY  //User App
{ flash_rchw : org = 0x00FA0000, len = 0x4
cpu0_reset_vec : org = 0x00FA0004, len = 0x4 m_text : org = 0x1000000, len = 2048K
m_data : org = 0x40000000, len = 384K local_dmem : org = 0x50800000, len = 64K
}

则BootLoader和App的在PFlash中的关系如下:

四、S19文件结构:

五、数据对齐问题:

例程中的对齐函数主体及注释如下:

    stafno = (srcd_t->addr&0x7)>>;   /* number of uint16_t need to be pre-staffed  */  //if addr is not a multiple of 8-Bytes, get the surplus bytes then >>1
srcd_t->addr &= 0xFFFFFFF8; /* align data base address at 4W */ //about why >>1(divided by 2 regardless odd num addr): maybe there isn't odd address if(stafno)
{
for(i=srcd_t->dtlen; i>; i--)
srcd_t->data[i+stafno-] = srcd_t->data[i-]; // move forward data in number of stafno srcd_t->dtlen += stafno; // update dtlen while(stafno--)
srcd_t->data[stafno] = 0xFFFF; // pre-staff 0xFFFF
} while((srcd_t->dtlen&0x000003)!=) // need to append post-staffing uint16_t //if data num is a multiple of 4(each data is uint_16, so it's a judge of 64bits - 8bytes)
srcd_t->data[srcd_t->dtlen++] = 0xFFFF; //if not enough 4*uint_16 - 8bytes, padding with 0xFFFF behind data's tail
}
// conclusion: address is aligned with 8bytes by &0xFFFFFFF8, but data field will not move accordingly,
// it just padding with 0xFF in the front of array, so as to accord with origin address(0x0004) correctly
//
// address data(uint16) address data(uint16)
// |0x0000| |0x0000|<-- 0xFF
// |0x0002| after |0x0002| 0xFF
// |0x0004|<-- 0x55(data[0]) =======>> |0x0004| 0x55
// |0x0006| 0x66 address |0x0006| 0x66
// |0x0008| 0x77 align |0x0008| 0x77
// |0x000A| 0x88 |0x000A| 0x88
// |0x000C| |0x000C|
//
// note: (1) i guess that 0xFF will not be recognized as a instruction by CPU, so CPU fetch instruction from 0x0000
// but execute from 0x0004 in fact.
// (2) and note that the graph above is base on the struct SRecord_t,
// so that data[0] is always correspond with base address(SRecord->addr)

其中srcd_t的结构如下:

typedef struct {
uint32_t addr;
uint32_t dtlen; // num of valid data
uint16_t data[];
} SRecord_t;

另外,关于数据对齐问题,可以参考博文:https://blog.csdn.net/maxlovezyy/article/details/70231804

六、其他:下图为建立多核工程时的Flash和RAM资源的分配,可以用来参考以加深对程序在内存中的存储的理解

了解BootLoader——基于MPC5744P Bootloader例程的更多相关文章

  1. STM32 Bootloader基于ymodem传输协议串口IAP升级详解

    硬件:stm32f103cbt6 软件:STM32F10x_StdPeriph_Lib_V3.5.0 文章目录 1 预备知识 2 Bootloader 2.1 启动流程 2.2 校验跳转地址是否有效 ...

  2. nrf52——DFU升级USB/UART升级方式详解(基于SDK开发例程)

    摘要:在前面的nrf52--DFU升级OTA升级方式详解(基于SDK开发例程)一文中我测试了基于蓝牙的OTA,本文将开始基于UART和USB(USB_CDC_)进行升级测试. 整体升级流程: 整个过程 ...

  3. PIC18 bootloader之UART bootloader

    了解更多关于bootloader 的C语言实现,请加我Q扣: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). 应客户要求, 将PIC ...

  4. nrf52——DFU升级OTA升级方式详解(基于SDK开发例程)

    在我们开始前,默认你已经安装好了一些基础工具,如nrfutil,如果你没有安装过请根据官方中文博客去安装好这些基础工具,连接如下:Nordic nRF5 SDK开发环境搭建(nRF51/nRF52芯片 ...

  5. S32Kxxx bootloader之UDS bootloader

    了解更多关于bootloader 的C语言实现,请加我Q扣: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). 两周前完成了基于UDS ...

  6. 【Bootloader】探究bootloader,分析u-boot源码

    Preface 之前也发表过关于<Bootloader启动过程分析>的文章,但是内容表达得比较抽象,大多是文字叙述,所以这里从系统和代码的角度来深入分析bootloader的启动过程. 工 ...

  7. BLE CC2541 串口BootLoader 即 SBL BootLoader 资料 收集

    1.[CC254X_Bootloader]SBL(串口Bootloader)使用说明 2.CC2540协议栈高速串口通信解决(UART的DMA方式) 3.[BLE]CC2541之SBL 4.[BLE] ...

  8. PIC16 bootloader之UART bootloader

    了解更多关于bootloader 的C语言实现,请加我Q扣: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). PIC16 bootl ...

  9. PIC18 bootloader之CAN bootloader

          了解更多关于bootloader 的C语言实现,请加我Q扣: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). PIC18 ...

随机推荐

  1. FastJson稍微使用不当就会导致StackOverflow

    GitHub 9.4k Star 的Java工程师成神之路 ,不来了解一下吗? GitHub 9.4k Star 的Java工程师成神之路 ,真的不来了解一下吗? GitHub 9.4k Star 的 ...

  2. windows下如何安装Python虚拟环境

    1.前言 由于Python的版本众多,还有Python2和Python3的争论,因此有些软件包或第三方库就容易出现版本不兼容的问题. 通过 virtualenv 这个工具,就可以构建一系列虚拟的Pyt ...

  3. OI 经典诗歌

    键盘行 学校机房夜送客,枫叶蒟蒻秋瑟瑟.主人下马客在船,代码欲写无键盘.夜不AC惨将别,别时茫茫屏幕亮. 忽闻楼上键盘声,主人忘归客不发.寻声暗问敲者谁,键盘声停欲语迟.上楼相近邀相见,添酒回灯重开宴 ...

  4. python3 控制安卓手机的飞行模式遇到的问题汇总

    一.首先调通电脑对手机能落实 adb shell命令 验证通过标准:控制wifi开关的命令,能让wifi功能开启和关闭 (adb shell svc wifi enable   和   adb she ...

  5. 微擎框架商业版 V2.1.2 去后门一键安装版+去除云平台+无附带模块

    下载地址:http://dd.ma/AdVvoDu5 关注微信公众号codervip,点击公众号菜单,获取提取码! 这个是一键安装版本,所以微擎安装比较简单,不用大家手动去改数据库了,而且修复上个2. ...

  6. 一分钟带你了解下MyBatis的动态SQL!

    MyBatis的强大特性之一便是它的动态SQL,以前拼接的时候需要注意的空格.列表最后的逗号等,现在都可以不用手动处理了,MyBatis采用功能强大的基于OGNL的表达式来实现,下面主要介绍下. 一. ...

  7. 🔥「课代表」帮你总结了全网最全的Redis知识点

    你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图.个人联系方式和人才交流群,欢迎Star和指教 ...

  8. ZeroC ICE中的对象

    在ZeroC Ice中定义了三种基本对象类型. 它们分别是IceProxy::Ice::Object(于Ice/Proxy.h),Ice::Object(于Ice/Object.h)和Ice::Loc ...

  9. mysql安装与sqlyog安装

    首先是mysql安装,参考下面两个链接 https://www.cnblogs.com/gengyufei/p/11735358.html#_label4 https://www.jb51.net/a ...

  10. 记一次net/net core delete 方法报404 解决方案

    今天一个net core的delete方法 执行的时候 报404 网上查阅资料后发现是IIS 默认只允许get/post方法接入 网上查找资料后 在web.config添加如下代码: 意为移除WebD ...