Do not dig struct smd_tty_info out of tty_struct using
tty_port_tty_get. It is unnecessarily too complicated, use simple
container_of instead.

Signed-off-by: Jiri Slaby <jsl...@suse.cz>
---
 drivers/tty/serial/msm_smd_tty.c | 14 +++++---------
 1 file changed, 5 insertions(+), 9 deletions(-)

diff --git a/drivers/tty/serial/msm_smd_tty.c b/drivers/tty/serial/msm_smd_tty.c
index e722ff1..1238ac3 100644
--- a/drivers/tty/serial/msm_smd_tty.c
+++ b/drivers/tty/serial/msm_smd_tty.c
@@ -90,13 +90,13 @@ static void smd_tty_notify(void *priv, unsigned event)
 
 static int smd_tty_port_activate(struct tty_port *tport, struct tty_struct 
*tty)
 {
+       struct smd_tty_info *info = container_of(tport, struct smd_tty_info,
+                       port);
        int i, res = 0;
-       int n = tty->index;
        const char *name = NULL;
-       struct smd_tty_info *info = smd_tty + n;
 
        for (i = 0; i < smd_tty_channels_len; i++) {
-               if (smd_tty_channels[i].id == n) {
+               if (smd_tty_channels[i].id == tty->index) {
                        name = smd_tty_channels[i].name;
                        break;
                }
@@ -117,17 +117,13 @@ static int smd_tty_port_activate(struct tty_port *tport, 
struct tty_struct *tty)
 
 static void smd_tty_port_shutdown(struct tty_port *tport)
 {
-       struct smd_tty_info *info;
-       struct tty_struct *tty = tty_port_tty_get(tport);
+       struct smd_tty_info *info = container_of(tport, struct smd_tty_info,
+                       port);
 
-       info = tty->driver_data;
        if (info->ch) {
                smd_close(info->ch);
                info->ch = 0;
        }
-
-       tty->driver_data = 0;
-       tty_kref_put(tty);
 }
 
 static int smd_tty_open(struct tty_struct *tty, struct file *f)
-- 
1.8.1.4


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to