n_gsm: Send CLD command on exit
authorAlan Cox <alan@linux.intel.com>
Fri, 26 Aug 2011 10:28:11 +0000 (11:28 +0100)
committerGreg Kroah-Hartman <gregkh@suse.de>
Fri, 26 Aug 2011 18:01:14 +0000 (11:01 -0700)
A DISC on DLCI 0 should close down the mux but Michael Lauer reports this
is not the case for some modems. Send a CLD as well.

Signed-off-by: Alan Cox <alan@linux.intel.com>
Tested-by: Michael Lauer
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/tty/n_gsm.c

index ed429082304dffca536dce93069453de8ddd33b5..8d7766bfef87a18d70ad7b2cdcf7dd25048c9bf9 100644 (file)
@@ -2003,6 +2003,7 @@ void gsm_cleanup_mux(struct gsm_mux *gsm)
        int i;
        struct gsm_dlci *dlci = gsm->dlci[0];
        struct gsm_msg *txq;
+       struct gsm_control *gc;
 
        gsm->dead = 1;
 
@@ -2016,6 +2017,13 @@ void gsm_cleanup_mux(struct gsm_mux *gsm)
        spin_unlock(&gsm_mux_lock);
        WARN_ON(i == MAX_MUX);
 
+       /* In theory disconnecting DLCI 0 is sufficient but for some
+          modems this is apparently not the case. */
+       if (dlci) {
+               gc = gsm_control_send(gsm, CMD_CLD, NULL, 0);
+               if (gc)
+                       gsm_control_wait(gsm, gc);
+       }
        del_timer_sync(&gsm->t2_timer);
        /* Now we are sure T2 has stopped */
        if (dlci) {