Skip to content

Latest commit

 

History

History
183 lines (176 loc) · 9.84 KB

UF_ModbusTCP_Manual.md

File metadata and controls

183 lines (176 loc) · 9.84 KB

UFACTORY ModbusTCP User Instructions

Notice:

  • Communication complies with standard Modbus TCP protocol
  • Data transmission uses Big-endian method, for example transmission order of data 0x1234 is: 0x12, 0x34
  • Different register addresses hold different specific contents, details refer to the appendix
  • Make sure to access the pre-defined register address(refer to appendix),or there will be exception in response

Supported Modbus TCP function codes:

  • Coil register(1 bit)

    • 0x01: Read multiple coil registers,each bit in responded data section represents the value of each one register:
      // sample request and response / exception
      // Request: Read consecutive 16 registers starting from address 0x0000
      00 01 00 00 00 06 01 01 00 00 00 10
      // Response: every bit in the Received data (0xF7 0x00 here as an example) represents the corresponding register value in order
      00 01 00 00 00 05 01 01 02 F7 00
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 81 XX
    • 0x05: Write single coil, according to Modbus protocol, specified data can only be 0xFF00 or 0x0000,for wriring 1 or 0 to the register.
      // sample request and response / exception
      // Request: Write 1 to register address 0x0002 (0xFF00 for writing 1, 0x0000 for writing 0)
      00 01 00 00 00 06 01 05 00 02 FF 00 
      // Response:
      00 01 00 00 00 06 01 05 00 02 FF 00
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 85 XX
    • 0x0F: Write multiple coil registers
      // sample request and response / exception
      // Request: write 3 registers starting from address 0x0002, 0x07 in binary form is for writing all 1s in the three registers.
      00 01 00 00 00 08 01 0F 00 02 00 03 01 07
      // Response:
      00 01 00 00 00 06 01 0F 00 02 00 03
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 8F XX
  • Discrete input register (1 bit)

    • 0x02: Read multiple discrete input registers
      // sample request and response / exception
      // Request: Read 16 consecutive registers from address 0x0000
      00 01 00 00 00 06 01 02 00 00 00 10
      // Response:: every bit in the Received data (0xFF 0x00 here as an example) represents the corresponding register value in order
      00 01 00 00 00 05 01 02 02 FF 00
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 82 XX
  • Holding register (16 bit)

    • 0x03: Read multiple holding registers
      // sample request and response / exception
      // Request: read 2 consecutive holding registers starting from address 0x0003
      00 01 00 00 00 06 01 03 00 03 00 02
      // Response:: Received values of the two registers are (00 05) and (00 06) as an example here
      00 01 00 00 00 07 01 03 04 00 05 00 06
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 83 XX
    • 0x06: Write single holding register
      // sample request and response / exception
      // Request: Write 0x0006 to register address 0x0020
      00 01 00 00 00 06 01 06 00 20 00 06
      // Response:
      00 01 00 00 00 06 01 06 00 20 00 06
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 86 XX
    • 0x10: Write multiple holding registers
      // sample request and response / exception
      // Request: Write consecutive 2 registers from address 0x0003
      // the written values are (04 D2) and (0D 80), with corresponding decimal values of 1234 and 3456
      00 01 00 00 00 0B 01 10 00 03 00 02 04 04 D2 0D 80
      // Response:
      00 01 00 00 00 06 01 10 00 03 00 02
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 90 XX
    • 0x16: Mask write single holding register
      // sample request and response / exception
      // Request: write to register address of 0x0000 with mask.
      // "AND" operation mask is (00 0F),"OR" operation mask is (0F 00)
      // If the value before this operation is "val", then after the mask opeation it becomes: (val & 0x000F) | (0x0F00 & ~0x000F)
      00 04 00 00 00 08 01 16 00 00 00 0F 0F 00
      // Response:
      00 04 00 00 00 08 01 16 00 00 00 0F 0F 00
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 96 XX
    • 0x17: Read and Write multiple holding registers
      // sample request and response / exception
      // Request: Write 2 registers from address 0x0020, and read 2 registers from address 0x0003
      // values to be written are (00 06) and (00 04)
      00 01 00 00 00 0F 01 17 00 03 00 02 00 20 00 02 04 00 06 00 04 
      // Response:  Received values of the two registers are (04 D1) and (0D 7F) as an example here  
      00 01 00 00 00 07 01 17 04 04 D1 0D 7F 
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 97 XX
  • Input register (16 bit)

    • 0x04: Read multiple input registers
      // sample request and response / exception
      // Request: read 2 consecutive holding registers from address 0x0003
      00 01 00 00 00 06 01 04 00 03 00 02
      // Response: Received 2 values are (00 0E) and (00 13) as an example
      00 01 00 00 00 07 01 04 04 00 0E 00 13
      // Exception: XX is the exception code
      00 01 00 00 00 03 01 84 XX

