mirror of
https://github.com/esphome/esphome.git
synced 2024-11-28 12:46:22 +01:00
Add support for using BMP280 with SPI (#7053)
Co-authored-by: Keith Burzinski <kbx81x@gmail.com>
This commit is contained in:
parent
1548fa0811
commit
18a1191e03
@ -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
|
Loading…
Reference in New Issue
Block a user