ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [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