提交 d0acf734 编写于 作者: C Corey Minyard

ipmi_ssif: Use interruptible completion for waiting in the thread

The code was using an normal completion, but that caused stuck
task errors after a while.  Use an interruptible one to avoid that.
Signed-off-by: NCorey Minyard <cminyard@mvista.com>
上级 ad1ed2a9
...@@ -468,11 +468,13 @@ static int ipmi_ssif_thread(void *data) ...@@ -468,11 +468,13 @@ static int ipmi_ssif_thread(void *data)
int result; int result;
/* Wait for something to do */ /* Wait for something to do */
wait_for_completion(&ssif_info->wake_thread); result = wait_for_completion_interruptible(
init_completion(&ssif_info->wake_thread); &ssif_info->wake_thread);
if (ssif_info->stopping) if (ssif_info->stopping)
break; break;
if (result == -ERESTARTSYS)
continue;
init_completion(&ssif_info->wake_thread);
if (ssif_info->i2c_read_write == I2C_SMBUS_WRITE) { if (ssif_info->i2c_read_write == I2C_SMBUS_WRITE) {
result = i2c_smbus_write_block_data( result = i2c_smbus_write_block_data(
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册