annotate Plugins/Input/console/Spc_Dsp.h @ 352:f13ab2d8e9cf trunk

[svn] various fixes :(
author nenolod
date Mon, 26 Dec 2005 14:12:35 -0800
parents 84aabc053b6e
children 7c5e886205ef
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
90
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
1
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
2 // Super Nintendo (SNES) SPC DSP emulator
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
3
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
4 // Game_Music_Emu 0.2.4. Copyright (C) 2004-2005 Shay Green. GNU LGPL license.
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
5 // Copyright (C) 2002 Brad Martin
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
6
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
7 #ifndef SPC_DSP_H
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
8 #define SPC_DSP_H
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
9
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
10 #include "blargg_common.h"
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
11
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
12 // Surround effects using opposite volumes for left and right are currently removed
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
13 // by making left and right volume positive if their signs differ.
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
14
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
15 class Spc_Dsp {
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
16 typedef BOOST::int8_t int8_t;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
17 typedef BOOST::uint8_t uint8_t;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
18 public:
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
19
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
20 // Keeps pointer to ram
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
21 Spc_Dsp( uint8_t ram [0x10000] );
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
22
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
23 // Mute voice n if bit n (1 << n) of mask is clear.
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
24 enum { voice_count = 8 };
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
25 void mute_voices( int mask );
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
26
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
27 // Clear state and silence everything.
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
28 void reset();
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
29
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
30 // Set gain, where 1.0 is normal. When greater than 1.0, output is clamped to
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
31 // the 16-bit sample range.
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
32 void set_gain( double );
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
33
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
34 // Read/write register 'n', where n ranges from 0 to register_count - 1.
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
35 enum { register_count = 128 };
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
36 int read ( int n );
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
37 void write( int n, int );
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
38
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
39 // Run DSP for 'count' samples. Write resulting samples to 'buf' if not NULL.
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
40 void run( long count, short* buf = NULL );
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
41
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
42
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
43 // End of public interface
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
44 private:
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
45
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
46 struct raw_voice_t {
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
47 int8_t left_vol;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
48 int8_t right_vol;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
49 uint8_t rate [2];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
50 uint8_t waveform;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
51 uint8_t adsr [2]; // envelope rates for attack, decay, and sustain
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
52 uint8_t gain; // envelope gain (if not using ADSR)
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
53 int8_t envx; // current envelope level
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
54 int8_t outx; // current sample
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
55 int8_t unused [6];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
56 };
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
57
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
58 union {
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
59 raw_voice_t voice [voice_count];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
60
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
61 uint8_t reg [register_count];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
62
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
63 struct {
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
64 int8_t unused1 [12];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
65 int8_t left_volume; // 0C Main Volume Left (-.7)
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
66 int8_t echo_feedback; // 0D Echo Feedback (-.7)
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
67 int8_t unused2 [14];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
68 int8_t right_volume; // 1C Main Volume Right (-.7)
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
69 int8_t unused3 [15];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
70 int8_t left_echo_volume; // 2C Echo Volume Left (-.7)
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
71 uint8_t pitch_mods; // 2D Pitch Modulation on/off for each voice
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
72 int8_t unused4 [14];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
73 int8_t right_echo_volume; // 3C Echo Volume Right (-.7)
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
74 uint8_t noise_enables; // 3D Noise output on/off for each voice
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
75 int8_t unused5 [14];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
76 uint8_t key_ons; // 4C Key On for each voice
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
77 uint8_t echo_ons; // 4D Echo on/off for each voice
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
78 int8_t unused6 [14];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
79 uint8_t key_offs; // 5C key off for each voice (instantiates release mode)
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
80 uint8_t wave_page; // 5D source directory (wave table offsets)
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
81 int8_t unused7 [14];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
82 uint8_t flags; // 6C flags and noise freq
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
83 uint8_t echo_page; // 6D
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
84 int8_t unused8 [14];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
85 uint8_t wave_ended; // 7C
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
86 uint8_t echo_delay; // 7D ms >> 4
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
87 char unused9 [2];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
88 } g;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
89 };
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
90
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
91 uint8_t* const ram;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
92
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
93 // Cache of echo FIR values for faster access
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
94 short fir_coeff [voice_count];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
95
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
96 // fir_buf [i + 8] == fir_buf [i], to avoid wrap checking in FIR code
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
97 short fir_buf [16] [2];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
98 int fir_offset; // (0 to 7)
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
99
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
100 short voice_vol [voice_count] [2];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
101
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
102 enum { emu_gain_bits = 8 };
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
103 int emu_gain;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
104
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
105 int keyed_on; // 8-bits for 8 voices
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
106 int keys;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
107
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
108 int echo_ptr;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
109 int noise_amp;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
110 int noise;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
111 int noise_count;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
112
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
113 int voices_muted;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
114 int disable_surround_; // set to sign bit (0x80) when disabled
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
115
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
116 static const short gauss [] [2];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
117
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
118 enum state_t {
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
119 state_attack,
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
120 state_decay,
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
121 state_sustain,
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
122 state_release
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
123 };
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
124
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
125 struct voice_t {
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
126 short fraction;// 12-bit fractional position
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
127 short interp0; // most recent four decoded samples
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
128 short interp1;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
129 short interp2;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
130 short interp3;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
131 short block_remain; // number of nybbles remaining in current block
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
132 unsigned short addr;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
133 short block_header; // header byte from current block
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
134 short envcnt;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
135 short envx;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
136 short on_cnt;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
137 state_t envstate;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
138 };
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
139
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
140 voice_t voice_state [voice_count];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
141
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
142 int clock_envelope( int );
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
143 };
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
144
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
145 inline int Spc_Dsp::read( int i ) {
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
146 assert( (unsigned) i < register_count );
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
147 return reg [i];
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
148 }
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
149
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
150 inline void Spc_Dsp::mute_voices( int mask ) {
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
151 voices_muted = mask;
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
152 }
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
153
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
154 inline void Spc_Dsp::set_gain( double v ) {
256
84aabc053b6e [svn] C++ warning fixes by external contractor Stephen Bennett.
chainsaw
parents: 90
diff changeset
155 emu_gain = (int) (v * (1 << emu_gain_bits));
90
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
156 }
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
157
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
158 #endif
252843aac42f [svn] Import the initial sources for console music support.
nenolod
parents:
diff changeset
159