diff options
author | Tanu Kaskinen <tanu.kaskinen@digia.com> | 2012-06-29 18:04:55 +0300 |
---|---|---|
committer | Tanu Kaskinen <tanuk@iki.fi> | 2012-10-25 16:47:53 +0300 |
commit | 43454bc48c5afee29a2b0c19e6fb80f9bd98ad58 (patch) | |
tree | c74ab70c3b3017cd349df894b759e4e97a0601f0 /src | |
parent | d0be10191ef492d13b014b9cf2ffad054cd034bf (diff) |
card: Store a pa_card pointer in pa_card_profile.
Diffstat (limited to 'src')
-rw-r--r-- | src/pulsecore/card.c | 23 | ||||
-rw-r--r-- | src/pulsecore/card.h | 1 |
2 files changed, 17 insertions, 7 deletions
diff --git a/src/pulsecore/card.c b/src/pulsecore/card.c index b1daa6352..1cde297cd 100644 --- a/src/pulsecore/card.c +++ b/src/pulsecore/card.c @@ -44,6 +44,7 @@ pa_card_profile *pa_card_profile_new(const char *name, const char *description, pa_assert(name); c = pa_xmalloc(PA_ALIGN(sizeof(pa_card_profile)) + extra); + c->card = NULL; c->name = pa_xstrdup(name); c->description = pa_xstrdup(description); @@ -56,6 +57,7 @@ pa_card_profile *pa_card_profile_new(const char *name, const char *description, void pa_card_profile_free(pa_card_profile *c) { pa_assert(c); + pa_assert(!c->card); /* Card profiles shouldn't be freed before removing them from the card. */ pa_xfree(c->name); pa_xfree(c->description); @@ -85,6 +87,7 @@ void pa_card_add_profile(pa_card *c, pa_card_profile *profile) { /* take ownership of the profile */ pa_assert_se(pa_hashmap_put(c->profiles, profile->name, profile) >= 0); + profile->card = c; pa_subscription_post(c->core, PA_SUBSCRIPTION_EVENT_CARD|PA_SUBSCRIPTION_EVENT_CHANGE, c->index); @@ -140,6 +143,8 @@ void pa_card_new_data_done(pa_card_new_data *data) { pa_card *pa_card_new(pa_core *core, pa_card_new_data *data) { pa_card *c; const char *name; + void *state; + pa_card_profile *profile; pa_core_assert_ref(core); pa_assert(data); @@ -178,6 +183,11 @@ pa_card *pa_card_new(pa_core *core, pa_card_new_data *data) { c->ports = data->ports; data->ports = NULL; + if (c->profiles) { + PA_HASHMAP_FOREACH(profile, c->profiles, state) + profile->card = c; + } + c->active_profile = NULL; c->save_profile = FALSE; @@ -186,12 +196,9 @@ pa_card *pa_card_new(pa_core *core, pa_card_new_data *data) { c->save_profile = data->save_profile; if (!c->active_profile) { - void *state; - pa_card_profile *p; - - PA_HASHMAP_FOREACH(p, c->profiles, state) - if (!c->active_profile || p->priority > c->active_profile->priority) - c->active_profile = p; + PA_HASHMAP_FOREACH(profile, c->profiles, state) + if (!c->active_profile || profile->priority > c->active_profile->priority) + c->active_profile = profile; } c->userdata = NULL; @@ -238,8 +245,10 @@ void pa_card_free(pa_card *c) { if (c->profiles) { pa_card_profile *p; - while ((p = pa_hashmap_steal_first(c->profiles))) + while ((p = pa_hashmap_steal_first(c->profiles))) { + p->card = NULL; pa_card_profile_free(p); + } pa_hashmap_free(c->profiles, NULL, NULL); } diff --git a/src/pulsecore/card.h b/src/pulsecore/card.h index 5b5be817a..d72a293cc 100644 --- a/src/pulsecore/card.h +++ b/src/pulsecore/card.h @@ -30,6 +30,7 @@ typedef struct pa_card pa_card; #include <pulsecore/idxset.h> typedef struct pa_card_profile { + pa_card *card; char *name; char *description; |