ARM: fiq_debugger: Update tty code for 3.9
authorArve Hjønnevåg <arve@android.com>
Tue, 15 Jan 2013 23:10:31 +0000 (15:10 -0800)
committerJohn Stultz <john.stultz@linaro.org>
Tue, 16 Feb 2016 21:52:25 +0000 (13:52 -0800)
Signed-off-by: Arve Hjønnevåg <arve@android.com>
arch/arm/common/fiq_debugger.c

index eabd94b98f4ba4ed59f71f90c5b470291dc2bcef..65b943c7630044a2db113524aa1c7021707e17dd 100644 (file)
@@ -89,8 +89,7 @@ struct fiq_debugger_state {
 #ifdef CONFIG_FIQ_DEBUGGER_CONSOLE
        spinlock_t console_lock;
        struct console console;
-       struct tty_struct *tty;
-       int tty_open_count;
+       struct tty_port tty_port;
        struct fiq_debugger_ringbuf *tty_rbuf;
        bool syslog_dumping;
 #endif
@@ -768,30 +767,34 @@ static irqreturn_t wakeup_irq_handler(int irq, void *dev)
        return IRQ_HANDLED;
 }
 
-
-static void debug_handle_irq_context(struct fiq_debugger_state *state)
+static void debug_handle_console_irq_context(struct fiq_debugger_state *state)
 {
-       if (!state->no_sleep) {
-               unsigned long flags;
-
-               spin_lock_irqsave(&state->sleep_timer_lock, flags);
-               wake_lock(&state->debugger_wake_lock);
-               mod_timer(&state->sleep_timer, jiffies + HZ * 5);
-               spin_unlock_irqrestore(&state->sleep_timer_lock, flags);
-       }
 #if defined(CONFIG_FIQ_DEBUGGER_CONSOLE)
-       if (state->tty) {
+       if (state->tty_port.ops) {
                int i;
                int count = fiq_debugger_ringbuf_level(state->tty_rbuf);
                for (i = 0; i < count; i++) {
                        int c = fiq_debugger_ringbuf_peek(state->tty_rbuf, 0);
-                       tty_insert_flip_char(state->tty, c, TTY_NORMAL);
+                       tty_insert_flip_char(&state->tty_port, c, TTY_NORMAL);
                        if (!fiq_debugger_ringbuf_consume(state->tty_rbuf, 1))
                                pr_warn("fiq tty failed to consume byte\n");
                }
-               tty_flip_buffer_push(state->tty);
+               tty_flip_buffer_push(&state->tty_port);
        }
 #endif
+}
+
+static void debug_handle_irq_context(struct fiq_debugger_state *state)
+{
+       if (!state->no_sleep) {
+               unsigned long flags;
+
+               spin_lock_irqsave(&state->sleep_timer_lock, flags);
+               wake_lock(&state->debugger_wake_lock);
+               mod_timer(&state->sleep_timer, jiffies + HZ * 5);
+               spin_unlock_irqrestore(&state->sleep_timer_lock, flags);
+       }
+       debug_handle_console_irq_context(state);
        if (state->debug_busy) {
                debug_irq_exec(state, state->debug_cmd);
                if (!state->console_enable)
@@ -995,26 +998,21 @@ int fiq_tty_open(struct tty_struct *tty, struct file *filp)
        int line = tty->index;
        struct fiq_debugger_state **states = tty->driver->driver_state;
        struct fiq_debugger_state *state = states[line];
-       if (state->tty_open_count++)
-               return 0;
 
-       tty->driver_data = state;
-       state->tty = tty;
-       return 0;
+       return tty_port_open(&state->tty_port, tty, filp);
 }
 
 void fiq_tty_close(struct tty_struct *tty, struct file *filp)
 {
-       struct fiq_debugger_state *state = tty->driver_data;
-       if (--state->tty_open_count)
-               return;
-       state->tty = NULL;
+       tty_port_close(tty->port, tty, filp);
 }
 
 int  fiq_tty_write(struct tty_struct *tty, const unsigned char *buf, int count)
 {
        int i;
-       struct fiq_debugger_state *state = tty->driver_data;
+       int line = tty->index;
+       struct fiq_debugger_state **states = tty->driver->driver_state;
+       struct fiq_debugger_state *state = states[line];
 
        if (!state->console_enable)
                return count;
@@ -1042,7 +1040,8 @@ static int fiq_tty_poll_init(struct tty_driver *driver, int line, char *options)
 
 static int fiq_tty_poll_get_char(struct tty_driver *driver, int line)
 {
-       struct fiq_debugger_state *state = driver->ttys[line]->driver_data;
+       struct fiq_debugger_state **states = driver->driver_state;
+       struct fiq_debugger_state *state = states[line];
        int c = NO_POLL_CHAR;
 
        debug_uart_enable(state);
@@ -1064,13 +1063,16 @@ static int fiq_tty_poll_get_char(struct tty_driver *driver, int line)
 
 static void fiq_tty_poll_put_char(struct tty_driver *driver, int line, char ch)
 {
-       struct fiq_debugger_state *state = driver->ttys[line]->driver_data;
+       struct fiq_debugger_state **states = driver->driver_state;
+       struct fiq_debugger_state *state = states[line];
        debug_uart_enable(state);
        debug_putc(state, ch);
        debug_uart_disable(state);
 }
 #endif
 
+static const struct tty_port_operations fiq_tty_port_ops;
+
 static const struct tty_operations fiq_tty_driver_ops = {
        .write = fiq_tty_write,
        .write_room = fiq_tty_write_room,
@@ -1150,8 +1152,11 @@ static int fiq_debugger_tty_init_one(struct fiq_debugger_state *state)
                goto err;
        }
 
-       tty_dev = tty_register_device(fiq_tty_driver, state->pdev->id,
-               &state->pdev->dev);
+       tty_port_init(&state->tty_port);
+       state->tty_port.ops = &fiq_tty_port_ops;
+
+       tty_dev = tty_port_register_device(&state->tty_port, fiq_tty_driver,
+                                          state->pdev->id, &state->pdev->dev);
        if (IS_ERR(tty_dev)) {
                pr_err("Failed to register fiq debugger tty device\n");
                ret = PTR_ERR(tty_dev);