SHA256
1
0
forked from pool/wireplumber

Accepting request 948381 from home:alarrosa:branches:multimedia:libs

- Since wireplumber keeps failing to run in openQA since 0.4.7,
  let's drop all patches added since then:
  * 0001-core-add-API-to-check-if-running-in-a-virtual-machine.patch
  * 0002-alsa-monitor-set-period-size-and-headroom-props-if-running-in-virtual-machine.patch
  * 0002-default-nodes-handle-nodes-without-Routes.patch
- And revert one of the commits introduced in 0.4.7:
  * 0001-reversed-default-nodes-check-if-default-node-has-available-ro.patch

OBS-URL: https://build.opensuse.org/request/show/948381
OBS-URL: https://build.opensuse.org/package/show/multimedia:libs/wireplumber?expand=0&rev=23
This commit is contained in:
Antonio Larrosa 2022-01-24 11:27:30 +00:00 committed by Git OBS Bridge
parent 096bf3d9ab
commit d9538f3c4f
6 changed files with 120 additions and 182 deletions

View File

@ -1,101 +0,0 @@
From db728c2f7fff23446feeeaf3b3f16189a18a8f1e Mon Sep 17 00:00:00 2001
From: Julian Bouzas <julian.bouzas@collabora.com>
Date: Fri, 14 Jan 2022 14:34:38 -0500
Subject: [PATCH] core: add API to check if running in a virtual machine
---
lib/wp/core.c | 26 ++++++++++++++++++++++++++
lib/wp/core.h | 5 +++++
modules/module-lua-scripting/api.c | 9 +++++++++
3 files changed, 40 insertions(+)
diff --git a/lib/wp/core.c b/lib/wp/core.c
index 23f6f35f..3713135c 100644
--- a/lib/wp/core.c
+++ b/lib/wp/core.c
@@ -15,6 +15,7 @@
#include <pipewire/pipewire.h>
#include <spa/utils/result.h>
+#include <spa/support/cpu.h>
#include <spa/debug/types.h>
/*
@@ -986,6 +987,31 @@ wp_core_get_registry (WpCore * self)
return &self->registry;
}
+/*!
+ * \brief Checks whether core is a guest running in a virtual machine or not.
+ *
+ * \ingroup wpcore
+ * \param self the core
+ * \returns: TRUE if core is a guest, FALSE otherwise
+ */
+gboolean
+wp_core_is_guest (WpCore * self)
+{
+ const struct spa_support *support;
+ uint32_t n_support;
+ struct spa_cpu *cpu;
+
+ g_return_val_if_fail (WP_IS_CORE (self), FALSE);
+ g_return_val_if_fail (self->pw_context, FALSE);
+
+ support = pw_context_get_support (self->pw_context, &n_support);
+ cpu = spa_support_find (support, n_support, SPA_TYPE_INTERFACE_CPU);
+ if (!cpu)
+ return FALSE;
+
+ return spa_cpu_get_vm_type (cpu) != SPA_CPU_VM_NONE;
+}
+
WpCore *
wp_registry_get_core (WpRegistry * self)
{
diff --git a/lib/wp/core.h b/lib/wp/core.h
index 07a6125b..8efb922d 100644
--- a/lib/wp/core.h
+++ b/lib/wp/core.h
@@ -115,6 +115,11 @@ WP_API
gboolean wp_core_sync_finish (WpCore * self, GAsyncResult * res,
GError ** error);
+/* Misc */
+
+WP_API
+gboolean wp_core_is_guest (WpCore * self);
+
/* Object Manager */
WP_API
diff --git a/modules/module-lua-scripting/api.c b/modules/module-lua-scripting/api.c
index 876b4f6f..27033027 100644
--- a/modules/module-lua-scripting/api.c
+++ b/modules/module-lua-scripting/api.c
@@ -228,6 +228,14 @@ core_require_api (lua_State *L)
return wp_require_api_transition_new_from_lua (L, core);
}
+static int
+core_is_guest (lua_State *L)
+{
+ WpCore * core = get_wp_core (L);
+ lua_pushboolean (L, wp_core_is_guest (core));
+ return 1;
+}
+
static const luaL_Reg core_funcs[] = {
{ "get_info", core_get_info },
{ "idle_add", core_idle_add },
@@ -235,6 +243,7 @@ static const luaL_Reg core_funcs[] = {
{ "sync", core_sync },
{ "quit", core_quit },
{ "require_api", core_require_api },
+ { "is_guest", core_is_guest },
{ NULL, NULL }
};
--
GitLab

View File

@ -0,0 +1,108 @@
--- b/modules/module-default-nodes.c
+++ a/modules/module-default-nodes.c
@@ -8,7 +8,6 @@
#include <wp/wp.h>
#include <errno.h>
-#include <pipewire/pipewire.h>
#include <pipewire/keys.h>
#define COMPILING_MODULE_DEFAULT_NODES 1
@@ -98,87 +97,6 @@
}
}
-static gboolean
-node_has_available_routes (WpDefaultNodes * self, WpNode *node)
-{
- const gchar *dev_id_str = wp_pipewire_object_get_property (
- WP_PIPEWIRE_OBJECT (node), PW_KEY_DEVICE_ID);
- const gchar *cpd_str = wp_pipewire_object_get_property (
- WP_PIPEWIRE_OBJECT (node), "card.profile.device");
- gint dev_id = dev_id_str ? atoi (dev_id_str) : -1;
- gint cpd = cpd_str ? atoi (cpd_str) : -1;
- g_autoptr (WpDevice) device = NULL;
-
- if (dev_id == -1 || cpd == -1)
- return TRUE;
-
- /* Get the device */
- device = wp_object_manager_lookup (self->rescan_om, WP_TYPE_DEVICE,
- WP_CONSTRAINT_TYPE_G_PROPERTY, "bound-id", "=i", dev_id, NULL);
- if (!device)
- return TRUE;
-
- /* Check if the current device route supports the node card device profile */
- {
- g_autoptr (WpIterator) routes = NULL;
- g_auto (GValue) val = G_VALUE_INIT;
- routes = wp_pipewire_object_enum_params_sync (WP_PIPEWIRE_OBJECT (device),
- "Route", NULL);
- for (; wp_iterator_next (routes, &val); g_value_unset (&val)) {
- WpSpaPod *route = g_value_get_boxed (&val);
- gint route_device = -1;
- guint32 route_avail = SPA_PARAM_AVAILABILITY_unknown;
-
- if (!wp_spa_pod_get_object (route, NULL,
- "device", "i", &route_device,
- "available", "?I", &route_avail,
- NULL))
- continue;
-
- if (route_device != cpd)
- continue;
-
- if (route_avail == SPA_PARAM_AVAILABILITY_no)
- return FALSE;
-
- return TRUE;
- }
- }
-
- /* Check if available routes support the node card device profile */
- {
- g_autoptr (WpIterator) routes = NULL;
- g_auto (GValue) val = G_VALUE_INIT;
- routes = wp_pipewire_object_enum_params_sync (WP_PIPEWIRE_OBJECT (device),
- "EnumRoute", NULL);
- for (; wp_iterator_next (routes, &val); g_value_unset (&val)) {
- WpSpaPod *route = g_value_get_boxed (&val);
- guint32 route_avail = SPA_PARAM_AVAILABILITY_unknown;
- g_autoptr (WpSpaPod) route_devices = NULL;
-
- if (!wp_spa_pod_get_object (route, NULL,
- "available", "?I", &route_avail,
- "devices", "?P", &route_devices,
- NULL))
- continue;
-
- {
- g_autoptr (WpIterator) it = wp_spa_pod_new_iterator (route_devices);
- g_auto (GValue) v = G_VALUE_INIT;
- for (; wp_iterator_next (it, &v); g_value_unset (&v)) {
- gint32 *d = (gint32 *)g_value_get_pointer (&v);
- if (d && *d == cpd) {
- if (route_avail != SPA_PARAM_AVAILABILITY_no)
- return TRUE;
- }
- }
- }
- }
- }
-
- return FALSE;
-}
-
static WpNode *
find_best_media_class_node (WpDefaultNodes * self, const gchar *media_class,
const gchar *node_name, WpDirection direction, gint *priority)
@@ -206,9 +124,6 @@
WP_PIPEWIRE_OBJECT (node), PW_KEY_PRIORITY_SESSION);
gint prio = prio_str ? atoi (prio_str) : -1;
- if (!node_has_available_routes (self, node))
- continue;
-
if (name && node_name && g_strcmp0 (name, node_name) == 0)
prio += 10000;

