libsidplayfp 2.15.0
Public Member Functions | List of all members
reSIDfp::WaveformGenerator Class Reference

#include <WaveformGenerator.h>

Public Member Functions

void setWaveformModels (matrix_t *models)
 
void setPulldownModels (matrix_t *models)
 
void setOtherWaveforms (const WaveformGenerator *prev, WaveformGenerator *next)
 
void setModel (bool is6581)
 
void clock ()
 
void synchronize () const
 
void writeFREQ_LO (unsigned char freq_lo)
 
void writeFREQ_HI (unsigned char freq_hi)
 
void writePW_LO (unsigned char pw_lo)
 
void writePW_HI (unsigned char pw_hi)
 
void writeCONTROL_REG (unsigned char control)
 
void reset ()
 
unsigned int output ()
 
unsigned char readOSC () const
 
unsigned int readAccumulator () const
 
unsigned int readFreq () const
 
bool readTest () const
 
bool readFollowingVoiceSync () const
 

Detailed Description

A 24 bit accumulator is the basis for waveform generation. FREQ is added to the lower 16 bits of the accumulator each cycle. The accumulator is set to zero when TEST is set, and starts counting when TEST is cleared.

Waveforms are generated as follows:

Operation: Calculate EOR result, shift register, set bit 0 = result.

               reset  +--------------------------------------------+
                 |    |                                            |
          test--OR-->EOR<--+                                       |
                 |         |                                       |
                 2 2 2 1 1 1 1 1 1 1 1 1 1                         |
Register bits:   2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 <---+
                     |   |       |     |   |       |     |   |
Waveform bits:       1   1       9     8   7       6     5   4
                     1   0

The low 4 waveform bits are zero (grounded).

Member Function Documentation

◆ clock()

RESID_INLINE void reSIDfp::WaveformGenerator::clock ( )

SID clocking.

◆ output()

RESID_INLINE unsigned int reSIDfp::WaveformGenerator::output ( )

12-bit waveform output.

Returns
the waveform generator digital output

◆ readAccumulator()

unsigned int reSIDfp::WaveformGenerator::readAccumulator ( ) const
inline

Read accumulator value.

◆ readFollowingVoiceSync()

bool reSIDfp::WaveformGenerator::readFollowingVoiceSync ( ) const
inline

Read sync value from following voice.

◆ readFreq()

unsigned int reSIDfp::WaveformGenerator::readFreq ( ) const
inline

Read freq value.

◆ readOSC()

unsigned char reSIDfp::WaveformGenerator::readOSC ( ) const
inline

Read OSC3 value.

◆ readTest()

bool reSIDfp::WaveformGenerator::readTest ( ) const
inline

Read test value.

◆ reset()

void reSIDfp::WaveformGenerator::reset ( )

SID reset.

◆ setModel()

void reSIDfp::WaveformGenerator::setModel ( bool  is6581)
inline

Set the chip model. Must be called before any operation.

Parameters
is6581true if MOS6581, false if CSG8580

◆ synchronize()

void reSIDfp::WaveformGenerator::synchronize ( ) const

Synchronize oscillators. This must be done after all the oscillators have been clock()'ed, so that they are in the same state.

◆ writeCONTROL_REG()

void reSIDfp::WaveformGenerator::writeCONTROL_REG ( unsigned char  control)

Write CONTROL REGISTER register.

Parameters
controlcontrol register value

◆ writeFREQ_HI()

void reSIDfp::WaveformGenerator::writeFREQ_HI ( unsigned char  freq_hi)
inline

Write FREQ HI register.

Parameters
freq_hihigh 8 bits of frequency

◆ writeFREQ_LO()

void reSIDfp::WaveformGenerator::writeFREQ_LO ( unsigned char  freq_lo)
inline

Write FREQ LO register.

Parameters
freq_lolow 8 bits of frequency

◆ writePW_HI()

void reSIDfp::WaveformGenerator::writePW_HI ( unsigned char  pw_hi)
inline

Write PW HI register.

Parameters
pw_hihigh 8 bits of pulse width

◆ writePW_LO()

void reSIDfp::WaveformGenerator::writePW_LO ( unsigned char  pw_lo)
inline

Write PW LO register.

Parameters
pw_lolow 8 bits of pulse width

The documentation for this class was generated from the following files: