From ed617fb21218a3fa4be7a5b70f426426edf53912 Mon Sep 17 00:00:00 2001 From: Than Ngo Date: Wed, 12 Feb 2025 20:35:07 +0100 Subject: [PATCH] Fix build error with new pipewire in f43 --- chromium-133-pipewire-cast.patch | 21 +++++++++++++++++++++ chromium.spec | 7 +++++++ 2 files changed, 28 insertions(+) create mode 100644 chromium-133-pipewire-cast.patch diff --git a/chromium-133-pipewire-cast.patch b/chromium-133-pipewire-cast.patch new file mode 100644 index 00000000..670cb70e --- /dev/null +++ b/chromium-133-pipewire-cast.patch @@ -0,0 +1,21 @@ +diff -up chromium-133.0.6943.53/third_party/webrtc/modules/video_capture/linux/pipewire_session.cc.me chromium-133.0.6943.53/third_party/webrtc/modules/video_capture/linux/pipewire_session.cc +--- chromium-133.0.6943.53/third_party/webrtc/modules/video_capture/linux/pipewire_session.cc.me 2025-02-12 19:09:54.742875003 +0100 ++++ chromium-133.0.6943.53/third_party/webrtc/modules/video_capture/linux/pipewire_session.cc 2025-02-12 19:12:17.492620559 +0100 +@@ -87,7 +87,7 @@ PipeWireNode::PipeWireNode(PipeWireSessi + .param = OnNodeParam, + }; + +- pw_node_add_listener(proxy_, &node_listener_, &node_events, this); ++ pw_node_add_listener((struct pw_node*) proxy_, &node_listener_, &node_events, this); + } + + // static +@@ -119,7 +119,7 @@ void PipeWireNode::OnNodeInfo(void* data + uint32_t id = info->params[i].id; + if (id == SPA_PARAM_EnumFormat && + info->params[i].flags & SPA_PARAM_INFO_READ) { +- pw_node_enum_params(that->proxy_, 0, id, 0, UINT32_MAX, nullptr); ++ pw_node_enum_params((struct pw_node*)that->proxy_, 0, id, 0, UINT32_MAX, nullptr); + break; + } + } diff --git a/chromium.spec b/chromium.spec index 9bcf736a..4058c995 100644 --- a/chromium.spec +++ b/chromium.spec @@ -357,6 +357,9 @@ Patch353: chromium-127-aarch64-duplicate-case-value.patch # remove flag split-threshold-for-reg-with-hint, it's not supported in clang <= 17 Patch354: chromium-126-split-threshold-for-reg-with-hint.patch +# fix build error with new pipewire in f43 +Patch356: chromium-133-pipewire-cast.patch + # fix build error: no member named 'hardware_destructive_interference_size' in namespace 'std' Patch355: chromium-130-hardware_destructive_interference_size.patch @@ -1060,6 +1063,10 @@ Qt6 UI for chromium. %patch -P355 -p1 -b .hardware_destructive_interference_size +%if 0%{?fedora} > 42 +%patch -P356 -p1 -b .pipewire-cast +%endif + %patch -P358 -p1 -b .rust-clang_lib %ifarch ppc64le