mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
Component/bt: add new cmd for blufi ,ESP32 close a gatt connection
This commit is contained in:
parent
8f9707fd07
commit
fb45ee7a4c
@ -21,6 +21,7 @@
|
|||||||
#include "btc_manage.h"
|
#include "btc_manage.h"
|
||||||
#include "btc_main.h"
|
#include "btc_main.h"
|
||||||
#include "future.h"
|
#include "future.h"
|
||||||
|
#include "btc_gatts.h"
|
||||||
|
|
||||||
esp_err_t esp_blufi_register_callbacks(esp_blufi_callbacks_t *callbacks)
|
esp_err_t esp_blufi_register_callbacks(esp_blufi_callbacks_t *callbacks)
|
||||||
{
|
{
|
||||||
@ -92,3 +93,17 @@ uint16_t esp_blufi_get_version(void)
|
|||||||
return btc_blufi_get_version();
|
return btc_blufi_get_version();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
esp_err_t esp_blufi_close(esp_gatt_if_t gatts_if, uint16_t conn_id)
|
||||||
|
{
|
||||||
|
btc_msg_t msg;
|
||||||
|
btc_ble_gatts_args_t arg;
|
||||||
|
if (esp_bluedroid_get_status() != ESP_BLUEDROID_STATUS_ENABLED) {
|
||||||
|
return ESP_ERR_INVALID_STATE;
|
||||||
|
}
|
||||||
|
msg.sig = BTC_SIG_API_CALL;
|
||||||
|
msg.pid = BTC_PID_GATTS;
|
||||||
|
msg.act = BTC_GATTS_ACT_CLOSE;
|
||||||
|
arg.close.conn_id = conn_id;
|
||||||
|
return (btc_transfer_context(&msg, &arg, sizeof(btc_ble_gatts_args_t), NULL)
|
||||||
|
== BT_STATUS_SUCCESS ? ESP_OK : ESP_FAIL);
|
||||||
|
}
|
||||||
|
@ -49,6 +49,7 @@ typedef enum {
|
|||||||
ESP_BLUFI_EVENT_RECV_SERVER_CERT, /*<! When Phone send Server certificate to ESP32, this event happen */
|
ESP_BLUFI_EVENT_RECV_SERVER_CERT, /*<! When Phone send Server certificate to ESP32, this event happen */
|
||||||
ESP_BLUFI_EVENT_RECV_CLIENT_PRIV_KEY, /*<! When Phone send Client Private key to ESP32, this event happen */
|
ESP_BLUFI_EVENT_RECV_CLIENT_PRIV_KEY, /*<! When Phone send Client Private key to ESP32, this event happen */
|
||||||
ESP_BLUFI_EVENT_RECV_SERVER_PRIV_KEY, /*<! When Phone send Server Private key to ESP32, this event happen */
|
ESP_BLUFI_EVENT_RECV_SERVER_PRIV_KEY, /*<! When Phone send Server Private key to ESP32, this event happen */
|
||||||
|
ESP_BLUFI_EVENT_RECV_SLAVE_DISCONNECT_BLE, /*<! When Phone send Disconnect key to ESP32, this event happen */
|
||||||
} esp_blufi_cb_event_t;
|
} esp_blufi_cb_event_t;
|
||||||
|
|
||||||
/// BLUFI config status
|
/// BLUFI config status
|
||||||
@ -122,6 +123,8 @@ typedef union {
|
|||||||
*/
|
*/
|
||||||
struct blufi_connect_evt_param {
|
struct blufi_connect_evt_param {
|
||||||
esp_bd_addr_t remote_bda; /*!< Blufi Remote bluetooth device address */
|
esp_bd_addr_t remote_bda; /*!< Blufi Remote bluetooth device address */
|
||||||
|
uint8_t server_if; /*!< server interface */
|
||||||
|
uint16_t conn_id; /*!< Connection id */
|
||||||
} connect; /*!< Blufi callback param of ESP_BLUFI_EVENT_CONNECT */
|
} connect; /*!< Blufi callback param of ESP_BLUFI_EVENT_CONNECT */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -353,6 +356,18 @@ esp_err_t esp_blufi_send_wifi_conn_report(wifi_mode_t opmode, esp_blufi_sta_conn
|
|||||||
*/
|
*/
|
||||||
uint16_t esp_blufi_get_version(void);
|
uint16_t esp_blufi_get_version(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Close a connection a remote device.
|
||||||
|
*
|
||||||
|
* @param[in] gatts_if: GATT server access interface
|
||||||
|
* @param[in] conn_id: connection ID to be closed.
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* - ESP_OK : success
|
||||||
|
* - other : failed
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
esp_err_t esp_blufi_close(esp_gatt_if_t gatts_if, uint16_t conn_id);
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -253,6 +253,8 @@ static void blufi_profile_cb(tBTA_GATTS_EVT event, tBTA_GATTS *p_data)
|
|||||||
msg.pid = BTC_PID_BLUFI;
|
msg.pid = BTC_PID_BLUFI;
|
||||||
msg.act = ESP_BLUFI_EVENT_BLE_CONNECT;
|
msg.act = ESP_BLUFI_EVENT_BLE_CONNECT;
|
||||||
memcpy(param.connect.remote_bda, p_data->conn.remote_bda, sizeof(esp_bd_addr_t));
|
memcpy(param.connect.remote_bda, p_data->conn.remote_bda, sizeof(esp_bd_addr_t));
|
||||||
|
param.connect.conn_id=p_data->conn.conn_id;
|
||||||
|
param.connect.server_if=p_data->conn.server_if;
|
||||||
btc_transfer_context(&msg, ¶m, sizeof(esp_blufi_cb_param_t), NULL);
|
btc_transfer_context(&msg, ¶m, sizeof(esp_blufi_cb_param_t), NULL);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -767,6 +769,9 @@ void btc_blufi_cb_handler(btc_msg_t *msg)
|
|||||||
case ESP_BLUFI_EVENT_RECV_SERVER_PRIV_KEY:
|
case ESP_BLUFI_EVENT_RECV_SERVER_PRIV_KEY:
|
||||||
btc_blufi_cb_to_app(ESP_BLUFI_EVENT_RECV_SERVER_PRIV_KEY, param);
|
btc_blufi_cb_to_app(ESP_BLUFI_EVENT_RECV_SERVER_PRIV_KEY, param);
|
||||||
break;
|
break;
|
||||||
|
case ESP_BLUFI_EVENT_RECV_SLAVE_DISCONNECT_BLE:
|
||||||
|
btc_blufi_cb_to_app(ESP_BLUFI_EVENT_RECV_SLAVE_DISCONNECT_BLE, param);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
LOG_ERROR("%s UNKNOWN %d\n", __func__, msg->act);
|
LOG_ERROR("%s UNKNOWN %d\n", __func__, msg->act);
|
||||||
break;
|
break;
|
||||||
|
@ -100,6 +100,12 @@ void btc_blufi_protocol_handler(uint8_t type, uint8_t *data, int len)
|
|||||||
btc_blufi_send_encap(type, &data[0], sizeof(data));
|
btc_blufi_send_encap(type, &data[0], sizeof(data));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case BLUFI_TYPE_CTRL_SUBTYPE_DISCONNECT_BLE:
|
||||||
|
msg.sig = BTC_SIG_API_CB;
|
||||||
|
msg.pid = BTC_PID_BLUFI;
|
||||||
|
msg.act = ESP_BLUFI_EVENT_RECV_SLAVE_DISCONNECT_BLE;
|
||||||
|
btc_transfer_context(&msg, NULL, 0, NULL);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
LOG_ERROR("%s Unkown Ctrl pkt %02x\n", __func__, type);
|
LOG_ERROR("%s Unkown Ctrl pkt %02x\n", __func__, type);
|
||||||
break;
|
break;
|
||||||
|
@ -92,6 +92,7 @@ typedef struct blufi_frag_hdr blufi_frag_hdr_t;
|
|||||||
#define BLUFI_TYPE_CTRL_SUBTYPE_GET_WIFI_STATUS 0x05
|
#define BLUFI_TYPE_CTRL_SUBTYPE_GET_WIFI_STATUS 0x05
|
||||||
#define BLUFI_TYPE_CTRL_SUBTYPE_DEAUTHENTICATE_STA 0x06
|
#define BLUFI_TYPE_CTRL_SUBTYPE_DEAUTHENTICATE_STA 0x06
|
||||||
#define BLUFI_TYPE_CTRL_SUBTYPE_GET_VERSION 0x07
|
#define BLUFI_TYPE_CTRL_SUBTYPE_GET_VERSION 0x07
|
||||||
|
#define BLUFI_TYPE_CTRL_SUBTYPE_DISCONNECT_BLE 0x08
|
||||||
|
|
||||||
#define BLUFI_TYPE_DATA 0x1
|
#define BLUFI_TYPE_DATA 0x1
|
||||||
#define BLUFI_TYPE_DATA_SUBTYPE_NEG 0x00
|
#define BLUFI_TYPE_DATA_SUBTYPE_NEG 0x00
|
||||||
|
@ -125,4 +125,5 @@ Functions
|
|||||||
.. doxygenfunction:: esp_blufi_profile_deinit
|
.. doxygenfunction:: esp_blufi_profile_deinit
|
||||||
.. doxygenfunction:: esp_blufi_send_wifi_conn_report
|
.. doxygenfunction:: esp_blufi_send_wifi_conn_report
|
||||||
.. doxygenfunction:: esp_blufi_get_version
|
.. doxygenfunction:: esp_blufi_get_version
|
||||||
|
.. doxygenfunction:: esp_blufi_close
|
||||||
|
|
||||||
|
@ -88,6 +88,9 @@ static uint8_t gl_sta_bssid[6];
|
|||||||
static uint8_t gl_sta_ssid[32];
|
static uint8_t gl_sta_ssid[32];
|
||||||
static int gl_sta_ssid_len;
|
static int gl_sta_ssid_len;
|
||||||
|
|
||||||
|
/* connect infor*/
|
||||||
|
static uint8_t server_if;
|
||||||
|
static uint16_t conn_id;
|
||||||
static esp_err_t example_net_event_handler(void *ctx, system_event_t *event)
|
static esp_err_t example_net_event_handler(void *ctx, system_event_t *event)
|
||||||
{
|
{
|
||||||
wifi_mode_t mode;
|
wifi_mode_t mode;
|
||||||
@ -178,6 +181,8 @@ static void example_event_callback(esp_blufi_cb_event_t event, esp_blufi_cb_para
|
|||||||
break;
|
break;
|
||||||
case ESP_BLUFI_EVENT_BLE_CONNECT:
|
case ESP_BLUFI_EVENT_BLE_CONNECT:
|
||||||
BLUFI_INFO("BLUFI ble connect\n");
|
BLUFI_INFO("BLUFI ble connect\n");
|
||||||
|
server_if=param->connect.server_if;
|
||||||
|
conn_id=param->connect.conn_id;
|
||||||
esp_ble_gap_stop_advertising();
|
esp_ble_gap_stop_advertising();
|
||||||
blufi_security_deinit();
|
blufi_security_deinit();
|
||||||
blufi_security_init();
|
blufi_security_init();
|
||||||
@ -218,6 +223,10 @@ static void example_event_callback(esp_blufi_cb_event_t event, esp_blufi_cb_para
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case ESP_BLUFI_EVENT_RECV_SLAVE_DISCONNECT_BLE:
|
||||||
|
BLUFI_INFO("blufi close a gatt connection");
|
||||||
|
esp_blufi_close(server_if,conn_id);
|
||||||
|
break;
|
||||||
case ESP_BLUFI_EVENT_DEAUTHENTICATE_STA:
|
case ESP_BLUFI_EVENT_DEAUTHENTICATE_STA:
|
||||||
/* TODO */
|
/* TODO */
|
||||||
break;
|
break;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user