mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
Merge branch 'change/add_convt_from_hci_state_to_esp_state_v5.2' into 'release/v5.2'
change(bt/bluedroid): Use BTC util to convert HCI status to ESP status (v5.2) See merge request espressif/esp-idf!29921
This commit is contained in:
commit
77920038f6
@ -10,6 +10,7 @@
|
|||||||
#include "btc/btc_common.h"
|
#include "btc/btc_common.h"
|
||||||
#include "btc/btc_dm.h"
|
#include "btc/btc_dm.h"
|
||||||
#include "btc/btc_main.h"
|
#include "btc/btc_main.h"
|
||||||
|
#include "btc/btc_util.h"
|
||||||
#include "common/bt_trace.h"
|
#include "common/bt_trace.h"
|
||||||
#include "common/bt_target.h"
|
#include "common/bt_target.h"
|
||||||
#include "btc/btc_storage.h"
|
#include "btc/btc_storage.h"
|
||||||
@ -717,14 +718,14 @@ static void btc_dm_acl_link_stat(tBTA_DM_ACL_LINK_STAT *p_acl_link_stat)
|
|||||||
switch (p_acl_link_stat->event) {
|
switch (p_acl_link_stat->event) {
|
||||||
case BTA_ACL_LINK_STAT_CONN_CMPL: {
|
case BTA_ACL_LINK_STAT_CONN_CMPL: {
|
||||||
event = ESP_BT_GAP_ACL_CONN_CMPL_STAT_EVT;
|
event = ESP_BT_GAP_ACL_CONN_CMPL_STAT_EVT;
|
||||||
param.acl_conn_cmpl_stat.stat = p_acl_link_stat->link_act.conn_cmpl.status | ESP_BT_STATUS_BASE_FOR_HCI_ERR;
|
param.acl_conn_cmpl_stat.stat = btc_hci_to_esp_status(p_acl_link_stat->link_act.conn_cmpl.status);
|
||||||
param.acl_conn_cmpl_stat.handle = p_acl_link_stat->link_act.conn_cmpl.handle;
|
param.acl_conn_cmpl_stat.handle = p_acl_link_stat->link_act.conn_cmpl.handle;
|
||||||
memcpy(param.acl_conn_cmpl_stat.bda, p_acl_link_stat->link_act.conn_cmpl.bd_addr, ESP_BD_ADDR_LEN);
|
memcpy(param.acl_conn_cmpl_stat.bda, p_acl_link_stat->link_act.conn_cmpl.bd_addr, ESP_BD_ADDR_LEN);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case BTA_ACL_LINK_STAT_DISCONN_CMPL: {
|
case BTA_ACL_LINK_STAT_DISCONN_CMPL: {
|
||||||
event = ESP_BT_GAP_ACL_DISCONN_CMPL_STAT_EVT;
|
event = ESP_BT_GAP_ACL_DISCONN_CMPL_STAT_EVT;
|
||||||
param.acl_disconn_cmpl_stat.reason = p_acl_link_stat->link_act.disconn_cmpl.reason | ESP_BT_STATUS_BASE_FOR_HCI_ERR;
|
param.acl_disconn_cmpl_stat.reason = btc_hci_to_esp_status(p_acl_link_stat->link_act.disconn_cmpl.reason);
|
||||||
param.acl_disconn_cmpl_stat.handle = p_acl_link_stat->link_act.disconn_cmpl.handle;
|
param.acl_disconn_cmpl_stat.handle = p_acl_link_stat->link_act.disconn_cmpl.handle;
|
||||||
memcpy(param.acl_disconn_cmpl_stat.bda, p_acl_link_stat->link_act.disconn_cmpl.bd_addr, ESP_BD_ADDR_LEN);
|
memcpy(param.acl_disconn_cmpl_stat.bda, p_acl_link_stat->link_act.disconn_cmpl.bd_addr, ESP_BD_ADDR_LEN);
|
||||||
break;
|
break;
|
||||||
|
@ -338,8 +338,11 @@ esp_bt_status_t btc_hci_to_esp_status(uint8_t hci_status)
|
|||||||
case HCI_ERR_ILLEGAL_PARAMETER_FMT:
|
case HCI_ERR_ILLEGAL_PARAMETER_FMT:
|
||||||
esp_status = ESP_BT_STATUS_ERR_ILLEGAL_PARAMETER_FMT;
|
esp_status = ESP_BT_STATUS_ERR_ILLEGAL_PARAMETER_FMT;
|
||||||
break;
|
break;
|
||||||
|
case HCI_ERR_UNSUPPORTED_VALUE:
|
||||||
|
esp_status = ESP_BT_STATUS_UNSUPPORTED;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
esp_status = ESP_BT_STATUS_FAIL;
|
esp_status = hci_status | ESP_BT_STATUS_BASE_FOR_HCI_ERR;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user