diff options
author | Rusty Russell <rusty@rustcorp.com.au> | 2009-06-13 00:27:04 -0400 |
---|---|---|
committer | Rusty Russell <rusty@rustcorp.com.au> | 2009-06-12 08:57:05 -0400 |
commit | e606490c440900e50ccf73a54f6fc6150ff40815 (patch) | |
tree | 43a660399ee81b3926789bd1644513e83c605d50 /Documentation/lguest/lguest.c | |
parent | f086122bb6e885f926f935b1418fca3b293375f0 (diff) |
lguest: clean up length-used value in example launcher
The "len" field in the used ring for virtio indicates the number of
bytes *written* to the buffer. This means the guest doesn't have to
zero the buffers in advance as it always knows the used length.
Erroneously, the console and network example code puts the length
*read* into that field. The guest ignores it, but it's wrong.
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Diffstat (limited to 'Documentation/lguest/lguest.c')
-rw-r--r-- | Documentation/lguest/lguest.c | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/Documentation/lguest/lguest.c b/Documentation/lguest/lguest.c index 9f3240c45718..8704600c5e42 100644 --- a/Documentation/lguest/lguest.c +++ b/Documentation/lguest/lguest.c | |||
@@ -830,15 +830,14 @@ static bool handle_console_input(struct device *dev) | |||
830 | static void handle_console_output(struct virtqueue *vq, bool timeout) | 830 | static void handle_console_output(struct virtqueue *vq, bool timeout) |
831 | { | 831 | { |
832 | unsigned int head, out, in; | 832 | unsigned int head, out, in; |
833 | int len; | ||
834 | struct iovec iov[vq->vring.num]; | 833 | struct iovec iov[vq->vring.num]; |
835 | 834 | ||
836 | /* Keep getting output buffers from the Guest until we run out. */ | 835 | /* Keep getting output buffers from the Guest until we run out. */ |
837 | while ((head = get_vq_desc(vq, iov, &out, &in)) != vq->vring.num) { | 836 | while ((head = get_vq_desc(vq, iov, &out, &in)) != vq->vring.num) { |
838 | if (in) | 837 | if (in) |
839 | errx(1, "Input buffers in output queue?"); | 838 | errx(1, "Input buffers in output queue?"); |
840 | len = writev(STDOUT_FILENO, iov, out); | 839 | writev(STDOUT_FILENO, iov, out); |
841 | add_used_and_trigger(vq, head, len); | 840 | add_used_and_trigger(vq, head, 0); |
842 | } | 841 | } |
843 | } | 842 | } |
844 | 843 | ||
@@ -870,7 +869,6 @@ static void block_vq(struct virtqueue *vq) | |||
870 | static void handle_net_output(struct virtqueue *vq, bool timeout) | 869 | static void handle_net_output(struct virtqueue *vq, bool timeout) |
871 | { | 870 | { |
872 | unsigned int head, out, in, num = 0; | 871 | unsigned int head, out, in, num = 0; |
873 | int len; | ||
874 | struct iovec iov[vq->vring.num]; | 872 | struct iovec iov[vq->vring.num]; |
875 | static int last_timeout_num; | 873 | static int last_timeout_num; |
876 | 874 | ||
@@ -878,10 +876,9 @@ static void handle_net_output(struct virtqueue *vq, bool timeout) | |||
878 | while ((head = get_vq_desc(vq, iov, &out, &in)) != vq->vring.num) { | 876 | while ((head = get_vq_desc(vq, iov, &out, &in)) != vq->vring.num) { |
879 | if (in) | 877 | if (in) |
880 | errx(1, "Input buffers in output queue?"); | 878 | errx(1, "Input buffers in output queue?"); |
881 | len = writev(vq->dev->fd, iov, out); | 879 | if (writev(vq->dev->fd, iov, out) < 0) |
882 | if (len < 0) | ||
883 | err(1, "Writing network packet to tun"); | 880 | err(1, "Writing network packet to tun"); |
884 | add_used_and_trigger(vq, head, len); | 881 | add_used_and_trigger(vq, head, 0); |
885 | num++; | 882 | num++; |
886 | } | 883 | } |
887 | 884 | ||