summaryrefslogtreecommitdiffstats
path: root/drivers/hv/ring_buffer.c
diff options
context:
space:
mode:
authorJason Wang2013-06-20 06:58:57 +0200
committerGreg Kroah-Hartman2013-06-25 01:24:17 +0200
commite91e84fa4cfeb67a9a096f1adaa1a1a692474724 (patch)
tree7e36ab11890da81a89817e2b24e85cc11b480b83 /drivers/hv/ring_buffer.c
parentvme: vme_tsi148.c: fix error return code in tsi148_probe() (diff)
downloadkernel-qcow2-linux-e91e84fa4cfeb67a9a096f1adaa1a1a692474724.tar.gz
kernel-qcow2-linux-e91e84fa4cfeb67a9a096f1adaa1a1a692474724.tar.xz
kernel-qcow2-linux-e91e84fa4cfeb67a9a096f1adaa1a1a692474724.zip
drivers: hv: check interrupt mask before read_index
This patches add a read barriers to force the driver to check the interrupt mask before read_index. Otherwise we may lost a kick to host. Cc: K. Y. Srinivasan <kys@microsoft.com> Cc: Haiyang Zhang <haiyangz@microsoft.com> Signed-off-by: Jason Wang <jasowang@redhat.com> Signed-off-by: K. Y. Srinivasan <kys@microsoft.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/hv/ring_buffer.c')
-rw-r--r--drivers/hv/ring_buffer.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/hv/ring_buffer.c b/drivers/hv/ring_buffer.c
index 791f45dfc85d..26c93cf9f6be 100644
--- a/drivers/hv/ring_buffer.c
+++ b/drivers/hv/ring_buffer.c
@@ -75,6 +75,8 @@ static bool hv_need_to_signal(u32 old_write, struct hv_ring_buffer_info *rbi)
if (rbi->ring_buffer->interrupt_mask)
return false;
+ /* check interrupt_mask before read_index */
+ rmb();
/*
* This is the only case we need to signal when the
* ring transitions from being empty to non-empty.