Commit 05357d9f authored by David Reid's avatar David Reid Committed by GitHub

Merge pull request #219 from HiberWorld/bugfix/intermediary-buffer-ref

Fix intermediaryBufferView losing reference to wasm memory after heap resize
parents 244182b3 56d22ae3
......@@ -31283,6 +31283,11 @@ static ma_result ma_device_init_by_type__webaudio(ma_context* pContext, const ma
return; /* This means the device has been uninitialized. */
}
if(device.intermediaryBufferView.length == 0) {
/* Recreate intermediaryBufferView when losing reference to the underlying buffer, probably due to emscripten resizing heap. */
device.intermediaryBufferView = new Float32Array(Module.HEAPF32.buffer, device.intermediaryBuffer, device.intermediaryBufferSizeInBytes);
}
/* Make sure silence it output to the AudioContext destination. Not doing this will cause sound to come out of the speakers! */
for (var iChannel = 0; iChannel < e.outputBuffer.numberOfChannels; ++iChannel) {
e.outputBuffer.getChannelData(iChannel).fill(0.0);
......@@ -31343,6 +31348,11 @@ static ma_result ma_device_init_by_type__webaudio(ma_context* pContext, const ma
return; /* This means the device has been uninitialized. */
}
if(device.intermediaryBufferView.length == 0) {
/* Recreate intermediaryBufferView when losing reference to the underlying buffer, probably due to emscripten resizing heap. */
device.intermediaryBufferView = new Float32Array(Module.HEAPF32.buffer, device.intermediaryBuffer, device.intermediaryBufferSizeInBytes);
}
var outputSilence = false;
/* Sanity check. This will never happen, right? */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment