symbian-qemu-0.9.1-12/qemu-symbian-svp/hw/fmopl.h
changeset 1 2fb8b9db1c86
equal deleted inserted replaced
0:ffa851df0825 1:2fb8b9db1c86
       
     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