提交 7f32f8dd 编写于 作者: J Jiri Slaby 提交者: Greg Kroah-Hartman

TTY: simserial, define local tty_port pointer

And use it to make the code more readable.

Since tport doesn't conflict with port anymore and there are not many
tport accessors left, do also s/\<tport\>/port/g.
Signed-off-by: NJiri Slaby <jslaby@suse.cz>
Cc: Tony Luck <tony.luck@intel.com>
Cc: Fenghua Yu <fenghua.yu@intel.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 3c4782dc
...@@ -47,7 +47,7 @@ ...@@ -47,7 +47,7 @@
#define NR_PORTS 1 /* only one port for now */ #define NR_PORTS 1 /* only one port for now */
struct serial_state { struct serial_state {
struct tty_port tport; struct tty_port port;
struct circ_buf xmit; struct circ_buf xmit;
int irq; int irq;
int x_char; int x_char;
...@@ -132,8 +132,9 @@ static void receive_chars(struct tty_struct *tty) ...@@ -132,8 +132,9 @@ static void receive_chars(struct tty_struct *tty)
static irqreturn_t rs_interrupt_single(int irq, void *dev_id) static irqreturn_t rs_interrupt_single(int irq, void *dev_id)
{ {
struct serial_state *info = dev_id; struct serial_state *info = dev_id;
struct tty_struct *tty = info->port.tty;
if (!info->tport.tty) { if (!tty) {
printk(KERN_INFO "simrs_interrupt_single: info|tty=0 info=%p problem\n", info); printk(KERN_INFO "simrs_interrupt_single: info|tty=0 info=%p problem\n", info);
return IRQ_NONE; return IRQ_NONE;
} }
...@@ -141,7 +142,7 @@ static irqreturn_t rs_interrupt_single(int irq, void *dev_id) ...@@ -141,7 +142,7 @@ static irqreturn_t rs_interrupt_single(int irq, void *dev_id)
* pretty simple in our case, because we only get interrupts * pretty simple in our case, because we only get interrupts
* on inbound traffic * on inbound traffic
*/ */
receive_chars(info->tport.tty); receive_chars(tty);
return IRQ_HANDLED; return IRQ_HANDLED;
} }
...@@ -416,7 +417,7 @@ static void shutdown(struct tty_struct *tty, struct serial_state *info) ...@@ -416,7 +417,7 @@ static void shutdown(struct tty_struct *tty, struct serial_state *info)
{ {
unsigned long flags; unsigned long flags;
if (!(info->tport.flags & ASYNC_INITIALIZED)) if (!(info->port.flags & ASYNC_INITIALIZED))
return; return;
#ifdef SIMSERIAL_DEBUG #ifdef SIMSERIAL_DEBUG
...@@ -436,7 +437,7 @@ static void shutdown(struct tty_struct *tty, struct serial_state *info) ...@@ -436,7 +437,7 @@ static void shutdown(struct tty_struct *tty, struct serial_state *info)
set_bit(TTY_IO_ERROR, &tty->flags); set_bit(TTY_IO_ERROR, &tty->flags);
info->tport.flags &= ~ASYNC_INITIALIZED; info->port.flags &= ~ASYNC_INITIALIZED;
} }
local_irq_restore(flags); local_irq_restore(flags);
} }
...@@ -454,6 +455,7 @@ static void shutdown(struct tty_struct *tty, struct serial_state *info) ...@@ -454,6 +455,7 @@ static void shutdown(struct tty_struct *tty, struct serial_state *info)
static void rs_close(struct tty_struct *tty, struct file * filp) static void rs_close(struct tty_struct *tty, struct file * filp)
{ {
struct serial_state *info = tty->driver_data; struct serial_state *info = tty->driver_data;
struct tty_port *port = &info->port;
unsigned long flags; unsigned long flags;
if (!info) if (!info)
...@@ -468,30 +470,30 @@ static void rs_close(struct tty_struct *tty, struct file * filp) ...@@ -468,30 +470,30 @@ static void rs_close(struct tty_struct *tty, struct file * filp)
return; return;
} }
#ifdef SIMSERIAL_DEBUG #ifdef SIMSERIAL_DEBUG
printk("rs_close ttys%d, count = %d\n", info->line, info->tport.count); printk("rs_close ttys%d, count = %d\n", info->line, port->count);
#endif #endif
if ((tty->count == 1) && (info->tport.count != 1)) { if ((tty->count == 1) && (port->count != 1)) {
/* /*
* Uh, oh. tty->count is 1, which means that the tty * Uh, oh. tty->count is 1, which means that the tty
* structure will be freed. info->tport.count should always * structure will be freed. port->count should always
* be one in these conditions. If it's greater than * be one in these conditions. If it's greater than
* one, we've got real problems, since it means the * one, we've got real problems, since it means the
* serial port won't be shutdown. * serial port won't be shutdown.
*/ */
printk(KERN_ERR "rs_close: bad serial port count; tty->count is 1, " printk(KERN_ERR "rs_close: bad serial port count; tty->count is 1, "
"info->tport.count is %d\n", info->tport.count); "port->count is %d\n", port->count);
info->tport.count = 1; port->count = 1;
} }
if (--info->tport.count < 0) { if (--port->count < 0) {
printk(KERN_ERR "rs_close: bad serial port count for ttys%d: %d\n", printk(KERN_ERR "rs_close: bad serial port count for ttys%d: %d\n",
tty->index, info->tport.count); tty->index, port->count);
info->tport.count = 0; port->count = 0;
} }
if (info->tport.count) { if (port->count) {
local_irq_restore(flags); local_irq_restore(flags);
return; return;
} }
info->tport.flags |= ASYNC_CLOSING; port->flags |= ASYNC_CLOSING;
local_irq_restore(flags); local_irq_restore(flags);
/* /*
...@@ -501,14 +503,14 @@ static void rs_close(struct tty_struct *tty, struct file * filp) ...@@ -501,14 +503,14 @@ static void rs_close(struct tty_struct *tty, struct file * filp)
shutdown(tty, info); shutdown(tty, info);
rs_flush_buffer(tty); rs_flush_buffer(tty);
tty_ldisc_flush(tty); tty_ldisc_flush(tty);
info->tport.tty = NULL; port->tty = NULL;
if (info->tport.blocked_open) { if (port->blocked_open) {
if (info->tport.close_delay) if (port->close_delay)
schedule_timeout_interruptible(info->tport.close_delay); schedule_timeout_interruptible(port->close_delay);
wake_up_interruptible(&info->tport.open_wait); wake_up_interruptible(&port->open_wait);
} }
info->tport.flags &= ~(ASYNC_NORMAL_ACTIVE|ASYNC_CLOSING); port->flags &= ~(ASYNC_NORMAL_ACTIVE|ASYNC_CLOSING);
wake_up_interruptible(&info->tport.close_wait); wake_up_interruptible(&port->close_wait);
} }
/* /*
...@@ -525,26 +527,27 @@ static void rs_wait_until_sent(struct tty_struct *tty, int timeout) ...@@ -525,26 +527,27 @@ static void rs_wait_until_sent(struct tty_struct *tty, int timeout)
static void rs_hangup(struct tty_struct *tty) static void rs_hangup(struct tty_struct *tty)
{ {
struct serial_state *info = tty->driver_data; struct serial_state *info = tty->driver_data;
struct tty_port *port = &info->port;
#ifdef SIMSERIAL_DEBUG #ifdef SIMSERIAL_DEBUG
printk("rs_hangup: called\n"); printk("rs_hangup: called\n");
#endif #endif
rs_flush_buffer(tty); rs_flush_buffer(tty);
if (info->tport.flags & ASYNC_CLOSING) if (port->flags & ASYNC_CLOSING)
return; return;
shutdown(tty, info); shutdown(tty, info);
info->tport.count = 0; port->count = 0;
info->tport.flags &= ~ASYNC_NORMAL_ACTIVE; port->flags &= ~ASYNC_NORMAL_ACTIVE;
info->tport.tty = NULL; port->tty = NULL;
wake_up_interruptible(&info->tport.open_wait); wake_up_interruptible(&port->open_wait);
} }
static int startup(struct tty_struct *tty, struct serial_state *state) static int startup(struct tty_struct *tty, struct serial_state *state)
{ {
struct tty_port *port = &state->tport; struct tty_port *port = &state->port;
unsigned long flags; unsigned long flags;
int retval=0; int retval=0;
unsigned long page; unsigned long page;
...@@ -622,26 +625,27 @@ static int startup(struct tty_struct *tty, struct serial_state *state) ...@@ -622,26 +625,27 @@ static int startup(struct tty_struct *tty, struct serial_state *state)
static int rs_open(struct tty_struct *tty, struct file * filp) static int rs_open(struct tty_struct *tty, struct file * filp)
{ {
struct serial_state *info = rs_table + tty->index; struct serial_state *info = rs_table + tty->index;
int retval; struct tty_port *port = &info->port;
int retval;
info->tport.count++; port->count++;
info->tport.tty = tty; port->tty = tty;
tty->driver_data = info; tty->driver_data = info;
tty->port = &info->tport; tty->port = port;
#ifdef SIMSERIAL_DEBUG #ifdef SIMSERIAL_DEBUG
printk("rs_open %s, count = %d\n", tty->name, info->tport.count); printk("rs_open %s, count = %d\n", tty->name, port->count);
#endif #endif
tty->low_latency = (info->tport.flags & ASYNC_LOW_LATENCY) ? 1 : 0; tty->low_latency = (port->flags & ASYNC_LOW_LATENCY) ? 1 : 0;
/* /*
* If the port is the middle of closing, bail out now * If the port is the middle of closing, bail out now
*/ */
if (tty_hung_up_p(filp) || (info->tport.flags & ASYNC_CLOSING)) { if (tty_hung_up_p(filp) || (port->flags & ASYNC_CLOSING)) {
if (info->tport.flags & ASYNC_CLOSING) if (port->flags & ASYNC_CLOSING)
interruptible_sleep_on(&info->tport.close_wait); interruptible_sleep_on(&port->close_wait);
#ifdef SERIAL_DO_RESTART #ifdef SERIAL_DO_RESTART
return ((info->tport.flags & ASYNC_HUP_NOTIFY) ? return ((port->flags & ASYNC_HUP_NOTIFY) ?
-EAGAIN : -ERESTARTSYS); -EAGAIN : -ERESTARTSYS);
#else #else
return -EAGAIN; return -EAGAIN;
...@@ -774,8 +778,8 @@ static int __init simrs_init(void) ...@@ -774,8 +778,8 @@ static int __init simrs_init(void)
* Let's have a little bit of fun ! * Let's have a little bit of fun !
*/ */
state = rs_table; state = rs_table;
tty_port_init(&state->tport); tty_port_init(&state->port);
state->tport.close_delay = 0; /* XXX really 0? */ state->port.close_delay = 0; /* XXX really 0? */
retval = hpsim_get_irq(KEYBOARD_INTR); retval = hpsim_get_irq(KEYBOARD_INTR);
if (retval < 0) { if (retval < 0) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册