4.7. BLE应用接口

概述

介绍BLE的应用层的接口使用方法

4.7.1. API参考

Defines

ble_op_set_own_address_type(address_type)

配置设备的地址类型,默认为 0(public address).

Note

!!!注意:设置的时候必须在、设置广播参数、或者扫描参数、或者创建连接参数前配置好.

Parameters
  • address_type[in] Range: 0x00 to 0x03.

Returns

see ble_cmd_ret_e.

ble_op_adv_enable(enable)

开关BLE广播.

Note

!!!注意:开广播前必现先配置好广播的参数.

Parameters
  • enable[in] 广播使能 :0(dis) or 1(en).

Returns

see ble_cmd_ret_e.

ble_op_set_adv_filter_policy(type)

配置广播过滤策略(决定链路层如何处理扫描、连接请求);默认为 0.

Note

!!!注意:设置的时候必须在“设置广播参数ble_op_set_adv_param前配置好.

Parameters
  • type[in] 类型 :Range: 0x00 to 0x03.

Returns

see ble_cmd_ret_e.

ble_op_set_adv_param(adv_interval, adv_type, adv_channel)

配置广播参数.

Note

!!!注意:设置的时候必现在广播关闭的状态下.

Parameters
  • adv_interval[in] 广播周期,Range: 0x0020 to 0x4000 (unit: 0.625ms).

  • adv_type[in] 广播类型,Range: 0x00 to 0x04.

  • adv_channel[in] 广播类型通道,range:Range: 0x01 to 0x07.

Returns

see ble_cmd_ret_e.

ble_op_set_adv_param_ext(adv_interval, adv_type, adv_channel, peer_info)

配置广播参数+配对信息(相比配对广播参数,这个函数主要是针对定向广播使用).

Note

!!!注意:设置的时候必现在广播关闭的状态下.

Parameters
  • adv_interval[in] 广播周期,Range: 0x0020 to 0x4000 (unit: 0.625ms).

  • adv_type[in] 广播类型,Range: 0x00 to 0x04.

  • adv_channel[in] 广播类型通道,range:Range: 0x01 to 0x07.

  • peer_info[in] (全局变量地址),定向广播时,填入对方的地址信息.

Returns

see ble_cmd_ret_e.

ble_op_set_adv_data(adv_len, adv_data)

配置广播 Advertising Data内容.

Note

!!!注意:设置的时候必现在广播关闭的状态下.

Parameters
  • adv_len[in] adv 数据包长度,Range: 0x00 to 0x1f.

  • adv_data[in] (全局变量地址),adv数据包地址.

Returns

see ble_cmd_ret_e.

ble_op_set_rsp_data(rsp_len, rsp_data)

配置广播 Scan Response Data内容.

Note

!!!注意:设置的时候必现在广播关闭的状态下.

Parameters
  • rsp_len[in] rsp 包长度,Range: 0x00 to 0x1f.

  • adv_data[in] (全局变量地址),rsp数据包地址.

Returns

see ble_cmd_ret_e.

ble_op_disconnect(con_handle)

请求断开 ble 连接.

Parameters
  • con_handle[in] range: >0.

Returns

see ble_cmd_ret_e.

ble_op_disconnect_ext(con_handle, reason)

请求断开 ble 连接,by reason

Parameters
  • con_handle[in] range: >0.

  • reason[in] range: see spec.

Returns

see ble_cmd_ret_e.

ble_op_att_send_init(con_handle, att_ram_addr, att_ram_size, att_payload_size)

配置ATT发送模块RAM大小.

Parameters
  • con_handle[in] range: >0.

  • att_ram_addr[in] 传入ATT发送模块ram地址,地址按4字节对齐.

  • att_ram_size[in] 传入ATT发送模块ram大小.

  • att_payload_size[in] 发送ATT包payload的最大长度 <= MTU的payload,range:20 to MTU的payload size.

Returns

see ble_cmd_ret_e.

ble_op_multi_att_send_init(att_ram_addr, att_ram_size, att_payload_size)

MULTI API: 配置ATT发送模块初始化.

Note

多机处理,只需要初始化一次就可以.

Parameters
  • att_ram_addr[in] 传入ATT发送模块ram地址,地址按4字节对齐.

  • att_ram_size[in] 传入ATT发送模块ram大小.

  • att_payload_size[in] 发送ATT包payload的最大长度 <= MTU的payload,range:20 to MTU的payload size.

