/* Copyright 2016 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. */ #ifndef CRAS_OBSERVER_H #define CRAS_OBSERVER_H #include "cras_observer_ops.h" struct cras_observer_client; /* Add an observer. * Args: * ops - Set callback function pointers in the operations that should be * called for state changes, or NULL otherwise. * context - Context pointer passed to the callbacks. * Returns: * Valid pointer to the client reference, or NULL on memory allocation * error. */ struct cras_observer_client *cras_observer_add( const struct cras_observer_ops *ops, void *context); /* Retrieve the observed state changes. * Args: * client - The client to query. * ops - Filled with the current values in the callback table. */ void cras_observer_get_ops(const struct cras_observer_client *client, struct cras_observer_ops *ops); /* Update the observed state changes. * Args: * client - The client to modify. * ops - Set callback function pointers in the operations that should be * called for state changes, or NULL otherwise. */ void cras_observer_set_ops(struct cras_observer_client *client, const struct cras_observer_ops *ops); /* Returns non-zero if the given ops are empty. */ int cras_observer_ops_are_empty(const struct cras_observer_ops *ops); /* Remove this observer client. * Args: * client - The client to remove. */ void cras_observer_remove(struct cras_observer_client *client); /* Initialize the observer server. */ int cras_observer_server_init(); /* Destroy the observer server. */ void cras_observer_server_free(); /* Notify observers of output volume change. */ void cras_observer_notify_output_volume(int32_t volume); /* Notify observers of output mute change. */ void cras_observer_notify_output_mute(int muted, int user_muted, int mute_locked); /* Notify observers of capture gain change. */ void cras_observer_notify_capture_gain(int32_t gain); /* Notify observers of capture mute change. */ void cras_observer_notify_capture_mute(int muted, int mute_locked); /* Notify observers of a nodes list change. */ void cras_observer_notify_nodes(void); /* Notify observers of active output node change. */ void cras_observer_notify_active_node(enum CRAS_STREAM_DIRECTION dir, cras_node_id_t node_id); /* Notify observers of output node volume change. */ void cras_observer_notify_output_node_volume(cras_node_id_t node_id, int32_t volume); /* Notify observers of node left-right swap change. */ void cras_observer_notify_node_left_right_swapped(cras_node_id_t node_id, int swapped); /* Notify observers of input node gain change. */ void cras_observer_notify_input_node_gain(cras_node_id_t node_id, int32_t gain); /* Notify observers of suspend state changed. */ void cras_observer_notify_suspend_changed(int suspended); /* Notify observers of the number of active streams. */ void cras_observer_notify_num_active_streams(enum CRAS_STREAM_DIRECTION dir, uint32_t num_active_streams); /* Notify observers of the timestamp when hotword triggered. */ void cras_observer_notify_hotword_triggered(int64_t tv_sec, int64_t tv_nsec); /* Notify observers the non-empty audio state changed. */ void cras_observer_notify_non_empty_audio_state_changed(int active); #endif /* CRAS_OBSERVER_H */