[pulseaudio-discuss] [PATCH 3/6] Cards now has ports directly, and device port has list of profiles
Tanu Kaskinen
tanuk at iki.fi
Thu Nov 3 12:04:51 PDT 2011
Somehow keeping a list of profiles in the ports doesn't feel right -
it's as if that list would have been thrown there just to make things
convenient for some random code... But I guess there's a reason, which
just isn't apparent from this patch yet, for having that list there.
Not much else to complain about.
--
Tanu
On Thu, 2011-10-27 at 16:45 +0200, David Henningsson wrote:
> This forms the base for being able to expose all ports of all
> profiles (even inactive ones) to clients.
>
> Signed-off-by: David Henningsson <david.henningsson at canonical.com>
> ---
> src/pulsecore/card.c | 9 ++++++++-
> src/pulsecore/card.h | 4 ++++
> src/pulsecore/device-port.c | 5 +++++
> src/pulsecore/device-port.h | 4 ++++
> 4 files changed, 21 insertions(+), 1 deletions(-)
>
> diff --git a/src/pulsecore/card.c b/src/pulsecore/card.c
> index feaa444..2b1a36a 100644
> --- a/src/pulsecore/card.c
> +++ b/src/pulsecore/card.c
> @@ -34,6 +34,7 @@
> #include <pulsecore/macro.h>
> #include <pulsecore/core-util.h>
> #include <pulsecore/namereg.h>
> +#include <pulsecore/device-port.h>
>
> #include "card.h"
>
> @@ -66,7 +67,7 @@ pa_card_new_data* pa_card_new_data_init(pa_card_new_data *data) {
>
> memset(data, 0, sizeof(*data));
> data->proplist = pa_proplist_new();
> -
> + data->ports = pa_hashmap_new(pa_idxset_string_hash_func, pa_idxset_string_compare_func);
> return data;
> }
>
> @@ -99,6 +100,8 @@ void pa_card_new_data_done(pa_card_new_data *data) {
> pa_hashmap_free(data->profiles, NULL, NULL);
> }
>
> + pa_device_port_hashmap_free(data->ports);
Reminder: if the NULL handling changes, this code will need to check
data->ports before calling the function.
> +
> pa_xfree(data->name);
> pa_xfree(data->active_profile);
> }
> @@ -139,6 +142,8 @@ pa_card *pa_card_new(pa_core *core, pa_card_new_data *data) {
> * copying it here */
> c->profiles = data->profiles;
> data->profiles = NULL;
> + c->ports = data->ports;
> + data->ports = NULL;
>
> c->active_profile = NULL;
> c->save_profile = FALSE;
> @@ -195,6 +200,8 @@ void pa_card_free(pa_card *c) {
> pa_assert(pa_idxset_isempty(c->sources));
> pa_idxset_free(c->sources, NULL, NULL);
>
> + pa_device_port_hashmap_free(c->ports);
Same reminder.
> +
> if (c->profiles) {
> pa_card_profile *p;
>
> diff --git a/src/pulsecore/card.h b/src/pulsecore/card.h
> index 2d691b6..6f942e8 100644
> --- a/src/pulsecore/card.h
> +++ b/src/pulsecore/card.h
> @@ -63,6 +63,8 @@ struct pa_card {
> pa_hashmap *profiles;
> pa_card_profile *active_profile;
>
> + pa_hashmap *ports;
> +
> pa_bool_t save_profile:1;
>
> void *userdata;
> @@ -80,6 +82,8 @@ typedef struct pa_card_new_data {
> pa_hashmap *profiles;
> char *active_profile;
>
> + pa_hashmap *ports;
> +
> pa_bool_t namereg_fail:1;
>
> pa_bool_t save_profile:1;
> diff --git a/src/pulsecore/device-port.c b/src/pulsecore/device-port.c
> index 9e6ad43..b30484a 100644
> --- a/src/pulsecore/device-port.c
> +++ b/src/pulsecore/device-port.c
> @@ -30,6 +30,8 @@ static void device_port_free(pa_object *o) {
> pa_assert(p);
> pa_assert(pa_device_port_refcnt(p) == 0);
>
> + if (p->profiles)
> + pa_hashmap_free(p->profiles, NULL, NULL);
pa_assert(pa_hashmap_isempty(p->profiles)) would be nice here.
> pa_xfree(p->name);
> pa_xfree(p->description);
> pa_xfree(p);
> @@ -48,6 +50,9 @@ pa_device_port *pa_device_port_new(const char *name, const char *description, si
> p->description = pa_xstrdup(description);
> p->priority = 0;
> p->available = PA_PORT_AVAILABLE_UNKNOWN;
> + p->profiles = NULL;
> + p->is_input = FALSE;
> + p->is_output = FALSE;
>
> return p;
> }
> diff --git a/src/pulsecore/device-port.h b/src/pulsecore/device-port.h
> index 5b54a62..f01d736 100644
> --- a/src/pulsecore/device-port.h
> +++ b/src/pulsecore/device-port.h
> @@ -45,6 +45,10 @@ struct pa_device_port {
> unsigned priority;
> pa_port_available_t available; /* PA_PORT_AVAILABLE_UNKNOWN, PA_PORT_AVAILABLE_NO or PA_PORT_AVAILABLE_YES */
>
> + pa_hashmap *profiles; /* Can be NULL. Does not own the profiles */
> + pa_bool_t is_input:1;
> + pa_bool_t is_output:1;
> +
> /* .. followed by some implementation specific data */
> };
>
More information about the pulseaudio-discuss
mailing list