项目实战:基于瑞萨RA6M5构建多节点OTA升级-创建工程MCUBoot<二>

项目系统架构搭好了,咱们就开始动手实践吧!

实现固件升级需要用到UBoot引导加载程序,因此,首先我们先创建一个项目实现UBoot功能。

目录

一、新建项目配置

二、新增MCUBoot

三、配置MCUBoot属性

四、配置项目属性

五、编写启动函数

六、编译工程

七、编译问题解决

八、工程源码


一、新建项目配置

项目在e2 studio创建,创建过程不再详述啦!FSP版本不必纠结,基本上大同小异变化不是太大,推荐使用近期发行的版本。项目配置信息如下:

二、新增MCUBoot

添加模块:

三、配置MCUBoot属性

Downgrade Prevention(Overwrite Only):设置为Disabled,关闭是为了日后异常可以灵活处理,回退版本。

Signing and Encryption Options选项下的内容没有启用,固件需要加密打包的,就没有必要使用签名加密了。

配置g_flash0属性:

关闭掉Data Flash Programming Enable可以减少固件尺寸,在项目中也用不到data flash。

配置完成,点击生成项目内容:

四、配置项目属性

配置完成后,点击应用关闭。

五、编写启动函数

在hal_entry.c中编写函数mcuboot_quick_setup

cpp 复制代码
void mcuboot_quick_setup()
{
#ifdef MCUBOOT_USE_MBED_TLS

    /* Initialize mbedtls. */
    mbedtls_platform_context ctx = {0};
    assert(0 == mbedtls_platform_setup(&ctx));
#elif (defined(MCUBOOT_USE_TINYCRYPT) && defined(RM_MCUBOOT_PORT_USE_TINYCRYPT_ACCELERATION))

    /* Initialize TinyCrypt port. */
    assert(FSP_SUCCESS == RM_TINCYRYPT_PORT_Init());
#elif (defined(MCUBOOT_USE_USER_DEFINED_CRYPTO_STACK))

/* Initialize Custom Crypto (Protected Mode) driver. */
    assert(FSP_SUCCESS == R_SCE_Open(&sce_ctrl, &sce_cfg));
#endif

    /* (Optional, not required if --pad is used during signing) To check for updates, call boot_set_pending. */
    bool update = 0;
    if (update)
    {
        boot_set_pending(0);
    }

    /* Verify the boot image and get its location. */
    struct boot_rsp rsp;
    assert(0 == boot_go(&rsp));

    /* Enter the application. */
    RM_MCUBOOT_PORT_BootApp(&rsp);
}
/*******************************************************************************************************************//**
 * main() is generated by the RA Configuration editor and is used to generate threads if an RTOS is used.  This function
 * is called by main() when no RTOS is used.
 **********************************************************************************************************************/
void hal_entry(void)
{
    /* TODO: add your own code here */
    mcuboot_quick_setup();
#if BSP_TZ_SECURE_BUILD
    /* Enter non-secure code */
    R_BSP_NonSecureEnter();
#endif
}

六、编译工程

编译输出结果:

七、编译问题解决

使用FSP5.1编译会出现找不到头文件rm_tinycrypt_port_cfg.h,用来做加密配置的,咱也没用到,注释掉就行啦!

八、工程源码

RA6M5_MCUBoot工程源代码https://download.csdn.net/download/xtudj/90492983

相关推荐
代码游侠9 分钟前
ARM开发——阶段问题综述(二)
运维·arm开发·笔记·单片机·嵌入式硬件·学习
DLGXY31 分钟前
STM32——旋转编码器计次(七)
stm32·单片机·嵌入式硬件
羽获飞1 小时前
从零开始学嵌入式之STM32——3.使用寄存器点亮一盏LED灯
单片机·嵌入式硬件
浩子智控2 小时前
商业航天计算机抗辐射设计
单片机·嵌入式硬件
独处东汉5 小时前
freertos开发空气检测仪之输入子系统结构体设计
数据结构·人工智能·stm32·单片机·嵌入式硬件·算法
czy87874756 小时前
机智云 MCU OTA可以对MCU程序进行无线远程升级。
单片机·嵌入式硬件
A9better8 小时前
嵌入式开发学习日志52——二值与计数信号量
单片机·嵌入式硬件·学习
日更嵌入式的打工仔9 小时前
(实用向)中断服务程序(ISR)的优化方向
笔记·单片机
想放学的刺客10 小时前
单片机嵌入式试题(第25)嵌入式系统可靠性设计与外设驱动异常处理
stm32·单片机·嵌入式硬件·mcu·物联网
wotaifuzao10 小时前
STM32+FreeRTOS 长期可维护架构设计(事件驱动篇)-- 告别“屎山”代码
c语言·stm32·嵌入式硬件·freertos·状态机·事件驱动·嵌入式架构