2019-04-22 10:27:22 -03:00
=================
The Lockronomicon
=================
2005-04-16 15:20:36 -07:00
Your guide to the ancient and twisted locking policies of the tty layer and
the warped logic behind them. Beware all ye who read on.
Line Discipline
---------------
Line disciplines are registered with tty_register_ldisc() passing the
2019-04-22 10:27:22 -03:00
discipline number and the ldisc structure. At the point of registration the
2005-04-16 15:20:36 -07:00
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.
2019-04-22 10:27:22 -03:00
After the return the ldisc data has been copied so you may free your own
2005-04-16 15:20:36 -07:00
copy of the structure. 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.
2005-06-23 00:10:32 -07:00
In order to remove a line discipline call tty_unregister_ldisc().
2005-04-16 15:20:36 -07:00
In ancient times this always worked. In modern times the function will
return -EBUSY if the ldisc is currently in use. Since the ldisc referencing
code manages the module counts this should not usually be a concern.
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
2019-04-22 10:27:22 -03:00
discipline. The reference count of the tty_ldisc structure within a tty
2005-04-16 15:20:36 -07:00
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).
Line Discipline Methods
-----------------------
2021-11-26 09:15:56 +01:00
.. kernel-doc :: include/linux/tty_ldisc.h
:identifiers: tty_ldisc_ops
2005-04-16 15:20:36 -07:00
2006-12-29 16:48:03 -08:00
Driver Access
2019-04-22 10:27:22 -03:00
^^^^^^^^^^^^^
2006-12-29 16:48:03 -08:00
2021-11-26 09:15:55 +01:00
Line discipline methods can call the methods of the underlying hardware driver.
These are documented as a part of struct tty_operations.
2006-12-29 16:48:03 -08:00
Flags
2019-04-22 10:27:22 -03:00
^^^^^
2006-12-29 16:48:03 -08:00
Line discipline methods have access to tty->flags field containing the
following interesting flags:
2019-04-22 10:27:22 -03:00
======================= =======================================================
2006-12-29 16:48:03 -08:00
TTY_THROTTLED Driver input is throttled. The ldisc should call
tty->driver->unthrottle() in order to resume
reception when it is ready to process more data.
TTY_DO_WRITE_WAKEUP If set, causes the driver to call the ldisc's
write_wakeup() method in order to resume
transmission when it can accept more data
to transmit.
TTY_IO_ERROR If set, causes all subsequent userspace read/write
calls on the tty to fail, returning -EIO.
TTY_OTHER_CLOSED Device is a pty and the other side has closed.
TTY_NO_WRITE_SPLIT Prevent driver from splitting up writes into
smaller chunks.
2019-04-22 10:27:22 -03:00
======================= =======================================================
2006-12-29 16:48:03 -08:00
2005-04-16 15:20:36 -07:00
Locking
2019-04-22 10:27:22 -03:00
^^^^^^^
2005-04-16 15:20:36 -07:00
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.
2019-04-22 10:27:22 -03:00
Three calls are now provided::
2005-04-16 15:20:36 -07:00
ldisc = tty_ldisc_ref(tty);
takes a handle to the line discipline in the tty and returns it. If no ldisc
is currently attached or the ldisc is being closed and re-opened at this
point then NULL is returned. While this handle is held the ldisc will not
2019-04-22 10:27:22 -03:00
change or go away::
2005-04-16 15:20:36 -07:00
tty_ldisc_deref(ldisc)
Returns the ldisc reference and allows the ldisc to be closed. Returning the
reference takes away your right to call the ldisc functions until you take
2019-04-22 10:27:22 -03:00
a new reference::
2005-04-16 15:20:36 -07:00
ldisc = tty_ldisc_ref_wait(tty);
Performs the same function as tty_ldisc_ref except that it will wait for an
2019-04-22 10:27:22 -03:00
ldisc change to complete and then return a reference to the new ldisc.
2005-04-16 15:20:36 -07:00
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.
2019-04-22 10:27:22 -03:00
A caution: The ldisc->open(), ldisc->close() and driver->set_ldisc
2005-04-16 15:20:36 -07:00
functions are called with the ldisc unavailable. Thus tty_ldisc_ref will
fail in this situation if used within these functions. Ldisc and driver
2019-04-22 10:27:22 -03:00
code calling its own functions must be careful in this case.