4
/* --- select emulation chips --- */
5
#define BUILD_YM3812 (HAS_YM3812)
6
//#define BUILD_YM3526 (HAS_YM3526)
7
//#define BUILD_Y8950 (HAS_Y8950)
9
/* --- system optimize --- */
10
/* select bit size of output : 8 or 16 */
11
#define OPL_OUTPUT_BIT 16
13
/* compiler dependence */
16
typedef unsigned char UINT8; /* unsigned 8bit */
17
typedef unsigned short UINT16; /* unsigned 16bit */
18
typedef unsigned int UINT32; /* unsigned 32bit */
19
typedef signed char INT8; /* signed 8bit */
20
typedef signed short INT16; /* signed 16bit */
21
typedef signed int INT32; /* signed 32bit */
24
#if (OPL_OUTPUT_BIT==16)
25
typedef INT16 OPLSAMPLE;
27
#if (OPL_OUTPUT_BIT==8)
28
typedef unsigned char OPLSAMPLE;
36
typedef void (*OPL_TIMERHANDLER)(int channel,double interval_Sec);
37
typedef void (*OPL_IRQHANDLER)(int param,int irq);
38
typedef void (*OPL_UPDATEHANDLER)(int param,int min_interval_us);
39
typedef void (*OPL_PORTHANDLER_W)(int param,unsigned char data);
40
typedef unsigned char (*OPL_PORTHANDLER_R)(int param);
42
/* !!!!! here is private section , do not access there member direct !!!!! */
44
#define OPL_TYPE_WAVESEL 0x01 /* waveform select */
45
#define OPL_TYPE_ADPCM 0x02 /* DELTA-T ADPCM unit */
46
#define OPL_TYPE_KEYBOARD 0x04 /* keyboard interface */
47
#define OPL_TYPE_IO 0x08 /* I/O port */
49
/* Saving is necessary for member of the 'R' mark for suspend/resume */
50
/* ---------- OPL one of slot ---------- */
51
typedef struct fm_opl_slot {
52
INT32 TL; /* total level :TL << 8 */
53
INT32 TLL; /* adjusted now TL */
54
UINT8 KSR; /* key scale rate :(shift down bit) */
55
INT32 *AR; /* attack rate :&AR_TABLE[AR<<2] */
56
INT32 *DR; /* decay rate :&DR_TALBE[DR<<2] */
57
INT32 SL; /* sustin level :SL_TALBE[SL] */
58
INT32 *RR; /* release rate :&DR_TABLE[RR<<2] */
59
UINT8 ksl; /* keyscale level :(shift down bits) */
60
UINT8 ksr; /* key scale rate :kcode>>KSR */
61
UINT32 mul; /* multiple :ML_TABLE[ML] */
62
UINT32 Cnt; /* frequency count : */
63
UINT32 Incr; /* frequency step : */
64
/* envelope generator state */
65
UINT8 eg_typ; /* envelope type flag */
66
UINT8 evm; /* envelope phase */
67
INT32 evc; /* envelope counter */
68
INT32 eve; /* envelope counter end point */
69
INT32 evs; /* envelope counter step */
70
INT32 evsa; /* envelope step for AR :AR[ksr] */
71
INT32 evsd; /* envelope step for DR :DR[ksr] */
72
INT32 evsr; /* envelope step for RR :RR[ksr] */
74
UINT8 ams; /* ams flag */
75
UINT8 vib; /* vibrate flag */
80
/* ---------- OPL one of channel ---------- */
81
typedef struct fm_opl_channel {
83
UINT8 CON; /* connection type */
84
UINT8 FB; /* feed back :(shift down bit) */
85
INT32 *connect1; /* slot1 output pointer */
86
INT32 *connect2; /* slot2 output pointer */
87
INT32 op1_out[2]; /* slot1 output for selfeedback */
88
/* phase generator state */
89
UINT32 block_fnum; /* block+fnum : */
90
UINT8 kcode; /* key code : KeyScaleCode */
91
UINT32 fc; /* Freq. Increment base */
92
UINT32 ksl_base; /* KeyScaleLevel Base step */
93
UINT8 keyon; /* key on/off flag */
97
typedef struct fm_opl_f {
98
UINT8 type; /* chip type */
99
int clock; /* master clock (Hz) */
100
int rate; /* sampling rate (Hz) */
101
double freqbase; /* frequency base */
102
double TimerBase; /* Timer base time (==sampling time) */
103
UINT8 address; /* address register */
104
UINT8 status; /* status flag */
105
UINT8 statusmask; /* status mask */
106
UINT32 mode; /* Reg.08 : CSM , notesel,etc. */
108
int T[2]; /* timer counter */
109
UINT8 st[2]; /* timer enable */
110
/* FM channel slots */
111
OPL_CH *P_CH; /* pointer of CH */
112
int max_ch; /* maximum channel */
114
UINT8 rythm; /* Rythm mode , key flag */
116
/* Delta-T ADPCM unit (Y8950) */
117
YM_DELTAT *deltat; /* DELTA-T ADPCM */
119
/* Keyboard / I/O interface unit (Y8950) */
122
OPL_PORTHANDLER_R porthandler_r;
123
OPL_PORTHANDLER_W porthandler_w;
125
OPL_PORTHANDLER_R keyboardhandler_r;
126
OPL_PORTHANDLER_W keyboardhandler_w;
129
INT32 AR_TABLE[75]; /* atttack rate tables */
130
INT32 DR_TABLE[75]; /* decay rate tables */
131
UINT32 FN_TABLE[1024]; /* fnumber -> increment counter */
139
/* wave selector enable flag */
141
/* external event callback handler */
142
OPL_TIMERHANDLER TimerHandler; /* TIMER handler */
143
int TimerParam; /* TIMER parameter */
144
OPL_IRQHANDLER IRQHandler; /* IRQ handler */
145
int IRQParam; /* IRQ parameter */
146
OPL_UPDATEHANDLER UpdateHandler; /* stream update handler */
147
int UpdateParam; /* stream update parameter */
150
/* ---------- Generic interface section ---------- */
151
#define OPL_TYPE_YM3526 (0)
152
#define OPL_TYPE_YM3812 (OPL_TYPE_WAVESEL)
153
#define OPL_TYPE_Y8950 (OPL_TYPE_ADPCM|OPL_TYPE_KEYBOARD|OPL_TYPE_IO)
155
FM_OPL *OPLCreate(int type, int clock, int rate);
156
void OPLDestroy(FM_OPL *OPL);
157
void OPLSetTimerHandler(FM_OPL *OPL,OPL_TIMERHANDLER TimerHandler,int channelOffset);
158
void OPLSetIRQHandler(FM_OPL *OPL,OPL_IRQHANDLER IRQHandler,int param);
159
void OPLSetUpdateHandler(FM_OPL *OPL,OPL_UPDATEHANDLER UpdateHandler,int param);
160
/* Y8950 port handlers */
161
void OPLSetPortHandler(FM_OPL *OPL,OPL_PORTHANDLER_W PortHandler_w,OPL_PORTHANDLER_R PortHandler_r,int param);
162
void OPLSetKeyboardHandler(FM_OPL *OPL,OPL_PORTHANDLER_W KeyboardHandler_w,OPL_PORTHANDLER_R KeyboardHandler_r,int param);
164
void OPLResetChip(FM_OPL *OPL);
165
int OPLWrite(FM_OPL *OPL,int a,int v);
166
unsigned char OPLRead(FM_OPL *OPL,int a);
167
int OPLTimerOver(FM_OPL *OPL,int c);
169
/* YM3626/YM3812 local section */
170
void YM3812UpdateOne(FM_OPL *OPL, INT16 *buffer, int length);
172
void Y8950UpdateOne(FM_OPL *OPL, INT16 *buffer, int length);