View File

@ -1,31 +0,0 @@
From ba2cd1cfd74de346ccc88028b6e1d6e95f055ba1 Mon Sep 17 00:00:00 2001
From: Julian Bouzas <julian.bouzas@collabora.com>
Date: Fri, 14 Jan 2022 14:35:58 -0500
Subject: [PATCH] alsa-monitor: set period-size and headroom props if running
in virtual machine
Fixes #162
---
src/scripts/monitors/alsa.lua | 6 ++++++
1 file changed, 6 insertions(+)
diff --git a/src/scripts/monitors/alsa.lua b/src/scripts/monitors/alsa.lua
index 3e8eda83..592a250d 100644
--- a/src/scripts/monitors/alsa.lua
+++ b/src/scripts/monitors/alsa.lua
@@ -166,6 +166,12 @@ function createNode(parent, id, type, factory, properties)
end
end
+ -- apply virtual machine properties
+ if Core.is_guest() then
+ properties["api.alsa.period-size"] = 256
+ properties["api.alsa.headroom"] = 8192
+ end
+
-- apply properties from config.rules
rulesApplyProperties(properties)
if properties["node.disabled"] then
--
GitLab

View File

@ -1,47 +0,0 @@
From 211f1e6b6cd4898121e4c2b821fae4dea6cc3317 Mon Sep 17 00:00:00 2001
From: Wim Taymans <wtaymans@redhat.com>
Date: Fri, 14 Jan 2022 16:28:48 +0100
Subject: [PATCH] default-nodes: handle nodes without Routes
When a node has not part of any EnumRoute, we must assume it is
available.
Fixes selection of Pro Audio nodes as default nodes.
---
modules/module-default-nodes.c | 6 ++++++
1 file changed, 6 insertions(+)
diff --git a/modules/module-default-nodes.c b/modules/module-default-nodes.c
index 32b2725b..15aadeaa 100644
--- a/modules/module-default-nodes.c
+++ b/modules/module-default-nodes.c
@@ -108,6 +108,7 @@ node_has_available_routes (WpDefaultNodes * self, WpNode *node)
gint dev_id = dev_id_str ? atoi (dev_id_str) : -1;
gint cpd = cpd_str ? atoi (cpd_str) : -1;
g_autoptr (WpDevice) device = NULL;
+ gint found = 0;
if (dev_id == -1 || cpd == -1)
return TRUE;
@@ -168,6 +169,7 @@ node_has_available_routes (WpDefaultNodes * self, WpNode *node)
for (; wp_iterator_next (it, &v); g_value_unset (&v)) {
gint32 *d = (gint32 *)g_value_get_pointer (&v);
if (d && *d == cpd) {
+ found++;
if (route_avail != SPA_PARAM_AVAILABILITY_no)
return TRUE;
}
@@ -175,6 +177,10 @@ node_has_available_routes (WpDefaultNodes * self, WpNode *node)
}
}
}
+ /* The node is part of a profile without routes so we assume it
+ * is available. This can happen for Pro Audio profiles */
+ if (found == 0)
+ return TRUE;
return FALSE;
}
--
GitLab

