这个问题出现在使用BLE Mesh快速配网时,可能是因为在创建新的OSI警报时,已经存在太多的警报回调(alarm_cbs)。为了解决这个问题,我们可以在创建新警报之前先删除旧的警报回调,示例代码如下:
#define MAX_NUM_ALARMS 10
// 创建新警报之前,删除旧警报 alarm_cancel_all();
// 创建新警报 osi_alarm_t *new_alarm = osi_alarm_new(name, timeout, cb, ctx);
// 如果未创建成功,则继续删除旧警报 while (!new_alarm && osi_alarm_locked()) { osi_alarm_t *expired_alarm = osi_alarm_unlock_first_expired(); osi_alarm_remove(expired_alarm); new_alarm = osi_alarm_new(name, timeout, cb, ctx); }
// 如果仍未成功,则删除最老的警报 if (!new_alarm && osi_alarm_locked()) { osi_alarm_t *oldest_alarm = osi_alarm_unlock_first(); osi_alarm_remove(oldest_alarm); new_alarm = osi_alarm_new(name, timeout, cb, ctx); }
// 如果仍未成功,则说明OSI警报用尽,需要重启设备 if (!new_alarm) { // 重启设备的代码 }
注意,以上示例代码仅供参考,在实际使用时需要根据具体情况进行相应的修改。