From b2c0b80f62912f932cc3bb04621408601a9ed4d5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20B=C5=93sch?= Date: Sat, 6 Sep 2014 13:47:59 +0200 Subject: [PATCH] avfilter/ebur128: rework channel weighting definition code Should fix CID1194399 (Bad bit shift operation) --- libavfilter/f_ebur128.c | 14 +++----------- 1 file changed, 3 insertions(+), 11 deletions(-) diff --git a/libavfilter/f_ebur128.c b/libavfilter/f_ebur128.c index a02cf28723..c18ae79915 100644 --- a/libavfilter/f_ebur128.c +++ b/libavfilter/f_ebur128.c @@ -363,7 +363,6 @@ static int config_audio_input(AVFilterLink *inlink) static int config_audio_output(AVFilterLink *outlink) { int i; - int idx_bitposn = 0; AVFilterContext *ctx = outlink->src; EBUR128Context *ebur128 = ctx->priv; const int nb_channels = av_get_channel_layout_nb_channels(outlink->channel_layout); @@ -379,23 +378,16 @@ static int config_audio_output(AVFilterLink *outlink) return AVERROR(ENOMEM); for (i = 0; i < nb_channels; i++) { - - /* find the next bit that is set starting from the right */ - while ((outlink->channel_layout & 1ULL<channel_layout, i); + if (chl & (AV_CH_LOW_FREQUENCY|AV_CH_LOW_FREQUENCY_2)) { ebur128->ch_weighting[i] = 0; - } else if (1ULL<ch_weighting[i] = 1.41; } else { ebur128->ch_weighting[i] = 1.0; } - idx_bitposn++; - if (!ebur128->ch_weighting[i]) continue;