[FFmpeg-cvslog] avfilter/vf_paletteuse: Fix left shift outside of range of int

Andreas Rheinhardt git at videolan.org
Sat Apr 3 01:18:20 EEST 2021


ffmpeg | branch: release/4.4 | Andreas Rheinhardt <andreas.rheinhardt at gmail.com> | Wed Jan 22 01:47:21 2020 +0100| [28dd12c9b7518adc2bda4ca980603504b32298cf] | committer: Andreas Rheinhardt

avfilter/vf_paletteuse: Fix left shift outside of range of int

by keeping the variable uint32_t which in this situation is the natural
type anyway. This affected the FATE-test filter-paletteuse-sierra2_4a.

Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt at gmail.com>
(cherry picked from commit 797c2ecc8fca65721b79637073df0a31fe31c463)

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=28dd12c9b7518adc2bda4ca980603504b32298cf
---

 libavfilter/vf_paletteuse.c | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/libavfilter/vf_paletteuse.c b/libavfilter/vf_paletteuse.c
index fc07c2581d..f4c7d60435 100644
--- a/libavfilter/vf_paletteuse.c
+++ b/libavfilter/vf_paletteuse.c
@@ -152,9 +152,10 @@ static int query_formats(AVFilterContext *ctx)
     return 0;
 }
 
-static av_always_inline int dither_color(uint32_t px, int er, int eg, int eb, int scale, int shift)
+static av_always_inline uint32_t dither_color(uint32_t px, int er, int eg,
+                                              int eb, int scale, int shift)
 {
-    return av_clip_uint8( px >> 24                                      ) << 24
+    return                px >> 24                                        << 24
          | av_clip_uint8((px >> 16 & 0xff) + ((er * scale) / (1<<shift))) << 16
          | av_clip_uint8((px >>  8 & 0xff) + ((eg * scale) / (1<<shift))) <<  8
          | av_clip_uint8((px       & 0xff) + ((eb * scale) / (1<<shift)));



More information about the ffmpeg-cvslog mailing list