[pulseaudio-discuss] [PATCH v0 03/11] dbus: Support dynamically created card profiles
Mikel Astiz
mikel.astiz.oss at gmail.com
Mon Oct 22 01:46:35 PDT 2012
From: Mikel Astiz <mikel.astiz at bmw-carit.de>
If a port availability update is received and the corresponding card
profile was not previously registered, it means the profile has been
created dynamically. Therefore, the D-Bus objects need to be updated.
---
src/modules/dbus/iface-card.c | 30 ++++++++++++++++++++++++++++++
1 file changed, 30 insertions(+)
diff --git a/src/modules/dbus/iface-card.c b/src/modules/dbus/iface-card.c
index 89e3988..4db1c01 100644
--- a/src/modules/dbus/iface-card.c
+++ b/src/modules/dbus/iface-card.c
@@ -60,6 +60,8 @@ struct pa_dbusiface_card {
pa_card_profile *active_profile;
pa_proplist *proplist;
+ pa_hook_slot *port_available_changed_slot;
+
pa_dbus_protocol *dbus_protocol;
pa_subscription *subscription;
};
@@ -478,6 +480,29 @@ static void subscription_cb(pa_core *core, pa_subscription_event_type_t t, uint3
}
}
+static pa_hook_result_t port_available_changed_cb(void *hook_data, void *call_data, void *slot_data) {
+ pa_core *core = hook_data;
+ pa_dbusiface_card *c = slot_data;
+ pa_device_port *port = call_data;
+ void *state;
+ pa_card_profile *profile;
+
+ if (pa_hashmap_get(c->card->ports, port->name) != port)
+ return PA_HOOK_OK;
+
+ PA_HASHMAP_FOREACH(profile, port->profiles, state) {
+ pa_dbusiface_card_profile *p;
+
+ if (pa_hashmap_get(c->profiles, profile->name) != NULL)
+ continue;
+
+ p = pa_dbusiface_card_profile_new(c, core, profile, c->next_profile_index++);
+ pa_hashmap_put(c->profiles, pa_dbusiface_card_profile_get_name(p), p);
+ }
+
+ return PA_HOOK_OK;
+}
+
pa_dbusiface_card *pa_dbusiface_card_new(pa_dbusiface_core *core, pa_card *card) {
pa_dbusiface_card *c = NULL;
pa_card_profile *profile;
@@ -504,6 +529,9 @@ pa_dbusiface_card *pa_dbusiface_card_new(pa_dbusiface_core *core, pa_card *card)
pa_assert_se(pa_dbus_protocol_add_interface(c->dbus_protocol, c->path, &card_interface_info, c) >= 0);
+ c->port_available_changed_slot = pa_hook_connect(&card->core->hooks[PA_CORE_HOOK_PORT_AVAILABLE_CHANGED], PA_HOOK_NORMAL,
+ port_available_changed_cb, c);
+
return c;
}
@@ -520,6 +548,8 @@ void pa_dbusiface_card_free(pa_dbusiface_card *c) {
pa_assert_se(pa_dbus_protocol_remove_interface(c->dbus_protocol, c->path, card_interface_info.name) >= 0);
+ pa_hook_slot_free(c->port_available_changed_slot);
+
pa_hashmap_free(c->profiles, profile_free_cb, NULL);
pa_proplist_free(c->proplist);
pa_dbus_protocol_unref(c->dbus_protocol);
--
1.7.11.7
More information about the pulseaudio-discuss
mailing list