Skip to content

Commit

Permalink
WIP: notes and findings
Browse files Browse the repository at this point in the history
The initial stackAlloc() is overflowing, seeming to need more space so this is accounted for.
  • Loading branch information
cwoffenden committed Oct 31, 2024
1 parent dd89a23 commit 37ec067
Showing 1 changed file with 2 additions and 1 deletion.
3 changes: 2 additions & 1 deletion src/audio_worklet.js
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ function createWasmAudioWorkletProcessor(audioParams) {
// may be required (with an arbitrary maximum of 16, for the case where a
// multi-MB stack is passed), allocated at the *top* of the worklet's
// stack (and whose addresses are fixed).
this.maxBuffers = Math.min((Module['sz'] / (this.samplesPerChannel * 4)) | 0, /*sensible limit*/ 16);
this.maxBuffers = Math.min(((Module['sz'] - /*stack guards?*/ 16) / (this.samplesPerChannel * 4)) | 0, /*sensible limit*/ 16);
// These are still alloc'd to take advantage of the overflow checks, etc.
var oldStackPtr = stackSave();
var viewDataIdx = stackAlloc(this.maxBuffers * this.samplesPerChannel * 4) >> 2;
Expand Down Expand Up @@ -144,6 +144,7 @@ function createWasmAudioWorkletProcessor(audioParams) {
}

#if ASSERTIONS
// TODO: addresses are now wrong
k = outputDataPtr;
for (i = outputViewsNeeded - 1; i >= 0; i--) {
console.assert(this.outputViews[i].byteOffset == k, 'Internal error in addresses of the output array views');
Expand Down

0 comments on commit 37ec067

Please sign in to comment.