On Thu, Apr 01, 2010 at 11:22:37AM -0700, David Stevens wrote: > kvm-owner@xxxxxxxxxxxxxxx wrote on 04/01/2010 03:54:15 AM: > > > On Wed, Mar 31, 2010 at 03:04:43PM -0700, David Stevens wrote: > > > > > > > > > + head.iov_base = (void > *)vhost_get_vq_desc(&net->dev, > > > vq, > > > > > + vq->iov, ARRAY_SIZE(vq->iov), &out, &in, > NULL, > > > > > > > > NULL); > > > > > > > > I this casting confusing. > > > > Is it really expensive to add an array of heads so that > > > > we do not need to cast? > > > > > > It needs the heads and the lengths, which looks a lot > > > like an iovec. I was trying to resist adding a new > > > struct XXX { unsigned head; unsigned len; } just for this, > > > but I could make these parallel arrays, one with head index and > > > the other with length. > > Michael, on this one, if I add vq->heads as an argument to > vhost_get_heads (aka vhost_get_desc_n), I'd need the length too. > Would you rather this 1) remain an iovec (and a single arg added) but > cast still there, 2) 2 arrays (head and length) and 2 args added, or > 3) a new struct type of {unsigned,int} to carry for the heads+len > instead of iovec? > My preference would be 1). I agree the casts are ugly, but > it is essentially an iovec the way we use it; it's just that the > base isn't a pointer but a descriptor index instead. I prefer 2 or 3. If you prefer 1 strongly, I think we should add a detailed comment near the iovec, and a couple of inline wrappers to store/get data in the iovec. > > > > > > EAGAIN is not possible after the change, because we don't > > > even enter the loop unless we have an skb on the read queue; the > > > other cases bomb out, so I figured the comment for future work is > > > now done. :-) > > > > Guest could be buggy so we'll get EFAULT. > > If skb is taken off the rx queue (as below), we might get EAGAIN. > > We break on any error. If we get EAGAIN because someone read > on the socket, this code would break the loop, but EAGAIN is a more > serious problem if it changed since we peeked (because it means > someone else is reading the socket). > But I don't understand -- are you suggesting that the error > handling be different than that, or that the comment is still > relevant? > My intention here is to do the "TODO" from the comment > so that it can be removed, by handling all error cases. I think > because of the peek, EAGAIN isn't something to be ignored anymore, > but the effect is the same whether we break out of the loop or > not, since we retry the packet next time around. Essentially, we > ignore every error since we will redo it with the same packet the > next time around. Maybe we should print something here, but since > we'll be retrying the packet that's still on the socket, a permanent > error would spew continuously. Maybe we should shut down entirely > if we get any negative return value here (including EAGAIN, since > that tells us someone messed with the socket when we don't want them > to). > If you want the comment still there, ok, but I do think EAGAIN > isn't a special case per the comment anymore, and is handled as all > other errors are: by exiting the loop and retrying next time. > > +-DLS Yes, I just think some comment should stay, as you say, because otherwise we simply retry continuously. Maybe we should trigger vq_err. It needs to be given some thought which I have not given it yet. Thinking aloud, EAGAIN means someone reads the socket together with us, I prefer that this condition is made a fatal error, we should make sure we are polling the socket so we see packets if more appear. -- MST _______________________________________________ Virtualization mailing list Virtualization@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/virtualization