9fans - fans of the OS Plan 9 from Bell Labs
 help / color / mirror / Atom feed
* [9fans] locking
@ 2007-04-18 12:24 Steve Simon
  2007-04-18 16:35 ` Russ Cox
  0 siblings, 1 reply; 3+ messages in thread
From: Steve Simon @ 2007-04-18 12:24 UTC (permalink / raw)
  To: 9fans

Hi,

I have a problem on an OS, its not plan9 but similar,
so I thought I would ask here.

Say you have a synthetic file which you use to query
the state of a subsystem, a plan9 example might /net/dns,
my example is reading a port in an fpga.

I want to run this multithreaded, but the requests
and replies are not atomic on the same file descriptor.
Thus I need to have each thread request on its own file
descriptor, or, have a Qlock in the requesting program
to interlock requests and replies.

Now the fun.

Some requests can take a long time (hours) so the Qlock
is inpractiable, though adding a open per thread is also
a pain.

When I get problems like this I usually think "how would I
do this on plan9", and the only answer I can come up with is
to have a single ioproc doing the device access and a load of
threads in another proc making requests.

Anyone think of a technique I have missed?

-Steve


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2007-04-18 23:10 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2007-04-18 12:24 [9fans] locking Steve Simon
2007-04-18 16:35 ` Russ Cox
2007-04-18 23:10   ` Steve Simon

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).