Exception code explanation

  • 0x01: Illegal/Unsuppported function code
  • 0x02: Illegal target address
  • 0x03: Exception of requested data

Appendix

  • Coil Registers (single bit access, READ/WRITE)

    Address(Dec) Address(Hex) Explanation
    0 ~ 31 0x00 ~ 0x1F 32 controller Digital Output (Now only 16 effective)
    32 ~ 39 0x20 ~ 0x27 8 tool Digital Output (Now only 2 effective)
    40 ~ 127 0x28 ~ 0x7F Reserved
    128 ~ 134 0x80 ~ 0x86 joint (J1-J7) brake states
    135 ~ 141 0x87 ~ 0x8D joint (J1-J7) enable states
    142 0x8E Reduced mode (0: OFF, 1: ON)
    143 0x8F Digital Fence (0: OFF, 1: ON)
    144 0x90 isPaused (0: False, 1: True)
    145 0x91 isStopped (0: False, 1: True)
    146 ~ 159 0x92 ~ 0x9F Robot Mode (14 bits for mode 0-13 respectively, 0: not in this mode, 1: in this mode)
    160 ~ 255 0xA0 ~ 0xFF Reserved
    256 ~ 511 0x100 ~ 0x1FF General purpose, user defined
  • Discrete Input Registers (single bit access, READ only)

    Address(Dec) Address(Hex) Explanation
    0 ~ 31 0x00 ~ 0x1F 32 controller Digital Input (Now only 16 effective)
    32 ~ 39 0x20 ~ 0x27 8 tool Digital Input (Now only 2 effective)
    40 ~ 127 0x28 ~ 0x7F Reserved
  • Holding Registers (16 bit access, READ/WRITE)

    Address(Dec) Address(Hex) Explanation
    0 ~ 1 0x00 ~ 0x01 32 controller Digital Outputs (Now only 16 effective), each bit correspond to one IO in order
    2 0x02 8 tool Digital Outputs (Now only 2 effective), each bit correspond to one IO in order
    3 ~ 6 0x03 ~ 0x06 4 controller analog outputs (now only 2 effective), it is 1000 times the real value
    7 ~ 10 0x07 ~ 0x0A 4 tool analog outputs (currently NOT EFFECTIVE), it is 1000 times the real value
    11 ~ 31 0x0B ~ 0x1F Reserved
    32 0x20 Robot Mode
    33 0x21 Robot State
    34 ~ 47 0x22 ~ 0x2F Reserved
    48 ~ 63 0x30 ~ 0x3F Offline (Blockly) Task (only effective by writing multiple (max 16) holding registers to address 0x30 via function code 0x10, each register value correspond to one Blockly project with specific naming convention, for example: value 1 for project '00001', 12 for project '00012', projects will be executed automatically in order)
    64 ~ 255 0x40 ~ 0xFF Reserved
    256 ~ 511 0x100 ~ 0x1FF General purpose, user defined
  • Input Registers (16 bit access, READ only)

    Address(Dec) Address(Hex) Explanation
    0 ~ 1 0x00 ~ 0x01 32 controller Digital Inputs (Now only 16 effective)
    2 0x02 8 tool Digital Inputs (Now only 2 effective)
    3 ~ 6 0x03 ~ 0x06 4 controller analog inputs (now only 2 effective), it is 1000 times the real value
    7 ~ 10 0x07 ~ 0x0A 4 tool analog inputs (now only 2 effective), it is 1000 times the real value
    11 ~ 31 0x0B ~ 0x1F Reserved
    32 0x20 Robot Error code
    33 0x21 Robot Warning code
    34 ~ 35 0x22 ~ 0x23 Counter value (0x22 stores the higher 16-bit, 0x23 stores the lower 16-bit)
    36 ~ 63 0x23 ~ 0x3F Reserved
    64 ~ 72 0x40 ~ 0x48 Current TCP coordinate of x/y/z/roll/pitch/yaw/rx/ry/rz values, register values are 10 times the real numbers (unit: mm, degree)
    73 ~ 76 0x49 ~ 0x4C TCP payload mass(1000x)/center_x(10x)/center_y(10x)/center_z(10x) (unit: kg, mm)
    77 ~ 82 0x4D ~ 0x52 TCP Offset, register values are 10 times the real numbers(unit: mm, degree)
    83 ~ 88 0x53 ~ 0x58 User/world coordinate offset, register values are 10 times the real numbers(unit: mm, degree)
    89 ~ 95 0x59 ~ 0x5F joint (J1-J7) angles, register values are 10 times the real numbers(unit: degree)
    86 ~ 102 0x60 ~ 0x66 joint (J1-J7) temperature (unit: degree Celsius)
    103 ~ 109 0x67 ~ 0x6D joint (J1-J7) speed, register values are 10 times the real numbers(unit: degree/s)
    110 0x6E Robot TCP linear speed, register values are 10 times the real numbers(unit: mm/s)
    111 ~ 127 0x6F ~ 0x7F Reserved