* [devel] Q: проблемы в отлове перезапуска халдыбаса
@ 2008-01-02 16:15 Alexey I. Froloff
2008-01-02 19:18 ` [devel] A: " Alexey I. Froloff
` (2 more replies)
0 siblings, 3 replies; 4+ messages in thread
From: Alexey I. Froloff @ 2008-01-02 16:15 UTC (permalink / raw)
To: ALT Devel discussion list
[-- Attachment #1: Type: text/plain, Size: 1623 bytes --]
Либо я совсем тупой, либо одно из двух.
Пытаюсь отловить перезапуск hal и dbus в своей софтине. Код
честно стырил из ivman (pulseaudio и powersaved с hal не
работают). План действий следующий:
1. Говорим DBus'у не делать _exit() при отвале коннекта.
2. Вешаем обработчик сигнала от DBus.
По сигналу Disconnected от DBus unref'им открытый коннект и
ставим в mainloop вызов процедуры реконнекта. Я пытался в этом
месте звать ещё и libhal_ctx_shutdown(), но ловил сегфолт.
Процедура реконнекта будет вызываться периодически, пока коннект
не появится (делается средствами glib).
По сигналу NameOwnerChanged от org.freedesktop.Hal если:
1. Старый owner валидный, а новый нет - зовём
libhal_ctx_shutdown().
2. Старый owner не валидный, а новый валидный - опять инитим hal.
Это всё есть в сорцах ivman.
Проблема в следующем:
Если сразу перезапустить DBus, моя софтина получает
NameOwnerChanged от Hal и сегфолтится.
Если перезапустить Hal, софтина получает два NameOwnerChanged и
работает дальше.
Если сначала перезапустить Hal, а потом сколько угодно раз
перезапускать DBus, то при перезапуске DBus будет ловиться
Disconnected и программа работает нормально.
Если отключить пляски с Hal картина будет следующая:
При первом перезапуске DBus будут вызываться:
NameOwnerChanged со смыслом "Hal ушёл"
Disconnected от DBus
NameOwnerChanged со смыслом "Hal пришёл"
При последующих перезапусках DBus сигнал "Hal ушёл" ко мне
попадать не будет.
Собсно, вопрос. Что с этим всем делать и не сегфолтится ли у
кого ivman при перезапуске DBus?
--
Regards,
Sir Raorn.
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 189 bytes --]
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [devel] A: проблемы в отлове перезапуска халдыбаса
2008-01-02 16:15 [devel] Q: проблемы в отлове перезапуска халдыбаса Alexey I. Froloff
@ 2008-01-02 19:18 ` Alexey I. Froloff
2008-01-03 5:38 ` [devel] Q: " Ildar Mulyukov
2008-01-03 15:53 ` Alexey I. Froloff
2 siblings, 0 replies; 4+ messages in thread
From: Alexey I. Froloff @ 2008-01-02 19:18 UTC (permalink / raw)
To: ALT Devel discussion list
[-- Attachment #1: Type: text/plain, Size: 354 bytes --]
* Alexey I. Froloff <raorn@> [080102 19:25]:
> Если сразу перезапустить DBus, моя софтина получает
> NameOwnerChanged от Hal и сегфолтится.
В этом месте помогает проверка на
dbus_connection_get_is_connected(dbus_connection). Если FALSE,
то libhal_ctx_shutdown() звать не надо.
Результат скоро будет в wmvolman.git.
--
Regards,
Sir Raorn.
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 189 bytes --]
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [devel] Q: проблемы в отлове перезапуска халдыбаса
2008-01-02 16:15 [devel] Q: проблемы в отлове перезапуска халдыбаса Alexey I. Froloff
2008-01-02 19:18 ` [devel] A: " Alexey I. Froloff
@ 2008-01-03 5:38 ` Ildar Mulyukov
2008-01-03 15:53 ` Alexey I. Froloff
2 siblings, 0 replies; 4+ messages in thread
From: Ildar Mulyukov @ 2008-01-03 5:38 UTC (permalink / raw)
To: devel
Приветствую!
On 02.01.2008 22:15:56, Alexey I. Froloff wrote:
> Либо я совсем тупой, либо одно из двух.
Это вряд ли ;)
> По сигналу Disconnected от DBus unref'им открытый коннект и
> ставим в mainloop вызов процедуры реконнекта. Я пытался в этом
> месте звать ещё и libhal_ctx_shutdown(), но ловил сегфолт.
Выглядит, как баг в апстрим. Почему бы не?
С уважением, Ильдар
--
Ildar Mulyukov, free SW designer/programmer/packager
=========================================
email: ildar@altlinux.ru
Jabber: ildar@jabber.ru
ICQ: 4334029
ALT Linux Sisyphus http://www.sisyphus.ru
=========================================
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [devel] Q: проблемы в отлове перезапуска халдыбаса
2008-01-02 16:15 [devel] Q: проблемы в отлове перезапуска халдыбаса Alexey I. Froloff
2008-01-02 19:18 ` [devel] A: " Alexey I. Froloff
2008-01-03 5:38 ` [devel] Q: " Ildar Mulyukov
@ 2008-01-03 15:53 ` Alexey I. Froloff
2 siblings, 0 replies; 4+ messages in thread
From: Alexey I. Froloff @ 2008-01-03 15:53 UTC (permalink / raw)
To: ALT Devel discussion list
[-- Attachment #1: Type: text/plain, Size: 629 bytes --]
* Alexey I. Froloff <raorn@> [080102 19:25]:
> Если сразу перезапустить DBus, моя софтина получает
> NameOwnerChanged от Hal и сегфолтится.
> Если сначала перезапустить Hal, а потом сколько угодно раз
> перезапускать DBus, то при перезапуске DBus будет ловиться
> Disconnected и программа работает нормально.
Тут видимо работает принцип "кто первый встал с утра того и
тапки". Обработчик сигнала от Hal в очереди первый, он
обрабатывает Disconnected и шлёт свой сигнал. После перезапуска
Hal мой обработчик в очереди оказывается раньше и я первый
получаю Disconnected. Имейте в виду.
--
Regards,
Sir Raorn.
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 189 bytes --]
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2008-01-03 15:53 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-01-02 16:15 [devel] Q: проблемы в отлове перезапуска халдыбаса Alexey I. Froloff
2008-01-02 19:18 ` [devel] A: " Alexey I. Froloff
2008-01-03 5:38 ` [devel] Q: " Ildar Mulyukov
2008-01-03 15:53 ` Alexey I. Froloff
ALT Linux Team development discussions
This inbox may be cloned and mirrored by anyone:
git clone --mirror http://lore.altlinux.org/devel/0 devel/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 devel/ http://lore.altlinux.org/devel \
devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
public-inbox-index devel
Example config snippet for mirrors.
Newsgroup available over NNTP:
nntp://lore.altlinux.org/org.altlinux.lists.devel
AGPL code for this site: git clone https://public-inbox.org/public-inbox.git