annotate libmpcodecs/vf_yvu9.c @ 9207:8fd4eb4c22bb

Link to codecs page added.
author diego
date Sat, 01 Feb 2003 18:12:36 +0000
parents a894e99c1e51
children e9a2af584986
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
6485
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
1 #include <stdio.h>
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
2 #include <stdlib.h>
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
3 #include <string.h>
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
4 #include <inttypes.h>
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
5
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
6 #include "../config.h"
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
7 #include "../mp_msg.h"
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
8
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
9 #include "img_format.h"
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
10 #include "mp_image.h"
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
11 #include "vf.h"
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
12
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
13 #include "../libvo/fastmemcpy.h"
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
14 #include "../postproc/rgb2rgb.h"
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
15
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
16 //===========================================================================//
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
17
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
18 static int config(struct vf_instance_s* vf,
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
19 int width, int height, int d_width, int d_height,
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
20 unsigned int flags, unsigned int outfmt){
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
21
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
22 if(vf_next_query_format(vf,IMGFMT_YV12)<=0){
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
23 printf("yv12 not supported by next filter/vo :(\n");
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
24 return 0;
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
25 }
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
26
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
27 return vf_next_config(vf,width,height,d_width,d_height,flags,IMGFMT_YV12);
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
28 }
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
29
7368
a894e99c1e51 changing return type of put_image void->int
arpi
parents: 6524
diff changeset
30 static int put_image(struct vf_instance_s* vf, mp_image_t *mpi){
6485
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
31 mp_image_t *dmpi;
6504
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
32 int y,w,h;
6485
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
33
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
34 // hope we'll get DR buffer:
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
35 dmpi=vf_get_image(vf->next,IMGFMT_YV12,
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
36 MP_IMGTYPE_TEMP, 0/*MP_IMGFLAG_ACCEPT_STRIDE*/,
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
37 mpi->w, mpi->h);
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
38
6504
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
39 for(y=0;y<mpi->h;y++)
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
40 memcpy(dmpi->planes[0]+dmpi->stride[0]*y,
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
41 mpi->planes[0]+mpi->stride[0]*y,
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
42 mpi->w);
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
43
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
44 w=mpi->w/4; h=mpi->h/2;
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
45 for(y=0;y<h;y++){
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
46 unsigned char* s=mpi->planes[1]+mpi->stride[1]*(y>>1);
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
47 unsigned char* d=dmpi->planes[1]+dmpi->stride[1]*y;
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
48 int x;
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
49 for(x=0;x<w;x++) d[2*x]=d[2*x+1]=s[x];
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
50 }
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
51 for(y=0;y<h;y++){
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
52 unsigned char* s=mpi->planes[2]+mpi->stride[2]*(y>>1);
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
53 unsigned char* d=dmpi->planes[2]+dmpi->stride[2]*y;
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
54 int x;
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
55 for(x=0;x<w;x++) d[2*x]=d[2*x+1]=s[x];
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
56 }
11c0ddb83168 use built-in yvu9->yv12 code, because it requires all src/dst strides and
arpi
parents: 6485
diff changeset
57
6485
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
58 dmpi->qscale=mpi->qscale;
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
59 dmpi->qstride=mpi->qstride;
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
60
7368
a894e99c1e51 changing return type of put_image void->int
arpi
parents: 6524
diff changeset
61 return vf_next_put_image(vf,dmpi);
6485
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
62 }
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
63
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
64 //===========================================================================//
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
65
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
66 static int query_format(struct vf_instance_s* vf, unsigned int fmt){
6524
05cd2cf758e4 if09 support
alex
parents: 6504
diff changeset
67 if (fmt == IMGFMT_YVU9 || fmt == IMGFMT_IF09)
6485
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
68 return vf_next_query_format(vf,IMGFMT_YV12) & (~VFCAP_CSP_SUPPORTED_BY_HW);
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
69 return 0;
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
70 }
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
71
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
72 static int open(vf_instance_t *vf, char* args){
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
73 vf->config=config;
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
74 vf->put_image=put_image;
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
75 vf->query_format=query_format;
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
76 return 1;
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
77 }
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
78
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
79 vf_info_t vf_info_yvu9 = {
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
80 "fast YVU9->YV12 conversion",
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
81 "yvu9",
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
82 "alex",
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
83 "",
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
84 open
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
85 };
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
86
52563321dc78 yvu9toyv12 converter
alex
parents:
diff changeset
87 //===========================================================================//