我正在尝试了解 Linux 的终端子系统,尤其是 tty 驱动程序和线路规则。显然,这个子系统的架构源于电传打字机(ttys)连接到计算机以将数据输入计算机并获得进程响应的时代。
我从未在真正的历史 tty 上工作过,我相信当我了解这种 tty 的工作原理时,我能够更好地理解 tty 驱动程序的内在特性。
我对回声和行编辑特别感兴趣。
那么,当 tty 上的操作员键入文本时:文本是否在 tty 上回显(通过在纸上打印一行)?它是在他键入单个键/字符时回显,还是仅在他按下新行/回车键时回显。
他键入的键(字符)是立即传送到计算机(线路规则?)还是存储在 tty 本地的缓冲区中,并在按下新线路键时传送。
操作员如何编辑错误的文本(退格键、ctrl-h)?退格信息是否会被发送到将相应编辑行的计算机,或者这是 tty 的一个功能(计算机会注意到它)?
最后,如果操作员在tty 从计算机接收数据时输入文本会发生什么?
最初的 tty 类似于ASR33 Teletype Model 33。它们是“哑”的,当您按下一个键时,它会向调制解调器或计算机发送一个字符。然后计算机可以发回一个字符并打印出来。
这也提供了传输工作的反馈。它还允许计算机在您只键入 1 时发送回 2 个或更多字符。例如,您键入 enter,它会发送回一个回车以将打印头移到左边距,然后发送一个换行将纸张向上移动到下一行。
stty onlcr
这就是为什么您今天仍然看到将输出换行符转换为回车换行符的选项。这也是选项在打印回车后有延迟的原因(以允许打印头向后移动)。
你可以有一些编辑器,用退格、X 和前进空格来呼应退格,从而删除最后一个字符。如果重复,编辑器可以进一步退格以删除更多内容,然后在您键入新字符时再次将打印头放在末尾。
当不在编辑器中时,行规则会在使用退格键从行尾删除字符后保持当前输入的行(因此
stty cooked
模式)。它stty rprnt
允许您指定要键入的字符,该字符将在您键入的退格键生效后重新打印到目前为止的整行。tty 设备的功能并不总是取决于某些可能连接或不连接的点阵行打印机的行为。请记住,tty 也被 DEC 的VT220之类的瘦客户端使用,它可以作为通过并行端口连接到外部调制解调器的CRT运行,例如US Robotics 9600 bps Courier模型。
当您处理的带宽如此之少(尽管当时认为 9600 bps 相对“快”)并且您通过 POTS 调制解调器发送文件时,您不希望必须上传通过等待远程系统将所有内容回显给您,该文件两次。同样,当您已经知道它是什么时,您不希望等待远程系统向您写回某些内容,从而在远程系统上浪费 CPU 周期。
当您处理 Internet 上的 telnet 连接时,这将是相同的想法。 Telnet不是原始TCP 连接!这是一个实际的互联网规范 ( RFC854 ),带有 IAC(“解释为命令”)协议数据,有助于控制 tty 行为。操纵 tty 设备(如 setserial、getty 等)的程序利用
ioctl
(“I/O 控制”)系统调用,并且termios.h
头文件为此定义了预处理器常量。类似地,POTS 调制解调器使用Hayes“AT”命令集来控制本地回声。minicom等终端仿真器程序也具有从它们的角度控制终端活动的配置设置。因此,需要调整 tty 设置以与所有其他正在使用的技术协同工作。出于同样的原因,创建行编辑以节省带宽和打印纸。当您甚至不确定它是否是您想要的东西时,为什么还要将一条线发送到其他系统进行处理或发送到打印机以在纸上着墨?