mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-31 15:12:06 +00:00 
			
		
		
		
	Add support for using BMP280 with SPI (#7053)
Co-authored-by: Keith Burzinski <kbx81x@gmail.com>
This commit is contained in:
		| @@ -70,6 +70,9 @@ esphome/components/bme680_bsec/* @trvrnrth | |||||||
| esphome/components/bme68x_bsec2/* @kbx81 @neffs | esphome/components/bme68x_bsec2/* @kbx81 @neffs | ||||||
| esphome/components/bme68x_bsec2_i2c/* @kbx81 @neffs | esphome/components/bme68x_bsec2_i2c/* @kbx81 @neffs | ||||||
| esphome/components/bmi160/* @flaviut | esphome/components/bmi160/* @flaviut | ||||||
|  | esphome/components/bmp280_base/* @ademuri | ||||||
|  | esphome/components/bmp280_i2c/* @ademuri | ||||||
|  | esphome/components/bmp280_spi/* @ademuri | ||||||
| esphome/components/bmp3xx/* @latonita | esphome/components/bmp3xx/* @latonita | ||||||
| esphome/components/bmp3xx_base/* @latonita @martgras | esphome/components/bmp3xx_base/* @latonita @martgras | ||||||
| esphome/components/bmp3xx_i2c/* @latonita | esphome/components/bmp3xx_i2c/* @latonita | ||||||
|   | |||||||
| @@ -1,96 +1,5 @@ | |||||||
| import esphome.codegen as cg |  | ||||||
| import esphome.config_validation as cv | import esphome.config_validation as cv | ||||||
| from esphome.components import i2c, sensor |  | ||||||
| from esphome.const import ( | CONFIG_SCHEMA = cv.invalid( | ||||||
|     CONF_ID, |     "The bmp280 sensor component has been renamed to bmp280_i2c." | ||||||
|     CONF_PRESSURE, |  | ||||||
|     CONF_TEMPERATURE, |  | ||||||
|     DEVICE_CLASS_PRESSURE, |  | ||||||
|     DEVICE_CLASS_TEMPERATURE, |  | ||||||
|     STATE_CLASS_MEASUREMENT, |  | ||||||
|     UNIT_CELSIUS, |  | ||||||
|     UNIT_HECTOPASCAL, |  | ||||||
|     CONF_IIR_FILTER, |  | ||||||
|     CONF_OVERSAMPLING, |  | ||||||
| ) | ) | ||||||
|  |  | ||||||
| DEPENDENCIES = ["i2c"] |  | ||||||
|  |  | ||||||
| bmp280_ns = cg.esphome_ns.namespace("bmp280") |  | ||||||
| BMP280Oversampling = bmp280_ns.enum("BMP280Oversampling") |  | ||||||
| OVERSAMPLING_OPTIONS = { |  | ||||||
|     "NONE": BMP280Oversampling.BMP280_OVERSAMPLING_NONE, |  | ||||||
|     "1X": BMP280Oversampling.BMP280_OVERSAMPLING_1X, |  | ||||||
|     "2X": BMP280Oversampling.BMP280_OVERSAMPLING_2X, |  | ||||||
|     "4X": BMP280Oversampling.BMP280_OVERSAMPLING_4X, |  | ||||||
|     "8X": BMP280Oversampling.BMP280_OVERSAMPLING_8X, |  | ||||||
|     "16X": BMP280Oversampling.BMP280_OVERSAMPLING_16X, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| BMP280IIRFilter = bmp280_ns.enum("BMP280IIRFilter") |  | ||||||
| IIR_FILTER_OPTIONS = { |  | ||||||
|     "OFF": BMP280IIRFilter.BMP280_IIR_FILTER_OFF, |  | ||||||
|     "2X": BMP280IIRFilter.BMP280_IIR_FILTER_2X, |  | ||||||
|     "4X": BMP280IIRFilter.BMP280_IIR_FILTER_4X, |  | ||||||
|     "8X": BMP280IIRFilter.BMP280_IIR_FILTER_8X, |  | ||||||
|     "16X": BMP280IIRFilter.BMP280_IIR_FILTER_16X, |  | ||||||
| } |  | ||||||
|  |  | ||||||
| BMP280Component = bmp280_ns.class_( |  | ||||||
|     "BMP280Component", cg.PollingComponent, i2c.I2CDevice |  | ||||||
| ) |  | ||||||
|  |  | ||||||
| CONFIG_SCHEMA = ( |  | ||||||
|     cv.Schema( |  | ||||||
|         { |  | ||||||
|             cv.GenerateID(): cv.declare_id(BMP280Component), |  | ||||||
|             cv.Optional(CONF_TEMPERATURE): sensor.sensor_schema( |  | ||||||
|                 unit_of_measurement=UNIT_CELSIUS, |  | ||||||
|                 accuracy_decimals=1, |  | ||||||
|                 device_class=DEVICE_CLASS_TEMPERATURE, |  | ||||||
|                 state_class=STATE_CLASS_MEASUREMENT, |  | ||||||
|             ).extend( |  | ||||||
|                 { |  | ||||||
|                     cv.Optional(CONF_OVERSAMPLING, default="16X"): cv.enum( |  | ||||||
|                         OVERSAMPLING_OPTIONS, upper=True |  | ||||||
|                     ), |  | ||||||
|                 } |  | ||||||
|             ), |  | ||||||
|             cv.Optional(CONF_PRESSURE): sensor.sensor_schema( |  | ||||||
|                 unit_of_measurement=UNIT_HECTOPASCAL, |  | ||||||
|                 accuracy_decimals=1, |  | ||||||
|                 device_class=DEVICE_CLASS_PRESSURE, |  | ||||||
|                 state_class=STATE_CLASS_MEASUREMENT, |  | ||||||
|             ).extend( |  | ||||||
|                 { |  | ||||||
|                     cv.Optional(CONF_OVERSAMPLING, default="16X"): cv.enum( |  | ||||||
|                         OVERSAMPLING_OPTIONS, upper=True |  | ||||||
|                     ), |  | ||||||
|                 } |  | ||||||
|             ), |  | ||||||
|             cv.Optional(CONF_IIR_FILTER, default="OFF"): cv.enum( |  | ||||||
|                 IIR_FILTER_OPTIONS, upper=True |  | ||||||
|             ), |  | ||||||
|         } |  | ||||||
|     ) |  | ||||||
|     .extend(cv.polling_component_schema("60s")) |  | ||||||
|     .extend(i2c.i2c_device_schema(0x77)) |  | ||||||
| ) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| async def to_code(config): |  | ||||||
|     var = cg.new_Pvariable(config[CONF_ID]) |  | ||||||
|     await cg.register_component(var, config) |  | ||||||
|     await i2c.register_i2c_device(var, config) |  | ||||||
|  |  | ||||||
|     if temperature_config := config.get(CONF_TEMPERATURE): |  | ||||||
|         sens = await sensor.new_sensor(temperature_config) |  | ||||||
|         cg.add(var.set_temperature_sensor(sens)) |  | ||||||
|         cg.add(var.set_temperature_oversampling(temperature_config[CONF_OVERSAMPLING])) |  | ||||||
|  |  | ||||||
|     if pressure_config := config.get(CONF_PRESSURE): |  | ||||||
|         sens = await sensor.new_sensor(pressure_config) |  | ||||||
|         cg.add(var.set_pressure_sensor(sens)) |  | ||||||
|         cg.add(var.set_pressure_oversampling(pressure_config[CONF_OVERSAMPLING])) |  | ||||||
|  |  | ||||||
|     cg.add(var.set_iir_filter(config[CONF_IIR_FILTER])) |  | ||||||
|   | |||||||
							
								
								
									
										88
									
								
								esphome/components/bmp280_base/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								esphome/components/bmp280_base/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,88 @@ | |||||||
|  | import esphome.codegen as cg | ||||||
|  | import esphome.config_validation as cv | ||||||
|  | from esphome.components import sensor | ||||||
|  | from esphome.const import ( | ||||||
|  |     CONF_ID, | ||||||
|  |     CONF_IIR_FILTER, | ||||||
|  |     CONF_OVERSAMPLING, | ||||||
|  |     CONF_PRESSURE, | ||||||
|  |     CONF_TEMPERATURE, | ||||||
|  |     DEVICE_CLASS_PRESSURE, | ||||||
|  |     DEVICE_CLASS_TEMPERATURE, | ||||||
|  |     STATE_CLASS_MEASUREMENT, | ||||||
|  |     UNIT_CELSIUS, | ||||||
|  |     UNIT_HECTOPASCAL, | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | CODEOWNERS = ["@ademuri"] | ||||||
|  |  | ||||||
|  | bmp280_ns = cg.esphome_ns.namespace("bmp280_base") | ||||||
|  | BMP280Oversampling = bmp280_ns.enum("BMP280Oversampling") | ||||||
|  | OVERSAMPLING_OPTIONS = { | ||||||
|  |     "NONE": BMP280Oversampling.BMP280_OVERSAMPLING_NONE, | ||||||
|  |     "1X": BMP280Oversampling.BMP280_OVERSAMPLING_1X, | ||||||
|  |     "2X": BMP280Oversampling.BMP280_OVERSAMPLING_2X, | ||||||
|  |     "4X": BMP280Oversampling.BMP280_OVERSAMPLING_4X, | ||||||
|  |     "8X": BMP280Oversampling.BMP280_OVERSAMPLING_8X, | ||||||
|  |     "16X": BMP280Oversampling.BMP280_OVERSAMPLING_16X, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | BMP280IIRFilter = bmp280_ns.enum("BMP280IIRFilter") | ||||||
|  | IIR_FILTER_OPTIONS = { | ||||||
|  |     "OFF": BMP280IIRFilter.BMP280_IIR_FILTER_OFF, | ||||||
|  |     "2X": BMP280IIRFilter.BMP280_IIR_FILTER_2X, | ||||||
|  |     "4X": BMP280IIRFilter.BMP280_IIR_FILTER_4X, | ||||||
|  |     "8X": BMP280IIRFilter.BMP280_IIR_FILTER_8X, | ||||||
|  |     "16X": BMP280IIRFilter.BMP280_IIR_FILTER_16X, | ||||||
|  | } | ||||||
|  |  | ||||||
|  | CONFIG_SCHEMA_BASE = cv.Schema( | ||||||
|  |     { | ||||||
|  |         cv.Optional(CONF_TEMPERATURE): sensor.sensor_schema( | ||||||
|  |             unit_of_measurement=UNIT_CELSIUS, | ||||||
|  |             accuracy_decimals=1, | ||||||
|  |             device_class=DEVICE_CLASS_TEMPERATURE, | ||||||
|  |             state_class=STATE_CLASS_MEASUREMENT, | ||||||
|  |         ).extend( | ||||||
|  |             { | ||||||
|  |                 cv.Optional(CONF_OVERSAMPLING, default="16X"): cv.enum( | ||||||
|  |                     OVERSAMPLING_OPTIONS, upper=True | ||||||
|  |                 ), | ||||||
|  |             } | ||||||
|  |         ), | ||||||
|  |         cv.Optional(CONF_PRESSURE): sensor.sensor_schema( | ||||||
|  |             unit_of_measurement=UNIT_HECTOPASCAL, | ||||||
|  |             accuracy_decimals=1, | ||||||
|  |             device_class=DEVICE_CLASS_PRESSURE, | ||||||
|  |             state_class=STATE_CLASS_MEASUREMENT, | ||||||
|  |         ).extend( | ||||||
|  |             { | ||||||
|  |                 cv.Optional(CONF_OVERSAMPLING, default="16X"): cv.enum( | ||||||
|  |                     OVERSAMPLING_OPTIONS, upper=True | ||||||
|  |                 ), | ||||||
|  |             } | ||||||
|  |         ), | ||||||
|  |         cv.Optional(CONF_IIR_FILTER, default="OFF"): cv.enum( | ||||||
|  |             IIR_FILTER_OPTIONS, upper=True | ||||||
|  |         ), | ||||||
|  |     } | ||||||
|  | ).extend(cv.polling_component_schema("60s")) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | async def to_code_base(config): | ||||||
|  |     var = cg.new_Pvariable(config[CONF_ID]) | ||||||
|  |     await cg.register_component(var, config) | ||||||
|  |  | ||||||
|  |     if temperature_config := config.get(CONF_TEMPERATURE): | ||||||
|  |         sens = await sensor.new_sensor(temperature_config) | ||||||
|  |         cg.add(var.set_temperature_sensor(sens)) | ||||||
|  |         cg.add(var.set_temperature_oversampling(temperature_config[CONF_OVERSAMPLING])) | ||||||
|  |  | ||||||
|  |     if pressure_config := config.get(CONF_PRESSURE): | ||||||
|  |         sens = await sensor.new_sensor(pressure_config) | ||||||
|  |         cg.add(var.set_pressure_sensor(sens)) | ||||||
|  |         cg.add(var.set_pressure_oversampling(pressure_config[CONF_OVERSAMPLING])) | ||||||
|  |  | ||||||
|  |     cg.add(var.set_iir_filter(config[CONF_IIR_FILTER])) | ||||||
|  |  | ||||||
|  |     return var | ||||||
| @@ -1,9 +1,9 @@ | |||||||
| #include "bmp280.h" | #include "bmp280_base.h" | ||||||
| #include "esphome/core/hal.h" | #include "esphome/core/hal.h" | ||||||
| #include "esphome/core/log.h" | #include "esphome/core/log.h" | ||||||
| 
 | 
 | ||||||
| namespace esphome { | namespace esphome { | ||||||
| namespace bmp280 { | namespace bmp280_base { | ||||||
| 
 | 
 | ||||||
| static const char *const TAG = "bmp280.sensor"; | static const char *const TAG = "bmp280.sensor"; | ||||||
| 
 | 
 | ||||||
| @@ -59,6 +59,14 @@ static const char *iir_filter_to_str(BMP280IIRFilter filter) { | |||||||
| void BMP280Component::setup() { | void BMP280Component::setup() { | ||||||
|   ESP_LOGCONFIG(TAG, "Setting up BMP280..."); |   ESP_LOGCONFIG(TAG, "Setting up BMP280..."); | ||||||
|   uint8_t chip_id = 0; |   uint8_t chip_id = 0; | ||||||
|  | 
 | ||||||
|  |   // Read the chip id twice, to work around a bug where the first read is 0.
 | ||||||
|  |   // 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)) { | ||||||
|  |     this->error_code_ = COMMUNICATION_FAILED; | ||||||
|  |     this->mark_failed(); | ||||||
|  |     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(); | ||||||
| @@ -122,7 +130,6 @@ void BMP280Component::setup() { | |||||||
| } | } | ||||||
| void BMP280Component::dump_config() { | void BMP280Component::dump_config() { | ||||||
|   ESP_LOGCONFIG(TAG, "BMP280:"); |   ESP_LOGCONFIG(TAG, "BMP280:"); | ||||||
|   LOG_I2C_DEVICE(this); |  | ||||||
|   switch (this->error_code_) { |   switch (this->error_code_) { | ||||||
|     case COMMUNICATION_FAILED: |     case COMMUNICATION_FAILED: | ||||||
|       ESP_LOGE(TAG, "Communication with BMP280 failed!"); |       ESP_LOGE(TAG, "Communication with BMP280 failed!"); | ||||||
| @@ -262,5 +269,5 @@ uint16_t BMP280Component::read_u16_le_(uint8_t a_register) { | |||||||
| } | } | ||||||
| int16_t BMP280Component::read_s16_le_(uint8_t a_register) { return this->read_u16_le_(a_register); } | int16_t BMP280Component::read_s16_le_(uint8_t a_register) { return this->read_u16_le_(a_register); } | ||||||
| 
 | 
 | ||||||
| }  // namespace bmp280
 | }  // namespace bmp280_base
 | ||||||
| }  // namespace esphome
 | }  // namespace esphome
 | ||||||
| @@ -2,10 +2,9 @@ | |||||||
| 
 | 
 | ||||||
| #include "esphome/core/component.h" | #include "esphome/core/component.h" | ||||||
| #include "esphome/components/sensor/sensor.h" | #include "esphome/components/sensor/sensor.h" | ||||||
| #include "esphome/components/i2c/i2c.h" |  | ||||||
| 
 | 
 | ||||||
| namespace esphome { | namespace esphome { | ||||||
| namespace bmp280 { | namespace bmp280_base { | ||||||
| 
 | 
 | ||||||
| /// Internal struct storing the calibration values of an BMP280.
 | /// Internal struct storing the calibration values of an BMP280.
 | ||||||
| struct BMP280CalibrationData { | struct BMP280CalibrationData { | ||||||
| @@ -50,8 +49,8 @@ enum BMP280IIRFilter { | |||||||
|   BMP280_IIR_FILTER_16X = 0b100, |   BMP280_IIR_FILTER_16X = 0b100, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| /// This class implements support for the BMP280 Temperature+Pressure i2c sensor.
 | /// This class implements support for the BMP280 Temperature+Pressure sensor.
 | ||||||
| class BMP280Component : public PollingComponent, public i2c::I2CDevice { | class BMP280Component : public PollingComponent { | ||||||
|  public: |  public: | ||||||
|   void set_temperature_sensor(sensor::Sensor *temperature_sensor) { temperature_sensor_ = temperature_sensor; } |   void set_temperature_sensor(sensor::Sensor *temperature_sensor) { temperature_sensor_ = temperature_sensor; } | ||||||
|   void set_pressure_sensor(sensor::Sensor *pressure_sensor) { pressure_sensor_ = pressure_sensor; } |   void set_pressure_sensor(sensor::Sensor *pressure_sensor) { pressure_sensor_ = pressure_sensor; } | ||||||
| @@ -68,6 +67,11 @@ class BMP280Component : public PollingComponent, public i2c::I2CDevice { | |||||||
|   float get_setup_priority() const override; |   float get_setup_priority() const override; | ||||||
|   void update() override; |   void update() override; | ||||||
| 
 | 
 | ||||||
|  |   virtual bool read_byte(uint8_t a_register, uint8_t *data) = 0; | ||||||
|  |   virtual bool write_byte(uint8_t a_register, uint8_t data) = 0; | ||||||
|  |   virtual bool read_bytes(uint8_t a_register, uint8_t *data, size_t len) = 0; | ||||||
|  |   virtual bool read_byte_16(uint8_t a_register, uint16_t *data) = 0; | ||||||
|  | 
 | ||||||
|  protected: |  protected: | ||||||
|   /// Read the temperature value and store the calculated ambient temperature in t_fine.
 |   /// Read the temperature value and store the calculated ambient temperature in t_fine.
 | ||||||
|   float read_temperature_(int32_t *t_fine); |   float read_temperature_(int32_t *t_fine); | ||||||
| @@ -90,5 +94,5 @@ class BMP280Component : public PollingComponent, public i2c::I2CDevice { | |||||||
|   } error_code_{NONE}; |   } error_code_{NONE}; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| }  // namespace bmp280
 | }  // namespace bmp280_base
 | ||||||
| }  // namespace esphome
 | }  // namespace esphome
 | ||||||
							
								
								
									
										0
									
								
								esphome/components/bmp280_i2c/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								esphome/components/bmp280_i2c/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										27
									
								
								esphome/components/bmp280_i2c/bmp280_i2c.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								esphome/components/bmp280_i2c/bmp280_i2c.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | #include "bmp280_i2c.h" | ||||||
|  | #include "esphome/core/hal.h" | ||||||
|  | #include "esphome/core/log.h" | ||||||
|  |  | ||||||
|  | namespace esphome { | ||||||
|  | namespace bmp280_i2c { | ||||||
|  |  | ||||||
|  | bool BMP280I2CComponent::read_byte(uint8_t a_register, uint8_t *data) { | ||||||
|  |   return I2CDevice::read_byte(a_register, data); | ||||||
|  | }; | ||||||
|  | bool BMP280I2CComponent::write_byte(uint8_t a_register, uint8_t data) { | ||||||
|  |   return I2CDevice::write_byte(a_register, data); | ||||||
|  | }; | ||||||
|  | bool BMP280I2CComponent::read_bytes(uint8_t a_register, uint8_t *data, size_t len) { | ||||||
|  |   return I2CDevice::read_bytes(a_register, data, len); | ||||||
|  | }; | ||||||
|  | bool BMP280I2CComponent::read_byte_16(uint8_t a_register, uint16_t *data) { | ||||||
|  |   return I2CDevice::read_byte_16(a_register, data); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | void BMP280I2CComponent::dump_config() { | ||||||
|  |   LOG_I2C_DEVICE(this); | ||||||
|  |   BMP280Component::dump_config(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | }  // namespace bmp280_i2c | ||||||
|  | }  // namespace esphome | ||||||
							
								
								
									
										22
									
								
								esphome/components/bmp280_i2c/bmp280_i2c.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								esphome/components/bmp280_i2c/bmp280_i2c.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "esphome/components/bmp280_base/bmp280_base.h" | ||||||
|  | #include "esphome/components/i2c/i2c.h" | ||||||
|  |  | ||||||
|  | namespace esphome { | ||||||
|  | namespace bmp280_i2c { | ||||||
|  |  | ||||||
|  | static const char *const TAG = "bmp280_i2c.sensor"; | ||||||
|  |  | ||||||
|  | /// This class implements support for the BMP280 Temperature+Pressure i2c sensor. | ||||||
|  | class BMP280I2CComponent : public esphome::bmp280_base::BMP280Component, public i2c::I2CDevice { | ||||||
|  |  public: | ||||||
|  |   bool read_byte(uint8_t a_register, uint8_t *data) override; | ||||||
|  |   bool write_byte(uint8_t a_register, uint8_t data) override; | ||||||
|  |   bool read_bytes(uint8_t a_register, uint8_t *data, size_t len) override; | ||||||
|  |   bool read_byte_16(uint8_t a_register, uint16_t *data) override; | ||||||
|  |   void dump_config() override; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | }  // namespace bmp280_i2c | ||||||
|  | }  // namespace esphome | ||||||
							
								
								
									
										22
									
								
								esphome/components/bmp280_i2c/sensor.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								esphome/components/bmp280_i2c/sensor.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | import esphome.codegen as cg | ||||||
|  | import esphome.config_validation as cv | ||||||
|  | from esphome.components import i2c | ||||||
|  | from ..bmp280_base import to_code_base, CONFIG_SCHEMA_BASE | ||||||
|  |  | ||||||
|  | AUTO_LOAD = ["bmp280_base"] | ||||||
|  | CODEOWNERS = ["@ademuri"] | ||||||
|  | DEPENDENCIES = ["i2c"] | ||||||
|  |  | ||||||
|  | bmp280_ns = cg.esphome_ns.namespace("bmp280_i2c") | ||||||
|  | BMP280I2CComponent = bmp280_ns.class_( | ||||||
|  |     "BMP280I2CComponent", cg.PollingComponent, i2c.I2CDevice | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | CONFIG_SCHEMA = CONFIG_SCHEMA_BASE.extend( | ||||||
|  |     i2c.i2c_device_schema(default_address=0x77) | ||||||
|  | ).extend({cv.GenerateID(): cv.declare_id(BMP280I2CComponent)}) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | async def to_code(config): | ||||||
|  |     var = await to_code_base(config) | ||||||
|  |     await i2c.register_i2c_device(var, config) | ||||||
							
								
								
									
										0
									
								
								esphome/components/bmp280_spi/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								esphome/components/bmp280_spi/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										65
									
								
								esphome/components/bmp280_spi/bmp280_spi.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										65
									
								
								esphome/components/bmp280_spi/bmp280_spi.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,65 @@ | |||||||
|  | #include <cstdint> | ||||||
|  | #include <cstddef> | ||||||
|  |  | ||||||
|  | #include "bmp280_spi.h" | ||||||
|  | #include <esphome/components/bmp280_base/bmp280_base.h> | ||||||
|  |  | ||||||
|  | namespace esphome { | ||||||
|  | namespace bmp280_spi { | ||||||
|  |  | ||||||
|  | uint8_t set_bit(uint8_t num, uint8_t position) { | ||||||
|  |   uint8_t mask = 1 << position; | ||||||
|  |   return num | mask; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | uint8_t clear_bit(uint8_t num, uint8_t position) { | ||||||
|  |   uint8_t mask = 1 << position; | ||||||
|  |   return num & ~mask; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | void BMP280SPIComponent::setup() { | ||||||
|  |   this->spi_setup(); | ||||||
|  |   BMP280Component::setup(); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | // In SPI mode, only 7 bits of the register addresses are used; the MSB of register address is not used | ||||||
|  | // and replaced by a read/write bit (RW = ‘0’ for write and RW = ‘1’ for read). | ||||||
|  | // Example: address 0xF7 is accessed by using SPI register address 0x77. For write access, the byte | ||||||
|  | // 0x77 is transferred, for read access, the byte 0xF7 is transferred. | ||||||
|  | // https://www.bosch-sensortec.com/media/boschsensortec/downloads/datasheets/bst-bmp280-ds001.pdf | ||||||
|  |  | ||||||
|  | bool BMP280SPIComponent::read_byte(uint8_t a_register, uint8_t *data) { | ||||||
|  |   this->enable(); | ||||||
|  |   this->transfer_byte(set_bit(a_register, 7)); | ||||||
|  |   *data = this->transfer_byte(0); | ||||||
|  |   this->disable(); | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool BMP280SPIComponent::write_byte(uint8_t a_register, uint8_t data) { | ||||||
|  |   this->enable(); | ||||||
|  |   this->transfer_byte(clear_bit(a_register, 7)); | ||||||
|  |   this->transfer_byte(data); | ||||||
|  |   this->disable(); | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool BMP280SPIComponent::read_bytes(uint8_t a_register, uint8_t *data, size_t len) { | ||||||
|  |   this->enable(); | ||||||
|  |   this->transfer_byte(set_bit(a_register, 7)); | ||||||
|  |   this->read_array(data, len); | ||||||
|  |   this->disable(); | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | bool BMP280SPIComponent::read_byte_16(uint8_t a_register, uint16_t *data) { | ||||||
|  |   this->enable(); | ||||||
|  |   this->transfer_byte(set_bit(a_register, 7)); | ||||||
|  |   ((uint8_t *) data)[1] = this->transfer_byte(0); | ||||||
|  |   ((uint8_t *) data)[0] = this->transfer_byte(0); | ||||||
|  |   this->disable(); | ||||||
|  |   return true; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | }  // namespace bmp280_spi | ||||||
|  | }  // namespace esphome | ||||||
							
								
								
									
										20
									
								
								esphome/components/bmp280_spi/bmp280_spi.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								esphome/components/bmp280_spi/bmp280_spi.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,20 @@ | |||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | #include "esphome/components/bmp280_base/bmp280_base.h" | ||||||
|  | #include "esphome/components/spi/spi.h" | ||||||
|  |  | ||||||
|  | namespace esphome { | ||||||
|  | namespace bmp280_spi { | ||||||
|  |  | ||||||
|  | class BMP280SPIComponent : public esphome::bmp280_base::BMP280Component, | ||||||
|  |                            public spi::SPIDevice<spi::BIT_ORDER_MSB_FIRST, spi::CLOCK_POLARITY_LOW, | ||||||
|  |                                                  spi::CLOCK_PHASE_LEADING, spi::DATA_RATE_200KHZ> { | ||||||
|  |   void setup() override; | ||||||
|  |   bool read_byte(uint8_t a_register, uint8_t *data) override; | ||||||
|  |   bool write_byte(uint8_t a_register, uint8_t data) override; | ||||||
|  |   bool read_bytes(uint8_t a_register, uint8_t *data, size_t len) override; | ||||||
|  |   bool read_byte_16(uint8_t a_register, uint16_t *data) override; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | }  // namespace bmp280_spi | ||||||
|  | }  // namespace esphome | ||||||
							
								
								
									
										22
									
								
								esphome/components/bmp280_spi/sensor.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								esphome/components/bmp280_spi/sensor.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | import esphome.codegen as cg | ||||||
|  | import esphome.config_validation as cv | ||||||
|  | from esphome.components import spi | ||||||
|  | from ..bmp280_base import to_code_base, CONFIG_SCHEMA_BASE | ||||||
|  |  | ||||||
|  | AUTO_LOAD = ["bmp280_base"] | ||||||
|  | CODEOWNERS = ["@ademuri"] | ||||||
|  | DEPENDENCIES = ["spi"] | ||||||
|  |  | ||||||
|  | bmp280_ns = cg.esphome_ns.namespace("bmp280_spi") | ||||||
|  | BMP280SPIComponent = bmp280_ns.class_( | ||||||
|  |     "BMP280SPIComponent", cg.PollingComponent, spi.SPIDevice | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | CONFIG_SCHEMA = CONFIG_SCHEMA_BASE.extend( | ||||||
|  |     spi.spi_device_schema(default_mode="mode3") | ||||||
|  | ).extend({cv.GenerateID(): cv.declare_id(BMP280SPIComponent)}) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | async def to_code(config): | ||||||
|  |     var = await to_code_base(config) | ||||||
|  |     await spi.register_spi_device(var, config) | ||||||
| @@ -1,15 +0,0 @@ | |||||||
| i2c: |  | ||||||
|   - id: i2c_bmp280 |  | ||||||
|     scl: 16 |  | ||||||
|     sda: 17 |  | ||||||
|  |  | ||||||
| sensor: |  | ||||||
|   - platform: bmp280 |  | ||||||
|     address: 0x77 |  | ||||||
|     temperature: |  | ||||||
|       name: Outside Temperature |  | ||||||
|       oversampling: 16x |  | ||||||
|     pressure: |  | ||||||
|       name: Outside Pressure |  | ||||||
|     iir_filter: 16x |  | ||||||
|     update_interval: 15s |  | ||||||
| @@ -1,15 +0,0 @@ | |||||||
| i2c: |  | ||||||
|   - id: i2c_bmp280 |  | ||||||
|     scl: 5 |  | ||||||
|     sda: 4 |  | ||||||
|  |  | ||||||
| sensor: |  | ||||||
|   - platform: bmp280 |  | ||||||
|     address: 0x77 |  | ||||||
|     temperature: |  | ||||||
|       name: Outside Temperature |  | ||||||
|       oversampling: 16x |  | ||||||
|     pressure: |  | ||||||
|       name: Outside Pressure |  | ||||||
|     iir_filter: 16x |  | ||||||
|     update_interval: 15s |  | ||||||
| @@ -1,15 +0,0 @@ | |||||||
| i2c: |  | ||||||
|   - id: i2c_bmp280 |  | ||||||
|     scl: 16 |  | ||||||
|     sda: 17 |  | ||||||
|  |  | ||||||
| sensor: |  | ||||||
|   - platform: bmp280 |  | ||||||
|     address: 0x77 |  | ||||||
|     temperature: |  | ||||||
|       name: Outside Temperature |  | ||||||
|       oversampling: 16x |  | ||||||
|     pressure: |  | ||||||
|       name: Outside Pressure |  | ||||||
|     iir_filter: 16x |  | ||||||
|     update_interval: 15s |  | ||||||
| @@ -1,15 +0,0 @@ | |||||||
| i2c: |  | ||||||
|   - id: i2c_bmp280 |  | ||||||
|     scl: 5 |  | ||||||
|     sda: 4 |  | ||||||
|  |  | ||||||
| sensor: |  | ||||||
|   - platform: bmp280 |  | ||||||
|     address: 0x77 |  | ||||||
|     temperature: |  | ||||||
|       name: Outside Temperature |  | ||||||
|       oversampling: 16x |  | ||||||
|     pressure: |  | ||||||
|       name: Outside Pressure |  | ||||||
|     iir_filter: 16x |  | ||||||
|     update_interval: 15s |  | ||||||
| @@ -1,15 +0,0 @@ | |||||||
| i2c: |  | ||||||
|   - id: i2c_bmp280 |  | ||||||
|     scl: 5 |  | ||||||
|     sda: 4 |  | ||||||
|  |  | ||||||
| sensor: |  | ||||||
|   - platform: bmp280 |  | ||||||
|     address: 0x77 |  | ||||||
|     temperature: |  | ||||||
|       name: Outside Temperature |  | ||||||
|       oversampling: 16x |  | ||||||
|     pressure: |  | ||||||
|       name: Outside Pressure |  | ||||||
|     iir_filter: 16x |  | ||||||
|     update_interval: 15s |  | ||||||
| @@ -1,15 +1,17 @@ | |||||||
| i2c: | i2c: | ||||||
|   - id: i2c_bmp280 |   - id: i2c_bmp280 | ||||||
|     scl: 5 |     scl: ${scl_pin} | ||||||
|     sda: 4 |     sda: ${sda_pin} | ||||||
| 
 | 
 | ||||||
| sensor: | sensor: | ||||||
|   - platform: bmp280 |   - platform: bmp280_i2c | ||||||
|  |     i2c_id: i2c_bmp280 | ||||||
|     address: 0x77 |     address: 0x77 | ||||||
|     temperature: |     temperature: | ||||||
|  |       id: bmp280_temperature | ||||||
|       name: Outside Temperature |       name: Outside Temperature | ||||||
|       oversampling: 16x |  | ||||||
|     pressure: |     pressure: | ||||||
|       name: Outside Pressure |       name: Outside Pressure | ||||||
|  |       id: bmp280_pressure | ||||||
|     iir_filter: 16x |     iir_filter: 16x | ||||||
|     update_interval: 15s |     update_interval: 15s | ||||||
							
								
								
									
										5
									
								
								tests/components/bmp280_i2c/test.esp32-ard.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								tests/components/bmp280_i2c/test.esp32-ard.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | substitutions: | ||||||
|  |   scl_pin: GPIO16 | ||||||
|  |   sda_pin: GPIO17 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										5
									
								
								tests/components/bmp280_i2c/test.esp32-c3-ard.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								tests/components/bmp280_i2c/test.esp32-c3-ard.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | substitutions: | ||||||
|  |   scl_pin: GPIO5 | ||||||
|  |   sda_pin: GPIO4 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										5
									
								
								tests/components/bmp280_i2c/test.esp32-c3-idf.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								tests/components/bmp280_i2c/test.esp32-c3-idf.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | substitutions: | ||||||
|  |   scl_pin: GPIO5 | ||||||
|  |   sda_pin: GPIO4 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										5
									
								
								tests/components/bmp280_i2c/test.esp32-idf.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								tests/components/bmp280_i2c/test.esp32-idf.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | substitutions: | ||||||
|  |   scl_pin: GPIO16 | ||||||
|  |   sda_pin: GPIO17 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										5
									
								
								tests/components/bmp280_i2c/test.esp8266-ard.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								tests/components/bmp280_i2c/test.esp8266-ard.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | substitutions: | ||||||
|  |   scl_pin: GPIO5 | ||||||
|  |   sda_pin: GPIO4 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										5
									
								
								tests/components/bmp280_i2c/test.rp2040-ard.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								tests/components/bmp280_i2c/test.rp2040-ard.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | substitutions: | ||||||
|  |   scl_pin: GPIO5 | ||||||
|  |   sda_pin: GPIO4 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										18
									
								
								tests/components/bmp280_spi/common.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								tests/components/bmp280_spi/common.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | |||||||
|  | spi: | ||||||
|  |   - id: spi_bmp280 | ||||||
|  |     clk_pin: ${clk_pin} | ||||||
|  |     mosi_pin: ${mosi_pin} | ||||||
|  |     miso_pin: ${miso_pin} | ||||||
|  |  | ||||||
|  | sensor: | ||||||
|  |   - platform: bmp280_spi | ||||||
|  |     spi_id: spi_bmp280 | ||||||
|  |     cs_pin: ${cs_pin} | ||||||
|  |     temperature: | ||||||
|  |       id: bmp280_temperature | ||||||
|  |       name: Outside Temperature | ||||||
|  |     pressure: | ||||||
|  |       name: Outside Pressure | ||||||
|  |       id: bmp280_pressure | ||||||
|  |     iir_filter: 16x | ||||||
|  |     update_interval: 15s | ||||||
							
								
								
									
										7
									
								
								tests/components/bmp280_spi/test.esp32-ard.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								tests/components/bmp280_spi/test.esp32-ard.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | substitutions: | ||||||
|  |   clk_pin: GPIO16 | ||||||
|  |   mosi_pin: GPIO17 | ||||||
|  |   miso_pin: GPIO15 | ||||||
|  |   cs_pin: GPIO5 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										7
									
								
								tests/components/bmp280_spi/test.esp32-c3-ard.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								tests/components/bmp280_spi/test.esp32-c3-ard.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | substitutions: | ||||||
|  |   clk_pin: GPIO6 | ||||||
|  |   mosi_pin: GPIO7 | ||||||
|  |   miso_pin: GPIO5 | ||||||
|  |   cs_pin: GPIO8 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										7
									
								
								tests/components/bmp280_spi/test.esp32-c3-idf.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								tests/components/bmp280_spi/test.esp32-c3-idf.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | substitutions: | ||||||
|  |   clk_pin: GPIO6 | ||||||
|  |   mosi_pin: GPIO7 | ||||||
|  |   miso_pin: GPIO5 | ||||||
|  |   cs_pin: GPIO8 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										7
									
								
								tests/components/bmp280_spi/test.esp32-idf.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								tests/components/bmp280_spi/test.esp32-idf.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | substitutions: | ||||||
|  |   clk_pin: GPIO16 | ||||||
|  |   mosi_pin: GPIO17 | ||||||
|  |   miso_pin: GPIO15 | ||||||
|  |   cs_pin: GPIO5 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										7
									
								
								tests/components/bmp280_spi/test.esp8266-ard.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								tests/components/bmp280_spi/test.esp8266-ard.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | substitutions: | ||||||
|  |   clk_pin: GPIO14 | ||||||
|  |   mosi_pin: GPIO13 | ||||||
|  |   miso_pin: GPIO12 | ||||||
|  |   cs_pin: GPIO15 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
							
								
								
									
										7
									
								
								tests/components/bmp280_spi/test.rp2040-ard.yaml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								tests/components/bmp280_spi/test.rp2040-ard.yaml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | substitutions: | ||||||
|  |   clk_pin: GPIO2 | ||||||
|  |   mosi_pin: GPIO3 | ||||||
|  |   miso_pin: GPIO4 | ||||||
|  |   cs_pin: GPIO5 | ||||||
|  |  | ||||||
|  | <<: !include common.yaml | ||||||
		Reference in New Issue
	
	Block a user