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