mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-26 12:43:48 +00:00 
			
		
		
		
	[bme280_base, bmp280_base] add reasons to the fails, clean up logging (#10209)
Co-authored-by: Keith Burzinski <kbx81x@gmail.com>
This commit is contained in:
		| @@ -7,6 +7,8 @@ | |||||||
| #include <esphome/components/sensor/sensor.h> | #include <esphome/components/sensor/sensor.h> | ||||||
| #include <esphome/core/component.h> | #include <esphome/core/component.h> | ||||||
|  |  | ||||||
|  | #define BME280_ERROR_WRONG_CHIP_ID "Wrong chip ID" | ||||||
|  |  | ||||||
| namespace esphome { | namespace esphome { | ||||||
| namespace bme280_base { | namespace bme280_base { | ||||||
|  |  | ||||||
| @@ -98,18 +100,18 @@ void BME280Component::setup() { | |||||||
|  |  | ||||||
|   if (!this->read_byte(BME280_REGISTER_CHIPID, &chip_id)) { |   if (!this->read_byte(BME280_REGISTER_CHIPID, &chip_id)) { | ||||||
|     this->error_code_ = COMMUNICATION_FAILED; |     this->error_code_ = COMMUNICATION_FAILED; | ||||||
|     this->mark_failed(); |     this->mark_failed(ESP_LOG_MSG_COMM_FAIL); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   if (chip_id != 0x60) { |   if (chip_id != 0x60) { | ||||||
|     this->error_code_ = WRONG_CHIP_ID; |     this->error_code_ = WRONG_CHIP_ID; | ||||||
|     this->mark_failed(); |     this->mark_failed(BME280_ERROR_WRONG_CHIP_ID); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Send a soft reset. |   // Send a soft reset. | ||||||
|   if (!this->write_byte(BME280_REGISTER_RESET, BME280_SOFT_RESET)) { |   if (!this->write_byte(BME280_REGISTER_RESET, BME280_SOFT_RESET)) { | ||||||
|     this->mark_failed(); |     this->mark_failed("Reset failed"); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   // Wait until the NVM data has finished loading. |   // Wait until the NVM data has finished loading. | ||||||
| @@ -118,14 +120,12 @@ void BME280Component::setup() { | |||||||
|   do {  // NOLINT |   do {  // NOLINT | ||||||
|     delay(2); |     delay(2); | ||||||
|     if (!this->read_byte(BME280_REGISTER_STATUS, &status)) { |     if (!this->read_byte(BME280_REGISTER_STATUS, &status)) { | ||||||
|       ESP_LOGW(TAG, "Error reading status register."); |       this->mark_failed("Error reading status register"); | ||||||
|       this->mark_failed(); |  | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|   } while ((status & BME280_STATUS_IM_UPDATE) && (--retry)); |   } while ((status & BME280_STATUS_IM_UPDATE) && (--retry)); | ||||||
|   if (status & BME280_STATUS_IM_UPDATE) { |   if (status & BME280_STATUS_IM_UPDATE) { | ||||||
|     ESP_LOGW(TAG, "Timeout loading NVM."); |     this->mark_failed("Timeout loading NVM"); | ||||||
|     this->mark_failed(); |  | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -153,26 +153,26 @@ void BME280Component::setup() { | |||||||
|  |  | ||||||
|   uint8_t humid_control_val = 0; |   uint8_t humid_control_val = 0; | ||||||
|   if (!this->read_byte(BME280_REGISTER_CONTROLHUMID, &humid_control_val)) { |   if (!this->read_byte(BME280_REGISTER_CONTROLHUMID, &humid_control_val)) { | ||||||
|     this->mark_failed(); |     this->mark_failed("Read humidity control"); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   humid_control_val &= ~0b00000111; |   humid_control_val &= ~0b00000111; | ||||||
|   humid_control_val |= this->humidity_oversampling_ & 0b111; |   humid_control_val |= this->humidity_oversampling_ & 0b111; | ||||||
|   if (!this->write_byte(BME280_REGISTER_CONTROLHUMID, humid_control_val)) { |   if (!this->write_byte(BME280_REGISTER_CONTROLHUMID, humid_control_val)) { | ||||||
|     this->mark_failed(); |     this->mark_failed("Write humidity control"); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   uint8_t config_register = 0; |   uint8_t config_register = 0; | ||||||
|   if (!this->read_byte(BME280_REGISTER_CONFIG, &config_register)) { |   if (!this->read_byte(BME280_REGISTER_CONFIG, &config_register)) { | ||||||
|     this->mark_failed(); |     this->mark_failed("Read config"); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   config_register &= ~0b11111100; |   config_register &= ~0b11111100; | ||||||
|   config_register |= 0b101 << 5;  // 1000 ms standby time |   config_register |= 0b101 << 5;  // 1000 ms standby time | ||||||
|   config_register |= (this->iir_filter_ & 0b111) << 2; |   config_register |= (this->iir_filter_ & 0b111) << 2; | ||||||
|   if (!this->write_byte(BME280_REGISTER_CONFIG, config_register)) { |   if (!this->write_byte(BME280_REGISTER_CONFIG, config_register)) { | ||||||
|     this->mark_failed(); |     this->mark_failed("Write config"); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @@ -183,7 +183,7 @@ void BME280Component::dump_config() { | |||||||
|       ESP_LOGE(TAG, ESP_LOG_MSG_COMM_FAIL); |       ESP_LOGE(TAG, ESP_LOG_MSG_COMM_FAIL); | ||||||
|       break; |       break; | ||||||
|     case WRONG_CHIP_ID: |     case WRONG_CHIP_ID: | ||||||
|       ESP_LOGE(TAG, "BME280 has wrong chip ID! Is it a BME280?"); |       ESP_LOGE(TAG, BME280_ERROR_WRONG_CHIP_ID); | ||||||
|       break; |       break; | ||||||
|     case NONE: |     case NONE: | ||||||
|     default: |     default: | ||||||
| @@ -223,21 +223,21 @@ void BME280Component::update() { | |||||||
|   this->set_timeout("data", uint32_t(ceilf(meas_time)), [this]() { |   this->set_timeout("data", uint32_t(ceilf(meas_time)), [this]() { | ||||||
|     uint8_t data[8]; |     uint8_t data[8]; | ||||||
|     if (!this->read_bytes(BME280_REGISTER_MEASUREMENTS, data, 8)) { |     if (!this->read_bytes(BME280_REGISTER_MEASUREMENTS, data, 8)) { | ||||||
|       ESP_LOGW(TAG, "Error reading registers."); |       ESP_LOGW(TAG, "Error reading registers"); | ||||||
|       this->status_set_warning(); |       this->status_set_warning(); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     int32_t t_fine = 0; |     int32_t t_fine = 0; | ||||||
|     float const temperature = this->read_temperature_(data, &t_fine); |     float const temperature = this->read_temperature_(data, &t_fine); | ||||||
|     if (std::isnan(temperature)) { |     if (std::isnan(temperature)) { | ||||||
|       ESP_LOGW(TAG, "Invalid temperature, cannot read pressure & humidity values."); |       ESP_LOGW(TAG, "Invalid temperature"); | ||||||
|       this->status_set_warning(); |       this->status_set_warning(); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     float const pressure = this->read_pressure_(data, t_fine); |     float const pressure = this->read_pressure_(data, t_fine); | ||||||
|     float const humidity = this->read_humidity_(data, t_fine); |     float const humidity = this->read_humidity_(data, t_fine); | ||||||
|  |  | ||||||
|     ESP_LOGV(TAG, "Got temperature=%.1f°C pressure=%.1fhPa humidity=%.1f%%", temperature, pressure, humidity); |     ESP_LOGV(TAG, "Temperature=%.1f°C Pressure=%.1fhPa Humidity=%.1f%%", temperature, pressure, humidity); | ||||||
|     if (this->temperature_sensor_ != nullptr) |     if (this->temperature_sensor_ != nullptr) | ||||||
|       this->temperature_sensor_->publish_state(temperature); |       this->temperature_sensor_->publish_state(temperature); | ||||||
|     if (this->pressure_sensor_ != nullptr) |     if (this->pressure_sensor_ != nullptr) | ||||||
|   | |||||||
| @@ -2,6 +2,8 @@ | |||||||
| #include "esphome/core/hal.h" | #include "esphome/core/hal.h" | ||||||
| #include "esphome/core/log.h" | #include "esphome/core/log.h" | ||||||
|  |  | ||||||
|  | #define BMP280_ERROR_WRONG_CHIP_ID "Wrong chip ID" | ||||||
|  |  | ||||||
| namespace esphome { | namespace esphome { | ||||||
| namespace bmp280_base { | namespace bmp280_base { | ||||||
|  |  | ||||||
| @@ -63,23 +65,23 @@ void BMP280Component::setup() { | |||||||
|   // https://community.st.com/t5/stm32-mcus-products/issue-with-reading-bmp280-chip-id-using-spi/td-p/691855 |   // https://community.st.com/t5/stm32-mcus-products/issue-with-reading-bmp280-chip-id-using-spi/td-p/691855 | ||||||
|   if (!this->read_byte(0xD0, &chip_id)) { |   if (!this->read_byte(0xD0, &chip_id)) { | ||||||
|     this->error_code_ = COMMUNICATION_FAILED; |     this->error_code_ = COMMUNICATION_FAILED; | ||||||
|     this->mark_failed(); |     this->mark_failed(ESP_LOG_MSG_COMM_FAIL); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   if (!this->read_byte(0xD0, &chip_id)) { |   if (!this->read_byte(0xD0, &chip_id)) { | ||||||
|     this->error_code_ = COMMUNICATION_FAILED; |     this->error_code_ = COMMUNICATION_FAILED; | ||||||
|     this->mark_failed(); |     this->mark_failed(ESP_LOG_MSG_COMM_FAIL); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   if (chip_id != 0x58) { |   if (chip_id != 0x58) { | ||||||
|     this->error_code_ = WRONG_CHIP_ID; |     this->error_code_ = WRONG_CHIP_ID; | ||||||
|     this->mark_failed(); |     this->mark_failed(BMP280_ERROR_WRONG_CHIP_ID); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Send a soft reset. |   // Send a soft reset. | ||||||
|   if (!this->write_byte(BMP280_REGISTER_RESET, BMP280_SOFT_RESET)) { |   if (!this->write_byte(BMP280_REGISTER_RESET, BMP280_SOFT_RESET)) { | ||||||
|     this->mark_failed(); |     this->mark_failed("Reset failed"); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   // Wait until the NVM data has finished loading. |   // Wait until the NVM data has finished loading. | ||||||
| @@ -88,14 +90,12 @@ void BMP280Component::setup() { | |||||||
|   do { |   do { | ||||||
|     delay(2); |     delay(2); | ||||||
|     if (!this->read_byte(BMP280_REGISTER_STATUS, &status)) { |     if (!this->read_byte(BMP280_REGISTER_STATUS, &status)) { | ||||||
|       ESP_LOGW(TAG, "Error reading status register."); |       this->mark_failed("Error reading status register"); | ||||||
|       this->mark_failed(); |  | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|   } while ((status & BMP280_STATUS_IM_UPDATE) && (--retry)); |   } while ((status & BMP280_STATUS_IM_UPDATE) && (--retry)); | ||||||
|   if (status & BMP280_STATUS_IM_UPDATE) { |   if (status & BMP280_STATUS_IM_UPDATE) { | ||||||
|     ESP_LOGW(TAG, "Timeout loading NVM."); |     this->mark_failed("Timeout loading NVM"); | ||||||
|     this->mark_failed(); |  | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -116,14 +116,14 @@ void BMP280Component::setup() { | |||||||
|  |  | ||||||
|   uint8_t config_register = 0; |   uint8_t config_register = 0; | ||||||
|   if (!this->read_byte(BMP280_REGISTER_CONFIG, &config_register)) { |   if (!this->read_byte(BMP280_REGISTER_CONFIG, &config_register)) { | ||||||
|     this->mark_failed(); |     this->mark_failed("Read config"); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
|   config_register &= ~0b11111100; |   config_register &= ~0b11111100; | ||||||
|   config_register |= 0b000 << 5;  // 0.5 ms standby time |   config_register |= 0b000 << 5;  // 0.5 ms standby time | ||||||
|   config_register |= (this->iir_filter_ & 0b111) << 2; |   config_register |= (this->iir_filter_ & 0b111) << 2; | ||||||
|   if (!this->write_byte(BMP280_REGISTER_CONFIG, config_register)) { |   if (!this->write_byte(BMP280_REGISTER_CONFIG, config_register)) { | ||||||
|     this->mark_failed(); |     this->mark_failed("Write config"); | ||||||
|     return; |     return; | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @@ -134,7 +134,7 @@ void BMP280Component::dump_config() { | |||||||
|       ESP_LOGE(TAG, ESP_LOG_MSG_COMM_FAIL); |       ESP_LOGE(TAG, ESP_LOG_MSG_COMM_FAIL); | ||||||
|       break; |       break; | ||||||
|     case WRONG_CHIP_ID: |     case WRONG_CHIP_ID: | ||||||
|       ESP_LOGE(TAG, "BMP280 has wrong chip ID! Is it a BME280?"); |       ESP_LOGE(TAG, BMP280_ERROR_WRONG_CHIP_ID); | ||||||
|       break; |       break; | ||||||
|     case NONE: |     case NONE: | ||||||
|     default: |     default: | ||||||
| @@ -172,13 +172,13 @@ void BMP280Component::update() { | |||||||
|     int32_t t_fine = 0; |     int32_t t_fine = 0; | ||||||
|     float temperature = this->read_temperature_(&t_fine); |     float temperature = this->read_temperature_(&t_fine); | ||||||
|     if (std::isnan(temperature)) { |     if (std::isnan(temperature)) { | ||||||
|       ESP_LOGW(TAG, "Invalid temperature, cannot read pressure values."); |       ESP_LOGW(TAG, "Invalid temperature"); | ||||||
|       this->status_set_warning(); |       this->status_set_warning(); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     float pressure = this->read_pressure_(t_fine); |     float pressure = this->read_pressure_(t_fine); | ||||||
|  |  | ||||||
|     ESP_LOGD(TAG, "Got temperature=%.1f°C pressure=%.1fhPa", temperature, pressure); |     ESP_LOGV(TAG, "Temperature=%.1f°C Pressure=%.1fhPa", temperature, pressure); | ||||||
|     if (this->temperature_sensor_ != nullptr) |     if (this->temperature_sensor_ != nullptr) | ||||||
|       this->temperature_sensor_->publish_state(temperature); |       this->temperature_sensor_->publish_state(temperature); | ||||||
|     if (this->pressure_sensor_ != nullptr) |     if (this->pressure_sensor_ != nullptr) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user