Re: [PATCH 2/5] /dev/vring: simple userspace-kernel ringbuffer interface.

From: Rusty Russell
Date: Sat Apr 19 2008 - 12:06:59 EST


On Saturday 19 April 2008 20:22:15 Evgeniy Polyakov wrote:
> Hi.
>
> On Fri, Apr 18, 2008 at 02:39:48PM +1000, Rusty Russell
(rusty@xxxxxxxxxxxxxxx) wrote:
> > +int vring_get_buffer(struct vring_info *vr,
> > + struct iovec *in_iov,
> > + unsigned int *num_in, unsigned long *in_len,
> > + struct iovec *out_iov,
> > + unsigned int *num_out, unsigned long *out_len)
> > +{
> > + unsigned int i, in = 0, out = 0;
> > + unsigned long dummy;
> > + u16 avail, last_avail, head;
> > + struct vring_desc d;
>
> Should this whole function and vring_used_buffer() be protected with
> vr->lock mutex?

No; it's up to the caller to make sure that they are serialized. In the case
of tun that happens naturally.

There are two reasons not to grab the lock. It turns out that if we tried to
lock here, we'd deadlock, since the callbacks are called under the lock.
Secondly, it's possible to implement an atomic vring_used_buffer variant,
which could fail: this would avoid using the thread most of the time.

Hope that helps,
Rusty.
--
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/