nRF52840 BLE 多服务开发中的 NRF_ERROR_NO_MEM 排查与解决实战

问题现象

在基于 nRF5 SDK 的 Heart Rate 示例上添加自定义 LBS(LED Button Service)私有服务后,程序启动后立即进入 Fatal Error → System Reset 循环,串口反复打印:

textapp: ble_lbs_init failed! Error code = 0x00000004

0x00000004 对应 NRF_ERROR_NO_MEM(内存不足)。

根本原因

nRF52840 的 SoftDevice(S140)在初始化时会分配一块 RAM 给协议栈使用。默认配置下,GATT 属性表(Attribute Table)大小有限。当同时启用以下服务和模块时,容易超出限制:

Heart Rate Service (HRS)

Battery Service (BAS)

Device Information Service (DIS)

自定义 LBS 服务(包含至少 2~3 个特征 + CCCD)

Peer Manager + Queued Write + LESC 等安全特性

每个 GATT 服务和特征都需要在属性表中占用空间,LBS 服务初始化时申请内存失败,导致 ble_lbs_init() 返回 NRF_ERROR_NO_MEM。

排查过程关键点

通过 APP_ERROR_CHECK + 日志打印,精确定位到 ble_lbs_init() 失败。

确认错误码为 0x00000004(NRF_ERROR_NO_MEM)。

分析同时运行的 BLE 服务数量和 RAM 使用情况。

发现 Keil 中 IRAM1 Size 设置过大(挤占了 SoftDevice 可用的 RAM)。

最终解决方案(三管齐下)

代码层面增大 GATT 属性表(最重要):Cble_cfg.gatts_cfg.attr_tab_size.attr_tab_size = 0x1400; // 或更高

err_code = sd_ble_cfg_set(BLE_GATTS_CFG_ATTR_TAB_SIZE, &ble_cfg, ram_start);

Keil 工程配置调整 IRAM1:

将 IRAM1 Size 适当调小(例如 0x3A000 ~ 0x39000),给 SoftDevice 留出更多 RAM。

打印内存信息辅助调试:CNRF_LOG_INFO("SoftDevice RAM start = 0x%08X", ram_start);

NRF_LOG_INFO("Available RAM for app ≈ %d bytes", (256*1024) - (ram_start - 0x20000000));

经验教训与最佳实践

添加自定义服务前,必须评估总的 GATT 属性表占用。

永远不要依赖默认配置,尤其当项目包含多个服务 + Peer Manager 时。

建议在 ble_stack_init() 中主动配置 attr_tab_size、conn_cfg 等关键参数。

开发过程中养成打印 RAM start 地址和可用内存的习惯,能大幅加快调试速度。

对于 nRF52840,推荐至少预留 20~30KB 给应用层使用

相关推荐
网络研究院17 天前
2026年网络安全
网络·安全·法律·法规·趋势·发展
酣大智17 天前
ARP代理--工作原理
运维·网络·arp·arp代理
treesforest17 天前
AI安全系统如何识别异常访问?IP风险识别正在成为关键能力
网络·人工智能·tcp/ip·安全·web安全
shushangyun_17 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
2601_9618451517 天前
粉笔行测题库|系统班|刷题
网络·百度·微信·微信公众平台·facebook·新浪微博
程序猿阿伟17 天前
《Chrome离线扩展安装的底层逻辑与场景落地指南》
服务器·网络·chrome
InHand云飞小白17 天前
无人值守站点网络困境?工业级路由器IR315破解连接难题
网络·物联网·4g·工业路由器·4g路由器·iiot·蜂窝路由器
森G17 天前
75、服务器源码解析---------云视频服务项目
linux·服务器·网络·c++·qt
江华森17 天前
TCP/IP 协议栈实战 — 7 个实验详解
网络·tcp/ip·智能路由器
酉鬼女又兒17 天前
零基础入门计算机网络运输层:端到端通信核心作用、端口号分类规则、复用分用工作机制及UDP与TCP协议全方位对比详解
网络·网络协议·tcp/ip·计算机网络·考研·udp·php