Ctrl-C não funciona com a sessão não desanexada pppd

12

Eu tenho uma placa ARM Mini2440 e coloquei um sistema Debian 6.0 básico nele multistrap.

Eu tenho usado tmuxpara executar vários processos em janelas defferent de /etc/rc.local. Eu me conecto à placa usando sua porta serial e uma entrada inittab para executar gettynessa porta. Eu uso picocomcomo comunicador serial.

Quando o root faz login, o ~/.bashrcanexa ao servidor tmux já em execução, e os processos podem ser facilmente monitorados. o comando real é exec tmux attach-session -t "main". O tmux é executado com a configuração padrão.

Tudo funciona, exceto um dos processos (um shell script ao redor pppd) não recebe Ctrlcdo terminal, enquanto outros processos recebem . Também Ctrl\funciona. também kill -INT <pppd_pid>funciona, mas kill -INT <shellscript_pid>não.

Eu realmente preciso Ctrlctrabalhar. O que há de errado com esta configuração?

Edit: aqui está a saída do stty -ascript shell, logo antes pppd:

speed 38400 baud; rows 23; columns 80; line = 0;
intr = ^C; quit = ^\; erase = ^?; kill = ^U; eof = ^D; eol = <undef>;
eol2 = <undef>; swtch = <undef>; start = ^Q; stop = ^S; susp = ^Z; rprnt = ^R;
werase = ^W; lnext = ^V; flush = ^O; min = 1; time = 0;
-parenb -parodd cs8 -hupcl -cstopb cread -clocal -crtscts
-ignbrk brkint -ignpar -parmrk -inpck -istrip -inlcr -igncr icrnl ixon -ixoff
-iuclc -ixany imaxbel -iutf8
opost -olcuc -ocrnl onlcr -onocr -onlret -ofill -ofdel nl0 cr0 tab0 bs0 vt0 ff0
isig icanon iexten echo echoe echok -echonl -noflsh -xcase -tostop -echoprt
echoctl echoke

Como é apenas um pppdprocesso com esse problema, acho que tem algo a ver com ele ou com sua configuração, mas quando executo pppdfora do tmux, o Ctrl-C funciona. pppdé executado com a nodetachopção, portanto permanece em primeiro plano do terminal.

Também testei na minha máquina de desenvolvimento (Debian 6.0 em amd64) com os mesmos resultados.

zaadeh
fonte
6
Será que stty -amostrar intr = ^C? Caso contrário, qual é a intrconfiguração? (Nota: stty -a | grep intrnão funcionará, pois faz a sttygravação em um canal, e não no seu tty.) Ctrl-V Ctrl-C ecoa ^C? Se não, o que ecoa?
9788 Keith Thompson #
@KeithThompson Ctrl-V imprime um ^e Ctrl-C adiciona um Ca ele.
Zaadeh 7/10
7
Isso parece óbvio demais, mas existe um trapcomando no script de shell?
Keith Thompson
1
pppdnão tem nada a dizer sobre o que seu shell subjacente decide fazer com um SIGINT direto. Tente escrever um pequeno script de shell que chame / bin / sleep 600 e envie um processo SIGINT ao shell, você verá exatamente a mesma coisa.
Andrew B
2
Não conheço o tmux o suficiente, mas suspeito que o pppd detecte que ele não possui um terminal, apesar de rodar no tmux, e depois ignore os sinais INT. um rastro de pppd enquanto ele é iniciado, bem como quando o tmux é "Detatched" na primeira vez, provavelmente será revelador.
28413 Johan Johan

Respostas:

2

Você já pensou em dar uma chance à tela do GNU? Para ser sincero, não tenho muita experiência com o tmux, mas a tela sempre fazia bem o trabalho.

Alessandro Meyer
fonte
A tela é sexy e fantástica. Um +1 para você.
root
0

Aconteceu que havia um bug na versão específica pppdque estava sendo usada na distribuição. Verifiquei e as versões anteriores e posteriores pppddo não têm esse problema. Além disso, o problema não é específico para este arco e plataforma ou tmux. Se pppdestiver sendo executado dentro de um script de shell, ele não manipula Ctrl-C, enquanto que fora do shell, não há problema.

zaadeh
fonte