pa_hook_slot *card_new_hook_slot;
pa_hook_slot *card_put_hook_slot;
pa_hook_slot *card_profile_hook_slot;
- pa_hook_slot *port_new_hook_slot;
pa_hook_slot *port_offset_hook_slot;
pa_time_event *save_time_event;
pa_database *database;
return p_info;
}
-static void port_info_update(struct port_info *p_info, pa_device_port *port) {
- pa_assert(p_info);
- pa_assert(port);
-
- pa_xfree(p_info->name);
- p_info->name = pa_xstrdup(port->name);
- p_info->offset = port->latency_offset;
-}
-
static void port_info_free(struct port_info *p_info) {
pa_assert(p_info);
return PA_HOOK_OK;
}
-static pa_hook_result_t card_port_add_callback(pa_core *c, pa_device_port *port, struct userdata *u) {
- struct entry *entry;
- pa_card *card;
-
- pa_assert(port);
- card = port->card;
-
- if ((entry = entry_read(u, card->name))) {
- struct port_info *p_info;
-
- if ((p_info = pa_hashmap_get(entry->ports, port->name)))
- port_info_update(p_info, port);
- else {
- p_info = port_info_new(port);
- pa_assert_se(pa_hashmap_put(entry->ports, p_info->name, p_info) >= 0);
- }
-
- pa_log_info("Storing port info for port %s on card %s.", port->name, card->name);
-
- } else {
- entry = entry_from_card(card);
- show_full_info(card);
- }
-
- if (entry_write(u, card->name, entry))
- trigger_save(u);
-
- entry_free(entry);
- return PA_HOOK_OK;
-}
-
static pa_hook_result_t port_offset_change_callback(pa_core *c, pa_device_port *port, struct userdata *u) {
struct entry *entry;
pa_card *card;
u->card_new_hook_slot = pa_hook_connect(&m->core->hooks[PA_CORE_HOOK_CARD_NEW], PA_HOOK_EARLY, (pa_hook_cb_t) card_new_hook_callback, u);
u->card_put_hook_slot = pa_hook_connect(&m->core->hooks[PA_CORE_HOOK_CARD_PUT], PA_HOOK_NORMAL, (pa_hook_cb_t) card_put_hook_callback, u);
u->card_profile_hook_slot = pa_hook_connect(&m->core->hooks[PA_CORE_HOOK_CARD_PROFILE_CHANGED], PA_HOOK_NORMAL, (pa_hook_cb_t) card_profile_change_callback, u);
- u->port_new_hook_slot = pa_hook_connect(&m->core->hooks[PA_CORE_HOOK_PORT_ADDED], PA_HOOK_NORMAL, (pa_hook_cb_t) card_port_add_callback, u);
u->port_offset_hook_slot = pa_hook_connect(&m->core->hooks[PA_CORE_HOOK_PORT_LATENCY_OFFSET_CHANGED], PA_HOOK_NORMAL, (pa_hook_cb_t) port_offset_change_callback, u);
u->hooks_connected = true;
pa_hook_slot_free(u->card_new_hook_slot);
pa_hook_slot_free(u->card_put_hook_slot);
pa_hook_slot_free(u->card_profile_hook_slot);
- pa_hook_slot_free(u->port_new_hook_slot);
pa_hook_slot_free(u->port_offset_hook_slot);
}
pa_hook_fire(&c->core->hooks[PA_CORE_HOOK_CARD_PROFILE_ADDED], profile);
}
-void pa_card_add_ports(pa_card *c, pa_hashmap *ports) {
- pa_device_port *p;
- void *state;
-
- pa_assert(c);
- pa_assert(ports);
-
- /* take ownership of the ports */
- PA_HASHMAP_FOREACH(p, ports, state) {
- p->card = c;
- pa_assert_se(pa_hashmap_put(c->ports, p->name, p) >= 0);
- }
-
- pa_subscription_post(c->core, PA_SUBSCRIPTION_EVENT_CARD|PA_SUBSCRIPTION_EVENT_CHANGE, c->index);
-
- while ((p = pa_hashmap_steal_first(ports)) != NULL)
- pa_hook_fire(&c->core->hooks[PA_CORE_HOOK_PORT_ADDED], p);
-}
-
void pa_card_new_data_set_profile(pa_card_new_data *data, const char *profile) {
pa_assert(data);