diff options
author | Moonchild <moonchild@palemoon.org> | 2022-06-28 09:19:07 +0000 |
---|---|---|
committer | Moonchild <moonchild@palemoon.org> | 2022-06-28 09:19:07 +0000 |
commit | 00514219902afaef5b914c5bedacf57be51d68be (patch) | |
tree | d639460f5898cea43d1e32f345a6aac7507cbff0 /media | |
parent | 58e418aeb04de7acd7e895a12c7ccfa247396863 (diff) | |
parent | 79e782e53f4ad38e924bf891f439f442ae818fe8 (diff) | |
download | uxp-00514219902afaef5b914c5bedacf57be51d68be.tar.gz |
Merge pull request 'Fix volume handling in sndio backend.' (#1945) from jobbautista9/UXP:sndio-volumehandling into master
Untested by me but assuming this all works as it's straightforward enough of a change otherwise.
Diffstat (limited to 'media')
-rw-r--r-- | media/libcubeb/src/cubeb_sndio.c | 32 |
1 files changed, 28 insertions, 4 deletions
diff --git a/media/libcubeb/src/cubeb_sndio.c b/media/libcubeb/src/cubeb_sndio.c index c7ac184465..320b4212f5 100644 --- a/media/libcubeb/src/cubeb_sndio.c +++ b/media/libcubeb/src/cubeb_sndio.c @@ -42,18 +42,35 @@ struct cubeb_stream { uint64_t wrpos; /* number of written frames */ cubeb_data_callback data_cb; /* cb to preapare data */ cubeb_state_callback state_cb; /* cb to notify about state changes */ + float volume; /* current volume */ void *arg; /* user arg to {data,state}_cb */ }; + +static void +s16_setvol(void *ptr, long nsamp, float volume) +{ + int16_t *dst = ptr; + int32_t mult = volume * 32768; + int32_t s; + + while (nsamp-- > 0) { + s = *dst; + s = (s * mult) >> 15; + *(dst++) = s; + } +} + static void -float_to_s16(void *ptr, long nsamp) +float_to_s16(void *ptr, long nsamp, float volume) { int16_t *dst = ptr; float *src = ptr; + float mult = volume * 32768; int s; while (nsamp-- > 0) { - s = lrintf(*(src++) * 32768); + s = lrintf(*(src++) * mult); if (s < -32768) s = -32768; else if (s > 32767) @@ -111,7 +128,9 @@ sndio_mainloop(void *arg) break; } if (s->conv) - float_to_s16(s->buf, nfr * s->pchan); + float_to_s16(s->buf, nfr * s->pchan, s->volume); + else + s16_setvol(s->buf, nfr * s->pchan, s->volume); start = 0; end = nfr * s->bpf; } @@ -260,6 +279,7 @@ sndio_stream_init(cubeb * context, free(s); return CUBEB_ERROR; } + s->volume = 1.0; *stream = s; DPR("sndio_stream_init() end, ok\n"); (void)context; @@ -346,7 +366,11 @@ sndio_stream_set_volume(cubeb_stream *s, float volume) { DPR("sndio_stream_set_volume(%f)\n", volume); pthread_mutex_lock(&s->mtx); - sio_setvol(s->hdl, SIO_MAXVOL * volume); + if (volume < 0.0) + volume = 0.0; + else if (volume > 1.0) + volume = 1.0; + s->volume = volume; pthread_mutex_unlock(&s->mtx); return CUBEB_OK; } |