An open API service indexing awesome lists of open source software.

https://github.com/sanny32/openmodsim

Open ModSim is a Free Modbus Slave (Server) Utility
https://github.com/sanny32/openmodsim

linux modbus modbus-rtu modbus-server modbus-slave modbus-tcp modsim windows

Last synced: 29 days ago
JSON representation

Open ModSim is a Free Modbus Slave (Server) Utility

Awesome Lists containing this project

README

          

# Open ModSim

[![GitHub all releases](https://img.shields.io/github/downloads/sanny32/OpenModSim/total?logo=github&cacheSeconds=3600)](https://github.com/sanny32/OpenModSim/releases)
[![GitHub release (latest by date)](https://img.shields.io/github/v/release/sanny32/OpenModSim?logo=github&cacheSeconds=3600)](https://github.com/sanny32/OpenModSim/releases/latest)
[![License](https://img.shields.io/github/license/sanny32/OpenModSim)](LICENSE.md)

Open ModSim is a free implimentation of modbus slave (server) utility for modbus-tcp and modbus-rtu protocols.

image

image

# Features

The following Modbus functions are available:

- Discrete Coils/Flags
```
0x01 - Read Coils
0x02 - Read Discrete Inputs
0x05 - Write Single Coil
0x0F - Write Multiple Coils
```

- Registers
```
0x03 - Read Holding Registers
0x04 - Read Input Registers
0x06 - Write Single Register
0x10 - Write Multiple Registers
0x16 - Mask Write Register
```

The following simulations are available:

- Discrete Coils/Flags
```
Random - simulate flag randomly
Toggle - simulate flag on/off periodicaly
```

- Registers
```
Random - simulate register randomly
Increment - simulate register from Low Limit to High Limit with a given Step
Decrement - simulate register from High Limit to Low Limit with a given Step
```

# Modbus Logging

image

# Extended Featues

- Modbus Message Parser

image

- Modbus Definitions

image

- Error Simualtions

image


# Scripting
From version 1.2.0 Open ModSim supports scripting. Qt runtime implements the [ECMAScript Language Specification](http://www.ecma-international.org/publications/standards/Ecma-262.htm) standard, so Javascript is used to write code.

image

Scripts can be launched in two modes: Once or Periodically. If you run script in Once mode the script will stop after it finishes executing. In Periodically mode, the script will start after a certain period of time until the user stops it or the method is called
```javascript
Script.stop();
```
Here is an example of using the script in the Periodically mode
```javascript
/**************************************************************************/
/*
/* Example script that store value after 3 seconds
/*
***************************************************************************/

/* Set the server address base starts from one (1-based) */
Server.addressBase = AddressBase.Base1;

let deviceId = 1;
let address1 = 1;
let address10 = 10;

function reset()
{
/* Write to a Holding register at address1 zero value */
Server.writeHolding(address1, 0, deviceId);
}

/* init function */
function init()
{
reset();

/* Print server error if occured and stop script execution */
Server.onError(deviceId, (error)=> {
console.error(error);
Script.stop();
});

/* Runs when Hodling register value at address1 was changed */
Server.onChange(deviceId, Register.Holding, address1, (value)=>
{
if(value === 1)
{
/* Runs after 3 seconds and increase Holding register value at address10
* Then reset register value at address1 and stop script execution
*/
Script.setTimeout(function()
{
Server.writeHolding(address10, Server.readHolding(address10, deviceId) + 1, deviceId);
reset();
Script.stop();
}, 3000);
}
});
}

/* Runs once when script started */
Script.onInit(init);
```

# Building
Building is available via cmake (with installed Qt version 5.15 and above) or Qt Creator. Supports both OS Microsoft Windows and Linux.

## Microsoft Windows Building

The minimum supported version of Microsoft Windows for building OpenModSim from sources is Windows 10.

1. Install latest [git](https://git-scm.com/downloads/win) version
2. Run Windows PowerShell terminal as an Administrator
3. Clone OpenModSim sources from github repository
```powershell
git clone https://github.com/sanny32/OpenModSim.git
```
4. Go to OpenModSim folder
```powershell
cd OpenModSim
```
5. Allow script execution in PowerShell terminal
```powershell
Set-ExecutionPolicy -Scope Process -ExecutionPolicy Bypass
```
6. Run the build script
```powershell
.\build.ps1
```
If you need to specify Qt framework major version (5 or 6), you can do it in the parameters
- `.\build.ps1 -qt5` or `.\build.ps1 -qt6`

The build script supports building the application only for 64-bit architecture.

## Linux Building
1. Install [git](https://git-scm.com/downloads/linux) for your Linux distribution
2. Run the following commands from the console:
```bash
git clone https://github.com/sanny32/OpenModSim.git
```
```bash
cd OpenModSim
```
```bash
./build.sh
```

If you need to specify Qt framework major version (5 or 6), you can do it in the parameters
- `./build.sh -qt5` or `./build.sh -qt6`

# About supported operating systems

The following minimum operating system versions are supported for OpenModSim:

- **Microsoft Windows 7**
- **Debian Linux 11**
- **Ubuntu Linux 22.04**
- **Mint Linux 22**
- **Zorin OS 18**
- **Fedora Linux 41**
- **Rocky Linux 9.7**
- **OpenSuse Linux 15.6**
- **Alt Linux 11**
- **Astra Linux 1.7**
- **RedOS 8**

# Install from [binary distributions](https://github.com/sanny32/OpenModSim/releases/latest)

Below are the methods for installing the OpenModSim for different OS

## Microsoft Windows
Run the installer:

- For 32-bit Windows: `qt5-omodsim_1.12.0_x86.exe`
- For 64-bit Windows: `qt5-omodsim_1.12.0_x64.exe` or `qt6-omodsim_1.12.0_x64.exe`

## Debian / Ubuntu / Mint / Zorin / Astra Linux
### Install
Install the DEB package from the command line:
```bash
sudo apt install ./qt6-omodsim_1.12.0-1_amd64.deb
```
or if you want to use Qt5 libraries:
```bash
sudo apt install ./qt5-omodsim_1.12.0-1_amd64.deb
```

### Remove
To remove the DEB package run:
```bash
sudo apt remove qt6-omodsim
```
or for Qt5 package:
```bash
sudo apt remove qt5-omodsim
```

## RedHat / Fedora / Rocky / RedOS Linux
### Install
Install the RPM package from the command line:
```bash
sudo dnf install ./qt6-omodsim-1.12.0-1.x86_64.rpm
```

### Remove
To remove the RPM package run:
```bash
sudo dnf remove qt6-omodsim
```

## Alt Linux
### Install
Install the RPM package from the command line as root user:
```bash
apt-get install ./qt6-omodsim-1.12.0-1.x86_64.rpm
```

### Remove
To remove the RPM package run as root user:
```bash
apt-get remove qt6-omodsim
```

## SUSE / OpenSUSE Linux
### Install
Import qt6-omodsim.rpm.pubkey to rpm repository:
```bash
sudo rpm --import qt6-omodsim.rpm.pubkey
```
Install the RPM package using Zypper:
```bash
sudo zypper install ./qt6-omodsim-1.12.0-1.x86_64.rpm
```

### Remove
To remove the RPM package run:
```bash
sudo zypper remove qt6-omodsim
```

# MIT License
Copyright 2023-2026 Alexandr Ananev [mail@ananev.org]

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.