2614 lines
83 KiB
C
2614 lines
83 KiB
C
#ifndef CO_BT_DEFINES_H_
|
|
#define CO_BT_DEFINES_H_
|
|
|
|
|
|
/**
|
|
****************************************************************************************
|
|
* @addtogroup CO_BT_DEFINES Common Bluetooth defines
|
|
* @ingroup CO_BT
|
|
* @brief Common Bluetooth definitions and structures.
|
|
*
|
|
* @{
|
|
****************************************************************************************
|
|
*/
|
|
|
|
|
|
/*
|
|
* DEFINES
|
|
****************************************************************************************
|
|
*/
|
|
|
|
/**
|
|
* BD Address format (values in bytes)
|
|
* | 3B | 1B | 2B |
|
|
* | LAP | UAP | NAP |
|
|
*/
|
|
#define BD_ADDR_LEN 6
|
|
#define BD_ADDR_LAP_POS 0
|
|
#define BD_ADDR_LAP_LEN 3
|
|
#define BD_ADDR_UAP_POS BD_ADDR_LAP_LEN
|
|
#define BD_ADDR_UAP_LEN 1
|
|
#define BD_ADDR_NAP_POS BD_ADDR_UAP_LEN
|
|
#define BD_ADDR_NAP_LEN 2
|
|
|
|
///Length of fields in Bluetooth messages, in number of bytes
|
|
#define EVT_MASK_LEN 8
|
|
#define DEV_CLASS_LEN 3
|
|
#define ACO_LEN 12
|
|
#define SRES_LEN 0x04
|
|
#define ACCESS_ADDR_LEN 0x04
|
|
#define LE_PASSKEY_LEN 0x04
|
|
#define BD_NAME_SIZE 0xF8 // Was 0x20 for BLE HL
|
|
#define ADV_DATA_LEN 0x1F
|
|
#define EXT_ADV_DATA_MAX_LEN 229 // HCI:7.7.65.13
|
|
#define PER_ADV_DATA_MAX_LEN 248 // HCI:7.7.65.16
|
|
#define BLE_DATA_LEN 0x1F
|
|
#define BLE_ADV_FLAG_PART_LEN 0x03
|
|
#define BLE_ADV_DATA_WITHOUT_FLAG_LEN (BLE_DATA_LEN)
|
|
#define BLE_ADV_DATA_WITH_FLAG_LEN (BLE_DATA_LEN - BLE_ADV_FLAG_PART_LEN)
|
|
#define SCAN_RSP_DATA_LEN (BLE_DATA_LEN)
|
|
#define CONNECT_REQ_DATA_LEN 0x16
|
|
#define LE_CHNL_MAP_LEN 0x05
|
|
#define CHNL_MAP_LEN 0x0A
|
|
#define KEY_LEN 0x10
|
|
#define PIN_CODE_MIN_LEN 0x01
|
|
#define PIN_CODE_MAX_LEN 0x10
|
|
#define PRIV_KEY_192_LEN 24
|
|
#define PUB_KEY_192_LEN 48
|
|
#define PRIV_KEY_256_LEN 32
|
|
#define PUB_KEY_256_LEN 64
|
|
#define CFM_LEN 0x10
|
|
#define ENC_DATA_LEN 0x10
|
|
#define RAND_VAL_LEN 0x10
|
|
#define RAND_NB_LEN 0x08
|
|
#define LE_FEATS_LEN 0x08
|
|
#define SUPP_CMDS_LEN 0x40
|
|
#define FEATS_LEN 0x08
|
|
#define NAME_VECT_SIZE 14
|
|
#define LMP_FEATS_LEN 0x08
|
|
#define LE_STATES_LEN 0x08
|
|
#define WHITE_LIST_LEN 0x0A
|
|
#define LE_FREQ_LEN 0x28
|
|
#define LE_DATA_FREQ_LEN 0x25
|
|
#define CRC_INIT_LEN 0x03
|
|
#define SESS_KEY_DIV_LEN 0x08
|
|
#define INIT_VECT_LEN 0x04
|
|
#define MIC_LEN 0x04
|
|
#define IV_LEN 0x08
|
|
#define SK_DIV_LEN 0x10
|
|
|
|
// Session Key Diversifier Master or slave
|
|
#define SKD_M_OFFSET 0x00
|
|
#define SKD_S_OFFSET 0x08
|
|
// Initialization Vector Master or slave
|
|
#define IV_M_OFFSET 0x00
|
|
#define IV_S_OFFSET 0x04
|
|
|
|
|
|
// BT 4.2 - Secure Connections
|
|
#define PUBLIC_KEY_P256_LEN 0x20
|
|
#define DHKEY_CHECK_LEN 0x10
|
|
|
|
#define DH_KEY_LEN 0x20
|
|
|
|
/// Maximum maskable event code
|
|
#define EVT_MASK_CODE_MAX EVT_MASK_LEN * 8
|
|
|
|
/// Advertising and Data Channel Indices (chapter 6.B.1.4.1)
|
|
#define DATA_CHANNEL_MIN 0
|
|
#define DATA_CHANNEL_MAX 36
|
|
#define DATA_CHANNEL_NB 37
|
|
#define ADV_CHANNEL_37 37
|
|
#define ADV_CHANNEL_38 38
|
|
#define ADV_CHANNEL_39 39
|
|
|
|
/// Minimum number of used channel in the map (chapter 6.B.4.5.8.1)
|
|
#define DATA_CHANNEL_USED_NB_MIN 2
|
|
|
|
/// Advertising interval (in 625us slot) (chapter 2.E.7.8.5)
|
|
#define ADV_INTERVAL_MIN 0x0020 //(20 ms)
|
|
#define ADV_INTERVAL_MAX 0x4000 //(10.24 sec)
|
|
#define ADV_INTERVAL_DFT 0x0800 //(1.28 sec)
|
|
|
|
/// Scanning interval (in 625us slot) (chapter 2.E.7.8.10)
|
|
#define SCAN_INTERVAL_MIN 0x0004 //(2.5 ms)
|
|
#define SCAN_INTERVAL_MAX 0x4000 //(10.24 sec)
|
|
#define SCAN_INTERVAL_DFT 0x0010 //(10 ms)
|
|
|
|
/// Scanning window (in 625us slot) (chapter 2.E.7.8.10)
|
|
#define SCAN_WINDOW_MIN 0x0004 //(2.5 ms)
|
|
#define SCAN_WINDOW_MAX 0x4000 //(10.24 sec)
|
|
#define SCAN_WINDOW_DFT 0x0010 //(10 ms)
|
|
|
|
/// Connection interval (N*1.250ms) (chapter 2.E.7.8.12)
|
|
#define CON_INTERVAL_MIN 0x0006 //(7.5 msec)
|
|
#define CON_INTERVAL_MAX 0x0C80 //(4 sec)
|
|
/// Connection latency (N*cnx evt) (chapter 2.E.7.8.12)
|
|
#define CON_LATENCY_MIN 0x0000
|
|
#define CON_LATENCY_MAX 0x01F3 // (499)
|
|
/// Supervision TO (N*10ms) (chapter 2.E.7.8.12)
|
|
#define CON_SUP_TO_MIN 0x000A //(100 msec)
|
|
#define CON_SUP_TO_MAX 0x0C80 //(32 sec)
|
|
|
|
/// Format of the Advertising packets
|
|
#define ADV_ADDR_OFFSET 0
|
|
#define ADV_ADDR_LEN BD_ADDR_LEN
|
|
#define ADV_DATA_OFFSET (ADV_ADDR_OFFSET + ADV_ADDR_LEN)
|
|
|
|
/// BLE supported features
|
|
//byte 0
|
|
#define BLE_ENC_FEAT 0x01
|
|
#define BLE_CON_PARAM_REQ_PROC_FEAT 0x02
|
|
#define BLE_REJ_IND_EXT_FEAT 0x04
|
|
#define BLE_SLAVE_INIT_EXCHG_FEAT 0x08
|
|
#define BLE_PING_FEAT 0x10
|
|
#define BLE_LENGTH_EXT_FEAT 0x20
|
|
#define BLE_LL_PRIVACY_FEAT 0x40
|
|
#define BLE_EXT_SCAN_POLICY_FEAT 0x80
|
|
|
|
//byte 1
|
|
#define BLE_2M_PHY_FEAT 0x01
|
|
#define BLE_STABLE_MOD_IDX_TX_FEAT 0x02
|
|
#define BLE_STABLE_MOD_IDX_RX_FEAT 0x04
|
|
#define BLE_CODED_PHY_FEAT 0x08
|
|
#define BLE_EXT_ADV_FEAT 0x10
|
|
#define BLE_PER_ADV_FEAT 0x20
|
|
#define BLE_CHAN_SEL_ALGO_2_FEAT 0x40
|
|
#define BLEPWR_CLASS_1_FEAT 0x80
|
|
|
|
//byte 2
|
|
#define BLE_MIN_NUM_USED_CHAN_PROC 0x01
|
|
|
|
// List of supported BLE Features
|
|
enum ble_feature
|
|
{
|
|
BLE_FEAT_ENC = (0),
|
|
BLE_FEAT_CON_PARAM_REQ_PROC = (1),
|
|
BLE_FEAT_REJ_IND_EXT = (2),
|
|
BLE_FEAT_SLAVE_INIT_EXCHG = (3),
|
|
BLE_FEAT_PING = (4),
|
|
BLE_FEAT_LENGTH_EXT = (5),
|
|
BLE_FEAT_LL_PRIVACY = (6),
|
|
BLE_FEAT_EXT_SCAN_POLICY = (7),
|
|
BLE_FEAT_2MBPS = (8),
|
|
BLE_FEAT_STABLE_MOD = (9),
|
|
};
|
|
|
|
/// BLE supported states
|
|
//byte 0
|
|
#define BLE_NON_CON_ADV_STATE 0x01
|
|
#define BLE_DISC_ADV_STATE 0x02
|
|
#define BLE_CON_ADV_STATE 0x04
|
|
#define BLE_HDC_DIRECT_ADV_STATE 0x08
|
|
#define BLE_PASS_SCAN_STATE 0x10
|
|
#define BLE_ACTIV_SCAN_STATE 0x20
|
|
#define BLE_INIT_MASTER_STATE 0x40
|
|
#define BLE_CON_SLAVE_STATE 0x80
|
|
|
|
//byte 1
|
|
#define BLE_NON_CON_ADV_PASS_SCAN_STATE 0x01
|
|
#define BLE_DISC_ADV_PASS_SCAN_STATE 0x02
|
|
#define BLE_CON_ADV_PASS_SCAN_STATE 0x04
|
|
#define BLE_HDC_DIRECT_ADV_PASS_SCAN_STATE 0x08
|
|
#define BLE_NON_CON_ADV_ACTIV_SCAN_STATE 0x10
|
|
#define BLE_DISC_ADV_ACTIV_SCAN_STATE 0x20
|
|
#define BLE_CON_ADV_ACTIV_SCAN_STATE 0x40
|
|
#define BLE_HDC_DIRECT_ADV_ACTIV_SCAN_STATE 0x80
|
|
|
|
//byte 2
|
|
#define BLE_NON_CON_ADV_INIT_STATE 0x01
|
|
#define BLE_DISC_ADV_INIT_STATE 0x02
|
|
#define BLE_NON_CON_ADV_MASTER_STATE 0x04
|
|
#define BLE_DISC_ADV_MASTER_STATE 0x08
|
|
#define BLE_NON_CON_ADV_SLAVE_STATE 0x10
|
|
#define BLE_DISC_ADV_SLAVE_STATE 0x20
|
|
#define BLE_PASS_SCAN_INIT_STATE 0x40
|
|
#define BLE_ACTIV_SCAN_INIT_STATE 0x80
|
|
|
|
//byte 3
|
|
#define BLE_PASS_SCAN_MASTER_STATE 0x01
|
|
#define BLE_ACTIV_SCAN_MASTER_STATE 0x02
|
|
#define BLE_PASS_SCAN_SLAVE_STATE 0x04
|
|
#define BLE_ACTIV_SCAN_SLAVE_STATE 0x08
|
|
#define BLE_INIT_MASTER_MASTER_STATE 0x10
|
|
#define BLE_LDC_DIRECT_ADV_STATE 0x20
|
|
#define BLE_LDC_DIRECT_ADV_PASS_SCAN_STATE 0x40
|
|
#define BLE_LDC_DIRECT_ADV_ACTIV_SCAN_STATE 0x80
|
|
|
|
//byte 4
|
|
#define BLE_CON_ADV_INIT_MASTER_SLAVE_STATE 0x01
|
|
#define BLE_HDC_DIRECT_ADV_INIT_MASTER_SLAVE_STATE 0x02
|
|
#define BLE_LDC_DIRECT_ADV_INIT_MASTER_SLAVE_STATE 0x04
|
|
#define BLE_CON_ADV_MASTER_SLAVE_STATE 0x08
|
|
#define BLE_HDC_DIRECT_ADV_MASTER_SLAVE_STATE 0x10
|
|
#define BLE_LDC_DIRECT_ADV_MASTER_SLAVE_STATE 0x20
|
|
#define BLE_CON_ADV_SLAVE_SLAVE_STATE 0x40
|
|
#define BLE_HDC_DIRECT_ADV_SLAVE_SLAVE_STATE 0x80
|
|
|
|
//byte 5
|
|
#define BLE_LDC_DIRECT_ADV_SLAVE_SLAVE_STATE 0x01
|
|
#define BLE_INIT_MASTER_SLAVE_STATE 0x02
|
|
|
|
/// BLE supported commands
|
|
//byte0
|
|
#define BLE_DISC_CMD 0x20
|
|
//byte2
|
|
#define BLE_RD_REM_VERS_CMD 0x80
|
|
//byte5
|
|
#define BLE_SET_EVT_MSK_CMD 0x40
|
|
#define BLE_RESET_CMD 0x80
|
|
//byte10
|
|
#define BLE_RD_TX_PWR_CMD 0x04
|
|
#define BLE_SET_CTRL_TO_HL_FCTRL_CMD 0x20
|
|
#define BLE_HL_BUF_SIZE_CMD 0x40
|
|
#define BLE_HL_NB_CMP_PKT_CMD 0x80
|
|
//byte14
|
|
#define BLE_RD_LOC_VERS_CMD 0x08
|
|
#define BLE_RD_LOC_SUP_FEAT_CMD 0x20
|
|
#define BLE_RD_BUF_SIZE_CMD 0x80
|
|
//byte15
|
|
#define BLE_RD_BD_ADDR_CMD 0x02
|
|
#define BLE_RD_RSSI_CMD 0x20
|
|
//byte22
|
|
#define BLE_SET_EVT_MSK_PG2_CMD 0x04
|
|
//byte25
|
|
#define BLE_LE_SET_EVT_MSK_CMD 0x01
|
|
#define BLE_LE_RD_BUF_SIZE_CMD 0x02
|
|
#define BLE_LE_RD_LOC_SUP_FEAT_CMD 0x04
|
|
#define BLE_LE_SET_RAND_ADDR_CMD 0x10
|
|
#define BLE_LE_SET_ADV_PARAM_CMD 0x20
|
|
#define BLE_LE_RD_ADV_TX_PWR_CMD 0x40
|
|
#define BLE_LE_SET_ADV_DATA_CMD 0x80
|
|
//byte26
|
|
#define BLE_LE_SET_SC_RSP_DATA_CMD 0x01
|
|
#define BLE_LE_SET_ADV_EN_CMD 0x02
|
|
#define BLE_LE_SET_SC_PARAM_CMD 0x04
|
|
#define BLE_LE_SET_SC_EN_CMD 0x08
|
|
#define BLE_LE_CREAT_CNX_CMD 0x10
|
|
#define BLE_LE_CREAT_CNX_CNL_CMD 0x20
|
|
#define BLE_LE_RD_WL_SIZE_CMD 0x40
|
|
#define BLE_LE_CLEAR_WL_CMD 0x80
|
|
//byte27
|
|
#define BLE_LE_ADD_DEV_WL_CMD 0x01
|
|
#define BLE_LE_REM_DEV_WL_CMD 0x02
|
|
#define BLE_LE_CNX_UPDATE_CMD 0x04
|
|
#define BLE_LE_SET_HL_CH_CLASS_CMD 0x08
|
|
#define BLE_LE_RD_CH_MAP_CMD 0x10
|
|
#define BLE_LE_RD_REM_FEAT_CMD 0x20
|
|
#define BLE_LE_ENCRYPT_CMD 0x40
|
|
#define BLE_LE_RAND_CMD 0x80
|
|
//byte28
|
|
#define BLE_LE_START_ENC_CMD 0x01
|
|
#define BLE_LE_LTK_REQ_RPLY_CMD 0x02
|
|
#define BLE_LE_LTK_REQ_NEG_RPLY_CMD 0x04
|
|
#define BLE_LE_RD_SUPP_STATES_CMD 0x08
|
|
#define BLE_LE_RX_TEST_CMD 0x10
|
|
#define BLE_LE_TX_TEST_CMD 0x20
|
|
#define BLE_LE_STOP_TEST_CMD 0x40
|
|
|
|
//byte32
|
|
#define BLE_RD_AUTH_PAYL_TO_CMD 0x10
|
|
#define BLE_WR_AUTH_PAYL_TO_CMD 0x20
|
|
|
|
|
|
//byte33
|
|
#define BLE_LE_REM_CON_PARA_REQ_RPLY_CMD 0x10
|
|
#define BLE_LE_REM_CON_PARA_REQ_NEG_RPLY_CMD 0x20
|
|
#define BLE_LE_SET_DATA_LEN_CMD 0x40
|
|
#define BLE_LE_RD_SUGGTED_DFT_DATA_LEN_CMD 0x80
|
|
|
|
//byte34
|
|
#define BLE_LE_WR_SUGGTED_DFT_DATA_LEN_CMD 0x01
|
|
#define BLE_LE_RD_LOC_P256_PUB_KEY_CMD 0x02
|
|
#define BLE_LE_GEN_DH_KEY_CMD 0x04
|
|
#define BLE_LE_ADD_DEV_TO_RESOLV_LIST_CMD 0x08
|
|
#define BLE_LE_REM_DEV_FROM_RESOLV_LIST_CMD 0x10
|
|
#define BLE_LE_CLEAR_RESOLV_LIST_CMD 0x20
|
|
#define BLE_LE_RD_RESOLV_LIST_SIZE_CMD 0x40
|
|
#define BLE_LE_RD_PEER_RESOLV_ADDR_CMD 0x80
|
|
|
|
//byte35
|
|
#define BLE_LE_RD_LOCAL_RESOLV_ADDR_CMD 0x01
|
|
#define BLE_LE_SET_ADDR_RESOL_CMD 0x02
|
|
#define BLE_LE_SET_RESOLV_PRIV_ADDR_TO_CMD 0x04
|
|
#define BLE_LE_RD_MAX_DATA_LEN_CMD 0x08
|
|
|
|
// Inquiry Length HCI:7.1.1
|
|
#define INQ_LEN_MIN 0x01
|
|
#define INQ_LEN_MAX 0x30
|
|
|
|
// Inquiry Length HCI:7.1.3
|
|
#define INQ_MIN_PER_LEN_MIN 0x0002
|
|
#define INQ_MIN_PER_LEN_MAX 0xFFFE
|
|
#define INQ_MAX_PER_LEN_MIN 0x0003
|
|
#define INQ_MAX_PER_LEN_MAX 0xFFFF
|
|
|
|
// IAC support
|
|
#define NB_IAC_MIN 0x01
|
|
#define NB_IAC_MAX 0x40
|
|
|
|
|
|
/// Logical Transport Adresses BB:4.2
|
|
#define LT_ADDR_BCST 0x00
|
|
#define LT_ADDR_MIN 0x01
|
|
#define LT_ADDR_MAX 0x07
|
|
|
|
/// Link type HCI:7.7.3
|
|
#define SCO_TYPE 0
|
|
#define ACL_TYPE 1
|
|
#define ESCO_TYPE 2
|
|
#define UNKNOWN_TYPE 3 // Used in LM
|
|
#define LE_TYPE 4
|
|
|
|
|
|
/// Allow Role Switch HCI:4.6.8
|
|
#define MASTER_ROLE 0
|
|
#define SLAVE_ROLE 1
|
|
#define UNKNOWN_ROLE 0xFF //Used in LC to init the links role
|
|
|
|
/// Link policy HCI:4.6.9 and HCI:4.6.10
|
|
#define POLICY_SWITCH 0x0001
|
|
#define POLICY_HOLD 0x0002
|
|
#define POLICY_SNIFF 0x0004
|
|
#define POLICY_PARK 0x0008
|
|
|
|
/// Allow Role Switch HCI:4.5.5
|
|
#define ROLE_SWITCH_NOT_ALLOWED 0
|
|
#define ROLE_SWITCH_ALLOWED 1
|
|
|
|
/// AcceptConnection Role HCI:4.5.8
|
|
#define ACCEPT_SWITCH_TO_MASTER 0
|
|
#define ACCEPT_REMAIN_SLAVE 1
|
|
|
|
/// Packet Type Flags HCI:7.1.14
|
|
#define PACKET_TYPE_EDR_MSK 0x330E
|
|
#define PACKET_TYPE_GFSK_MSK 0xCCF8
|
|
#define PACKET_TYPE_NO_2_DH1_FLAG 0x0002
|
|
#define PACKET_TYPE_NO_3_DH1_FLAG 0x0004
|
|
#define PACKET_TYPE_DM1_FLAG 0x0008
|
|
#define PACKET_TYPE_DH1_FLAG 0x0010
|
|
#define PACKET_TYPE_HV1_FLAG 0x0020
|
|
#define PACKET_TYPE_HV2_FLAG 0x0040
|
|
#define PACKET_TYPE_HV3_FLAG 0x0080
|
|
#define PACKET_TYPE_NO_2_DH3_FLAG 0x0100
|
|
#define PACKET_TYPE_NO_3_DH3_FLAG 0x0200
|
|
#define PACKET_TYPE_DM3_FLAG 0x0400
|
|
#define PACKET_TYPE_DH3_FLAG 0x0800
|
|
#define PACKET_TYPE_NO_2_DH5_FLAG 0x1000
|
|
#define PACKET_TYPE_NO_3_DH5_FLAG 0x2000
|
|
#define PACKET_TYPE_DM5_FLAG 0x4000
|
|
#define PACKET_TYPE_DH5_FLAG 0x8000
|
|
|
|
/// Synchronous Packet Types HCI:7.1.14
|
|
#define SYNC_PACKET_TYPE_HV1_FLAG 0x0001
|
|
#define SYNC_PACKET_TYPE_HV2_FLAG 0x0002
|
|
#define SYNC_PACKET_TYPE_HV3_FLAG 0x0004
|
|
#define SYNC_PACKET_TYPE_EV3_FLAG 0x0008
|
|
#define SYNC_PACKET_TYPE_EV4_FLAG 0x0010
|
|
#define SYNC_PACKET_TYPE_EV5_FLAG 0x0020
|
|
|
|
#define SYNC_PACKET_TYPE_NO_EV3_2_FLAG 0x0040
|
|
#define SYNC_PACKET_TYPE_NO_EV3_3_FLAG 0x0080
|
|
#define SYNC_PACKET_TYPE_NO_EV5_2_FLAG 0x0100
|
|
#define SYNC_PACKET_TYPE_NO_EV5_3_FLAG 0x0200
|
|
|
|
#define SYNC_PACKET_TYPE_EV3_2_FLAG 0x0040
|
|
#define SYNC_PACKET_TYPE_EV3_3_FLAG 0x0080
|
|
#define SYNC_PACKET_TYPE_EV5_2_FLAG 0x0100
|
|
#define SYNC_PACKET_TYPE_EV5_3_FLAG 0x0200
|
|
|
|
/// RWBT 1.2
|
|
#define SYNC_EV3_PACKET_SIZE 30
|
|
#define SYNC_EV4_PACKET_SIZE 120
|
|
#define SYNC_EV5_PACKET_SIZE 180
|
|
|
|
/// Packet Boundary Flag HCI:5.4.2
|
|
#define PBF_1ST_NF_HL_FRAG 0x00 // Non-flushable packets
|
|
#define PBF_CONT_HL_FRAG 0x01
|
|
#define PBF_1ST_HL_FRAG 0x02
|
|
#define PBF_CMP_PDU 0x03
|
|
//#define PBF_MASK 0x03
|
|
|
|
/// Broadcast Flag HCI:5.4.2
|
|
#define BCF_P2P 0x00
|
|
#define BCF_ACTIVE_SLV_BCST 0x01
|
|
#define BCF_PARK_SLV_BCST 0x02
|
|
#define BCF_MASK 0x03
|
|
|
|
/// Synchronous Packet Status Flag HCI:5.4.3
|
|
#define CORRECTLY_RX_FLAG 0x00
|
|
#define POSSIBLY_INVALID_FLAG 0x01
|
|
#define NO_RX_DATA_FLAG 0x02
|
|
#define PARTIALLY_LOST_FLAG 0x03
|
|
|
|
/// Park mode defines LMP:3.17
|
|
#define MACCESS_MSK 0x0F
|
|
#define ACCSCHEM_MSK 0xF0
|
|
|
|
/// Support 3 feature pages
|
|
#define FEATURE_PAGE_MAX 3
|
|
|
|
#define FEATURE_PAGE_0 0
|
|
#define FEATURE_PAGE_1 1
|
|
#define FEATURE_PAGE_2 2
|
|
|
|
/// Feature mask definition LMP:3.3
|
|
#define B0_3_SLOT_POS 0
|
|
#define B0_3_SLOT_MSK 0x01
|
|
#define B0_5_SLOT_POS 1
|
|
#define B0_5_SLOT_MSK 0x02
|
|
#define B0_ENC_POS 2
|
|
#define B0_ENC_MSK 0x04
|
|
#define B0_SLOT_OFF_POS 3
|
|
#define B0_SLOT_OFF_MSK 0x08
|
|
#define B0_TIMING_ACCU_POS 4
|
|
#define B0_TIMING_ACCU_MSK 0x10
|
|
#define B0_ROLE_SWITCH_POS 5
|
|
#define B0_ROLE_SWITCH_MSK 0x20
|
|
#define B0_HOLD_MODE_POS 6
|
|
#define B0_HOLD_MODE_MSK 0x40
|
|
#define B0_SNIFF_MODE_POS 7
|
|
#define B0_SNIFF_MODE_MSK 0x80
|
|
|
|
#define B1_PARK_POS 0
|
|
#define B1_PARK_MSK 0x01
|
|
#define B1_RSSI_POS 1
|
|
#define B1_RSSI_MSK 0x02
|
|
#define B1_CQDDR_POS 2
|
|
#define B1_CQDDR_MSK 0x04
|
|
#define B1_SCO_POS 3
|
|
#define B1_SCO_MSK 0x08
|
|
#define B1_HV2_POS 4
|
|
#define B1_HV2_MSK 0x10
|
|
#define B1_HV3_POS 5
|
|
#define B1_HV3_MSK 0x20
|
|
#define B1_MULAW_POS 6
|
|
#define B1_MULAW_MSK 0x40
|
|
#define B1_ALAW_POS 7
|
|
#define B1_ALAW_MSK 0x80
|
|
|
|
#define B2_CVSD_POS 0
|
|
#define B2_CVSD_MSK 0x01
|
|
#define B2_PAGING_PAR_NEGO_POS 1
|
|
#define B2_PAGING_PAR_NEGO_MSK 0x02
|
|
#define B2_PWR_CTRL_POS 2
|
|
#define B2_PWR_CTRL_MSK 0x04
|
|
#define B2_TRANSPARENT_SCO_POS 3
|
|
#define B2_TRANSPARENT_SCO_MSK 0x08
|
|
#define B2_FLOW_CTRL_LAG_POS 4
|
|
#define B2_FLOW_CTRL_LAG_MSK 0x70
|
|
#define B2_BCAST_ENC_POS 7
|
|
#define B2_BCAST_ENC_MSK 0x80
|
|
|
|
#define B3_EDR_2MBPS_ACL_POS 1
|
|
#define B3_EDR_2MBPS_ACL_MSK 0x02
|
|
#define B3_EDR_3MBPS_ACL_POS 2
|
|
#define B3_EDR_3MBPS_ACL_MSK 0x04
|
|
#define B3_ENH_INQSCAN_POS 3
|
|
#define B3_ENH_INQSCAN_MSK 0x08
|
|
#define B3_INT_INQSCAN_POS 4
|
|
#define B3_INT_INQSCAN_MSK 0x10
|
|
#define B3_INT_PAGESCAN_POS 5
|
|
#define B3_INT_PAGESCAN_MSK 0x20
|
|
#define B3_RSSI_INQ_RES_POS 6
|
|
#define B3_RSSI_INQ_RES_MSK 0x40
|
|
#define B3_ESCO_EV3_POS 7
|
|
#define B3_ESCO_EV3_MSK 0x80
|
|
|
|
#define B4_EV4_PKT_POS 0
|
|
#define B4_EV4_PKT_MSK 0x01
|
|
#define B4_EV5_PKT_POS 1
|
|
#define B4_EV5_PKT_MSK 0x02
|
|
#define B4_AFH_CAP_SLV_POS 3
|
|
#define B4_AFH_CAP_SLV_MSK 0x08
|
|
#define B4_AFH_CLASS_SLV_POS 4
|
|
#define B4_AFH_CLASS_SLV_MSK 0x10
|
|
#define B4_BR_EDR_NOT_SUPP_POS 5
|
|
#define B4_BR_EDR_NOT_SUPP_MSK 0x20
|
|
#define B4_LE_SUPP_POS 6
|
|
#define B4_LE_SUPP_MSK 0x40
|
|
#define B4_3_SLOT_EDR_ACL_POS 7
|
|
#define B4_3_SLOT_EDR_ACL_MSK 0x80
|
|
|
|
#define B5_5_SLOT_EDR_ACL_POS 0
|
|
#define B5_5_SLOT_EDR_ACL_MSK 0x01
|
|
#define B5_SSR_POS 1
|
|
#define B5_SSR_MSK 0x02
|
|
#define B5_PAUSE_ENC_POS 2
|
|
#define B5_PAUSE_ENC_MSK 0x04
|
|
#define B5_AFH_CAP_MST_POS 3
|
|
#define B5_AFH_CAP_MST_MSK 0x08
|
|
#define B5_AFH_CLASS_MST_POS 4
|
|
#define B5_AFH_CLASS_MST_MSK 0x10
|
|
#define B5_EDR_ESCO_2MBPS_POS 5
|
|
#define B5_EDR_ESCO_2MBPS_MSK 0x20
|
|
#define B5_EDR_ESCO_3MBPS_POS 6
|
|
#define B5_EDR_ESCO_3MBPS_MSK 0x40
|
|
#define B5_3_SLOT_EDR_ESCO_POS 7
|
|
#define B5_3_SLOT_EDR_ESCO_MSK 0x80
|
|
|
|
#define B6_EIR_POS 0
|
|
#define B6_EIR_MSK 0x01
|
|
#define B6_SIM_LE_BREDR_DEV_CAP_POS 1
|
|
#define B6_SIM_LE_BREDR_DEV_CAP_MSK 0x02
|
|
#define B6_SSP_POS 3
|
|
#define B6_SSP_MSK 0x08
|
|
#define B6_ENCAPS_PDU_POS 4
|
|
#define B6_ENCAPS_PDU_MSK 0x10
|
|
#define B6_ERR_DATA_REP_POS 5
|
|
#define B6_ERR_DATA_REP_MSK 0x20
|
|
#define B6_NONFLUSH_PBF_POS 6
|
|
#define B6_NONFLUSH_PBF_MSK 0x40
|
|
|
|
#define B7_LST_CHANGE_EVT_POS 0
|
|
#define B7_LST_CHANGE_EVT_MSK 0x01
|
|
#define B7_INQRES_TXPOW_POS 1
|
|
#define B7_INQRES_TXPOW_MSK 0x02
|
|
#define B7_ENH_PWR_CTRL_POS 2
|
|
#define B7_ENH_PWR_CTRL_MSK 0x04
|
|
#define B7_EXT_FEATS_POS 7
|
|
#define B7_EXT_FEATS_MSK 0x80
|
|
|
|
/// Extended feature mask definition page 1 LMP:3.3
|
|
#define B0_HOST_SSP_POS 0
|
|
#define B0_HOST_SSP_MSK 0x01
|
|
#define B0_HOST_LE_POS 1
|
|
#define B0_HOST_LE_MSK 0x02
|
|
#define B0_HOST_LE_BR_EDR_POS 2
|
|
#define B0_HOST_LE_BR_EDR_MSK 0x04
|
|
#define B0_HOST_SECURE_CON_POS 3
|
|
#define B0_HOST_SECURE_CON_MSK 0x08
|
|
|
|
/// Extended feature mask definition page 2 LMP:3.3
|
|
#define B0_CSB_MASTER_POS 0
|
|
#define B0_CSB_MASTER_MSK 0x01
|
|
#define B0_CSB_SLAVE_POS 1
|
|
#define B0_CSB_SLAVE_MSK 0x02
|
|
#define B0_SYNC_TRAIN_POS 2
|
|
#define B0_SYNC_TRAIN_MSK 0x04
|
|
#define B0_SYNC_SCAN_POS 3
|
|
#define B0_SYNC_SCAN_MSK 0x08
|
|
#define B0_INQ_RES_NOTIF_EVT_POS 4
|
|
#define B0_INQ_RES_NOTIF_EVT_MSK 0x10
|
|
#define B0_GEN_INTERL_SCAN_POS 5
|
|
#define B0_GEN_INTERL_SCAN_MSK 0x20
|
|
#define B0_COARSE_CLK_ADJ_POS 6
|
|
#define B0_COARSE_CLK_ADJ_MSK 0x40
|
|
|
|
#define B1_SEC_CON_CTRL_POS 0
|
|
#define B1_SEC_CON_CTRL_MSK 0x01
|
|
#define B1_PING_POS 1
|
|
#define B1_PING_MSK 0x02
|
|
#define B1_TRAIN_NUDGING_POS 3
|
|
#define B1_TRAIN_NUDGING_MSK 0x08
|
|
|
|
/// Features definitions
|
|
#define FEAT_3_SLOT_BIT_POS 0
|
|
#define FEAT_5_SLOT_BIT_POS 1
|
|
#define FEAT_ENC_BIT_POS 2
|
|
#define FEAT_SLOT_OFFSET_BIT_POS 3
|
|
#define FEAT_TIMING_ACC_BIT_POS 4
|
|
#define FEAT_SWITCH_BIT_POS 5
|
|
#define FEAT_HOLD_BIT_POS 6
|
|
#define FEAT_SNIFF_BIT_POS 7
|
|
|
|
#define FEAT_PARK_BIT_POS 8
|
|
#define FEAT_RSSI_BIT_POS 9
|
|
#define FEAT_QUALITY_BIT_POS 10
|
|
#define FEAT_SCO_BIT_POS 11
|
|
#define FEAT_HV2_BIT_POS 12
|
|
#define FEAT_HV3_BIT_POS 13
|
|
#define FEAT_ULAW_BIT_POS 14
|
|
#define FEAT_ALAW_BIT_POS 15
|
|
|
|
#define FEAT_CVSD_BIT_POS 16
|
|
#define FEAT_PAGING_BIT_POS 17
|
|
#define FEAT_POWER_BIT_POS 18
|
|
#define FEAT_TRANSP_SCO_BIT_POS 19
|
|
#define FEAT_BCAST_ENCRYPT_BIT_POS 23
|
|
|
|
#define FEAT_EDR_2MB_BIT_POS 25
|
|
#define FEAT_EDR_3MB_BIT_POS 26
|
|
#define FEAT_ENH_INQSCAN_BIT_POS 27
|
|
#define FEAT_INT_INQSCAN_BIT_POS 28
|
|
#define FEAT_INT_PAGESCAN_BIT_POS 29
|
|
#define FEAT_RSSI_INQRES_BIT_POS 30
|
|
#define FEAT_EV3_BIT_POS 31
|
|
|
|
#define FEAT_EV4_BIT_POS 32
|
|
#define FEAT_EV5_BIT_POS 33
|
|
#define FEAT_AFH_CAPABLE_S_BIT_POS 35
|
|
#define FEAT_AFH_CLASS_S_BIT_POS 36
|
|
#define FEAT_BR_EDR_NO_SUPP_BIT_POS 37
|
|
#define FEAT_LE_BIT_POS 38
|
|
#define FEAT_3_SLOT_EDR_BIT_POS 39
|
|
#define FEAT_5_SLOT_EDR_BIT_POS 40
|
|
#define FEAT_SNIFF_SUBRAT_BIT_POS 41
|
|
#define FEAT_PAUSE_ENCRYPT_BIT_POS 42
|
|
#define FEAT_AFH_CAPABLE_M_BIT_POS 43
|
|
#define FEAT_AFH_CLASS_M_BIT_POS 44
|
|
#define FEAT_EDR_ESCO_2MB_BIT_POS 45
|
|
#define FEAT_EDR_ESCO_3MB_BIT_POS 46
|
|
#define FEAT_3_SLOT_EDR_ESCO_BIT_POS 47
|
|
#define FEAT_EIR_BIT_POS 48
|
|
#define FEAT_LE_BR_EDR_BIT_POS 49
|
|
#define FEAT_SSP_BIT_POS 51
|
|
#define FEAT_ENCAP_PDU_BIT_POS 52
|
|
#define FEAT_ERRO_DATA_REP_BIT_POS 53
|
|
#define FEAT_NFLUSH_PBF_BIT_POS 54
|
|
#define FEAT_LSTO_CHG_EVT_BIT_POS 56
|
|
#define FEAT_INQ_TXPWR_BIT_POS 57
|
|
#define FEAT_EPC_BIT_POS 58
|
|
#define FEAT_EXT_FEATS_BIT_POS 63
|
|
#define FEAT_SSP_HOST_BIT_POS 64
|
|
#define FEAT_LE_HOST_BIT_POS 65
|
|
#define FEAT_LE_BR_EDR_HOST_BIT_POS 66
|
|
#define FEAT_SEC_CON_HOST_BIT_POS 67
|
|
|
|
#define FEAT_CSB_MASTER_BIT_POS 128
|
|
#define FEAT_CSB_SLAVE_BIT_POS 129
|
|
#define FEAT_SYNC_TRAIN_BIT_POS 130
|
|
#define FEAT_SYNC_SCAN_BIT_POS 131
|
|
#define FEAT_INQ_RES_NOTIF_EVT_BIT_POS 132
|
|
#define FEAT_GEN_INTERL_SCAN_BIT_POS 133
|
|
#define FEAT_COARSE_CLK_ADJ_BIT_POS 134
|
|
#define FEAT_SEC_CON_CTRL_BIT_POS 136
|
|
#define FEAT_PING_BIT_POS 137
|
|
#define FEAT_TRAIN_NUDGING_BIT_POS 139
|
|
|
|
/// Maximum number of feature bits per page (8 bytes x 8 bits)
|
|
#define MAX_FEAT_BITS_PER_PAGE 64
|
|
|
|
/// Poll interval defines LMP:5.2
|
|
#define POLL_INTERVAL_MIN 0x0006
|
|
#define POLL_INTERVAL_DFT 0x0028
|
|
#define POLL_INTERVAL_MAX 0x1000
|
|
|
|
/// Power Adjustment Request LMP:5.2
|
|
#define PWR_ADJ_REQ_DEC_1_STEP 0x00
|
|
#define PWR_ADJ_REQ_INC_1_STEP 0x01
|
|
#define PWR_ADJ_REQ_INC_MAX 0x02
|
|
|
|
/// Power Adjustment Response LMP:5.2
|
|
#define PWR_ADJ_RES_GFSK_POS 0
|
|
#define PWR_ADJ_RES_GFSK_MASK 0x03
|
|
#define PWR_ADJ_RES_DQPSK_POS 2
|
|
#define PWR_ADJ_RES_DQPSK_MASK 0x0C
|
|
#define PWR_ADJ_RES_8DPSK_POS 4
|
|
#define PWR_ADJ_RES_8DPSK_MASK 0x30
|
|
|
|
#define PWR_ADJ_RES_NOT_SUPP 0x00
|
|
#define PWR_ADJ_RES_CHG_1_STEP 0x01
|
|
#define PWR_ADJ_RES_MAX 0x02
|
|
#define PWR_ADJ_RES_MIN 0x03
|
|
|
|
/// Nb of Broadcast retransmissions defines
|
|
#define NB_BROADCAST_DFT 0x01
|
|
|
|
/// Nb of Broadcast CLK_ADJ PDU Baseband:4.1.14.1
|
|
#define NB_BROADCAST_CLK_ADJ 0x06
|
|
|
|
/// Min PCA clk_adj_instant (in slots) LMP:4.1.14.1
|
|
#define PCA_INSTANT_MIN 12
|
|
|
|
/// Piconet Clock Adjustment clk_adj_mode LMP:4.1.14.1
|
|
#define CLK_ADJ_BEFORE_INSTANT 0
|
|
#define CLK_ADJ_AFTER_INSTANT 1
|
|
|
|
|
|
/// Different packet types BaseBand:6.7
|
|
/* Packet and buffer sizes. These sizes do not include payload header (except for FHS
|
|
* packet where there is no payload header) since payload header is written or read by
|
|
* the RWBT in a different control structure part (TX/RXPHDR) */
|
|
#define FHS_PACKET_SIZE 18
|
|
#define DM1_PACKET_SIZE 17
|
|
#define DH1_PACKET_SIZE 27
|
|
#define DH1_2_PACKET_SIZE 54
|
|
#define DH1_3_PACKET_SIZE 83
|
|
#define DV_ACL_PACKET_SIZE 9
|
|
#define DM3_PACKET_SIZE 121
|
|
#define DH3_PACKET_SIZE 183
|
|
#define DH3_2_PACKET_SIZE 367
|
|
#define DH3_3_PACKET_SIZE 552
|
|
#define DM5_PACKET_SIZE 224
|
|
#define DH5_PACKET_SIZE 339
|
|
#define DH5_2_PACKET_SIZE 679
|
|
#define DH5_3_PACKET_SIZE 1021
|
|
#define AUX1_PACKET_SIZE 29
|
|
|
|
#define HV1_PACKET_SIZE 10
|
|
#define HV2_PACKET_SIZE 20
|
|
#define HV3_PACKET_SIZE 30
|
|
#define EV3_PACKET_SIZE 30
|
|
#define EV3_2_PACKET_SIZE 60
|
|
#define EV3_3_PACKET_SIZE 90
|
|
#define EV4_PACKET_SIZE 120
|
|
#define EV5_PACKET_SIZE 180
|
|
#define EV5_2_PACKET_SIZE 360
|
|
#define EV5_3_PACKET_SIZE 540
|
|
|
|
/// SCO Packet coding LMP:5.2
|
|
#define SCO_PACKET_HV1 0x00
|
|
#define SCO_PACKET_HV2 0x01
|
|
#define SCO_PACKET_HV3 0x02
|
|
|
|
/// eSCO Packet coding LMP:5.2
|
|
#define ESCO_PACKET_NULL 0x00
|
|
#define ESCO_PACKET_EV3 0x07
|
|
#define ESCO_PACKET_EV4 0x0C
|
|
#define ESCO_PACKET_EV5 0x0D
|
|
#define ESCO_PACKET_EV3_2 0x26
|
|
#define ESCO_PACKET_EV3_3 0x37
|
|
#define ESCO_PACKET_EV5_2 0x2C
|
|
#define ESCO_PACKET_EV5_3 0x3D
|
|
|
|
/// Max number of HV packet BaseBand:4.4.2.1
|
|
#define MAX_NB_HV1 1
|
|
#define MAX_NB_HV2 2
|
|
#define MAX_NB_HV3 3
|
|
|
|
/// Tsco (ScoInterval) BaseBand:4.4.2.1
|
|
#define TSCO_HV1 2
|
|
#define TSCO_HV2 4
|
|
#define TSCO_HV3 6
|
|
|
|
/* Inquiry train repetition length , Baseband :Table 10.4
|
|
* - 256 repetitions if no SCO
|
|
* - 512 repetitions if 1 SCO
|
|
* - 768 repetitions if 2 SCO */
|
|
#define INQ_TRAIN_LENGTH_NO_SCO 256
|
|
#define INQ_TRAIN_LENGTH_1_SCO 512
|
|
#define INQ_TRAIN_LENGTH_2_SCO 768
|
|
|
|
/* Counter for train length, Npage (N*16 slots) depends on the slave page scan mode and
|
|
* the number of active SCO:
|
|
* | SR mode | no SCO | one SCO | two SCO |
|
|
* | R0 | >=1 | >=2 | >=3 |
|
|
* | R1 | >=128 | >=256 | >=384 |
|
|
* | R2 | >=256 | >=512 | >=768 | */
|
|
#define PAGE_TRAIN_LENGTH_R0 1
|
|
#define PAGE_TRAIN_LENGTH_R1 128
|
|
#define PAGE_TRAIN_LENGTH_R2 256
|
|
|
|
/// Synchronisation defines
|
|
#define NORMAL_SYNC_POS (64 + 4) // End of Synchro word at bit 68 (64 + 4)
|
|
#define SLOT_SIZE 625 // A slot is 625 us
|
|
#define HALF_SLOT_SIZE 625 // A half slot is 312.5 us (in half us)
|
|
|
|
/// Baseband timeout default value, Baseband timers: 1.1
|
|
#define PAGE_RESP_TO_DEF 8
|
|
#define INQ_RESP_TO_DEF 128
|
|
#define NEW_CONNECTION_TO 32
|
|
|
|
/// LMP Response Timeout (in sec)
|
|
#define LMP_RSP_TO 30
|
|
/// LLCP Response Timeout (in units of 10 ms)
|
|
#define LLCP_RSP_TO 3000 // 30 secs
|
|
|
|
/// Athenticated Payload Timeout (in units of 10 ms)
|
|
#define AUTH_PAYL_TO_DFT 0x0BB8 // 30 secs
|
|
#define AUTH_PAYL_TO_MIN 0x0001
|
|
|
|
/// Voice mute pattern defines
|
|
#define MU_LAW_MUTE 0xFF
|
|
#define ALAW_CVSD_MUTE 0x55
|
|
#define TRANSP_MUTE 0x00
|
|
|
|
/// Air Mode LMP:5.2
|
|
#define MU_LAW_MODE 0
|
|
#define A_LAW_MODE 1
|
|
#define CVSD_MODE 2
|
|
#define TRANS_MODE 3
|
|
|
|
/// eSCO negotiation State LMP:5.2
|
|
#define ESCO_NEGO_INIT 0
|
|
#define ESCO_NEGO_LATEST_POSSIBLE 1
|
|
#define ESCO_NEGO_SLOT_VIOLATION 2
|
|
#define ESCO_NEGO_LAT_VIOLATION 3
|
|
#define ESCO_NEGO_UNSUPPORTED 4
|
|
|
|
#define SCO_BANDWIDTH 8000
|
|
#define SYNC_BANDWIDTH_DONT_CARE 0xFFFFFFFF
|
|
|
|
#define SYNC_MIN_LATENCY 0x0004
|
|
#define SYNC_MAX_LATENCY_ESCO_S1 0x0007
|
|
#define SYNC_MAX_LATENCY_ESCO_S2 0x0007
|
|
#define SYNC_MAX_LATENCY_ESCO_S3 0x000A
|
|
#define SYNC_DONT_CARE_LATENCY 0xFFFF
|
|
|
|
#define SYNC_NO_RE_TX 0x00
|
|
#define SYNC_RE_TX_POWER 0x01
|
|
#define SYNC_RE_TX_QUALITY 0x02
|
|
#define SYNC_RE_TX_DONT_CARE 0xFF
|
|
|
|
/// Timing Control Flags LMP:5.2
|
|
#define TIM_CHANGE_FLAG 0x01
|
|
#define INIT2_FLAG 0x02
|
|
#define ACCESS_WIN_FLAG 0x04
|
|
|
|
/// Packet Type Table defines LMP:4.1.11
|
|
#define PACKET_TABLE_1MBPS 0x00
|
|
#define PACKET_TABLE_2_3MBPS 0x01
|
|
|
|
/// Data Rate defines LMP:5.2
|
|
#define FEC_RATE_MSK 0x01
|
|
#define USE_FEC_RATE 0x00
|
|
#define NO_FEC_RATE 0x01
|
|
#define PREF_PACK_MSK 0x06
|
|
#define NO_PREF_PACK_SIZE 0x00
|
|
#define USE_1_SLOT_PACKET 0x02
|
|
#define USE_3_SLOT_PACKET 0x04
|
|
#define USE_5_SLOT_PACKET 0x06
|
|
#define PREF_EDR_MSK 0x18
|
|
#define USE_DM1_ONLY 0x00
|
|
#define USE_2_MBPS_RATE 0x08
|
|
#define USE_3_MBPS_RATE 0x10
|
|
#define PREF_PACK_EDR_MSK 0x60
|
|
#define USE_1_SLOT_EDR_PKT 0x20
|
|
#define USE_3_SLOT_EDR_PKT 0x40
|
|
#define USE_5_SLOT_EDR_PKT 0x60
|
|
|
|
/// EIR Data Size HCI:6.24
|
|
#define EIR_DATA_SIZE 240
|
|
|
|
/// Voice setting HCI:4.7.29 & 4.7.30
|
|
#define INPUT_COD_LIN 0x0000
|
|
#define INPUT_COD_MULAW 0x0100
|
|
#define INPUT_COD_ALAW 0x0200
|
|
#define INPUT_COD_MSK 0x0300
|
|
#define INPUT_COD_OFF 8
|
|
#define INPUT_DATA_1COMP 0x0000
|
|
#define INPUT_DATA_2COMP 0x0040
|
|
#define INPUT_DATA_SMAG 0x0080
|
|
#define INPUT_DATA_UNSIGNED 0x00C0
|
|
#define INPUT_DATAFORM_MSK 0x00C0
|
|
#define INPUT_DATAFORM_OFF 6
|
|
#define INPUT_SAMP_8BIT 0x0000
|
|
#define INPUT_SAMP_16BIT 0x0020
|
|
#define INPUT_SAMPSIZE_MSK 0x0020
|
|
#define INPUT_SAMPSIZE_OFF 5
|
|
#define LIN_PCM_BIT_POS_MSK 0x001C
|
|
#define LIN_PCM_BIT_POS_OFF 2
|
|
#define AIR_COD_CVSD 0x0000
|
|
#define AIR_COD_MULAW 0x0001
|
|
#define AIR_COD_ALAW 0x0002
|
|
#define AIR_COD_TRANS 0x0003
|
|
#define AIR_COD_MSK 0x0003
|
|
#define AIR_COD_OFF 0
|
|
|
|
/// ScanEnable HCI:6.1
|
|
#define BOTH_SCAN_DISABLE 0
|
|
#define INQUIRY_SCAN_ENABLE 1
|
|
#define PAGE_SCAN_ENABLE 2
|
|
#define BOTH_SCAN_ENABLE 3
|
|
|
|
/// PageScanInterval HCI:6.8
|
|
#define PAGE_SCAN_INTV_MIN 0x0012
|
|
#define PAGE_SCAN_INTV_MAX 0x1000
|
|
#define PAGE_SCAN_INTV_DFT 0x0800
|
|
|
|
/// PageScanWindow HCI:6.9
|
|
#define PAGE_SCAN_WIN_MIN 0x0011
|
|
#define PAGE_SCAN_WIN_MAX 0x1000
|
|
#define PAGE_SCAN_WIN_DFT 0x0012
|
|
|
|
/// InquiryScanInterval HCI:6.2
|
|
#define INQ_SCAN_INTV_MIN 0x0012
|
|
#define INQ_SCAN_INTV_MAX 0x1000
|
|
#define INQ_SCAN_INTV_DFT 0x1000
|
|
|
|
/// InquiryScanWindow HCI:6.3
|
|
#define INQ_SCAN_WIN_MIN 0x0011
|
|
#define INQ_SCAN_WIN_MAX 0x1000
|
|
#define INQ_SCAN_WIN_DFT 0x0012
|
|
|
|
/// General/Unlimited Inquiry Access Code (GIAC)
|
|
#define GIAC_LAP_0 0x33
|
|
#define GIAC_LAP_1 0x8B
|
|
#define GIAC_LAP_2 0x9E
|
|
|
|
/// Limited Dedicated Inquiry Access Code (LIAC)
|
|
#define LIAC_LAP_0 0x00
|
|
#define LIAC_LAP_1 0x8B
|
|
#define LIAC_LAP_2 0x9E
|
|
|
|
/// Maximum Dedicated Inquiry Access Code (DIAC MAX)
|
|
#define DIAC_MAX_LAP_0 0x3F
|
|
#define DIAC_MAX_LAP_1 0x8B
|
|
#define DIAC_MAX_LAP_2 0x9E
|
|
|
|
/// PIN Type HCI:6.13
|
|
#define VARIABLE_PIN 0
|
|
#define FIXED_PIN 1
|
|
|
|
/// ConnectionAcceptTimeout HCI:6.7
|
|
#define CON_ACCEPT_TO_MIN 0x00A0
|
|
#define CON_ACCEPT_TO_MAX 0xB540
|
|
#define CON_ACCEPT_TO_DFT 0x1FA0
|
|
|
|
/// PageTimeout HCI:6.6
|
|
#define PAGE_TO_MIN 0x0016
|
|
#define PAGE_TO_MAX 0xFFFF
|
|
#define PAGE_TO_DFT 0x2000
|
|
|
|
/// Clock offset valid flag in clock offset field HCI:7.1.5/7.1.19
|
|
#define CLK_OFFSET_VALID_FLAG_POS 15
|
|
#define CLK_OFFSET_VALID_FLAG_MSK 0x8000
|
|
|
|
/// AuthenticationEnable HCI:4.7.24
|
|
#define AUTH_DISABLED 0x00 // Default
|
|
#define AUTH_ENABLED 0x01
|
|
|
|
/// EncryptionMode HCI:4.7.26
|
|
#define ENC_DISABLED 0x00 // Default
|
|
#define ENC_PP_ENABLED 0x01
|
|
#define ENC_PP_BC_ENABLED 0x02
|
|
|
|
/// AutomaticFlushTimeout HCI:4.7.32
|
|
#define AUTO_FLUSH_TIMEOUT_MAX 0x07FF
|
|
#define AUTO_FLUSH_TIMEOUT_OFF 0x0000
|
|
#define AUTO_FLUSH_TIMEOUT_DFT AUTO_FLUSH_TIMEOUT_OFF // Default (no automatic flush timeout)
|
|
|
|
/// Link Supervision Time Out (in slots) HCI:6.21
|
|
#define LSTO_OFF 0x0000
|
|
#define LSTO_MIN 0x0001
|
|
#define LSTO_DFT 0x7D00 // Default is 20 s
|
|
#define LSTO_MAX 0xFFFF
|
|
|
|
/// PageScanRepetitionMode HCI:4.5.5
|
|
#define R0 0x00
|
|
#define R1 0x01
|
|
#define R2 0x02
|
|
#define PAGESCAN_REP_DEF R1 // Default
|
|
|
|
/// PageScanPeriodMode HCI:4.7.49
|
|
#define P0 0x00 // Default
|
|
#define P1 0x01
|
|
#define P2 0x02
|
|
|
|
/// PageScanMode HCI:4.7.51
|
|
#define MANDATORY_PAGE_SCAN_MODE 0x00 // Default
|
|
|
|
#define OPT_PAGE_SCAN_MODE_1 0x01
|
|
#define OPT_PAGE_SCAN_MODE_2 0x02
|
|
#define OPT_PAGE_SCAN_MODE_3 0x03
|
|
|
|
/// Encryption Enable HCI:4.5.17
|
|
#define ENCRYPTION_OFF 0x00
|
|
#define ENCRYPTION_ON 0x01
|
|
|
|
/// Country Code HCI:4.8.4
|
|
#define NORTH_AMERICA_EUROPE 0x00
|
|
#define FRANCE 0x01
|
|
#define SPAIN 0x02
|
|
#define JAPAN 0x03
|
|
|
|
/// Loopback mode HCI:7.6.2
|
|
#define NO_LOOPBACK 0x00 // Default
|
|
#define LOCAL_LOOPBACK 0x01
|
|
#define REMOTE_LOOPBACK 0x02
|
|
|
|
/// Erroneous Data Reporting HCI:7.3.65
|
|
#define ERR_DATA_REP_DIS 0x00 // Default
|
|
#define ERR_DATA_REP_EN 0x01
|
|
|
|
/// LM modes HCI:5.2.20
|
|
#define LM_ACTIVE_MODE 0x00
|
|
#define LM_HOLD_MODE 0x01
|
|
#define LM_SNIFF_MODE 0x02
|
|
#define LM_PARK_MODE 0x03
|
|
|
|
/// Key Type HCI:5.2.24
|
|
#define COMB_KEY 0
|
|
//#define LOCAL_UNIT_KEY 1
|
|
//#define REMOTE_UNIT_KEY 2
|
|
#define DEBUG_COMB_KEY 3
|
|
#define UNAUTH_COMB_KEY_192 4
|
|
#define AUTH_COMB_KEY_192 5
|
|
#define CHANGED_COMB_KEY 6
|
|
#define UNAUTH_COMB_KEY_256 7
|
|
#define AUTH_COMB_KEY_256 8
|
|
|
|
/// Key Flag HCI:5.4.18
|
|
#define SEMI_PERMANENT_KEY 0x00
|
|
#define TEMPORARY_KEY 0x01
|
|
|
|
/// QOS Service Type HCI:4.6.6
|
|
#define QOS_NO_TRAFFIC 0x00
|
|
#define QOS_BEST_EFFORT 0x01
|
|
#define QOS_GUARANTEED 0x02
|
|
#define QOS_NOTSPECIFIED 0xFF
|
|
|
|
#define QOS_WILD_CARD 0xFFFFFFFF
|
|
|
|
/// RSSI golden range
|
|
#define RSSI_GOLDEN_RG 0x00
|
|
|
|
/// Inquiry TX power level (in dBm) HCI:7.3.62
|
|
#define INQ_TX_PWR_DBM_MIN -70
|
|
#define INQ_TX_PWR_DBM_DFT 0
|
|
#define INQ_TX_PWR_DBM_MAX +20
|
|
|
|
/// Bluetooth Test Mode defines Bluetooth Test Mode: Table 3.2
|
|
|
|
#define PAUSE_MODE 0x00
|
|
#define TXTEST0_MODE 0x01
|
|
#define TXTEST1_MODE 0x02
|
|
#define TXTEST10_MODE 0x03
|
|
#define PRAND_MODE 0x04
|
|
#define ACLLOOP_MODE 0x05
|
|
#define SCOLOOP_MODE 0x06
|
|
#define ACLNOWHIT_MODE 0x07
|
|
#define SCONOWHIT_MODE 0x08
|
|
#define TXTEST1100_MODE 0x09
|
|
#define EXITTEST_MODE 0xFF
|
|
|
|
#define HOPSINGLE 0x00
|
|
#define HOPUSA 0x01
|
|
|
|
#define FIXTXPOW 0x00
|
|
#define ADAPTTXPOW 0x01
|
|
|
|
/// Packet type parameter bit field of LMP_test_control
|
|
#define LMP_TEST_CTRL_PKT_TYPE_CODE_POS 0
|
|
#define LMP_TEST_CTRL_PKT_TYPE_CODE_MSK 0x0F
|
|
#define LMP_TEST_CTRL_PKT_TYPE_LINK_POS 4
|
|
#define LMP_TEST_CTRL_PKT_TYPE_LINK_MSK 0xF0
|
|
#define TEST_ACLSCO 0
|
|
#define TEST_ESCO 1
|
|
#define TEST_EDRACL 2
|
|
#define TEST_EDRESCO 3
|
|
|
|
/// LMP_encapsulated_header parameters LMP:5.3
|
|
#define LMP_ENCAPS_P192_MAJ_TYPE 1
|
|
#define LMP_ENCAPS_P192_MIN_TYPE 1
|
|
#define LMP_ENCAPS_P192_PAYL_LEN 48
|
|
#define LMP_ENCAPS_P192_PAYL_NB 3
|
|
#define LMP_ENCAPS_P256_MAJ_TYPE 1
|
|
#define LMP_ENCAPS_P256_MIN_TYPE 2
|
|
#define LMP_ENCAPS_P256_PAYL_LEN 64
|
|
#define LMP_ENCAPS_P256_PAYL_NB 4
|
|
|
|
/// Number of bits in the passkey code used during Secure Simple Pairing
|
|
#define SSP_PASSKEY_NB_BITS 20
|
|
|
|
// Event Filter HCI 4.7.3
|
|
|
|
/// Filter type
|
|
#define CLEAR_ALL_FILTER_TYPE 0x00
|
|
#define INQUIRY_FILTER_TYPE 0x01
|
|
#define CONNECTION_FILTER_TYPE 0x02
|
|
|
|
/// Filter size
|
|
#define CLEAR_ALL_FILTER_SIZE 0
|
|
|
|
/// Inquiry & Connection Setup Filter Condition Type
|
|
#define ALL_FILTER_CONDITION_TYPE 0x00
|
|
#define CLASS_FILTER_CONDITION_TYPE 0x01
|
|
#define BD_ADDR_FILTER_CONDITION_TYPE 0x02
|
|
|
|
/// Auto Accept Flag
|
|
#define DO_NOT_AUTO_ACCEPT_CONNECTION 0x01
|
|
#define ACCEPT_CONNECTION_SLAVE 0x02
|
|
#define ACCEPT_CONNECTION_MASTER 0x03
|
|
|
|
/// Event Mask HCI 4.7.1
|
|
#define NO_EVENTS_SPECIFIED_FILTER 0x00000000
|
|
#define INQUIRY_COMPLETE_EVENT_FILTER 0x00000001
|
|
#define INQUIRY_RESULT_EVENT_FILTER 0x00000002
|
|
#define CONNECTION_COMPLETE_EVENT_FILTER 0x00000004
|
|
#define CONNECTION_REQUEST_EVENT_FILTER 0x00000008
|
|
#define DISCONNECTION_COMPLETE_EVENT_FILTER 0x00000010
|
|
#define AUTHENTICATION_COMPLETE_EVENT_FILTER 0x00000020
|
|
#define REMOTE_NAME_REQUEST_COMPLETE_EVENT_FILTER 0x00000040
|
|
#define ENCRYPTION_CHANGE_EVENT_FILTER 0x00000080
|
|
#define CHANGE_CONNECTION_LINK_KEY_COMPLETE_EVENT_FILTER 0x00000100
|
|
#define MASTER_LINK_KEY_COMPLETE_EVENT_FILTER 0x00000200
|
|
#define READ_REMOTE_SUPPORTED_FEATURES_COMPLETE_EVENT_FILTER 0x00000400
|
|
#define READ_REMOTE_VERSION_INFORMATION_COMPLETE_EVENT_FILTER 0x00000800
|
|
#define QOS_SETUP_COMPLETE_EVENT_FILTER 0x00001000
|
|
#define COMMAND_COMPLETE_EVENT_FILTER 0x00002000 // Unchecked */
|
|
#define COMMAND_STATUS_EVENT_FILTER 0x00004000 // Unchecked */
|
|
#define HARDWARE_ERROR_EVENT_FILTER 0x00008000
|
|
#define FLUSH_OCCURRED_EVENT_FILTER 0x00010000
|
|
#define ROLE_CHANGE_EVENT_FILTER 0x00020000
|
|
#define NUMBER_OF_COMPLETED_PACKETS_EVENT_FILTER 0x00040000 // Unchecked */
|
|
#define MODE_CHANGE_EVENT_FILTER 0x00080000
|
|
#define RETURN_LINK_KEYS_EVENT_FILTER 0x00100000
|
|
#define PIN_CODE_REQUEST_EVENT_FILTER 0x00200000
|
|
#define LINK_KEY_REQUEST_EVENT_FILTER 0x00400000
|
|
#define LINK_KEY_NOTIFICATION_EVENT_FILTER 0x00800000
|
|
#define LOOPBACK_COMMAND_EVENT_FILTER 0x01000000 // Not implemented */
|
|
#define DATA_BUFFER_OVERFLOW_EVENT_FILTER 0x02000000
|
|
#define MAX_SLOTS_CHANGE_EVENT_FILTER 0x04000000
|
|
#define READ_CLOCK_OFFSET_COMPLETE_EVENT_FILTER 0x08000000
|
|
#define CONNECTION_PACKET_TYPE_CHANGED_EVENT_FILTER 0x10000000
|
|
#define QOS_VIOLATION_EVENT_FILTER 0x20000000
|
|
#define PAGE_SCAN_MODE_CHANGE_EVENT_FILTER 0x40000000 // Deprecated */
|
|
#define PAGE_SCAN_REPETITION_MODE_CHANGE_EVENT_FILTER 0x80000000
|
|
|
|
#define FLOW_SPECIFICATION_COMPLETE_EVENT_FILTER 0x00000001
|
|
#define INQUIRY_RESULT_WITH_RSSI_EVENT_FILTER 0x00000002
|
|
#define READ_REMOTE_EXTENDED_FEATURES_COMPLETE_EVENT_FILTER 0x00000004
|
|
#define SYNCHRONOUS_CONNECTION_COMPLETE_EVENT_FILTER 0x00000800
|
|
#define SYNCHRONOUS_CONNECTION_CHANGE_EVENT_FILTER 0x00001000
|
|
#define SNIFF_SUBRATING_EVENT_FILTER 0x00002000
|
|
#define EXTENDED_INQUIRY_RESULT_EVENT_FILTER 0x00004000
|
|
#define ENCRYPTION_KEY_REFRESH_COMPLETE_EVENT_FILTER 0x00008000
|
|
#define IO_CAPABILITY_REQUEST_EVENT_FILTER 0x00010000
|
|
#define IO_CAPABILITY_REQUEST_REPLY_EVENT_FILTER 0x00020000
|
|
#define USER_CONFIRMATION_REQUEST_EVENT_FILTER 0x00040000
|
|
#define USER_PASSKEY_REQUEST_EVENT_FILTER 0x00080000
|
|
#define REMOTE_OOB_DATA_REQUEST_EVENT_FILTER 0x00100000
|
|
#define SIMPLE_PAIRING_COMPLETE_EVENT_FILTER 0x00200000
|
|
#define LINK_SUPERVISION_TIMEOUT_CHANGE_EVENT_FILTER 0x00800000
|
|
#define ENHANCED_FLUSH_COMPLETE_EVENT_FILTER 0x01000000
|
|
#define USER_PASSKEY_NOTIFICATION_EVENT_FILTER 0x04000000
|
|
#define KEYPRESS_NOTIFICATION_EVENT_FILTER 0x08000000
|
|
#define REM_HOST_SUPPORTED_FEATURES_NOTIFICATION_EVENT_FILTER 0x10000000
|
|
|
|
/// HostControllerToHostFlowControl (ACL) HCI 7.3.40
|
|
#define FLOW_CONTROL_OFF 0x00
|
|
#define FLOW_CONTROL_ACL 0x01
|
|
#define FLOW_CONTROL_SCO 0x02
|
|
#define FLOW_CONTROL_ACL_SCO 0x03
|
|
|
|
/// SynchroinousFlowControlEnable (SCO) HCI 7.3.39
|
|
#define SYNC_FLOW_CONTROL_OFF 0x00
|
|
#define SYNC_FLOW_CONTROL_ON 0x01
|
|
|
|
/// Tx Power HCI:4.7.37
|
|
#define CURRENT_TX_POWER 0x00
|
|
#define MAX_TX_POWER 0x01
|
|
|
|
/// Flow_direction HCI:7.2.13
|
|
#define FLOW_DIR_OUT 0x00
|
|
#define FLOW_DIR_IN 0x01
|
|
|
|
/// Drift and Jitter default value LMP 5.2
|
|
#define DRIFT_BLE_DFT 500
|
|
#define DRIFT_BT_DFT 250
|
|
#define JITTER_DFT 10
|
|
#define DRIFT_BT_ACTIVE_MAX 20 // BB:2.2.5
|
|
|
|
/// Read Stored Link Key HCI:4.7.8
|
|
#define LINK_KEY_BD_ADDR 0x00
|
|
#define LINK_KEY_ALL 0x01
|
|
|
|
/// Read/Write Hold Mode Activity HCI:4.7.35 and 4.7.36
|
|
#define HOLD_MODE_ACTIV_DEFAULT 0x00
|
|
#define HOLD_MODE_ACTIV_SUSP_PAGE_SCAN 0x01
|
|
#define HOLD_MODE_ACTIV_SUSP_INQUIRY_SCAN 0x02
|
|
#define HOLD_MODE_ACTIV_SUSP_PERIODIC_INQ 0x04
|
|
#define HOLD_MODE_ACTIV_NOT_MASK 0xF8
|
|
|
|
/// AFH Mode
|
|
#define AFH_DISABLED 0x00
|
|
#define AFH_ENABLED 0x01
|
|
|
|
/// AFH Reporting Mode
|
|
#define AFH_REPORTING_DISABLED 0x00
|
|
#define AFH_REPORTING_ENABLED 0x01
|
|
|
|
/// AFH channel assessment Mode
|
|
#define AFH_CH_ASS_DISABLED 0x00
|
|
#define AFH_CH_ASS_ENABLED 0x01
|
|
|
|
/// AFH MIn/Max interval, in BT slots (1s - 30s)
|
|
#define AFH_REPORT_INTERVAL_MIN 0x0640
|
|
#define AFH_REPORT_INTERVAL_MAX 0xBB80
|
|
|
|
/// Channel classification values for frequency pairs
|
|
#define AFH_CH_CLASS_UNKNOWN 0x0
|
|
#define AFH_CH_CLASS_GOOD 0x1
|
|
#define AFH_CH_CLASS_RESERVED 0x2
|
|
#define AFH_CH_CLASS_BAD 0x3
|
|
|
|
/// Maximum number of frequencies used in adapted channel hopping sequence
|
|
#define AFH_NB_CHANNEL_MIN 20
|
|
#define AFH_NB_CHANNEL_MAX 79
|
|
|
|
/// Maximum number of frequencies used in synchronization train BB:2.6.4.8
|
|
#define SYNC_TRAIN_CHANNEL_NB 3
|
|
/// Indices of frequencies used in synchronization train
|
|
#define SYNC_TRAIN_CHANNEL_0 0
|
|
#define SYNC_TRAIN_CHANNEL_1 24
|
|
#define SYNC_TRAIN_CHANNEL_2 78
|
|
|
|
/// Maximum delay in synchronization train (in slots) BB:2.7.2
|
|
#define SYNC_TRAIN_DELAY_MAX_DFT 16
|
|
/// Maximum delay in synchronization train for Coarse clock adjustment (in slots) BB:2.7.2
|
|
#define SYNC_TRAIN_DELAY_MAX_CLK_ADJ 4
|
|
/// Synchronization train interval for Coarse clock adjustment (in slots) BB:2.7.2
|
|
#define SYNC_TRAIN_INTV_CLK_ADJ 32
|
|
|
|
/// Future CSB instant value offset for Coarse clock adjustment (in slots) BB: 8.11.2
|
|
#define SYNC_TRAIN_CSB_INSTANT_OFFSET_CLK_ADJ 1600
|
|
|
|
/// Minimum value for synchronization train interval (in slots) HCI:7.3.90
|
|
#define SYNC_TRAIN_INTV_MIN 0x20
|
|
/// Minimum value for synchronization train timeout (in slots) HCI:7.3.90
|
|
#define SYNC_TRAIN_TO_MIN 0x00000002
|
|
/// Maximum value for synchronization train timeout (in slots) HCI:7.3.90
|
|
#define SYNC_TRAIN_TO_MAX 0x07FFFFFE
|
|
|
|
/// Default value for synchronization train interval (in slots) HCI:6.36
|
|
#define SYNC_TRAIN_INTV_DEFAULT 0x80
|
|
/// Default value for synchronization train timeout (in slots) HCI:6.37
|
|
#define SYNC_TRAIN_TO_DEFAULT 0x0002EE00
|
|
/// Default value for synchronization train service data HCI:6.39
|
|
#define SYNC_TRAIN_SVC_DATA_DEFAULT 0x00
|
|
|
|
/// Minimum value for synchronization scan timeout (in slots) HCI:7.1.52
|
|
#define SYNC_SCAN_TO_MIN 0x22
|
|
/// Minimum value for synchronization scan window (in slots) HCI:7.1.52
|
|
#define SYNC_SCAN_WIN_MIN 0x22
|
|
/// Minimum value for synchronization scan interval (in slots) HCI:7.1.52
|
|
#define SYNC_SCAN_INTV_MIN 0x02
|
|
|
|
/// Default value for synchronization scan timeout (in slots) BB: Apppendix B
|
|
#define SYNC_SCAN_TO_DEFAULT 0x2000
|
|
/// Recommended value for synchronization scan window (91.25ms) GAP: Appendix A
|
|
#define SYNC_SCAN_WIN_DEFAULT 0x0092
|
|
/// Recommended value for synchronization scan interval (320 ms) GAP: Appendix A
|
|
#define SYNC_SCAN_INTV_DEFAULT 0x0200
|
|
|
|
/// CSB receive enable HCI:7.1.50
|
|
#define CSB_RX_MODE_DIS 0x00
|
|
#define CSB_RX_MODE_EN 0x01
|
|
|
|
/// CSB fragment HCI:7.2.88
|
|
#define CSB_CONTINUATION_FRAGMENT 0
|
|
#define CSB_STARTING_FRAGMENT 1
|
|
#define CSB_ENDING_FRAGMENT 2
|
|
#define CSB_NO_FRAGMENTATION 3
|
|
|
|
/// CSB max fragment size HCI:7.2.88
|
|
#define CSB_FRAGMENT_SIZE_MAX 0xFF
|
|
|
|
/// MWS Channel_Enable
|
|
#define MWS_CHANNEL_DISABLED 0x00
|
|
#define MWS_CHANNEL_ENABLED 0x01
|
|
|
|
/// MWS Channel_Type
|
|
#define MWS_TDD_CHANNEL_TYPE 0x00
|
|
#define MWS_FDD_CHANNEL_TYPE 0x01
|
|
|
|
/// MWS Transport_Layer
|
|
#define MWS_SIGNALING_ONLY 0x00
|
|
#define MWS_WCI_1 0x01
|
|
#define MWS_WCI_2 0x02
|
|
#define MWS_TRANSPORT_TYPE_MAX 0x02
|
|
|
|
/// MWS PATTERN Index
|
|
#define MWS_PATTERN_INDEX_MAX 2
|
|
|
|
/// MWS PATTERN IntervalType
|
|
#define MWS_PATTERN_NO_TXRX 0
|
|
#define MWS_PATTERN_TX_ALLOWED 1
|
|
#define MWS_PATTERN_RX_ALLOWED 2
|
|
#define MWS_PATTERN_TXRX_ALLOWED 3
|
|
#define MWS_PATTERN_EXT_FRAME 4
|
|
#define MWS_PATTERN_TYPE_MAX 4
|
|
|
|
|
|
/// MWS Ext_Num_Periods
|
|
#define MWS_EXT_NUM_PERIODS_MIN 0x01
|
|
#define MWS_EXT_NUM_PERIODS_MAX 0x32
|
|
|
|
/// MWS Period_Type
|
|
#define MWS_PERIOD_TYPE_DOWNLINK 0x00
|
|
#define MWS_PERIOD_TYPE_UPLINK 0x01
|
|
#define MWS_PERIOD_TYPE_BIDIRECTIONAL 0x02
|
|
#define MWS_PERIOD_TYPE_GUARD_PERIOD 0x03
|
|
#define MWS_PERIOD_TYPE_RESERVED 0x04
|
|
|
|
/// Simple pairing mode HCI:7.3.58/HCI:7.3.59
|
|
#define SP_MODE_DIS 0x00
|
|
#define SP_MODE_EN 0x01
|
|
|
|
/// Inquiry Scan Type and Page Scan Type HCI:6.4/HCI:6.11
|
|
#define STANDARD_SCAN 0x00
|
|
#define INTERLACED_SCAN 0x01
|
|
|
|
/// Default interlace offset used for frequency selection during interlaced inquiry/page scan BB:8.3.1/8.4.1
|
|
#define INTERLACE_OFFSET_DFT 16
|
|
|
|
/// Inquiry Mode
|
|
#define STANDARD_INQUIRY 0x00
|
|
#define RSSI_INQUIRY 0x01
|
|
#define EXTENDED_INQUIRY 0x02
|
|
|
|
/// Maximum number of link keys Host can write via HCI Write Stored Link Key Command
|
|
#define NB_LINK_KEY 0x0B
|
|
|
|
/// LMP Version
|
|
#define BT_LMP_V1_0 0
|
|
#define BT_LMP_V1_1 1
|
|
#define BT_LMP_V1_2 2
|
|
#define BT_LMP_V2_0 3
|
|
#define BT_LMP_V2_1 4
|
|
#define BT_LMP_V3_0 5
|
|
#define BT_LMP_V4_0 6
|
|
#define BT_LMP_V4_1 7
|
|
|
|
/// WhichClock parameter
|
|
#define LOCAL_CLOCK 0
|
|
#define PICONET_CLOCK 1
|
|
|
|
/// Clock Accuracy parameter
|
|
#define CLOCK_ACCURACY_UNKNOWN 0xFFFF
|
|
|
|
#define SP_PASSKEY_STARTED 0x00
|
|
#define SP_PASSKEY_DIGIT_ENTERED 0x01
|
|
#define SP_PASSKEY_DIGIT_ERASED 0x02
|
|
#define SP_PASSKEY_CLEARED 0x03
|
|
#define SP_PASSKEY_COMPLETED 0x04
|
|
|
|
/// Low Power Mode
|
|
#define PARK_BEACON_MIN 0x000E
|
|
|
|
/// RWBT Device can be slave of 2 master at max
|
|
#define MAX_SLAVES_FOR_DIFFERENT_MASTERS 2
|
|
// Flags for ld_util_get_nb_acl function
|
|
/// Flag for master link
|
|
#define MASTER_FLAG 0x01
|
|
/// Flag for slave link
|
|
#define SLAVE_FLAG 0x02
|
|
|
|
|
|
/// BLE packet info in bytes
|
|
#define BLE_PKT_HDR_LEN (2)
|
|
#define BLE_PKT_CRC_LEN (3)
|
|
#define BLE_PKT_ACCESS_LEN (4)
|
|
|
|
/// IFS duration in us
|
|
#define BLE_IFS_DUR (150)
|
|
|
|
|
|
/// BLE event mask
|
|
enum le_evt_mask
|
|
{
|
|
LE_EVT_MASK_CON_CMP_EVT_BIT = 0, //!< LE_EVT_MASK_CON_CMP_EVT_BIT
|
|
LE_EVT_MASK_CON_CMP_EVT_MSK = 0x0001,//!< LE_EVT_MASK_CON_CMP_EVT_MSK
|
|
LE_EVT_MASK_ADV_REP_EVT_BIT = 1, //!< LE_EVT_MASK_ADV_REP_EVT_BIT
|
|
LE_EVT_MASK_ADV_REP_EVT_MSK = 0x0002,//!< LE_EVT_MASK_ADV_REP_EVT_MSK
|
|
LE_EVT_MASK_CON_UPD_EVT_BIT = 2, //!< LE_EVT_MASK_CON_UPD_EVT_BIT
|
|
LE_EVT_MASK_CON_UPD_EVT_MSK = 0x0004,//!< LE_EVT_MASK_CON_UPD_EVT_MSK
|
|
LE_EVT_MASK_CON_RD_REM_FEAT_EVT_BIT = 3, //!< LE_EVT_MASK_CON_RD_REM_FEAT_EVT_BIT
|
|
LE_EVT_MASK_CON_RD_REM_FEAT_EVT_MSK = 0x0008,//!< LE_EVT_MASK_CON_RD_REM_FEAT_EVT_MSK
|
|
LE_EVT_MASK_LG_TR_KEY_REQ_EVT_BIT = 4, //!< LE_EVT_MASK_LG_TR_KEY_REQ_EVT_BIT
|
|
LE_EVT_MASK_LG_TR_KEY_REQ_EVT_MSK = 0x0010,//!< LE_EVT_MASK_LG_TR_KEY_REQ_EVT_MSK
|
|
LE_EVT_MASK_REM_CON_PARA_REQ_EVT_BIT = 5, //!< LE_EVT_MASK_REM_CON_PARA_REQ_EVT_BIT
|
|
LE_EVT_MASK_REM_CON_PARA_REQ_EVT_MSK = 0x0020,//!< LE_EVT_MASK_REM_CON_PARA_REQ_EVT_MSK
|
|
LE_EVT_MASK_DATA_LEN_CHG_EVT_BIT = 6, //!< LE_EVT_MASK_DATA_LEN_CHG_EVT_BIT
|
|
LE_EVT_MASK_DATA_LEN_CHG_EVT_MSK = 0x0040,//!< LE_EVT_MASK_DATA_LEN_CHG_EVT_MSK
|
|
LE_EVT_MASK_RD_LOC_P256_PUB_KEY_CMP_EVT_BIT = 7, //!< LE_EVT_MASK_RD_LOC_P256_PUB_KEY_CMP_EVT_BIT
|
|
LE_EVT_MASK_RD_LOC_P256_PUB_KEY_CMP_EVT_MSK = 0x0080,//!< LE_EVT_MASK_RD_LOC_P256_PUB_KEY_CMP_EVT_MSK
|
|
LE_EVT_MASK_GEN_DHKEY_CMP_EVT_BIT = 8, //!< LE_EVT_MASK_GEN_DHKEY_CMP_EVT_BIT
|
|
LE_EVT_MASK_GEN_DHKEY_CMP_EVT_MSK = 0x0100,//!< LE_EVT_MASK_GEN_DHKEY_CMP_EVT_MSK
|
|
LE_EVT_MASK_ENH_CON_CMP_EVT_BIT = 9, //!< LE_EVT_MASK_ENH_CON_CMP_EVT_BIT
|
|
LE_EVT_MASK_ENH_CON_CMP_EVT_MSK = 0x0200,//!< LE_EVT_MASK_ENH_CON_CMP_EVT_MSK
|
|
LE_EVT_MASK_DIR_ADV_REP_EVT_BIT = 10, //!< LE_EVT_MASK_DIR_ADV_REP_EVT_BIT
|
|
LE_EVT_MASK_DIR_ADV_REP_EVT_MSK = 0x0400,//!< LE_EVT_MASK_DIR_ADV_REP_EVT_MSK
|
|
LE_EVT_MASK_PHY_UPD_CMP_EVT_BIT = 11, //!< LE_EVT_MASK_PHY_UPD_CMP_EVT_BIT
|
|
LE_EVT_MASK_PHY_UPD_CMP_EVT_MSK = 0x0800,//!< LE_EVT_MASK_PHY_UPD_CMP_EVT_MSK
|
|
|
|
LE_EVT_MASK_DFT = 0x001F,//!< LE_EVT_MASK_DFT
|
|
};
|
|
|
|
/// Enhanced Synchronous Connection HCI:7.1.41 & 7.1.42
|
|
#define CODING_FORMAT_ULAW 0x00
|
|
#define CODING_FORMAT_ALAW 0x01
|
|
#define CODING_FORMAT_CVSD 0x02
|
|
#define CODING_FORMAT_TRANSP 0x03
|
|
#define CODING_FORMAT_LINPCM 0x04
|
|
#define CODING_FORMAT_MSBC 0x05
|
|
#define CODING_FORMAT_VENDSPEC 0xFF
|
|
|
|
#define PCM_FORMAT_NA 0x00
|
|
#define PCM_FORMAT_1SCOMP 0x01
|
|
#define PCM_FORMAT_2SCOMP 0x02
|
|
#define PCM_FORMAT_SIGNMAG 0x03
|
|
#define PCM_FORMAT_UNSIGNED 0x04
|
|
|
|
#define PCM_SAMPLE_SIZE_8BITS 8
|
|
#define PCM_SAMPLE_SIZE_16BITS 16
|
|
|
|
#define AUDIO_DATA_PATH_HCI 0
|
|
#define AUDIO_DATA_PATH_PCM 1
|
|
|
|
/// Default maximum number of slots per packet
|
|
#define MAX_SLOT_DFT 1
|
|
|
|
/// Packet type code interpretation possibilities BB:6.5
|
|
#define ID_NUL_TYPE 0x0
|
|
#define POLL_TYPE 0x1
|
|
#define FHS_TYPE 0x2
|
|
#define DM1_TYPE 0x3
|
|
#define DH1_TYPE 0x4
|
|
#define DH1_2_TYPE 0x4
|
|
#define DH1_3_TYPE 0x8
|
|
#define HV1_TYPE 0x5
|
|
#define HV2_TYPE 0x6
|
|
#define EV3_2_TYPE 0x6
|
|
#define HV3_TYPE 0x7
|
|
#define EV3_TYPE 0x7
|
|
#define EV3_3_TYPE 0x7
|
|
#define DV_TYPE 0x8
|
|
#define AUX1_TYPE 0x9
|
|
#define DM3_TYPE 0xA
|
|
#define DH3_TYPE 0xB
|
|
#define DH3_2_TYPE 0xA
|
|
#define DH3_3_TYPE 0xB
|
|
#define EV4_TYPE 0xC
|
|
#define EV5_2_TYPE 0xC
|
|
#define EV5_TYPE 0xD
|
|
#define EV5_3_TYPE 0xD
|
|
#define DM5_TYPE 0xE
|
|
#define DH5_TYPE 0xF
|
|
#define DH5_2_TYPE 0xE
|
|
#define DH5_3_TYPE 0xF
|
|
|
|
/// Format of the FHS payload BB:6.5.1.4
|
|
#define FHS_PAR_BITS_POS 0
|
|
#define FHS_PAR_BITS_LEN 34
|
|
#define FHS_PAR_BITS_END (FHS_PAR_BITS_POS + FHS_PAR_BITS_LEN)
|
|
#define FHS_LAP_POS FHS_PAR_BITS_END
|
|
#define FHS_LAP_LEN 24
|
|
#define FHS_LAP_END (FHS_LAP_POS + FHS_LAP_LEN)
|
|
#define FHS_EIR_POS FHS_LAP_END
|
|
#define FHS_EIR_LEN 1
|
|
#define FHS_EIR_END (FHS_EIR_POS + FHS_EIR_LEN)
|
|
#define FHS_UNDEF_POS FHS_EIR_END
|
|
#define FHS_UNDEF_LEN 1
|
|
#define FHS_UNDEF_END (FHS_UNDEF_POS + FHS_UNDEF_LEN)
|
|
#define FHS_SR_POS FHS_UNDEF_END
|
|
#define FHS_SR_LEN 2
|
|
#define FHS_SR_END (FHS_SR_POS + FHS_SR_LEN)
|
|
#define FHS_RSVD_POS FHS_SR_END
|
|
#define FHS_RSVD_LEN 2
|
|
#define FHS_RSVD_END (FHS_RSVD_POS + FHS_RSVD_LEN)
|
|
#define FHS_UAP_POS FHS_RSVD_END
|
|
#define FHS_UAP_LEN 8
|
|
#define FHS_UAP_END (FHS_UAP_POS + FHS_UAP_LEN)
|
|
#define FHS_NAP_POS FHS_UAP_END
|
|
#define FHS_NAP_LEN 16
|
|
#define FHS_NAP_END (FHS_NAP_POS + FHS_NAP_LEN)
|
|
#define FHS_CLASS_OF_DEV_POS FHS_NAP_END
|
|
#define FHS_CLASS_OF_DEV_LEN 24
|
|
#define FHS_CLASS_OF_DEV_END (FHS_CLASS_OF_DEV_POS + FHS_CLASS_OF_DEV_LEN)
|
|
#define FHS_LT_ADDR_POS FHS_CLASS_OF_DEV_END
|
|
#define FHS_LT_ADDR_LEN 3
|
|
#define FHS_LT_ADDR_END (FHS_LT_ADDR_POS + FHS_LT_ADDR_LEN)
|
|
#define FHS_CLK_POS FHS_LT_ADDR_END
|
|
#define FHS_CLK_LEN 26
|
|
#define FHS_CLK_END (FHS_CLK_POS + FHS_CLK_LEN)
|
|
#define FHS_PAGE_SCAN_MODE_POS FHS_CLK_END
|
|
#define FHS_PAGE_SCAN_MODE_LEN 3
|
|
#define FHS_PAGE_SCAN_MODE_END (FHS_PAGE_SCAN_MODE_POS + FHS_PAGE_SCAN_MODE_LEN)
|
|
|
|
/// Format of the STP payload BB:8.11.2
|
|
#define STP_CLK_POS 0
|
|
#define STP_CLK_LEN 4
|
|
#define STP_FUT_CSB_INST_POS 4
|
|
#define STP_FUT_CSB_INST_LEN 4
|
|
#define STP_AFH_CH_MAP_POS 8
|
|
#define STP_AFH_CH_MAP_LEN 10
|
|
#define STP_MST_BD_ADDR_POS 18
|
|
#define STP_MST_BD_ADDR_LEN 6
|
|
#define STP_CSB_INTV_POS 24
|
|
#define STP_CSB_INTV_LEN 2
|
|
#define STP_CSB_LT_ADDR_POS 26
|
|
#define STP_CSB_LT_ADDR_LEN 1
|
|
#define STP_SVC_DATA_POS 27
|
|
#define STP_SVC_DATA_LEN 1
|
|
#define STP_PACKET_SIZE 28
|
|
|
|
/// CSB Receive status HCI:7.7.69
|
|
#define CSB_RX_OK 0x00
|
|
#define CSB_RX_KO 0x01
|
|
|
|
|
|
/// HCI 7.8.18 LE Connection Update Command
|
|
/// Connection interval min (N*1.250ms)
|
|
#define LE_CNX_INTERVAL_MIN 6 //(0x06)
|
|
/// Connection interval Max (N*1.250ms)
|
|
#define LE_CNX_INTERVAL_MAX 3200 //(0xC80)
|
|
/// Connection latency min (N*cnx evt)
|
|
#define LE_CNX_LATENCY_MIN 0 //(0x00)
|
|
/// Connection latency Max (N*cnx evt
|
|
#define LE_CNX_LATENCY_MAX 500 //(0x1F4)
|
|
/// Supervision TO min (N*10ms)
|
|
#define LE_CNX_SUP_TO_MIN 10 //(0x0A)
|
|
/// Supervision TO Max (N*10ms)
|
|
#define LE_CNX_SUP_TO_MAX 3200 //(0xC80)
|
|
/// Connection event length min (N*0.625ms)
|
|
#define LE_CNX_CE_LGTH_MIN 0 //(0x00)
|
|
/// Connection event length Max (N*0.625ms)
|
|
#define LE_CNX_CE_LGTH_MAX 65535 //(0xFFFF)'
|
|
|
|
|
|
/// HCI 7.8.33 LE Set Data Length Command
|
|
/// Preferred minimum number of payload octets
|
|
#define LE_MIN_OCTETS (27)
|
|
/// Preferred minimum number of microseconds
|
|
#define LE_MIN_TIME (328)
|
|
/// Preferred maximum number of payload octets
|
|
#define LE_MAX_OCTETS (251)
|
|
/// Preferred maximum number of microseconds
|
|
#define LE_MAX_TIME (2120)
|
|
|
|
/// LE LL 2.1.2 Access Address
|
|
#define LE_ADV_CH_ACC_ADDR_H 0x8E89
|
|
#define LE_ADV_CH_ACC_ADDR_L 0xBED6
|
|
|
|
/// Resolvable private address timeout (in seconds) HCI:7.8.45
|
|
#define RPA_TO_MAX 0xA1B8 // approximately 11.5 hours
|
|
#define RPA_TO_DFT 0x0384 // 900 seconds or 15 minutes
|
|
#define RPA_TO_MIN 0x0001 // 1 second
|
|
|
|
/// Scan/Init PHYs (bit fields, as defined in HCI:7.8.64, HCI:7.8.66).
|
|
#define LE_1M_PHY_BIT_POS 0
|
|
#define LE_1M_PHY_BIT_MSK 0x01
|
|
#define LE_CODED_PHY_BIT_POS 2
|
|
#define LE_CODED_PHY_BIT_MSK 0x04
|
|
|
|
/// Max scanning PHYs which can be set HCI:7.8.64
|
|
#define MAX_SCAN_PHYS 2
|
|
|
|
/// Max initiatng PHYs which can be set HCI:7.8.66
|
|
#define MAX_INIT_PHYS 2
|
|
|
|
/// Ext Scanning interval (in 625us slot) (chapter 2.E.7.8.64)
|
|
#define EXT_SCAN_INTERVAL_MIN 0x0004 //(2.5 ms)
|
|
#define EXT_SCAN_INTERVAL_MAX 0xFFFF //(40.96 sec)
|
|
|
|
/// Ext Scanning window (in 625us slot) (chapter 2.E.7.8.64)
|
|
#define EXT_SCAN_WINDOW_MIN 0x0004 //(2.5 ms)
|
|
#define EXT_SCAN_WINDOW_MAX 0xFFFF //(40.96 sec)
|
|
|
|
/// Advertiser PHY definitions for Ext Adv report Evts HCI:7.7.65.13
|
|
#define HCI_ADV_PHY_1M 1
|
|
#define HCI_ADV_PHY_2M 2
|
|
#define HCI_ADV_PHY_CODED 3
|
|
|
|
/// Duration of 1MBPS PDU of specified payload length in microseconds (chapter 6.B.2.1)
|
|
#define PDU_1MBPS_LEN_US(n_bytes) ((8 + (2 + n_bytes))*8) // (1 + 4 + (2 + payload_len) + 3)*8
|
|
|
|
/// Duration of 2MBPS PDU of specified payload length in microseconds (chapter 6.B.2.1)
|
|
#define PDU_2MBPS_LEN_US(n_bytes) ((9 + (2 + n_bytes))*4) // (2 + 4 + (2 + payload_len) + 3)*4
|
|
|
|
/// Duration of 500KBPS PDU of specified payload length in microseconds (chapter 6.B.2.2)
|
|
#define PDU_500KBPS_LEN_US(n_bytes) (430 + (2 + n_bytes)*16) // 80 + 256 + 16 + 24 + (2 + payload_len)*8*2 + 24*2 + 3*2
|
|
|
|
/// Duration of 125KBPS PDU of specified payload length in microseconds (chapter 6.B.2.2)
|
|
#define PDU_125KBPS_LEN_US(n_bytes) (592 + (2 + n_bytes)*64) // 80 + 256 + 16 + 24 + (2 + payload_len)*8*8 + 24*8 + 3*8
|
|
|
|
/// Maximum length of BLE advertising channel PDU payloads ((chapter 6.B.2.3))
|
|
#define PDU_ADV_PAYLOAD_LEN_MAX 255
|
|
|
|
/// Ext Adv Report - ADV SID - Define for no ADI filed in the PDU HCI:7.7.65.13
|
|
#define REP_ADV_NO_ADI 0xFF
|
|
|
|
/// Ext Adv Report - Tx Power & RSSI dBm - Define for information not available HCI:7.7.65.13
|
|
#define REP_ADV_DBM_UNKNOWN 127
|
|
|
|
/// Periodic Advertising Report - Unused parameter - mandatory value HCI:7.7.65.15
|
|
#define PER_ADV_REPORT_TRAIL_BYTE 0xFF
|
|
|
|
/// Maximum advertising handle HCI:7.8.53
|
|
#define ADV_HDL_MAX 0xEF
|
|
|
|
/// Advertising_Tx_Power, Host has no preference HCI:7.8.53
|
|
#define ADV_TX_PWR_NO_PREF 127
|
|
|
|
|
|
/*
|
|
* ENUMERATIONS
|
|
****************************************************************************************
|
|
*/
|
|
/// BLE 2MBPS HCI:7.8.x
|
|
enum le_phys_preference
|
|
{
|
|
/// The Host has no preference among the transmitter PHYs supported by the Controller
|
|
ALL_PHYS_TX_NO_PREF = (1 << 0),
|
|
/// The Host has no preference among the receiver PHYs supported by the Controller
|
|
ALL_PHYS_RX_NO_PREF = (1 << 1),
|
|
};
|
|
|
|
enum le_phy_value
|
|
{
|
|
/// The Host prefers to use the LE 1M transmitter/receiver PHY (possibly among others)
|
|
PHY_1MBPS = (1<<0),
|
|
/// The Host prefers to use the LE 2M transmitter/receiver PHY (possibly among others)
|
|
PHY_2MBPS = (1<<1),
|
|
/// The Host prefers to use the LE Coded transmitter/receiver PHY (possibly among others)
|
|
PHY_LE_CODED = (1<<2),
|
|
/// The Host prefers to use the LE Coded transmitter/receiver PHY (possibly among others)
|
|
PHY_ALL = (PHY_1MBPS | PHY_2MBPS | PHY_LE_CODED),
|
|
};
|
|
|
|
enum le_phy_opt
|
|
{
|
|
/// The Host has no preferred coding when transmitting on the LE Coded PHY
|
|
PHY_OPT_NO_LE_CODED_TX_PREF,
|
|
/// The Host prefers that S=2 coding be used when transmitting on the LE Coded PHY
|
|
PHY_OPT_S2_LE_CODED_TX_PREF,
|
|
/// The Host prefers that S=8 coding be used when transmitting on the LE Coded PHY
|
|
PHY_OPT_S8_LE_CODED_TX_PREF,
|
|
};
|
|
|
|
|
|
enum le_phy_mode
|
|
{
|
|
PHYS_MOD_STANDARD ,
|
|
PHYS_MOD_STABLE ,
|
|
PHYS_MOD_MAX,
|
|
};
|
|
|
|
///Transmit Power level types
|
|
enum
|
|
{
|
|
///Current Power Level
|
|
TX_PW_LVL_CURRENT = 0x00,
|
|
///Maximum power level
|
|
TX_PW_LVL_MAX,
|
|
};
|
|
|
|
///Controller to Host flow control
|
|
enum
|
|
{
|
|
/// C-> H flow control off
|
|
FLOW_CTRL_OFF = 0x00,
|
|
///C->H ACL flow control on only
|
|
FLOW_CTRL_ON_ACL_OFF_SYNC,
|
|
///C->H Sync flow control on only
|
|
FLOW_CTRL_OFF_ACL_ON_SYNC,
|
|
///C->H ACL and Sync flow control on
|
|
FLOW_CTRL_ON_ACL_ON_SYNC,
|
|
};
|
|
|
|
///LE Supported Host enable
|
|
enum
|
|
{
|
|
///Disable LE supported Host
|
|
LE_SUPP_HOST_DIS = 0x00,
|
|
///Enable LE Supported Host
|
|
LE_SUPP_HOST_EN,
|
|
};
|
|
|
|
///Simultaneous LE Host enable
|
|
enum
|
|
{
|
|
///Disable LE simultaneous Host disable
|
|
SIMULT_LE_HOST_DIS = 0x00,
|
|
///Enable LE simultaneous Host disable
|
|
SIMULT_LE_HOST_EN,
|
|
};
|
|
|
|
///Advertising HCI Type
|
|
enum
|
|
{
|
|
///Connectable Undirected advertising
|
|
ADV_CONN_UNDIR = 0x00,
|
|
///Connectable high duty cycle directed advertising
|
|
ADV_CONN_DIR,
|
|
///Discoverable undirected advertising
|
|
ADV_DISC_UNDIR,
|
|
///Non-connectable undirected advertising
|
|
ADV_NONCONN_UNDIR,
|
|
///Connectable low duty cycle directed advertising
|
|
ADV_CONN_DIR_LDC,
|
|
};
|
|
|
|
///Advertising event properties values for legacy PDUs
|
|
enum
|
|
{
|
|
///Connectable and scannable undirected
|
|
ADV_IND = 0x13,
|
|
///Connectable directed (low duty cycle)
|
|
ADV_DIRECT_LO_IND = 0x15,
|
|
///Connectable directed (high duty cycle)
|
|
ADV_DIRECT_HI_IND = 0x1D,
|
|
///Connectable directed (received)
|
|
ADV_DIRECT_IND = 0x15,
|
|
///Scannable undirected
|
|
ADV_SCAN_IND = 0x12,
|
|
///Non-connectable and non-scannable undirected
|
|
ADV_NONCONN_IND = 0x10,
|
|
///Scan response to an ADV_IND
|
|
SCAN_RSP_TO_ADV_IND = 0x1B,
|
|
///Scan response to an ADV_SCAN_IND
|
|
SCAN_RSP_TO_ADV_SCAN_IND = 0x1A,
|
|
};
|
|
|
|
///Advertising event properties masks
|
|
enum
|
|
{
|
|
///Connectable advertising
|
|
ADV_CON = 0x01,
|
|
///Scannable advertising
|
|
ADV_SCAN = 0x02,
|
|
///Directed advertising
|
|
ADV_DIRECT = 0x04,
|
|
///High duty cycle directed connectable advertising
|
|
ADV_DIRECT_HI = 0x08,
|
|
///Use legacy advertising PDUs
|
|
ADV_LEGACY = 0x10,
|
|
///Omit advertiser's address from all PDUs ("anonymous advertising")
|
|
ADV_ANONYMOUS = 0x20,
|
|
///Include TxPower in the extended header of the advertising PDU
|
|
ADV_TX_PWR = 0x40,
|
|
};
|
|
|
|
///Scanning HCI Type
|
|
enum
|
|
{
|
|
///Scan request
|
|
SCAN_REQ,
|
|
///Scan response
|
|
SCAN_RSP,
|
|
};
|
|
|
|
///BD address type
|
|
enum
|
|
{
|
|
///Public BD address
|
|
ADDR_PUBLIC = 0x00,
|
|
///Random BD Address
|
|
ADDR_RAND,
|
|
/// Controller generates Resolvable Private Address based on the
|
|
/// local IRK from resolving list. If resolving list contains no matching
|
|
/// entry, use public address.
|
|
ADDR_RPA_OR_PUBLIC,
|
|
/// Controller generates Resolvable Private Address based on the
|
|
/// local IRK from resolving list. If resolving list contains no matching
|
|
/// entry, use random address.
|
|
ADDR_RPA_OR_RAND,
|
|
/// mask used to determine Address type in the air
|
|
ADDR_MASK = 0x01,
|
|
/// mask used to determine if an address is an RPA
|
|
ADDR_RPA_MASK = 0x02,
|
|
/// Random device address (controller unable to resolve)
|
|
ADDR_RAND_UNRESOLVED = 0xFE,
|
|
/// No address provided (anonymous advertisement)
|
|
ADDR_NONE = 0xFF,
|
|
};
|
|
|
|
///Privacy mode type
|
|
enum
|
|
{
|
|
///Network privacy mode
|
|
PRIV_TYPE_NETWORK = 0x00,
|
|
///Device privacy mode
|
|
PRIV_TYPE_DEVICE = 0x01,
|
|
};
|
|
|
|
/// Random Address type (2 MSB of the LE BD Address)
|
|
enum rnd_addr_type
|
|
{
|
|
/// Static random address - 11 (MSB->LSB)
|
|
RND_STATIC_ADDR = 0xC0,
|
|
/// Private non resolvable address - 00 (MSB->LSB)
|
|
RND_NON_RSLV_ADDR = 0x00,
|
|
/// Private resolvable address - 01 (MSB->LSB)
|
|
RND_RSLV_ADDR = 0x40,
|
|
};
|
|
|
|
///Advertising channels enables
|
|
enum adv_channel_map
|
|
{
|
|
///Byte value for advertising channel map for channel 37 enable
|
|
ADV_CHNL_37_EN = 0x01,
|
|
///Byte value for advertising channel map for channel 38 enable
|
|
ADV_CHNL_38_EN = 0x02,
|
|
///Byte value for advertising channel map for channel 39 enable
|
|
ADV_CHNL_39_EN = 0x04,
|
|
///Byte value for advertising channel map for channel 37, 38 and 39 enable
|
|
ADV_ALL_CHNLS_EN = 0x07,
|
|
};
|
|
|
|
///Advertising filter policy
|
|
enum adv_filter_policy
|
|
{
|
|
///Allow both scan and connection requests from anyone
|
|
ADV_ALLOW_SCAN_ANY_CON_ANY = 0x00,
|
|
///Allow both scan req from White List devices only and connection req from anyone
|
|
ADV_ALLOW_SCAN_WLST_CON_ANY,
|
|
///Allow both scan req from anyone and connection req from White List devices only
|
|
ADV_ALLOW_SCAN_ANY_CON_WLST,
|
|
///Allow scan and connection requests from White List devices only
|
|
ADV_ALLOW_SCAN_WLST_CON_WLST,
|
|
};
|
|
|
|
///Advertising enables
|
|
enum
|
|
{
|
|
///Disable advertising
|
|
ADV_DIS = 0x00,
|
|
///Enable advertising
|
|
ADV_EN,
|
|
};
|
|
|
|
///LE Scan type
|
|
enum
|
|
{
|
|
///Passive scan
|
|
SCAN_PASSIVE = 0x00,
|
|
///Active scan
|
|
SCAN_ACTIVE,
|
|
};
|
|
|
|
///Scan filter policy
|
|
enum scan_filter_policy
|
|
{
|
|
///Allow advertising packets from anyone
|
|
SCAN_ALLOW_ADV_ALL = 0x00,
|
|
///Allow advertising packets from White List devices only
|
|
SCAN_ALLOW_ADV_WLST,
|
|
///Allow advertising packets from anyone and Direct adv using RPA in InitA
|
|
SCAN_ALLOW_ADV_ALL_AND_INIT_RPA,
|
|
///Allow advertising packets from White List devices only and Direct adv using RPA in InitA
|
|
SCAN_ALLOW_ADV_WLST_AND_INIT_RPA,
|
|
};
|
|
|
|
///Le Scan enables
|
|
enum
|
|
{
|
|
///Disable scan
|
|
SCAN_DIS = 0x00,
|
|
///Enable scan
|
|
SCAN_EN,
|
|
};
|
|
|
|
///Filter duplicates
|
|
enum scan_dup_filter_policy
|
|
{
|
|
///Disable filtering of duplicate packets
|
|
SCAN_FILT_DUPLIC_DIS = 0x00,
|
|
///Enable filtering of duplicate packets
|
|
SCAN_FILT_DUPLIC_EN,
|
|
///Enable filtering of duplicate packets per scan period
|
|
SCAN_FILT_DUPLIC_EN_PER_PERIOD,
|
|
};
|
|
|
|
///Initiator Filter policy
|
|
enum
|
|
{
|
|
///Initiator will ignore White List
|
|
INIT_FILT_IGNORE_WLST = 0x00,
|
|
///Initiator will use White List
|
|
INIT_FILT_USE_WLST,
|
|
};
|
|
|
|
///Transmitter test Packet Payload Type
|
|
enum
|
|
{
|
|
///Pseudo-random 9 TX test payload type
|
|
PAYL_PSEUDO_RAND_9 = 0x00,
|
|
///11110000 TX test payload type
|
|
PAYL_11110000,
|
|
///10101010 TX test payload type
|
|
PAYL_10101010,
|
|
///Pseudo-random 15 TX test payload type
|
|
PAYL_PSEUDO_RAND_15,
|
|
///All 1s TX test payload type
|
|
PAYL_ALL_1,
|
|
///All 0s TX test payload type
|
|
PAYL_ALL_0,
|
|
///00001111 TX test payload type
|
|
PAYL_00001111,
|
|
///01010101 TX test payload type
|
|
PAYL_01010101,
|
|
};
|
|
|
|
/// Constant defining the role
|
|
enum
|
|
{
|
|
///Master role
|
|
ROLE_MASTER,
|
|
///Slave role
|
|
ROLE_SLAVE,
|
|
};
|
|
|
|
/// Constant clock accuracy
|
|
enum
|
|
{
|
|
///Clock accuracy at 500PPM
|
|
SCA_500PPM,
|
|
///Clock accuracy at 250PPM
|
|
SCA_250PPM,
|
|
///Clock accuracy at 150PPM
|
|
SCA_150PPM,
|
|
///Clock accuracy at 100PPM
|
|
SCA_100PPM,
|
|
///Clock accuracy at 75PPM
|
|
SCA_75PPM,
|
|
///Clock accuracy at 50PPM
|
|
SCA_50PPM,
|
|
///Clock accuracy at 30PPM
|
|
SCA_30PPM,
|
|
///Clock accuracy at 20PPM
|
|
SCA_20PPM
|
|
};
|
|
|
|
///Advertising pdu Type
|
|
enum ble_adv_type
|
|
{
|
|
/// Undirected advertising
|
|
BLE_ADV_IND = 0x00,
|
|
/// Directed advertising
|
|
BLE_ADV_DIRECT_IND = 0x01,
|
|
/// Non Connectable advertising
|
|
BLE_ADV_NONCONN_IND = 0x02,
|
|
/// Scan Request on primary channel
|
|
BLE_SCAN_REQ = 0x03,
|
|
/// Scan Response on secondary channel
|
|
BLE_AUX_SCAN_REQ = 0x03,
|
|
|
|
/// Scan Response
|
|
BLE_SCAN_RSP = 0x04,
|
|
/// Connect Request on primary channel
|
|
BLE_CONNECT_IND = 0x05,
|
|
/// Connect Request on secondary channel
|
|
BLE_AUX_CONNECT_REQ = 0x05,
|
|
|
|
/// Discoverable advertising
|
|
BLE_ADV_SCAN_IND = 0x06,
|
|
|
|
/// Extended Advertising indication on primary channel
|
|
BLE_ADV_EXT_IND = 0x07,
|
|
|
|
/// ADV data indication on secondary channel
|
|
BLE_AUX_ADV_IND = 0x07,
|
|
/// Scan response data on secondary channel
|
|
BLE_AUX_SCAN_RSP = 0x07,
|
|
/// Periodic Advertising packet on secondary channel
|
|
BLE_AUX_SYNC_IND = 0x07,
|
|
/// Continuation of advertising data on secondary channel
|
|
BLE_AUX_CHAIN_IND = 0x07,
|
|
/// Response of the AUX_CONNECT_REQ on secondary channel to confirm that connection is accepted
|
|
BLE_AUX_CONNECT_RSP = 0x08,
|
|
|
|
/// Reserved
|
|
BLE_RESERVED_PDU_TYPES,
|
|
};
|
|
|
|
|
|
/// LE Advertising Report Event Type HCI:7.7.65.2
|
|
enum
|
|
{
|
|
/// Connectable undirected advertising
|
|
ADV_IND_EVT = 0x00,
|
|
/// Connectable directed advertising
|
|
ADV_DIRECT_IND_EVT,
|
|
/// Scannable undirected advertising
|
|
ADV_SCAN_IND_EVT,
|
|
/// Non connectable undirected advertising
|
|
ADV_NONCONN_IND_EVT,
|
|
/// Scan Response
|
|
SCAN_RSP_EVT,
|
|
/// Reserved
|
|
RESERVED_ADV_EVT_TYPES,
|
|
};
|
|
|
|
/// LE Extended Advertising Report Event Type Bit Mask HCI:7.765.13
|
|
|
|
/// Connectable advertising event
|
|
#define CON_ADV_EVT_MSK 0x01
|
|
/// Scannable advertising event
|
|
#define SCAN_ADV_EVT_MSK 0x02
|
|
/// Directed advertising event
|
|
#define DIR_ADV_EVT_MSK 0x04
|
|
/// Scan Response
|
|
#define SCAN_RSP_EVT_MSK 0x08
|
|
/// Legacy advertising PDUs
|
|
#define LGCY_ADV_EVT_MSK 0x10
|
|
|
|
/// Connectable undirected advertising
|
|
#define LGCY_ADV_IND_EVT 0x13 //LGCY_ADV_EVT_MSK|SCAN_ADV_EVT_MSK|CON_ADV_EVT_MSK
|
|
/// Connectable directed advertising
|
|
#define LGCY_ADV_DIRECT_IND_EVT 0x15 //LGCY_ADV_EVT_MSK|DIR_ADV_EVT_MSK|CON_ADV_EVT_MSK
|
|
/// Scannable undirected advertising
|
|
#define LGCY_ADV_SCAN_IND_EVT 0x12 //LGCY_ADV_EVT_MSK|SCAN_ADV_EVT_MSK
|
|
/// Non connectable undirected advertising
|
|
#define LGCY_ADV_NONCONN_IND_EVT 0x10 //LGCY_ADV_EVT_MSK
|
|
/// Scan Response to ADV_IND
|
|
#define LGCY_SCAN_RSP_TO_ADV_IND_EVT 0x1B //LGCY_ADV_EVT_MSK|SCAN_RSP_EVT_MSK|SCAN_ADV_EVT_MSK|CON_ADV_EVT_MSK
|
|
/// Scan Response to ADV_SCAN_IND
|
|
#define LGCY_SCAN_RSP_TO_ADV_SCAN_IND_EVT 0x1A //LGCY_ADV_EVT_MSK|SCAN_RSP_EVT_MSK|SCAN_ADV_EVT_MSK
|
|
|
|
/// Offset of data status field in event type value
|
|
#define ADV_EVT_DATA_STATUS_OFFSET 5
|
|
/// Mask for data status field in event type value
|
|
#define ADV_EVT_DATA_STATUS_MASK 0x0003
|
|
/// Data status of extended advertising event - Complete
|
|
#define ADV_EVT_DATA_STATUS_COMPLETE 0
|
|
/// Data status of extended advertising event - Incomplete, more data to come
|
|
#define ADV_EVT_DATA_STATUS_INCOMPLETE 1
|
|
/// Data status of extended advertising event - Incomplete, data truncated, no more to come
|
|
#define ADV_EVT_DATA_STATUS_TRUNCATED 2
|
|
/// Data status of extended advertising event - Reserved for future use
|
|
#define ADV_EVT_DATA_STATUS_RESERVED 3
|
|
|
|
/// LLID packet
|
|
enum
|
|
{
|
|
/// Reserved for future use
|
|
LLID_RFU,
|
|
/// Continue
|
|
LLID_CONTINUE,
|
|
/// Start
|
|
LLID_START,
|
|
/// Control
|
|
LLID_CNTL
|
|
};
|
|
|
|
/// Remote OOB Data present parameter value HCI:7.1.29
|
|
enum
|
|
{
|
|
REM_OOB_DATA_NO = 0x00,
|
|
REM_OOB_DATA_P192 = 0x01,
|
|
REM_OOB_DATA_P256 = 0x02,
|
|
REM_OOB_DATA_P192_P256 = 0x03,
|
|
};
|
|
|
|
/// Encryption enabled parameter in HCI_Enc_Chg_Evt HCI:7.7.8
|
|
enum
|
|
{
|
|
ENC_OFF = 0x00,
|
|
ENC_BRDER_E0_LE_AESCCM = 0x01,
|
|
ENC_BREDR_AESCC = 0x02,
|
|
};
|
|
|
|
/// Combined duration of Preamble and Access Address depending on the PHY used (in us)
|
|
#define BLE_PREAMBLE_ACCESS_ADDR_DUR_1MBPS (5*8)
|
|
#define BLE_PREAMBLE_ACCESS_ADDR_DUR_2MBPS (6*4)
|
|
#define BLE_PREAMBLE_ACCESS_ADDR_DUR_125KBPS (80+256)
|
|
#define BLE_PREAMBLE_ACCESS_ADDR_DUR_500KBPS (80+256)
|
|
|
|
/// size of the LEN & MODE info preceeding the extended header
|
|
#define BLE_EXT_ADV_PRE_HEADER_LEN (1)
|
|
/// size of the FLAGS info at start of the extended header
|
|
#define BLE_EXT_ADV_HEADER_FLAGS_LEN (1)
|
|
/// size of the extended header in bytes (pre-header + flags)
|
|
#define BLE_EXT_ADV_HEADER_LEN (2)
|
|
/// Size of supplemental info in extended header
|
|
#define BLE_EXT_SUP_INFO_LEN (1)
|
|
/// Size of ADV Data Info in extended header
|
|
#define BLE_EXT_ADI_LEN (2)
|
|
/// Size of Aux Pointer info in extended header
|
|
#define BLE_EXT_AUX_PTR_LEN (3)
|
|
/// Size of Sync PTR info in extended header
|
|
#define BLE_EXT_SYNC_LEN (18)
|
|
/// Size of TX Power info in extended header
|
|
#define BLE_EXT_TX_PWR_LEN (1)
|
|
|
|
/// Extended Header Flags
|
|
enum ble_ext_header_flags
|
|
{
|
|
// AdvA
|
|
ADVA_BIT = 0x01,
|
|
ADVA_POS = 0,
|
|
// TargetA
|
|
TARGETA_BIT = 0x02,
|
|
TARGETA_POS = 1,
|
|
// SuppInfo
|
|
SUPPINFO_BIT = 0x04,
|
|
SUPPINFO_POS = 2,
|
|
// AdvDataInfo (ADI)
|
|
ADI_BIT = 0x08,
|
|
ADI_POS = 3,
|
|
// AuxPtr
|
|
AUXPTR_BIT = 0x10,
|
|
AUXPTR_POS = 4,
|
|
// SyncInfo
|
|
SYNCINFO_BIT = 0x20,
|
|
SYNCINFO_POS = 5,
|
|
// TxPower
|
|
TXPOWER_BIT = 0x40,
|
|
TXPOWER_POS = 6,
|
|
};
|
|
|
|
/// AUX pointer description
|
|
enum ble_aux_ptr
|
|
{
|
|
// Aux LL Channel
|
|
BLE_AUX_LL_CHANNEL_MASK = 0x0000003F,
|
|
BLE_AUX_LL_CHANNEL_LSB = 0,
|
|
// Aux Clock Accuracy
|
|
BLE_AUX_CA_BIT = 0x00000040,
|
|
BLE_AUX_CA_POS = 6,
|
|
// Aux Offset Unit
|
|
BLE_AUX_OFFSET_UNIT_BIT = 0x00000080,
|
|
BLE_AUX_OFFSET_UNIT_POS = 7,
|
|
// Aux ADV offset
|
|
BLE_AUX_OFFSET_MASK = 0x001FFF00,
|
|
BLE_AUX_OFFSET_LSB = 8,
|
|
// Aux PHY
|
|
BLE_AUX_PHY_MASK = 0x00E00000,
|
|
BLE_AUX_PHY_LSB = 21,
|
|
};
|
|
|
|
/// AdvDataInfo (ADI) field description
|
|
enum ble_adi
|
|
{
|
|
// Advertising Data ID (DID)
|
|
BLE_ADI_DID_MASK = 0x0FFF,
|
|
BLE_ADI_DID_LSB = 0,
|
|
// Advertising Set ID (SID)
|
|
BLE_ADI_SID_MASK = 0xF000,
|
|
BLE_ADI_SID_LSB = 12,
|
|
};
|
|
|
|
/// Advertising mode
|
|
enum ble_adv_mode
|
|
{
|
|
/// Non connectable and non scannable mode
|
|
BLE_MODE_NON_CON_SCAN = 0,
|
|
/// Connectable Mode (accept connection request)
|
|
BLE_MODE_CONNECTABLE = 1,
|
|
/// Scannable Mode (accept scan request)
|
|
BLE_MODE_SCANNABLE = 2,
|
|
/// Reserved Advertising mode
|
|
BLE_MODE_RESERVED = 3,
|
|
};
|
|
|
|
/// Advertising data operation
|
|
enum adv_data_op
|
|
{
|
|
/// Intermediate fragment of fragmented extended advertising data
|
|
ADV_DATA_OP_INTERMEDIATE_FRAG = 0,
|
|
/// First fragment of fragmented extended advertising data
|
|
ADV_DATA_OP_FIRST_FRAG = 1,
|
|
/// Last fragment of fragmented extended advertising data
|
|
ADV_DATA_OP_LAST_FRAG = 2,
|
|
/// Complete extended advertising data
|
|
ADV_DATA_OP_COMPLETE = 3,
|
|
/// Unchanged data (just update the Advertising DID)
|
|
ADV_DATA_OP_UNCHANGED_DATA = 4,
|
|
};
|
|
|
|
/// Advertising data fragment preference
|
|
enum adv_data_frag_pref
|
|
{
|
|
/// The Controller may fragment all Host advertising data
|
|
ADV_DATA_MAY_FRAG = 0,
|
|
/// The Controller should not fragment nor minimize fragmentation of Host advertising data
|
|
ADV_DATA_SHOULD_NOT_FRAG = 1,
|
|
};
|
|
|
|
/*
|
|
* STRUCTURE DEFINITONS
|
|
****************************************************************************************
|
|
*/
|
|
|
|
///BD name structure
|
|
struct bd_name
|
|
{
|
|
///length for name
|
|
uint8_t namelen;
|
|
///array of bytes for name
|
|
uint8_t name[BD_NAME_SIZE];
|
|
};
|
|
|
|
///Structure device name
|
|
struct device_name
|
|
{
|
|
///array of bytes for name
|
|
uint8_t name[BD_NAME_SIZE];
|
|
};
|
|
|
|
///Structure name vector
|
|
struct name_vect
|
|
{
|
|
uint8_t vect[NAME_VECT_SIZE];
|
|
};
|
|
|
|
/// lap structure
|
|
struct lap
|
|
{
|
|
/// LAP
|
|
uint8_t A[BD_ADDR_LAP_LEN];
|
|
};
|
|
|
|
/// class structure
|
|
struct devclass
|
|
{
|
|
/// class
|
|
uint8_t A[DEV_CLASS_LEN];
|
|
};
|
|
|
|
///Extended inquiry response structure
|
|
struct eir
|
|
{
|
|
/// eir data
|
|
uint8_t data[EIR_DATA_SIZE];
|
|
};
|
|
|
|
///Event mask structure
|
|
struct evt_mask
|
|
{
|
|
///8-byte array for mask value
|
|
uint8_t mask[EVT_MASK_LEN];
|
|
};
|
|
|
|
///Host number of completed packets structure, for 1 connection handle
|
|
struct host_cmpl_pkts
|
|
{
|
|
///Connection handle
|
|
uint16_t con_hdl;
|
|
///Number of completed packets
|
|
uint16_t nb_cmpl_pkts;
|
|
};
|
|
|
|
///BD Address structure
|
|
struct bd_addr
|
|
{
|
|
///6-byte array address value
|
|
uint8_t addr[BD_ADDR_LEN];
|
|
};
|
|
|
|
///Access Address structure
|
|
struct access_addr
|
|
{
|
|
///4-byte array access address
|
|
uint8_t addr[ACCESS_ADDR_LEN];
|
|
};
|
|
|
|
///Advertising data structure
|
|
struct adv_data
|
|
{
|
|
///Maximum length data bytes array
|
|
uint8_t data[ADV_DATA_LEN];
|
|
};
|
|
|
|
///Scan response data structure
|
|
struct scan_rsp_data
|
|
{
|
|
///Maximum length data bytes array
|
|
uint8_t data[SCAN_RSP_DATA_LEN];
|
|
};
|
|
|
|
///Channel map structure
|
|
struct chnl_map
|
|
{
|
|
///10-bytes channel map array
|
|
uint8_t map[CHNL_MAP_LEN];
|
|
};
|
|
|
|
///Channel map structure
|
|
struct le_chnl_map
|
|
{
|
|
///5-byte channel map array
|
|
uint8_t map[LE_CHNL_MAP_LEN];
|
|
};
|
|
|
|
///Long Term Key structure
|
|
struct ltk
|
|
{
|
|
///16-byte array for LTK value
|
|
uint8_t ltk[KEY_LEN];
|
|
};
|
|
|
|
///Identity Resolving Key structure
|
|
struct irk
|
|
{
|
|
///16-byte array for IRK value
|
|
uint8_t key[KEY_LEN];
|
|
};
|
|
|
|
/// Initialization vector (for AES-CCM encryption)
|
|
struct initialization_vector
|
|
{
|
|
///8-byte array
|
|
uint8_t vect[IV_LEN];
|
|
};
|
|
|
|
/// Bluetooth address with link key
|
|
struct bd_addr_plus_key
|
|
{
|
|
/// BD Address
|
|
struct bd_addr bd_addr;
|
|
/// Link Key
|
|
struct ltk link_key;
|
|
};
|
|
|
|
///Random number structure
|
|
struct rand_nb
|
|
{
|
|
///8-byte array for random number
|
|
uint8_t nb[RAND_NB_LEN];
|
|
};
|
|
|
|
///Advertising report structure
|
|
struct adv_report
|
|
{
|
|
///Event type:
|
|
/// - ADV_CONN_UNDIR: Connectable Undirected advertising
|
|
/// - ADV_CONN_DIR: Connectable directed advertising
|
|
/// - ADV_DISC_UNDIR: Discoverable undirected advertising
|
|
/// - ADV_NONCONN_UNDIR: Non-connectable undirected advertising
|
|
uint8_t evt_type;
|
|
///Advertising address type: public/random
|
|
uint8_t adv_addr_type;
|
|
///Advertising address value
|
|
struct bd_addr adv_addr;
|
|
///Data length in advertising packet
|
|
uint8_t data_len;
|
|
///Data of advertising packet
|
|
uint8_t data[ADV_DATA_LEN];
|
|
///RSSI value for advertising packet
|
|
uint8_t rssi;
|
|
};
|
|
|
|
///Direct Advertising report structure
|
|
struct dir_adv_report
|
|
{
|
|
///Event type:
|
|
/// - ADV_CONN_DIR: Connectable directed advertising
|
|
uint8_t evt_type;
|
|
///Address type: public/random
|
|
uint8_t addr_type;
|
|
///Address value
|
|
struct bd_addr addr;
|
|
///Direct address type: public/random
|
|
uint8_t dir_addr_type;
|
|
///Direct address value
|
|
struct bd_addr dir_addr;
|
|
///RSSI value for advertising packet
|
|
uint8_t rssi;
|
|
};
|
|
|
|
///Exteneded Advertising report structure
|
|
struct ext_adv_report
|
|
{
|
|
///Event type
|
|
uint16_t evt_type;
|
|
///Advertising address type: public/random
|
|
uint8_t adv_addr_type;
|
|
///Advertising address value
|
|
struct bd_addr adv_addr;
|
|
///Primary PHY
|
|
uint8_t phy;
|
|
///Secondary PHY
|
|
uint8_t phy2;
|
|
///Advertising SID
|
|
uint8_t adv_sid;
|
|
///Tx Power
|
|
uint8_t tx_power;
|
|
///RSSI value for advertising packet
|
|
uint8_t rssi;
|
|
///Periodic Advertising interval (Time=N*1.25ms)
|
|
uint16_t interval;
|
|
///Direct address type
|
|
uint8_t dir_addr_type;
|
|
///Direct address value
|
|
struct bd_addr dir_addr;
|
|
///Data length in advertising packet
|
|
uint8_t data_len;
|
|
///Data of advertising packet
|
|
uint8_t data[EXT_ADV_DATA_MAX_LEN];
|
|
};
|
|
|
|
///Supported LE Features structure
|
|
struct le_features
|
|
{
|
|
///8-byte array for LE features
|
|
uint8_t feats[LE_FEATS_LEN];
|
|
};
|
|
|
|
///Simple pairing hash structure
|
|
struct hash
|
|
{
|
|
///16-byte array for LTK value
|
|
uint8_t C[KEY_LEN];
|
|
};
|
|
|
|
///Simple pairing randomizer structure
|
|
struct randomizer
|
|
{
|
|
///16-byte array for LTK value
|
|
uint8_t R[KEY_LEN];
|
|
};
|
|
|
|
///Pin code structure
|
|
struct pin_code
|
|
{
|
|
///16-byte array for PIN value
|
|
uint8_t pin[PIN_CODE_MAX_LEN];
|
|
};
|
|
|
|
///Sres structure
|
|
struct sres_nb
|
|
{
|
|
///8-byte array for random number
|
|
uint8_t nb[SRES_LEN];
|
|
};
|
|
|
|
///aco structure
|
|
struct aco
|
|
{
|
|
///8-byte array for random number
|
|
uint8_t a[ACO_LEN];
|
|
};
|
|
|
|
///struct byte 16 to stay align with the sdl version
|
|
struct byte16
|
|
{
|
|
uint8_t A[16];
|
|
};
|
|
|
|
///Controller number of completed packets structure
|
|
struct nb_cmpl_pk
|
|
{
|
|
///Connection handle
|
|
uint16_t con_hdl;
|
|
///Controller number of data packets that have been completed since last time
|
|
uint16_t nb_hc_cmpl_pkts;
|
|
};
|
|
|
|
///Supported Features structure
|
|
struct features
|
|
{
|
|
///8-byte array for features
|
|
uint8_t feats[FEATS_LEN];
|
|
};
|
|
|
|
///Supported commands structure
|
|
struct supp_cmds
|
|
{
|
|
///64-byte array for supported commands
|
|
uint8_t cmds[SUPP_CMDS_LEN];
|
|
};
|
|
|
|
///Supported LMP features structure
|
|
struct lmp_features
|
|
{
|
|
///8-byte array for LMp features
|
|
uint8_t feats[FEATS_LEN];
|
|
};
|
|
|
|
///Simple pairing IO capabilities
|
|
struct io_capability
|
|
{
|
|
///IO capability
|
|
uint8_t io_cap;
|
|
/// Out Of Band Data present
|
|
bool oob_data_present;
|
|
///Authentication Requirement
|
|
uint8_t aut_req;
|
|
};
|
|
|
|
///Public key
|
|
struct pub_key_192
|
|
{
|
|
uint8_t p_key[PUB_KEY_192_LEN/2];
|
|
};
|
|
|
|
///Public key
|
|
struct pub_key_256
|
|
{
|
|
uint8_t p_key[PUB_KEY_256_LEN/2];
|
|
};
|
|
|
|
///Simple pairing public keys 192
|
|
struct sp_pub_key_192
|
|
{
|
|
///Public key X
|
|
struct pub_key_192 X;
|
|
///Public key Y
|
|
struct pub_key_192 Y;
|
|
};
|
|
|
|
///Simple pairing public keys 256
|
|
struct sp_pub_key_256
|
|
{
|
|
///Public key X
|
|
struct pub_key_256 X;
|
|
///Public key Y
|
|
struct pub_key_256 Y;
|
|
};
|
|
|
|
///Supported LE states structure
|
|
struct le_states
|
|
{
|
|
///8-byte array for LE states
|
|
uint8_t supp_states[LE_STATES_LEN];
|
|
};
|
|
|
|
///White List element structure
|
|
struct white_list
|
|
{
|
|
///BD address of device entry
|
|
struct bd_addr wl_bdaddr;
|
|
///BD address type of device entry
|
|
uint8_t wl_bdaddr_type;
|
|
};
|
|
|
|
///CRC initial value structure
|
|
struct crc_init
|
|
{
|
|
///3-byte array CRC initial value
|
|
uint8_t crc[CRC_INIT_LEN];
|
|
};
|
|
|
|
///Session key diversifier master or slave structure
|
|
struct sess_k_div_x
|
|
{
|
|
///8-byte array for diversifier value
|
|
uint8_t skdiv[SESS_KEY_DIV_LEN];
|
|
};
|
|
|
|
///Session key diversifier structure
|
|
struct sess_k_div
|
|
{
|
|
///16-byte array for session key diversifier.
|
|
uint8_t skd[2*SESS_KEY_DIV_LEN];
|
|
};
|
|
|
|
///Initiator vector
|
|
struct init_vect
|
|
{
|
|
///4-byte array for vector
|
|
uint8_t iv[INIT_VECT_LEN];
|
|
};
|
|
|
|
typedef struct t_public_key
|
|
{
|
|
uint8_t x[PUBLIC_KEY_P256_LEN];
|
|
uint8_t y[PUBLIC_KEY_P256_LEN];
|
|
|
|
} t_public_key;
|
|
|
|
/// structure connection request
|
|
struct pdu_con_req
|
|
{
|
|
/// access address
|
|
struct access_addr aa;
|
|
|
|
/// CRC init
|
|
struct crc_init crcinit;
|
|
|
|
/// window size
|
|
uint8_t winsize;
|
|
|
|
/// window offset
|
|
uint16_t winoffset;
|
|
|
|
/// interval
|
|
uint16_t interval;
|
|
|
|
/// latency
|
|
uint16_t latency;
|
|
|
|
/// timeout
|
|
uint16_t timeout;
|
|
|
|
/// channel mapping
|
|
struct le_chnl_map chm;
|
|
|
|
/// hopping
|
|
uint8_t hop_sca;
|
|
};
|
|
|
|
/// Device specific link preferences
|
|
typedef struct
|
|
{
|
|
// **** Data Length Management ****
|
|
/// Suggested value for the Controller's maximum transmitted number of payload octets
|
|
uint16_t suggested_max_tx_octets;
|
|
/// Suggested value for the Controller's maximum packet transmission time (in us)
|
|
uint16_t suggested_max_tx_time;
|
|
|
|
// **** PHY Management ****
|
|
/// Default TX preferred PHY to use (@see enum le_phy_value)
|
|
uint8_t tx_phys;
|
|
/// Default RX preferred PHY to use (@see enum le_phy_value)
|
|
uint8_t rx_phys;
|
|
} link_pref_t;
|
|
|
|
|
|
/// @} CO_BT_DEFINES
|
|
#endif // CO_BT_DEFINES_H_
|