Flips tracking of IPC

Christian Helmuth ch12 at os.inf.tu-dresden.de
Mon May 2 17:09:35 CEST 2005


Hello,

On Fri, Apr 29, 2005 at 04:55:31PM +0100, Tiago Jorge wrote:
[...]
> is there any problem with FLIPS that prevents me from sending something 
> from a socket that is blocked in a recv in another thread (should't be 
> because TCP is bi-directional)?

Unfortunately you're right. We implemented FLIPS session-based and one
session can be used only for one blocking operation at a time. This comes
from the design of dde_linux and Linux, where client threads must be
represented as process threads (with task_struct and all) for native Linux
kernel code.

A thread (process) that is enqueued in a wait queue calls schedule().
schedule() is implemented in a way that the L4 thread representing the
Linux process blocks until woken up by a call to wake_up() or a similar
operation. For your socket this means: If the session thread is blocked,
then no further requests are processed on FLIPS side.

The L4VFS dietlibc backend may also be a spoiler here (not investigated
further) as it may not support multiple server threads for one and the
same file id.

Sorry for not helping you much, but I hope this clears things up.
-- 
Christian Helmuth
## Dept. of CS, TU Dresden,  Germany ##
## http://os.inf.tu-dresden.de/~ch12 ##




More information about the l4-hackers mailing list