Demo:Btble

来自Bouffalo Lab Docs
跳转到导航 跳转到搜索

Demo介绍:

这部分Demo主要是蓝牙通讯相关功能的实例代码,这些demo保存在SDK的 example/btble路径下。

blemesh_cli:

基本介绍:

该demo创建了一个 Bluetooth mesh 网络,通过向串口发送指令进行初始化后,就可以通过手机APP在mesh网络中进行添加并连接。

DEMO命令和输出:

bouffalolab />blemesh_init              #初始化bluemesh网络
#输出:
Init successfully 
Env[LOCAL_NAME] Data len[10], setting_env_cb
Use pb-adv or pb-gatt to enable advertising

bouffalolab />blemesh_pb 2 1            
#输出:
PB-GATT enabled

执行完上述命令后,就可以使用手机APP进行NODE的添加和连接。 添加的步骤如下:

如何使用配网器 Provisioner 将新设备添加进网络中:

大概流程如下:

1.打开未配网设备 ---- 2.启动配网器Provisioner ---- 3.监听设备广播 ---- 4.添加设备到网络 ---- 5.获取设备信息 ---- 6.分配密钥

provisioner设备编译时,必须更改一个编译选项:

CONFIG_BT_MESH_PROVISIONER=1

执行步骤1:打开未配网设备并且输入以下命令:

blemesh_init        # 初始化Mesh协议栈
blemesh_pb 1 1      # 开启PB-ADV和PB-GATT配网承载

执行步骤2: 打开配网器设备输入以下命令:

bouffalolab />blemesh_pvnr_init             #初始化Provisioner
#得到输出:
    .........
    Local node provisioned, net_idx 0x0000 address 0x0001

    Network key:8fe7deea92943001567251dc1f9b0f03

    Dev key:89c2f18f9f286661c6bbb1430d7aadb7

    Provisioning completed
  • net_idx 0x0000:网络索引
  • address 0x0001:Provisioner自身地址
  • Network key:网络层加密密钥
  • Dev key:设备专属配置密钥

执行步骤3:打开广播

执行以下命令:

blemesh_beacon_listen 0x01  # 开启广播监听
  • 扫描周围广播Mesh信标的设备
  • 捕获并显示未配网设备的UUID(如:07af000011112222333318b905de96c2
  • UUID包含设备身份信息(厂商ID、产品ID等)

执行步骤4:在配网器设备上执行 添加设备到网络命令

bouffalolab />blemesh_provision_adv 07af000011112222333318b905de96c2 0 3 0
#输出
    P1:“07af000011112222333318b905de96c2" is UUID information.
    P2:0:net_idx
    P3:3: assign node unicast address。
    P4:0:attention_duration
  • UUID:目标设备的唯一标识
  • net_idx 0:使用的网络索引
  • address 3:分配给设备的单播地址(0x0003)
  • attention_duration 0:配网指示时长(0=无提示)

执行步骤5:获取设备信息

执行的命令与输出内容:

bouffalolab /> blemesh_get_comp 0x0000 0x0003 0x00
#输出:
P1:net index.

P2:dst address.

P3:page number.
  • net_idx 0x0000:网络索引
  • dst 0x0003:目标设备地址
  • page 0x00:组成数据页码

执行步骤6:分配密钥key

bouffalolab />  blemesh_app_key_add 0x0000 0x0003 0x0000 0x0000
#输出
P1:net index.

P2:dst address.

P3:Network key index。

P4:Application key index.

blemesh_simple

该demo的功能与上述的一致,但是该demo不需要前置的命令操作,在板子上电后会自动启动 blue mesh 网络,你可以参考blemesh_cli中的连接步骤直接进行节点连接。

如果你需要发送指令来控制,你可以发送以下指令:

"gen_cli_send dstaddress"将控制数据发送到指定的设备地址或这组地址。

btble_cli

该demo会启动一个基本的BLE设备。你需要使用命令去进行操控该设备。

如果您不熟悉BLE的通信流程,请参考以下基本流程。

#服务端执行
ble_init
ble_start_adv 0 0 0x80 0x80

#客户端设备执行
ble_start_scan 0 1 0x80 0x50

#scan后会获取到对应的地址 进行连接 这里是示例地址
#连接成功后 服务端的终端会显示  connected
ble_connect 0 B40ECF2E90FC          

#查询GATT服务 这里是通用服务码
ble_discover 0 0x1800 0x1 0xffff 或者 ble_discover 0 0x1801 0x1 0xffff

#如果要查询特殊码(这里可以省略这一步)
ble_discover 3 0x1800 0x1 0xffff

#查询到服务后,可以选择直接读写:
ble_read 0x7 0
ble_write 0x7 0 2 0102

#也可以通过CCC进行订阅操作
ble_subscribe 0x4 0x3 0x1  
#取消订阅:
ble_unsubscribe

上述的函数相关具体说明,全部保存在SDK的路径下: docs/en/api_reference/ble.rst

BLE基本通信流程: GATT服务是什么:


CCC则是一个订阅开关,本质上是一个数值,服务端会监控这个数值,假设该数值变化了,那么服务端则认为连接设备需要订阅消息。

btble_controller_test

BLE控制器测试demo,终端返回 pwr_mod is bf 则表示正常。

btble_central

该demo上电后会直接自动扫描周围的BLE设备,当设备存在并且名称匹配时,会直接进行连接并扫描对应的GATT服务然后进行订阅。

设备名称,GATT服务等都是程序提前设定好的,这部分设定在同级目录下的 config.h 文件中。

这里展示一部分 :

#endif 

/**
*  CONFIG_BT_DEVICE_NAME:Bluetooth device name. Name can be up
*  to 248 bytes long (excluding NULL termination). Can be empty string
*/
#ifndef CONFIG_BT_DEVICE_NAME
#if defined(CONFIG_AUTO_PTS)
#define CONFIG_BT_DEVICE_NAME "AUTO_PTS_TEST0123456789012345"
#else
#if defined(BL602)
#define CONFIG_BT_DEVICE_NAME "BL602-BLE-DEV"
#elif defined(BL702)
#define CONFIG_BT_DEVICE_NAME "BL702-BLE-DEV"
#elif defined(BL702L)
#define CONFIG_BT_DEVICE_NAME "BL702L-BLE-DEV"
#else
#define CONFIG_BT_DEVICE_NAME "BTBLE-DEV"
#endif
#endif
#endif
/**

btble_periphral

该demo测试了BLE的OAD服务,上电后会直接执行GATT的OAD服务注册,然后进行广播,所有了连接上该服务端的设备订阅OAD服务都可以进行OAD远程升级。

注意这部分代码需要分区表,所以在烧录时必须进行 make whole 将分区表信息烧录进去。

OAD烧录的固件需要手动生成:

#其中FW.bin 是你要进行升级的bin
python3 components/wireless/bluetooth/tools/GenerateOAD.py FW.bin FW.bin.sha256