diff options
Diffstat (limited to 'src/adlmidi.cpp')
-rw-r--r-- | src/adlmidi.cpp | 34 |
1 files changed, 20 insertions, 14 deletions
diff --git a/src/adlmidi.cpp b/src/adlmidi.cpp index 39bb5b6..ade4f33 100644 --- a/src/adlmidi.cpp +++ b/src/adlmidi.cpp @@ -40,8 +40,8 @@ static ADL_Version adl_version = { static const ADLMIDI_AudioFormat adl_DefaultAudioFormat = { ADLMIDI_SampleType_S16, - sizeof(short), - 2 * sizeof(short), + sizeof(int16_t), + 2 * sizeof(int16_t), }; /*---------------------------EXPORTS---------------------------*/ @@ -620,8 +620,8 @@ static void CopySamplesRaw(ADL_UInt8 *dstLeft, ADL_UInt8 *dstRight, const int32_ size_t frameCount, unsigned sampleOffset) { for(size_t i = 0; i < frameCount; ++i) { - *(Dst *)(dstLeft + i * sampleOffset) = src[2 * i]; - *(Dst *)(dstRight + i * sampleOffset) = src[2 * i + 1]; + *(Dst *)(dstLeft + (i * sampleOffset)) = src[2 * i]; + *(Dst *)(dstRight + (i * sampleOffset)) = src[(2 * i) + 1]; } } @@ -631,8 +631,8 @@ static void CopySamplesTransformed(ADL_UInt8 *dstLeft, ADL_UInt8 *dstRight, cons Ret(&transform)(int32_t)) { for(size_t i = 0; i < frameCount; ++i) { - *(Dst *)(dstLeft + i * sampleOffset) = transform(src[2 * i]); - *(Dst *)(dstRight + i * sampleOffset) = transform(src[2 * i + 1]); + *(Dst *)(dstLeft + (i * sampleOffset)) = transform(src[2 * i]); + *(Dst *)(dstRight + (i * sampleOffset)) = transform(src[(2 * i) + 1]); } } @@ -655,6 +655,9 @@ static int SendStereoAudio(int samples_requested, const unsigned containerSize = format->containerSize; const unsigned sampleOffset = format->sampleOffset; + left += outputOffset * containerSize; + right += outputOffset * containerSize; + switch(sampleType) { case ADLMIDI_SampleType_S8: switch(containerSize) { @@ -707,14 +710,15 @@ ADLMIDI_EXPORT int adl_play(struct ADL_MIDIPlayer *device, int sampleCount, shor } ADLMIDI_EXPORT int adl_playFormat(ADL_MIDIPlayer *device, int sampleCount, - ADL_UInt8 out_left[], ADL_UInt8 out_right[], + ADL_UInt8 *out_left, ADL_UInt8 *out_right, const ADLMIDI_AudioFormat *format) { #ifndef ADLMIDI_DISABLE_MIDI_SEQUENCER #ifdef ADLMIDI_HW_OPL (void)device; (void)sampleCount; - (void)out; + (void)out_left; + (void)out_right; (void)format; return 0; #else @@ -774,14 +778,15 @@ ADLMIDI_EXPORT int adl_playFormat(ADL_MIDIPlayer *device, int sampleCount, unsigned int chips = player->opl.NumCards; if(chips == 1) { - player->opl.cardsOP2[0]->generate(out_buf, (size_t)in_generatedStereo); + player->opl.cardsOP2[0]->generate32(out_buf, (size_t)in_generatedStereo); } else if(n_periodCountStereo > 0) { /* Generate data from every chip and mix result */ for(size_t card = 0; card < chips; ++card) - player->opl.cardsOP2[card]->generateAndMix(out_buf, (size_t)in_generatedStereo); + player->opl.cardsOP2[card]->generateAndMix32(out_buf, (size_t)in_generatedStereo); } + /* Process it */ if(SendStereoAudio(sampleCount, in_generatedStereo, out_buf, gotten_len, out_left, out_right, format) == -1) return 0; @@ -815,13 +820,14 @@ ADLMIDI_EXPORT int adl_generate(struct ADL_MIDIPlayer *device, int sampleCount, } ADLMIDI_EXPORT int adl_generateFormat(struct ADL_MIDIPlayer *device, int sampleCount, - ADL_UInt8 out_left[], ADL_UInt8 out_right[], + ADL_UInt8 *out_left, ADL_UInt8 *out_right, const ADLMIDI_AudioFormat *format) { #ifdef ADLMIDI_HW_OPL (void)device; (void)sampleCount; - (void)out; + (void)out_left; + (void)out_right; (void)format; return 0; #else @@ -863,12 +869,12 @@ ADLMIDI_EXPORT int adl_generateFormat(struct ADL_MIDIPlayer *device, int sampleC std::memset(out_buf, 0, static_cast<size_t>(in_generatedPhys) * sizeof(out_buf[0])); unsigned int chips = player->opl.NumCards; if(chips == 1) - player->opl.cardsOP2[0]->generate(out_buf, (size_t)in_generatedStereo); + player->opl.cardsOP2[0]->generate32(out_buf, (size_t)in_generatedStereo); else if(n_periodCountStereo > 0) { /* Generate data from every chip and mix result */ for(unsigned card = 0; card < chips; ++card) - player->opl.cardsOP2[card]->generateAndMix(out_buf, (size_t)in_generatedStereo); + player->opl.cardsOP2[card]->generateAndMix32(out_buf, (size_t)in_generatedStereo); } /* Process it */ if(SendStereoAudio(sampleCount, in_generatedStereo, out_buf, gotten_len, out_left, out_right, format) == -1) |