mirror of
				https://github.com/0xFEEDC0DE64/arduino-esp32.git
				synced 2025-11-04 08:01:38 +01:00 
			
		
		
		
	* Update mDNS and LEDC * update toolchain * Update IDF to 1c3dd23 * Advertise the board variant for Arduino OTA * Add generic variant definition for mDNS
		
			
				
	
	
		
			138 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			6.5 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_ERR_ILLEGAL_PARAMETER_FMT,    /* relate to HCI_ERR_ILLEGAL_PARAMETER_FMT in hcidefs.h */
 | 
						|
    ESP_BT_STATUS_MEMORY_FULL,                  /* relate to BT_STATUS_MEMORY_FULL in bt_def.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
 | 
						|
 | 
						|
#define ESP_BLE_CONN_INT_MIN                0x0006       /*!< relate to BTM_BLE_CONN_INT_MIN in btm_ble_api.h */
 | 
						|
#define ESP_BLE_CONN_INT_MAX                0x0C80       /*!< relate to BTM_BLE_CONN_INT_MAX in btm_ble_api.h */
 | 
						|
#define ESP_BLE_CONN_LATENCY_MAX            500          /*!< relate to ESP_BLE_CONN_LATENCY_MAX in btm_ble_api.h */
 | 
						|
#define ESP_BLE_CONN_SUP_TOUT_MIN           0x000A       /*!< relate to BTM_BLE_CONN_SUP_TOUT_MIN in btm_ble_api.h */
 | 
						|
#define ESP_BLE_CONN_SUP_TOUT_MAX           0x0C80       /*!< relate to ESP_BLE_CONN_SUP_TOUT_MAX in btm_ble_api.h */
 | 
						|
#define ESP_BLE_CONN_PARAM_UNDEF            0xffff       /* use this value when a specific value not to be overwritten */ /* relate to ESP_BLE_CONN_PARAM_UNDEF in btm_ble_api.h */
 | 
						|
#define ESP_BLE_SCAN_PARAM_UNDEF            0xffffffff   /* relate to ESP_BLE_SCAN_PARAM_UNDEF in btm_ble_api.h */
 | 
						|
 | 
						|
/// 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__ */
 |