mirror of
https://github.com/mpv-player/mpv
synced 2025-01-15 03:23:23 +00:00
03e3deb95c
broken) - arts server always expects 16-bit sound in little endian byte order, even in the case the artsd server runs on a big endian machine. Make sure that mplayer's audio filters convert the samples into one of the arts supported sound formats. git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@8577 b3059339-0415-0410-9bf9-f77b7e298cf2
137 lines
2.9 KiB
C
137 lines
2.9 KiB
C
/*
|
|
* ao_arts - aRts audio output driver for MPlayer
|
|
*
|
|
* Michele Balistreri <brain87@gmx.net>
|
|
*
|
|
* This driver is distribuited under terms of GPL
|
|
*
|
|
*/
|
|
|
|
#include <artsc.h>
|
|
#include <stdio.h>
|
|
|
|
#include "audio_out.h"
|
|
#include "audio_out_internal.h"
|
|
#include "afmt.h"
|
|
#include "../config.h"
|
|
#include "../mp_msg.h"
|
|
|
|
#define OBTAIN_BITRATE(a) (((a != AFMT_U8) && (a != AFMT_S8)) ? 16 : 8)
|
|
|
|
/* Feel free to experiment with the following values: */
|
|
#define ARTS_PACKETS 10 /* Number of audio packets */
|
|
#define ARTS_PACKET_SIZE_LOG2 11 /* Log2 of audio packet size */
|
|
|
|
static arts_stream_t stream;
|
|
|
|
static ao_info_t info =
|
|
{
|
|
"aRts audio output",
|
|
"arts",
|
|
"Michele Balistreri <brain87@gmx.net>",
|
|
""
|
|
};
|
|
|
|
LIBAO_EXTERN(arts)
|
|
|
|
static int control(int cmd, int arg)
|
|
{
|
|
return(CONTROL_UNKNOWN);
|
|
}
|
|
|
|
static int init(int rate_hz, int channels, int format, int flags)
|
|
{
|
|
int err;
|
|
int frag_spec;
|
|
|
|
if( (err=arts_init()) ) {
|
|
mp_msg(MSGT_AO, MSGL_ERR, "AO: [arts] %s\n", arts_error_text(err));
|
|
return 0;
|
|
}
|
|
mp_msg(MSGT_AO, MSGL_INFO, "AO: [arts] Connected to sound server\n");
|
|
|
|
/*
|
|
* arts supports 8bit unsigned and 16bit signed sample formats
|
|
* (16bit apparently in little endian format, even in the case
|
|
* when artsd runs on a big endian cpu).
|
|
*
|
|
* Unsupported formats are translated to one of these two formats
|
|
* using mplayer's audio filters.
|
|
*/
|
|
switch (format) {
|
|
case AFMT_U8:
|
|
case AFMT_S8:
|
|
format = AFMT_U8;
|
|
break;
|
|
default:
|
|
format = AFMT_S16_LE; /* artsd always expects little endian?*/
|
|
break;
|
|
}
|
|
|
|
ao_data.format = format;
|
|
ao_data.channels = channels;
|
|
ao_data.samplerate = rate_hz;
|
|
ao_data.bps = (rate_hz*channels);
|
|
|
|
if(format != AFMT_U8 && format != AFMT_S8)
|
|
ao_data.bps*=2;
|
|
|
|
stream=arts_play_stream(rate_hz, OBTAIN_BITRATE(format), channels, "Mplayer");
|
|
|
|
if(stream == NULL) {
|
|
mp_msg(MSGT_AO, MSGL_ERR, "AO: [arts] Unable to open a stream\n");
|
|
arts_free();
|
|
return 0;
|
|
}
|
|
|
|
/* Set the stream to blocking: it will not block anyway, but it seems */
|
|
/* to be working better */
|
|
arts_stream_set(stream, ARTS_P_BLOCKING, 1);
|
|
frag_spec = ARTS_PACKET_SIZE_LOG2 | ARTS_PACKETS << 16;
|
|
arts_stream_set(stream, ARTS_P_PACKET_SETTINGS, frag_spec);
|
|
ao_data.buffersize = arts_stream_get(stream, ARTS_P_BUFFER_SIZE);
|
|
mp_msg(MSGT_AO, MSGL_INFO, "AO: [arts] Stream opened\n");
|
|
|
|
mp_msg(MSGT_AO, MSGL_INFO,"AO: [arts] buffer size: %d\n",
|
|
ao_data.buffersize);
|
|
mp_msg(MSGT_AO, MSGL_INFO,"AO: [arts] packet size: %d\n",
|
|
arts_stream_get(stream, ARTS_P_PACKET_SIZE));
|
|
|
|
return 1;
|
|
}
|
|
|
|
static void uninit()
|
|
{
|
|
arts_close_stream(stream);
|
|
arts_free();
|
|
}
|
|
|
|
static int play(void* data,int len,int flags)
|
|
{
|
|
return arts_write(stream, data, len);
|
|
}
|
|
|
|
static void audio_pause()
|
|
{
|
|
}
|
|
|
|
static void audio_resume()
|
|
{
|
|
}
|
|
|
|
static void reset()
|
|
{
|
|
}
|
|
|
|
static int get_space()
|
|
{
|
|
return arts_stream_get(stream, ARTS_P_BUFFER_SPACE);
|
|
}
|
|
|
|
static float get_delay()
|
|
{
|
|
return ((float) (ao_data.buffersize - arts_stream_get(stream,
|
|
ARTS_P_BUFFER_SPACE))) / ((float) ao_data.bps);
|
|
}
|
|
|