Search
lxdream.org :: lxdream/src/aica/audio.h
lxdream 0.9.1
released Jun 29
Download Now
filename src/aica/audio.h
changeset 1024:c67f2d61ab97
prev759:f16975739abc
next1089:a3984d242909
author nkeynes
date Sun Jul 05 13:52:50 2009 +1000 (14 years ago)
permissions -rw-r--r--
last change No-op merge lxdream-mmu to remove head (actually merged long ago)
file annotate diff log raw
nkeynes@66
     1
/**
nkeynes@561
     2
 * $Id$
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@736
    18
#ifndef lxdream_audio_H
nkeynes@736
    19
#define lxdream_audio_H 1
nkeynes@66
    20
nkeynes@66
    21
#include <stdint.h>
nkeynes@465
    22
#include <stdio.h>
nkeynes@66
    23
#include <glib/gtypes.h>
nkeynes@755
    24
#include "gettext.h"
nkeynes@1024
    25
#include "plugin.h"
nkeynes@700
    26
nkeynes@66
    27
#ifdef __cplusplus
nkeynes@66
    28
extern "C" {
nkeynes@66
    29
#endif
nkeynes@66
    30
nkeynes@465
    31
#define AUDIO_CHANNEL_COUNT 64
nkeynes@465
    32
nkeynes@66
    33
#define AUDIO_FMT_8BIT 0
nkeynes@66
    34
#define AUDIO_FMT_16BIT 1
nkeynes@66
    35
#define AUDIO_FMT_ADPCM 2
nkeynes@697
    36
#define AUDIO_FMT_FLOAT 3  // 32-bit -1.0 to 1.0
nkeynes@66
    37
#define AUDIO_FMT_MONO 0
nkeynes@66
    38
#define AUDIO_FMT_STEREO 4
nkeynes@66
    39
#define AUDIO_FMT_SIGNED 0
nkeynes@66
    40
#define AUDIO_FMT_UNSIGNED 8
nkeynes@697
    41
    
nkeynes@697
    42
#define AUDIO_FMT_SAMPLE_MASK 3
nkeynes@66
    43
nkeynes@106
    44
#define AUDIO_FMT_16ST (AUDIO_FMT_16BIT|AUDIO_FMT_STEREO)
nkeynes@697
    45
#define AUDIO_FMT_FLOATST (AUDIO_FMT_FLOAT|AUDIO_FMT_STEREO)
nkeynes@66
    46
nkeynes@697
    47
#define DEFAULT_SAMPLE_RATE 44100
nkeynes@697
    48
#define DEFAULT_SAMPLE_FORMAT AUDIO_FMT_16ST
nkeynes@697
    49
    
nkeynes@463
    50
typedef enum { LOOP_OFF = 0, LOOP_ON = 1, LOOP_LOOPED = 2 } loop_t;
nkeynes@463
    51
nkeynes@66
    52
typedef struct audio_channel {
nkeynes@66
    53
    gboolean active;
nkeynes@434
    54
    uint32_t posn; /* current sample #, 0 = first sample */
nkeynes@66
    55
    uint32_t posn_left;
nkeynes@66
    56
    uint32_t start;
nkeynes@66
    57
    uint32_t end;
nkeynes@463
    58
    loop_t loop;
nkeynes@66
    59
    uint32_t loop_start;
nkeynes@82
    60
    int vol; /* 0..255 */
nkeynes@82
    61
    int pan; /* 0 (left) .. 31 (right) */
nkeynes@66
    62
    uint32_t sample_rate;
nkeynes@66
    63
    int sample_format; 
nkeynes@66
    64
    /* Envelope etc stuff */
nkeynes@66
    65
    /* ADPCM */
nkeynes@66
    66
    int adpcm_step;
nkeynes@66
    67
    int adpcm_predict;
nkeynes@66
    68
} *audio_channel_t;
nkeynes@66
    69
nkeynes@66
    70
nkeynes@66
    71
typedef struct audio_buffer {
nkeynes@73
    72
    uint32_t length; /* Bytes */
nkeynes@73
    73
    uint32_t posn; /* Bytes */
nkeynes@66
    74
    int status;
nkeynes@66
    75
    char data[0];
nkeynes@66
    76
} *audio_buffer_t;
nkeynes@66
    77
nkeynes@91
    78
