mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-01-11 18:09:36 +00:00
avfilter/vf_signalstats: Use 64bit for processing histogram
The result might not fit into 32bit if an image has gigantic dimensions and one of the planes has a dominant value (particularly so if said value is big). Fixes Coverity issues #1598399, #1598401, #1598402, #1598403, #1598404. Signed-off-by: Andreas Rheinhardt <andreas.rheinhardt@outlook.com>
This commit is contained in:
parent
4008a80c1b
commit
dfd0320e23
@ -721,10 +721,10 @@ static int filter_frame(AVFilterLink *link, AVFrame *in)
|
|||||||
if (histv[fil]) maxv = fil;
|
if (histv[fil]) maxv = fil;
|
||||||
if (histsat[fil]) maxsat = fil;
|
if (histsat[fil]) maxsat = fil;
|
||||||
|
|
||||||
toty += histy[fil] * fil;
|
toty += (uint64_t)histy[fil] * fil;
|
||||||
totu += histu[fil] * fil;
|
totu += (uint64_t)histu[fil] * fil;
|
||||||
totv += histv[fil] * fil;
|
totv += (uint64_t)histv[fil] * fil;
|
||||||
totsat += histsat[fil] * fil;
|
totsat += (uint64_t)histsat[fil] * fil;
|
||||||
|
|
||||||
accy += histy[fil];
|
accy += histy[fil];
|
||||||
accu += histu[fil];
|
accu += histu[fil];
|
||||||
@ -745,7 +745,7 @@ static int filter_frame(AVFilterLink *link, AVFrame *in)
|
|||||||
maxhue = histhue[0];
|
maxhue = histhue[0];
|
||||||
medhue = -1;
|
medhue = -1;
|
||||||
for (fil = 0; fil < 360; fil++) {
|
for (fil = 0; fil < 360; fil++) {
|
||||||
tothue += histhue[fil] * fil;
|
tothue += (uint64_t)histhue[fil] * fil;
|
||||||
acchue += histhue[fil];
|
acchue += histhue[fil];
|
||||||
|
|
||||||
if (medhue == -1 && acchue > s->cfs / 2)
|
if (medhue == -1 && acchue > s->cfs / 2)
|
||||||
|
Loading…
Reference in New Issue
Block a user