From cb4244b0052890c88b23ac639fa50b5f803db0ad Mon Sep 17 00:00:00 2001 From: derselbst Date: Sun, 8 Sep 2024 13:52:40 +0200 Subject: [PATCH] Fix modLfoToVol behavior --- src/utils/fluid_conv.c | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/src/utils/fluid_conv.c b/src/utils/fluid_conv.c index 28740ea4f..659625da0 100644 --- a/src/utils/fluid_conv.c +++ b/src/utils/fluid_conv.c @@ -111,9 +111,20 @@ fluid_cb2amp(fluid_real_t cb) */ /* minimum attenuation: 0 dB */ - if(cb < 0) + if(FLUID_UNLIKELY(cb < 0)) { - return 1.0; + /* Issue #1374: it seems that by using modLfoToVolEnv, the attenuation can become negative and + * therefore the signal needs to be amplified. + * In such a rare case, calculate the attenuation on the fly. + * + * This behavior is backed by the spec saying: + * modLfoToVolume: "A positive number indicates a positive LFO excursion increases volume; + * a negative number indicates a positive excursion decreases volume. + * [...] For example, a value of 100 indicates that the volume will first rise ten dB, then fall ten dB." + * + * And in order to rise, a negative attenuation must be permitted. + */ + return FLUID_POW(10.0f, cb / -200.0f); } if(cb >= FLUID_CB_AMP_SIZE)