Devpts - Devpts

Упрощенная структура Ядро Linux: Терминалы и драйверы символьных устройств, также известные как «подсистема TTY».

Devpts виртуальная файловая система, доступная в Ядро Linux с версии 2.1.93 (апрель 1998 г.). Обычно он устанавливается на / dev / pts и содержит только файлы устройств, которые представляют рабы к мультиплексированию мастер расположен на / dev / ptmx.[1]

Создание разработчиков явилось следствием желания отказаться от необходимости Setuid вспомогательная программа, например / usr / libexec / pt_chown. Это отличная реализация идеи псевдотерминала; предыдущая реализация предусматривала фиксированное количество пар главный / подчиненный, которые имели постоянные узлы устройств, например, пара главный-подчиненный / dev / ptyp63 и / dev / ttyp63, ср. Интерфейс программирования Linux глава 62 «Терминалы» и глава 64 «Псевдотерминалы».

А псевдотерминал («псевдо TTY» или «PTY») - пара псевдоустройства - а раб и мастер - которые обеспечивают особый канал связи. Подчиненное псевдоустройство имитирует текстовый терминал физического компьютера, например то DEC VT100, он может читать и писать текст, как если бы это был физический терминал. В мастер Псевдоустройство предоставляет средства, с помощью которых программа, предоставляющая текстовый пользовательский интерфейс, работает со своим подчиненным устройством и управляет им. Широко распространены программы с текстовым пользовательским интерфейсом. эмуляторы терминала, например xterm, гном-терминал или Konsole, или программы, использующие SSH или телнет. Запись на ведущее устройство - это точно так же, как набор текста на терминале, поэтому ведущее псевдоустройство действует как человек, сидящий перед текстовым терминалом физического компьютера.

Псевдотерминальная пара похожа на двунаправленную трубу. Все, что записано на ведущем устройстве, отображается как ввод на ведомом устройстве, а все, что записывается на ведомом устройстве, появляется как ввод на ведущем устройстве. Как и трубы, псевдотерминалы имеют ограниченную емкость. В Linux емкость псевдотерминала составляет около 4 КБ в каждом направлении.

Типичная операционная система на основе ядра Linux предоставляет множество PTY для поддержки текстовых интерфейсов, предоставляемых эмуляторами терминала (такими как xterm или gnome-terminal) и интерфейсами удаленного доступа, такими как SSH.

История внедрения

В феврале 1998 года в Linux 2.1.87 появилась поддержка / dev / ptmx ведущее устройство мультиплексирования.[2] Открытие этого устройства обеспечивает доступ к другому неиспользуемому псевдо-главному устройству TTY и позволяет идентифицировать соответствующее подчиненное устройство с помощью ioctl (). В апреле того же года в Linux 2.1.93 была добавлена ​​новая виртуальная файловая система под названием devpts, которая обычно монтируется в / dev / pts. Всякий раз, когда создается новая пара главный / подчиненный, в этой виртуальной файловой системе создается узел устройства для подчиненного устройства.

Чтобы облегчить перенос эмуляции терминала в пользовательское пространство, сохранив при этом подсистему TTY (управление сеансами и дисциплину линии), был изобретен псевдотерминал.[3]

Причина, по которой дисциплина линий находится внутри ядра, состоит в том, чтобы избежать переключатели контекста при получении каждого персонажа (что в ранние времена малых основных воспоминаний предполагало замену и замену!). Таким образом, линейная дисциплина сохраняет в буфере ядра строку ввода, и, поскольку достаточно просто проверить конкретный байт и уменьшить счетчик, чтобы реализовать "редактирование" backspace (и несколько других простых функций редактирования), это делается там .

Альтернативой является использование необработанного режима, в котором символы перенаправляются в приложение, как только они получены, что необходимо для более сложных редакторов, таких как (в то время) широко известный Emacs. И действительно, поскольку emacs должен был использовать этот необработанный режим, который подразумевает переключение контекста при приеме каждого набранного символа, он постоянно менял местами, когда у компьютеров не было достаточно памяти, чтобы держать emacs и все другие программы в ядре.

С добавлением псевдотерминалов (PTY) код TTY также стал своего рода механизмом межпроцессного взаимодействия с сохранением всей странной семантики TTY. Код TTY также должен поддерживать сетевые протоколы, такие как PPP, без создания узких мест в производительности.[4]

использованная литература

  1. ^ Нил Браун (2016-06-01). «Контейнеры, псевдотайты и обратная совместимость». LWN.net.
  2. ^ "diff of /drivers/char/pty.c".
  3. ^ Linux Akesson. "Телетайп демистифицирован".
  4. ^ Джонатан Корбет (2009-07-29). "Буря в tty pot". LWN.net.