Mercurial > mplayer.hg
view libao2/ao_dxr3.c @ 2652:fd279f14b9ab
new stream field: size
author | arpi |
---|---|
date | Sat, 03 Nov 2001 20:57:13 +0000 |
parents | 9d8d69fc517c |
children | b9732eaa82d9 |
line wrap: on
line source
#include <stdio.h> #include <stdlib.h> #include <time.h> #include <unistd.h> #include <sys/types.h> #include <sys/ioctl.h> #include <libdxr3/api.h> #include "../config.h" #include "afmt.h" #include "audio_out.h" #include "audio_out_internal.h" struct { int ao_format; int ao_rate; int ao_channels; } ao_device; static ao_info_t info = { "DXR3/H+ audio out", "dxr3", "David Holm <dholm@iname.com>", "" }; LIBAO_EXTERN(dxr3) // there are some globals: // ao_samplerate // ao_channels // ao_format // ao_bps // ao_outburst // ao_buffersize // to set/get/query special features/parameters static int control(int cmd,int arg) { switch(cmd) { case AOCONTROL_SET_DEVICE: return CONTROL_OK; case AOCONTROL_QUERY_FORMAT: return CONTROL_TRUE; case AOCONTROL_GET_VOLUME: case AOCONTROL_SET_VOLUME: { return CONTROL_OK; } } return CONTROL_TRUE; } // open & setup audio device // return: 1=success 0=fail static int init(int rate,int channels,int format,int flags) { ao_device.ao_format = format; ao_device.ao_rate = rate; ao_device.ao_channels = channels; if( dxr3_get_status() == DXR3_STATUS_CLOSED ) { if( dxr3_open( "/dev/em8300", "/etc/dxr3.ux" ) != 0 ) printf( "Error loading /dev/em8300 with /etc/dxr3.ux microcode\n" ); printf( "DXR3 status: &s\n", dxr3_get_status() ? "opened":"closed" ); } else printf( "DXR3 already open\n" ); if( dxr3_set_playmode( DXR3_PLAYMODE_PLAY ) != 0 ) printf( "Error setting playmode of DXR3\n" ); if( format == AFMT_AC3 ) { if( dxr3_audio_set_mode( DXR3_AUDIOMODE_DIGITALAC3 ) != 0 ) { printf( "Cannot set DXR3 to AC3 playback!\n" ); return -1; } } else { if( dxr3_audio_set_mode( DXR3_AUDIOMODE_ANALOG ) != 0 ) { printf( "Cannot set DXR3 to analog playback!\n" ); return -1; } if( format == AFMT_U8 ) dxr3_audio_set_samplesize( 8 ); else if( format == AFMT_S16_LE ) dxr3_audio_set_samplesize( 16 ); else { printf( "Unsupported audio format\n" ); return -1; } } dxr3_audio_set_stereo( (channels > 1) ? "true":"false" ); dxr3_audio_set_rate( rate ); return 1; } // close audio device static void uninit() { dxr3_close(); } // stop playing and empty buffers (for seeking/pause) static void reset() { uninit(); if( !init( ao_device.ao_rate, ao_device.ao_channels, ao_device.ao_format, 0 ) ) printf("\nFatal error: *** CANNOT RE-OPEN / RESET AUDIO DEVICE ***\n"); } // stop playing, keep buffers (for pause) static void audio_pause() { // for now, just call reset(); reset(); } // resume playing, after audio_pause() static void audio_resume() { } // return: how many bytes can be played without blocking static int get_space() { return dxr3_audio_get_buffersize()-dxr3_audio_get_bytesleft(); } // plays 'len' bytes of 'data' // it should round it down to outburst*n // return: number of bytes played static int play(void* data,int len,int flags) { if(len) if( ao_device.ao_format == AFMT_AC3 ) return dxr3_audio_write_ac3( data, len ); else return dxr3_audio_write_ac3( data, len ); printf( "Invalid audio data\n" ); return 0; } // return: how many unplayed bytes are in the buffer static int get_delay() { return dxr3_audio_get_bytesleft(); }