Ctrl-C nie działa z nie odłączoną sesją pppd


12

Mam płytkę ARM Mini2440 i umieściłem na niej podstawowy system Debian 6.0 multistrap.

Kiedyś tmuxuruchamiałem kilka procesów w różnych oknach /etc/rc.local. Łączę się z płytą za pomocą portu szeregowego i wpisu inittab, aby uruchomić gettyna tym porcie. Używam picocomjako komunikatora szeregowego.

Gdy root się loguje, ~/.bashrcdołącza go do już działającego serwera tmux, a procesy można łatwo monitorować. rzeczywiste polecenie to exec tmux attach-session -t "main". tmux działa z domyślną konfiguracją.

Wszystko działa, z wyjątkiem jednego procesu (skrypt powłoki pppd) nie odbiera Ctrlcz terminala, podczas gdy inne procesy tak. Ctrl\Działa również . działa również kill -INT <pppd_pid>, ale kill -INT <shellscript_pid>nie działa.

Naprawdę muszę Ctrlcpracować. Co jest nie tak z tą konfiguracją?

Edycja: oto wynik działania stty -askryptu powłoki, tuż przed 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

ponieważ jest to pppdproces, który ma ten problem, myślę, że ma to coś wspólnego z jego konfiguracją, ale kiedy uruchamiam pppdpoza Tmuxem, Ctrl-C działa. pppddziała z nodetachopcją, więc pozostaje na pierwszym planie terminala.

Przetestowałem to również na moim komputerze deweloperskim (Debian 6.0 na amd64) z tymi samymi wynikami.


6
Czy stty -apokazuje intr = ^C? Jeśli nie, jakie jest intrustawienie? (Uwaga: stty -a | grep intrnie będzie działać, ponieważ powoduje sttyzapis w potoku zamiast w tty.) Czy echo Ctrl-V Ctrl-C ^C? Jeśli nie, co to odbija?
Keith Thompson

@KeithThompson Ctrl-V drukuje a, ^a Ctrl-C dodaje Cdo niego.
zaadeh

7
To wydaje się zbyt oczywiste, ale czy trapw skrypcie powłoki jest polecenie?
Keith Thompson

1
pppdnie ma wpływu na to, co decyduje o tym jego powłoka bazowa z bezpośrednim SIGINT. Spróbuj napisać mały skrypt powłoki, który wywołuje / bin / sleep 600 i wysyła proces powłoki SIGINT, zobaczysz dokładnie to samo.
Andrew B,

2
Nie znam wystarczająco dobrze Tmux, ale podejrzewam, że pppd wykrywa, że ​​nie ma terminala pomimo działania pod tmux, a następnie ignoruje sygnały INT. ślad pppd podczas jego uruchamiania, a także, gdy tmux jest „Detched” po raz pierwszy, prawdopodobnie będzie mówił.
Johan

Odpowiedzi:


2

Czy myślałeś kiedyś o wypróbowaniu ekranu GNU? Szczerze mówiąc, nie mam dużego doświadczenia z tmux, ale ekran zawsze dobrze sobie radził.


Ekran jest seksowny i fantastyczny. +1 dla Ciebie.
root

0

Okazało się, że był to błąd w konkretnej wersji, pppdktóra była używana w dystrybucji. Sprawdziłem i poprzednie i późniejsze wersje pppdnie mają tego problemu. Również problem nie jest specyficzny dla tego łuku i platformy lub tmux. Jeśli pppdjest uruchamiany w skrypcie powłoki, nie obsługuje Ctrl-C, a poza powłoką nie ma problemu.

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.