1 |
commit: 95839274ef7c289570c1c7c7549f3ed5439b9b98 |
2 |
Author: Sam James <sam <AT> gentoo <DOT> org> |
3 |
AuthorDate: Fri Oct 1 00:00:18 2021 +0000 |
4 |
Commit: Sam James <sam <AT> gentoo <DOT> org> |
5 |
CommitDate: Fri Oct 1 00:00:39 2021 +0000 |
6 |
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=95839274 |
7 |
|
8 |
media-video/pipewire: add 0.3.38 |
9 |
|
10 |
Signed-off-by: Sam James <sam <AT> gentoo.org> |
11 |
|
12 |
media-video/pipewire/Manifest | 1 + |
13 |
.../files/pipewire-0.3.38-find-readline.patch | 36 +++++++++++ |
14 |
.../files/pipewire-0.3.38-fix-arm-build.patch | 18 ++++++ |
15 |
.../pipewire-0.3.38-libcamera-null-deref.patch | 70 ++++++++++++++++++++++ |
16 |
...pipewire-9999.ebuild => pipewire-0.3.38.ebuild} | 5 ++ |
17 |
media-video/pipewire/pipewire-9999.ebuild | 1 + |
18 |
6 files changed, 131 insertions(+) |
19 |
|
20 |
diff --git a/media-video/pipewire/Manifest b/media-video/pipewire/Manifest |
21 |
index 3e2400ff6d7..a76808c0197 100644 |
22 |
--- a/media-video/pipewire/Manifest |
23 |
+++ b/media-video/pipewire/Manifest |
24 |
@@ -5,3 +5,4 @@ DIST pipewire-0.3.34.tar.gz 1682396 BLAKE2B 1a3524a833bde6facf637071f905bb0237f3 |
25 |
DIST pipewire-0.3.35.tar.gz 1704419 BLAKE2B 5c0debd19b29a9488be26125794f04e57e8b3cd3842654cb935decae18ffefc4137927d969448f60f1c1c2985d54db139fc3dcf07e36e81014021d63490096d8 SHA512 08a2e305fe4e9d3c3f4533c163b725dd32d26513e51a9f476bd18d6157ebf67e97e48b8df9595d45c81599f416e6b3f76e90df575dd460a8d26fe951db30e0f6 |
26 |
DIST pipewire-0.3.36.tar.gz 1708209 BLAKE2B 20fce0d7f88347fe594491d4fae7b6a8edee67ff7749f1a40b807a5d5094d792e61e3efd05dca2221f781c263e34ff0a50ad3c162231911d4b1d87704df6c775 SHA512 f0fc68ea005018b420a4f65a24dc9c85eb6263c24e66852a7ce2b03f966990d62487b388c7d73ff5adfc10c80c439b1200ae876e41d78f91db190036a1799a14 |
27 |
DIST pipewire-0.3.37.tar.gz 1716320 BLAKE2B ce98b28015de69a0c91953a4839d5f86a29cfa19e2058ba0a2476a75a03b782ae67239b418306e4ed7dab81fe7e77928a417b966ff3c72ac552006cea66e3218 SHA512 3f4cf1ac66117a56a7a264262e2e238a54060457da6a986bd9227f51cc7e8d1a8fd282aef8462c096819282c5baec22779d2025c2e1918bbfb3d6ff75829aea6 |
28 |
+DIST pipewire-0.3.38.tar.gz 1727371 BLAKE2B dac7f3e1992b9690195df1dbc04575d386d21d06d1727b004b851e300709b3707806b7b20d36c1e74225d91a2df5428c913376903b286592f87083857347e53e SHA512 c3c6c822bf4e5e77fed8d6ef09059d3e43195957692ab7baddc349af3d759d892a9af0e7802d389e2a9a15e5fece4c08ec963ac42df931233eec6057bad67eb6 |
29 |
|
30 |
diff --git a/media-video/pipewire/files/pipewire-0.3.38-find-readline.patch b/media-video/pipewire/files/pipewire-0.3.38-find-readline.patch |
31 |
new file mode 100644 |
32 |
index 00000000000..6b56304f5d1 |
33 |
--- /dev/null |
34 |
+++ b/media-video/pipewire/files/pipewire-0.3.38-find-readline.patch |
35 |
@@ -0,0 +1,36 @@ |
36 |
+https://gitlab.freedesktop.org/pipewire/pipewire/-/commit/ddfbd684e78e2b8b9ad40bedb4612ea0197d231a.patch |
37 |
+ |
38 |
+From: Joshua Strobl <joshua@××××××××××.io> |
39 |
+Date: Thu, 30 Sep 2021 23:11:50 +0300 |
40 |
+Subject: [PATCH] Fix readline detection by allowing fallback to cc |
41 |
+ find_library |
42 |
+ |
43 |
+--- a/meson.build |
44 |
++++ b/meson.build |
45 |
+@@ -326,6 +326,11 @@ dbus_dep = dependency('dbus-1') |
46 |
+ sdl_dep = dependency('sdl2', required : get_option('sdl2')) |
47 |
+ summary({'SDL 2': sdl_dep.found()}, bool_yn: true, section: 'Misc dependencies') |
48 |
+ readline_dep = dependency('readline', required : false) |
49 |
++ |
50 |
++if not readline_dep.found() |
51 |
++ readline_dep = cc.find_library('readline', required: false) |
52 |
++endif |
53 |
++ |
54 |
+ summary({'readline (for pw-cli)': readline_dep.found()}, bool_yn: true, section: 'Misc dependencies') |
55 |
+ ncurses_dep = dependency('ncursesw', required : false) |
56 |
+ sndfile_dep = dependency('sndfile', version : '>= 1.0.20', required : get_option('sndfile')) |
57 |
+@@ -406,7 +411,12 @@ libinotify_dep = (build_machine.system() == 'freebsd' |
58 |
+ : dependency('', required: false)) |
59 |
+ |
60 |
+ # On FreeBSD, libintl library is required for gettext |
61 |
+-libintl_dep = cc.find_library('intl', required: false) |
62 |
++libintl_dep = dependency('intl', required: false) |
63 |
++ |
64 |
++if not libintl_dep.found() |
65 |
++ libintl_dep = cc.find_library('intl', required: false) |
66 |
++endif |
67 |
++summary({'intl support': libintl_dep.found()}, bool_yn: true) |
68 |
+ |
69 |
+ need_alsa = get_option('pipewire-alsa').enabled() or get_option('session-managers').contains('media-session') |
70 |
+ alsa_dep = dependency('alsa', version : '>=1.1.7', required: need_alsa) |
71 |
+GitLab |
72 |
|
73 |
diff --git a/media-video/pipewire/files/pipewire-0.3.38-fix-arm-build.patch b/media-video/pipewire/files/pipewire-0.3.38-fix-arm-build.patch |
74 |
new file mode 100644 |
75 |
index 00000000000..222aa58cce1 |
76 |
--- /dev/null |
77 |
+++ b/media-video/pipewire/files/pipewire-0.3.38-fix-arm-build.patch |
78 |
@@ -0,0 +1,18 @@ |
79 |
+https://gitlab.freedesktop.org/pipewire/pipewire/-/commit/f8817b439433798bd7217dc4ae72197887b0fc96.patch |
80 |
+ |
81 |
+From: Wim Taymans <wtaymans@××××××.com> |
82 |
+Date: Thu, 30 Sep 2021 11:12:27 +0200 |
83 |
+Subject: [PATCH] cpu: fix compilation on ARM |
84 |
+ |
85 |
+--- a/spa/plugins/support/cpu-arm.c |
86 |
++++ b/spa/plugins/support/cpu-arm.c |
87 |
+@@ -80,7 +80,7 @@ arm_init(struct impl *impl) |
88 |
+ int arch; |
89 |
+ |
90 |
+ if (!(cpuinfo = get_cpuinfo())) { |
91 |
+- spa_log_warn(impl->log, NAME " %p: Can't read cpuinfo", impl); |
92 |
++ spa_log_warn(impl->log, "%p: Can't read cpuinfo", impl); |
93 |
+ return 1; |
94 |
+ } |
95 |
+ |
96 |
+GitLab |
97 |
|
98 |
diff --git a/media-video/pipewire/files/pipewire-0.3.38-libcamera-null-deref.patch b/media-video/pipewire/files/pipewire-0.3.38-libcamera-null-deref.patch |
99 |
new file mode 100644 |
100 |
index 00000000000..beabd1a3029 |
101 |
--- /dev/null |
102 |
+++ b/media-video/pipewire/files/pipewire-0.3.38-libcamera-null-deref.patch |
103 |
@@ -0,0 +1,70 @@ |
104 |
+https://gitlab.freedesktop.org/pipewire/pipewire/-/commit/d71a10b7fa9b5c560485b6bbde409c10d3fdd114.patch |
105 |
+ |
106 |
+From: Wim Taymans <wtaymans@××××××.com> |
107 |
+Date: Thu, 30 Sep 2021 12:54:29 +0200 |
108 |
+Subject: [PATCH] libcamera: handle failure gracefully |
109 |
+ |
110 |
+Don't try to access NULL pointers |
111 |
+--- a/spa/plugins/libcamera/libcamera-client.c |
112 |
++++ b/spa/plugins/libcamera/libcamera-client.c |
113 |
+@@ -210,10 +210,10 @@ impl_init(const struct spa_handle_factory *factory, |
114 |
+ SPA_DEVICE_CHANGE_MASK_PROPS; |
115 |
+ this->info.flags = 0; |
116 |
+ |
117 |
+- if(this->dev.camera == NULL) { |
118 |
++ if(this->dev.camera == NULL) |
119 |
+ this->dev.camera = (LibCamera*)newLibCamera(); |
120 |
++ if(this->dev.camera != NULL) |
121 |
+ libcamera_set_log(this->dev.camera, this->dev.log); |
122 |
+- } |
123 |
+ |
124 |
+ return 0; |
125 |
+ } |
126 |
+--- a/spa/plugins/libcamera/libcamera-source.c |
127 |
++++ b/spa/plugins/libcamera/libcamera-source.c |
128 |
+@@ -994,10 +994,10 @@ impl_init(const struct spa_handle_factory *factory, |
129 |
+ port->dev.log = this->log; |
130 |
+ port->dev.fd = -1; |
131 |
+ |
132 |
+- if(port->dev.camera == NULL) { |
133 |
++ if(port->dev.camera == NULL) |
134 |
+ port->dev.camera = (LibCamera*)newLibCamera(); |
135 |
++ if(port->dev.camera != NULL) |
136 |
+ libcamera_set_log(port->dev.camera, port->dev.log); |
137 |
+- } |
138 |
+ |
139 |
+ if (info && (str = spa_dict_lookup(info, SPA_KEY_API_LIBCAMERA_PATH))) { |
140 |
+ strncpy(this->props.device, str, 63); |
141 |
+--- a/spa/plugins/libcamera/libcamera_wrapper.cpp |
142 |
++++ b/spa/plugins/libcamera/libcamera_wrapper.cpp |
143 |
+@@ -540,7 +540,8 @@ extern "C" { |
144 |
+ } |
145 |
+ |
146 |
+ void LibCamera::close() { |
147 |
+- this->cam_->release(); |
148 |
++ if (this->cam_) |
149 |
++ this->cam_->release(); |
150 |
+ } |
151 |
+ |
152 |
+ void LibCamera::connect() |
153 |
+@@ -775,6 +776,9 @@ extern "C" { |
154 |
+ std::unique_ptr<CameraManager> cm = std::make_unique<CameraManager>(); |
155 |
+ LibCamera* camera = new LibCamera(); |
156 |
+ |
157 |
++ pthread_mutexattr_init(&attr); |
158 |
++ pthread_mutex_init(&camera->lock, &attr); |
159 |
++ |
160 |
+ ret = cm->start(); |
161 |
+ if (ret) { |
162 |
+ deleteLibCamera(camera); |
163 |
+@@ -794,9 +798,6 @@ extern "C" { |
164 |
+ return nullptr; |
165 |
+ } |
166 |
+ |
167 |
+- pthread_mutexattr_init(&attr); |
168 |
+- pthread_mutex_init(&camera->lock, &attr); |
169 |
+- |
170 |
+ camera->ring_buffer_init(); |
171 |
+ |
172 |
+ return camera; |
173 |
+GitLab |
174 |
|
175 |
diff --git a/media-video/pipewire/pipewire-9999.ebuild b/media-video/pipewire/pipewire-0.3.38.ebuild |
176 |
similarity index 97% |
177 |
copy from media-video/pipewire/pipewire-9999.ebuild |
178 |
copy to media-video/pipewire/pipewire-0.3.38.ebuild |
179 |
index 7725dfa300f..9b2951c0793 100644 |
180 |
--- a/media-video/pipewire/pipewire-9999.ebuild |
181 |
+++ b/media-video/pipewire/pipewire-0.3.38.ebuild |
182 |
@@ -47,6 +47,7 @@ RDEPEND=" |
183 |
acct-group/audio |
184 |
media-libs/alsa-lib |
185 |
sys-apps/dbus[${MULTILIB_USEDEP}] |
186 |
+ sys-libs/readline:= |
187 |
sys-libs/ncurses:=[unicode(+)] |
188 |
virtual/libintl[${MULTILIB_USEDEP}] |
189 |
virtual/libudev[${MULTILIB_USEDEP}] |
190 |
@@ -96,6 +97,10 @@ DOCS=( {README,INSTALL}.md NEWS ) |
191 |
|
192 |
PATCHES=( |
193 |
"${FILESDIR}"/${PN}-0.3.25-enable-failed-mlock-warning.patch |
194 |
+ # Upstream |
195 |
+ "${FILESDIR}"/${P}-fix-arm-build.patch |
196 |
+ "${FILESDIR}"/${P}-libcamera-null-deref.patch # (we don't have it in ::gentoo but let's be nice) |
197 |
+ "${FILESDIR}"/${P}-find-readline.patch # just in case |
198 |
) |
199 |
|
200 |
# limitsdfile related code taken from =sys-auth/realtime-base-0.1 |
201 |
|
202 |
diff --git a/media-video/pipewire/pipewire-9999.ebuild b/media-video/pipewire/pipewire-9999.ebuild |
203 |
index 7725dfa300f..b6c000cf8a5 100644 |
204 |
--- a/media-video/pipewire/pipewire-9999.ebuild |
205 |
+++ b/media-video/pipewire/pipewire-9999.ebuild |
206 |
@@ -47,6 +47,7 @@ RDEPEND=" |
207 |
acct-group/audio |
208 |
media-libs/alsa-lib |
209 |
sys-apps/dbus[${MULTILIB_USEDEP}] |
210 |
+ sys-libs/readline:= |
211 |
sys-libs/ncurses:=[unicode(+)] |
212 |
virtual/libintl[${MULTILIB_USEDEP}] |
213 |
virtual/libudev[${MULTILIB_USEDEP}] |