annotate flvdec.c @ 10790:145b62a1de1c libavcodec

flv.h should ideally be included in flvdec.c
author michael
date Thu, 07 Jan 2010 06:20:57 +0000
parents 0c8f9288b5e4
children d0657e337f91
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
10788
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
1 /*
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
2 * FLV decoding.
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
3 * This file is part of FFmpeg.
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
4 *
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
5 * FFmpeg is free software; you can redistribute it and/or
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
6 * modify it under the terms of the GNU Lesser General Public
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
7 * License as published by the Free Software Foundation; either
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
8 * version 2.1 of the License, or (at your option) any later version.
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
9 *
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
10 * FFmpeg is distributed in the hope that it will be useful,
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
13 * Lesser General Public License for more details.
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
14 *
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
15 * You should have received a copy of the GNU Lesser General Public
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
16 * License along with FFmpeg; if not, write to the Free Software
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
18 */
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
19
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
20 #include "mpegvideo.h"
10790
145b62a1de1c flv.h should ideally be included in flvdec.c
michael
parents: 10788
diff changeset
21 #include "flv.h"
10788
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
22
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
23 void ff_flv2_decode_ac_esc(GetBitContext *gb, int *level, int *run, int *last){
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
24 int is11 = get_bits1(gb);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
25 *last = get_bits1(gb);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
26 *run = get_bits(gb, 6);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
27 if(is11){
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
28 *level = get_sbits(gb, 11);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
29 } else {
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
30 *level = get_sbits(gb, 7);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
31 }
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
32 }
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
33
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
34 int ff_flv_decode_picture_header(MpegEncContext *s)
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
35 {
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
36 int format, width, height;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
37
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
38 /* picture header */
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
39 if (get_bits_long(&s->gb, 17) != 1) {
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
40 av_log(s->avctx, AV_LOG_ERROR, "Bad picture start code\n");
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
41 return -1;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
42 }
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
43 format = get_bits(&s->gb, 5);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
44 if (format != 0 && format != 1) {
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
45 av_log(s->avctx, AV_LOG_ERROR, "Bad picture format\n");
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
46 return -1;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
47 }
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
48 s->h263_flv = format+1;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
49 s->picture_number = get_bits(&s->gb, 8); /* picture timestamp */
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
50 format = get_bits(&s->gb, 3);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
51 switch (format) {
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
52 case 0:
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
53 width = get_bits(&s->gb, 8);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
54 height = get_bits(&s->gb, 8);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
55 break;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
56 case 1:
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
57 width = get_bits(&s->gb, 16);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
58 height = get_bits(&s->gb, 16);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
59 break;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
60 case 2:
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
61 width = 352;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
62 height = 288;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
63 break;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
64 case 3:
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
65 width = 176;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
66 height = 144;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
67 break;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
68 case 4:
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
69 width = 128;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
70 height = 96;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
71 break;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
72 case 5:
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
73 width = 320;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
74 height = 240;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
75 break;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
76 case 6:
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
77 width = 160;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
78 height = 120;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
79 break;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
80 default:
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
81 width = height = 0;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
82 break;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
83 }
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
84 if(avcodec_check_dimensions(s->avctx, width, height))
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
85 return -1;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
86 s->width = width;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
87 s->height = height;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
88
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
89 s->pict_type = FF_I_TYPE + get_bits(&s->gb, 2);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
90 s->dropable= s->pict_type > FF_P_TYPE;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
91 if (s->dropable)
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
92 s->pict_type = FF_P_TYPE;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
93
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
94 skip_bits1(&s->gb); /* deblocking flag */
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
95 s->chroma_qscale= s->qscale = get_bits(&s->gb, 5);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
96
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
97 s->h263_plus = 0;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
98
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
99 s->unrestricted_mv = 1;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
100 s->h263_long_vectors = 0;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
101
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
102 /* PEI */
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
103 while (get_bits1(&s->gb) != 0) {
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
104 skip_bits(&s->gb, 8);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
105 }
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
106 s->f_code = 1;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
107
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
108 if(s->avctx->debug & FF_DEBUG_PICT_INFO){
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
109 av_log(s->avctx, AV_LOG_DEBUG, "%c esc_type:%d, qp:%d num:%d\n",
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
110 s->dropable ? 'D' : av_get_pict_type_char(s->pict_type), s->h263_flv-1, s->qscale, s->picture_number);
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
111 }
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
112
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
113 s->y_dc_scale_table=
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
114 s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
115
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
116 return 0;
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
117 }
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
118
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
119 AVCodec flv_decoder = {
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
120 "flv",
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
121 CODEC_TYPE_VIDEO,
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
122 CODEC_ID_FLV1,
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
123 sizeof(MpegEncContext),
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
124 ff_h263_decode_init,
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
125 NULL,
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
126 ff_h263_decode_end,
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
127 ff_h263_decode_frame,
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
128 CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
129 .long_name= NULL_IF_CONFIG_SMALL("Flash Video (FLV) / Sorenson Spark / Sorenson H.263"),
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
130 .pix_fmts= ff_pixfmt_list_420,
0c8f9288b5e4 Split flv decoding out.
michael
parents:
diff changeset
131 };