Zephyr Project API 4.4.99
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
147
155
164
177
180
181#if CONFIG_BT_CSIP_SET_MEMBER_MAX_INSTANCE_COUNT > 1 || defined(__DOXYGEN__)
191 const struct bt_gatt_service *parent;
192#endif /* CONFIG_BT_CSIP_SET_MEMBER_MAX_INSTANCE_COUNT > 1 */
193};
194
205
222 struct bt_csip_set_member_svc_inst **svc_inst);
223
234
242 const uint8_t sirk[BT_CSIP_SIRK_SIZE]);
243
271 uint8_t rank);
272
317
328 struct bt_csip_set_member_set_info *info);
329
342
357 bool lock, bool force);
358
386
400
406
417 struct bt_conn *conn,
418 const struct bt_csip_set_coordinator_set_member *member,
419 int err, size_t set_count);
420
430
445
452typedef void (*bt_csip_set_coordinator_lock_set_cb)(int err);
453
465 struct bt_csip_set_coordinator_csis_inst *inst, bool locked);
466
476
493 struct bt_conn *conn, const struct bt_csip_set_coordinator_csis_inst *inst);
494
510 const struct bt_csip_set_coordinator_set_info *set_info,
511 int err, bool locked,
513
540
550 struct bt_data *data);
551
560
573 const struct bt_csip_set_coordinator_set_info *set_info,
574 struct bt_csip_set_coordinator_set_member *members[],
575 size_t count);
576
601 const struct bt_csip_set_coordinator_set_member *members[],
602 uint8_t count,
603 const struct bt_csip_set_coordinator_set_info *set_info,
605
623 uint8_t count,
624 const struct bt_csip_set_coordinator_set_info *set_info);
625
641 uint8_t count,
642 const struct bt_csip_set_coordinator_set_info *set_info);
643
644#ifdef __cplusplus
645}
646#endif
647
651
652#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:509
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:572
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:464
void(* bt_csip_set_coordinator_lock_set_cb)(int err)
Callback for locking a set across one or more devices.
Definition csip.h:452
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:474
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:492
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:416
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:519
bt_csip_set_coordinator_lock_set_cb lock_set
Callback when locking a set has finished.
Definition csip.h:523
bt_csip_set_coordinator_sirk_changed_cb sirk_changed
Callback when a set's SIRK has changed.
Definition csip.h:529
bt_csip_set_coordinator_discover_cb discover
Callback when discovery has finished.
Definition csip.h:521
bt_csip_set_coordinator_size_changed_cb size_changed
Callback when a set's size has changed.
Definition csip.h:531
bt_csip_set_coordinator_lock_set_cb release_set
Callback when unlocking a set has finished.
Definition csip.h:525
bt_csip_set_coordinator_lock_changed_cb lock_changed
Callback when a set's lock state has changed.
Definition csip.h:527
bt_csip_set_coordinator_ordered_access_cb_t ordered_access
Callback for the ordered access procedure.
Definition csip.h:533
Struct representing a coordinated set instance on a remote device.
Definition csip.h:393
struct bt_csip_set_coordinator_set_info info
Information about the coordinated set.
Definition csip.h:395
void * svc_inst
Internally used pointer value.
Definition csip.h:398
Information about a specific set.
Definition csip.h:360
uint8_t rank
The rank of the set on the remote device.
Definition csip.h:381
uint8_t sirk[16]
The 16 octet set Set Identity Resolving Key (SIRK).
Definition csip.h:367
bool lockable
Whether or not the set can be locked on this device.
Definition csip.h:384
uint8_t set_size
The size of the set.
Definition csip.h:374
Struct representing a remote device as a set member.
Definition csip.h:402
struct bt_csip_set_coordinator_csis_inst insts[0]
Array of Coordinated Set Identification Service instances for the remote device.
Definition csip.h:404
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:179
const struct bt_gatt_service * parent
Parent service pointer.
Definition csip.h:191
uint8_t sirk[16]
The unique Set Identity Resolving Key (SIRK).
Definition csip.h:154
bool lockable
Boolean to set whether the set is lockable by clients.
Definition csip.h:163
uint8_t rank
Rank of this device in this set.
Definition csip.h:176
uint8_t set_size
Size of the set.
Definition csip.h:146
Struct to hold information about a service instance.
Definition csip.h:274
bool lockable
Whether the set is lockable.
Definition csip.h:300
bt_addr_le_t lock_client_addr
The address of the client that currently holds the lock.
Definition csip.h:315
uint8_t rank
The rank.
Definition csip.h:292
bool locked
Whether the set is currently locked.
Definition csip.h:308
uint8_t sirk[16]
The 16-octet SIRK.
Definition csip.h:276
uint8_t set_size
The set size.
Definition csip.h:284
Opaque Coordinated Set Identification Service instance.
Bluetooth data.
Definition data.h:40
GATT Service structure.
Definition gatt.h:332