summaryrefslogtreecommitdiff
path: root/lib/dynamic_debug.c
diff options
context:
space:
mode:
authorDaniel Starke <daniel.starke@siemens.com>2022-05-04 10:17:32 +0200
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2022-05-05 23:00:06 +0200
commitedd5f60c340086891fab094ad61270d6c80f9ca4 (patch)
tree9979906a9a5590ddec4dd2791580f5cd52d2b5e6 /lib/dynamic_debug.c
parentfd442e5ba30aaa75ea47b32149e7a3110dc20a46 (diff)
tty: n_gsm: fix mux activation issues in gsm_config()
The current implementation activates the mux if it was restarted and opens the control channel if the mux was previously closed and we are now acting as initiator instead of responder, which is the default setting. This has two issues. 1) No mux is activated if we keep all default values and only switch to initiator. The control channel is not allocated but will be opened next which results in a NULL pointer dereference. 2) Switching the configuration after it was once configured while keeping the initiator value the same will not reopen the control channel if it was closed due to parameter incompatibilities. The mux remains dead. Fix 1) by always activating the mux if it is dead after configuration. Fix 2) by always opening the control channel after mux activation. Fixes: e1eaea46bb40 ("tty: n_gsm line discipline") Cc: stable@vger.kernel.org Signed-off-by: Daniel Starke <daniel.starke@siemens.com> Link: https://lore.kernel.org/r/20220504081733.3494-2-daniel.starke@siemens.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'lib/dynamic_debug.c')
0 files changed, 0 insertions, 0 deletions