LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

the connection for the given session has been lost

Solved!
Go to solution

I connecting to the IDRC DSP-300-02.5HR power supply via ethernet by VISA. After system starts connection is normal. I send commands and receive answers. But when I shutdown power supply and start it again VISA don't refresh information about it. Power supply obtain IP by DHCP, but even IP not changed I receive error "VISA: (Hex 0xBFFF00A6) The connection for the given session has been lost" when try to write command by VISA Write function. Information about visa resources in the system I obtain by VISA Find Resource vi. How to solve this problem?

 

PS Power supply connected to second Ethernet adapter in the system. 

0 Kudos
Message 1 of 8
(15,604 Views)

Update.

I checked the connection of the power supply to both the first and second network cards. The result did not change.

0 Kudos
Message 2 of 8
(15,578 Views)

I would try closing the VISA reference and then opening it up again.  VISA likely need to establish a new TCP connection.


GCentral
There are only two ways to tell somebody thanks: Kudos and Marked Solutions
Unofficial Forum Rules and Guidelines
"Not that we are sufficient in ourselves to claim anything as coming from us, but our sufficiency is from God" - 2 Corinthians 3:5
0 Kudos
Message 3 of 8
(15,562 Views)
Solution
Accepted by topic author shda1
Yes, what you describe is expected behavior. When you turn off the power supply the connection is broken and has to be reestablished. How often do you need to.communicate with this device? It might be more efficient to open a connection, do what you need to do, and then close the connection.

Mike...

Certified Professional Instructor
Certified LabVIEW Architect
LabVIEW Champion

"... after all, He's not a tame lion..."

For help with grief and grieving.
Message 4 of 8
(15,550 Views)

@crossrulz wrote:

I would try closing the VISA reference and then opening it up again.  VISA likely need to establish a new TCP connection.


After VISA Find Resource I use VISA Open, then VISA Write, VISA Read and VISA Close. It gives nothing. New connection establish only after restart LabView.

Can I restart VISA programmatically without restart LabView?

 

PS I tried to work with the power supply via the TCP connection. Everything is good except for auto-detection.

0 Kudos
Message 5 of 8
(15,547 Views)

It really sounds like an error is happening, and that error is preventing the clean-up process, which would close that session, releasing that hardware, and allowing a new session to be made again.  Post your code and we can try to determine why the close operation isn't happening.  But I agree with mikeporter in this situation.  If the power the device might come and go at uncontrollable times, and the operations are small, it might be a better design to open a session, perform the action, and then close it.

Message 6 of 8
(15,482 Views)

Adding my experience for anyone encountering this problem. I wasn't able to close the visa session (gave me a different error). Clearing the buffer seemed to solve the problem though.

Message 7 of 8
(12,708 Views)

I would like to add my input as I just solved my issues on this topic. 

 

I have a weather station that uses Serial Modbus to communicate with LabVIEW, through a RS485 to USB converter. I previously tried to use a case structure to build a methodical reconnection process but it never worked. Just like in the post from Proven Zealot, the issue was that there was not a clean process to close the session and release the hardware. Therefore, it would throw errors during reconnection.

 

The solution that I chose was to open the Modbus connection, read the desired registers, and immediately close it. This works in my case because I do not do any data collection faster than a minute (I tested that it is fast enough at 15 seconds of elapsed time in idle). I also saw from another post that error handling for Modbus is a big role as well to ensure that the program does not get stuck. I disconnected the error wire from the shift register and just have the error message reading out to the front panel, staying inside the while loop of the data collection. The picture attached is a screenshot of the block diagram in case people are more visual.

 

I hope this helps if anyone else comes by! 

0 Kudos
Message 8 of 8
(3,625 Views)