1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * H.263i decoder 3cabdff1aSopenharmony_ci * 4cabdff1aSopenharmony_ci * This file is part of FFmpeg. 5cabdff1aSopenharmony_ci * 6cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 7cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 8cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 9cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 10cabdff1aSopenharmony_ci * 11cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 12cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 13cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 14cabdff1aSopenharmony_ci * Lesser General Public License for more details. 15cabdff1aSopenharmony_ci * 16cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 17cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 18cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 19cabdff1aSopenharmony_ci */ 20cabdff1aSopenharmony_ci 21cabdff1aSopenharmony_ci#include "codec_internal.h" 22cabdff1aSopenharmony_ci#include "mpegutils.h" 23cabdff1aSopenharmony_ci#include "mpegvideo.h" 24cabdff1aSopenharmony_ci#include "mpegvideodec.h" 25cabdff1aSopenharmony_ci#include "h263data.h" 26cabdff1aSopenharmony_ci#include "h263dec.h" 27cabdff1aSopenharmony_ci#include "mpegvideodata.h" 28cabdff1aSopenharmony_ci 29cabdff1aSopenharmony_ci/* don't understand why they choose a different header ! */ 30cabdff1aSopenharmony_ciint ff_intel_h263_decode_picture_header(MpegEncContext *s) 31cabdff1aSopenharmony_ci{ 32cabdff1aSopenharmony_ci int format; 33cabdff1aSopenharmony_ci 34cabdff1aSopenharmony_ci if (get_bits_left(&s->gb) == 64) { /* special dummy frames */ 35cabdff1aSopenharmony_ci return FRAME_SKIPPED; 36cabdff1aSopenharmony_ci } 37cabdff1aSopenharmony_ci 38cabdff1aSopenharmony_ci /* picture header */ 39cabdff1aSopenharmony_ci if (get_bits(&s->gb, 22) != 0x20) { 40cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "Bad picture start code\n"); 41cabdff1aSopenharmony_ci return -1; 42cabdff1aSopenharmony_ci } 43cabdff1aSopenharmony_ci s->picture_number = get_bits(&s->gb, 8); /* picture timestamp */ 44cabdff1aSopenharmony_ci 45cabdff1aSopenharmony_ci if (check_marker(s->avctx, &s->gb, "after picture_number") != 1) { 46cabdff1aSopenharmony_ci return -1; /* marker */ 47cabdff1aSopenharmony_ci } 48cabdff1aSopenharmony_ci if (get_bits1(&s->gb) != 0) { 49cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "Bad H.263 id\n"); 50cabdff1aSopenharmony_ci return -1; /* H.263 id */ 51cabdff1aSopenharmony_ci } 52cabdff1aSopenharmony_ci skip_bits1(&s->gb); /* split screen off */ 53cabdff1aSopenharmony_ci skip_bits1(&s->gb); /* camera off */ 54cabdff1aSopenharmony_ci skip_bits1(&s->gb); /* freeze picture release off */ 55cabdff1aSopenharmony_ci 56cabdff1aSopenharmony_ci format = get_bits(&s->gb, 3); 57cabdff1aSopenharmony_ci if (format == 0 || format == 6) { 58cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "Intel H.263 free format not supported\n"); 59cabdff1aSopenharmony_ci return -1; 60cabdff1aSopenharmony_ci } 61cabdff1aSopenharmony_ci s->h263_plus = 0; 62cabdff1aSopenharmony_ci 63cabdff1aSopenharmony_ci s->pict_type = AV_PICTURE_TYPE_I + get_bits1(&s->gb); 64cabdff1aSopenharmony_ci 65cabdff1aSopenharmony_ci s->h263_long_vectors = get_bits1(&s->gb); 66cabdff1aSopenharmony_ci 67cabdff1aSopenharmony_ci if (get_bits1(&s->gb) != 0) { 68cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "SAC not supported\n"); 69cabdff1aSopenharmony_ci return -1; /* SAC: off */ 70cabdff1aSopenharmony_ci } 71cabdff1aSopenharmony_ci s->obmc= get_bits1(&s->gb); 72cabdff1aSopenharmony_ci s->pb_frame = get_bits1(&s->gb); 73cabdff1aSopenharmony_ci 74cabdff1aSopenharmony_ci if (format < 6) { 75cabdff1aSopenharmony_ci s->width = ff_h263_format[format][0]; 76cabdff1aSopenharmony_ci s->height = ff_h263_format[format][1]; 77cabdff1aSopenharmony_ci s->avctx->sample_aspect_ratio.num = 12; 78cabdff1aSopenharmony_ci s->avctx->sample_aspect_ratio.den = 11; 79cabdff1aSopenharmony_ci } else { 80cabdff1aSopenharmony_ci format = get_bits(&s->gb, 3); 81cabdff1aSopenharmony_ci if(format == 0 || format == 7){ 82cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "Wrong Intel H.263 format\n"); 83cabdff1aSopenharmony_ci return -1; 84cabdff1aSopenharmony_ci } 85cabdff1aSopenharmony_ci if(get_bits(&s->gb, 2)) 86cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "Bad value for reserved field\n"); 87cabdff1aSopenharmony_ci s->loop_filter = get_bits1(&s->gb) * !s->avctx->lowres; 88cabdff1aSopenharmony_ci if(get_bits1(&s->gb)) 89cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "Bad value for reserved field\n"); 90cabdff1aSopenharmony_ci if(get_bits1(&s->gb)) 91cabdff1aSopenharmony_ci s->pb_frame = 2; 92cabdff1aSopenharmony_ci if(get_bits(&s->gb, 5)) 93cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "Bad value for reserved field\n"); 94cabdff1aSopenharmony_ci if(get_bits(&s->gb, 5) != 1) 95cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "Invalid marker\n"); 96cabdff1aSopenharmony_ci } 97cabdff1aSopenharmony_ci if(format == 6){ 98cabdff1aSopenharmony_ci int ar = get_bits(&s->gb, 4); 99cabdff1aSopenharmony_ci skip_bits(&s->gb, 9); // display width 100cabdff1aSopenharmony_ci check_marker(s->avctx, &s->gb, "in dimensions"); 101cabdff1aSopenharmony_ci skip_bits(&s->gb, 9); // display height 102cabdff1aSopenharmony_ci if(ar == 15){ 103cabdff1aSopenharmony_ci s->avctx->sample_aspect_ratio.num = get_bits(&s->gb, 8); // aspect ratio - width 104cabdff1aSopenharmony_ci s->avctx->sample_aspect_ratio.den = get_bits(&s->gb, 8); // aspect ratio - height 105cabdff1aSopenharmony_ci } else { 106cabdff1aSopenharmony_ci s->avctx->sample_aspect_ratio = ff_h263_pixel_aspect[ar]; 107cabdff1aSopenharmony_ci } 108cabdff1aSopenharmony_ci if (s->avctx->sample_aspect_ratio.num == 0) 109cabdff1aSopenharmony_ci av_log(s->avctx, AV_LOG_ERROR, "Invalid aspect ratio.\n"); 110cabdff1aSopenharmony_ci } 111cabdff1aSopenharmony_ci 112cabdff1aSopenharmony_ci s->chroma_qscale= s->qscale = get_bits(&s->gb, 5); 113cabdff1aSopenharmony_ci skip_bits1(&s->gb); /* Continuous Presence Multipoint mode: off */ 114cabdff1aSopenharmony_ci 115cabdff1aSopenharmony_ci if(s->pb_frame){ 116cabdff1aSopenharmony_ci skip_bits(&s->gb, 3); //temporal reference for B-frame 117cabdff1aSopenharmony_ci skip_bits(&s->gb, 2); //dbquant 118cabdff1aSopenharmony_ci } 119cabdff1aSopenharmony_ci 120cabdff1aSopenharmony_ci /* PEI */ 121cabdff1aSopenharmony_ci if (skip_1stop_8data_bits(&s->gb) < 0) 122cabdff1aSopenharmony_ci return AVERROR_INVALIDDATA; 123cabdff1aSopenharmony_ci s->f_code = 1; 124cabdff1aSopenharmony_ci 125cabdff1aSopenharmony_ci s->y_dc_scale_table= 126cabdff1aSopenharmony_ci s->c_dc_scale_table= ff_mpeg1_dc_scale_table; 127cabdff1aSopenharmony_ci 128cabdff1aSopenharmony_ci ff_h263_show_pict_info(s); 129cabdff1aSopenharmony_ci 130cabdff1aSopenharmony_ci return 0; 131cabdff1aSopenharmony_ci} 132cabdff1aSopenharmony_ci 133cabdff1aSopenharmony_ciconst FFCodec ff_h263i_decoder = { 134cabdff1aSopenharmony_ci .p.name = "h263i", 135cabdff1aSopenharmony_ci .p.long_name = NULL_IF_CONFIG_SMALL("Intel H.263"), 136cabdff1aSopenharmony_ci .p.type = AVMEDIA_TYPE_VIDEO, 137cabdff1aSopenharmony_ci .p.id = AV_CODEC_ID_H263I, 138cabdff1aSopenharmony_ci .priv_data_size = sizeof(MpegEncContext), 139cabdff1aSopenharmony_ci .init = ff_h263_decode_init, 140cabdff1aSopenharmony_ci .close = ff_h263_decode_end, 141cabdff1aSopenharmony_ci FF_CODEC_DECODE_CB(ff_h263_decode_frame), 142cabdff1aSopenharmony_ci .p.capabilities = AV_CODEC_CAP_DRAW_HORIZ_BAND | AV_CODEC_CAP_DR1, 143cabdff1aSopenharmony_ci .caps_internal = FF_CODEC_CAP_INIT_THREADSAFE | 144cabdff1aSopenharmony_ci FF_CODEC_CAP_SKIP_FRAME_FILL_PARAM, 145cabdff1aSopenharmony_ci .p.pix_fmts = (const enum AVPixelFormat[]) { 146cabdff1aSopenharmony_ci AV_PIX_FMT_YUV420P, 147cabdff1aSopenharmony_ci AV_PIX_FMT_NONE 148cabdff1aSopenharmony_ci }, 149cabdff1aSopenharmony_ci}; 150