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