1 /**
2  * @file
3  * @brief Bluetooth Microphone Control Profile (MICP) APIs.
4  */
5 
6 /*
7  * Copyright (c) 2020-2024 Nordic Semiconductor ASA
8  *
9  * SPDX-License-Identifier: Apache-2.0
10  */
11 
12 #ifndef ZEPHYR_INCLUDE_BLUETOOTH_MICP_H_
13 #define ZEPHYR_INCLUDE_BLUETOOTH_MICP_H_
14 
15 /**
16  * @brief Microphone Control Profile (MICP)
17  *
18  * @defgroup bt_micp Microphone Control Profile (MICP)
19  *
20  * @since 2.7
21  * @version 0.8.0
22  *
23  * @ingroup bluetooth
24  * @{
25  */
26 
27 #include <stdint.h>
28 
29 #include <zephyr/bluetooth/audio/aics.h>
30 #include <zephyr/bluetooth/conn.h>
31 #include <zephyr/sys/slist.h>
32 
33 #ifdef __cplusplus
34 extern "C" {
35 #endif
36 
37 /**
38  * Defines the maximum number of Microphone Control Service instances for the
39  * Microphone Control Profile Microphone Device
40  */
41 #if defined(CONFIG_BT_MICP_MIC_DEV)
42 #define BT_MICP_MIC_DEV_AICS_CNT CONFIG_BT_MICP_MIC_DEV_AICS_INSTANCE_COUNT
43 #else
44 #define BT_MICP_MIC_DEV_AICS_CNT 0
45 #endif /* CONFIG_BT_MICP_MIC_DEV */
46 
47 /**
48  * @name Application error codes
49  * @{
50  */
51 /** Mute/unmute commands are disabled. */
52 #define BT_MICP_ERR_MUTE_DISABLED                  0x80
53 /** @} */
54 
55 /**
56  * @name Microphone Control Profile mute states
57  * @{
58  */
59 /** The microphone state is unmuted */
60 #define BT_MICP_MUTE_UNMUTED                       0x00
61 /** The microphone state is muted */
62 #define BT_MICP_MUTE_MUTED                         0x01
63 /** The microphone state is disabled and cannot be muted or unmuted */
64 #define BT_MICP_MUTE_DISABLED                      0x02
65 /** @} */
66 
67 /** @brief Opaque Microphone Controller instance. */
68 struct bt_micp_mic_ctlr;
69 
70 /** @brief Register parameters structure for Microphone Control Service */
71 struct bt_micp_mic_dev_register_param {
72 #if defined(CONFIG_BT_MICP_MIC_DEV_AICS) || defined(__DOXYGEN__)
73 	/** Register parameter structure for Audio Input Control Services */
74 	struct bt_aics_register_param aics_param[BT_MICP_MIC_DEV_AICS_CNT];
75 #endif /* CONFIG_BT_MICP_MIC_DEV_AICS */
76 
77 	/** Microphone Control Profile callback structure. */
78 	struct bt_micp_mic_dev_cb *cb;
79 };
80 
81 /**
82  * @brief Microphone Control Profile included services
83  *
84  * Used for to represent the Microphone Control Profile included service
85  * instances, for either a Microphone Controller or a Microphone Device.
86  * The instance pointers either represent local service instances,
87  * or remote service instances.
88  */
89 struct bt_micp_included {
90 	/** Number of Audio Input Control Service instances */
91 	uint8_t aics_cnt;
92 	/** Array of pointers to Audio Input Control Service instances */
93 	struct bt_aics **aics;
94 };
95 
96 /**
97  * @brief Initialize the Microphone Control Profile Microphone Device
98  *
99  * This will enable the Microphone Control Service instance and make it
100  * discoverable by Microphone Controllers.
101  *
102  * @param param Pointer to an initialization structure.
103  *
104  * @return 0 if success, errno on failure.
105  */
106 int bt_micp_mic_dev_register(struct bt_micp_mic_dev_register_param *param);
107 
108 /**
109  * @brief Get Microphone Device included services
110  *
111  * Returns a pointer to a struct that contains information about the
112  * Microphone Device included Audio Input Control Service instances.
113  *
114  * Requires that @kconfig{CONFIG_BT_MICP_MIC_DEV_AICS} is enabled.
115  *
116  * @param included Pointer to store the result in.
117  *
118  * @return 0 if success, errno on failure.
119  */
120 int bt_micp_mic_dev_included_get(struct bt_micp_included *included);
121 
122 /**
123  * @brief Struct to hold the Microphone Device callbacks
124  *
125  * These can be registered for usage with bt_micp_mic_dev_register().
126  */
127 struct bt_micp_mic_dev_cb {
128 	/**
129 	 * @brief Callback function for Microphone Device mute.
130 	 *
131 	 * Called when the value is read with bt_micp_mic_dev_mute_get(),
132 	 * or if the value is changed by either the Microphone Device or a
133 	 * Microphone Controller.
134 	 *
135 	 * @param mute     The mute setting of the Microphone Control Service.
136 	 */
137 	void (*mute)(uint8_t mute);
138 };
139 
140 /**
141  * @brief Unmute the Microphone Device.
142  *
143  * @return 0 on success, GATT error value on fail.
144  */
145 int bt_micp_mic_dev_unmute(void);
146 
147 /**
148  * @brief Mute the Microphone Device.
149  *
150  * @return 0 on success, GATT error value on fail.
151  */
152 int bt_micp_mic_dev_mute(void);
153 
154 /**
155  * @brief Disable the mute functionality on the Microphone Device.
156  *
157  * Can be reenabled by called @ref bt_micp_mic_dev_mute or @ref bt_micp_mic_dev_unmute.
158  *
159  * @return 0 on success, GATT error value on fail.
160  */
161 int bt_micp_mic_dev_mute_disable(void);
162 
163 /**
164  * @brief Read the mute state on the Microphone Device.
165  *
166  * @return 0 on success, GATT error value on fail.
167  */
168 int bt_micp_mic_dev_mute_get(void);
169 
170 /**
171  * @brief Struct to hold the Microphone Controller callbacks
172  *
173  * These can be registered for usage with bt_micp_mic_ctlr_cb_register().
174  */
175 struct bt_micp_mic_ctlr_cb {
176 	/**
177 	 * @brief Callback function for Microphone Control Profile mute.
178 	 *
179 	 * Called when the value is read,
180 	 * or if the value is changed by either the Microphone Device or a
181 	 * Microphone Controller.
182 	 *
183 	 * @param mic_ctlr Microphone Controller instance pointer.
184 	 * @param err      Error value. 0 on success, GATT error or errno on fail.
185 	 *                 For notifications, this will always be 0.
186 	 * @param mute     The mute setting of the Microphone Control Service.
187 	 */
188 	void (*mute)(struct bt_micp_mic_ctlr *mic_ctlr, int err, uint8_t mute);
189 
190 	/**
191 	 * @brief Callback function for bt_micp_mic_ctlr_discover().
192 	 *
193 	 * @param mic_ctlr     Microphone Controller instance pointer.
194 	 * @param err          Error value. 0 on success, GATT error or errno on fail.
195 	 * @param aics_count   Number of Audio Input Control Service instances on
196 	 *                     peer device.
197 	 */
198 	void (*discover)(struct bt_micp_mic_ctlr *mic_ctlr, int err,
199 			 uint8_t aics_count);
200 
201 	/**
202 	 * @brief Callback function for Microphone Control Profile mute/unmute.
203 	 *
204 	 * @param mic_ctlr  Microphone Controller instance pointer.
205 	 * @param err       Error value. 0 on success, GATT error or errno on fail.
206 	 */
207 	void (*mute_written)(struct bt_micp_mic_ctlr *mic_ctlr, int err);
208 
209 	/**
210 	 * @brief Callback function for Microphone Control Profile mute/unmute.
211 	 *
212 	 * @param mic_ctlr  Microphone Controller instance pointer.
213 	 * @param err       Error value. 0 on success, GATT error or errno on fail.
214 	 */
215 	void (*unmute_written)(struct bt_micp_mic_ctlr *mic_ctlr, int err);
216 
217 #if defined(CONFIG_BT_MICP_MIC_CTLR_AICS)
218 	/** Audio Input Control Service client callback */
219 	struct bt_aics_cb               aics_cb;
220 #endif /* CONFIG_BT_MICP_MIC_CTLR_AICS */
221 
222 	/** @internal Internally used field for list handling */
223 	sys_snode_t _node;
224 };
225 
226 /**
227  * @brief Get Microphone Control Profile included services
228  *
229  * Returns a pointer to a struct that contains information about the
230  * Microphone Control Profile included services instances, such as
231  * pointers to the Audio Input Control Service instances.
232  *
233  * Requires that @kconfig{CONFIG_BT_MICP_MIC_CTLR_AICS} is enabled.
234  *
235  * @param      mic_ctlr Microphone Controller instance pointer.
236  * @param[out] included Pointer to store the result in.
237  *
238  * @return 0 if success, errno on failure.
239  */
240 int bt_micp_mic_ctlr_included_get(struct bt_micp_mic_ctlr *mic_ctlr,
241 				  struct bt_micp_included *included);
242 
243 /**
244  * @brief Get the connection pointer of a Microphone Controller instance
245  *
246  * Get the Bluetooth connection pointer of a Microphone Controller instance.
247  *
248  * @param mic_ctlr    Microphone Controller instance pointer.
249  * @param conn        Connection pointer.
250  *
251  * @return 0 if success, errno on failure.
252  */
253 int bt_micp_mic_ctlr_conn_get(const struct bt_micp_mic_ctlr *mic_ctlr,
254 			      struct bt_conn **conn);
255 
256 /**
257  * @brief Get the volume controller from a connection pointer
258  *
259  * Get the Volume Control Profile Volume Controller pointer from a connection pointer.
260  * Only volume controllers that have been initiated via bt_micp_mic_ctlr_discover() can be
261  * retrieved.
262  *
263  * @param conn     Connection pointer.
264  *
265  * @retval Pointer to a Microphone Control Profile Microphone Controller instance
266  * @retval NULL if @p conn is NULL or if the connection has not done discovery yet
267  */
268 struct bt_micp_mic_ctlr *bt_micp_mic_ctlr_get_by_conn(const struct bt_conn *conn);
269 
270 /**
271  * @brief Discover Microphone Control Service
272  *
273  * This will start a GATT discovery and setup handles and subscriptions.
274  * This shall be called once before any other actions can be executed for the
275  * peer device, and the @ref bt_micp_mic_ctlr_cb.discover callback will notify
276  * when it is possible to start remote operations.
277  * *
278  * @param conn          The connection to initialize the profile for.
279  * @param[out] mic_ctlr Valid remote instance object on success.
280  *
281  * @return 0 on success, GATT error value on fail.
282  */
283 int bt_micp_mic_ctlr_discover(struct bt_conn *conn,
284 			      struct bt_micp_mic_ctlr **mic_ctlr);
285 
286 /**
287  * @brief Unmute a remote Microphone Device.
288  *
289  * @param mic_ctlr  Microphone Controller instance pointer.
290  *
291  * @return 0 on success, GATT error value on fail.
292  */
293 int bt_micp_mic_ctlr_unmute(struct bt_micp_mic_ctlr *mic_ctlr);
294 
295 /**
296  * @brief Mute a remote Microphone Device.
297  *
298  * @param mic_ctlr  Microphone Controller instance pointer.
299  *
300  * @return 0 on success, GATT error value on fail.
301  */
302 int bt_micp_mic_ctlr_mute(struct bt_micp_mic_ctlr *mic_ctlr);
303 
304 /**
305  * @brief Read the mute state of a remote Microphone Device.
306  *
307  * @param mic_ctlr  Microphone Controller instance pointer.
308  *
309  * @return 0 on success, GATT error value on fail.
310  */
311 int bt_micp_mic_ctlr_mute_get(struct bt_micp_mic_ctlr *mic_ctlr);
312 
313 /**
314  * @brief Registers the callbacks used by Microphone Controller.
315  *
316  * This can only be done as the client.
317  *
318  * @param cb    The callback structure.
319  *
320  * @return 0 if success, errno on failure.
321  */
322 int bt_micp_mic_ctlr_cb_register(struct bt_micp_mic_ctlr_cb *cb);
323 #ifdef __cplusplus
324 }
325 #endif
326 
327 /**
328  * @}
329  */
330 
331 #endif /* ZEPHYR_INCLUDE_BLUETOOTH_MICP_H_ */
332