FFmpeg
vapoursynth.c
Go to the documentation of this file.
1 /*
2  * This file is part of FFmpeg.
3  *
4  * FFmpeg is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * FFmpeg is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with FFmpeg; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
17  */
18 
19 /**
20 * @file
21 * VapourSynth demuxer
22 *
23 * Synthesizes vapour (?)
24 */
25 
26 #include <limits.h>
27 
28 #include <VapourSynth.h>
29 #include <VSScript.h>
30 
31 #include "libavutil/avassert.h"
32 #include "libavutil/avstring.h"
33 #include "libavutil/eval.h"
34 #include "libavutil/imgutils.h"
35 #include "libavutil/opt.h"
36 #include "libavutil/pixdesc.h"
37 #include "avformat.h"
38 #include "internal.h"
39 
40 struct VSState {
41  VSScript *vss;
42 };
43 
44 typedef struct VSContext {
45  const AVClass *class;
46 
48 
49  const VSAPI *vsapi;
50  VSCore *vscore;
51 
52  VSNodeRef *outnode;
53  int is_cfr;
55 
56  int c_order[4];
57 
58  /* options */
59  int64_t max_script_size;
60 } VSContext;
61 
62 #define OFFSET(x) offsetof(VSContext, x)
63 #define A AV_OPT_FLAG_AUDIO_PARAM
64 #define D AV_OPT_FLAG_DECODING_PARAM
65 static const AVOption options[] = {
66  {"max_script_size", "set max file size supported (in bytes)", OFFSET(max_script_size), AV_OPT_TYPE_INT64, {.i64 = 1 * 1024 * 1024}, 0, SIZE_MAX - 1, A|D},
67  {NULL}
68 };
69 
70 static void free_vss_state(void *opaque, uint8_t *data)
71 {
72  struct VSState *vss = opaque;
73 
74  if (vss->vss) {
75  vsscript_freeScript(vss->vss);
76  vsscript_finalize();
77  }
78 }
79 
81 {
82  VSContext *vs = s->priv_data;
83 
84  if (vs->outnode)
85  vs->vsapi->freeNode(vs->outnode);
86 
88 
89  vs->vsapi = NULL;
90  vs->vscore = NULL;
91  vs->outnode = NULL;
92 
93  return 0;
94 }
95 
97 {
99  const AVPixFmtDescriptor *pd;
100  if (other == AV_PIX_FMT_NONE || other == pixfmt)
101  return 1; // not affected by byte order
103  return pd && (!!HAVE_BIGENDIAN == !!(pd->flags & AV_PIX_FMT_FLAG_BE));
104 }
105 
106 static av_cold enum AVPixelFormat match_pixfmt(const VSFormat *vsf, int c_order[4])
107 {
108  static const int yuv_order[4] = {0, 1, 2, 0};
109  static const int rgb_order[4] = {1, 2, 0, 0};
110  const AVPixFmtDescriptor *pd;
111 
112  for (pd = av_pix_fmt_desc_next(NULL); pd; pd = av_pix_fmt_desc_next(pd)) {
113  int is_rgb, is_yuv, i;
114  const int *order;
115  enum AVPixelFormat pixfmt;
116 
118 
121  continue;
122 
123  if (pd->log2_chroma_w != vsf->subSamplingW ||
124  pd->log2_chroma_h != vsf->subSamplingH)
125  continue;
126 
127  is_rgb = vsf->colorFamily == cmRGB;
128  if (is_rgb != !!(pd->flags & AV_PIX_FMT_FLAG_RGB))
129  continue;
130 
131  is_yuv = vsf->colorFamily == cmYUV ||
132  vsf->colorFamily == cmYCoCg ||
133  vsf->colorFamily == cmGray;
134  if (!is_rgb && !is_yuv)
135  continue;
136 
137  if (vsf->sampleType != ((pd->flags & AV_PIX_FMT_FLAG_FLOAT) ? stFloat : stInteger))
138  continue;
139 
140  if (av_pix_fmt_count_planes(pixfmt) != vsf->numPlanes)
141  continue;
142 
143  if (strncmp(pd->name, "xyz", 3) == 0)
144  continue;
145 
146  if (!is_native_endian(pixfmt))
147  continue;
148 
149  order = is_yuv ? yuv_order : rgb_order;
150 
151  for (i = 0; i < pd->nb_components; i++) {
152  const AVComponentDescriptor *c = &pd->comp[i];
153  if (order[c->plane] != i ||
154  c->offset != 0 || c->shift != 0 ||
155  c->step != vsf->bytesPerSample ||
156  c->depth != vsf->bitsPerSample)
157  goto cont;
158  }
159 
160  // Use it.
161  memcpy(c_order, order, sizeof(int[4]));
162  return pixfmt;
163 
164  cont: ;
165  }
166 
167  return AV_PIX_FMT_NONE;
168 }
169 
171 {
172  AVStream *st;
173  AVIOContext *pb = s->pb;
174  VSContext *vs = s->priv_data;
175  int64_t sz = avio_size(pb);
176  char *buf = NULL;
177  char dummy;
178  const VSVideoInfo *info;
179  struct VSState *vss_state;
180  int err = 0;
181 
182  vss_state = av_mallocz(sizeof(*vss_state));
183  if (!vss_state) {
184  err = AVERROR(ENOMEM);
185  goto done;
186  }
187 
188  vs->vss_state = av_buffer_create(NULL, 0, free_vss_state, vss_state, 0);
189  if (!vs->vss_state) {
190  err = AVERROR(ENOMEM);
191  av_free(vss_state);
192  goto done;
193  }
194 
195  if (!vsscript_init()) {
196  av_log(s, AV_LOG_ERROR, "Failed to initialize VSScript (possibly PYTHONPATH not set).\n");
197  err = AVERROR_EXTERNAL;
198  goto done;
199  }
200 
201  if (vsscript_createScript(&vss_state->vss)) {
202  av_log(s, AV_LOG_ERROR, "Failed to create script instance.\n");
203  err = AVERROR_EXTERNAL;
204  vsscript_finalize();
205  goto done;
206  }
207 
208  if (sz < 0 || sz > vs->max_script_size) {
209  if (sz < 0)
210  av_log(s, AV_LOG_WARNING, "Could not determine file size\n");
211  sz = vs->max_script_size;
212  }
213 
214  buf = av_malloc(sz + 1);
215  if (!buf) {
216  err = AVERROR(ENOMEM);
217  goto done;
218  }
219  sz = avio_read(pb, buf, sz);
220 
221  if (sz < 0) {
222  av_log(s, AV_LOG_ERROR, "Could not read script.\n");
223  err = sz;
224  goto done;
225  }
226 
227  // Data left means our buffer (the max_script_size option) is too small
228  if (avio_read(pb, &dummy, 1) == 1) {
229  av_log(s, AV_LOG_ERROR, "File size is larger than max_script_size option "
230  "value %"PRIi64", consider increasing the max_script_size option\n",
231  vs->max_script_size);
233  goto done;
234  }
235 
236  buf[sz] = '\0';
237  if (vsscript_evaluateScript(&vss_state->vss, buf, s->url, 0)) {
238  const char *msg = vsscript_getError(vss_state->vss);
239  av_log(s, AV_LOG_ERROR, "Failed to parse script: %s\n", msg ? msg : "(unknown)");
240  err = AVERROR_EXTERNAL;
241  goto done;
242  }
243 
244  vs->vsapi = vsscript_getVSApi();
245  vs->vscore = vsscript_getCore(vss_state->vss);
246 
247  vs->outnode = vsscript_getOutput(vss_state->vss, 0);
248  if (!vs->outnode) {
249  av_log(s, AV_LOG_ERROR, "Could not get script output node.\n");
250  err = AVERROR_EXTERNAL;
251  goto done;
252  }
253 
254  st = avformat_new_stream(s, NULL);
255  if (!st) {
256  err = AVERROR(ENOMEM);
257  goto done;
258  }
259 
260  info = vs->vsapi->getVideoInfo(vs->outnode);
261 
262  if (!info->format || !info->width || !info->height) {
263  av_log(s, AV_LOG_ERROR, "Non-constant input format not supported.\n");
264  err = AVERROR_PATCHWELCOME;
265  goto done;
266  }
267 
268  if (info->fpsDen) {
269  vs->is_cfr = 1;
270  avpriv_set_pts_info(st, 64, info->fpsDen, info->fpsNum);
271  st->duration = info->numFrames;
272  } else {
273  // VFR. Just set "something".
274  avpriv_set_pts_info(st, 64, 1, AV_TIME_BASE);
275  s->ctx_flags |= AVFMTCTX_UNSEEKABLE;
276  }
277 
280  st->codecpar->width = info->width;
281  st->codecpar->height = info->height;
282  st->codecpar->format = match_pixfmt(info->format, vs->c_order);
283 
284  if (st->codecpar->format == AV_PIX_FMT_NONE) {
285  av_log(s, AV_LOG_ERROR, "Unsupported VS pixel format %s\n", info->format->name);
286  err = AVERROR_EXTERNAL;
287  goto done;
288  }
289  av_log(s, AV_LOG_VERBOSE, "VS format %s -> pixfmt %s\n", info->format->name,
291 
292  if (info->format->colorFamily == cmYCoCg)
294 
295 done:
296  av_free(buf);
297  if (err < 0)
298  read_close_vs(s);
299  return err;
300 }
301 
302 static void free_frame(void *opaque, uint8_t *data)
303 {
304  AVFrame *frame = (AVFrame *)data;
305 
307 }
308 
309 static int get_vs_prop_int(AVFormatContext *s, const VSMap *map, const char *name, int def)
310 {
311  VSContext *vs = s->priv_data;
312  int64_t res;
313  int err = 1;
314 
315  res = vs->vsapi->propGetInt(map, name, 0, &err);
316  return err || res < INT_MIN || res > INT_MAX ? def : res;
317 }
318 
320  const VSAPI *vsapi;
321  const VSFrameRef *frame;
323 };
324 
325 static void free_vsframe_ref(void *opaque, uint8_t *data)
326 {
327  struct vsframe_ref_data *d = opaque;
328 
329  if (d->frame)
330  d->vsapi->freeFrame(d->frame);
331 
333 
334  av_free(d);
335 }
336 
338 {
339  VSContext *vs = s->priv_data;
340  AVStream *st = s->streams[0];
341  AVFrame *frame = NULL;
342  char vserr[80];
343  const VSFrameRef *vsframe;
344  const VSVideoInfo *info = vs->vsapi->getVideoInfo(vs->outnode);
345  const VSMap *props;
346  const AVPixFmtDescriptor *desc;
347  AVBufferRef *vsframe_ref = NULL;
348  struct vsframe_ref_data *ref_data;
349  int err = 0;
350  int i;
351 
352  if (vs->current_frame >= info->numFrames)
353  return AVERROR_EOF;
354 
355  ref_data = av_mallocz(sizeof(*ref_data));
356  if (!ref_data) {
357  err = AVERROR(ENOMEM);
358  goto end;
359  }
360 
361  // (the READONLY flag is important because the ref is reused for plane data)
362  vsframe_ref = av_buffer_create(NULL, 0, free_vsframe_ref, ref_data, AV_BUFFER_FLAG_READONLY);
363  if (!vsframe_ref) {
364  err = AVERROR(ENOMEM);
365  av_free(ref_data);
366  goto end;
367  }
368 
369  vsframe = vs->vsapi->getFrame(vs->current_frame, vs->outnode, vserr, sizeof(vserr));
370  if (!vsframe) {
371  av_log(s, AV_LOG_ERROR, "Error getting frame: %s\n", vserr);
372  err = AVERROR_EXTERNAL;
373  goto end;
374  }
375 
376  ref_data->vsapi = vs->vsapi;
377  ref_data->frame = vsframe;
378 
379  ref_data->vss_state = av_buffer_ref(vs->vss_state);
380  if (!ref_data->vss_state) {
381  err = AVERROR(ENOMEM);
382  goto end;
383  }
384 
385  props = vs->vsapi->getFramePropsRO(vsframe);
386 
387  frame = av_frame_alloc();
388  if (!frame) {
389  err = AVERROR(ENOMEM);
390  goto end;
391  }
392 
393  frame->format = st->codecpar->format;
394  frame->width = st->codecpar->width;
395  frame->height = st->codecpar->height;
396  frame->colorspace = st->codecpar->color_space;
397 
398  // Values according to ISO/IEC 14496-10.
399  frame->colorspace = get_vs_prop_int(s, props, "_Matrix", frame->colorspace);
400  frame->color_primaries = get_vs_prop_int(s, props, "_Primaries", frame->color_primaries);
401  frame->color_trc = get_vs_prop_int(s, props, "_Transfer", frame->color_trc);
402 
403  if (get_vs_prop_int(s, props, "_ColorRange", 1) == 0)
404  frame->color_range = AVCOL_RANGE_JPEG;
405 
406  frame->sample_aspect_ratio.num = get_vs_prop_int(s, props, "_SARNum", 0);
407  frame->sample_aspect_ratio.den = get_vs_prop_int(s, props, "_SARDen", 1);
408 
409  av_assert0(vs->vsapi->getFrameWidth(vsframe, 0) == frame->width);
410  av_assert0(vs->vsapi->getFrameHeight(vsframe, 0) == frame->height);
411 
412  desc = av_pix_fmt_desc_get(frame->format);
413 
414  for (i = 0; i < info->format->numPlanes; i++) {
415  int p = vs->c_order[i];
416  ptrdiff_t plane_h = frame->height;
417 
418  frame->data[i] = (void *)vs->vsapi->getReadPtr(vsframe, p);
419  frame->linesize[i] = vs->vsapi->getStride(vsframe, p);
420 
421  frame->buf[i] = av_buffer_ref(vsframe_ref);
422  if (!frame->buf[i]) {
423  err = AVERROR(ENOMEM);
424  goto end;
425  }
426 
427  // Each plane needs an AVBufferRef that indicates the correct plane
428  // memory range. VapourSynth doesn't even give us the memory range,
429  // so make up a bad guess to make FFmpeg happy (even if almost nothing
430  // checks the memory range).
431  if (i == 1 || i == 2)
432  plane_h = AV_CEIL_RSHIFT(plane_h, desc->log2_chroma_h);
433  frame->buf[i]->data = frame->data[i];
434  frame->buf[i]->size = frame->linesize[i] * plane_h;
435  }
436 
437  pkt->buf = av_buffer_create((uint8_t*)frame, sizeof(*frame),
438  free_frame, NULL, 0);
439  if (!pkt->buf) {
440  err = AVERROR(ENOMEM);
441  goto end;
442  }
443 
444  frame = NULL; // pkt owns it now
445 
446  pkt->data = pkt->buf->data;
447  pkt->size = pkt->buf->size;
449 
450  if (vs->is_cfr)
451  pkt->pts = vs->current_frame;
452 
453  vs->current_frame++;
454 
455 end:
457  av_buffer_unref(&vsframe_ref);
458  return err;
459 }
460 
461 static int read_seek_vs(AVFormatContext *s, int stream_idx, int64_t ts, int flags)
462 {
463  VSContext *vs = s->priv_data;
464 
465  if (!vs->is_cfr)
466  return AVERROR(ENOSYS);
467 
468  vs->current_frame = FFMIN(FFMAX(0, ts), s->streams[0]->duration);
469  return 0;
470 }
471 
472 static av_cold int probe_vs(const AVProbeData *p)
473 {
474  // Explicitly do not support this. VS scripts are written in Python, and
475  // can run arbitrary code on the user's system.
476  return 0;
477 }
478 
479 static const AVClass class_vs = {
480  .class_name = "VapourSynth demuxer",
481  .item_name = av_default_item_name,
482  .option = options,
483  .version = LIBAVUTIL_VERSION_INT,
484 };
485 
487  .name = "vapoursynth",
488  .long_name = NULL_IF_CONFIG_SMALL("VapourSynth demuxer"),
489  .priv_data_size = sizeof(VSContext),
490  .read_probe = probe_vs,
495  .priv_class = &class_vs,
496 };
ff_vapoursynth_demuxer
AVInputFormat ff_vapoursynth_demuxer
Definition: vapoursynth.c:486
av_pix_fmt_swap_endianness
enum AVPixelFormat av_pix_fmt_swap_endianness(enum AVPixelFormat pix_fmt)
Utility function to swap the endianness of a pixel format.
Definition: pixdesc.c:2618
AV_LOG_WARNING
#define AV_LOG_WARNING
Something somehow does not look correct.
Definition: log.h:182
AVPixelFormat
AVPixelFormat
Pixel format.
Definition: pixfmt.h:64
AVERROR
Filter the word “frame” indicates either a video frame or a group of audio as stored in an AVFrame structure Format for each input and each output the list of supported formats For video that means pixel format For audio that means channel sample they are references to shared objects When the negotiation mechanism computes the intersection of the formats supported at each end of a all references to both lists are replaced with a reference to the intersection And when a single format is eventually chosen for a link amongst the remaining all references to the list are updated That means that if a filter requires that its input and output have the same format amongst a supported all it has to do is use a reference to the same list of formats query_formats can leave some formats unset and return AVERROR(EAGAIN) to cause the negotiation mechanism toagain later. That can be used by filters with complex requirements to use the format negotiated on one link to set the formats supported on another. Frame references ownership and permissions
opt.h
avformat_new_stream
AVStream * avformat_new_stream(AVFormatContext *s, const AVCodec *c)
Add a new stream to a media file.
Definition: utils.c:4480
AVCodecParameters::codec_type
enum AVMediaType codec_type
General type of the encoded data.
Definition: avcodec.h:3953
AVCodecParameters::color_space
enum AVColorSpace color_space
Definition: avcodec.h:4046
VSContext::current_frame
int current_frame
Definition: vapoursynth.c:54
av_pix_fmt_desc_get
const AVPixFmtDescriptor * av_pix_fmt_desc_get(enum AVPixelFormat pix_fmt)
Definition: pixdesc.c:2522
AVERROR_EOF
#define AVERROR_EOF
End of file.
Definition: error.h:55
AVBufferRef::data
uint8_t * data
The data buffer.
Definition: buffer.h:89
AV_PIX_FMT_FLAG_FLOAT
#define AV_PIX_FMT_FLAG_FLOAT
The pixel format contains IEEE-754 floating point values.
Definition: pixdesc.h:188
av_frame_free
void av_frame_free(AVFrame **frame)
Free the frame and any dynamically allocated objects in it, e.g.
Definition: frame.c:202
end
static av_cold int end(AVCodecContext *avctx)
Definition: avrndec.c:90
AVFrame
This structure describes decoded (raw) audio or video data.
Definition: frame.h:295
pixdesc.h
AVCOL_RANGE_JPEG
@ AVCOL_RANGE_JPEG
the normal 2^n-1 "JPEG" YUV ranges
Definition: pixfmt.h:522
name
const char * name
Definition: avisynth_c.h:867
AVPacket::data
uint8_t * data
Definition: avcodec.h:1477
AVPixFmtDescriptor::name
const char * name
Definition: pixdesc.h:82
AVOption
AVOption.
Definition: opt.h:246
vsframe_ref_data::vss_state
AVBufferRef * vss_state
Definition: vapoursynth.c:322
data
const char data[16]
Definition: mxf.c:91
av_pix_fmt_desc_next
const AVPixFmtDescriptor * av_pix_fmt_desc_next(const AVPixFmtDescriptor *prev)
Iterate over all pixel format descriptors known to libavutil.
Definition: pixdesc.c:2529
AV_LOG_VERBOSE
#define AV_LOG_VERBOSE
Detailed information.
Definition: log.h:192
av_buffer_create
AVBufferRef * av_buffer_create(uint8_t *data, int size, void(*free)(void *opaque, uint8_t *data), void *opaque, int flags)
Create an AVBuffer from an existing array.
Definition: buffer.c:28
OFFSET
#define OFFSET(x)
Definition: vapoursynth.c:62
get_vs_prop_int
static int get_vs_prop_int(AVFormatContext *s, const VSMap *map, const char *name, int def)
Definition: vapoursynth.c:309
avio_size
int64_t avio_size(AVIOContext *s)
Get the filesize.
Definition: aviobuf.c:336
free_vss_state
static void free_vss_state(void *opaque, uint8_t *data)
Definition: vapoursynth.c:70
av_malloc
#define av_malloc(s)
Definition: tableprint_vlc.h:31
AVBufferRef::size
int size
Size of data in bytes.
Definition: buffer.h:93
av_pix_fmt_count_planes
int av_pix_fmt_count_planes(enum AVPixelFormat pix_fmt)
Definition: pixdesc.c:2562
VSContext::outnode
VSNodeRef * outnode
Definition: vapoursynth.c:52
class_vs
static const AVClass class_vs
Definition: vapoursynth.c:479
VSContext::vscore
VSCore * vscore
Definition: vapoursynth.c:50
read_seek
static int read_seek(AVFormatContext *ctx, int stream_index, int64_t timestamp, int flags)
Definition: libcdio.c:153
AV_PIX_FMT_FLAG_HWACCEL
#define AV_PIX_FMT_FLAG_HWACCEL
Pixel format is an HW accelerated format.
Definition: pixdesc.h:140
read_close
static av_cold int read_close(AVFormatContext *ctx)
Definition: libcdio.c:145
AVERROR_BUFFER_TOO_SMALL
#define AVERROR_BUFFER_TOO_SMALL
Buffer too small.
Definition: error.h:51
AVStream::duration
int64_t duration
Decoding: duration of the stream, in stream time base.
Definition: avformat.h:919
av_frame_alloc
AVFrame * av_frame_alloc(void)
Allocate an AVFrame and set its fields to default values.
Definition: frame.c:189
avassert.h
AV_LOG_ERROR
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
Definition: log.h:176
buf
void * buf
Definition: avisynth_c.h:766
AVInputFormat
Definition: avformat.h:640
av_cold
#define av_cold
Definition: attributes.h:84
options
static const AVOption options[]
Definition: vapoursynth.c:65
s
#define s(width, name)
Definition: cbs_vp9.c:257
AV_CEIL_RSHIFT
#define AV_CEIL_RSHIFT(a, b)
Definition: common.h:58
AV_BUFFER_FLAG_READONLY
#define AV_BUFFER_FLAG_READONLY
Always treat the buffer as read-only, even when it has only one reference.
Definition: buffer.h:113
AVInputFormat::name
const char * name
A comma separated list of short names for the format.
Definition: avformat.h:645
AVCodecParameters::width
int width
Video only.
Definition: avcodec.h:4023
info
MIPS optimizations info
Definition: mips.txt:2
vsframe_ref_data::vsapi
const VSAPI * vsapi
Definition: vapoursynth.c:320
AV_OPT_TYPE_INT64
@ AV_OPT_TYPE_INT64
Definition: opt.h:224
av_assert0
#define av_assert0(cond)
assert() equivalent, that is always enabled.
Definition: avassert.h:37
VSContext::max_script_size
int64_t max_script_size
Definition: vapoursynth.c:59
read_header_vs
static av_cold int read_header_vs(AVFormatContext *s)
Definition: vapoursynth.c:170
AV_PIX_FMT_FLAG_ALPHA
#define AV_PIX_FMT_FLAG_ALPHA
The pixel format has an alpha channel.
Definition: pixdesc.h:177
limits.h
AVPixFmtDescriptor::log2_chroma_w
uint8_t log2_chroma_w
Amount to shift the luma width right to find the chroma width.
Definition: pixdesc.h:92
AV_CODEC_ID_WRAPPED_AVFRAME
@ AV_CODEC_ID_WRAPPED_AVFRAME
Passthrough codec, AVFrames wrapped in AVPacket.
Definition: avcodec.h:708
AVFormatContext
Format I/O context.
Definition: avformat.h:1342
internal.h
AVPacket::buf
AVBufferRef * buf
A reference to the reference-counted buffer where the packet data is stored.
Definition: avcodec.h:1460
AVStream::codecpar
AVCodecParameters * codecpar
Codec parameters associated with this stream.
Definition: avformat.h:1017
LIBAVUTIL_VERSION_INT
#define LIBAVUTIL_VERSION_INT
Definition: version.h:85
read_header
static int read_header(FFV1Context *f)
Definition: ffv1dec.c:530
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:67
NULL
#define NULL
Definition: coverity.c:32
VSContext::c_order
int c_order[4]
Definition: vapoursynth.c:56
AVERROR_PATCHWELCOME
#define AVERROR_PATCHWELCOME
Not yet implemented in FFmpeg, patches welcome.
Definition: error.h:62
av_buffer_unref
void av_buffer_unref(AVBufferRef **buf)
Free a given reference and automatically free the buffer if there are no more references to it.
Definition: buffer.c:125
AVComponentDescriptor
Definition: pixdesc.h:31
read_probe
static int read_probe(const AVProbeData *pd)
Definition: jvdec.c:55
AVPixFmtDescriptor::nb_components
uint8_t nb_components
The number of components each pixel has, (1-4)
Definition: pixdesc.h:83
AVFMTCTX_UNSEEKABLE
#define AVFMTCTX_UNSEEKABLE
signal that the stream is definitely not seekable, and attempts to call the seek function will fail.
Definition: avformat.h:1293
av_default_item_name
const char * av_default_item_name(void *ptr)
Return the context name.
Definition: log.c:191
AVProbeData
This structure contains the data a format has to probe a file.
Definition: avformat.h:446
VSContext::vsapi
const VSAPI * vsapi
Definition: vapoursynth.c:49
AVCOL_SPC_YCGCO
@ AVCOL_SPC_YCGCO
Used by Dirac / VC-2 and H.264 FRext, see ITU-T SG16.
Definition: pixfmt.h:505
read_seek_vs
static int read_seek_vs(AVFormatContext *s, int stream_idx, int64_t ts, int flags)
Definition: vapoursynth.c:461
AVPixFmtDescriptor::flags
uint64_t flags
Combination of AV_PIX_FMT_FLAG_...
Definition: pixdesc.h:106
is_native_endian
static av_cold int is_native_endian(enum AVPixelFormat pixfmt)
Definition: vapoursynth.c:96
c
Undefined Behavior In the C some operations are like signed integer dereferencing freed accessing outside allocated Undefined Behavior must not occur in a C it is not safe even if the output of undefined operations is unused The unsafety may seem nit picking but Optimizing compilers have in fact optimized code on the assumption that no undefined Behavior occurs Optimizing code based on wrong assumptions can and has in some cases lead to effects beyond the output of computations The signed integer overflow problem in speed critical code Code which is highly optimized and works with signed integers sometimes has the problem that often the output of the computation does not c
Definition: undefined.txt:32
VSState::vss
VSScript * vss
Definition: vapoursynth.c:41
eval.h
desc
const char * desc
Definition: nvenc.c:68
AVIOContext
Bytestream IO Context.
Definition: avio.h:161
AVPacket::size
int size
Definition: avcodec.h:1478
NULL_IF_CONFIG_SMALL
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification.
Definition: internal.h:188
AV_PIX_FMT_FLAG_RGB
#define AV_PIX_FMT_FLAG_RGB
The pixel format contains RGB-like data (as opposed to YUV/grayscale).
Definition: pixdesc.h:148
FFMAX
#define FFMAX(a, b)
Definition: common.h:94
avpriv_set_pts_info
void avpriv_set_pts_info(AVStream *s, int pts_wrap_bits, unsigned int pts_num, unsigned int pts_den)
Set the time base and wrapping info for a given stream.
Definition: utils.c:4910
AV_PIX_FMT_FLAG_BITSTREAM
#define AV_PIX_FMT_FLAG_BITSTREAM
All values of a component are bit-wise packed end to end.
Definition: pixdesc.h:136
VSContext::vss_state
AVBufferRef * vss_state
Definition: vapoursynth.c:47
FFMIN
#define FFMIN(a, b)
Definition: common.h:96
read_close_vs
static av_cold int read_close_vs(AVFormatContext *s)
Definition: vapoursynth.c:80
AVERROR_EXTERNAL
#define AVERROR_EXTERNAL
Generic error in an external library.
Definition: error.h:57
av_pix_fmt_desc_get_id
enum AVPixelFormat av_pix_fmt_desc_get_id(const AVPixFmtDescriptor *desc)
Definition: pixdesc.c:2541
AVPacket::flags
int flags
A combination of AV_PKT_FLAG values.
Definition: avcodec.h:1483
AV_PIX_FMT_FLAG_BAYER
#define AV_PIX_FMT_FLAG_BAYER
The pixel format is following a Bayer pattern.
Definition: pixdesc.h:182
free_frame
static void free_frame(void *opaque, uint8_t *data)
Definition: vapoursynth.c:302
VSContext::is_cfr
int is_cfr
Definition: vapoursynth.c:53
i
#define i(width, name, range_min, range_max)
Definition: cbs_h2645.c:259
AVPacket::pts
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...
Definition: avcodec.h:1470
read_packet_vs
static int read_packet_vs(AVFormatContext *s, AVPacket *pkt)
Definition: vapoursynth.c:337
AVCodecParameters::height
int height
Definition: avcodec.h:4024
AV_TIME_BASE
#define AV_TIME_BASE
Internal time base represented as integer.
Definition: avutil.h:254
AV_PIX_FMT_FLAG_BE
#define AV_PIX_FMT_FLAG_BE
Pixel format is big-endian.
Definition: pixdesc.h:128
uint8_t
uint8_t
Definition: audio_convert.c:194
av_mallocz
void * av_mallocz(size_t size)
Allocate a memory block with alignment suitable for all memory accesses (including vectors if availab...
Definition: mem.c:236
VSContext
Definition: vapoursynth.c:44
match_pixfmt
static av_cold enum AVPixelFormat match_pixfmt(const VSFormat *vsf, int c_order[4])
Definition: vapoursynth.c:106
read_packet
static int read_packet(void *opaque, uint8_t *buf, int buf_size)
Definition: avio_reading.c:42
AVStream
Stream structure.
Definition: avformat.h:870
pixfmt
enum AVPixelFormat pixfmt
Definition: kmsgrab.c:202
AVClass::class_name
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
Definition: log.h:72
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
avformat.h
A
#define A
Definition: vapoursynth.c:63
probe_vs
static av_cold int probe_vs(const AVProbeData *p)
Definition: vapoursynth.c:472
pkt
static AVPacket pkt
Definition: demuxing_decoding.c:54
AV_PIX_FMT_NONE
@ AV_PIX_FMT_NONE
Definition: pixfmt.h:65
dummy
int dummy
Definition: motion.c:64
avio_read
int avio_read(AVIOContext *s, unsigned char *buf, int size)
Read size bytes from AVIOContext into buf.
Definition: aviobuf.c:647
vsframe_ref_data
Definition: vapoursynth.c:319
AVPixFmtDescriptor::comp
AVComponentDescriptor comp[4]
Parameters that describe how pixels are packed.
Definition: pixdesc.h:117
av_buffer_ref
AVBufferRef * av_buffer_ref(AVBufferRef *buf)
Create a new reference to an AVBuffer.
Definition: buffer.c:93
AVMEDIA_TYPE_VIDEO
@ AVMEDIA_TYPE_VIDEO
Definition: avutil.h:201
D
#define D
Definition: vapoursynth.c:64
AVBufferRef
A reference to a data buffer.
Definition: buffer.h:81
AVCodecParameters::format
int format
Definition: avcodec.h:3981
AVPixFmtDescriptor
Descriptor that unambiguously describes how the bits of a pixel are stored in the up to 4 data planes...
Definition: pixdesc.h:81
map
const VDPAUPixFmtMap * map
Definition: hwcontext_vdpau.c:85
av_free
#define av_free(p)
Definition: tableprint_vlc.h:34
AVCodecParameters::codec_id
enum AVCodecID codec_id
Specific type of the encoded data (the codec used).
Definition: avcodec.h:3957
AVPacket
This structure stores compressed data.
Definition: avcodec.h:1454
vsframe_ref_data::frame
const VSFrameRef * frame
Definition: vapoursynth.c:321
imgutils.h
flags
#define flags(name, subs,...)
Definition: cbs_av1.c:565
av_log
#define av_log(a,...)
Definition: tableprint_vlc.h:28
avstring.h
AV_PKT_FLAG_TRUSTED
#define AV_PKT_FLAG_TRUSTED
The packet comes from a trusted source.
Definition: avcodec.h:1523
VSState
Definition: vapoursynth.c:40
AVPixFmtDescriptor::log2_chroma_h
uint8_t log2_chroma_h
Amount to shift the luma height right to find the chroma height.
Definition: pixdesc.h:101
free_vsframe_ref
static void free_vsframe_ref(void *opaque, uint8_t *data)
Definition: vapoursynth.c:325
av_get_pix_fmt_name
const char * av_get_pix_fmt_name(enum AVPixelFormat pix_fmt)
Return the short name for a pixel format, NULL in case pix_fmt is unknown.
Definition: pixdesc.c:2438