summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLennart Poettering <lennart@poettering.net>2009-03-30 19:15:39 +0200
committerLennart Poettering <lennart@poettering.net>2009-03-30 19:15:39 +0200
commit1743322d3e184d57a80cd58e9bcfb0bf01bd4c67 (patch)
tree4f9315ff43c6b3767ca6cf128b3066014cdb062e
parent061344fbd78f4a643f4e2a12b24c5d1ae1622e04 (diff)
parent205cbe8afcf83ac7392b90ba8c73f40b798104c6 (diff)
Merge commit 'coling/master'
-rw-r--r--src/modules/module-raop-sink.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/modules/module-raop-sink.c b/src/modules/module-raop-sink.c
index 00f0c63c..d8ddf184 100644
--- a/src/modules/module-raop-sink.c
+++ b/src/modules/module-raop-sink.c
@@ -135,13 +135,22 @@ enum {
/* Forward declaration */
static void sink_set_volume_cb(pa_sink *);
-static void on_connection(PA_GCC_UNUSED int fd, void*userdata) {
+static void on_connection(int fd, void*userdata) {
+ int so_sndbuf = 0;
+ socklen_t sl = sizeof(int);
struct userdata *u = userdata;
pa_assert(u);
pa_assert(u->fd < 0);
u->fd = fd;
+ if (getsockopt(u->fd, SOL_SOCKET, SO_SNDBUF, &so_sndbuf, &sl) < 0)
+ pa_log_warn("getsockopt(SO_SNDBUF) failed: %s", pa_cstrerror(errno));
+ else {
+ pa_log_debug("SO_SNDBUF is %zu.", (size_t) so_sndbuf);
+ pa_sink_set_max_request(u->sink, PA_MAX((size_t) so_sndbuf, u->block_size));
+ }
+
/* Set the initial volume */
sink_set_volume_cb(u->sink);