When rs485 transmission over an 8250 port stops, __stop_tx() assigns
active_timer = NULL before calling __stop_tx_rs485().
That function in turn either assigns active_timer = stop_tx_timer and
rearms the timer (in case a delay_rts_after_send needs to be observed)
or directly calls __do_stop_tx_rs485().
Move the assignment active_timer = NULL to __stop_tx_rs485() into the
branch which directly calls __do_stop_tx_rs485(), thereby avoiding a
duplicate assignment and simplifying the code.
Signed-off-by: Lukas Wunner <lukas@wunner.de>
Cc: Matwey V. Kornilov <matwey@sai.msu.ru>
Link: https://lore.kernel.org/r/bca638405550eaf92f0c6060b553b687f35885e0.1582895077.git.lukas@wunner.de
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
                                   p->port.rs485.delay_rts_after_send);
        } else {
                __do_stop_tx_rs485(p);
+               em485->active_timer = NULL;
        }
 }
 
                if ((lsr & BOTH_EMPTY) != BOTH_EMPTY)
                        return;
 
-               em485->active_timer = NULL;
-
                __stop_tx_rs485(p);
        }
        __do_stop_tx(p);