Zephyr API Documentation 4.0.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
gatt.h
Go to the documentation of this file.
1
5/*
6 * Copyright (c) 2015-2016 Intel Corporation
7 *
8 * SPDX-License-Identifier: Apache-2.0
9 */
10#ifndef ZEPHYR_INCLUDE_BLUETOOTH_GATT_H_
11#define ZEPHYR_INCLUDE_BLUETOOTH_GATT_H_
12
20#include <stdint.h>
21#include <stddef.h>
22
23#include <sys/types.h>
24
25#include <zephyr/sys/slist.h>
26#include <zephyr/sys/util.h>
31
32#ifdef __cplusplus
33extern "C" {
34#endif
35
92
100#define BT_GATT_ERR(_att_err) (-(_att_err))
101
103enum {
110
117
125};
126
127/* Forward declaration of GATT Attribute structure */
128struct bt_gatt_attr;
129
160typedef ssize_t (*bt_gatt_attr_read_func_t)(struct bt_conn *conn,
161 const struct bt_gatt_attr *attr,
162 void *buf, uint16_t len,
163 uint16_t offset);
164
203typedef ssize_t (*bt_gatt_attr_write_func_t)(struct bt_conn *conn,
204 const struct bt_gatt_attr *attr,
205 const void *buf, uint16_t len,
206 uint16_t offset, uint8_t flags);
207
237 const struct bt_uuid *uuid;
238
251
264
277
290
301
310 bool _auto_assigned_handle: 1;
312};
313
317 const struct bt_gatt_attr *attrs;
320};
321
331
339
349
361 void (*att_mtu_updated)(struct bt_conn *conn, uint16_t tx, uint16_t rx);
362
364};
365
379 bool (*read_authorize)(struct bt_conn *conn,
380 const struct bt_gatt_attr *attr);
381
393 bool (*write_authorize)(struct bt_conn *conn,
394 const struct bt_gatt_attr *attr);
395};
396
405#define BT_GATT_CHRC_BROADCAST 0x01
411#define BT_GATT_CHRC_READ 0x02
417#define BT_GATT_CHRC_WRITE_WITHOUT_RESP 0x04
423#define BT_GATT_CHRC_WRITE 0x08
430#define BT_GATT_CHRC_NOTIFY 0x10
436#define BT_GATT_CHRC_INDICATE 0x20
442#define BT_GATT_CHRC_AUTH 0x40
449#define BT_GATT_CHRC_EXT_PROP 0x80
450
460
462#define BT_GATT_CEP_RELIABLE_WRITE 0x0001
463#define BT_GATT_CEP_WRITABLE_AUX 0x0002
464
470
478#define BT_GATT_CCC_NOTIFY 0x0001
484#define BT_GATT_CCC_INDICATE 0x0002
485
491
500#define BT_GATT_SCC_BROADCAST 0x0001
501
507
523
546static inline const char *bt_gatt_err_to_str(int gatt_err)
547{
548 return bt_att_err_to_str((gatt_err) < 0 ? -(gatt_err) : (gatt_err));
549}
550
559
579
607
615
623
624enum {
627};
628
639typedef uint8_t (*bt_gatt_attr_func_t)(const struct bt_gatt_attr *attr,
641 void *user_data);
642
655void bt_gatt_foreach_attr_type(uint16_t start_handle, uint16_t end_handle,
656 const struct bt_uuid *uuid,
657 const void *attr_data, uint16_t num_matches,
659 void *user_data);
660
670static inline void bt_gatt_foreach_attr(uint16_t start_handle, uint16_t end_handle,
672 void *user_data)
673{
674 bt_gatt_foreach_attr_type(start_handle, end_handle, NULL, NULL, 0, func,
675 user_data);
676}
677
686struct bt_gatt_attr *bt_gatt_attr_next(const struct bt_gatt_attr *attr);
687
703 uint16_t attr_count,
704 const struct bt_uuid *uuid);
705
715
727
743ssize_t bt_gatt_attr_read(struct bt_conn *conn, const struct bt_gatt_attr *attr,
744 void *buf, uint16_t buf_len, uint16_t offset,
745 const void *value, uint16_t value_len);
746
763 const struct bt_gatt_attr *attr,
764 void *buf, uint16_t len, uint16_t offset);
765
773#define BT_GATT_SERVICE_DEFINE(_name, ...) \
774 const struct bt_gatt_attr attr_##_name[] = { __VA_ARGS__ }; \
775 const STRUCT_SECTION_ITERABLE(bt_gatt_service_static, _name) = \
776 BT_GATT_SERVICE(attr_##_name)
777
778#define _BT_GATT_ATTRS_ARRAY_DEFINE(n, _instances, _attrs_def) \
779 static struct bt_gatt_attr attrs_##n[] = _attrs_def(_instances[n])
780
781#define _BT_GATT_SERVICE_ARRAY_ITEM(_n, _) BT_GATT_SERVICE(attrs_##_n)
782
798#define BT_GATT_SERVICE_INSTANCE_DEFINE( \
799 _name, _instances, _instance_num, _attrs_def) \
800 BUILD_ASSERT(ARRAY_SIZE(_instances) == _instance_num, \
801 "The number of array elements does not match its size"); \
802 LISTIFY(_instance_num, _BT_GATT_ATTRS_ARRAY_DEFINE, (;), \
803 _instances, _attrs_def); \
804 static struct bt_gatt_service _name[] = { \
805 LISTIFY(_instance_num, _BT_GATT_SERVICE_ARRAY_ITEM, (,)) \
806 }
807
815#define BT_GATT_SERVICE(_attrs) \
816{ \
817 .attrs = _attrs, \
818 .attr_count = ARRAY_SIZE(_attrs), \
819}
820
828#define BT_GATT_PRIMARY_SERVICE(_service) \
829 BT_GATT_ATTRIBUTE(BT_UUID_GATT_PRIMARY, BT_GATT_PERM_READ, \
830 bt_gatt_attr_read_service, NULL, (void *)_service)
831
842#define BT_GATT_SECONDARY_SERVICE(_service) \
843 BT_GATT_ATTRIBUTE(BT_UUID_GATT_SECONDARY, BT_GATT_PERM_READ, \
844 bt_gatt_attr_read_service, NULL, (void *)_service)
845
862 const struct bt_gatt_attr *attr,
863 void *buf, uint16_t len, uint16_t offset);
864
872#define BT_GATT_INCLUDE_SERVICE(_service_incl) \
873 BT_GATT_ATTRIBUTE(BT_UUID_GATT_INCLUDE, BT_GATT_PERM_READ, \
874 bt_gatt_attr_read_included, NULL, _service_incl)
875
891ssize_t bt_gatt_attr_read_chrc(struct bt_conn *conn,
892 const struct bt_gatt_attr *attr, void *buf,
893 uint16_t len, uint16_t offset);
894
895#define BT_GATT_CHRC_INIT(_uuid, _handle, _props) \
896{ \
897 .uuid = _uuid, \
898 .value_handle = _handle, \
899 .properties = _props, \
900}
901
919#define BT_GATT_CHARACTERISTIC(_uuid, _props, _perm, _read, _write, _user_data) \
920 BT_GATT_ATTRIBUTE(BT_UUID_GATT_CHRC, BT_GATT_PERM_READ, \
921 bt_gatt_attr_read_chrc, NULL, \
922 ((struct bt_gatt_chrc[]) { \
923 BT_GATT_CHRC_INIT(_uuid, 0U, _props), \
924 })), \
925 BT_GATT_ATTRIBUTE(_uuid, _perm, _read, _write, _user_data)
926
927#if defined(CONFIG_BT_SETTINGS_CCC_LAZY_LOADING)
928 #define BT_GATT_CCC_MAX (CONFIG_BT_MAX_CONN)
929#elif defined(CONFIG_BT_CONN)
930 #define BT_GATT_CCC_MAX (CONFIG_BT_MAX_PAIRED + CONFIG_BT_MAX_CONN)
931#else
932 #define BT_GATT_CCC_MAX 0
933#endif
934
944
946struct _bt_gatt_ccc {
949
951 uint16_t value;
952
958 void (*cfg_changed)(const struct bt_gatt_attr *attr, uint16_t value);
959
969 ssize_t (*cfg_write)(struct bt_conn *conn,
970 const struct bt_gatt_attr *attr, uint16_t value);
971
983 bool (*cfg_match)(struct bt_conn *conn,
984 const struct bt_gatt_attr *attr);
985};
986
1003ssize_t bt_gatt_attr_read_ccc(struct bt_conn *conn,
1004 const struct bt_gatt_attr *attr, void *buf,
1005 uint16_t len, uint16_t offset);
1006
1023ssize_t bt_gatt_attr_write_ccc(struct bt_conn *conn,
1024 const struct bt_gatt_attr *attr, const void *buf,
1025 uint16_t len, uint16_t offset, uint8_t flags);
1026
1027
1037#define BT_GATT_CCC_INITIALIZER(_changed, _write, _match) \
1038 { \
1039 .cfg = {}, \
1040 .cfg_changed = _changed, \
1041 .cfg_write = _write, \
1042 .cfg_match = _match, \
1043 }
1044
1054#define BT_GATT_CCC_MANAGED(_ccc, _perm) \
1055 BT_GATT_ATTRIBUTE(BT_UUID_GATT_CCC, _perm, \
1056 bt_gatt_attr_read_ccc, bt_gatt_attr_write_ccc, \
1057 _ccc)
1058
1068#define BT_GATT_CCC(_changed, _perm) \
1069 BT_GATT_CCC_MANAGED(((struct _bt_gatt_ccc[]) \
1070 {BT_GATT_CCC_INITIALIZER(_changed, NULL, NULL)}), _perm)
1071
1088ssize_t bt_gatt_attr_read_cep(struct bt_conn *conn,
1089 const struct bt_gatt_attr *attr, void *buf,
1090 uint16_t len, uint16_t offset);
1091
1099#define BT_GATT_CEP(_value) \
1100 BT_GATT_DESCRIPTOR(BT_UUID_GATT_CEP, BT_GATT_PERM_READ, \
1101 bt_gatt_attr_read_cep, NULL, (void *)_value)
1102
1120ssize_t bt_gatt_attr_read_cud(struct bt_conn *conn,
1121 const struct bt_gatt_attr *attr, void *buf,
1122 uint16_t len, uint16_t offset);
1123
1133#define BT_GATT_CUD(_value, _perm) \
1134 BT_GATT_DESCRIPTOR(BT_UUID_GATT_CUD, _perm, bt_gatt_attr_read_cud, \
1135 NULL, (void *)_value)
1136
1153ssize_t bt_gatt_attr_read_cpf(struct bt_conn *conn,
1154 const struct bt_gatt_attr *attr, void *buf,
1155 uint16_t len, uint16_t offset);
1156
1164#define BT_GATT_CPF(_value) \
1165 BT_GATT_DESCRIPTOR(BT_UUID_GATT_CPF, BT_GATT_PERM_READ, \
1166 bt_gatt_attr_read_cpf, NULL, (void *)_value)
1167
1182#define BT_GATT_DESCRIPTOR(_uuid, _perm, _read, _write, _user_data) \
1183 BT_GATT_ATTRIBUTE(_uuid, _perm, _read, _write, _user_data)
1184
1197#define BT_GATT_ATTRIBUTE(_uuid, _perm, _read, _write, _user_data) \
1198{ \
1199 .uuid = _uuid, \
1200 .read = _read, \
1201 .write = _write, \
1202 .user_data = _user_data, \
1203 .handle = 0, \
1204 .perm = _perm, \
1205}
1206
1212typedef void (*bt_gatt_complete_func_t) (struct bt_conn *conn, void *user_data);
1213
1220 const struct bt_uuid *uuid;
1226 const struct bt_gatt_attr *attr;
1228 const void *data;
1235#if defined(CONFIG_BT_EATT)
1237#endif /* CONFIG_BT_EATT */
1238};
1239
1261int bt_gatt_notify_cb(struct bt_conn *conn,
1262 struct bt_gatt_notify_params *params);
1263
1315int bt_gatt_notify_multiple(struct bt_conn *conn,
1316 uint16_t num_params,
1317 struct bt_gatt_notify_params params[]);
1318
1338static inline int bt_gatt_notify(struct bt_conn *conn,
1339 const struct bt_gatt_attr *attr,
1340 const void *data, uint16_t len)
1341{
1342 struct bt_gatt_notify_params params;
1343
1344 memset(&params, 0, sizeof(params));
1345
1346 params.attr = attr;
1347 params.data = data;
1348 params.len = len;
1349#if defined(CONFIG_BT_EATT)
1351#endif /* CONFIG_BT_EATT */
1352
1353 return bt_gatt_notify_cb(conn, &params);
1354}
1355
1375static inline int bt_gatt_notify_uuid(struct bt_conn *conn,
1376 const struct bt_uuid *uuid,
1377 const struct bt_gatt_attr *attr,
1378 const void *data, uint16_t len)
1379{
1380 struct bt_gatt_notify_params params;
1381
1382 memset(&params, 0, sizeof(params));
1383
1384 params.uuid = uuid;
1385 params.attr = attr;
1386 params.data = data;
1387 params.len = len;
1388#if defined(CONFIG_BT_EATT)
1390#endif /* CONFIG_BT_EATT */
1391
1392 return bt_gatt_notify_cb(conn, &params);
1393}
1394
1395/* Forward declaration of the bt_gatt_indicate_params structure */
1397
1405typedef void (*bt_gatt_indicate_func_t)(struct bt_conn *conn,
1406 struct bt_gatt_indicate_params *params,
1407 uint8_t err);
1408
1410 struct bt_gatt_indicate_params *params);
1411
1419 const struct bt_uuid *uuid;
1425 const struct bt_gatt_attr *attr;
1431 const void *data;
1435 uint8_t _ref;
1436#if defined(CONFIG_BT_EATT)
1438#endif /* CONFIG_BT_EATT */
1439};
1440
1466int bt_gatt_indicate(struct bt_conn *conn,
1467 struct bt_gatt_indicate_params *params);
1468
1469
1488bool bt_gatt_is_subscribed(struct bt_conn *conn,
1489 const struct bt_gatt_attr *attr, uint16_t ccc_type);
1490
1500uint16_t bt_gatt_get_mtu(struct bt_conn *conn);
1501
1517uint16_t bt_gatt_get_uatt_mtu(struct bt_conn *conn);
1518
1530 void (*func)(struct bt_conn *conn, uint8_t err,
1531 struct bt_gatt_exchange_params *params);
1532};
1533
1561int bt_gatt_exchange_mtu(struct bt_conn *conn,
1562 struct bt_gatt_exchange_params *params);
1563
1565
1610typedef uint8_t (*bt_gatt_discover_func_t)(struct bt_conn *conn,
1611 const struct bt_gatt_attr *attr,
1612 struct bt_gatt_discover_params *params);
1613
1615enum {
1656};
1657
1659#define BT_GATT_AUTO_DISCOVER_CCC_HANDLE 0x0000U
1660
1664 const struct bt_uuid *uuid;
1667 union {
1668 struct {
1675 } _included;
1677 uint16_t start_handle;
1678 };
1683#if defined(CONFIG_BT_GATT_AUTO_DISCOVER_CCC) || defined(__DOXYGEN__)
1686#endif /* defined(CONFIG_BT_GATT_AUTO_DISCOVER_CCC) || defined(__DOXYGEN__) */
1687#if defined(CONFIG_BT_EATT)
1689#endif /* CONFIG_BT_EATT */
1690};
1691
1728int bt_gatt_discover(struct bt_conn *conn,
1729 struct bt_gatt_discover_params *params);
1730
1731struct bt_gatt_read_params;
1732
1748typedef uint8_t (*bt_gatt_read_func_t)(struct bt_conn *conn, uint8_t err,
1749 struct bt_gatt_read_params *params,
1750 const void *data, uint16_t length);
1751
1761 union {
1762 struct {
1768 struct {
1785 struct {
1791 const struct bt_uuid *uuid;
1793 };
1794#if defined(CONFIG_BT_EATT)
1796#endif /* CONFIG_BT_EATT */
1798 uint16_t _att_mtu;
1799};
1800
1843int bt_gatt_read(struct bt_conn *conn, struct bt_gatt_read_params *params);
1844
1846
1854typedef void (*bt_gatt_write_func_t)(struct bt_conn *conn, uint8_t err,
1855 struct bt_gatt_write_params *params);
1856
1866 const void *data;
1869#if defined(CONFIG_BT_EATT)
1871#endif /* CONFIG_BT_EATT */
1872};
1873
1896int bt_gatt_write(struct bt_conn *conn, struct bt_gatt_write_params *params);
1897
1928int bt_gatt_write_without_response_cb(struct bt_conn *conn, uint16_t handle,
1929 const void *data, uint16_t length,
1930 bool sign, bt_gatt_complete_func_t func,
1931 void *user_data);
1932
1954static inline int bt_gatt_write_without_response(struct bt_conn *conn,
1955 uint16_t handle, const void *data,
1956 uint16_t length, bool sign)
1957{
1958 return bt_gatt_write_without_response_cb(conn, handle, data, length,
1959 sign, NULL, NULL);
1960}
1961
1963
1980typedef uint8_t (*bt_gatt_notify_func_t)(struct bt_conn *conn,
1981 struct bt_gatt_subscribe_params *params,
1982 const void *data, uint16_t length);
1983
1991typedef void (*bt_gatt_subscribe_func_t)(struct bt_conn *conn, uint8_t err,
1992 struct bt_gatt_subscribe_params *params);
1993
1995enum {
2006
2020
2029
2041
2044
2053
2058#if defined(CONFIG_BT_GATT_AUTO_DISCOVER_CCC) || defined(__DOXYGEN__)
2063#endif /* defined(CONFIG_BT_GATT_AUTO_DISCOVER_CCC) || defined(__DOXYGEN__) */
2066#if defined(CONFIG_BT_SMP)
2072#endif
2075
2077#if defined(CONFIG_BT_EATT)
2079#endif /* CONFIG_BT_EATT */
2080};
2081
2119int bt_gatt_subscribe(struct bt_conn *conn,
2120 struct bt_gatt_subscribe_params *params);
2121
2139 struct bt_gatt_subscribe_params *params);
2140
2166int bt_gatt_unsubscribe(struct bt_conn *conn,
2167 struct bt_gatt_subscribe_params *params);
2168
2186void bt_gatt_cancel(struct bt_conn *conn, void *params);
2187
2190#ifdef __cplusplus
2191}
2192#endif
2193
2198#endif /* ZEPHYR_INCLUDE_BLUETOOTH_GATT_H_ */
Attribute Protocol handling.
Bluetooth connection handling.
#define ATOMIC_DEFINE(name, num_bits)
Define an array of atomic variables.
Definition atomic.h:111
bt_att_chan_opt
ATT channel option bit field values.
Definition att.h:171
static const char * bt_att_err_to_str(uint8_t att_err)
Converts a ATT error to string.
Definition att.h:121
@ BT_ATT_CHAN_OPT_NONE
Both Enhanced and Unenhanced channels can be used
Definition att.h:173
bt_security_t
Security level.
Definition conn.h:809
int bt_gatt_exchange_mtu(struct bt_conn *conn, struct bt_gatt_exchange_params *params)
Exchange MTU.
int bt_gatt_read(struct bt_conn *conn, struct bt_gatt_read_params *params)
Read Attribute Value by handle.
uint8_t(* bt_gatt_read_func_t)(struct bt_conn *conn, uint8_t err, struct bt_gatt_read_params *params, const void *data, uint16_t length)
Read callback function.
Definition gatt.h:1748
void(* bt_gatt_write_func_t)(struct bt_conn *conn, uint8_t err, struct bt_gatt_write_params *params)
Write callback function.
Definition gatt.h:1854
void(* bt_gatt_subscribe_func_t)(struct bt_conn *conn, uint8_t err, struct bt_gatt_subscribe_params *params)
Subscription callback function.
Definition gatt.h:1991
int bt_gatt_write_without_response_cb(struct bt_conn *conn, uint16_t handle, const void *data, uint16_t length, bool sign, bt_gatt_complete_func_t func, void *user_data)
Write Attribute Value by handle without response with callback.
void bt_gatt_cancel(struct bt_conn *conn, void *params)
Try to cancel the first pending request identified by params.
int bt_gatt_unsubscribe(struct bt_conn *conn, struct bt_gatt_subscribe_params *params)
Unsubscribe Attribute Value Notification.
int bt_gatt_resubscribe(uint8_t id, const bt_addr_le_t *peer, struct bt_gatt_subscribe_params *params)
Resubscribe Attribute Value Notification subscription.
int bt_gatt_subscribe(struct bt_conn *conn, struct bt_gatt_subscribe_params *params)
Subscribe Attribute Value Notification.
int bt_gatt_write(struct bt_conn *conn, struct bt_gatt_write_params *params)
Write Attribute Value by handle.
static int bt_gatt_write_without_response(struct bt_conn *conn, uint16_t handle, const void *data, uint16_t length, bool sign)
Write Attribute Value by handle without response.
Definition gatt.h:1954
uint8_t(* bt_gatt_notify_func_t)(struct bt_conn *conn, struct bt_gatt_subscribe_params *params, const void *data, uint16_t length)
Notification callback function.
Definition gatt.h:1980
uint8_t(* bt_gatt_discover_func_t)(struct bt_conn *conn, const struct bt_gatt_attr *attr, struct bt_gatt_discover_params *params)
Discover attribute callback function.
Definition gatt.h:1610
int bt_gatt_discover(struct bt_conn *conn, struct bt_gatt_discover_params *params)
GATT Discover function.
@ BT_GATT_DISCOVER_DESCRIPTOR
Discover Descriptors.
Definition gatt.h:1635
@ BT_GATT_DISCOVER_SECONDARY
Discover Secondary Services.
Definition gatt.h:1619
@ BT_GATT_DISCOVER_CHARACTERISTIC
Discover Characteristic Values.
Definition gatt.h:1626
@ BT_GATT_DISCOVER_INCLUDE
Discover Included Services.
Definition gatt.h:1621
@ BT_GATT_DISCOVER_STD_CHAR_DESC
Discover standard characteristic descriptor values.
Definition gatt.h:1655
@ BT_GATT_DISCOVER_PRIMARY
Discover Primary Services.
Definition gatt.h:1617
@ BT_GATT_DISCOVER_ATTRIBUTE
Discover Attributes.
Definition gatt.h:1644
@ BT_GATT_SUBSCRIBE_FLAG_NO_RESUB
No resubscribe flag.
Definition gatt.h:2019
@ BT_GATT_SUBSCRIBE_NUM_FLAGS
Definition gatt.h:2042
@ BT_GATT_SUBSCRIBE_FLAG_SENT
Sent flag.
Definition gatt.h:2040
@ BT_GATT_SUBSCRIBE_FLAG_VOLATILE
Persistence flag.
Definition gatt.h:2005
@ BT_GATT_SUBSCRIBE_FLAG_WRITE_PENDING
Write pending flag.
Definition gatt.h:2028
void(* bt_gatt_indicate_func_t)(struct bt_conn *conn, struct bt_gatt_indicate_params *params, uint8_t err)
Indication complete result callback.
Definition gatt.h:1405
static int bt_gatt_notify_uuid(struct bt_conn *conn, const struct bt_uuid *uuid, const struct bt_gatt_attr *attr, const void *data, uint16_t len)
Notify attribute value change by UUID.
Definition gatt.h:1375
void bt_gatt_cb_register(struct bt_gatt_cb *cb)
Register GATT callbacks.
ssize_t bt_gatt_attr_read_cud(struct bt_conn *conn, const struct bt_gatt_attr *attr, void *buf, uint16_t len, uint16_t offset)
Read Characteristic User Description Descriptor Attribute helper.
uint16_t bt_gatt_attr_get_handle(const struct bt_gatt_attr *attr)
Get Attribute handle.
ssize_t bt_gatt_attr_read_ccc(struct bt_conn *conn, const struct bt_gatt_attr *attr, void *buf, uint16_t len, uint16_t offset)
Read Client Characteristic Configuration Attribute helper.
uint16_t bt_gatt_get_mtu(struct bt_conn *conn)
Get ATT MTU for a connection.
struct bt_gatt_attr * bt_gatt_attr_next(const struct bt_gatt_attr *attr)
Iterate to the next attribute.
ssize_t bt_gatt_attr_read_included(struct bt_conn *conn, const struct bt_gatt_attr *attr, void *buf, uint16_t len, uint16_t offset)
Read Include Attribute helper.
int bt_gatt_indicate(struct bt_conn *conn, struct bt_gatt_indicate_params *params)
Indicate attribute value change.
int bt_gatt_notify_cb(struct bt_conn *conn, struct bt_gatt_notify_params *params)
Notify attribute value change.
ssize_t bt_gatt_attr_read_cep(struct bt_conn *conn, const struct bt_gatt_attr *attr, void *buf, uint16_t len, uint16_t offset)
Read Characteristic Extended Properties Attribute helper.
ssize_t bt_gatt_attr_read_cpf(struct bt_conn *conn, const struct bt_gatt_attr *attr, void *buf, uint16_t len, uint16_t offset)
Read Characteristic Presentation format Descriptor Attribute helper.
void(* bt_gatt_indicate_params_destroy_t)(struct bt_gatt_indicate_params *params)
Definition gatt.h:1409
int bt_gatt_authorization_cb_register(const struct bt_gatt_authorization_cb *cb)
Register GATT authorization callbacks.
uint8_t(* bt_gatt_attr_func_t)(const struct bt_gatt_attr *attr, uint16_t handle, void *user_data)
Attribute iterator callback.
Definition gatt.h:639
uint16_t bt_gatt_get_uatt_mtu(struct bt_conn *conn)
Get Unenhanced ATT (UATT) MTU for a connection.
static int bt_gatt_notify(struct bt_conn *conn, const struct bt_gatt_attr *attr, const void *data, uint16_t len)
Notify attribute value change.
Definition gatt.h:1338
int bt_gatt_notify_multiple(struct bt_conn *conn, uint16_t num_params, struct bt_gatt_notify_params params[])
Send multiple notifications in a single PDU.
uint16_t bt_gatt_attr_value_handle(const struct bt_gatt_attr *attr)
Get the handle of the characteristic value descriptor.
static void bt_gatt_foreach_attr(uint16_t start_handle, uint16_t end_handle, bt_gatt_attr_func_t func, void *user_data)
Attribute iterator.
Definition gatt.h:670
int bt_gatt_service_register(struct bt_gatt_service *svc)
Register GATT service.
ssize_t bt_gatt_attr_write_ccc(struct bt_conn *conn, const struct bt_gatt_attr *attr, const void *buf, uint16_t len, uint16_t offset, uint8_t flags)
Write Client Characteristic Configuration Attribute helper.
bool bt_gatt_is_subscribed(struct bt_conn *conn, const struct bt_gatt_attr *attr, uint16_t ccc_type)
Check if connection have subscribed to attribute.
#define BT_GATT_CCC_MAX
Definition gatt.h:932
void(* bt_gatt_complete_func_t)(struct bt_conn *conn, void *user_data)
Notification complete result callback.
Definition gatt.h:1212
ssize_t bt_gatt_attr_read_service(struct bt_conn *conn, const struct bt_gatt_attr *attr, void *buf, uint16_t len, uint16_t offset)
Read Service Attribute helper.
struct bt_gatt_attr * bt_gatt_find_by_uuid(const struct bt_gatt_attr *attr, uint16_t attr_count, const struct bt_uuid *uuid)
Find Attribute by UUID.
ssize_t bt_gatt_attr_read_chrc(struct bt_conn *conn, const struct bt_gatt_attr *attr, void *buf, uint16_t len, uint16_t offset)
Read Characteristic Attribute helper.
void bt_gatt_foreach_attr_type(uint16_t start_handle, uint16_t end_handle, const struct bt_uuid *uuid, const void *attr_data, uint16_t num_matches, bt_gatt_attr_func_t func, void *user_data)
Attribute iterator by type.
bool bt_gatt_service_is_registered(const struct bt_gatt_service *svc)
Check if GATT service is registered.
int bt_gatt_service_unregister(struct bt_gatt_service *svc)
Unregister GATT service.
ssize_t bt_gatt_attr_read(struct bt_conn *conn, const struct bt_gatt_attr *attr, void *buf, uint16_t buf_len, uint16_t offset, const void *value, uint16_t value_len)
Generic Read Attribute value helper.
static const char * bt_gatt_err_to_str(int gatt_err)
Converts a GATT error to string.
Definition gatt.h:546
@ BT_GATT_ITER_STOP
Definition gatt.h:625
@ BT_GATT_ITER_CONTINUE
Definition gatt.h:626
ssize_t(* bt_gatt_attr_write_func_t)(struct bt_conn *conn, const struct bt_gatt_attr *attr, const void *buf, uint16_t len, uint16_t offset, uint8_t flags)
Attribute Value write implementation.
Definition gatt.h:203
ssize_t(* bt_gatt_attr_read_func_t)(struct bt_conn *conn, const struct bt_gatt_attr *attr, void *buf, uint16_t len, uint16_t offset)
Attribute read callback.
Definition gatt.h:160
bt_gatt_perm
GATT attribute permission bit field values.
Definition gatt.h:37
@ BT_GATT_PERM_READ_ENCRYPT
Attribute read permission with encryption.
Definition gatt.h:51
@ BT_GATT_PERM_WRITE
Attribute write permission.
Definition gatt.h:45
@ BT_GATT_PERM_WRITE_ENCRYPT
Attribute write permission with encryption.
Definition gatt.h:57
@ BT_GATT_PERM_NONE
No operations supported, e.g.
Definition gatt.h:39
@ BT_GATT_PERM_READ
Attribute read permission.
Definition gatt.h:42
@ BT_GATT_PERM_PREPARE_WRITE
Attribute prepare write permission.
Definition gatt.h:78
@ BT_GATT_PERM_WRITE_LESC
Attribute write permission with LE Secure Connection encryption.
Definition gatt.h:90
@ BT_GATT_PERM_READ_AUTHEN
Attribute read permission with authentication.
Definition gatt.h:64
@ BT_GATT_PERM_WRITE_AUTHEN
Attribute write permission with authentication.
Definition gatt.h:71
@ BT_GATT_PERM_READ_LESC
Attribute read permission with LE Secure Connection encryption.
Definition gatt.h:84
@ BT_GATT_WRITE_FLAG_PREPARE
Attribute prepare write flag.
Definition gatt.h:109
@ BT_GATT_WRITE_FLAG_CMD
Attribute write command flag.
Definition gatt.h:116
@ BT_GATT_WRITE_FLAG_EXECUTE
Attribute write execute flag.
Definition gatt.h:124
struct _snode sys_snode_t
Single-linked list node structure.
Definition slist.h:39
#define BIT(n)
Unsigned integer with bit position n set (signed in assembly language).
Definition util_macro.h:44
__SIZE_TYPE__ ssize_t
Definition types.h:28
flags
Definition parser.h:97
#define bool
Definition stdbool.h:13
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
__INT8_TYPE__ int8_t
Definition stdint.h:72
void * memset(void *buf, int c, size_t n)
Bluetooth LE Device Address.
Definition addr.h:49
GATT Attribute.
Definition gatt.h:224
bt_gatt_attr_read_func_t read
Attribute Value read method.
Definition gatt.h:250
uint16_t perm
Attribute Permissions.
Definition gatt.h:300
bt_gatt_attr_write_func_t write
Attribute Value write method.
Definition gatt.h:263
const struct bt_uuid * uuid
Attribute Type, aka.
Definition gatt.h:237
void * user_data
Private data for read() and write() implementation.
Definition gatt.h:276
uint16_t handle
Attribute Handle or zero, maybe?
Definition gatt.h:289
GATT authorization callback structure.
Definition gatt.h:367
bool(* read_authorize)(struct bt_conn *conn, const struct bt_gatt_attr *attr)
Authorize the GATT read operation.
Definition gatt.h:379
bool(* write_authorize)(struct bt_conn *conn, const struct bt_gatt_attr *attr)
Authorize the GATT write operation.
Definition gatt.h:393
GATT callback structure.
Definition gatt.h:351
void(* att_mtu_updated)(struct bt_conn *conn, uint16_t tx, uint16_t rx)
The maximum ATT MTU on a connection has changed.
Definition gatt.h:361
sys_snode_t node
Definition gatt.h:363
GATT CCC configuration entry.
Definition gatt.h:936
uint16_t value
Configuration value.
Definition gatt.h:942
bt_addr_le_t peer
Remote peer address.
Definition gatt.h:940
uint8_t id
Local identity, BT_ID_DEFAULT in most cases.
Definition gatt.h:938
Client Characteristic Configuration Attribute Value.
Definition gatt.h:487
uint16_t flags
Client Characteristic Configuration flags.
Definition gatt.h:489
Characteristic Extended Properties Attribute Value.
Definition gatt.h:466
uint16_t properties
Characteristic Extended properties.
Definition gatt.h:468
Characteristic Attribute Value.
Definition gatt.h:452
uint16_t value_handle
Characteristic Value handle.
Definition gatt.h:456
uint8_t properties
Characteristic properties.
Definition gatt.h:458
const struct bt_uuid * uuid
Characteristic UUID.
Definition gatt.h:454
GATT Characteristic Presentation Format Attribute Value.
Definition gatt.h:509
uint8_t name_space
Name space of the description.
Definition gatt.h:519
uint16_t unit
Unit of the characteristic.
Definition gatt.h:517
int8_t exponent
Exponent field to determine how the value of this characteristic is further formatted.
Definition gatt.h:515
uint16_t description
Description of the characteristic as defined in a higher layer profile.
Definition gatt.h:521
uint8_t format
Format of the value of the characteristic.
Definition gatt.h:511
GATT Discover Attributes parameters.
Definition gatt.h:1662
uint16_t start_handle
Included service start handle.
Definition gatt.h:1672
uint16_t end_handle
Included service end handle.
Definition gatt.h:1674
bt_gatt_discover_func_t func
Discover attribute callback.
Definition gatt.h:1666
uint16_t attr_handle
Include service attribute declaration handle.
Definition gatt.h:1670
const struct bt_uuid * uuid
Discover UUID type.
Definition gatt.h:1664
struct bt_gatt_subscribe_params * sub_params
Only for stack-internal use, used for automatic discovery.
Definition gatt.h:1685
uint8_t type
Discover type.
Definition gatt.h:1682
enum bt_att_chan_opt chan_opt
Definition gatt.h:1688
GATT Exchange MTU parameters.
Definition gatt.h:1528
void(* func)(struct bt_conn *conn, uint8_t err, struct bt_gatt_exchange_params *params)
Response callback.
Definition gatt.h:1530
Include Attribute Value.
Definition gatt.h:341
uint16_t end_handle
Service end handle.
Definition gatt.h:347
uint16_t start_handle
Service start handle.
Definition gatt.h:345
const struct bt_uuid * uuid
Service UUID.
Definition gatt.h:343
GATT Indicate Value parameters.
Definition gatt.h:1413
enum bt_att_chan_opt chan_opt
Definition gatt.h:1437
uint16_t len
Indicate Value length.
Definition gatt.h:1433
const struct bt_gatt_attr * attr
Indicate Attribute object.
Definition gatt.h:1425
const void * data
Indicate Value data.
Definition gatt.h:1431
bt_gatt_indicate_params_destroy_t destroy
Indicate operation complete callback.
Definition gatt.h:1429
bt_gatt_indicate_func_t func
Indicate Value callback.
Definition gatt.h:1427
const struct bt_uuid * uuid
Indicate Attribute UUID type.
Definition gatt.h:1419
Definition gatt.h:1214
const struct bt_uuid * uuid
Notification Attribute UUID type.
Definition gatt.h:1220
uint16_t len
Notification Value length.
Definition gatt.h:1230
const struct bt_gatt_attr * attr
Notification Attribute object.
Definition gatt.h:1226
enum bt_att_chan_opt chan_opt
Definition gatt.h:1236
bt_gatt_complete_func_t func
Notification Value callback.
Definition gatt.h:1232
void * user_data
Notification Value callback user data.
Definition gatt.h:1234
const void * data
Notification Value data.
Definition gatt.h:1228
GATT Read parameters.
Definition gatt.h:1753
size_t handle_count
If equals to 1 single.handle and single.offset are used.
Definition gatt.h:1760
enum bt_att_chan_opt chan_opt
Definition gatt.h:1795
uint16_t * handles
Attribute handles to read with Read Multiple Characteristic Values.
Definition gatt.h:1772
uint16_t offset
Attribute data offset.
Definition gatt.h:1766
bt_gatt_read_func_t func
Read attribute callback.
Definition gatt.h:1755
bool variable
If true use Read Multiple Variable Length Characteristic Values procedure.
Definition gatt.h:1783
struct bt_gatt_read_params::@128::@131 multiple
uint16_t end_handle
Last requested handle number.
Definition gatt.h:1789
struct bt_gatt_read_params::@128::@132 by_uuid
uint16_t start_handle
First requested handle number.
Definition gatt.h:1787
const struct bt_uuid * uuid
2 or 16 octet UUID.
Definition gatt.h:1791
struct bt_gatt_read_params::@128::@130 single
uint16_t handle
Attribute handle.
Definition gatt.h:1764
Server Characteristic Configuration Attribute Value.
Definition gatt.h:503
uint16_t flags
Server Characteristic Configuration flags.
Definition gatt.h:505
GATT Service structure.
Definition gatt.h:315
const struct bt_gatt_attr * attrs
Service Attributes.
Definition gatt.h:317
size_t attr_count
Service Attribute count.
Definition gatt.h:319
Service Attribute Value.
Definition gatt.h:333
const struct bt_uuid * uuid
Service UUID.
Definition gatt.h:335
uint16_t end_handle
Service end handle.
Definition gatt.h:337
GATT Service structure.
Definition gatt.h:323
struct bt_gatt_attr * attrs
Service Attributes.
Definition gatt.h:325
size_t attr_count
Service Attribute count.
Definition gatt.h:327
sys_snode_t node
Definition gatt.h:329
GATT Subscribe parameters.
Definition gatt.h:2046
uint16_t value
Subscribe value.
Definition gatt.h:2065
bt_security_t min_security
Minimum required security for received notification.
Definition gatt.h:2071
uint16_t ccc_handle
Subscribe CCC handle.
Definition gatt.h:2057
bt_gatt_subscribe_func_t subscribe
Subscribe CCC write request response callback If given, called with the subscription parameters given...
Definition gatt.h:2052
uint16_t value_handle
Subscribe value handle.
Definition gatt.h:2055
sys_snode_t node
Definition gatt.h:2076
bt_gatt_notify_func_t notify
Notification value callback.
Definition gatt.h:2048
struct bt_gatt_discover_params * disc_params
Discover parameters used when ccc_handle = BT_GATT_AUTO_DISCOVER_CCC_HANDLE.
Definition gatt.h:2062
enum bt_att_chan_opt chan_opt
Definition gatt.h:2078
uint16_t end_handle
Subscribe End handle (for automatic discovery)
Definition gatt.h:2060
GATT Write parameters.
Definition gatt.h:1858
bt_gatt_write_func_t func
Response callback.
Definition gatt.h:1860
uint16_t handle
Attribute handle.
Definition gatt.h:1862
const void * data
Data to be written.
Definition gatt.h:1866
enum bt_att_chan_opt chan_opt
Definition gatt.h:1870
uint16_t offset
Attribute data offset.
Definition gatt.h:1864
uint16_t length
Length of the data.
Definition gatt.h:1868
This is a 'tentative' type and should be used as a pointer only.
Definition uuid.h:49
Misc utilities.
Bluetooth UUID handling.