diff options
author | Michael Niedermayer <michael@niedermayer.cc> | 2018-12-27 02:21:00 +0100 |
---|---|---|
committer | Michael Niedermayer <michael@niedermayer.cc> | 2018-12-31 17:44:23 +0100 |
commit | 609e2e64f6e0b348ce861ccd8d17c7a7651b9157 (patch) | |
tree | 0cd2aeda1387f7b08bc5aec1fe0db9e17d1d7a8e | |
parent | b6c2c589041cd99c5bf4117d13708ab010f97bd1 (diff) | |
download | ffmpeg-609e2e64f6e0b348ce861ccd8d17c7a7651b9157.tar.gz |
avcodec/scpr: Use local variables in decode_run_i()
This improves the speed of decode_run_i()
Before: clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_SCPR_fuzzer-5656821117747200 in 17420 ms
After: clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_SCPR_fuzzer-5656821117747200 in 14018 ms
Improves: 11270/clusterfuzz-testcase-minimized-ffmpeg_AV_CODEC_ID_SCPR_fuzzer-5656821117747200
Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/projects/ffmpeg
Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
-rw-r--r-- | libavcodec/scpr.h | 125 |
1 files changed, 67 insertions, 58 deletions
diff --git a/libavcodec/scpr.h b/libavcodec/scpr.h index a013d7e600..bb9b4d6a9b 100644 --- a/libavcodec/scpr.h +++ b/libavcodec/scpr.h @@ -78,58 +78,62 @@ typedef struct SCPRContext { } SCPRContext; static int decode_run_i(AVCodecContext *avctx, uint32_t ptype, int run, - int *x, int *y, uint32_t clr, uint32_t *dst, - int linesize, uint32_t *lx, uint32_t *ly, + int *px, int *py, uint32_t clr, uint32_t *dst, + int linesize, uint32_t *plx, uint32_t *ply, uint32_t backstep, int off, int *cx, int *cx1) { uint32_t r, g, b; int z; + int x = *px, + y = *py; + uint32_t lx = *plx, + ly = *ply; switch (ptype) { case 0: while (run-- > 0) { - if (*y >= avctx->height) + if (y >= avctx->height) return AVERROR_INVALIDDATA; - dst[*y * linesize + *x] = clr; - *lx = *x; - *ly = *y; - (*x)++; - if (*x >= avctx->width) { - *x = 0; - (*y)++; + dst[y * linesize + x] = clr; + lx = x; + ly = y; + (x)++; + if (x >= avctx->width) { + x = 0; + (y)++; } } break; case 1: while (run-- > 0) { - if (*y >= avctx->height) + if (y >= avctx->height) return AVERROR_INVALIDDATA; - dst[*y * linesize + *x] = dst[*ly * linesize + *lx]; - *lx = *x; - *ly = *y; - (*x)++; - if (*x >= avctx->width) { - *x = 0; - (*y)++; + dst[y * linesize + x] = dst[ly * linesize + lx]; + lx = x; + ly = y; + (x)++; + if (x >= avctx->width) { + x = 0; + (y)++; } } - clr = dst[*ly * linesize + *lx]; + clr = dst[ly * linesize + lx]; break; case 2: while (run-- > 0) { - if (*y < 1 || *y >= avctx->height) + if (y < 1 || y >= avctx->height) return AVERROR_INVALIDDATA; - clr = dst[*y * linesize + *x + off + 1]; - dst[*y * linesize + *x] = clr; - *lx = *x; - *ly = *y; - (*x)++; - if (*x >= avctx->width) { - *x = 0; - (*y)++; + clr = dst[y * linesize + x + off + 1]; + dst[y * linesize + x] = clr; + lx = x; + ly = y; + (x)++; + if (x >= avctx->width) { + x = 0; + (y)++; } } break; @@ -137,61 +141,66 @@ static int decode_run_i(AVCodecContext *avctx, uint32_t ptype, int run, while (run-- > 0) { uint8_t *odst = (uint8_t *)dst; - if (*y < 1 || *y >= avctx->height || - (*y == 1 && *x == 0)) + if (y < 1 || y >= avctx->height || + (y == 1 && x == 0)) return AVERROR_INVALIDDATA; - if (*x == 0) { + if (x == 0) { z = backstep; } else { z = 0; } - r = odst[(*ly * linesize + *lx) * 4] + - odst[((*y * linesize + *x) + off) * 4 + 4] - - odst[((*y * linesize + *x) + off - z) * 4]; - g = odst[(*ly * linesize + *lx) * 4 + 1] + - odst[((*y * linesize + *x) + off) * 4 + 5] - - odst[((*y * linesize + *x) + off - z) * 4 + 1]; - b = odst[(*ly * linesize + *lx) * 4 + 2] + - odst[((*y * linesize + *x) + off) * 4 + 6] - - odst[((*y * linesize + *x) + off - z) * 4 + 2]; + r = odst[(ly * linesize + lx) * 4] + + odst[((y * linesize + x) + off) * 4 + 4] - + odst[((y * linesize + x) + off - z) * 4]; + g = odst[(ly * linesize + lx) * 4 + 1] + + odst[((y * linesize + x) + off) * 4 + 5] - + odst[((y * linesize + x) + off - z) * 4 + 1]; + b = odst[(ly * linesize + lx) * 4 + 2] + + odst[((y * linesize + x) + off) * 4 + 6] - + odst[((y * linesize + x) + off - z) * 4 + 2]; clr = ((b & 0xFF) << 16) + ((g & 0xFF) << 8) + (r & 0xFF); - dst[*y * linesize + *x] = clr; - *lx = *x; - *ly = *y; - (*x)++; - if (*x >= avctx->width) { - *x = 0; - (*y)++; + dst[y * linesize + x] = clr; + lx = x; + ly = y; + (x)++; + if (x >= avctx->width) { + x = 0; + (y)++; } } break; case 5: while (run-- > 0) { - if (*y < 1 || *y >= avctx->height || - (*y == 1 && *x == 0)) + if (y < 1 || y >= avctx->height || + (y == 1 && x == 0)) return AVERROR_INVALIDDATA; - if (*x == 0) { + if (x == 0) { z = backstep; } else { z = 0; } - clr = dst[*y * linesize + *x + off - z]; - dst[*y * linesize + *x] = clr; - *lx = *x; - *ly = *y; - (*x)++; - if (*x >= avctx->width) { - *x = 0; - (*y)++; + clr = dst[y * linesize + x + off - z]; + dst[y * linesize + x] = clr; + lx = x; + ly = y; + (x)++; + if (x >= avctx->width) { + x = 0; + (y)++; } } break; } + *px = x; + *py = y; + *plx= lx; + *ply= ly; + if (avctx->bits_per_coded_sample == 16) { *cx1 = (clr & 0x3F00) >> 2; *cx = (clr & 0x3FFFFF) >> 16; |