Browse Source

msvideo1: use the AVFrame API properly.

tags/n2.2-rc1
Anton Khirnov 12 years ago
parent
commit
ef2a99c7f4
1 changed files with 13 additions and 11 deletions
  1. +13
    -11
      libavcodec/msvideo1.c

+ 13
- 11
libavcodec/msvideo1.c View File

@@ -47,7 +47,7 @@
typedef struct Msvideo1Context {

AVCodecContext *avctx;
AVFrame frame;
AVFrame *frame;

const unsigned char *buf;
int size;
@@ -72,7 +72,9 @@ static av_cold int msvideo1_decode_init(AVCodecContext *avctx)
avctx->pix_fmt = AV_PIX_FMT_RGB555;
}

avcodec_get_frame_defaults(&s->frame);
s->frame = av_frame_alloc();
if (!s->frame)
return AVERROR(ENOMEM);

return 0;
}
@@ -93,8 +95,8 @@ static void msvideo1_decode_8bit(Msvideo1Context *s)
unsigned short flags;
int skip_blocks;
unsigned char colors[8];
unsigned char *pixels = s->frame.data[0];
int stride = s->frame.linesize[0];
unsigned char *pixels = s->frame->data[0];
int stride = s->frame->linesize[0];

stream_ptr = 0;
skip_blocks = 0;
@@ -174,7 +176,7 @@ static void msvideo1_decode_8bit(Msvideo1Context *s)

/* make the palette available on the way out */
if (s->avctx->pix_fmt == AV_PIX_FMT_PAL8)
memcpy(s->frame.data[1], s->pal, AVPALETTE_SIZE);
memcpy(s->frame->data[1], s->pal, AVPALETTE_SIZE);
}

static void msvideo1_decode_16bit(Msvideo1Context *s)
@@ -193,8 +195,8 @@ static void msvideo1_decode_16bit(Msvideo1Context *s)
unsigned short flags;
int skip_blocks;
unsigned short colors[8];
unsigned short *pixels = (unsigned short *)s->frame.data[0];
int stride = s->frame.linesize[0] / 2;
unsigned short *pixels = (unsigned short *)s->frame->data[0];
int stride = s->frame->linesize[0] / 2;

stream_ptr = 0;
skip_blocks = 0;
@@ -298,7 +300,7 @@ static int msvideo1_decode_frame(AVCodecContext *avctx,
s->buf = buf;
s->size = buf_size;

if ((ret = ff_reget_buffer(avctx, &s->frame)) < 0) {
if ((ret = ff_reget_buffer(avctx, s->frame)) < 0) {
av_log(s->avctx, AV_LOG_ERROR, "reget_buffer() failed\n");
return ret;
}
@@ -308,7 +310,7 @@ static int msvideo1_decode_frame(AVCodecContext *avctx,

if (pal) {
memcpy(s->pal, pal, AVPALETTE_SIZE);
s->frame.palette_has_changed = 1;
s->frame->palette_has_changed = 1;
}
}

@@ -317,7 +319,7 @@ static int msvideo1_decode_frame(AVCodecContext *avctx,
else
msvideo1_decode_16bit(s);

if ((ret = av_frame_ref(data, &s->frame)) < 0)
if ((ret = av_frame_ref(data, s->frame)) < 0)
return ret;

*got_frame = 1;
@@ -330,7 +332,7 @@ static av_cold int msvideo1_decode_end(AVCodecContext *avctx)
{
Msvideo1Context *s = avctx->priv_data;

av_frame_unref(&s->frame);
av_frame_free(&s->frame);

return 0;
}


Loading…
Cancel
Save