Thanks to visit codestin.com
Credit goes to github.com

Skip to content

sanny32/OpenModSim

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Open ModSim

GitHub all releases GitHub release (latest by date) License

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 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

Script.stop();

Here is an example of using the script in the Periodically mode

/**************************************************************************/
/*
/* 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

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

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
  • Fedora Linux 41
  • OpenSuse Linux 15.6
  • Alt Linux 11
  • Astra Linux 1.7
  • RedOS 8

Install from binary distributions

Below are the methods for installing the OpenModSim for different OS

Microsoft Windows

Run the installer:

  • For 32-bit Windows: qt5-omodsim_1.10.0_x86.exe
  • For 64-bit Windows: qt5-omodsim_1.10.0_x64.exe or qt6-omodsim_1.10.0_x64.exe

Debian/Ubintu/Mint/Astra Linux

Install

Install the DEB package from the command line:

sudo apt install -f ./qt6-omodsim_1.10.0-1_amd64.deb

or if you want to use Qt5 libraries:

sudo apt install -f ./qt5-omodsim_1.10.0-1_amd64.deb

Remove

To remove the DEB package run:

sudo apt remove qt6-omodsim

or for Qt5 package:

sudo apt remove qt5-omodsim

RedHat/Fedora/RedOS Linux

Install

Install the RPM package from the command line:

sudo dnf install ./qt6-omodsim-1.10.0-1.x86_64.rpm

Remove

To remove the RPM package run:

sudo dnf remove qt6-omodsim

Alt Linux

Install

Install the RPM package from the command line as root user:

apt-get install ./qt6-omodsim-1.10.0-1.x86_64.rpm

Remove

To remove the RPM package run as root user:

apt-get remove qt6-omodsim

SUSE/OpenSUSE Linux

Install

Import qt6-omodsim.rpm.pubkey to rpm repository:

sudo rpm --import qt6-omodsim.rpm.pubkey

Install the RPM package using Zypper:

sudo zypper install ./qt6-omodsim-1.10.0-1.x86_64.rpm

Remove

To remove the RPM package run:

sudo zypper remove qt6-omodsim

MIT License

Copyright 2025 Alexandr Ananev [[email protected]]

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.