diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2013-10-14 02:10:43 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2013-10-14 02:10:43 +0200 |
commit | d794b7db1453ada81c49ae03e777250b5c2868c6 (patch) | |
tree | 67ed04875db0777ef699f5a289a7266160e1b4e5 /libavcodec | |
parent | fb8a10db5d77424774493376b5d0412808bb0491 (diff) | |
parent | 1b20d0f581f01f2df601c9e68d0d321672d97af7 (diff) | |
download | ffmpeg-d794b7db1453ada81c49ae03e777250b5c2868c6.tar.gz |
Merge commit '1b20d0f581f01f2df601c9e68d0d321672d97af7'
* commit '1b20d0f581f01f2df601c9e68d0d321672d97af7':
cavs: Return meaningful error values
Conflicts:
libavcodec/cavsdec.c
Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/cavsdec.c | 20 |
1 files changed, 10 insertions, 10 deletions
diff --git a/libavcodec/cavsdec.c b/libavcodec/cavsdec.c index 4a8d21b2ac..7a8501426a 100644 --- a/libavcodec/cavsdec.c +++ b/libavcodec/cavsdec.c @@ -535,7 +535,7 @@ static inline int dequant(AVSContext *h, int16_t *level_buf, uint8_t *run_buf, av_log(h->avctx, AV_LOG_ERROR, "position out of block bounds at pic %d MB(%d,%d)\n", h->cur.poc, h->mbx, h->mby); - return -1; + return AVERROR_INVALIDDATA; } dst[scantab[pos]] = (level_buf[coeff_num] * mul + round) >> shift; } @@ -555,7 +555,7 @@ static int decode_residual_block(AVSContext *h, GetBitContext *gb, const struct dec_2dvlc *r, int esc_golomb_order, int qp, uint8_t *dst, int stride) { - int i, esc_code, level, mask; + int i, esc_code, level, mask, ret; unsigned int level_code, run; int16_t level_buf[65]; uint8_t run_buf[65]; @@ -583,9 +583,9 @@ static int decode_residual_block(AVSContext *h, GetBitContext *gb, level_buf[i] = level; run_buf[i] = run; } - if (dequant(h, level_buf, run_buf, block, dequant_mul[qp], - dequant_shift[qp], i)) - return -1; + if ((ret = dequant(h, level_buf, run_buf, block, dequant_mul[qp], + dequant_shift[qp], i)) < 0) + return ret; h->cdsp.cavs_idct8_add(dst, block, stride); h->dsp.clear_block(block); return 0; @@ -610,7 +610,7 @@ static inline int decode_residual_inter(AVSContext *h) int cbp = get_ue_golomb(&h->gb); if (cbp > 63U) { av_log(h->avctx, AV_LOG_ERROR, "illegal inter cbp\n"); - return -1; + return AVERROR_INVALIDDATA; } h->cbp = cbp_tab[cbp][1]; @@ -672,7 +672,7 @@ static int decode_mb_i(AVSContext *h, int cbp_code) pred_mode_uv = get_ue_golomb(gb); if (pred_mode_uv > 6) { av_log(h->avctx, AV_LOG_ERROR, "illegal intra chroma pred mode\n"); - return -1; + return AVERROR_INVALIDDATA; } ff_cavs_modify_mb_i(h, &pred_mode_uv); @@ -681,7 +681,7 @@ static int decode_mb_i(AVSContext *h, int cbp_code) cbp_code = get_ue_golomb(gb); if (cbp_code > 63U) { av_log(h->avctx, AV_LOG_ERROR, "illegal intra cbp\n"); - return -1; + return AVERROR_INVALIDDATA; } h->cbp = cbp_tab[cbp_code][0]; if (h->cbp && !h->qp_fixed) @@ -960,12 +960,12 @@ static int decode_pic(AVSContext *h) h->cur.f->pict_type = get_bits(&h->gb, 2) + AV_PICTURE_TYPE_I; if (h->cur.f->pict_type > AV_PICTURE_TYPE_B) { av_log(h->avctx, AV_LOG_ERROR, "illegal picture type\n"); - return -1; + return AVERROR_INVALIDDATA; } /* make sure we have the reference frames we need */ if (!h->DPB[0].f->data[0] || (!h->DPB[1].f->data[0] && h->cur.f->pict_type == AV_PICTURE_TYPE_B)) - return -1; + return AVERROR_INVALIDDATA; } else { h->cur.f->pict_type = AV_PICTURE_TYPE_I; if (get_bits1(&h->gb)) |