Keil更改RAM地址

一、代码现象

在 Nordic nRF52 系列芯片的开发中,我们经常会遇到这样一个现象:当我们在项目中增加了一个新的 BLE 服务(例如 LED Button Service,LBS)后,程序在初始化 SoftDevice 时突然报错:

二、原理

原理:为什么 RAM 需要"改"

nRF52840 的 RAM 大小是固定的(256 KB)。但 RAM 被分为两个区域:

  • SoftDevice 区域(蓝牙协议栈) :协议栈运行时需要占用的 RAM(包括连接上下文、属性表、GATT 缓存等)。

  • 应用程序区域(你的代码、数据、堆栈) :你的代码(数据段、堆、栈)使用的 RAM。

这两个区域的分配由链接脚本(或 IDE 中的 RAM 起始地址)决定

通常在链接脚本中,RAM 起始地址被设置为 0x20000000 + SoftDevice 占用大小,而 SoftDevice 的占用大小取决于你的配置(例如最大连接数、ATT MTU、安全参数等)。

当你修改了配置(例如增加连接数、启用更多功能),SoftDevice 需要更多 RAM,但链接脚本中的偏移量(RAM 起始地址)没有同步增大,就会导致 SoftDevice 初始化时发现预留空间不足,从而报错并提示你增大偏移量。


为什么会提示从 0x20002250 改为 0x20002260

计算过程:

  • SoftDevice 需要从 RAM 起始地址 0x20000000 开始占用一部分空间。

  • 你的应用程序当前配置的 RAM 起始地址是 0x20002250,这意味着为 SoftDevice 预留了 0x2250 字节(约 8.8 KB)。

  • 但是根据当前的项目配置(例如最大连接数、GATT 属性数量等),SoftDevice 实际需要 0x2260 字节(约 8.8 KB + 16 字节)

  • 因此 SoftDevice 初始化时发现空间不足,返回错误,并提示你将 RAM 起始地址改为 0x20002260,即多预留 16 字节。

三、SoftDevice 的 RAM 需求由什么决定

SoftDevice 运行时需要存储大量动态数据,包括:

  • 连接上下文(每个连接约 1.2 KB)

  • GATT 属性表(服务、特征、描述符)

  • 安全数据库(绑定信息)

  • 队列缓存(如 Queued Writes)

  • 其他协议栈内部状态

这些需求的大小并非固定,而是 由应用程序的配置决定 。当你添加新的 BLE 服务时,例如增加了一个自定义服务(LBS),GATT 属性表的条目数增加了,SoftDevice 需要更多的 RAM 来存储这些属性。同样,增加连接数、启用更多安全功能等也会导致需求增加。

相关推荐
米高梅狮子1 天前
03.网络类服务实践
linux·运维·服务器·网络·kubernetes·centos·openstack
June`1 天前
网络编程时内核究竟做了什么???
linux·服务器·网络
原来是猿1 天前
腾讯云服务器端口开放完全指南
服务器·网络·腾讯云
你的保护色1 天前
【无标题】
java·服务器·网络
楼兰公子1 天前
RK3588 + Linux7.0.3 网络工程调试错误速查手册
linux·网络·3588
IpdataCloud1 天前
稳定的企业级IP数据接口怎么选?可用性指标+离线库高可用方案
运维·网络·tcp/ip
HMS工业网络1 天前
如何解决使用TwinCAT时EtherCAT网络出现“Sync Manager Watchdog”报错
网络·网络协议·网络安全
Jason_zhao_MR1 天前
RK3576 MIPI Camera ISP调试:主观调优与工程实战(下)
stm32·嵌入式硬件·安全·系统架构·嵌入式
ACP广源盛139246256731 天前
iOS 27 开放 AI 生态@ACP#小型化扩展黄金风口,IX8008全面超越 ASM2806,铸就嵌入式 AI 扩展核心
人工智能·嵌入式硬件·macos·ios·计算机外设·objective-c·cocoa
smartpi_ai1 天前
玩具产品从按键控制升级为语音控制:语音模块与MCU串口通信实战
单片机·嵌入式硬件