const snd_config_t *rate_converter;
enum snd_pcm_plug_route_policy route_policy;
snd_pcm_route_ttable_entry_t *ttable;
- int ttable_ok, ttable_last;
+ int ttable_ok;
unsigned int tt_ssize, tt_cused, tt_sused;
} snd_pcm_plug_t;
snd_pcm_route_ttable_entry_t *ttable;
int err;
if (clt->channels == slv->channels &&
- (!plug->ttable || !plug->ttable_last))
+ (!plug->ttable || plug->ttable_ok))
return 0;
if (clt->rate != slv->rate &&
clt->channels > slv->channels)
/* No conversion is needed */
if (clt->format == slv->format &&
clt->rate == slv->rate &&
- clt->channels == slv->channels)
+ clt->channels == slv->channels &&
+ (!plug->ttable || plug->ttable_ok))
return 0;
if (snd_pcm_format_linear(slv->format)) {
/* Conversion is done in another plugin */
if (clt->rate != slv->rate ||
- clt->channels != slv->channels)
+ clt->channels != slv->channels ||
+ (plug->ttable && !plug->ttable_ok))
return 0;
cfmt = clt->format;
switch (clt->format) {
if (snd_pcm_format_linear(clt->format)) {
cfmt = clt->format;
f = snd_pcm_lfloat_open;
- } else if (clt->rate != slv->rate || clt->channels != slv->channels) {
+ } else if (clt->rate != slv->rate || clt->channels != slv->channels ||
+ (plug->ttable && !plug->ttable_ok)) {
cfmt = SND_PCM_FORMAT_S16;
f = snd_pcm_lfloat_open;
} else
};
snd_pcm_plug_params_t p = *slave;
unsigned int k = 0;
- plug->ttable_ok = plug->ttable_last = 0;
+ plug->ttable_ok = 0;
while (client->format != p.format ||
client->channels != p.channels ||
client->rate != p.rate ||
- client->access != p.access) {
+ client->access != p.access ||
+ (plug->ttable && !plug->ttable_ok)) {
snd_pcm_t *new;
int err;
if (k >= sizeof(funcs)/sizeof(*funcs))
}
k++;
}
-#ifdef BUILD_PCM_PLUGIN_ROUTE
- /* it's exception, user specified ttable, but no reduction/expand */
- if (plug->ttable && !plug->ttable_ok) {
- snd_pcm_t *new;
- int err;
- plug->ttable_last = 1;
- err = snd_pcm_plug_change_channels(pcm, &new, client, &p);
- if (err < 0) {
- snd_pcm_plug_clear(pcm);
- return err;
- }
- assert(err);
- assert(plug->ttable_ok);
- plug->gen.slave = new;
- pcm->fast_ops = new->fast_ops;
- pcm->fast_op_arg = new->fast_op_arg;
- }
-#endif
return 0;
}