Search code examples
pythonasciimodbusminimalmodbus

Modbus: Wrong response from the slave


I am trying to write data to DVP28SS2 controller using minimalmodbus in ASCII mode. I have received a response from the controller but it seems wrong. In particular bits, corresponding to slave address and the function code don't match them.

  • The request is: 3A 30 31 31 30 30 30 32 38 30 30 30 31 30 32 30 30 36 34 36 30 0D 0A (:01100028000102006460\r\n)
  • The response is: 3A 30 B1 39 30 30 B2 36 44 8D 0A (:0±900²6D\x8d\n)

The correct response for a request (as an example) should look like this: enter image description here

import minimalmodbus
import serial

D40 = 4096 + 40
instrument = minimalmodbus.Instrument(port = 'COM5',mode = 'ascii', slaveaddress = 1,  debug = True)  # port name, slave address (in decimal)

instrument.serial.baudrate = 9600        # Baud
instrument.serial.bytesize = 7
instrument.serial.parity   = serial.PARITY_EVEN
instrument.serial.stopbits = 1
instrument.serial.timeout  = 0.05         # seconds

## Write  ##
data_to_write = 100
instrument.write_register(registeraddress=D40, value=data_to_write,number_of_decimals=0)  

As a result I have received:

MinimalModbus debug mode. Create serial port COM5
MinimalModbus debug mode. Will write to instrument (expecting 17 bytes back): 3A 30 31 31 30 30 30 32 38 30 30 30 31 30 32 30 30 36 34 36 30 0D 0A (23 bytes)
MinimalModbus debug mode. Clearing serial buffers for port COM5
MinimalModbus debug mode. No sleep required before write. Time since previous read: 45037250.00 ms, minimum silent period: 4.01 ms.
Traceback (most recent call last):
  File "G:\Проекты\Python\Neurolumber_utils\utils\ModbusWriter.py", line 15, in <module>
    instrument.write_register(registeraddress=D40, value=data_to_write,number_of_decimals=0)  # Registernumber, value, number of decimals for storage
  File "C:\Users\Иван Малахов\AppData\Local\Programs\Python\Python39\lib\site-packages\minimalmodbus.py", line 550, in write_register
    self._generic_command(
  File "C:\Users\Иван Малахов\AppData\Local\Programs\Python\Python39\lib\site-packages\minimalmodbus.py", line 1245, in _generic_command
    payload_from_slave = self._perform_command(functioncode, payload_to_slave)
  File "C:\Users\Иван Малахов\AppData\Local\Programs\Python\Python39\lib\site-packages\minimalmodbus.py", line 1329, in _perform_command
    payload_from_slave = _extract_payload(
  File "C:\Users\Иван Малахов\AppData\Local\Programs\Python\Python39\lib\site-packages\minimalmodbus.py", line 1825, in _extract_payload
    raise InvalidResponseError(
minimalmodbus.InvalidResponseError: Did not find footer ('\r\n') as end of ASCII response. The plain response is: ':0±900²6D\x8d\n'
MinimalModbus debug mode. Response from instrument: 3A 30 B1 39 30 30 B2 36 44 8D 0A (11 bytes), roundtrip time: 0.1 ms. Timeout for reading: 50.0 ms.

Solution

  • Colleagues told me that the controller that I use has problems with the ASCII standard. When I changed the mode to "RTU", everything worked.