virtualization.lists.linux-foundation.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 0/1] virtio: console: regression in virtqueue_add_buf() change
@ 2012-12-07  6:04 Amit Shah
  2012-12-07  6:04 ` [PATCH 1/1] virtio: console: virtqueue_add_buf() no longer returns > 0 Amit Shah
  2012-12-09 23:36 ` [PATCH 0/1] virtio: console: regression in virtqueue_add_buf() change Rusty Russell
  0 siblings, 2 replies; 3+ messages in thread
From: Amit Shah @ 2012-12-07  6:04 UTC (permalink / raw)
  To: Rusty Russell; +Cc: Amit Shah, Virtualization List

Hi Rusty,

The linux-next kernel was failing my virtio-console test suite for a
while.  I looked into it today, and it's due to the
virtqueue_add_buf() change that doesn't return > 0 values anymore.  I
found your commit that adjusts virtio_console.c, but you missed one
instance where the return value mattered, and as a result not enough
buffers were queued for the host to send in data.

This resulted in the port's name to be not populated in sysfs, which
meant udev didn't create any symlinks in /dev/virtio-ports/.

I've just updated your commit with the small diff (attached below).
Please put this commit after 

commit e794093a52cdfef09b3fdb6294b75ab8cacb30a8
Author: Rusty Russell <rusty@rustcorp.com.au>
Date:   Tue Oct 16 23:56:14 2012 +1030

    virtio_net: don't rely on virtqueue_add_buf() returning capacity.
    
and before

commit 08d088e8357b3c031db7de006247f613c7f136ab
Author: Rusty Russell <rusty@rustcorp.com.au>
Date:   Tue Oct 16 23:56:15 2012 +1030

    virtio: make virtqueue_add_buf() returning 0 on success, not capacity.
    
in the pull request you send so that there's no regression in
virtio_console on bisection.

(commit ids from linux-next/master).

I didn't see your linux-next commit

commit 80162488188c239733433cff98ece5cde18b8b3b
Author: Rusty Russell <rusty@rustcorp.com.au>
Date:   Tue Oct 16 23:56:15 2012 +1030

    virtio: console: make it clear that virtqueue_add_buf() no longer returns > 0

on a mailing list (please CC me!), and I missed reviewing the virtio
changes, but glad that the testsuite caught this :)

Diff relative to your patch:

diff --git a/drivers/char/virtio_console.c b/drivers/char/virtio_console.c
index 82ebe02..6a36994 100644
--- a/drivers/char/virtio_console.c
+++ b/drivers/char/virtio_console.c
@@ -396,6 +396,8 @@ static int add_inbuf(struct virtqueue *vq, struct port_buffer *buf)
 
 	ret = virtqueue_add_buf(vq, sg, 0, 1, buf, GFP_ATOMIC);
 	virtqueue_kick(vq);
+	if (!ret)
+		ret = vq->num_free;
 	return ret;
 }
 

Please apply.


Rusty Russell (1):
  virtio: console: virtqueue_add_buf() no longer returns > 0

 drivers/char/virtio_console.c | 12 +++++++-----
 1 file changed, 7 insertions(+), 5 deletions(-)

-- 
1.8.0.1

^ permalink raw reply related	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2012-12-09 23:36 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-12-07  6:04 [PATCH 0/1] virtio: console: regression in virtqueue_add_buf() change Amit Shah
2012-12-07  6:04 ` [PATCH 1/1] virtio: console: virtqueue_add_buf() no longer returns > 0 Amit Shah
2012-12-09 23:36 ` [PATCH 0/1] virtio: console: regression in virtqueue_add_buf() change Rusty Russell

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).