0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

应用笔记 | STM32WB基于Custom Template实现客户定制BLE私有协议

STM32单片机 来源:未知 2023-10-08 17:40 次阅读


关键字:STM32WB,BLE私有协议,定制



目录预览


1.引言

2.STM32CubeMx 实现步骤

3.测试平台搭建及功能测试

4.小结



01

引言


STM32WB55是一款支持BLE5.x的双核高性能MCU,针对BLE的应用固件包STM32Cube_FW_WB_V1.xx.xxProjectsP-NUCLEO-WB55.NucleoApplicationsBLE里面也提供了大量的例程,目前支持的标准GAP服务例程在STM32CubeMX中已有列出,或可以在固件包STM32Cube_FW_WB_V1.xx.xx MiddlewareSTSTM32_WPANlesvc中找到。然而,在实际的STM32WB意向客户中,使用BLE私有协议来开发Profile非标产品的客户占了绝大部分。读者可以去查看BLE_p2pServer、BLE_Custom等例程,对于需要添加自定义ATT属性和服务的应用,现有例程里面STM32CubeMX是无法自定义添加ATT属性和服务。但笔者发现,其实使用STM32CubeMX的Custom Template是能实现上述功能的。


本文的目的旨在使用STM32CubeMX以及Custom Template例程基于STM32WB55-Nucleo实现基于BLE私有协议的通用通信框架,使客户快速上手进行产品开发,且可以直接应用在产品上,应用框架的设计如下图所示。另外,本文还对BLE协议栈的下载和升级注意事项做了详细指导,如果读者不熟悉这些内容,可以先行阅读。



如上图所示,使用手机APP与STM32WB进行BLE私有协议通信,一共设计了4种类型的数据访问:读/写、只写、只读、通知,这4种访问类型基本可以覆盖大部分数据访问场景


02

STM32CubeMX实现步骤


2.1 创建BLE工程添加并配置外设


请在搭建工程之前,下载安装最新的STM32CubeMX和STM32CubeWB


2.1.1 在STM32CubeMX中点击“File”/“New Project”在弹出对话框中输入“STM32WB55RG”创建一个新工程



2.1.2 工程配置如下图所示,配置工程名字、保存路径、选择编译工具、调整堆栈大小和选择需要的STM32CubeWB的库文件(缺省为已安装的最新版本)。



2.1.3 系统配置:调试口



2.1.4 外设配置:添加外部高速晶振(HSE)和低速晶振(LSE)



2.1.5 外设配置:调试打印串口USART,手动将USART1引脚重映射到PB6/PB7



使能USART1的TX的DMA功能和USART1的全局中断



2.1.6 外设配置:使能HESM,它完全由BLE stack管理



2.1.7 外设配置:使能RF,它完全由BLE stack管理。



2.1.8 外设配置:使能IPCC,它完全由BLE stack管理。只需同时使能它的RX/TX中断即可。



2.1.9 外设配置:使能RTC,同时选择WakeUp为“Internal WakeUp”和WakeUp中断。



2.1.10 外设配置:配置时钟



2.1.11 外设配置:NVIC的配置



至此,外设的配置和添加部分已经完成。


2.2 BLE协议栈的添加及配置


2.2.1 协议栈配置:使能BLE协议栈



2.2.2 协议栈配置:禁止“Custom P2P Server”并使能“Custom Template”自定义GATT通用模板



2.2.3 协议栈配置:新建一个GATT服务,其名称为“My_Data_Server"



2.2.4 协议栈配置:GATT服务基本配置



2.2.5 协议栈配置:配置GATT读&写 服务特征及属性值



2.2.6 协议栈配置:配置GATT写 服务特征及属性值



2.2.7 协议栈配置:配置GATT读 服务特征及属性值



2.2.8 协议栈配置:配置GATT通知 服务特征及属性值



2.2.9 协议栈配置:配置GATT广播参数配置



2.2.10 协议栈配置:BLE配对参数设置



2.2.11 协议栈配置:BLE协议栈调试及打印配置(需依次序配置)



2.3 生成工程代码并初步测试


2.3.1 点击“GENERATE CODE”生成工程代码



2.3.2 在生成的代码中添加BLE Trace&Debug初始化代码


2.3.3 在“main.c”文件中取消“MX_UART_Init(void)”的“static”属性


2.3.4 在“app_entry.c”文件中增加“Debug”模块的初始化代码“APPD_Init()”。



2.3.5 下载代码到STM32WB55-NUCLEO中运行。此时,在手机的蓝牙列表中,已经能成功地搜索添加的BLE设备。说明Debug和BLE协议栈已经成功运行。



2.4 添加BLE Stack应用代码


为了便于对后续添加代码的理解,我们先将Central(手机)与STM32WB进行BLE通信的数据交互概括如下。所以需要将用户代码添加到Custom_STM_Event_Handler()、Custom_STM_App_Notification()中。



BLE应用代码添加:定义用户数据缓存。

在“custom_app.c”文件中定义4个用户缓存区数组。



BLE事件驱动代码添加:


在“custom_stm.c”文件中的“Custom_STM_Event_Handle r(void*Event)”中依次为WRITE_READ_DATA_BUF、WRITE_DATA_BUF、NOTIFY_DATA_BUF特征和属性添加stack层的事件驱动代码,以使BLE数据从stack层传递到app层。


添加特征1 Events:WRITE_READ_DATA_BUF(即User_Write_Read_Data[]对应的写&读操作句柄)请求驱动代码。



上图对应的代码文本如下所示:




上图对应的代码文本如下图所示:



添加特征2 Events驱动:WRITE_DATA_BUF(即User_Write_Data []对应的写操作句柄)代码。



上图对应的代码文本如下图所示:



添加特征3 Events驱动:READ_DATA_BUF(即User_Read_Data[]对应的写操作句柄)代码



上图对应的代码文本如下图所示:



添加特征4 Events驱动:NOTIFY_DATA_BUF(即User_Notify_Data[]对应的写操作句柄)请求驱动已经由STM32CubeMX自动完成了。NOTIFY_DATA_BUF不用再手动添加。



BLE应用数据代码添加:


在“custom_app.c”文件中的Custom_STM_App_Notification(Custom_STM_App_Notification_evt_t*pNotification)”添加代码,以将BLE数据上传到4个User_xxx_Data[]缓冲区,依次添加代码如下。



2.5 修改BLE最大数据包传输长度


如果不修改,BLE单包长度最大仅为23字节


1. 在“app_conf.h”中修改BLE stack最大数据包长度(CFG_BLE_MAX_ATT_MTU)



2. 在“app_ble.c”文件SVCCTL_UserEvtFlowStatus_t_SVC CTL_App_Notification(void*pckt)中添加红色部分代码。



至此,所有代码更改完成。


03

测试平台搭建及功能测试


3.1 使用STM32CubeProgrammer BLE协议栈安装(升级)


升级ST-LINK固件以保证与STM32CubeProgrammer驱动是匹配的



查看当前FUS版本,并将FUS升级到最新版本



如果当前FUS版本是0.5.3,FUS固件使用“stm32wb5x_FUS_fw_for_fus_0_5_3.bin”,否则FUS固件使用“stm32wb5x_FUS_fw.bin”,强烈建议阅读BLE协议栈及FUS升级详细说明“STM32Cube_FW_WB_V1.13.3Projects STM32WB_Copro_Wireless_BinariesSTM32WB5xRelease_Notes.html”。



升级(安装)BLE协议栈,根据MCU型号选择相应的固件和下载地址



3.2 测试平台搭建及验证


3.2.1 在Android安卓应用市场下载安装“BLE调试助手”



3.2.2 可发现设备“MY_STM32WB”,并点击“CONNECT”后可以发现application特征和属性访问服务,如下图所示。



3.2.3 设置BLE最大单包传输长度为256字节,否则L2CAP层传输超过23字节将自动分包。



3.2.4 手机app写数据访问(User_Write_Read_Data[64])测试



3.2.5 手机App读数据访问(User_Write_Read_Data[64])测试



3.2.6 手机App写User_Write_Data[64]测试



3.2.7 手机App读User_Read_Data[64]测试。



3.2.8 通知数据访问(User_Notify_Data[64])测试



至此,整个验证和测试过程完成。


04

小结



BLE经过多年的发展和迭代,BLE协议本身已是一个很复杂和庞大的协议族,如果希望开发自定义Service和GATT应用时,若对底层协议不熟悉的话还是较为困难的。但是由于STM32良好的生态,特别是借助于我们的STM32CubeMX+STM32Cube_FW_ WB固件包,使得我们可以快速、高效地开发出各种BLE应用。



完整内容请点击“阅读原文”下载原文档。


订阅号

关注STM32

视频


B站账号


原文标题:应用笔记 | STM32WB基于Custom Template实现客户定制BLE私有协议

文章出处:【微信公众号:STM32单片机】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    6001

    文章

    43973

    浏览量

    620845
  • STM32
    +关注

    关注

    2239

    文章

    10671

    浏览量

    348755

原文标题:应用笔记 | STM32WB基于Custom Template实现客户定制BLE私有协议

