mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-03 09:01:54 -05:00
device: improve properties and info
This commit is contained in:
parent
cff8ce8e99
commit
59d77818d6
2 changed files with 62 additions and 57 deletions
|
|
@ -99,26 +99,20 @@ static const char *get_subclass(snd_pcm_info_t *pcminfo)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int emit_node(struct impl *this, snd_ctl_card_info_t *info, snd_pcm_info_t *pcminfo)
|
static int emit_node(struct impl *this, snd_pcm_info_t *pcminfo)
|
||||||
{
|
{
|
||||||
struct spa_dict_item items[12];
|
struct spa_dict_item items[6];
|
||||||
const struct spa_handle_factory *factory;
|
const struct spa_handle_factory *factory;
|
||||||
char device_name[128];
|
char device_name[128];
|
||||||
|
|
||||||
snprintf(device_name, 128, "%s,%d", this->props.device, snd_pcm_info_get_device(pcminfo));
|
snprintf(device_name, 128, "%s,%d", this->props.device, snd_pcm_info_get_device(pcminfo));
|
||||||
|
|
||||||
items[0] = SPA_DICT_ITEM_INIT("alsa.device", device_name);
|
items[0] = SPA_DICT_ITEM_INIT("alsa.device", device_name);
|
||||||
items[1] = SPA_DICT_ITEM_INIT("alsa.card.id", snd_ctl_card_info_get_id(info));
|
items[1] = SPA_DICT_ITEM_INIT("alsa.pcm.id", snd_pcm_info_get_id(pcminfo));
|
||||||
items[2] = SPA_DICT_ITEM_INIT("alsa.card.components", snd_ctl_card_info_get_components(info));
|
items[2] = SPA_DICT_ITEM_INIT("alsa.pcm.name", snd_pcm_info_get_name(pcminfo));
|
||||||
items[3] = SPA_DICT_ITEM_INIT("alsa.card.driver", snd_ctl_card_info_get_driver(info));
|
items[3] = SPA_DICT_ITEM_INIT("alsa.pcm.subname", snd_pcm_info_get_subdevice_name(pcminfo));
|
||||||
items[4] = SPA_DICT_ITEM_INIT("alsa.card.name", snd_ctl_card_info_get_name(info));
|
items[4] = SPA_DICT_ITEM_INIT("alsa.pcm.class", get_class(pcminfo));
|
||||||
items[5] = SPA_DICT_ITEM_INIT("alsa.card.longname", snd_ctl_card_info_get_longname(info));
|
items[5] = SPA_DICT_ITEM_INIT("alsa.pcm.subclass", get_subclass(pcminfo));
|
||||||
items[6] = SPA_DICT_ITEM_INIT("alsa.card.mixername", snd_ctl_card_info_get_mixername(info));
|
|
||||||
items[7] = SPA_DICT_ITEM_INIT("alsa.pcm.id", snd_pcm_info_get_id(pcminfo));
|
|
||||||
items[8] = SPA_DICT_ITEM_INIT("alsa.pcm.name", snd_pcm_info_get_name(pcminfo));
|
|
||||||
items[9] = SPA_DICT_ITEM_INIT("alsa.pcm.subname", snd_pcm_info_get_subdevice_name(pcminfo));
|
|
||||||
items[10] = SPA_DICT_ITEM_INIT("alsa.pcm.class", get_class(pcminfo));
|
|
||||||
items[11] = SPA_DICT_ITEM_INIT("alsa.pcm.subclass", get_subclass(pcminfo));
|
|
||||||
|
|
||||||
if (snd_pcm_info_get_stream(pcminfo) == SND_PCM_STREAM_PLAYBACK)
|
if (snd_pcm_info_get_stream(pcminfo) == SND_PCM_STREAM_PLAYBACK)
|
||||||
factory = &spa_alsa_sink_factory;
|
factory = &spa_alsa_sink_factory;
|
||||||
|
|
@ -133,9 +127,10 @@ static int emit_node(struct impl *this, snd_ctl_card_info_t *info, snd_pcm_info_
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int emit_nodes(struct impl *this)
|
static int emit_info(struct impl *this)
|
||||||
{
|
{
|
||||||
int err = 0, dev;
|
int err = 0, dev;
|
||||||
|
struct spa_dict_item items[8];
|
||||||
snd_ctl_card_info_t *info;
|
snd_ctl_card_info_t *info;
|
||||||
snd_pcm_info_t *pcminfo;
|
snd_pcm_info_t *pcminfo;
|
||||||
|
|
||||||
|
|
@ -153,6 +148,18 @@ static int emit_nodes(struct impl *this)
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
items[0] = SPA_DICT_ITEM_INIT("device.path", (char *)this->props.device);
|
||||||
|
items[1] = SPA_DICT_ITEM_INIT("media.class", "Audio/Device");
|
||||||
|
items[2] = SPA_DICT_ITEM_INIT("alsa.card.id", snd_ctl_card_info_get_id(info));
|
||||||
|
items[3] = SPA_DICT_ITEM_INIT("alsa.card.components", snd_ctl_card_info_get_components(info));
|
||||||
|
items[4] = SPA_DICT_ITEM_INIT("alsa.card.driver", snd_ctl_card_info_get_driver(info));
|
||||||
|
items[5] = SPA_DICT_ITEM_INIT("alsa.card.name", snd_ctl_card_info_get_name(info));
|
||||||
|
items[6] = SPA_DICT_ITEM_INIT("alsa.card.longname", snd_ctl_card_info_get_longname(info));
|
||||||
|
items[7] = SPA_DICT_ITEM_INIT("alsa.card.mixername", snd_ctl_card_info_get_mixername(info));
|
||||||
|
|
||||||
|
if (this->callbacks->info)
|
||||||
|
this->callbacks->info(this->callbacks_data, &SPA_DICT_INIT(items, 8));
|
||||||
|
|
||||||
snd_pcm_info_alloca(&pcminfo);
|
snd_pcm_info_alloca(&pcminfo);
|
||||||
dev = -1;
|
dev = -1;
|
||||||
while (1) {
|
while (1) {
|
||||||
|
|
@ -171,28 +178,23 @@ static int emit_nodes(struct impl *this)
|
||||||
if (err != -ENOENT)
|
if (err != -ENOENT)
|
||||||
spa_log_error(this->log, "error pcm info: %s", snd_strerror(err));
|
spa_log_error(this->log, "error pcm info: %s", snd_strerror(err));
|
||||||
}
|
}
|
||||||
if (err >= 0)
|
if (err >= 0 && this->callbacks->add)
|
||||||
emit_node(this, info, pcminfo);
|
emit_node(this, pcminfo);
|
||||||
|
|
||||||
snd_pcm_info_set_stream(pcminfo, SND_PCM_STREAM_CAPTURE);
|
snd_pcm_info_set_stream(pcminfo, SND_PCM_STREAM_CAPTURE);
|
||||||
if ((err = snd_ctl_pcm_info(this->ctl_hndl, pcminfo)) < 0) {
|
if ((err = snd_ctl_pcm_info(this->ctl_hndl, pcminfo)) < 0) {
|
||||||
if (err != -ENOENT)
|
if (err != -ENOENT)
|
||||||
spa_log_error(this->log, "error pcm info: %s", snd_strerror(err));
|
spa_log_error(this->log, "error pcm info: %s", snd_strerror(err));
|
||||||
}
|
}
|
||||||
if (err >= 0)
|
if (err >= 0 && this->callbacks->add)
|
||||||
emit_node(this, info, pcminfo);
|
emit_node(this, pcminfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
exit:
|
exit:
|
||||||
snd_ctl_close(this->ctl_hndl);
|
snd_ctl_close(this->ctl_hndl);
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct spa_dict_item info_items[] = {
|
|
||||||
{ "media.class", "Audio/Device" },
|
|
||||||
};
|
|
||||||
|
|
||||||
static int impl_set_callbacks(struct spa_device *device,
|
static int impl_set_callbacks(struct spa_device *device,
|
||||||
const struct spa_device_callbacks *callbacks,
|
const struct spa_device_callbacks *callbacks,
|
||||||
void *data)
|
void *data)
|
||||||
|
|
@ -206,13 +208,8 @@ static int impl_set_callbacks(struct spa_device *device,
|
||||||
this->callbacks = callbacks;
|
this->callbacks = callbacks;
|
||||||
this->callbacks_data = data;
|
this->callbacks_data = data;
|
||||||
|
|
||||||
if (callbacks) {
|
if (callbacks)
|
||||||
if (callbacks->info)
|
emit_info(this);
|
||||||
callbacks->info(data, &SPA_DICT_INIT_ARRAY(info_items));
|
|
||||||
|
|
||||||
if (this->callbacks->add)
|
|
||||||
emit_nodes(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -69,16 +69,43 @@ struct impl {
|
||||||
struct spa_v4l2_device dev;
|
struct spa_v4l2_device dev;
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct spa_dict_item info_items[] = {
|
static int emit_info(struct impl *this)
|
||||||
{ "media.class", "Video/Device" },
|
{
|
||||||
};
|
int res;
|
||||||
|
struct spa_dict_item items[5];
|
||||||
|
|
||||||
|
if ((res = spa_v4l2_open(&this->dev, this->props.device)) < 0)
|
||||||
|
return res;
|
||||||
|
|
||||||
|
items[0] = SPA_DICT_ITEM_INIT("device.path", (char *)this->props.device);
|
||||||
|
items[1] = SPA_DICT_ITEM_INIT("media.class", "Video/Device");
|
||||||
|
items[2] = SPA_DICT_ITEM_INIT("v4l2.driver", (char *)this->dev.cap.driver);
|
||||||
|
items[3] = SPA_DICT_ITEM_INIT("v4l2.card", (char *)this->dev.cap.card);
|
||||||
|
items[4] = SPA_DICT_ITEM_INIT("v4l2.bus", (char *)this->dev.cap.bus_info);
|
||||||
|
|
||||||
|
if (this->callbacks->info)
|
||||||
|
this->callbacks->info(this->callbacks_data, &SPA_DICT_INIT(items, 5));
|
||||||
|
|
||||||
|
if (this->callbacks->add) {
|
||||||
|
if (spa_v4l2_is_capture(&this->dev)) {
|
||||||
|
this->callbacks->add(this->callbacks_data, 0,
|
||||||
|
&spa_v4l2_source_factory,
|
||||||
|
SPA_TYPE_INTERFACE_Node,
|
||||||
|
&SPA_DICT_INIT(items, 1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
spa_v4l2_close(&this->dev);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int impl_set_callbacks(struct spa_device *device,
|
static int impl_set_callbacks(struct spa_device *device,
|
||||||
const struct spa_device_callbacks *callbacks,
|
const struct spa_device_callbacks *callbacks,
|
||||||
void *data)
|
void *data)
|
||||||
{
|
{
|
||||||
struct impl *this;
|
struct impl *this;
|
||||||
struct spa_dict_item items[1];
|
int res = 0;
|
||||||
|
|
||||||
spa_return_val_if_fail(device != NULL, -EINVAL);
|
spa_return_val_if_fail(device != NULL, -EINVAL);
|
||||||
|
|
||||||
|
|
@ -88,23 +115,9 @@ static int impl_set_callbacks(struct spa_device *device,
|
||||||
this->callbacks_data = data;
|
this->callbacks_data = data;
|
||||||
|
|
||||||
if (callbacks) {
|
if (callbacks) {
|
||||||
if (callbacks->info)
|
res = emit_info(this);
|
||||||
callbacks->info(data, &SPA_DICT_INIT_ARRAY(info_items));
|
|
||||||
|
|
||||||
if (callbacks->add) {
|
|
||||||
if (spa_v4l2_is_capture(&this->dev)) {
|
|
||||||
items[0] = SPA_DICT_ITEM_INIT("device.path", this->props.device);
|
|
||||||
callbacks->add(data, 0,
|
|
||||||
&spa_v4l2_source_factory,
|
|
||||||
SPA_TYPE_INTERFACE_Node,
|
|
||||||
&SPA_DICT_INIT(items, 1));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
return res;
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int impl_enum_params(struct spa_device *device,
|
static int impl_enum_params(struct spa_device *device,
|
||||||
|
|
@ -169,7 +182,6 @@ impl_init(const struct spa_handle_factory *factory,
|
||||||
struct impl *this;
|
struct impl *this;
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
const char *str;
|
const char *str;
|
||||||
int res;
|
|
||||||
|
|
||||||
spa_return_val_if_fail(factory != NULL, -EINVAL);
|
spa_return_val_if_fail(factory != NULL, -EINVAL);
|
||||||
spa_return_val_if_fail(handle != NULL, -EINVAL);
|
spa_return_val_if_fail(handle != NULL, -EINVAL);
|
||||||
|
|
@ -194,12 +206,8 @@ impl_init(const struct spa_handle_factory *factory,
|
||||||
|
|
||||||
reset_props(&this->props);
|
reset_props(&this->props);
|
||||||
|
|
||||||
if (info && (str = spa_dict_lookup(info, "device.path"))) {
|
if (info && (str = spa_dict_lookup(info, "device.path")))
|
||||||
strncpy(this->props.device, str, 63);
|
strncpy(this->props.device, str, 63);
|
||||||
if ((res = spa_v4l2_open(&this->dev, this->props.device)) < 0)
|
|
||||||
return res;
|
|
||||||
spa_v4l2_close(&this->dev);
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue