summaryrefslogtreecommitdiffstats
path: root/sesman/chansrv
diff options
context:
space:
mode:
authorJay Sorg <jay.sorg@gmail.com>2014-11-26 16:48:37 -0800
committerJay Sorg <jay.sorg@gmail.com>2014-11-26 16:48:37 -0800
commitbff2009147c3262024c0ac20347ea55c6d4369be (patch)
tree93972103ae329c024d33b5b19485276699726903 /sesman/chansrv
parent2d514e666afdccdf370cfc92fa284b3fa4492824 (diff)
downloadxrdp-proprietary-bff2009147c3262024c0ac20347ea55c6d4369be.tar.gz
xrdp-proprietary-bff2009147c3262024c0ac20347ea55c6d4369be.zip
chansrv: change to 44100 recording, disconnect / reconnect fixes
Diffstat (limited to 'sesman/chansrv')
-rw-r--r--sesman/chansrv/pulse/module-xrdp-source.c55
-rw-r--r--sesman/chansrv/sound.c13
2 files changed, 52 insertions, 16 deletions
diff --git a/sesman/chansrv/pulse/module-xrdp-source.c b/sesman/chansrv/pulse/module-xrdp-source.c
index 3d73fd03..37c0bb4e 100644
--- a/sesman/chansrv/pulse/module-xrdp-source.c
+++ b/sesman/chansrv/pulse/module-xrdp-source.c
@@ -174,6 +174,7 @@ static int data_get(struct userdata *u, pa_memchunk *chunk) {
int fd;
int bytes;
+ int read_bytes;
struct sockaddr_un s;
char *data;
char buf[11];
@@ -216,7 +217,12 @@ static int data_get(struct userdata *u, pa_memchunk *chunk) {
buf[9] = 0;
buf[10] = 0;
- lsend(u->fd, buf, 11);
+ if (lsend(u->fd, buf, 11) != 11) {
+ close(u->fd);
+ u->fd = 0;
+ pa_memblock_release(chunk->memblock);
+ return -1;
+ }
u->want_src_data = 1;
pa_log_debug("###### started recording");
}
@@ -234,10 +240,22 @@ static int data_get(struct userdata *u, pa_memchunk *chunk) {
buf[9] = (unsigned char) chunk->length;
buf[10] = (unsigned char) ((chunk->length >> 8) & 0xff);
- lsend(u->fd, buf, 11);
+ if (lsend(u->fd, buf, 11) != 11) {
+ close(u->fd);
+ u->fd = 0;
+ pa_memblock_release(chunk->memblock);
+ u->want_src_data = 0;
+ return -1;
+ }
/* read length of data available */
- lrecv(u->fd, (char *) ubuf, 2);
+ if (lrecv(u->fd, (char *) ubuf, 2) != 2) {
+ close(u->fd);
+ u->fd = 0;
+ pa_memblock_release(chunk->memblock);
+ u->want_src_data = 0;
+ return -1;
+ }
bytes = ((ubuf[1] << 8) & 0xff00) | (ubuf[0] & 0xff);
if (bytes == 0) {
@@ -246,15 +264,22 @@ static int data_get(struct userdata *u, pa_memchunk *chunk) {
}
/* get data */
- bytes = lrecv(u->fd, data, bytes);
-
+ read_bytes = lrecv(u->fd, data, bytes);
+ if (read_bytes != bytes) {
+ close(u->fd);
+ u->fd = 0;
+ pa_memblock_release(chunk->memblock);
+ u->want_src_data = 0;
+ return -1;
+ }
pa_memblock_release(chunk->memblock);
- return bytes;
+ return read_bytes;
}
static void thread_func(void *userdata) {
struct userdata *u = userdata;
+ int bytes;
pa_assert(u);
pa_thread_mq_install(&u->thread_mq);
@@ -271,10 +296,15 @@ static void thread_func(void *userdata) {
now = pa_rtclock_now();
if ((chunk.length = pa_usec_to_bytes(now - u->timestamp, &u->source->sample_spec)) > 0) {
- chunk.memblock = pa_memblock_new(u->core->mempool, (size_t) -1); /* or chunk.length? */
+ chunk.length *= 4;
+ chunk.memblock = pa_memblock_new(u->core->mempool, chunk.length);
chunk.index = 0;
- data_get(u, &chunk);
- pa_source_post(u->source, &chunk);
+ bytes = data_get(u, &chunk);
+ if (bytes > 0)
+ {
+ chunk.length = bytes;
+ pa_source_post(u->source, &chunk);
+ }
pa_memblock_unref(chunk.memblock);
u->timestamp = now;
}
@@ -298,7 +328,10 @@ static void thread_func(void *userdata) {
buf[9] = 0;
buf[10] = 0;
- lsend(u->fd, buf, 11);
+ if (lsend(u->fd, buf, 11) != 11) {
+ close(u->fd);
+ u->fd = 0;
+ }
u->want_src_data = 0;
pa_log_debug("###### stopped recording");
}
@@ -338,7 +371,7 @@ int pa__init(pa_module *m) {
goto fail;
}
-#if 0
+#if 1
ss = m->core->default_sample_spec;
#else
ss.format = PA_SAMPLE_S16LE;
diff --git a/sesman/chansrv/sound.c b/sesman/chansrv/sound.c
index 6281969b..e0628a87 100644
--- a/sesman/chansrv/sound.c
+++ b/sesman/chansrv/sound.c
@@ -140,8 +140,8 @@ static struct xr_wave_format_ex g_pcm_inp_44100 =
#define SND_NUM_INP_FORMATS 2
static struct xr_wave_format_ex *g_wave_inp_formats[SND_NUM_INP_FORMATS] =
{
- &g_pcm_inp_22050,
- &g_pcm_inp_44100
+ &g_pcm_inp_44100,
+ &g_pcm_inp_22050
};
static int g_client_input_format_index = 0;
@@ -960,7 +960,7 @@ sound_process_input_format(int aindex, int wFormatTag, int nChannels,
LOG(10, (" wBitsPerSample %d", wBitsPerSample));
LOG(10, (" cbSize %d", cbSize));
-#if 0
+#if 1
/* select CD quality audio */
if (wFormatTag == g_pcm_inp_44100.wFormatTag &&
nChannels == g_pcm_inp_44100.nChannels &&
@@ -1047,7 +1047,9 @@ sound_input_start_recording(void)
/* if there is any data in FIFO, discard it */
while ((s = (struct stream *) fifo_remove(&g_in_fifo)) != NULL)
+ {
xstream_free(s);
+ }
g_bytes_in_fifo = 0;
xstream_new(s, 1024);
@@ -1110,14 +1112,15 @@ sound_process_input_data(struct stream *s, int bytes)
{
struct stream *ls;
- LOG(0, ("sound_process_input_data: bytes %d g_bytes_in_fifo %d",
+ LOG(10, ("sound_process_input_data: bytes %d g_bytes_in_fifo %d",
bytes, g_bytes_in_fifo));
-
+#if 0 /* no need to cap anymore */
/* cap data in fifo */
if (g_bytes_in_fifo > 8 * 1024)
{
return 0;
}
+#endif
xstream_new(ls, bytes);
g_memcpy(ls->data, s->p, bytes);
ls->p += bytes;