diff options
author | Paul B Mahol <onemda@gmail.com> | 2017-11-27 16:32:54 +0100 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2017-11-27 16:34:09 +0100 |
commit | 2d1594a8d6a754a426cb53184dccf9cf8c8a94b0 (patch) | |
tree | 753d3888cd48a9a77b0434f8061732cd4d712c1d | |
parent | b7324950c0fc84a93d4e7abdfd2b75ea647ec3fc (diff) | |
download | ffmpeg-2d1594a8d6a754a426cb53184dccf9cf8c8a94b0.tar.gz |
avfilter/af_silenceremove: fix possible crash if supplied duration is negative
Signed-off-by: Paul B Mahol <onemda@gmail.com>
-rw-r--r-- | libavfilter/af_silenceremove.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/libavfilter/af_silenceremove.c b/libavfilter/af_silenceremove.c index b9a9e13caf..d826a22e9d 100644 --- a/libavfilter/af_silenceremove.c +++ b/libavfilter/af_silenceremove.c @@ -186,8 +186,17 @@ static int config_input(AVFilterLink *inlink) s->start_duration = av_rescale(s->start_duration, inlink->sample_rate, AV_TIME_BASE); + if (s->start_duration < 0) { + av_log(ctx, AV_LOG_WARNING, "start duration must be non-negative\n"); + s->start_duration = -s->start_duration; + } + s->stop_duration = av_rescale(s->stop_duration, inlink->sample_rate, AV_TIME_BASE); + if (s->stop_duration < 0) { + av_log(ctx, AV_LOG_WARNING, "stop duration must be non-negative\n"); + s->stop_duration = -s->stop_duration; + } s->start_holdoff = av_malloc_array(FFMAX(s->start_duration, 1), sizeof(*s->start_holdoff) * |