1 /***************************************************************************
\r
2 externals.h - description
\r
4 begin : Wed May 15 2002
\r
5 copyright : (C) 2002 by Pete Bernert
\r
6 email : BlackDove@addcom.de
\r
7 ***************************************************************************/
\r
8 /***************************************************************************
\r
10 * This program is free software; you can redistribute it and/or modify *
\r
11 * it under the terms of the GNU General Public License as published by *
\r
12 * the Free Software Foundation; either version 2 of the License, or *
\r
13 * (at your option) any later version. See also the license.txt file for *
\r
14 * additional informations. *
\r
16 ***************************************************************************/
\r
20 /////////////////////////////////////////////////////////
\r
22 /////////////////////////////////////////////////////////
\r
25 #define noinline __attribute__((noinline))
\r
26 #define unlikely(x) __builtin_expect((x), 0)
\r
29 #define unlikely(x) x
\r
31 #if defined(__GNUC__) && !defined(_TMS320C6X)
\r
32 #define preload __builtin_prefetch
\r
34 #define preload(...)
\r
37 #define PSE_LT_SPU 4
\r
38 #define PSE_SPU_ERR_SUCCESS 0
\r
39 #define PSE_SPU_ERR -60
\r
40 #define PSE_SPU_ERR_NOTCONFIGURED PSE_SPU_ERR - 1
\r
41 #define PSE_SPU_ERR_INIT PSE_SPU_ERR - 2
\r
43 #define max(a,b) (((a) > (b)) ? (a) : (b))
\r
44 #define min(a,b) (((a) < (b)) ? (a) : (b))
\r
47 ////////////////////////////////////////////////////////////////////////
\r
49 ////////////////////////////////////////////////////////////////////////
\r
54 // note: must be even due to the way reverb works now
\r
55 #define NSSIZE ((44100 / 50 + 16) & ~1)
\r
57 ///////////////////////////////////////////////////////////
\r
59 ///////////////////////////////////////////////////////////
\r
68 // ADSR INFOS PER CHANNEL
\r
71 unsigned char State:2; // ADSR_State
\r
72 unsigned char AttackModeExp:1;
\r
73 unsigned char SustainModeExp:1;
\r
74 unsigned char SustainIncrease:1;
\r
75 unsigned char ReleaseModeExp:1;
\r
76 unsigned char AttackRate;
\r
77 unsigned char DecayRate;
\r
78 unsigned char SustainLevel;
\r
79 unsigned char SustainRate;
\r
80 unsigned char ReleaseRate;
\r
84 ///////////////////////////////////////////////////////////
\r
88 // used for debug channel muting
\r
91 // used for simple interpolation
\r
92 #define FLAG_IPOL0 2
\r
93 #define FLAG_IPOL1 4
\r
95 ///////////////////////////////////////////////////////////
\r
97 // MAIN CHANNEL STRUCT
\r
100 int iSBPos; // mixing stuff
\r
105 unsigned char * pCurr; // current pos in sound mem
\r
106 unsigned char * pLoop; // loop ptr in sound mem
\r
108 unsigned int bReverb:1; // can we do reverb on this channel? must have ctrl register bit, to get active
\r
109 unsigned int bRVBActive:1; // reverb active flag
\r
110 unsigned int bNoise:1; // noise active flag
\r
111 unsigned int bFMod:2; // freq mod (0=off, 1=sound channel, 2=freq channel)
\r
112 unsigned int prevflags:3; // flags from previous block
\r
114 int iLeftVolume; // left volume
\r
115 int iRightVolume; // right volume
\r
117 int iRawPitch; // raw pitch (0...3fff)
\r
120 ///////////////////////////////////////////////////////////
\r
124 int StartAddr; // reverb area start addr in samples
\r
125 int CurrAddr; // reverb area curr addr in samples
\r
130 int FB_SRC_A; // (offset)
\r
131 int FB_SRC_B; // (offset)
\r
132 int IIR_ALPHA; // (coef.)
\r
133 int ACC_COEF_A; // (coef.)
\r
134 int ACC_COEF_B; // (coef.)
\r
135 int ACC_COEF_C; // (coef.)
\r
136 int ACC_COEF_D; // (coef.)
\r
137 int IIR_COEF; // (coef.)
\r
138 int FB_ALPHA; // (coef.)
\r
139 int FB_X; // (coef.)
\r
140 int IIR_DEST_A0; // (offset)
\r
141 int IIR_DEST_A1; // (offset)
\r
142 int ACC_SRC_A0; // (offset)
\r
143 int ACC_SRC_A1; // (offset)
\r
144 int ACC_SRC_B0; // (offset)
\r
145 int ACC_SRC_B1; // (offset)
\r
146 int IIR_SRC_A0; // (offset)
\r
147 int IIR_SRC_A1; // (offset)
\r
148 int IIR_DEST_B0; // (offset)
\r
149 int IIR_DEST_B1; // (offset)
\r
150 int ACC_SRC_C0; // (offset)
\r
151 int ACC_SRC_C1; // (offset)
\r
152 int ACC_SRC_D0; // (offset)
\r
153 int ACC_SRC_D1; // (offset)
\r
154 int IIR_SRC_B1; // (offset)
\r
155 int IIR_SRC_B0; // (offset)
\r
156 int MIX_DEST_A0; // (offset)
\r
157 int MIX_DEST_A1; // (offset)
\r
158 int MIX_DEST_B0; // (offset)
\r
159 int MIX_DEST_B1; // (offset)
\r
160 int IN_COEF_L; // (coef.)
\r
161 int IN_COEF_R; // (coef.)
\r
163 int dirty; // registers changed
\r
165 // MIX_DEST_xx - FB_SRC_x
\r
166 int FB_SRC_A0, FB_SRC_A1, FB_SRC_B0, FB_SRC_B1;
\r
169 ///////////////////////////////////////////////////////////
\r
171 // psx buffers / addresses
\r
173 #define SB_SIZE (32 + 4)
\r
177 unsigned short spuCtrl;
\r
178 unsigned short spuStat;
\r
180 unsigned int spuAddr;
\r
182 unsigned char *spuMemC;
\r
183 unsigned short *spuMem;
\r
185 unsigned char * pSpuIrq;
\r
187 unsigned int cycles_played;
\r
189 int decode_dirty_ch;
\r
190 unsigned int bSpuInit:1;
\r
191 unsigned int bSPUIsOpen:1;
\r
192 unsigned int bMemDirty:1; // had external write to SPU RAM
\r
194 unsigned int dwNoiseVal; // global noise generator
\r
195 unsigned int dwNoiseCount;
\r
196 unsigned int dwNewChannel; // flags for faster testing, if new channel starts
\r
197 unsigned int dwChannelOn; // not silent channels
\r
198 unsigned int dwChannelDead; // silent+not useful channels
\r
200 unsigned char * pSpuBuffer;
\r
203 void (CALLBACK *irqCallback)(void); // func of main emu, called on spu irq
\r
204 void (CALLBACK *cddavCallback)(unsigned short,unsigned short);
\r
205 void (CALLBACK *scheduleCallback)(unsigned int);
\r
207 xa_decode_t * xapGlobal;
\r
208 unsigned int * XAFeed;
\r
209 unsigned int * XAPlay;
\r
210 unsigned int * XAStart;
\r
211 unsigned int * XAEnd;
\r
213 unsigned int * CDDAFeed;
\r
214 unsigned int * CDDAPlay;
\r
215 unsigned int * CDDAStart;
\r
216 unsigned int * CDDAEnd;
\r
218 unsigned int XARepeat;
\r
219 unsigned int XALastVal;
\r
232 unsigned short regArea[0x400];
\r
235 ///////////////////////////////////////////////////////////
\r
237 ///////////////////////////////////////////////////////////
\r
241 extern SPUInfo spu;
\r
243 void do_samples(unsigned int cycles_to, int do_sync);
\r
244 void schedule_next_irq(void);
\r
246 #define regAreaGet(ch,offset) \
\r
247 spu.regArea[((ch<<4)|(offset))>>1]
\r
249 #define do_samples_if_needed(c, sync) \
\r
251 if (sync || (int)((c) - spu.cycles_played) >= 16 * 768) \
\r
252 do_samples(c, sync); \
\r