1 | #ifndef __FMOPL_H_ |
---|
2 | #define __FMOPL_H_ |
---|
3 | |
---|
4 | /* --- select emulation chips --- */ |
---|
5 | #define BUILD_YM3812 (HAS_YM3812) |
---|
6 | //#define BUILD_YM3526 (HAS_YM3526) |
---|
7 | //#define BUILD_Y8950 (HAS_Y8950) |
---|
8 | |
---|
9 | /* --- system optimize --- */ |
---|
10 | /* select bit size of output : 8 or 16 */ |
---|
11 | #define OPL_OUTPUT_BIT 16 |
---|
12 | |
---|
13 | /* compiler dependence */ |
---|
14 | #ifndef OSD_CPU_H |
---|
15 | #define OSD_CPU_H |
---|
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 */ |
---|
22 | #endif |
---|
23 | |
---|
24 | #if (OPL_OUTPUT_BIT==16) |
---|
25 | typedef INT16 OPLSAMPLE; |
---|
26 | #endif |
---|
27 | #if (OPL_OUTPUT_BIT==8) |
---|
28 | typedef unsigned char OPLSAMPLE; |
---|
29 | #endif |
---|
30 | |
---|
31 | |
---|
32 | #if BUILD_Y8950 |
---|
33 | #include "ymdeltat.h" |
---|
34 | #endif |
---|
35 | |
---|
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); |
---|
41 | |
---|
42 | /* !!!!! here is private section , do not access there member direct !!!!! */ |
---|
43 | |
---|
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 */ |
---|
48 | |
---|
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] */ |
---|
73 | /* LFO */ |
---|
74 | UINT8 ams; /* ams flag */ |
---|
75 | UINT8 vib; /* vibrate flag */ |
---|
76 | /* wave selector */ |
---|
77 | INT32 **wavetable; |
---|
78 | }OPL_SLOT; |
---|
79 | |
---|
80 | /* ---------- OPL one of channel ---------- */ |
---|
81 | typedef struct fm_opl_channel { |
---|
82 | OPL_SLOT SLOT[2]; |
---|
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 */ |
---|
94 | } OPL_CH; |
---|
95 | |
---|
96 | /* OPL state */ |
---|
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. */ |
---|
107 | /* Timer */ |
---|
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 */ |
---|
113 | /* Rythm sention */ |
---|
114 | UINT8 rythm; /* Rythm mode , key flag */ |
---|
115 | #if BUILD_Y8950 |
---|
116 | /* Delta-T ADPCM unit (Y8950) */ |
---|
117 | YM_DELTAT *deltat; /* DELTA-T ADPCM */ |
---|
118 | #endif |
---|
119 | /* Keyboard / I/O interface unit (Y8950) */ |
---|
120 | UINT8 portDirection; |
---|
121 | UINT8 portLatch; |
---|
122 | OPL_PORTHANDLER_R porthandler_r; |
---|
123 | OPL_PORTHANDLER_W porthandler_w; |
---|
124 | int port_param; |
---|
125 | OPL_PORTHANDLER_R keyboardhandler_r; |
---|
126 | OPL_PORTHANDLER_W keyboardhandler_w; |
---|
127 | int keyboard_param; |
---|
128 | /* time tables */ |
---|
129 | INT32 AR_TABLE[75]; /* atttack rate tables */ |
---|
130 | INT32 DR_TABLE[75]; /* decay rate tables */ |
---|
131 | UINT32 FN_TABLE[1024]; /* fnumber -> increment counter */ |
---|
132 | /* LFO */ |
---|
133 | INT32 *ams_table; |
---|
134 | INT32 *vib_table; |
---|
135 | INT32 amsCnt; |
---|
136 | INT32 amsIncr; |
---|
137 | INT32 vibCnt; |
---|
138 | INT32 vibIncr; |
---|
139 | /* wave selector enable flag */ |
---|
140 | UINT8 wavesel; |
---|
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 */ |
---|
148 | } FM_OPL; |
---|
149 | |
---|
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) |
---|
154 | |
---|
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); |
---|
163 | |
---|
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); |
---|
168 | |
---|
169 | /* YM3626/YM3812 local section */ |
---|
170 | void YM3812UpdateOne(FM_OPL *OPL, INT16 *buffer, int length); |
---|
171 | |
---|
172 | void Y8950UpdateOne(FM_OPL *OPL, INT16 *buffer, int length); |
---|
173 | |
---|
174 | #endif |
---|