mirror of
https://github.com/esphome/esphome.git
synced 2024-11-27 09:18:00 +01:00
fix modbus output (#2630)
This commit is contained in:
parent
c6adaaea97
commit
72108684ea
5 changed files with 31 additions and 35 deletions
|
@ -61,6 +61,21 @@ SENSOR_VALUE_TYPE = {
|
||||||
"FP32_R": SensorValueType.FP32_R,
|
"FP32_R": SensorValueType.FP32_R,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TYPE_REGISTER_MAP = {
|
||||||
|
"RAW": 1,
|
||||||
|
"U_WORD": 1,
|
||||||
|
"S_WORD": 1,
|
||||||
|
"U_DWORD": 2,
|
||||||
|
"U_DWORD_R": 2,
|
||||||
|
"S_DWORD": 2,
|
||||||
|
"S_DWORD_R": 2,
|
||||||
|
"U_QWORD": 4,
|
||||||
|
"U_QWORDU_R": 4,
|
||||||
|
"S_QWORD": 4,
|
||||||
|
"U_QWORD_R": 4,
|
||||||
|
"FP32": 2,
|
||||||
|
"FP32_R": 2,
|
||||||
|
}
|
||||||
|
|
||||||
MULTI_CONF = True
|
MULTI_CONF = True
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,7 @@ from .. import (
|
||||||
ModbusController,
|
ModbusController,
|
||||||
SENSOR_VALUE_TYPE,
|
SENSOR_VALUE_TYPE,
|
||||||
SensorItem,
|
SensorItem,
|
||||||
|
TYPE_REGISTER_MAP,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -39,22 +40,6 @@ ModbusNumber = modbus_controller_ns.class_(
|
||||||
"ModbusNumber", cg.Component, number.Number, SensorItem
|
"ModbusNumber", cg.Component, number.Number, SensorItem
|
||||||
)
|
)
|
||||||
|
|
||||||
TYPE_REGISTER_MAP = {
|
|
||||||
"RAW": 1,
|
|
||||||
"U_WORD": 1,
|
|
||||||
"S_WORD": 1,
|
|
||||||
"U_DWORD": 2,
|
|
||||||
"U_DWORD_R": 2,
|
|
||||||
"S_DWORD": 2,
|
|
||||||
"S_DWORD_R": 2,
|
|
||||||
"U_QWORD": 4,
|
|
||||||
"U_QWORDU_R": 4,
|
|
||||||
"S_QWORD": 4,
|
|
||||||
"U_QWORD_R": 4,
|
|
||||||
"FP32": 2,
|
|
||||||
"FP32_R": 2,
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
def validate_min_max(config):
|
def validate_min_max(config):
|
||||||
if config[CONF_MAX_VALUE] <= config[CONF_MIN_VALUE]:
|
if config[CONF_MAX_VALUE] <= config[CONF_MIN_VALUE]:
|
||||||
|
|
|
@ -13,11 +13,13 @@ from .. import (
|
||||||
SensorItem,
|
SensorItem,
|
||||||
modbus_controller_ns,
|
modbus_controller_ns,
|
||||||
ModbusController,
|
ModbusController,
|
||||||
|
TYPE_REGISTER_MAP,
|
||||||
)
|
)
|
||||||
|
|
||||||
from ..const import (
|
from ..const import (
|
||||||
CONF_BYTE_OFFSET,
|
CONF_BYTE_OFFSET,
|
||||||
CONF_MODBUS_CONTROLLER_ID,
|
CONF_MODBUS_CONTROLLER_ID,
|
||||||
|
CONF_REGISTER_COUNT,
|
||||||
CONF_VALUE_TYPE,
|
CONF_VALUE_TYPE,
|
||||||
CONF_WRITE_LAMBDA,
|
CONF_WRITE_LAMBDA,
|
||||||
)
|
)
|
||||||
|
@ -40,6 +42,7 @@ CONFIG_SCHEMA = cv.All(
|
||||||
cv.Optional(CONF_OFFSET, default=0): cv.positive_int,
|
cv.Optional(CONF_OFFSET, default=0): cv.positive_int,
|
||||||
cv.Optional(CONF_BYTE_OFFSET): cv.positive_int,
|
cv.Optional(CONF_BYTE_OFFSET): cv.positive_int,
|
||||||
cv.Optional(CONF_VALUE_TYPE, default="U_WORD"): cv.enum(SENSOR_VALUE_TYPE),
|
cv.Optional(CONF_VALUE_TYPE, default="U_WORD"): cv.enum(SENSOR_VALUE_TYPE),
|
||||||
|
cv.Optional(CONF_REGISTER_COUNT, default=0): cv.positive_int,
|
||||||
cv.Optional(CONF_WRITE_LAMBDA): cv.returning_lambda,
|
cv.Optional(CONF_WRITE_LAMBDA): cv.returning_lambda,
|
||||||
cv.Optional(CONF_MULTIPLY, default=1.0): cv.float_,
|
cv.Optional(CONF_MULTIPLY, default=1.0): cv.float_,
|
||||||
}
|
}
|
||||||
|
@ -54,8 +57,16 @@ async def to_code(config):
|
||||||
# A CONF_BYTE_OFFSET setting overrides CONF_OFFSET
|
# A CONF_BYTE_OFFSET setting overrides CONF_OFFSET
|
||||||
if CONF_BYTE_OFFSET in config:
|
if CONF_BYTE_OFFSET in config:
|
||||||
byte_offset = config[CONF_BYTE_OFFSET]
|
byte_offset = config[CONF_BYTE_OFFSET]
|
||||||
|
value_type = config[CONF_VALUE_TYPE]
|
||||||
|
reg_count = config[CONF_REGISTER_COUNT]
|
||||||
|
if reg_count == 0:
|
||||||
|
reg_count = TYPE_REGISTER_MAP[value_type]
|
||||||
var = cg.new_Pvariable(
|
var = cg.new_Pvariable(
|
||||||
config[CONF_ID], config[CONF_ADDRESS], byte_offset, config[CONF_VALUE_TYPE]
|
config[CONF_ID],
|
||||||
|
config[CONF_ADDRESS],
|
||||||
|
byte_offset,
|
||||||
|
value_type,
|
||||||
|
reg_count,
|
||||||
)
|
)
|
||||||
await output.register_output(var, config)
|
await output.register_output(var, config)
|
||||||
cg.add(var.set_write_multiply(config[CONF_MULTIPLY]))
|
cg.add(var.set_write_multiply(config[CONF_MULTIPLY]))
|
||||||
|
|
|
@ -11,12 +11,13 @@ using value_to_data_t = std::function<float>(float);
|
||||||
|
|
||||||
class ModbusOutput : public output::FloatOutput, public Component, public SensorItem {
|
class ModbusOutput : public output::FloatOutput, public Component, public SensorItem {
|
||||||
public:
|
public:
|
||||||
ModbusOutput(uint16_t start_address, uint8_t offset, SensorValueType value_type)
|
ModbusOutput(uint16_t start_address, uint8_t offset, SensorValueType value_type, int register_count)
|
||||||
: output::FloatOutput(), Component() {
|
: output::FloatOutput(), Component() {
|
||||||
this->register_type = ModbusRegisterType::HOLDING;
|
this->register_type = ModbusRegisterType::HOLDING;
|
||||||
this->start_address = start_address;
|
this->start_address = start_address;
|
||||||
this->offset = offset;
|
this->offset = offset;
|
||||||
this->bitmask = bitmask;
|
this->bitmask = bitmask;
|
||||||
|
this->register_count = register_count;
|
||||||
this->sensor_value_type = value_type;
|
this->sensor_value_type = value_type;
|
||||||
this->skip_updates = 0;
|
this->skip_updates = 0;
|
||||||
this->start_address += offset;
|
this->start_address += offset;
|
||||||
|
|
|
@ -9,6 +9,7 @@ from .. import (
|
||||||
ModbusController,
|
ModbusController,
|
||||||
MODBUS_REGISTER_TYPE,
|
MODBUS_REGISTER_TYPE,
|
||||||
SENSOR_VALUE_TYPE,
|
SENSOR_VALUE_TYPE,
|
||||||
|
TYPE_REGISTER_MAP,
|
||||||
)
|
)
|
||||||
from ..const import (
|
from ..const import (
|
||||||
CONF_BITMASK,
|
CONF_BITMASK,
|
||||||
|
@ -29,23 +30,6 @@ ModbusSensor = modbus_controller_ns.class_(
|
||||||
"ModbusSensor", cg.Component, sensor.Sensor, SensorItem
|
"ModbusSensor", cg.Component, sensor.Sensor, SensorItem
|
||||||
)
|
)
|
||||||
|
|
||||||
TYPE_REGISTER_MAP = {
|
|
||||||
"RAW": 1,
|
|
||||||
"U_WORD": 1,
|
|
||||||
"S_WORD": 1,
|
|
||||||
"U_DWORD": 2,
|
|
||||||
"U_DWORD_R": 2,
|
|
||||||
"S_DWORD": 2,
|
|
||||||
"S_DWORD_R": 2,
|
|
||||||
"U_QWORD": 4,
|
|
||||||
"U_QWORDU_R": 4,
|
|
||||||
"S_QWORD": 4,
|
|
||||||
"U_QWORD_R": 4,
|
|
||||||
"FP32": 2,
|
|
||||||
"FP32_R": 2,
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
CONFIG_SCHEMA = cv.All(
|
CONFIG_SCHEMA = cv.All(
|
||||||
sensor.SENSOR_SCHEMA.extend(
|
sensor.SENSOR_SCHEMA.extend(
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue