diff --git a/docs/modbus_enable_quirks.md b/docs/modbus_enable_quirks.md index f209ad1dd..d6d28f82d 100644 --- a/docs/modbus_enable_quirks.md +++ b/docs/modbus_enable_quirks.md @@ -22,6 +22,8 @@ offers the following flags: - `MODBUS_QUIRK_MAX_SLAVE` allows slave adresses between 247 and 255. - `MODBUS_QUIRK_REPLY_TO_BROADCAST` force a reply to a broacast request when the device is a slave in RTU mode (should be enabled on the slave device). +- `MODBUS_QUIRK_IGNORE_RTU_SLAVE_CHECK` allows no filtering on the Modbus unit + identifier (slave) in RTU mode while checking integrity. You can combine the flags by using the bitwise OR operator. diff --git a/src/modbus-rtu.c b/src/modbus-rtu.c index b7749230c..eacd1f1a1 100644 --- a/src/modbus-rtu.c +++ b/src/modbus-rtu.c @@ -354,7 +354,8 @@ static int _modbus_rtu_check_integrity(modbus_t *ctx, uint8_t *msg, const int ms /* Filter on the Modbus unit identifier (slave) in RTU mode to avoid useless * CRC computing. */ - if (slave != ctx->slave && slave != MODBUS_BROADCAST_ADDRESS) { + if (slave != ctx->slave && slave != MODBUS_BROADCAST_ADDRESS && + !(ctx->quirks & MODBUS_QUIRK_IGNORE_RTU_SLAVE_CHECK)) { if (ctx->debug) { printf("Request for slave %d ignored (not %d)\n", slave, ctx->slave); } diff --git a/src/modbus.h b/src/modbus.h index 55ef08a0d..24104aa26 100644 --- a/src/modbus.h +++ b/src/modbus.h @@ -181,6 +181,7 @@ typedef enum { MODBUS_QUIRK_NONE = 0, MODBUS_QUIRK_MAX_SLAVE = (1 << 1), MODBUS_QUIRK_REPLY_TO_BROADCAST = (1 << 2), + MODBUS_QUIRK_IGNORE_RTU_SLAVE_CHECK = (1 << 3), MODBUS_QUIRK_ALL = 0xFF } modbus_quirks;