X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=libavcodec%2Fflvdec.c;h=f2d49294c6e89cea30aa89d1fdba6ffdc404afd4;hb=8f144d9e3d5cb2ca92e5bdf7cc9f72effa1bd2ce;hp=665208adde258310aba0fb23c19ab07034f156b0;hpb=b2bed9325dbd6be0da1d91ffed3f513c40274fd2;p=ffmpeg diff --git a/libavcodec/flvdec.c b/libavcodec/flvdec.c index 665208adde2..f2d49294c6e 100644 --- a/libavcodec/flvdec.c +++ b/libavcodec/flvdec.c @@ -1,5 +1,6 @@ /* * FLV decoding. + * * This file is part of Libav. * * Libav is free software; you can redistribute it and/or @@ -17,20 +18,22 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ -#include "mpegvideo.h" -#include "h263.h" -#include "flv.h" #include "libavutil/imgutils.h" -void ff_flv2_decode_ac_esc(GetBitContext *gb, int *level, int *run, int *last){ +#include "flv.h" +#include "h263.h" +#include "mpegvideo.h" +#include "mpegvideodata.h" + +void ff_flv2_decode_ac_esc(GetBitContext *gb, int *level, int *run, int *last) +{ int is11 = get_bits1(gb); *last = get_bits1(gb); - *run = get_bits(gb, 6); - if(is11){ + *run = get_bits(gb, 6); + if (is11) *level = get_sbits(gb, 11); - } else { + else *level = get_sbits(gb, 7); - } } int ff_flv_decode_picture_header(MpegEncContext *s) @@ -47,45 +50,45 @@ int ff_flv_decode_picture_header(MpegEncContext *s) av_log(s->avctx, AV_LOG_ERROR, "Bad picture format\n"); return -1; } - s->h263_flv = format+1; + s->h263_flv = format + 1; s->picture_number = get_bits(&s->gb, 8); /* picture timestamp */ - format = get_bits(&s->gb, 3); + format = get_bits(&s->gb, 3); switch (format) { case 0: - width = get_bits(&s->gb, 8); + width = get_bits(&s->gb, 8); height = get_bits(&s->gb, 8); break; case 1: - width = get_bits(&s->gb, 16); + width = get_bits(&s->gb, 16); height = get_bits(&s->gb, 16); break; case 2: - width = 352; + width = 352; height = 288; break; case 3: - width = 176; + width = 176; height = 144; break; case 4: - width = 128; + width = 128; height = 96; break; case 5: - width = 320; + width = 320; height = 240; break; case 6: - width = 160; + width = 160; height = 120; break; default: width = height = 0; break; } - if(av_image_check_size(width, height, 0, s->avctx)) + if (av_image_check_size(width, height, 0, s->avctx)) return -1; - s->width = width; + s->width = width; s->height = height; s->pict_type = AV_PICTURE_TYPE_I + get_bits(&s->gb, 2); @@ -94,27 +97,25 @@ int ff_flv_decode_picture_header(MpegEncContext *s) s->pict_type = AV_PICTURE_TYPE_P; skip_bits1(&s->gb); /* deblocking flag */ - s->chroma_qscale= s->qscale = get_bits(&s->gb, 5); + s->chroma_qscale = s->qscale = get_bits(&s->gb, 5); s->h263_plus = 0; - s->unrestricted_mv = 1; + s->unrestricted_mv = 1; s->h263_long_vectors = 0; /* PEI */ - while (get_bits1(&s->gb) != 0) { + while (get_bits1(&s->gb) != 0) skip_bits(&s->gb, 8); - } s->f_code = 1; - if(s->avctx->debug & FF_DEBUG_PICT_INFO){ + if (s->avctx->debug & FF_DEBUG_PICT_INFO) { av_log(s->avctx, AV_LOG_DEBUG, "%c esc_type:%d, qp:%d num:%d\n", s->droppable ? 'D' : av_get_picture_type_char(s->pict_type), s->h263_flv - 1, s->qscale, s->picture_number); } - s->y_dc_scale_table= - s->c_dc_scale_table= ff_mpeg1_dc_scale_table; + s->y_dc_scale_table = s->c_dc_scale_table = ff_mpeg1_dc_scale_table; return 0; } @@ -128,6 +129,7 @@ AVCodec ff_flv_decoder = { .init = ff_h263_decode_init, .close = ff_h263_decode_end, .decode = ff_h263_decode_frame, - .capabilities = CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1, - .pix_fmts = ff_pixfmt_list_420, + .capabilities = AV_CODEC_CAP_DRAW_HORIZ_BAND | AV_CODEC_CAP_DR1, + .pix_fmts = (const enum AVPixelFormat[]) { AV_PIX_FMT_YUV420P, + AV_PIX_FMT_NONE }, };