/* Simple Plugin API */ /* SPDX-FileCopyrightText: Copyright © 2023 Wim Taymans */ /* SPDX-License-Identifier: MIT */ #ifndef SPA_PARAM_LATENY_H #define SPA_PARAM_LATENY_H #ifdef __cplusplus extern "C" { #endif /** * \addtogroup spa_param * \{ */ #include /** * Properties for SPA_TYPE_OBJECT_ParamLatency * * The latency indicates: * * - for playback: time delay between start of a graph cycle, and the rendering of * the first sample of that cycle in audio output. * * - for capture: time delay between start of a graph cycle, and the first sample * of that cycle having occurred in audio input. * * For physical output/input, the latency is intended to correspond to the * rendering/capture of physical audio, including hardware internal rendering delay. * * The latency values are adjusted by \ref SPA_PROP_latencyOffsetNsec or * SPA_PARAM_ProcessLatency, if present. (e.g. for ALSA this is used to adjust for * the internal hardware latency). */ enum spa_param_latency { SPA_PARAM_LATENCY_START, SPA_PARAM_LATENCY_direction, /**< direction, input/output (Id enum spa_direction) */ SPA_PARAM_LATENCY_minQuantum, /**< min latency relative to quantum (Float) */ SPA_PARAM_LATENCY_maxQuantum, /**< max latency relative to quantum (Float) */ SPA_PARAM_LATENCY_minRate, /**< min latency (Int) relative to graph rate */ SPA_PARAM_LATENCY_maxRate, /**< max latency (Int) relative to graph rate */ SPA_PARAM_LATENCY_minNs, /**< min latency (Long) in nanoseconds */ SPA_PARAM_LATENCY_maxNs, /**< max latency (Long) in nanoseconds */ }; /** helper structure for managing latency objects */ struct spa_latency_info { enum spa_direction direction; float min_quantum; float max_quantum; int32_t min_rate; int32_t max_rate; int64_t min_ns; int64_t max_ns; }; #define SPA_LATENCY_INFO(dir,...) ((struct spa_latency_info) { .direction = (dir), ## __VA_ARGS__ }) /** * Properties for SPA_TYPE_OBJECT_ParamProcessLatency * * The processing latency indicates logical time delay between a sample in an input port, * and a corresponding sample in an output port, relative to the graph time. */ enum spa_param_process_latency { SPA_PARAM_PROCESS_LATENCY_START, SPA_PARAM_PROCESS_LATENCY_quantum, /**< latency relative to quantum (Float) */ SPA_PARAM_PROCESS_LATENCY_rate, /**< latency (Int) relative to graph rate */ SPA_PARAM_PROCESS_LATENCY_ns, /**< latency (Long) in nanoseconds */ }; /** Helper structure for managing process latency objects */ struct spa_process_latency_info { float quantum; int32_t rate; int64_t ns; }; #define SPA_PROCESS_LATENCY_INFO_INIT(...) ((struct spa_process_latency_info) { __VA_ARGS__ }) /** * \} */ #ifdef __cplusplus } /* extern "C" */ #endif #endif /* SPA_PARAM_LATENY_H */