[gentoo-commits] repo/gentoo:master commit in: media-sound/pulseaudio-daemon/files/, media-sound/pulseaudio-daemon/

2024-02-24 Thread Sam James
commit: 7805d72c8427ae393bd4ab6facf7de83ae5c912c
Author: Igor V. Kovalenko  gmail  com>
AuthorDate: Sat Feb 24 09:55:15 2024 +
Commit: Sam James  gentoo  org>
CommitDate: Sat Feb 24 10:03:31 2024 +
URL:https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=7805d72c

media-sound/pulseaudio-daemon: Backport alsa UCM handling assertion fix to 17.0

Bug: https://bugs.gentoo.org/925345
Signed-off-by: Igor V. Kovalenko  gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/35512
Signed-off-by: Sam James  gentoo.org>

 .../files/pulseaudio-17.0-pr801.patch  |  95 +
 .../files/pulseaudio-17.0-pr802.patch  |  64 
 .../pulseaudio-daemon-17.0-r1.ebuild   | 386 +
 3 files changed, 545 insertions(+)

diff --git a/media-sound/pulseaudio-daemon/files/pulseaudio-17.0-pr801.patch 
b/media-sound/pulseaudio-daemon/files/pulseaudio-17.0-pr801.patch
new file mode 100644
index ..6e1bd338992c
--- /dev/null
+++ b/media-sound/pulseaudio-daemon/files/pulseaudio-17.0-pr801.patch
@@ -0,0 +1,95 @@
+From f5cacd94abcc47003bd88ad7ca1450de649ffb15 Mon Sep 17 00:00:00 2001
+From: Alper Nebi Yasak 
+Date: Thu, 30 Nov 2023 20:17:22 +0300
+Subject: [PATCH] alsa-ucm: Check UCM verb before working with device status
+
+Some versions of the ALSA libraries run into a segmentation fault when
+we query a UCM device/modifier status without first setting a UCM verb.
+It's not a reasonable thing to do anyway, so check for this case and
+return an error. Also do the check in other helpers.
+
+Signed-off-by: Alper Nebi Yasak 
+Part-of: 

+---
+ src/modules/alsa/alsa-ucm.c | 30 ++
+ 1 file changed, 30 insertions(+)
+
+diff --git a/src/modules/alsa/alsa-ucm.c b/src/modules/alsa/alsa-ucm.c
+index bb9438f79..7f5136249 100644
+--- a/src/modules/alsa/alsa-ucm.c
 b/src/modules/alsa/alsa-ucm.c
