summaryrefslogtreecommitdiffstats
path: root/video/filter
diff options
context:
space:
mode:
authorwm4 <wm4@nowhere>2012-12-26 21:31:56 +0100
committerwm4 <wm4@nowhere>2013-01-13 20:04:13 +0100
commit54dffdbbe6d02fd3aa3c3a6a85f4aa47559cacdd (patch)
tree3f9f958b1c946435388fbadf8360a73255569f01 /video/filter
parenta26d6020244a6da1b48fd6d2b6ff2374f945aea2 (diff)
downloadmpv-54dffdbbe6d02fd3aa3c3a6a85f4aa47559cacdd.tar.bz2
mpv-54dffdbbe6d02fd3aa3c3a6a85f4aa47559cacdd.tar.xz
vf_softpulldown: reject unsupported image formats, fix code duplication
Not really tested.
Diffstat (limited to 'video/filter')
-rw-r--r--video/filter/vf_softpulldown.c71
1 files changed, 24 insertions, 47 deletions
diff --git a/video/filter/vf_softpulldown.c b/video/filter/vf_softpulldown.c
index ce7cddb29a..11eab7c0c3 100644
--- a/video/filter/vf_softpulldown.c
+++ b/video/filter/vf_softpulldown.c
@@ -38,6 +38,16 @@ struct vf_priv_s {
struct mp_image *buffer;
};
+static void copy_pic_field(struct mp_image *dmpi, struct mp_image *mpi, int f)
+{
+ for (int p = 0; p < dmpi->num_planes; p++) {
+ my_memcpy_pic(dmpi->planes[p] + dmpi->stride[p] * f,
+ mpi->planes[p] + mpi->stride[p] * f,
+ mpi->plane_w[p], mpi->plane_h[p] / 2,
+ dmpi->stride[p] * 2, mpi->stride[p] * 2);
+ }
+}
+
static int filter(struct vf_instance *vf, struct mp_image *mpi)
{
int flags = mpi->fields;
@@ -75,39 +85,11 @@ static int filter(struct vf_instance *vf, struct mp_image *mpi)
vf_add_output_frame(vf, new);
vf->priv->out++;
if (flags & MP_IMGFIELD_REPEAT_FIRST) {
- my_memcpy_pic(dmpi->planes[0],
- mpi->planes[0], mpi->w, mpi->h/2,
- dmpi->stride[0]*2, mpi->stride[0]*2);
- if (mpi->flags & MP_IMGFLAG_PLANAR) {
- my_memcpy_pic(dmpi->planes[1],
- mpi->planes[1],
- mpi->chroma_width,
- mpi->chroma_height/2,
- dmpi->stride[1]*2,
- mpi->stride[1]*2);
- my_memcpy_pic(dmpi->planes[2],
- mpi->planes[2],
- mpi->chroma_width,
- mpi->chroma_height/2,
- dmpi->stride[2]*2,
- mpi->stride[2]*2);
- }
+ copy_pic_field(dmpi, mpi, 0);
state=1;
}
} else {
- my_memcpy_pic(dmpi->planes[0]+dmpi->stride[0],
- mpi->planes[0]+mpi->stride[0], mpi->w, mpi->h/2,
- dmpi->stride[0]*2, mpi->stride[0]*2);
- if (mpi->flags & MP_IMGFLAG_PLANAR) {
- my_memcpy_pic(dmpi->planes[1]+dmpi->stride[1],
- mpi->planes[1]+mpi->stride[1],
- mpi->chroma_width, mpi->chroma_height/2,
- dmpi->stride[1]*2, mpi->stride[1]*2);
- my_memcpy_pic(dmpi->planes[2]+dmpi->stride[2],
- mpi->planes[2]+mpi->stride[2],
- mpi->chroma_width, mpi->chroma_height/2,
- dmpi->stride[2]*2, mpi->stride[2]*2);
- }
+ copy_pic_field(dmpi, mpi, 1);
struct mp_image *new = mp_image_new_ref(mpi);
new->pts = vf_softpulldown_adjust_pts(&vf->priv->ptsbuf, mpi->pts, 0, 0, vf->priv->last_frame_duration);
vf_add_output_frame(vf, new);
@@ -119,23 +101,7 @@ static int filter(struct vf_instance *vf, struct mp_image *mpi)
vf->priv->out++;
vf->priv->state=0;
} else {
- my_memcpy_pic(dmpi->planes[0],
- mpi->planes[0], mpi->w, mpi->h/2,
- dmpi->stride[0]*2, mpi->stride[0]*2);
- if (mpi->flags & MP_IMGFLAG_PLANAR) {
- my_memcpy_pic(dmpi->planes[1],
- mpi->planes[1],
- mpi->chroma_width,
- mpi->chroma_height/2,
- dmpi->stride[1]*2,
- mpi->stride[1]*2);
- my_memcpy_pic(dmpi->planes[2],
- mpi->planes[2],
- mpi->chroma_width,
- mpi->chroma_height/2,
- dmpi->stride[2]*2,
- mpi->stride[2]*2);
- }
+ copy_pic_field(dmpi, mpi, 0);
}
}
@@ -163,11 +129,22 @@ static void uninit(struct vf_instance *vf)
free(vf->priv);
}
+static int query_format(struct vf_instance *vf, unsigned int fmt)
+{
+ struct mp_imgfmt_desc desc = mp_imgfmt_get_desc(fmt);
+ if (!(desc.flags & MP_IMGFLAG_YUV_P))
+ return 0;
+ if (desc.plane_bits != 8)
+ return 0;
+ return vf_next_query_format(vf, fmt);
+}
+
static int vf_open(vf_instance_t *vf, char *args)
{
vf->config = config;
vf->filter_ext = filter;
vf->uninit = uninit;
+ vf->query_format = query_format;
vf->priv = calloc(1, sizeof(struct vf_priv_s));
vf->priv->last_frame_duration = 2;
vf_detc_init_pts_buf(&vf->priv->ptsbuf);