[wrap]
MAME source file: / src / emu / sound / okim6295.h [download] (view on mamedev.org)
#pragma once

#ifndef __OKIM6295_H__
#define __OKIM6295_H__

/* an interface for the OKIM6295 and similar chips */

/*
  Note about the playback frequency: the external clock is internally divided,
  depending on pin 7, by 132 (high) or 165 (low).
*/
typedef struct _okim6295_interface okim6295_interface;
struct _okim6295_interface
{
	int pin7;
	const char *rgnoverride;
};

extern const okim6295_interface okim6295_interface_pin7high;
extern const okim6295_interface okim6295_interface_pin7low;



void okim6295_set_bank_base(int which, int base);
void okim6295_set_pin7(int which, int pin7);

READ8_HANDLER( okim6295_status_0_r );
READ8_HANDLER( okim6295_status_1_r );
READ8_HANDLER( okim6295_status_2_r );
READ16_HANDLER( okim6295_status_0_lsb_r );
READ16_HANDLER( okim6295_status_1_lsb_r );
READ16_HANDLER( okim6295_status_2_lsb_r );
READ16_HANDLER( okim6295_status_0_msb_r );
READ16_HANDLER( okim6295_status_1_msb_r );
READ16_HANDLER( okim6295_status_2_msb_r );
WRITE8_HANDLER( okim6295_data_0_w );
WRITE8_HANDLER( okim6295_data_1_w );
WRITE8_HANDLER( okim6295_data_2_w );
WRITE16_HANDLER( okim6295_data_0_lsb_w );
WRITE16_HANDLER( okim6295_data_1_lsb_w );
WRITE16_HANDLER( okim6295_data_2_lsb_w );
WRITE16_HANDLER( okim6295_data_0_msb_w );
WRITE16_HANDLER( okim6295_data_1_msb_w );
WRITE16_HANDLER( okim6295_data_2_msb_w );

/*
    To help the various custom ADPCM generators out there,
    the following routines may be used.
*/
struct adpcm_state
{
	INT32	signal;
	INT32	step;
};
void reset_adpcm(struct adpcm_state *state);
INT16 clock_adpcm(struct adpcm_state *state, UINT8 nibble);

SND_GET_INFO( okim6295 );

#endif /* __OKIM6295_H__ */
  
2004-2009 MAWS all copyrights belong to their respective owners