Zephyr API Documentation 4.4.0-rc1
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
csip.h
Go to the documentation of this file.
1
5
6/*
7 * Copyright (c) 2021-2024 Nordic Semiconductor ASA
8 *
9 * SPDX-License-Identifier: Apache-2.0
10 */
11
12#ifndef ZEPHYR_SUBSYS_BLUETOOTH_AUDIO_CSIP_H_
13#define ZEPHYR_SUBSYS_BLUETOOTH_AUDIO_CSIP_H_
14
29
30#include <stdbool.h>
31#include <stddef.h>
32#include <stdint.h>
33
34#include <zephyr/autoconf.h>
40#include <zephyr/kernel.h>
41#include <zephyr/sys/slist.h>
42
43#ifdef __cplusplus
44extern "C" {
45#endif
46
48#define BT_CSIP_SET_COORDINATOR_DISCOVER_TIMER_VALUE K_SECONDS(10)
49
54#if defined(CONFIG_BT_CSIP_SET_COORDINATOR)
55#define BT_CSIP_SET_COORDINATOR_MAX_CSIS_INSTANCES CONFIG_BT_CSIP_SET_COORDINATOR_MAX_CSIS_INSTANCES
56#else
57#define BT_CSIP_SET_COORDINATOR_MAX_CSIS_INSTANCES 0
58#endif /* CONFIG_BT_CSIP_SET_COORDINATOR */
59
61#define BT_CSIP_READ_SIRK_REQ_RSP_ACCEPT 0x00
63#define BT_CSIP_READ_SIRK_REQ_RSP_ACCEPT_ENC 0x01
65#define BT_CSIP_READ_SIRK_REQ_RSP_REJECT 0x02
67#define BT_CSIP_READ_SIRK_REQ_RSP_OOB_ONLY 0x03
68
70#define BT_CSIP_SIRK_SIZE 16
71
73#define BT_CSIP_RSI_SIZE 6
74
75/* Coordinate Set Identification Service Error codes */
77#define BT_CSIP_ERROR_LOCK_DENIED 0x80
79#define BT_CSIP_ERROR_LOCK_RELEASE_DENIED 0x81
81#define BT_CSIP_ERROR_LOCK_INVAL_VALUE 0x82
83#define BT_CSIP_ERROR_SIRK_OOB_ONLY 0x83
85#define BT_CSIP_ERROR_LOCK_ALREADY_GRANTED 0x84
86
95#define BT_CSIP_DATA_RSI(_rsi) BT_DATA(BT_DATA_CSIS_RSI, _rsi, BT_CSIP_RSI_SIZE)
96
102
116 void (*lock_changed)(struct bt_conn *conn,
117 struct bt_csip_set_member_svc_inst *svc_inst,
118 bool locked);
119
134 struct bt_csip_set_member_svc_inst *svc_inst);
135};
136
145
153
160
169
172
173#if CONFIG_BT_CSIP_SET_MEMBER_MAX_INSTANCE_COUNT > 1 || defined(__DOXYGEN__)
183 const struct bt_gatt_service *parent;
184#endif /* CONFIG_BT_CSIP_SET_MEMBER_MAX_INSTANCE_COUNT > 1 */
185};
186
197
214 struct bt_csip_set_member_svc_inst **svc_inst);
215
226
234 const uint8_t sirk[BT_CSIP_SIRK_SIZE]);
235
259 uint8_t rank);
260
289
300 struct bt_csip_set_member_set_info *info);
301
314
327 bool lock, bool force);
328
356
370
376
387 struct bt_conn *conn,
388 const struct bt_csip_set_coordinator_set_member *member,
389 int err, size_t set_count);
390
400
415
422typedef void (*bt_csip_set_coordinator_lock_set_cb)(int err);
423
435 struct bt_csip_set_coordinator_csis_inst *inst, bool locked);
436
446
463 struct bt_conn *conn, const struct bt_csip_set_coordinator_csis_inst *inst);
464
480 const struct bt_csip_set_coordinator_set_info *set_info,
481 int err, bool locked,
483
510
520 struct bt_data *data);
521
530
543 const struct bt_csip_set_coordinator_set_info *set_info,
544 struct bt_csip_set_coordinator_set_member *members[],
545 size_t count);
546
571 const struct bt_csip_set_coordinator_set_member *members[],
572 uint8_t count,
573 const struct bt_csip_set_coordinator_set_info *set_info,
575
593 uint8_t count,
594 const struct bt_csip_set_coordinator_set_info *set_info);
595
611 uint8_t count,
612 const struct bt_csip_set_coordinator_set_info *set_info);
613
614#ifdef __cplusplus
615}
616#endif
617
621
622#endif /* ZEPHYR_SUBSYS_BLUETOOTH_AUDIO_CSIP_H_ */
Bluetooth device address definitions and utilities.
Bluetooth Assigned Numbers, codes and identifiers.
Bluetooth subsystem core APIs.
Bluetooth connection handling.
Bluetooth Generic Access Profile defines and Assigned Numbers.
int bt_csip_set_coordinator_register_cb(struct bt_csip_set_coordinator_cb *cb)
Registers callbacks for csip_set_coordinator.
void(* bt_csip_set_coordinator_ordered_access_cb_t)(const struct bt_csip_set_coordinator_set_info *set_info, int err, bool locked, struct bt_csip_set_coordinator_set_member *member)
Callback for bt_csip_set_coordinator_ordered_access().
Definition csip.h:479
bool(* bt_csip_set_coordinator_ordered_access_t)(const struct bt_csip_set_coordinator_set_info *set_info, struct bt_csip_set_coordinator_set_member *members[], size_t count)
Callback function definition for bt_csip_set_coordinator_ordered_access().
Definition csip.h:542
int bt_csip_set_coordinator_lock(const struct bt_csip_set_coordinator_set_member **members, uint8_t count, const struct bt_csip_set_coordinator_set_info *set_info)
Lock an array of set members.
#define BT_CSIP_SIRK_SIZE
Size of the Set Identification Resolving Key (SIRK).
Definition csip.h:70
#define BT_CSIP_SET_COORDINATOR_MAX_CSIS_INSTANCES
Defines the maximum number of Coordinated Set Identification service instances for the Coordinated Se...
Definition csip.h:57
int bt_csip_set_coordinator_release(const struct bt_csip_set_coordinator_set_member **members, uint8_t count, const struct bt_csip_set_coordinator_set_info *set_info)
Release an array of set members.
#define BT_CSIP_RSI_SIZE
Size of the Resolvable Set Identifier (RSI).
Definition csip.h:73
int bt_csip_set_coordinator_discover(struct bt_conn *conn)
Initialise the csip_set_coordinator instance for a connection.
struct bt_csip_set_coordinator_set_member * bt_csip_set_coordinator_set_member_by_conn(const struct bt_conn *conn)
Get the set member from a connection pointer.
int bt_csip_set_member_generate_rsi(const struct bt_csip_set_member_svc_inst *svc_inst, uint8_t rsi[6])
Generate the Resolvable Set Identifier (RSI) value.
int bt_csip_set_member_lock(struct bt_csip_set_member_svc_inst *svc_inst, bool lock, bool force)
Locks a specific Coordinated Set Identification Service instance on the server.
void(* bt_csip_set_coordinator_lock_changed_cb)(struct bt_csip_set_coordinator_csis_inst *inst, bool locked)
Callback when the lock value on a set of a connected device changes.
Definition csip.h:434
void(* bt_csip_set_coordinator_lock_set_cb)(int err)
Callback for locking a set across one or more devices.
Definition csip.h:422
int bt_csip_set_member_unregister(struct bt_csip_set_member_svc_inst *svc_inst)
Unregister a Coordinated Set Identification Service instance.
int bt_csip_set_member_register(const struct bt_csip_set_member_register_param *param, struct bt_csip_set_member_svc_inst **svc_inst)
Register a Coordinated Set Identification Service instance.
void * bt_csip_set_member_svc_decl_get(const struct bt_csip_set_member_svc_inst *svc_inst)
Get the service declaration attribute.
bool bt_csip_set_coordinator_is_set_member(const uint8_t sirk[16], struct bt_data *data)
Check if advertising data indicates a set member.
int bt_csip_set_coordinator_ordered_access(const struct bt_csip_set_coordinator_set_member *members[], uint8_t count, const struct bt_csip_set_coordinator_set_info *set_info, bt_csip_set_coordinator_ordered_access_t cb)
Access Coordinated Set devices in an ordered manner as a client.
void(* bt_csip_set_coordinator_sirk_changed_cb)(struct bt_csip_set_coordinator_csis_inst *inst)
Callback when the SIRK value of a set of a connected device changes.
Definition csip.h:444
int bt_csip_set_member_get_info(const struct bt_csip_set_member_svc_inst *svc_inst, struct bt_csip_set_member_set_info *info)
Get information about a service instances.
int bt_csip_set_member_sirk(struct bt_csip_set_member_svc_inst *svc_inst, const uint8_t sirk[16])
Set the SIRK of a service instance.
void(* bt_csip_set_coordinator_size_changed_cb)(struct bt_conn *conn, const struct bt_csip_set_coordinator_csis_inst *inst)
Callback when the size of a set of a connected device changes.
Definition csip.h:462
void(* bt_csip_set_coordinator_discover_cb)(struct bt_conn *conn, const struct bt_csip_set_coordinator_set_member *member, int err, size_t set_count)
Callback for discovering Coordinated Set Identification Services.
Definition csip.h:386
int bt_csip_set_member_set_size_and_rank(struct bt_csip_set_member_svc_inst *svc_inst, uint8_t size, uint8_t rank)
Set a new size and rank for a service instance.
struct _snode sys_snode_t
Single-linked list node structure.
Definition slist.h:39
Public kernel APIs.
#define bool
Definition stdbool.h:13
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
Bluetooth LE Device Address.
Definition addr.h:49
Opaque type representing a connection to a remote device.
Struct to hold the Coordinated Set Identification Profile Set Coordinator callbacks.
Definition csip.h:489
bt_csip_set_coordinator_lock_set_cb lock_set
Callback when locking a set has finished.
Definition csip.h:493
bt_csip_set_coordinator_sirk_changed_cb sirk_changed
Callback when a set's SIRK has changed.
Definition csip.h:499
bt_csip_set_coordinator_discover_cb discover
Callback when discovery has finished.
Definition csip.h:491
bt_csip_set_coordinator_size_changed_cb size_changed
Callback when a set's size has changed.
Definition csip.h:501
bt_csip_set_coordinator_lock_set_cb release_set
Callback when unlocking a set has finished.
Definition csip.h:495
bt_csip_set_coordinator_lock_changed_cb lock_changed
Callback when a set's lock state has changed.
Definition csip.h:497
bt_csip_set_coordinator_ordered_access_cb_t ordered_access
Callback for the ordered access procedure.
Definition csip.h:503
Struct representing a coordinated set instance on a remote device.
Definition csip.h:363
struct bt_csip_set_coordinator_set_info info
Information about the coordinated set.
Definition csip.h:365
void * svc_inst
Internally used pointer value.
Definition csip.h:368
Information about a specific set.
Definition csip.h:330
uint8_t rank
The rank of the set on the remote device.
Definition csip.h:351
uint8_t sirk[16]
The 16 octet set Set Identity Resolving Key (SIRK).
Definition csip.h:337
bool lockable
Whether or not the set can be locked on this device.
Definition csip.h:354
uint8_t set_size
The size of the set.
Definition csip.h:344
Struct representing a remote device as a set member.
Definition csip.h:372
struct bt_csip_set_coordinator_csis_inst insts[0]
Array of Coordinated Set Identification Service instances for the remote device.
Definition csip.h:374
Callback structure for the Coordinated Set Identification Service.
Definition csip.h:104
uint8_t(* sirk_read_req)(struct bt_conn *conn, struct bt_csip_set_member_svc_inst *svc_inst)
Request from a peer device to read the sirk.
Definition csip.h:133
void(* lock_changed)(struct bt_conn *conn, struct bt_csip_set_member_svc_inst *svc_inst, bool locked)
Callback whenever the lock changes on the server.
Definition csip.h:116
Register structure for Coordinated Set Identification Service.
Definition csip.h:138
struct bt_csip_set_member_cb * cb
Pointer to the callback structure.
Definition csip.h:171
const struct bt_gatt_service * parent
Parent service pointer.
Definition csip.h:183
uint8_t sirk[16]
The unique Set Identity Resolving Key (SIRK).
Definition csip.h:152
bool lockable
Boolean to set whether the set is lockable by clients.
Definition csip.h:159
uint8_t rank
Rank of this device in this set.
Definition csip.h:168
uint8_t set_size
Size of the set.
Definition csip.h:144
Struct to hold information about a service instance.
Definition csip.h:262
bool lockable
Whether the set is lockable.
Definition csip.h:277
bt_addr_le_t lock_client_addr
The address of the client that currently holds the lock.
Definition csip.h:287
uint8_t rank
The rank.
Definition csip.h:274
bool locked
Whether the set is currently locked.
Definition csip.h:280
uint8_t sirk[16]
The 16-octet SIRK.
Definition csip.h:264
uint8_t set_size
The set size.
Definition csip.h:267
Opaque Coordinated Set Identification Service instance.
Bluetooth data.
Definition bluetooth.h:548
GATT Service structure.
Definition gatt.h:332