Returns

see ble_cmd_ret_e.

ble_op_multi_att_send_conn_handle(con_handle, handle_index, role)

MULTI API: 配置ATT模块 使用的连接con_handle.

Note

多机处理.

Parameters
  • con_handle[in] range:>0.

  • handle_index[in] range: 0~7 //多连接的hanlde id.

  • role[in] range: 0-gatt_sever,1-gatt_client.

Returns

see ble_cmd_ret_e.

ble_op_att_set_send_mtu(mtu)

根据对方的接收MTU大小,配置本地可发送MTU的payload大小.

Parameters
  • mtu[in] 对方mtu payload的大小.

Returns

see ble_cmd_ret_e.

ble_op_multi_att_set_send_mtu(con_handle, mtu)

MULTI API: 根据对方的接收MTU大小,配置本地可发送的MTU的大小.

Parameters
  • con_handle[in] 连接 con_handle,range:>0.

  • mtu[in] 对方mtu payload的大小.

Returns

see ble_cmd_ret_e.

ble_op_att_get_remain(remain_size_ptr)

获取ATT发送模块,cbuffer可写入数据的长度.

Parameters
  • remain_size_ptr[out] 输出可写入长度值.

Returns

see ble_cmd_ret_e.

ble_op_multi_att_get_remain(con_handle, remain_size_ptr)

MULTI API: 获取ATT发送模块,cbuffer 可写入数据的长度.

Parameters
  • con_handle[in] range:>0.

  • remain_size_ptr[out] 输出可写入长度值.

Returns

see ble_cmd_ret_e.

ble_op_att_send_data(att_handle, data, len, att_op_type)

ATT操作handle发送数据.

Parameters
  • att_handle[in] att操作的handle.

  • data[in] 数据地址.

  • len[in] 数据长度 <= cbuffer 可写入的长度.

  • att_op_type[in] see att_op_type_e (att.h).

Returns

see ble_cmd_ret_e.

ble_op_multi_att_send_data(con_handle, att_handle, data, len, att_op_type)

MULTI API: ATT操作handle发送数据.

Note

多机处理.

Parameters
  • con_handle[in] 连接 con_handle,range:>0.

  • att_handle[in] att操作handle.

  • data[in] 数据地址.

  • len[in] 数据长度 <= cbuffer 可写入的长度.

  • att_op_type[in] see att_op_type_e (att.h).

Returns

see ble_cmd_ret_e.

ble_op_att_clear_send_data(void)

ATT操作,清缓存发送的数据缓存

Returns

see ble_cmd_ret_e.

ble_op_conn_param_request(con_handle, con_param)

从机请求更新连接参数,走l2cap命令.

Parameters
  • con_handle[in] 连接 con_handle,range:>0.

  • con_param[in] (全局变量地址),连接参数.

Returns

see ble_cmd_ret_e.

ble_op_set_data_length(con_handle, tx_octets, tx_time)

发起data length 交换.(btctrl的feature打开支持DLE)

Parameters
  • tx_octets[in] DLE发送长度.

  • tx_time[in] DLE发送事件.

Returns

see ble_cmd_ret_e.

ble_op_set_ext_adv_param(param, param_len)

ble5.0 配置广播参数.

Parameters
  • param[in] 广播参数.

  • tx_time[in] 参数长度.

Returns

see ble_cmd_ret_e.

ble_op_set_ext_adv_data(data, data_len)

ble5.0 配置 adv 数据包.

Parameters
  • data[in] 数据包内容.

  • data_len[in] 数据包长度.

Returns

see ble_cmd_ret_e.

ble_op_set_ext_rsp_data(data, data_len)

ble5.0 配置 respond 数据包.

Parameters
  • data[in] 数据包内容.

  • data_len[in] 数据包长度.

Returns

see ble_cmd_ret_e.

ble_op_set_ext_adv_enable(cmd, cmd_len)

ble5.0 开关广播.

Parameters
  • cmd[in] 命令信息.

  • cmd_len[in] 命令长度.

Returns

see ble_cmd_ret_e.

ble_op_set_ext_phy(con_handle, all_phys, tx_phy, rx_phy, phy_options)

ble5.0 配置phy.