View File

@ -1,3 +1,14 @@
-------------------------------------------------------------------
Mon Jan 24 11:08:04 UTC 2022 - Antonio Larrosa <alarrosa@suse.com>
- Since wireplumber keeps failing to run in openQA since 0.4.7,
let's drop all patches added since then:
* 0001-core-add-API-to-check-if-running-in-a-virtual-machine.patch
* 0002-alsa-monitor-set-period-size-and-headroom-props-if-running-in-virtual-machine.patch
* 0002-default-nodes-handle-nodes-without-Routes.patch
- And revert one of the commits introduced in 0.4.7:
* 0001-reversed-default-nodes-check-if-default-node-has-available-ro.patch
-------------------------------------------------------------------
Fri Jan 21 11:41:03 UTC 2022 - Antonio Larrosa <alarrosa@suse.com>

View File

@ -30,9 +30,7 @@ Group: Development/Libraries/C and C++
URL: https://gitlab.freedesktop.org/pipewire/wireplumber
Source0: wireplumber-%{version}.tar.xz
Source1: split-config-file.py
Patch1: 0002-default-nodes-handle-nodes-without-Routes.patch
Patch2: 0001-core-add-API-to-check-if-running-in-a-virtual-machine.patch
Patch3: 0002-alsa-monitor-set-period-size-and-headroom-props-if-running-in-virtual-machine.patch
Patch0: 0001-reversed-default-nodes-check-if-default-node-has-available-ro.patch
Patch100: reduce-meson-required-version.patch
# docs
BuildRequires: doxygen