diff options
author | Kostya Shishkov <kostya.shishkov@gmail.com> | 2014-01-18 14:34:30 +0100 |
---|---|---|
committer | Kostya Shishkov <kostya.shishkov@gmail.com> | 2014-01-21 17:47:50 +0100 |
commit | e91a3f1bdba9b4945e42c191d2e35e9844625fb4 (patch) | |
tree | d0533abb691596d56ba25dc82226c47eeadc8d49 | |
parent | ade4ecb42d2dacd18d04eb8df2afa8131e5ad653 (diff) | |
download | ffmpeg-e91a3f1bdba9b4945e42c191d2e35e9844625fb4.tar.gz |
dxtory: correctly handle YUV slices with average odd height
-rw-r--r-- | libavcodec/dxtory.c | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/libavcodec/dxtory.c b/libavcodec/dxtory.c index 6018ebb206..f69b6cdbf9 100644 --- a/libavcodec/dxtory.c +++ b/libavcodec/dxtory.c @@ -118,7 +118,8 @@ static int dxtory_decode_v2(AVCodecContext *avctx, AVFrame *pic, { GetByteContext gb; GetBitContext gb2; - int nslices, slice, slice_height; + int nslices, slice, slice_height, ref_slice_height; + int cur_y, next_y; uint32_t off, slice_size; uint8_t *Y, *U, *V; int ret; @@ -137,10 +138,10 @@ static int dxtory_decode_v2(AVCodecContext *avctx, AVFrame *pic, return AVERROR(ENOSYS); } - slice_height = avctx->height / nslices; - if ((avctx->width & 1) || (slice_height & 1)) { - avpriv_request_sample(avctx, "slice dimensions %dx%d", - avctx->width, slice_height); + ref_slice_height = avctx->height / nslices; + if ((avctx->width & 1) || (avctx->height & 1)) { + avpriv_request_sample(avctx, "Frame dimensions %dx%d", + avctx->width, avctx->height); } avctx->pix_fmt = AV_PIX_FMT_YUV420P; @@ -151,8 +152,11 @@ static int dxtory_decode_v2(AVCodecContext *avctx, AVFrame *pic, U = pic->data[1]; V = pic->data[2]; + cur_y = 0; + next_y = ref_slice_height; for (slice = 0; slice < nslices; slice++) { - slice_size = bytestream2_get_le32(&gb); + slice_size = bytestream2_get_le32(&gb); + slice_height = (next_y & ~1) - (cur_y & ~1); if (slice_size > src_size - off) { av_log(avctx, AV_LOG_ERROR, "invalid slice size %d (only %d bytes left)\n", @@ -177,6 +181,8 @@ static int dxtory_decode_v2(AVCodecContext *avctx, AVFrame *pic, U += pic->linesize[1] * (slice_height >> 1); V += pic->linesize[2] * (slice_height >> 1); off += slice_size; + cur_y = next_y; + next_y += ref_slice_height; } return 0; |