Estou tentando entender o subsistema de terminal do Linux, especialmente os drivers tty e a disciplina de linha. Aparentemente, a arquitetura desse subsistema vem de uma época em que os teletipos (ttys) eram conectados a um computador para inserir dados no computador e obter uma resposta do processo.
Nunca trabalhei em um tty histórico real e acredito que quando entendo como esse tty funciona, sou mais capaz de entender os intrínsecos de um driver tty.
Estou particularmente interessado em eco e edição de linha .
Então, quando o operador no tty digitava o texto: o texto foi ecoado no tty (imprimindo uma linha no papel)? É ecoado enquanto ele digita as teclas/caracteres individuais ou apenas quando ele pressiona a tecla de nova linha/entrada.
As chaves (caracteres) que ele digita são entregues imediatamente ao computador (disciplina de linha?) ou são armazenadas em um buffer local para o tty e entregues quando a nova tecla de linha é pressionada.
Como um operador editou o texto errado (backspace, ctrl-h)? As informações de backspace seriam enviadas para o computador onde a linha seria editada de acordo ou isso era um recurso do tty (com corte do computador percebendo isso)?
E, finalmente, o que aconteceria se o operador digitasse um texto enquanto o tty estava recebendo dados do computador?
Os ttys originais eram como o ASR33 Teletype Model 33. Eles são "burros" e quando você pressiona uma tecla, ele envia um caractere para o modem ou computador. O computador pode então enviar de volta um caractere e ele é impresso.
Isso também fornece feedback de que a transmissão funcionou. Ele também permite que o computador envie de volta 2 ou mais caracteres quando você digita apenas 1. Por exemplo, você digita enter e ele envia de volta um retorno de carro para mover o cabeçote de impressão para a margem esquerda e, em seguida, uma alimentação de linha para mover o papel para a próxima linha. É por isso que você ainda vê hoje a opção
stty onlcr
que significa traduzir nova linha de saída para nova linha de retorno de carro .É também o motivo da opção de um atraso após o retorno do carro de impressão (para permitir que o cabeçote de impressão volte).
Você poderia ter editores que ecoariam backspace com backspace, X e forward-space, eliminando o último caractere. Se repetido, o editor pode retroceder ainda mais para riscar mais e, em seguida, colocar o cabeçote de impressão no final novamente quando você digitar novos caracteres.
Quando não estiver em um editor, a disciplina de linha mantém a linha atual digitada até o momento (daí o
stty cooked
modo), após a remoção dos caracteres do final da linha com backspace. Ele permitestty rprnt
que você especifique um caractere a ser digitado que reimprimirá toda a linha até o momento, depois que os backspaces digitados tiverem efeito.Os recursos dos dispositivos tty nem sempre dependem do comportamento de algumas impressoras matriciais que podem ou não estar conectadas. Tenha em mente que os tty's também foram usados por thin clients como o VT220 da DEC, que poderia ter operado como um CRT conectado a um modem externo via porta paralela, como um modelo US Robotics 9600 bps Courier , por exemplo.
Quando você tem uma quantidade tão pequena de largura de banda com a qual está lidando (embora 9600 bps fosse considerado relativamente "rápido" na época) e está enviando um arquivo por um modem POTS, não quer ter que carregar o arquivo duas vezes esperando que o sistema remoto repita tudo de volta para você. Da mesma forma, você não quer desperdiçar ciclos de CPU no sistema remoto esperando que ele escreva algo de volta para você quando você já sabe o que é.
Teria sido a mesma ideia quando você está lidando com uma conexão telnet pela Internet. Telnet não é uma conexão TCP bruta! É uma especificação Internetwork real ( RFC854 ) com dados de protocolo IAC ("Interpret As Command") que auxilia no controle do comportamento tty. Programas que manipulam dispositivos tty como setserial, getty, etc. utilizam a
ioctl
chamada de sistema ("controle de E/S") e otermios.h
arquivo de cabeçalho define constantes de pré-processador para esse fim.Da mesma forma, os modems POTS utilizavam o conjunto de comandos Hayes "AT" para controlar o eco local. Programas emuladores de terminal, como minicom e outros, também possuem definições de configuração para controlar a atividade do terminal de sua perspectiva. Portanto, as configurações de tty precisam ser ajustadas para operar em conjunto com todas as outras tecnologias usadas. Pelas mesmas razões, a edição de linha foi criada para economizar largura de banda e papel da impressora. Por que enviar uma linha para o outro sistema para processamento ou para uma impressora para ser impressa no papel quando você nem tem certeza de que é o que deseja?