aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michael@niedermayer.cc>2017-03-13 20:45:09 +0100
committerMichael Niedermayer <michael@niedermayer.cc>2017-05-17 20:35:19 +0200
commit6a70c38e397b4e90691f6ba7cf4c81067c7e1804 (patch)
treea38fa15feba9610b5222b606e415bf84fe1196fe
parent5e69ec6c2f886556483354dddd32f4332c78681d (diff)
downloadffmpeg-6a70c38e397b4e90691f6ba7cf4c81067c7e1804.tar.gz
avcodec/mpegaudiodec_template: Make l3_unscale() work with e=0
Fixes undefined behavior Fixes: 830/clusterfuzz-testcase-6253175327686656 Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/targets/ffmpeg Signed-off-by: Michael Niedermayer <michael@niedermayer.cc> (cherry picked from commit 8ebed703f153e979edb2156754c8bdac4d5d6266) Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
-rw-r--r--libavcodec/mpegaudiodec_template.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/libavcodec/mpegaudiodec_template.c b/libavcodec/mpegaudiodec_template.c
index 72f0613b7a..79ca97a8eb 100644
--- a/libavcodec/mpegaudiodec_template.c
+++ b/libavcodec/mpegaudiodec_template.c
@@ -252,7 +252,7 @@ static inline int l3_unscale(int value, int exponent)
#endif
if (e > 31)
return 0;
- m = (m + (1 << (e - 1))) >> e;
+ m = (m + ((1U << e)>>1)) >> e;
return m;
}