[PATCH/RFC 1/1] sink-input: always validate sample specs

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Eero Nurkkala <eero.nurkkala@xxxxxxxxxx>

It's not guaranteed 'ss' has a valid set of data in itself. Occasionally
it may contain data that makes the pulseaudio not usable at all. In that
particular scenario, pulseaudio rejects all requests into it. If the
data isn't valid, it better not be used:

I  [pulseaudio] protocol-native.c: Client authenticated anonymously.
D  [pulseaudio] protocol-dbus.c: Interface org.PulseAudio.Core1.Client added for object /org/pulseaudio/core1/client2
D  [pulseaudio] protocol-native.c: Protocol version: remote 23, local 23
D  [pulseaudio] protocol-native.c: SHM possible: no
D  [pulseaudio] protocol-native.c: Negotiated SHM: no
D  [pulseaudio] sink-input.c: Assertion 'pa_sample_spec_valid(&data->sample_spec)' failed at pulsecore/sink-input.c:312, function pa_sink_input_new.

Signed-off-by: Eero Nurkkala <eero.nurkkala at offcode.fi>
---
Note: This has been tested on version 1.1 only, but looks like the logic
hasn't changed. Could be I'm doing something wrong, but things appears to
work better with the patch.
 src/pulsecore/sink-input.c |    3 ++-
 1 files changed, 2 insertions(+), 1 deletions(-)

diff --git a/src/pulsecore/sink-input.c b/src/pulsecore/sink-input.c
index f6f7324..d134056 100644
--- a/src/pulsecore/sink-input.c
+++ b/src/pulsecore/sink-input.c
@@ -293,7 +293,8 @@ int pa_sink_input_new(
     /* Now populate the sample spec and format according to the final
      * format that we've negotiated */
     pa_return_val_if_fail(pa_format_info_to_sample_spec(data->format, &ss, &map) == 0, -PA_ERR_INVALID);
-    pa_sink_input_new_data_set_sample_spec(data, &ss);
+    if (pa_sample_spec_valid(&ss))
+        pa_sink_input_new_data_set_sample_spec(data, &ss);
     if (pa_format_info_is_pcm(data->format) && pa_channel_map_valid(&map))
         pa_sink_input_new_data_set_channel_map(data, &map);
 
-- 
1.7.4.1



[Index of Archives]     [Linux Audio Users]     [AMD Graphics]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux