bt_gatt_client_unsubscribe()

bt_gatt_client_unsubscribe()

Description

Function unsubscribes to characteristic value.

Syntax

bt_gatt_client_unsubscribe(connection_id, chrc_value_handle);

Parameters

Variable

Input

Variable

Input

connection_id

Connection ID which was described for a connection during connect to peer device procedure. Could be either 0 or 1.

chrc_value_handle

Characteristic value handle to unsubscribe from.

Returns

Return value

Return explanation

SCRIPT_OPERATION_SUCCESS

Unsubscribe operation was successful.

SCRIPT_OPERATION_FAILED

Unsubscribe operation failed.

SCRIPT_NO_ACCESS

Bluetooth GATT client is not initialized.

SCRIPT_PARAM_INVALID

Could be one of the following:

  • Incorrect connection id or connection is not present

  • Characteristic or descriptor handle too high or too low.

Function call example

#include <io> #include <read> #include <float> #include <string> #include <core> #include <write> #include <define> #include <socket> #include <bluetooth> #define FIRST_CONNECTION 0 #define SECOND_CONNECTION 1 new peer_mac_address[] = [0xFF, 0x48, 0x80, 0x33, 0xE3, 0xA8]; new chr_val_handle = 0x0F; new chr_val_ccc_handle = 0x10; main() { bt_init(); bt_gatt_client_init(); while (bt_gatt_client_connect(FIRST_CONNECTION, BT_ADDR_RANDOM, peer_mac_address) != SCRIPT_OPERATION_SUCCESS) { Delay(100); } bt_gatt_client_subscribe(FIRST_CONNECTION, chr_val_handle, chr_val_ccc_handle, BT_GATT_CCC_NOTIFY); bt_gatt_client_unsubscribe(FIRST_CONNECTION, chr_val_handle); for(;;) { Delay(100); } }

 

Debug example

This example initializes BLE, then initializes GATT Client module, connects to peer device, subscribes to attribute and unsubscribes from it. Example uses debug_print function to print information log to Initialized peripheral.

#include <io> #include <read> #include <float> #include <string> #include <core> #include <write> #include <define> #include <socket> #include <bluetooth> #include <debug> #define RS232_SPEED 115200 #define WORD_LENGTH WORDLENGTH_8 #define STOP_BITS STOPBITS_1 #define PARITY PARITY_NONE #define FIRST_CONNECTION 0 #define SECOND_CONNECTION 1 new peer_mac_address[] = [0xFF, 0x48, 0x80, 0x33, 0xE3, 0xA8]; new chr_val_handle = 0x0F; new chr_val_ccc_handle = 0x10; new return_code = SCRIPT_OPERATION_SUCCESS; main() { Init(RS232, RS232_SPEED, WORD_LENGTH, STOP_BITS, PARITY); debug_init(RS232); return_code = bt_init(); if (return_code != SCRIPT_OPERATION_SUCCESS) { // Handle failed bt_init here debug_print("bt_init failed\r\n"); } else { debug_print("bt_init succeeded\r\n"); } return_code = bt_gatt_client_init(); if (return_code != SCRIPT_OPERATION_SUCCESS) { // Handle failed bt_gatt_client_init here debug_print("bt_gatt_client_init failed\r\n"); } else { debug_print("bt_gatt_client_init succeeded\r\n"); } debug_print("Connecting to a device with this MAC address: %X:%X:%X:%X:%X:%X\r\n", peer_mac_address[0], peer_mac_address[1], peer_mac_address[2], peer_mac_address[3], peer_mac_address[4], peer_mac_address[5]); while (bt_gatt_client_connect(FIRST_CONNECTION, BT_ADDR_RANDOM, peer_mac_address) != SCRIPT_OPERATION_SUCCESS) { debug_print("bt_gatt_client_connect time-out\r\n"); Delay(100); } debug_print("Connected successfully\r\n"); return_code = bt_gatt_client_subscribe(FIRST_CONNECTION, chr_val_handle, chr_val_ccc_handle, BT_GATT_CCC_NOTIFY); if (return_code != SCRIPT_OPERATION_SUCCESS) { // Handle failed bt_gatt_client_subscribe here debug_print("bt_gatt_client_subscribe failed\r\n"); } else { debug_print("bt_gatt_client_subscribe succeeded\r\n"); } return_code = bt_gatt_client_unsubscribe(FIRST_CONNECTION, chr_val_handle); if (return_code != SCRIPT_OPERATION_SUCCESS) { // Handle failed bt_gatt_client_unsubscribe here debug_print("bt_gatt_client_unsubscribe failed\r\n"); } else { debug_print("bt_gatt_client_unsubscribe succeeded\r\n"); } for(;;) { Delay(1000); } }