diff options
author | David S. Miller <davem@davemloft.net> | 2010-05-17 01:26:58 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-05-17 01:26:58 -0400 |
commit | 6811d58fc148c393f80a9f5a9db49d7e75cdc546 (patch) | |
tree | c25d5b0e49ec848943d35f819e748d157ccb492e /drivers/vhost | |
parent | c4949f074332a64baeb2ead6ab9319ca37642f96 (diff) | |
parent | c02db8c6290bb992442fec1407643c94cc414375 (diff) |
Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
Conflicts:
include/linux/if_link.h
Diffstat (limited to 'drivers/vhost')
-rw-r--r-- | drivers/vhost/vhost.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c index 5c9c657ab753..750effe0f98b 100644 --- a/drivers/vhost/vhost.c +++ b/drivers/vhost/vhost.c | |||
@@ -1036,7 +1036,12 @@ int vhost_add_used(struct vhost_virtqueue *vq, unsigned int head, int len) | |||
1036 | /* This actually signals the guest, using eventfd. */ | 1036 | /* This actually signals the guest, using eventfd. */ |
1037 | void vhost_signal(struct vhost_dev *dev, struct vhost_virtqueue *vq) | 1037 | void vhost_signal(struct vhost_dev *dev, struct vhost_virtqueue *vq) |
1038 | { | 1038 | { |
1039 | __u16 flags = 0; | 1039 | __u16 flags; |
1040 | /* Flush out used index updates. This is paired | ||
1041 | * with the barrier that the Guest executes when enabling | ||
1042 | * interrupts. */ | ||
1043 | smp_mb(); | ||
1044 | |||
1040 | if (get_user(flags, &vq->avail->flags)) { | 1045 | if (get_user(flags, &vq->avail->flags)) { |
1041 | vq_err(vq, "Failed to get flags"); | 1046 | vq_err(vq, "Failed to get flags"); |
1042 | return; | 1047 | return; |