mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
fix(bt/bluedroid): Fix prepare write for BLE example
This commit is contained in:
parent
67b9c0ac09
commit
36505e1c82
@ -387,20 +387,21 @@ void example_prepare_write_event_env(esp_gatt_if_t gatts_if, prepare_type_env_t
|
|||||||
{
|
{
|
||||||
EXAMPLE_DEBUG(EXAMPLE_TAG, "prepare write, handle = %d, value len = %d", param->write.handle, param->write.len);
|
EXAMPLE_DEBUG(EXAMPLE_TAG, "prepare write, handle = %d, value len = %d", param->write.handle, param->write.len);
|
||||||
esp_gatt_status_t status = ESP_GATT_OK;
|
esp_gatt_status_t status = ESP_GATT_OK;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_OFFSET;
|
||||||
|
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_ATTR_LEN;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status == ESP_GATT_OK && prepare_write_env->prepare_buf == NULL) {
|
||||||
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE * sizeof(uint8_t));
|
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE * sizeof(uint8_t));
|
||||||
prepare_write_env->prepare_len = 0;
|
prepare_write_env->prepare_len = 0;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if (prepare_write_env->prepare_buf == NULL) {
|
||||||
ESP_LOGE(EXAMPLE_TAG, "%s, Gatt_server prep no mem", __func__);
|
ESP_LOGE(EXAMPLE_TAG, "%s, Gatt_server prep no mem", __func__);
|
||||||
status = ESP_GATT_NO_RESOURCES;
|
status = ESP_GATT_NO_RESOURCES;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_OFFSET;
|
|
||||||
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_ATTR_LEN;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*send response when param->write.need_rsp is true */
|
/*send response when param->write.need_rsp is true */
|
||||||
if (param->write.need_rsp){
|
if (param->write.need_rsp){
|
||||||
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
||||||
|
@ -281,20 +281,19 @@ void example_write_event_env(esp_gatt_if_t gatts_if, prepare_type_env_t *prepare
|
|||||||
esp_gatt_status_t status = ESP_GATT_OK;
|
esp_gatt_status_t status = ESP_GATT_OK;
|
||||||
if (param->write.need_rsp) {
|
if (param->write.need_rsp) {
|
||||||
if (param->write.is_prep) {
|
if (param->write.is_prep) {
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_OFFSET;
|
||||||
|
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_ATTR_LEN;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status == ESP_GATT_OK && prepare_write_env->prepare_buf == NULL) {
|
||||||
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE * sizeof(uint8_t));
|
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE * sizeof(uint8_t));
|
||||||
prepare_write_env->prepare_len = 0;
|
prepare_write_env->prepare_len = 0;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if (prepare_write_env->prepare_buf == NULL) {
|
||||||
ESP_LOGE(GATTS_TAG, "Gatt_server prep no mem\n");
|
ESP_LOGE(GATTS_TAG, "Gatt_server prep no mem\n");
|
||||||
status = ESP_GATT_NO_RESOURCES;
|
status = ESP_GATT_NO_RESOURCES;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if(param->write.offset > PREPARE_BUF_MAX_SIZE ||
|
|
||||||
prepare_write_env->prepare_len > param->write.offset) {
|
|
||||||
status = ESP_GATT_INVALID_OFFSET;
|
|
||||||
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_ATTR_LEN;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
||||||
|
@ -242,19 +242,18 @@ void example_write_event_env(esp_gatt_if_t gatts_if, prepare_type_env_t *prepare
|
|||||||
esp_gatt_status_t status = ESP_GATT_OK;
|
esp_gatt_status_t status = ESP_GATT_OK;
|
||||||
if (param->write.need_rsp){
|
if (param->write.need_rsp){
|
||||||
if (param->write.is_prep){
|
if (param->write.is_prep){
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_OFFSET;
|
||||||
|
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_ATTR_LEN;
|
||||||
|
}
|
||||||
|
if (status == ESP_GATT_OK && prepare_write_env->prepare_buf == NULL) {
|
||||||
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
||||||
prepare_write_env->prepare_len = 0;
|
prepare_write_env->prepare_len = 0;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if (prepare_write_env->prepare_buf == NULL) {
|
||||||
ESP_LOGE(GATTS_TAG, "Gatt_server prep no mem\n");
|
ESP_LOGE(GATTS_TAG, "Gatt_server prep no mem\n");
|
||||||
status = ESP_GATT_NO_RESOURCES;
|
status = ESP_GATT_NO_RESOURCES;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_OFFSET;
|
|
||||||
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_ATTR_LEN;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
||||||
|
@ -770,21 +770,19 @@ The `example_write_event_env()` function contains the logic for the write long c
|
|||||||
void example_write_event_env(esp_gatt_if_t gatts_if, prepare_type_env_t *prepare_write_env, esp_ble_gatts_cb_param_t *param){
|
void example_write_event_env(esp_gatt_if_t gatts_if, prepare_type_env_t *prepare_write_env, esp_ble_gatts_cb_param_t *param){
|
||||||
esp_gatt_status_t status = ESP_GATT_OK;
|
esp_gatt_status_t status = ESP_GATT_OK;
|
||||||
if (param->write.need_rsp){
|
if (param->write.need_rsp){
|
||||||
if (param->write.is_prep){
|
if (param->write.is_prep){
|
||||||
if (prepare_write_env->prepare_buf == NULL){
|
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_OFFSET;
|
||||||
|
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_ATTR_LEN;
|
||||||
|
}
|
||||||
|
if (status == ESP_GATT_OK && prepare_write_env->prepare_buf == NULL) {
|
||||||
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
||||||
prepare_write_env->prepare_len = 0;
|
prepare_write_env->prepare_len = 0;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if (prepare_write_env->prepare_buf == NULL) {
|
||||||
ESP_LOGE(GATTS_TAG, "Gatt_server prep no mem\n");
|
ESP_LOGE(GATTS_TAG, "Gatt_server prep no mem\n");
|
||||||
status = ESP_GATT_NO_RESOURCES;
|
status = ESP_GATT_NO_RESOURCES;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_OFFSET;
|
|
||||||
}
|
|
||||||
else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_ATTR_LEN;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
||||||
@ -798,7 +796,6 @@ void example_write_event_env(esp_gatt_if_t gatts_if, prepare_type_env_t *prepare
|
|||||||
if (response_err != ESP_OK){
|
if (response_err != ESP_OK){
|
||||||
ESP_LOGE(GATTS_TAG, "Send response error\n");
|
ESP_LOGE(GATTS_TAG, "Send response error\n");
|
||||||
}
|
}
|
||||||
free(gatt_rsp);
|
|
||||||
if (status != ESP_GATT_OK){
|
if (status != ESP_GATT_OK){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -850,9 +847,9 @@ static prepare_type_env_t b_prepare_write_env;
|
|||||||
In order to use the prepare buffer, some memory space is allocated for it. In case the allocation fails due to a lack of memory, an error is printed:
|
In order to use the prepare buffer, some memory space is allocated for it. In case the allocation fails due to a lack of memory, an error is printed:
|
||||||
|
|
||||||
```c
|
```c
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if (status == ESP_GATT_OK && prepare_write_env->prepare_buf == NULL) {
|
||||||
prepare_write_env->prepare_buf =
|
prepare_write_env->prepare_buf =
|
||||||
(uint8_t*)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
(uint8_t*)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
||||||
prepare_write_env->prepare_len = 0;
|
prepare_write_env->prepare_len = 0;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if (prepare_write_env->prepare_buf == NULL) {
|
||||||
ESP_LOGE(GATTS_TAG, "Gatt_server prep no mem\n");
|
ESP_LOGE(GATTS_TAG, "Gatt_server prep no mem\n");
|
||||||
|
@ -283,20 +283,20 @@ void example_prepare_write_event_env(esp_gatt_if_t gatts_if, prepare_type_env_t
|
|||||||
{
|
{
|
||||||
ESP_LOGI(GATTS_TABLE_TAG, "prepare write, handle = %d, value len = %d", param->write.handle, param->write.len);
|
ESP_LOGI(GATTS_TABLE_TAG, "prepare write, handle = %d, value len = %d", param->write.handle, param->write.len);
|
||||||
esp_gatt_status_t status = ESP_GATT_OK;
|
esp_gatt_status_t status = ESP_GATT_OK;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_OFFSET;
|
||||||
|
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_ATTR_LEN;
|
||||||
|
}
|
||||||
|
if (status == ESP_GATT_OK && prepare_write_env->prepare_buf == NULL) {
|
||||||
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE * sizeof(uint8_t));
|
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE * sizeof(uint8_t));
|
||||||
prepare_write_env->prepare_len = 0;
|
prepare_write_env->prepare_len = 0;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if (prepare_write_env->prepare_buf == NULL) {
|
||||||
ESP_LOGE(GATTS_TABLE_TAG, "%s, Gatt_server prep no mem", __func__);
|
ESP_LOGE(GATTS_TABLE_TAG, "%s, Gatt_server prep no mem", __func__);
|
||||||
status = ESP_GATT_NO_RESOURCES;
|
status = ESP_GATT_NO_RESOURCES;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_OFFSET;
|
|
||||||
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_ATTR_LEN;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*send response when param->write.need_rsp is true */
|
/*send response when param->write.need_rsp is true */
|
||||||
if (param->write.need_rsp){
|
if (param->write.need_rsp){
|
||||||
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
||||||
|
@ -198,19 +198,19 @@ void example_write_event_env(esp_gatt_if_t gatts_if, prepare_type_env_t *prepare
|
|||||||
esp_gatt_status_t status = ESP_GATT_OK;
|
esp_gatt_status_t status = ESP_GATT_OK;
|
||||||
if (param->write.need_rsp){
|
if (param->write.need_rsp){
|
||||||
if (param->write.is_prep){
|
if (param->write.is_prep){
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_OFFSET;
|
||||||
|
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_ATTR_LEN;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (status == ESP_GATT_OK && prepare_write_env->prepare_buf == NULL) {
|
||||||
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
||||||
prepare_write_env->prepare_len = 0;
|
prepare_write_env->prepare_len = 0;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if (prepare_write_env->prepare_buf == NULL) {
|
||||||
ESP_LOGE(BT_BLE_COEX_TAG, "Gatt_server prep no mem\n");
|
ESP_LOGE(BT_BLE_COEX_TAG, "Gatt_server prep no mem\n");
|
||||||
status = ESP_GATT_NO_RESOURCES;
|
status = ESP_GATT_NO_RESOURCES;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_OFFSET;
|
|
||||||
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_ATTR_LEN;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
||||||
|
@ -526,19 +526,18 @@ static void example_write_event_env(esp_gatt_if_t gatts_if, prepare_type_env_t *
|
|||||||
esp_gatt_status_t status = ESP_GATT_OK;
|
esp_gatt_status_t status = ESP_GATT_OK;
|
||||||
if (param->write.need_rsp) {
|
if (param->write.need_rsp) {
|
||||||
if (param->write.is_prep) {
|
if (param->write.is_prep) {
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_OFFSET;
|
||||||
|
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
||||||
|
status = ESP_GATT_INVALID_ATTR_LEN;
|
||||||
|
}
|
||||||
|
if (status == ESP_GATT_OK && prepare_write_env->prepare_buf == NULL) {
|
||||||
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
prepare_write_env->prepare_buf = (uint8_t *)malloc(PREPARE_BUF_MAX_SIZE*sizeof(uint8_t));
|
||||||
prepare_write_env->prepare_len = 0;
|
prepare_write_env->prepare_len = 0;
|
||||||
if (prepare_write_env->prepare_buf == NULL) {
|
if (prepare_write_env->prepare_buf == NULL) {
|
||||||
ESP_LOGE(COEX_TAG, "Gatt_server prep no mem\n");
|
ESP_LOGE(COEX_TAG, "Gatt_server prep no mem\n");
|
||||||
status = ESP_GATT_NO_RESOURCES;
|
status = ESP_GATT_NO_RESOURCES;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if(param->write.offset > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_OFFSET;
|
|
||||||
} else if ((param->write.offset + param->write.len) > PREPARE_BUF_MAX_SIZE) {
|
|
||||||
status = ESP_GATT_INVALID_ATTR_LEN;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
esp_gatt_rsp_t *gatt_rsp = (esp_gatt_rsp_t *)malloc(sizeof(esp_gatt_rsp_t));
|
||||||
|
Loading…
Reference in New Issue
Block a user