mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-04 04:06:26 +00:00
b96cd8b05e
Based on discussion starting as 87mthw2o93.fsf@meer.lwn.net, let's move the tty documentation to driver-api. It's more appropriate there. Cc: Jonathan Corbet <corbet@lwn.net> Signed-off-by: Jiri Slaby <jslaby@suse.cz> Link: https://lore.kernel.org/r/20220411110143.10019-2-jslaby@suse.cz Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
86 lines
3.1 KiB
ReStructuredText
86 lines
3.1 KiB
ReStructuredText
.. SPDX-License-Identifier: GPL-2.0
|
||
|
||
===================
|
||
TTY Line Discipline
|
||
===================
|
||
|
||
.. contents:: :local:
|
||
|
||
TTY line discipline process all incoming and outgoing character from/to a tty
|
||
device. The default line discipline is :doc:`N_TTY <n_tty>`. It is also a
|
||
fallback if establishing any other discipline for a tty fails. If even N_TTY
|
||
fails, N_NULL takes over. That never fails, but also does not process any
|
||
characters -- it throws them away.
|
||
|
||
Registration
|
||
============
|
||
|
||
Line disciplines are registered with tty_register_ldisc() passing the ldisc
|
||
structure. At the point of registration the discipline must be ready to use and
|
||
it is possible it will get used before the call returns success. If the call
|
||
returns an error then it won’t get called. Do not re-use ldisc numbers as they
|
||
are part of the userspace ABI and writing over an existing ldisc will cause
|
||
demons to eat your computer. You must not re-register over the top of the line
|
||
discipline even with the same data or your computer again will be eaten by
|
||
demons. In order to remove a line discipline call tty_unregister_ldisc().
|
||
|
||
Heed this warning: the reference count field of the registered copies of the
|
||
tty_ldisc structure in the ldisc table counts the number of lines using this
|
||
discipline. The reference count of the tty_ldisc structure within a tty counts
|
||
the number of active users of the ldisc at this instant. In effect it counts
|
||
the number of threads of execution within an ldisc method (plus those about to
|
||
enter and exit although this detail matters not).
|
||
|
||
.. kernel-doc:: drivers/tty/tty_ldisc.c
|
||
:identifiers: tty_register_ldisc tty_unregister_ldisc
|
||
|
||
Other Functions
|
||
===============
|
||
|
||
.. kernel-doc:: drivers/tty/tty_ldisc.c
|
||
:identifiers: tty_set_ldisc tty_ldisc_flush
|
||
|
||
Line Discipline Operations Reference
|
||
====================================
|
||
|
||
.. kernel-doc:: include/linux/tty_ldisc.h
|
||
:identifiers: tty_ldisc_ops
|
||
|
||
Driver Access
|
||
=============
|
||
|
||
Line discipline methods can call the methods of the underlying hardware driver.
|
||
These are documented as a part of struct tty_operations.
|
||
|
||
TTY Flags
|
||
=========
|
||
|
||
Line discipline methods have access to :c:member:`tty_struct.flags` field. See
|
||
:doc:`tty_struct`.
|
||
|
||
Locking
|
||
=======
|
||
|
||
Callers to the line discipline functions from the tty layer are required to
|
||
take line discipline locks. The same is true of calls from the driver side
|
||
but not yet enforced.
|
||
|
||
.. kernel-doc:: drivers/tty/tty_ldisc.c
|
||
:identifiers: tty_ldisc_ref_wait tty_ldisc_ref tty_ldisc_deref
|
||
|
||
While these functions are slightly slower than the old code they should have
|
||
minimal impact as most receive logic uses the flip buffers and they only
|
||
need to take a reference when they push bits up through the driver.
|
||
|
||
A caution: The :c:member:`tty_ldisc_ops.open()`,
|
||
:c:member:`tty_ldisc_ops.close()` and :c:member:`tty_driver.set_ldisc()`
|
||
functions are called with the ldisc unavailable. Thus tty_ldisc_ref() will fail
|
||
in this situation if used within these functions. Ldisc and driver code
|
||
calling its own functions must be careful in this case.
|
||
|
||
Internal Functions
|
||
==================
|
||
|
||
.. kernel-doc:: drivers/tty/tty_ldisc.c
|
||
:internal:
|