/* Copyright (c) 2012 The Chromium OS Authors. All rights reserved. * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ /* * IO list manages the list of inputs and outputs available. */ #ifndef CRAS_IODEV_LIST_H_ #define CRAS_IODEV_LIST_H_ #include <stdbool.h> #include <stdint.h> #include "cras_types.h" struct cras_iodev; struct cras_iodev_info; struct cras_ionode; struct cras_rclient; struct cras_rstream; struct cras_audio_format; struct stream_list; /* Device enabled/disabled callback. */ typedef void (*device_enabled_callback_t)(struct cras_iodev *dev, void *cb_data); typedef void (*device_disabled_callback_t)(struct cras_iodev *dev, void *cb_data); /* Initialize the list of iodevs. */ void cras_iodev_list_init(); /* Clean up any resources used by iodev. */ void cras_iodev_list_deinit(); /* Adds an output to the output list. * Args: * output - the output to add. * Returns: * 0 on success, negative error on failure. */ int cras_iodev_list_add_output(struct cras_iodev *output); /* Adds an input to the input list. * Args: * input - the input to add. * Returns: * 0 on success, negative error on failure. */ int cras_iodev_list_add_input(struct cras_iodev *input); /* Removes an output from the output list. * Args: * output - the output to remove. * Returns: * 0 on success, negative error on failure. */ int cras_iodev_list_rm_output(struct cras_iodev *output); /* Removes an input from the input list. * Args: * output - the input to remove. * Returns: * 0 on success, negative error on failure. */ int cras_iodev_list_rm_input(struct cras_iodev *input); /* Gets a list of outputs. Callee must free the list when finished. If list_out * is NULL, this function can be used to return the number of outputs. * Args: * list_out - This will be set to the malloc'd area containing the list of * devices. Ignored if NULL. * Returns: * The number of devices on the list. */ int cras_iodev_list_get_outputs(struct cras_iodev_info **list_out); /* Gets a list of inputs. Callee must free the list when finished. If list_out * is NULL, this function can be used to return the number of inputs. * Args: * list_out - This will be set to the malloc'd area containing the list of * devices. Ignored if NULL. * Returns: * The number of devices on the list. */ int cras_iodev_list_get_inputs(struct cras_iodev_info **list_out); /* Returns the first enabled device. * Args: * direction - Playback or capture. * Returns: * Pointer to the first enabled device of direction. */ struct cras_iodev *cras_iodev_list_get_first_enabled_iodev( enum CRAS_STREAM_DIRECTION direction); /* Returns the active node id. * Args: * direction - Playback or capture. * Returns: * The id of the active node. */ cras_node_id_t cras_iodev_list_get_active_node_id( enum CRAS_STREAM_DIRECTION direction); /* Stores the following data to the shared memory server state region: * (1) device list * (2) node list * (3) selected nodes */ void cras_iodev_list_update_device_list(); /* Stores the node list in the shared memory server state region. */ void cras_iodev_list_update_node_list(); /* Gets the supported hotword models of an ionode. Caller should free * the returned string after use. */ char *cras_iodev_list_get_hotword_models(cras_node_id_t node_id); /* Sets the desired hotword model to an ionode. */ int cras_iodev_list_set_hotword_model(cras_node_id_t id, const char *model_name); /* Notify that nodes are added/removed. */ void cras_iodev_list_notify_nodes_changed(); /* Notify that active node is changed for the given direction. * Args: * direction - Direction of the node. */ void cras_iodev_list_notify_active_node_changed( enum CRAS_STREAM_DIRECTION direction); /* Sets an attribute of an ionode on a device. * Args: * id - the id of the ionode. * node_index - Index of the ionode on the device. * attr - the attribute we want to change. * value - the value we want to set. */ int cras_iodev_list_set_node_attr(cras_node_id_t id, enum ionode_attr attr, int value); /* Select a node as the preferred node. * Args: * direction - Playback or capture. * node_id - the id of the ionode to be selected. As a special case, if * node_id is 0, don't select any node in this direction. */ void cras_iodev_list_select_node(enum CRAS_STREAM_DIRECTION direction, cras_node_id_t node_id); /* Checks if an iodev is enabled. */ int cras_iodev_list_dev_is_enabled(const struct cras_iodev *dev); /* Enables an iodev. If the fallback device was already enabled, this * call will disable it. */ void cras_iodev_list_enable_dev(struct cras_iodev *dev); /* * Disables an iodev. If this is the last device to disable, the * fallback devices will be enabled accordingly. * Set `foce_close` to true if the device must be closed regardless of having * pinned streams attached. */ void cras_iodev_list_disable_dev(struct cras_iodev *dev, bool force_close); /* Adds a node to the active devices list. * Args: * direction - Playback or capture. * node_id - The id of the ionode to be added. */ void cras_iodev_list_add_active_node(enum CRAS_STREAM_DIRECTION direction, cras_node_id_t node_id); /* Removes a node from the active devices list. * Args: * direction - Playback or capture. * node_id - The id of the ionode to be removed. */ void cras_iodev_list_rm_active_node(enum CRAS_STREAM_DIRECTION direction, cras_node_id_t node_id); /* Returns 1 if the node is selected, 0 otherwise. */ int cras_iodev_list_node_selected(struct cras_ionode *node); /* Notify the current volume of the given node. */ void cras_iodev_list_notify_node_volume(struct cras_ionode *node); /* Notify the current capture gain of the given node. */ void cras_iodev_list_notify_node_capture_gain(struct cras_ionode *node); /* Notify the current left right channel swapping state of the given node. */ void cras_iodev_list_notify_node_left_right_swapped(struct cras_ionode *node); /* Handles the adding and removing of test iodevs. */ void cras_iodev_list_add_test_dev(enum TEST_IODEV_TYPE type); /* Handles sending a command to a test iodev. */ void cras_iodev_list_test_dev_command(unsigned int iodev_idx, enum CRAS_TEST_IODEV_CMD command, unsigned int data_len, const uint8_t *data); /* Gets the audio thread used by the devices. */ struct audio_thread *cras_iodev_list_get_audio_thread(); /* Gets the list of all active audio streams attached to devices. */ struct stream_list *cras_iodev_list_get_stream_list(); /* Sets the function to call when a device is enabled or disabled. */ int cras_iodev_list_set_device_enabled_callback( device_enabled_callback_t enabled_cb, device_disabled_callback_t disabled_cb, void *cb_data); /* Suspends all hotwording streams. */ int cras_iodev_list_suspend_hotword_streams(); /* Resumes all hotwording streams. */ int cras_iodev_list_resume_hotword_stream(); /* For unit test only. */ void cras_iodev_list_reset(); #endif /* CRAS_IODEV_LIST_H_ */