|
|
@ -88,20 +88,19 @@ static int cyuv_decode_frame(AVCodecContext *avctx, |
|
|
|
* (3 * 16) + height * (width * 3 / 4) */ |
|
|
|
* (3 * 16) + height * (width * 3 / 4) */ |
|
|
|
if (buf_size != 48 + s->height * (s->width * 3 / 4)) { |
|
|
|
if (buf_size != 48 + s->height * (s->width * 3 / 4)) { |
|
|
|
av_log(avctx, AV_LOG_ERROR, "ffmpeg: cyuv: got a buffer with %d bytes when %d were expected\n", |
|
|
|
av_log(avctx, AV_LOG_ERROR, "ffmpeg: cyuv: got a buffer with %d bytes when %d were expected\n", |
|
|
|
buf_size, |
|
|
|
buf_size, 48 + s->height * (s->width * 3 / 4)); |
|
|
|
48 + s->height * (s->width * 3 / 4)); |
|
|
|
|
|
|
|
return -1; |
|
|
|
return -1; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/* pixel data starts 48 bytes in, after 3x16-byte tables */ |
|
|
|
/* pixel data starts 48 bytes in, after 3x16-byte tables */ |
|
|
|
stream_ptr = 48; |
|
|
|
stream_ptr = 48; |
|
|
|
|
|
|
|
|
|
|
|
if(s->frame.data[0]) |
|
|
|
if (s->frame.data[0]) |
|
|
|
avctx->release_buffer(avctx, &s->frame); |
|
|
|
avctx->release_buffer(avctx, &s->frame); |
|
|
|
|
|
|
|
|
|
|
|
s->frame.buffer_hints = FF_BUFFER_HINTS_VALID; |
|
|
|
s->frame.buffer_hints = FF_BUFFER_HINTS_VALID; |
|
|
|
s->frame.reference = 0; |
|
|
|
s->frame.reference = 0; |
|
|
|
if(avctx->get_buffer(avctx, &s->frame) < 0) { |
|
|
|
if (avctx->get_buffer(avctx, &s->frame) < 0) { |
|
|
|
av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); |
|
|
|
av_log(avctx, AV_LOG_ERROR, "get_buffer() failed\n"); |
|
|
|
return -1; |
|
|
|
return -1; |
|
|
|
} |
|
|
|
} |
|
|
|