audio.c File Reference

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include "audio.h"
#include "audio_oss.h"
#include "audio_alsa.h"

Include dependency graph for audio.c:

Go to the source code of this file.

Data Structures

struct  ts_audio_device

Defines

#define AUDIO_NUMBER_OF_DEVICE_TYPES   ( (sizeof(AUDIO_DEVICE_TABLE) / sizeof(AUDIO_DEVICE_TABLE[0])) - 1)

Functions

static void error_message (char *msg)
p_audio_device audio_create (uint32_t device_type, te_audio_rec_play rec_play)
int32_t audio_open (p_audio_device device, int32_t sample_frequency)
int32_t audio_close (p_audio_device device)
int32_t audio_init (p_audio_device device)
int32_t audio_destroy (p_audio_device *device)
void audio_capture (p_audio_device device, te_audio_segments buffer_segment)
void audio_capture_wait (p_audio_device device, te_audio_segments buffer_segment)
void audio_play (p_audio_device device, te_audio_segments buffer_segment)
void audio_raw2double (p_audio_device device, te_audio_segments buffer_segment, double *audio_data)
void audio_double2raw (p_audio_device device, te_audio_segments buffer_segment, double *audio_data)
uint32_t audio_device_samples_get (p_audio_device device)
int32_t audio_supported_device_types_get (void)
char * audio_device_type_name_get (int32_t audio_device_type_id)
void audio_device_name_set (p_audio_device device, const char *name)
void audio_device_name_get (p_audio_device device, char **name)
void audio_sample_rate_set (p_audio_device device, int32_t Hertz)
int32_t audio_sample_rate_get (p_audio_device device)
void register_error_message_handler (message_handler handler)

Variables

static message_handler msg_handler = NULL
static const ts_audio_api AUDIO_DEVICE_TABLE []


Define Documentation

#define AUDIO_NUMBER_OF_DEVICE_TYPES   ( (sizeof(AUDIO_DEVICE_TABLE) / sizeof(AUDIO_DEVICE_TABLE[0])) - 1)

Definition at line 64 of file audio.c.

Referenced by audio_create(), and audio_supported_device_types_get().


Function Documentation

void audio_capture ( p_audio_device  device,
te_audio_segments  buffer_segment 
)

Capture raw audio data from audio device.

Parameters:
device The audio device object.
See also:
p_audio_device
Parameters:
buffer_segment The buffer segment to put data into.

Definition at line 150 of file audio.c.

References ts_audio_device::audio_api, ts_audio_device::audio_pub, ts_audio_api::record, and ts_audio_device::segment_cond_t.

Referenced by data_collection().

void audio_capture_wait ( p_audio_device  device,
te_audio_segments  buffer_segment 
)

Blocking function that releases when buffer segment has been captured.

Parameters:
device The audio device object.
See also:
p_audio_device
Parameters:
buffer_segment The buffer segment capture to wait on.

Definition at line 158 of file audio.c.

References ts_audio_device::segment_cond_t, and ts_audio_device::segment_mutex_t.

Referenced by audio_post_process().

int32_t audio_close ( p_audio_device  device  ) 

Close audio device.

Note:
Audio device MUST be created first.
See also:
audio_create
Parameters:
device Pointer to audio device object.
See also:
p_audio_device
Returns:
-1 if error, 0 if no error.

Definition at line 117 of file audio.c.

References ts_audio_device::audio_api, ts_audio_device::audio_pub, and ts_audio_api::close.

Referenced by free_all().

p_audio_device audio_create ( uint32_t  device_type,
te_audio_rec_play  rec_play 
)

Creates an audio object.

Parameters:
device_type OSS, ALSA, ...
rec_play REcord or Playback device.
See also:
te_audio_rec_play
Returns:
Pointer to audio object.
See also:
p_audio_device

Definition at line 66 of file audio.c.

References ts_audio_device::audio_api, ts_audio_pub::audio_buffer_raw, AUDIO_BUFFER_SEGMENTS, AUDIO_NUMBER_OF_DEVICE_TYPES, ts_audio_device::audio_pub, error_message(), ts_audio_pub::error_msg_handler, ts_audio_pub::play_record, ts_audio_device::segment_cond_t, and ts_audio_device::segment_mutex_t.

Referenced by audio_loopback_start(), and morse_initialize().

Here is the call graph for this function:

int32_t audio_destroy ( p_audio_device device  ) 

Close and release audio device.

Note:
Audio device MUST be created for this to apply.
See also:
audio_create
Parameters:
device Pointer to audio device object.
See also:
p_audio_device
Returns:
-1 if error, 0 if no error.

Definition at line 137 of file audio.c.

Referenced by audio_loopback_stop(), and morse_shutdown().

void audio_device_name_get ( p_audio_device  device,
char **  name 
)

Get the audio device name, i.e. /dev/dsp.

Parameters:
device Pointer to the audio device
name Destination for audio device name.

Definition at line 264 of file audio.c.

References ts_audio_device::audio_pub, and ts_audio_pub::name.

Referenced by on_morse2txt_properties_show(), and save_config_file().

void audio_device_name_set ( p_audio_device  device,
const char *  name 
)

Set the audio device name, i.e. /dev/dsp.

Parameters:
device Pointer to the audio device
name Audio device name to set.
See also:
audio_create

Definition at line 257 of file audio.c.

References AUDIO_DEVICE_NAME_LENGTH, ts_audio_device::audio_pub, and ts_audio_pub::name.

Referenced by load_config_file(), and on_morse2txt_properties_apply().

uint32_t audio_device_samples_get ( p_audio_device  device  ) 

Returns the samples that will be captured by the audio device.

See also:
p_audio_device
Parameters:
device Pointer to the audio device
See also:
audio_create
Returns:
The number of samples to be acquired by the audio device.

