你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

实战经验 | 关于STM32WB OTA 速率提升引发的讨论

[复制链接]
STMCU-管管 发布时间:2024-4-22 16:06
1. 引言
& T1 L# n# Y! \: J0 P! d客户的 STM32WB 产品考虑功耗和 OTA 传输速率的平衡,在正常工作和做 OTA 升级时会使用两套不同的 BLE 连接参数。这就涉及到 BLE 连接参数更新。客户的问题也正是由更新 BLE 连接参数引起。连接参数的更新除了会影响 BLE 的传输速率,还需要考虑 OTA 接收到数据后的擦写 Flash 操作。
2 e  S  p3 ^7 s( |' H- z7 S9 b# P% r' |( z1 [0 O/ ]
2. BLE 连接参数及更新过程
( m" u6 p0 y% M3 i2 v. K我们先简单回顾一下影响 OTA 传输速率,也就是 BLE 传输速率的因素: % f) D& i1 A$ }$ ~5 k
PHY:BLE 的 PHY 是选用 1M,还是 2M- }3 {  Y# i5 j* ^2 V
DLE: Data length extension 允许数据包大小容纳更大的负载最大为 251 字节, 禁用时为 27 字节
; B$ \2 h3 G3 J$ k% I1 }- }ATT MTU ,当开启 DLE 时建议最大值设 247 字节
7 I8 b; L5 S+ E2 V- ^# ]连接间隔(connection interval),范围是 7.5ms 至 4000ms
+ |# K1 G4 q% o+ l9 H8 f连接事件(connection event),每个连接事件的最大数据包数,受限于 BLE 堆 栈,Android 和 IOS 设备会有差异。
) G3 w, m) n- F) ]3 K' q从机端的间隔唤醒(Slave Latency): 定义从机可以忽略主机发起的连接事件 数。
4 }" a! c3 J$ i发送数据后是否需要 RSP,不需要的时候选用 write without RSP/notify 的方式速度更快。 $ H2 Y- G" E% M3 `& ?; m# _$ d& d+ @
客户的应用中其 BLE 连接参数更新其实只涉及 connection interval 和 slave latency 两个参数。实际改变的只有 slave latency,其更新连接参数过程如下:
1 |9 z, @3 }) L3 n- C1. 在正常应用中,也即是 BLE OTA 升级前 connection interval 和 slave latency 的参数是[7.5ms, 6 latency] 。
3 U) F( ~, i7 w5 `9 @2. 准备 OTA 升级时,更新连接参数为[7.5ms, 0latency]以加快数据传输。
6 G8 c: z: g3 N4 }3. OTA 升级接收主设备传过来的数据,每接到 4K 数据会擦除 Flash,并将数据写入 Flash。这时需要在擦除 Flash 前将连接参数更新回[7.5ms, 6 latency] 。这样做的目 的是为了满足在射频活动前至少 25ms 不进行 Flash 的擦除操作(具体见 AN5289)。 7 a4 y  r- c& Y# ]9 Y
4. 在写完 4K Flash 后,又将 BLE 参数更新为[7.5ms, 0latency]继续接收 OTA 的数据。
- U/ H2 I0 ^, P  ?
3. 问题产生
9 v7 [" k/ n% y* W5 w从上面的描述可知,客户的程序设计是每接收到 4KB 数据,就要做 BLE 连接参数的更新。频繁的 BLE 连接参数更新会引发了一些问题。首先是连接参数更新是由从设备 STM32WB 发起把更新请求发给主机,主机收到更新请求后,正常会回一个 response 给从机,告诉从机后面可以按新的连接参数进行通信。但有些主设备有可能不支持参数更新或更新参数的时机有差异。导致更新失败。这就产生了兼容性的问题。如下图一,蓝牙规格书中有提醒,应该在建立 BLE 连接后的至少 5s 后更新连接参数 。
% I: m! I% N5 Y# z3 `5 c* M2 A

图一

图一
▲ 图一
另外 BLE 连接参数更新的持续时间: (9 + 6 x latency) x conn_interval (conn_interval 是当前的 conn_interval)。
) x) B  f: E2 w2 \! H而且对于两次 BLE 连接参数的间隔时间,蓝牙规格书中也有建议。建议更新参数的超时时间是 30s,如下图二:
9 q" w1 p7 X1 K' u

图二

图二
▲ 图二
如果按照这个要求,每次需要间隔 30s 再更新 BLE 连接参数,那整个 OTA 的速率将会比不更新的速率更低,那更新 BLE 连接参数来提高 OTA 速率就失去了意义。- M" u( [9 H3 a) `, Q3 [
4. 问题解决 3 x0 ^* C# O$ l
为了解决 BLE 连接参数更新带来的问题。有两个建议,一个是可以在 OTA 更新数据之前将 Flash 区域提前擦除,后面收到 OTA 数据后直接写 Flash。因为在 BLE 射频 IDLE 时 间内写 Flash 的操作不受限制,这样就可以不用频繁更新 BLE 连接参数,完成 OTA 升 级。另一个是建议对于 STM32WB BLE 协议栈,只要主机对从机更新连接参数请求有response,从机收到这个 response 后就可以再次发起连接参数更新请求,而无需等待 30s。这样也不会影响 OTA 的升级速率。 - g5 r4 x& o3 T  o# |
其实上面是针对使用的是 STM32Cube_FW_WB_V1.8 的协议栈版本的解决方案,它必须使用ACI_L2CAP_CONNECTION_PARAMETER_UPDATE_REQ 命令发送更新请求。 # F' |! k5 E0 y; V: D
对于最新的 STM32WB BLE 协议栈可以使用 ACI_HAL_SET_PERIPHERAL_LATENCY input parameters 命令,如下图三,这条命令可以直接在从机端使能或禁止 slave latency 而不需要等待主机的响应。这就可以满足客户的频繁更新连接参数而不需要考虑 主机的需求,巧妙地解决了兼容性问题。这里 latency 设置为 0 和 latency disable 效果是一样的。6 N/ ?7 X3 }: j

图三

图三
▲ 图三

7 g! D  ]1 g8 A: H8 X
5. 小结 ' [, B( P. S6 K6 }: z' g
本文分享了客户为提升 STM32WB OTA 速率引发的关于 BLE 连接参数更新的讨论。最后根据客户需要频繁更新连接参数,给出了相应的处理办法。以上供大家参考。8 _! z( j. F; c2 O& m+ q

/ v# O6 |1 Y/ Z. o$ h9 L: g4 g( M  D" ]

8 H8 m, L. S; f: ?& ^
收藏 评论0 发布时间:2024-4-22 16:06

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版