diff options
| author | Corey Minyard <cminyard@mvista.com> | 2015-04-04 02:54:26 -0400 |
|---|---|---|
| committer | Corey Minyard <cminyard@mvista.com> | 2015-04-10 21:51:42 -0400 |
| commit | d0acf734d886ce50bb5103cc75f7ca39f280e8a7 (patch) | |
| tree | c6e1b760a7456e4eb3cf6712e390535fc383c111 /drivers/char/ipmi | |
| parent | ad1ed2a9dd4c435d6a3ce470211db9a8d107c3e0 (diff) | |
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: Corey Minyard <cminyard@mvista.com>
Diffstat (limited to 'drivers/char/ipmi')
| -rw-r--r-- | drivers/char/ipmi/ipmi_ssif.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/drivers/char/ipmi/ipmi_ssif.c b/drivers/char/ipmi/ipmi_ssif.c index f6e378dac5f5..f40e3bd2c69c 100644 --- a/drivers/char/ipmi/ipmi_ssif.c +++ b/drivers/char/ipmi/ipmi_ssif.c | |||
| @@ -468,11 +468,13 @@ static int ipmi_ssif_thread(void *data) | |||
| 468 | int result; | 468 | int result; |
| 469 | 469 | ||
| 470 | /* Wait for something to do */ | 470 | /* Wait for something to do */ |
| 471 | wait_for_completion(&ssif_info->wake_thread); | 471 | result = wait_for_completion_interruptible( |
| 472 | init_completion(&ssif_info->wake_thread); | 472 | &ssif_info->wake_thread); |
| 473 | |||
| 474 | if (ssif_info->stopping) | 473 | if (ssif_info->stopping) |
| 475 | break; | 474 | break; |
| 475 | if (result == -ERESTARTSYS) | ||
| 476 | continue; | ||
| 477 | init_completion(&ssif_info->wake_thread); | ||
| 476 | 478 | ||
| 477 | if (ssif_info->i2c_read_write == I2C_SMBUS_WRITE) { | 479 | if (ssif_info->i2c_read_write == I2C_SMBUS_WRITE) { |
| 478 | result = i2c_smbus_write_block_data( | 480 | result = i2c_smbus_write_block_data( |
