Ctrl-C non funziona con la sessione non staccata di pppd


12

Ho una scheda ARM Mini2440 e ho usato un sistema Debian 6.0 di base multistrap.

Ho usato tmuxper eseguire diversi processi in finestre diverse da /etc/rc.local. Mi collego alla scheda usando la sua porta seriale e una voce inittab per funzionare gettysu quella porta. Uso picocomcome comunicatore seriale.

Quando il root accede, ~/.bashrclo collega al server tmux già in esecuzione e i processi possono essere facilmente monitorati. il comando effettivo è exec tmux attach-session -t "main". tmux funziona con la configurazione predefinita.

Tutto funziona, tranne uno dei processi (uno script di shell in giro pppd) non riceve Ctrlcdal terminale, mentre altri processi lo fanno. Ctrl\Funziona anche . funziona anche kill -INT <pppd_pid>, ma kill -INT <shellscript_pid>non.

Ho davvero bisogno Ctrlcdi lavorare. Cosa c'è di sbagliato in questa configurazione?

Modifica: ecco l'output di stty -anello script shell, subito prima di 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

dato che è solo il pppdprocesso che ha questo problema, penso che abbia qualcosa a che fare con esso o con la sua configurazione, ma quando corro pppdfuori da tmux, Ctrl-C funziona. pppdfunziona con l' nodetachopzione, quindi rimane in primo piano terminale.

L'ho anche testato sulla mia macchina dev (Debian 6.0 su amd64) con gli stessi risultati.


6
Non stty -amostrare intr = ^C? In caso contrario, qual è l' intrimpostazione? (Nota: stty -a | grep intrnon funzionerà, dal momento che fa sttyscrivere su una pipe piuttosto che sulla tua tty.) Ctrl-V Ctrl-C fa eco ^C? In caso contrario, cosa fa eco?
Keith Thompson,

@KeithThompson Ctrl-V stampa a ^e Ctrl-C aggiunge Ca.
zaadeh,

7
Questo sembra troppo ovvio, ma c'è un trapcomando nello script della shell?
Keith Thompson,

1
pppdnon ha voce in capitolo su ciò che la sua shell sottostante decide di fare con un SIGINT diretto. Prova a scrivere un piccolo script shell che invoca / bin / sleep 600 e invia al processo shell un SIGINT, vedrai esattamente la stessa cosa.
Andrew B,

2
Non conosco abbastanza bene tmux ma sospetto che pppd rilevi che non ha un terminale nonostante funzioni sotto tmux e quindi ignora i segnali INT. una traccia di pppd mentre è avviata, così come quando tmux viene "Staccato" la prima volta, probabilmente lo dirà.
Johan,

Risposte:


2

Hai mai pensato di provare lo schermo GNU? Ad essere sincero, non ho molta esperienza con tmux, ma lo schermo ha sempre fatto bene il lavoro.


Lo schermo è sexy e fantastico. Un +1 per te.
radice

0

Si è scoperto che si trattava di un bug nella particolare versione pppdutilizzata nella distribuzione. Ho controllato e le versioni precedenti e successive pppdnon presentano questo problema. Inoltre il problema non è specifico di questo arco e piattaforma o tmux. Se pppdviene eseguito all'interno di uno script di shell, non gestisce Ctrl-C, mentre all'esterno della shell non ha problemi.

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.