aboutsummaryrefslogtreecommitdiff
path: root/src/chips/dosbox_opl3.cpp
diff options
context:
space:
mode:
authorVitaly Novichkov <Wohlstand@users.noreply.github.com>2018-04-11 23:19:24 +0300
committerGitHub <noreply@github.com>2018-04-11 23:19:24 +0300
commit1fd5e88ea326b05680ba213b9af0416162c36290 (patch)
tree378dd9714b6496f4f3a28424a468098c63cdf7d3 /src/chips/dosbox_opl3.cpp
parent47e2f73719ab55075d2d479daea3e9269370d421 (diff)
parent0bd662b2d7fc11c0b4c02372f97cf6062940c570 (diff)
downloadlibADLMIDI-1fd5e88ea326b05680ba213b9af0416162c36290.tar.gz
libADLMIDI-1fd5e88ea326b05680ba213b9af0416162c36290.tar.bz2
libADLMIDI-1fd5e88ea326b05680ba213b9af0416162c36290.zip
Merge pull request #54 from jpcima/32bitmix-bis
support for 32 bit mixing, and multiple sample formats
Diffstat (limited to 'src/chips/dosbox_opl3.cpp')
-rw-r--r--src/chips/dosbox_opl3.cpp28
1 files changed, 28 insertions, 0 deletions
diff --git a/src/chips/dosbox_opl3.cpp b/src/chips/dosbox_opl3.cpp
index b696343..57b1412 100644
--- a/src/chips/dosbox_opl3.cpp
+++ b/src/chips/dosbox_opl3.cpp
@@ -78,6 +78,34 @@ int DosBoxOPL3::generateAndMix(int16_t *output, size_t frames)
return (int)frames;
}
+int DosBoxOPL3::generate(int32_t *output, size_t frames)
+{
+ DBOPL::Handler *chip_r = reinterpret_cast<DBOPL::Handler*>(m_chip);
+ ssize_t left = (ssize_t)frames;
+ while(left > 0)
+ {
+ ssize_t frames_i = left;
+ chip_r->GenerateArr(output, &frames_i);
+ output += (frames_i * 2);
+ left -= frames_i;
+ }
+ return (int)frames;
+}
+
+int DosBoxOPL3::generateAndMix(int32_t *output, size_t frames)
+{
+ DBOPL::Handler *chip_r = reinterpret_cast<DBOPL::Handler*>(m_chip);
+ ssize_t left = (ssize_t)frames;
+ while(left > 0)
+ {
+ ssize_t frames_i = left;
+ chip_r->GenerateArrMix(output, &frames_i);
+ output += (frames_i * 2);
+ left -= frames_i;
+ }
+ return (int)frames;
+}
+
const char *DosBoxOPL3::emulatorName()
{
return "DosBox 0.74 OPL3";