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