[INA219] Add sleep/wake_up actions

This commit is contained in:
Ali Essam 2024-11-17 23:38:10 +01:00
parent e81191ebd2
commit 44d00562e7
3 changed files with 82 additions and 2 deletions

View file

@ -129,6 +129,36 @@ void INA219Component::setup() {
} }
} }
void INA219Component::sleep() {
// Set operating mode bits to power-down mode (bits 0-2 set to 0)
ESP_LOGD(TAG, "Putting INA219 to sleep");
this->sleeping_ = true;
uint16_t config;
if (!this->read_byte_16(INA219_REGISTER_CONFIG, &config)) {
ESP_LOGD(TAG, "INA219 did not respond to sleep action, failed to read config register");
return;
}
config &= ~0b0000000000000111; // Clear last 3 bits
if (!this->write_byte_16(INA219_REGISTER_CONFIG, config)) {
ESP_LOGD(TAG, "INA219 did not respond to sleep action, failed to write config register");
}
}
void INA219Component::wake_up() {
// Set operating mode bits to continuous operation of Bus and Shunt ADCs (bits 0-2 set to 1)
ESP_LOGD(TAG, "Waking up INA219");
this->sleeping_ = false;
uint16_t config;
if (!this->read_byte_16(INA219_REGISTER_CONFIG, &config)) {
ESP_LOGD(TAG, "INA219 did not respond to wake up action, failed to read config register");
return;
}
config |= 0b0000000000000111; // Set last 3 bits
if (!this->write_byte_16(INA219_REGISTER_CONFIG, config)) {
ESP_LOGD(TAG, "INA219 did not respond to wake up action, failed to write config register");
}
}
void INA219Component::dump_config() { void INA219Component::dump_config() {
ESP_LOGCONFIG(TAG, "INA219:"); ESP_LOGCONFIG(TAG, "INA219:");
LOG_I2C_DEVICE(this); LOG_I2C_DEVICE(this);
@ -148,6 +178,10 @@ void INA219Component::dump_config() {
float INA219Component::get_setup_priority() const { return setup_priority::DATA; } float INA219Component::get_setup_priority() const { return setup_priority::DATA; }
void INA219Component::update() { void INA219Component::update() {
if (this->sleeping_) {
return;
}
if (this->bus_voltage_sensor_ != nullptr) { if (this->bus_voltage_sensor_ != nullptr) {
uint16_t raw_bus_voltage; uint16_t raw_bus_voltage;
if (!this->read_byte_16(INA219_REGISTER_BUS_VOLTAGE, &raw_bus_voltage)) { if (!this->read_byte_16(INA219_REGISTER_BUS_VOLTAGE, &raw_bus_voltage)) {

View file

@ -3,6 +3,7 @@
#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" #include "esphome/components/i2c/i2c.h"
#include "esphome/core/automation.h"
#include <cinttypes> #include <cinttypes>
@ -15,6 +16,8 @@ class INA219Component : public PollingComponent, public i2c::I2CDevice {
void dump_config() override; void dump_config() override;
float get_setup_priority() const override; float get_setup_priority() const override;
void update() override; void update() override;
void sleep();
void wake_up();
void set_shunt_resistance_ohm(float shunt_resistance_ohm) { shunt_resistance_ohm_ = shunt_resistance_ohm; } void set_shunt_resistance_ohm(float shunt_resistance_ohm) { shunt_resistance_ohm_ = shunt_resistance_ohm; }
void set_max_current_a(float max_current_a) { max_current_a_ = max_current_a; } void set_max_current_a(float max_current_a) { max_current_a_ = max_current_a; }
@ -28,12 +31,20 @@ class INA219Component : public PollingComponent, public i2c::I2CDevice {
float shunt_resistance_ohm_; float shunt_resistance_ohm_;
float max_current_a_; float max_current_a_;
float max_voltage_v_; float max_voltage_v_;
bool sleeping_{false};
uint32_t calibration_lsb_; uint32_t calibration_lsb_;
sensor::Sensor *bus_voltage_sensor_{nullptr}; sensor::Sensor *bus_voltage_sensor_{nullptr};
sensor::Sensor *shunt_voltage_sensor_{nullptr}; sensor::Sensor *shunt_voltage_sensor_{nullptr};
sensor::Sensor *current_sensor_{nullptr}; sensor::Sensor *current_sensor_{nullptr};
sensor::Sensor *power_sensor_{nullptr}; sensor::Sensor *power_sensor_{nullptr};
}; };
template<typename... Ts> class SleepAction : public Action<Ts...>, public Parented<INA219Component> {
void play(Ts... x) override { this->parent_->sleep(); }
};
template<typename... Ts> class WakeUpAction : public Action<Ts...>, public Parented<INA219Component> {
void play(Ts... x) override { this->parent_->wake_up(); }
};
} // namespace ina219 } // namespace ina219
} // namespace esphome } // namespace esphome

View file

@ -1,6 +1,7 @@
from esphome import automation
import esphome.codegen as cg import esphome.codegen as cg
import esphome.config_validation as cv
from esphome.components import i2c, sensor from esphome.components import i2c, sensor
import esphome.config_validation as cv
from esphome.const import ( from esphome.const import (
CONF_BUS_VOLTAGE, CONF_BUS_VOLTAGE,
CONF_CURRENT, CONF_CURRENT,
@ -14,8 +15,8 @@ from esphome.const import (
DEVICE_CLASS_POWER, DEVICE_CLASS_POWER,
DEVICE_CLASS_VOLTAGE, DEVICE_CLASS_VOLTAGE,
STATE_CLASS_MEASUREMENT, STATE_CLASS_MEASUREMENT,
UNIT_VOLT,
UNIT_AMPERE, UNIT_AMPERE,
UNIT_VOLT,
UNIT_WATT, UNIT_WATT,
) )
@ -70,6 +71,40 @@ CONFIG_SCHEMA = (
) )
SleepAction = ina219_ns.class_("SleepAction", automation.Action)
WakeUpAction = ina219_ns.class_("WakeUpAction", automation.Action)
@automation.register_action(
"ina219.sleep",
SleepAction,
cv.Schema(
{
cv.GenerateID(): cv.use_id(INA219Component),
}
),
)
async def ina219_sleep_to_code(config, action_id, template_arg, args):
var = cg.new_Pvariable(action_id, template_arg)
await cg.register_parented(var, config[CONF_ID])
return var
@automation.register_action(
"ina219.wake_up",
WakeUpAction,
cv.Schema(
{
cv.GenerateID(): cv.use_id(INA219Component),
}
),
)
async def ina219_wake_up_to_code(config, action_id, template_arg, args):
var = cg.new_Pvariable(action_id, template_arg)
await cg.register_parented(var, config[CONF_ID])
return var
async def to_code(config): async def to_code(config):
var = cg.new_Pvariable(config[CONF_ID]) var = cg.new_Pvariable(config[CONF_ID])
await cg.register_component(var, config) await cg.register_component(var, config)