202c5783db
component/bt: cherry-pick the bugfix/btdm_api_manage_pair_info_#13119 to this branch. component/bt: Change the ble gap API code format & added the status judgment in the btc_storage_load_bonded_ble_devices function.
130 lines
5.6 KiB
C
130 lines
5.6 KiB
C
// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
|
|
//
|
|
// Licensed 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 __ESP_BT_DEFS_H__
|
|
#define __ESP_BT_DEFS_H__
|
|
|
|
#include <stdint.h>
|
|
#include <stdbool.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#define ESP_BLUEDROID_STATUS_CHECK(status) \
|
|
if (esp_bluedroid_get_status() != (status)) { \
|
|
return ESP_ERR_INVALID_STATE; \
|
|
}
|
|
|
|
|
|
/* relate to BT_STATUS_xxx in bt_def.h */
|
|
/// Status Return Value
|
|
typedef enum {
|
|
ESP_BT_STATUS_SUCCESS = 0, /* relate to BT_STATUS_SUCCESS in bt_def.h */
|
|
ESP_BT_STATUS_FAIL, /* relate to BT_STATUS_FAIL in bt_def.h */
|
|
ESP_BT_STATUS_NOT_READY, /* relate to BT_STATUS_NOT_READY in bt_def.h */
|
|
ESP_BT_STATUS_NOMEM, /* relate to BT_STATUS_NOMEM in bt_def.h */
|
|
ESP_BT_STATUS_BUSY, /* relate to BT_STATUS_BUSY in bt_def.h */
|
|
ESP_BT_STATUS_DONE = 5, /* relate to BT_STATUS_DONE in bt_def.h */
|
|
ESP_BT_STATUS_UNSUPPORTED, /* relate to BT_STATUS_UNSUPPORTED in bt_def.h */
|
|
ESP_BT_STATUS_PARM_INVALID, /* relate to BT_STATUS_PARM_INVALID in bt_def.h */
|
|
ESP_BT_STATUS_UNHANDLED, /* relate to BT_STATUS_UNHANDLED in bt_def.h */
|
|
ESP_BT_STATUS_AUTH_FAILURE, /* relate to BT_STATUS_AUTH_FAILURE in bt_def.h */
|
|
ESP_BT_STATUS_RMT_DEV_DOWN = 10, /* relate to BT_STATUS_RMT_DEV_DOWN in bt_def.h */
|
|
ESP_BT_STATUS_AUTH_REJECTED, /* relate to BT_STATUS_AUTH_REJECTED in bt_def.h */
|
|
ESP_BT_STATUS_INVALID_STATIC_RAND_ADDR, /* relate to BT_STATUS_INVALID_STATIC_RAND_ADDR in bt_def.h */
|
|
ESP_BT_STATUS_PENDING, /* relate to BT_STATUS_PENDING in bt_def.h */
|
|
ESP_BT_STATUS_UNACCEPT_CONN_INTERVAL, /* relate to BT_UNACCEPT_CONN_INTERVAL in bt_def.h */
|
|
ESP_BT_STATUS_PARAM_OUT_OF_RANGE, /* relate to BT_PARAM_OUT_OF_RANGE in bt_def.h */
|
|
ESP_BT_STATUS_TIMEOUT, /* relate to BT_STATUS_TIMEOUT in bt_def.h */
|
|
ESP_BT_STATUS_PEER_LE_DATA_LEN_UNSUPPORTED, /* relate to BTM_PEER_LE_DATA_LEN_UNSUPPORTED in btm_api.h */
|
|
ESP_BT_STATUS_CONTROL_LE_DATA_LEN_UNSUPPORTED,/* relate to BTM_CONTROL_LE_DATA_LEN_UNSUPPORTED in btm_api.h */
|
|
} esp_bt_status_t;
|
|
|
|
|
|
/*Define the bt octet 16 bit size*/
|
|
#define ESP_BT_OCTET16_LEN 16
|
|
typedef uint8_t esp_bt_octet16_t[ESP_BT_OCTET16_LEN]; /* octet array: size 16 */
|
|
|
|
#define ESP_BT_OCTET8_LEN 8
|
|
typedef uint8_t esp_bt_octet8_t[ESP_BT_OCTET8_LEN]; /* octet array: size 8 */
|
|
|
|
typedef uint8_t esp_link_key[ESP_BT_OCTET16_LEN]; /* Link Key */
|
|
|
|
/// Default GATT interface id
|
|
#define ESP_DEFAULT_GATT_IF 0xff
|
|
|
|
/// Default BLE connection param, if the value doesn't be overwritten
|
|
#define ESP_BLE_CONN_PARAM_UNDEF 0xffff /* use this value when a specific value not to be overwritten */
|
|
|
|
/// Check the param is valid or not
|
|
#define ESP_BLE_IS_VALID_PARAM(x, min, max) (((x) >= (min) && (x) <= (max)) || ((x) == ESP_BLE_CONN_PARAM_UNDEF))
|
|
|
|
/// UUID type
|
|
typedef struct {
|
|
#define ESP_UUID_LEN_16 2
|
|
#define ESP_UUID_LEN_32 4
|
|
#define ESP_UUID_LEN_128 16
|
|
uint16_t len; /*!< UUID length, 16bit, 32bit or 128bit */
|
|
union {
|
|
uint16_t uuid16;
|
|
uint32_t uuid32;
|
|
uint8_t uuid128[ESP_UUID_LEN_128];
|
|
} uuid; /*!< UUID */
|
|
} __attribute__((packed)) esp_bt_uuid_t;
|
|
|
|
/// Bluetooth device type
|
|
typedef enum {
|
|
ESP_BT_DEVICE_TYPE_BREDR = 0x01,
|
|
ESP_BT_DEVICE_TYPE_BLE = 0x02,
|
|
ESP_BT_DEVICE_TYPE_DUMO = 0x03,
|
|
} esp_bt_dev_type_t;
|
|
|
|
/// Bluetooth address length
|
|
#define ESP_BD_ADDR_LEN 6
|
|
|
|
/// Bluetooth device address
|
|
typedef uint8_t esp_bd_addr_t[ESP_BD_ADDR_LEN];
|
|
|
|
/// BLE device address type
|
|
typedef enum {
|
|
BLE_ADDR_TYPE_PUBLIC = 0x00,
|
|
BLE_ADDR_TYPE_RANDOM = 0x01,
|
|
BLE_ADDR_TYPE_RPA_PUBLIC = 0x02,
|
|
BLE_ADDR_TYPE_RPA_RANDOM = 0x03,
|
|
} esp_ble_addr_type_t;
|
|
|
|
/// Used to exchange the encrytyption key in the init key & response key
|
|
#define ESP_BLE_ENC_KEY_MASK (1 << 0) /* relate to BTM_BLE_ENC_KEY_MASK in btm_api.h */
|
|
/// Used to exchange the IRK key in the init key & response key
|
|
#define ESP_BLE_ID_KEY_MASK (1 << 1) /* relate to BTM_BLE_ID_KEY_MASK in btm_api.h */
|
|
/// Used to exchange the CSRK key in the init key & response key
|
|
#define ESP_BLE_CSR_KEY_MASK (1 << 2) /* relate to BTM_BLE_CSR_KEY_MASK in btm_api.h */
|
|
/// Used to exchange the link key(this key just used in the BLE & BR/EDR coexist mode) in the init key & response key
|
|
#define ESP_BLE_LINK_KEY_MASK (1 << 3) /* relate to BTM_BLE_LINK_KEY_MASK in btm_api.h */
|
|
typedef uint8_t esp_ble_key_mask_t; /* the key mask type */
|
|
|
|
/// Minimum of the application id
|
|
#define ESP_APP_ID_MIN 0x0000
|
|
/// Maximum of the application id
|
|
#define ESP_APP_ID_MAX 0x7fff
|
|
|
|
#define ESP_BD_ADDR_STR "%02x:%02x:%02x:%02x:%02x:%02x"
|
|
#define ESP_BD_ADDR_HEX(addr) addr[0], addr[1], addr[2], addr[3], addr[4], addr[5]
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* __ESP_BT_DEFS_H__ */
|