]> Git Repo - qemu.git/blame - hw/audio/fmopl.h
audio: remove UINT16
[qemu.git] / hw / audio / fmopl.h
CommitLineData
2a6a4076
MA
1#ifndef FMOPL_H
2#define FMOPL_H
85571bc7 3
4a796e97
JQ
4#include <stdint.h>
5
85571bc7
FB
6/* --- system optimize --- */
7/* select bit size of output : 8 or 16 */
8#define OPL_OUTPUT_BIT 16
9
10/* compiler dependence */
11#ifndef OSD_CPU_H
12#define OSD_CPU_H
85571bc7
FB
13typedef unsigned int UINT32; /* unsigned 32bit */
14typedef signed char INT8; /* signed 8bit */
15typedef signed short INT16; /* signed 16bit */
16typedef signed int INT32; /* signed 32bit */
17#endif
18
19#if (OPL_OUTPUT_BIT==16)
20typedef INT16 OPLSAMPLE;
21#endif
22#if (OPL_OUTPUT_BIT==8)
23typedef unsigned char OPLSAMPLE;
24#endif
25
85571bc7
FB
26typedef void (*OPL_TIMERHANDLER)(int channel,double interval_Sec);
27typedef void (*OPL_IRQHANDLER)(int param,int irq);
28typedef void (*OPL_UPDATEHANDLER)(int param,int min_interval_us);
29typedef void (*OPL_PORTHANDLER_W)(int param,unsigned char data);
30typedef unsigned char (*OPL_PORTHANDLER_R)(int param);
31
32/* !!!!! here is private section , do not access there member direct !!!!! */
33
34#define OPL_TYPE_WAVESEL 0x01 /* waveform select */
35#define OPL_TYPE_ADPCM 0x02 /* DELTA-T ADPCM unit */
36#define OPL_TYPE_KEYBOARD 0x04 /* keyboard interface */
37#define OPL_TYPE_IO 0x08 /* I/O port */
38
39/* Saving is necessary for member of the 'R' mark for suspend/resume */
40/* ---------- OPL one of slot ---------- */
41typedef struct fm_opl_slot {
42 INT32 TL; /* total level :TL << 8 */
43 INT32 TLL; /* adjusted now TL */
4a796e97 44 uint8_t KSR; /* key scale rate :(shift down bit) */
85571bc7
FB
45 INT32 *AR; /* attack rate :&AR_TABLE[AR<<2] */
46 INT32 *DR; /* decay rate :&DR_TALBE[DR<<2] */
47 INT32 SL; /* sustin level :SL_TALBE[SL] */
48 INT32 *RR; /* release rate :&DR_TABLE[RR<<2] */
4a796e97
JQ
49 uint8_t ksl; /* keyscale level :(shift down bits) */
50 uint8_t ksr; /* key scale rate :kcode>>KSR */
85571bc7
FB
51 UINT32 mul; /* multiple :ML_TABLE[ML] */
52 UINT32 Cnt; /* frequency count : */
53 UINT32 Incr; /* frequency step : */
54 /* envelope generator state */
4a796e97
JQ
55 uint8_t eg_typ; /* envelope type flag */
56 uint8_t evm; /* envelope phase */
85571bc7
FB
57 INT32 evc; /* envelope counter */
58 INT32 eve; /* envelope counter end point */
59 INT32 evs; /* envelope counter step */
60 INT32 evsa; /* envelope step for AR :AR[ksr] */
61 INT32 evsd; /* envelope step for DR :DR[ksr] */
62 INT32 evsr; /* envelope step for RR :RR[ksr] */
63 /* LFO */
4a796e97
JQ
64 uint8_t ams; /* ams flag */
65 uint8_t vib; /* vibrate flag */
85571bc7
FB
66 /* wave selector */
67 INT32 **wavetable;
68}OPL_SLOT;
69
70/* ---------- OPL one of channel ---------- */
71typedef struct fm_opl_channel {
72 OPL_SLOT SLOT[2];
4a796e97
JQ
73 uint8_t CON; /* connection type */
74 uint8_t FB; /* feed back :(shift down bit) */
85571bc7
FB
75 INT32 *connect1; /* slot1 output pointer */
76 INT32 *connect2; /* slot2 output pointer */
77 INT32 op1_out[2]; /* slot1 output for selfeedback */
78 /* phase generator state */
79 UINT32 block_fnum; /* block+fnum : */
4a796e97 80 uint8_t kcode; /* key code : KeyScaleCode */
85571bc7
FB
81 UINT32 fc; /* Freq. Increment base */
82 UINT32 ksl_base; /* KeyScaleLevel Base step */
4a796e97 83 uint8_t keyon; /* key on/off flag */
85571bc7
FB
84} OPL_CH;
85
86/* OPL state */
87typedef struct fm_opl_f {
4a796e97 88 uint8_t type; /* chip type */
85571bc7
FB
89 int clock; /* master clock (Hz) */
90 int rate; /* sampling rate (Hz) */
91 double freqbase; /* frequency base */
92 double TimerBase; /* Timer base time (==sampling time) */
4a796e97
JQ
93 uint8_t address; /* address register */
94 uint8_t status; /* status flag */
95 uint8_t statusmask; /* status mask */
85571bc7
FB
96 UINT32 mode; /* Reg.08 : CSM , notesel,etc. */
97 /* Timer */
98 int T[2]; /* timer counter */
4a796e97 99 uint8_t st[2]; /* timer enable */
85571bc7
FB
100 /* FM channel slots */
101 OPL_CH *P_CH; /* pointer of CH */
102 int max_ch; /* maximum channel */
c11e80e2 103 /* Rhythm sention */
4a796e97 104 uint8_t rhythm; /* Rhythm mode , key flag */
85571bc7
FB
105 OPL_PORTHANDLER_R porthandler_r;
106 OPL_PORTHANDLER_W porthandler_w;
107 int port_param;
108 OPL_PORTHANDLER_R keyboardhandler_r;
109 OPL_PORTHANDLER_W keyboardhandler_w;
110 int keyboard_param;
111 /* time tables */
112 INT32 AR_TABLE[75]; /* atttack rate tables */
113 INT32 DR_TABLE[75]; /* decay rate tables */
114 UINT32 FN_TABLE[1024]; /* fnumber -> increment counter */
115 /* LFO */
116 INT32 *ams_table;
117 INT32 *vib_table;
118 INT32 amsCnt;
119 INT32 amsIncr;
120 INT32 vibCnt;
121 INT32 vibIncr;
122 /* wave selector enable flag */
4a796e97 123 uint8_t wavesel;
85571bc7
FB
124 /* external event callback handler */
125 OPL_TIMERHANDLER TimerHandler; /* TIMER handler */
126 int TimerParam; /* TIMER parameter */
127 OPL_IRQHANDLER IRQHandler; /* IRQ handler */
128 int IRQParam; /* IRQ parameter */
129 OPL_UPDATEHANDLER UpdateHandler; /* stream update handler */
130 int UpdateParam; /* stream update parameter */
131} FM_OPL;
132
133/* ---------- Generic interface section ---------- */
85571bc7 134#define OPL_TYPE_YM3812 (OPL_TYPE_WAVESEL)
85571bc7
FB
135
136FM_OPL *OPLCreate(int type, int clock, int rate);
137void OPLDestroy(FM_OPL *OPL);
138void OPLSetTimerHandler(FM_OPL *OPL,OPL_TIMERHANDLER TimerHandler,int channelOffset);
139void OPLSetIRQHandler(FM_OPL *OPL,OPL_IRQHANDLER IRQHandler,int param);
140void OPLSetUpdateHandler(FM_OPL *OPL,OPL_UPDATEHANDLER UpdateHandler,int param);
85571bc7
FB
141
142void OPLResetChip(FM_OPL *OPL);
143int OPLWrite(FM_OPL *OPL,int a,int v);
144unsigned char OPLRead(FM_OPL *OPL,int a);
145int OPLTimerOver(FM_OPL *OPL,int c);
146
85571bc7 147void YM3812UpdateOne(FM_OPL *OPL, INT16 *buffer, int length);
85571bc7 148#endif
This page took 0.785288 seconds and 4 git commands to generate.