annotate libmpcodecs/vf_qp.c @ 20105:bcb586a0800c

Avoid crash with fontconfig 2.3.9x (as shipped with SuSE 10.1, FcDirScan is broken) and warn that these are beta versions and not supported.
author reimar
date Sun, 08 Oct 2006 13:01:14 +0000
parents e83548b7bd3b
children 918b0974e3a1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
1 /*
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
2 Copyright (C) 2004 Michael Niedermayer <michaelni@gmx.at>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
3
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
4 This program is free software; you can redistribute it and/or modify
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
5 it under the terms of the GNU General Public License as published by
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
6 the Free Software Foundation; either version 2 of the License, or
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
7 (at your option) any later version.
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
8
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
9 This program is distributed in the hope that it will be useful,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
12 GNU General Public License for more details.
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
13
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
14 You should have received a copy of the GNU General Public License
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
15 along with this program; if not, write to the Free Software
17367
401b440a6d76 Update licensing information: The FSF changed postal address.
diego
parents: 17012
diff changeset
16 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
17 */
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
18
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
19 #include <stdio.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
20 #include <stdlib.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
21 #include <string.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
22 #include <math.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
23 #include <inttypes.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
24
17012
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
25 #include "config.h"
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
26
17012
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
27 #include "mp_msg.h"
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
28 #include "cpudetect.h"
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
29
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
30 #if 1
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
31 double ff_eval(char *s, double *const_value, const char **const_name,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
32 double (**func1)(void *, double), const char **func1_name,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
33 double (**func2)(void *, double, double), char **func2_name,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
34 void *opaque);
11923
e9ab21c4db24 #include dsputil.h as it contains the lrintf emu code
michael
parents: 11921
diff changeset
35 #endif
e9ab21c4db24 #include dsputil.h as it contains the lrintf emu code
michael
parents: 11921
diff changeset
36
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
37 // Needed to bring in lrintf.
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
38 #define HAVE_AV_CONFIG_H
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
39
17012
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
40 #include "libavcodec/avcodec.h"
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
41 #include "libavcodec/dsputil.h"
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
42 #include "libavutil/common.h"
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
43
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
44 /* FIXME: common.h defines printf away when HAVE_AV_CONFIG
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
45 * is defined, but mp_image.h needs printf.
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
46 */
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
47 #undef printf
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
48
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
49 #ifdef HAVE_MALLOC_H
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
50 #include <malloc.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
51 #endif
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
52
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
53 #include "img_format.h"
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
54 #include "mp_image.h"
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
55 #include "vf.h"
17012
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
56 #include "libvo/fastmemcpy.h"
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
57
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
58
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
59 struct vf_priv_s {
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
60 char eq[200];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
61 int8_t *qp;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
62 int8_t lut[257];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
63 int qp_stride;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
64 };
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
65
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
66 static int config(struct vf_instance_s* vf,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
67 int width, int height, int d_width, int d_height,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
68 unsigned int flags, unsigned int outfmt){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
69 int h= (height+15)>>4;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
70 int i;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
71
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
72 vf->priv->qp_stride= (width+15)>>4;
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
73 vf->priv->qp= av_malloc(vf->priv->qp_stride*h*sizeof(int8_t));
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
74
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
75 for(i=-129; i<128; i++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
76 double const_values[]={
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
77 M_PI,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
78 M_E,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
79 i != -129,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
80 i,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
81 0
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
82 };
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
83 static const char *const_names[]={
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
84 "PI",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
85 "E",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
86 "known",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
87 "qp",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
88 NULL
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
89 };
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
90
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
91 vf->priv->lut[i+129]= lrintf(ff_eval(vf->priv->eq, const_values, const_names, NULL, NULL, NULL, NULL, NULL));
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
92 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
93
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
94 return vf_next_config(vf,width,height,d_width,d_height,flags,outfmt);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
95 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
96
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
97 static void get_image(struct vf_instance_s* vf, mp_image_t *mpi){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
98 if(mpi->flags&MP_IMGFLAG_PRESERVE) return; // don't change
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
99 // ok, we can do pp in-place (or pp disabled):
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
100 vf->dmpi=vf_get_image(vf->next,mpi->imgfmt,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
101 mpi->type, mpi->flags, mpi->w, mpi->h);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
102 mpi->planes[0]=vf->dmpi->planes[0];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
103 mpi->stride[0]=vf->dmpi->stride[0];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
104 mpi->width=vf->dmpi->width;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
105 if(mpi->flags&MP_IMGFLAG_PLANAR){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
106 mpi->planes[1]=vf->dmpi->planes[1];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
107 mpi->planes[2]=vf->dmpi->planes[2];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
108 mpi->stride[1]=vf->dmpi->stride[1];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
109 mpi->stride[2]=vf->dmpi->stride[2];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
110 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
111 mpi->flags|=MP_IMGFLAG_DIRECT;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
112 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
113
17906
20aca9baf5d8 passing pts through the filter layer (lets see if pts or cola comes out at the end)
michael
parents: 17523
diff changeset
114 static int put_image(struct vf_instance_s* vf, mp_image_t *mpi, double pts){
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
115 mp_image_t *dmpi;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
116 int x,y;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
117
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
118 if(!(mpi->flags&MP_IMGFLAG_DIRECT)){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
119 // no DR, so get a new image! hope we'll get DR buffer:
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
120 vf->dmpi=vf_get_image(vf->next,mpi->imgfmt,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
121 MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_STRIDE|MP_IMGFLAG_PREFER_ALIGNED_STRIDE,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
122 mpi->w,mpi->h);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
123 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
124
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
125 dmpi= vf->dmpi;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
126
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
127 if(!(mpi->flags&MP_IMGFLAG_DIRECT)){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
128 memcpy_pic(dmpi->planes[0], mpi->planes[0], mpi->w, mpi->h, dmpi->stride[0], mpi->stride[0]);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
129 if(mpi->flags&MP_IMGFLAG_PLANAR){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
130 memcpy_pic(dmpi->planes[1], mpi->planes[1], mpi->w>>mpi->chroma_x_shift, mpi->h>>mpi->chroma_y_shift, dmpi->stride[1], mpi->stride[1]);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
131 memcpy_pic(dmpi->planes[2], mpi->planes[2], mpi->w>>mpi->chroma_x_shift, mpi->h>>mpi->chroma_y_shift, dmpi->stride[2], mpi->stride[2]);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
132 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
133 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
134 vf_clone_mpi_attributes(dmpi, mpi);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
135
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
136 dmpi->qscale = vf->priv->qp;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
137 dmpi->qstride= vf->priv->qp_stride;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
138 if(mpi->qscale){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
139 for(y=0; y<((dmpi->h+15)>>4); y++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
140 for(x=0; x<vf->priv->qp_stride; x++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
141 dmpi->qscale[x + dmpi->qstride*y]=
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
142 vf->priv->lut[ 129 + ((int8_t)mpi->qscale[x + mpi->qstride*y]) ];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
143 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
144 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
145 }else{
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
146 int qp= vf->priv->lut[0];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
147 for(y=0; y<((dmpi->h+15)>>4); y++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
148 for(x=0; x<vf->priv->qp_stride; x++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
149 dmpi->qscale[x + dmpi->qstride*y]= qp;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
150 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
151 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
152 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
153
17906
20aca9baf5d8 passing pts through the filter layer (lets see if pts or cola comes out at the end)
michael
parents: 17523
diff changeset
154 return vf_next_put_image(vf,dmpi, pts);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
155 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
156
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
157 static void uninit(struct vf_instance_s* vf){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
158 if(!vf->priv) return;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
159
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
160 if(vf->priv->qp) av_free(vf->priv->qp);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
161 vf->priv->qp= NULL;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
162
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
163 av_free(vf->priv);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
164 vf->priv=NULL;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
165 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
166
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
167 //===========================================================================//
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
168 static int open(vf_instance_t *vf, char* args){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
169 vf->config=config;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
170 vf->put_image=put_image;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
171 vf->get_image=get_image;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
172 vf->uninit=uninit;
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
173 vf->priv=av_malloc(sizeof(struct vf_priv_s));
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
174 memset(vf->priv, 0, sizeof(struct vf_priv_s));
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
175
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
176 // avcodec_init();
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
177
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
178 if (args) strncpy(vf->priv->eq, args, 199);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
179
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
180 return 1;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
181 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
182
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
183 vf_info_t vf_info_qp = {
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
184 "QP changer",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
185 "qp",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
186 "Michael Niedermayer",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
187 "",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
188 open,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
189 NULL
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
190 };