+@@ -624,6 +624,11 @@ static long ucm_device_status(pa_alsa_ucm_config *ucm, 
pa_alsa_ucm_device *dev)
+ char *devstatus;
+ long status = 0;
+ 
++if (!ucm->active_verb) {
++pa_log_error("Failed to get status for UCM device %s: no UCM verb 
set", dev_name);
++return -1;
++}
++
+ devstatus = pa_sprintf_malloc("_devstatus/%s", dev_name);
+ if (snd_use_case_geti(ucm->ucm_mgr, devstatus, ) < 0) {
+ pa_log_debug("Failed to get status for UCM device %s", dev_name);
+@@ -637,6 +642,11 @@ static long ucm_device_status(pa_alsa_ucm_config *ucm, 
pa_alsa_ucm_device *dev)
+ static int ucm_device_disable(pa_alsa_ucm_config *ucm, pa_alsa_ucm_device 
*dev) {
+ const char *dev_name = pa_proplist_gets(dev->proplist, 
PA_ALSA_PROP_UCM_NAME);
+ 
++if (!ucm->active_verb) {
++pa_log_error("Failed to disable UCM device %s: no UCM verb set", 
dev_name);
++return -1;
++}
++
+ /* If any of dev's conflicting devices is enabled, trying to disable
+  * dev gives an error despite the fact that it's already disabled.
+  * Check that dev is enabled to avoid this error. */
+@@ -657,6 +667,11 @@ static int ucm_device_disable(pa_alsa_ucm_config *ucm, 
pa_alsa_ucm_device *dev)
+ static int ucm_device_enable(pa_alsa_ucm_config *ucm, pa_alsa_ucm_device 
*dev) {
+ const char *dev_name = pa_proplist_gets(dev->proplist, 
PA_ALSA_PROP_UCM_NAME);
+ 
++if (!ucm->active_verb) {
++pa_log_error("Failed to enable UCM device %s: no UCM verb set", 
dev_name);
++return -1;
++}
++
+ /* We don't need to enable devices that are already enabled */
+ if (ucm_device_status(ucm, dev) > 0) {
+ pa_log_debug("UCM device %s is already enabled", dev_name);
+@@ -707,6 +722,11 @@ static long ucm_modifier_status(pa_alsa_ucm_config *ucm, 
pa_alsa_ucm_modifier *m
+ char *modstatus;
+ long status = 0;
+ 
++if (!ucm->active_verb) {
++pa_log_error("Failed to get status for UCM modifier %s: no UCM verb 
set", mod_name);
++return -1;
++}
++
+ modstatus = pa_sprintf_malloc("_modstatus/%s", mod_name);
+ if (snd_use_case_geti(ucm->ucm_mgr, modstatus, ) < 0) {
+ pa_log_debug("Failed to get status for UCM modifier %s", mod_name);
+@@ -720,6 +740,11 @@ static long ucm_modifier_status(pa_alsa_ucm_config *ucm, 
pa_alsa_ucm_modifier *m
+ static int ucm_modifier_disable(pa_alsa_ucm_config *ucm, pa_alsa_ucm_modifier 
*mod) {
+ const char *mod_name = pa_proplist_gets(mod->proplist, 
PA_ALSA_PROP_UCM_NAME);
+ 
++if (!ucm->active_verb) {
++pa_log_error("Failed to disable UCM modifier %s: no UCM verb set", 
mod_name);
++return -1;
++}
++
+ /* We don't need to disable modifiers that are already disabled */
+ if (ucm_modifier_status(ucm, mod) == 0) {
+ pa_log_debug("UCM modifier %s is already disabled", mod_name);
+@@ -738,6 +763,11 @@ static int ucm_modifier_disable(pa_alsa_ucm_config *ucm, 
pa_alsa_ucm_modifier *m
+ static int 

[gentoo-commits] repo/gentoo:master commit in: media-sound/pulseaudio-daemon/files/, media-sound/pulseaudio-daemon/

2023-10-06 Thread Sam James
commit: cf2d6215f969b58406cb6894c46ec913581f60db
Author: Igor V. Kovalenko  gmail  com>
AuthorDate: Fri Oct  6 08:35:34 2023 +
Commit: Sam James  gentoo  org>
CommitDate: Fri Oct  6 12:05:10 2023 +
URL:https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cf2d6215

media-sound/pulseaudio-daemon: Backport oversized resampler memblock fix

Upstream commit 1cfa7378236b3cf9daf3be09d3227b92df69cc53

Signed-off-by: Igor V. Kovalenko  gmail.com>
Signed-off-by: Sam James  gentoo.org>

 ...dio-16.1-fix-resampler-oversized-memblock.patch | 55 ++
 .../pulseaudio-daemon-16.1-r8.ebuild   |  1 +
 2 files changed, 56 insertions(+)

diff --git 
a/media-sound/pulseaudio-daemon/files/pulseaudio-16.1-fix-resampler-oversized-memblock.patch
 
b/media-sound/pulseaudio-daemon/files/pulseaudio-16.1-fix-resampler-oversized-memblock.patch
new file mode 100644
index ..bd3d39d0af82
--- /dev/null
+++ 
b/media-sound/pulseaudio-daemon/files/pulseaudio-16.1-fix-resampler-oversized-memblock.patch
@@ -0,0 +1,55 @@
+commit 1cfa7378236b3cf9daf3be09d3227b92df69cc53
+Author: Igor V. Kovalenko 
+Date:   Wed Feb 8 03:24:59 2023 +0300
+
+resampler: Fix oversized memblock pushed from resampler
+
+The assumption that the format enum is ordered by size is not valid for 
quite
+some time, since 24bit formats were appended to format enum later than 
32bit
+formats. This causes resampler to produce properly aligned memblock of size
+larger than maximum mempool block size if input format is 24bit and output
+format is 32bit.
+
+Oversized block is getting split by `pa_pstream_send_memblock()` into 
parts of
+size not exceeding maximum mempool block size. This usually works well but 
for
+32ch 32bit 48000Hz stream the frame alignment is 128 bytes and maximum 
mempool
+block size value is multiple of 64 but not 128 bytes, therefore resulting 
parts
+are misaligned.
+
+On receiving side this causes extra allocation of 128 byte chunk while 
`mcalign`
+helper reassembles properly aligned frame out of second block of misaligned
+size. While first and second properly aligned frames are retrieved 
successfully
+from `mcalign` helper, third retrieved frame would end up with properly 
aligned
+size but misaligned memblock index (in this example, that would be 64 
bytes.)
+Attempt to push a chunk with misaligned memblock index causes assertion 
failure
+
+  Assertion 'uchunk->index % bq->base == 0' failed at memblockq.c:289,
+function pa_memblockq_push(). Aborting.
+
+Fix oversized block issue by checking proper size of format instead of enum
+value.
+
+Fixes: a67c21f09 ("merge 'lennart' branch back into trunk.")
+Part-of: 

+
+diff --git a/src/pulsecore/resampler.c b/src/pulsecore/resampler.c
+index b035f67ed..ba18c92c4 100644
+--- a/src/pulsecore/resampler.c
 b/src/pulsecore/resampler.c
+@@ -613,9 +613,13 @@ size_t pa_resampler_max_block_size(pa_resampler *r) {
+  * conversion */
+ max_ss.channels = (uint8_t) (PA_MAX(r->i_ss.channels, r->o_ss.channels));
+ 
+-/* We silently assume that the format enum is ordered by size */
+-max_ss.format = PA_MAX(r->i_ss.format, r->o_ss.format);
+-max_ss.format = PA_MAX(max_ss.format, r->work_format);
++max_ss.format = r->i_ss.format;
++
++if (pa_sample_size_of_format(max_ss.format) < 
pa_sample_size_of_format(r->o_ss.format))
++max_ss.format = r->o_ss.format;
++
++if (pa_sample_size_of_format(max_ss.format) < 
pa_sample_size_of_format(r->work_format))
++max_ss.format = r->work_format;
+ 
+ max_ss.rate = PA_MAX(r->i_ss.rate, r->o_ss.rate);
+ 

diff --git a/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.1-r8.ebuild 
b/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.1-r8.ebuild
index 44c1c3c46161..0245469211bc 100644
--- a/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.1-r8.ebuild
+++ b/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.1-r8.ebuild
@@ -167,6 +167,7 @@ PATCHES=(
# alignment fix changes internal abi, added requirement matching 
>=media-libs/libpulse-16.1-r3
"${FILESDIR}"/pulseaudio-16.1-fix-memblock-alignment.patch
"${FILESDIR}"/pulseaudio-16.1-add-more-standard-samplerates.patch
+   "${FILESDIR}"/pulseaudio-16.1-fix-resampler-oversized-memblock.patch
 )
 
 src_prepare() {



[gentoo-commits] repo/gentoo:master commit in: media-sound/pulseaudio-daemon/files/, media-sound/pulseaudio-daemon/

2022-06-17 Thread Sam James
commit: 34c7075aeac33688f7d7758c4f723cdfd8055820
Author: Igor V. Kovalenko  gmail  com>
AuthorDate: Fri Jun 17 23:37:30 2022 +
Commit: Sam James  gentoo  org>
CommitDate: Sat Jun 18 00:18:17 2022 +
URL:https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=34c7075a

media-sound/pulseaudio-daemon: Fix crash using pacmd play-file command

Upstream commit a8a2a31408c4acf54530d65922d235d3e590ce05

Fixes pulseaudio crash when playing a file using pacmd play-file command.

Signed-off-by: Igor V. Kovalenko  gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/25949
Signed-off-by: Sam James  gentoo.org>

 ...pulseaudio-16.0-fix-pacmd-play-file-crash.patch | 42 ++
 .../pulseaudio-daemon-16.0-r5.ebuild   |  1 +
 2 files changed, 43 insertions(+)

diff --git 
a/media-sound/pulseaudio-daemon/files/pulseaudio-16.0-fix-pacmd-play-file-crash.patch
 
b/media-sound/pulseaudio-daemon/files/pulseaudio-16.0-fix-pacmd-play-file-crash.patch
new file mode 100644
index ..f9c044dbb2be
--- /dev/null
+++ 
b/media-sound/pulseaudio-daemon/files/pulseaudio-16.0-fix-pacmd-play-file-crash.patch
@@ -0,0 +1,42 @@
+https://gitlab.freedesktop.org/pulseaudio/pulseaudio/-/commit/a8a2a31408c4acf54530d65922d235d3e590ce05
+
+From a8a2a31408c4acf54530d65922d235d3e590ce05 Mon Sep 17 00:00:00 2001
+From: Jaechul Lee 
+Date: Thu, 2 Jun 2022 15:07:09 +0900
+Subject: [PATCH] sound-file-stream: Fix crash when playing a file which is not
+ aligned
+
+pulseaudio crash occurred when I play a file using pacmd play-file command.
+The file is not aligned with its frame size and the last rendering size
+is also not aligned. Thus, an assertion was generated at the end of the
+file as the following.
+
+memblockq.c: Assertion 'uchunk->length % bq->base == 0' failed at
+../src/pulsecore/memblockq.c:288, function pa_memblockq_push(). Aborting.
+
+When I play the file using paplay, it works good. So, I changed to
+pa_memblockq_push_align instead of pa_memblockq_push to prevent the
+assertion.
+
+Signed-off-by: Jaechul Lee 
+Part-of: 

+---
+ src/pulsecore/sound-file-stream.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/src/pulsecore/sound-file-stream.c 
b/src/pulsecore/sound-file-stream.c
+index 147aa2288..255f4b61a 100644
+--- a/src/pulsecore/sound-file-stream.c
 b/src/pulsecore/sound-file-stream.c
+@@ -185,7 +185,7 @@ static int sink_input_pop_cb(pa_sink_input *i, size_t 
length, pa_memchunk *chunk
+ 
+ tchunk.length = (size_t) n * fs;
+ 
+-pa_memblockq_push(u->memblockq, );
++pa_memblockq_push_align(u->memblockq, );
+ pa_memblock_unref(tchunk.memblock);
+ }
+ 
+-- 
+GitLab
+

diff --git a/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild 
b/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild
index 25e717a28ffa..5e19cc3419c7 100644
--- a/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild
+++ b/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild
@@ -167,6 +167,7 @@ PATCHES=(
"${FILESDIR}"/pulseaudio-16.0-optional-module-console-kit.patch
"${FILESDIR}"/pulseaudio-16.0-fix-combine-sink-underrun-crash.patch
"${FILESDIR}"/pulseaudio-16.0-fix-gstreamer-bluetooth-arm-crash.patch
+   "${FILESDIR}"/pulseaudio-16.0-fix-pacmd-play-file-crash.patch
 )
 
 src_prepare() {



[gentoo-commits] repo/gentoo:master commit in: media-sound/pulseaudio-daemon/files/, media-sound/pulseaudio-daemon/

2022-06-17 Thread Sam James
commit: 3408c976d850bad9d19c1cdc25fbf0851cb9b22d
Author: Igor V. Kovalenko  gmail  com>
AuthorDate: Fri Jun 17 23:37:29 2022 +
Commit: Sam James  gentoo  org>
CommitDate: Sat Jun 18 00:18:16 2022 +
URL:https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=3408c976

media-sound/pulseaudio-daemon: Fix crash after combine-sink underrun

Upstream commit ee8bfb49a271d8a8cafa796c6f9fa84de48a

Closes: https://bugs.gentoo.org/852848
Signed-off-by: Igor V. Kovalenko  gmail.com>
Signed-off-by: Sam James  gentoo.org>

 ...udio-16.0-fix-combine-sink-underrun-crash.patch | 72 ++
 .../pulseaudio-daemon-16.0-r5.ebuild   |  1 +
 2 files changed, 73 insertions(+)

diff --git 
a/media-sound/pulseaudio-daemon/files/pulseaudio-16.0-fix-combine-sink-underrun-crash.patch
 
b/media-sound/pulseaudio-daemon/files/pulseaudio-16.0-fix-combine-sink-underrun-crash.patch
new file mode 100644
index ..d66d75afdfda
--- /dev/null
+++ 
b/media-sound/pulseaudio-daemon/files/pulseaudio-16.0-fix-combine-sink-underrun-crash.patch
@@ -0,0 +1,72 @@
+https://gitlab.freedesktop.org/pulseaudio/pulseaudio/-/commit/ee8bfb49a271d8a8cafa796c6f9fa84de48a
+
+From ee8bfb49a271d8a8cafa796c6f9fa84de48a Mon Sep 17 00:00:00 2001
+From: Georg Chini 
+Date: Fri, 17 Jun 2022 13:11:11 +0200
+Subject: [PATCH] combine-sink: Fix threading issue during underrun
+
+A recent commit added i->origin sink for the sink inputs of the combine sinks.
+Therefore pa_sink_process_input_underruns() treated the combine sink like
+filter sinks. pa_sink_process_input_underruns() calls itself with the
+origin sink, which is only correct for filter sinks because they run in the
+thread context of the origin sink. The combine sink however has its own
+thread context, so pa_sink_process_input_underruns() was executed in the
+wrong context.
+This patch fixes the issue by skipping the section for module-combine-sink.
+
+Part-of: 

+---
+ src/pulsecore/sink.c | 37 +++--
+ 1 file changed, 23 insertions(+), 14 deletions(-)
+
+diff --git a/src/pulsecore/sink.c b/src/pulsecore/sink.c
+index 3108ae765..0f0dc56fc 100644
+--- a/src/pulsecore/sink.c
 b/src/pulsecore/sink.c
+@@ -1016,20 +1016,29 @@ size_t pa_sink_process_input_underruns(pa_sink *s, 
size_t left_to_play) {
+ if (i->origin_sink) {
+ size_t filter_result, left_to_play_origin;
+ 
+-/* The recursive call works in the origin sink domain ... */
+-left_to_play_origin = pa_convert_size(left_to_play, 
>sink->sample_spec, >origin_sink->sample_spec);
+-
+-/* .. and returns the time to sleep before waking up. We need the
+- * underrun duration for comparisons, so we undo the subtraction 
on
+- * the return value... */
+-filter_result = left_to_play_origin - 
pa_sink_process_input_underruns(i->origin_sink, left_to_play_origin);
+-
+-/* ... and convert it back to the master sink domain */
+-filter_result = pa_convert_size(filter_result, 
>origin_sink->sample_spec, >sink->sample_spec);
+-
+-/* Remember the longest underrun so far */
+-if (filter_result > result)
+-result = filter_result;
++/* The combine sink sets i->origin sink but has a different 
threading model
++ * than the filter sinks. Therefore the recursion below may not 
be executed
++ * because pa_sink_process_input_underruns() was not called in 
the thread
++ * context of the origin sink.
++ * FIXME: It is unclear if some other kind of recursion would be 
necessary
++ * for the combine sink. */
++if (!i->module || !pa_safe_streq(i->module->name, 
"module-combine-sink")) {
++
++/* The recursive call works in the origin sink domain ... */
++left_to_play_origin = pa_convert_size(left_to_play, 
>sink->sample_spec, >origin_sink->sample_spec);
++
++/* .. and returns the time to sleep before waking up. We need 
the
++ * underrun duration for comparisons, so we undo the 
subtraction on
++ * the return value... */
++filter_result = left_to_play_origin - 
pa_sink_process_input_underruns(i->origin_sink, left_to_play_origin);
++
++/* ... and convert it back to the master sink domain */
++filter_result = pa_convert_size(filter_result, 
>origin_sink->sample_spec, >sink->sample_spec);
++
++/* Remember the longest underrun so far */
++if (filter_result > result)
++result = filter_result;
++}
+ }
+ 
+ if (uf == 0) {
+-- 
+GitLab
+

diff --git a/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild 
b/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild

[gentoo-commits] repo/gentoo:master commit in: media-sound/pulseaudio-daemon/files/, media-sound/pulseaudio-daemon/

2022-06-17 Thread Sam James
commit: 18059c099d4073d0708d9e40c16ebc974df86aff
Author: Igor V. Kovalenko  gmail  com>
AuthorDate: Fri Jun 17 23:37:30 2022 +
Commit: Sam James  gentoo  org>
CommitDate: Sat Jun 18 00:18:17 2022 +
URL:https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=18059c09

media-sound/pulseaudio-daemon: Fix gstreamer bluetooth crash on 32-bit ARM

Upstream commit dd4dc5e8bce2c03631c3613dbddee1a691bdd17d

Fixes pulseaudio crash on ARM 32-bit when pulseaudio is compiled with
gstreamer and either LDAC or aptX support is available.

Signed-off-by: Igor V. Kovalenko  gmail.com>
Signed-off-by: Sam James  gentoo.org>

 ...io-16.0-fix-gstreamer-bluetooth-arm-crash.patch | 43 ++
 .../pulseaudio-daemon-16.0-r5.ebuild   |  1 +
 2 files changed, 44 insertions(+)

diff --git 
a/media-sound/pulseaudio-daemon/files/pulseaudio-16.0-fix-gstreamer-bluetooth-arm-crash.patch
 
b/media-sound/pulseaudio-daemon/files/pulseaudio-16.0-fix-gstreamer-bluetooth-arm-crash.patch
new file mode 100644
index ..a2efaf37b381
--- /dev/null
+++ 
b/media-sound/pulseaudio-daemon/files/pulseaudio-16.0-fix-gstreamer-bluetooth-arm-crash.patch
@@ -0,0 +1,43 @@
+https://gitlab.freedesktop.org/pulseaudio/pulseaudio/-/commit/dd4dc5e8bce2c03631c3613dbddee1a691bdd17d
+
+From dd4dc5e8bce2c03631c3613dbddee1a691bdd17d Mon Sep 17 00:00:00 2001
+From: Jan Palus 
+Date: Fri, 17 Jun 2022 14:36:36 +0200
+Subject: [PATCH] bluetooth/gst: Correct var type for GST_TYPE_BITMASK
+
+GST_TYPE_BITMASK is 64-bit bit mask while corresponding channel_mask in
+pulseaudio is int therefore usually 32-bit. Switch to uint64_t instead
+to match internal representation in gstreamer.
+
+Fixes pulseaudio crash on ARM 32-bit when pulseaudio is compiled with
+gstreamer and either LDAC or aptX support is available.
+
+Part-of: 

+---
+ src/modules/bluetooth/a2dp-codec-gst.c | 3 ++-
+ 1 file changed, 2 insertions(+), 1 deletion(-)
+
+diff --git a/src/modules/bluetooth/a2dp-codec-gst.c 
b/src/modules/bluetooth/a2dp-codec-gst.c
+index 8ef74be9c..11839c580 100644
+--- a/src/modules/bluetooth/a2dp-codec-gst.c
 b/src/modules/bluetooth/a2dp-codec-gst.c
+@@ -22,6 +22,7 @@
+ #endif
+ 
+ #include 
++#include 
+ 
+ #include 
+ #include 
+@@ -82,7 +83,7 @@ fail:
+ static GstCaps *gst_create_caps_from_sample_spec(const pa_sample_spec *ss) {
+ gchar *sample_format;
+ GstCaps *caps;
+-int channel_mask;
++uint64_t channel_mask;
+ 
+ switch (ss->format) {
+ case PA_SAMPLE_S16LE:
+-- 
+GitLab
+

diff --git a/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild 
b/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild
index c6b1b5a0b623..25e717a28ffa 100644
--- a/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild
+++ b/media-sound/pulseaudio-daemon/pulseaudio-daemon-16.0-r5.ebuild
@@ -166,6 +166,7 @@ PATCHES=(
"${FILESDIR}"/pulseaudio-16.0-fix-rtp-receiver-sdp-record.patch
"${FILESDIR}"/pulseaudio-16.0-optional-module-console-kit.patch
"${FILESDIR}"/pulseaudio-16.0-fix-combine-sink-underrun-crash.patch
+   "${FILESDIR}"/pulseaudio-16.0-fix-gstreamer-bluetooth-arm-crash.patch
 )
 
 src_prepare() {



[gentoo-commits] repo/gentoo:master commit in: media-sound/pulseaudio-daemon/files/, media-sound/pulseaudio-daemon/

2022-04-28 Thread Sam James
commit: d5453db8e7aec0b61f772a7b76e3400f1d8b
Author: Igor V. Kovalenko  gmail  com>
AuthorDate: Tue Apr 26 21:55:30 2022 +
Commit: Sam James  gentoo  org>
CommitDate: Thu Apr 28 15:59:52 2022 +
URL:https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d5453db8

media-sound/pulseaudio-daemon: Daemon part of split autospawn implementation

Now that libpulse has daemon autospawn disabled, enable it back
for systems without systemd when pulseaudio-daemon is installed.

Signed-off-by: Igor V. Kovalenko  gmail.com>
Closes: https://github.com/gentoo/gentoo/pull/25207
Signed-off-by: Sam James  gentoo.org>

 media-sound/pulseaudio-daemon/files/enable-autospawn.conf   | 2 ++
 ...io-daemon-15.99.1.ebuild => pulseaudio-daemon-15.99.1-r1.ebuild} | 6 ++
 2 files changed, 8 insertions(+)

diff --git a/media-sound/pulseaudio-daemon/files/enable-autospawn.conf 
b/media-sound/pulseaudio-daemon/files/enable-autospawn.conf
new file mode 100644
index ..5681459a32cd
--- /dev/null
+++ b/media-sound/pulseaudio-daemon/files/enable-autospawn.conf
@@ -0,0 +1,2 @@
+# Enable automatic spawning of pulseaudio daemon
+autospawn = yes

diff --git a/media-sound/pulseaudio-daemon/pulseaudio-daemon-15.99.1.ebuild 
b/media-sound/pulseaudio-daemon/pulseaudio-daemon-15.99.1-r1.ebuild
similarity index 97%
rename from media-sound/pulseaudio-daemon/pulseaudio-daemon-15.99.1.ebuild
rename to media-sound/pulseaudio-daemon/pulseaudio-daemon-15.99.1-r1.ebuild
index 71655e65efbd..19134e3b2752 100644
--- a/media-sound/pulseaudio-daemon/pulseaudio-daemon-15.99.1.ebuild
+++ b/media-sound/pulseaudio-daemon/pulseaudio-daemon-15.99.1-r1.ebuild
@@ -272,6 +272,12 @@ src_install() {
|| die
fi
 
+   # Only enable autospawning pulseaudio daemon on systems without systemd
+   if ! use systemd; then
+   insinto /etc/pulse/client.conf.d
+   newins "${FILESDIR}/enable-autospawn.conf" 
"enable-autospawn.conf"
+   fi
+
find "${ED}" \( -name '*.a' -o -name '*.la' \) -delete || die
 }