blob: 77834ec093b03d4ccabd83fa700430a6207769cd [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
#ifndef H_BLE_HCI_COMMON_
#define H_BLE_HCI_COMMON_
#include "ble.h"
/*
* HCI Command Header
*
* Comprises the following fields
* -> Opcode group field & Opcode command field (2)
* -> Parameter Length (1)
* Length of all the parameters (does not include any part of the hci
* command header
*/
#define BLE_HCI_CMD_HDR_LEN (3)
#define BLE_HCI_OPCODE_NOP (0)
/* Get the OGF and OCF from the opcode in the command */
#define BLE_HCI_OGF(opcode) (((opcode) >> 10) & 0x003F)
#define BLE_HCI_OCF(opcode) ((opcode) & 0x03FF)
/* Opcode Group */
#define BLE_HCI_OGF_LINK_CTRL (0x01)
#define BLE_HCI_OGF_LINK_POLICY (0x02)
#define BLE_HCI_OGF_CTLR_BASEBAND (0x03)
#define BLE_HCI_OGF_INFO_PARAMS (0x04)
#define BLE_HCI_OGF_STATUS_PARAMS (0x05)
#define BLE_HCI_OGF_TESTING (0x06)
/* NOTE: 0x07 not defined in specification */
#define BLE_HCI_OGF_LE (0x08)
/* List of OCF for Link Control commands (OGF=0x01) */
#define BLE_HCI_OCF_DISCONNECT_CMD (0x0006)
#define BLE_HCI_OCF_RD_REM_VER_INFO (0x001D)
/* Command specific definitions */
/* Disconnect command */
#define BLE_HCI_DISCONNECT_CMD_LEN (3)
/* List of OCF for Controller and Baseband commands (OGF=0x03) */
#define BLE_HCI_OCF_CB_SET_EVENT_MASK (0x0001)
#define BLE_HCI_OCF_CB_RESET (0x0003)
#define BLE_HCI_OCF_CB_SET_EV_FILT (0x0005)
/* Command specific definitions */
/* Set event mask */
#define BLE_HCI_SET_EVENT_MASK_LEN (8)
/* List of OCF for Info Param commands (OGF=0x04) */
#define BLE_HCI_OCF_IP_RD_LOCAL_VER (0x0001)
/* Command specific definitions */
/* NOTE: does not include status field in command complete event! */
#define BLE_HCI_RD_LOC_VER_INFO_RSPLEN (8)
/* Bluetooth Assigned numbers for version information.*/
#define BLE_HCI_VER_BCS_1_0b (0)
#define BLE_HCI_VER_BCS_1_1 (1)
#define BLE_HCI_VER_BCS_1_2 (2)
#define BLE_HCI_VER_BCS_2_0_EDR (3)
#define BLE_HCI_VER_BCS_2_1_EDR (4)
#define BLE_HCI_VER_BCS_3_0_HCS (5)
#define BLE_HCI_VER_BCS_4_0 (6)
#define BLE_HCI_VER_BCS_4_1 (7)
#define BLE_HCI_VER_BCS_4_2 (8)
#define BLE_LMP_VER_BCS_1_0b (0)
#define BLE_LMP_VER_BCS_1_1 (1)
#define BLE_LMP_VER_BCS_1_2 (2)
#define BLE_LMP_VER_BCS_2_0_EDR (3)
#define BLE_LMP_VER_BCS_2_1_EDR (4)
#define BLE_LMP_VER_BCS_3_0_HCS (5)
#define BLE_LMP_VER_BCS_4_0 (6)
#define BLE_LMP_VER_BCS_4_1 (7)
#define BLE_LMP_VER_BCS_4_2 (8)
/* List of OCD for Status parameters commands (OGF = 0x05) */
#define BLE_HCI_OCF_RD_RSSI (0x0005)
/* List of OCF for LE commands (OGF = 0x08) */
#define BLE_HCI_OCF_LE_SET_EVENT_MASK (0x0001)
#define BLE_HCI_OCF_LE_RD_BUF_SIZE (0x0002)
#define BLE_HCI_OCF_LE_RD_LOC_SUPP_FEAT (0x0003)
/* NOTE: 0x0004 is intentionally left undefined */
#define BLE_HCI_OCF_LE_SET_RAND_ADDR (0x0005)
#define BLE_HCI_OCF_LE_SET_ADV_PARAMS (0x0006)
#define BLE_HCI_OCF_LE_RD_ADV_CHAN_TXPWR (0x0007)
#define BLE_HCI_OCF_LE_SET_ADV_DATA (0x0008)
#define BLE_HCI_OCF_LE_SET_SCAN_RSP_DATA (0x0009)
#define BLE_HCI_OCF_LE_SET_ADV_ENABLE (0x000A)
#define BLE_HCI_OCF_LE_SET_SCAN_PARAMS (0x000B)
#define BLE_HCI_OCF_LE_SET_SCAN_ENABLE (0x000C)
#define BLE_HCI_OCF_LE_CREATE_CONN (0x000D)
#define BLE_HCI_OCF_LE_CREATE_CONN_CANCEL (0x000E)
#define BLE_HCI_OCF_LE_RD_WHITE_LIST_SIZE (0x000F)
#define BLE_HCI_OCF_LE_CLEAR_WHITE_LIST (0x0010)
#define BLE_HCI_OCF_LE_ADD_WHITE_LIST (0x0011)
#define BLE_HCI_OCF_LE_RMV_WHITE_LIST (0x0012)
#define BLE_HCI_OCF_LE_CONN_UPDATE (0x0013)
#define BLE_HCI_OCF_LE_SET_HOST_CHAN_CLASS (0x0014)
#define BLE_HCI_OCF_LE_RD_CHAN_MAP (0x0015)
#define BLE_HCI_OCF_LE_RD_REM_FEAT (0x0016)
#define BLE_HCI_OCF_LE_ENCRYPT (0x0017)
#define BLE_HCI_OCF_LE_RAND (0x0018)
#define BLE_HCI_OCF_LE_START_ENCRYPT (0x0019)
#define BLE_HCI_OCF_LE_LT_KEY_REQ_REPLY (0x001A)
#define BLE_HCI_OCF_LE_LT_KEY_REQ_NEG_REPLY (0x001B)
#define BLE_HCI_OCF_LE_RD_SUPP_STATES (0x001C)
#define BLE_HCI_OCF_LE_RX_TEST (0x001D)
#define BLE_HCI_OCF_LE_TX_TEST (0x001E)
#define BLE_HCI_OCF_LE_TEST_END (0x001F)
#define BLE_HCI_OCF_LE_REM_CONN_PARAM_RR (0x0020)
#define BLE_HCI_OCF_LE_REM_CONN_PARAM_NRR (0x0021)
#define BLE_HCI_OCF_LE_SET_DATA_LEN (0x0022)
#define BLE_HCI_OCF_LE_RD_SUGG_DEF_DATA_LEN (0x0023)
#define BLE_HCI_OCF_LE_WR_SUGG_DEF_DATA_LEN (0x0024)
#define BLE_HCI_OCF_LE_RD_P256_PUBKEY (0x0025)
#define BLE_HCI_OCF_LE_GEN_DHKEY (0x0026)
#define BLE_HCI_OCF_LE_ADD_RESOLV_LIST (0x0027)
#define BLE_HCI_OCF_LE_RMV_RESOLV_LIST (0x0028)
#define BLE_HCI_OCF_LE_CLR_RESOLV_LIST (0x0029)
#define BLE_HCI_OCF_LE_RD_RESOLV_LIST_SIZE (0x002A)
#define BLE_HCI_OCF_LE_RD_PEER_RESOLV_ADDR (0x002B)
#define BLE_HCI_OCF_LE_RD_LOCAL_RESOLV_ADDR (0x002C)
#define BLE_HCI_OCF_LE_SET_ADDR_RES_EN (0x002D)
#define BLE_HCI_OCF_LE_SET_RESOLV_PRIV_ADDR (0x002E)
#define BLE_HCI_OCF_LE_RD_MAX_DATA_LEN (0x002F)
/* Command Specific Definitions */
/* --- Read RSSI (OGF 0x05, OCF 0x0005) --- */
#define BLE_HCI_READ_RSSI_ACK_PARAM_LEN (4) /* Includes status byte. */
/* --- LE set event mask (OCF 0x0001) --- */
#define BLE_HCI_SET_LE_EVENT_MASK_LEN (8)
/* --- LE read buffer size (OCF 0x0002) --- */
#define BLE_HCI_RD_BUF_SIZE_LEN (0)
#define BLE_HCI_RD_BUF_SIZE_RSPLEN (3)
/* --- LE read local supported features (OCF 0x0003) --- */
#define BLE_HCI_RD_LOC_SUPP_FEAT_RSPLEN (8)
/* --- LE set advertising parameters (OCF 0x0006) */
#define BLE_HCI_SET_ADV_PARAM_LEN (15)
/* Advertising types */
#define BLE_HCI_ADV_TYPE_ADV_IND (0)
#define BLE_HCI_ADV_TYPE_ADV_DIRECT_IND_HD (1)
#define BLE_HCI_ADV_TYPE_ADV_SCAN_IND (2)
#define BLE_HCI_ADV_TYPE_ADV_NONCONN_IND (3)
#define BLE_HCI_ADV_TYPE_ADV_DIRECT_IND_LD (4)
#define BLE_HCI_ADV_TYPE_MAX (4)
/* Own address types */
#define BLE_HCI_ADV_OWN_ADDR_PUBLIC (0)
#define BLE_HCI_ADV_OWN_ADDR_RANDOM (1)
#define BLE_HCI_ADV_OWN_ADDR_PRIV_PUB (2)
#define BLE_HCI_ADV_OWN_ADDR_PRIV_RAND (3)
#define BLE_HCI_ADV_OWN_ADDR_MAX (3)
/* Advertisement peer address Type */
#define BLE_HCI_ADV_PEER_ADDR_PUBLIC (0)
#define BLE_HCI_ADV_PEER_ADDR_RANDOM (1)
#define BLE_HCI_ADV_PEER_ADDR_MAX (1)
/* --- LE advertising channel tx power (OCF 0x0007) */
#define BLE_HCI_ADV_CHAN_TXPWR_ACK_PARAM_LEN (2) /* Includes status byte. */
#define BLE_HCI_ADV_CHAN_TXPWR_MIN (-20)
#define BLE_HCI_ADV_CHAN_TXPWR_MAX (10)
/* --- LE set advertising data (OCF 0x0008) */
#define BLE_HCI_MAX_ADV_DATA_LEN (31)
/* --- LE set scan response data (OCF 0x0009) */
#define BLE_HCI_MAX_SCAN_RSP_DATA_LEN (31)
/* --- LE set advertising enable (OCF 0x000a) */
#define BLE_HCI_SET_ADV_ENABLE_LEN (1)
/* --- LE set scan enable (OCF 0x000c) */
#define BLE_HCI_SET_SCAN_ENABLE_LEN (2)
/* Connect peer address type */
#define BLE_HCI_CONN_PEER_ADDR_PUBLIC (0)
#define BLE_HCI_CONN_PEER_ADDR_RANDOM (1)
#define BLE_HCI_CONN_PEER_ADDR_PUBLIC_IDENT (2)
#define BLE_HCI_CONN_PEER_ADDR_RANDOM_IDENT (3)
#define BLE_HCI_CONN_PEER_ADDR_MAX (3)
/*
* Advertising filter policy
*
* Determines how an advertiser filters scan and connection requests.
*
* NONE: no filtering (default value). No whitelist used.
* SCAN: process all connection requests but only scans from white list.
* CONN: process all scan request but only connection requests from white list
* BOTH: ignore all scan and connection requests unless in white list.
*/
#define BLE_HCI_ADV_FILT_NONE (0)
#define BLE_HCI_ADV_FILT_SCAN (1)
#define BLE_HCI_ADV_FILT_CONN (2)
#define BLE_HCI_ADV_FILT_BOTH (3)
#define BLE_HCI_ADV_FILT_MAX (3)
#define BLE_HCI_ADV_FILT_DEF (BLE_HCI_ADV_FILT_NONE)
/* Advertising interval */
#define BLE_HCI_ADV_ITVL (625) /* usecs */
#define BLE_HCI_ADV_ITVL_MIN (32) /* units */
#define BLE_HCI_ADV_ITVL_MAX (16384) /* units */
#define BLE_HCI_ADV_ITVL_NONCONN_MIN (160) /* units */
#define BLE_HCI_ADV_ITVL_DEF (0x800) /* 1.28 seconds */
#define BLE_HCI_ADV_CHANMASK_DEF (0x7) /* all channels */
/* Set scan parameters */
#define BLE_HCI_SET_SCAN_PARAM_LEN (7)
#define BLE_HCI_SCAN_TYPE_PASSIVE (0)
#define BLE_HCI_SCAN_TYPE_ACTIVE (1)
/* Scan interval and scan window timing */
#define BLE_HCI_SCAN_ITVL (625) /* usecs */
#define BLE_HCI_SCAN_ITVL_MIN (4) /* units */
#define BLE_HCI_SCAN_ITVL_MAX (16384) /* units */
#define BLE_HCI_SCAN_ITVL_DEF (16) /* units */
#define BLE_HCI_SCAN_WINDOW_MIN (4) /* units */
#define BLE_HCI_SCAN_WINDOW_MAX (16384) /* units */
#define BLE_HCI_SCAN_WINDOW_DEF (16) /* units */
/*
* Scanning filter policy
* NO_WL:
* Scanner processes all advertising packets (white list not used) except
* directed, connectable advertising packets not sent to the scanner.
* USE_WL:
* Scanner processes advertisements from white list only. A connectable,
* directed advertisment is ignored unless it contains scanners address.
* NO_WL_INITA:
* Scanner process all advertising packets (white list not used). A
* connectable, directed advertisement shall not be ignored if the InitA
* is a resolvable private address.
* USE_WL_INITA:
* Scanner process advertisements from white list only. A connectable,
* directed advertisement shall not be ignored if the InitA is a
* resolvable private address.
*/
#define BLE_HCI_SCAN_FILT_NO_WL (0)
#define BLE_HCI_SCAN_FILT_USE_WL (1)
#define BLE_HCI_SCAN_FILT_NO_WL_INITA (2)
#define BLE_HCI_SCAN_FILT_USE_WL_INITA (3)
#define BLE_HCI_SCAN_FILT_MAX (3)
/* Whitelist commands */
#define BLE_HCI_CHG_WHITE_LIST_LEN (7)
/* Create Connection */
#define BLE_HCI_CREATE_CONN_LEN (25)
#define BLE_HCI_CONN_ITVL (1250) /* usecs */
#define BLE_HCI_CONN_FILT_NO_WL (0)
#define BLE_HCI_CONN_FILT_USE_WL (1)
#define BLE_HCI_CONN_FILT_MAX (1)
#define BLE_HCI_CONN_ITVL_MIN (0x0006)
#define BLE_HCI_CONN_ITVL_MAX (0x0c80)
#define BLE_HCI_CONN_LATENCY_MIN (0x0000)
#define BLE_HCI_CONN_LATENCY_MAX (0x01f3)
#define BLE_HCI_CONN_SPVN_TIMEOUT_MIN (0x000a)
#define BLE_HCI_CONN_SPVN_TIMEOUT_MAX (0x0c80)
#define BLE_HCI_CONN_SPVN_TMO_UNITS (10) /* msecs */
#define BLE_HCI_INITIATOR_FILT_POLICY_MAX (1)
/* Peer Address Type */
#define BLE_HCI_CONN_PEER_ADDR_PUBLIC (0)
#define BLE_HCI_CONN_PEER_ADDR_RANDOM (1)
#define BLE_HCI_CONN_PEER_ADDR_PUB_ID (2)
#define BLE_HCI_CONN_PEER_ADDR_RAND_ID (3)
#define BLE_HCI_CONN_PEER_ADDR_MAX (3)
/* --- LE connection update (OCF 0x0013) */
#define BLE_HCI_CONN_UPDATE_LEN (14)
/* --- LE read remote features (OCF 0x0016) */
#define BLE_HCI_CONN_RD_REM_FEAT_LEN (2)
/* --- LE remote connection parameter request reply (OCF 0x0020) */
#define BLE_HCI_CONN_PARAM_REPLY_LEN (14)
/* --- LE remote connection parameter request negative reply (OCF 0x0021) */
#define BLE_HCI_CONN_PARAM_NEG_REPLY_LEN (3)
/* Event Codes */
#define BLE_HCI_EVCODE_INQUIRY_CMP (0x01)
#define BLE_HCI_EVCODE_INQUIRY_RESULT (0x02)
#define BLE_HCI_EVCODE_CONN_DONE (0x03)
#define BLE_HCI_EVCODE_CONN_REQUEST (0x04)
#define BLE_HCI_EVCODE_DISCONN_CMP (0x05)
#define BLE_HCI_EVCODE_AUTH_CMP (0x06)
#define BLE_HCI_EVCODE_REM_NAME_REQ_CMP (0x07)
#define BLE_HCI_EVCODE_ENCRYPT_CHG (0x08)
#define BLE_HCI_EVCODE_CHG_LINK_KEY_CMP (0x09)
#define BLE_HCI_EVCODE_MASTER_LINK_KEY_CMP (0x0A)
#define BLE_HCI_EVCODE_RD_REM_SUPP_FEAT_CMP (0x0B)
#define BLE_HCI_EVCODE_RD_REM_VER_INFO_CMP (0x0C)
#define BLE_HCI_EVCODE_QOS_SETUP_CMP (0x0D)
#define BLE_HCI_EVCODE_COMMAND_COMPLETE (0x0E)
#define BLE_HCI_EVCODE_COMMAND_STATUS (0x0F)
#define BLE_HCI_EVCODE_HW_ERROR (0x10)
#define BLE_HCI_EVCODE_NUM_COMP_PKTS (0x13)
#define BLE_HCI_EVCODE_MODE_CHANGE (0x14)
#define BLE_HCI_EVCODE_RETURN_LINK_KEYS (0x15)
#define BLE_HCI_EVCODE_PIN_CODE_REQ (0x16)
#define BLE_HCI_EVCODE_LINK_KEY_REQ (0x17)
#define BLE_HCI_EVCODE_LINK_KEY_NOTIFY (0x18)
#define BLE_HCI_EVCODE_LOOPBACK_CMD (0x19)
#define BLE_HCI_EVCODE_DATA_BUF_OVERFLOW (0x1A)
#define BLE_HCI_EVCODE_MAX_SLOTS_CHG (0x1B)
#define BLE_HCI_EVCODE_READ_CLK_OFF_COMP (0x1C)
#define BLE_HCI_EVCODE_CONN_PKT_TYPE_CHG (0x1D)
#define BLE_HCI_EVCODE_QOS_VIOLATION (0x1E)
/* NOTE: 0x1F not defined */
#define BLE_HCI_EVCODE_PSR_MODE_CHG (0x20)
#define BLE_HCI_EVCODE_FLOW_SPEC_COMP (0x21)
#define BLE_HCI_EVCODE_INQ_RESULT_RSSI (0x22)
#define BLE_HCI_EVCODE_READ_REM_EXT_FEAT (0x23)
/* NOTE: 0x24 - 0x2B not defined */
#define BLE_HCI_EVCODE_SYNCH_CONN_COMP (0x2C)
#define BLE_HCI_EVCODE_SYNCH_CONN_CHG (0x2D)
#define BLE_HCI_EVCODE_SNIFF_SUBRATING (0x2E)
#define BLE_HCI_EVCODE_EXT_INQ_RESULT (0x2F)
#define BLE_HCI_EVCODE_ENC_KEY_REFRESH (0x30)
#define BLE_HCI_EVOCDE_IO_CAP_REQ (0x31)
#define BLE_HCI_EVCODE_IO_CAP_RSP (0x32)
#define BLE_HCI_EVCODE_USER_CONFIRM_REQ (0x33)
#define BLE_HCI_EVCODE_PASSKEY_REQ (0x34)
#define BLE_HCI_EVCODE_REM_OOB_DATA_REQ (0x35)
#define BLE_HCI_EVCODE_SIMPLE_PAIR_COMP (0x36)
/* NOTE: 0x37 not defined */
#define BLE_HCI_EVCODE_LNK_SPVN_TMO_CHG (0x38)
#define BLE_HCI_EVCODE_ENH_FLUSH_COMP (0x39)
#define BLE_HCI_EVCODE_USER_PASSKEY_NOTIFY (0x3B)
#define BLE_HCI_EVCODE_KEYPRESS_NOTIFY (0x3C)
#define BLE_HCI_EVCODE_REM_HOST_SUPP_FEAT (0x3D)
#define BLE_HCI_EVCODE_LE_META (0x3E)
/* NOTE: 0x3F not defined */
#define BLE_HCI_EVCODE_PHYS_LINK_COMP (0x40)
#define BLE_HCI_EVCODE_CHAN_SELECTED (0x41)
#define BLE_HCI_EVCODE_DISCONN_PHYS_LINK (0x42)
#define BLE_HCI_EVCODE_PHYS_LINK_LOSS_EARLY (0x43)
#define BLE_HCI_EVCODE_PHYS_LINK_RECOVERY (0x44)
#define BLE_HCI_EVCODE_LOGICAL_LINK_COMP (0x45)
#define BLE_HCI_EVCODE_DISCONN_LOGICAL_LINK (0x46)
#define BLE_HCI_EVCODE_FLOW_SPEC_MODE_COMP (0x47)
#define BLE_HCI_EVCODE_NUM_COMP_DATA_BLKS (0x48)
#define BLE_HCI_EVCODE_AMP_START_TEST (0x49)
#define BLE_HCI_EVOCDE_AMP_TEST_END (0x4A)
#define BLE_HCI_EVOCDE_AMP_RCVR_REPORT (0x4B)
#define BLE_HCI_EVCODE_SHORT_RANGE_MODE_CHG (0x4C)
#define BLE_HCI_EVCODE_AMP_STATUS_CHG (0x4D)
#define BLE_HCI_EVCODE_TRIG_CLK_CAPTURE (0x4E)
#define BLE_HCI_EVCODE_SYNCH_TRAIN_COMP (0x4F)
#define BLE_HCI_EVCODE_SYNCH_TRAIN_RCVD (0x50)
#define BLE_HCI_EVCODE_SLAVE_BCAST_RX (0x51)
#define BLE_HCI_EVCODE_SLAVE_BCAST_TMO (0x52)
#define BLE_HCI_EVCODE_TRUNC_PAGE_COMP (0x53)
#define BLE_HCI_EVCODE_SLAVE_PAGE_RSP_TMO (0x54)
#define BLE_HCI_EVCODE_SLAVE_BCAST_CHAN_MAP (0x55)
#define BLE_HCI_EVCODE_INQ_RSP_NOTIFY (0x56)
#define BLE_HCI_EVCODE_AUTH_PYLD_TMO (0x57)
/* LE sub-event codes */
#define BLE_HCI_LE_SUBEV_CONN_COMPLETE (0x01)
#define BLE_HCI_LE_SUBEV_ADV_RPT (0x02)
#define BLE_HCI_LE_SUBEV_CONN_UPD_COMPLETE (0x03)
#define BLE_HCI_LE_SUBEV_RD_REM_USED_FEAT (0x04)
#define BLE_HCI_LE_SUBEV_LT_KEY_REQ (0x05)
#define BLE_HCI_LE_SUBEV_REM_CONN_PARM_REQ (0x06)
#define BLE_HCI_LE_SUBEV_DATA_LEN_CHG (0x07)
#define BLE_HCI_LE_SUBEV_RD_LOC_P256_PUBKEY (0x08)
#define BLE_HCI_LE_SUBEV_GEN_DHKEY_COMPLETE (0x09)
#define BLE_HCI_LE_SUBEV_ENH_CONN_COMPLETE (0x0A)
#define BLE_HCI_LE_SUBEV_DIRECT_ADV_RPT (0x0B)
/* Generic event header */
#define BLE_HCI_EVENT_HDR_LEN (2)
/* Event specific definitions */
/* Event disconnect complete */
#define BLE_HCI_EVENT_DISCONN_COMPLETE_LEN (4)
/* Event command complete */
#define BLE_HCI_EVENT_CMD_COMPLETE_HDR_LEN (5)
#define BLE_HCI_EVENT_CMD_COMPLETE_MIN_LEN (6)
/* Event command status */
#define BLE_HCI_EVENT_CMD_STATUS_LEN (6)
/* Number of completed packets */
#define BLE_HCI_EVENT_NUM_COMP_PKTS_HDR_LEN (1)
#define BLE_HCI_EVENT_NUM_COMP_PKTS_ENT_LEN (4)
/* Read remote version informaton */
#define BLE_HCI_EVENT_RD_RM_VER_LEN (8)
/* Advertising report */
#define BLE_HCI_ADV_RPT_EVTYPE_ADV_IND (0)
#define BLE_HCI_ADV_RPT_EVTYPE_DIR_IND (1)
#define BLE_HCI_ADV_RPT_EVTYPE_SCAN_IND (2)
#define BLE_HCI_ADV_RPT_EVTYPE_NONCONN_IND (3)
#define BLE_HCI_ADV_RPT_EVTYPE_SCAN_RSP (5)
/* LE sub-event specific definitions */
#define BLE_HCI_LE_MIN_LEN (1) /* Not including event hdr. */
/* LE connection complete event (sub event 0x01) */
#define BLE_HCI_LE_CONN_COMPLETE_LEN (19)
#define BLE_HCI_LE_CONN_COMPLETE_ROLE_MASTER (0x00)
#define BLE_HCI_LE_CONN_COMPLETE_ROLE_SLAVE (0x01)
/* LE advertising report event. (sub event 0x02) */
#define BLE_HCI_LE_ADV_RPT_MIN_LEN (12)
#define BLE_HCI_LE_ADV_RPT_NUM_RPTS_MIN (1)
#define BLE_HCI_LE_ADV_RPT_NUM_RPTS_MAX (0x19)
/* LE connection update complete event (sub event 0x03) */
#define BLE_HCI_LE_CONN_UPD_LEN (10)
/* LE connection update complete event (sub event 0x03) */
#define BLE_HCI_LE_RD_REM_USED_FEAT_LEN (12)
/* LE remote connection parameter request event (sub event 0x06) */
#define BLE_HCI_LE_REM_CONN_PARM_REQ_LEN (11)
/* LE data length change event (sub event 0x07) */
#define BLE_HCI_LE_DATA_LEN_CHG_LEN (11)
/*--- Shared data structures ---*/
/* Read local version information (OGF=0x0004, OCF=0x0001) */
struct hci_loc_ver_info
{
uint8_t status;
uint8_t hci_version;
uint16_t hci_revision;
uint8_t lmp_pal_version;
uint16_t mfrg_name;
uint8_t lmp_pal_subversion;
};
/* set advertising parameters command (ocf = 0x0006) */
struct hci_adv_params
{
uint8_t adv_type;
uint8_t adv_channel_map;
uint8_t own_addr_type;
uint8_t peer_addr_type;
uint8_t adv_filter_policy;
uint16_t adv_itvl_min;
uint16_t adv_itvl_max;
uint8_t peer_addr[BLE_DEV_ADDR_LEN];
};
/* LE create connection command */
struct hci_create_conn
{
uint16_t scan_itvl;
uint16_t scan_window;
uint8_t filter_policy;
uint8_t peer_addr_type;
uint8_t peer_addr[BLE_DEV_ADDR_LEN];
uint8_t own_addr_type;
uint16_t conn_itvl_min;
uint16_t conn_itvl_max;
uint16_t conn_latency;
uint16_t supervision_timeout;
uint16_t min_ce_len;
uint16_t max_ce_len;
};
/* LE connection update command */
struct hci_conn_update
{
uint16_t handle;
uint16_t conn_itvl_min;
uint16_t conn_itvl_max;
uint16_t conn_latency;
uint16_t supervision_timeout;
uint16_t min_ce_len;
uint16_t max_ce_len;
};
/* LE Remote connection parameter request reply command */
struct hci_conn_param_reply
{
uint16_t handle;
uint16_t conn_itvl_min;
uint16_t conn_itvl_max;
uint16_t conn_latency;
uint16_t supervision_timeout;
uint16_t min_ce_len;
uint16_t max_ce_len;
};
/* LE Remote connection parameter request negative reply command */
struct hci_conn_param_neg_reply
{
uint16_t handle;
uint8_t reason;
};
/* Connection complete LE meta subevent */
struct hci_le_conn_complete
{
uint8_t subevent_code;
uint8_t status;
uint16_t connection_handle;
uint8_t role;
uint8_t peer_addr_type;
uint8_t peer_addr[BLE_DEV_ADDR_LEN];
uint16_t conn_itvl;
uint16_t conn_latency;
uint16_t supervision_timeout;
uint8_t master_clk_acc;
};
/* Connection update complete LE meta subevent */
struct hci_le_conn_upd_complete
{
uint8_t subevent_code;
uint8_t status;
uint16_t connection_handle;
uint16_t conn_itvl;
uint16_t conn_latency;
uint16_t supervision_timeout;
};
/* Remote connection parameter request LE meta subevent */
struct hci_le_conn_param_req
{
uint8_t subevent_code;
uint16_t connection_handle;
uint16_t itvl_min;
uint16_t itvl_max;
uint16_t latency;
uint16_t timeout;
};
/* Disconnection complete event (note: fields out of order). */
struct hci_disconn_complete
{
uint16_t connection_handle;
uint8_t status;
uint8_t reason;
};
/* Read RSSI command-complete parameters (note: fields out of order). */
struct hci_read_rssi_ack_params
{
uint16_t connection_handle;
uint8_t status;
int8_t rssi;
};
#define BLE_HCI_DATA_HDR_SZ 4
#define BLE_HCI_DATA_HANDLE(handle_pb_bc) (((handle_pb_bc) & 0x0fff) >> 0)
#define BLE_HCI_DATA_PB(handle_pb_bc) (((handle_pb_bc) & 0x3000) >> 12)
#define BLE_HCI_DATA_BC(handle_pb_bc) (((handle_pb_bc) & 0xc000) >> 14)
struct hci_data_hdr
{
uint16_t hdh_handle_pb_bc;
uint16_t hdh_len;
};
#define BLE_HCI_PB_FIRST_NON_FLUSH 0
#define BLE_HCI_PB_MIDDLE 1
#define BLE_HCI_PB_FIRST_FLUSH 2
#define BLE_HCI_PB_FULL 3
#endif /* H_BLE_HCI_COMMON_ */