diff options
author | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2010-10-12 10:27:56 +0100 |
---|---|---|
committer | Samuel Thibault <samuel.thibault@ens-lyon.org> | 2010-10-12 10:27:56 +0100 |
commit | 0ad4600ac796b16551ff58ffe68ad83a30cb6da7 (patch) | |
tree | 7213eb2f76ec89bf4800ac1029f59255e457d4ba /extras | |
parent | f5f0af18aa1746841ee0d76fa1057c7c6e68e09d (diff) | |
download | xen-0ad4600ac796b16551ff58ffe68ad83a30cb6da7.tar.gz xen-0ad4600ac796b16551ff58ffe68ad83a30cb6da7.tar.bz2 xen-0ad4600ac796b16551ff58ffe68ad83a30cb6da7.zip |
MiniOS: Fix continue; in netfront receive loop
To properly ignore some requests through the use of continue;, indexes need to
be updated.
Signed-off-by: Samuel Thibault <samuel.thibault@ens-lyon.org>
Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
committer: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Diffstat (limited to 'extras')
-rw-r--r-- | extras/mini-os/netfront.c | 10 |
1 files changed, 3 insertions, 7 deletions
diff --git a/extras/mini-os/netfront.c b/extras/mini-os/netfront.c index 5674c4ae0f..ade329ee45 100644 --- a/extras/mini-os/netfront.c +++ b/extras/mini-os/netfront.c @@ -105,9 +105,9 @@ moretodo: rmb(); /* Ensure we see queued responses up to 'rp'. */ cons = dev->rx.rsp_cons; - nr_consumed = 0; - some = 0; - while ((cons != rp) && !some) + for (nr_consumed = 0, some = 0; + (cons != rp) && !some; + nr_consumed++, cons++) { struct net_buffer* buf; unsigned char* page; @@ -146,10 +146,6 @@ moretodo: #endif dev->netif_rx(page+rx->offset,rx->status); } - - nr_consumed++; - - ++cons; } dev->rx.rsp_cons=cons; |