Parameters
  • con_handle[in] 连接 con_handle,range:>0.

  • all_phys[in] 0.

  • tx_phy[in] CONN_SET_CODED_PHY.

  • rx_phy[in] CONN_SET_CODED_PHY.

  • phy_options[in] CONN_SET_PHY_OPTIONS.

Returns

see ble_cmd_ret_e.

ble_op_set_ext_scan_param(param, param_len)

ble5.0 配置 主机scan 参数.

Parameters
  • param[in] 参数内容.

  • param_len[in] 参数长度.

Returns

see ble_cmd_ret_e.

ble_op_ext_scan_enable(cmd, cmd_len)

ble5.0 配置 主机scan 开关.

Parameters
  • cmd[in] 命令信息.

  • cmd_len[in] 命令长度.

Returns

see ble_cmd_ret_e.

ble_op_ext_create_conn(conn_param, param_len)

ble5.0 配置 主机创建连接监听.

Parameters
  • conn_param[in] 连接参数信息.

  • param_len[in] 参数长度.

Returns

see ble_cmd_ret_e.

ble_op_latency_skip(con_handle, skip_interval)

忽略进入latency 作用的次数

Note

!!!注意:让设备不进入latency模式,加快响应速度,但会耗电.

Parameters
  • con_handle[in] range:>0.

  • skip_interval[in] 忽略的interval的次数.

Returns

see ble_cmd_ret_e.

ble_op_test_key_num(con_handle, key_num)

测试盒识别按键测试.

Parameters
  • con_handle[in] range:>0.

  • key_num[in] 按键.

Returns

see ble_cmd_ret_e.

ble_op_stack_exit(control)

退出ble协议栈.

Note

若已调用btstack_exit退出,则无需调用此接口

Parameters
  • control[in] : 0&#8212;退出stack(默认),1&#8212;退出stack + controller.

Returns

see ble_cmd_ret_e.

ble_op_regist_thread_call(thread_callback)

挂载协议栈线程调用.

Note

用于同步线程处理,慎用

Parameters
  • thread_callback[in] 回调函数.

Returns

see ble_cmd_ret_e.

ble_op_scan_enable(enable)

开关BLE搜索扫描.

Note

filter_duplicate 默认为 1.

Note

!!!注意:开搜索前必现先配置好搜索的参数ble_op_set_scan_param.

Parameters
  • enable[in] 0 or 1.

Returns

see ble_cmd_ret_e.

ble_op_scan_enable2(enable, filter_duplicate)

开关BLE搜索扫描2.

Note

filter_duplicate 默认为 1.

Note

!!!注意:开搜索前必现先配置好搜索的参数ble_op_set_scan_param.

Parameters
  • enable[in] 0 or 1.

  • filter_duplicate[in] 0 or 1.

Returns

see ble_cmd_ret_e.

ble_op_set_scan_filter_policy(type)

配置scan filter policy,默认type为0.

Note

!!!注意:设置的时候必须在 设置扫描参数 ble_op_set_scan_param 前配置好.

Parameters
  • type[in] Range: 0x00 to 0x03.

Returns

see ble_cmd_ret_e.

ble_op_set_scan_param(scan_type, scan_interval, scan_window)

配置搜索参数.

Parameters
  • scan_type[in] 搜索类型 Range: 0x00 to 0x01 (unit: 0.625ms).

  • scan_interval[in] 搜索周期 Range: 0x0004 to 0x4000 (unit: 0.625ms) >= scan_window.

  • scan_window[in] 搜索窗口 Range: 0x0004 to 0x4000 (unit: 0.625ms), <= scan_interval.

Returns

see ble_cmd_ret_e.

ble_op_set_create_filter_policy(type)

配置creat filter policy,默认type: 0.

Note

!!!注意:设置的时候必须在 设置创建连接参数 ble_op_create_connection 前配置好.

Parameters
  • type[in] Range: 0x00 to 0x03.

Returns

see ble_cmd_ret_e.

ble_op_create_connection(create_conn_param)

BLE创建连接监听.

Parameters
  • create_conn_param[in] 连接参数.

Returns

see ble_cmd_ret_e.

ble_op_create_connection_ext(create_conn_param_ext)

BLE创建连接监听,扩展传入参数

Parameters
  • create_conn_param_ext[in] 连接参数.

Returns

see ble_cmd_ret_e.

ble_op_create_connection_cancel()

取消BLE连接监听.

Returns

see ble_cmd_ret_e.

ble_op_search_profile_all()

ble 主机搜索所有服务.

Returns

see ble_cmd_ret_e.

ble_op_search_profile_uuid16(uuid16)

ble 主机搜索指定UUID16服务.

Parameters
  • uuid16[in] uuid.

Returns

see ble_cmd_ret_e.

ble_op_search_profile_uuid128(uuid128_pt)

ble 主机搜索指定UUID128服务.

Parameters
  • uuid128_pt[in] uuid.

Returns

see ble_cmd_ret_e.

ble_op_conn_param_update(con_handle, con_param)

ble 主机更新连接参数.

Parameters
  • con_handle[in] range:>0.

  • con_param[in] (全局变量地址),连接参数.

Returns

see ble_cmd_ret_e.

Enums

enum ble_cmd_type_e

ble命令请求类型

Note

用户不能自己在中间添加值

Values:

enumerator BLE_CMD_ADV_ENABLE
enumerator BLE_CMD_ADV_PARAM
enumerator BLE_CMD_ADV_DATA
enumerator BLE_CMD_RSP_DATA
enumerator BLE_CMD_DISCONNECT
enumerator BLE_CMD_REGIEST_THREAD
enumerator BLE_CMD_ATT_SEND_INIT
enumerator BLE_CMD_ATT_MTU_SIZE
enumerator BLE_CMD_ATT_VAILD_LEN
enumerator BLE_CMD_ATT_SEND_DATA
enumerator BLE_CMD_REQ_CONN_PARAM_UPDATE
enumerator BLE_CMD_SCAN_ENABLE
enumerator BLE_CMD_SCAN_PARAM
enumerator BLE_CMD_STACK_EXIT
enumerator BLE_CMD_CREATE_CONN
enumerator BLE_CMD_CREATE_CONN_CANCEL
enumerator BLE_CMD_ADV_PARAM_EXT
enumerator BLE_CMD_SEND_TEST_KEY_NUM
enumerator BLE_CMD_LATENCY_HOLD_CNT
enumerator BLE_CMD_SET_DATA_LENGTH
enumerator BLE_CMD_SET_HCI_CFG
enumerator BLE_CMD_SCAN_ENABLE2
enumerator BLE_CMD_ATT_SERVER_REQ_RESUME
enumerator BLE_CMD_MULTI_ATT_SEND_INIT
enumerator BLE_CMD_MULTI_ATT_SET_CONN_HANDLE
enumerator BLE_CMD_MULTI_ATT_SEND_DATA
enumerator BLE_CMD_MULTI_ATT_MTU_SIZE
enumerator BLE_CMD_MULTI_ATT_VAILD_LEN
enumerator BLE_CMD_SM_REQ_RESUME
enumerator BLE_CMD_CREATE_CONN_EXT
enumerator BLE_CMD_DISCONNECT_EXT
enumerator BLE_CMD_ATT_CLEAR_SEND_DATA
enumerator BLE_CMD_EXT_ADV_PARAM
enumerator BLE_CMD_EXT_ADV_DATA
enumerator BLE_CMD_EXT_RSP_DATA
enumerator BLE_CMD_EXT_ADV_ENABLE
enumerator BLE_CMD_SET_PHY
enumerator BLE_CMD_EXT_SCAN_PARAM
enumerator BLE_CMD_EXT_SCAN_ENABLE
enumerator BLE_CMD_EXT_CREATE_CONN
enumerator BLE_CMD_PERIODIC_ADV_PARAM
enumerator BLE_CMD_PERIODIC_ADV_DATA
enumerator BLE_CMD_PERIODIC_ADV_ENABLE
enumerator BLE_CMD_PERIODIC_ADV_CREAT_SYNC
enumerator BLE_CMD_PERIODIC_ADV_TERMINATE_SYNC
enumerator BLE_CMD_PERIODIC_ADV_CREATE_SYNC_CANCEL
enumerator BLE_CMD_SEARCH_PROFILE
enumerator BLE_CMD_WRITE_CCC
enumerator BLE_CMD_ONNN_PARAM_UPDATA
enum ble_cmd_ret_e

ble命令请求返回值

Note

用户不能自己在中间添加值

Values:

