mirror of
https://git.FreeBSD.org/ports.git
synced 2024-12-22 04:17:44 +00:00
mail/thunderbird: Backport sndio volume handling fix
https://bugzilla.mozilla.org/show_bug.cgi?id=1467882 PR: 229135 Approved by: gecko (jbeich)
This commit is contained in:
parent
ff8ff58f05
commit
faea41af6d
Notes:
svn2git
2021-03-31 03:12:20 +00:00
svn path=/head/; revision=473631
@ -3,7 +3,7 @@
|
||||
|
||||
PORTNAME= thunderbird
|
||||
DISTVERSION= 52.8.0
|
||||
PORTREVISION= 6
|
||||
PORTREVISION= 7
|
||||
CATEGORIES= mail news net-im ipv6
|
||||
MASTER_SITES= MOZILLA/${PORTNAME}/releases/${DISTVERSION}/source \
|
||||
MOZILLA/${PORTNAME}/candidates/${DISTVERSION}-candidates/build1/source
|
||||
|
70
mail/thunderbird/files/patch-bug1467882
Normal file
70
mail/thunderbird/files/patch-bug1467882
Normal file
@ -0,0 +1,70 @@
|
||||
--- mozilla/media/libcubeb/src/cubeb_sndio.c.orig 2018-04-04 00:35:17 UTC
|
||||
+++ mozilla/media/libcubeb/src/cubeb_sndio.c
|
||||
@@ -43,17 +43,33 @@ struct cubeb_stream {
|
||||
cubeb_data_callback data_cb; /* cb to preapare data */
|
||||
cubeb_state_callback state_cb; /* cb to notify about state changes */
|
||||
void *arg; /* user arg to {data,state}_cb */
|
||||
+ float volume; /* current volume */
|
||||
};
|
||||
|
||||
static void
|
||||
-float_to_s16(void *ptr, long nsamp)
|
||||
+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 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 +127,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 +278,7 @@ sndio_stream_init(cubeb * context,
|
||||
free(s);
|
||||
return CUBEB_ERROR;
|
||||
}
|
||||
+ s->volume = 1.;
|
||||
*stream = s;
|
||||
DPR("sndio_stream_init() end, ok\n");
|
||||
(void)context;
|
||||
@@ -346,7 +365,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.)
|
||||
+ volume = 0.;
|
||||
+ else if (volume > 1.0)
|
||||
+ volume = 1.;
|
||||
+ s->volume = volume;
|
||||
pthread_mutex_unlock(&s->mtx);
|
||||
return CUBEB_OK;
|
||||
}
|
Loading…
Reference in New Issue
Block a user