mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
fix(bt): get remote device name from eir data
This commit is contained in:
parent
85ded0b544
commit
602bd2d89a
@ -275,6 +275,7 @@ static void handle_bt_device_result(struct disc_res_param *disc_res)
|
|||||||
uint8_t len = 0;
|
uint8_t len = 0;
|
||||||
uint8_t *data = 0;
|
uint8_t *data = 0;
|
||||||
|
|
||||||
|
do {
|
||||||
data = esp_bt_gap_resolve_eir_data((uint8_t *)prop->val, ESP_BT_EIR_TYPE_CMPL_16BITS_UUID, &len);
|
data = esp_bt_gap_resolve_eir_data((uint8_t *)prop->val, ESP_BT_EIR_TYPE_CMPL_16BITS_UUID, &len);
|
||||||
if (data == NULL) {
|
if (data == NULL) {
|
||||||
data = esp_bt_gap_resolve_eir_data((uint8_t *)prop->val, ESP_BT_EIR_TYPE_INCMPL_16BITS_UUID, &len);
|
data = esp_bt_gap_resolve_eir_data((uint8_t *)prop->val, ESP_BT_EIR_TYPE_INCMPL_16BITS_UUID, &len);
|
||||||
@ -283,7 +284,7 @@ static void handle_bt_device_result(struct disc_res_param *disc_res)
|
|||||||
uuid.len = ESP_UUID_LEN_16;
|
uuid.len = ESP_UUID_LEN_16;
|
||||||
uuid.uuid.uuid16 = data[0] + (data[1] << 8);
|
uuid.uuid.uuid16 = data[0] + (data[1] << 8);
|
||||||
GAP_DBG_PRINTF(", "); print_uuid(&uuid);
|
GAP_DBG_PRINTF(", "); print_uuid(&uuid);
|
||||||
continue;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
data = esp_bt_gap_resolve_eir_data((uint8_t *)prop->val, ESP_BT_EIR_TYPE_CMPL_32BITS_UUID, &len);
|
data = esp_bt_gap_resolve_eir_data((uint8_t *)prop->val, ESP_BT_EIR_TYPE_CMPL_32BITS_UUID, &len);
|
||||||
@ -294,7 +295,7 @@ static void handle_bt_device_result(struct disc_res_param *disc_res)
|
|||||||
uuid.len = len;
|
uuid.len = len;
|
||||||
memcpy(&uuid.uuid.uuid32, data, sizeof(uint32_t));
|
memcpy(&uuid.uuid.uuid32, data, sizeof(uint32_t));
|
||||||
GAP_DBG_PRINTF(", "); print_uuid(&uuid);
|
GAP_DBG_PRINTF(", "); print_uuid(&uuid);
|
||||||
continue;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
data = esp_bt_gap_resolve_eir_data((uint8_t *)prop->val, ESP_BT_EIR_TYPE_CMPL_128BITS_UUID, &len);
|
data = esp_bt_gap_resolve_eir_data((uint8_t *)prop->val, ESP_BT_EIR_TYPE_CMPL_128BITS_UUID, &len);
|
||||||
@ -305,8 +306,8 @@ static void handle_bt_device_result(struct disc_res_param *disc_res)
|
|||||||
uuid.len = len;
|
uuid.len = len;
|
||||||
memcpy(uuid.uuid.uuid128, (uint8_t *)data, len);
|
memcpy(uuid.uuid.uuid128, (uint8_t *)data, len);
|
||||||
GAP_DBG_PRINTF(", "); print_uuid(&uuid);
|
GAP_DBG_PRINTF(", "); print_uuid(&uuid);
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
} while (0);
|
||||||
|
|
||||||
//try to find a name
|
//try to find a name
|
||||||
if (name == NULL) {
|
if (name == NULL) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user