mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-03 09:01:54 -05:00
filter-chain: simplify plugin API some more
This commit is contained in:
parent
48136b4c2b
commit
a2aaa71392
4 changed files with 41 additions and 107 deletions
|
|
@ -318,7 +318,7 @@ done:
|
|||
static float get_default(struct impl *impl, struct descriptor *desc, uint32_t p)
|
||||
{
|
||||
struct fc_port *port = &desc->desc->ports[p];
|
||||
return port->get_param(port, "default");
|
||||
return port->def;
|
||||
}
|
||||
|
||||
static struct node *find_node(struct graph *graph, const char *name)
|
||||
|
|
@ -388,13 +388,8 @@ static struct spa_pod *get_prop_info(struct graph *graph, struct spa_pod_builder
|
|||
struct descriptor *desc = node->desc;
|
||||
const struct fc_descriptor *d = desc->desc;
|
||||
struct fc_port *p = &d->ports[port->p];
|
||||
float def, min, max;
|
||||
char name[512];
|
||||
|
||||
def = p->get_param(p, "default");
|
||||
min = p->get_param(p, "min");
|
||||
max = p->get_param(p, "max");
|
||||
|
||||
if (node->name[0] != '\0')
|
||||
snprintf(name, sizeof(name), "%s:%s", node->name, p->name);
|
||||
else
|
||||
|
|
@ -407,13 +402,13 @@ static struct spa_pod *get_prop_info(struct graph *graph, struct spa_pod_builder
|
|||
SPA_PROP_INFO_name, SPA_POD_String(name),
|
||||
0);
|
||||
spa_pod_builder_prop(b, SPA_PROP_INFO_type, 0);
|
||||
if (min == max) {
|
||||
spa_pod_builder_float(b, def);
|
||||
if (p->min == p->max) {
|
||||
spa_pod_builder_float(b, p->def);
|
||||
} else {
|
||||
spa_pod_builder_push_choice(b, &f[1], SPA_CHOICE_Range, 0);
|
||||
spa_pod_builder_float(b, def);
|
||||
spa_pod_builder_float(b, min);
|
||||
spa_pod_builder_float(b, max);
|
||||
spa_pod_builder_float(b, p->def);
|
||||
spa_pod_builder_float(b, p->min);
|
||||
spa_pod_builder_float(b, p->max);
|
||||
spa_pod_builder_pop(b, &f[1]);
|
||||
}
|
||||
spa_pod_builder_prop(b, SPA_PROP_INFO_params, 0);
|
||||
|
|
@ -736,10 +731,10 @@ static struct plugin *plugin_load(struct impl *impl, const char *type, const cha
|
|||
}
|
||||
}
|
||||
|
||||
if (spa_streq(path, "builtin")) {
|
||||
if (spa_streq(type, "builtin")) {
|
||||
pl = load_builtin_plugin(path, NULL);
|
||||
}
|
||||
else if (spa_streq(path, "ladspa")) {
|
||||
else if (spa_streq(type, "ladspa")) {
|
||||
pl = load_ladspa_plugin(path, NULL);
|
||||
}
|
||||
if (pl == NULL)
|
||||
|
|
|
|||
|
|
@ -89,10 +89,6 @@ static struct fc_port copy_ports[] = {
|
|||
static const struct fc_descriptor copy_desc = {
|
||||
.name = "copy",
|
||||
|
||||
//.Name = "Copy input to output",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 2,
|
||||
.ports = copy_ports,
|
||||
|
||||
|
|
@ -122,14 +118,6 @@ static void mixer_run(void * Instance, unsigned long SampleCount)
|
|||
}
|
||||
}
|
||||
|
||||
#if 0
|
||||
static const LADSPA_PortRangeHint mixer_range_hints[] = {
|
||||
{ 0, }, { 0, }, { 0, },
|
||||
{ LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_BOUNDED_ABOVE | LADSPA_HINT_DEFAULT_1, 0.0, 10.0 },
|
||||
{ LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_BOUNDED_ABOVE | LADSPA_HINT_DEFAULT_1, 0.0, 10.0 }
|
||||
};
|
||||
#endif
|
||||
|
||||
static struct fc_port mixer_ports[] = {
|
||||
{ .index = 0,
|
||||
.name = "Out",
|
||||
|
|
@ -146,29 +134,18 @@ static struct fc_port mixer_ports[] = {
|
|||
{ .index = 3,
|
||||
.name = "Gain 1",
|
||||
.flags = LADSPA_PORT_INPUT | LADSPA_PORT_CONTROL,
|
||||
.def = 1.0f, .min = 0.0f, .max = 10.0f
|
||||
},
|
||||
{ .index = 4,
|
||||
.name = "Gain 2",
|
||||
.flags = LADSPA_PORT_INPUT | LADSPA_PORT_CONTROL,
|
||||
.def = 1.0f, .min = 0.0f, .max = 10.0f
|
||||
},
|
||||
};
|
||||
|
||||
static const char *mixer_get_prop(struct fc_descriptor *desc, const char *name)
|
||||
{
|
||||
if (spa_streq(name, "description"))
|
||||
return "Mix 2 inputs";
|
||||
if (spa_streq(name, "maker"))
|
||||
return "PipeWire";
|
||||
if (spa_streq(name, "copyright"))
|
||||
return "MIT";
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static const struct fc_descriptor mixer_desc = {
|
||||
.name = "mixer",
|
||||
|
||||
.get_prop = mixer_get_prop,
|
||||
|
||||
.n_ports = 5,
|
||||
.ports = mixer_ports,
|
||||
|
||||
|
|
@ -178,18 +155,6 @@ static const struct fc_descriptor mixer_desc = {
|
|||
.cleanup = builtin_cleanup,
|
||||
};
|
||||
|
||||
#if 0
|
||||
static const LADSPA_PortRangeHint bq_range_hints[] = {
|
||||
{ 0, }, { 0, },
|
||||
{ LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_BOUNDED_ABOVE |
|
||||
LADSPA_HINT_SAMPLE_RATE | LADSPA_HINT_DEFAULT_LOW, 0.0, 1.0 },
|
||||
{ LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_BOUNDED_ABOVE |
|
||||
LADSPA_HINT_DEFAULT_0, 0.0, 10.0 },
|
||||
{ LADSPA_HINT_BOUNDED_BELOW | LADSPA_HINT_BOUNDED_ABOVE |
|
||||
LADSPA_HINT_DEFAULT_0, -120.0, 5.0 },
|
||||
};
|
||||
#endif
|
||||
|
||||
static struct fc_port bq_ports[] = {
|
||||
{ .index = 0,
|
||||
.name = "Out",
|
||||
|
|
@ -202,14 +167,18 @@ static struct fc_port bq_ports[] = {
|
|||
{ .index = 2,
|
||||
.name = "Freq",
|
||||
.flags = LADSPA_PORT_INPUT | LADSPA_PORT_CONTROL,
|
||||
.hint = LADSPA_HINT_SAMPLE_RATE,
|
||||
.def = 0.0f, .min = 0.0f, .max = 1.0f,
|
||||
},
|
||||
{ .index = 3,
|
||||
.name = "Q",
|
||||
.flags = LADSPA_PORT_INPUT | LADSPA_PORT_CONTROL,
|
||||
.def = 0.0f, .min = 0.0f, .max = 10.0f,
|
||||
},
|
||||
{ .index = 4,
|
||||
.name = "Gain",
|
||||
.flags = LADSPA_PORT_INPUT | LADSPA_PORT_CONTROL,
|
||||
.def = 0.0f, .min = -120.0f, .max = 5.0f,
|
||||
},
|
||||
};
|
||||
|
||||
|
|
@ -264,9 +233,7 @@ static void bq_lowpass_run(void * Instance, unsigned long SampleCount)
|
|||
|
||||
static const struct fc_descriptor bq_lowpass_desc = {
|
||||
.name = "bq_lowpass",
|
||||
//.Name = "Biquad lowpass filter",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 5,
|
||||
.ports = bq_ports,
|
||||
|
||||
|
|
@ -285,11 +252,10 @@ static void bq_highpass_run(void * Instance, unsigned long SampleCount)
|
|||
|
||||
static const struct fc_descriptor bq_highpass_desc = {
|
||||
.name = "bq_highpass",
|
||||
//.Name = "Biquad highpass filter",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 5,
|
||||
.ports = bq_ports,
|
||||
|
||||
.instantiate = builtin_instantiate,
|
||||
.connect_port = builtin_connect_port,
|
||||
.run = bq_highpass_run,
|
||||
|
|
@ -305,11 +271,10 @@ static void bq_bandpass_run(void * Instance, unsigned long SampleCount)
|
|||
|
||||
static const struct fc_descriptor bq_bandpass_desc = {
|
||||
.name = "bq_bandpass",
|
||||
//.Name = "Biquad bandpass filter",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 5,
|
||||
.ports = bq_ports,
|
||||
|
||||
.instantiate = builtin_instantiate,
|
||||
.connect_port = builtin_connect_port,
|
||||
.run = bq_bandpass_run,
|
||||
|
|
@ -325,11 +290,10 @@ static void bq_lowshelf_run(void * Instance, unsigned long SampleCount)
|
|||
|
||||
static const struct fc_descriptor bq_lowshelf_desc = {
|
||||
.name = "bq_lowshelf",
|
||||
//.Name = "Biquad lowshelf filter",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 5,
|
||||
.ports = bq_ports,
|
||||
|
||||
.instantiate = builtin_instantiate,
|
||||
.connect_port = builtin_connect_port,
|
||||
.run = bq_lowshelf_run,
|
||||
|
|
@ -345,11 +309,10 @@ static void bq_highshelf_run(void * Instance, unsigned long SampleCount)
|
|||
|
||||
static const struct fc_descriptor bq_highshelf_desc = {
|
||||
.name = "bq_highshelf",
|
||||
//.Name = "Biquad highshelf filter",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 5,
|
||||
.ports = bq_ports,
|
||||
|
||||
.instantiate = builtin_instantiate,
|
||||
.connect_port = builtin_connect_port,
|
||||
.run = bq_highshelf_run,
|
||||
|
|
@ -365,11 +328,10 @@ static void bq_peaking_run(void * Instance, unsigned long SampleCount)
|
|||
|
||||
static const struct fc_descriptor bq_peaking_desc = {
|
||||
.name = "bq_peaking",
|
||||
//.Name = "Biquad peaking filter",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 5,
|
||||
.ports = bq_ports,
|
||||
|
||||
.instantiate = builtin_instantiate,
|
||||
.connect_port = builtin_connect_port,
|
||||
.run = bq_peaking_run,
|
||||
|
|
@ -385,11 +347,10 @@ static void bq_notch_run(void * Instance, unsigned long SampleCount)
|
|||
|
||||
static const struct fc_descriptor bq_notch_desc = {
|
||||
.name = "bq_notch",
|
||||
//.Name = "Biquad notch filter",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 5,
|
||||
.ports = bq_ports,
|
||||
|
||||
.instantiate = builtin_instantiate,
|
||||
.connect_port = builtin_connect_port,
|
||||
.run = bq_notch_run,
|
||||
|
|
@ -406,11 +367,10 @@ static void bq_allpass_run(void * Instance, unsigned long SampleCount)
|
|||
|
||||
static const struct fc_descriptor bq_allpass_desc = {
|
||||
.name = "bq_allpass",
|
||||
//.Name = "Biquad allpass filter",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 5,
|
||||
.ports = bq_ports,
|
||||
|
||||
.instantiate = builtin_instantiate,
|
||||
.connect_port = builtin_connect_port,
|
||||
.run = bq_allpass_run,
|
||||
|
|
@ -495,11 +455,10 @@ static void convolve_run(void * Instance, unsigned long SampleCount)
|
|||
|
||||
static const struct fc_descriptor convolve_desc = {
|
||||
.name = "convolver",
|
||||
//.Name = "Convolver",
|
||||
//.Maker = "PipeWire",
|
||||
//.Copyright = "MIT",
|
||||
|
||||
.n_ports = 2,
|
||||
.ports = convolve_ports,
|
||||
|
||||
.instantiate = convolver_instantiate,
|
||||
.connect_port = convolver_connect_port,
|
||||
.run = convolve_run,
|
||||
|
|
|
|||
|
|
@ -67,11 +67,6 @@ static const LADSPA_Descriptor *find_desc(LADSPA_Descriptor_Function desc_func,
|
|||
return NULL;
|
||||
}
|
||||
|
||||
static const char *ladspa_get_prop(struct fc_descriptor *desc, const char *name)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static float get_default(struct fc_port *port, LADSPA_PortRangeHintDescriptor hint,
|
||||
LADSPA_Data lower, LADSPA_Data upper)
|
||||
{
|
||||
|
|
@ -126,9 +121,8 @@ static float get_default(struct fc_port *port, LADSPA_PortRangeHintDescriptor hi
|
|||
return def;
|
||||
}
|
||||
|
||||
static float ladspa_port_get_param(struct fc_port *port, const char *name)
|
||||
static void ladspa_port_update_ranges(struct descriptor *dd, struct fc_port *port)
|
||||
{
|
||||
struct descriptor *dd = (struct descriptor*)port->desc;
|
||||
const LADSPA_Descriptor *d = dd->d;
|
||||
unsigned long p = port->index;
|
||||
LADSPA_PortRangeHintDescriptor hint = d->PortRangeHints[p].HintDescriptor;
|
||||
|
|
@ -137,21 +131,10 @@ static float ladspa_port_get_param(struct fc_port *port, const char *name)
|
|||
lower = d->PortRangeHints[p].LowerBound;
|
||||
upper = d->PortRangeHints[p].UpperBound;
|
||||
|
||||
if (LADSPA_IS_HINT_SAMPLE_RATE(hint)) {
|
||||
lower *= (LADSPA_Data) 48000.0f;
|
||||
upper *= (LADSPA_Data) 48000.0f;
|
||||
}
|
||||
|
||||
if (spa_streq(name, "default")) {
|
||||
return get_default(port, hint, lower, upper);
|
||||
}
|
||||
if (spa_streq(name, "min")) {
|
||||
return lower;
|
||||
}
|
||||
if (spa_streq(name, "max")) {
|
||||
return upper;
|
||||
}
|
||||
return 0.0f;
|
||||
port->hint = hint;
|
||||
port->def = get_default(port, hint, lower, upper);
|
||||
port->min = lower;
|
||||
port->max = upper;
|
||||
}
|
||||
|
||||
static void ladspa_free(struct fc_descriptor *desc)
|
||||
|
|
@ -183,7 +166,6 @@ static const struct fc_descriptor *ladspa_make_desc(struct fc_plugin *plugin, co
|
|||
desc->desc.run = d->run;
|
||||
|
||||
desc->desc.free = ladspa_free;
|
||||
desc->desc.get_prop = ladspa_get_prop;
|
||||
|
||||
desc->desc.name = d->Label;
|
||||
desc->desc.flags = d->Properties;
|
||||
|
|
@ -195,7 +177,7 @@ static const struct fc_descriptor *ladspa_make_desc(struct fc_plugin *plugin, co
|
|||
desc->desc.ports[i].index = i;
|
||||
desc->desc.ports[i].name = d->PortNames[i];
|
||||
desc->desc.ports[i].flags = d->PortDescriptors[i];
|
||||
desc->desc.ports[i].get_param = ladspa_port_get_param;
|
||||
ladspa_port_update_ranges(desc, &desc->desc.ports[i]);
|
||||
}
|
||||
return &desc->desc;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -39,23 +39,21 @@ struct fc_plugin {
|
|||
|
||||
struct fc_port {
|
||||
uint32_t index;
|
||||
struct fc_descriptor *desc;
|
||||
const char *name;
|
||||
uint64_t flags;
|
||||
|
||||
float (*get_param) (struct fc_port *port, const char *name);
|
||||
uint64_t hint;
|
||||
float def;
|
||||
float min;
|
||||
float max;
|
||||
};
|
||||
|
||||
struct fc_descriptor {
|
||||
struct fc_plugin *plugin;
|
||||
|
||||
const char *name;
|
||||
uint64_t flags;
|
||||
|
||||
void (*free) (struct fc_descriptor *desc);
|
||||
|
||||
const char *(*get_prop) (struct fc_descriptor *desc, const char *name);
|
||||
|
||||
uint32_t n_ports;
|
||||
struct fc_port *ports;
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue