75#define SPA_STATUS_OK 0
76#define SPA_STATUS_NEED_DATA (1<<0)
77#define SPA_STATUS_HAVE_DATA (1<<1)
78#define SPA_STATUS_STOPPED (1<<2)
79#define SPA_STATUS_DRAINED (1<<3)
84#define SPA_IO_BUFFERS_INIT ((struct spa_io_buffers) { SPA_STATUS_OK, SPA_ID_INVALID, })
94#define SPA_IO_MEMORY_INIT ((struct spa_io_memory) { SPA_STATUS_OK, 0, NULL, })
130#define SPA_IO_CLOCK_FLAG_FREEWHEEL (1u<<0)
135#define SPA_IO_CLOCK_FLAG_XRUN_RECOVER (1u<<1)
145#define SPA_IO_CLOCK_FLAG_LAZY (1u<<2)
147#define SPA_IO_CLOCK_FLAG_NO_RATE (1u<<3)
150#define SPA_IO_CLOCK_FLAG_DISCONT (1u<<4)
196#define SPA_IO_VIDEO_SIZE_VALID (1<<0)
224#define SPA_IO_SEGMENT_BAR_FLAG_VALID (1<<0)
238#define SPA_IO_SEGMENT_VIDEO_FLAG_VALID (1<<0)
239#define SPA_IO_SEGMENT_VIDEO_FLAG_DROP_FRAME (1<<1)
240#define SPA_IO_SEGMENT_VIDEO_FLAG_PULL_DOWN (1<<2)
241#define SPA_IO_SEGMENT_VIDEO_FLAG_INTERLACED (1<<3)
275#define SPA_IO_SEGMENT_FLAG_LOOPING (1<<0)
276#define SPA_IO_SEGMENT_FLAG_NO_POSITION (1<<1)
307#define SPA_IO_POSITION_MAX_SEGMENTS 8
380#define SPA_IO_RATE_MATCH_FLAG_ACTIVE (1 << 0)
uint32_t id
Definition core.h:432
spa_io_position_state
Definition io.h:325
spa_io_type
IO areas.
Definition io.h:36
#define SPA_IO_POSITION_MAX_SEGMENTS
the maximum number of segments visible in the future
Definition io.h:333
@ SPA_IO_POSITION_STATE_RUNNING
Definition io.h:328
@ SPA_IO_POSITION_STATE_STOPPED
Definition io.h:326
@ SPA_IO_POSITION_STATE_STARTING
Definition io.h:327
@ SPA_IO_AsyncBuffers
async area to exchange buffers, struct spa_io_async_buffers
Definition io.h:47
@ SPA_IO_Notify
area for notify messages, struct spa_io_sequence
Definition io.h:43
@ SPA_IO_Memory
memory pointer, struct spa_io_memory (currently not used in PipeWire)
Definition io.h:46
@ SPA_IO_Clock
area to update clock information, struct spa_io_clock
Definition io.h:40
@ SPA_IO_Control
area for control messages, struct spa_io_sequence
Definition io.h:42
@ SPA_IO_Latency
latency reporting, struct spa_io_latency
Definition io.h:41
@ SPA_IO_Range
expected byte range, struct spa_io_range (currently not used in PipeWire)
Definition io.h:39
@ SPA_IO_Invalid
Definition io.h:37
@ SPA_IO_Position
position information in the graph, struct spa_io_position
Definition io.h:44
@ SPA_IO_Buffers
area to exchange buffers, struct spa_io_buffers
Definition io.h:38
@ SPA_IO_RateMatch
rate matching between nodes, struct spa_io_rate_match
Definition io.h:45
async buffers
Definition io.h:415
struct spa_io_buffers buffers[2]
async buffers, writers write to current (cycle+1)&1, readers read from (cycle)&1
Definition io.h:416
IO area to exchange buffers.
Definition io.h:79
int32_t status
the status code
Definition io.h:90
uint32_t buffer_id
a buffer id
Definition io.h:91
Absolute time reporting.
Definition io.h:141
struct spa_fraction target_rate
Target rate of next cycle.
Definition io.h:203
uint64_t next_nsec
Estimated next wakeup time in nanoseconds.
Definition io.h:198
uint64_t xrun
Estimated accumulated xrun duration.
Definition io.h:208
uint64_t position
Current position, in samples @ rate.
Definition io.h:191
uint32_t cycle
incremented each time the graph is started
Definition io.h:207
uint64_t nsec
Time in nanoseconds against monotonic clock (CLOCK_MONOTONIC).
Definition io.h:186
struct spa_fraction rate
Rate for position/duration/delay/xrun.
Definition io.h:190
double rate_diff
Rate difference between clock and monotonic time, as a ratio of clock speeds.
Definition io.h:194
uint32_t flags
Clock flags.
Definition io.h:181
uint64_t target_duration
Target duration of next cycle.
Definition io.h:204
uint64_t duration
Duration of current cycle, in samples @ rate.
Definition io.h:192
int64_t delay
Delay between position and hardware, in samples @ rate.
Definition io.h:193
uint32_t target_seq
Seq counter.
Definition io.h:205
Latency reporting.
Definition io.h:229
int64_t playback_latency
playback latency
Definition io.h:232
int64_t capture_latency
capture latency
Definition io.h:231
struct spa_fraction rate
rate for latencies
Definition io.h:230
IO area to exchange a memory region.
Definition io.h:100
uint32_t size
the size of data
Definition io.h:102
The position information adds extra meaning to the raw clock times.
Definition io.h:352
struct spa_io_clock clock
clock position of driver, always valid and read only
Definition io.h:353
struct spa_io_video_size video
size of the video in the current cycle
Definition io.h:355
uint32_t state
one of enum spa_io_position_state
Definition io.h:361
uint32_t n_segments
number of segments
Definition io.h:363
struct spa_io_segment segments[SPA_IO_POSITION_MAX_SEGMENTS]
segments
Definition io.h:364
int64_t offset
an offset to subtract from the clock position to get a running time.
Definition io.h:356
A range, suitable for input ports that can suggest a range to output ports.
Definition io.h:109
uint64_t offset
offset in range
Definition io.h:110
uint32_t max_size
maximum size of data
Definition io.h:112
uint32_t min_size
minimum size of data
Definition io.h:111
Rate matching.
Definition io.h:401
int32_t delay_frac
resampling delay fractional part, in units of nanosamples (1/10^9 sample) at node rate
Definition io.h:409
uint32_t padding[6]
Definition io.h:411
uint32_t flags
extra flags (set by node)
Definition io.h:408
double rate
rate for resampler (set by node)
Definition io.h:405
uint32_t delay
resampling delay, in samples at node rate
Definition io.h:402
uint32_t size
requested input size for resampler
Definition io.h:404
bar and beat segment
Definition io.h:241
double beat
current beat in segment
Definition io.h:249
uint32_t padding[4]
Definition io.h:252
double bpm
beats per minute
Definition io.h:248
float signature_denom
time signature denominator
Definition io.h:247
double ticks_per_beat
Definition io.h:251
double bar_start_tick
Definition io.h:250
uint32_t offset
offset in segment of this beat
Definition io.h:245
float signature_num
time signature numerator
Definition io.h:246
uint32_t flags
extra flags
Definition io.h:244
video frame segment
Definition io.h:256
uint32_t seconds
Definition io.h:270
struct spa_fraction framerate
Definition io.h:267
uint32_t field_count
0 for progressive, 1 and 2 for interlaced
Definition io.h:272
uint32_t flags
flags
Definition io.h:265
uint32_t hours
Definition io.h:268
uint32_t minutes
Definition io.h:269
uint32_t frames
Definition io.h:271
uint32_t offset
offset in segment
Definition io.h:266
A segment converts a running time to a segment (stream) position.
Definition io.h:296
uint64_t duration
duration when this info becomes invalid expressed in running time.
Definition io.h:310
uint64_t position
The position when the running time == start.
Definition io.h:317
double rate
overall rate of the segment, can be negative for backwards time reporting.
Definition io.h:315
struct spa_io_segment_video video
Definition io.h:322
struct spa_io_segment_bar bar
Definition io.h:321
uint32_t version
Definition io.h:297
control stream, io area for SPA_IO_Control and SPA_IO_Notify
Definition io.h:236
struct spa_pod_sequence sequence
sequence of timed events
Definition io.h:237
struct spa_fraction framerate
the minimum framerate, the cycle duration is always smaller to ensure there is only one video frame p...
Definition io.h:218
uint32_t padding[4]
Definition io.h:221
uint32_t stride
video stride in bytes
Definition io.h:216
uint32_t flags
optional flags
Definition io.h:215
struct spa_rectangle size
the video size
Definition io.h:217
a sequence of timed controls
Definition pod.h:271