FFmpeg
ffmpeg_sched.h
Go to the documentation of this file.
1 /*
2  * Inter-thread scheduling/synchronization.
3  * Copyright (c) 2023 Anton Khirnov
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
22 #ifndef FFTOOLS_FFMPEG_SCHED_H
23 #define FFTOOLS_FFMPEG_SCHED_H
24 
25 #include <stddef.h>
26 #include <stdint.h>
27 
28 #include "ffmpeg_utils.h"
29 
30 /*
31  * This file contains the API for the transcode scheduler.
32  *
33  * Overall architecture of the transcoding process involves instances of the
34  * following components:
35  * - demuxers, each containing any number of demuxed streams; demuxed packets
36  * belonging to some stream are sent to any number of decoders (transcoding)
37  * and/or muxers (streamcopy);
38  * - decoders, which receive encoded packets from some demuxed stream or
39  * encoder, decode them, and send decoded frames to any number of filtergraph
40  * inputs (audio/video) or encoders (subtitles);
41  * - filtergraphs, each containing zero or more inputs (0 in case the
42  * filtergraph contains a lavfi source filter), and one or more outputs; the
43  * inputs and outputs need not have matching media types;
44  * each filtergraph input receives decoded frames from some decoder or another
45  * filtergraph output;
46  * filtered frames from each output are sent to some encoder;
47  * - encoders, which receive decoded frames from some decoder (subtitles) or
48  * some filtergraph output (audio/video), encode them, and send encoded
49  * packets to any number of muxed streams or decoders;
50  * - muxers, each containing any number of muxed streams; each muxed stream
51  * receives encoded packets from some demuxed stream (streamcopy) or some
52  * encoder (transcoding); those packets are interleaved and written out by the
53  * muxer.
54  *
55  * The structure formed by the above components is a directed acyclic graph
56  * (absence of cycles is checked at startup).
57  *
58  * There must be at least one muxer instance, otherwise the transcode produces
59  * no output and is meaningless. Otherwise, in a generic transcoding scenario
60  * there may be arbitrary number of instances of any of the above components,
61  * interconnected in various ways.
62  *
63  * The code tries to keep all the output streams across all the muxers in sync
64  * (i.e. at the same DTS), which is accomplished by varying the rates at which
65  * packets are read from different demuxers and lavfi sources. Note that the
66  * degree of control we have over synchronization is fundamentally limited - if
67  * some demuxed streams in the same input are interleaved at different rates
68  * than that at which they are to be muxed (e.g. because an input file is badly
69  * interleaved, or the user changed their speed by mismatching amounts), then
70  * there will be increasing amounts of buffering followed by eventual
71  * transcoding failure.
72  *
73  * N.B. 1: there are meaningful transcode scenarios with no demuxers, e.g.
74  * - encoding and muxing output from filtergraph(s) that have no inputs;
75  * - creating a file that contains nothing but attachments and/or metadata.
76  *
77  * N.B. 2: a filtergraph output could, in principle, feed multiple encoders, but
78  * this is unnecessary because the (a)split filter provides the same
79  * functionality.
80  *
81  * The scheduler, in the above model, is the master object that oversees and
82  * facilitates the transcoding process. The basic idea is that all instances
83  * of the abovementioned components communicate only with the scheduler and not
84  * with each other. The scheduler is then the single place containing the
85  * knowledge about the whole transcoding pipeline.
86  */
87 
88 struct AVFrame;
89 struct AVPacket;
90 
91 typedef struct Scheduler Scheduler;
92 
101 };
102 
103 typedef struct SchedulerNode {
105  unsigned idx;
106  unsigned idx_stream;
107 } SchedulerNode;
108 
109 typedef int (*SchThreadFunc)(void *arg);
110 
111 #define SCH_DSTREAM(file, stream) \
112  (SchedulerNode){ .type = SCH_NODE_TYPE_DEMUX, \
113  .idx = file, .idx_stream = stream }
114 #define SCH_MSTREAM(file, stream) \
115  (SchedulerNode){ .type = SCH_NODE_TYPE_MUX, \
116  .idx = file, .idx_stream = stream }
117 #define SCH_DEC_IN(decoder) \
118  (SchedulerNode){ .type = SCH_NODE_TYPE_DEC, \
119  .idx = decoder }
120 #define SCH_DEC_OUT(decoder, out_idx) \
121  (SchedulerNode){ .type = SCH_NODE_TYPE_DEC, \
122  .idx = decoder, .idx_stream = out_idx }
123 #define SCH_ENC(encoder) \
124  (SchedulerNode){ .type = SCH_NODE_TYPE_ENC, \
125  .idx = encoder }
126 #define SCH_FILTER_IN(filter, input) \
127  (SchedulerNode){ .type = SCH_NODE_TYPE_FILTER_IN, \
128  .idx = filter, .idx_stream = input }
129 #define SCH_FILTER_OUT(filter, output) \
130  (SchedulerNode){ .type = SCH_NODE_TYPE_FILTER_OUT, \
131  .idx = filter, .idx_stream = output }
132 
133 Scheduler *sch_alloc(void);
134 void sch_free(Scheduler **sch);
135 
136 int sch_start(Scheduler *sch);
137 int sch_stop(Scheduler *sch, int64_t *finish_ts);
138 
139 /**
140  * Wait until transcoding terminates or the specified timeout elapses.
141  *
142  * @param timeout_us Amount of time in microseconds after which this function
143  * will timeout.
144  * @param transcode_ts Current transcode timestamp in AV_TIME_BASE_Q, for
145  * informational purposes only.
146  *
147  * @retval 0 waiting timed out, transcoding is not finished
148  * @retval 1 transcoding is finished
149  */
150 int sch_wait(Scheduler *sch, uint64_t timeout_us, int64_t *transcode_ts);
151 
152 /**
153  * Add a demuxer to the scheduler.
154  *
155  * @param func Function executed as the demuxer task.
156  * @param ctx Demuxer state; will be passed to func and used for logging.
157  *
158  * @retval ">=0" Index of the newly-created demuxer.
159  * @retval "<0" Error code.
160  */
161 int sch_add_demux(Scheduler *sch, SchThreadFunc func, void *ctx);
162 /**
163  * Add a demuxed stream for a previously added demuxer.
164  *
165  * @param demux_idx index previously returned by sch_add_demux()
166  *
167  * @retval ">=0" Index of the newly-created demuxed stream.
168  * @retval "<0" Error code.
169  */
170 int sch_add_demux_stream(Scheduler *sch, unsigned demux_idx);
171 
172 /**
173  * Add a decoder to the scheduler.
174  *
175  * @param func Function executed as the decoder task.
176  * @param ctx Decoder state; will be passed to func and used for logging.
177  * @param send_end_ts The decoder will return an end timestamp after flush packets
178  * are delivered to it. See documentation for
179  * sch_dec_receive() for more details.
180  *
181  * @retval ">=0" Index of the newly-created decoder.
182  * @retval "<0" Error code.
183  */
184 int sch_add_dec(Scheduler *sch, SchThreadFunc func, void *ctx, int send_end_ts);
185 
186 /**
187  * Add another output to decoder (e.g. for multiview video).
188  *
189  * @retval ">=0" Index of the newly-added decoder output.
190  * @retval "<0" Error code.
191  */
192 int sch_add_dec_output(Scheduler *sch, unsigned dec_idx);
193 
194 /**
195  * Add a filtergraph to the scheduler.
196  *
197  * @param nb_inputs Number of filtergraph inputs.
198  * @param nb_outputs number of filtergraph outputs
199  * @param func Function executed as the filtering task.
200  * @param ctx Filter state; will be passed to func and used for logging.
201  *
202  * @retval ">=0" Index of the newly-created filtergraph.
203  * @retval "<0" Error code.
204  */
205 int sch_add_filtergraph(Scheduler *sch, unsigned nb_inputs, unsigned nb_outputs,
206  SchThreadFunc func, void *ctx);
207 
208 /**
209  * Add a muxer to the scheduler.
210  *
211  * Note that muxer thread startup is more complicated than for other components,
212  * because
213  * - muxer streams fed by audio/video encoders become initialized dynamically at
214  * runtime, after those encoders receive their first frame and initialize
215  * themselves, followed by calling sch_mux_stream_ready()
216  * - the header can be written after all the streams for a muxer are initialized
217  * - we may need to write an SDP, which must happen
218  * - AFTER all the headers are written
219  * - BEFORE any packets are written by any muxer
220  * - with all the muxers quiescent
221  * To avoid complicated muxer-thread synchronization dances, we postpone
222  * starting the muxer threads until after the SDP is written. The sequence of
223  * events is then as follows:
224  * - After sch_mux_stream_ready() is called for all the streams in a given muxer,
225  * the header for that muxer is written (care is taken that headers for
226  * different muxers are not written concurrently, since they write file
227  * information to stderr). If SDP is not wanted, the muxer thread then starts
228  * and muxing begins.
229  * - When SDP _is_ wanted, no muxer threads start until the header for the last
230  * muxer is written. After that, the SDP is written, after which all the muxer
231  * threads are started at once.
232  *
233  * In order for the above to work, the scheduler needs to be able to invoke
234  * just writing the header, which is the reason the init parameter exists.
235  *
236  * @param func Function executed as the muxing task.
237  * @param init Callback that is called to initialize the muxer and write the
238  * header. Called after sch_mux_stream_ready() is called for all the
239  * streams in the muxer.
240  * @param ctx Muxer state; will be passed to func/init and used for logging.
241  * @param sdp_auto Determines automatic SDP writing - see sch_sdp_filename().
242  * @param thread_queue_size number of packets that can be buffered before
243  * sending to the muxer blocks
244  *
245  * @retval ">=0" Index of the newly-created muxer.
246  * @retval "<0" Error code.
247  */
248 int sch_add_mux(Scheduler *sch, SchThreadFunc func, int (*init)(void *),
249  void *ctx, int sdp_auto, unsigned thread_queue_size);
250 
251 /**
252  * Default size of a packet thread queue. For muxing this can be overridden by
253  * the thread_queue_size option as passed to a call to sch_add_mux().
254  */
255 #define DEFAULT_PACKET_THREAD_QUEUE_SIZE 8
256 
257 /**
258  * Default size of a frame thread queue.
259  */
260 #define DEFAULT_FRAME_THREAD_QUEUE_SIZE 8
261 
262 /**
263  * Add a muxed stream for a previously added muxer.
264  *
265  * @param mux_idx index previously returned by sch_add_mux()
266  *
267  * @retval ">=0" Index of the newly-created muxed stream.
268  * @retval "<0" Error code.
269  */
270 int sch_add_mux_stream(Scheduler *sch, unsigned mux_idx);
271 
272 /**
273  * Configure limits on packet buffering performed before the muxer task is
274  * started.
275  *
276  * @param mux_idx index previously returned by sch_add_mux()
277  * @param stream_idx_idx index previously returned by sch_add_mux_stream()
278  * @param data_threshold Total size of the buffered packets' data after which
279  * max_packets applies.
280  * @param max_packets maximum Maximum number of buffered packets after
281  * data_threshold is reached.
282  */
283 void sch_mux_stream_buffering(Scheduler *sch, unsigned mux_idx, unsigned stream_idx,
284  size_t data_threshold, int max_packets);
285 
286 /**
287  * Signal to the scheduler that the specified muxed stream is initialized and
288  * ready. Muxing is started once all the streams are ready.
289  */
290 int sch_mux_stream_ready(Scheduler *sch, unsigned mux_idx, unsigned stream_idx);
291 
292 /**
293  * Set the file path for the SDP.
294  *
295  * The SDP is written when either of the following is true:
296  * - this function is called at least once
297  * - sdp_auto=1 is passed to EVERY call of sch_add_mux()
298  */
299 int sch_sdp_filename(Scheduler *sch, const char *sdp_filename);
300 
301 /**
302  * Add an encoder to the scheduler.
303  *
304  * @param func Function executed as the encoding task.
305  * @param ctx Encoder state; will be passed to func and used for logging.
306  * @param open_cb This callback, if specified, will be called when the first
307  * frame is obtained for this encoder. For audio encoders with a
308  * fixed frame size (which use a sync queue in the scheduler to
309  * rechunk frames), it must return that frame size on success.
310  * Otherwise (non-audio, variable frame size) it should return 0.
311  *
312  * @retval ">=0" Index of the newly-created encoder.
313  * @retval "<0" Error code.
314  */
315 int sch_add_enc(Scheduler *sch, SchThreadFunc func, void *ctx,
316  int (*open_cb)(void *func_arg, const struct AVFrame *frame));
317 
318 /**
319  * Add an pre-encoding sync queue to the scheduler.
320  *
321  * @param buf_size_us Sync queue buffering size, passed to sq_alloc().
322  * @param logctx Logging context for the sync queue. passed to sq_alloc().
323  *
324  * @retval ">=0" Index of the newly-created sync queue.
325  * @retval "<0" Error code.
326  */
327 int sch_add_sq_enc(Scheduler *sch, uint64_t buf_size_us, void *logctx);
328 int sch_sq_add_enc(Scheduler *sch, unsigned sq_idx, unsigned enc_idx,
329  int limiting, uint64_t max_frames);
330 
332 
334  /**
335  * Treat the packet as an EOF for SCH_NODE_TYPE_MUX destinations
336  * send normally to other types.
337  */
339 };
340 
341 /**
342  * Called by demuxer tasks to communicate with their downstreams. The following
343  * may be sent:
344  * - a demuxed packet for the stream identified by pkt->stream_index;
345  * - demuxer discontinuity/reset (e.g. after a seek) - this is signalled by an
346  * empty packet with stream_index=-1.
347  *
348  * @param demux_idx demuxer index
349  * @param pkt A demuxed packet to send.
350  * When flushing (i.e. pkt->stream_index=-1 on entry to this
351  * function), on successful return pkt->pts/pkt->time_base will be
352  * set to the maximum end timestamp of any decoded audio stream, or
353  * AV_NOPTS_VALUE if no decoded audio streams are present.
354  *
355  * @retval "non-negative value" success
356  * @retval AVERROR_EOF all consumers for the stream are done
357  * @retval AVERROR_EXIT all consumers are done, should terminate demuxing
358  * @retval "anoter negative error code" other failure
359  */
360 int sch_demux_send(Scheduler *sch, unsigned demux_idx, struct AVPacket *pkt,
361  unsigned flags);
362 
363 /**
364  * Called by decoder tasks to receive a packet for decoding.
365  *
366  * @param dec_idx decoder index
367  * @param pkt Input packet will be written here on success.
368  *
369  * An empty packet signals that the decoder should be flushed, but
370  * more packets will follow (e.g. after seeking). When a decoder
371  * created with send_end_ts=1 receives a flush packet, it must write
372  * the end timestamp of the stream after flushing to
373  * pkt->pts/time_base on the next call to this function (if any).
374  *
375  * @retval "non-negative value" success
376  * @retval AVERROR_EOF no more packets will arrive, should terminate decoding
377  * @retval "another negative error code" other failure
378  */
379 int sch_dec_receive(Scheduler *sch, unsigned dec_idx, struct AVPacket *pkt);
380 
381 /**
382  * Called by decoder tasks to send a decoded frame downstream.
383  *
384  * @param dec_idx Decoder index previously returned by sch_add_dec().
385  * @param frame Decoded frame; on success it is consumed and cleared by this
386  * function
387  *
388  * @retval ">=0" success
389  * @retval AVERROR_EOF all consumers are done, should terminate decoding
390  * @retval "another negative error code" other failure
391  */
392 int sch_dec_send(Scheduler *sch, unsigned dec_idx,
393  unsigned out_idx, struct AVFrame *frame);
394 
395 /**
396  * Called by filtergraph tasks to obtain frames for filtering. Will wait for a
397  * frame to become available and return it in frame.
398  *
399  * Filtergraphs that contain lavfi sources and do not currently require new
400  * input frames should call this function as a means of rate control - then
401  * in_idx should be set equal to nb_inputs on entry to this function.
402  *
403  * @param fg_idx Filtergraph index previously returned by sch_add_filtergraph().
404  * @param[in,out] in_idx On input contains the index of the input on which a frame
405  * is most desired. May be set to nb_inputs to signal that
406  * the filtergraph does not need more input currently.
407  *
408  * On success, will be replaced with the input index of
409  * the actually returned frame or EOF timestamp.
410  *
411  * @retval ">=0" Frame data or EOF timestamp was delivered into frame, in_idx
412  * contains the index of the input it belongs to.
413  * @retval AVERROR(EAGAIN) No frame was returned, the filtergraph should
414  * resume filtering. May only be returned when
415  * in_idx=nb_inputs on entry to this function.
416  * @retval AVERROR_EOF No more frames will arrive, should terminate filtering.
417  */
418 int sch_filter_receive(Scheduler *sch, unsigned fg_idx,
419  unsigned *in_idx, struct AVFrame *frame);
420 /**
421  * Called by filter tasks to signal that a filter input will no longer accept input.
422  *
423  * @param fg_idx Filtergraph index previously returned from sch_add_filtergraph().
424  * @param in_idx Index of the input to finish.
425  */
426 void sch_filter_receive_finish(Scheduler *sch, unsigned fg_idx, unsigned in_idx);
427 
428 /**
429  * Called by filtergraph tasks to send a filtered frame or EOF to consumers.
430  *
431  * @param fg_idx Filtergraph index previously returned by sch_add_filtergraph().
432  * @param out_idx Index of the output which produced the frame.
433  * @param frame The frame to send to consumers. When NULL, signals that no more
434  * frames will be produced for the specified output. When non-NULL,
435  * the frame is consumed and cleared by this function on success.
436  *
437  * @retval "non-negative value" success
438  * @retval AVERROR_EOF all consumers are done
439  * @retval "anoter negative error code" other failure
440  */
441 int sch_filter_send(Scheduler *sch, unsigned fg_idx, unsigned out_idx,
442  struct AVFrame *frame);
443 
444 int sch_filter_command(Scheduler *sch, unsigned fg_idx, struct AVFrame *frame);
445 
446 /**
447  * Called by encoder tasks to obtain frames for encoding. Will wait for a frame
448  * to become available and return it in frame.
449  *
450  * @param enc_idx Encoder index previously returned by sch_add_enc().
451  * @param frame Newly-received frame will be stored here on success. Must be
452  * clean on entrance to this function.
453  *
454  * @retval 0 A frame was successfully delivered into frame.
455  * @retval AVERROR_EOF No more frames will be delivered, the encoder should
456  * flush everything and terminate.
457  *
458  */
459 int sch_enc_receive(Scheduler *sch, unsigned enc_idx, struct AVFrame *frame);
460 
461 /**
462  * Called by encoder tasks to send encoded packets downstream.
463  *
464  * @param enc_idx Encoder index previously returned by sch_add_enc().
465  * @param pkt An encoded packet; it will be consumed and cleared by this
466  * function on success.
467  *
468  * @retval 0 success
469  * @retval "<0" Error code.
470  */
471 int sch_enc_send (Scheduler *sch, unsigned enc_idx, struct AVPacket *pkt);
472 
473 /**
474  * Called by muxer tasks to obtain packets for muxing. Will wait for a packet
475  * for any muxed stream to become available and return it in pkt.
476  *
477  * @param mux_idx Muxer index previously returned by sch_add_mux().
478  * @param pkt Newly-received packet will be stored here on success. Must be
479  * clean on entrance to this function.
480  *
481  * @retval 0 A packet was successfully delivered into pkt. Its stream_index
482  * corresponds to a stream index previously returned from
483  * sch_add_mux_stream().
484  * @retval AVERROR_EOF When pkt->stream_index is non-negative, this signals that
485  * no more packets will be delivered for this stream index.
486  * Otherwise this indicates that no more packets will be
487  * delivered for any stream and the muxer should therefore
488  * flush everything and terminate.
489  */
490 int sch_mux_receive(Scheduler *sch, unsigned mux_idx, struct AVPacket *pkt);
491 
492 /**
493  * Called by muxer tasks to signal that a stream will no longer accept input.
494  *
495  * @param stream_idx Stream index previously returned from sch_add_mux_stream().
496  */
497 void sch_mux_receive_finish(Scheduler *sch, unsigned mux_idx, unsigned stream_idx);
498 
499 int sch_mux_sub_heartbeat_add(Scheduler *sch, unsigned mux_idx, unsigned stream_idx,
500  unsigned dec_idx);
501 int sch_mux_sub_heartbeat(Scheduler *sch, unsigned mux_idx, unsigned stream_idx,
502  const AVPacket *pkt);
503 
504 #endif /* FFTOOLS_FFMPEG_SCHED_H */
func
int(* func)(AVBPrint *dst, const char *in, const char *arg)
Definition: jacosubdec.c:68
SchedulerNode::idx_stream
unsigned idx_stream
Definition: ffmpeg_sched.h:106
SCH_NODE_TYPE_ENC
@ SCH_NODE_TYPE_ENC
Definition: ffmpeg_sched.h:98
sch_dec_send
int sch_dec_send(Scheduler *sch, unsigned dec_idx, unsigned out_idx, struct AVFrame *frame)
Called by decoder tasks to send a decoded frame downstream.
Definition: ffmpeg_sched.c:2243
int64_t
long long int64_t
Definition: coverity.c:34
sch_stop
int sch_stop(Scheduler *sch, int64_t *finish_ts)
Definition: ffmpeg_sched.c:2581
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:389
sch_add_demux
int sch_add_demux(Scheduler *sch, SchThreadFunc func, void *ctx)
Add a demuxer to the scheduler.
Definition: ffmpeg_sched.c:688
SCH_NODE_TYPE_MUX
@ SCH_NODE_TYPE_MUX
Definition: ffmpeg_sched.h:96
SchedulerNode::type
enum SchedulerNodeType type
Definition: ffmpeg_sched.h:104
sch_free
void sch_free(Scheduler **sch)
Definition: ffmpeg_sched.c:467
SchThreadFunc
int(* SchThreadFunc)(void *arg)
Definition: ffmpeg_sched.h:109
SCH_NODE_TYPE_NONE
@ SCH_NODE_TYPE_NONE
Definition: ffmpeg_sched.h:94
sch_mux_receive
int sch_mux_receive(Scheduler *sch, unsigned mux_idx, struct AVPacket *pkt)
Called by muxer tasks to obtain packets for muxing.
Definition: ffmpeg_sched.c:2083
sch_enc_send
int sch_enc_send(Scheduler *sch, unsigned enc_idx, struct AVPacket *pkt)
Called by encoder tasks to send encoded packets downstream.
Definition: ffmpeg_sched.c:2356
pkt
AVPacket * pkt
Definition: movenc.c:60
sch_mux_stream_ready
int sch_mux_stream_ready(Scheduler *sch, unsigned mux_idx, unsigned stream_idx)
Signal to the scheduler that the specified muxed stream is initialized and ready.
Definition: ffmpeg_sched.c:1221
sch_sdp_filename
int sch_sdp_filename(Scheduler *sch, const char *sdp_filename)
Set the file path for the SDP.
Definition: ffmpeg_sched.c:619
SchedulerNodeType
SchedulerNodeType
Definition: ffmpeg_sched.h:93
sch_demux_send
int sch_demux_send(Scheduler *sch, unsigned demux_idx, struct AVPacket *pkt, unsigned flags)
Called by demuxer tasks to communicate with their downstreams.
Definition: ffmpeg_sched.c:2039
ctx
AVFormatContext * ctx
Definition: movenc.c:49
ffmpeg_utils.h
sch_enc_receive
int sch_enc_receive(Scheduler *sch, unsigned enc_idx, struct AVFrame *frame)
Called by encoder tasks to obtain frames for encoding.
Definition: ffmpeg_sched.c:2312
sch_start
int sch_start(Scheduler *sch)
Definition: ffmpeg_sched.c:1599
arg
const char * arg
Definition: jacosubdec.c:67
sch_mux_sub_heartbeat
int sch_mux_sub_heartbeat(Scheduler *sch, unsigned mux_idx, unsigned stream_idx, const AVPacket *pkt)
Definition: ffmpeg_sched.c:2114
DemuxSendFlags
DemuxSendFlags
Definition: ffmpeg_sched.h:333
sch_connect
int sch_connect(Scheduler *sch, SchedulerNode src, SchedulerNode dst)
Definition: ffmpeg_sched.c:927
SCH_NODE_TYPE_DEMUX
@ SCH_NODE_TYPE_DEMUX
Definition: ffmpeg_sched.h:95
sch_filter_command
int sch_filter_command(Scheduler *sch, unsigned fg_idx, struct AVFrame *frame)
Definition: ffmpeg_sched.c:2515
sch_alloc
Scheduler * sch_alloc(void)
Definition: ffmpeg_sched.c:585
DEMUX_SEND_STREAMCOPY_EOF
@ DEMUX_SEND_STREAMCOPY_EOF
Treat the packet as an EOF for SCH_NODE_TYPE_MUX destinations send normally to other types.
Definition: ffmpeg_sched.h:338
sch_add_demux_stream
int sch_add_demux_stream(Scheduler *sch, unsigned demux_idx)
Add a demuxed stream for a previously added demuxer.
Definition: ffmpeg_sched.c:715
Scheduler
Definition: ffmpeg_sched.c:275
init
int(* init)(AVBSFContext *ctx)
Definition: dts2pts.c:368
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:83
sch_filter_receive_finish
void sch_filter_receive_finish(Scheduler *sch, unsigned fg_idx, unsigned in_idx)
Called by filter tasks to signal that a filter input will no longer accept input.
Definition: ffmpeg_sched.c:2449
sch_add_dec_output
int sch_add_dec_output(Scheduler *sch, unsigned dec_idx)
Add another output to decoder (e.g.
Definition: ffmpeg_sched.c:727
sch_add_enc
int sch_add_enc(Scheduler *sch, SchThreadFunc func, void *ctx, int(*open_cb)(void *func_arg, const struct AVFrame *frame))
Add an encoder to the scheduler.
SCH_NODE_TYPE_FILTER_OUT
@ SCH_NODE_TYPE_FILTER_OUT
Definition: ffmpeg_sched.h:100
sch_add_dec
int sch_add_dec(Scheduler *sch, SchThreadFunc func, void *ctx, int send_end_ts)
Add a decoder to the scheduler.
Definition: ffmpeg_sched.c:748
sch_filter_send
int sch_filter_send(Scheduler *sch, unsigned fg_idx, unsigned out_idx, struct AVFrame *frame)
Called by filtergraph tasks to send a filtered frame or EOF to consumers.
Definition: ffmpeg_sched.c:2470
sch_add_sq_enc
int sch_add_sq_enc(Scheduler *sch, uint64_t buf_size_us, void *logctx)
Add an pre-encoding sync queue to the scheduler.
Definition: ffmpeg_sched.c:871
SCH_NODE_TYPE_FILTER_IN
@ SCH_NODE_TYPE_FILTER_IN
Definition: ffmpeg_sched.h:99
SchedulerNode
Definition: ffmpeg_sched.h:103
SCH_NODE_TYPE_DEC
@ SCH_NODE_TYPE_DEC
Definition: ffmpeg_sched.h:97
sch_wait
int sch_wait(Scheduler *sch, uint64_t timeout_us, int64_t *transcode_ts)
Wait until transcoding terminates or the specified timeout elapses.
Definition: ffmpeg_sched.c:1665
sch_add_mux_stream
int sch_add_mux_stream(Scheduler *sch, unsigned mux_idx)
Add a muxed stream for a previously added muxer.
Definition: ffmpeg_sched.c:656
frame
these buffered frames must be flushed immediately if a new input produces new the filter must not call request_frame to get more It must just process the frame or queue it The task of requesting more frames is left to the filter s request_frame method or the application If a filter has several the filter must be ready for frames arriving randomly on any input any filter with several inputs will most likely require some kind of queuing mechanism It is perfectly acceptable to have a limited queue and to drop frames when the inputs are too unbalanced request_frame For filters that do not use the this method is called when a frame is wanted on an output For a it should directly call filter_frame on the corresponding output For a if there are queued frames already one of these frames should be pushed If the filter should request a frame on one of its repeatedly until at least one frame has been pushed Return or at least make progress towards producing a frame
Definition: filter_design.txt:264
sch_add_filtergraph
int sch_add_filtergraph(Scheduler *sch, unsigned nb_inputs, unsigned nb_outputs, SchThreadFunc func, void *ctx)
Add a filtergraph to the scheduler.
Definition: ffmpeg_sched.c:829
sch_filter_receive
int sch_filter_receive(Scheduler *sch, unsigned fg_idx, unsigned *in_idx, struct AVFrame *frame)
Called by filtergraph tasks to obtain frames for filtering.
Definition: ffmpeg_sched.c:2405
sch_sq_add_enc
int sch_sq_add_enc(Scheduler *sch, unsigned sq_idx, unsigned enc_idx, int limiting, uint64_t max_frames)
Definition: ffmpeg_sched.c:896
sch_mux_sub_heartbeat_add
int sch_mux_sub_heartbeat_add(Scheduler *sch, unsigned mux_idx, unsigned stream_idx, unsigned dec_idx)
Definition: ffmpeg_sched.c:1246
SchedulerNode::idx
unsigned idx
Definition: ffmpeg_sched.h:105
AVPacket
This structure stores compressed data.
Definition: packet.h:516
sch_dec_receive
int sch_dec_receive(Scheduler *sch, unsigned dec_idx, struct AVPacket *pkt)
Called by decoder tasks to receive a packet for decoding.
Definition: ffmpeg_sched.c:2167
sch_mux_receive_finish
void sch_mux_receive_finish(Scheduler *sch, unsigned mux_idx, unsigned stream_idx)
Called by muxer tasks to signal that a stream will no longer accept input.
Definition: ffmpeg_sched.c:2096
flags
#define flags(name, subs,...)
Definition: cbs_av1.c:482
sch_add_mux
int sch_add_mux(Scheduler *sch, SchThreadFunc func, int(*init)(void *), void *ctx, int sdp_auto, unsigned thread_queue_size)
Add a muxer to the scheduler.
Definition: ffmpeg_sched.c:632
src
#define src
Definition: vp8dsp.c:248
sch_mux_stream_buffering
void sch_mux_stream_buffering(Scheduler *sch, unsigned mux_idx, unsigned stream_idx, size_t data_threshold, int max_packets)
Configure limits on packet buffering performed before the muxer task is started.
Definition: ffmpeg_sched.c:1205