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

STM32 生态系统|基于STM32WB的低功耗蓝牙应用(一)

[复制链接]
eefishing 发布时间:2019-10-2 12:15
1、基于STM32WB的低功耗蓝牙应用(二)RF协议栈的有线和无线更新:https://www.stmcu.org.cn/module/forum/thread-625173-1-1.html
2、基于STM32WB的低功耗蓝牙应用(三)用户应用程序的无线更新(OTA空中升级):https://www.stmcu.org.cn/module/forum/thread-625175-1-1.html

$ ?; i2 g# z) h0 w) P5 U. w$ a
; ], R# c  m; A+ ?' {% ~& q" S$ ^0 K2 C2 k, [; `
1 K8 I' E. Q7 K8 b& G
从使用角度,我们有以下六类设计资源,提供给开发者,做基于STM32WB的低功耗蓝牙应用开发。
# E* \! c+ `' @技术文档、评估板、参考固件例程、配合低功耗应用的软件工具、中文培训材料、本地方案(ST本地支持团队和中国合作伙伴开发的方案,都会在这里向大家集中展示)

9 L2 W  l2 r3 C: Y0 Q
STM32WB生态系统
1.png
: `5 ]* Q2 v6 q8 l' z
2 E; L* d, j6 Y. O6 s. k2 z
STM32WB. 技术文档
STM32WB的基础文档,首先是芯片的参考手册。目前STM32WB家族里只有一个55系列,它的参考手册是RM0434。它有1500多页,分章节描述了STM32WB芯片架构、总线、片上RAM、Flash、以及各个外设的功能、寄存器说明。WB主要新增的外设有实现RSA、ECC等非对称加解密功能的PKA单元,即public key accelerator(公钥加速器),用于双核通信的IPCC(inter processor communication controller)和硬件信号量HSEM等。1 x- c, X4 Z% D: V( i2 o
7 t3 V/ U0 L) u' S4 X" ^
然后是数据手册,勘误手册。(这三篇是STM32WB的基础技术文档)% ?/ {3 V+ Y& a) }2 s5 u7 m

: n9 D6 H) J/ _8 \: c, D
这里的5个应用笔记,都和STM32WB的硬件设计使用有关。
3.jpg
% B" h, Z2 s: ]. U9 O0 X
  • 因为WB集成了一颗支持低功耗蓝牙应用和802.15.4的RF收发器,相比以前的STM32,WB在硬件lay板子的时候,需要额外注意一些问题。【AN5165】是WB做射频应用时硬件开发方面总的指南。
  • STM32WB设计的目标之一就是高集成度,在保证优化的射频性能前提下,能让用户尽量减少外部器件的使用,降低BOM成本。【AN5290】就以QFN48引脚封装的WB55芯片为例,并给出了最小系统原理图。“高集成度” 主要体现在WB集成了开关电源,以提高2V以上供电时的电源转换效率。WB使用HSE外部高速晶振给RF模块提供时钟,可通过芯片内部集成的负载电容调节HSE精度,无需用户采用外部电容器件。另外两个应用笔记【AN5042】和【AN5246】就是对这两个特性展开的说明。为了进一步节约成本,还可以使用PCB天线,只要设计得当,它的性能可以和表贴陶瓷天线相当。【AN5129】对其进行了详细指导和说明。

    5 B  V' }. D* g; N

% T! J9 D. B' ^* }& Q. G6 B) r
STM32WB的主要应用是低功耗蓝牙应用,低功耗是STM32WB的主要设计目标之二。STM32WB继承了STM32L4的低功耗特性,支持多种低功耗模式,以及每个模式下面的子模式选项;低功耗的模拟外设、BAM(批处理获取模式)、灵活的时钟系统。【AN5071】就是对STM32WB芯片的低功耗特性概览。
STM32WB的双核之一,M0+内核是专门跑射频协议栈的,对用户或者说对M4内核,是一个黑盒子。要更新M0+上运行的协议栈,无论是通过JTAG/SWD、USB/UART这样的近程有线,还是通过BLE空中升级方式,要烧写和更新射频协议栈,必须通过FUS,即firmware update service。这里的firmware,不是指跑在M4内核上的用户应用程序firmware,是专指跑在M0+内核上,对用户不可见的射频协议栈firmware。这是一段芯片出厂就已经固化在STM32WB的secure flash中的一段程序,永远擦除不掉。芯片出厂时,只有预装了FUS,没有任何协议栈。需要用户根据自己的应用,使用无线或者有线方式,来把对应的协议栈通过FUS写进去。然后才可以继续在M4+内核上开发应用程序。【AN5185】就是对FUS的详细说明;【AN5247】是STM32CubeWB固件包里的OTA例程说明文档。里面描述了这个ota样例程序的逻辑,用户使用步骤。这个ota程序,不仅可以空中升级M4上运行的用户应用程序,也可以空中升级M0+上运行的射频协议栈。由于FUS的存在,射频协议栈,一定是被ST公钥签名加密过的。关于FUS和OTA的使用,我们下期,会有更详细的介绍。
4.jpg

, k2 B! A2 g1 x0 e1 o2 E; T
BLE Mesh应用,在STM32CubeWB中也有示例程序,这里的三个文档【AN5292】、【UM2180】、【UM2361】,分别是对BLE Mesh例程的说明,以及搭配例程使用的手机app的说明。' U. {: K1 j1 `+ P( {  B
9 T9 T; k0 y8 t( {" \! L
【AN5270】和【AN5289】,更偏向于开发者角度,详细列出了ACI层和HCI层的事件,比如连接完成,请求LTK这些LE META事件;比如配对完成、绑定丢失、数值比较这些ACI层的GAP事件;比如notification、server confirmation这样的ACI层GATT/ATT事件。以及所有协议栈使用的,私有的HCI层、GAP、GATT相关命令。

$ T4 q# ~7 f' U; S5 N% O# o
5.jpg
这里的前四个文档,是对三个例程的使用说明,分别是) p/ {; S/ [4 E4 D& N2 S. J
  • 使用STM32WB获取传感器参数,并通过BLE发送给手机
  • 使用STM32WB做全双工的音频传输
  • 基于STM32WB的SBSFU,即安全启动和安全固件升级。之前在STM32CubeWB固件包里的ota例程,对M4内核上运行的用户应用程序升级,是明文升级。如果对用户应用程序的升级有加密和认证需求,可以参考这个例程的实现。

    + X- h0 v- ]- Z! P5 R

! U. |' w- c& \/ t
STM32WB. 评估板
接下来,是ST官方出品的STM32WB55,目前唯一一款评估板:订购号,P-Nucleo-WB55 pack。这个套件里包含两块基于STM32WB55的板子,如图示:一个是Nucleo板,板载QFPN68引脚封装的STM32WB,和STLINKV2;一个是板载QFPN48引脚封装STM32WB的USB dongle板。, |1 R5 S$ R* K7 t; U) ]

# e3 `) ~& y& ~, u
STM32CubeWB固件包里包含两个板子上的多个例程。Nucleo板,由于板载了STLINK,因此烧写程序比较方便;USB dongle板只能通过48引脚WB芯片上,系统memory里面集成的bootloader来烧写应用程序。USB dongle板通常搭配STM32CubeMonitor-RF使用。由于需要系统memory启动,USB dongle板引出了拨码开关,方便启动模式的切换。/ r0 |' D$ x/ ~& y8 L$ `+ U4 J
' k! l( `0 [4 o$ f$ ?: a, |; p9 w
下期介绍ota例程时,会详细说明。
6.jpg
, Y- O; {) V& k1 c, ?' O% M, t6 G) x
' @7 I5 D3 t: }1 i0 w, v6 \
STM32WB. 固件例程
介绍完了STM32WB的技术文档、评估板,我们接下来看一下,ST目前提供了哪些关于低功耗蓝牙应用的参考例程。
% d) _) Z$ _$ ]9 [3 B6 [+ H, _$ _& u% Q
beacon,和几个SIG协会定义的标准profile,例程都有支持。P2P通信基于自定义profile,我们给出了sever,client,router的实现例程。其中蓝色框中的三个例程演示了如何通过ota bootloader,把用户应用从p2p server更新到心跳profile。这个例程,Nucleo板作为OTA server,OTA server可以由手机上的app,ST BLE Sensor或者STM32CubeMonitor-RF来担任。使用后者的时候,需要搭配使用USB dongle板。
7.jpg
( ?$ x8 Y# c! f' m) J- |* x
STM32CubeWB固件包里还有大家最关心的BLE Mesh智能照明应用例程,对应的手机App是ST BLE Mesh。例程的使用,以及手机app的使用,都可以参考表格里的文档。
' G4 o. o0 d7 O/ |
还有一个值得强调的是CKS加密这个例程。这不是BLE应用的标准场景,是STM32WB芯片特有的安全功能。STM32WB提供对用户应用key的安全存储。在安全环境中,用户把应用key放到STM32WB的安全存储区域内,之后M4的应用就可以使用这些key进行加解密运算。key的存储和使用都很安全,用户通过index来操作key,得到的是明文和密文,永远无法或者key本身。key的存储,可以通过M4上的用户存储调用FUS API,也可以通过STM32CubeMonitor-RF来把用户key传递给STM32WB,当然底层也是一样调用的FUS API。这个例子的讲解,也会在下次介绍来展开。
8.jpg

* L" B- D1 H1 A7 M
除了BLE协议栈,M0+内核还可以运行OpenThread,以及generic MAC,基于这两个RF协议栈的例程,ST也提供了若干,如表格中所列。
9.jpg
  Y* m4 {- }# ]: `

6 ]/ Y2 Y/ X" b  n# L' H1 f) M) F
STM32WB. RF协议栈:在STM32CubeWB 固件包中发布

# t8 m4 E7 l$ `) R
这张图,大家之前一定多次看到。它展示了STM32WB芯片支持的多种RF 协议栈。即可以在M0+内核烧写不同的协议栈,图中蓝色部分;然后在M4+上运行不同类型的用户程序,图中绿色部分。每一列是一个使用场景,但是彼此独立。比如左边第二列,是最常见的应用,就是M0+里运行BLE full stack,然后M4上跑BLE应用,比如mesh啊,比如其他标准或者自定义的profile,service啊。也可以,采用第四列,M0+里运行Thread FTD,Full Thread stack,然后绿色的M4内核部分运行Full thread应用。但是这两种使用场景是不能同时存在的。$ [$ @  |! U/ k! ]7 L4 q6 h

4 z" X5 T- _5 u; R5 G! @
目前,6种RF 协议栈都已经支持,并且随STM32CubeWB固件包一起发布。Zigbee协议栈也会马上支持,预计在下一个版本STM32CubeWB 1.3.0中大家可以拿到。
11.jpg

7 a- t! m% D3 q+ Q, d- N! c
STM32CubeWB 固件包,当前最新版本是1.2.0,在Project目录下,有一个STM32WB coprocessor wireless binaries文件夹,下面就存放了最新版本的各种RF协议栈。
, b4 p6 S7 ?* E8 v* F& Z# L! Z7 ]/ A; l" ~
注意:所有随STM32CubeWB 固件包发布的协议栈,都是被ST私钥签名加密过的,必须搭配STM32WB中的FUS才能验签并且解密,然后烧写到M0+内核独享的secure flash中。
5 z* Y5 M; {$ `5 [; b. j# a5 ?( r: n( M5 p! v& u1 x+ v
表格中前6行是前一页说的目前支持的6种RF 协议栈。后面两个,不是RF 协议栈,一个是FUS本身,一个是用于配合STM32CubeMonitor-RF做STM32WB板射频性能测试使用的。
  N8 k9 J9 [, C) m" b* V$ v% Y
. w+ h" j0 t  I2 q$ @FUS在芯片出厂时已经固化在STM32WB中,但是版本默认都是0.5.3,要想使用CKS功能,FUS要进行版本升级。现在STM32CubeWB固件包里的FUS是v1.0.1。
12.jpg
- N6 b8 @$ C( g) q

: B) J. n. m% Z' {: N
STM32WB. 固件例程:STM32Cube 功能扩展固件包

  d& }, O. y2 l
除了STM32CubeWB 固件包里包含的多个低功耗蓝牙和Thread应用的例程,在STM32CubeWB固件包之外,还有不少独立的固件例程,来展示STM32WB芯片的各种使用案例。
" h; g/ z9 p2 @+ i! a6 @
/ r% {6 k8 Y8 f0 Y1 n- J4 Z
  • 调整HSE精度以提供STM32WB的射频应用高精度时钟
  • 基于STM32WB的SBSFU,即安全启动和安全固件升级。之前在STM32CubeWB固件包里的ota例程,对M4内核上运行的用户应用程序升级,是明文升级。如果对用户应用程序的升级有加密和认证需求,可以参考这个例程的实现
  • 使用STM32WB做全双工的音频传输升级。之前在STM32CubeWB固件包里的ota例程,对M4内核上运行的用户应用程序升级,是明文升级。如果对用户应用程序的升级有加密和认证需求,可以参考这个例程的实现
  • 使用STM32WB获取传感器参数,并通过BLE发送给手机( f, g/ h) o  v& R5 F
    6 R, }; f0 R4 ?& {  u* i

    7 F. u- c* t7 ]
它们分别搭配的说明文档,在之前讲STM32WB的技术文档时,都已经提到过。

5 a+ t" L1 c% U
13.jpg

, s& C* {1 e3 h+ }* }
( f. y8 w6 Y( F0 ^
STM32WB. 软件工具
我们提供的丰富的基于STM32WB的低功耗蓝牙应用,有的是蓝牙板板子之间的通信,有的是蓝牙板和手机通信。
& z/ n. L" T  _8 L) {4 G4 v
2 i/ z# Q0 a6 S9 V6 K需要用到的手机端app,源码都公布在st github下;苹果版app在苹果商店可以下载,安卓版app在STM32中文网站可以下载。
% D# N8 V1 j' h
# v1 l! V1 u1 e1 D1 z! t
在做OTA和FUS更新时候需要用到的STM32Cube PC端工具,也都在表格里列了出来。下期介绍,我们会结合具体使用案例,来展示如何使用。
! S9 k! F/ ]+ V) u- h+ I
14.png
( q% n, Y! t3 y. _, [9 L
3 K' x5 T3 N* r; k
STM32WB. 本地培训材料
自从2017年推出STM32WB芯片以来,STM32中国支持团队,做了很多技术资料的本地化工作。包括今年中在六个城市的线下培训,由STM32WB技术支持工程师撰写培训材料,并到现场做培训,和客户交流,解决问题。手机扫描胶片里的二维码,可以下载到2019年STM32WB线下培训的课件。
15.jpg

7 E. e  f* M% o2 L0 b: X. m# o, t
STM32WB. 本地方案
我们还开发了基于STM32WB的智能锁方案。除了STM32WB作为主控芯片,方案里还集成了ST的安全芯片STSafe,直流马达驱动芯片STSPIN240,NFC读卡器芯片ST25,加速度传感器芯片LSM303AGR。通过安卓手机app连接、配置并管理智能锁,包括
向服务器注册用户、注册锁
绑定锁和用户,并使用户成为管理员
添加和删除 锁关联的用户, 等等

+ y4 s8 ]. ]8 h. u5 l( w
智能锁的控制包括
通过按键, 开、关锁
使用安卓手机app,通过蓝牙, 开、关锁
通过手机自带的NFC,开、关锁
通过事先关联的NFC tag,开、关锁
通过临时密码,开、关锁

: F" S+ V) J1 Y3 q* r$ P
整个方案都是开源的,包括原理图、手机app源码,MCU端固件,详情登陆链接http://club.stmcu.com.cn:8080/smartlock/  (复制链接粘贴到外部浏览器搜索),了解更多信息。
16.jpg
4 S# ^& ~" S0 w7 ^3 S
! o) P  K0 M: V2 s' a
收藏 1 评论5 发布时间:2019-10-2 12:15

举报

5个回答
cpt 回答时间:2024-10-15 14:35:17

您好,开源的STM32WB的智能锁方案链接失效了,有新的下载地址吗?

zykzyk-93033 回答时间:2019-11-6 15:10:18
请问这个基于STM32WB的智能锁方案的源代码相关资料哪里可以下载?
qindaotang 回答时间:2021-2-28 23:15:08
WB的智能锁方案的源代码相关资料哪里可以下载
zsdonline 回答时间:2021-3-1 09:45:44
学习
ZJU_Tom 回答时间:2024-11-11 11:07:40

谢谢,学习

所属标签

相似分享

官网相关资源

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