annotate libmpcodecs/vd_ffmpeg.c @ 22153:0cf24df5d97b

Revert part of commit r22170. FFmpeg lavcodecs version is still (or according to ffmpeg commit r7868, it's back to) 49.3.0, so global variables are not yet directly accessable (if ever).
author iive
date Wed, 07 Feb 2007 12:31:37 +0000
parents 1f6c89bc1c3a
children 1a2a37852799
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"
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
9
21372
1767c271d710 Remove bswap.h, use libavutil/bswap.h instead.
diego
parents: 21251
diff changeset
10 #include "libavutil/common.h"
21457
af4c8fd34494 Compile fix, BE_32 definition has been moved
reimar
parents: 21372
diff changeset
11 #include "libavutil/intreadwrite.h"
21507
fa99b3d31d13 Hack around libavutil/bswap.h compilation problems due to always_inline undefined.
reimar
parents: 21498
diff changeset
12 #include "mpbswap.h"
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
13
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
14 #include "vd_internal.h"
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
15
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
16 static vd_info_t info = {
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
17 "FFmpeg's libavcodec codec family",
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
18 "ffmpeg",
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
19 "A'rpi",
7388
2c35b856cf73 extended par support
alex
parents: 7303
diff changeset
20 "A'rpi, Michael, Alex",
2c35b856cf73 extended par support
alex
parents: 7303
diff changeset
21 "native codecs (http://ffmpeg.sf.net/)"
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
22 };
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
23
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
24 LIBVD_EXTERN(ffmpeg)
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
25
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
26 #ifdef USE_LIBAVCODEC_SO
7004
8eff71f38685 dynamic libavcodec.so support updated by
arpi
parents: 6897
diff changeset
27 #include <ffmpeg/avcodec.h>
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
28 #else
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
29 #include "libavcodec/avcodec.h"
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
30 #endif
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
31
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
32 #ifdef HAVE_XVMC
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
33 #include "xvmc_render.h"
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
34 #endif
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
35
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
36 int avcodec_inited=0;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
37
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
38 typedef struct {
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
39 AVCodecContext *avctx;
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
40 AVFrame *pic;
17973
75442247ee56 reinit vo when pix_fmt changes.
reimar
parents: 17932
diff changeset
41 enum PixelFormat pix_fmt;
8237
d7bc284a2b4a aspect ratio clenaup
michael
parents: 8200
diff changeset
42 float last_aspect;
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
43 int do_slices;
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
44 int do_dr1;
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
45 int vo_inited;
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
46 int best_csp;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
47 int b_age;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
48 int ip_age[2];
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
49 int qp_stat[32];
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
50 double qp_sum;
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
51 double inv_qp_sum;
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
52 int ip_count;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
53 int b_count;
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
54 } vd_ffmpeg_ctx;
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
55
17463
b56f34ba3f2f proper support for shared libpostproc
diego
parents: 17226
diff changeset
56 //#ifdef USE_LIBPOSTPROC
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
57 //unsigned int lavc_pp=0;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
58 //#endif
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
59
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
60 #include "m_option.h"
6265
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
61
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
62 static int get_buffer(AVCodecContext *avctx, AVFrame *pic);
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
63 static void release_buffer(AVCodecContext *avctx, AVFrame *pic);
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
64 static enum PixelFormat get_format(struct AVCodecContext * avctx,
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
65 const enum PixelFormat * pix_fmt);
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
66
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
67 #ifdef HAVE_XVMC
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
68 static int mc_get_buffer(AVCodecContext *avctx, AVFrame *pic);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
69 static void mc_release_buffer(AVCodecContext *avctx, AVFrame *pic);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
70 static void mc_render_slice(struct AVCodecContext *s,
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
71 AVFrame *src, int offset[4],
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
72 int y, int type, int height);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
73 #endif
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
74
7722
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
75 static int lavc_param_workaround_bugs= FF_BUG_AUTODETECT;
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
76 static int lavc_param_error_resilience=2;
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
77 static int lavc_param_error_concealment=3;
6355
e97686ab386b grayscale only decoding support
michael
parents: 6265
diff changeset
78 static int lavc_param_gray=0;
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
79 static int lavc_param_vstats=0;
7564
24165f770c0d idct algo selection support
michael
parents: 7512
diff changeset
80 static int lavc_param_idct_algo=0;
8341
fd670708f87f specific debug output support
michael
parents: 8340
diff changeset
81 static int lavc_param_debug=0;
11702
e4c043ebf3a6 vismv, alt, ilme options
michael
parents: 11669
diff changeset
82 static int lavc_param_vismv=0;
12670
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
83 static int lavc_param_skip_top=0;
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
84 static int lavc_param_skip_bottom=0;
13230
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
85 static int lavc_param_fast=0;
13473
daeea32a0956 low resolution decoding
michael
parents: 13333
diff changeset
86 static int lavc_param_lowres=0;
14169
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
87 static char *lavc_param_lowres_str=NULL;
15986
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
88 static char *lavc_param_skip_loop_filter_str = NULL;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
89 static char *lavc_param_skip_idct_str = NULL;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
90 static char *lavc_param_skip_frame_str = NULL;
17080
b3ef98ca8677 multithreaded decoding
michael
parents: 17073
diff changeset
91 static int lavc_param_threads=1;
17217
0d8eee43f85c bitexact flag
michael
parents: 17080
diff changeset
92 static int lavc_param_bitexact=0;
6265
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
93
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
94 m_option_t lavc_decode_opts_conf[]={
9547
3b3b7b6fdb22 merging fourcc with codec_tag
michael
parents: 9400
diff changeset
95 {"bug", &lavc_param_workaround_bugs, CONF_TYPE_INT, CONF_RANGE, -1, 999999, NULL},
7722
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
96 {"er", &lavc_param_error_resilience, CONF_TYPE_INT, CONF_RANGE, 0, 99, NULL},
6355
e97686ab386b grayscale only decoding support
michael
parents: 6265
diff changeset
97 {"gray", &lavc_param_gray, CONF_TYPE_FLAG, 0, 0, CODEC_FLAG_PART, NULL},
7564
24165f770c0d idct algo selection support
michael
parents: 7512
diff changeset
98 {"idct", &lavc_param_idct_algo, CONF_TYPE_INT, CONF_RANGE, 0, 99, NULL},
7722
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
99 {"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
100 {"vstats", &lavc_param_vstats, CONF_TYPE_FLAG, 0, 0, 1, NULL},
8341
fd670708f87f specific debug output support
michael
parents: 8340
diff changeset
101 {"debug", &lavc_param_debug, CONF_TYPE_INT, CONF_RANGE, 0, 9999999, NULL},
11702
e4c043ebf3a6 vismv, alt, ilme options
michael
parents: 11669
diff changeset
102 {"vismv", &lavc_param_vismv, CONF_TYPE_INT, CONF_RANGE, 0, 9999999, NULL},
12670
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
103 {"st", &lavc_param_skip_top, CONF_TYPE_INT, CONF_RANGE, 0, 999, NULL},
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
104 {"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
105 #ifdef CODEC_FLAG2_FAST
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
106 {"fast", &lavc_param_fast, CONF_TYPE_FLAG, 0, 0, CODEC_FLAG2_FAST, NULL},
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
107 #endif
14169
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
108 {"lowres", &lavc_param_lowres_str, CONF_TYPE_STRING, 0, 0, 0, NULL},
15986
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
109 {"skiploopfilter", &lavc_param_skip_loop_filter_str, CONF_TYPE_STRING, 0, 0, 0, NULL},
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
110 {"skipidct", &lavc_param_skip_idct_str, CONF_TYPE_STRING, 0, 0, 0, NULL},
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
111 {"skipframe", &lavc_param_skip_frame_str, CONF_TYPE_STRING, 0, 0, 0, NULL},
17080
b3ef98ca8677 multithreaded decoding
michael
parents: 17073
diff changeset
112 {"threads", &lavc_param_threads, CONF_TYPE_INT, CONF_RANGE, 1, 8, NULL},
17217
0d8eee43f85c bitexact flag
michael
parents: 17080
diff changeset
113 {"bitexact", &lavc_param_bitexact, CONF_TYPE_FLAG, 0, 0, CODEC_FLAG_BITEXACT, NULL},
6265
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
114 {NULL, NULL, 0, 0, 0, 0, NULL}
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
115 };
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
116
15986
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
117 static enum AVDiscard str2AVDiscard(char *str) {
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
118 if (!str)
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
119 return AVDISCARD_DEFAULT;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
120 if (strcasecmp(str, "none") == 0)
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
121 return AVDISCARD_NONE;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
122 if (strcasecmp(str, "default") == 0)
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
123 return AVDISCARD_DEFAULT;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
124 if (strcasecmp(str, "nonref") == 0)
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
125 return AVDISCARD_NONREF;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
126 if (strcasecmp(str, "bidir") == 0)
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
127 return AVDISCARD_BIDIR;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
128 if (strcasecmp(str, "nonkey") == 0)
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
129 return AVDISCARD_NONKEY;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
130 if (strcasecmp(str, "all") == 0)
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
131 return AVDISCARD_ALL;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
132 mp_msg(MSGT_DECVIDEO, MSGL_ERR, "Unknown discard value %s\n", str);
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
133 return AVDISCARD_DEFAULT;
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
134 }
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
135
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
136 // to set/get/query special features/parameters
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
137 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
138 vd_ffmpeg_ctx *ctx = sh->context;
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
139 AVCodecContext *avctx = ctx->avctx;
5592
b545d56314d2 yuy2 support, fixed bug of dropping frame after config_vo calls
arpi
parents: 5517
diff changeset
140 switch(cmd){
b545d56314d2 yuy2 support, fixed bug of dropping frame after config_vo calls
arpi
parents: 5517
diff changeset
141 case VDCTRL_QUERY_FORMAT:
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
142 {
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
143 int format =(*((int*)arg));
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
144 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
145 // possible conversions:
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
146 switch( format ){
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
147 case IMGFMT_YV12:
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
148 case IMGFMT_IYUV:
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
149 case IMGFMT_I420:
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
150 // "converted" using pointer/stride modification
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
151 if(avctx->pix_fmt==PIX_FMT_YUV420P) return CONTROL_TRUE;// u/v swap
11064
cc5944174c46 YUV422P dr1 fix
michael
parents: 11000
diff changeset
152 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
153 break;
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
154 #ifdef HAVE_XVMC
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
155 case IMGFMT_XVMC_IDCT_MPEG2:
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
156 case IMGFMT_XVMC_MOCO_MPEG2:
10471
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
157 if(avctx->pix_fmt==PIX_FMT_XVMC_MPEG2_IDCT) return CONTROL_TRUE;
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
158 #endif
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
159 }
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
160 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
161 }
efb37725d616 flushing stuff after seeking (finally we can view MPEG without thouse blocks after seeking with -vc ffmpeg12)
michael
parents: 11955
diff changeset
162 break;
efb37725d616 flushing stuff after seeking (finally we can view MPEG without thouse blocks after seeking with -vc ffmpeg12)
michael
parents: 11955
diff changeset
163 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
164 avcodec_flush_buffers(avctx);
18917
d9a75b26da6c Add a new video pts tracking mode, enabled by option -correct-pts.
uau
parents: 18879
diff changeset
165 return CONTROL_TRUE;
d9a75b26da6c Add a new video pts tracking mode, enabled by option -correct-pts.
uau
parents: 18879
diff changeset
166 case VDCTRL_QUERY_UNSEEN_FRAMES:
d9a75b26da6c Add a new video pts tracking mode, enabled by option -correct-pts.
uau
parents: 18879
diff changeset
167 return avctx->has_b_frames + 10;
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
168 }
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
169 return CONTROL_UNKNOWN;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
170 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
171
20741
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
172 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
173 {
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
174 static int print_prefix=1;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
175 AVClass* avc= ptr ? *(AVClass**)ptr : NULL;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
176 int type= MSGT_FIXME;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
177 int mp_level;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
178 char buf[256];
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
179
21242
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
180 switch(level){
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
181 case AV_LOG_DEBUG: mp_level= MSGL_V ; break;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
182 case AV_LOG_INFO : mp_level= MSGL_INFO; break;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
183 case AV_LOG_ERROR: mp_level= MSGL_ERR ; break;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
184 default : mp_level= MSGL_ERR ; break;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
185 }
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
186
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
187 if (!mp_msg_test(type, mp_level)) return;
8d671a2c1b00 Check the log level before processing the message
henry
parents: 20920
diff changeset
188
20741
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
189 if(ptr){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
190 if(!strcmp(avc->class_name, "AVCodecContext")){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
191 AVCodecContext * s= ptr;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
192 if(s->codec){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
193 if(s->codec->type == CODEC_TYPE_AUDIO){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
194 if(s->codec->decode)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
195 type= MSGT_DECAUDIO;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
196 }else if(s->codec->type == CODEC_TYPE_VIDEO){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
197 if(s->codec->decode)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
198 type= MSGT_DECVIDEO;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
199 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
200 //FIXME subtitles, encoders (what msgt for them? there is no appropiate ...)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
201 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
202 }else if(!strcmp(avc->class_name, "AVFormatContext")){
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
203 #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
204 AVFormatContext * s= ptr;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
205 if(s->iformat)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
206 type= MSGT_DEMUXER;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
207 else if(s->oformat)
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
208 type= MSGT_MUXER;
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
209 #endif
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
210 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
211 }
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 if(print_prefix && avc) {
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
214 mp_msg(type, mp_level, "[%s @ %p]", avc->item_name(ptr), avc);
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
215 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
216
21243
3ee64ff583a9 Useless use of strstr, strchr is good enough.
reimar
parents: 21242
diff changeset
217 print_prefix= strchr(fmt, '\n') != NULL;
20741
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
218 vsnprintf(buf, sizeof(buf), fmt, vl);
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
219 mp_msg(type, mp_level, buf);
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
220 }
b3ef93332896 feed av_log() through mp_msg()
michael
parents: 19278
diff changeset
221
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
222 // init driver
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
223 static int init(sh_video_t *sh){
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
224 AVCodecContext *avctx;
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
225 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
226 AVCodec *lavc_codec;
14169
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
227 int lowres_w=0;
11712
5905aae865c7 disable dr1&slices for the other vissualizations too
michael
parents: 11711
diff changeset
228 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
229
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
230 if(!avcodec_inited){
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
231 avcodec_init();
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
232 avcodec_register_all();
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
233 avcodec_inited=1;
22153
0cf24df5d97b Revert part of commit r22170.
iive
parents: 22152
diff changeset
234 av_log_set_callback(mp_msp_av_log_callback);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
235 }
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
236
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
237 ctx = sh->context = malloc(sizeof(vd_ffmpeg_ctx));
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
238 if (!ctx)
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
239 return(0);
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
240 memset(ctx, 0, sizeof(vd_ffmpeg_ctx));
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
241
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
242 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
243 if(!lavc_codec){
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
244 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
245 uninit(sh);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
246 return 0;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
247 }
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
248
11712
5905aae865c7 disable dr1&slices for the other vissualizations too
michael
parents: 11711
diff changeset
249 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
250 ctx->do_slices=1;
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
251
13275
75b2ff55c972 disable direct rendering for h264
michael
parents: 13230
diff changeset
252 if(lavc_codec->capabilities&CODEC_CAP_DR1 && !do_vis_debug && lavc_codec->id != CODEC_ID_H264)
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
253 ctx->do_dr1=1;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
254 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
255 ctx->ip_count= ctx->b_count= 0;
7444
56a16bd12b79 use avcodec_alloc_context()
michael
parents: 7388
diff changeset
256
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
257 ctx->pic = avcodec_alloc_frame();
7444
56a16bd12b79 use avcodec_alloc_context()
michael
parents: 7388
diff changeset
258 ctx->avctx = avcodec_alloc_context();
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
259 avctx = ctx->avctx;
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
260
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
261 #ifdef HAVE_XVMC
12033
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
262
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
263 #ifdef CODEC_CAP_HWACCEL
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
264 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
265 #else
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
266 if(lavc_codec->id == CODEC_ID_MPEG2VIDEO_XVMC){
12033
3dd75c52bf38 use flag for XvMC codec recognition and enable dr1 for fixed version of lavc
iive
parents: 12006
diff changeset
267 #endif
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
268 mp_msg(MSGT_DECVIDEO, MSGL_INFO, MSGTR_MPCODECS_XVMCAcceleratedCodec);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
269 assert(ctx->do_dr1);//these are must to!
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
270 assert(ctx->do_slices); //it is (vo_)ffmpeg bug if this fails
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
271 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
272 avctx->get_format= get_format;//for now only this decoder will use it
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
273 avctx->get_buffer= mc_get_buffer;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
274 avctx->release_buffer= mc_release_buffer;
10471
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
275 avctx->draw_horiz_band = mc_render_slice;
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
276 avctx->slice_flags=SLICE_FLAG_CODED_ORDER|SLICE_FLAG_ALLOW_FIELD;
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
277 }else
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
278 #endif
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
279 if(ctx->do_dr1){
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
280 avctx->flags|= CODEC_FLAG_EMU_EDGE;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
281 avctx->get_buffer= get_buffer;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
282 avctx->release_buffer= release_buffer;
11526
523570adaad5 reget_buffer() support
rtognimp
parents: 11431
diff changeset
283 avctx->reget_buffer= get_buffer;
6739
8a680d5f3a17 10l (init flags after init ...)
michael
parents: 6738
diff changeset
284 }
7303
e805ef05536c fixing mpeg in avi
michael
parents: 7220
diff changeset
285
e805ef05536c fixing mpeg in avi
michael
parents: 7220
diff changeset
286 #ifdef CODEC_FLAG_NOT_TRUNCATED
e805ef05536c fixing mpeg in avi
michael
parents: 7220
diff changeset
287 avctx->flags|= CODEC_FLAG_NOT_TRUNCATED;
e805ef05536c fixing mpeg in avi
michael
parents: 7220
diff changeset
288 #endif
17217
0d8eee43f85c bitexact flag
michael
parents: 17080
diff changeset
289 avctx->flags|= lavc_param_bitexact;
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
290
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
291 avctx->width = sh->disp_w;
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
292 avctx->height= sh->disp_h;
6265
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
293 avctx->workaround_bugs= lavc_param_workaround_bugs;
f49ec39ab0c6 workaround bugs & error resilience ffmpeg decoder options
michael
parents: 5940
diff changeset
294 avctx->error_resilience= lavc_param_error_resilience;
6355
e97686ab386b grayscale only decoding support
michael
parents: 6265
diff changeset
295 if(lavc_param_gray) avctx->flags|= CODEC_FLAG_GRAY;
13230
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
296 #ifdef CODEC_FLAG2_FAST
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
297 avctx->flags2|= lavc_param_fast;
a83623b3b86a non spec compliant optizations support
michael
parents: 13190
diff changeset
298 #endif
9547
3b3b7b6fdb22 merging fourcc with codec_tag
michael
parents: 9400
diff changeset
299 avctx->codec_tag= sh->format;
10847
98dc548dbf2d pass stream header FCC
michael
parents: 10774
diff changeset
300 avctx->stream_codec_tag= sh->video.fccHandler;
7564
24165f770c0d idct algo selection support
michael
parents: 7512
diff changeset
301 avctx->idct_algo= lavc_param_idct_algo;
7722
a181875e0aa8 new error resilience support
michael
parents: 7662
diff changeset
302 avctx->error_concealment= lavc_param_error_concealment;
8341
fd670708f87f specific debug output support
michael
parents: 8340
diff changeset
303 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
304 if (lavc_param_debug)
22153
0cf24df5d97b Revert part of commit r22170.
iive
parents: 22152
diff changeset
305 av_log_set_level(AV_LOG_DEBUG);
11702
e4c043ebf3a6 vismv, alt, ilme options
michael
parents: 11669
diff changeset
306 avctx->debug_mv= lavc_param_vismv;
12670
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
307 avctx->skip_top = lavc_param_skip_top;
aebedab0ecac top/bottom mb row skipping
michael
parents: 12534
diff changeset
308 avctx->skip_bottom= lavc_param_skip_bottom;
14169
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
309 if(lavc_param_lowres_str != NULL)
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
310 {
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
311 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
312 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
313 lavc_param_lowres = 0;
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
314 avctx->lowres = lavc_param_lowres;
95dd81b8b9de conditional lowres: activate lowres if frame width >= threshold
nicodvb
parents: 14118
diff changeset
315 }
15986
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
316 avctx->skip_loop_filter = str2AVDiscard(lavc_param_skip_loop_filter_str);
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
317 avctx->skip_idct = str2AVDiscard(lavc_param_skip_idct_str);
999f16654819 Support for skip options
reimar
parents: 15823
diff changeset
318 avctx->skip_frame = str2AVDiscard(lavc_param_skip_frame_str);
5280
ea8f3e8f39c1 added aspect ratio support and local ctx
alex
parents: 5219
diff changeset
319 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
320 switch (sh->format) {
19278
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
321 case mmioFOURCC('S','V','Q','3'):
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
322 /* 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
323 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
324 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
325 if (sh->ImageDesc) {
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
326 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
327 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
328 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
329 break;
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
330 }
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
331 /* fallthrough */
c41d4672c675 Fix SVQ3 extradata handling so it works correctly with demux_lavf
pacman
parents: 19277
diff changeset
332
18023
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
333 case mmioFOURCC('A','V','R','n'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
334 case mmioFOURCC('M','J','P','G'):
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
335 /* AVRn stores huffman table in AVI header */
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
336 /* 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
337 MJPG fourcc :( */
18023
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
338 if (!sh->bih || sh->bih->biSize <= sizeof(BITMAPINFOHEADER))
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
339 break;
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
340 avctx->flags |= CODEC_FLAG_EXTERN_HUFF;
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
341 avctx->extradata_size = sh->bih->biSize-sizeof(BITMAPINFOHEADER);
17226
255b14c0bc36 malloc padding to avoid access beyond allocated memory
henry
parents: 17217
diff changeset
342 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
343 memcpy(avctx->extradata, sh->bih+1, avctx->extradata_size);
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
344
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
345 #if 0
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
346 {
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
347 int x;
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
348 uint8_t *p = avctx->extradata;
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
349
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
350 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
351 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
352 mp_msg(MSGT_DECVIDEO, MSGL_INFO,"\n");
5939
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
353 }
65ee86f5a45f avid mjpeg support (external huffman table)
alex
parents: 5875
diff changeset
354 #endif
18023
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
355 break;
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
356
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
357 case mmioFOURCC('R', 'V', '1', '0'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
358 case mmioFOURCC('R', 'V', '1', '3'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
359 case mmioFOURCC('R', 'V', '2', '0'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
360 case mmioFOURCC('R', 'V', '3', '0'):
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
361 case mmioFOURCC('R', 'V', '4', '0'):
20920
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
362 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
363 /* only 1 packet per frame & sub_id from fourcc */
20920
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
364 avctx->extradata_size= 8;
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
365 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
366 ((uint32_t*)avctx->extradata)[0] = 0;
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
367 ((uint32_t*)avctx->extradata)[1] =
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
368 (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
369 } else {
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
370 /* has extra slice header (demux_rm or rm->avi streamcopy) */
20920
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
371 avctx->extradata_size = sh->bih->biSize-sizeof(BITMAPINFOHEADER);
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
372 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
373 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
374 }
21946
ea78a2b99651 BE_32 -> AV_RB32
reimar
parents: 21531
diff changeset
375 avctx->sub_id= AV_RB32(avctx->extradata+4);
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
376
7126
d3fd5d568594 passing extra stuff from real stuff to lavc
michael
parents: 7051
diff changeset
377 // 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
378 break;
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
379
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
380 default:
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
381 if (!sh->bih || sh->bih->biSize <= sizeof(BITMAPINFOHEADER))
4ca6b585aa58 simplify extradata handling and make passing extradata on the default.
reimar
parents: 18004
diff changeset
382 break;
7736
b81b0ab0aa40 put M4S2 & MP4S headers in avctx->extradata (in the unlikely case that they arent missing completly)
michael
parents: 7722
diff changeset
383 avctx->extradata_size = sh->bih->biSize-sizeof(BITMAPINFOHEADER);
17226
255b14c0bc36 malloc padding to avoid access beyond allocated memory
henry
parents: 17217
diff changeset
384 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
385 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
386 break;
7736
b81b0ab0aa40 put M4S2 & MP4S headers in avctx->extradata (in the unlikely case that they arent missing completly)
michael
parents: 7722
diff changeset
387 }
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
388 /* Pass palette to codec */
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
389 if (sh->bih && (sh->bih->biBitCount <= 8)) {
18879
cc65a585fdcc rm unnecesary casts from void* - part 3
reynaldo
parents: 18023
diff changeset
390 avctx->palctrl = calloc(1,sizeof(AVPaletteControl));
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
391 avctx->palctrl->palette_changed = 1;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
392 if (sh->bih->biSize-sizeof(BITMAPINFOHEADER))
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
393 /* Palette size in biSize */
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
394 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
395 FFMIN(sh->bih->biSize-sizeof(BITMAPINFOHEADER), AVPALETTE_SIZE));
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
396 else
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
397 /* Palette size in biClrUsed */
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
398 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
399 FFMIN(sh->bih->biClrUsed * 4, AVPALETTE_SIZE));
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
400 }
19073
8b52dad54b1d Remove #if LIBAVCODEC_BUILD >= XXX and #if LIBAVFORMAT_BUILD >= XXX jungle.
diego
parents: 18917
diff changeset
401
8264
1f3708389d0a 10l (broken ffmpeg12)
michael
parents: 8237
diff changeset
402 if(sh->bih)
1f3708389d0a 10l (broken ffmpeg12)
michael
parents: 8237
diff changeset
403 avctx->bits_per_sample= sh->bih->biBitCount;
7126
d3fd5d568594 passing extra stuff from real stuff to lavc
michael
parents: 7051
diff changeset
404
17080
b3ef98ca8677 multithreaded decoding
michael
parents: 17073
diff changeset
405 if(lavc_param_threads > 1)
b3ef98ca8677 multithreaded decoding
michael
parents: 17073
diff changeset
406 avcodec_thread_init(avctx, lavc_param_threads);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
407 /* 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
408 if (avcodec_open(avctx, lavc_codec) < 0) {
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
409 mp_msg(MSGT_DECVIDEO,MSGL_ERR, MSGTR_CantOpenCodec);
21498
f2c58d4fb683 Fix memleak if vd_ffmpeg init fails
reimar
parents: 21457
diff changeset
410 uninit(sh);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
411 return 0;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
412 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
413 mp_msg(MSGT_DECVIDEO,MSGL_V,"INFO: libavcodec init OK!\n");
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
414 ctx->last_aspect=-3;
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;
6740
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
453 int start=0, i;
10449
498568fe7fd8 width -> frame / field type
michael
parents: 10436
diff changeset
454 int width= s->width;
13489
912c906db2ed compensate for width/height being picture width/height instead of bitstream width/height
michael
parents: 13473
diff changeset
455 int skip_stride= ((width<<lavc_param_lowres)+15)>>4;
9400
e572a8df7e88 10l to kabi (compile fix, uint8->uint8_t)
arpi
parents: 8885
diff changeset
456 uint8_t *skip= &s->coded_frame->mbskip_table[(y>>4)*skip_stride];
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
457 int threshold= s->coded_frame->age;
10436
f9e4db4e4759 new ff_draw_horiz_band()
michael
parents: 10423
diff changeset
458 uint8_t *source[3]= {src->data[0] + offset[0], src->data[1] + offset[1], src->data[2] + offset[2]};
6740
913736867009 10l y422p -> y420p
michael
parents: 6739
diff changeset
459 #if 0
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!!!
8770be0a5bb5 aspect change does not flush buffers
iive
parents: 11372
diff changeset
501 if (// aspect != ctx->last_aspect ||
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 ||
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
505 !ctx->vo_inited)
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);
c9a3a1e70263 sample_aspect_ratio
michael
parents: 11064
diff changeset
508 ctx->last_aspect = aspect;
8510
43a716922d41 1l (%d->%f), cosmetics
arpi
parents: 8413
diff changeset
509 // if(ctx->last_aspect>=0.01 && ctx->last_aspect<100)
10080
312eb2923169 Made the decoder honor the aspect ratio set by the container (if it was set at all).
mosu
parents: 9991
diff changeset
510 if(sh->aspect==0.0)
8510
43a716922d41 1l (%d->%f), cosmetics
arpi
parents: 8413
diff changeset
511 sh->aspect = ctx->last_aspect;
15567
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
512 sh->disp_w = width;
c8ef0513f470 prefer width&height from bitmapinfoheader for h263 streams
henry
parents: 15064
diff changeset
513 sh->disp_h = height;
17973
75442247ee56 reinit vo when pix_fmt changes.
reimar
parents: 17932
diff changeset
514 ctx->pix_fmt = pix_fmt;
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
515 switch(pix_fmt){
14597
9bc220e867ed "support" YUVJ colorspaces added to libavcodec, makes mjpeg decoding work again
reimar
parents: 14576
diff changeset
516 // 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
517 // 16 - 235 (see colorspaces.txt).
9bc220e867ed "support" YUVJ colorspaces added to libavcodec, makes mjpeg decoding work again
reimar
parents: 14576
diff changeset
518 // Currently they are all treated the same way.
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
519 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
520 case PIX_FMT_YUVJ420P:
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
521 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
522 case PIX_FMT_YUVJ422P:
8190
c3716e345dfb ffhuffyuv
michael
parents: 8130
diff changeset
523 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
524 case PIX_FMT_YUVJ444P:
8510
43a716922d41 1l (%d->%f), cosmetics
arpi
parents: 8413
diff changeset
525 case PIX_FMT_YUV444P: ctx->best_csp=IMGFMT_444P;break; //photo jpeg
7662
c92b0b4d9e77 411P added (DV ntsc)
arpi
parents: 7578
diff changeset
526 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
527 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
528 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
529 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
530 case PIX_FMT_BGR24 : ctx->best_csp=IMGFMT_BGR24;break; //8bps
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
531 case PIX_FMT_RGB555: ctx->best_csp=IMGFMT_BGR15;break; //rpza,cram
12171
michael
parents: 12033
diff changeset
532 case PIX_FMT_RGB565: ctx->best_csp=IMGFMT_BGR16;break; //4xm
17561
7b7b7552fcbb Add support for grayscale [m]jpeg
rtognimp
parents: 17523
diff changeset
533 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
534 case PIX_FMT_PAL8: ctx->best_csp=IMGFMT_BGR8;break; //8bps,mrle,cram
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
535 #ifdef HAVE_XVMC
10471
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
536 case PIX_FMT_XVMC_MPEG2_MC:ctx->best_csp=IMGFMT_XVMC_MOCO_MPEG2;break;
8672c6119e2c xvmc updates
iive
parents: 10452
diff changeset
537 case PIX_FMT_XVMC_MPEG2_IDCT:ctx->best_csp=IMGFMT_XVMC_IDCT_MPEG2;break;
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
538 #endif
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
539 default:
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
540 ctx->best_csp=0;
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
541 }
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
542 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
543 return -1;
16963
4aa0f65686a6 do not set ctx->vo_inited when init fails. This caused a crash when a
reimar
parents: 16497
diff changeset
544 ctx->vo_inited = 1;
5592
b545d56314d2 yuy2 support, fixed bug of dropping frame after config_vo calls
arpi
parents: 5517
diff changeset
545 }
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
546 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
547 }
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
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
549 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
550 sh_video_t * sh = avctx->opaque;
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
551 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
552 mp_image_t* mpi=NULL;
6875
255b150a75a5 - some reorder/cleanup of mp_image flags
arpi
parents: 6873
diff changeset
553 int flags= MP_IMGFLAG_ACCEPT_STRIDE | MP_IMGFLAG_PREFER_ALIGNED_STRIDE;
6737
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
554 int type= MP_IMGTYPE_IPB;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
555 int width= avctx->width;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
556 int height= avctx->height;
6738
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
557 int align=15;
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
558 //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
559 if(avctx->pix_fmt == PIX_FMT_YUV410P)
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
560 align=63; //yes seriously, its really needed (16x16 chroma blocks in SVQ1 -> 64x64)
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
561
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
562 if (pic->buffer_hints) {
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
563 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
564 type = MP_IMGTYPE_TEMP;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
565 if (pic->buffer_hints & FF_BUFFER_HINTS_READABLE)
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
566 flags |= MP_IMGFLAG_READABLE;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
567 if (pic->buffer_hints & FF_BUFFER_HINTS_PRESERVE) {
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
568 type = MP_IMGTYPE_STATIC;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
569 flags |= MP_IMGFLAG_PRESERVE;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
570 }
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
571 if (pic->buffer_hints & FF_BUFFER_HINTS_REUSABLE) {
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
572 type = MP_IMGTYPE_STATIC;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
573 flags |= MP_IMGFLAG_PRESERVE;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
574 }
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
575 flags|=(!avctx->hurry_up && ctx->do_slices) ?
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
576 MP_IMGFLAG_DRAW_CALLBACK:0;
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
577 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
578 } else {
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
579 if(!pic->reference){
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
580 ctx->b_count++;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
581 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
582 MP_IMGFLAG_DRAW_CALLBACK:0;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
583 }else{
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
584 ctx->ip_count++;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
585 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
586 | (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
587 }
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
588 }
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
589
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
590 if(init_vo(sh,avctx->pix_fmt) < 0){
9991
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
591 avctx->release_buffer= avcodec_default_release_buffer;
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
592 avctx->get_buffer= avcodec_default_get_buffer;
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
593 return avctx->get_buffer(avctx, pic);
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
594 }
19073
8b52dad54b1d Remove #if LIBAVCODEC_BUILD >= XXX and #if LIBAVFORMAT_BUILD >= XXX jungle.
diego
parents: 18917
diff changeset
595
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
596 if (!pic->buffer_hints) {
9991
8568ef7f6c2f segfault fix
michael
parents: 9982
diff changeset
597 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
598 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
599
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
600 ctx->do_dr1=0; //FIXME
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
601 avctx->get_buffer= avcodec_default_get_buffer;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
602 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
603 }
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
6737
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
605 if(avctx->has_b_frames){
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
606 type= MP_IMGTYPE_IPB;
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
607 }else{
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
608 type= MP_IMGTYPE_IP;
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
609 }
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
610 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
611 }
6737
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
612
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
613 mpi= mpcodecs_get_image(sh,type, flags,
6738
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
614 (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
615
11000
6e35326c742f many small typo and grammar fixes
gabucino
parents: 10847
diff changeset
616 // 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
617 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
618 !(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
619 // 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
620 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
621 } 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
622 avctx->draw_horiz_band= NULL;
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
623
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
624 // Palette support: libavcodec copies palette to *data[1]
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
625 if (mpi->bpp == 8)
14431
0c10f923746e change malloc and free to av_ variants where needed.
reimar
parents: 14169
diff changeset
626 mpi->planes[1] = av_malloc(AVPALETTE_SIZE);
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
627
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
628 pic->data[0]= mpi->planes[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
629 pic->data[1]= mpi->planes[1];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
630 pic->data[2]= mpi->planes[2];
8595
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
631
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
632 #if 0
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
633 assert(mpi->width >= ((width +align)&(~align)));
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
634 assert(mpi->height >= ((height+align)&(~align)));
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
635 assert(mpi->stride[0] >= mpi->width);
7051
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
636 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
637 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
638 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
639
d03fad6123a3 asserts to check buffer size and non overlapingness
michael
parents: 7004
diff changeset
640 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
641 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
642 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
643 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
644 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
645 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
646 }
8595
64efd67fee9b i hate asserts
arpi
parents: 8586
diff changeset
647 #endif
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
648
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
649 /* 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
650 * 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
651 */
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
652 pic->linesize[0]= mpi->stride[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
653 pic->linesize[1]= mpi->stride[1];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
654 pic->linesize[2]= mpi->stride[2];
6734
e614de962b6e fixing fixmes
michael
parents: 6733
diff changeset
655
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
656 pic->opaque = mpi;
6742
93bce3460e2a fallback to slices, if dr1 fails (bug found by kabi)
michael
parents: 6740
diff changeset
657 //printf("%X\n", (int)mpi->planes[0]);
6869
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
658 #if 0
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
659 if(mpi->flags&MP_IMGFLAG_DIRECT)
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
660 printf("D");
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
661 else if(mpi->flags&MP_IMGFLAG_DRAW_CALLBACK)
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
662 printf("S");
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
663 else
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
664 printf(".");
591a6c942551 compatibility with _OLD_ lavc & uv_stride check
michael
parents: 6835
diff changeset
665 #endif
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
666 if(pic->reference){
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
667 pic->age= ctx->ip_age[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
668
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
669 ctx->ip_age[0]= ctx->ip_age[1]+1;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
670 ctx->ip_age[1]= 1;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
671 ctx->b_age++;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
672 }else{
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
673 pic->age= ctx->b_age;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
674
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
675 ctx->ip_age[0]++;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
676 ctx->ip_age[1]++;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
677 ctx->b_age=1;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
678 }
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
679 pic->type= FF_BUFFER_TYPE_USER;
7928
5d1c1d73e8f3 handle direct rendering buffer allocation failure
michael
parents: 7898
diff changeset
680 return 0;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
681 }
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
682
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
683 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
684 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
685 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
686 vd_ffmpeg_ctx *ctx = sh->context;
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
687 int i;
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
688
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
689 //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
690
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
691 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
692 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
693 ctx->ip_count--;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
694 else
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
695 ctx->b_count--;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
696 }
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
697
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
698 // 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
699 if ( mpi && (mpi->bpp == 8))
0c10f923746e change malloc and free to av_ variants where needed.
reimar
parents: 14169
diff changeset
700 av_freep(&mpi->planes[1]);
11420
b99147bd6cce Support for paletted codecs in ffmpeg
rtognimp
parents: 11414
diff changeset
701
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
702 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
703 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
704 return;
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
705 }
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
706
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
707 for(i=0; i<4; i++){
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
708 pic->data[i]= NULL;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
709 }
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
710 //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
711 }
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
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
713 // copypaste from demux_real.c - it should match to get it working!
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
714 //FIXME put into some header
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
715 typedef struct dp_hdr_s {
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
716 uint32_t chunks; // number of chunks
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
717 uint32_t timestamp; // timestamp from packet header
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
718 uint32_t len; // length of actual data
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
719 uint32_t chunktab; // offset to chunk offset array
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
720 } dp_hdr_t;
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
721
22076
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
722 void swap_palette(void *pal) {
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
723 int i;
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
724 uint32_t *p = pal;
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
725 for (i = 0; i < AVPALETTE_COUNT; i++)
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
726 p[i] = le2me_32(p[i]);
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
727 }
13190
8be7dbcea0be AVC (fourcc avc1) in mp4 support
rtognimp
parents: 13075
diff changeset
728
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
729 // 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
730 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
731 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
732 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
733 vd_ffmpeg_ctx *ctx = sh->context;
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
734 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
735 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
736 mp_image_t* mpi=NULL;
6737
39619804c8b6 imgtype IP support
michael
parents: 6736
diff changeset
737 int dr1= ctx->do_dr1;
13190
8be7dbcea0be AVC (fourcc avc1) in mp4 support
rtognimp
parents: 13075
diff changeset
738 unsigned char *buf = 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
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;
10161
a339c588ddcd removed obsolete (and currently non-working) scaling functions, after that it works correctly with YV12,422P and 444P mjpegs
alex
parents: 10131
diff changeset
746 if(ctx->vo_inited && !(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
7574
87f57e23e301 fixing RV10 streamcopy - detect packet format (simple single frame vs. slices
arpi
parents: 7573
diff changeset
758 // if(sh->ds->demuxer->type == DEMUXER_TYPE_REAL){
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'))
20920
94b1a797661f Fix extradata passing to lavc RV20 decoder
rtogni
parents: 20741
diff changeset
764 if(sh->bih->biSize>=sizeof(*sh->bih)+8){
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
765 int i;
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
766 dp_hdr_t *hdr= (dp_hdr_t*)data;
22147
f4f90f0f5d2b Add missing checks in RealVideo slice handling code.
reimar
parents: 22092
diff changeset
767 uint32_t *offsets = (uint32_t*)(data + hdr->chunktab) + 1;
f4f90f0f5d2b Add missing checks in RealVideo slice handling code.
reimar
parents: 22092
diff changeset
768 char *end = data + len;
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
769
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
770 if(avctx->slice_offset==NULL)
14431
0c10f923746e change malloc and free to av_ variants where needed.
reimar
parents: 14169
diff changeset
771 avctx->slice_offset= av_malloc(sizeof(int)*1000);
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
772
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
773 // for(i=0; i<25; i++) printf("%02X ", ((uint8_t*)data)[i]);
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
774
22147
f4f90f0f5d2b Add missing checks in RealVideo slice handling code.
reimar
parents: 22092
diff changeset
775 avctx->slice_count= FFMIN(hdr->chunks+1, 1000);
f4f90f0f5d2b Add missing checks in RealVideo slice handling code.
reimar
parents: 22092
diff changeset
776 for(i=0; i<avctx->slice_count && end >= &offsets[2*i+1]; i++)
f4f90f0f5d2b Add missing checks in RealVideo slice handling code.
reimar
parents: 22092
diff changeset
777 avctx->slice_offset[i]= offsets[2*i];
7578
f64b73e009af 1l - update len too in sliced mode
arpi
parents: 7574
diff changeset
778 len=hdr->len;
7573
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
779 data+= sizeof(dp_hdr_t);
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
780 }
30e1c1f77737 rv10 cleanup
michael
parents: 7564
diff changeset
781
16497
182794778785 print the first 16 bytes of frame data with -v -v, helps detect when
reimar
parents: 15986
diff changeset
782 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
783 ((int *)data)[0], ((int *)data)[1], ((int *)data)[2], ((int *)data)[3]);
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
784 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
785 &got_picture, data, len);
13190
8be7dbcea0be AVC (fourcc avc1) in mp4 support
rtognimp
parents: 13075
diff changeset
786
9982
cd76f332bdee fallback to non-dr1 if the codec wants more than 1+2 buffers
michael
parents: 9931
diff changeset
787 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
788 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
789 //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
790 //-- vstats generation
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
791 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
792 static FILE *fvstats=NULL;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
793 char filename[20];
6834
2d7dfcc79651 Fix overall frametime overflow, hopefully long long int is portable. (untested, will test tomorrow)
atmos4
parents: 6833
diff changeset
794 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
795 static int frame_number=0;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
796 static double all_frametime=0.0;
8413
2670aec42989 AVVideoFrame -> AVFrame
michael
parents: 8411
diff changeset
797 AVFrame *pic= avctx->coded_frame;
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
798 double quality=0.0;
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
799
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
800 if(!fvstats) {
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
801 time_t today2;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
802 struct tm *today;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
803 today2 = time(NULL);
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
804 today = localtime(&today2);
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
805 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
806 today->tm_min, today->tm_sec);
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
807 fvstats = fopen(filename,"w");
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
808 if(!fvstats) {
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
809 perror("fopen");
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
810 lavc_param_vstats=0; // disable block
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
811 break;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
812 /*exit(1);*/
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
813 }
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
814 }
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
815
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
816 // average MB quantizer
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
817 {
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
818 int x, y;
13489
912c906db2ed compensate for width/height being picture width/height instead of bitstream width/height
michael
parents: 13473
diff changeset
819 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
820 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
821 int8_t *q = pic->qscale_table;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
822 for( y = 0; y < h; y++ ) {
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
823 for( x = 0; x < w; x++ )
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
824 quality += (double)*(q+x);
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
825 q += pic->qstride;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
826 }
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
827 quality /= w * h;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
828 }
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
829
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
830 all_len+=len;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
831 all_frametime+=sh->frametime;
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
832 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
833 ++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
834 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
835 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
836 (double)(all_len*8)/all_frametime/1000.0);
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
837 switch(pic->pict_type){
8347
michael
parents: 8341
diff changeset
838 case FF_I_TYPE:
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
839 fprintf(fvstats, "type= I\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_P_TYPE:
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
842 fprintf(fvstats, "type= P\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_S_TYPE:
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
845 fprintf(fvstats, "type= S\n");
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
846 break;
8347
michael
parents: 8341
diff changeset
847 case FF_B_TYPE:
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
848 fprintf(fvstats, "type= B\n");
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
849 break;
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
850 default:
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
851 fprintf(fvstats, "type= ? (%d)\n", pic->pict_type);
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
852 break;
8065
a3e7c0e16d5b fixing vstats so B frames are shown as B and not P
michael
parents: 7984
diff changeset
853 }
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
854
9865
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
855 ctx->qp_stat[(int)(quality+0.5)]++;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
856 ctx->qp_sum += quality;
30893b593947 Adaptive quantization support for "-lavcopts psnr" and "-lavdopts vstats".
rguyom
parents: 9547
diff changeset
857 ctx->inv_qp_sum += 1.0/(double)quality;
8411
5630321c8026 ffmpeg cleanup/messup support
michael
parents: 8347
diff changeset
858
6828
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
859 break;
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
860 }
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
861 //--
010be15e48ad Generate ffmpeg compatible vstats_<time>.log, when -lavdopts vstats is specified.
atmos4
parents: 6771
diff changeset
862
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 if(!got_picture) return NULL; // skipped image
6738
77f2713ae7fd svq1 direct rendering
michael
parents: 6737
diff changeset
864
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
865 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
866
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
867 if(dr1 && pic->opaque){
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
868 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
869 }
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
870
5482
cd97c8313300 libavcodec slices support
arpi
parents: 5457
diff changeset
871 if(!mpi)
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
872 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
873 avctx->width, avctx->height);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
874 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
875 mp_msg(MSGT_DECVIDEO, MSGL_WARN, MSGTR_MPCODECS_CouldntAllocateImageForCodec);
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
876 return NULL;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
877 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
878
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
879 if(!dr1){
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
880 mpi->planes[0]=pic->data[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
881 mpi->planes[1]=pic->data[1];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
882 mpi->planes[2]=pic->data[2];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
883 mpi->stride[0]=pic->linesize[0];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
884 mpi->stride[1]=pic->linesize[1];
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
885 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
886 }
11372
3761aff4722e If alex is too lazy to apply a patch, then i'll do it :)
attila
parents: 11194
diff changeset
887
3761aff4722e If alex is too lazy to apply a patch, then i'll do it :)
attila
parents: 11194
diff changeset
888 if (!mpi->planes[0])
3761aff4722e If alex is too lazy to apply a patch, then i'll do it :)
attila
parents: 11194
diff changeset
889 return NULL;
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
890
6873
1206fa765697 colorspace part cleanup and support for IMGFMT_422P, _444P
arpi
parents: 6869
diff changeset
891 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
892 // we have 422p but user wants 420p
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
893 mpi->stride[1]*=2;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
894 mpi->stride[2]*=2;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
895 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
896
22076
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
897 #ifdef WORDS_BIGENDIAN
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
898 // FIXME: this might cause problems for buffers with FF_BUFFER_HINTS_PRESERVE
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
899 if (mpi->bpp == 8)
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
900 swap_palette(mpi->planes[1]);
e81065a87c2d Swap palette on bigendian.
reimar
parents: 21946
diff changeset
901 #endif
6665
3284abe2d73f support avcontext based quant_store export
alex
parents: 6355
diff changeset
902 /* to comfirm with newer lavc style */
8339
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
903 mpi->qscale =pic->qscale_table;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
904 mpi->qstride=pic->qstride;
ff0bddb59e81 support for lavc build 4641
michael
parents: 8264
diff changeset
905 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
906 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
907 mpi->fields = MP_IMGFIELD_ORDERED;
bcf9862f61b2 set top_field first for lavc decoding and add MP_IMGFIELD_INTERLACED
michael
parents: 11541
diff changeset
908 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
909 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
910 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
911
4952
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
912 return mpi;
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
913 }
ffeba1050226 vd_ffmpeg added
arpi
parents:
diff changeset
914
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
915 static enum PixelFormat get_format(struct AVCodecContext * avctx,
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
916 const enum PixelFormat * fmt){
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
917 sh_video_t * sh = avctx->opaque;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
918 vd_ffmpeg_ctx *ctx = sh->context;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
919 int i;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
920
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
921 #ifdef HAVE_XVMC
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
922 if(avctx->xvmc_acceleration){
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
923 avctx->get_buffer= mc_get_buffer;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
924 avctx->release_buffer= mc_release_buffer;
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
925 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
926 mp_msg(MSGT_DECVIDEO, MSGL_INFO, MSGTR_MPCODECS_XVMCAcceleratedMPEG2);
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
927 assert(ctx->do_dr1);//these are must to!
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
928 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
929 avctx->flags|= CODEC_FLAG_EMU_EDGE;//do i need that??!!
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
930 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
931 }
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
932 #endif
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
933 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
934 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
935 if( init_vo(sh,fmt[i]) >= 0)
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
936 return fmt[i];
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
937 }
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
938 return fmt[0];
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
939 }
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
940
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
941 #ifdef HAVE_XVMC
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
942 static int mc_get_buffer(AVCodecContext *avctx, AVFrame *pic){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
943 sh_video_t * sh = avctx->opaque;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
944 vd_ffmpeg_ctx *ctx = sh->context;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
945 mp_image_t* mpi=NULL;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
946 xvmc_render_state_t * render;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
947 int flags= MP_IMGFLAG_ACCEPT_STRIDE | MP_IMGFLAG_PREFER_ALIGNED_STRIDE|
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
948 MP_IMGFLAG_DRAW_CALLBACK;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
949
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
950 // 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
951 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
952 mp_msg(MSGT_DECVIDEO, MSGL_INFO, MSGTR_MPCODECS_McGetBufferShouldWorkOnlyWithXVMC);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
953 assert(0);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
954 exit(1);
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
955 // return -1;//!!fixme check error conditions
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
956 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
957 assert(avctx->draw_horiz_band == mc_render_slice);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
958 assert(avctx->release_buffer == mc_release_buffer);
17932
3fe3b2b3a6ce Convert all if(verbose>X) to mp_msg_test calls.
diego
parents: 17561
diff changeset
959 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
960 mp_msg(MSGT_DECVIDEO, MSGL_DBG5, "vd_ffmpeg::mc_get_buffer\n");
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
961
12006
f4537eee7c33 xvmc use get_format for IDCT/MC recognition
iive
parents: 11992
diff changeset
962 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
963 mp_msg(MSGT_DECVIDEO, MSGL_WARN, MSGTR_MPCODECS_UnexpectedInitVoError);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
964 exit(1);
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
965 // return -1;//!!fixme check error conditions
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
966 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
967
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
968
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
969
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
970 if(!pic->reference){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
971 ctx->b_count++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
972 }else{
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
973 ctx->ip_count++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
974 flags|= MP_IMGFLAG_PRESERVE|MP_IMGFLAG_READABLE;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
975 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
976
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
977 mpi= mpcodecs_get_image(sh, MP_IMGTYPE_IPB,flags ,
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
978 avctx->width, avctx->height);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
979 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
980 mp_msg(MSGT_DECVIDEO, MSGL_ERR, MSGTR_MPCODECS_UnrecoverableErrorRenderBuffersNotTaken);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
981 assert(0);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
982 exit(1);
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
983 // return -1;//!!fixme check error conditions in ffmpeg
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
984 };
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
985
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
986 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
987 mp_msg(MSGT_DECVIDEO, MSGL_ERR, MSGTR_MPCODECS_OnlyBuffersAllocatedByVoXvmcAllowed);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
988 assert(0);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
989 exit(1);
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
990 // return -1;//!!fixme check error conditions in ffmpeg
10362
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 pic->data[0]= mpi->planes[0];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
994 pic->data[1]= mpi->planes[1];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
995 pic->data[2]= mpi->planes[2];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
996
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
997
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
998 /* Note, some (many) codecs in libavcodec must have stride1==stride2 && no changes between frames
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
999 * lavc will check that and die with an error message, if its not true
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1000 */
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1001 pic->linesize[0]= mpi->stride[0];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1002 pic->linesize[1]= mpi->stride[1];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1003 pic->linesize[2]= mpi->stride[2];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1004
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1005 pic->opaque = mpi;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1006
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1007 if(pic->reference){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1008 //I or P frame
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1009 pic->age= ctx->ip_age[0];
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1010
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1011 ctx->ip_age[0]= ctx->ip_age[1]+1;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1012 ctx->ip_age[1]= 1;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1013 ctx->b_age++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1014 }else{
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1015 //B frame
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1016 pic->age= ctx->b_age;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1017
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1018 ctx->ip_age[0]++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1019 ctx->ip_age[1]++;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1020 ctx->b_age=1;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1021 }
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1022
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1023 pic->type= FF_BUFFER_TYPE_USER;
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1024
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1025 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
1026 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
1027 mp_msg(MSGT_DECVIDEO, MSGL_DBG5, "vd_ffmpeg::mc_get_buffer (render=%p)\n",render);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1028 assert(render != 0);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1029 assert(render->magic == MP_XVMC_RENDER_MAGIC);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1030 render->state |= MP_XVMC_STATE_PREDICTION;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1031 return 0;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1032 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1033
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1034
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1035 static void mc_release_buffer(AVCodecContext *avctx, AVFrame *pic){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1036 mp_image_t* mpi= pic->opaque;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1037 sh_video_t * sh = avctx->opaque;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1038 vd_ffmpeg_ctx *ctx = sh->context;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1039 xvmc_render_state_t * render;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1040 int i;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1041
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1042
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1043 if(ctx->ip_count <= 2 && ctx->b_count<=1){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1044 if(mpi->flags&MP_IMGFLAG_PRESERVE)
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1045 ctx->ip_count--;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1046 else
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1047 ctx->b_count--;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1048 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1049
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1050 //printf("R%X %X\n", pic->linesize[0], pic->data[0]);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1051 //mark the surface as not requared for prediction
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1052 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
1053 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
1054 mp_msg(MSGT_DECVIDEO, MSGL_DBG5, "vd_ffmpeg::mc_release_buffer (render=%p)\n",render);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1055 assert(render!=NULL);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1056 assert(render->magic==MP_XVMC_RENDER_MAGIC);
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1057 render->state&=~MP_XVMC_STATE_PREDICTION;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1058 for(i=0; i<4; i++){
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1059 pic->data[i]= NULL;
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1060 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1061 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1062
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1063 static void mc_render_slice(struct AVCodecContext *s,
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1064 AVFrame *src, int offset[4],
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1065 int y, int type, int height){
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1066 int width= s->width;
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1067 sh_video_t * sh = s->opaque;
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1068 uint8_t *source[3]= {src->data[0], src->data[1], src->data[2]};
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1069
10452
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1070 assert(src->linesize[0]==0 && src->linesize[1]==0 && src->linesize[2]==0);
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1071 assert(offset[0]==0 && offset[1]==0 && offset[2]==0);
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1072
4eaf6fa120b1 sync to ffmpeg, updates, cleanups
iive
parents: 10449
diff changeset
1073 mpcodecs_draw_slice (sh, source, src->linesize, width, height, 0, y);
10362
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1074
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1075 }
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1076
8e3e884ec8a4 xvmc support
iive
parents: 10162
diff changeset
1077 #endif // HAVE_XVMC