You've already forked FFmpeg
							
							
				mirror of
				https://github.com/FFmpeg/FFmpeg.git
				synced 2025-10-30 23:18:11 +02:00 
			
		
		
		
	avfilter/af_loudnorm: switch to activate
This commit is contained in:
		| @@ -22,6 +22,7 @@ | |||||||
|  |  | ||||||
| #include "libavutil/opt.h" | #include "libavutil/opt.h" | ||||||
| #include "avfilter.h" | #include "avfilter.h" | ||||||
|  | #include "filters.h" | ||||||
| #include "internal.h" | #include "internal.h" | ||||||
| #include "audio.h" | #include "audio.h" | ||||||
| #include "ebur128.h" | #include "ebur128.h" | ||||||
| @@ -502,9 +503,7 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in) | |||||||
|         ff_ebur128_add_frames_double(s->r128_out, dst, subframe_length); |         ff_ebur128_add_frames_double(s->r128_out, dst, subframe_length); | ||||||
|  |  | ||||||
|         s->pts += |         s->pts += | ||||||
|         out->nb_samples = |         out->nb_samples = subframe_length; | ||||||
|         inlink->min_samples = |  | ||||||
|         inlink->max_samples = subframe_length; |  | ||||||
|  |  | ||||||
|         s->frame_type = INNER_FRAME; |         s->frame_type = INNER_FRAME; | ||||||
|         break; |         break; | ||||||
| @@ -636,15 +635,14 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in) | |||||||
|     return ff_filter_frame(outlink, out); |     return ff_filter_frame(outlink, out); | ||||||
| } | } | ||||||
|  |  | ||||||
| static int request_frame(AVFilterLink *outlink) | static int flush_frame(AVFilterLink *outlink) | ||||||
| { | { | ||||||
|     int ret; |  | ||||||
|     AVFilterContext *ctx = outlink->src; |     AVFilterContext *ctx = outlink->src; | ||||||
|     AVFilterLink *inlink = ctx->inputs[0]; |     AVFilterLink *inlink = ctx->inputs[0]; | ||||||
|     LoudNormContext *s = ctx->priv; |     LoudNormContext *s = ctx->priv; | ||||||
|  |     int ret = 0; | ||||||
|  |  | ||||||
|     ret = ff_request_frame(inlink); |     if (s->frame_type == INNER_FRAME) { | ||||||
|     if (ret == AVERROR_EOF && s->frame_type == INNER_FRAME) { |  | ||||||
|         double *src; |         double *src; | ||||||
|         double *buf; |         double *buf; | ||||||
|         int nb_samples, n, c, offset; |         int nb_samples, n, c, offset; | ||||||
| @@ -681,6 +679,48 @@ static int request_frame(AVFilterLink *outlink) | |||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | static int activate(AVFilterContext *ctx) | ||||||
|  | { | ||||||
|  |     AVFilterLink *inlink = ctx->inputs[0]; | ||||||
|  |     AVFilterLink *outlink = ctx->outputs[0]; | ||||||
|  |     LoudNormContext *s = ctx->priv; | ||||||
|  |     AVFrame *in = NULL; | ||||||
|  |     int ret = 0, status; | ||||||
|  |     int64_t pts; | ||||||
|  |  | ||||||
|  |     FF_FILTER_FORWARD_STATUS_BACK(outlink, inlink); | ||||||
|  |  | ||||||
|  |     if (s->frame_type != LINEAR_MODE) { | ||||||
|  |         int nb_samples; | ||||||
|  |  | ||||||
|  |         if (s->frame_type == FIRST_FRAME) { | ||||||
|  |             nb_samples = frame_size(inlink->sample_rate, 3000); | ||||||
|  |         } else { | ||||||
|  |             nb_samples = frame_size(inlink->sample_rate, 100); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         ret = ff_inlink_consume_samples(inlink, nb_samples, nb_samples, &in); | ||||||
|  |     } else { | ||||||
|  |         ret = ff_inlink_consume_frame(inlink, &in); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     if (ret < 0) | ||||||
|  |         return ret; | ||||||
|  |     if (ret > 0) | ||||||
|  |         ret = filter_frame(inlink, in); | ||||||
|  |     if (ret < 0) | ||||||
|  |         return ret; | ||||||
|  |  | ||||||
|  |     if (ff_inlink_acknowledge_status(inlink, &status, &pts)) { | ||||||
|  |         ff_outlink_set_status(outlink, status, pts); | ||||||
|  |         return flush_frame(outlink); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     FF_FILTER_FORWARD_WANTED(outlink, inlink); | ||||||
|  |  | ||||||
|  |     return FFERROR_NOT_READY; | ||||||
|  | } | ||||||
|  |  | ||||||
| static int query_formats(AVFilterContext *ctx) | static int query_formats(AVFilterContext *ctx) | ||||||
| { | { | ||||||
|     LoudNormContext *s = ctx->priv; |     LoudNormContext *s = ctx->priv; | ||||||
| @@ -749,11 +789,6 @@ static int config_input(AVFilterLink *inlink) | |||||||
|  |  | ||||||
|     init_gaussian_filter(s); |     init_gaussian_filter(s); | ||||||
|  |  | ||||||
|     if (s->frame_type != LINEAR_MODE) { |  | ||||||
|         inlink->min_samples = |  | ||||||
|         inlink->max_samples = frame_size(inlink->sample_rate, 3000); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     s->pts = AV_NOPTS_VALUE; |     s->pts = AV_NOPTS_VALUE; | ||||||
|     s->buf_index = |     s->buf_index = | ||||||
|     s->prev_buf_index = |     s->prev_buf_index = | ||||||
| @@ -894,14 +929,12 @@ static const AVFilterPad avfilter_af_loudnorm_inputs[] = { | |||||||
|         .name         = "default", |         .name         = "default", | ||||||
|         .type         = AVMEDIA_TYPE_AUDIO, |         .type         = AVMEDIA_TYPE_AUDIO, | ||||||
|         .config_props = config_input, |         .config_props = config_input, | ||||||
|         .filter_frame = filter_frame, |  | ||||||
|     }, |     }, | ||||||
| }; | }; | ||||||
|  |  | ||||||
| static const AVFilterPad avfilter_af_loudnorm_outputs[] = { | static const AVFilterPad avfilter_af_loudnorm_outputs[] = { | ||||||
|     { |     { | ||||||
|         .name          = "default", |         .name          = "default", | ||||||
|         .request_frame = request_frame, |  | ||||||
|         .type          = AVMEDIA_TYPE_AUDIO, |         .type          = AVMEDIA_TYPE_AUDIO, | ||||||
|     }, |     }, | ||||||
| }; | }; | ||||||
| @@ -912,6 +945,7 @@ const AVFilter ff_af_loudnorm = { | |||||||
|     .priv_size     = sizeof(LoudNormContext), |     .priv_size     = sizeof(LoudNormContext), | ||||||
|     .priv_class    = &loudnorm_class, |     .priv_class    = &loudnorm_class, | ||||||
|     .init          = init, |     .init          = init, | ||||||
|  |     .activate      = activate, | ||||||
|     .uninit        = uninit, |     .uninit        = uninit, | ||||||
|     FILTER_INPUTS(avfilter_af_loudnorm_inputs), |     FILTER_INPUTS(avfilter_af_loudnorm_inputs), | ||||||
|     FILTER_OUTPUTS(avfilter_af_loudnorm_outputs), |     FILTER_OUTPUTS(avfilter_af_loudnorm_outputs), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user