Definition at line 220 of file audio.c.

References ts_audio_device::audio_pub, and ts_audio_pub::samples.

Referenced by audio_loopback_start(), audio_post_process(), morse_code(), morse_create_fft_amp_array(), and morse_start_threads().

char* audio_device_type_name_get ( int32_t  audio_device_type_id  ) 

Get the name of audio device type.

Parameters:
audio_device_type_id Device type Id.
Returns:
Pointer to the name of the audio device API (OSS, Alsa, ...)

Definition at line 249 of file audio.c.

References ts_audio_api::audio_device_type_name.

Referenced by on_morse2txt_properties_show().

void audio_double2raw ( p_audio_device  device,
te_audio_segments  buffer_segment,
double *  audio_data 
)

Converts double audio data to raw for soundcard.

Parameters:
device The audio device object.
buffer_segment the buffer segment to convert to fill with raw.
audio_data Pointer to double formatted audio data.
Note:
This assumes that the real audio data is not clipped.
See also:
p_audio_device

Definition at line 197 of file audio.c.

References ts_audio_pub::audio_buffer_raw, ts_audio_pub::audio_buffer_size, ts_audio_device::audio_pub, and ts_audio_pub::dsp_channels.

Referenced by audio_loopback_convert_thr().

int32_t audio_init ( p_audio_device  device  ) 

Initialize audio device.

Note:
Audio device MUST be opened first.
See also:
audio_open
Parameters:
device Pointer to audio device object.
See also:
p_audio_device
Returns:
-1 if error, 0 if no error.

Definition at line 127 of file audio.c.

References ts_audio_device::audio_api, ts_audio_device::audio_pub, and ts_audio_api::init.

Referenced by audio_loopback_start().

int32_t audio_open ( p_audio_device  device,
int32_t  sample_frequency 
)

Open audio device.

Note:
Audio device MUST be created first.
See also:
audio_create
Parameters:
device Pointer to audio device object.
See also:
p_audio_device
Parameters:
sample_frequency Sample frequency in Hertz.
Returns:
-1 if error, 0 if no error.

Definition at line 101 of file audio.c.

References ts_audio_device::audio_api, ts_audio_device::audio_pub, ts_audio_api::init, ts_audio_api::open, and ts_audio_pub::sample_frequency.

Referenced by audio_loopback_start(), and morse_start_threads().

void audio_play ( p_audio_device  device,
te_audio_segments  buffer_segment 
)

Send raw audio data to audio device.

Parameters:
device The audio device object.
See also:
p_audio_device
Parameters:
buffer_segment The buffer segment to play.

Definition at line 165 of file audio.c.

References ts_audio_device::audio_api, ts_audio_device::audio_pub, and ts_audio_api::play.

Referenced by audio_loopback_thr().

void audio_raw2double ( p_audio_device  device,
te_audio_segments  buffer_segment,
double *  audio_data 
)

Converts the raw audio data to real.

Note:
Real data is required GSL's FFT library.
Parameters:
device The audio device object.
See also:
p_audio_device
Parameters:
buffer_segment the buffer segment to convert to real.
audio_data Pointer to scaled audio data.

Definition at line 172 of file audio.c.

References ts_audio_pub::audio_buffer_raw, ts_audio_pub::audio_buffer_size, ts_audio_device::audio_pub, ts_audio_pub::dsp_channels, and ts_audio_device::segment_mutex_t.

Referenced by audio_post_process().

int32_t audio_sample_rate_get ( p_audio_device  device  ) 

Get the audio sample rate.

Returns:
Sample rate in Hertz.

Note:
This assumes record and playback are at the same rate. The audio API could support multiple cards at different rates, but that capability will not be used for now.

Definition at line 281 of file audio.c.

References ts_audio_device::audio_pub, and ts_audio_pub::sample_frequency.

Referenced by morse_start_threads().

void audio_sample_rate_set ( p_audio_device  device,
int32_t  Hertz 
)

Set the audio device sample rate.

Parameters:
device Pointer to the audio device
Hertz Frequency in Hertz.

Definition at line 274 of file audio.c.

References ts_audio_device::audio_pub, and ts_audio_pub::sample_frequency.

int32_t audio_supported_device_types_get ( void   ) 

Get the number of audio device types supported (OSS, Alsa, etc.).

Returns:
The number of audio device API's supported.

Definition at line 244 of file audio.c.

References AUDIO_NUMBER_OF_DEVICE_TYPES.

static void error_message ( char *  msg  )  [static]

Definition at line 231 of file audio.c.

References msg_handler.

Referenced by audio_create().

void register_error_message_handler ( message_handler  handler  ) 

Used to register an external error message handler function.

Definition at line 299 of file audio.c.

References msg_handler.

Referenced by init_gui_interface_hooks().


Variable Documentation

const ts_audio_api AUDIO_DEVICE_TABLE[] [static]

Initial value:

 {
    
    {
        .audio_device_type_name         =   "OSS",
        .open                           =    audio_open_oss,
        .init                           =    audio_init_oss,
        .close                          =    audio_close_oss,
        .play                           =    audio_play_oss,
        .record                         =    audio_record_oss
    },
    
    {
        .audio_device_type_name         =   "Alsa",
        .open                           =    audio_open_alsa,
        .init                           =    audio_init_alsa,
        .close                          =    audio_close_alsa,
        .play                           =    audio_play_alsa,
        .record                         =    audio_record_alsa
    },
    
    AUDIO_DEVICE_TEMINATOR
}

Definition at line 42 of file audio.c.

message_handler msg_handler = NULL [static]

Definition at line 30 of file audio.c.

Referenced by error_message(), and register_error_message_handler().


Generated on Mon Jun 22 21:38:38 2009 for morse2txt by  doxygen 1.5.6