hcimsgs.h revision f857d64505d81ce0834de150b79b333a4ff445f2
1/****************************************************************************** 2 * 3 * Copyright (C) 1999-2012 Broadcom Corporation 4 * 5 * Licensed under the Apache License, Version 2.0 (the "License"); 6 * you may not use this file except in compliance with the License. 7 * You may obtain a copy of the License at: 8 * 9 * http://www.apache.org/licenses/LICENSE-2.0 10 * 11 * Unless required by applicable law or agreed to in writing, software 12 * distributed under the License is distributed on an "AS IS" BASIS, 13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 * See the License for the specific language governing permissions and 15 * limitations under the License. 16 * 17 ******************************************************************************/ 18 19#ifndef HCIMSGS_H 20#define HCIMSGS_H 21 22#include "bt_target.h" 23#include "hcidefs.h" 24#include "bt_types.h" 25 26 27#ifdef __cplusplus 28extern "C" { 29#endif 30 31void bte_main_hci_send(BT_HDR *p_msg, UINT16 event); 32void bte_main_lpm_allow_bt_device_sleep(void); 33 34/* Message by message.... */ 35 36#define HCIC_GET_UINT8(p, off) (UINT8)(*((UINT8 *)((p) + 1) + p->offset + 3 + (off))) 37 38#define HCIC_GET_UINT16(p, off) (UINT16)((*((UINT8 *)((p) + 1) + p->offset + 3 + (off)) + \ 39 (*((UINT8 *)((p) + 1) + p->offset + 3 + (off) + 1) << 8))) 40 41#define HCIC_GET_UINT32(p, off) (UINT32)((*((UINT8 *)((p) + 1) + p->offset + 3 + (off)) + \ 42 (*((UINT8 *)((p) + 1) + p->offset + 3 + (off) + 1) << 8) + \ 43 (*((UINT8 *)((p) + 1) + p->offset + 3 + (off) + 2) << 16) + \ 44 (*((UINT8 *)((p) + 1) + p->offset + 3 + (off) + 3) << 24))) 45 46#define HCIC_GET_ARRAY(p, off, x, len) \ 47{ \ 48 UINT8 *qq = ((UINT8 *)((p) + 1) + p->offset + 3 + (off)); UINT8 *rr = (UINT8 *)x; \ 49 int ii; for (ii = 0; ii < len; ii++) *rr++ = *qq++; \ 50} 51 52#define HCIC_GET_ARRAY16(p, off, x) \ 53{ \ 54 UINT8 *qq = ((UINT8 *)((p) + 1) + p->offset + 3 + (off)); UINT8 *rr = (UINT8 *)x + 15; \ 55 int ii; for (ii = 0; ii < 16; ii++) *rr-- = *qq++; \ 56} 57 58#define HCIC_GET_BDADDR(p, off, x) \ 59{ \ 60 UINT8 *qq = ((UINT8 *)((p) + 1) + p->offset + 3 + (off)); UINT8 *rr = (UINT8 *)x + BD_ADDR_LEN - 1; \ 61 int ii; for (ii = 0; ii < BD_ADDR_LEN; ii++) *rr-- = *qq++; \ 62} 63 64#define HCIC_GET_DEVCLASS(p, off, x) \ 65{ \ 66 UINT8 *qq = ((UINT8 *)((p) + 1) + p->offset + 3 + (off)); UINT8 *rr = (UINT8 *)x + DEV_CLASS_LEN - 1; \ 67 int ii; for (ii = 0; ii < DEV_CLASS_LEN; ii++) *rr-- = *qq++; \ 68} 69 70#define HCIC_GET_LAP(p, off, x) \ 71{ \ 72 UINT8 *qq = ((UINT8 *)((p) + 1) + p->offset + 3 + (off)); UINT8 *rr = (UINT8 *)x + LAP_LEN - 1; \ 73 int ii; for (ii = 0; ii < LAP_LEN; ii++) *rr-- = *qq++; \ 74} 75 76#define HCIC_GET_POINTER(p, off) ((UINT8 *)((p) + 1) + p->offset + 3 + (off)) 77 78 79HCI_API extern BOOLEAN btsnd_hcic_inquiry(const LAP inq_lap, UINT8 duration, 80 UINT8 response_cnt); 81 82#define HCIC_PARAM_SIZE_INQUIRY 5 83 84 85#define HCIC_INQ_INQ_LAP_OFF 0 86#define HCIC_INQ_DUR_OFF 3 87#define HCIC_INQ_RSP_CNT_OFF 4 88 /* Inquiry */ 89 90 /* Inquiry Cancel */ 91HCI_API extern BOOLEAN btsnd_hcic_inq_cancel(void); 92 93#define HCIC_PARAM_SIZE_INQ_CANCEL 0 94 95 /* Periodic Inquiry Mode */ 96HCI_API extern BOOLEAN btsnd_hcic_per_inq_mode(UINT16 max_period, UINT16 min_period, 97 const LAP inq_lap, UINT8 duration, 98 UINT8 response_cnt); 99 100#define HCIC_PARAM_SIZE_PER_INQ_MODE 9 101 102#define HCI_PER_INQ_MAX_INTRVL_OFF 0 103#define HCI_PER_INQ_MIN_INTRVL_OFF 2 104#define HCI_PER_INQ_INQ_LAP_OFF 4 105#define HCI_PER_INQ_DURATION_OFF 7 106#define HCI_PER_INQ_RSP_CNT_OFF 8 107 /* Periodic Inquiry Mode */ 108 109 /* Exit Periodic Inquiry Mode */ 110HCI_API extern BOOLEAN btsnd_hcic_exit_per_inq(void); 111 112#define HCIC_PARAM_SIZE_EXIT_PER_INQ 0 113 /* Create Connection */ 114HCI_API extern BOOLEAN btsnd_hcic_create_conn(BD_ADDR dest, UINT16 packet_types, 115 UINT8 page_scan_rep_mode, 116 UINT8 page_scan_mode, 117 UINT16 clock_offset, 118 UINT8 allow_switch); 119 120#define HCIC_PARAM_SIZE_CREATE_CONN 13 121 122#define HCIC_CR_CONN_BD_ADDR_OFF 0 123#define HCIC_CR_CONN_PKT_TYPES_OFF 6 124#define HCIC_CR_CONN_REP_MODE_OFF 8 125#define HCIC_CR_CONN_PAGE_SCAN_MODE_OFF 9 126#define HCIC_CR_CONN_CLK_OFF_OFF 10 127#define HCIC_CR_CONN_ALLOW_SWITCH_OFF 12 128 /* Create Connection */ 129 130 /* Disconnect */ 131HCI_API extern BOOLEAN btsnd_hcic_disconnect(UINT16 handle, UINT8 reason); 132 133#define HCIC_PARAM_SIZE_DISCONNECT 3 134 135#define HCI_DISC_HANDLE_OFF 0 136#define HCI_DISC_REASON_OFF 2 137 /* Disconnect */ 138 139#if BTM_SCO_INCLUDED == TRUE 140 /* Add SCO Connection */ 141HCI_API extern BOOLEAN btsnd_hcic_add_SCO_conn (UINT16 handle, UINT16 packet_types); 142#endif /* BTM_SCO_INCLUDED */ 143 144#define HCIC_PARAM_SIZE_ADD_SCO_CONN 4 145 146#define HCI_ADD_SCO_HANDLE_OFF 0 147#define HCI_ADD_SCO_PACKET_TYPES_OFF 2 148 /* Add SCO Connection */ 149 150 /* Create Connection Cancel */ 151HCI_API extern BOOLEAN btsnd_hcic_create_conn_cancel(BD_ADDR dest); 152 153#define HCIC_PARAM_SIZE_CREATE_CONN_CANCEL 6 154 155#define HCIC_CR_CONN_CANCEL_BD_ADDR_OFF 0 156 /* Create Connection Cancel */ 157 158 /* Accept Connection Request */ 159HCI_API extern BOOLEAN btsnd_hcic_accept_conn (BD_ADDR bd_addr, UINT8 role); 160 161#define HCIC_PARAM_SIZE_ACCEPT_CONN 7 162 163#define HCI_ACC_CONN_BD_ADDR_OFF 0 164#define HCI_ACC_CONN_ROLE_OFF 6 165 /* Accept Connection Request */ 166 167 /* Reject Connection Request */ 168HCI_API extern BOOLEAN btsnd_hcic_reject_conn (BD_ADDR bd_addr, UINT8 reason); 169 170#define HCIC_PARAM_SIZE_REJECT_CONN 7 171 172#define HCI_REJ_CONN_BD_ADDR_OFF 0 173#define HCI_REJ_CONN_REASON_OFF 6 174 /* Reject Connection Request */ 175 176 /* Link Key Request Reply */ 177HCI_API extern BOOLEAN btsnd_hcic_link_key_req_reply (BD_ADDR bd_addr, 178 LINK_KEY link_key); 179 180#define HCIC_PARAM_SIZE_LINK_KEY_REQ_REPLY 22 181 182#define HCI_LINK_KEY_REPLY_BD_ADDR_OFF 0 183#define HCI_LINK_KEY_REPLY_LINK_KEY_OFF 6 184 /* Link Key Request Reply */ 185 186 /* Link Key Request Neg Reply */ 187HCI_API extern BOOLEAN btsnd_hcic_link_key_neg_reply (BD_ADDR bd_addr); 188 189#define HCIC_PARAM_SIZE_LINK_KEY_NEG_REPLY 6 190 191#define HCI_LINK_KEY_NEG_REP_BD_ADR_OFF 0 192 /* Link Key Request Neg Reply */ 193 194 /* PIN Code Request Reply */ 195HCI_API extern BOOLEAN btsnd_hcic_pin_code_req_reply (BD_ADDR bd_addr, 196 UINT8 pin_code_len, 197 PIN_CODE pin_code); 198 199#define HCIC_PARAM_SIZE_PIN_CODE_REQ_REPLY 23 200 201#define HCI_PIN_CODE_REPLY_BD_ADDR_OFF 0 202#define HCI_PIN_CODE_REPLY_PIN_LEN_OFF 6 203#define HCI_PIN_CODE_REPLY_PIN_CODE_OFF 7 204 /* PIN Code Request Reply */ 205 206 /* Link Key Request Neg Reply */ 207HCI_API extern BOOLEAN btsnd_hcic_pin_code_neg_reply (BD_ADDR bd_addr); 208 209#define HCIC_PARAM_SIZE_PIN_CODE_NEG_REPLY 6 210 211#define HCI_PIN_CODE_NEG_REP_BD_ADR_OFF 0 212 /* Link Key Request Neg Reply */ 213 214 /* Change Connection Type */ 215HCI_API extern BOOLEAN btsnd_hcic_change_conn_type (UINT16 handle, UINT16 packet_types); 216 217#define HCIC_PARAM_SIZE_CHANGE_CONN_TYPE 4 218 219#define HCI_CHNG_PKT_TYPE_HANDLE_OFF 0 220#define HCI_CHNG_PKT_TYPE_PKT_TYPE_OFF 2 221 /* Change Connection Type */ 222 223#define HCIC_PARAM_SIZE_CMD_HANDLE 2 224 225#define HCI_CMD_HANDLE_HANDLE_OFF 0 226 227HCI_API extern BOOLEAN btsnd_hcic_auth_request (UINT16 handle); /* Authentication Request */ 228 229 /* Set Connection Encryption */ 230HCI_API extern BOOLEAN btsnd_hcic_set_conn_encrypt (UINT16 handle, BOOLEAN enable); 231#define HCIC_PARAM_SIZE_SET_CONN_ENCRYPT 3 232 233 234#define HCI_SET_ENCRYPT_HANDLE_OFF 0 235#define HCI_SET_ENCRYPT_ENABLE_OFF 2 236 /* Set Connection Encryption */ 237 238HCI_API extern BOOLEAN btsnd_hcic_change_link_key (UINT16 handle); /* Change Connection Link Key */ 239 240 /* Master Link Key */ 241HCI_API extern BOOLEAN btsnd_hcic_master_link_key (BOOLEAN key_flag); 242 243#define HCIC_PARAM_SIZE_MASTER_LINK_KEY 1 244 245#define HCI_MASTER_KEY_FLAG_OFF 0 246 /* Master Link Key */ 247 248 /* Remote Name Request */ 249HCI_API extern BOOLEAN btsnd_hcic_rmt_name_req (BD_ADDR bd_addr, 250 UINT8 page_scan_rep_mode, 251 UINT8 page_scan_mode, 252 UINT16 clock_offset); 253 254#define HCIC_PARAM_SIZE_RMT_NAME_REQ 10 255 256#define HCI_RMT_NAME_BD_ADDR_OFF 0 257#define HCI_RMT_NAME_REP_MODE_OFF 6 258#define HCI_RMT_NAME_PAGE_SCAN_MODE_OFF 7 259#define HCI_RMT_NAME_CLK_OFF_OFF 8 260 /* Remote Name Request */ 261 262 /* Remote Name Request Cancel */ 263HCI_API extern BOOLEAN btsnd_hcic_rmt_name_req_cancel(BD_ADDR bd_addr); 264 265#define HCIC_PARAM_SIZE_RMT_NAME_REQ_CANCEL 6 266 267#define HCI_RMT_NAME_CANCEL_BD_ADDR_OFF 0 268 /* Remote Name Request Cancel */ 269 270HCI_API extern BOOLEAN btsnd_hcic_rmt_features_req(UINT16 handle); /* Remote Features Request */ 271 272 /* Remote Extended Features */ 273HCI_API extern BOOLEAN btsnd_hcic_rmt_ext_features(UINT16 handle, UINT8 page_num); 274 275#define HCIC_PARAM_SIZE_RMT_EXT_FEATURES 3 276 277#define HCI_RMT_EXT_FEATURES_HANDLE_OFF 0 278#define HCI_RMT_EXT_FEATURES_PAGE_NUM_OFF 2 279 /* Remote Extended Features */ 280 281 282 /* Local Extended Features */ 283HCI_API extern BOOLEAN btsnd_hcic_read_local_ext_features (UINT8 page_num); 284 285#define HCIC_PARAM_SIZE_LOCAL_EXT_FEATURES 1 286 287#define HCI_LOCAL_EXT_FEATURES_PAGE_NUM_OFF 0 288 /* Local Extended Features */ 289 290 291HCI_API extern BOOLEAN btsnd_hcic_rmt_ver_req(UINT16 handle); /* Remote Version Info Request */ 292HCI_API extern BOOLEAN btsnd_hcic_read_rmt_clk_offset(UINT16 handle); /* Remote Clock Offset */ 293HCI_API extern BOOLEAN btsnd_hcic_read_lmp_handle(UINT16 handle); /* Remote LMP Handle */ 294 295HCI_API extern BOOLEAN btsnd_hcic_setup_esco_conn (UINT16 handle, 296 UINT32 tx_bw, UINT32 rx_bw, 297 UINT16 max_latency, UINT16 voice, 298 UINT8 retrans_effort, 299 UINT16 packet_types); 300#define HCIC_PARAM_SIZE_SETUP_ESCO 17 301 302#define HCI_SETUP_ESCO_HANDLE_OFF 0 303#define HCI_SETUP_ESCO_TX_BW_OFF 2 304#define HCI_SETUP_ESCO_RX_BW_OFF 6 305#define HCI_SETUP_ESCO_MAX_LAT_OFF 10 306#define HCI_SETUP_ESCO_VOICE_OFF 12 307#define HCI_SETUP_ESCO_RETRAN_EFF_OFF 14 308#define HCI_SETUP_ESCO_PKT_TYPES_OFF 15 309 310 311HCI_API extern BOOLEAN btsnd_hcic_accept_esco_conn (BD_ADDR bd_addr, 312 UINT32 tx_bw, UINT32 rx_bw, 313 UINT16 max_latency, 314 UINT16 content_fmt, 315 UINT8 retrans_effort, 316 UINT16 packet_types); 317#define HCIC_PARAM_SIZE_ACCEPT_ESCO 21 318 319#define HCI_ACCEPT_ESCO_BDADDR_OFF 0 320#define HCI_ACCEPT_ESCO_TX_BW_OFF 6 321#define HCI_ACCEPT_ESCO_RX_BW_OFF 10 322#define HCI_ACCEPT_ESCO_MAX_LAT_OFF 14 323#define HCI_ACCEPT_ESCO_VOICE_OFF 16 324#define HCI_ACCEPT_ESCO_RETRAN_EFF_OFF 18 325#define HCI_ACCEPT_ESCO_PKT_TYPES_OFF 19 326 327 328HCI_API extern BOOLEAN btsnd_hcic_reject_esco_conn (BD_ADDR bd_addr, UINT8 reason); 329#define HCIC_PARAM_SIZE_REJECT_ESCO 7 330 331#define HCI_REJECT_ESCO_BDADDR_OFF 0 332#define HCI_REJECT_ESCO_REASON_OFF 6 333 334/* Hold Mode */ 335HCI_API extern BOOLEAN btsnd_hcic_hold_mode(UINT16 handle, UINT16 max_hold_period, 336 UINT16 min_hold_period); 337 338#define HCIC_PARAM_SIZE_HOLD_MODE 6 339 340#define HCI_HOLD_MODE_HANDLE_OFF 0 341#define HCI_HOLD_MODE_MAX_PER_OFF 2 342#define HCI_HOLD_MODE_MIN_PER_OFF 4 343 /* Hold Mode */ 344 345 /* Sniff Mode */ 346HCI_API extern BOOLEAN btsnd_hcic_sniff_mode(UINT16 handle, 347 UINT16 max_sniff_period, 348 UINT16 min_sniff_period, 349 UINT16 sniff_attempt, 350 UINT16 sniff_timeout); 351 352#define HCIC_PARAM_SIZE_SNIFF_MODE 10 353 354 355#define HCI_SNIFF_MODE_HANDLE_OFF 0 356#define HCI_SNIFF_MODE_MAX_PER_OFF 2 357#define HCI_SNIFF_MODE_MIN_PER_OFF 4 358#define HCI_SNIFF_MODE_ATTEMPT_OFF 6 359#define HCI_SNIFF_MODE_TIMEOUT_OFF 8 360 /* Sniff Mode */ 361 362HCI_API extern BOOLEAN btsnd_hcic_exit_sniff_mode(UINT16 handle); /* Exit Sniff Mode */ 363 364 /* Park Mode */ 365HCI_API extern BOOLEAN btsnd_hcic_park_mode (UINT16 handle, 366 UINT16 beacon_max_interval, 367 UINT16 beacon_min_interval); 368 369#define HCIC_PARAM_SIZE_PARK_MODE 6 370 371#define HCI_PARK_MODE_HANDLE_OFF 0 372#define HCI_PARK_MODE_MAX_PER_OFF 2 373#define HCI_PARK_MODE_MIN_PER_OFF 4 374 /* Park Mode */ 375 376HCI_API extern BOOLEAN btsnd_hcic_exit_park_mode(UINT16 handle); /* Exit Park Mode */ 377 378 /* QoS Setup */ 379HCI_API extern BOOLEAN btsnd_hcic_qos_setup (UINT16 handle, UINT8 flags, 380 UINT8 service_type, 381 UINT32 token_rate, UINT32 peak, 382 UINT32 latency, UINT32 delay_var); 383 384#define HCIC_PARAM_SIZE_QOS_SETUP 20 385 386#define HCI_QOS_HANDLE_OFF 0 387#define HCI_QOS_FLAGS_OFF 2 388#define HCI_QOS_SERVICE_TYPE_OFF 3 389#define HCI_QOS_TOKEN_RATE_OFF 4 390#define HCI_QOS_PEAK_BANDWIDTH_OFF 8 391#define HCI_QOS_LATENCY_OFF 12 392#define HCI_QOS_DELAY_VAR_OFF 16 393 /* QoS Setup */ 394 395HCI_API extern BOOLEAN btsnd_hcic_role_discovery (UINT16 handle); /* Role Discovery */ 396 397 /* Switch Role Request */ 398HCI_API extern BOOLEAN btsnd_hcic_switch_role (BD_ADDR bd_addr, UINT8 role); 399 400#define HCIC_PARAM_SIZE_SWITCH_ROLE 7 401 402#define HCI_SWITCH_BD_ADDR_OFF 0 403#define HCI_SWITCH_ROLE_OFF 6 404 /* Switch Role Request */ 405 406HCI_API extern BOOLEAN btsnd_hcic_read_policy_set(UINT16 handle); /* Read Policy Settings */ 407 408 /* Write Policy Settings */ 409HCI_API extern BOOLEAN btsnd_hcic_write_policy_set(UINT16 handle, UINT16 settings); 410 411#define HCIC_PARAM_SIZE_WRITE_POLICY_SET 4 412 413#define HCI_WRITE_POLICY_HANDLE_OFF 0 414#define HCI_WRITE_POLICY_SETTINGS_OFF 2 415 /* Write Policy Settings */ 416 417 /* Read Default Policy Settings */ 418HCI_API extern BOOLEAN btsnd_hcic_read_def_policy_set(void); 419 420#define HCIC_PARAM_SIZE_READ_DEF_POLICY_SET 0 421 /* Read Default Policy Settings */ 422 423 /* Write Default Policy Settings */ 424HCI_API extern BOOLEAN btsnd_hcic_write_def_policy_set(UINT16 settings); 425 426#define HCIC_PARAM_SIZE_WRITE_DEF_POLICY_SET 2 427 428#define HCI_WRITE_DEF_POLICY_SETTINGS_OFF 0 429 /* Write Default Policy Settings */ 430 431 /* Flow Specification */ 432HCI_API extern BOOLEAN btsnd_hcic_flow_specification(UINT16 handle, UINT8 flags, 433 UINT8 flow_direct, 434 UINT8 service_type, 435 UINT32 token_rate, 436 UINT32 token_bucket_size, 437 UINT32 peak, UINT32 latency); 438 439#define HCIC_PARAM_SIZE_FLOW_SPEC 21 440 441#define HCI_FLOW_SPEC_HANDLE_OFF 0 442#define HCI_FLOW_SPEC_FLAGS_OFF 2 443#define HCI_FLOW_SPEC_FLOW_DIRECT_OFF 3 444#define HCI_FLOW_SPEC_SERVICE_TYPE_OFF 4 445#define HCI_FLOW_SPEC_TOKEN_RATE_OFF 5 446#define HCI_FLOW_SPEC_TOKEN_BUCKET_SIZE_OFF 9 447#define HCI_FLOW_SPEC_PEAK_BANDWIDTH_OFF 13 448#define HCI_FLOW_SPEC_LATENCY_OFF 17 449 /* Flow Specification */ 450 451/****************************************** 452** Lisbon Features 453*******************************************/ 454#if BTM_SSR_INCLUDED == TRUE 455 /* Sniff Subrating */ 456HCI_API extern BOOLEAN btsnd_hcic_sniff_sub_rate(UINT16 handle, UINT16 max_lat, 457 UINT16 min_remote_lat, 458 UINT16 min_local_lat); 459 460#define HCIC_PARAM_SIZE_SNIFF_SUB_RATE 8 461 462#define HCI_SNIFF_SUB_RATE_HANDLE_OFF 0 463#define HCI_SNIFF_SUB_RATE_MAX_LAT_OFF 2 464#define HCI_SNIFF_SUB_RATE_MIN_REM_LAT_OFF 4 465#define HCI_SNIFF_SUB_RATE_MIN_LOC_LAT_OFF 6 466 /* Sniff Subrating */ 467 468#else /* BTM_SSR_INCLUDED == FALSE */ 469 470#define btsnd_hcic_sniff_sub_rate(handle, max_lat, min_remote_lat, min_local_lat) FALSE 471 472#endif /* BTM_SSR_INCLUDED */ 473 474 /* Extended Inquiry Response */ 475#if (BTM_EIR_SERVER_INCLUDED == TRUE) 476HCI_API extern void btsnd_hcic_write_ext_inquiry_response(void *buffer, UINT8 fec_req); 477 478#define HCIC_PARAM_SIZE_EXT_INQ_RESP 241 479 480#define HCIC_EXT_INQ_RESP_FEC_OFF 0 481#define HCIC_EXT_INQ_RESP_RESPONSE 1 482 483HCI_API extern BOOLEAN btsnd_hcic_read_ext_inquiry_response(void); /* Read Extended Inquiry Response */ 484#else 485#define btsnd_hcic_write_ext_inquiry_response(buffer, fec_req) 486#define btsnd_hcic_read_ext_inquiry_response() FALSE 487#endif 488 /* Write Simple Pairing Mode */ 489/**** Simple Pairing Commands ****/ 490HCI_API extern BOOLEAN btsnd_hcic_write_simple_pairing_mode(UINT8 mode); 491 492#define HCIC_PARAM_SIZE_W_SIMP_PAIR 1 493 494#define HCIC_WRITE_SP_MODE_OFF 0 495 496 497HCI_API extern BOOLEAN btsnd_hcic_read_simple_pairing_mode (void); 498 499#define HCIC_PARAM_SIZE_R_SIMP_PAIR 0 500 501 /* Write Simple Pairing Debug Mode */ 502HCI_API extern BOOLEAN btsnd_hcic_write_simp_pair_debug_mode(UINT8 debug_mode); 503 504#define HCIC_PARAM_SIZE_SIMP_PAIR_DBUG 1 505 506#define HCIC_WRITE_SP_DBUG_MODE_OFF 0 507 508 /* IO Capabilities Response */ 509HCI_API extern BOOLEAN btsnd_hcic_io_cap_req_reply (BD_ADDR bd_addr, UINT8 capability, 510 UINT8 oob_present, UINT8 auth_req); 511 512#define HCIC_PARAM_SIZE_IO_CAP_RESP 9 513 514#define HCI_IO_CAP_BD_ADDR_OFF 0 515#define HCI_IO_CAPABILITY_OFF 6 516#define HCI_IO_CAP_OOB_DATA_OFF 7 517#define HCI_IO_CAP_AUTH_REQ_OFF 8 518 519 /* IO Capabilities Req Neg Reply */ 520HCI_API extern BOOLEAN btsnd_hcic_io_cap_req_neg_reply (BD_ADDR bd_addr, UINT8 err_code); 521 522#define HCIC_PARAM_SIZE_IO_CAP_NEG_REPLY 7 523 524#define HCI_IO_CAP_NR_BD_ADDR_OFF 0 525#define HCI_IO_CAP_NR_ERR_CODE 6 526 527 /* Read Local OOB Data */ 528HCI_API extern BOOLEAN btsnd_hcic_read_local_oob_data (void); 529 530#define HCIC_PARAM_SIZE_R_LOCAL_OOB 0 531 532 533HCI_API extern BOOLEAN btsnd_hcic_user_conf_reply (BD_ADDR bd_addr, BOOLEAN is_yes); 534 535#define HCIC_PARAM_SIZE_UCONF_REPLY 6 536 537#define HCI_USER_CONF_BD_ADDR_OFF 0 538 539 540HCI_API extern BOOLEAN btsnd_hcic_user_passkey_reply (BD_ADDR bd_addr, UINT32 value); 541 542#define HCIC_PARAM_SIZE_U_PKEY_REPLY 10 543 544#define HCI_USER_PASSKEY_BD_ADDR_OFF 0 545#define HCI_USER_PASSKEY_VALUE_OFF 6 546 547 548HCI_API extern BOOLEAN btsnd_hcic_user_passkey_neg_reply (BD_ADDR bd_addr); 549 550#define HCIC_PARAM_SIZE_U_PKEY_NEG_REPLY 6 551 552#define HCI_USER_PASSKEY_NEG_BD_ADDR_OFF 0 553 554 /* Remote OOB Data Request Reply */ 555HCI_API extern BOOLEAN btsnd_hcic_rem_oob_reply (BD_ADDR bd_addr, UINT8 *p_c, 556 UINT8 *p_r); 557 558#define HCIC_PARAM_SIZE_REM_OOB_REPLY 38 559 560#define HCI_REM_OOB_DATA_BD_ADDR_OFF 0 561#define HCI_REM_OOB_DATA_C_OFF 6 562#define HCI_REM_OOB_DATA_R_OFF 22 563 564 /* Remote OOB Data Request Negative Reply */ 565HCI_API extern BOOLEAN btsnd_hcic_rem_oob_neg_reply (BD_ADDR bd_addr); 566 567#define HCIC_PARAM_SIZE_REM_OOB_NEG_REPLY 6 568 569#define HCI_REM_OOB_DATA_NEG_BD_ADDR_OFF 0 570 571 /* Read Tx Power Level */ 572HCI_API extern BOOLEAN btsnd_hcic_read_inq_tx_power (void); 573 574#define HCIC_PARAM_SIZE_R_TX_POWER 0 575 576 /* Write Tx Power Level */ 577HCI_API extern BOOLEAN btsnd_hcic_write_inq_tx_power (INT8 level); 578 579#define HCIC_PARAM_SIZE_W_TX_POWER 1 580 581#define HCIC_WRITE_TX_POWER_LEVEL_OFF 0 582 /* Read Default Erroneous Data Reporting */ 583HCI_API extern BOOLEAN btsnd_hcic_read_default_erroneous_data_rpt (void); 584 585#define HCIC_PARAM_SIZE_R_ERR_DATA_RPT 0 586 587 /* Write Default Erroneous Data Reporting */ 588HCI_API extern BOOLEAN btsnd_hcic_write_default_erroneous_data_rpt (UINT8 level); 589 590#define HCIC_PARAM_SIZE_W_ERR_DATA_RPT 1 591 592#define HCIC_WRITE_ERR_DATA_RPT_OFF 0 593 594 595#if L2CAP_NON_FLUSHABLE_PB_INCLUDED == TRUE 596HCI_API extern BOOLEAN btsnd_hcic_enhanced_flush (UINT16 handle, UINT8 packet_type); 597 598#define HCIC_PARAM_SIZE_ENHANCED_FLUSH 3 599#endif 600 601 602HCI_API extern BOOLEAN btsnd_hcic_send_keypress_notif (BD_ADDR bd_addr, UINT8 notif); 603 604#define HCIC_PARAM_SIZE_SEND_KEYPRESS_NOTIF 7 605 606#define HCI_SEND_KEYPRESS_NOTIF_BD_ADDR_OFF 0 607#define HCI_SEND_KEYPRESS_NOTIF_NOTIF_OFF 6 608 609 610HCI_API extern BOOLEAN btsnd_hcic_refresh_encryption_key(UINT16 handle); /* Refresh Encryption Key */ 611 612/**** end of Simple Pairing Commands ****/ 613 614 615HCI_API extern BOOLEAN btsnd_hcic_set_event_mask(UINT8 local_controller_id, BT_EVENT_MASK evt_mask); 616 617#define HCIC_PARAM_SIZE_SET_EVENT_MASK 8 618#define HCI_EVENT_MASK_MASK_OFF 0 619 /* Set Event Mask */ 620 621 /* Reset */ 622HCI_API extern BOOLEAN btsnd_hcic_set_event_mask_page_2 (UINT8 local_controller_id, 623 BT_EVENT_MASK event_mask); 624 625#define HCIC_PARAM_SIZE_SET_EVENT_MASK_PAGE_2 8 626#define HCI_EVENT_MASK_MASK_OFF 0 627 /* Set Event Mask Page 2 */ 628 629 /* Reset */ 630HCI_API extern BOOLEAN btsnd_hcic_reset(UINT8 local_controller_id); 631 632#define HCIC_PARAM_SIZE_RESET 0 633 /* Reset */ 634 635 /* Store Current Settings */ 636#define MAX_FILT_COND (sizeof (BD_ADDR) + 1) 637 638HCI_API extern BOOLEAN btsnd_hcic_set_event_filter(UINT8 filt_type, 639 UINT8 filt_cond_type, 640 UINT8 *filt_cond, 641 UINT8 filt_cond_len); 642 643#define HCIC_PARAM_SIZE_SET_EVT_FILTER 9 644 645#define HCI_FILT_COND_FILT_TYPE_OFF 0 646#define HCI_FILT_COND_COND_TYPE_OFF 1 647#define HCI_FILT_COND_FILT_OFF 2 648 /* Set Event Filter */ 649 650HCI_API extern BOOLEAN btsnd_hcic_flush(UINT8 local_controller_id, UINT16 handle); /* Flush */ 651 652 /* Create New Unit Type */ 653HCI_API extern BOOLEAN btsnd_hcic_new_unit_key(void); 654 655#define HCIC_PARAM_SIZE_NEW_UNIT_KEY 0 656 /* Create New Unit Type */ 657 658 /* Read Stored Key */ 659HCI_API extern BOOLEAN btsnd_hcic_read_stored_key (BD_ADDR bd_addr, 660 BOOLEAN read_all_flag); 661 662#define HCIC_PARAM_SIZE_READ_STORED_KEY 7 663 664#define HCI_READ_KEY_BD_ADDR_OFF 0 665#define HCI_READ_KEY_ALL_FLAG_OFF 6 666 /* Read Stored Key */ 667 668#define MAX_WRITE_KEYS 10 669 /* Write Stored Key */ 670HCI_API extern BOOLEAN btsnd_hcic_write_stored_key (UINT8 num_keys, BD_ADDR *bd_addr, 671 LINK_KEY *link_key); 672 673#define HCIC_PARAM_SIZE_WRITE_STORED_KEY sizeof(btmsg_hcic_write_stored_key_t) 674 675#define HCI_WRITE_KEY_NUM_KEYS_OFF 0 676#define HCI_WRITE_KEY_BD_ADDR_OFF 1 677#define HCI_WRITE_KEY_KEY_OFF 7 678/* only 0x0b keys cab be sent in one HCI command */ 679#define HCI_MAX_NUM_OF_LINK_KEYS_PER_CMMD 0x0b 680 /* Write Stored Key */ 681 682 /* Delete Stored Key */ 683HCI_API extern BOOLEAN btsnd_hcic_delete_stored_key (BD_ADDR bd_addr, BOOLEAN delete_all_flag); 684 685#define HCIC_PARAM_SIZE_DELETE_STORED_KEY 7 686 687#define HCI_DELETE_KEY_BD_ADDR_OFF 0 688#define HCI_DELETE_KEY_ALL_FLAG_OFF 6 689 /* Delete Stored Key */ 690 691 /* Change Local Name */ 692HCI_API extern BOOLEAN btsnd_hcic_change_name(BD_NAME name); 693 694#define HCIC_PARAM_SIZE_CHANGE_NAME BD_NAME_LEN 695 696#define HCI_CHANGE_NAME_NAME_OFF 0 697 /* Change Local Name */ 698 699 700#define HCIC_PARAM_SIZE_READ_CMD 0 701 702#define HCIC_PARAM_SIZE_WRITE_PARAM1 1 703 704#define HCIC_WRITE_PARAM1_PARAM_OFF 0 705 706#define HCIC_PARAM_SIZE_WRITE_PARAM2 2 707 708#define HCIC_WRITE_PARAM2_PARAM_OFF 0 709 710#define HCIC_PARAM_SIZE_WRITE_PARAM3 3 711 712#define HCIC_WRITE_PARAM3_PARAM_OFF 0 713 714#define HCIC_PARAM_SIZE_SET_AFH_CHANNELS 10 715 716HCI_API extern BOOLEAN btsnd_hcic_read_pin_type(void); /* Read PIN Type */ 717HCI_API extern BOOLEAN btsnd_hcic_write_pin_type(UINT8 type); /* Write PIN Type */ 718HCI_API extern BOOLEAN btsnd_hcic_read_auto_accept(void); /* Read Auto Accept */ 719HCI_API extern BOOLEAN btsnd_hcic_write_auto_accept(UINT8 flag); /* Write Auto Accept */ 720HCI_API extern BOOLEAN btsnd_hcic_read_name (void); /* Read Local Name */ 721HCI_API extern BOOLEAN btsnd_hcic_read_conn_acc_tout(UINT8 local_controller_id); /* Read Connection Accept Timout */ 722HCI_API extern BOOLEAN btsnd_hcic_write_conn_acc_tout(UINT8 local_controller_id, UINT16 tout); /* Write Connection Accept Timout */ 723HCI_API extern BOOLEAN btsnd_hcic_read_page_tout(void); /* Read Page Timout */ 724HCI_API extern BOOLEAN btsnd_hcic_write_page_tout(UINT16 timeout); /* Write Page Timout */ 725HCI_API extern BOOLEAN btsnd_hcic_read_scan_enable(void); /* Read Scan Enable */ 726HCI_API extern BOOLEAN btsnd_hcic_write_scan_enable(UINT8 flag); /* Write Scan Enable */ 727HCI_API extern BOOLEAN btsnd_hcic_read_pagescan_cfg(void); /* Read Page Scan Activity */ 728 729HCI_API extern BOOLEAN btsnd_hcic_write_pagescan_cfg(UINT16 interval, 730 UINT16 window); /* Write Page Scan Activity */ 731 732#define HCIC_PARAM_SIZE_WRITE_PAGESCAN_CFG 4 733 734#define HCI_SCAN_CFG_INTERVAL_OFF 0 735#define HCI_SCAN_CFG_WINDOW_OFF 2 736 /* Write Page Scan Activity */ 737 738HCI_API extern BOOLEAN btsnd_hcic_read_inqscan_cfg(void); /* Read Inquiry Scan Activity */ 739 740 /* Write Inquiry Scan Activity */ 741HCI_API extern BOOLEAN btsnd_hcic_write_inqscan_cfg(UINT16 interval, UINT16 window); 742 743#define HCIC_PARAM_SIZE_WRITE_INQSCAN_CFG 4 744 745#define HCI_SCAN_CFG_INTERVAL_OFF 0 746#define HCI_SCAN_CFG_WINDOW_OFF 2 747 /* Write Inquiry Scan Activity */ 748 749HCI_API extern BOOLEAN btsnd_hcic_read_auth_enable(void); /* Read Authentication Enable */ 750HCI_API extern BOOLEAN btsnd_hcic_write_auth_enable(UINT8 flag); /* Write Authentication Enable */ 751HCI_API extern BOOLEAN btsnd_hcic_read_encr_mode (void); /* Read encryption mode */ 752HCI_API extern BOOLEAN btsnd_hcic_write_encr_mode (UINT8 mode); /* Write encryption mode */ 753HCI_API extern BOOLEAN btsnd_hcic_read_dev_class(void); /* Read Class of Device */ 754HCI_API extern BOOLEAN btsnd_hcic_write_dev_class(DEV_CLASS dev); /* Write Class of Device */ 755HCI_API extern BOOLEAN btsnd_hcic_read_voice_settings(void); /* Read Voice Settings */ 756HCI_API extern BOOLEAN btsnd_hcic_write_voice_settings(UINT16 flags); /* Write Voice Settings */ 757 758/* Host Controller to Host flow control */ 759#define HCI_HOST_FLOW_CTRL_OFF 0 760#define HCI_HOST_FLOW_CTRL_ACL_ON 1 761#define HCI_HOST_FLOW_CTRL_SCO_ON 2 762#define HCI_HOST_FLOW_CTRL_BOTH_ON 3 763 764HCI_API extern BOOLEAN btsnd_hcic_set_host_flow_ctrl (UINT8 value); /* Enable/disable flow control toward host */ 765 766 767HCI_API extern BOOLEAN btsnd_hcic_read_auto_flush_tout(UINT16 handle); /* Read Retransmit Timout */ 768 769HCI_API extern BOOLEAN btsnd_hcic_write_auto_flush_tout(UINT16 handle, 770 UINT16 timeout); /* Write Retransmit Timout */ 771 772#define HCIC_PARAM_SIZE_WRITE_AUTO_FLUSH_TOUT 4 773 774#define HCI_FLUSH_TOUT_HANDLE_OFF 0 775#define HCI_FLUSH_TOUT_TOUT_OFF 2 776 777HCI_API extern BOOLEAN btsnd_hcic_read_num_bcast_xmit(void); /* Read Num Broadcast Retransmits */ 778HCI_API extern BOOLEAN btsnd_hcic_write_num_bcast_xmit(UINT8 num); /* Write Num Broadcast Retransmits */ 779HCI_API extern BOOLEAN btsnd_hcic_read_hold_mode_act(void); /* Read Hold Mode Activity */ 780HCI_API extern BOOLEAN btsnd_hcic_write_hold_mode_act(UINT8 flags); /* Write Hold Mode Activity */ 781 782HCI_API extern BOOLEAN btsnd_hcic_read_tx_power(UINT16 handle, UINT8 type); /* Read Tx Power */ 783 784#define HCIC_PARAM_SIZE_READ_TX_POWER 3 785 786#define HCI_READ_TX_POWER_HANDLE_OFF 0 787#define HCI_READ_TX_POWER_TYPE_OFF 2 788 789/* Read transmit power level parameter */ 790#define HCI_READ_CURRENT 0x00 791#define HCI_READ_MAXIMUM 0x01 792 793HCI_API extern BOOLEAN btsnd_hcic_read_sco_flow_enable(void); /* Read Authentication Enable */ 794HCI_API extern BOOLEAN btsnd_hcic_write_sco_flow_enable(UINT8 flag); /* Write Authentication Enable */ 795 796 /* Set Host Buffer Size */ 797HCI_API extern BOOLEAN btsnd_hcic_set_host_buf_size (UINT16 acl_len, 798 UINT8 sco_len, 799 UINT16 acl_num, 800 UINT16 sco_num); 801 802#define HCIC_PARAM_SIZE_SET_HOST_BUF_SIZE 7 803 804#define HCI_HOST_BUF_SIZE_ACL_LEN_OFF 0 805#define HCI_HOST_BUF_SIZE_SCO_LEN_OFF 2 806#define HCI_HOST_BUF_SIZE_ACL_NUM_OFF 3 807#define HCI_HOST_BUF_SIZE_SCO_NUM_OFF 5 808 809 810HCI_API extern BOOLEAN btsnd_hcic_host_num_xmitted_pkts (UINT8 num_handles, 811 UINT16 *handle, 812 UINT16 *num_pkts); /* Set Host Buffer Size */ 813 814#define HCIC_PARAM_SIZE_NUM_PKTS_DONE_SIZE sizeof(btmsg_hcic_num_pkts_done_t) 815 816#define MAX_DATA_HANDLES 10 817 818#define HCI_PKTS_DONE_NUM_HANDLES_OFF 0 819#define HCI_PKTS_DONE_HANDLE_OFF 1 820#define HCI_PKTS_DONE_NUM_PKTS_OFF 3 821 822HCI_API extern BOOLEAN btsnd_hcic_read_link_super_tout(UINT8 local_controller_id, UINT16 handle); /* Read Link Supervision Timeout */ 823 824 /* Write Link Supervision Timeout */ 825HCI_API extern BOOLEAN btsnd_hcic_write_link_super_tout(UINT8 local_controller_id, UINT16 handle, UINT16 timeout); 826 827#define HCIC_PARAM_SIZE_WRITE_LINK_SUPER_TOUT 4 828 829#define HCI_LINK_SUPER_TOUT_HANDLE_OFF 0 830#define HCI_LINK_SUPER_TOUT_TOUT_OFF 2 831 /* Write Link Supervision Timeout */ 832 833HCI_API extern BOOLEAN btsnd_hcic_read_max_iac (void); /* Read Num Supported IAC */ 834HCI_API extern BOOLEAN btsnd_hcic_read_cur_iac_lap (void); /* Read Current IAC LAP */ 835 836HCI_API extern BOOLEAN btsnd_hcic_write_cur_iac_lap (UINT8 num_cur_iac, 837 LAP * const iac_lap); /* Write Current IAC LAP */ 838 839#define MAX_IAC_LAPS 0x40 840 841#define HCI_WRITE_IAC_LAP_NUM_OFF 0 842#define HCI_WRITE_IAC_LAP_LAP_OFF 1 843 /* Write Current IAC LAP */ 844 845 /* Read Clock */ 846HCI_API extern BOOLEAN btsnd_hcic_read_clock (UINT16 handle, UINT8 which_clock); 847 848#define HCIC_PARAM_SIZE_READ_CLOCK 3 849 850#define HCI_READ_CLOCK_HANDLE_OFF 0 851#define HCI_READ_CLOCK_WHICH_CLOCK 2 852 /* Read Clock */ 853 854#ifdef TESTER_ENABLE 855 856#define HCIC_PARAM_SIZE_ENTER_TEST_MODE 2 857 858#define HCI_ENTER_TEST_HANDLE_OFF 0 859 860#define HCIC_PARAM_SIZE_TEST_CNTRL 10 861#define HCI_TEST_CNTRL_HANDLE_OFF 0 862#define HCI_TEST_CNTRL_SCENARIO_OFF 2 863#define HCI_TEST_CNTRL_HOPPINGMODE_OFF 3 864#define HCI_TEST_CNTRL_TX_FREQ_OFF 4 865#define HCI_TEST_CNTRL_RX_FREQ_OFF 5 866#define HCI_TEST_CNTRL_PWR_CNTRL_MODE_OFF 6 867#define HCI_TEST_CNTRL_POLL_PERIOD_OFF 7 868#define HCI_TEST_CNTRL_PKT_TYPE_OFF 8 869#define HCI_TEST_CNTRL_LENGTH_OFF 9 870 871#endif 872 873HCI_API extern BOOLEAN btsnd_hcic_read_page_scan_per (void); /* Read Page Scan Period Mode */ 874HCI_API extern BOOLEAN btsnd_hcic_write_page_scan_per (UINT8 mode); /* Write Page Scan Period Mode */ 875HCI_API extern BOOLEAN btsnd_hcic_read_page_scan_mode (void); /* Read Page Scan Mode */ 876HCI_API extern BOOLEAN btsnd_hcic_write_page_scan_mode (UINT8 mode); /* Write Page Scan Mode */ 877HCI_API extern BOOLEAN btsnd_hcic_read_local_ver (UINT8 local_controller_id); /* Read Local Version Info */ 878HCI_API extern BOOLEAN btsnd_hcic_read_local_supported_cmds (UINT8 local_controller_id); /* Read Local Supported Commands */ 879HCI_API extern BOOLEAN btsnd_hcic_read_local_features (void); /* Read Local Supported Features */ 880HCI_API extern BOOLEAN btsnd_hcic_read_buffer_size (void); /* Read Local buffer sizes */ 881HCI_API extern BOOLEAN btsnd_hcic_read_country_code (void); /* Read Country Code */ 882HCI_API extern BOOLEAN btsnd_hcic_read_bd_addr (void); /* Read Local BD_ADDR */ 883HCI_API extern BOOLEAN btsnd_hcic_read_fail_contact_count (UINT8 local_controller_id, UINT16 handle); /* Read Failed Contact Counter */ 884HCI_API extern BOOLEAN btsnd_hcic_reset_fail_contact_count (UINT8 local_controller_id, UINT16 handle);/* Reset Failed Contact Counter */ 885HCI_API extern BOOLEAN btsnd_hcic_get_link_quality (UINT16 handle); /* Get Link Quality */ 886HCI_API extern BOOLEAN btsnd_hcic_read_rssi (UINT16 handle); /* Read RSSI */ 887HCI_API extern BOOLEAN btsnd_hcic_read_loopback_mode (void); /* Read Loopback Mode */ 888HCI_API extern BOOLEAN btsnd_hcic_write_loopback_mode (UINT8 mode); /* Write Loopback Mode */ 889HCI_API extern BOOLEAN btsnd_hcic_enable_test_mode (void); /* Enable Device Under Test Mode */ 890HCI_API extern BOOLEAN btsnd_hcic_write_pagescan_type(UINT8 type); /* Write Page Scan Type */ 891HCI_API extern BOOLEAN btsnd_hcic_read_pagescan_type(void); /* Read Page Scan Type */ 892HCI_API extern BOOLEAN btsnd_hcic_write_inqscan_type(UINT8 type); /* Write Inquiry Scan Type */ 893HCI_API extern BOOLEAN btsnd_hcic_read_inqscan_type(void); /* Read Inquiry Scan Type */ 894HCI_API extern BOOLEAN btsnd_hcic_write_inquiry_mode(UINT8 type); /* Write Inquiry Mode */ 895HCI_API extern BOOLEAN btsnd_hcic_read_inquiry_mode(void); /* Read Inquiry Mode */ 896HCI_API extern BOOLEAN btsnd_hcic_set_afh_channels (UINT8 first, UINT8 last); 897HCI_API extern BOOLEAN btsnd_hcic_write_afh_channel_assessment_mode (UINT8 mode); 898HCI_API extern BOOLEAN btsnd_hcic_set_afh_host_channel_class (UINT8 *p_afhchannelmap); 899HCI_API extern BOOLEAN btsnd_hcic_read_afh_channel_assessment_mode(void); 900HCI_API extern BOOLEAN btsnd_hcic_read_afh_channel_map (UINT16 handle); 901HCI_API extern BOOLEAN btsnd_hcic_nop(void); /* NOP */ 902 903 /* Send HCI Data */ 904HCI_API extern void btsnd_hcic_data (BT_HDR *p_buf, UINT16 len, UINT16 handle, UINT8 boundary, UINT8 broadcast); 905 906#define HCI_DATA_HANDLE_MASK 0x0FFF 907 908#define HCID_GET_HANDLE_EVENT(p) (UINT16)((*((UINT8 *)((p) + 1) + p->offset) + \ 909 (*((UINT8 *)((p) + 1) + p->offset + 1) << 8))) 910 911#define HCID_GET_HANDLE(u16) (UINT16)((u16) & HCI_DATA_HANDLE_MASK) 912 913#define HCI_DATA_EVENT_MASK 3 914#define HCI_DATA_EVENT_OFFSET 12 915#define HCID_GET_EVENT(u16) (UINT8)(((u16) >> HCI_DATA_EVENT_OFFSET) & HCI_DATA_EVENT_MASK) 916 917#define HCI_DATA_BCAST_MASK 3 918#define HCI_DATA_BCAST_OFFSET 10 919#define HCID_GET_BCAST(u16) (UINT8)(((u16) >> HCI_DATA_BCAST_OFFSET) & HCI_DATA_BCAST_MASK) 920 921#define HCID_GET_ACL_LEN(p) (UINT16)((*((UINT8 *)((p) + 1) + p->offset + 2) + \ 922 (*((UINT8 *)((p) + 1) + p->offset + 3) << 8))) 923 924#define HCID_HEADER_SIZE 4 925 /* Send HCI Data */ 926 927#define HCID_GET_SCO_LEN(p) (*((UINT8 *)((p) + 1) + p->offset + 2)) 928 929HCI_API extern void btsnd_hcic_vendor_spec_cmd ( 930 void *buffer, UINT16 opcode, 931 UINT8 len, UINT8 *p_data, 932 void *p_cmd_cplt_cback); 933 934 935/********************************************************************************* 936** ** 937** H C I E V E N T S ** 938** ** 939*********************************************************************************/ 940 941/* Inquiry Complete Event */ 942HCI_API extern void btsnd_hcie_inq_comp(void *buffer, UINT8 status); 943 944#define HCIE_PARAM_SIZE_INQ_COMP 1 945 946/* Inquiry Response Event */ 947HCI_API extern void btsnd_hcie_inq_res(void *buffer, UINT8 num_resp, UINT8 **bd_addr, 948 UINT8 *page_scan_rep_mode, UINT8 *page_scan_per_mode, 949 UINT8 *page_scan_mode, UINT8 **dev_class, 950 UINT16 *clock_offset); 951 952/* Connection Complete Event */ 953HCI_API extern void btsnd_hcie_connection_comp(void *buffer, UINT8 status, UINT16 handle, 954 BD_ADDR bd_addr, UINT8 link_type, UINT8 encr_mode); 955 956#define HCIE_PARAM_SIZE_CONNECTION_COMP 11 957 958 959#define HCI_LINK_TYPE_SCO 0x00 960#define HCI_LINK_TYPE_ACL 0x01 961 962#define HCI_ENCRYPT_MODE_DISABLED 0x00 963#define HCI_ENCRYPT_MODE_POINT_TO_POINT 0x01 964#define HCI_ENCRYPT_MODE_ALL 0x02 965 966 967/* Connection Request Event */ 968HCI_API extern void btsnd_hcie_connection_req(void *buffer, BD_ADDR bd_addr, DEV_CLASS dev_class, UINT8 link_type); 969 970#define HCIE_PARAM_SIZE_CONNECTION_REQ 10 971 972#define HCI_LINK_TYPE_SCO 0x00 973#define HCI_LINK_TYPE_ACL 0x01 974 975 976/* Disonnection Complete Event */ 977HCI_API extern void btsnd_hcie_disc_comp(void *buffer, UINT8 status, UINT16 handle, UINT8 reason); 978 979#define HCIE_PARAM_SIZE_DISC_COMP 4 980 981 982/* Authentication Complete Event */ 983HCI_API extern void btsnd_hcie_auth_comp (void *buffer, UINT8 status, UINT16 handle); 984 985#define HCIE_PARAM_SIZE_AUTH_COMP 3 986 987 988/* Remote Name Request Complete Event */ 989HCI_API extern void btsnd_hcie_rmt_name_req_comp(void *buffer, UINT8 status, BD_ADDR bd_addr, BD_NAME name); 990 991#define HCIE_PARAM_SIZE_RMT_NAME_REQ_COMP (1 + BD_ADDR_LEN + BD_NAME_LEN) 992 993 994/* Encryption Change Event */ 995HCI_API extern void btsnd_hcie_encryption_change (void *buffer, UINT8 status, UINT16 handle, BOOLEAN enable); 996 997#define HCIE_PARAM_SIZE_ENCR_CHANGE 4 998 999 1000/* Connection Link Key Change Event */ 1001HCI_API extern void btsnd_hcie_conn_link_key_change (void *buffer, UINT8 status, UINT16 handle); 1002 1003#define HCIE_PARAM_SIZE_LINK_KEY_CHANGE 3 1004 1005 1006/* Encryption Key Refresh Complete Event */ 1007HCI_API extern void btsnd_hcie_encrypt_key_refresh (void *buffer, UINT8 status, UINT16 handle); 1008 1009#define HCIE_PARAM_SIZE_ENCRYPT_KEY_REFRESH 3 1010 1011 1012/* Master Link Key Complete Event */ 1013HCI_API extern void btsnd_hcie_master_link_key (void *buffer, UINT8 status, UINT16 handle, UINT8 flag); 1014 1015#define HCIE_PARAM_SIZE_MASTER_LINK_KEY 4 1016 1017 1018/* Read Remote Supported Features Complete Event */ 1019HCI_API extern void btsnd_hcie_read_rmt_features (void *buffer, UINT8 status, UINT16 handle, UINT8 *features); 1020 1021#define LMP_FEATURES_SIZE 8 1022#define HCIE_PARAM_SIZE_READ_RMT_FEATURES 11 1023 1024 1025/* Read Remote Extended Features Complete Event */ 1026HCI_API extern void btsnd_hcie_read_rmt_ext_features (void *buffer, UINT8 status, UINT16 handle, UINT8 page_num, 1027 UINT8 max_page_num, UINT8 *features); 1028 1029#define EXT_LMP_FEATURES_SIZE 8 1030#define HCIE_PARAM_SIZE_READ_RMT_EXT_FEATURES 13 1031 1032 1033/* Read Remote Version Complete Event */ 1034HCI_API extern void btsnd_hcie_read_rmt_version (void *buffer, UINT8 status, UINT16 handle, UINT8 version, 1035 UINT16 comp_name, UINT16 sub_version); 1036 1037#define HCIE_PARAM_SIZE_READ_RMT_VERSION 8 1038 1039 1040/* QOS setup complete */ 1041HCI_API extern void btsnd_hcie_qos_setup_compl (void *buffer, UINT8 status, UINT16 handle, UINT8 flags, 1042 UINT8 service_type, UINT32 token_rate, UINT32 peak, 1043 UINT32 latency, UINT32 delay_var); 1044 1045#define HCIE_PARAM_SIZE_QOS_SETUP_COMP 21 1046 1047 1048/* Flow Specification complete */ 1049HCI_API extern void btsnd_hcie_flow_spec_compl (void *buffer, UINT8 status, UINT16 handle, UINT8 flags, 1050 UINT8 flow_direction, UINT8 service_type, UINT32 token_rate, UINT32 token_bucket_size, 1051 UINT32 peak, UINT32 latency); 1052 1053#define HCIE_PARAM_SIZE_FLOW_SPEC_COMP 22 1054 1055 1056/* Command Complete Event */ 1057HCI_API extern void btsnd_hcie_cmd_comp(void *buffer, UINT8 max_host_cmds, UINT16 opcode, UINT8 status); 1058 1059#define HCIE_PARAM_SIZE_CMD_COMP 4 1060 1061 1062/* Command Complete with pre-filled in parameters */ 1063HCI_API extern void btsnd_hcie_cmd_comp_params (void *buffer, UINT8 max_host_cmds, UINT16 cmd_opcode, UINT8 status); 1064 1065#define HCI_CMD_COMPL_PARAM_OFFSET 4 1066 1067 1068/* Command Complete Event with 1-byte param */ 1069HCI_API extern void btsnd_hcie_cmd_comp_param1(void *buffer, UINT8 max_host_cmds, UINT16 opcode, 1070 UINT8 status, UINT8 param1); 1071 1072#define HCIE_PARAM_SIZE_CMD_COMP_PARAM1 5 1073 1074/* Command Complete Event with 2-byte param */ 1075HCI_API extern void btsnd_hcie_cmd_comp_param2(void *buffer, UINT8 max_host_cmds, UINT16 opcode, 1076 UINT8 status, UINT16 param2); 1077 1078#define HCIE_PARAM_SIZE_CMD_COMP_PARAM2 6 1079 1080 1081/* Command Complete Event with BD-addr as param */ 1082HCI_API extern void btsnd_hcie_cmd_comp_bd_addr(void *buffer, UINT8 max_host_cmds, UINT16 opcode, 1083 UINT8 status, BD_ADDR bd_addr); 1084 1085#define HCIE_PARAM_SIZE_CMD_COMP_BD_ADDR 10 1086 1087 1088/* Command Pending Event */ 1089HCI_API extern void btsnd_hcie_cmd_status (void *buffer, UINT8 status, UINT8 max_host_cmds, UINT16 opcode); 1090 1091#define HCIE_PARAM_SIZE_CMD_STATUS 4 1092 1093 1094/* HW failure Event */ 1095HCI_API extern void btsnd_hcie_hw_failure (void *buffer, UINT8 code); 1096 1097#define HCIE_PARAM_SIZE_HW_FAILURE 1 1098 1099 1100/* Flush Occured Event */ 1101HCI_API extern void btsnd_hcie_flush_occured (void *buffer, UINT16 handle); 1102 1103#define HCIE_PARAM_SIZE_FLUSH_OCCURED 2 1104 1105 1106/* Role Changed Event */ 1107HCI_API extern void btsnd_hcie_role_change (void *buffer, UINT8 status, BD_ADDR bd_addr, UINT8 role); 1108 1109#define HCIE_PARAM_SIZE_ROLE_CHANGE 8 1110 1111 1112/* Ready for Data Packets Event */ 1113HCI_API extern void btsnd_hcie_num_compl_pkts (void *buffer, UINT8 num_handles, UINT16 *p_handle, UINT16 *num_pkts); 1114 1115#define MAX_DATA_HANDLES 10 1116 1117 1118/* Mode Change Event */ 1119HCI_API extern void btsnd_hcie_mode_change (void *buffer, UINT8 status, UINT16 handle, 1120 UINT8 mode, UINT16 interval); 1121 1122#define HCIE_PARAM_SIZE_MODE_CHANGE 6 1123#define MAX_DATA_HANDLES 10 1124 1125 1126 1127/* Return Link Keys Event */ 1128HCI_API extern void btsnd_hcie_return_link_keys (void *buffer, UINT8 num_keys, BD_ADDR *bd_addr, LINK_KEY *link_key); 1129 1130/* This should not be more than 0x0b */ 1131#define MAX_LINK_KEYS 10 1132 1133 1134 1135/* PIN Code Request Event */ 1136HCI_API extern void btsnd_hcie_pin_code_req (void *buffer, BD_ADDR bd_addr); 1137 1138#define HCIE_PARAM_SIZE_PIN_CODE_REQ 6 1139 1140 1141 1142/* Link Key Request Event */ 1143HCI_API extern void btsnd_hcie_link_key_req (void *buffer, BD_ADDR bd_addr); 1144 1145#define HCIE_PARAM_SIZE_LINK_KEY_REQ 6 1146 1147 1148 1149/* Link Key Notification Event */ 1150HCI_API extern void btsnd_hcie_link_key_notify (void *buffer, BD_ADDR bd_addr, LINK_KEY link_key, UINT8 key_type); 1151 1152#define HCIE_PARAM_SIZE_LINK_KEY_NOTIFY 23 1153 1154 1155 1156/* Loopback Command Event */ 1157HCI_API extern void btsnd_hcie_loopback_command (void *buffer, UINT8 data_len, UINT8 *data); 1158 1159#define HCIE_PARAM_SIZE_LOOPBACK_COMMAND sizeof(btmsg_hcie_loopback_cmd_t) 1160 1161 1162 1163/* Data Buffer Overflow Event */ 1164HCI_API extern void btsnd_hcie_data_buf_overflow (void *buffer, UINT8 link_type); 1165 1166#define HCIE_PARAM_SIZE_DATA_BUF_OVERFLOW 1 1167 1168 1169 1170/* Max Slots Change Event */ 1171HCI_API extern void btsnd_hcie_max_slots_change(void *buffer, UINT16 handle, UINT8 max_slots); 1172 1173#define HCIE_PARAM_SIZE_MAX_SLOTS_CHANGE 3 1174 1175 1176/* Read Clock Offset Complet Event */ 1177HCI_API extern void btsnd_hcie_read_clock_off_comp(void *buffer, UINT8 status, UINT16 handle, 1178 UINT16 clock_offset); 1179 1180#define HCIE_PARAM_SIZE_READ_CLOCK_OFF_COMP 5 1181 1182 1183 1184/* Connection Packet Type Change Event */ 1185HCI_API extern void btsnd_hcie_pkt_type_change (void *buffer, UINT8 status, UINT16 handle, UINT16 pkt_type); 1186 1187#define HCIE_PARAM_SIZE_PKT_TYPE_CHANGE 5 1188 1189 1190 1191/* QOS violation Event */ 1192HCI_API extern void btsnd_hcie_qos_violation (void *buffer, UINT16 handle); 1193 1194#define HCIE_PARAM_SIZE_QOS_VIOLATION 2 1195 1196 1197 1198/* Page Scan Mode Change Event */ 1199HCI_API extern void btsnd_hcie_pagescan_mode_chng (void *buffer, BD_ADDR bd_addr, UINT8 mode); 1200 1201#define HCIE_PARAM_SIZE_PAGE_SCAN_MODE_CHNG 7 1202 1203 1204/* Page Scan Repetition Mode Change Event */ 1205HCI_API extern void btsnd_hcie_pagescan_rep_mode_chng (void *buffer, BD_ADDR bd_addr, UINT8 mode); 1206 1207#define HCIE_PARAM_SIZE_PAGE_SCAN_REP_MODE_CHNG 7 1208 1209 1210/* Sniff Sub Rate Event */ 1211HCI_API extern void btsnd_hcie_sniff_sub_rate(void *buffer, UINT8 status, UINT16 handle, UINT16 max_tx_lat, UINT16 max_rx_lat, 1212 UINT16 min_remote_timeout, UINT16 min_local_timeout); 1213 1214#define HCIE_PARAM_SIZE_SNIFF_SUB_RATE 11 1215 1216 1217 1218/* Extended Inquiry Result Event */ 1219HCI_API extern void btsnd_hcie_ext_inquiry_result(void *buffer, UINT8 num_resp, UINT8 **bd_addr, 1220 UINT8 *page_scan_rep_mode, UINT8 *reserved, 1221 UINT8 **dev_class, UINT16 *clock_offset, UINT8 *rssi, UINT8 *p_data); 1222 1223 1224#if (BLE_INCLUDED == TRUE) 1225/******************************************************************************** 1226** BLE Commands 1227** Note: "local_controller_id" is for transport, not counted in HCI message size 1228*********************************************************************************/ 1229#define HCIC_PARAM_SIZE_SET_USED_FEAT_CMD 8 1230#define HCIC_PARAM_SIZE_WRITE_RANDOM_ADDR_CMD 6 1231#define HCIC_PARAM_SIZE_BLE_WRITE_ADV_PARAMS 15 1232#define HCIC_PARAM_SIZE_BLE_WRITE_SCAN_RSP 31 1233#define HCIC_PARAM_SIZE_WRITE_ADV_ENABLE 1 1234#define HCIC_PARAM_SIZE_BLE_WRITE_SCAN_PARAM 7 1235#define HCIC_PARAM_SIZE_BLE_WRITE_SCAN_ENABLE 2 1236#define HCIC_PARAM_SIZE_BLE_CREATE_LL_CONN 25 1237#define HCIC_PARAM_SIZE_BLE_CREATE_CONN_CANCEL 0 1238#define HCIC_PARAM_SIZE_CLEAR_WHITE_LIST 0 1239#define HCIC_PARAM_SIZE_ADD_WHITE_LIST 7 1240#define HCIC_PARAM_SIZE_REMOVE_WHITE_LIST 7 1241#define HCIC_PARAM_SIZE_BLE_UPD_LL_CONN_PARAMS 14 1242#define HCIC_PARAM_SIZE_SET_HOST_CHNL_CLASS 5 1243#define HCIC_PARAM_SIZE_READ_CHNL_MAP 2 1244#define HCIC_PARAM_SIZE_BLE_READ_REMOTE_FEAT 2 1245#define HCIC_PARAM_SIZE_BLE_ENCRYPT 32 1246#define HCIC_PARAM_SIZE_BLE_RAND 0 1247#define HCIC_PARAM_SIZE_WRITE_LE_HOST_SUPPORTED 2 1248 1249#define HCIC_BLE_RAND_DI_SIZE 8 1250#define HCIC_BLE_ENCRYT_KEY_SIZE 16 1251#define HCIC_PARAM_SIZE_BLE_START_ENC (4 + HCIC_BLE_RAND_DI_SIZE + HCIC_BLE_ENCRYT_KEY_SIZE) 1252#define HCIC_PARAM_SIZE_LTK_REQ_REPLY (2 + HCIC_BLE_ENCRYT_KEY_SIZE) 1253#define HCIC_PARAM_SIZE_LTK_REQ_NEG_REPLY 2 1254#define HCIC_BLE_CHNL_MAP_SIZE 5 1255#define HCIC_PARAM_SIZE_BLE_WRITE_ADV_DATA 31 1256 1257/* ULP HCI command */ 1258HCI_API extern BOOLEAN btsnd_hcic_ble_set_evt_mask (BT_EVENT_MASK event_mask); 1259 1260HCI_API extern BOOLEAN btsnd_hcic_ble_read_buffer_size (void); 1261 1262HCI_API extern BOOLEAN btsnd_hcic_ble_read_local_spt_feat (void); 1263 1264HCI_API extern BOOLEAN btsnd_hcic_ble_set_local_used_feat (UINT8 feat_set[8]); 1265 1266HCI_API extern BOOLEAN btsnd_hcic_ble_set_random_addr (BD_ADDR random_addr); 1267 1268HCI_API extern BOOLEAN btsnd_hcic_ble_write_adv_params (UINT16 adv_int_min, UINT16 adv_int_max, 1269 UINT8 adv_type, UINT8 addr_type_own, 1270 UINT8 addr_type_dir, BD_ADDR direct_bda, 1271 UINT8 channel_map, UINT8 scan_filter_policy); 1272 1273HCI_API extern BOOLEAN btsnd_hcic_ble_read_adv_chnl_tx_power (void); 1274 1275HCI_API extern BOOLEAN btsnd_hcic_ble_set_adv_data (UINT8 data_len, UINT8 *p_data); 1276 1277HCI_API extern BOOLEAN btsnd_hcic_ble_set_scan_rsp_data (UINT8 data_len, UINT8 *p_scan_rsp); 1278 1279HCI_API extern BOOLEAN btsnd_hcic_ble_set_adv_enable (UINT8 adv_enable); 1280 1281HCI_API extern BOOLEAN btsnd_hcic_ble_set_scan_params (UINT8 scan_type, 1282 UINT16 scan_int, UINT16 scan_win, 1283 UINT8 addr_type, UINT8 scan_filter_policy); 1284 1285HCI_API extern BOOLEAN btsnd_hcic_ble_set_scan_enable (UINT8 scan_enable, UINT8 duplicate); 1286 1287HCI_API extern BOOLEAN btsnd_hcic_ble_create_ll_conn (UINT16 scan_int, UINT16 scan_win, 1288 UINT8 init_filter_policy, UINT8 addr_type_peer, BD_ADDR bda_peer, UINT8 addr_type_own, 1289 UINT16 conn_int_min, UINT16 conn_int_max, UINT16 conn_latency, UINT16 conn_timeout, 1290 UINT16 min_ce_len, UINT16 max_ce_len); 1291 1292HCI_API extern BOOLEAN btsnd_hcic_ble_create_conn_cancel (void); 1293 1294HCI_API extern BOOLEAN btsnd_hcic_ble_read_white_list_size (void); 1295 1296HCI_API extern BOOLEAN btsnd_hcic_ble_clear_white_list (void); 1297 1298HCI_API extern BOOLEAN btsnd_hcic_ble_add_white_list (UINT8 addr_type, BD_ADDR bda); 1299 1300HCI_API extern BOOLEAN btsnd_hcic_ble_remove_from_white_list (UINT8 addr_type, BD_ADDR bda); 1301 1302HCI_API extern BOOLEAN btsnd_hcic_ble_upd_ll_conn_params (UINT16 handle, UINT16 conn_int_min, UINT16 conn_int_max, 1303 UINT16 conn_latency, UINT16 conn_timeout, UINT16 min_len, UINT16 max_len); 1304 1305HCI_API extern BOOLEAN btsnd_hcic_ble_set_host_chnl_class (UINT8 chnl_map[HCIC_BLE_CHNL_MAP_SIZE]); 1306 1307HCI_API extern BOOLEAN btsnd_hcic_ble_read_chnl_map (UINT16 handle); 1308 1309HCI_API extern BOOLEAN btsnd_hcic_ble_read_remote_feat ( UINT16 handle); 1310 1311HCI_API extern BOOLEAN btsnd_hcic_ble_encrypt (UINT8* key, UINT8 key_len, UINT8* plain_text, UINT8 pt_len, void *p_cmd_cplt_cback); 1312 1313HCI_API extern BOOLEAN btsnd_hcic_ble_rand (void *p_cmd_cplt_cback); 1314 1315HCI_API extern BOOLEAN btsnd_hcic_ble_start_enc ( UINT16 handle, 1316 UINT8 rand[HCIC_BLE_RAND_DI_SIZE], 1317 UINT16 ediv, UINT8 ltk[HCIC_BLE_ENCRYT_KEY_SIZE]); 1318 1319HCI_API extern BOOLEAN btsnd_hcic_ble_ltk_req_reply (UINT16 handle, UINT8 ltk[HCIC_BLE_ENCRYT_KEY_SIZE]); 1320 1321HCI_API extern BOOLEAN btsnd_hcic_ble_ltk_req_neg_reply (UINT16 handle); 1322 1323HCI_API extern BOOLEAN btsnd_hcic_ble_read_supported_states (void); 1324 1325HCI_API extern BOOLEAN btsnd_hcic_ble_write_host_supported (UINT8 le_host_spt, UINT8 simul_le_host_spt); 1326 1327HCI_API extern BOOLEAN btsnd_hcic_ble_read_host_supported (void); 1328 1329HCI_API extern BOOLEAN btsnd_hcic_ble_receiver_test(UINT8 rx_freq); 1330 1331HCI_API extern BOOLEAN btsnd_hcic_ble_transmitter_test(UINT8 tx_freq, UINT8 test_data_len, 1332 UINT8 payload); 1333HCI_API extern BOOLEAN btsnd_hcic_ble_test_end(void); 1334 1335#if (defined BLE_LLT_INCLUDED) && (BLE_LLT_INCLUDED == TRUE) 1336 1337#define HCIC_PARAM_SIZE_BLE_RC_PARAM_REQ_REPLY 14 1338HCI_API extern BOOLEAN btsnd_hcic_ble_rc_param_req_reply(UINT16 handle, 1339 UINT16 conn_int_min, UINT16 conn_int_max, 1340 UINT16 conn_latency, UINT16 conn_timeout, 1341 UINT16 min_ce_len, UINT16 max_ce_len); 1342 1343#define HCIC_PARAM_SIZE_BLE_RC_PARAM_REQ_NEG_REPLY 3 1344HCI_API extern BOOLEAN btsnd_hcic_ble_rc_param_req_neg_reply(UINT16 handle, UINT8 reason); 1345 1346#endif /* BLE_LLT_INCLUDED */ 1347 1348 1349#endif /* BLE_INCLUDED */ 1350 1351#ifdef __cplusplus 1352} 1353#endif 1354 1355#endif 1356 1357