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:
|