forked from Minki/linux
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: David Kershner <david.kershner@unisys.com> Reviewed-by: Tim Sell <timothy.sell@unisys.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
d02bde9d37
commit
04dbc09b25
@ -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)
|
|||||||
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;
|
||||||
|
Loading…
Reference in New Issue
Block a user