|
|
@ -27,17 +27,23 @@ |
|
|
|
#include "reSID.h" |
|
|
|
#include "reSID.h" |
|
|
|
#include <AudioStream.h> |
|
|
|
#include <AudioStream.h> |
|
|
|
|
|
|
|
|
|
|
|
#define SAMPLERATE 44118 |
|
|
|
|
|
|
|
#define CLOCKFREQ (22.5 * SAMPLERATE) //nearest int to 985248
|
|
|
|
#define SAMPLERATE AUDIO_SAMPLE_RATE_EXACT |
|
|
|
|
|
|
|
#define CLOCKFREQ 985248 |
|
|
|
|
|
|
|
|
|
|
|
void AudioPlaySID::begin(void) |
|
|
|
void AudioPlaySID::begin(void) |
|
|
|
{ |
|
|
|
{ |
|
|
|
sidptr = &sid; |
|
|
|
sidptr = &sid; |
|
|
|
this->reset(); |
|
|
|
this->reset(); |
|
|
|
sid.set_sampling_parameters(CLOCKFREQ, SAMPLE_FAST, SAMPLERATE);
|
|
|
|
setSampleParameters(CLOCKFREQ, SAMPLERATE); |
|
|
|
playing = true; |
|
|
|
playing = true; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void AudioPlaySID::setSampleParameters(unsigned clockfreq, unsigned samplerate) { |
|
|
|
|
|
|
|
sid.set_sampling_parameters(clockfreq, SAMPLE_FAST, samplerate);
|
|
|
|
|
|
|
|
csdelta = round((float)clockfreq / ((float)samplerate / AUDIO_BLOCK_SAMPLES)); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void AudioPlaySID::reset(void) |
|
|
|
void AudioPlaySID::reset(void) |
|
|
|
{ |
|
|
|
{ |
|
|
|
sid.reset(); |
|
|
|
sid.reset(); |
|
|
@ -60,8 +66,8 @@ void AudioPlaySID::update(void) { |
|
|
|
block = allocate(); |
|
|
|
block = allocate(); |
|
|
|
if (block == NULL) return; |
|
|
|
if (block == NULL) return; |
|
|
|
|
|
|
|
|
|
|
|
//I'm not 100% if this is correct:
|
|
|
|
//cycle_count delta_t = CLOCKFREQ / (SAMPLERATE / AUDIO_BLOCK_SAMPLES);
|
|
|
|
cycle_count delta_t = CLOCKFREQ / (SAMPLERATE / AUDIO_BLOCK_SAMPLES); |
|
|
|
cycle_count delta_t = csdelta; |
|
|
|
|
|
|
|
|
|
|
|
sidptr->clock(delta_t, (short int*)block->data, AUDIO_BLOCK_SAMPLES); |
|
|
|
sidptr->clock(delta_t, (short int*)block->data, AUDIO_BLOCK_SAMPLES); |
|
|
|
|
|
|
|
|
|
|
|