#ifndef foopulsecardhfoo #define foopulsecardhfoo /*** This file is part of PulseAudio. Copyright 2009 Lennart Poettering PulseAudio is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version. PulseAudio is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU Lesser General Public License along with PulseAudio; if not, see . ***/ #include #include #include #include #include /* This enum replaces pa_port_available_t (defined in pulse/def.h) for * internal use, so make sure both enum types stay in sync. */ typedef enum pa_available { PA_AVAILABLE_UNKNOWN = 0, PA_AVAILABLE_NO = 1, PA_AVAILABLE_YES = 2, } pa_available_t; struct pa_card_profile { pa_card *card; char *name; char *description; /* Identifiers for the profile's input and output parts, i e, if two different profiles have the same input_name string, they have the same source(s). Same for output_name and sink(s). Can be NULL (and in case of an input- or output- only profile, the other direction will be NULL). */ char *input_name; char *output_name; unsigned priority; pa_available_t available; /* PA_AVAILABLE_UNKNOWN, PA_AVAILABLE_NO or PA_AVAILABLE_YES */ /* We probably want to have different properties later on here */ unsigned n_sinks; unsigned n_sources; unsigned max_sink_channels; unsigned max_source_channels; /* .. followed by some implementation specific data */ }; #define PA_CARD_PROFILE_DATA(d) ((void*) ((uint8_t*) d + PA_ALIGN(sizeof(pa_card_profile)))) struct pa_card { uint32_t index; pa_core *core; char *name; pa_proplist *proplist; pa_module *module; char *driver; pa_idxset *sinks; pa_idxset *sources; pa_hashmap *profiles; pa_card_profile *active_profile; pa_hashmap *ports; pa_device_port *preferred_input_port; pa_device_port *preferred_output_port; bool save_profile:1; pa_suspend_cause_t suspend_cause; bool linked; void *userdata; int (*set_profile)(pa_card *c, pa_card_profile *profile); }; typedef struct pa_card_new_data { char *name; pa_proplist *proplist; const char *driver; pa_module *module; pa_hashmap *profiles; pa_hashmap *ports; pa_device_port *preferred_input_port; pa_device_port *preferred_output_port; bool namereg_fail:1; } pa_card_new_data; typedef struct { pa_card *card; pa_direction_t direction; } pa_card_preferred_port_changed_hook_data; const char *pa_available_to_string(pa_available_t available); pa_card_profile *pa_card_profile_new(const char *name, const char *description, size_t extra); void pa_card_profile_free(pa_card_profile *c); /* The profile's available status has changed */ void pa_card_profile_set_available(pa_card_profile *c, pa_available_t available); pa_card_new_data *pa_card_new_data_init(pa_card_new_data *data); void pa_card_new_data_set_name(pa_card_new_data *data, const char *name); void pa_card_new_data_set_preferred_port(pa_card_new_data *data, pa_direction_t direction, pa_device_port *port); void pa_card_new_data_done(pa_card_new_data *data); pa_card *pa_card_new(pa_core *c, pa_card_new_data *data); /* Select the initial card profile according to the configured policies. This * must be called between pa_card_new() and pa_card_put(), after the port and * profile availabilities have been initialized. */ void pa_card_choose_initial_profile(pa_card *card); void pa_card_put(pa_card *c); void pa_card_free(pa_card *c); void pa_card_add_profile(pa_card *c, pa_card_profile *profile); int pa_card_set_profile(pa_card *c, pa_card_profile *profile, bool save); void pa_card_set_preferred_port(pa_card *c, pa_direction_t direction, pa_device_port *port); int pa_card_suspend(pa_card *c, bool suspend, pa_suspend_cause_t cause); #endif