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

Blue NRG-1/2芯片Flash与BLE互斥处理经验分享

[复制链接]
攻城狮Melo 发布时间:2023-4-7 16:24
1. 引言
在许多基于 BlueNRG-1/2 系列芯片的低功耗蓝牙的设计项目时,客户通常会在 Flash 的特定区域存储定制的数据。然而需要特别注意的是,在 BlueNRG-1/2 方案中,用户对 Flash 的读写操作必须在射频空闲的情况下进行,两者是互斥的关系。

9 M3 E. h/ L6 f- `* T0 l$ [
1 k" ^9 u8 |' Z3 h( K1 ~
2. 问题描述
客户经常反馈类似问题,诸如:当用户程序尝试将用户定制数据写入 Flash 中特定区 域时,发现 BLE 射频部分停止工作,或芯片直接死机了。

, o/ }5 n& d  _) _. h3 M
2.1. 原因分析
' [$ J# H9 g9 ^% b* c$ e& S
  • 2.1.1. BlueNRG-1/2 的 Flash 存储应用数据时可能遇到这个问题。因为在擦除一页的过程 中,中断会被关掉大概 20 多 ms, 在此期间,radio 中断是被关掉了的,会导致整个 radio 的状态被延时或者整个 radio 部分的状态被破坏。

    7 N& ~- D" U& O0 m9 G0 _
  • 2.1.2. ST 的 SDK 虽然提供了访问 Flash 的示例代码,但是当 Flash 操作比较多时,与蓝 牙事件的互斥就比较难处理了;特别是对于一些多连接应用或者同时用了主从、多 种蓝牙事件的场景,互斥就显得更麻烦了。
    - o2 U/ t- N0 e
: n) D. i! q/ r' @* w

5 _' F$ n: q1 `
3. 解决办法
使用一个双向链表来管理 Flash 操作(Flash 擦除或者是 Flash 写,Flash 读无需和 BLE 相关事件互斥),并使用一个双向链表来管理空余时间状态。在空余的时间执行 Flash 操作。从芯片手册可以知道,操作 Flash,特别是擦除时,会占用比较多的时间。为 了避免操作 Flash 占用过多的时间片,把每次写或者擦除 Flash,用一个列表来管理,每 次写或者擦除操作,插入 Flash 操作链表的最后。在主循环中检测是否有足够的时间写, 如果当前空闲的时间足够,取出 Flash 操作链表中最前的一个节点,执行 Flash 操作,然 后将节点移除。对于如何检测空闲时刻,也用一个链表来管理空闲时刻。具体思路如下:

0 N! d' i, o. m" l& C

# R6 ^, }! i5 H

第一步:初始化时需要设置 radio active 事件抛到应用。aci_hal_set_radio_activity_mask(0x0001|0x0002|0x0004|0x0008|0x0010|0x0020)
/ I# ^3 ]; f, @* j
微信图片_20230407162359.jpg
% d# X; z! c( p! p$ `2 H1 q: \
第二步:设置之后,重写函数aci_hal_end_of_radio_activity_event,当有事件触发时, 就会进入这个函数。
3 g+ }0 S" Y0 f) r' W
微信图片_20230407162354.png
7 W8 ]3 F) r1 U
第三步:构造一个 Flash 操作调度函数,每次进入这个函数,生成一个空闲时刻的节点插 入到链表中。主循环中有个 Flash 操作的调度函数,不停的调度是否有数据需要写入。在 Flash 操作的调度函数中,主要做两件事情,一个是把空闲时间计算出来给到底层的 Flash 操作链表调 度中。另一个是移除过期的节点。
+ m; {! y$ C2 u

$ \2 W+ r. X% Q 微信图片_20230407162347.png
) i8 s0 h- `5 l* C* C9 k
3 M4 i) g( J  A& q
第四步:构造 flash_list_tick 函数,flash_list_tick 函数主要是从 Flash 任务列表中去取节 点,当空余时间满足时,则执行相应的 Flash 操作,然后将节点从任务列表中移除,回收到空闲列表中。1 R: h# p5 I/ G& N3 l+ w% O
/ l- X3 \' f2 o' g% S6 b/ N' M9 N
. F0 _2 `2 s4 f) Q8 s' y
微信图片_20230407162344.png : \0 H6 x& l, S, n

9 v- @, s3 m9 n% b1 C2 M/ ~! p& G


. c1 e. D- N! I* ^
4. 将上述方案加入客户工程的步骤示例

8 n8 S* a( \+ }/ ^6 g' J

1. 初始化相关链表和初始化 radio 事件回调屏蔽。0 @# M, A) C" z
4 V3 Q  g. g0 t6 r- U; ~

5 R1 a9 f" _8 z( x 微信图片_20230407162340.png
* T. r; g  K% ?3 F: ~
% q# _8 k* D! m) ~0 f
2. 在 aci_hal_end_of_radio_activity_event 中添加空闲链表的更新函数。
( ]3 c3 Z- A% ?" @1 F0 G) i1 V" ?4 Y4 `7 G! t

, y, a# Q9 b4 o9 E6 B' T9 N  k4 h 微信图片_20230407162335.png 8 j/ [) U' j) V- B  T! I( \# v

6 k6 P* f& G" @* C
3. 在主循环中调度。
6 d3 e& C; o6 N# M! y
1 u$ C. o  ?+ ~1 W
( k/ N5 x6 J: V* e' z& M
微信图片_20230407162331.png
5 i; M# j9 X5 {) j! j
$ [7 v9 ?% S" ?1 s4 \
4. 应用操作 Flash 调用接口。
' n0 u, [  K6 Z1 ^( O5 P- w" F
' p7 n( ~/ T4 K1 T4 Q0 ~  J/ V
$ S4 X. E/ X7 O" j/ `+ m, W
微信图片_20230407162326.png % a0 z2 N3 L1 e$ N% \& J. s2 s* i1 R

. S0 o! F: x2 N8 _; Q+ q: R6 K
5. 小结
如果使用此方法中的 Flash 擦除,没有任何 BLE 事件时,直接调用此方法不会执行任何 Flash 的操作。所以当没有蓝牙事件时,可以使用 SDK 默认的 Flash 访问接口或者是手工调度函数,类似这样:flash_list_tick(~0u)
; a9 Z; }( a( n. `
工程测试源码参考附件压缩包:
BlueNRG Flash vs BLE event handle source code.7z
- D/ E) Z; v) X5 [; R! e6 }
工程路径为:
BlueNRG_Demo/BlueNRG-1_2DK 3.1.0/Project/Supply/BLE_Chat_Master_Slave_WithFlashAccess/

& @* _6 t5 _5 j; B& d
转载自: STM32单片机
如有侵权请联系删除- F5 W1 i5 t: k

4 a! R1 `: r7 U, j% s5 e% f9 y: |- r, E& `
收藏 评论0 发布时间:2023-4-7 16:24

举报

0个回答

所属标签

相似分享

官网相关资源

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