1 /** 2 * @file 3 * @brief Bluetooth Published Audio Capabilities Service (PACS) APIs 4 */ 5 6 /* Copyright (c) 2021 Intel Corporation 7 * Copyright (c) 2021-2024 Nordic Semiconductor ASA 8 * 9 * SPDX-License-Identifier: Apache-2.0 10 */ 11 12 #ifndef ZEPHYR_INCLUDE_BLUETOOTH_AUDIO_PACS_H_ 13 #define ZEPHYR_INCLUDE_BLUETOOTH_AUDIO_PACS_H_ 14 15 /** 16 * @brief Published Audio Capabilities Service (PACS) 17 * 18 * @defgroup bt_pacs Published Audio Capabilities Service (PACS) 19 * 20 * @since 3.0 21 * @version 0.8.0 22 * 23 * @ingroup bluetooth 24 * @{ 25 * 26 * The Published Audio Capabilities Service (PACS) is used to expose capabilities to remote devices. 27 */ 28 29 #include <stdbool.h> 30 31 #include <zephyr/bluetooth/audio/audio.h> 32 #include <zephyr/bluetooth/conn.h> 33 #include <zephyr/sys/slist.h> 34 35 #ifdef __cplusplus 36 extern "C" { 37 #endif 38 39 /** @brief Published Audio Capability structure. */ 40 struct bt_pacs_cap { 41 /** Codec capability reference */ 42 const struct bt_audio_codec_cap *codec_cap; 43 44 /** @internal Internally used list node */ 45 sys_snode_t _node; 46 }; 47 48 /** 49 * @typedef bt_pacs_cap_foreach_func_t 50 * @brief Published Audio Capability iterator callback. 51 * 52 * @param cap Capability found. 53 * @param user_data Data given. 54 * 55 * @return true to continue to the next capability 56 * @return false to stop the iteration 57 */ 58 typedef bool (*bt_pacs_cap_foreach_func_t)(const struct bt_pacs_cap *cap, 59 void *user_data); 60 61 /** 62 * @brief Published Audio Capability iterator. 63 * 64 * Iterate capabilities with endpoint direction specified. 65 * 66 * @param dir Direction of the endpoint to look capability for. 67 * @param func Callback function. 68 * @param user_data Data to pass to the callback. 69 */ 70 void bt_pacs_cap_foreach(enum bt_audio_dir dir, 71 bt_pacs_cap_foreach_func_t func, 72 void *user_data); 73 74 /** 75 * @brief Register Published Audio Capability. 76 * 77 * Register Audio Local Capability. 78 * 79 * @param dir Direction of the endpoint to register capability for. 80 * @param cap Capability structure. 81 * 82 * @return 0 in case of success or negative value in case of error. 83 */ 84 int bt_pacs_cap_register(enum bt_audio_dir dir, struct bt_pacs_cap *cap); 85 86 /** 87 * @brief Unregister Published Audio Capability. 88 * 89 * Unregister Audio Local Capability. 90 * 91 * @param dir Direction of the endpoint to unregister capability for. 92 * @param cap Capability structure. 93 * 94 * @return 0 in case of success or negative value in case of error. 95 */ 96 int bt_pacs_cap_unregister(enum bt_audio_dir dir, struct bt_pacs_cap *cap); 97 98 /** 99 * @brief Set the location for an endpoint type 100 * 101 * @param dir Direction of the endpoints to change location for. 102 * @param location The location to be set. 103 * 104 * @return 0 in case of success or negative value in case of error. 105 */ 106 int bt_pacs_set_location(enum bt_audio_dir dir, 107 enum bt_audio_location location); 108 109 /** 110 * @brief Set the available contexts for an endpoint type 111 * 112 * @param dir Direction of the endpoints to change available contexts for. 113 * @param contexts The contexts to be set. 114 * 115 * @return 0 in case of success or negative value in case of error. 116 */ 117 int bt_pacs_set_available_contexts(enum bt_audio_dir dir, 118 enum bt_audio_context contexts); 119 120 /** 121 * @brief Get the available contexts for an endpoint type 122 * 123 * @param dir Direction of the endpoints to get contexts for. 124 * 125 * @return Bitmask of available contexts. 126 */ 127 enum bt_audio_context bt_pacs_get_available_contexts(enum bt_audio_dir dir); 128 129 /** 130 * @brief Set the available contexts for a given connection 131 * 132 * This function sets the available contexts value for a given @p conn connection object. 133 * If the @p contexts parameter is NULL the available contexts value is reset to default. 134 * The default value of the available contexts is set using @ref bt_pacs_set_available_contexts 135 * function. 136 * The Available Context Value is reset to default on ACL disconnection. 137 * 138 * @param conn Connection object. 139 * @param dir Direction of the endpoints to change available contexts for. 140 * @param contexts The contexts to be set or NULL to reset to default. 141 * 142 * @return 0 in case of success or negative value in case of error. 143 */ 144 int bt_pacs_conn_set_available_contexts_for_conn(struct bt_conn *conn, enum bt_audio_dir dir, 145 enum bt_audio_context *contexts); 146 147 /** 148 * @brief Get the available contexts for a given connection 149 * 150 * This server function returns the available contexts value for a given @p conn connection object. 151 * The value returned is the one set with @ref bt_pacs_conn_set_available_contexts_for_conn function 152 * or the default value set with @ref bt_pacs_set_available_contexts function. 153 * 154 * @param conn Connection object. 155 * @param dir Direction of the endpoints to get contexts for. 156 * 157 * @return Bitmask of available contexts. 158 * @retval BT_AUDIO_CONTEXT_TYPE_PROHIBITED if @p conn or @p dir are invalid 159 */ 160 enum bt_audio_context bt_pacs_get_available_contexts_for_conn(struct bt_conn *conn, 161 enum bt_audio_dir dir); 162 163 /** 164 * @brief Set the supported contexts for an endpoint type 165 * 166 * @param dir Direction of the endpoints to change available contexts for. 167 * @param contexts The contexts to be set. 168 * 169 * @return 0 in case of success or negative value in case of error. 170 */ 171 int bt_pacs_set_supported_contexts(enum bt_audio_dir dir, 172 enum bt_audio_context contexts); 173 174 #ifdef __cplusplus 175 } 176 #endif 177 178 /** @} */ 179 180 #endif /* ZEPHYR_INCLUDE_BLUETOOTH_AUDIO_PACS_H_ */ 181