12-18-2013 09:55 AM
Hi all,
I'm looking for help on how to handle acquiring a semaphore while maintaining the position in the queue to maintain FIFO of a multi unit test setup that shares resources.
What I'm doing now is using a long timeout, which I can't get out of if I would like to abort the test.
I would use a short timeout and put it in a loop, but I don't want the UUT to lose it's place in line.
Any ideas?
12-18-2013 10:07 AM
use -1 timeout and just destroy the semaphore on abort.
12-18-2013 10:10 AM
"use -1 timeout and just destroy the semaphore on abort."
But that would squash the semaphore for the other UUT waiting for the resource to free up.
12-18-2013 11:09 AM
Yes, it would.
So, you are going to need to poll a semaphore. Something tells me there is a better way to do this since there really is no means to signal a "Stop waiting" on semaphore BUT, you could write your own using a notifier or user event to cancel wait on semaphore.
12-18-2013 11:46 AM
Hmm. Interesting question.
I posted an idea about having occurrences linked to the timeout functionality of such functions allowing for aborting the waits.
Go HERE and vote for it if you want a solution to your problem.
This idea would allow you to have a seperate parallel loop terminate the wait by setting an occurrence. Leaving the wait running until you actually need to stop it would prevent your primitive "losing its palce in the queue".
Shane.
12-18-2013 11:59 AM
@JÞB wrote:
Yes, it would.
So, you are going to need to poll a semaphore. Something tells me there is a better way to do this since there really is no means to signal a "Stop waiting" on semaphore BUT, you could write your own using a notifier or user event to cancel wait on semaphore.
I was hoping to avoid polling the semaphore because it would violate my FIFO process, and could possibly extend test time on a UUT if it keeps getting bumped to the end of the line.
I appreciate you putting that together.
12-18-2013 12:00 PM
@Intaris wrote:
Hmm. Interesting question.
I posted an idea about having occurrences linked to the timeout functionality of such functions allowing for aborting the waits.
Go HERE and vote for it if you want a solution to your problem.
This idea would allow you to have a seperate parallel loop terminate the wait by setting an occurrence. Leaving the wait running until you actually need to stop it would prevent your primitive "losing its palce in the queue".
Shane.
It's got my vote. Seems like that would work for this situation. Thanks for putting forth that idea.