enumerator BLE_CMD_RET_SUCESS

执行成功

enumerator BLE_CMD_RET_BUSY

命令处理忙

enumerator BLE_CMD_PARAM_OVERFLOW

传数溢出

enumerator BLE_CMD_OPT_FAIL

操作失败

enumerator BLE_BUFFER_FULL

缓存满了

enumerator BLE_BUFFER_ERROR

缓存出错

enumerator BLE_CMD_PARAM_ERROR

传参出错

enumerator BLE_CMD_STACK_NOT_RUN

协议栈没有运行

enumerator BLE_CMD_CCC_FAIL

没有使能通知,导致NOTIFY或INDICATE发送失败

enum search_profile_type_e

搜索profile的方式

Note

用户不能自己在中间添加值

Values:

enumerator PFL_SERVER_UUID16

指定16bit UUID搜索方式

enumerator PFL_SERVER_UUID128

指定128bit UUID搜索方式

enumerator PFL_SERVER_ALL

搜索所有的UUID

enum hci_cfg_par_e

设置过滤规则

Note

用户不能自己在中间添加值

Values:

enumerator HCI_CFG_OWN_ADDRESS_TYPE

设置mac地址过滤规则

enumerator HCI_CFG_ADV_FILTER_POLICY

设置广播包过滤规则

enumerator HCI_CFG_SCAN_FILTER_POLICY

设置扫描过滤规则

enumerator HCI_CFG_INITIATOR_FILTER_POLICY

设置连接发起的过滤规则

enum remote_type_e

对方主机的系统类型

Note

用户不能自己在中间添加值

Values:

enumerator REMOTE_TYPE_UNKNOWN

未查询or查询对方未响应

enumerator REMOTE_TYPE_ANDROID

安卓系统

enumerator REMOTE_TYPE_IOS

ios系统

Functions

ble_cmd_ret_e ble_user_cmd_prepare(ble_cmd_type_e cmd, int argc, ...)

ble命令请求.

Parameters
  • cmd[in] 命令类型.

  • argc[in] 命令个数.

Returns

ble_cmd_ret_e

void gatt_client_init(void)

Gatt client角色初始化.

void gatt_client_register_packet_handler(btstack_packet_handler_t handler)

注册gatt client角色,事件回调函数.

Parameters

handler[in] 事件处理函数.

void le_device_db_init(void)

初始化配对表.

Note

上电初始化一次.

void reset_PK_cb_register(void (*reset_pk)(u32*))

注册passkey输入回调.

Parameters

reset_pk[in] 复位按键输入.

int le_controller_set_mac(void *addr)

设置ble蓝牙的public地址.

Note

可以结合接口 ble_op_set_ownaddress_type 配置选择地址类型.

Note

修改地址必须在ble非工作状态下才能生效( 没有scan,没有adv,没有connected).

Parameters

addr[in] public地址.

Returns

0->success ,非0->fail.

int le_controller_get_mac(void *addr)

获取ble蓝牙的public地址.

Parameters

addr[out] pulic地址.

Returns

0->success ,非0->fail.

int le_controller_set_random_mac(void *addr)

初始化ble蓝牙random地址.

Note

结合接口ble_op_set_own_address_type 配置选择地址类型.

Note

修改地址必须在ble非工作状态下才能生效(内有scan,没有adv,没connected).

Parameters

addr[in] random地址.

Returns

0->success ,非0->fail.

int le_controller_get_random_mac(void *addr)

获取ble蓝牙的random地址.

Parameters

addr[out] random地址.

Returns

0->success ,非0->fail.

void ble_stack_gatt_role(u8 role)

配置协议栈 GATT 角色处理,default server.

Parameters

role[in] GATT role: 0&#8212;server ,1&#8212;client ,2&#8212;server + client.

void user_client_init(u16 handle, u8 *buffer, u16 buffer_size)

client 连接后初始化.

Parameters
  • handle[in] range :>0.

  • buffer[in] 配置缓存地址.

  • buffer_size[in] 缓存大小.

s8 ble_vendor_get_peer_rssi(u16 conn_handle)

获取链路对方的信号强度.

Parameters

con_handle[in] range :>0.

Returns

rssi 强度 ,range :-127 ~128 dbm.

bool ble_vendor_interval_event_enable(u16 conn_handle, int enable)

使能周期interval事件上报.

