mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-15 01:24:33 +00:00
cris: sync_serial: remove interruptible_sleep_on
sleep_on and its variants are racy and going away. This replaces the two uses in the cris sync_serial drivers with the equivalent but race-free wait_event_interruptible. Signed-off-by: Arnd Bergmann <arnd@arndb.de> Cc: Mikael Starvik <starvik@axis.com> Cc: linux-cris-kernel@axis.com Signed-off-by: Jesper Nilsson <jespern@axis.com>
This commit is contained in:
parent
64d8ad933d
commit
329fddd7b6
@ -22,6 +22,7 @@
|
||||
#include <linux/init.h>
|
||||
#include <linux/mutex.h>
|
||||
#include <linux/timer.h>
|
||||
#include <linux/wait.h>
|
||||
#include <asm/irq.h>
|
||||
#include <asm/dma.h>
|
||||
#include <asm/io.h>
|
||||
@ -1136,7 +1137,8 @@ static ssize_t sync_serial_read(struct file *file, char *buf,
|
||||
if (file->f_flags & O_NONBLOCK)
|
||||
return -EAGAIN;
|
||||
|
||||
interruptible_sleep_on(&port->in_wait_q);
|
||||
wait_event_interruptible(port->in_wait_q,
|
||||
!(start == end && !port->full));
|
||||
if (signal_pending(current))
|
||||
return -EINTR;
|
||||
|
||||
|
@ -19,6 +19,7 @@
|
||||
#include <linux/init.h>
|
||||
#include <linux/timer.h>
|
||||
#include <linux/spinlock.h>
|
||||
#include <linux/wait.h>
|
||||
|
||||
#include <asm/io.h>
|
||||
#include <dma.h>
|
||||
@ -1144,7 +1145,8 @@ static ssize_t sync_serial_read(struct file * file, char * buf,
|
||||
if (file->f_flags & O_NONBLOCK)
|
||||
return -EAGAIN;
|
||||
|
||||
interruptible_sleep_on(&port->in_wait_q);
|
||||
wait_event_interruptible(port->in_wait_q,
|
||||
!(start == end && !port->full));
|
||||
if (signal_pending(current))
|
||||
return -EINTR;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user