diff options
Diffstat (limited to 'arch/um/drivers/chan_kern.c')
| -rw-r--r-- | arch/um/drivers/chan_kern.c | 27 | 
1 files changed, 9 insertions, 18 deletions
diff --git a/arch/um/drivers/chan_kern.c b/arch/um/drivers/chan_kern.c index e9a0abc6a32..acbe6c67afb 100644 --- a/arch/um/drivers/chan_kern.c +++ b/arch/um/drivers/chan_kern.c @@ -81,12 +81,6 @@ static const struct chan_ops not_configged_ops = {  };  #endif /* CONFIG_NOCONFIG_CHAN */ -static void tty_receive_char(struct tty_struct *tty, char ch) -{ -	if (tty) -		tty_insert_flip_char(tty, ch, TTY_NORMAL); -} -  static int open_one_chan(struct chan *chan)  {  	int fd, err; @@ -128,20 +122,18 @@ static int open_chan(struct list_head *chans)  	return err;  } -void chan_enable_winch(struct chan *chan, struct tty_struct *tty) +void chan_enable_winch(struct chan *chan, struct tty_port *port)  {  	if (chan && chan->primary && chan->ops->winch) -		register_winch(chan->fd, tty); +		register_winch(chan->fd, port);  }  static void line_timer_cb(struct work_struct *work)  {  	struct line *line = container_of(work, struct line, task.work); -	struct tty_struct *tty = tty_port_tty_get(&line->port);  	if (!line->throttled) -		chan_interrupt(line, tty, line->driver->read_irq); -	tty_kref_put(tty); +		chan_interrupt(line, line->driver->read_irq);  }  int enable_chan(struct line *line) @@ -552,8 +544,9 @@ int parse_chan_pair(char *str, struct line *line, int device,  	return 0;  } -void chan_interrupt(struct line *line, struct tty_struct *tty, int irq) +void chan_interrupt(struct line *line, int irq)  { +	struct tty_port *port = &line->port;  	struct chan *chan = line->chan_in;  	int err;  	char c; @@ -562,21 +555,20 @@ void chan_interrupt(struct line *line, struct tty_struct *tty, int irq)  		goto out;  	do { -		if (tty && !tty_buffer_request_room(tty, 1)) { +		if (!tty_buffer_request_room(port, 1)) {  			schedule_delayed_work(&line->task, 1);  			goto out;  		}  		err = chan->ops->read(chan->fd, &c, chan->data);  		if (err > 0) -			tty_receive_char(tty, c); +			tty_insert_flip_char(port, c, TTY_NORMAL);  	} while (err > 0);  	if (err == 0)  		reactivate_fd(chan->fd, irq);  	if (err == -EIO) {  		if (chan->primary) { -			if (tty != NULL) -				tty_hangup(tty); +			tty_port_tty_hangup(&line->port, false);  			if (line->chan_out != chan)  				close_one_chan(line->chan_out, 1);  		} @@ -585,6 +577,5 @@ void chan_interrupt(struct line *line, struct tty_struct *tty, int irq)  			return;  	}   out: -	if (tty) -		tty_flip_buffer_push(tty); +	tty_flip_buffer_push(port);  }  |