source: trunk/packages/xen-3.1/xen-3.1/tools/ioemu/hw/fmopl.h @ 34

Last change on this file since 34 was 34, checked in by hartmans, 18 years ago

Add xen and xen-common

File size: 6.5 KB
Line 
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
16typedef unsigned char   UINT8;   /* unsigned  8bit */
17typedef unsigned short  UINT16;  /* unsigned 16bit */
18typedef unsigned int    UINT32;  /* unsigned 32bit */
19typedef signed char             INT8;    /* signed  8bit   */
20typedef signed short    INT16;   /* signed 16bit   */
21typedef signed int              INT32;   /* signed 32bit   */
22#endif
23
24#if (OPL_OUTPUT_BIT==16)
25typedef INT16 OPLSAMPLE;
26#endif
27#if (OPL_OUTPUT_BIT==8)
28typedef unsigned char  OPLSAMPLE;
29#endif
30
31
32#if BUILD_Y8950
33#include "ymdeltat.h"
34#endif
35
36typedef void (*OPL_TIMERHANDLER)(int channel,double interval_Sec);
37typedef void (*OPL_IRQHANDLER)(int param,int irq);
38typedef void (*OPL_UPDATEHANDLER)(int param,int min_interval_us);
39typedef void (*OPL_PORTHANDLER_W)(int param,unsigned char data);
40typedef 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  ---------- */
51typedef 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  ---------- */
81typedef 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 */
97typedef 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
155FM_OPL *OPLCreate(int type, int clock, int rate);
156void OPLDestroy(FM_OPL *OPL);
157void OPLSetTimerHandler(FM_OPL *OPL,OPL_TIMERHANDLER TimerHandler,int channelOffset);
158void OPLSetIRQHandler(FM_OPL *OPL,OPL_IRQHANDLER IRQHandler,int param);
159void OPLSetUpdateHandler(FM_OPL *OPL,OPL_UPDATEHANDLER UpdateHandler,int param);
160/* Y8950 port handlers */
161void OPLSetPortHandler(FM_OPL *OPL,OPL_PORTHANDLER_W PortHandler_w,OPL_PORTHANDLER_R PortHandler_r,int param);
162void OPLSetKeyboardHandler(FM_OPL *OPL,OPL_PORTHANDLER_W KeyboardHandler_w,OPL_PORTHANDLER_R KeyboardHandler_r,int param);
163
164void OPLResetChip(FM_OPL *OPL);
165int OPLWrite(FM_OPL *OPL,int a,int v);
166unsigned char OPLRead(FM_OPL *OPL,int a);
167int OPLTimerOver(FM_OPL *OPL,int c);
168
169/* YM3626/YM3812 local section */
170void YM3812UpdateOne(FM_OPL *OPL, INT16 *buffer, int length);
171
172void Y8950UpdateOne(FM_OPL *OPL, INT16 *buffer, int length);
173
174#endif
Note: See TracBrowser for help on using the repository browser.