annotate libmpcodecs/vd_ffmpeg.c @ 27249:4be2b34aa431

Try to keep decoded audio buffer aligned. Seems to be enough to avoid crashes (due to unaligned SSE2) with FFmpeg vorbis decoding for now.
author reimar
date Mon, 14 Jul 2008 16:38:58 +0000
parents 63630c09e237
children e7c989f7a7c9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
1 #include <stdio.h>
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
2 #include <stdlib.h>
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
3 #include <assert.h>
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
4 #include <time.h>
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
5
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
6 #include "config.h"
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
7 #include "mp_msg.h"
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
8 #include "help_mp.h"
26692
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
9 #include "av_opts.h"
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
10
21372
1767c271d710 Remove bswap.h, use libavutil/bswap.h instead.
diego
parents: 21251
diff changeset
11 #include "libavutil/common.h"
21457
af4c8fd34494 Compile fix, BE_32 definition has been moved
reimar
parents: 21372
diff changeset
12 #include "libavutil/intreadwrite.h"
21507
fa99b3d31d13 Hack around libavutil/bswap.h compilation problems due to always_inline undefined.
reimar
parents: 21498
diff changeset
13 #include "mpbswap.h"
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
14
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
15 #include "vd_internal.h"
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
16
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
17 static vd_info_t info = {
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
18 "FFmpeg's libavcodec codec family",
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
19 "ffmpeg",
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
20 "A'rpi",
7388
2c35b856cf73 extended par support
alex
parents: 7303
diff changeset
21 "A'rpi, Michael, Alex",
2c35b856cf73 extended par support
alex
parents: 7303
diff changeset
22 "native codecs (http://ffmpeg.sf.net/)"
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
23 };
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
24
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
25 LIBVD_EXTERN(ffmpeg)
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
26
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
27 #include "libavcodec/avcodec.h"
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
28
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
29 #ifdef HAVE_XVMC
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
30 #include "xvmc_render.h"
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
31 #endif
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
32
25962
afa125da85cf typo fix: inited --> initialized
diego
parents: 25241
diff changeset
33 int avcodec_initialized=0;
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
34
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
35 typedef struct {
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
36 AVCodecContext *avctx;
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
37 AVFrame *pic;
17973
75442247ee56 reinit vo when pix_fmt changes.
reimar
parents: 17932
diff changeset
38 enum PixelFormat pix_fmt;
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
39 int do_slices;
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
40 int do_dr1;
25962
afa125da85cf typo fix: inited --> initialized
diego
parents: 25241
diff changeset
41 int vo_initialized;
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
42 int best_csp;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
43 int b_age;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
44 int ip_age[2];
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
45 int qp_stat[32];
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
46 double qp_sum;
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
47 double inv_qp_sum;
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
48 int ip_count;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
49 int b_count;
22277
de3ca43ae51e reinit the vo when aspect ratio changes; patch by C.E. Hoyos approved by Michael
nicodvb
parents: 22222
diff changeset
50 AVRational last_sample_aspect_ratio;
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
51 } vd_ffmpeg_ctx;
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
52
17463
b56f34ba3f2f proper support for shared libpostproc
diego
parents: 17226
diff changeset
53 //#ifdef USE_LIBPOSTPROC
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
54 //unsigned int lavc_pp=0;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
55 //#endif
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
56
10594
57bdcdb061d7 Removed the historic cfgparser and switched full to the new config parser (altought some macros still remain for compatibility). As a side effect 90% of the warning messages are gone from the core. Things should be cleaner now and less confusing for newbies.
alex
parents: 10471
diff changeset
57 #include "m_option.h"
6265
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
58
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
59 static int get_buffer(AVCodecContext *avctx, AVFrame *pic);
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
60 static void release_buffer(AVCodecContext *avctx, AVFrame *pic);
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
61
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
62 #ifdef HAVE_XVMC
24253
e0ed786a7fb9 warning fix:
diego
parents: 24248
diff changeset
63 static enum PixelFormat get_format(struct AVCodecContext * avctx,
e0ed786a7fb9 warning fix:
diego
parents: 24248
diff changeset
64 const enum PixelFormat * pix_fmt);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
65 static int mc_get_buffer(AVCodecContext *avctx, AVFrame *pic);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
66 static void mc_release_buffer(AVCodecContext *avctx, AVFrame *pic);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
67 static void mc_render_slice(struct AVCodecContext *s,
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
68 AVFrame *src, int offset[4],
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
69 int y, int type, int height);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
70 #endif
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
71
7722
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
72 static int lavc_param_workaround_bugs= FF_BUG_AUTODETECT;
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
73 static int lavc_param_error_resilience=2;
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
74 static int lavc_param_error_concealment=3;
26395
71bd93e71a97 Restore grayscale decoding support with FFmpeg.
diego
parents: 26166
diff changeset
75 static int lavc_param_gray=0;
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
76 static int lavc_param_vstats=0;
7564
24165f770c0d idct algo selection support
michael
parents: 7512
diff changeset
77 static int lavc_param_idct_algo=0;
8341
fd670708f87f specific debug output support
michael
parents: 8340
diff changeset
78 static int lavc_param_debug=0;
11702
e4c043ebf3a6 vismv, alt, ilme options
michael
parents: 11669
diff changeset
79 static int lavc_param_vismv=0;
12670
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
80 static int lavc_param_skip_top=0;
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
81 static int lavc_param_skip_bottom=0;
13230
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
82 static int lavc_param_fast=0;
13473
daeea32a0956 low resolution decoding
michael
parents: 13333
diff changeset
83 static int lavc_param_lowres=0;
14169
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
84 static char *lavc_param_lowres_str=NULL;
15986
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
85 static char *lavc_param_skip_loop_filter_str = NULL;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
86 static char *lavc_param_skip_idct_str = NULL;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
87 static char *lavc_param_skip_frame_str = NULL;
17080
b3ef98ca8677 multithreaded decoding
michael
parents: 17073
diff changeset
88 static int lavc_param_threads=1;
17217
0d8eee43f85c bitexact flag
michael
parents: 17080
diff changeset
89 static int lavc_param_bitexact=0;
26692
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
90 static char *lavc_avopt = NULL;
6265
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
91
25241
bb7c65f2a289 Make m_option_t arrays referenced by cfg-common.h const
reimar
parents: 24854
diff changeset
92 const m_option_t lavc_decode_opts_conf[]={
9547
3b3b7b6fdb22 merging fourcc with codec_tag
michael
parents: 9400
diff changeset
93 {"bug", &lavc_param_workaround_bugs, CONF_TYPE_INT, CONF_RANGE, -1, 999999, NULL},
7722
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
94 {"er", &lavc_param_error_resilience, CONF_TYPE_INT, CONF_RANGE, 0, 99, NULL},
26395
71bd93e71a97 Restore grayscale decoding support with FFmpeg.
diego
parents: 26166
diff changeset
95 {"gray", &lavc_param_gray, CONF_TYPE_FLAG, 0, 0, CODEC_FLAG_PART, NULL},
7564
24165f770c0d idct algo selection support
michael
parents: 7512
diff changeset
96 {"idct", &lavc_param_idct_algo, CONF_TYPE_INT, CONF_RANGE, 0, 99, NULL},
7722
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
97 {"ec", &lavc_param_error_concealment, CONF_TYPE_INT, CONF_RANGE, 0, 99, NULL},
6869
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
98 {"vstats", &lavc_param_vstats, CONF_TYPE_FLAG, 0, 0, 1, NULL},
8341
fd670708f87f specific debug output support
michael
parents: 8340
diff changeset
99 {"debug", &lavc_param_debug, CONF_TYPE_INT, CONF_RANGE, 0, 9999999, NULL},
11702
e4c043ebf3a6 vismv, alt, ilme options
michael
parents: 11669
diff changeset
100 {"vismv", &lavc_param_vismv, CONF_TYPE_INT, CONF_RANGE, 0, 9999999, NULL},
12670
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
101 {"st", &lavc_param_skip_top, CONF_TYPE_INT, CONF_RANGE, 0, 999, NULL},
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
102 {"sb", &lavc_param_skip_bottom, CONF_TYPE_INT, CONF_RANGE, 0, 999, NULL},
13230
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
103 #ifdef CODEC_FLAG2_FAST
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
104 {"fast", &lavc_param_fast, CONF_TYPE_FLAG, 0, 0, CODEC_FLAG2_FAST, NULL},
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
105 #endif
14169
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
106 {"lowres", &lavc_param_lowres_str, CONF_TYPE_STRING, 0, 0, 0, NULL},
15986
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
107 {"skiploopfilter", &lavc_param_skip_loop_filter_str, CONF_TYPE_STRING, 0, 0, 0, NULL},
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
108 {"skipidct", &lavc_param_skip_idct_str, CONF_TYPE_STRING, 0, 0, 0, NULL},
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
109 {"skipframe", &lavc_param_skip_frame_str, CONF_TYPE_STRING, 0, 0, 0, NULL},
17080
b3ef98ca8677 multithreaded decoding
michael
parents: 17073
diff changeset
110 {"threads", &lavc_param_threads, CONF_TYPE_INT, CONF_RANGE, 1, 8, NULL},
17217
0d8eee43f85c bitexact flag
michael
parents: 17080
diff changeset
111 {"bitexact", &lavc_param_bitexact, CONF_TYPE_FLAG, 0, 0, CODEC_FLAG_BITEXACT, NULL},
26692
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
112 {"o", &lavc_avopt, CONF_TYPE_STRING, 0, 0, 0, NULL},
6265
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
113 {NULL, NULL, 0, 0, 0, 0, NULL}
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
114 };
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
115
15986
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
116 static enum AVDiscard str2AVDiscard(char *str) {
26694
75ec8833185c Reformat very ugly code.
michael
parents: 26692
diff changeset
117 if (!str) return AVDISCARD_DEFAULT;
75ec8833185c Reformat very ugly code.
michael
parents: 26692
diff changeset
118 if (strcasecmp(str, "none" ) == 0) return AVDISCARD_NONE;
75ec8833185c Reformat very ugly code.
michael
parents: 26692
diff changeset
119 if (strcasecmp(str, "default") == 0) return AVDISCARD_DEFAULT;
75ec8833185c Reformat very ugly code.
michael
parents: 26692
diff changeset
120 if (strcasecmp(str, "nonref" ) == 0) return AVDISCARD_NONREF;
75ec8833185c Reformat very ugly code.
michael
parents: 26692
diff changeset
121 if (strcasecmp(str, "bidir" ) == 0) return AVDISCARD_BIDIR;
75ec8833185c Reformat very ugly code.
michael
parents: 26692
diff changeset
122 if (strcasecmp(str, "nonkey" ) == 0) return AVDISCARD_NONKEY;
75ec8833185c Reformat very ugly code.
michael
parents: 26692
diff changeset
123 if (strcasecmp(str, "all" ) == 0) return AVDISCARD_ALL;
75ec8833185c Reformat very ugly code.
michael
parents: 26692
diff changeset
124 mp_msg(MSGT_DECVIDEO, MSGL_ERR, "Unknown discard value %s\n", str);
15986
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
125 return AVDISCARD_DEFAULT;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
126 }
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
127
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
128 // to set/get/query special features/parameters
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
129 static int control(sh_video_t *sh,int cmd,void* arg,...){
5592
b545d56314d2 yuy2 support, fixed bug of dropping frame after config_vo calls
arpi
parents: 5517
diff changeset
130 vd_ffmpeg_ctx *ctx = sh->context;
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
131 AVCodecContext *avctx = ctx->avctx;
5592
b545d56314d2 yuy2 support, fixed bug of dropping frame after config_vo calls
arpi
parents: 5517
diff changeset
132 switch(cmd){
b545d56314d2 yuy2 support, fixed bug of dropping frame after config_vo calls
arpi
parents: 5517
diff changeset
133 case VDCTRL_QUERY_FORMAT:
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
134 {
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
135 int format =(*((int*)arg));
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
136 if( format == ctx->best_csp ) return CONTROL_TRUE;//supported
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
137 // possible conversions:
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
138 switch( format ){
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
139 case IMGFMT_YV12:
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
140 case IMGFMT_IYUV:
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
141 case IMGFMT_I420:
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
142 // "converted" using pointer/stride modification
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
143 if(avctx->pix_fmt==PIX_FMT_YUV420P) return CONTROL_TRUE;// u/v swap
11064
cc5944174c46 YUV422P dr1 fix
michael
parents: 11000
diff changeset
144 if(avctx->pix_fmt==PIX_FMT_YUV422P && !ctx->do_dr1) return CONTROL_TRUE;// half stride
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
145 break;
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
146 #ifdef HAVE_XVMC
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
147 case IMGFMT_XVMC_IDCT_MPEG2:
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
148 case IMGFMT_XVMC_MOCO_MPEG2:
10471
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
149 if(avctx->pix_fmt==PIX_FMT_XVMC_MPEG2_IDCT) return CONTROL_TRUE;
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
150 #endif
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
151 }
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
152 return CONTROL_FALSE;
11977
efb37725d616 flushing stuff after seeking (finally we can view MPEG without thouse blocks after seeking with -vc ffmpeg12)
michael
parents: 11955
diff changeset
153 }
efb37725d616 flushing stuff after seeking (finally we can view MPEG without thouse blocks after seeking with -vc ffmpeg12)
michael
parents: 11955
diff changeset
154 break;
efb37725d616 flushing stuff after seeking (finally we can view MPEG without thouse blocks after seeking with -vc ffmpeg12)
michael
parents: 11955
diff changeset
155 case VDCTRL_RESYNC_STREAM:
efb37725d616 flushing stuff after seeking (finally we can view MPEG without thouse blocks after seeking with -vc ffmpeg12)
michael
parents: 11955
diff changeset
156 avcodec_flush_buffers(avctx);
18917
d9a75b26da6c Add a new video pts tracking mode, enabled by option -correct-pts.
uau
parents: 18879
diff changeset
157 return CONTROL_TRUE;
d9a75b26da6c Add a new video pts tracking mode, enabled by option -correct-pts.
uau
parents: 18879
diff changeset
158 case VDCTRL_QUERY_UNSEEN_FRAMES:
d9a75b26da6c Add a new video pts tracking mode, enabled by option -correct-pts.
uau
parents: 18879
diff changeset
159 return avctx->has_b_frames + 10;
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
160 }
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
161 return CONTROL_UNKNOWN;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
162 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
163
20741
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
164 void mp_msp_av_log_callback(void* ptr, int level, const char* fmt, va_list vl)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
165 {
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
166 static int print_prefix=1;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
167 AVClass* avc= ptr ? *(AVClass**)ptr : NULL;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
168 int type= MSGT_FIXME;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
169 int mp_level;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
170 char buf[256];
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
171
21242
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
172 switch(level){
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
173 case AV_LOG_DEBUG: mp_level= MSGL_V ; break;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
174 case AV_LOG_INFO : mp_level= MSGL_INFO; break;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
175 case AV_LOG_ERROR: mp_level= MSGL_ERR ; break;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
176 default : mp_level= MSGL_ERR ; break;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
177 }
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
178
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
179 if (!mp_msg_test(type, mp_level)) return;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
180
20741
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
181 if(ptr){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
182 if(!strcmp(avc->class_name, "AVCodecContext")){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
183 AVCodecContext * s= ptr;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
184 if(s->codec){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
185 if(s->codec->type == CODEC_TYPE_AUDIO){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
186 if(s->codec->decode)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
187 type= MSGT_DECAUDIO;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
188 }else if(s->codec->type == CODEC_TYPE_VIDEO){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
189 if(s->codec->decode)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
190 type= MSGT_DECVIDEO;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
191 }
22316
f3d7a1b58a82 cosmetics: Fix some common typos, appropiate --> appropRiate,
diego
parents: 22277
diff changeset
192 //FIXME subtitles, encoders (what msgt for them? there is no appropriate ...)
20741
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
193 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
194 }else if(!strcmp(avc->class_name, "AVFormatContext")){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
195 #if 0 //needs libavformat include FIXME iam too lazy to do this cleanly,probably the whole should be moved out of this file ...
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
196 AVFormatContext * s= ptr;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
197 if(s->iformat)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
198 type= MSGT_DEMUXER;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
199 else if(s->oformat)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
200 type= MSGT_MUXER;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
201 #endif
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
202 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
203 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
204
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
205 if(print_prefix && avc) {
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
206 mp_msg(type, mp_level, "[%s @ %p]", avc->item_name(ptr), avc);
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
207 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
208
21243
3ee64ff583a9 Useless use of strstr, strchr is good enough.
reimar
parents: 21242
diff changeset
209 print_prefix= strchr(fmt, '\n') != NULL;
20741
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
210 vsnprintf(buf, sizeof(buf), fmt, vl);
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
211 mp_msg(type, mp_level, buf);
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
212 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
213
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
214 // init driver
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
215 static int init(sh_video_t *sh){
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
216 AVCodecContext *avctx;
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
217 vd_ffmpeg_ctx *ctx;
5457
f248c9e86423 config vo only if aspect really changed and width&&height isn't changed (if w||h changes, we set it later)
alex
parents: 5331
diff changeset
218 AVCodec *lavc_codec;
14169
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
219 int lowres_w=0;
11712
5905aae865c7 disable dr1&slices for the other vissualizations too
michael
parents: 11711
diff changeset
220 int do_vis_debug= lavc_param_vismv || (lavc_param_debug&(FF_DEBUG_VIS_MB_TYPE|FF_DEBUG_VIS_QP));
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
221
25962
afa125da85cf typo fix: inited --> initialized
diego
parents: 25241
diff changeset
222 if(!avcodec_initialized){
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
223 avcodec_init();
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
224 avcodec_register_all();
25962
afa125da85cf typo fix: inited --> initialized
diego
parents: 25241
diff changeset
225 avcodec_initialized=1;
22153
0cf24df5d97b Revert part of commit r22170.
iive
parents: 22152
diff changeset
226 av_log_set_callback(mp_msp_av_log_callback);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
227 }
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
228
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
229 ctx = sh->context = malloc(sizeof(vd_ffmpeg_ctx));
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
230 if (!ctx)
26754
63630c09e237 cosmetics: Remove pointless parentheses from return calls.
diego
parents: 26694
diff changeset
231 return 0;
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
232 memset(ctx, 0, sizeof(vd_ffmpeg_ctx));
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
233
5457
f248c9e86423 config vo only if aspect really changed and width&&height isn't changed (if w||h changes, we set it later)
alex
parents: 5331
diff changeset
234 lavc_codec = (AVCodec *)avcodec_find_decoder_by_name(sh->codec->dll);
f248c9e86423 config vo only if aspect really changed and width&&height isn't changed (if w||h changes, we set it later)
alex
parents: 5331
diff changeset
235 if(!lavc_codec){
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
236 mp_msg(MSGT_DECVIDEO,MSGL_ERR,MSGTR_MissingLAVCcodec,sh->codec->dll);
21498
f2c58d4fb683 Fix memleak if vd_ffmpeg init fails
reimar
parents: 21457
diff changeset
237 uninit(sh);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
238 return 0;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
239 }
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
240
11712
5905aae865c7 disable dr1&slices for the other vissualizations too
michael
parents: 11711
diff changeset
241 if(vd_use_slices && (lavc_codec->capabilities&CODEC_CAP_DRAW_HORIZ_BAND) && !do_vis_debug)
5494
1c45b1484ffb i just fixed b-frames & slices in libavcodec :) ... iam too tired for benchmarks now ...
michael
parents: 5482
diff changeset
242 ctx->do_slices=1;
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
243
24656
ed5edb202ec2 Disable direct rendering for ROQ video, the buffer management used by
rtogni
parents: 24523
diff changeset
244 if(lavc_codec->capabilities&CODEC_CAP_DR1 && !do_vis_debug && lavc_codec->id != CODEC_ID_H264 && lavc_codec->id != CODEC_ID_INTERPLAY_VIDEO && lavc_codec->id != CODEC_ID_ROQ)
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
245 ctx->do_dr1=1;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
246 ctx->b_age= ctx->ip_age[0]= ctx->ip_age[1]= 256*256*256*64;
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
247 ctx->ip_count= ctx->b_count= 0;
7444
56a16bd12b79 use avcodec_alloc_context()
michael
parents: 7388
diff changeset
248
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
249 ctx->pic = avcodec_alloc_frame();
7444
56a16bd12b79 use avcodec_alloc_context()
michael
parents: 7388
diff changeset
250 ctx->avctx = avcodec_alloc_context();
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
251 avctx = ctx->avctx;
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
252
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
253 #ifdef HAVE_XVMC
12033
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
254
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
255 #ifdef CODEC_CAP_HWACCEL
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
256 if(lavc_codec->capabilities & CODEC_CAP_HWACCEL){
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
257 #else
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
258 if(lavc_codec->id == CODEC_ID_MPEG2VIDEO_XVMC){
24248
09014500046f cosmetics: Add some explanatory comments to #endif directives.
diego
parents: 24142
diff changeset
259 #endif /* CODEC_CAP_HWACCEL */
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
260 mp_msg(MSGT_DECVIDEO, MSGL_INFO, MSGTR_MPCODECS_XVMCAcceleratedCodec);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
261 assert(ctx->do_dr1);//these are must to!
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
262 assert(ctx->do_slices); //it is (vo_)ffmpeg bug if this fails
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
263 avctx->flags|= CODEC_FLAG_EMU_EDGE;//do i need that??!!
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
264 avctx->get_format= get_format;//for now only this decoder will use it
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
265 avctx->get_buffer= mc_get_buffer;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
266 avctx->release_buffer= mc_release_buffer;
10471
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
267 avctx->draw_horiz_band = mc_render_slice;
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
268 avctx->slice_flags=SLICE_FLAG_CODED_ORDER|SLICE_FLAG_ALLOW_FIELD;
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
269 }else
24248
09014500046f cosmetics: Add some explanatory comments to #endif directives.
diego
parents: 24142
diff changeset
270 #endif /* HAVE_XVMC */
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
271 if(ctx->do_dr1){
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
272 avctx->flags|= CODEC_FLAG_EMU_EDGE;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
273 avctx->get_buffer= get_buffer;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
274 avctx->release_buffer= release_buffer;
11526
523570adaad5 reget_buffer() support
rtognimp
parents: 11431
diff changeset
275 avctx->reget_buffer= get_buffer;
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
276 }
7303
e805ef05536c fixing mpeg in avi
michael
parents: 7220
diff changeset
277
e805ef05536c fixing mpeg in avi
michael
parents: 7220
diff changeset
278 #ifdef CODEC_FLAG_NOT_TRUNCATED
e805ef05536c fixing mpeg in avi
michael
parents: 7220
diff changeset
279 avctx->flags|= CODEC_FLAG_NOT_TRUNCATED;
e805ef05536c fixing mpeg in avi
michael
parents: 7220
diff changeset
280 #endif
17217
0d8eee43f85c bitexact flag
michael
parents: 17080
diff changeset
281 avctx->flags|= lavc_param_bitexact;
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
282
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
283 avctx->width = sh->disp_w;
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
284 avctx->height= sh->disp_h;
6265
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
285 avctx->workaround_bugs= lavc_param_workaround_bugs;
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
286 avctx->error_resilience= lavc_param_error_resilience;
26395
71bd93e71a97 Restore grayscale decoding support with FFmpeg.
diego
parents: 26166
diff changeset
287 if(lavc_param_gray) avctx->flags|= CODEC_FLAG_GRAY;
13230
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
288 #ifdef CODEC_FLAG2_FAST
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
289 avctx->flags2|= lavc_param_fast;
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
290 #endif
9547
3b3b7b6fdb22 merging fourcc with codec_tag
michael
parents: 9400
diff changeset
291 avctx->codec_tag= sh->format;
10847
98dc548dbf2d pass stream header FCC
michael
parents: 10774
diff changeset
292 avctx->stream_codec_tag= sh->video.fccHandler;
7564
24165f770c0d idct algo selection support
michael
parents: 7512
diff changeset
293 avctx->idct_algo= lavc_param_idct_algo;
7722
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
294 avctx->error_concealment= lavc_param_error_concealment;
8341
fd670708f87f specific debug output support
michael
parents: 8340
diff changeset
295 avctx->debug= lavc_param_debug;
17073
177c02c3785f make -lavdopts debug work again, patch by Jason Tackaberry ( tack AH sault POIS org )
gpoirier
parents: 16963
diff changeset
296 if (lavc_param_debug)
22153
0cf24df5d97b Revert part of commit r22170.
iive
parents: 22152
diff changeset
297 av_log_set_level(AV_LOG_DEBUG);
11702
e4c043ebf3a6 vismv, alt, ilme options
michael
parents: 11669
diff changeset
298 avctx->debug_mv= lavc_param_vismv;
12670
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
299 avctx->skip_top = lavc_param_skip_top;
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
300 avctx->skip_bottom= lavc_param_skip_bottom;
14169
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
301 if(lavc_param_lowres_str != NULL)
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
302 {
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
303 sscanf(lavc_param_lowres_str, "%d,%d", &lavc_param_lowres, &lowres_w);
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
304 if(lavc_param_lowres < 1 || lavc_param_lowres > 16 || (lowres_w > 0 && avctx->width < lowres_w))
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
305 lavc_param_lowres = 0;
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
306 avctx->lowres = lavc_param_lowres;
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
307 }
15986
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
308 avctx->skip_loop_filter = str2AVDiscard(lavc_param_skip_loop_filter_str);
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
309 avctx->skip_idct = str2AVDiscard(lavc_param_skip_idct_str);
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
310 avctx->skip_frame = str2AVDiscard(lavc_param_skip_frame_str);
26692
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
311
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
312 if(lavc_avopt){
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
313 if(parse_avopts(avctx, lavc_avopt) < 0){
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
314 mp_msg(MSGT_DECVIDEO,MSGL_ERR, "Your options /%s/ look like gibberish to me pal\n", lavc_avopt);
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
315 uninit(sh);
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
316 return 0;
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
317 }
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
318 }
0e325c1957f1 AVOptions support for libavcodec based video decoders.
michael
parents: 26395
diff changeset
319
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
320 mp_dbg(MSGT_DECVIDEO,MSGL_DBG2,"libavcodec.size: %d x %d\n",avctx->width,avctx->height);
18023
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
321 switch (sh->format) {
19278
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
322 case mmioFOURCC('S','V','Q','3'):
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
323 /* SVQ3 extradata can show up as sh->ImageDesc if demux_mov is used, or
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
324 in the phony AVI header if demux_lavf is used. The first case is
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
325 handled here; the second case falls through to the next section. */
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
326 if (sh->ImageDesc) {
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
327 avctx->extradata_size = (*(int*)sh->ImageDesc) - sizeof(int);
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
328 avctx->extradata = av_mallocz(avctx->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
329 memcpy(avctx->extradata, ((int*)sh->ImageDesc)+1, avctx->extradata_size);
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
330 break;
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
331 }
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
332 /* fallthrough */
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
333
18023
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
334 case mmioFOURCC('A','V','R','n'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
335 case mmioFOURCC('M','J','P','G'):
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
336 /* AVRn stores huffman table in AVI header */
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
337 /* Pegasus MJPEG stores it also in AVI header, but it uses the common
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
338 MJPG fourcc :( */
18023
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
339 if (!sh->bih || sh->bih->biSize <= sizeof(BITMAPINFOHEADER))
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
340 break;
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
341 avctx->flags |= CODEC_FLAG_EXTERN_HUFF;
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
342 avctx->extradata_size = sh->bih->biSize-sizeof(BITMAPINFOHEADER);
17226
255b14c0bc36 malloc padding to avoid access beyond allocated memory
henry
parents: 17217
diff changeset
343 avctx->extradata = av_mallocz(avctx->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
19277
3f910f7b0e53 Fix bogus pointer addition in the extraction of extradata from
pacman
parents: 19073
diff changeset
344 memcpy(avctx->extradata, sh->bih+1, avctx->extradata_size);
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
345
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
346 #if 0
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
347 {
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
348 int x;
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
349 uint8_t *p = avctx->extradata;
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
350
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
351 for (x=0; x<avctx->extradata_size; x++)
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
352 mp_msg(MSGT_DECVIDEO, MSGL_INFO,"[%x] ", p[x]);
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
353 mp_msg(MSGT_DECVIDEO, MSGL_INFO,"\n");
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
354 }
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
355 #endif
18023
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
356 break;
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
357
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
358 case mmioFOURCC('R', 'V', '1', '0'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
359 case mmioFOURCC('R', 'V', '1', '3'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
360 case mmioFOURCC('R', 'V', '2', '0'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
361 case mmioFOURCC('R', 'V', '3', '0'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
362 case mmioFOURCC('R', 'V', '4', '0'):
20920
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
363 if(sh->bih->biSize<sizeof(*sh->bih)+8){
7574
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
364 /* only 1 packet per frame & sub_id from fourcc */
20920
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
365 avctx->extradata_size= 8;
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
366 avctx->extradata = av_mallocz(avctx->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
7574
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
367 ((uint32_t*)avctx->extradata)[0] = 0;
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
368 ((uint32_t*)avctx->extradata)[1] =
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
369 (sh->format == mmioFOURCC('R', 'V', '1', '3')) ? 0x10003001 : 0x10000000;
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
370 } else {
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
371 /* has extra slice header (demux_rm or rm->avi streamcopy) */
20920
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
372 avctx->extradata_size = sh->bih->biSize-sizeof(BITMAPINFOHEADER);
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
373 avctx->extradata = av_mallocz(avctx->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
374 memcpy(avctx->extradata, sh->bih+1, avctx->extradata_size);
7574
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
375 }
21946
ea78a2b99651 BE_32 -> AV_RB32
reimar
parents: 21531
diff changeset
376 avctx->sub_id= AV_RB32(avctx->extradata+4);
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
377
7126
d3fd5d568594 passing extra stuff from real stuff to lavc
michael
parents: 7051
diff changeset
378 // printf("%X %X %d %d\n", extrahdr[0], extrahdr[1]);
18023
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
379 break;
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
380
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
381 default:
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
382 if (!sh->bih || sh->bih->biSize <= sizeof(BITMAPINFOHEADER))
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
383 break;
7736
b81b0ab0aa40 put M4S2 & MP4S headers in avctx->extradata (in the unlikely case that they arent missing completly)
michael
parents: 7722
diff changeset
384 avctx->extradata_size = sh->bih->biSize-sizeof(BITMAPINFOHEADER);
17226
255b14c0bc36 malloc padding to avoid access beyond allocated memory
henry
parents: 17217
diff changeset
385 avctx->extradata = av_mallocz(avctx->extradata_size + FF_INPUT_BUFFER_PADDING_SIZE);
7736
b81b0ab0aa40 put M4S2 & MP4S headers in avctx->extradata (in the unlikely case that they arent missing completly)
michael
parents: 7722
diff changeset
386 memcpy(avctx->extradata, sh->bih+1, avctx->extradata_size);
18023
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
387 break;
7736
b81b0ab0aa40 put M4S2 & MP4S headers in avctx->extradata (in the unlikely case that they arent missing completly)
michael
parents: 7722
diff changeset
388 }
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
389 /* Pass palette to codec */
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
390 if (sh->bih && (sh->bih->biBitCount <= 8)) {
18879
cc65a585fdcc rm unnecesary casts from void* - part 3
reynaldo
parents: 18023
diff changeset
391 avctx->palctrl = calloc(1,sizeof(AVPaletteControl));
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
392 avctx->palctrl->palette_changed = 1;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
393 if (sh->bih->biSize-sizeof(BITMAPINFOHEADER))
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
394 /* Palette size in biSize */
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
395 memcpy(avctx->palctrl->palette, sh->bih+1,
21531
a90aa203186c Get rid of min/max macros from aviheader.h, they do not belong here.
reimar
parents: 21507
diff changeset
396 FFMIN(sh->bih->biSize-sizeof(BITMAPINFOHEADER), AVPALETTE_SIZE));
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
397 else
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
398 /* Palette size in biClrUsed */
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
399 memcpy(avctx->palctrl->palette, sh->bih+1,
21531
a90aa203186c Get rid of min/max macros from aviheader.h, they do not belong here.
reimar
parents: 21507
diff changeset
400 FFMIN(sh->bih->biClrUsed * 4, AVPALETTE_SIZE));
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
401 }
19073
8b52dad54b1d Remove #if LIBAVCODEC_BUILD >= XXX and #if LIBAVFORMAT_BUILD >= XXX jungle.
diego
parents: 18917
diff changeset
402
8264
1f3708389d0a 10l (broken ffmpeg12)
michael
parents: 8237
diff changeset
403 if(sh->bih)
1f3708389d0a 10l (broken ffmpeg12)
michael
parents: 8237
diff changeset
404 avctx->bits_per_sample= sh->bih->biBitCount;
7126
d3fd5d568594 passing extra stuff from real stuff to lavc
michael
parents: 7051
diff changeset
405
17080
b3ef98ca8677 multithreaded decoding
michael
parents: 17073
diff changeset
406 if(lavc_param_threads > 1)
b3ef98ca8677 multithreaded decoding
michael
parents: 17073
diff changeset
407 avcodec_thread_init(avctx, lavc_param_threads);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
408 /* open it */
5457
f248c9e86423 config vo only if aspect really changed and width&&height isn't changed (if w||h changes, we set it later)
alex
parents: 5331
diff changeset
409 if (avcodec_open(avctx, lavc_codec) < 0) {
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
410 mp_msg(MSGT_DECVIDEO,MSGL_ERR, MSGTR_CantOpenCodec);
21498
f2c58d4fb683 Fix memleak if vd_ffmpeg init fails
reimar
parents: 21457
diff changeset
411 uninit(sh);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
412 return 0;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
413 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
414 mp_msg(MSGT_DECVIDEO,MSGL_V,"INFO: libavcodec init OK!\n");
5510
f2c4cace6450 don't config twice
arpi
parents: 5495
diff changeset
415 return 1; //mpcodecs_config_vo(sh,sh->disp_w,sh->disp_h,IMGFMT_YV12);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
416 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
417
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
418 // uninit driver
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
419 static void uninit(sh_video_t *sh){
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
420 vd_ffmpeg_ctx *ctx = sh->context;
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
421 AVCodecContext *avctx = ctx->avctx;
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
422
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
423 if(lavc_param_vstats){
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
424 int i;
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
425 for(i=1; i<32; i++){
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
426 mp_msg(MSGT_DECVIDEO, MSGL_INFO,"QP: %d, count: %d\n", i, ctx->qp_stat[i]);
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
427 }
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
428 mp_msg(MSGT_DECVIDEO, MSGL_INFO,MSGTR_MPCODECS_ArithmeticMeanOfQP,
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
429 ctx->qp_sum / avctx->coded_frame->coded_picture_number,
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
430 1.0/(ctx->inv_qp_sum / avctx->coded_frame->coded_picture_number)
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
431 );
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
432 }
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
433
22091
035fd43fe5f1 Avoid crash in uninit if codec not found
reimar
parents: 22076
diff changeset
434 if (avctx) {
22092
acac2d8bc25f Cosmetics
reimar
parents: 22091
diff changeset
435 if (avctx->codec && avcodec_close(avctx) < 0)
acac2d8bc25f Cosmetics
reimar
parents: 22091
diff changeset
436 mp_msg(MSGT_DECVIDEO,MSGL_ERR, MSGTR_CantCloseCodec);
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
437
22092
acac2d8bc25f Cosmetics
reimar
parents: 22091
diff changeset
438 av_freep(&avctx->extradata);
acac2d8bc25f Cosmetics
reimar
parents: 22091
diff changeset
439 av_freep(&avctx->palctrl);
acac2d8bc25f Cosmetics
reimar
parents: 22091
diff changeset
440 av_freep(&avctx->slice_offset);
22091
035fd43fe5f1 Avoid crash in uninit if codec not found
reimar
parents: 22076
diff changeset
441 }
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
442
14431
0c10f923746e change malloc and free to av_ variants where needed.
reimar
parents: 14169
diff changeset
443 av_freep(&avctx);
0c10f923746e change malloc and free to av_ variants where needed.
reimar
parents: 14169
diff changeset
444 av_freep(&ctx->pic);
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
445 if (ctx)
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
446 free(ctx);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
447 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
448
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
449 static void draw_slice(struct AVCodecContext *s,
10436
f9e4db4e4759 new ff_draw_horiz_band()
michael
parents: 10423
diff changeset
450 AVFrame *src, int offset[4],
10449
498568fe7fd8 width -> frame / field type
michael
parents: 10436
diff changeset
451 int y, int type, int height){
6710
8898dd6c0302 Don't call libvo draw slice directly
albeu
parents: 6681
diff changeset
452 sh_video_t * sh = s->opaque;
24142
931b5401fa01 Fix some unused variable warnings.
diego
parents: 23381
diff changeset
453 uint8_t *source[3]= {src->data[0] + offset[0], src->data[1] + offset[1], src->data[2] + offset[2]};
931b5401fa01 Fix some unused variable warnings.
diego
parents: 23381
diff changeset
454 #if 0
6740
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
455 int start=0, i;
10449
498568fe7fd8 width -> frame / field type
michael
parents: 10436
diff changeset
456 int width= s->width;
13489
912c906db2ed compensate for width/height being picture width/height instead of bitstream width/height
michael
parents: 13473
diff changeset
457 int skip_stride= ((width<<lavc_param_lowres)+15)>>4;
9400
e572a8df7e88 10l to kabi (compile fix, uint8->uint8_t)
arpi
parents: 8885
diff changeset
458 uint8_t *skip= &s->coded_frame->mbskip_table[(y>>4)*skip_stride];
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
459 int threshold= s->coded_frame->age;
6740
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
460 if(s->pict_type!=B_TYPE){
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
461 for(i=0; i*16<width+16; i++){
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
462 if(i*16>=width || skip[i]>=threshold){
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
463 if(start==i) start++;
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
464 else{
9400
e572a8df7e88 10l to kabi (compile fix, uint8->uint8_t)
arpi
parents: 8885
diff changeset
465 uint8_t *src2[3]= {src[0] + start*16,
6740
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
466 src[1] + start*8,
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
467 src[2] + start*8};
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
468 //printf("%2d-%2d x %d\n", start, i, y);
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
469 mpcodecs_draw_slice (sh,src2, stride, (i-start)*16, height, start*16, y);
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
470 start= i+1;
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
471 }
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
472 }
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
473 }
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
474 }else
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
475 #endif
15683
978f2346dc43 correcting the previous draw_slice fix
henry
parents: 15678
diff changeset
476 if (y < sh->disp_h) {
15694
22024992b231 10l for me
henry
parents: 15683
diff changeset
477 mpcodecs_draw_slice (sh, source, src->linesize, sh->disp_w, (y+height)<=sh->disp_h?height:sh->disp_h-y, 0, y);
15683
978f2346dc43 correcting the previous draw_slice fix
henry
parents: 15678
diff changeset
478 }
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
479 }
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
480
10436
f9e4db4e4759 new ff_draw_horiz_band()
michael
parents: 10423
diff changeset
481
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
482 static int init_vo(sh_video_t *sh, enum PixelFormat pix_fmt){
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
483 vd_ffmpeg_ctx *ctx = sh->context;
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
484 AVCodecContext *avctx = ctx->avctx;
11194
c9a3a1e70263 sample_aspect_ratio
michael
parents: 11064
diff changeset
485 float aspect= av_q2d(avctx->sample_aspect_ratio) * avctx->width / avctx->height;
15567
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
486 int width, height;
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
487
15567
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
488 width = avctx->width;
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
489 height = avctx->height;
15569
dff7e79b194f quicktime fix update
henry
parents: 15567
diff changeset
490
dff7e79b194f quicktime fix update
henry
parents: 15567
diff changeset
491 // HACK!
dff7e79b194f quicktime fix update
henry
parents: 15567
diff changeset
492 // if sh->ImageDesc is non-NULL, it means we decode QuickTime(tm) video.
dff7e79b194f quicktime fix update
henry
parents: 15567
diff changeset
493 // use dimensions from BIH to avoid black borders at the right and bottom.
dff7e79b194f quicktime fix update
henry
parents: 15567
diff changeset
494 if (sh->bih && sh->ImageDesc) {
dff7e79b194f quicktime fix update
henry
parents: 15567
diff changeset
495 width = sh->bih->biWidth>>lavc_param_lowres;
dff7e79b194f quicktime fix update
henry
parents: 15567
diff changeset
496 height = sh->bih->biHeight>>lavc_param_lowres;
15567
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
497 }
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
498
11414
8770be0a5bb5 aspect change does not flush buffers
iive
parents: 11372
diff changeset
499 // it is possible another vo buffers to be used after vo config()
8770be0a5bb5 aspect change does not flush buffers
iive
parents: 11372
diff changeset
500 // lavc reset its buffers on width/heigh change but not on aspect change!!!
22277
de3ca43ae51e reinit the vo when aspect ratio changes; patch by C.E. Hoyos approved by Michael
nicodvb
parents: 22222
diff changeset
501 if (av_cmp_q(avctx->sample_aspect_ratio, ctx->last_sample_aspect_ratio) ||
15567
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
502 width != sh->disp_w ||
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
503 height != sh->disp_h ||
17973
75442247ee56 reinit vo when pix_fmt changes.
reimar
parents: 17932
diff changeset
504 pix_fmt != ctx->pix_fmt ||
25962
afa125da85cf typo fix: inited --> initialized
diego
parents: 25241
diff changeset
505 !ctx->vo_initialized)
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
506 {
11194
c9a3a1e70263 sample_aspect_ratio
michael
parents: 11064
diff changeset
507 mp_msg(MSGT_DECVIDEO, MSGL_V, "[ffmpeg] aspect_ratio: %f\n", aspect);
22466
f3220a5807b5 Fix ratio aspect on Matroska files, broken with recent 'spect change in DVB' patch
gpoirier
parents: 22316
diff changeset
508 if (sh->aspect == 0 ||
f3220a5807b5 Fix ratio aspect on Matroska files, broken with recent 'spect change in DVB' patch
gpoirier
parents: 22316
diff changeset
509 av_cmp_q(avctx->sample_aspect_ratio,
f3220a5807b5 Fix ratio aspect on Matroska files, broken with recent 'spect change in DVB' patch
gpoirier
parents: 22316
diff changeset
510 ctx->last_sample_aspect_ratio))
f3220a5807b5 Fix ratio aspect on Matroska files, broken with recent 'spect change in DVB' patch
gpoirier
parents: 22316
diff changeset
511 sh->aspect = aspect;
22277
de3ca43ae51e reinit the vo when aspect ratio changes; patch by C.E. Hoyos approved by Michael
nicodvb
parents: 22222
diff changeset
512 ctx->last_sample_aspect_ratio = avctx->sample_aspect_ratio;
15567
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
513 sh->disp_w = width;
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
514 sh->disp_h = height;
17973
75442247ee56 reinit vo when pix_fmt changes.
reimar
parents: 17932
diff changeset
515 ctx->pix_fmt = pix_fmt;
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
516 switch(pix_fmt){
14597
9bc220e867ed "support" YUVJ colorspaces added to libavcodec, makes mjpeg decoding work again
reimar
parents: 14576
diff changeset
517 // YUVJ are YUV formats that use the full Y range and not just
9bc220e867ed "support" YUVJ colorspaces added to libavcodec, makes mjpeg decoding work again
reimar
parents: 14576
diff changeset
518 // 16 - 235 (see colorspaces.txt).
9bc220e867ed "support" YUVJ colorspaces added to libavcodec, makes mjpeg decoding work again
reimar
parents: 14576
diff changeset
519 // Currently they are all treated the same way.
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
520 case PIX_FMT_YUV410P: ctx->best_csp=IMGFMT_YVU9;break; //svq1
14597
9bc220e867ed "support" YUVJ colorspaces added to libavcodec, makes mjpeg decoding work again
reimar
parents: 14576
diff changeset
521 case PIX_FMT_YUVJ420P:
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
522 case PIX_FMT_YUV420P: ctx->best_csp=IMGFMT_YV12;break; //mpegs
14597
9bc220e867ed "support" YUVJ colorspaces added to libavcodec, makes mjpeg decoding work again
reimar
parents: 14576
diff changeset
523 case PIX_FMT_YUVJ422P:
8190
c3716e345dfb ffhuffyuv
michael
parents: 8130
diff changeset
524 case PIX_FMT_YUV422P: ctx->best_csp=IMGFMT_422P;break; //mjpeg / huffyuv
14597
9bc220e867ed "support" YUVJ colorspaces added to libavcodec, makes mjpeg decoding work again
reimar
parents: 14576
diff changeset
525 case PIX_FMT_YUVJ444P:
8510
43a716922d41 1l (%d->%f), cosmetics
arpi
parents: 8413
diff changeset
526 case PIX_FMT_YUV444P: ctx->best_csp=IMGFMT_444P;break; //photo jpeg
7662
c92b0b4d9e77 411P added (DV ntsc)
arpi
parents: 7578
diff changeset
527 case PIX_FMT_YUV411P: ctx->best_csp=IMGFMT_411P;break; //dv ntsc
22152
1f6c89bc1c3a Fix compilation after deprecation of some lav log level and
reimar
parents: 22147
diff changeset
528 case PIX_FMT_YUYV422: ctx->best_csp=IMGFMT_YUY2;break; //huffyuv perhaps in the future
11955
e1e01dea7c35 Fix ffmpeg RGB24 mapping (needed for qtrle)
rtognimp
parents: 11847
diff changeset
529 case PIX_FMT_RGB24 : ctx->best_csp=IMGFMT_RGB24;break; //qtrle
22152
1f6c89bc1c3a Fix compilation after deprecation of some lav log level and
reimar
parents: 22147
diff changeset
530 case PIX_FMT_RGB32: ctx->best_csp=IMGFMT_BGR32;break; //huffyuv / mjpeg
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
531 case PIX_FMT_BGR24 : ctx->best_csp=IMGFMT_BGR24;break; //8bps
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
532 case PIX_FMT_RGB555: ctx->best_csp=IMGFMT_BGR15;break; //rpza,cram
12171
michael
parents: 12033
diff changeset
533 case PIX_FMT_RGB565: ctx->best_csp=IMGFMT_BGR16;break; //4xm
17561
7b7b7552fcbb Add support for grayscale [m]jpeg
rtognimp
parents: 17523
diff changeset
534 case PIX_FMT_GRAY8: ctx->best_csp=IMGFMT_Y800;break; // gray jpeg
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
535 case PIX_FMT_PAL8: ctx->best_csp=IMGFMT_BGR8;break; //8bps,mrle,cram
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
536 #ifdef HAVE_XVMC
10471
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
537 case PIX_FMT_XVMC_MPEG2_MC:ctx->best_csp=IMGFMT_XVMC_MOCO_MPEG2;break;
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
538 case PIX_FMT_XVMC_MPEG2_IDCT:ctx->best_csp=IMGFMT_XVMC_IDCT_MPEG2;break;
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
539 #endif
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
540 default:
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
541 ctx->best_csp=0;
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
542 }
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
543 if (!mpcodecs_config_vo(sh,sh->disp_w,sh->disp_h, ctx->best_csp))
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
544 return -1;
25962
afa125da85cf typo fix: inited --> initialized
diego
parents: 25241
diff changeset
545 ctx->vo_initialized = 1;
5592
b545d56314d2 yuy2 support, fixed bug of dropping frame after config_vo calls
arpi
parents: 5517
diff changeset
546 }
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
547 return 0;
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
548 }
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
549
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
550 static int get_buffer(AVCodecContext *avctx, AVFrame *pic){
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
551 sh_video_t * sh = avctx->opaque;
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
552 vd_ffmpeg_ctx *ctx = sh->context;
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
553 mp_image_t* mpi=NULL;
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6873
diff changeset
554 int flags= MP_IMGFLAG_ACCEPT_STRIDE | MP_IMGFLAG_PREFER_ALIGNED_STRIDE;
6737
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
555 int type= MP_IMGTYPE_IPB;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
556 int width= avctx->width;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
557 int height= avctx->height;
6738
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
558 int align=15;
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
559 //printf("get_buffer %d %d %d\n", pic->reference, ctx->ip_count, ctx->b_count);
6738
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
560 if(avctx->pix_fmt == PIX_FMT_YUV410P)
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
561 align=63; //yes seriously, its really needed (16x16 chroma blocks in SVQ1 -> 64x64)
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
562
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
563 if (pic->buffer_hints) {
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
564 mp_msg(MSGT_DECVIDEO,MSGL_DBG2, "Buffer hints: %u\n", pic->buffer_hints);
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
565 type = MP_IMGTYPE_TEMP;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
566 if (pic->buffer_hints & FF_BUFFER_HINTS_READABLE)
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
567 flags |= MP_IMGFLAG_READABLE;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
568 if (pic->buffer_hints & FF_BUFFER_HINTS_PRESERVE) {
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
569 type = MP_IMGTYPE_STATIC;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
570 flags |= MP_IMGFLAG_PRESERVE;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
571 }
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
572 if (pic->buffer_hints & FF_BUFFER_HINTS_REUSABLE) {
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
573 type = MP_IMGTYPE_STATIC;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
574 flags |= MP_IMGFLAG_PRESERVE;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
575 }
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
576 flags|=(!avctx->hurry_up && ctx->do_slices) ?
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
577 MP_IMGFLAG_DRAW_CALLBACK:0;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
578 mp_msg(MSGT_DECVIDEO,MSGL_DBG2, type == MP_IMGTYPE_STATIC ? "using STATIC\n" : "using TEMP\n");
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
579 } else {
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
580 if(!pic->reference){
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
581 ctx->b_count++;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
582 flags|=(!avctx->hurry_up && ctx->do_slices) ?
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
583 MP_IMGFLAG_DRAW_CALLBACK:0;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
584 }else{
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
585 ctx->ip_count++;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
586 flags|= MP_IMGFLAG_PRESERVE|MP_IMGFLAG_READABLE
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
587 | (ctx->do_slices ? MP_IMGFLAG_DRAW_CALLBACK : 0);
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
588 }
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
589 }
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
590
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
591 if(init_vo(sh,avctx->pix_fmt) < 0){
9991
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
592 avctx->release_buffer= avcodec_default_release_buffer;
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
593 avctx->get_buffer= avcodec_default_get_buffer;
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
594 return avctx->get_buffer(avctx, pic);
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
595 }
19073
8b52dad54b1d Remove #if LIBAVCODEC_BUILD >= XXX and #if LIBAVFORMAT_BUILD >= XXX jungle.
diego
parents: 18917
diff changeset
596
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
597 if (!pic->buffer_hints) {
9991
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
598 if(ctx->b_count>1 || ctx->ip_count>2){
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
599 mp_msg(MSGT_DECVIDEO, MSGL_WARN, MSGTR_MPCODECS_DRIFailure);
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
600
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
601 ctx->do_dr1=0; //FIXME
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
602 avctx->get_buffer= avcodec_default_get_buffer;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
603 return avctx->get_buffer(avctx, pic);
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
604 }
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
605
6737
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
606 if(avctx->has_b_frames){
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
607 type= MP_IMGTYPE_IPB;
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
608 }else{
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
609 type= MP_IMGTYPE_IP;
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
610 }
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
611 mp_msg(MSGT_DECVIDEO,MSGL_DBG2, type== MP_IMGTYPE_IPB ? "using IPB\n" : "using IP\n");
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
612 }
6737
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
613
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
614 mpi= mpcodecs_get_image(sh,type, flags,
6738
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
615 (width+align)&(~align), (height+align)&(~align));
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
616
11000
6e35326c742f many small typo and grammar fixes
gabucino
parents: 10847
diff changeset
617 // ok, let's see what did we get:
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
618 if( mpi->flags&MP_IMGFLAG_DRAW_CALLBACK &&
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
619 !(mpi->flags&MP_IMGFLAG_DIRECT)){
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
620 // nice, filter/vo likes draw_callback :)
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
621 avctx->draw_horiz_band= draw_slice;
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
622 } else
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
623 avctx->draw_horiz_band= NULL;
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
624
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
625 // Palette support: libavcodec copies palette to *data[1]
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
626 if (mpi->bpp == 8)
14431
0c10f923746e change malloc and free to av_ variants where needed.
reimar
parents: 14169
diff changeset
627 mpi->planes[1] = av_malloc(AVPALETTE_SIZE);
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
628
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
629 pic->data[0]= mpi->planes[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
630 pic->data[1]= mpi->planes[1];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
631 pic->data[2]= mpi->planes[2];
8595
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
632
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
633 #if 0
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
634 assert(mpi->width >= ((width +align)&(~align)));
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
635 assert(mpi->height >= ((height+align)&(~align)));
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
636 assert(mpi->stride[0] >= mpi->width);
7051
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
637 if(mpi->imgfmt==IMGFMT_I420 || mpi->imgfmt==IMGFMT_YV12 || mpi->imgfmt==IMGFMT_IYUV){
8586
88f2362f1291 5l - fixed asserts... mpi->width is allocated width, not the effective one
arpi
parents: 8510
diff changeset
638 const int y_size= mpi->stride[0] * (mpi->h-1) + mpi->w;
88f2362f1291 5l - fixed asserts... mpi->width is allocated width, not the effective one
arpi
parents: 8510
diff changeset
639 const int c_size= mpi->stride[1] * ((mpi->h>>1)-1) + (mpi->w>>1);
7051
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
640
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
641 assert(mpi->planes[0] > mpi->planes[1] || mpi->planes[0] + y_size <= mpi->planes[1]);
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
642 assert(mpi->planes[0] > mpi->planes[2] || mpi->planes[0] + y_size <= mpi->planes[2]);
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
643 assert(mpi->planes[1] > mpi->planes[0] || mpi->planes[1] + c_size <= mpi->planes[0]);
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
644 assert(mpi->planes[1] > mpi->planes[2] || mpi->planes[1] + c_size <= mpi->planes[2]);
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
645 assert(mpi->planes[2] > mpi->planes[0] || mpi->planes[2] + c_size <= mpi->planes[0]);
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
646 assert(mpi->planes[2] > mpi->planes[1] || mpi->planes[2] + c_size <= mpi->planes[1]);
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
647 }
8595
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
648 #endif
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
649
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
650 /* Note, some (many) codecs in libavcodec must have stride1==stride2 && no changes between frames
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
651 * lavc will check that and die with an error message, if its not true
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
652 */
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
653 pic->linesize[0]= mpi->stride[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
654 pic->linesize[1]= mpi->stride[1];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
655 pic->linesize[2]= mpi->stride[2];
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
656
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
657 pic->opaque = mpi;
6742
93bce3460e2a fallback to slices, if dr1 fails (bug found by kabi)
michael
parents: 6740
diff changeset
658 //printf("%X\n", (int)mpi->planes[0]);
6869
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
659 #if 0
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
660 if(mpi->flags&MP_IMGFLAG_DIRECT)
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
661 printf("D");
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
662 else if(mpi->flags&MP_IMGFLAG_DRAW_CALLBACK)
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
663 printf("S");
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
664 else
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
665 printf(".");
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
666 #endif
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
667 if(pic->reference){
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
668 pic->age= ctx->ip_age[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
669
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
670 ctx->ip_age[0]= ctx->ip_age[1]+1;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
671 ctx->ip_age[1]= 1;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
672 ctx->b_age++;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
673 }else{
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
674 pic->age= ctx->b_age;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
675
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
676 ctx->ip_age[0]++;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
677 ctx->ip_age[1]++;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
678 ctx->b_age=1;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
679 }
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
680 pic->type= FF_BUFFER_TYPE_USER;
7928
5d1c1d73e8f3 handle direct rendering buffer allocation failure
michael
parents: 7898
diff changeset
681 return 0;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
682 }
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
683
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
684 static void release_buffer(struct AVCodecContext *avctx, AVFrame *pic){
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
685 mp_image_t* mpi= pic->opaque;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
686 sh_video_t * sh = avctx->opaque;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
687 vd_ffmpeg_ctx *ctx = sh->context;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
688 int i;
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
689
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
690 //printf("release buffer %d %d %d\n", mpi ? mpi->flags&MP_IMGFLAG_PRESERVE : -99, ctx->ip_count, ctx->b_count);
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
691
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
692 if(ctx->ip_count <= 2 && ctx->b_count<=1){
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
693 if(mpi->flags&MP_IMGFLAG_PRESERVE)
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
694 ctx->ip_count--;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
695 else
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
696 ctx->b_count--;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
697 }
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
698
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
699 // Palette support: free palette buffer allocated in get_buffer
14431
0c10f923746e change malloc and free to av_ variants where needed.
reimar
parents: 14169
diff changeset
700 if ( mpi && (mpi->bpp == 8))
0c10f923746e change malloc and free to av_ variants where needed.
reimar
parents: 14169
diff changeset
701 av_freep(&mpi->planes[1]);
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
702
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
703 if(pic->type!=FF_BUFFER_TYPE_USER){
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
704 avcodec_default_release_buffer(avctx, pic);
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
705 return;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
706 }
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
707
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
708 for(i=0; i<4; i++){
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
709 pic->data[i]= NULL;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
710 }
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
711 //printf("R%X %X\n", pic->linesize[0], pic->data[0]);
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
712 }
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
713
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
714 // copypaste from demux_real.c - it should match to get it working!
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
715 //FIXME put into some header
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
716 typedef struct dp_hdr_s {
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
717 uint32_t chunks; // number of chunks
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
718 uint32_t timestamp; // timestamp from packet header
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
719 uint32_t len; // length of actual data
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
720 uint32_t chunktab; // offset to chunk offset array
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
721 } dp_hdr_t;
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
722
22076
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
723 void swap_palette(void *pal) {
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
724 int i;
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
725 uint32_t *p = pal;
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
726 for (i = 0; i < AVPALETTE_COUNT; i++)
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
727 p[i] = le2me_32(p[i]);
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
728 }
13190
8be7dbcea0be AVC (fourcc avc1) in mp4 support
rtognimp
parents: 13075
diff changeset
729
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
730 // decode a frame
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
731 static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
732 int got_picture=0;
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
733 int ret;
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
734 vd_ffmpeg_ctx *ctx = sh->context;
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
735 AVFrame *pic= ctx->pic;
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
736 AVCodecContext *avctx = ctx->avctx;
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
737 mp_image_t* mpi=NULL;
6737
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
738 int dr1= ctx->do_dr1;
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
739
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
740 if(len<=0) return NULL; // skipped frame
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
741
12033
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
742 //ffmpeg interlace (mpeg2) bug have been fixed. no need of -noslices
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
743 if (!dr1)
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
744 avctx->draw_horiz_band=NULL;
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
745 avctx->opaque=sh;
25962
afa125da85cf typo fix: inited --> initialized
diego
parents: 25241
diff changeset
746 if(ctx->vo_initialized && !(flags&3) && !dr1){
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
747 mpi=mpcodecs_get_image(sh, MP_IMGTYPE_EXPORT, MP_IMGFLAG_PRESERVE |
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
748 (ctx->do_slices?MP_IMGFLAG_DRAW_CALLBACK:0),
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
749 sh->disp_w, sh->disp_h);
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
750 if(mpi && mpi->flags&MP_IMGFLAG_DRAW_CALLBACK){
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
751 // vd core likes slices!
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
752 avctx->draw_horiz_band=draw_slice;
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
753 }
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
754 }
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
755
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
756 avctx->hurry_up=(flags&3)?((flags&2)?2:1):0;
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
757
24523
72d1de1a3f04 Make vd_ffmpeg work with lavf demuxer also for RealVideo.
reimar
parents: 24254
diff changeset
758 if(sh->ds->demuxer->type != DEMUXER_TYPE_LAVF)
7574
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
759 if( sh->format == mmioFOURCC('R', 'V', '1', '0')
11541
753ca0c44913 ffrv20 decoder
michael
parents: 11526
diff changeset
760 || sh->format == mmioFOURCC('R', 'V', '1', '3')
11669
bcf9862f61b2 set top_field first for lavc decoding and add MP_IMGFIELD_INTERLACED
michael
parents: 11541
diff changeset
761 || sh->format == mmioFOURCC('R', 'V', '2', '0')
bcf9862f61b2 set top_field first for lavc decoding and add MP_IMGFIELD_INTERLACED
michael
parents: 11541
diff changeset
762 || sh->format == mmioFOURCC('R', 'V', '3', '0')
bcf9862f61b2 set top_field first for lavc decoding and add MP_IMGFIELD_INTERLACED
michael
parents: 11541
diff changeset
763 || sh->format == mmioFOURCC('R', 'V', '4', '0'))
24854
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
764 {
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
765 dp_hdr_t *hdr= (dp_hdr_t*)data;
24854
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
766 uint32_t *offsets = (uint32_t*)(data + hdr->chunktab);
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
767 uint8_t *offstab = av_malloc((hdr->chunks+1) * 8);
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
768 uint8_t *buf = data;
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
769 int chunks = hdr->chunks;
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
770 int dlen = hdr->len;
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
771
24854
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
772 buf[0] = chunks;
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
773 memcpy(offstab, offsets, (chunks + 1) * 8);
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
774 memmove(buf + 1 + (chunks + 1) * 8, data + sizeof(dp_hdr_t), dlen);
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
775 memcpy(buf + 1, offstab, (chunks + 1) * 8);
8d8e46de9df6 Change the frame format passed to lavc realvideo decoders to adapt for
rtogni
parents: 24656
diff changeset
776 av_free(offstab);
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
777 }
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
778
16497
182794778785 print the first 16 bytes of frame data with -v -v, helps detect when
reimar
parents: 15986
diff changeset
779 mp_msg(MSGT_DECVIDEO, MSGL_DBG2, "vd_ffmpeg data: %04x, %04x, %04x, %04x\n",
182794778785 print the first 16 bytes of frame data with -v -v, helps detect when
reimar
parents: 15986
diff changeset
780 ((int *)data)[0], ((int *)data)[1], ((int *)data)[2], ((int *)data)[3]);
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
781 ret = avcodec_decode_video(avctx, pic,
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
782 &got_picture, data, len);
13190
8be7dbcea0be AVC (fourcc avc1) in mp4 support
rtognimp
parents: 13075
diff changeset
783
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
784 dr1= ctx->do_dr1;
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
785 if(ret<0) mp_msg(MSGT_DECVIDEO,MSGL_WARN, "Error while decoding frame!\n");
9547
3b3b7b6fdb22 merging fourcc with codec_tag
michael
parents: 9400
diff changeset
786 //printf("repeat: %d\n", pic->repeat_pict);
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
787 //-- vstats generation
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
788 while(lavc_param_vstats){ // always one time loop
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
789 static FILE *fvstats=NULL;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
790 char filename[20];
6834
2d7dfcc79651 Fix overall frametime overflow, hopefully long long int is portable. (untested, will test tomorrow)
atmos4
parents: 6833
diff changeset
791 static long long int all_len=0;
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
792 static int frame_number=0;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
793 static double all_frametime=0.0;
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
794 AVFrame *pic= avctx->coded_frame;
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
795 double quality=0.0;
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
796
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
797 if(!fvstats) {
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
798 time_t today2;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
799 struct tm *today;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
800 today2 = time(NULL);
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
801 today = localtime(&today2);
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
802 sprintf(filename, "vstats_%02d%02d%02d.log", today->tm_hour,
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
803 today->tm_min, today->tm_sec);
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
804 fvstats = fopen(filename,"w");
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
805 if(!fvstats) {
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
806 perror("fopen");
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
807 lavc_param_vstats=0; // disable block
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
808 break;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
809 /*exit(1);*/
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
810 }
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
811 }
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
812
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
813 // average MB quantizer
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
814 {
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
815 int x, y;
13489
912c906db2ed compensate for width/height being picture width/height instead of bitstream width/height
michael
parents: 13473
diff changeset
816 int w = ((avctx->width << lavc_param_lowres)+15) >> 4;
912c906db2ed compensate for width/height being picture width/height instead of bitstream width/height
michael
parents: 13473
diff changeset
817 int h = ((avctx->height << lavc_param_lowres)+15) >> 4;
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
818 int8_t *q = pic->qscale_table;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
819 for( y = 0; y < h; y++ ) {
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
820 for( x = 0; x < w; x++ )
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
821 quality += (double)*(q+x);
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
822 q += pic->qstride;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
823 }
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
824 quality /= w * h;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
825 }
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
826
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
827 all_len+=len;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
828 all_frametime+=sh->frametime;
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
829 fprintf(fvstats, "frame= %5d q= %2.2f f_size= %6d s_size= %8.0fkB ",
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
830 ++frame_number, quality, len, (double)all_len/1024);
6833
a709a7662cd1 Add type= and fix a minor typing difference from ffmpeg
atmos4
parents: 6828
diff changeset
831 fprintf(fvstats, "time= %0.3f br= %7.1fkbits/s avg_br= %7.1fkbits/s ",
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
832 all_frametime, (double)(len*8)/sh->frametime/1000.0,
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
833 (double)(all_len*8)/all_frametime/1000.0);
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
834 switch(pic->pict_type){
8347
michael
parents: 8341
diff changeset
835 case FF_I_TYPE:
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
836 fprintf(fvstats, "type= I\n");
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
837 break;
8347
michael
parents: 8341
diff changeset
838 case FF_P_TYPE:
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
839 fprintf(fvstats, "type= P\n");
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
840 break;
8347
michael
parents: 8341
diff changeset
841 case FF_S_TYPE:
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
842 fprintf(fvstats, "type= S\n");
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
843 break;
8347
michael
parents: 8341
diff changeset
844 case FF_B_TYPE:
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
845 fprintf(fvstats, "type= B\n");
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
846 break;
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
847 default:
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
848 fprintf(fvstats, "type= ? (%d)\n", pic->pict_type);
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
849 break;
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
850 }
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
851
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
852 ctx->qp_stat[(int)(quality+0.5)]++;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
853 ctx->qp_sum += quality;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
854 ctx->inv_qp_sum += 1.0/(double)quality;
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
855
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
856 break;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
857 }
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
858 //--
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
859
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
860 if(!got_picture) return NULL; // skipped image
6738
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
861
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
862 if(init_vo(sh,avctx->pix_fmt) < 0) return NULL;
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
863
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
864 if(dr1 && pic->opaque){
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
865 mpi= (mp_image_t*)pic->opaque;
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
866 }
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
867
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
868 if(!mpi)
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
869 mpi=mpcodecs_get_image(sh, MP_IMGTYPE_EXPORT, MP_IMGFLAG_PRESERVE,
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
870 avctx->width, avctx->height);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
871 if(!mpi){ // temporary!
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
872 mp_msg(MSGT_DECVIDEO, MSGL_WARN, MSGTR_MPCODECS_CouldntAllocateImageForCodec);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
873 return NULL;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
874 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
875
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
876 if(!dr1){
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
877 mpi->planes[0]=pic->data[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
878 mpi->planes[1]=pic->data[1];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
879 mpi->planes[2]=pic->data[2];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
880 mpi->stride[0]=pic->linesize[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
881 mpi->stride[1]=pic->linesize[1];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
882 mpi->stride[2]=pic->linesize[2];
6733
3b1f37fc0693 direct rendering method 1 (disabled currently as its not bugfree / finished yet, just set dr1=1 if u want to try it)
michael
parents: 6710
diff changeset
883 }
11372
3761aff4722e If alex is too lazy to apply a patch, then i'll do it :)
attila
parents: 11194
diff changeset
884
3761aff4722e If alex is too lazy to apply a patch, then i'll do it :)
attila
parents: 11194
diff changeset
885 if (!mpi->planes[0])
3761aff4722e If alex is too lazy to apply a patch, then i'll do it :)
attila
parents: 11194
diff changeset
886 return NULL;
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
887
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
888 if(avctx->pix_fmt==PIX_FMT_YUV422P && mpi->chroma_y_shift==1){
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
889 // we have 422p but user wants 420p
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
890 mpi->stride[1]*=2;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
891 mpi->stride[2]*=2;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
892 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
893
22076
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
894 #ifdef WORDS_BIGENDIAN
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
895 // FIXME: this might cause problems for buffers with FF_BUFFER_HINTS_PRESERVE
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
896 if (mpi->bpp == 8)
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
897 swap_palette(mpi->planes[1]);
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
898 #endif
6665
3284abe2d73f support avcontext based quant_store export
alex
parents: 6355
diff changeset
899 /* to comfirm with newer lavc style */
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
900 mpi->qscale =pic->qscale_table;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
901 mpi->qstride=pic->qstride;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
902 mpi->pict_type=pic->pict_type;
9925
420640a0f6d0 passing qscale_type around so the pp code can fix the mpeg2 <<1 thing
michael
parents: 9865
diff changeset
903 mpi->qscale_type= pic->qscale_type;
11669
bcf9862f61b2 set top_field first for lavc decoding and add MP_IMGFIELD_INTERLACED
michael
parents: 11541
diff changeset
904 mpi->fields = MP_IMGFIELD_ORDERED;
bcf9862f61b2 set top_field first for lavc decoding and add MP_IMGFIELD_INTERLACED
michael
parents: 11541
diff changeset
905 if(pic->interlaced_frame) mpi->fields |= MP_IMGFIELD_INTERLACED;
bcf9862f61b2 set top_field first for lavc decoding and add MP_IMGFIELD_INTERLACED
michael
parents: 11541
diff changeset
906 if(pic->top_field_first ) mpi->fields |= MP_IMGFIELD_TOP_FIRST;
11992
d8890a065727 vd_ffmpeg to set repeat-first-field patch by (Zoltan Hidvegi <mplayer at hzoli do 2y dot net>)
michael
parents: 11977
diff changeset
907 if(pic->repeat_pict == 1) mpi->fields |= MP_IMGFIELD_REPEAT_FIRST;
19073
8b52dad54b1d Remove #if LIBAVCODEC_BUILD >= XXX and #if LIBAVFORMAT_BUILD >= XXX jungle.
diego
parents: 18917
diff changeset
908
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
909 return mpi;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
910 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
911
24253
e0ed786a7fb9 warning fix:
diego
parents: 24248
diff changeset
912 #ifdef HAVE_XVMC
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
913 static enum PixelFormat get_format(struct AVCodecContext * avctx,
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
914 const enum PixelFormat * fmt){
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
915 sh_video_t * sh = avctx->opaque;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
916 int i;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
917
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
918 if(avctx->xvmc_acceleration){
24142
931b5401fa01 Fix some unused variable warnings.
diego
parents: 23381
diff changeset
919 vd_ffmpeg_ctx *ctx = sh->context;
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
920 avctx->get_buffer= mc_get_buffer;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
921 avctx->release_buffer= mc_release_buffer;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
922 avctx->draw_horiz_band = mc_render_slice;
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
923 mp_msg(MSGT_DECVIDEO, MSGL_INFO, MSGTR_MPCODECS_XVMCAcceleratedMPEG2);
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
924 assert(ctx->do_dr1);//these are must to!
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
925 assert(ctx->do_slices); //it is (vo_)ffmpeg bug if this fails
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
926 avctx->flags|= CODEC_FLAG_EMU_EDGE;//do i need that??!!
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
927 avctx->slice_flags=SLICE_FLAG_CODED_ORDER|SLICE_FLAG_ALLOW_FIELD;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
928 }
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
929 for(i=0;fmt[i]!=-1;i++){
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
930 mp_msg(MSGT_DECVIDEO, MSGL_INFO, MSGTR_MPCODECS_TryingPixfmt,i);
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
931 if( init_vo(sh,fmt[i]) >= 0)
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
932 return fmt[i];
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
933 }
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
934 return fmt[0];
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
935 }
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
936
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
937 static int mc_get_buffer(AVCodecContext *avctx, AVFrame *pic){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
938 sh_video_t * sh = avctx->opaque;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
939 vd_ffmpeg_ctx *ctx = sh->context;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
940 mp_image_t* mpi=NULL;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
941 xvmc_render_state_t * render;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
942 int flags= MP_IMGFLAG_ACCEPT_STRIDE | MP_IMGFLAG_PREFER_ALIGNED_STRIDE|
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
943 MP_IMGFLAG_DRAW_CALLBACK;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
944
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
945 // printf("vd_ffmpeg::mc_get_buffer (xvmc) %d %d %d\n", pic->reference, ctx->ip_count, ctx->b_count);
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
946 if(!avctx->xvmc_acceleration){
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
947 mp_msg(MSGT_DECVIDEO, MSGL_INFO, MSGTR_MPCODECS_McGetBufferShouldWorkOnlyWithXVMC);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
948 assert(0);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
949 exit(1);
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
950 // return -1;//!!fixme check error conditions
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
951 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
952 assert(avctx->draw_horiz_band == mc_render_slice);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
953 assert(avctx->release_buffer == mc_release_buffer);
17932
3fe3b2b3a6ce Convert all if(verbose>X) to mp_msg_test calls.
diego
parents: 17561
diff changeset
954 if( mp_msg_test(MSGT_DECVIDEO,MSGL_DBG5) )
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
955 mp_msg(MSGT_DECVIDEO, MSGL_DBG5, "vd_ffmpeg::mc_get_buffer\n");
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
956
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
957 if(init_vo(sh,avctx->pix_fmt) < 0){
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
958 mp_msg(MSGT_DECVIDEO, MSGL_WARN, MSGTR_MPCODECS_UnexpectedInitVoError);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
959 exit(1);
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
960 // return -1;//!!fixme check error conditions
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
961 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
962
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
963
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
964
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
965 if(!pic->reference){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
966 ctx->b_count++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
967 }else{
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
968 ctx->ip_count++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
969 flags|= MP_IMGFLAG_PRESERVE|MP_IMGFLAG_READABLE;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
970 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
971
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
972 mpi= mpcodecs_get_image(sh, MP_IMGTYPE_IPB,flags ,
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
973 avctx->width, avctx->height);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
974 if(mpi==NULL){
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
975 mp_msg(MSGT_DECVIDEO, MSGL_ERR, MSGTR_MPCODECS_UnrecoverableErrorRenderBuffersNotTaken);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
976 assert(0);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
977 exit(1);
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
978 // return -1;//!!fixme check error conditions in ffmpeg
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
979 };
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
980
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
981 if( (mpi->flags & MP_IMGFLAG_DIRECT) == 0){
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
982 mp_msg(MSGT_DECVIDEO, MSGL_ERR, MSGTR_MPCODECS_OnlyBuffersAllocatedByVoXvmcAllowed);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
983 assert(0);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
984 exit(1);
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
985 // return -1;//!!fixme check error conditions in ffmpeg
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
986 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
987
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
988 pic->data[0]= mpi->planes[0];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
989 pic->data[1]= mpi->planes[1];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
990 pic->data[2]= mpi->planes[2];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
991
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
992
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
993 /* Note, some (many) codecs in libavcodec must have stride1==stride2 && no changes between frames
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
994 * lavc will check that and die with an error message, if its not true
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
995 */
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
996 pic->linesize[0]= mpi->stride[0];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
997 pic->linesize[1]= mpi->stride[1];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
998 pic->linesize[2]= mpi->stride[2];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
999
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1000 pic->opaque = mpi;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1001
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1002 if(pic->reference){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1003 //I or P frame
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1004 pic->age= ctx->ip_age[0];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1005
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1006 ctx->ip_age[0]= ctx->ip_age[1]+1;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1007 ctx->ip_age[1]= 1;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1008 ctx->b_age++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1009 }else{
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1010 //B frame
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1011 pic->age= ctx->b_age;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1012
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1013 ctx->ip_age[0]++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1014 ctx->ip_age[1]++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1015 ctx->b_age=1;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1016 }
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1017
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1018 pic->type= FF_BUFFER_TYPE_USER;
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1019
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1020 render=(xvmc_render_state_t*)mpi->priv;//same as data[2]
17932
3fe3b2b3a6ce Convert all if(verbose>X) to mp_msg_test calls.
diego
parents: 17561
diff changeset
1021 if( mp_msg_test(MSGT_DECVIDEO,MSGL_DBG5) )
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
1022 mp_msg(MSGT_DECVIDEO, MSGL_DBG5, "vd_ffmpeg::mc_get_buffer (render=%p)\n",render);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1023 assert(render != 0);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1024 assert(render->magic == MP_XVMC_RENDER_MAGIC);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1025 render->state |= MP_XVMC_STATE_PREDICTION;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1026 return 0;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1027 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1028
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1029
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1030 static void mc_release_buffer(AVCodecContext *avctx, AVFrame *pic){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1031 mp_image_t* mpi= pic->opaque;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1032 sh_video_t * sh = avctx->opaque;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1033 vd_ffmpeg_ctx *ctx = sh->context;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1034 xvmc_render_state_t * render;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1035 int i;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1036
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1037
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1038 if(ctx->ip_count <= 2 && ctx->b_count<=1){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1039 if(mpi->flags&MP_IMGFLAG_PRESERVE)
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1040 ctx->ip_count--;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1041 else
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1042 ctx->b_count--;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1043 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1044
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1045 //printf("R%X %X\n", pic->linesize[0], pic->data[0]);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1046 //mark the surface as not requared for prediction
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1047 render=(xvmc_render_state_t*)pic->data[2];//same as mpi->priv
17932
3fe3b2b3a6ce Convert all if(verbose>X) to mp_msg_test calls.
diego
parents: 17561
diff changeset
1048 if( mp_msg_test(MSGT_DECVIDEO,MSGL_DBG5) )
18004
bcd805923554 Part2 of several printf2mp_msg changes in patch from Otvos Attila oattila AT chello DOT hu with LOTS of modifications by me
reynaldo
parents: 17973
diff changeset
1049 mp_msg(MSGT_DECVIDEO, MSGL_DBG5, "vd_ffmpeg::mc_release_buffer (render=%p)\n",render);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1050 assert(render!=NULL);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1051 assert(render->magic==MP_XVMC_RENDER_MAGIC);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1052 render->state&=~MP_XVMC_STATE_PREDICTION;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1053 for(i=0; i<4; i++){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1054 pic->data[i]= NULL;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1055 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1056 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1057
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1058 static void mc_render_slice(struct AVCodecContext *s,
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1059 AVFrame *src, int offset[4],
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1060 int y, int type, int height){
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1061 int width= s->width;
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1062 sh_video_t * sh = s->opaque;
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1063 uint8_t *source[3]= {src->data[0], src->data[1], src->data[2]};
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1064
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1065 assert(src->linesize[0]==0 && src->linesize[1]==0 && src->linesize[2]==0);
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1066 assert(offset[0]==0 && offset[1]==0 && offset[2]==0);
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1067
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1068 mpcodecs_draw_slice (sh, source, src->linesize, width, height, 0, y);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1069
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1070 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1071
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1072 #endif // HAVE_XVMC