modbus_write_and_read_registers.txt 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. modbus_write_and_read_registers(3)
  2. ==================================
  3. NAME
  4. ----
  5. modbus_write_and_read_registers - write and read many registers in a single transaction
  6. SYNOPSIS
  7. --------
  8. *int modbus_write_and_read_registers(modbus_t *'ctx', int 'write_addr', int 'write_nb', const uint16_t *'src', int 'read_addr', int 'read_nb', const uint16_t *'dest')*
  9. DESCRIPTION
  10. -----------
  11. The _modbus_write_and_read_registers()_ function shall write the content of the
  12. 'write_nb' holding registers from the array 'src' to the address 'write_addr' of
  13. the remote device then shall read the content of the 'read_nb' holding registers
  14. to the address 'read_addr' of the remote device. The result of reading is stored
  15. in 'dest' array as word values (16 bits).
  16. You must take care to allocate enough memory to store the results in 'dest'
  17. (at least 'nb' * sizeof(uint16_t)).
  18. The function uses the Modbus function code 0x17 (write/read registers).
  19. RETURN VALUE
  20. ------------
  21. The _modbus_write_and_read_registers()_ function shall return the number of read
  22. registers if successful. Otherwise it shall return -1 and set errno.
  23. ERRORS
  24. ------
  25. EMBMDATA::
  26. Too many registers requested, Too many registers to write
  27. SEE ALSO
  28. --------
  29. linkmb:modbus_read_registers[3]
  30. linkmb:modbus_write_register[3]
  31. linkmb:modbus_write_registers[3]
  32. AUTHORS
  33. -------
  34. The libmodbus documentation was written by Stéphane Raimbault
  35. <stephane.raimbault@gmail.com>