Ctrl-C не работает с неотключенным сеансом pppd


12

У меня есть плата ARM Mini2440, и я установил на нее базовую систему Debian 6.0 multistrap.

Я использовал tmuxдля запуска нескольких процессов в разных окнах из /etc/rc.local. Я подключаюсь к плате, используя ее последовательный порт и запись inittab для запуска gettyна этом порту. Я использую picocomкак последовательный коммуникатор.

Когда root входит в систему, ~/.bashrcприсоединяет его к уже запущенному серверу tmux, и процессы можно легко контролировать. фактическая команда exec tmux attach-session -t "main". tmux работает с конфигурацией по умолчанию.

Все работает, кроме одного из процессов (сценарий оболочки pppd) не получает Ctrlcот терминала, в то время как другие процессы делают. Также Ctrl\работает. тоже kill -INT <pppd_pid>работает, но kill -INT <shellscript_pid>нет.

Мне действительно нужно Ctrlcработать. Что не так с этой настройкой?

Изменить: вот вывод stty -aв сценарии оболочки, прямо перед 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

так как pppdэта проблема связана с процессом, я думаю, что это как-то связано с ним или его конфигурацией, но когда я запускаю pppdвне tmux, Ctrl-C работает. pppdработает с nodetachопцией, поэтому он остается на переднем плане терминала.

Я также протестировал его на моей машине разработчика (Debian 6.0 на amd64) с теми же результатами.


6
Есть ли stty -aшоу intr = ^C? Если нет, какие intrнастройки? (Примечание: stty -a | grep intrне будет работать, так как это делает sttyзапись в канал, а не в ваш tty.) Отвечает ли Ctrl-V Ctrl-C ^C? Если нет, что это эхо?
Кит Томпсон

@KeithThompson Ctrl-V печатает a, ^а Ctrl-C добавляет Cк нему.
Зааде

7
Это кажется слишком очевидным, но есть ли trapкоманда в сценарии оболочки?
Кит Томпсон

1
pppdне имеет никакого отношения к тому, что его основная оболочка решает сделать с прямым SIGINT. Попробуйте написать крошечный сценарий оболочки, который вызывает / bin / sleep 600 и отправит процессу оболочки SIGINT, вы увидите точно такую ​​же вещь.
Андрей Б

2
Я недостаточно хорошо знаю tmux, но подозреваю, что pppd обнаруживает, что у него нет терминала, несмотря на то, что он работает под tmux, а затем игнорирует сигналы INT. трассировка pppd во время его запуска, а также когда tmux "Datatched" в первый раз, вероятно, будет показывать.
Йохан

Ответы:


2

Вы когда-нибудь задумывались о том, чтобы попробовать экран givin GNU? Честно говоря, у меня нет большого опыта работы с tmux, но screen всегда справлялся со своей задачей.


Экран сексуальный и фантастический. +1 для вас.
root

0

Оказалось, что это была ошибка в той версии pppd, которая использовалась в дистрибутиве. Я проверил и предыдущие и более поздние версии pppdне имеют этой проблемы. Также проблема не является специфичной для этой арки и платформы или tmux. Если pppdон запускается внутри сценария оболочки, он не обрабатывает Ctrl-C, в то время как вне оболочки он не имеет проблем.

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.