2011-05-14 23:46:11 +00:00
|
|
|
/////
|
|
|
|
// API header for external SSNES audio driver plugins.
|
|
|
|
//
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef __SSNES_AUDIO_DRIVER_PLUGIN_H
|
|
|
|
#define __SSNES_AUDIO_DRIVER_PLUGIN_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef _WIN32
|
|
|
|
#ifdef SSNES_DLL_IMPORT
|
|
|
|
#define SSNES_API_EXPORT __declspec(dllimport)
|
|
|
|
#else
|
|
|
|
#define SSNES_API_EXPORT __declspec(dllexport)
|
|
|
|
#endif
|
|
|
|
#define SSNES_API_CALLTYPE __cdecl
|
|
|
|
#else
|
|
|
|
#define SSNES_API_EXPORT
|
|
|
|
#define SSNES_API_CALLTYPE
|
|
|
|
#endif
|
|
|
|
|
2011-05-17 17:20:41 +00:00
|
|
|
#ifndef SSNES_TRUE
|
2011-05-14 23:46:11 +00:00
|
|
|
#define SSNES_TRUE 1
|
2011-05-17 17:20:41 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef SSNES_FALSE
|
2011-05-14 23:46:11 +00:00
|
|
|
#define SSNES_FALSE 0
|
2011-05-17 17:20:41 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef SSNES_OK
|
2011-05-14 23:46:11 +00:00
|
|
|
#define SSNES_OK 1
|
2011-05-17 17:20:41 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef SSNES_ERROR
|
2011-05-14 23:46:11 +00:00
|
|
|
#define SSNES_ERROR 0
|
2011-05-17 17:20:41 +00:00
|
|
|
#endif
|
2011-05-14 23:46:11 +00:00
|
|
|
|
2011-05-23 12:04:31 +00:00
|
|
|
#define SSNES_AUDIO_API_VERSION 2
|
2011-05-14 23:46:11 +00:00
|
|
|
|
|
|
|
typedef struct ssnes_audio_driver_info
|
|
|
|
{
|
|
|
|
// A hint for a subdevice of the audio driver.
|
|
|
|
// This is driver independent, and not relevant for all
|
|
|
|
// audio drivers. I.e. ALSA driver might use "hw:0",
|
|
|
|
// OSS "/dev/audio", etc.
|
|
|
|
const char *device;
|
|
|
|
|
|
|
|
// Audio sample rate.
|
|
|
|
unsigned sample_rate;
|
|
|
|
|
|
|
|
// Maximum audio latency requested for output,
|
|
|
|
// measured in milliseconds.
|
|
|
|
// If driver is not able to provide this latency, it can
|
|
|
|
// be disregarded.
|
|
|
|
unsigned latency;
|
|
|
|
} ssnes_audio_driver_info_t;
|
|
|
|
|
|
|
|
typedef struct ssnes_audio_driver
|
|
|
|
{
|
|
|
|
// Initializes the device.
|
|
|
|
void* (*init)(const ssnes_audio_driver_info_t *info);
|
|
|
|
|
|
|
|
// Write data in buffer to audio driver.
|
|
|
|
// A frame here is defined as one combined sample of left and right
|
|
|
|
// channels. (I.e. 44.1kHz, 16-bit stereo has 88.2k samples/s, and
|
|
|
|
// 44.1k frames/s.)
|
|
|
|
//
|
|
|
|
// Samples are interleaved in format LRLRLRLRLR ...
|
|
|
|
// If the driver returns true in use_float(), a floating point
|
|
|
|
// format will be used, with range [-1.0, 1.0].
|
|
|
|
// If not, signed 16-bit samples in native byte ordering will be used.
|
|
|
|
//
|
|
|
|
// This function returns the number of frames successfully written.
|
|
|
|
// If an error occurs, -1 should be returned.
|
|
|
|
// Note that non-blocking behavior that cannot write at this time
|
|
|
|
// should return 0 as returning -1 will terminate the driver.
|
|
|
|
//
|
|
|
|
// Unless said otherwise with set_nonblock_state(), all writes
|
|
|
|
// are blocking, and it should block till it has written all frames.
|
|
|
|
int (*write)(void *data, const void *buffer, unsigned frames);
|
|
|
|
|
|
|
|
// Temporarily pauses the audio driver.
|
|
|
|
int (*stop)(void *data);
|
|
|
|
|
|
|
|
// Resumes audio driver from the paused state.
|
|
|
|
int (*start)(void *data);
|
|
|
|
|
|
|
|
// If state is true, nonblocking operation is assumed.
|
|
|
|
// This is typically used for fast-forwarding. If driver cannot
|
|
|
|
// implement nonblocking writes, this can be disregarded, but should
|
|
|
|
// log a message to stderr.
|
|
|
|
void (*set_nonblock_state)(void *data, int state);
|
|
|
|
|
|
|
|
// Stops and frees the audio driver.
|
|
|
|
void (*free)(void *data);
|
|
|
|
|
|
|
|
// If true is returned, the audio driver is capable of using
|
|
|
|
// floating point data. This will likely increase performance as the
|
|
|
|
// resampler unit uses floating point. The sample range is
|
|
|
|
// [-1.0, 1.0].
|
|
|
|
int (*use_float)(void *data);
|
|
|
|
|
2011-05-23 12:04:31 +00:00
|
|
|
// The driver might be forced to use a certain output frequency
|
|
|
|
// (i.e. Jack), and thus to avoid double resampling, the driver
|
|
|
|
// can request SSNES to resample to a different sample rate.
|
|
|
|
// This function can be set to NULL if the driver does not
|
|
|
|
// desire to override the sample rate.
|
|
|
|
unsigned (*sample_rate)(void *data);
|
|
|
|
|
2011-05-14 23:46:11 +00:00
|
|
|
// Human readable identification string for the driver.
|
|
|
|
const char *ident;
|
|
|
|
|
2011-05-17 17:20:41 +00:00
|
|
|
// Must be set to SSNES_AUDIO_API_VERSION.
|
2011-05-14 23:46:11 +00:00
|
|
|
// Used for detecting API mismatch.
|
|
|
|
int api_version;
|
|
|
|
} ssnes_audio_driver_t;
|
|
|
|
|
|
|
|
SSNES_API_EXPORT const ssnes_audio_driver_t* SSNES_API_CALLTYPE
|
|
|
|
ssnes_audio_driver_init(void);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|