mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-02 09:01:50 -05:00
media-session: detect and block passthrough-only streams
If we see that the stream only has passthrough formats, make them error immediately for now.
This commit is contained in:
parent
1a713e963a
commit
10c3bf5ff3
1 changed files with 20 additions and 6 deletions
|
|
@ -130,13 +130,14 @@ struct node {
|
|||
unsigned int capture_sink:1;
|
||||
unsigned int virtual:1;
|
||||
unsigned int linking:1;
|
||||
unsigned int passthrough_only:1;
|
||||
};
|
||||
|
||||
static bool find_format(struct node *node)
|
||||
{
|
||||
struct impl *impl = node->impl;
|
||||
struct sm_param *p;
|
||||
bool have_format = false;
|
||||
bool have_format = false, have_passthrough = false;
|
||||
|
||||
spa_list_for_each(p, &node->obj->param_list, link) {
|
||||
struct spa_audio_info info = { 0, };
|
||||
|
|
@ -149,10 +150,14 @@ static bool find_format(struct node *node)
|
|||
if (spa_format_parse(p->param, &info.media_type, &info.media_subtype) < 0)
|
||||
continue;
|
||||
|
||||
if (info.media_type != SPA_MEDIA_TYPE_audio ||
|
||||
info.media_subtype != SPA_MEDIA_SUBTYPE_raw)
|
||||
if (info.media_type != SPA_MEDIA_TYPE_audio)
|
||||
continue;
|
||||
|
||||
if (info.media_subtype != SPA_MEDIA_SUBTYPE_raw) {
|
||||
have_passthrough = true;
|
||||
continue;
|
||||
}
|
||||
|
||||
spa_pod_object_fixate((struct spa_pod_object*)p->param);
|
||||
if (pw_log_level_enabled(SPA_LOG_LEVEL_DEBUG))
|
||||
spa_debug_pod(2, NULL, p->param);
|
||||
|
|
@ -182,6 +187,11 @@ static bool find_format(struct node *node)
|
|||
|
||||
have_format = true;
|
||||
}
|
||||
if (!have_format && have_passthrough) {
|
||||
pw_log_info("passthrough only stream found");
|
||||
node->passthrough_only = true;
|
||||
have_format = true;
|
||||
}
|
||||
return have_format;
|
||||
}
|
||||
|
||||
|
|
@ -880,6 +890,13 @@ static int rescan_node(struct impl *impl, struct node *n)
|
|||
}
|
||||
}
|
||||
|
||||
if (n->passthrough_only) {
|
||||
path_id = SPA_ID_INVALID;
|
||||
peer = NULL;
|
||||
reconnect = false;
|
||||
goto do_link;
|
||||
}
|
||||
|
||||
pw_log_info("trying to link node %d exclusive:%d reconnect:%d target:%d",
|
||||
n->id, exclusive, reconnect, path_id);
|
||||
|
||||
|
|
@ -900,7 +917,6 @@ static int rescan_node(struct impl *impl, struct node *n)
|
|||
pw_log_warn("node %d target:%d not found, find fallback:%d", n->id,
|
||||
path_id, reconnect);
|
||||
}
|
||||
|
||||
if (path_id == SPA_ID_INVALID && (reconnect || n->connect_count == 0)) {
|
||||
/* find fallback */
|
||||
struct find_data find;
|
||||
|
|
@ -923,8 +939,6 @@ static int rescan_node(struct impl *impl, struct node *n)
|
|||
|
||||
do_link:
|
||||
if (peer == NULL) {
|
||||
struct sm_object *obj;
|
||||
|
||||
if (!reconnect) {
|
||||
pw_log_info("don-reconnect target node destroyed: destroy %d", n->id);
|
||||
sm_media_session_destroy_object(impl->session, n->id);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue