mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-31 07:03:55 +00:00 
			
		
		
		
	[esp32_ble_client] Reduce log level for harmless BLE timeout race conditions (#10339)
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
This commit is contained in:
		| @@ -136,7 +136,8 @@ void BLEClientBase::disconnect() { | |||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   if (this->state_ == espbt::ClientState::CONNECTING || this->conn_id_ == UNSET_CONN_ID) { |   if (this->state_ == espbt::ClientState::CONNECTING || this->conn_id_ == UNSET_CONN_ID) { | ||||||
|     this->log_warning_("Disconnect before connected, disconnect scheduled."); |     ESP_LOGD(TAG, "[%d] [%s] Disconnect before connected, disconnect scheduled", this->connection_index_, | ||||||
|  |              this->address_str_.c_str()); | ||||||
|     this->want_disconnect_ = true; |     this->want_disconnect_ = true; | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
| @@ -284,11 +285,22 @@ bool BLEClientBase::gattc_event_handler(esp_gattc_cb_event_t event, esp_gatt_if_ | |||||||
|       this->log_gattc_event_("OPEN"); |       this->log_gattc_event_("OPEN"); | ||||||
|       // conn_id was already set in ESP_GATTC_CONNECT_EVT |       // conn_id was already set in ESP_GATTC_CONNECT_EVT | ||||||
|       this->service_count_ = 0; |       this->service_count_ = 0; | ||||||
|  |  | ||||||
|  |       // ESP-IDF's BLE stack may send ESP_GATTC_OPEN_EVT after esp_ble_gattc_open() returns an | ||||||
|  |       // error, if the error occurred at the BTA/GATT layer. This can result in the event | ||||||
|  |       // arriving after we've already transitioned to IDLE state. | ||||||
|  |       if (this->state_ == espbt::ClientState::IDLE) { | ||||||
|  |         ESP_LOGD(TAG, "[%d] [%s] ESP_GATTC_OPEN_EVT in IDLE state (status=%d), ignoring", this->connection_index_, | ||||||
|  |                  this->address_str_.c_str(), param->open.status); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|       if (this->state_ != espbt::ClientState::CONNECTING) { |       if (this->state_ != espbt::ClientState::CONNECTING) { | ||||||
|         // This should not happen but lets log it in case it does |         // This should not happen but lets log it in case it does | ||||||
|         // because it means we have a bad assumption about how the |         // because it means we have a bad assumption about how the | ||||||
|         // ESP BT stack works. |         // ESP BT stack works. | ||||||
|         this->log_error_("ESP_GATTC_OPEN_EVT wrong state status", param->open.status); |         ESP_LOGE(TAG, "[%d] [%s] ESP_GATTC_OPEN_EVT in %s state (status=%d)", this->connection_index_, | ||||||
|  |                  this->address_str_.c_str(), espbt::client_state_to_string(this->state_), param->open.status); | ||||||
|       } |       } | ||||||
|       if (param->open.status != ESP_GATT_OK && param->open.status != ESP_GATT_ALREADY_OPEN) { |       if (param->open.status != ESP_GATT_OK && param->open.status != ESP_GATT_ALREADY_OPEN) { | ||||||
|         this->log_gattc_warning_("Connection open", param->open.status); |         this->log_gattc_warning_("Connection open", param->open.status); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user