annotate intelh263dec.c @ 10793:9b3ec3d1bdae libavcodec

Factorize if() surrounding every ff_h263_show_pict_info() call.
author michael
date Thu, 07 Jan 2010 14:55:11 +0000
parents 48adb5a1b47b
children 238c62c8728e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
10791
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
1 /*
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
2 * H.263i decoder
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
3 *
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
4 * This file is part of FFmpeg.
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
5 *
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
6 * FFmpeg is free software; you can redistribute it and/or
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
7 * modify it under the terms of the GNU Lesser General Public
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
8 * License as published by the Free Software Foundation; either
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
9 * version 2.1 of the License, or (at your option) any later version.
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
10 *
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
11 * FFmpeg is distributed in the hope that it will be useful,
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
14 * Lesser General Public License for more details.
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
15 *
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
16 * You should have received a copy of the GNU Lesser General Public
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
17 * License along with FFmpeg; if not, write to the Free Software
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
19 */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
20
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
21 #include "mpegvideo.h"
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
22
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
23 /* don't understand why they choose a different header ! */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
24 int ff_intel_h263_decode_picture_header(MpegEncContext *s)
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
25 {
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
26 int format;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
27
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
28 /* picture header */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
29 if (get_bits_long(&s->gb, 22) != 0x20) {
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
30 av_log(s->avctx, AV_LOG_ERROR, "Bad picture start code\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
31 return -1;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
32 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
33 s->picture_number = get_bits(&s->gb, 8); /* picture timestamp */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
34
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
35 if (get_bits1(&s->gb) != 1) {
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
36 av_log(s->avctx, AV_LOG_ERROR, "Bad marker\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
37 return -1; /* marker */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
38 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
39 if (get_bits1(&s->gb) != 0) {
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
40 av_log(s->avctx, AV_LOG_ERROR, "Bad H263 id\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
41 return -1; /* h263 id */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
42 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
43 skip_bits1(&s->gb); /* split screen off */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
44 skip_bits1(&s->gb); /* camera off */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
45 skip_bits1(&s->gb); /* freeze picture release off */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
46
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
47 format = get_bits(&s->gb, 3);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
48 if (format != 7) {
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
49 av_log(s->avctx, AV_LOG_ERROR, "Intel H263 free format not supported\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
50 return -1;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
51 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
52 s->h263_plus = 0;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
53
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
54 s->pict_type = FF_I_TYPE + get_bits1(&s->gb);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
55
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
56 s->unrestricted_mv = get_bits1(&s->gb);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
57 s->h263_long_vectors = s->unrestricted_mv;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
58
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
59 if (get_bits1(&s->gb) != 0) {
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
60 av_log(s->avctx, AV_LOG_ERROR, "SAC not supported\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
61 return -1; /* SAC: off */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
62 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
63 s->obmc= get_bits1(&s->gb);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
64 s->pb_frame = get_bits1(&s->gb);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
65
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
66 if(format == 7){
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
67 format = get_bits(&s->gb, 3);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
68 if(format == 0 || format == 7){
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
69 av_log(s->avctx, AV_LOG_ERROR, "Wrong Intel H263 format\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
70 return -1;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
71 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
72 if(get_bits(&s->gb, 2))
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
73 av_log(s->avctx, AV_LOG_ERROR, "Bad value for reserved field\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
74 s->loop_filter = get_bits1(&s->gb);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
75 if(get_bits1(&s->gb))
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
76 av_log(s->avctx, AV_LOG_ERROR, "Bad value for reserved field\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
77 if(get_bits1(&s->gb))
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
78 s->pb_frame = 2;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
79 if(get_bits(&s->gb, 5))
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
80 av_log(s->avctx, AV_LOG_ERROR, "Bad value for reserved field\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
81 if(get_bits(&s->gb, 5) != 1)
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
82 av_log(s->avctx, AV_LOG_ERROR, "Invalid marker\n");
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
83 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
84 if(format == 6){
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
85 int ar = get_bits(&s->gb, 4);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
86 skip_bits(&s->gb, 9); // display width
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
87 skip_bits1(&s->gb);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
88 skip_bits(&s->gb, 9); // display height
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
89 if(ar == 15){
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
90 skip_bits(&s->gb, 8); // aspect ratio - width
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
91 skip_bits(&s->gb, 8); // aspect ratio - height
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
92 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
93 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
94
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
95 s->chroma_qscale= s->qscale = get_bits(&s->gb, 5);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
96 skip_bits1(&s->gb); /* Continuous Presence Multipoint mode: off */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
97
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
98 if(s->pb_frame){
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
99 skip_bits(&s->gb, 3); //temporal reference for B-frame
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
100 skip_bits(&s->gb, 2); //dbquant
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
101 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
102
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
103 /* PEI */
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
104 while (get_bits1(&s->gb) != 0) {
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
105 skip_bits(&s->gb, 8);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
106 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
107 s->f_code = 1;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
108
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
109 s->y_dc_scale_table=
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
110 s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
111
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
112 ff_h263_show_pict_info(s);
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
113
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
114 return 0;
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
115 }
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
116
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
117 AVCodec h263i_decoder = {
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
118 "h263i",
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
119 CODEC_TYPE_VIDEO,
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
120 CODEC_ID_H263I,
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
121 sizeof(MpegEncContext),
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
122 ff_h263_decode_init,
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
123 NULL,
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
124 ff_h263_decode_end,
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
125 ff_h263_decode_frame,
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
126 CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
127 .long_name = NULL_IF_CONFIG_SMALL("Intel H.263"),
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
128 .pix_fmts= ff_pixfmt_list_420,
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
129 };
48adb5a1b47b Split out intel H263 decoder.
michael
parents:
diff changeset
130