avfilter/af_aresample: split flushing code out
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
		
							parent
							
								
									e4f8a973aa
								
							
						
					
					
						commit
						97da68172a
					
				@ -223,6 +223,37 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *insamplesref)
 | 
				
			|||||||
    return ret;
 | 
					    return ret;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					static int flush_frame(AVFilterLink *outlink, int final, AVFrame **outsamplesref_ret)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    AVFilterContext *ctx = outlink->src;
 | 
				
			||||||
 | 
					    AResampleContext *aresample = ctx->priv;
 | 
				
			||||||
 | 
					    AVFilterLink *const inlink = outlink->src->inputs[0];
 | 
				
			||||||
 | 
					    AVFrame *outsamplesref;
 | 
				
			||||||
 | 
					    int n_out = 4096;
 | 
				
			||||||
 | 
					    int64_t pts;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    outsamplesref = ff_get_audio_buffer(outlink, n_out);
 | 
				
			||||||
 | 
					    *outsamplesref_ret = outsamplesref;
 | 
				
			||||||
 | 
					    if (!outsamplesref)
 | 
				
			||||||
 | 
					        return AVERROR(ENOMEM);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    pts = swr_next_pts(aresample->swr, INT64_MIN);
 | 
				
			||||||
 | 
					    pts = ROUNDED_DIV(pts, inlink->sample_rate);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    n_out = swr_convert(aresample->swr, outsamplesref->extended_data, n_out, final ? NULL : (void*)outsamplesref->extended_data, 0);
 | 
				
			||||||
 | 
					    if (n_out <= 0) {
 | 
				
			||||||
 | 
					        av_frame_free(&outsamplesref);
 | 
				
			||||||
 | 
					        return (n_out == 0) ? AVERROR_EOF : n_out;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    outsamplesref->sample_rate = outlink->sample_rate;
 | 
				
			||||||
 | 
					    outsamplesref->nb_samples  = n_out;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    outsamplesref->pts = pts;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return 0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
static int request_frame(AVFilterLink *outlink)
 | 
					static int request_frame(AVFilterLink *outlink)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    AVFilterContext *ctx = outlink->src;
 | 
					    AVFilterContext *ctx = outlink->src;
 | 
				
			||||||
@ -237,26 +268,9 @@ static int request_frame(AVFilterLink *outlink)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    if (ret == AVERROR_EOF) {
 | 
					    if (ret == AVERROR_EOF) {
 | 
				
			||||||
        AVFrame *outsamplesref;
 | 
					        AVFrame *outsamplesref;
 | 
				
			||||||
        int n_out = 4096;
 | 
					 | 
				
			||||||
        int64_t pts;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        outsamplesref = ff_get_audio_buffer(outlink, n_out);
 | 
					        if ((ret = flush_frame(outlink, 1, &outsamplesref)) < 0)
 | 
				
			||||||
        if (!outsamplesref)
 | 
					            return ret;
 | 
				
			||||||
            return AVERROR(ENOMEM);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        pts = swr_next_pts(aresample->swr, INT64_MIN);
 | 
					 | 
				
			||||||
        pts = ROUNDED_DIV(pts, inlink->sample_rate);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        n_out = swr_convert(aresample->swr, outsamplesref->extended_data, n_out, 0, 0);
 | 
					 | 
				
			||||||
        if (n_out <= 0) {
 | 
					 | 
				
			||||||
            av_frame_free(&outsamplesref);
 | 
					 | 
				
			||||||
            return (n_out == 0) ? AVERROR_EOF : n_out;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        outsamplesref->sample_rate = outlink->sample_rate;
 | 
					 | 
				
			||||||
        outsamplesref->nb_samples  = n_out;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        outsamplesref->pts = pts;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        return ff_filter_frame(outlink, outsamplesref);
 | 
					        return ff_filter_frame(outlink, outsamplesref);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user