From 127c72d6dffdf840e8e8dd70170ad1a412391ad6 Mon Sep 17 00:00:00 2001 From: Matthew Firth Date: Tue, 27 Feb 2024 21:31:40 +0000 Subject: [PATCH] Fix buffer alignment issue using 64ch versions of DAW --- .../plugins/scene/src/scene_plugin_processor.cpp | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/ear-production-suite-plugins/plugins/scene/src/scene_plugin_processor.cpp b/ear-production-suite-plugins/plugins/scene/src/scene_plugin_processor.cpp index 32cc28c8..f63c103e 100644 --- a/ear-production-suite-plugins/plugins/scene/src/scene_plugin_processor.cpp +++ b/ear-production-suite-plugins/plugins/scene/src/scene_plugin_processor.cpp @@ -144,7 +144,7 @@ void SceneAudioProcessor::processBlock(AudioBuffer& buffer, } } else { size_t sampleSize = sizeof(float); - uint8_t numChannels = numDawChannels_; + uint8_t numChannels = MAX_DAW_CHANNELS; size_t msg_size = buffer.getNumSamples() * numChannels * sampleSize; auto msg = std::make_shared(msg_size); @@ -156,9 +156,12 @@ void SceneAudioProcessor::processBlock(AudioBuffer& buffer, int bufferChannels = buffer.getNumChannels(); int bufferSamplesPerChannel = buffer.getNumSamples(); + // TODO: We could do with a better system than sending channels of blanks, + // but at least this way we don't need to worry about DAW channel limits + // and routings in to the Scene. for (int sample = 0; sample < bufferSamplesPerChannel; ++sample) { for (int channel = 0; channel < numChannels; ++channel) { - curSample = buffer.getSample(channel, sample); + curSample = channel < bufferChannels? buffer.getSample(channel, sample) : 0.f; assert(msgPosOffset + sampleSize <= msg_size); memcpy(msgPosPtr + msgPosOffset, &curSample, sampleSize); msgPosOffset += sampleSize;