[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <200804200205.31508.rusty@rustcorp.com.au>
Date: Sun, 20 Apr 2008 02:05:31 +1000
From: Rusty Russell <rusty@...tcorp.com.au>
To: Evgeniy Polyakov <johnpol@....mipt.ru>
Cc: netdev@...r.kernel.org, Max Krasnyansky <maxk@...lcomm.com>,
virtualization@...ts.linux-foundation.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH 2/5] /dev/vring: simple userspace-kernel ringbuffer interface.
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@...tcorp.com.au) 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 netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists