Merge branch 'bugfix/btdm_blufi_send_longer_custom_data_will_congested_v4.0' into 'release/v4.0'

component/bt: fix Blufi sends longer customer data  will will lead congested(backport v4.0)

See merge request espressif/esp-idf!9918
This commit is contained in:
Island
2020-08-05 14:23:41 +08:00

View File

@@ -36,6 +36,7 @@
#include "blufi_int.h" #include "blufi_int.h"
#include "esp_blufi_api.h" #include "esp_blufi_api.h"
#include "esp_gatt_common_api.h"
#if (GATTS_INCLUDED == TRUE) #if (GATTS_INCLUDED == TRUE)
@@ -530,10 +531,17 @@ void btc_blufi_send_encap(uint8_t type, uint8_t *data, int total_data_len)
remain_len -= hdr->data_len; remain_len -= hdr->data_len;
} }
btc_blufi_send_notify((uint8_t *)hdr, retry:
if (esp_ble_get_cur_sendable_packets_num(blufi_env.conn_id) > 0) {
btc_blufi_send_notify((uint8_t *)hdr,
((hdr->fc & BLUFI_FC_CHECK) ? ((hdr->fc & BLUFI_FC_CHECK) ?
hdr->data_len + sizeof(struct blufi_hdr) + 2 : hdr->data_len + sizeof(struct blufi_hdr) + 2 :
hdr->data_len + sizeof(struct blufi_hdr))); hdr->data_len + sizeof(struct blufi_hdr)));
} else {
BTC_TRACE_WARNING("%s wait to send blufi custom data\n", __func__);
vTaskDelay(pdMS_TO_TICKS(10));
goto retry;
}
osi_free(hdr); osi_free(hdr);
hdr = NULL; hdr = NULL;