staging: most: cdev: fix race condition
This patch fixes a race condition between the functions disconnect and poll. Signed-off-by: Christian Gromm <christian.gromm@microchip.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
021fa2dbc4
commit
993c1637a0
|
@ -292,13 +292,15 @@ static __poll_t comp_poll(struct file *filp, poll_table *wait)
|
||||||
|
|
||||||
poll_wait(filp, &c->wq, wait);
|
poll_wait(filp, &c->wq, wait);
|
||||||
|
|
||||||
|
mutex_lock(&c->io_mutex);
|
||||||
if (c->cfg->direction == MOST_CH_RX) {
|
if (c->cfg->direction == MOST_CH_RX) {
|
||||||
if (!kfifo_is_empty(&c->fifo))
|
if (!c->dev || !kfifo_is_empty(&c->fifo))
|
||||||
mask |= EPOLLIN | EPOLLRDNORM;
|
mask |= EPOLLIN | EPOLLRDNORM;
|
||||||
} else {
|
} else {
|
||||||
if (!kfifo_is_empty(&c->fifo) || ch_has_mbo(c))
|
if (!c->dev || !kfifo_is_empty(&c->fifo) || ch_has_mbo(c))
|
||||||
mask |= EPOLLOUT | EPOLLWRNORM;
|
mask |= EPOLLOUT | EPOLLWRNORM;
|
||||||
}
|
}
|
||||||
|
mutex_unlock(&c->io_mutex);
|
||||||
return mask;
|
return mask;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue