[FFmpeg-cvslog] mpeg12dec: Refactor mpeg1_decode_block_intra()
Diego Biurrun
git at videolan.org
Tue Feb 16 20:06:27 CET 2016
ffmpeg | branch: master | Diego Biurrun <diego at biurrun.de> | Sat Feb 6 18:02:47 2016 +0100| [249827f736db4c94dfcb24a3883aa4c04f9b119b] | committer: Diego Biurrun
mpeg12dec: Refactor mpeg1_decode_block_intra()
Reduce variable scope, improve variable name, drop pointless ff_dlog(),
merge variable declaration and initialization, whitespace cosmetics.
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=249827f736db4c94dfcb24a3883aa4c04f9b119b
---
libavcodec/mpeg12dec.c | 29 ++++++++++++++++++-----------
1 file changed, 18 insertions(+), 11 deletions(-)
diff --git a/libavcodec/mpeg12dec.c b/libavcodec/mpeg12dec.c
index 882fdf3..2a88756 100644
--- a/libavcodec/mpeg12dec.c
+++ b/libavcodec/mpeg12dec.c
@@ -139,30 +139,33 @@ static int mpeg_decode_motion(MpegEncContext *s, int fcode, int pred)
} while (0)
static inline int mpeg1_decode_block_intra(MpegEncContext *s,
- int16_t *block, int n)
+ int16_t *block, int index)
{
- int level, dc, diff, i, j, run;
- int component;
- RLTable *rl = &ff_rl_mpeg1;
+ int dc, diff, i = 0, component;
+ RLTable *rl = &ff_rl_mpeg1;
uint8_t *const scantable = s->intra_scantable.permutated;
const uint16_t *quant_matrix = s->intra_matrix;
const int qscale = s->qscale;
/* DC coefficient */
- component = (n <= 3 ? 0 : n - 4 + 1);
+ component = index <= 3 ? 0 : index - 4 + 1;
+
diff = decode_dc(&s->gb, component);
if (diff >= 0xffff)
return AVERROR_INVALIDDATA;
+
dc = s->last_dc[component];
dc += diff;
s->last_dc[component] = dc;
+
block[0] = dc * quant_matrix[0];
- ff_dlog(s->avctx, "dc=%d diff=%d\n", dc, diff);
- i = 0;
+
{
OPEN_READER(re, &s->gb);
/* now quantify & encode AC coefficients */
- for (;;) {
+ while (1) {
+ int level, run, j;
+
UPDATE_CACHE(re, &s->gb);
GET_RL_VLC(level, run, re, &s->gb, rl->rl_vlc[0],
TEX_VLC_BITS, 2, 0);
@@ -173,6 +176,7 @@ static inline int mpeg1_decode_block_intra(MpegEncContext *s,
i += run;
if (i > MAX_INDEX)
break;
+
j = scantable[i];
level = (level * qscale * quant_matrix[j]) >> 4;
level = (level - 1) | 1;
@@ -186,6 +190,7 @@ static inline int mpeg1_decode_block_intra(MpegEncContext *s,
UPDATE_CACHE(re, &s->gb);
level = SHOW_SBITS(re, &s->gb, 8);
SKIP_BITS(re, &s->gb, 8);
+
if (level == -128) {
level = SHOW_UBITS(re, &s->gb, 8) - 256;
LAST_SKIP_BITS(re, &s->gb, 8);
@@ -193,9 +198,11 @@ static inline int mpeg1_decode_block_intra(MpegEncContext *s,
level = SHOW_UBITS(re, &s->gb, 8);
LAST_SKIP_BITS(re, &s->gb, 8);
}
+
i += run;
if (i > MAX_INDEX)
break;
+
j = scantable[i];
if (level < 0) {
level = -level;
@@ -215,13 +222,13 @@ static inline int mpeg1_decode_block_intra(MpegEncContext *s,
check_scantable_index(s, i);
- s->block_last_index[n] = i;
+ s->block_last_index[index] = i;
return 0;
}
-int ff_mpeg1_decode_block_intra(MpegEncContext *s, int16_t *block, int n)
+int ff_mpeg1_decode_block_intra(MpegEncContext *s, int16_t *block, int index)
{
- return mpeg1_decode_block_intra(s, block, n);
+ return mpeg1_decode_block_intra(s, block, index);
}
static inline int mpeg1_decode_block_inter(MpegEncContext *s,
More information about the ffmpeg-cvslog
mailing list