Patrick Posted January 4, 2021 Report Share Posted January 4, 2021 So I got hold of a remote I/O which a would like to control over TCP with Visilogic (Samba 7), however I can not make head nor tail of the register table. Could anyone give me some pointers as to how to read this type of table please, or give me a link to a tutorial. I have looked, but without luck so far. Thanks Link to comment Share on other sites More sharing options...
MVP 2023 Joe Tauser Posted January 5, 2021 MVP 2023 Report Share Posted January 5, 2021 That table was created for some who understands Modbus to the byte level. You don't need to go that deep to use this module. The DI's and DO's are also known as coils and will equate directly to MB addresses. The AI's are called "holding registers" and represent 16 bit signed integers, also known as MI addresses. This table can be totally confusing because they list the same "register address" of 0x00000 for both DI1 and AI1. If you don't know Modbus, you'll be like "What the hell does this mean?" In ModbusSpeak, coils are their own data type and always start with a real 0 followed by the address to four significant digits And start at 1, so DI1 would properly be 00001. Unitronics adds to the confusion by starting at 0, so DI1 corresponds to MB 0. Registers in Modbus start with a 4, so AI1 would be 40001. Unitronics calls this MI 0. Look in the Examples for Modbus TCP and you'll see what's needed to read and write your device. After you do this post your program with questions. Joe T. Link to comment Share on other sites More sharing options...
MVP 2023 Ausman Posted January 5, 2021 MVP 2023 Report Share Posted January 5, 2021 On top of what Joe says, my experience of many modbus devices from "lesser known" makers, especially those from Asia, is that they often don't follow normal conventions. You often need their special program to change crucial settings so that you can then communicate with it in the normal way. Perhaps your device is not one of these, but be aware of the possibility. cheers, Aus Link to comment Share on other sites More sharing options...
Patrick Posted January 8, 2021 Author Report Share Posted January 8, 2021 Hi Guys, thanks for the pointers. In case this may help anyone else with similar newbie problems, here is what I have done so far. One of the things I noted while reading through the forum was to always use Modbus testers before trying put together a program. I had a hunt around, tried various freebies, and so far I have discovered a few things about the device, which as Ausman correctly guessed comes from Asia. http://www.hi-flying.com/hf6208 Using Modbus Poll Test Center, I managed to turn on and off the output relays by copy pasting the various instructions from the manual But this did not help with identifying what was going on elswhere. So using CAS Modbus scanner I managed to get the following : I then used the same tool to check the addresses with function 01 and got the following Function 2 gave me this Function 4 gave me this At the moment there is a single analogue input, a single digital input, and 7 relays on and one off. So far so good, I can read the status of everything, but I am still having problems with function 5. With the exception of Modbus Poll Test Center, every other test i have tried strips out the two zeros after the function bit. i.e. I try to send 01 05 00 10 00 etc, but only manage 01 05 10 00 00 etc, which returns an error. Can anyone enlighten me as to what is going on? Cheers Link to comment Share on other sites More sharing options...
Patrick Posted January 10, 2021 Author Report Share Posted January 10, 2021 (edited) I did a test program to try and work this all out. Very frustrating. I have tried using the addresses I found with CAS Modbus Scanner (shown in previous post), in both decimal and hex. I have not been able to read or write anything at all to the device with Visilogic. I then realised that every time I tried to send a message, the status operand was giving me 4 for each attempted send, than going to 5 when finished. This leads me to believe that the communications are the first problem to solve. I have looked at the examples, but can not see anything different to what I am doing. The remote IO device works fine with both CAS Modbus Scanner and Modbus Poll, so there should not be be any communications issue. SB147 tells me that the socket is connected, i am not sure what to do next. Test program Modbus TCP with constants.vlp Edited January 10, 2021 by Patrick Upload new copy of program with constants Link to comment Share on other sites More sharing options...
MVP 2023 kratmel Posted January 10, 2021 MVP 2023 Report Share Posted January 10, 2021 Hi, in code you use some operand to configure slave register (coil) address and slave register vector length but it is not placed correct numbers to this operand in program. Please define correct slave register (coil) address (place constant or set needed numbers to operand). Slave ID need to be 1 as in PC dialog Link to comment Share on other sites More sharing options...
Patrick Posted January 10, 2021 Author Report Share Posted January 10, 2021 Many thanks to Kratmel for finding the mistake in my setup, communications now working! Link to comment Share on other sites More sharing options...
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now