Mercurial > mplayer.hg
annotate libmpcodecs/dec_video.c @ 5507:d0d029fda134
video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
author | arpi |
---|---|
date | Sat, 06 Apr 2002 22:05:01 +0000 |
parents | 014ddf03476d |
children | 868c13f78f08 |
rev | line source |
---|---|
2775 | 1 |
2 #include "config.h" | |
1294 | 3 |
4 #include <stdio.h> | |
2775 | 5 #ifdef HAVE_MALLOC_H |
6 #include <malloc.h> | |
7 #endif | |
1294 | 8 #include <stdlib.h> |
1430 | 9 #include <unistd.h> |
1294 | 10 |
1567 | 11 #include "mp_msg.h" |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1949
diff
changeset
|
12 #include "help_mp.h" |
1294 | 13 |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1309
diff
changeset
|
14 #include "linux/timer.h" |
1496 | 15 #include "linux/shmem.h" |
1327
b12e1817bcc2
some cleanup - fixed warnings, removed old stuff, moved audio resync to dec_audio
arpi
parents:
1309
diff
changeset
|
16 |
2563 | 17 extern int verbose; // defined in mplayer.c |
18 | |
1294 | 19 #include "stream.h" |
20 #include "demuxer.h" | |
1375
dbcb5b5e1fae
file-format detection stuff moved out from mplayer.c to demuxer.c and dec_video.c
arpi
parents:
1367
diff
changeset
|
21 #include "parse_es.h" |
1294 | 22 |
23 #include "codec-cfg.h" | |
24 | |
25 #include "libvo/video_out.h" | |
26 | |
4188 | 27 #include "stheader.h" |
4902
7c4edfe929c8
implemented basic wrapper functions to new libmpcodecs api
arpi
parents:
4901
diff
changeset
|
28 #include "vd.h" |
5507
d0d029fda134
video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
5328
diff
changeset
|
29 #include "vf.h" |
4188 | 30 |
2563 | 31 #include "dec_video.h" |
32 | |
33 // =================================================================== | |
34 | |
35 extern double video_time_usage; | |
36 extern double vout_time_usage; | |
4388 | 37 extern vo_vaa_t vo_vaa; |
2563 | 38 |
2184 | 39 #include "postproc/postprocess.h" |
40 | |
3144 | 41 #include "cpudetect.h" |
42 | |
2563 | 43 int divx_quality=0; |
1294 | 44 |
5180 | 45 vd_functions_t* mpvdec=NULL; |
4902
7c4edfe929c8
implemented basic wrapper functions to new libmpcodecs api
arpi
parents:
4901
diff
changeset
|
46 |
1429 | 47 int get_video_quality_max(sh_video_t *sh_video){ |
4957 | 48 if(mpvdec){ |
4967 | 49 int ret=mpvdec->control(sh_video,VDCTRL_QUERY_MAX_PP_LEVEL,NULL); |
4957 | 50 if(ret>=0) return ret; |
51 } | |
1429 | 52 return 0; |
53 } | |
54 | |
55 void set_video_quality(sh_video_t *sh_video,int quality){ | |
4957 | 56 if(mpvdec) |
57 mpvdec->control(sh_video,VDCTRL_SET_PP_LEVEL, (void*)(&quality)); | |
1429 | 58 } |
59 | |
4395 | 60 int set_video_colors(sh_video_t *sh_video,char *item,int value) |
61 { | |
62 if(vo_vaa.get_video_eq) | |
4388 | 63 { |
4395 | 64 vidix_video_eq_t veq; |
65 if(vo_vaa.get_video_eq(&veq) == 0) | |
4388 | 66 { |
4395 | 67 int v_hw_equ_cap = veq.cap; |
68 if(v_hw_equ_cap != 0) | |
69 { | |
70 if(vo_vaa.set_video_eq) | |
71 { | |
72 vidix_video_eq_t veq; | |
73 veq.flags = VEQ_FLG_ITU_R_BT_601; /* Fixme please !!! */ | |
74 if(strcmp(item,"Brightness") == 0) | |
75 { | |
76 if(!(v_hw_equ_cap & VEQ_CAP_BRIGHTNESS)) goto try_sw_control; | |
77 veq.brightness = value*10; | |
78 veq.cap = VEQ_CAP_BRIGHTNESS; | |
79 } | |
80 else | |
81 if(strcmp(item,"Contrast") == 0) | |
82 { | |
83 if(!(v_hw_equ_cap & VEQ_CAP_CONTRAST)) goto try_sw_control; | |
84 veq.contrast = value*10; | |
85 veq.cap = VEQ_CAP_CONTRAST; | |
86 } | |
87 else | |
88 if(strcmp(item,"Saturation") == 0) | |
89 { | |
90 if(!(v_hw_equ_cap & VEQ_CAP_SATURATION)) goto try_sw_control; | |
91 veq.saturation = value*10; | |
92 veq.cap = VEQ_CAP_SATURATION; | |
93 } | |
94 else | |
95 if(strcmp(item,"Hue") == 0) | |
96 { | |
97 if(!(v_hw_equ_cap & VEQ_CAP_HUE)) goto try_sw_control; | |
98 veq.hue = value*10; | |
99 veq.cap = VEQ_CAP_HUE; | |
100 } | |
101 else goto try_sw_control;; | |
102 vo_vaa.set_video_eq(&veq); | |
103 } | |
104 return 1; | |
105 } | |
4388 | 106 } |
107 } | |
4395 | 108 try_sw_control: |
5005
24d5713afe2f
old temp vars removed, in-codecs equalizer support added, error message if -vfm N/A
arpi
parents:
4971
diff
changeset
|
109 if(mpvdec) return mpvdec->control(sh_video,VDCTRL_SET_EQUALIZER,item,(int)value); |
1429 | 110 return 0; |
111 } | |
1294 | 112 |
2049
df41903fd7d7
VfW stuff moved to dll_init, warnings fixed, using dll_init.h
arpi
parents:
2044
diff
changeset
|
113 void uninit_video(sh_video_t *sh_video){ |
1654 | 114 if(!sh_video->inited) return; |
1973
5216f108cb4f
all error/warn/info messages moved to help_mp-en.h for translation
arpi
parents:
1949
diff
changeset
|
115 mp_msg(MSGT_DECVIDEO,MSGL_V,"uninit video: %d \n",sh_video->codec->driver); |
4902
7c4edfe929c8
implemented basic wrapper functions to new libmpcodecs api
arpi
parents:
4901
diff
changeset
|
116 mpvdec->uninit(sh_video); |
1654 | 117 sh_video->inited=0; |
118 } | |
119 | |
5171
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
120 int init_video(sh_video_t *sh_video,char* codecname,int vfm,int status){ |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
121 sh_video->codec=NULL; |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
122 while((sh_video->codec=find_codec(sh_video->format, |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
123 sh_video->bih?((unsigned int*) &sh_video->bih->biCompression):NULL, |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
124 sh_video->codec,0) )){ |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
125 // ok we found one codec |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
126 int i; |
5328
014ddf03476d
check and set codec selection - impossible to do it at find_codec
arpi
parents:
5266
diff
changeset
|
127 if(sh_video->codec->flags&CODECS_FLAG_SELECTED) continue; // already tried & failed |
5171
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
128 if(codecname && strcmp(sh_video->codec->name,codecname)) continue; // -vc |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
129 if(vfm>=0 && sh_video->codec->driver!=vfm) continue; // vfm doesn't match |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
130 if(sh_video->codec->status<status) continue; // too unstable |
5328
014ddf03476d
check and set codec selection - impossible to do it at find_codec
arpi
parents:
5266
diff
changeset
|
131 sh_video->codec->flags|=CODECS_FLAG_SELECTED; // tagging it |
5171
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
132 // ok, it matches all rules, let's find the driver! |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
133 for (i=0; mpcodecs_vd_drivers[i] != NULL; i++) |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
134 if(mpcodecs_vd_drivers[i]->info->id==sh_video->codec->driver) break; |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
135 mpvdec=mpcodecs_vd_drivers[i]; |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
136 if(!mpvdec){ // driver not available (==compiled in) |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
137 mp_msg(MSGT_DECVIDEO,MSGL_ERR,"Requested video codec family [%s] (vfm=%d) not available (enable it at compile time!)\n", |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
138 sh_video->codec->name, sh_video->codec->driver); |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
139 continue; |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
140 } |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
141 // it's available, let's try to init! |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
142 printf("Opening Video Decoder: [%s] %s\n",mpvdec->info->short_name,mpvdec->info->name); |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
143 if(!mpvdec->init(sh_video)){ |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
144 printf("VDecoder init failed :(\n"); |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
145 continue; // try next... |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
146 } |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
147 // Yeah! We got it! |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
148 sh_video->inited=1; |
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
149 return 1; |
4902
7c4edfe929c8
implemented basic wrapper functions to new libmpcodecs api
arpi
parents:
4901
diff
changeset
|
150 } |
5171
7145d6aba6cd
init_video() changed - now it handles codec selection
arpi
parents:
5155
diff
changeset
|
151 return 0; |
1294 | 152 } |
153 | |
5224 | 154 extern int vo_directrendering; |
4515 | 155 |
5507
d0d029fda134
video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
5328
diff
changeset
|
156 int decode_video(sh_video_t *sh_video,unsigned char *start,int in_size,int drop_frame){ |
d0d029fda134
video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
5328
diff
changeset
|
157 vf_instance_t* vf=sh_video->vfilter; |
4898 | 158 mp_image_t *mpi=NULL; |
1294 | 159 int blit_frame=0; |
1360 | 160 unsigned int t=GetTimer(); |
161 unsigned int t2; | |
4834 | 162 double tt; |
1360 | 163 |
5266
413e450da31c
try to uncomment this line - very funny effect (skipping I frames)
arpi
parents:
5224
diff
changeset
|
164 //if(!(sh_video->ds->flags&1) || sh_video->ds->pack_no<5) |
4902
7c4edfe929c8
implemented basic wrapper functions to new libmpcodecs api
arpi
parents:
4901
diff
changeset
|
165 mpi=mpvdec->decode(sh_video, start, in_size, drop_frame); |
7c4edfe929c8
implemented basic wrapper functions to new libmpcodecs api
arpi
parents:
4901
diff
changeset
|
166 |
1294 | 167 //------------------------ frame decoded. -------------------- |
168 | |
3160 | 169 #ifdef ARCH_X86 |
1367 | 170 // some codecs is broken, and doesn't restore MMX state :( |
171 // it happens usually with broken/damaged files. | |
3144 | 172 if(gCpuCaps.has3DNow){ |
173 __asm __volatile ("femms\n\t":::"memory"); | |
174 } | |
175 else if(gCpuCaps.hasMMX){ | |
176 __asm __volatile ("emms\n\t":::"memory"); | |
177 } | |
3160 | 178 #endif |
1367 | 179 |
4902
7c4edfe929c8
implemented basic wrapper functions to new libmpcodecs api
arpi
parents:
4901
diff
changeset
|
180 if(!mpi) return 0; // error / skipped frame |
7c4edfe929c8
implemented basic wrapper functions to new libmpcodecs api
arpi
parents:
4901
diff
changeset
|
181 |
4834 | 182 t2=GetTimer();t=t2-t; |
183 tt = t*0.000001f; | |
184 video_time_usage+=tt; | |
4898 | 185 |
5040 | 186 if(drop_frame) return 0; |
187 | |
5507
d0d029fda134
video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
5328
diff
changeset
|
188 //vo_draw_image(video_out,mpi); |
d0d029fda134
video filter layer - written from scratch, but inspired a lot by Fredrik Kuivinen's patch
arpi
parents:
5328
diff
changeset
|
189 vf->put_image(vf,mpi); |
4898 | 190 |
4834 | 191 t2=GetTimer()-t2; |
192 tt=t2*0.000001f; | |
193 vout_time_usage+=tt; | |
1360 | 194 blit_frame=1; |
195 | |
1294 | 196 return blit_frame; |
197 } |