@*********************************************************** | |
@ 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 | |
@**************************************************************************** | |