Parameters
  • con_handle[in] range :>0.

  • enable[in] 1 or 0.

Returns

true or false.

u16 ble_vendor_set_default_att_mtu(u16 mtu_size)

配置协议栈ATT默认的MTU大小.

Parameters

mtu_size[in] 配置MUT大小 ,range :23 ~517.

Returns

配置后mtu_size的值.

void user_client_set_search_complete(void)

设置 client 搜索结束.

bool ble_vendor_random_address_generate(u8 *address, u8 type)

提供生成ble对应的类型地址.

Note

生成RESOLVABLE_PRIVATE_ADDR,需要等协议栈初始化IRK后才能生成.

Parameters
  • address[out] 类型对应地址.

  • type[in] ble_type (eg:1.STATIC_DEVICE_ADDR. 2.NON_RESOLVABLE_PRIVATE_ADDR. 3.RESOLVABLE_PRIVATE_ADDR).

Returns

true or false.

void lib_make_ble_address(u8 *ble_address, u8 *edr_address)

根据提供的edr地址生成唯一对应的ble地址.

Note

用户可以自定义edr和ble地址关联规则,重写这个接口

Parameters
  • ble_adress[out] BLE_address.

  • edr_adress[in] EDR_address.

void ble_list_config_reset(u8 pair_devices_count, u8 is_allow_cover)

ble master&slave 配置配对表(可以不设置,使用sdk默认值).

Note

上电调用配置,若配置的个数跟之前不一样,默认清所有的配对表数据.

Note

VM 掉电记录保护.

Note

主从机共用一个配对表.

Parameters
  • pair_devices_count[in] 记录配对设备,range: 0~10,默认10.若配置为0:则不使用配对表记录管理,不限制配对个数.

  • is_allow_cover[in] 是否允许循环覆盖记录 1 or 0,默认1.

Returns

true or false.

bool ble_list_pair_accept(u8 enable)

配置是否接受新设备请求配对,记录在VM,(可以不设置,使用sdk默认值).

Note

VM 掉电记录保护.

Note

是否覆盖是由接口 ble_list_config_reset 的参数 is_allow_cover 决定.

Parameters

enable[in] 允许新设备配对开关,1 or 0,默认1.

Returns

true or false.

u16 ble_list_get_count(void)

获取配对表已有配对个数.

Returns

0~10.

bool ble_list_bonding_remote(u8 *conn_addr, u8 conn_addr_type)

绑定已配对的指定设备,清除其他配对设备.

Note

VM 掉电记录保护.

Parameters
  • conn_addr[in] 对方地址6bytes.

  • conn_addr_type[in] 对方地址类型range: 0~1.

Returns

true or false.

bool ble_list_clear_all(void)

ble 清空配对表.

Returns

true or false.

bool ble_list_check_addr_is_exist(u8 *conn_addr, u8 conn_addr_type)

ble 检测连接地址是否在已配对表中.

Parameters
  • conn_addr[in] 对方地址6bytes.

  • conn_addr_type[in] 对方地址类型range: 0~1.

Returns

true or false.

bool ble_list_delete_device(u8 *conn_addr, u8 conn_addr_type)

ble 把设备从配对表中删除.

Parameters
  • conn_addr[in] 对方地址6bytes.

  • conn_addr_type[in] 对方地址类型range: 0~1.

Returns

true or false.

bool ble_list_get_last_id_addr(u8 *id_addr)

ble 获取配对表中最后连接设备的 id_address (public address).

Parameters

id_addr[out] 输出最后连接设备的id地址.

Returns

true or false.

bool ble_list_get_id_addr(u8 *conn_addr, u8 conn_addr_type, u8 *id_addr)

ble 获取已配对设备连接地址对应的 id_address (public address or static address).

Parameters
  • conn_addr[in] 对方连接地址6bytes.

  • conn_addr_type[in] 对方连接地址类型range: 0~1.

  • id_addr[out] 输出已配对设备的id地址.

Returns

true or false.

bool ble_list_get_remote_type(u8 *conn_addr, u8 conn_addr_type, u8 *output_type)

ble 获取已配对设备的系统类型.

Note

只支持作为从机获取手机类型.

Parameters
  • conn_addr[in] 对方连接地址6bytes.

  • conn_addr_type[in] 对方连接地址类型range: 0~1.

  • output_type[out] 见 remote_type_e 定义.

