[FFmpeg-devel] [PATCH] avfilter/af_afade: remove fade duration limit
realies
ffmpeg at reali.es
Fri Apr 30 06:36:48 EEST 2021
On Thu, Apr 29, 2021 at 2:49 AM realies <ffmpeg at reali.es> wrote:
>
> From 8a4fe250e508932d8018adbb1af95d7c4a599a58 Mon Sep 17 00:00:00 2001
> From: realies <ffmpeg at reali.es>
> Date: Fri, 9 Apr 2021 21:57:47 +0100
> Subject: [PATCH] avfilter/af_afade: remove fade duration limit
>
> Removes arbitrary filter duration to allow fades up to the limit
> of available memory. A docs warning has been added noting memory
> use & potential delay with large fade durations on some muxer
> configurations.
> ---
> doc/filters.texi | 3 +++
> libavfilter/af_afade.c | 4 ++--
> 2 files changed, 5 insertions(+), 2 deletions(-)
>
> diff --git a/doc/filters.texi b/doc/filters.texi
> index 5e35fa6467..05ac14f30c 100644
> --- a/doc/filters.texi
> +++ b/doc/filters.texi
> @@ -1146,6 +1146,9 @@ no fade applied
> @end table
> @end table
>
> +Warning: This filter requires memory to buffer the fade duration. Some
> +muxer configurations can cause delays with large fade durations.
> +
> @subsection Commands
>
> This filter supports the all above options as @ref{commands}.
> diff --git a/libavfilter/af_afade.c b/libavfilter/af_afade.c
> index 976b6752cd..23ece37774 100644
> --- a/libavfilter/af_afade.c
> +++ b/libavfilter/af_afade.c
> @@ -385,8 +385,8 @@ AVFilter ff_af_afade = {
> static const AVOption acrossfade_options[] = {
> { "nb_samples", "set number of samples for cross fade
> duration", OFFSET(nb_samples), AV_OPT_TYPE_INT, {.i64 = 44100},
> 1, INT32_MAX/10, FLAGS },
> { "ns", "set number of samples for cross fade
> duration", OFFSET(nb_samples), AV_OPT_TYPE_INT, {.i64 = 44100},
> 1, INT32_MAX/10, FLAGS },
> - { "duration", "set cross fade duration",
> OFFSET(duration), AV_OPT_TYPE_DURATION, {.i64 = 0 }, 0,
> 60000000, FLAGS },
> - { "d", "set cross fade duration",
> OFFSET(duration), AV_OPT_TYPE_DURATION, {.i64 = 0 }, 0,
> 60000000, FLAGS },
> + { "duration", "set cross fade duration",
> OFFSET(duration), AV_OPT_TYPE_DURATION, {.i64 = 0 }, 0, INT_MAX,
> FLAGS },
> + { "d", "set cross fade duration",
> OFFSET(duration), AV_OPT_TYPE_DURATION, {.i64 = 0 }, 0, INT_MAX,
> FLAGS },
> { "overlap", "overlap 1st stream end with 2nd stream start",
> OFFSET(overlap), AV_OPT_TYPE_BOOL, {.i64 = 1 }, 0, 1,
> FLAGS },
> { "o", "overlap 1st stream end with 2nd stream start",
> OFFSET(overlap), AV_OPT_TYPE_BOOL, {.i64 = 1 }, 0, 1,
> FLAGS },
> { "curve1", "set fade curve type for 1st stream",
> OFFSET(curve), AV_OPT_TYPE_INT, {.i64 = TRI }, NONE,
> NB_CURVES - 1, FLAGS, "curve" },
> --
> 2.25.1
-------------- next part --------------
A non-text attachment was scrubbed...
Name: 0001-avfilter-af_afade-remove-fade-duration-limit.patch
Type: application/octet-stream
Size: 2592 bytes
Desc: not available
URL: <https://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20210430/cf563df0/attachment.obj>
More information about the ffmpeg-devel
mailing list