* [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