• Lukas Wunner's avatar
    serial: 8250: Support console on software emulated rs485 ports · 7f980307
    Lukas Wunner authored
    Commit e490c914 ("tty: Add software emulated RS485 support for 8250")
    introduced support to use RTS as an rs485 Transmit Enable signal if data
    is transmitted through the tty layer.
    
    Console messages bypass the tty layer and instead are emitted via
    serial8250_console_write().  Amend that function to drive RTS as well,
    allowing for a console on rs485 ports.
    
    Note that serial8250_console_write() may be called concurrently to the
    tty layer accessing the port.  The two protect their accesses with the
    port lock, but serial8250_console_write() may find RTS still being
    asserted by the tty layer, in which case it shouldn't be deasserted
    after the console message has been printed.  Recognize such situations
    by checking the em485->tx_stopped flag.
    
    If a delay_rts_before_send or delay_rts_after_send has been specified,
    serial8250_console_write() busy-waits for its duration.  Optimizations
    for those wait times are conceivable:  E.g. if RTS is already asserted,
    we could check whether em485->start_tx_timer is active and wait only
    for the remaining expire time.  But this would require calling into
    the hrtimer infrastructure, which involves acquiring locks and
    potentially reprogramming timer hardware.  Such operations seem too
    risky in the context of console printout, which needs to work even when
    the kernel has crashed and emits a BUG splat.  So I've gone with a
    simplistic solution which just always waits for the full delay.
    Signed-off-by: default avatarLukas Wunner <lukas@wunner.de>
    Cc: Matwey V. Kornilov <matwey@sai.msu.ru>
    Link: https://lore.kernel.org/r/65edffce4670a19e598015c03cbe46f1ffd93e43.1582895077.git.lukas@wunner.deSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
    7f980307
8250_port.c 82.8 KB