[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1464948891-5532-1-git-send-email-vkuznets@redhat.com>
Date: Fri, 3 Jun 2016 12:14:51 +0200
From: Vitaly Kuznetsov <vkuznets@...hat.com>
To: devel@...uxdriverproject.org
Cc: linux-kernel@...r.kernel.org,
"K. Y. Srinivasan" <kys@...rosoft.com>,
Haiyang Zhang <haiyangz@...rosoft.com>
Subject: [PATCH] Drivers: hv: fix infinite wait when channel open timeouts
vmbus_teardown_gpadl() can result in infinite wait when it is called
on 5 second timeout in vmbus_open(). The issue is caused by the fact
that gpadl teardown operation won't ever succeed for an opened channel
and the timeout isn't always enough. Increase the timeout to 15 seconds
and add sending CHANNELMSG_CLOSECHANNEL message on timeout to make sure
the channel is closed.
The other possible solution for the issue would be to remove the timeout
in vmbus_open() making our wait infinite.
Signed-off-by: Vitaly Kuznetsov <vkuznets@...hat.com>
---
drivers/hv/channel.c | 14 +++++++++++++-
1 file changed, 13 insertions(+), 1 deletion(-)
diff --git a/drivers/hv/channel.c b/drivers/hv/channel.c
index 6a8660d..becb9e8 100644
--- a/drivers/hv/channel.c
+++ b/drivers/hv/channel.c
@@ -69,6 +69,7 @@ int vmbus_open(struct vmbus_channel *newchannel, u32 send_ringbuffer_size,
void (*onchannelcallback)(void *context), void *context)
{
struct vmbus_channel_open_channel *open_msg;
+ struct vmbus_channel_close_channel *close_msg;
struct vmbus_channel_msginfo *open_info = NULL;
void *in, *out;
unsigned long flags;
@@ -183,8 +184,19 @@ int vmbus_open(struct vmbus_channel *newchannel, u32 send_ringbuffer_size,
goto error1;
}
- t = wait_for_completion_timeout(&open_info->waitevent, 5*HZ);
+ t = wait_for_completion_timeout(&open_info->waitevent, 15*HZ);
if (t == 0) {
+ /*
+ * We won't be able to tear down the gpadl handle if the
+ * channel finally gets openned, send channel close message
+ * to be on the safe side.
+ */
+ close_msg = &newchannel->close_msg.msg;
+ close_msg->header.msgtype = CHANNELMSG_CLOSECHANNEL;
+ close_msg->child_relid = newchannel->offermsg.child_relid;
+ vmbus_post_msg(close_msg,
+ sizeof(struct vmbus_channel_close_channel));
+
err = -ETIMEDOUT;
goto error1;
}
--
2.5.5
Powered by blists - more mailing lists