Commit 964dfbe3 authored by K. Y. Srinivasan's avatar K. Y. Srinivasan Committed by Greg Kroah-Hartman

Drivers: hv: vmbus: On the read path cleanup the logic to interrupt the host

commit 3372592a upstream.

Signal the host when we determine the host is to be signaled -
on th read path. The currrent code determines the need to signal in the
ringbuffer code and actually issues the signal elsewhere. This can result
in the host viewing this interrupt as spurious since the host may also
poll the channel. Make the necessary adjustments.
Signed-off-by: default avatarK. Y. Srinivasan <kys@microsoft.com>
Cc: Rolf Neugebauer <rolf.neugebauer@docker.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent e2fdf784
...@@ -879,16 +879,9 @@ __vmbus_recvpacket(struct vmbus_channel *channel, void *buffer, ...@@ -879,16 +879,9 @@ __vmbus_recvpacket(struct vmbus_channel *channel, void *buffer,
u32 bufferlen, u32 *buffer_actual_len, u64 *requestid, u32 bufferlen, u32 *buffer_actual_len, u64 *requestid,
bool raw) bool raw)
{ {
int ret; return hv_ringbuffer_read(channel, buffer, bufferlen,
bool signal = false; buffer_actual_len, requestid, raw);
ret = hv_ringbuffer_read(&channel->inbound, buffer, bufferlen,
buffer_actual_len, requestid, &signal, raw);
if (signal)
vmbus_setevent(channel);
return ret;
} }
int vmbus_recvpacket(struct vmbus_channel *channel, void *buffer, int vmbus_recvpacket(struct vmbus_channel *channel, void *buffer,
......
...@@ -532,9 +532,9 @@ int hv_ringbuffer_write(struct vmbus_channel *channel, ...@@ -532,9 +532,9 @@ int hv_ringbuffer_write(struct vmbus_channel *channel,
u32 kv_count, bool lock, u32 kv_count, bool lock,
bool kick_q); bool kick_q);
int hv_ringbuffer_read(struct hv_ring_buffer_info *inring_info, int hv_ringbuffer_read(struct vmbus_channel *channel,
void *buffer, u32 buflen, u32 *buffer_actual_len, void *buffer, u32 buflen, u32 *buffer_actual_len,
u64 *requestid, bool *signal, bool raw); u64 *requestid, bool raw);
void hv_ringbuffer_get_debuginfo(struct hv_ring_buffer_info *ring_info, void hv_ringbuffer_get_debuginfo(struct hv_ring_buffer_info *ring_info,
struct hv_ring_buffer_debug_info *debug_info); struct hv_ring_buffer_debug_info *debug_info);
......
...@@ -353,9 +353,9 @@ int hv_ringbuffer_write(struct vmbus_channel *channel, ...@@ -353,9 +353,9 @@ int hv_ringbuffer_write(struct vmbus_channel *channel,
return 0; return 0;
} }
int hv_ringbuffer_read(struct hv_ring_buffer_info *inring_info, int hv_ringbuffer_read(struct vmbus_channel *channel,
void *buffer, u32 buflen, u32 *buffer_actual_len, void *buffer, u32 buflen, u32 *buffer_actual_len,
u64 *requestid, bool *signal, bool raw) u64 *requestid, bool raw)
{ {
u32 bytes_avail_toread; u32 bytes_avail_toread;
u32 next_read_location = 0; u32 next_read_location = 0;
...@@ -364,6 +364,7 @@ int hv_ringbuffer_read(struct hv_ring_buffer_info *inring_info, ...@@ -364,6 +364,7 @@ int hv_ringbuffer_read(struct hv_ring_buffer_info *inring_info,
u32 offset; u32 offset;
u32 packetlen; u32 packetlen;
int ret = 0; int ret = 0;
struct hv_ring_buffer_info *inring_info = &channel->inbound;
if (buflen <= 0) if (buflen <= 0)
return -EINVAL; return -EINVAL;
...@@ -421,7 +422,7 @@ int hv_ringbuffer_read(struct hv_ring_buffer_info *inring_info, ...@@ -421,7 +422,7 @@ int hv_ringbuffer_read(struct hv_ring_buffer_info *inring_info,
/* Update the read index */ /* Update the read index */
hv_set_next_read_location(inring_info, next_read_location); hv_set_next_read_location(inring_info, next_read_location);
*signal = hv_need_to_signal_on_read(inring_info); hv_signal_on_read(channel);
return ret; return ret;
} }
...@@ -1480,10 +1480,11 @@ hv_get_ring_buffer(struct hv_ring_buffer_info *ring_info) ...@@ -1480,10 +1480,11 @@ hv_get_ring_buffer(struct hv_ring_buffer_info *ring_info)
* there is room for the producer to send the pending packet. * there is room for the producer to send the pending packet.
*/ */
static inline bool hv_need_to_signal_on_read(struct hv_ring_buffer_info *rbi) static inline void hv_signal_on_read(struct vmbus_channel *channel)
{ {
u32 cur_write_sz; u32 cur_write_sz;
u32 pending_sz; u32 pending_sz;
struct hv_ring_buffer_info *rbi = &channel->inbound;
/* /*
* Issue a full memory barrier before making the signaling decision. * Issue a full memory barrier before making the signaling decision.
...@@ -1501,14 +1502,14 @@ static inline bool hv_need_to_signal_on_read(struct hv_ring_buffer_info *rbi) ...@@ -1501,14 +1502,14 @@ static inline bool hv_need_to_signal_on_read(struct hv_ring_buffer_info *rbi)
pending_sz = READ_ONCE(rbi->ring_buffer->pending_send_sz); pending_sz = READ_ONCE(rbi->ring_buffer->pending_send_sz);
/* If the other end is not blocked on write don't bother. */ /* If the other end is not blocked on write don't bother. */
if (pending_sz == 0) if (pending_sz == 0)
return false; return;
cur_write_sz = hv_get_bytes_to_write(rbi); cur_write_sz = hv_get_bytes_to_write(rbi);
if (cur_write_sz >= pending_sz) if (cur_write_sz >= pending_sz)
return true; vmbus_setevent(channel);
return false; return;
} }
/* /*
...@@ -1590,8 +1591,7 @@ static inline void commit_rd_index(struct vmbus_channel *channel) ...@@ -1590,8 +1591,7 @@ static inline void commit_rd_index(struct vmbus_channel *channel)
virt_rmb(); virt_rmb();
ring_info->ring_buffer->read_index = ring_info->priv_read_index; ring_info->ring_buffer->read_index = ring_info->priv_read_index;
if (hv_need_to_signal_on_read(ring_info)) hv_signal_on_read(channel);
vmbus_set_event(channel);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment