mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-20 18:01:44 +00:00 
			
		
		
		
	esp_http_client: Fixed handling of EAGAIN return
For https connection `ESP_TLS_ERR_SSL_WANT_READ` of esp_transport_read was getting treated as error. Treated this as a timeout to fix connection abort issue! Also handled http connection EAGAIN with `errno == EAGAIN` check. Signed-off-by: Vikram Dattu <vikram.dattu@espressif.com>
This commit is contained in:
		| @@ -967,11 +967,18 @@ int esp_http_client_read(esp_http_client_handle_t client, char *buffer, int len) | |||||||
|                 } |                 } | ||||||
|                 ESP_LOG_LEVEL(sev, TAG, "esp_transport_read returned:%d and errno:%d ", rlen, errno); |                 ESP_LOG_LEVEL(sev, TAG, "esp_transport_read returned:%d and errno:%d ", rlen, errno); | ||||||
|             } |             } | ||||||
|             if (rlen < 0 && ridx == 0 && !esp_http_client_is_complete_data_received(client)) { | #ifdef CONFIG_ESP_HTTP_CLIENT_ENABLE_HTTPS | ||||||
|                 return ESP_FAIL; |             if (rlen == ESP_TLS_ERR_SSL_WANT_READ || errno == EAGAIN) { | ||||||
|             } else { | #else | ||||||
|  |             if (errno == EAGAIN) { | ||||||
|  | #endif | ||||||
|  |                 ESP_LOGD(TAG, "Received EAGAIN! rlen = %d, errno %d", rlen, errno); | ||||||
|                 return ridx; |                 return ridx; | ||||||
|             } |             } | ||||||
|  |             if (rlen < 0 && ridx == 0 && !esp_http_client_is_complete_data_received(client)) { | ||||||
|  |                 return ESP_FAIL; | ||||||
|  |             } | ||||||
|  |             return ridx; | ||||||
|         } |         } | ||||||
|         res_buffer->output_ptr = buffer + ridx; |         res_buffer->output_ptr = buffer + ridx; | ||||||
|         http_parser_execute(client->parser, client->parser_settings, res_buffer->data, rlen); |         http_parser_execute(client->parser, client->parser_settings, res_buffer->data, rlen); | ||||||
|   | |||||||
| @@ -327,6 +327,7 @@ esp_err_t esp_https_ota_perform(esp_https_ota_handle_t https_ota_handle) | |||||||
|             } else if (data_read > 0) { |             } else if (data_read > 0) { | ||||||
|                 return _ota_write(handle, (const void *)handle->ota_upgrade_buf, data_read); |                 return _ota_write(handle, (const void *)handle->ota_upgrade_buf, data_read); | ||||||
|             } else { |             } else { | ||||||
|  |                 ESP_LOGE(TAG, "data read %d, errno %d", data_read, errno); | ||||||
|                 return ESP_FAIL; |                 return ESP_FAIL; | ||||||
|             } |             } | ||||||
|             handle->state = ESP_HTTPS_OTA_SUCCESS; |             handle->state = ESP_HTTPS_OTA_SUCCESS; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Vikram Dattu
					Vikram Dattu