Returns

true or false.

void att_server_set_exchange_mtu(u16 con_handle)

ble slave: att server 连接后主动发起请求MTU交换流程.

Parameters

handle[in] range:>0.

void att_server_flow_enable(u8 enable)

ble slave: att server 使能流控功能.

Note

蓝牙初始化后可调用.

Parameters
  • handle[in] range:>0.

  • enable[in] 1 or 0.

void att_server_flow_hold(hci_con_handle_t con_handle, u8 hold_flag)

ble slave: att server 控制收数流控.

Note

蓝牙初始化后可调用,对方client要使用write的方式发送数据才能有流控生效

Parameters
  • handle[in] range:>0.

  • hold_flag[in] 1&#8212;停止收发数据,0&#8212;开始正常收发数.

void att_server_set_check_remote(u16 con_handle, void (*callback)(u16 con_handle, remote_type_e remote_type))

ble slave: server 配对连接时,检查对方操作系统.

Note

在第一次配对连接时调用,HCI_EVENT_ENCRYPTION_CHANGE 事件后.

Parameters
  • handle[in] range:>0.

  • callback[in] 检查完回调.

int att_send_check_multi_dev(u8 server_max, u8 client_max)

检测协议栈att模块是否支持多机.

Parameters
  • server_max[in] 传入判断的从机个数.

  • client_max[in] 传入判断的主机个数.

Returns

0->success ,非0->fail.

int att_server_change_profile(u8 const *profile_data)

可修改GATT服务的profile.

Note

蓝牙未连接状态下,可调用修改.

Parameters

profile_data[in] gatt profile.

Returns

0->success ,非0->fail.

Variables

struct create_conn_param_t _GNU_PACKED_
struct conn_update_param_t
#include <ble_api.h>

更新连接参数

Public Members

u16 interval_min

连接周期范围最小值(unit:1.25ms)

u16 interval_max

连接周期范围最大值(unit:1.25ms)

u16 latency

忽略通信次数(unit: interval)

u16 timeout

(unit:10ms)

struct create_conn_param_t
#include <ble_api.h>

连接创建时的连接参数

Public Members

u16 conn_interval

连接周期(unit:1.25ms)

u16 conn_latency

忽略通信次数(unit: interval)

u16 supervision_timeout

(通信超时 unit:10ms)

u8 peer_address_type

对方地址类型:0&#8212;public address,1&#8212;random address

u8 peer_address[6]

对方地址address

struct create_conn_param_ext_t
#include <ble_api.h>

扩展类型BLE 5.0连接创建时的连接参数

Public Members

u16 le_scan_interval

scan 周期(unit: 0.625ms)

u16 le_scan_window

scan 窗口(unit: 0.625ms)

u8 initiator_filter_policy

过滤,set 0

u8 peer_address_type

对方地址类型:0&#8212;public address,1&#8212;random address

u8 peer_address[6]

对方地址

u8 own_address_type

本地地址类型:0&#8212;public address,1&#8212;random address

u16 conn_interval_min

连接周期最小值(unit:1.25ms)

u16 conn_interval_max

连接周期最大值(unit:1.25ms)

u16 conn_latency

忽略通信次数(unit: interval)

u16 supervision_timeout

通信超时 unit:10ms

u16 minimum_ce_length

set 1

u16 maximum_ce_length

set 1

struct adv_report_t
#include <ble_api.h>

广播包信息

Public Members

u8 event_type

对方广播包类型: 0&#8212;ADV_IND,1&#8212;ADV_DIRECT_IND,2&#8212;ADV_SCAN_IND,3&#8212;ADV_NONCONN_IND,4&#8212;SCAN_RSP

u8 address_type

对方地址类型:0&#8212;public address,1&#8212;random address

u8 address[6]

peer_address

s8 rssi

range:-127 ~128 dbm

u8 length

广播包长度

u8 data[0]

广播包内容

struct sm_just_event_t
#include <ble_api.h>

安全认证确认信息

Public Members

u8 type

See <btstack/hci_cmds.h> SM_…

u8 size

信息长度

u16 con_handle

connection ‘s handle, >0

u8 addr_type

对方地址类型:0&#8212;public address,1&#8212;random address

u8 address[6]

对方地址

u8 data[4]

扩展信息