Commit fdd2b7b1 authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

aout: remove the old rate kludge to probe resamplers

parent 140ca2a5
...@@ -42,44 +42,43 @@ ...@@ -42,44 +42,43 @@
#include <libvlc.h> #include <libvlc.h>
#include "aout_internal.h" #include "aout_internal.h"
/***************************************************************************** static filter_t *FindFilter (vlc_object_t *obj, const char *type,
* FindFilter: find an audio filter for a specific transformation const char *name,
*****************************************************************************/
static filter_t * FindFilter( vlc_object_t *obj,
const audio_sample_format_t *infmt, const audio_sample_format_t *infmt,
const audio_sample_format_t *outfmt ) const audio_sample_format_t *outfmt)
{ {
static const char typename[] = "audio converter"; filter_t *filter = vlc_custom_create (obj, sizeof (*filter), type);
const char *type = "audio converter", *name = NULL; if (unlikely(filter == NULL))
filter_t * p_filter; return NULL;
p_filter = vlc_custom_create( obj, sizeof(*p_filter), typename );
if ( p_filter == NULL ) return NULL;
p_filter->fmt_in.audio = *infmt;
p_filter->fmt_in.i_codec = infmt->i_format;
p_filter->fmt_out.audio = *outfmt;
p_filter->fmt_out.i_codec = outfmt->i_format;
if( infmt->i_format == outfmt->i_format filter->fmt_in.audio = *infmt;
&& infmt->i_physical_channels == outfmt->i_physical_channels filter->fmt_in.i_codec = infmt->i_format;
&& infmt->i_original_channels == outfmt->i_original_channels ) filter->fmt_out.audio = *outfmt;
filter->fmt_out.i_codec = outfmt->i_format;
filter->p_module = module_need (filter, type, name, false);
if (filter->p_module == NULL)
{ {
assert( infmt->i_rate != outfmt->i_rate ); vlc_object_release (filter);
type = "audio resampler"; filter = NULL;
name = "$audio-resampler";
} }
else
assert (filter->pf_audio_filter != NULL);
return filter;
}
p_filter->p_module = module_need( p_filter, type, name, false ); static filter_t *FindConverter (vlc_object_t *obj,
if ( p_filter->p_module == NULL ) const audio_sample_format_t *infmt,
{ const audio_sample_format_t *outfmt)
vlc_object_release( p_filter ); {
return NULL; return FindFilter (obj, "audio converter", NULL, infmt, outfmt);
} }
assert( p_filter->pf_audio_filter ); static filter_t *FindResampler (vlc_object_t *obj,
return p_filter; const audio_sample_format_t *infmt,
const audio_sample_format_t *outfmt)
{
return FindFilter (obj, "audio resampler", "$audio-resampler",
infmt, outfmt);
} }
/** /**
...@@ -105,7 +104,7 @@ static filter_t *TryFormat (vlc_object_t *obj, vlc_fourcc_t codec, ...@@ -105,7 +104,7 @@ static filter_t *TryFormat (vlc_object_t *obj, vlc_fourcc_t codec,
output.i_format = codec; output.i_format = codec;
aout_FormatPrepare (&output); aout_FormatPrepare (&output);
filter_t *filter = FindFilter (obj, fmt, &output); filter_t *filter = FindConverter (obj, fmt, &output);
if (filter != NULL) if (filter != NULL)
*fmt = output; *fmt = output;
return filter; return filter;
...@@ -213,7 +212,7 @@ static int aout_FiltersPipelineCreate(vlc_object_t *obj, filter_t **filters, ...@@ -213,7 +212,7 @@ static int aout_FiltersPipelineCreate(vlc_object_t *obj, filter_t **filters,
output.i_original_channels = outfmt->i_original_channels; output.i_original_channels = outfmt->i_original_channels;
aout_FormatPrepare (&output); aout_FormatPrepare (&output);
filter_t *f = FindFilter (obj, &input, &output); filter_t *f = FindConverter (obj, &input, &output);
if (f == NULL) if (f == NULL)
{ {
msg_Err (obj, "cannot find %s for conversion pipeline", msg_Err (obj, "cannot find %s for conversion pipeline",
...@@ -234,7 +233,7 @@ static int aout_FiltersPipelineCreate(vlc_object_t *obj, filter_t **filters, ...@@ -234,7 +233,7 @@ static int aout_FiltersPipelineCreate(vlc_object_t *obj, filter_t **filters,
audio_sample_format_t output = input; audio_sample_format_t output = input;
output.i_rate = outfmt->i_rate; output.i_rate = outfmt->i_rate;
filter_t *f = FindFilter (obj, &input, &output); filter_t *f = FindConverter (obj, &input, &output);
if (f == NULL) if (f == NULL)
{ {
msg_Err (obj, "cannot find %s for conversion pipeline", msg_Err (obj, "cannot find %s for conversion pipeline",
...@@ -573,20 +572,13 @@ int aout_FiltersNew (audio_output_t *aout, ...@@ -573,20 +572,13 @@ int aout_FiltersNew (audio_output_t *aout,
/* insert the resampler */ /* insert the resampler */
output_format.i_rate = outfmt->i_rate; output_format.i_rate = outfmt->i_rate;
assert (AOUT_FMTS_IDENTICAL(&output_format, outfmt)); assert (AOUT_FMTS_IDENTICAL(&output_format, outfmt));
owner->resampler = FindResampler (VLC_OBJECT(aout), &input_format,
unsigned rate_bak = input_format.i_rate;
if (output_format.i_rate == input_format.i_rate)
/* For historical reasons, a different rate is required to probe
* resampling filters. */
input_format.i_rate++;
owner->resampler = FindFilter (VLC_OBJECT(aout), &input_format,
&output_format); &output_format);
if (owner->resampler == NULL) if (owner->resampler == NULL)
{ {
msg_Err (aout, "cannot setup a resampler"); msg_Err (aout, "cannot setup a resampler");
goto error; goto error;
} }
owner->resampler->fmt_in.audio.i_rate = rate_bak;
if (owner->rate_filter == NULL) if (owner->rate_filter == NULL)
owner->rate_filter = owner->resampler; owner->rate_filter = owner->resampler;
owner->resampling = 0; owner->resampling = 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment