1. 07 11月, 2014 3 次提交
  2. 06 11月, 2014 11 次提交
    • P
      serial: core: Fix port count when uart_open() errors · 91b32f54
      Peter Hurley 提交于
      A port count mismatch occurs if mutex_lock_interruptible()
      exits uart_open() and the port has already been opened. This may
      prematurely close a port on an open tty. Since uart_close() is _always_
      called if uart_open() fails, the port count must be corrected if errors
      occur.
      
      Always increment the port count in uart_open(), regardless of errors;
      always decrement the port count in uart_close(). Note that
      tty_port_close_start() decrements the port count when uart_open()
      was successful.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      91b32f54
    • P
      serial: core: Remove extra locking in uart_write() · 64dbee31
      Peter Hurley 提交于
      uart_start() only claims the port->lock to call __uart_start(),
      which does the actual processing. Eliminate the extra acquire/release
      in uart_write(); call __uart_start() directly with port->lock already
      held.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      64dbee31
    • P
      serial: core: Colocate crucial structure linkage · 2b702b9b
      Peter Hurley 提交于
      The key function of uart_add_one_port() is to cross-reference the
      UART driver's port structure with the serial core's state table;
      keep the assignments together and document this crucial association.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      2b702b9b
    • P
      serial: core: Remove redundant timeout assignments · 1f0afd16
      Peter Hurley 提交于
      tty_port_init() initializes close_delay and closing_wait to these
      same values; remove.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      1f0afd16
    • P
      serial: core: Unwrap >80 char line in uart_close() · 74866e75
      Peter Hurley 提交于
      The wrapped line looks wrong and out-of-place; leave it as
      >80 char line.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      74866e75
    • P
      serial: Fix locking for uart driver set_termios() method · 7c8ab967
      Peter Hurley 提交于
      The low-level uart driver may modify termios settings to override
      settings that are not compatible with the uart, such as CRTSCTS.
      Thus, callers of the low-level uart driver's set_termios() method must
      hold termios_rwsem write lock to prevent concurrent access to termios,
      in case such override occurs.
      
      The termios_rwsem lock requirement does not extend to console setup
      (ie., uart_set_options), as console setup cannot race with tty
      operations. Nor does this lock requirement extend to functions which
      cannot be concurrent with tty ioctls (ie., uart_port_startup() and
      uart_resume_port()).
      
      Further, always claim the port mutex to protect hardware
      re-reprogramming in the set_termios() uart driver method. Note this
      is unnecessary for console initialization in uart_set_options()
      which cannot be concurrent with other uart operations.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      7c8ab967
    • P
      serial: core: Flush ldisc after dropping port mutex in uart_close() · 2e758910
      Peter Hurley 提交于
      The tty buffers (and any line discipline buffers) must be flushed after
      the UART hardware has shutdown; otherwise, a racing open on the same
      tty may receive data from the previous session, which is a security
      hazard. However, holding the port mutex while flushing the line
      discipline buffers creates a lock inversion if the set_termios()
      handler takes the port mutex (as it does in the followup patch,
      'serial: Fix locking for uart driver set_termios method'.
      
      Flush the ldisc buffers after dropping the port mutex; the tty lock
      is still held which prevents a concurrent open() from advancing while
      flushing. Since no new rx data is possible after uart_shutdown() until
      a new open reinitializes the port, the later flush has no impact on
      what data is being discarded.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      2e758910
    • P
      serial: Refactor uart_flush_buffer() from uart_close() · 479e9b94
      Peter Hurley 提交于
      In the context of the final tty & port close, flushing the tx
      ring buffer after the hardware has already been shutdown and
      the ring buffer freed is neither required nor desirable.
      
      uart_flush_buffer() performs 3 operations:
      1. Resets tx ring buffer indices, but the tx ring buffer has
         already been freed and the indices are reset if the port is
         re-opened.
      2. Calls uart driver's flush_buffer() method
         5 in-tree uart drivers define flush_buffer() methods:
           amba-pl011, atmel-serial, imx, serial-tegra, timbuart
         These have been refactored into the shutdown() method, if
         required.
      3. Kicks the ldisc for more writing, but this is undesirable.
         The file handle is being released; any waiting writer will
         will be kicked out by tty_release() with a warning. Further,
         the N_TTY ldisc may generate SIGIO for a file handle which
         is no longer valid.
      
      Cc: Nicolas Ferre <nicolas.ferre@atmel.com>
      Cc: Russell King <linux@arm.linux.org.uk>
      Cc: Laxman Dewangan <ldewangan@nvidia.com>
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      479e9b94
    • P
      serial: Fix sparse warnings in uart_throttle()/uart_unthrottle() · 91f189de
      Peter Hurley 提交于
      The struct uart_port.flags field is type upf_t, as are the matching
      bit definitions. Change local mask variable to type upf_t.
      
      Fixes sparse warnings:
      drivers/tty/serial/serial_core.c:620:22: warning: invalid assignment: |=
      drivers/tty/serial/serial_core.c:620:22:    left side has type unsigned int
      drivers/tty/serial/serial_core.c:620:22:    right side has type restricted upf_t
      drivers/tty/serial/serial_core.c:622:22: warning: invalid assignment: |=
      drivers/tty/serial/serial_core.c:622:22:    left side has type unsigned int
      drivers/tty/serial/serial_core.c:622:22:    right side has type restricted upf_t
      drivers/tty/serial/serial_core.c:624:17: warning: restricted upf_t degrades to integer
      drivers/tty/serial/serial_core.c:626:22: warning: invalid assignment: &=
      drivers/tty/serial/serial_core.c:626:22:    left side has type unsigned int
      drivers/tty/serial/serial_core.c:626:22:    right side has type restricted upf_t
      drivers/tty/serial/serial_core.c:629:20: warning: restricted upf_t degrades to integer
      drivers/tty/serial/serial_core.c:632:20: warning: restricted upf_t degrades to integer
      drivers/tty/serial/serial_core.c:643:22: warning: invalid assignment: |=
      drivers/tty/serial/serial_core.c:643:22:    left side has type unsigned int
      drivers/tty/serial/serial_core.c:643:22:    right side has type restricted upf_t
      drivers/tty/serial/serial_core.c:645:22: warning: invalid assignment: |=
      drivers/tty/serial/serial_core.c:645:22:    left side has type unsigned int
      drivers/tty/serial/serial_core.c:645:22:    right side has type restricted upf_t
      drivers/tty/serial/serial_core.c:647:17: warning: restricted upf_t degrades to integer
      drivers/tty/serial/serial_core.c:649:22: warning: invalid assignment: &=
      drivers/tty/serial/serial_core.c:649:22:    left side has type unsigned int
      drivers/tty/serial/serial_core.c:649:22:    right side has type restricted upf_t
      drivers/tty/serial/serial_core.c:652:20: warning: restricted upf_t degrades to integer
      drivers/tty/serial/serial_core.c:655:20: warning: restricted upf_t degrades to integer
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      91f189de
    • P
      serial: Fix upstat_t sparse warnings · d4260b51
      Peter Hurley 提交于
      Commit 299245a1,
      serial: core: Privatize modem status enable flags, introduced
      the upstat_t type and matching bit definitions. The purpose is to
      produce sparse warnings if the wrong bit definitions are used
      (by warning of implicit integer conversions).
      
      Fix implicit conversion to integer return type from uart_cts_enabled()
      and uart_dcd_enabled().
      
      Fixes the following sparse warnings:
      drivers/tty/serial/serial_core.c:63:30: warning: incorrect type in return expression (different base types)
      drivers/tty/serial/serial_core.c:63:30:    expected int
      drivers/tty/serial/serial_core.c:63:30:    got restricted upstat_t
      include/linux/serial_core.h:364:30: warning: incorrect type in return expression (different base types)
      include/linux/serial_core.h:364:30:    expected bool
      include/linux/serial_core.h:364:30:    got restricted upstat_t
      include/linux/serial_core.h:364:30: warning: incorrect type in return expression (different base types)
      include/linux/serial_core.h:364:30:    expected bool
      include/linux/serial_core.h:364:30:    got restricted upstat_t
      Reported-by: NFengguang Wu <fengguang.wu@intel.com>
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      d4260b51
    • P
      serial: Fix divide-by-zero fault in uart_get_divisor() · 547039ec
      Peter Hurley 提交于
      uart_get_baud_rate() will return baud == 0 if the max rate is set
      to the "magic" 38400 rate and the SPD_* flags are also specified.
      On the first iteration, if the current baud rate is higher than the
      max, the baud rate is clamped at the max (which in the degenerate
      case is 38400). On the second iteration, the now-"magic" 38400 baud
      rate selects the possibly higher alternate baud rate indicated by
      the SPD_* flag. Since only two loop iterations are performed, the
      loop is exited, a kernel WARNING is generated and a baud rate of
      0 is returned.
      
      Reproducible with:
       setserial /dev/ttyS0 spd_hi base_baud 38400
      
      Only perform the "magic" 38400 -> SPD_* baud transform on the first
      loop iteration, which prevents the degenerate case from recognizing
      the clamped baud rate as the "magic" 38400 value.
      Reported-by: NRobert Święcki <robert@swiecki.net>
      Cc: <stable@vger.kernel.org> # all
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      547039ec
  3. 03 10月, 2014 1 次提交
  4. 29 9月, 2014 1 次提交
  5. 24 9月, 2014 4 次提交
  6. 09 9月, 2014 6 次提交
  7. 24 7月, 2014 1 次提交
  8. 18 7月, 2014 1 次提交
  9. 11 7月, 2014 4 次提交
    • P
      tty: serial: Fix termios/port flags mismatch · c18b55fd
      Peter Hurley 提交于
      Uart port drivers may reconfigure termios settings based on available
      hardware support; set/clear ASYNC_CTS_FLOW and ASYNC_CHECK_CD _after_
      calling the port driver's .set_termios method.
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      c18b55fd
    • P
      tty: Remove tty_hung_up_p() tests from tty drivers' open() · e359a4e3
      Peter Hurley 提交于
      Since at least before 2.6.30, it has not been possible to observe
      a hung up file pointer in a tty driver's open() method unless/until
      the driver open() releases the tty_lock() (eg., before blocking).
      
      This is because tty_open() adds the file pointer while holding
      the tty_lock() _and_ doesn't release the lock until after calling
      the tty driver's open() method. [ Before tty_lock(), this was
      lock_kernel(). ]
      
      Since __tty_hangup() first waits on the tty_lock() before
      enumerating and hanging up the open file pointers, either
      __tty_hangup() will wait for the tty_lock() or tty_open() will
      not yet have added the file pointer. For example,
      
      CPU 0                          |  CPU 1
                                     |
      tty_open                       |  __tty_hangup
        ..                           |    ..
        tty_lock                     |    ..
        tty_reopen                   |    tty_lock  / blocks
        ..                           |
        tty_add_file(tty, filp)      |
        ..                           |
        tty->ops->open(tty, filp)    |
          tty_port_open              |
            tty_port_block_til_ready |
              ..                     |
              while (1)              |
                ..                   |
                tty_unlock           |    / unblocks
                schedule             |    for each filp on tty->tty_files
                                     |      f_ops = tty_hung_up_fops;
                                     |    ..
                                     |    tty_unlock
                tty_lock             |
        ..                           |
        tty_unlock                   |
      
      Note that since tty_port_block_til_ready() and similar drop
      the tty_lock while blocking, when woken, the file pointer
      must then be tested for having been hung up.
      
      Also, fix bit-rotted drivers that used extra_count to track the
      port->count bump.
      
      CC: Mikael Starvik <starvik@axis.com>
      CC: Samuel Ortiz <samuel@sortiz.org>
      CC: "David S. Miller" <davem@davemloft.net>
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Acked-by: NJesper Nilsson <jesper.nilsson@axis.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      e359a4e3
    • P
      tty: Move tty->closing from port lock critical section · ddc7b758
      Peter Hurley 提交于
      tty->closing informs the line discipline that the hardware will
      be shutting down imminently, and to disable further input other
      than soft flow control (but to still allow additional output).
      
      However, the tty lock is the necessary lock for preventing
      concurrent changes to tty->closing. As shown by the call-tree
      audit [1] of functions that modify tty->closing, the tty lock
      is already held for those functions.
      
      [1]
      Call-tree audit of functions that modify tty->closing
      * does not include call tree to tty_port_close(), tty_port_close_start(),
        or tty_port_close_end() which is already documented in
        'tty: Document locking for tty_port_close{,start,end}' that shows
        callers to those 3 functions hold the tty lock
      
      tty_release()
        tty->ops->close() --+
                            |
      __tty_hangup()        |
        tty->ops->close() --+
                            |
              mp_close():drivers/staging/sb105x/sb_pci_mp.c
              dngc_tty_close():drivers/staging/dgnc/dgnc_tty.c
              dgap_tty_close():drivers/staging/dgap/dgap_tty.c
              dgrp_tty_close():drivers/staging/dgrp/dgrp_tty.c
              rp_close():drivers/tty/rocket.c
              hvsi_close():drivers/tty/hvc/hvsi.c
              rs_close():drivers/tty/serial/68328serial.c
              rs_close():drivers/tty/serial/crisv10.c
              uart_close():drivers/tty/serial/serial_core.c
              isdn_tty_close():drivers/isdn/i4l/isdn_tty.c
              tty3215_close():drivers/s390/char/con3215.c
      
      tty_open()
        tty_ldisc_setup() ----+
                              |
      __tty_hangup()          |
        tty_ldisc_hangup() ---+
                              |
      tty_set_ldisc() --------+
        tty_ldisc_restore() --+
                              |
                              +- tty_ldisc_open()
                                   ld->ops->open() --+
                                                     |
                                                     +- n_tty_open()
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      ddc7b758
    • P
      serial: core: Preserve termios c_cflag for console resume · ae84db96
      Peter Hurley 提交于
      When a tty is opened for the serial console, the termios c_cflag
      settings are inherited from the console line settings.
      However, if the tty is subsequently closed, the termios settings
      are lost. This results in a garbled console if the console is later
      suspended and resumed.
      
      Preserve the termios c_cflag for the serial console when the tty
      is shutdown; this reflects the most recent line settings.
      
      Fixes: Bugzilla #69751, 'serial console does not wake from S3'
      Reported-by: NValerio Vanni <valerio.vanni@inwind.it>
      Acked-by: NAlan Cox <alan@linux.intel.com>
      Signed-off-by: NPeter Hurley <peter@hurleysoftware.com>
      Cc: stable <stable@vger.kernel.org>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      ae84db96
  10. 10 7月, 2014 1 次提交
  11. 27 6月, 2014 1 次提交
    • G
      of: Enable console on serial ports specified by /chosen/stdout-path · a208ffd2
      Grant Likely 提交于
      If the devicetree specifies a serial port as a stdout device, then the
      kernel can use it as the default console if nothing else was selected on
      the command line. For any serial port that uses the uart_add_one_port()
      feature, the uart_add_one_port() has all the information needed to
      automatically enable the console device, which is what this patch does.
      
      With this change applied, a device tree platform can be booted without
      any console= parameters on the command line and the kernel will still be
      able to determine its console.
      
      Tested on QEMU Versatile model and i.MX
      Signed-off-by: NGrant Likely <grant.likely@linaro.org>
      Tested-by: NSascha Hauer <s.hauer@pengutronix.de>
      a208ffd2
  12. 29 5月, 2014 1 次提交
    • M
      serial: uart: add hw flow control support configuration · 06aa82e4
      Murali Karicheri 提交于
      8250 uart driver currently supports only software assisted hw flow
      control. The software assisted hw flow control maintains a hw_stopped
      flag in the tty structure to stop and start transmission and use modem
      status interrupt for the event to drive the handshake signals. This is
      not needed if hw has flow control capabilities. This patch adds a
      DT attribute for enabling hw flow control for a uart port. Also skip
      stop and start if this flag is present in flag field of the port
      structure.
      Signed-off-by: NMurali Karicheri <m-karicheri2@ti.com>
      CC: Rob Herring <robh+dt@kernel.org>
      CC: Pawel Moll <pawel.moll@arm.com>
      CC: Mark Rutland <mark.rutland@arm.com>
      CC: Ian Campbell <ijc+devicetree@hellion.org.uk>
      CC: Kumar Gala <galak@codeaurora.org>
      CC: Randy Dunlap <rdunlap@infradead.org>
      CC: Jiri Slaby <jslaby@suse.cz>
      CC: Santosh Shilimkar <santosh.shilimkar@ti.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      06aa82e4
  13. 25 4月, 2014 2 次提交
    • D
      serial_core: Commonalize crlf when working w/ a non open console port · c7d44a02
      Doug Anderson 提交于
      In (efe2f29e kgdboc,kdb: Allow kdb to work on a non open console port)
      support was added to directly use the "write_char" functions when
      doing kdb over a non-open console port.  This is great, but it ends up
      bypassing the normal code in uart_console_write() that adds a carriage
      return before any newlines.
      
      There appears to have been a trend to add this support directly in
      some console driver's poll_put_char() functions.  This had a few side
      effects, including:
      - In this case we were doing LFCR, not CRLF.  This was fixed in
        uart_console_write() back in (d358788f [SERIAL] kernel console should
        send CRLF not LFCR)
      - Not all serial drivers had the LFCR code in their poll_put_char()
        functions.  In my case I was running serial/samsung.c which lacked
        it.
      
      I've moved the handling to uart_poll_put_char() to fix the above
      problems.  Now when I use kdb (and don't point console= to the same
      UART) I no longer get:
      
      [0]kdb>
             [0]kdb>
                    [0]kdb>
      Signed-off-by: NDoug Anderson <dianders@chromium.org>
      Reviewed-by: NAlan Cox <alan@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      c7d44a02
    • T
      serial_core: fix uart PORT_UNKNOWN handling · 7deb39ed
      Thomas Pfaff 提交于
      While porting a RS485 driver from 2.6.29 to 3.14, i noticed that the serial tty
      driver could break it by using uart ports that it does not own :
      
      1. uart_change_pm ist called during uart_open and calls the uart pm function
         without checking for PORT_UNKNOWN.
         The fix is to move uart_change_pm from uart_open to uart_port_startup.
      2. The return code from the uart request_port call in uart_set_info is not
         handled properly, leading to the situation that the serial driver also
         thinks it owns the uart ports.
         This can triggered by doing following actions :
      
         setserial /dev/ttyS0 uart none    # release the uart ports
         modprobe lirc-serial              # or any other device that uses the uart
         setserial /dev/ttyS0 uart 16550   # gives no error and the uart tty driver
                                           # can use the ports as well
      Signed-off-by: NThomas Pfaff <tpfaff@pcs.com>
      Reviewed-by: NAlan Cox <alan@linux.intel.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      7deb39ed
  14. 17 4月, 2014 2 次提交
    • G
      serial_core: Fix pm imbalance on unbind · bf903c0c
      Geert Uytterhoeven 提交于
      When a serial port is closed, uart_close() takes care of shutting down the
      hardware, and powering it down.
      
      When a serial port is unbound while in use, uart_close() bypasses all of
      this, as this is supposed to be done through uart_hangup() (invoked via
      tty_vhangup() in uart_remove_one_port()).
      
      However, uart_hangup() does not set the hardware's power state, leaving it
      powered up.  This may also lead to unbounded nesting counts in clock and
      power management, depending on their internal implementation.
      
      Make sure to power down the port in uart_hangup(), except when the port is
      used as a serial console.
      
      For serial consoles, this operation must be postponed until after the port
      becomes completely unused. This case is not fixed yet, as it depends on a
      (future) fix for the tty->count vs. port->count imbalance on failed
      uart_open().
      
      After this, the module clock used by the sh-sci driver is disabled on
      unbind while the serial port is in use.
      Signed-off-by: NGeert Uytterhoeven <geert+renesas@glider.be>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      bf903c0c
    • S
      serial_core: Fix conditional start_tx on ring buffer not empty · 717f3bba
      Seth Bollinger 提交于
      If the serial_core ring buffer empties just as the tty layer receives
      an XOFF, then start_tx will never be called when the tty layer
      receives an XON as the serial_core ring buffer is empty.  This will
      possibly leave a few bytes trapped in the fifo for drivers that
      disable the transmitter when flow controlled.
      Signed-off-by: NSeth Bollinger <sethb@digi.com>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      717f3bba
  15. 18 3月, 2014 1 次提交
    • G
      serial_core: Avoid NULL pointer dereference in uart_close() · 4ed94cd4
      Geert Uytterhoeven 提交于
      When unbinding a serial driver that's being used as a serial console,
      the kernel may crash with a NULL pointer dereference in a uart_*() function
      called from uart_close () (e.g. uart_flush_buffer() or
      uart_chars_in_buffer()).
      
      To fix this, let uart_close() check for port->count == 0. If this is the
      case, bail out early. Else tty_port_close_start() will make the port
      counts inconsistent, printing out warnings like
      
          tty_port_close_start: tty->count = 1 port count = 0.
      
      and
      
          tty_port_close_start: count = -1
      
      and once uport == NULL, it will also crash.
      
      Also fix the related crash in pr_debug() by checking for a non-NULL uport
      first.
      
      Detailed description:
      
      On driver unbind, uart_remove_one_port() is called. Basically it;
        - marks the port dead,
        - calls tty_vhangup(),
        - sets state->uart_port = NULL.
      
      What will happen depends on whether the port is just in use by e.g. getty,
      or was also opened as a console.
      
      A. If the tty was not opened as a console:
      
        - tty_vhangup() will (in __tty_hangup()):
            - mark all file descriptors for this tty hung up by pointing them to
      	hung_up_tty_fops,
            - call uart_hangup(), which sets port->count to 0.
      
        - A subsequent uart_open() (this may be through /dev/ttyS*, or through
          /dev/console if this is a serial console) will fail with -ENXIO as the
          port was marked dead,
        - uart_close() after the failed uart_open() will return early, as
          tty_hung_up_p() (called from tty_port_close_start()) will notice it was
          hung up.
      
      B. If the tty was also opened as a console:
      
        - tty_vhangup() will (in __tty_hangup()):
            - mark non-console file descriptors for this tty hung up by pointing
      	them to hung_up_tty_fops,
            - NOT call uart_hangup(), but instead call uart_close() for every
              non-console file descriptor, so port->count will still have a
      	non-zero value afterwards.
      
        - A subsequent uart_open() will fail with -ENXIO as the port was
          marked dead,
        - uart_close() after the failed uart_open() starts to misbehave:
            - tty_hung_up_p() will not notice it was hung up,
            - As port->count is non-zero, tty_port_close_start() will decrease
              port->count, making the tty and port counts inconsistent. Later,
      	warnings like these will be printed:
      
      	    tty_port_close_start: tty->count = 1 port count = 0.
      
      	and
      	    tty_port_close_start: count = -1
      
            - If all of this happens after state->uart_port was set to zero, a
              NULL pointer dereference will happen.
      Signed-off-by: NGeert Uytterhoeven <geert+renesas@linux-m68k.org>
      Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
      4ed94cd4