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 来存储这些属性。同样,增加连接数、启用更多安全功能等也会导致需求增加。

相关推荐
云边云科技_云网融合2 小时前
AI 时代组网新范式:零信任软件定义组网,让连接更安全更灵活
网络·安全
简单点了3 小时前
全栈编程基础知识7
运维·服务器·网络
LCG元3 小时前
STM32实战:基于STM32F103的Bootloader设计与IAP在线升级
javascript·stm32·嵌入式硬件
房开民3 小时前
modbus相关学习
网络·学习
不怕犯错,就怕不做4 小时前
Linux-Sensor驱动移植与调试(转载)
linux·驱动开发·嵌入式硬件
2603_954708314 小时前
如何确保微电网标准化架构设计流程的完整性?
网络·人工智能·物联网·架构·系统架构
LCMICRO-133108477464 小时前
长芯微LCMDC8584完全P2P替代ADS8584,是一款16位、4通道同步采样的逐次逼近型(SAR)模数转换器(ADC)
stm32·单片机·嵌入式硬件·fpga开发·硬件工程·模数转换器adc
STC_USB_CAN_80514 小时前
菜单学习,科学计算器使用【TFT240*320彩屏+实际键盘】@Ai8051U,ST7789
单片机·学习·51单片机
FreakStudio5 小时前
无硬件学LVGL—定时器篇:基于Web模拟器+MicroPython速通GUI开发
python·单片机·嵌入式·大学生·面向对象·并行计算·电子diy·电子计算机
异方辰电子7 小时前
8.原理图为什么看不到具体的电路(比如STM32的晶振等)
stm32·单片机·嵌入式硬件