Skip to content

Commit

Permalink
Fix WT-length-one clamp error
Browse files Browse the repository at this point in the history
In recent versions we allowed wavetables of length one
but when doing so missed this clamp which resulted in
hi < lo. that is UB (but defacto clamped to low) but
that inversion triggers an assert on some configurations.

So (1) add a debug assert to our limit range and (2) use a max of
0 on the upper bound.

Closes surge-synthesizer#6702
  • Loading branch information
baconpaul committed Nov 20, 2022
1 parent 70aca67 commit 66a9062
Show file tree
Hide file tree
Showing 2 changed files with 2 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/common/dsp/oscillators/WavetableOscillator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ void WavetableOscillator::init(float pitch, bool is_display, bool nonzero_init_d
float intpart;
shape *= ((float)oscdata->wt.n_tables - 1.f + nointerp) * 0.99999f;
tableipol = modff(shape, &intpart);
tableid = limit_range((int)intpart, 0, (int)oscdata->wt.n_tables - 2 + nointerp);
tableid = limit_range((int)intpart, 0, std::max((int)oscdata->wt.n_tables - 2 + nointerp, 0));
last_tableipol = tableipol;
last_tableid = tableid;
hskew = 0.f;
Expand Down
1 change: 1 addition & 0 deletions src/common/dsp/vembertech/basic_dsp.h
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

template <typename T> inline T limit_range(const T &x, const T &low, const T &high)
{
assert(low <= high);
return std::clamp(x, low, high);
}

Expand Down

0 comments on commit 66a9062

Please sign in to comment.