154 lines
4.5 KiB
C++
154 lines
4.5 KiB
C++
@***********************************************************
|
|
@ File: ARM_synth_constants.inc
|
|
@ Processor: ARM
|
|
@ Description: Contains constants and defines, most of which
|
|
@ are mirrored in synth.h
|
|
@
|
|
@ Copyright Sonic Network Inc. 2004
|
|
@****************************************************************
|
|
@ Revision Control:
|
|
@ $Revision: 741 $
|
|
@ $Date: 2007-06-22 16:39:21 -0700 (Fri, 22 Jun 2007) $
|
|
@****************************************************************
|
|
|
|
|
|
#ifdef SAMPLE_RATE_8000
|
|
.equ SYNTH_UPDATE_PERIOD_IN_BITS, 5
|
|
.equ BUFFER_SIZE_IN_MONO_SAMPLES, 32
|
|
#endif
|
|
|
|
#ifdef SAMPLE_RATE_16000
|
|
.equ SYNTH_UPDATE_PERIOD_IN_BITS, 6
|
|
.equ BUFFER_SIZE_IN_MONO_SAMPLES, 64
|
|
#endif
|
|
|
|
#ifdef SAMPLE_RATE_20000
|
|
.equ SYNTH_UPDATE_PERIOD_IN_BITS, 7
|
|
.equ BUFFER_SIZE_IN_MONO_SAMPLES, 128
|
|
#endif
|
|
|
|
#ifdef SAMPLE_RATE_22050
|
|
.equ SYNTH_UPDATE_PERIOD_IN_BITS, 7
|
|
.equ BUFFER_SIZE_IN_MONO_SAMPLES, 128
|
|
#endif
|
|
|
|
#ifdef SAMPLE_RATE_24000
|
|
.equ SYNTH_UPDATE_PERIOD_IN_BITS, 7
|
|
.equ BUFFER_SIZE_IN_MONO_SAMPLES, 128
|
|
#endif
|
|
|
|
#ifdef SAMPLE_RATE_32000
|
|
.equ SYNTH_UPDATE_PERIOD_IN_BITS, 7
|
|
.equ BUFFER_SIZE_IN_MONO_SAMPLES, 128
|
|
#endif
|
|
|
|
#ifdef SAMPLE_RATE_44100
|
|
.equ SYNTH_UPDATE_PERIOD_IN_BITS, 8
|
|
.equ BUFFER_SIZE_IN_MONO_SAMPLES, 256
|
|
#endif
|
|
|
|
#ifdef SAMPLE_RATE_48000
|
|
.equ SYNTH_UPDATE_PERIOD_IN_BITS, 8
|
|
.equ BUFFER_SIZE_IN_MONO_SAMPLES, 256
|
|
#endif
|
|
|
|
|
|
@ if the OUTPUT PCM sample is 16-bits, then when using indexed addressing,
|
|
@ the next sample is this many bytes away
|
|
.equ NEXT_OUTPUT_PCM, 2
|
|
|
|
@****************************************************************************
|
|
@/* macros for fractional phase accumulator */
|
|
.equ NUM_PHASE_FRAC_BITS, 15
|
|
|
|
.equ PHASE_FRAC_MASK, 0x7FFF
|
|
|
|
@ shift for phase accumulator when fraction carries over
|
|
#ifdef SAMPLES_8_BIT
|
|
.equ NEXT_INPUT_PCM_SHIFT, 0
|
|
#endif
|
|
|
|
#ifdef SAMPLES_16_BIT
|
|
.equ NEXT_INPUT_PCM_SHIFT, 1
|
|
#endif
|
|
|
|
@****************************************************************************
|
|
.equ NUM_MIXER_GUARD_BITS, 4
|
|
|
|
@****************************************************************************
|
|
@/* Envelope 1 (EG1) calculation macros */
|
|
.equ NUM_EG1_FRAC_BITS, 15
|
|
|
|
@****************************************************************************
|
|
|
|
.equ NUM_ENHANCER_FILTER_COEF_FRAC_BITS, 5
|
|
|
|
@****************************************************************************
|
|
|
|
@
|
|
@ I've temporarily given up on the idea of getting ADS/RV and gcc to
|
|
@ handle a struct in a compatible fashion. Switching to old fashion EQU
|
|
@
|
|
|
|
#if FILTER_ENABLED
|
|
@**************************************
|
|
@ typedef struct s_filter_tag
|
|
.equ m_z1, 0
|
|
.equ m_z2, 2
|
|
#endif
|
|
|
|
@**************************************
|
|
@ typedef struct s_wt_frame_tag
|
|
.equ m_gainTarget, 0
|
|
.equ m_phaseIncrement, 4
|
|
|
|
#if FILTER_ENABLED
|
|
.equ m_k, 8
|
|
.equ m_b1, 12
|
|
.equ m_b2, 16
|
|
.equ m_pAudioBuffer, 20
|
|
.equ m_pMixBuffer, 24
|
|
.equ m_numSamples, 28
|
|
.equ m_prevGain, 32
|
|
#else
|
|
.equ m_pAudioBuffer, 8
|
|
.equ m_pMixBuffer, 12
|
|
.equ m_numSamples, 16
|
|
.equ m_prevGain, 20
|
|
#endif
|
|
|
|
|
|
@**************************************
|
|
@ typedef struct s_wt_voice_tag
|
|
.equ m_pLoopEnd, 0 @ /* points to last PCM sample (not 1 beyond last) */
|
|
.equ m_pLoopStart, 4 @ /* points to first sample at start of loop */
|
|
.equ m_pPhaseAccum, 8 @ /* points to first sample at start of loop */
|
|
.equ m_phaseFrac, 12 @ /* points to first sample at start of loop */
|
|
|
|
#if STEREO_OUTPUT
|
|
.equ m_gainLeft, 16 @ /* current gain, left ch */
|
|
.equ m_gainRight, 18 @ /* current gain, right ch */
|
|
#endif
|
|
|
|
|
|
@****************************************************************************
|
|
@ enhancer
|
|
.equ m_nEnhancerFeedForward1, 0
|
|
.equ m_nEnhancerFeedback1, 1
|
|
.equ m_nDriveCoef, 2
|
|
.equ m_nEnhancerFeedback2, 3
|
|
.equ m_nWet, 4
|
|
.equ m_nDry, 5
|
|
|
|
.equ m_zF0L, 6 @ filter 1 zero state var, left
|
|
.equ m_zF1L, 8 @ filter 1 pole state var, left
|
|
.equ m_zF2L, 10 @ filter 2 zero state var, left
|
|
.equ m_zF0R, 12 @ filter 1 zero state var, right
|
|
.equ m_zF1R, 14 @ filter 1 pole state var, right
|
|
.equ m_zF2R, 16 @ filter 2 zero state var, right
|
|
|
|
@****************************************************************************
|
|
|
|
|
|
|