annotate libmpcodecs/vf_qp.c @ 25210:92204ff32b27

When IFO file is opened (detected by extension), set dvd-device to IFO file's directory and start dvd:// stream instead of file://. If VTS_<N>_*.IFO is opened, open stream as dvd://<N> As Nico Sabbi said: There is no no guarantie that title N is in titleset N, but there are at least good chances. The main purpose of this patch is ability to load DVDs, stored on HDD, using OSD menu. Modified patch from Benjamin Zores ben at geexbox dot org
author voroshil
date Sun, 02 Dec 2007 13:13:02 +0000
parents 6f05850b5fd1
children 00fff9a3b735
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"
24974
6f05850b5fd1 Rearrange headers to get rid of an #undef and remove unnecessary headers.
diego
parents: 24972
diff changeset
29 #include "img_format.h"
6f05850b5fd1 Rearrange headers to get rid of an #undef and remove unnecessary headers.
diego
parents: 24972
diff changeset
30 #include "mp_image.h"
6f05850b5fd1 Rearrange headers to get rid of an #undef and remove unnecessary headers.
diego
parents: 24972
diff changeset
31 #include "vf.h"
6f05850b5fd1 Rearrange headers to get rid of an #undef and remove unnecessary headers.
diego
parents: 24972
diff changeset
32 #include "libvo/fastmemcpy.h"
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
33
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
34 // Needed to bring in lrintf.
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
35 #define HAVE_AV_CONFIG_H
17012
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
36 #include "libavcodec/avcodec.h"
24972
60e8bf1f23e9 #include libavcodec/eval.h instead of manually declaring ff_eval.
diego
parents: 24020
diff changeset
37 #include "libavcodec/eval.h"
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
38
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
39 #ifdef HAVE_MALLOC_H
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
40 #include <malloc.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
41 #endif
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
42
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
43
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
44 struct vf_priv_s {
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
45 char eq[200];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
46 int8_t *qp;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
47 int8_t lut[257];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
48 int qp_stride;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
49 };
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
50
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
51 static int config(struct vf_instance_s* vf,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
52 int width, int height, int d_width, int d_height,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
53 unsigned int flags, unsigned int outfmt){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
54 int h= (height+15)>>4;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
55 int i;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
56
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
57 vf->priv->qp_stride= (width+15)>>4;
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
58 vf->priv->qp= av_malloc(vf->priv->qp_stride*h*sizeof(int8_t));
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
59
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
60 for(i=-129; i<128; i++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
61 double const_values[]={
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
62 M_PI,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
63 M_E,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
64 i != -129,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
65 i,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
66 0
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
67 };
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
68 static const char *const_names[]={
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
69 "PI",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
70 "E",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
71 "known",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
72 "qp",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
73 NULL
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
74 };
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
75
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
76 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
77 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
78
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
79 return vf_next_config(vf,width,height,d_width,d_height,flags,outfmt);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
80 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
81
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
82 static void get_image(struct vf_instance_s* vf, mp_image_t *mpi){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
83 if(mpi->flags&MP_IMGFLAG_PRESERVE) return; // don't change
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
84 // ok, we can do pp in-place (or pp disabled):
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
85 vf->dmpi=vf_get_image(vf->next,mpi->imgfmt,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
86 mpi->type, mpi->flags, mpi->w, mpi->h);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
87 mpi->planes[0]=vf->dmpi->planes[0];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
88 mpi->stride[0]=vf->dmpi->stride[0];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
89 mpi->width=vf->dmpi->width;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
90 if(mpi->flags&MP_IMGFLAG_PLANAR){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
91 mpi->planes[1]=vf->dmpi->planes[1];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
92 mpi->planes[2]=vf->dmpi->planes[2];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
93 mpi->stride[1]=vf->dmpi->stride[1];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
94 mpi->stride[2]=vf->dmpi->stride[2];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
95 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
96 mpi->flags|=MP_IMGFLAG_DIRECT;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
97 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
98
17906
20aca9baf5d8 passing pts through the filter layer (lets see if pts or cola comes out at the end)
michael
parents: 17523
diff changeset
99 static int put_image(struct vf_instance_s* vf, mp_image_t *mpi, double pts){
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
100 mp_image_t *dmpi;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
101 int x,y;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
102
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
103 if(!(mpi->flags&MP_IMGFLAG_DIRECT)){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
104 // no DR, so get a new image! hope we'll get DR buffer:
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
105 vf->dmpi=vf_get_image(vf->next,mpi->imgfmt,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
106 MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_STRIDE|MP_IMGFLAG_PREFER_ALIGNED_STRIDE,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
107 mpi->w,mpi->h);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
108 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
109
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
110 dmpi= vf->dmpi;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
111
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
112 if(!(mpi->flags&MP_IMGFLAG_DIRECT)){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
113 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
114 if(mpi->flags&MP_IMGFLAG_PLANAR){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
115 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
116 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
117 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
118 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
119 vf_clone_mpi_attributes(dmpi, mpi);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
120
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
121 dmpi->qscale = vf->priv->qp;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
122 dmpi->qstride= vf->priv->qp_stride;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
123 if(mpi->qscale){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
124 for(y=0; y<((dmpi->h+15)>>4); y++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
125 for(x=0; x<vf->priv->qp_stride; x++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
126 dmpi->qscale[x + dmpi->qstride*y]=
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
127 vf->priv->lut[ 129 + ((int8_t)mpi->qscale[x + mpi->qstride*y]) ];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
128 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
129 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
130 }else{
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
131 int qp= vf->priv->lut[0];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
132 for(y=0; y<((dmpi->h+15)>>4); y++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
133 for(x=0; x<vf->priv->qp_stride; x++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
134 dmpi->qscale[x + dmpi->qstride*y]= qp;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
135 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
136 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
137 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
138
17906
20aca9baf5d8 passing pts through the filter layer (lets see if pts or cola comes out at the end)
michael
parents: 17523
diff changeset
139 return vf_next_put_image(vf,dmpi, pts);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
140 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
141
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
142 static void uninit(struct vf_instance_s* vf){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
143 if(!vf->priv) return;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
144
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
145 if(vf->priv->qp) av_free(vf->priv->qp);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
146 vf->priv->qp= NULL;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
147
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
148 av_free(vf->priv);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
149 vf->priv=NULL;
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 static int open(vf_instance_t *vf, char* args){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
154 vf->config=config;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
155 vf->put_image=put_image;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
156 vf->get_image=get_image;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
157 vf->uninit=uninit;
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
158 vf->priv=av_malloc(sizeof(struct vf_priv_s));
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
159 memset(vf->priv, 0, sizeof(struct vf_priv_s));
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
160
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
161 // avcodec_init();
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
162
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
163 if (args) strncpy(vf->priv->eq, args, 199);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
164
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
165 return 1;
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 vf_info_t vf_info_qp = {
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
169 "QP changer",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
170 "qp",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
171 "Michael Niedermayer",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
172 "",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
173 open,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
174 NULL
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
175 };