Search
lxdream.org :: lxdream/src/aica/audio.h
lxdream 0.9.1
released Jun 29
Download Now
filename src/aica/audio.h
changeset 74:771ee2b1e4f8
prev73:0bb57e51ac9e
next82:81a4acf75f10
author nkeynes
date Mon Jan 16 11:23:28 2006 +0000 (18 years ago)
permissions -rw-r--r--
last change Tweaks to timer to make sure it's actually a one-shot
file annotate diff log raw
nkeynes@66
     1
/**
nkeynes@74
     2
 * $Id: audio.h,v 1.3 2006-01-12 12:38:59 nkeynes Exp $
nkeynes@66
     3
 * 
nkeynes@66
     4
 * Audio engine, ie the part that does the actual work.
nkeynes@66
     5
 *
nkeynes@66
     6
 * Copyright (c) 2005 Nathan Keynes.
nkeynes@66
     7
 *
nkeynes@66
     8
 * This program is free software; you can redistribute it and/or modify
nkeynes@66
     9
 * it under the terms of the GNU General Public License as published by
nkeynes@66
    10
 * the Free Software Foundation; either version 2 of the License, or
nkeynes@66
    11
 * (at your option) any later version.
nkeynes@66
    12
 *
nkeynes@66
    13
 * This program is distributed in the hope that it will be useful,
nkeynes@66
    14
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
nkeynes@66
    15
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
nkeynes@66
    16
 * GNU General Public License for more details.
nkeynes@66
    17
 */
nkeynes@66
    18
#ifndef dream_audio_H
nkeynes@66
    19
#define dream_audio_H 1
nkeynes@66
    20
nkeynes@66
    21
#include <stdint.h>
nkeynes@66
    22
#include <glib/gtypes.h>
nkeynes@66
    23
nkeynes@66
    24
#ifdef __cplusplus
nkeynes@66
    25
extern "C" {
nkeynes@66
    26
#endif
nkeynes@66
    27
nkeynes@66
    28
#define AUDIO_FMT_8BIT 0
nkeynes@66
    29
#define AUDIO_FMT_16BIT 1
nkeynes@66
    30
#define AUDIO_FMT_ADPCM 2
nkeynes@66
    31
#define AUDIO_FMT_MONO 0
nkeynes@66
    32
#define AUDIO_FMT_STEREO 4
nkeynes@66
    33
#define AUDIO_FMT_SIGNED 0
nkeynes@66
    34
#define AUDIO_FMT_UNSIGNED 8
nkeynes@66
    35
nkeynes@66
    36
nkeynes@66
    37
typedef struct audio_channel {
nkeynes@66
    38
    gboolean active;
nkeynes@66
    39
    uint32_t posn;
nkeynes@66
    40
    uint32_t posn_left;
nkeynes@66
    41
    uint32_t start;
nkeynes@66
    42
    uint32_t end;
nkeynes@73
    43
    gboolean loop;
nkeynes@66
    44
    uint32_t loop_start;
nkeynes@66
    45
    int vol_left; /* 0..255 */
nkeynes@66
    46
    int vol_right; /* 0..255 */
nkeynes@66
    47
    uint32_t sample_rate;
nkeynes@66
    48
    int sample_format; 
nkeynes@66
    49
    /* Envelope etc stuff */
nkeynes@66
    50
    /* ADPCM */
nkeynes@66
    51
    int adpcm_nibble; /* 0 = low nibble, 1 = high nibble */
nkeynes@66
    52
    int adpcm_step;
nkeynes@66
    53
    int adpcm_predict;
nkeynes@66
    54
} *audio_channel_t;
nkeynes@66
    55
nkeynes@66
    56
nkeynes@66
    57
typedef struct audio_buffer {
nkeynes@73
    58
    uint32_t length; /* Bytes */
nkeynes@73
    59
    uint32_t posn; /* Bytes */
nkeynes@66
    60
    int status;
nkeynes@66
    61
    char data[0];
nkeynes@66
    62
} *audio_buffer_t;
nkeynes@66
    63
nkeynes@66
    64
struct audio_driver {
nkeynes@74
    65
    char *name;
nkeynes@66
    66
    gboolean (*set_output_format)( uint32_t sample_rate, uint32_t format );
nkeynes@66
    67
    gboolean (*process_buffer)( audio_buffer_t buffer );
nkeynes@66
    68
};
nkeynes@66
    69
nkeynes@66
    70
typedef struct audio_driver *audio_driver_t;
nkeynes@66
    71
nkeynes@66
    72
extern struct audio_driver null_audio_driver;
nkeynes@66
    73
extern struct audio_driver esd_audio_driver;
nkeynes@66
    74
nkeynes@66
    75
/**
nkeynes@66
    76
 * Set the output driver, sample rate and format. Also initializes the 
nkeynes@66
    77
 * output buffers, flushing any current data and reallocating as 
nkeynes@66
    78
 * necessary. Must be called before attempting to generate any audio.
nkeynes@66
    79
 */
nkeynes@66
    80
void audio_set_output( audio_driver_t driver, uint32_t samplerate,
nkeynes@66
    81
		       int format );
nkeynes@66
    82
nkeynes@66
    83
/**
nkeynes@66
    84
 * Mark the current write buffer as full and prepare the next buffer for
nkeynes@66
    85
 * writing. Returns the next buffer to write to.
nkeynes@66
    86
 * If all buffers are full, returns NULL.
nkeynes@66
    87
 */
nkeynes@66
    88
audio_buffer_t audio_next_write_buffer();
nkeynes@66
    89
nkeynes@66
    90
/**
nkeynes@66
    91
 * Mark the current read buffer as empty and return the next buffer for
nkeynes@66
    92
 * reading. If there is no next buffer yet, returns NULL.
nkeynes@66
    93
 */
nkeynes@66
    94
audio_buffer_t audio_next_read_buffer();
nkeynes@66
    95
nkeynes@66
    96
/**
nkeynes@66
    97
 * Mix a single output sample and append it to the output buffers
nkeynes@66
    98
 */
nkeynes@73
    99
void audio_mix_samples( int num_samples );
nkeynes@66
   100
nkeynes@66
   101
/**
nkeynes@66
   102
 * Retrieve the channel information for the channel, numbered 0..63. 
nkeynes@66
   103
 */
nkeynes@66
   104
audio_channel_t audio_get_channel( int channel );
nkeynes@66
   105
nkeynes@66
   106
void audio_start_channel( int channel );
nkeynes@66
   107
void audio_stop_channel( int channel );
nkeynes@66
   108
nkeynes@66
   109
nkeynes@66
   110
#ifdef __cplusplus
nkeynes@66
   111
}
nkeynes@66
   112
#endif
nkeynes@66
   113
#endif
.