ModbusBridge
ModbusBridge is a simple cross-platform (Windows, Linux) Modbus converter/gateway application that provides mutual convertions between different types of Modbus protocol: TCP, RTU, ASC
Install / Use
/learn @serhmarch/ModbusBridgeREADME
ModbusBridge
Overview
ModbusBridge (mbridge) is a simple cross-platform (Windows, Linux) Modbus converter application
that provides interconvertion between different types of Modbus protocol: TCP, RTU, ASC.
It can be used, for instance, in Raspberry Pi computer to act as Modbus converter.
It's free and open source software based on ModbusLib project:
https://github.com/serhmarch/ModbusLib
Application implements such Modbus functions as:
1(0x01) -READ_COILS2(0x02) -READ_DISCRETE_INPUTS3(0x03) -READ_HOLDING_REGISTERS4(0x04) -READ_INPUT_REGISTERS5(0x05) -WRITE_SINGLE_COIL6(0x06) -WRITE_SINGLE_REGISTER7(0x07) -READ_EXCEPTION_STATUS8(0x08) -DIAGNOSTICS11(0x0B) -GET_COMM_EVENT_COUNTER12(0x0C) -GET_COMM_EVENT_LOG15(0x0F) -WRITE_MULTIPLE_COILS16(0x10) -WRITE_MULTIPLE_REGISTERS17(0x11) -REPORT_SERVER_ID22(0x16) -MASK_WRITE_REGISTER23(0x17) -READ_WRITE_MULTIPLE_REGISTERS24(0x18) -READ_FIFO_QUEUE
Using mbridge
To show list of available parameters print:
$ mbridge -?
Usage: mbridge -ctype <type> [-coptions] -stype <type> [-soptions]
Options (-c client, -s server):
--version (-v) - show program version.
--help (-?) - show this help.
-c<param> - param for client.
-s<param> - param for server.
Params <param> for client (-c) and server (-s):
* type (t) <type> - protocol type. Can be TCP, RTU or ASC (mandatory)
* host (h) <host> - remote TCP host name (localhost is default)
* port (p) <port> - remote TCP port (502 is default)
* tm <timeout> - timeout for TCP (millisec, default is 3000)
* maxconn <count> - max active TCP connections (default is 10)
* serial (sl) - serial port name for RTU and ASC
* baud (b) - baud rate (for RTU and ASC) (default is 9600)
* data (d) - data bits (5-8, for RTU and ASC, default is 8)
* parity - parity: E (even), O (odd), N (none) (default is none)
* stop (s) - stop bits: 1, 1.5, 2 (default is 1)
* tfb <timeout> - timeout first byte for RTU or ASC (millisec, default is 1000)
* tib <timeout> - timeout inter byte for RTU or ASC (millisec, default is 50)
Options for server:
-sunit (-su) <list> - list of units for server to responde like '1,3,6-10,11,27'
Examples:
mbridge -stype TCP -ctype RTU -cserial COM6
mbridge -stype RTU -sserial /dev/ttyUSB0 -sbaud 19200 -ctype TCP -chost some.plc
Next example makes Modbus bridge with RTU client part and TCP server part works on TCP port 502:
> mbridge -stype TCP -smaxconn 5 -ctype RTU -cserial "COM6"
RTU:Client parameters:
----------------------
port = COM6
baud = 9600
data = 8
parity = No
stop = 1
flow = No
tfb = 1000
tib = 50
TCP:Server parameters:
----------------------
port = 502
timeout = 3000
maxconn = 5
mbridge starts ...
TCP:Server opened
New connection: 192.168.1.102:50392
192.168.1.102:50392 Rx: 00 05 00 00 00 06 03 03 00 00 00 05
RTU:Client opened
RTU:Client Tx: 03 03 00 00 00 05 84 2B
RTU:Client Rx: 03 03 0A 00 00 00 00 00 00 00 00 00 00 23 F4
192.168.1.102:50392 Tx: 00 05 00 00 00 0D 03 03 0A 00 00 00 00 00 00 00 00 00 00
...
192.168.1.102:50392 Rx: 00 08 00 00 00 06 03 03 00 00 00 05
RTU:Client Tx: 03 03 00 00 00 05 84 2B
RTU:Client Rx: 03 03 0A 00 00 00 00 00 00 00 00 00 00 23 F4
192.168.1.102:50392 Tx: 00 08 00 00 00 0D 03 03 0A 00 00 00 00 00 00 00 00 00 00
Close connection: 192.168.1.102:50392
mbridge stopped
Build using CMake
-
Build Tools
Previously you need to install c++ compiler kit, git and cmake itself. Then set PATH env variable to find compliler, cmake, git etc.
-
Create project directory, move to it and clone repository:
$ cd ~ $ mkdir src $ cd src $ git clone --recursive https://github.com/serhmarch/ModbusBridge.git -
Create and/or move to directory for build output, e.g.
~/bin/ModbusBridge:$ cd ~ $ mkdir -p bin/ModbusBridge $ cd bin/ModbusBridge -
Run cmake to generate project (make) files.
$ cmake -S ~/src/ModbusBridge -B . -
Make binaries (+ debug|release config):
$ cmake --build . $ cmake --build . --config Debug $ cmake --build . --config Release -
Resulting bin files is located in
./bindirectory.
Related Skills
node-connect
353.1kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
111.6kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
353.1kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
353.1kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
