aboutsummaryrefslogtreecommitdiff
path: root/src/chips/opl_chip_base.cpp
diff options
context:
space:
mode:
authorVitaly Novichkov <Wohlstand@users.noreply.github.com>2018-04-13 02:32:14 +0300
committerGitHub <noreply@github.com>2018-04-13 02:32:14 +0300
commit5c0cd9d1902d3d174ac7edd67a6c201b522cd47e (patch)
treeb333fc755c776db7ff9db02225dc1a5cb277159e /src/chips/opl_chip_base.cpp
parent147822b9c45dbbc063a42280d4f5d8183662a163 (diff)
parent4eedcaafb9eba8d246b21e0471d44bdc9f254125 (diff)
downloadlibADLMIDI-5c0cd9d1902d3d174ac7edd67a6c201b522cd47e.tar.gz
libADLMIDI-5c0cd9d1902d3d174ac7edd67a6c201b522cd47e.tar.bz2
libADLMIDI-5c0cd9d1902d3d174ac7edd67a6c201b522cd47e.zip
Merge pull request #58 from jpcima/chipbase32bit
general 32bit generator methods, like OPNMIDI
Diffstat (limited to 'src/chips/opl_chip_base.cpp')
-rw-r--r--src/chips/opl_chip_base.cpp30
1 files changed, 30 insertions, 0 deletions
diff --git a/src/chips/opl_chip_base.cpp b/src/chips/opl_chip_base.cpp
index 65d4b73..4a7c4f5 100644
--- a/src/chips/opl_chip_base.cpp
+++ b/src/chips/opl_chip_base.cpp
@@ -20,3 +20,33 @@ void OPLChipBase::reset(uint32_t rate)
{
setRate(rate);
}
+
+int OPLChipBase::generate32(int32_t *output, size_t frames)
+{
+ enum { maxFramesAtOnce = 256 };
+ int16_t temp[2 * maxFramesAtOnce];
+ for(size_t left = frames; left > 0;) {
+ size_t count = (left < maxFramesAtOnce) ? left : maxFramesAtOnce;
+ generate(temp, count);
+ for(size_t i = 0; i < 2 * count; ++i)
+ output[i] = temp[i];
+ left -= count;
+ output += 2 * count;
+ }
+ return (int)frames;
+}
+
+int OPLChipBase::generateAndMix32(int32_t *output, size_t frames)
+{
+ enum { maxFramesAtOnce = 256 };
+ int16_t temp[2 * maxFramesAtOnce];
+ for(size_t left = frames; left > 0;) {
+ size_t count = (left < maxFramesAtOnce) ? left : maxFramesAtOnce;
+ generate(temp, count);
+ for(size_t i = 0; i < 2 * count; ++i)
+ output[i] += temp[i];
+ left -= count;
+ output += 2 * count;
+ }
+ return (int)frames;
+}