1. ModScan Overview 1.1 Document/View Architecture 1.2 Modbus Data Definition 1.3 Display Formats 1.4 Connecting to a Modbus Network 1.4.1 Direct Serial Connections 1.4.2 Modem Connections 1.4.3 Network Connections 2. Menu Commands 2.1 File menu 2.2 Connection menu 2.3 Setup menu 2.4 View menu 2.5 Window menu 2.6 Help menu 3. Tool & Status Bars 3.1 Toolbar 3.2 Format Selections 3.3 Status Bar 4. Testing Features 4.1 Writing Data to the Modbus 4.2 Message Counters 4.3 Observing Serial Traffic 4.4 Capturing Data to Text File 4.5 User Defined Commands 4.6 Scripts 5. Using ModScan with a Database 6. Using OLE Automation 6.1 Overview 6.2 Automation Routines 7. Distribution/Registration 7.1 Pricing 7.2 Licensing 7.3 Support 7.4 Other Products 1. ModScan Overview The ModScan application operates as a MODBUS mastermodbus_protocol device in either RTU or ASCII transmission modes. ModScan may be used to access and modify data points contained in one or more MODBUS slave devices connected to the PC via a serial port, modem, or network. ModScan supports the standard MODBUS message types 01-06, 15 & 16, as well as providing the ability for you to exercise special features of a slave device by transmitting custom command strings and observing the response. ModScan is a useful test and diagnostic tool for verifying the proper slave response to MODBUS queries as well as being a low cost data collection tool for interfacing data into PC database and spreadsheet applications. 1.1 Document/View Architecture ModScan utilizes the standard Windows Multiple-Document-Interface, (MDI), architecture for displaying modbus data to the user. Each document represents a series, (array), of modbus data points identified by the following parameters: Slave Device Address Represents the physical device attached to the modbus network Data Type Internal data representation, (i.e. input, coil, register) Data Address Point address within the device Length Number of points to scan/display Associated with each document is also a timer, which is used to periodically scan new data from the defined slave and refresh the display. The modbus data definition is accessible from the ModScan menu or via edit controls in the top splitter window of the document display. As new data is obtained from the slave device, it is written to the bottom splitter window in one of several formats, depending upon your preference. The size of each document display window is adjustable via the splitter control. 1.2 Modbus Data Definition The upper half of each Document's View represents the data selected for display, (and possible capture to a historical data file). In most testing applications, the ModScan will only be connected to a single modbus slave device, however, in a multidrop modbus network, there may be several devices accessible from a single connection. The "Device Id" edit control allows you to specify the slave address for the source of the data. Likewise, edit controls are available to select the point type, data address, and number of data points to access. Notice that the modbus protocol uses a 5-digit representation for the slave data address which infers the point-type. For example, INPUT STATUS values are always represented in the range 10001-19999: HOLDING REGISTERS are displayed as 40000-49999. The ModScan application uses the standard notation for displaying data in the bottom splitter window, however the address specified in the upper splitter address edit control assumes a 4-digit physical point address. This address, coupled with the point-type specifier completely defines the data to be accessed in the slave device. The upper splitter window also contains two counters which are used to tally the number of data requests made from this document to the modbus connection and the number of valid slave responses received in reply. A button is available within the display which resets the counters associated with this document. 1.3 Display Formats As data is received from the slave device, it is displayed to the lower splitter view of the associated document. Any errors incurred during the exchange of information will be displayed on the first line. The font and colors used to display the data is configurable via the View, Config menu options. Modbus register data may be displayed in any of the following formats: Binary Data displayed as 16 discrete values. Decimal Ranges from -32767 to 32768 Hexadecimal 0000-ffff Floating Point IEEE Standard Floating Point Notation (Requires two registers per value) Word-Swapped Floating Point Inverted Floating Point used by some processors Double-Precision Floating Point 64-bit Floating Point Notation Word Swapped Dbl Precision Inverted 64-bit Float Values 1.4 Connecting to a Modbus Network 1.4.1 Direct Serial Connections ModScan may be used to obtain data from modbus slave device connected to the PC in one of three basic physical arrangements. The most common connection is via any one of the four available PC serial COM ports. ModScan uses the standard Win32 software drivers for communication with the COM ports, thereby providing support for any hardware serial boards which may be installed in the Windows operating system, (including RS-232, RS-485, etc.). You have complete control over the operating characteristics of the serial connection by selecting the appropriate baud rate, parity, and control line, (handshaking), properties to match the slave device(s). 1.4.2 Modem Connections In remote testing situations, the ModScan application may be used to communicate with a modbus network over a dedicated modem connection. ModScan supports the TAPI, (telephony application interface), standard implemented in Windows and Windows NT. If selected, the modem connection dialog allows you to enter a phone number for dialing. Any TAPI device configured within the Windows operating system is available for use. It is also possible to connect via modem to a remote system utilizing the built-in networking characteristics of Windows '95 & NT. To do this, you will need to configure the ModScan application to connect via a TCP/IP connection which has been setup within Windows to automatically dial and establish a PPP connection with another Windows machine which is connected directly to the slave device(s) you wish to use. In this case, ModScan operates as if it were using a network card connected directly to a modbus to tcp/ip bridge device. 1.4.3 Network Connections ModScan allows modbus communications to occur over a TCP/IP network. This feature requires the use of a modbus to TCP/IP bridge device which can service network requests from the network and obtain the data from a connected slave device prior to responding to queries from the ModScan application. A bridge device operates as a network server, providing support to numerous client applications distributed over the network. WinTECH Software provides such a server for interfacing to a single serial modbus network. Third-party vendors may provide various solutions for interfacing TCP/IP to modbus devices via other hardware, (i.e. modbus plus, etc.). If the interfacing specification for these network bridge devices is available in the public domain, they may be included in future releases of the ModScan application. If you have the need to use ModScan with a third-party vendor's equipment, please contact the WinTECH Software support line for consideration. 2. Menu Commands 2.1 File menu The File Menu offers the following commands: New Creates a new ModScan document. Each document represents a different block of data from a modbus device. Open Opens an existing document. Close Closes an open document. Save Saves an open document. SaveAs Saves an open document to a specified file name. Print Prints an open document. Print Setup Selects a Printer and Printer connection. Exit Exits ModScan 2.2 Connection menu The Connect menu offers the following commands: Connect Attaches the ModScan application to a modbus network, enabling data collection. Disconnect Detaches the ModScan application from the network, freeing up resources for other Windows applications. 2.3 Setup menu The Setup menu offers the following commands: Data Definition Defines the document properties of the modbus data to be scanned. Display Options Allows the document data to be viewed in a variety of formats. Show Data -This default view configuration displays data values as obtained from the modbus slave device. Show Traffic-This option allows the serial data stream to be displayed in place of the data points. Binary -Register values are displayed as 16 discrete bits. Decimal -Register values are displayed in decimal format, (-32767-32768). Hex -Register Values are displayed in Hexadecimal, (0000-ffff). Floating Pt.-Register Values are displayed in floating point notation, (two registers are required). Swapped FP -Register Values are displayed in floating point notation, (least significant register first). Dbl Float -Register Values are displayed in floating point notation, (four registers, (64 bits), are required). Swapped Dbl -Register Values are displayed in floating point notation, (least significant register first). Hex Addresses-Displays the addresses of data points in hexadecimal notation.. Extended Options Provides the ability to write data to a connected slave device. Force Coils -Provides the ability to write coil values to a designated slave device. PreSet Registers-Provides the ability to write register values to a designated slave device. User Commands-Allows you to define and transmit a custom command. Script Files-Begins execution of a test script. Text Capture Begins collecting modbus data to a specified text file. Dbase Capture Begins collecting data into a defined database table. Capture Off Stops data collection. Reset Counters Clears all modbus message status counters in all documents. 2.4 View menu The View menu offers the following commands: Toolbar Shows or hides the toolbar. Status Bar Shows or hides the status bar. Display Bar Shows or hides the format toolbar used to select the display format for modbus registers. Config Allows you to customize the appearance of ModScan by selecting the colors and font used. Background Color-Selects the color for the ModScan data display splitter view. Foreground Color-Selects the text color used to display data values. Status Color-Selects the color used to show the modbus status line. Font -Selects the font. 2.5 Window menu The Window menu offers the following commands, which enable you to arrange multiple views of multiple documents in the application window: New Window Creates a new window that views the same document. Cascade Arranges windows in an overlapped fashion. Tile Arranges windows in non-overlapped tiles. Arrange Icons Arranges icons of closed windows. Window 1, 2, Goes to specified window. 2.6 Help menu The Help menu offers the following commands, which provide you assistance with this application: Help Topics Offers you an index to topics on which you can get help. About Displays the version number of this application. 3. Tool & Status Bars 3.1 Toolbar The toolbar is displayed across the top of the application window, below the menu bar. The toolbar provides quick mouse access to many tools used in ModScan. The toolbar is detachable and dockable by clicking the mouse on the toolbar background and dragging it to the desired location within the ModScan application window. 3.2 Format Selections The format toolbar is displayed across the top of the application window, below the menu bar. The format toolbar provides quick mouse access to select the format used by ModScan to display the contents of modbus registers. The toolbar is detachable and dockable by clicking the mouse on the toolbar background and dragging it to the desired location within the ModScan application window. 3.3 Status Bar The status bar is displayed at the bottom of the ModScan window. To display or hide the status bar, use the Status Bar command in the View menu. The left area of the status bar describes actions of menu items as you use the arrow keys to navigate through menus. This area similarly shows messages that describe the actions of toolbar buttons as you depress them, before releasing them. If after viewing the description of the toolbar button command you wish not to execute the command, then release the mouse button while the pointer is off the toolbar button. The right areas of the status bar indicate the message counters for all modbus message activity logged by the various active documents. 4. Testing Features 4.1 Writing Data to the Modbus In order to write a MODBUS data point in a slave device, the communications with the device must first be initiated by scanning a series of data points by configuring the correct addressing information and initiating a polling cycle. Once the data is successfully displayed, double-clicking the address/value portion of the screen will initiate a dialog box which allows the value to be changed. If the polling cycle has been configured to represent coil addresses, double-clicking an address will initiate the Change Coil Dialog. The Change Register Dialog Box may be initiated by configuring the display to represent register data and double clicking on an address. Register values may be written using binary, decimal, hexadecimal, or floating-point notation, depending on the preference selection currently in effect. Pressing the Update Button in either write data point dialog will initiate the appropriate MODBUS write command, (05 or 06), during the next scheduled poll. 4.2 Message Counters Each document maintains a counter for each query message transmitted to a modbus slave device and a counter for each correct response returned from the addresses slave. The counters for a given document may be reset via a button control accessible via the upper, (data definition), splitter view. A total count of all message counters from all active documents, (including any OLE Automation client documents), is displayed via the ModScan status bar. 4.3 Observing Serial Traffic Use this command to troubleshoot the connection to a particular modbus device. When selected, this option will display the serial data exchanged between the ModScan application and the slave device associated with this document. The data display splitter view will show data transmitted to the slave device and data returned from the slave device as communications occur during the normal polling cycle. This will help to isolate a problem with possible misinterpretation of the modbus protocol. Data will be displayed in either decimal or hex, depending upon the preference settings in effect for viewing the modbus data points. Normal data collection, (if enabled), will continue. 4.4 Capturing Data to Text File An optional feature of ModScan is its ability to capture modbus data directly into a database. The Microsoft Jet database engine allows you to automatically update a compatible database with new data each time it is read by a ModScan document. Included within a database, the data is easily accessible for manipulation and display of customized applications. Even without this option, ModScan may be used to capture data to an ASCII text file , which may then be ported in an off-line fashion to your database. 4.5 User Defined Commands Use this command to customize a command string for transmission to a designated modbus slave device. This command is useful for observing the slave response to non-standard modbus queries or to test its reaction to requests for data which may not be available. The slave device should respond with the proper exception message if a master device asks for data which is beyond its address range or otherwise unavailable via the modbus. After transmitting the user string, ModScan will receive characters for the entire time-out period specified for the connection. The results will then be updated to the appropriate edit control on the dialog box. User defined messages transmitted to a slave device will not show up in the ModScan message counters. 4.6 Scripts Test scripts are one of the most unique features of ModScan. They provide for production testing of modbus slave devices by allowing you to construct and execute a series of modbus messages to be sent to an attached slave device to verify and log the responses. Script files are constructed using any word-processor or spreadsheet application to define the test message and expected slave response. Response codes are available which determine how ModScan verifies the response against the user supplied data. For example, one script entry may request the contents of a group of known registers and expect the exact response to be returned. Another script entry may complete successfully if the correct number of register values is returned, regardless of the contents. Test scripts may be executed one entry at a time, (single-step), or placed in a loop to execute continuously, logging the results to a text file for later observation by a test technician. If continuous execution of the script is desired, an auxiliary dialog box defines the looping characteristics. Test results are displayed as each script entry is executed. 5. Using ModScan with a Database An optional feature of ModScan32 allows you to write data directly into a Microsoft compatible database such as Access. ModScan uses the Jet database engine to provide an efficient exchange of information from an addressed slave device into the designated database table. Selecting the Dbase Capture menu ietm allows you to associate a ModScan document with a given database table. The table will then be updated with new data each time the slave device is polled. If you change the properties of the document while collection is enabled, updates to the database will temporarily cease. Database updates will resume if the original properties are restored. 6. Using OLE Automation 6.1 Overview An optional feature of ModScan32 is the ability to access modbus data using OLE Automation routines. This allows custom programs to be generated, (using Visual Basic, Excel Basic, etc.,), to interpret and format data according to your specific requirements. OLE Automation routinesHID_OLE_ROUTINES provide both read and write access to one or more modbus slave devices through the ModScan application. Using the OLE Automation routines is a very simple process: The VBA application links to the ModScan32.tlb file, (Type Library), which details the names for each automation procedure and its argument list. From the Visual Basic development framework, this is done by selecting the menu item to include a custom type library and then browsing for ModScan32.tlb. During the initial Form Load operation, the application must call Create Object as follows: CreateObject("ModScan32.Document") The application then creates one or more PollRequests which define an array of data points to be read from a modbus device. Data defined by the Poll Request will be automatically scanned by the ModScan application on a 1 second basis. (NOTE: The ModScan application must be connected to the modbus network prior to the VBA application starting up.) The application uses the handle returned from the CreatePollRequest procedure to access, (read or write), a value within the defined array. During application termination, it must free the memory used by the ModScan application to maintain the data points by deleting any Poll Requests created. Refer to the Visual Basic Example application included with the ModScan distribution files for additional details. 6.2 Automation Routines The following OLE Automation routines are supported by ModScan32: short CreatePollRequest (short Device, long Address, short Length) Arguments: Device - Specifies the slave device address Address - Specifies the data point address, (in modbus master (5 digit) format. coil status addresses: 00000-09999 input status addresses: 10000-19999 input register addresses: 30000-39999 holding register addresses: 40000-49999 Length - Specifies the number of values included in the definition Return Value: Point Handle - Defines the array structure for future reads & writes Notes: Sets up data structures within ModScan to begin polling the specified data. ModScan must be connected to the modbus network prior to creating the data array. CreatePollRequest returns a non-zero value if the data structure was successfully created, otherwise it returns 0. short ReadValue (short PointHandle, short Index, short *pValue) Arguments: Point Handle - refers to value returned from CreatePollRequest Index - Specifies the index into the array structure *pValue - is a pointer to a value to be returned. Return Value: Status - indicates whether or not the operation was completed successfully Notes: Status will be MBUS_OK, (0), if the data point was successfully read, otherwise, a non-zero value indicates one of the defined error conditions. short WriteValue (short PointHandle, short Index, short Value) Arguments: Point Handle - refers to value returned from CreatePollRequest Index - Specifies the index into the array structure Value - is the data to be written. Return Value: Status - indicates whether or not the operation was completed successfully Notes: Status will be MBUS_OK, (0), if the data point was successfully queued for transmission to the addresses slave. A zero return value does not indicate successful transmission of the request to the slave device. The controlling application is responsible for verifying the write operation by reading back the value written. short ModifyPollRequest (short PointHandle, short Device, long Address, short Length) Arguments: Point Handle - refers to value returned from CreatePollRequest Device - Specifies the new slave device address Address - Specifies the new data point address,(in modbus master (5 digit) format. Length - Specifies the number of values included in the definition Return Value: Status will be MBUS_OK, (0), if the data point was successfully modified, otherwise, a non-zero value indicates one of the defined error conditions. Notes: Immediately after changing the parameters of a defined data point, the current status of each value in the array will be set to MBUS_UNINITIALIZED, indicating that the data does not represent that defined by the device/address definition. The first poll after modification should reflect the true status of the addressed data array. short DeletePollRequest (short PointHandle) Arguments: Point Handle - refers to value returned from CreatePollRequest Return Value: Status will be MBUS_OK, (0), if the data point was successfully modified, otherwise, a non-zero value indicates one of the defined error conditions. Notes: This routine frees up memory allocated by ModScan to support the defined Poll Request. 7. Distribution/Registration 7.1 Pricing ModScan is a time-limited demo application which allows you to connect up to a modbus network and evaluate its operation without cost or obligation. ModScan is designed to allow unrestricted use for a period of 3 1/2 minutes after successful communication is established with a slave device. During this time, all features, including OLE and database support are active. At the end of the demo period, ModScan will cease updating the views associated with each document. You must restart the application to resume operation. The introductory registration price for the ModScan32 application is $64.95. Options to allow interfacing data to a database and/or OLE are additional. ou may print an order form by selecting a button control within the ModScan About box. For the latest pricing and availability details, please refer to the WinTECH Software Web-Site at http://www.win-tech.com 7.2 Licensing ModScan32 is distributed as a shareware/demo-ware application which may be freely distributed without charge to prospective users. Time limits and registration reminder screens are utilized to encourage registration. If you find this application useful, please refer it to your associates in the hope that they too may be able to use it. If you choose to register this application, you will receive a license certificate with access codes which will remove all program restrictions when entered into the initial sign-on dialog box. You will only need to enter the registration codes once. A single-user license allows the purchaser to use the application on as many different machines as desired, so long as there is only one copy of the application running at any given time. Running multiple instances of the application on different machines at the same time is a violation of the copyright owned by WinTECH Software. Multiple-User and Site-licenses are available for installations which require multiple simultaneous use of the ModScan application. 7.3 Support For the latest product and pricing information, please refer to the WinTECH Software Web-Site at: http://www.win-tech.com For technical support, please e-mail: support@win-tech.com To place an order, fax to: 1-304-645-5966 or mail: WinTECH Software P.O. Box 907 Lewisburg, WV 24901 U.S.A. 7.4 Other Products WinTECH Software offers the following products and services which may be of interest: Modbus Driver Dll's Windows drivers are available to support either the modbus master or modbus slave protocol on a PC. These drivers are written in 'C'. They are available in either 16 or 32-bit designs and include all modbus message formatting and interaction with the Windows serial drivers. A simple API is made available to your application, which greatly simplifies its design and allows you to very easily implement a custom modbus design under Windows. Each driver is very reasonably priced, and comes with a sample Windows application written in the Microsoft MFC. ModSim Windows Application ModSim is the counterpart to ModScan and simulates the slave end of the modbus protocol. ModSim allows you to define a series of data points, (representing one or more slave devices), and provides this data to an attached modbus master application. MNetSvr Windows Application MNetSvr is a Windows application which serves as a Modbus to TCP/IP gateway device for interfacing serial modbus slave devices to plant networks. MNetSvr utilizes the MBAP protocol standard, (Modbus Application Programming Interface), to service multiple Modbus Master Client applications requesting data from one or more slaves. Listen Windows Application Listen is a fully functional serial data link monitor, (datascope), which allows you to watch data traffic in real time as it travels in two directions between communicating devices. Listen is highly customizable in the way it displays data and uses standard COM drivers for compatibility with any serial hardware configurable under Windows. Socket Spy Windows Application The Socket Spy allows you to monitor TCP/IP packets transferred between a Windows application and the Windows Sockets dll. Designed as a design and trouble-shooting aide for communications developers, Socket Spy provides full debugging data relative to all sockets activity occurring within the target application. --------------------------------------------------------------------------