Re: [PATCH] fix race in AF_UNIX
From: Miklos Szeredi
Date: Tue Jun 26 2007 - 04:55:11 EST
> > Right. But the devil is in the details, and (as you correctly point
> > out later) to implement this, the whole locking scheme needs to be
> > overhauled. Problems:
> >
> > - Using the queue lock to make the dequeue and the fd detach atomic
> > wrt the GC is difficult, if not impossible: they are are far from
> > each other with various magic in between. It would need thorough
> > understanding of these functions and _big_ changes to implement.
> >
> > - Sleeping on u->readlock in GC is currently not possible, since that
> > could deadlock with unix_dgram_recvmsg(). That function could
> > probably be modified to release u->readlock, while waiting for
> > data, similarly to unix_stream_recvmsg() at the cost of some added
> > complexity.
> >
> > - Sleeping on u->readlock is also impossible, because GC is holding
> > unix_table_lock for the whole operation. We could release
> > unix_table_lock, but then would have to cope with sockets coming
> > and going, making the current socket iterator unworkable.
> >
> > So theoretically it's quite simple, but it needs big changes. And
> > this wouldn't even solve all the problems with the GC, like being a
> > possible DoS vector.
>
> Making the GC fully incremental will solve the DoS vector problem as
> well. Basically you do a fixed amount of reclaim in the new socket
> allocation code.
And I think incremental GC algorithms are much too complex for this
task. What I've realized, is that in fact we don't require a generic
garbage collection algorithm, just a much more specialized cycle
collection algorithm, since refcounting in struct file takes care of
the rest.
This would help with localizing the problem to the problematic sockets
(which have an in-flight unix socket), instead of having to blindly
traverse _all_ unix sockets in the system.
I'll look at reimplementing the GC with such an algorithm.
> It appears clear that since we can't stop the world and garbage
> collect we need an incremental collector.
Constraining ourselves to stopping unix sockets from going in flight
or coming out of flight during garbage collection should be OK I
think. There's still a possibility of a DoS there, but it would only
be able to affect _very_ few applications.
Miklos
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/