EFR32BG蓝牙进行空中升级(OTA)时会把NVM擦掉

博客内容讲述了在使用GNU编译器进行空中升级(OTA)时,NVM数据被擦除的问题。原因是变量nvmData在IAR和GNU编译器下分配的地址不同。通过分析链接配置文件,发现在IAR的icf文件中有明确的nvm3 section定义,而在GNU的ld文件中虽然有.simee section,但未在变量定义中使用。为解决这个问题,作者将nvmData的定义修改为使用attribute((section(.simee))),确保在GNU编译器下也能正确分配到NVM区域。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述:

使用emdrv/nvm保存数据,当使用IAR编译器时没有问题,但是使用GNU编译器,进行空中升级(OTA)时会把NVM擦掉。
经分析程序和调试观察,发现存放NVM数据的变量——nvmData,在使用IAR编译器时和使用GNU编译器时分配的地址不一样。这个变量的定义如下:
#define SL_ATTRIBUTE_ALIGN(X) attribute ((aligned(X)))
#ifdef ICCARM
static const uint8_t nvmData[NVM_PAGE_SIZE * NUMBER_OF_PAGES] @ “SIMEE”;
#else
static const uint8_t nvmData[NVM_PAGE_SIZE * NUMBER_OF_PAGES] SL_ATTRIBUTE_ALIGN(NVM_PAGE_SIZE) = { 0xFF };
#endif

在IAR的链接配置文件efr32bg13p632f512gm48.icf中,相关section的定义如下:
define block nvm3
{
section SIMEE,
};

“.text_nvm3”:
place at end of ROM_region { block nvm3 };

在GNU的链接配置文件efr32bg13p632f512gm48.ld里,也有nvm的section的定义如下:
.nvm_dummy (DSECT):
{
KEEP(*(.simee));
} > FLASH
但是在上面的变量定义中没有用到。

解决方法:

把nvmData的定义改为:
static const uint8_t nvmData[NVM_PAGE_SIZE * NUMBER_OF_PAGES] SL_ATTRIBUTE_ALIGN(NVM_PAGE_SIZE) attribute ((section (".simee"))) = { 0xFF };

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值