<div class="gmail_quote">On Tue, Jun 22, 2010 at 10:44 PM, Eric Norum <span dir="ltr"><<a href="mailto:wenorum@lbl.gov">wenorum@lbl.gov</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<div style="word-wrap:break-word">Why not just use the message queues that RTEMS provides?<div>It seems like a lot of extra work to go through the network stack for this.</div><div><div><div></div><div class="h5"><br></div>
</div></div></div></blockquote><div>I am not working on C code directly. I am a student currently working</div><div>on the GSoC project of porting gccgo, the gcc frontend to Go into RTEMS.</div><div><br></div><div>The problem is with a network library component of Go. The code is in Go. This </div>
<div>part of the library provides functionality for handling nonblocking sockets efficiently. </div><div>They basically put all the nonblocking sockets into a set, and poll the set to see if </div><div>any one is ready. In linux, they used epoll, but since RTEMS doesn't have it, we </div>
<div>have to use select.</div><div><br></div><div>As part of this support we need to wakeup select when we have to add a new socket</div><div>into the set. So what they used is a pipe, and the read end of the pipe would go into</div>
<div>the set of fds, that epoll/select is polling on. So if we want to wakeup select, we can</div><div>just write something into the pipe. The problem here in RTEMS is, we can't use pipes,</div><div>because select can't wait on them. So we thought of using sockets, that is when the original</div>
<div>doubt of using the same socket for writing in multiple threads came up.</div><div><br></div><div>So I hope you are clear on the context in which this problem came up ?</div><div><br></div><div>So, if writing into the same socket from different threads is not a problem in waking up</div>
<div>select, then I can safely use that. I don't care about the data transferred using the socket.</div><div>Are there better solutions than this ? </div><div><br></div><div>I was asking about socketpairs() because, if it is possible, I can add that function,</div>
<div>into RTEMS, as part of my work.</div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;"><div style="word-wrap:break-word"><div><div><div class="h5"><div>
<div>On Jun 22, 2010, at 10:04 AM, Vinu Rajashekhar wrote:</div><br><blockquote type="cite"><div class="gmail_quote">On Tue, Jun 22, 2010 at 10:11 PM, Eric Norum <span dir="ltr"><<a href="mailto:wenorum@lbl.gov" target="_blank">wenorum@lbl.gov</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div style="word-wrap:break-word"><br><div><div><div>On Jun 22, 2010, at 9:21 AM, Vinu Rajashekhar wrote:</div><br><blockquote type="cite"><div class="gmail_quote">On Tue, Jun 22, 2010 at 9:48 PM, Eric Norum <span dir="ltr"><<a href="mailto:wenorum@lbl.gov" target="_blank">wenorum@lbl.gov</a>></span> wrote:<br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
You can read and write a socket from different threads.<br>
Just don't have multiple threads trying to read at the same time or trying to write at the same time.<br>
<div><div></div><div><br></div></div></blockquote><div><br></div><div>Yes, what if that happens, I don't care about the data being transferred.</div><div>I just want to wakeup select using the socket, then ?</div></div>

</blockquote><div><br></div></div>Are you doing a select waiting for read data to appear?</div><div>or are you doing a select waiting for space to become ready in a write queue?</div><div><br></div><div>Do you mean you do a write on one machine and want the 'select read' to wake up on the other machine?</div>

<div><br></div><div>It's not clear to me what you have in mind.</div><div><div><br></div></div></div></blockquote><div> </div><div>Ok. What I need to do is to wakeup a select call, that's all, on the same machine.</div>

<div><br></div><div>The original code, had a pipe whose read end would go into the set of fds in select.</div><div>But with RTEMS, since select can't wait on file descriptors, I can't use this. I can't</div><div>

use socketpairs in place of the pipe, by the way, since RTEMS doesn't support that.</div><div><br></div><div>So the solution is to use a plain sockets. I will write something into one socket, sw, </div><div>which should wakeup select, because it would be waiting on the socket at the other</div>

<div>end of the connection, socket sr. Basically replicating something like a pipe, but I don't</div><div>care about the data, just need to wakeup the select.</div><div><br></div><div>Now, this write into sw, can happen from more than one thread, at the same time.</div>

<div> that is a potential problem in RTEMS. So what is the solution for this problem ? </div><div>Is there a better solution to my problem ?</div><div><br></div><div>As an aside, is implementing socketpairs() in RTEMS very difficult at this point in time ?</div>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><div><div></div><div><blockquote type="cite"><div class="gmail_quote"><div>
 </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div>
On Jun 22, 2010, at 9:03 AM, Vinu Rajashekhar wrote:<br>
<br>
> From the networking documentation, it seems that one cannot<br>
> share the same socket across threads/tasks for the same operation, like<br>
> read or write.<br>
><br>
> What is the exact problem if I use the same socket to write something<br>
> across different threads, is data corruption the only problem? More specifically,<br>
> if I have run a select call on a socket, and if I write something into the socket,<br>
> from different threads, does the select wakeup for sure ?<br>
</div></div><div><div></div><div>> _______________________________________________<br>
> rtems-users mailing list<br>
> <a href="mailto:rtems-users@rtems.org" target="_blank">rtems-users@rtems.org</a><br>
> <a href="http://www.rtems.org/mailman/listinfo/rtems-users" target="_blank">http://www.rtems.org/mailman/listinfo/rtems-users</a><br>
<br>
--<br>
Eric Norum<br>
<a href="mailto:wenorum@lbl.gov" target="_blank">wenorum@lbl.gov</a><br>
<br>
</div></div></blockquote></div><br>
</blockquote></div><br></div><div>
<span style="border-collapse:separate;color:rgb(0, 0, 0);font-family:Helvetica;font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:auto;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px"><div>

-- <div><br>Eric Norum<br><a href="mailto:wenorum@lbl.gov" target="_blank">wenorum@lbl.gov</a></div></div></span>
</div>
<br></div></blockquote></div><br>
</blockquote></div><br></div></div><div>
<span style="border-collapse:separate;color:rgb(0, 0, 0);font-family:Helvetica;font-size:medium;font-style:normal;font-variant:normal;font-weight:normal;letter-spacing:normal;line-height:normal;text-align:auto;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px"><div>
-- <div class="im"><br>Eric Norum<br><a href="mailto:wenorum@lbl.gov" target="_blank">wenorum@lbl.gov</a></div></div></span>
</div>
<br></div></div></blockquote></div><br>