文章出处:【微信号:STM32_STM8_MCU,微信公众号:STM32单片机】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    STM32WB thread启动错误是什么原因导致的?

    STM32Cube_FW_WB_V1.3.0ProjectsP-NUCLEO-WB55.NucleoApplicationsBLE_ThreadBle_Thread_Static 硬件环境:STM32WB nucleo 使用SW2切换
    发表于 04-16 08:01

    STM32WB55开发(1)----监测STM32WB连接状态

    STM32WB系列微控制器代表了STMicroelectronics在无线技术领域的新一代创新,集成了Bluetooth 5.0、Zigbee和Thread等多种无线通信协议。而在这些无线
    的头像 发表于 12-01 15:41 407次阅读
    <b class='flag-5'>STM32WB</b>55开发(1)----监测<b class='flag-5'>STM32WB</b>连接状态

    AT32WB415 Custom HID over BLE开发指南

    AT32WB415 Custom HID over BLE开发指南本应用笔记将以 AN0097的 Custom HID device为蓝本,
    发表于 10-26 06:06

    如何让STM32WB在没有LSE时运行BLE应用程序

    如何让STM32WB在没有LSE时运行BLE应用程序
    的头像 发表于 10-24 16:41 224次阅读
    如何让<b class='flag-5'>STM32WB</b>在没有LSE时运行<b class='flag-5'>BLE</b>应用程序

    用笔记 | STM32WB如何一次性烧写FUS+STACK+APP

    关键字:STM32WB,烧写,FUS+STACK+APP   目录预览 1.前言 2.操作方法 3.烧录验证 4.总结 5.附录 0 1 前言 在使用STM32WB系列MCU时,通过
    的头像 发表于 10-13 18:15 372次阅读

    基于STM32WB系列产品开发Zigbee智能能源(SE)应用

    本应用笔记全面介绍了 Zigbee®智能能源(SE)。提供了一些关于如何在 STM32WB 系列微控制器上构建 Zigbee®智能能源(SE)应用的提示,还涵盖了 sub-GHz 操作和 LBT
    发表于 10-09 17:30 3次下载

    STM32WB系列上开始使用Zigbee

    本应用笔记将指导设计者完成基于 STM32WB 系列微控制器构建特定 Zigbee®应用程序所需的所有步骤。阐明了如何与STM32WB 系列微控制器连接,同时还整合了与 Zigbee®相关的最重
    发表于 10-09 17:30 0次下载

    STM32WB BLE应用低功耗设计

    电子发烧友网站提供《STM32WB BLE应用低功耗设计.pdf》资料免费下载
    发表于 09-20 14:58 4次下载
    <b class='flag-5'>STM32WB</b> <b class='flag-5'>BLE</b>应用低功耗设计

    STM32WB的用户密钥存储(CKS)

    电子发烧友网站提供《STM32WB的用户密钥存储(CKS).pdf》资料免费下载
    发表于 09-20 14:47 0次下载
    <b class='flag-5'>STM32WB</b>的用户密钥存储(CKS)

    STM32WB硬件、软件、BLE低功耗设计及速率优化

    电子发烧友网站提供《STM32WB硬件、软件、BLE低功耗设计及速率优化.pdf》资料免费下载
    发表于 09-20 11:47 3次下载
    <b class='flag-5'>STM32WB</b>硬件、软件、<b class='flag-5'>BLE</b>低功耗设计及速率优化

    STM32WB系列的ST固件升级服务

    安装、升级或删除 STM32WB Cortex®-M0+无线协议栈:‒仅由意法半导体加密和签名‒或者,如
    发表于 09-12 09:34 0次下载

    STM32WB产品详解及FUS无线协议栈升级

    STM32WB产品详解及FUS无线协议栈升级2.4GHz无线双核STM32WB, 采用SoC单芯片设计,支持多协议射频。
    发表于 09-06 06:35

    STM32WB BLE协议栈编程指南

    本文档的主要目的是为开发人员提供有关如何使用 STM32WB BLE 协议栈 API 和相关事件回调开发低功耗蓝牙(BLE)应用的一些参考编程指南。本文档介绍了允许访问
    发表于 08-14 10:13

    STM32WB无线产品介绍

    电子发烧友网站提供《STM32WB无线产品介绍.pdf》资料免费下载
    发表于 07-31 16:50 1次下载
    <b class='flag-5'>STM32WB</b>无线产品介绍

    基于STM32WB的2.4G多协议 无线多节点连接技术

    电子发烧友网站提供《基于STM32WB的2.4G多协议 无线多节点连接技术.pdf》资料免费下载
    发表于 07-29 11:05 1次下载
    基于<b class='flag-5'>STM32WB</b>的2.4G多<b class='flag-5'>协议</b> 无线多节点连接技术