From: Sergey Vlasov <vsu@altlinux.ru> To: devel-kernel@altlinux.ru Subject: Re: [d-kernel] о pppd, группах процессов, терминалах, /dev/pts и SIGHUP Date: Thu, 13 Oct 2005 14:04:32 +0400 Message-ID: <20051013100432.GA12092@master.mivlgu.local> (raw) In-Reply-To: <434D8058.7000308@nm.ru> [-- Attachment #1: Type: text/plain, Size: 2526 bytes --] On Thu, Oct 13, 2005 at 12:30:00AM +0300, Artem wrote: > Небольшое введение. Имеется аппаратный модем на /dev/ttyS0. + pppd . При > разрыве соединения по вине модема - pppd шлется SIGHUP. Насколько я > понял из чтения исходников kernel, ядром ( см. tty_io.c ) посылаются > SIGHUP и SIGCONT группе процессов, связанных с данным терминалом. Т.е. > выполняется функция do_tty_hangup (см. kernel-source/drivers/char/tty_io.c). Именно так (драйвер порта вызывает tty_hangup()). > Далее.. Имеется софтмодем (slmodemd + snd_intel8x0m). Работает все это > дело через /dev/pts (устройство > модема /dev/ttySLM0 является symlink-ом на /dev/ptx/x, где x - вирт. > вторичный терминал, выделенный для связи pppd или чего там еще с > slmodemd. Slmodemd слушает на другом конце - /dev/ptmx > Вопрос. Как реализовать поведение /dev/pts, аналогичное с поведением > /dev/ttySx ? Судя по исходникам /dev/pts - это всего лишь фс (в > подробностях реализации не разбирался - это каналы? ). devpts просто автоматически создаёт файлы устройств для slave-терминалов при открытии /dev/ptmx (при каждом открытии создаётся новый терминал). Дальнейшая работа идёт одинаково и для /dev/ptmx, и для BSD-style /dev/pty* (где программа должна самостоятельно искать свободное устройство, перебирая файлы в /dev). > Функций, подобных tty_hangup в /dev/pts я не обнаружил. Эти функции лежат в drivers/char/pty.c. > Неужели единственным вариантом является сканирование /proc на > предмет открытого процессами /dev/pts/x и отсылка всем обнаруженным > процессам SIGHUP- а? tty_vhangup() для slave вызывается при закрытии master-а. Т.е., при разрыве соединения slmodemd должен закрыть дескриптор, полученный при открытии /dev/ptmx. Перед закрытием нужно открыть /dev/ptmx ещё раз, получить новое имя slave и перенаправить ссылку /dev/ttySL* на него; после закрытия нужно переключиться на использование нового дескриптора вместо закрытого. (Если переоткрывать /dev/ptmx после закрытия предыдущего, в течение некоторого времени /dev/ttySL* будет указывать на несуществующий терминал, что нежелательно.) Да, права на /dev/ttySL* при этом будут каждый раз слетать - их тоже придётся переустанавливать. > Ведь при обрыве соединения по вине софтмодема - pppd работает > дальше, не зная о том, что физический уровень уже давно в дауне. > Соответственно - никакого пересоединения. Для pppd это можно пытаться обходить костылями, указанными в соседнем письме, но в общем случае это не решает проблему. [-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]
next prev parent reply other threads:[~2005-10-13 10:04 UTC|newest] Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top 2005-10-12 21:30 Artem 2005-10-13 8:10 ` Yuriy Kashirin 2005-10-13 9:31 ` Artem 2005-10-13 10:04 ` Sergey Vlasov [this message] 2005-10-13 10:48 ` Artem
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20051013100432.GA12092@master.mivlgu.local \ --to=vsu@altlinux.ru \ --cc=devel-kernel@altlinux.ru \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
ALT Linux kernel packages development This inbox may be cloned and mirrored by anyone: git clone --mirror http://lore.altlinux.org/devel-kernel/0 devel-kernel/git/0.git # If you have public-inbox 1.1+ installed, you may # initialize and index your mirror using the following commands: public-inbox-init -V2 devel-kernel devel-kernel/ http://lore.altlinux.org/devel-kernel \ devel-kernel@altlinux.org devel-kernel@altlinux.ru devel-kernel@altlinux.com public-inbox-index devel-kernel Example config snippet for mirrors. Newsgroup available over NNTP: nntp://lore.altlinux.org/org.altlinux.lists.devel-kernel AGPL code for this site: git clone https://public-inbox.org/public-inbox.git