typedef struct audio_driver {
nkeynes@1024
    79
    const char *name;
nkeynes@1024
    80
    const char *description;
nkeynes@1024
    81
    int priority; /* Lower == higher priority */
nkeynes@697
    82
    uint32_t sample_rate;
nkeynes@697
    83
    uint32_t sample_format;
nkeynes@697
    84
    gboolean (*init)( );
nkeynes@697
    85
    void (*start)( );
nkeynes@66
    86
    gboolean (*process_buffer)( audio_buffer_t buffer );
nkeynes@697
    87
    void (*stop)( );
nkeynes@697
    88
    gboolean (*shutdown)(  );
nkeynes@91
    89
} *audio_driver_t;
nkeynes@66
    90
nkeynes@700
    91
nkeynes@700
    92
/**
nkeynes@700
    93
 * Print the configured audio drivers to the output stream, one to a line.
nkeynes@700
    94
 */
nkeynes@700
    95
void print_audio_drivers( FILE *out );
nkeynes@700
    96
nkeynes@531
    97
audio_driver_t get_audio_driver_by_name( const char *name );
nkeynes@531
    98
nkeynes@66
    99
/**
nkeynes@66
   100
 * Set the output driver, sample rate and format. Also initializes the 
nkeynes@66
   101
 * output buffers, flushing any current data and reallocating as 
nkeynes@66
   102
 * necessary. Must be called before attempting to generate any audio.
nkeynes@66
   103
 */
nkeynes@697
   104
gboolean audio_set_driver( audio_driver_t driver );
nkeynes@66
   105
nkeynes@66
   106
/**
nkeynes@759
   107
 * Initialize the audio driver, using the specified driver if available.
nkeynes@759
   108
 */
nkeynes@759
   109
audio_driver_t audio_init_driver( const char *preferred_driver );
nkeynes@759
   110
nkeynes@759
   111
/**
nkeynes@1024
   112
 * Add a new audio driver to the available drivers list
nkeynes@1024
   113
 */
nkeynes@1024
   114
gboolean audio_register_driver( audio_driver_t driver );
nkeynes@1024
   115
nkeynes@1024
   116
/**
nkeynes@1024
   117
 * Signal the audio driver that playback is beginning
nkeynes@1024
   118
 */
nkeynes@1024
   119
void audio_start_driver();
nkeynes@1024
   120
nkeynes@1024
   121
/**
nkeynes@1024
   122
 * Signal the audio driver that playback is stopping
nkeynes@1024
   123
 */
nkeynes@1024
   124
void audio_stop_driver();
nkeynes@1024
   125
nkeynes@1024
   126
/**
nkeynes@66
   127
 * Mark the current write buffer as full and prepare the next buffer for
nkeynes@66
   128
 * writing. Returns the next buffer to write to.
nkeynes@66
   129
 * If all buffers are full, returns NULL.
nkeynes@66
   130
 */
nkeynes@66
   131
audio_buffer_t audio_next_write_buffer();
nkeynes@66
   132
nkeynes@66
   133
/**
nkeynes@66
   134
 * Mark the current read buffer as empty and return the next buffer for
nkeynes@66
   135
 * reading. If there is no next buffer yet, returns NULL.
nkeynes@66
   136
 */
nkeynes@66
   137
audio_buffer_t audio_next_read_buffer();
nkeynes@66
   138
nkeynes@66
   139
/**
nkeynes@66
   140
 * Mix a single output sample and append it to the output buffers
nkeynes@66
   141
 */
nkeynes@73
   142
void audio_mix_samples( int num_samples );
nkeynes@66
   143
nkeynes@66
   144
/**
nkeynes@66
   145
 * Retrieve the channel information for the channel, numbered 0..63. 
nkeynes@66
   146
 */
nkeynes@66
   147
audio_channel_t audio_get_channel( int channel );
nkeynes@66
   148
nkeynes@434
   149
void audio_start_stop_channel( int channel, gboolean start );
nkeynes@66
   150
void audio_start_channel( int channel );
nkeynes@66
   151
void audio_stop_channel( int channel );
nkeynes@66
   152
nkeynes@465
   153
void audio_save_state( FILE *f );
nkeynes@465
   154
int audio_load_state( FILE *f );
nkeynes@66
   155
nkeynes@66
   156
#ifdef __cplusplus
nkeynes@66
   157
}
nkeynes@66
   158
#endif
nkeynes@736
   159
nkeynes@736
   160
#endif /* !lxdream_audio_H */
.