26 #include "siddefs-fp.h"
50 const char* getMessage() {
return message; }
60 static const int BUS_TTL;
102 unsigned char delayedValue;
105 unsigned char busValue;
117 void writeImmediate(
int offset,
unsigned char value);
124 void ageBusValue(
int n);
139 void voiceSync(
bool sync);
170 void input(
int value);
192 unsigned char read(
int offset);
200 void write(
int offset,
unsigned char value);
208 void mute(
int channel,
bool enable) { muted[channel] = enable; }
234 void setSamplingParameters(
double clockFrequency, SamplingMethod method,
double samplingFrequency,
double highestAccurateFrequency);
243 int clock(
int cycles,
short* buf);
274 #if RESID_INLINING || defined(SID_CPP)
279 #include "ExternalFilter.h"
281 #include "resample/Resampler.h"
287 void SID::ageBusValue(
int n)
289 if (likely(busValueTtl != 0))
293 if (unlikely(busValueTtl <= 0))
302 int SID::output()
const
304 const int v1 = voice[0]->
output(voice[2]->wave());
305 const int v2 = voice[1]->
output(voice[0]->wave());
306 const int v3 = voice[2]->
output(voice[1]->wave());
308 return externalFilter->
clock(filter->
clock(v1, v2, v3));
320 int delta_t = std::min(nextVoiceSync, cycles);
322 if (likely(delta_t > 0))
324 if (unlikely(delayedOffset != -1))
329 for (
int i = 0; i < delta_t; i++)
332 voice[0]->wave()->
clock();
333 voice[1]->wave()->
clock();
334 voice[2]->wave()->
clock();
337 voice[0]->envelope()->
clock();
338 voice[1]->envelope()->
clock();
339 voice[2]->envelope()->
clock();
341 if (unlikely(resampler->
input(output())))
347 if (unlikely(delayedOffset != -1))
349 writeImmediate(delayedOffset, delayedValue);
354 nextVoiceSync -= delta_t;
357 if (unlikely(nextVoiceSync == 0))
Definition: Filter8580.h:74
Definition: Potentiometer.h:37
void clockSilent(int cycles)
Definition: SID.cpp:356
short getOutput() const
Definition: Resampler.h:55
void clock()
Definition: EnvelopeGenerator.h:204
void input(int value)
Definition: SID.cpp:276
Filter6581 * getFilter6581() const
Definition: SID.h:262
virtual int clock(int v1, int v2, int v3)=0
int clock(int cycles, short *buf)
Definition: SID.h:313
Definition: ExternalFilter.h:45
Definition: Resampler.h:32
void setSamplingParameters(double clockFrequency, SamplingMethod method, double samplingFrequency, double highestAccurateFrequency)
Definition: SID.cpp:333
Filter8580 * getFilter8580() const
Definition: SID.h:269
Definition: Filter6581.h:42
virtual bool input(int sample)=0
unsigned char read(int offset)
Definition: SID.cpp:282
void write(int offset, unsigned char value)
Definition: SID.cpp:317
RESID_INLINE int output(const WaveformGenerator *ringModulator) const
Definition: Voice.h:59
void mute(int channel, bool enable)
Definition: SID.h:208
void setChipModel(ChipModel model)
Definition: SID.cpp:224
ChipModel getChipModel() const
Definition: SID.h:155
void reset()
Definition: SID.cpp:254
int clock(int Vi)
Definition: ExternalFilter.h:92