mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 09:08:14 +00:00
design: latency: fix missing markup
This commit is contained in:
parent
81088410bc
commit
22a72f31b2
1 changed files with 22 additions and 22 deletions
|
@ -87,11 +87,11 @@ configured the device with the samplerate in the caps.
|
||||||
is not prerolled. The sink will commit state to `PLAYING` when it prerolls.
|
is not prerolled. The sink will commit state to `PLAYING` when it prerolls.
|
||||||
* src: *PAUSED→PLAYING*: starts pushing buffers.
|
* src: *PAUSED→PLAYING*: starts pushing buffers.
|
||||||
|
|
||||||
- since the sink is still performing a state change from `READY→PAUSED`, it remains ASYNC. The pending state will be set to
|
- since the sink is still performing a state change from `READY→PAUSED`, it remains `ASYNC`. The pending state will be set to
|
||||||
PLAYING.
|
`PLAYING`.
|
||||||
|
|
||||||
- The clock starts running as soon as all the elements have been
|
- The clock starts running as soon as all the elements have been
|
||||||
set to PLAYING.
|
set to `PLAYING`.
|
||||||
|
|
||||||
- the source is a live source with a latency. Since it is
|
- the source is a live source with a latency. Since it is
|
||||||
synchronized with the clock, it will produce a buffer with
|
synchronized with the clock, it will produce a buffer with
|
||||||
|
@ -99,13 +99,13 @@ timestamp 0 and duration D after time D, ie. it will only be
|
||||||
able to produce the last sample of the buffer (with timestamp D)
|
able to produce the last sample of the buffer (with timestamp D)
|
||||||
at time D. This latency depends on the size of the buffer.
|
at time D. This latency depends on the size of the buffer.
|
||||||
|
|
||||||
- the sink will receive the buffer with timestamp 0 at time \>= D.
|
- the sink will receive the buffer with timestamp 0 at time `>= D`.
|
||||||
At this point the buffer is too late already and might be
|
At this point the buffer is too late already and might be
|
||||||
dropped. This state of constantly dropping data will not change
|
dropped. This state of constantly dropping data will not change
|
||||||
unless a constant latency correction is added to the incoming
|
unless a constant latency correction is added to the incoming
|
||||||
buffer timestamps.
|
buffer timestamps.
|
||||||
|
|
||||||
The problem is due to the fact that the sink is set to (pending) PLAYING
|
The problem is due to the fact that the sink is set to (pending) `PLAYING`
|
||||||
without being prerolled, which only happens in live pipelines.
|
without being prerolled, which only happens in live pipelines.
|
||||||
|
|
||||||
### Example 2
|
### Example 2
|
||||||
|
@ -133,7 +133,7 @@ have them played back synchronized again.
|
||||||
```
|
```
|
||||||
|
|
||||||
The state changes happen in the same way as example 1. Both sinks end up with
|
The state changes happen in the same way as example 1. Both sinks end up with
|
||||||
pending state of `PLAYING` and a return value of ASYNC until they receive the
|
pending state of `PLAYING` and a return value of `ASYNC` until they receive the
|
||||||
first buffer.
|
first buffer.
|
||||||
|
|
||||||
For audio and video to be played in sync, both sinks must compensate for the
|
For audio and video to be played in sync, both sinks must compensate for the
|
||||||
|
@ -141,7 +141,7 @@ latency of its source but must also use exactly the same latency correction.
|
||||||
|
|
||||||
Suppose asrc has a latency of 20ms and vsrc a latency of 33ms, the total
|
Suppose asrc has a latency of 20ms and vsrc a latency of 33ms, the total
|
||||||
latency in the pipeline has to be at least 33ms. This also means that the
|
latency in the pipeline has to be at least 33ms. This also means that the
|
||||||
pipeline must have at least a 33 - 20 = 13ms buffering on the audio stream or
|
pipeline must have at least a `33 - 20 = 13ms` buffering on the audio stream or
|
||||||
else the audio src will underrun while the audiosink waits for the previous
|
else the audio src will underrun while the audiosink waits for the previous
|
||||||
sample to play.
|
sample to play.
|
||||||
|
|
||||||
|
@ -165,7 +165,7 @@ connected to live sinks (vsink, sink).
|
||||||
```
|
```
|
||||||
|
|
||||||
The state changes happen in the same way as example 1. Except sink will be
|
The state changes happen in the same way as example 1. Except sink will be
|
||||||
able to preroll (commit its state to PAUSED).
|
able to preroll (commit its state to `PAUSED`).
|
||||||
|
|
||||||
In this case sink will have no latency but vsink will. The total latency
|
In this case sink will have no latency but vsink will. The total latency
|
||||||
should be that of vsink.
|
should be that of vsink.
|
||||||
|
@ -173,7 +173,7 @@ should be that of vsink.
|
||||||
Note that because of the presence of a live source (vsrc), the pipeline can be
|
Note that because of the presence of a live source (vsrc), the pipeline can be
|
||||||
set to playing before the sink is able to preroll. Without compensation for the
|
set to playing before the sink is able to preroll. Without compensation for the
|
||||||
live source, this might lead to synchronisation problems because the latency
|
live source, this might lead to synchronisation problems because the latency
|
||||||
should be configured in the element before it can go to PLAYING.
|
should be configured in the element before it can go to `PLAYING`.
|
||||||
|
|
||||||
### Example 4
|
### Example 4
|
||||||
|
|
||||||
|
@ -195,7 +195,7 @@ source is connected to a live sink and the live source to a non-live sink.
|
||||||
```
|
```
|
||||||
|
|
||||||
The state changes happen in the same way as example 3. Sink will be
|
The state changes happen in the same way as example 3. Sink will be
|
||||||
able to preroll (commit its state to PAUSED). files will not be able to
|
able to preroll (commit its state to `PAUSED`). files will not be able to
|
||||||
preroll.
|
preroll.
|
||||||
|
|
||||||
sink will have no latency since it is not connected to a live source. files
|
sink will have no latency since it is not connected to a live source. files
|
||||||
|
@ -211,7 +211,7 @@ prerolled.
|
||||||
|
|
||||||
A sink is never set to `PLAYING` before it is prerolled. In order to do
|
A sink is never set to `PLAYING` before it is prerolled. In order to do
|
||||||
this, the pipeline (at the `GstBin` level) keeps track of all elements
|
this, the pipeline (at the `GstBin` level) keeps track of all elements
|
||||||
that require preroll (the ones that return ASYNC from the state change).
|
that require preroll (the ones that return `ASYNC` from the state change).
|
||||||
These elements posted an `ASYNC_START` message without a matching
|
These elements posted an `ASYNC_START` message without a matching
|
||||||
`ASYNC_DONE` one.
|
`ASYNC_DONE` one.
|
||||||
|
|
||||||
|
@ -236,9 +236,9 @@ currently used for going from `PAUSED→PLAYING` in a non-live pipeline).
|
||||||
|
|
||||||
The pipeline latency is queried with the `LATENCY` query.
|
The pipeline latency is queried with the `LATENCY` query.
|
||||||
|
|
||||||
* **`live`** `G_TYPE_BOOLEAN` (default FALSE): - if a live element is found upstream
|
* **`live`** `G_TYPE_BOOLEAN` (default `FALSE`): - if a live element is found upstream
|
||||||
|
|
||||||
* **`min-latency`** `G_TYPE_UINT64` (default 0, must not be NONE): - the minimum
|
* **`min-latency`** `G_TYPE_UINT64` (default 0, must not be `NONE`): - the minimum
|
||||||
latency in the pipeline, meaning the minimum time downstream elements
|
latency in the pipeline, meaning the minimum time downstream elements
|
||||||
synchronizing to the clock have to wait until they can be sure all data
|
synchronizing to the clock have to wait until they can be sure all data
|
||||||
for the current running time has been received.
|
for the current running time has been received.
|
||||||
|
@ -257,7 +257,7 @@ current element:
|
||||||
min_latency = upstream_min_latency + own_min_latency
|
min_latency = upstream_min_latency + own_min_latency
|
||||||
```
|
```
|
||||||
|
|
||||||
* **`max-latency`** `G_TYPE_UINT64` (default 0, NONE meaning infinity): - the
|
* **`max-latency`** `G_TYPE_UINT64` (default 0, `NONE` meaning infinity): - the
|
||||||
maximum latency in the pipeline, meaning the maximum time an element
|
maximum latency in the pipeline, meaning the maximum time an element
|
||||||
synchronizing to the clock is allowed to wait for receiving all data for the
|
synchronizing to the clock is allowed to wait for receiving all data for the
|
||||||
current running time. Waiting for a longer time will result in data loss,
|
current running time. Waiting for a longer time will result in data loss,
|
||||||
|
@ -311,7 +311,7 @@ max_latency = MIN (upstream_max_latency, own_max_latency)
|
||||||
|
|
||||||
## Event
|
## Event
|
||||||
|
|
||||||
The latency in the pipeline is configured with the LATENCY event, which
|
The latency in the pipeline is configured with the `LATENCY` event, which
|
||||||
contains the following fields:
|
contains the following fields:
|
||||||
|
|
||||||
* **`latency`** `G_TYPE_UINT64`: the configured latency in the pipeline
|
* **`latency`** `G_TYPE_UINT64`: the configured latency in the pipeline
|
||||||
|
@ -328,13 +328,13 @@ the global latency as follows:
|
||||||
- sources set their minimum and maximum latency
|
- sources set their minimum and maximum latency
|
||||||
- other elements add their own values as described above
|
- other elements add their own values as described above
|
||||||
- latency = MAX (all min latencies)
|
- latency = MAX (all min latencies)
|
||||||
- if MIN (all max latencies) \< latency, we have an impossible
|
- `if MIN (all max latencies) < latency`, we have an impossible
|
||||||
situation and we must generate an error indicating that this
|
situation and we must generate an error indicating that this
|
||||||
pipeline cannot be played. This usually means that there is not
|
pipeline cannot be played. This usually means that there is not
|
||||||
enough buffering in some chain of the pipeline. A queue can be added
|
enough buffering in some chain of the pipeline. A queue can be added
|
||||||
to those chains.
|
to those chains.
|
||||||
|
|
||||||
The sinks gather this information with a LATENCY query upstream.
|
The sinks gather this information with a `LATENCY` query upstream.
|
||||||
Intermediate elements pass the query upstream and add the amount of
|
Intermediate elements pass the query upstream and add the amount of
|
||||||
latency they add to the result.
|
latency they add to the result.
|
||||||
|
|
||||||
|
@ -350,15 +350,15 @@ ex2: sink1: [20 - 50] sink2: [33 - 40]
|
||||||
MIN (50, 40) = 40 >= 33 -> latency = 33
|
MIN (50, 40) = 40 >= 33 -> latency = 33
|
||||||
```
|
```
|
||||||
|
|
||||||
The latency is set on the pipeline by sending a LATENCY event to the
|
The latency is set on the pipeline by sending a `LATENCY` event to the
|
||||||
sinks in the pipeline. This event configures the total latency on the
|
sinks in the pipeline. This event configures the total latency on the
|
||||||
sinks. The sink forwards this LATENCY event upstream so that
|
sinks. The sink forwards this `LATENCY` event upstream so that
|
||||||
intermediate elements can configure themselves as well.
|
intermediate elements can configure themselves as well.
|
||||||
|
|
||||||
After this step, the pipeline continues setting the pending state on its
|
After this step, the pipeline continues setting the pending state on its
|
||||||
elements.
|
elements.
|
||||||
|
|
||||||
A sink adds the latency value, received in the LATENCY event, to the
|
A sink adds the latency value, received in the `LATENCY` event, to the
|
||||||
times used for synchronizing against the clock. This will effectively
|
times used for synchronizing against the clock. This will effectively
|
||||||
delay the rendering of the buffer with the required latency. Since this
|
delay the rendering of the buffer with the required latency. Since this
|
||||||
delay is the same for all sinks, all sinks will render data relatively
|
delay is the same for all sinks, all sinks will render data relatively
|
||||||
|
@ -366,9 +366,9 @@ synchronised.
|
||||||
|
|
||||||
## Flushing a playing pipeline
|
## Flushing a playing pipeline
|
||||||
|
|
||||||
We can implement resynchronisation after an uncontrolled FLUSH in (part
|
We can implement resynchronisation after an uncontrolled `FLUSH` in (part
|
||||||
of) a pipeline in the same way. Indeed, when a flush is performed on a
|
of) a pipeline in the same way. Indeed, when a flush is performed on a
|
||||||
PLAYING live element, a new base time must be distributed to this
|
`PLAYING` live element, a new base time must be distributed to this
|
||||||
element.
|
element.
|
||||||
|
|
||||||
A flush in a pipeline can happen in the following cases:
|
A flush in a pipeline can happen in the following cases:
|
||||||
|
|
Loading…
Reference in a new issue