xref: /linux/include/net/bluetooth/mgmt.h (revision bea06c7c1b83bcd0519b91141999369eae6925bd)
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3    BlueZ - Bluetooth protocol stack for Linux
4 
5    Copyright (C) 2010  Nokia Corporation
6    Copyright (C) 2011-2012  Intel Corporation
7 
8    THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
9    OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
10    FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
11    IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
12    CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES
13    WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14    ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15    OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16 
17    ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS,
18    COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS
19    SOFTWARE IS DISCLAIMED.
20 */
21 
22 #define MGMT_INDEX_NONE			0xFFFF
23 
24 #define MGMT_STATUS_SUCCESS		0x00
25 #define MGMT_STATUS_UNKNOWN_COMMAND	0x01
26 #define MGMT_STATUS_NOT_CONNECTED	0x02
27 #define MGMT_STATUS_FAILED		0x03
28 #define MGMT_STATUS_CONNECT_FAILED	0x04
29 #define MGMT_STATUS_AUTH_FAILED		0x05
30 #define MGMT_STATUS_NOT_PAIRED		0x06
31 #define MGMT_STATUS_NO_RESOURCES	0x07
32 #define MGMT_STATUS_TIMEOUT		0x08
33 #define MGMT_STATUS_ALREADY_CONNECTED	0x09
34 #define MGMT_STATUS_BUSY		0x0a
35 #define MGMT_STATUS_REJECTED		0x0b
36 #define MGMT_STATUS_NOT_SUPPORTED	0x0c
37 #define MGMT_STATUS_INVALID_PARAMS	0x0d
38 #define MGMT_STATUS_DISCONNECTED	0x0e
39 #define MGMT_STATUS_NOT_POWERED		0x0f
40 #define MGMT_STATUS_CANCELLED		0x10
41 #define MGMT_STATUS_INVALID_INDEX	0x11
42 #define MGMT_STATUS_RFKILLED		0x12
43 #define MGMT_STATUS_ALREADY_PAIRED	0x13
44 #define MGMT_STATUS_PERMISSION_DENIED	0x14
45 
46 struct mgmt_hdr {
47 	__le16	opcode;
48 	__le16	index;
49 	__le16	len;
50 } __packed;
51 
52 struct mgmt_tlv {
53 	/* New members MUST be added within the __struct_group() macro below. */
54 	__struct_group(mgmt_tlv_hdr, __hdr, __packed,
55 		__le16 type;
56 		__u8   length;
57 	);
58 	__u8   value[];
59 } __packed;
60 static_assert(offsetof(struct mgmt_tlv, value) == sizeof(struct mgmt_tlv_hdr),
61 	      "struct member likely outside of __struct_group()");
62 
63 struct mgmt_addr_info {
64 	bdaddr_t	bdaddr;
65 	__u8		type;
66 } __packed;
67 #define MGMT_ADDR_INFO_SIZE		7
68 
69 #define MGMT_OP_READ_VERSION		0x0001
70 #define MGMT_READ_VERSION_SIZE		0
71 struct mgmt_rp_read_version {
72 	__u8	version;
73 	__le16	revision;
74 } __packed;
75 
76 #define MGMT_OP_READ_COMMANDS		0x0002
77 #define MGMT_READ_COMMANDS_SIZE		0
78 struct mgmt_rp_read_commands {
79 	__le16	num_commands;
80 	__le16	num_events;
81 	__le16	opcodes[];
82 } __packed;
83 
84 #define MGMT_OP_READ_INDEX_LIST		0x0003
85 #define MGMT_READ_INDEX_LIST_SIZE	0
86 struct mgmt_rp_read_index_list {
87 	__le16	num_controllers;
88 	__le16	index[];
89 } __packed;
90 
91 /* Reserve one extra byte for names in management messages so that they
92  * are always guaranteed to be nul-terminated */
93 #define MGMT_MAX_NAME_LENGTH		(HCI_MAX_NAME_LENGTH + 1)
94 #define MGMT_MAX_SHORT_NAME_LENGTH	(HCI_MAX_SHORT_NAME_LENGTH + 1)
95 
96 #define MGMT_SETTING_POWERED		BIT(0)
97 #define MGMT_SETTING_CONNECTABLE	BIT(1)
98 #define MGMT_SETTING_FAST_CONNECTABLE	BIT(2)
99 #define MGMT_SETTING_DISCOVERABLE	BIT(3)
100 #define MGMT_SETTING_BONDABLE		BIT(4)
101 #define MGMT_SETTING_LINK_SECURITY	BIT(5)
102 #define MGMT_SETTING_SSP		BIT(6)
103 #define MGMT_SETTING_BREDR		BIT(7)
104 #define MGMT_SETTING_HS			BIT(8)
105 #define MGMT_SETTING_LE			BIT(9)
106 #define MGMT_SETTING_ADVERTISING	BIT(10)
107 #define MGMT_SETTING_SECURE_CONN	BIT(11)
108 #define MGMT_SETTING_DEBUG_KEYS		BIT(12)
109 #define MGMT_SETTING_PRIVACY		BIT(13)
110 #define MGMT_SETTING_CONFIGURATION	BIT(14)
111 #define MGMT_SETTING_STATIC_ADDRESS	BIT(15)
112 #define MGMT_SETTING_PHY_CONFIGURATION	BIT(16)
113 #define MGMT_SETTING_WIDEBAND_SPEECH	BIT(17)
114 #define MGMT_SETTING_CIS_CENTRAL	BIT(18)
115 #define MGMT_SETTING_CIS_PERIPHERAL	BIT(19)
116 #define MGMT_SETTING_ISO_BROADCASTER	BIT(20)
117 #define MGMT_SETTING_ISO_SYNC_RECEIVER	BIT(21)
118 #define MGMT_SETTING_LL_PRIVACY		BIT(22)
119 #define MGMT_SETTING_PAST_SENDER	BIT(23)
120 #define MGMT_SETTING_PAST_RECEIVER	BIT(24)
121 
122 #define MGMT_OP_READ_INFO		0x0004
123 #define MGMT_READ_INFO_SIZE		0
124 struct mgmt_rp_read_info {
125 	bdaddr_t	bdaddr;
126 	__u8		version;
127 	__le16		manufacturer;
128 	__le32		supported_settings;
129 	__le32		current_settings;
130 	__u8		dev_class[3];
131 	__u8		name[MGMT_MAX_NAME_LENGTH];
132 	__u8		short_name[MGMT_MAX_SHORT_NAME_LENGTH];
133 } __packed;
134 
135 struct mgmt_mode {
136 	__u8 val;
137 } __packed;
138 
139 #define MGMT_SETTING_SIZE		1
140 
141 #define MGMT_OP_SET_POWERED		0x0005
142 
143 #define MGMT_OP_SET_DISCOVERABLE	0x0006
144 struct mgmt_cp_set_discoverable {
145 	__u8	val;
146 	__le16	timeout;
147 } __packed;
148 #define MGMT_SET_DISCOVERABLE_SIZE	3
149 
150 #define MGMT_OP_SET_CONNECTABLE		0x0007
151 
152 #define MGMT_OP_SET_FAST_CONNECTABLE	0x0008
153 
154 #define MGMT_OP_SET_BONDABLE		0x0009
155 
156 #define MGMT_OP_SET_LINK_SECURITY	0x000A
157 
158 #define MGMT_OP_SET_SSP			0x000B
159 
160 #define MGMT_OP_SET_HS			0x000C
161 
162 #define MGMT_OP_SET_LE			0x000D
163 #define MGMT_OP_SET_DEV_CLASS		0x000E
164 struct mgmt_cp_set_dev_class {
165 	__u8	major;
166 	__u8	minor;
167 } __packed;
168 #define MGMT_SET_DEV_CLASS_SIZE		2
169 
170 #define MGMT_OP_SET_LOCAL_NAME		0x000F
171 struct mgmt_cp_set_local_name {
172 	__u8	name[MGMT_MAX_NAME_LENGTH];
173 	__u8	short_name[MGMT_MAX_SHORT_NAME_LENGTH];
174 } __packed;
175 #define MGMT_SET_LOCAL_NAME_SIZE	260
176 
177 #define MGMT_OP_ADD_UUID		0x0010
178 struct mgmt_cp_add_uuid {
179 	__u8	uuid[16];
180 	__u8	svc_hint;
181 } __packed;
182 #define MGMT_ADD_UUID_SIZE		17
183 
184 #define MGMT_OP_REMOVE_UUID		0x0011
185 struct mgmt_cp_remove_uuid {
186 	__u8	uuid[16];
187 } __packed;
188 #define MGMT_REMOVE_UUID_SIZE		16
189 
190 struct mgmt_link_key_info {
191 	struct mgmt_addr_info addr;
192 	__u8	type;
193 	__u8	val[16];
194 	__u8	pin_len;
195 } __packed;
196 
197 #define MGMT_OP_LOAD_LINK_KEYS		0x0012
198 struct mgmt_cp_load_link_keys {
199 	__u8	debug_keys;
200 	__le16	key_count;
201 	struct	mgmt_link_key_info keys[];
202 } __packed;
203 #define MGMT_LOAD_LINK_KEYS_SIZE	3
204 
205 #define MGMT_LTK_UNAUTHENTICATED	0x00
206 #define MGMT_LTK_AUTHENTICATED		0x01
207 #define MGMT_LTK_P256_UNAUTH		0x02
208 #define MGMT_LTK_P256_AUTH		0x03
209 #define MGMT_LTK_P256_DEBUG		0x04
210 
211 struct mgmt_ltk_info {
212 	struct mgmt_addr_info addr;
213 	__u8	type;
214 	__u8	initiator;
215 	__u8	enc_size;
216 	__le16	ediv;
217 	__le64	rand;
218 	__u8	val[16];
219 } __packed;
220 
221 #define MGMT_OP_LOAD_LONG_TERM_KEYS	0x0013
222 struct mgmt_cp_load_long_term_keys {
223 	__le16	key_count;
224 	struct	mgmt_ltk_info keys[];
225 } __packed;
226 #define MGMT_LOAD_LONG_TERM_KEYS_SIZE	2
227 
228 #define MGMT_OP_DISCONNECT		0x0014
229 struct mgmt_cp_disconnect {
230 	struct mgmt_addr_info addr;
231 } __packed;
232 #define MGMT_DISCONNECT_SIZE		MGMT_ADDR_INFO_SIZE
233 struct mgmt_rp_disconnect {
234 	struct mgmt_addr_info addr;
235 } __packed;
236 
237 #define MGMT_OP_GET_CONNECTIONS		0x0015
238 #define MGMT_GET_CONNECTIONS_SIZE	0
239 struct mgmt_rp_get_connections {
240 	__le16 conn_count;
241 	struct mgmt_addr_info addr[];
242 } __packed;
243 
244 #define MGMT_OP_PIN_CODE_REPLY		0x0016
245 struct mgmt_cp_pin_code_reply {
246 	struct mgmt_addr_info addr;
247 	__u8	pin_len;
248 	__u8	pin_code[16];
249 } __packed;
250 #define MGMT_PIN_CODE_REPLY_SIZE	(MGMT_ADDR_INFO_SIZE + 17)
251 struct mgmt_rp_pin_code_reply {
252 	struct mgmt_addr_info addr;
253 } __packed;
254 
255 #define MGMT_OP_PIN_CODE_NEG_REPLY	0x0017
256 struct mgmt_cp_pin_code_neg_reply {
257 	struct mgmt_addr_info addr;
258 } __packed;
259 #define MGMT_PIN_CODE_NEG_REPLY_SIZE	MGMT_ADDR_INFO_SIZE
260 
261 #define MGMT_OP_SET_IO_CAPABILITY	0x0018
262 struct mgmt_cp_set_io_capability {
263 	__u8	io_capability;
264 } __packed;
265 #define MGMT_SET_IO_CAPABILITY_SIZE	1
266 
267 #define MGMT_OP_PAIR_DEVICE		0x0019
268 struct mgmt_cp_pair_device {
269 	struct mgmt_addr_info addr;
270 	__u8	io_cap;
271 } __packed;
272 #define MGMT_PAIR_DEVICE_SIZE		(MGMT_ADDR_INFO_SIZE + 1)
273 struct mgmt_rp_pair_device {
274 	struct mgmt_addr_info addr;
275 } __packed;
276 
277 #define MGMT_OP_CANCEL_PAIR_DEVICE	0x001A
278 #define MGMT_CANCEL_PAIR_DEVICE_SIZE	MGMT_ADDR_INFO_SIZE
279 
280 #define MGMT_OP_UNPAIR_DEVICE		0x001B
281 struct mgmt_cp_unpair_device {
282 	struct mgmt_addr_info addr;
283 	__u8 disconnect;
284 } __packed;
285 #define MGMT_UNPAIR_DEVICE_SIZE		(MGMT_ADDR_INFO_SIZE + 1)
286 struct mgmt_rp_unpair_device {
287 	struct mgmt_addr_info addr;
288 };
289 
290 #define MGMT_OP_USER_CONFIRM_REPLY	0x001C
291 struct mgmt_cp_user_confirm_reply {
292 	struct mgmt_addr_info addr;
293 } __packed;
294 #define MGMT_USER_CONFIRM_REPLY_SIZE	MGMT_ADDR_INFO_SIZE
295 struct mgmt_rp_user_confirm_reply {
296 	struct mgmt_addr_info addr;
297 } __packed;
298 
299 #define MGMT_OP_USER_CONFIRM_NEG_REPLY	0x001D
300 struct mgmt_cp_user_confirm_neg_reply {
301 	struct mgmt_addr_info addr;
302 } __packed;
303 #define MGMT_USER_CONFIRM_NEG_REPLY_SIZE MGMT_ADDR_INFO_SIZE
304 
305 #define MGMT_OP_USER_PASSKEY_REPLY	0x001E
306 struct mgmt_cp_user_passkey_reply {
307 	struct mgmt_addr_info addr;
308 	__le32	passkey;
309 } __packed;
310 #define MGMT_USER_PASSKEY_REPLY_SIZE	(MGMT_ADDR_INFO_SIZE + 4)
311 struct mgmt_rp_user_passkey_reply {
312 	struct mgmt_addr_info addr;
313 } __packed;
314 
315 #define MGMT_OP_USER_PASSKEY_NEG_REPLY	0x001F
316 struct mgmt_cp_user_passkey_neg_reply {
317 	struct mgmt_addr_info addr;
318 } __packed;
319 #define MGMT_USER_PASSKEY_NEG_REPLY_SIZE MGMT_ADDR_INFO_SIZE
320 
321 #define MGMT_OP_READ_LOCAL_OOB_DATA	0x0020
322 #define MGMT_READ_LOCAL_OOB_DATA_SIZE	0
323 struct mgmt_rp_read_local_oob_data {
324 	__u8	hash192[16];
325 	__u8	rand192[16];
326 	__u8	hash256[16];
327 	__u8	rand256[16];
328 } __packed;
329 
330 #define MGMT_OP_ADD_REMOTE_OOB_DATA	0x0021
331 struct mgmt_cp_add_remote_oob_data {
332 	struct mgmt_addr_info addr;
333 	__u8	hash[16];
334 	__u8	rand[16];
335 } __packed;
336 #define MGMT_ADD_REMOTE_OOB_DATA_SIZE	(MGMT_ADDR_INFO_SIZE + 32)
337 struct mgmt_cp_add_remote_oob_ext_data {
338 	struct mgmt_addr_info addr;
339 	__u8	hash192[16];
340 	__u8	rand192[16];
341 	__u8	hash256[16];
342 	__u8	rand256[16];
343 } __packed;
344 #define MGMT_ADD_REMOTE_OOB_EXT_DATA_SIZE (MGMT_ADDR_INFO_SIZE + 64)
345 
346 #define MGMT_OP_REMOVE_REMOTE_OOB_DATA	0x0022
347 struct mgmt_cp_remove_remote_oob_data {
348 	struct mgmt_addr_info addr;
349 } __packed;
350 #define MGMT_REMOVE_REMOTE_OOB_DATA_SIZE MGMT_ADDR_INFO_SIZE
351 
352 #define MGMT_OP_START_DISCOVERY		0x0023
353 struct mgmt_cp_start_discovery {
354 	__u8 type;
355 } __packed;
356 #define MGMT_START_DISCOVERY_SIZE	1
357 
358 #define MGMT_OP_STOP_DISCOVERY		0x0024
359 struct mgmt_cp_stop_discovery {
360 	__u8 type;
361 } __packed;
362 #define MGMT_STOP_DISCOVERY_SIZE	1
363 
364 #define MGMT_OP_CONFIRM_NAME		0x0025
365 struct mgmt_cp_confirm_name {
366 	struct mgmt_addr_info addr;
367 	__u8	name_known;
368 } __packed;
369 #define MGMT_CONFIRM_NAME_SIZE		(MGMT_ADDR_INFO_SIZE + 1)
370 struct mgmt_rp_confirm_name {
371 	struct mgmt_addr_info addr;
372 } __packed;
373 
374 #define MGMT_OP_BLOCK_DEVICE		0x0026
375 struct mgmt_cp_block_device {
376 	struct mgmt_addr_info addr;
377 } __packed;
378 #define MGMT_BLOCK_DEVICE_SIZE		MGMT_ADDR_INFO_SIZE
379 
380 #define MGMT_OP_UNBLOCK_DEVICE		0x0027
381 struct mgmt_cp_unblock_device {
382 	struct mgmt_addr_info addr;
383 } __packed;
384 #define MGMT_UNBLOCK_DEVICE_SIZE	MGMT_ADDR_INFO_SIZE
385 
386 #define MGMT_OP_SET_DEVICE_ID		0x0028
387 struct mgmt_cp_set_device_id {
388 	__le16	source;
389 	__le16	vendor;
390 	__le16	product;
391 	__le16	version;
392 } __packed;
393 #define MGMT_SET_DEVICE_ID_SIZE		8
394 
395 #define MGMT_OP_SET_ADVERTISING		0x0029
396 
397 #define MGMT_OP_SET_BREDR		0x002A
398 
399 #define MGMT_OP_SET_STATIC_ADDRESS	0x002B
400 struct mgmt_cp_set_static_address {
401 	bdaddr_t bdaddr;
402 } __packed;
403 #define MGMT_SET_STATIC_ADDRESS_SIZE	6
404 
405 #define MGMT_OP_SET_SCAN_PARAMS		0x002C
406 struct mgmt_cp_set_scan_params {
407 	__le16	interval;
408 	__le16	window;
409 } __packed;
410 #define MGMT_SET_SCAN_PARAMS_SIZE	4
411 
412 #define MGMT_OP_SET_SECURE_CONN		0x002D
413 
414 #define MGMT_OP_SET_DEBUG_KEYS		0x002E
415 
416 #define MGMT_OP_SET_PRIVACY		0x002F
417 struct mgmt_cp_set_privacy {
418 	__u8 privacy;
419 	__u8 irk[16];
420 } __packed;
421 #define MGMT_SET_PRIVACY_SIZE		17
422 
423 struct mgmt_irk_info {
424 	struct mgmt_addr_info addr;
425 	__u8 val[16];
426 } __packed;
427 
428 #define MGMT_OP_LOAD_IRKS		0x0030
429 struct mgmt_cp_load_irks {
430 	__le16 irk_count;
431 	struct mgmt_irk_info irks[];
432 } __packed;
433 #define MGMT_LOAD_IRKS_SIZE		2
434 
435 #define MGMT_OP_GET_CONN_INFO		0x0031
436 struct mgmt_cp_get_conn_info {
437 	struct mgmt_addr_info addr;
438 } __packed;
439 #define MGMT_GET_CONN_INFO_SIZE		MGMT_ADDR_INFO_SIZE
440 struct mgmt_rp_get_conn_info {
441 	struct mgmt_addr_info addr;
442 	__s8	rssi;
443 	__s8	tx_power;
444 	__s8	max_tx_power;
445 } __packed;
446 
447 #define MGMT_OP_GET_CLOCK_INFO		0x0032
448 struct mgmt_cp_get_clock_info {
449 	struct mgmt_addr_info addr;
450 } __packed;
451 #define MGMT_GET_CLOCK_INFO_SIZE	MGMT_ADDR_INFO_SIZE
452 struct mgmt_rp_get_clock_info {
453 	struct mgmt_addr_info addr;
454 	__le32  local_clock;
455 	__le32  piconet_clock;
456 	__le16  accuracy;
457 } __packed;
458 
459 #define MGMT_OP_ADD_DEVICE		0x0033
460 struct mgmt_cp_add_device {
461 	struct mgmt_addr_info addr;
462 	__u8	action;
463 } __packed;
464 #define MGMT_ADD_DEVICE_SIZE		(MGMT_ADDR_INFO_SIZE + 1)
465 
466 #define MGMT_OP_REMOVE_DEVICE		0x0034
467 struct mgmt_cp_remove_device {
468 	struct mgmt_addr_info addr;
469 } __packed;
470 #define MGMT_REMOVE_DEVICE_SIZE		MGMT_ADDR_INFO_SIZE
471 
472 struct mgmt_conn_param {
473 	struct mgmt_addr_info addr;
474 	__le16 min_interval;
475 	__le16 max_interval;
476 	__le16 latency;
477 	__le16 timeout;
478 } __packed;
479 
480 #define MGMT_OP_LOAD_CONN_PARAM		0x0035
481 struct mgmt_cp_load_conn_param {
482 	__le16 param_count;
483 	struct mgmt_conn_param params[];
484 } __packed;
485 #define MGMT_LOAD_CONN_PARAM_SIZE	2
486 
487 #define MGMT_OP_READ_UNCONF_INDEX_LIST	0x0036
488 #define MGMT_READ_UNCONF_INDEX_LIST_SIZE 0
489 struct mgmt_rp_read_unconf_index_list {
490 	__le16	num_controllers;
491 	__le16	index[];
492 } __packed;
493 
494 #define MGMT_OPTION_EXTERNAL_CONFIG	0x00000001
495 #define MGMT_OPTION_PUBLIC_ADDRESS	0x00000002
496 
497 #define MGMT_OP_READ_CONFIG_INFO	0x0037
498 #define MGMT_READ_CONFIG_INFO_SIZE	0
499 struct mgmt_rp_read_config_info {
500 	__le16	manufacturer;
501 	__le32	supported_options;
502 	__le32	missing_options;
503 } __packed;
504 
505 #define MGMT_OP_SET_EXTERNAL_CONFIG	0x0038
506 struct mgmt_cp_set_external_config {
507 	__u8 config;
508 } __packed;
509 #define MGMT_SET_EXTERNAL_CONFIG_SIZE	1
510 
511 #define MGMT_OP_SET_PUBLIC_ADDRESS	0x0039
512 struct mgmt_cp_set_public_address {
513 	bdaddr_t bdaddr;
514 } __packed;
515 #define MGMT_SET_PUBLIC_ADDRESS_SIZE	6
516 
517 #define MGMT_OP_START_SERVICE_DISCOVERY	0x003A
518 struct mgmt_cp_start_service_discovery {
519 	__u8 type;
520 	__s8 rssi;
521 	__le16 uuid_count;
522 	__u8 uuids[][16];
523 } __packed;
524 #define MGMT_START_SERVICE_DISCOVERY_SIZE 4
525 
526 #define MGMT_OP_READ_LOCAL_OOB_EXT_DATA	0x003B
527 struct mgmt_cp_read_local_oob_ext_data {
528 	__u8 type;
529 } __packed;
530 #define MGMT_READ_LOCAL_OOB_EXT_DATA_SIZE 1
531 struct mgmt_rp_read_local_oob_ext_data {
532 	__u8    type;
533 	__le16	eir_len;
534 	__u8	eir[];
535 } __packed;
536 
537 #define MGMT_OP_READ_EXT_INDEX_LIST	0x003C
538 #define MGMT_READ_EXT_INDEX_LIST_SIZE	0
539 struct mgmt_rp_read_ext_index_list {
540 	__le16	num_controllers;
541 	struct {
542 		__le16 index;
543 		__u8   type;
544 		__u8   bus;
545 	} entry[];
546 } __packed;
547 
548 #define MGMT_OP_READ_ADV_FEATURES	0x0003D
549 #define MGMT_READ_ADV_FEATURES_SIZE	0
550 struct mgmt_rp_read_adv_features {
551 	__le32 supported_flags;
552 	__u8   max_adv_data_len;
553 	__u8   max_scan_rsp_len;
554 	__u8   max_instances;
555 	__u8   num_instances;
556 	__u8   instance[];
557 } __packed;
558 
559 #define MGMT_OP_ADD_ADVERTISING		0x003E
560 struct mgmt_cp_add_advertising {
561 	__u8	instance;
562 	__le32	flags;
563 	__le16	duration;
564 	__le16	timeout;
565 	__u8	adv_data_len;
566 	__u8	scan_rsp_len;
567 	__u8	data[];
568 } __packed;
569 #define MGMT_ADD_ADVERTISING_SIZE	11
570 struct mgmt_rp_add_advertising {
571 	__u8	instance;
572 } __packed;
573 
574 #define MGMT_ADV_FLAG_CONNECTABLE	BIT(0)
575 #define MGMT_ADV_FLAG_DISCOV		BIT(1)
576 #define MGMT_ADV_FLAG_LIMITED_DISCOV	BIT(2)
577 #define MGMT_ADV_FLAG_MANAGED_FLAGS	BIT(3)
578 #define MGMT_ADV_FLAG_TX_POWER		BIT(4)
579 #define MGMT_ADV_FLAG_APPEARANCE	BIT(5)
580 #define MGMT_ADV_FLAG_LOCAL_NAME	BIT(6)
581 #define MGMT_ADV_FLAG_SEC_1M 		BIT(7)
582 #define MGMT_ADV_FLAG_SEC_2M 		BIT(8)
583 #define MGMT_ADV_FLAG_SEC_CODED 	BIT(9)
584 #define MGMT_ADV_FLAG_CAN_SET_TX_POWER	BIT(10)
585 #define MGMT_ADV_FLAG_HW_OFFLOAD	BIT(11)
586 #define MGMT_ADV_PARAM_DURATION		BIT(12)
587 #define MGMT_ADV_PARAM_TIMEOUT		BIT(13)
588 #define MGMT_ADV_PARAM_INTERVALS	BIT(14)
589 #define MGMT_ADV_PARAM_TX_POWER		BIT(15)
590 #define MGMT_ADV_PARAM_SCAN_RSP		BIT(16)
591 
592 #define MGMT_ADV_FLAG_SEC_MASK	(MGMT_ADV_FLAG_SEC_1M | MGMT_ADV_FLAG_SEC_2M | \
593 				 MGMT_ADV_FLAG_SEC_CODED)
594 
595 #define MGMT_OP_REMOVE_ADVERTISING	0x003F
596 struct mgmt_cp_remove_advertising {
597 	__u8	instance;
598 } __packed;
599 #define MGMT_REMOVE_ADVERTISING_SIZE	1
600 struct mgmt_rp_remove_advertising {
601 	__u8	instance;
602 } __packed;
603 
604 #define MGMT_OP_GET_ADV_SIZE_INFO	0x0040
605 struct mgmt_cp_get_adv_size_info {
606 	__u8	instance;
607 	__le32	flags;
608 } __packed;
609 #define MGMT_GET_ADV_SIZE_INFO_SIZE	5
610 struct mgmt_rp_get_adv_size_info {
611 	__u8	instance;
612 	__le32	flags;
613 	__u8	max_adv_data_len;
614 	__u8	max_scan_rsp_len;
615 } __packed;
616 
617 #define MGMT_OP_START_LIMITED_DISCOVERY	0x0041
618 
619 #define MGMT_OP_READ_EXT_INFO		0x0042
620 #define MGMT_READ_EXT_INFO_SIZE		0
621 struct mgmt_rp_read_ext_info {
622 	bdaddr_t bdaddr;
623 	__u8     version;
624 	__le16   manufacturer;
625 	__le32   supported_settings;
626 	__le32   current_settings;
627 	__le16   eir_len;
628 	__u8     eir[];
629 } __packed;
630 
631 #define MGMT_OP_SET_APPEARANCE		0x0043
632 struct mgmt_cp_set_appearance {
633 	__le16	appearance;
634 } __packed;
635 #define MGMT_SET_APPEARANCE_SIZE	2
636 
637 #define MGMT_OP_GET_PHY_CONFIGURATION	0x0044
638 struct mgmt_rp_get_phy_configuration {
639 	__le32	supported_phys;
640 	__le32	configurable_phys;
641 	__le32	selected_phys;
642 } __packed;
643 #define MGMT_GET_PHY_CONFIGURATION_SIZE	0
644 
645 #define MGMT_PHY_BR_1M_1SLOT		BIT(0)
646 #define MGMT_PHY_BR_1M_3SLOT		BIT(1)
647 #define MGMT_PHY_BR_1M_5SLOT		BIT(2)
648 #define MGMT_PHY_EDR_2M_1SLOT		BIT(3)
649 #define MGMT_PHY_EDR_2M_3SLOT		BIT(4)
650 #define MGMT_PHY_EDR_2M_5SLOT		BIT(5)
651 #define MGMT_PHY_EDR_3M_1SLOT		BIT(6)
652 #define MGMT_PHY_EDR_3M_3SLOT		BIT(7)
653 #define MGMT_PHY_EDR_3M_5SLOT		BIT(8)
654 #define MGMT_PHY_LE_1M_TX		BIT(9)
655 #define MGMT_PHY_LE_1M_RX		BIT(10)
656 #define MGMT_PHY_LE_2M_TX		BIT(11)
657 #define MGMT_PHY_LE_2M_RX		BIT(12)
658 #define MGMT_PHY_LE_CODED_TX		BIT(13)
659 #define MGMT_PHY_LE_CODED_RX		BIT(14)
660 
661 #define MGMT_PHY_BREDR_MASK (MGMT_PHY_BR_1M_1SLOT | MGMT_PHY_BR_1M_3SLOT | \
662 			     MGMT_PHY_BR_1M_5SLOT | MGMT_PHY_EDR_2M_1SLOT | \
663 			     MGMT_PHY_EDR_2M_3SLOT | MGMT_PHY_EDR_2M_5SLOT | \
664 			     MGMT_PHY_EDR_3M_1SLOT | MGMT_PHY_EDR_3M_3SLOT | \
665 			     MGMT_PHY_EDR_3M_5SLOT)
666 #define MGMT_PHY_LE_MASK (MGMT_PHY_LE_1M_TX | MGMT_PHY_LE_1M_RX | \
667 			  MGMT_PHY_LE_2M_TX | MGMT_PHY_LE_2M_RX | \
668 			  MGMT_PHY_LE_CODED_TX | MGMT_PHY_LE_CODED_RX)
669 #define MGMT_PHY_LE_TX_MASK (MGMT_PHY_LE_1M_TX | MGMT_PHY_LE_2M_TX | \
670 			     MGMT_PHY_LE_CODED_TX)
671 #define MGMT_PHY_LE_RX_MASK (MGMT_PHY_LE_1M_RX | MGMT_PHY_LE_2M_RX | \
672 			     MGMT_PHY_LE_CODED_RX)
673 
674 #define MGMT_OP_SET_PHY_CONFIGURATION	0x0045
675 struct mgmt_cp_set_phy_configuration {
676 	__le32	selected_phys;
677 } __packed;
678 #define MGMT_SET_PHY_CONFIGURATION_SIZE	4
679 
680 #define MGMT_OP_SET_BLOCKED_KEYS	0x0046
681 
682 #define HCI_BLOCKED_KEY_TYPE_LINKKEY	0x00
683 #define HCI_BLOCKED_KEY_TYPE_LTK	0x01
684 #define HCI_BLOCKED_KEY_TYPE_IRK	0x02
685 
686 struct mgmt_blocked_key_info {
687 	__u8 type;
688 	__u8 val[16];
689 } __packed;
690 
691 struct mgmt_cp_set_blocked_keys {
692 	__le16 key_count;
693 	struct mgmt_blocked_key_info keys[];
694 } __packed;
695 #define MGMT_OP_SET_BLOCKED_KEYS_SIZE 2
696 
697 #define MGMT_OP_SET_WIDEBAND_SPEECH	0x0047
698 
699 #define MGMT_CAP_SEC_FLAGS		0x01
700 #define MGMT_CAP_MAX_ENC_KEY_SIZE	0x02
701 #define MGMT_CAP_SMP_MAX_ENC_KEY_SIZE	0x03
702 #define MGMT_CAP_LE_TX_PWR		0x04
703 
704 #define MGMT_OP_READ_CONTROLLER_CAP	0x0048
705 #define MGMT_READ_CONTROLLER_CAP_SIZE	0
706 struct mgmt_rp_read_controller_cap {
707 	__le16   cap_len;
708 	__u8     cap[];
709 } __packed;
710 
711 #define MGMT_OP_READ_EXP_FEATURES_INFO	0x0049
712 #define MGMT_READ_EXP_FEATURES_INFO_SIZE 0
713 struct mgmt_rp_read_exp_features_info {
714 	__le16 feature_count;
715 	struct {
716 		__u8   uuid[16];
717 		__le32 flags;
718 	} features[];
719 } __packed;
720 
721 #define MGMT_OP_SET_EXP_FEATURE		0x004a
722 struct mgmt_cp_set_exp_feature {
723 	__u8   uuid[16];
724 	__u8   param[];
725 } __packed;
726 #define MGMT_SET_EXP_FEATURE_SIZE	16
727 struct mgmt_rp_set_exp_feature {
728 	__u8   uuid[16];
729 	__le32 flags;
730 } __packed;
731 
732 #define MGMT_OP_READ_DEF_SYSTEM_CONFIG	0x004b
733 #define MGMT_READ_DEF_SYSTEM_CONFIG_SIZE	0
734 
735 #define MGMT_OP_SET_DEF_SYSTEM_CONFIG	0x004c
736 #define MGMT_SET_DEF_SYSTEM_CONFIG_SIZE		0
737 
738 #define MGMT_OP_READ_DEF_RUNTIME_CONFIG	0x004d
739 #define MGMT_READ_DEF_RUNTIME_CONFIG_SIZE	0
740 
741 #define MGMT_OP_SET_DEF_RUNTIME_CONFIG	0x004e
742 #define MGMT_SET_DEF_RUNTIME_CONFIG_SIZE	0
743 
744 #define MGMT_OP_GET_DEVICE_FLAGS	0x004F
745 #define MGMT_GET_DEVICE_FLAGS_SIZE	7
746 struct mgmt_cp_get_device_flags {
747 	struct mgmt_addr_info addr;
748 } __packed;
749 struct mgmt_rp_get_device_flags {
750 	struct mgmt_addr_info addr;
751 	__le32 supported_flags;
752 	__le32 current_flags;
753 } __packed;
754 
755 #define MGMT_OP_SET_DEVICE_FLAGS	0x0050
756 #define MGMT_SET_DEVICE_FLAGS_SIZE	11
757 struct mgmt_cp_set_device_flags {
758 	struct mgmt_addr_info addr;
759 	__le32 current_flags;
760 } __packed;
761 struct mgmt_rp_set_device_flags {
762 	struct mgmt_addr_info addr;
763 } __packed;
764 
765 #define MGMT_ADV_MONITOR_FEATURE_MASK_OR_PATTERNS    BIT(0)
766 
767 #define MGMT_OP_READ_ADV_MONITOR_FEATURES	0x0051
768 #define MGMT_READ_ADV_MONITOR_FEATURES_SIZE	0
769 struct mgmt_rp_read_adv_monitor_features {
770 	__le32 supported_features;
771 	__le32 enabled_features;
772 	__le16 max_num_handles;
773 	__u8 max_num_patterns;
774 	__le16 num_handles;
775 	__le16 handles[];
776 }  __packed;
777 
778 struct mgmt_adv_pattern {
779 	__u8 ad_type;
780 	__u8 offset;
781 	__u8 length;
782 	__u8 value[HCI_MAX_AD_LENGTH];
783 } __packed;
784 
785 #define MGMT_OP_ADD_ADV_PATTERNS_MONITOR	0x0052
786 struct mgmt_cp_add_adv_patterns_monitor {
787 	__u8 pattern_count;
788 	struct mgmt_adv_pattern patterns[];
789 } __packed;
790 #define MGMT_ADD_ADV_PATTERNS_MONITOR_SIZE	1
791 struct mgmt_rp_add_adv_patterns_monitor {
792 	__le16 monitor_handle;
793 } __packed;
794 
795 #define MGMT_OP_REMOVE_ADV_MONITOR		0x0053
796 struct mgmt_cp_remove_adv_monitor {
797 	__le16 monitor_handle;
798 } __packed;
799 #define MGMT_REMOVE_ADV_MONITOR_SIZE		2
800 struct mgmt_rp_remove_adv_monitor {
801 	__le16 monitor_handle;
802 } __packed;
803 
804 #define MGMT_OP_ADD_EXT_ADV_PARAMS		0x0054
805 struct mgmt_cp_add_ext_adv_params {
806 	__u8	instance;
807 	__le32	flags;
808 	__le16	duration;
809 	__le16	timeout;
810 	__le32	min_interval;
811 	__le32	max_interval;
812 	__s8	tx_power;
813 } __packed;
814 #define MGMT_ADD_EXT_ADV_PARAMS_MIN_SIZE	18
815 struct mgmt_rp_add_ext_adv_params {
816 	__u8	instance;
817 	__s8	tx_power;
818 	__u8	max_adv_data_len;
819 	__u8	max_scan_rsp_len;
820 } __packed;
821 
822 #define MGMT_OP_ADD_EXT_ADV_DATA		0x0055
823 struct mgmt_cp_add_ext_adv_data {
824 	__u8	instance;
825 	__u8	adv_data_len;
826 	__u8	scan_rsp_len;
827 	__u8	data[];
828 } __packed;
829 #define MGMT_ADD_EXT_ADV_DATA_SIZE	3
830 struct mgmt_rp_add_ext_adv_data {
831 	__u8	instance;
832 } __packed;
833 
834 struct mgmt_adv_rssi_thresholds {
835 	__s8	high_threshold;
836 	__le16	high_threshold_timeout;
837 	__s8	low_threshold;
838 	__le16	low_threshold_timeout;
839 	__u8	sampling_period;
840 } __packed;
841 
842 #define MGMT_OP_ADD_ADV_PATTERNS_MONITOR_RSSI	0x0056
843 struct mgmt_cp_add_adv_patterns_monitor_rssi {
844 	struct mgmt_adv_rssi_thresholds rssi;
845 	__u8	pattern_count;
846 	struct mgmt_adv_pattern patterns[];
847 } __packed;
848 #define MGMT_ADD_ADV_PATTERNS_MONITOR_RSSI_SIZE	8
849 #define MGMT_OP_SET_MESH_RECEIVER		0x0057
850 struct mgmt_cp_set_mesh {
851 	__u8   enable;
852 	__le16 window;
853 	__le16 period;
854 	__u8   num_ad_types;
855 	__u8   ad_types[] __counted_by(num_ad_types);
856 } __packed;
857 #define MGMT_SET_MESH_RECEIVER_SIZE	6
858 
859 #define MGMT_OP_MESH_READ_FEATURES	0x0058
860 #define MGMT_MESH_READ_FEATURES_SIZE	0
861 #define MESH_HANDLES_MAX	3
862 struct mgmt_rp_mesh_read_features {
863 	__le16	index;
864 	__u8   max_handles;
865 	__u8   used_handles;
866 	__u8   handles[MESH_HANDLES_MAX];
867 } __packed;
868 
869 #define MGMT_OP_MESH_SEND		0x0059
870 struct mgmt_cp_mesh_send {
871 	struct mgmt_addr_info addr;
872 	__le64  instant;
873 	__le16  delay;
874 	__u8   cnt;
875 	__u8   adv_data_len;
876 	__u8   adv_data[];
877 } __packed;
878 #define MGMT_MESH_SEND_SIZE		19
879 
880 #define MGMT_OP_MESH_SEND_CANCEL	0x005A
881 struct mgmt_cp_mesh_send_cancel {
882 	__u8  handle;
883 } __packed;
884 #define MGMT_MESH_SEND_CANCEL_SIZE	1
885 
886 #define MGMT_OP_HCI_CMD_SYNC		0x005B
887 struct mgmt_cp_hci_cmd_sync {
888 	__le16 opcode;
889 	__u8   event;
890 	__u8   timeout;
891 	__le16 params_len;
892 	__u8   params[];
893 } __packed;
894 #define MGMT_HCI_CMD_SYNC_SIZE		6
895 
896 #define MGMT_EV_CMD_COMPLETE		0x0001
897 struct mgmt_ev_cmd_complete {
898 	__le16	opcode;
899 	__u8	status;
900 	__u8	data[];
901 } __packed;
902 
903 #define MGMT_EV_CMD_STATUS		0x0002
904 struct mgmt_ev_cmd_status {
905 	__le16	opcode;
906 	__u8	status;
907 } __packed;
908 
909 #define MGMT_EV_CONTROLLER_ERROR	0x0003
910 struct mgmt_ev_controller_error {
911 	__u8	error_code;
912 } __packed;
913 
914 #define MGMT_EV_INDEX_ADDED		0x0004
915 
916 #define MGMT_EV_INDEX_REMOVED		0x0005
917 
918 #define MGMT_EV_NEW_SETTINGS		0x0006
919 
920 #define MGMT_EV_CLASS_OF_DEV_CHANGED	0x0007
921 struct mgmt_ev_class_of_dev_changed {
922 	__u8	dev_class[3];
923 };
924 
925 #define MGMT_EV_LOCAL_NAME_CHANGED	0x0008
926 struct mgmt_ev_local_name_changed {
927 	__u8	name[MGMT_MAX_NAME_LENGTH];
928 	__u8	short_name[MGMT_MAX_SHORT_NAME_LENGTH];
929 } __packed;
930 
931 #define MGMT_EV_NEW_LINK_KEY		0x0009
932 struct mgmt_ev_new_link_key {
933 	__u8	store_hint;
934 	struct mgmt_link_key_info key;
935 } __packed;
936 
937 #define MGMT_EV_NEW_LONG_TERM_KEY	0x000A
938 struct mgmt_ev_new_long_term_key {
939 	__u8	store_hint;
940 	struct mgmt_ltk_info key;
941 } __packed;
942 
943 #define MGMT_EV_DEVICE_CONNECTED	0x000B
944 struct mgmt_ev_device_connected {
945 	struct mgmt_addr_info addr;
946 	__le32	flags;
947 	__le16	eir_len;
948 	__u8	eir[];
949 } __packed;
950 
951 #define MGMT_DEV_DISCONN_UNKNOWN	0x00
952 #define MGMT_DEV_DISCONN_TIMEOUT	0x01
953 #define MGMT_DEV_DISCONN_LOCAL_HOST	0x02
954 #define MGMT_DEV_DISCONN_REMOTE		0x03
955 #define MGMT_DEV_DISCONN_AUTH_FAILURE	0x04
956 #define MGMT_DEV_DISCONN_LOCAL_HOST_SUSPEND	0x05
957 
958 #define MGMT_EV_DEVICE_DISCONNECTED	0x000C
959 struct mgmt_ev_device_disconnected {
960 	struct mgmt_addr_info addr;
961 	__u8	reason;
962 } __packed;
963 
964 #define MGMT_EV_CONNECT_FAILED		0x000D
965 struct mgmt_ev_connect_failed {
966 	struct mgmt_addr_info addr;
967 	__u8	status;
968 } __packed;
969 
970 #define MGMT_EV_PIN_CODE_REQUEST	0x000E
971 struct mgmt_ev_pin_code_request {
972 	struct mgmt_addr_info addr;
973 	__u8	secure;
974 } __packed;
975 
976 #define MGMT_EV_USER_CONFIRM_REQUEST	0x000F
977 struct mgmt_ev_user_confirm_request {
978 	struct mgmt_addr_info addr;
979 	__u8	confirm_hint;
980 	__le32	value;
981 } __packed;
982 
983 #define MGMT_EV_USER_PASSKEY_REQUEST	0x0010
984 struct mgmt_ev_user_passkey_request {
985 	struct mgmt_addr_info addr;
986 } __packed;
987 
988 #define MGMT_EV_AUTH_FAILED		0x0011
989 struct mgmt_ev_auth_failed {
990 	struct mgmt_addr_info addr;
991 	__u8	status;
992 } __packed;
993 
994 #define MGMT_DEV_FOUND_CONFIRM_NAME		BIT(0)
995 #define MGMT_DEV_FOUND_LEGACY_PAIRING		BIT(1)
996 #define MGMT_DEV_FOUND_NOT_CONNECTABLE		BIT(2)
997 #define MGMT_DEV_FOUND_INITIATED_CONN		BIT(3)
998 #define MGMT_DEV_FOUND_NAME_REQUEST_FAILED	BIT(4)
999 #define MGMT_DEV_FOUND_SCAN_RSP			BIT(5)
1000 
1001 #define MGMT_EV_DEVICE_FOUND		0x0012
1002 struct mgmt_ev_device_found {
1003 	struct mgmt_addr_info addr;
1004 	__s8	rssi;
1005 	__le32	flags;
1006 	__le16	eir_len;
1007 	__u8	eir[];
1008 } __packed;
1009 
1010 #define MGMT_EV_DISCOVERING		0x0013
1011 struct mgmt_ev_discovering {
1012 	__u8	type;
1013 	__u8	discovering;
1014 } __packed;
1015 
1016 #define MGMT_EV_DEVICE_BLOCKED		0x0014
1017 struct mgmt_ev_device_blocked {
1018 	struct mgmt_addr_info addr;
1019 } __packed;
1020 
1021 #define MGMT_EV_DEVICE_UNBLOCKED	0x0015
1022 struct mgmt_ev_device_unblocked {
1023 	struct mgmt_addr_info addr;
1024 } __packed;
1025 
1026 #define MGMT_EV_DEVICE_UNPAIRED		0x0016
1027 struct mgmt_ev_device_unpaired {
1028 	struct mgmt_addr_info addr;
1029 } __packed;
1030 
1031 #define MGMT_EV_PASSKEY_NOTIFY		0x0017
1032 struct mgmt_ev_passkey_notify {
1033 	struct mgmt_addr_info addr;
1034 	__le32	passkey;
1035 	__u8	entered;
1036 } __packed;
1037 
1038 #define MGMT_EV_NEW_IRK			0x0018
1039 struct mgmt_ev_new_irk {
1040 	__u8     store_hint;
1041 	bdaddr_t rpa;
1042 	struct mgmt_irk_info irk;
1043 } __packed;
1044 
1045 #define MGMT_CSRK_LOCAL_UNAUTHENTICATED		0x00
1046 #define MGMT_CSRK_REMOTE_UNAUTHENTICATED	0x01
1047 #define MGMT_CSRK_LOCAL_AUTHENTICATED		0x02
1048 #define MGMT_CSRK_REMOTE_AUTHENTICATED		0x03
1049 
1050 struct mgmt_csrk_info {
1051 	struct mgmt_addr_info addr;
1052 	__u8 type;
1053 	__u8 val[16];
1054 } __packed;
1055 
1056 #define MGMT_EV_NEW_CSRK		0x0019
1057 struct mgmt_ev_new_csrk {
1058 	__u8 store_hint;
1059 	struct mgmt_csrk_info key;
1060 } __packed;
1061 
1062 #define MGMT_EV_DEVICE_ADDED		0x001a
1063 struct mgmt_ev_device_added {
1064 	struct mgmt_addr_info addr;
1065 	__u8 action;
1066 } __packed;
1067 
1068 #define MGMT_EV_DEVICE_REMOVED		0x001b
1069 struct mgmt_ev_device_removed {
1070 	struct mgmt_addr_info addr;
1071 } __packed;
1072 
1073 #define MGMT_EV_NEW_CONN_PARAM		0x001c
1074 struct mgmt_ev_new_conn_param {
1075 	struct mgmt_addr_info addr;
1076 	__u8 store_hint;
1077 	__le16 min_interval;
1078 	__le16 max_interval;
1079 	__le16 latency;
1080 	__le16 timeout;
1081 } __packed;
1082 
1083 #define MGMT_EV_UNCONF_INDEX_ADDED	0x001d
1084 
1085 #define MGMT_EV_UNCONF_INDEX_REMOVED	0x001e
1086 
1087 #define MGMT_EV_NEW_CONFIG_OPTIONS	0x001f
1088 
1089 struct mgmt_ev_ext_index {
1090 	__u8 type;
1091 	__u8 bus;
1092 } __packed;
1093 
1094 #define MGMT_EV_EXT_INDEX_ADDED		0x0020
1095 
1096 #define MGMT_EV_EXT_INDEX_REMOVED	0x0021
1097 
1098 #define MGMT_EV_LOCAL_OOB_DATA_UPDATED	0x0022
1099 struct mgmt_ev_local_oob_data_updated {
1100 	__u8    type;
1101 	__le16	eir_len;
1102 	__u8	eir[];
1103 } __packed;
1104 
1105 #define MGMT_EV_ADVERTISING_ADDED	0x0023
1106 struct mgmt_ev_advertising_added {
1107 	__u8    instance;
1108 } __packed;
1109 
1110 #define MGMT_EV_ADVERTISING_REMOVED	0x0024
1111 struct mgmt_ev_advertising_removed {
1112 	__u8    instance;
1113 } __packed;
1114 
1115 #define MGMT_EV_EXT_INFO_CHANGED	0x0025
1116 struct mgmt_ev_ext_info_changed {
1117 	__le16	eir_len;
1118 	__u8	eir[];
1119 } __packed;
1120 
1121 #define MGMT_EV_PHY_CONFIGURATION_CHANGED	0x0026
1122 struct mgmt_ev_phy_configuration_changed {
1123 	__le32	selected_phys;
1124 } __packed;
1125 
1126 #define MGMT_EV_EXP_FEATURE_CHANGED	0x0027
1127 struct mgmt_ev_exp_feature_changed {
1128 	__u8	uuid[16];
1129 	__le32	flags;
1130 } __packed;
1131 
1132 #define MGMT_EV_DEVICE_FLAGS_CHANGED		0x002a
1133 struct mgmt_ev_device_flags_changed {
1134 	struct mgmt_addr_info addr;
1135 	__le32 supported_flags;
1136 	__le32 current_flags;
1137 } __packed;
1138 
1139 #define MGMT_EV_ADV_MONITOR_ADDED	0x002b
1140 struct mgmt_ev_adv_monitor_added {
1141 	__le16 monitor_handle;
1142 }  __packed;
1143 
1144 #define MGMT_EV_ADV_MONITOR_REMOVED	0x002c
1145 struct mgmt_ev_adv_monitor_removed {
1146 	__le16 monitor_handle;
1147 }  __packed;
1148 
1149 #define MGMT_EV_CONTROLLER_SUSPEND		0x002d
1150 struct mgmt_ev_controller_suspend {
1151 	__u8	suspend_state;
1152 } __packed;
1153 
1154 #define MGMT_EV_CONTROLLER_RESUME		0x002e
1155 struct mgmt_ev_controller_resume {
1156 	__u8	wake_reason;
1157 	struct mgmt_addr_info addr;
1158 } __packed;
1159 
1160 #define MGMT_WAKE_REASON_NON_BT_WAKE		0x0
1161 #define MGMT_WAKE_REASON_UNEXPECTED		0x1
1162 #define MGMT_WAKE_REASON_REMOTE_WAKE		0x2
1163 
1164 #define MGMT_EV_ADV_MONITOR_DEVICE_FOUND	0x002f
1165 struct mgmt_ev_adv_monitor_device_found {
1166 	__le16 monitor_handle;
1167 	struct mgmt_addr_info addr;
1168 	__s8   rssi;
1169 	__le32 flags;
1170 	__le16 eir_len;
1171 	__u8   eir[];
1172 } __packed;
1173 
1174 #define MGMT_EV_ADV_MONITOR_DEVICE_LOST		0x0030
1175 struct mgmt_ev_adv_monitor_device_lost {
1176 	__le16 monitor_handle;
1177 	struct mgmt_addr_info addr;
1178 } __packed;
1179 
1180 #define MGMT_EV_MESH_DEVICE_FOUND	0x0031
1181 struct mgmt_ev_mesh_device_found {
1182 	struct mgmt_addr_info addr;
1183 	__s8	rssi;
1184 	__le64	instant;
1185 	__le32	flags;
1186 	__le16	eir_len;
1187 	__u8	eir[];
1188 } __packed;
1189 
1190 
1191 #define MGMT_EV_MESH_PACKET_CMPLT		0x0032
1192 struct mgmt_ev_mesh_pkt_cmplt {
1193 	__u8	handle;
1194 } __packed;
1195