diff options
author | Paul B Mahol <onemda@gmail.com> | 2023-11-27 11:45:34 +0100 |
---|---|---|
committer | Paul B Mahol <onemda@gmail.com> | 2023-11-27 11:56:26 +0100 |
commit | b1942734c7cbcdc9034034373abcc9ecb9644c47 (patch) | |
tree | fb910c2e842e701742bde070a85a37013ed43b6b | |
parent | 4671fb7dfb8e72b228e04f3b81da7f2003c62240 (diff) | |
download | ffmpeg-b1942734c7cbcdc9034034373abcc9ecb9644c47.tar.gz |
avfilter/af_afwtdn: fix crash with EOF handling
-rw-r--r-- | libavfilter/af_afwtdn.c | 34 |
1 files changed, 19 insertions, 15 deletions
diff --git a/libavfilter/af_afwtdn.c b/libavfilter/af_afwtdn.c index 0fcfa779f9..63b7f5fc25 100644 --- a/libavfilter/af_afwtdn.c +++ b/libavfilter/af_afwtdn.c @@ -408,6 +408,7 @@ typedef struct AudioFWTDNContext { uint64_t sn; int64_t eof_pts; + int eof; int wavelet_type; int channels; @@ -1069,7 +1070,7 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in) s->drop_samples = 0; } else { if (s->padd_samples < 0 && eof) { - out->nb_samples += s->padd_samples; + out->nb_samples = FFMAX(0, out->nb_samples + s->padd_samples); s->padd_samples = 0; } if (!eof) @@ -1208,23 +1209,26 @@ static int activate(AVFilterContext *ctx) FF_FILTER_FORWARD_STATUS_BACK(outlink, inlink); - ret = ff_inlink_consume_samples(inlink, s->nb_samples, s->nb_samples, &in); - if (ret < 0) - return ret; - if (ret > 0) - return filter_frame(inlink, in); + if (!s->eof) { + ret = ff_inlink_consume_samples(inlink, s->nb_samples, s->nb_samples, &in); + if (ret < 0) + return ret; + if (ret > 0) + return filter_frame(inlink, in); + } if (ff_inlink_acknowledge_status(inlink, &status, &pts)) { - if (status == AVERROR_EOF) { - while (s->padd_samples != 0) { - ret = filter_frame(inlink, NULL); - if (ret < 0) - return ret; - } - ff_outlink_set_status(outlink, status, pts); - return ret; - } + if (status == AVERROR_EOF) + s->eof = 1; } + + if (s->eof && s->padd_samples != 0) { + return filter_frame(inlink, NULL); + } else if (s->eof) { + ff_outlink_set_status(outlink, AVERROR_EOF, s->eof_pts); + return 0; + } + FF_FILTER_FORWARD_WANTED(outlink, inlink); return FFERROR_NOT_READY; |