Commit 04dbc09b authored by David Kershner's avatar David Kershner Committed by Greg Kroah-Hartman

staging: unisys: visorbus: add timeout to controlvm_periodic_work

Limit the amount that gets pulled from the queue on each try so we don't
get stuck in an infinite loop if something has gone wrong with the s-Par
firmware.
Signed-off-by: default avatarDavid Kershner <david.kershner@unisys.com>
Reviewed-by: default avatarTim Sell <timothy.sell@unisys.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent d02bde9d
...@@ -1785,6 +1785,7 @@ static void ...@@ -1785,6 +1785,7 @@ static void
controlvm_periodic_work(struct work_struct *work) controlvm_periodic_work(struct work_struct *work)
{ {
struct controlvm_message inmsg; struct controlvm_message inmsg;
int count = 0;
int err; int err;
/* Drain the RESPONSE queue make it empty */ /* Drain the RESPONSE queue make it empty */
...@@ -1792,7 +1793,7 @@ controlvm_periodic_work(struct work_struct *work) ...@@ -1792,7 +1793,7 @@ controlvm_periodic_work(struct work_struct *work)
err = visorchannel_signalremove(chipset_dev->controlvm_channel, err = visorchannel_signalremove(chipset_dev->controlvm_channel,
CONTROLVM_QUEUE_RESPONSE, CONTROLVM_QUEUE_RESPONSE,
&inmsg); &inmsg);
} while (!err); } while ((!err) && (++count < CONTROLVM_MESSAGE_MAX));
if (err != -EAGAIN) if (err != -EAGAIN)
goto schedule_out; goto schedule_out;
......
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