rockbox/uisimulator/x11/oss_sound.c

85 lines
2.5 KiB
C
Raw Normal View History

/***************************************************************************
* __________ __ ___.
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
* \/ \/ \/ \/ \/
*
* Copyright (C) 2002 Dave Chapman
*
* oss_sound - a sound driver for Linux (and others?) OSS audio
*
* All files in this archive are subject to the GNU General Public License.
* See the file COPYING in the source tree root for full license agreement.
*
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
* KIND, either express or implied.
*
****************************************************************************/
#include <stdio.h>
#include <fcntl.h>
#include <sys/soundcard.h>
#include "../common/sound.h"
/* We want to use the "real" open in this file */
#undef open
int init_sound(sound_t* sound) {
sound->fd=open("/dev/dsp", O_WRONLY);
sound->freq=-1;
sound->channels=-1;
if (sound->fd <= 0) {
fprintf(stderr,"Can not open /dev/dsp - simulating sound output\n");
sound->fd=0;
}
}
int config_sound(sound_t* sound, int sound_freq, int channels) {
int format=AFMT_S16_NE;
int setting=0x000C000D; // 12 fragments size 8kb ? WHAT IS THIS?
sound->freq=sound_freq;
sound->channels=channels;
if (sound->fd) {
if (ioctl(sound->fd,SNDCTL_DSP_SETFRAGMENT,&setting)==-1) {
perror("SNDCTL_DSP_SETFRAGMENT");
}
if (ioctl(sound->fd,SNDCTL_DSP_CHANNELS,&channels)==-1) {
perror("SNDCTL_DSP_STEREO");
}
if (channels==0) { fprintf(stderr,"Warning, only mono supported\n"); }
if (ioctl(sound->fd,SNDCTL_DSP_SETFMT,&format)==-1) {
perror("SNDCTL_DSP_SETFMT");
}
if (ioctl(sound->fd,SNDCTL_DSP_SPEED,&sound_freq)==-1) {
perror("SNDCTL_DSP_SPEED");
}
}
}
int output_sound(sound_t* sound,const void* buf, int count) {
unsigned long long t;
if (sound->fd) {
return(write(sound->fd,buf,count));
} else {
t=(unsigned int)(((unsigned int)(1000000/sound->channels)*count)/sound->freq);
// fprintf(stderr,"writing %d bytes at %d frequency - sleeping for %u microseconds\n",count,sound->freq,t);
usleep(t);
return(count);
}
}
void close_sound(sound_t* sound) {
if (sound->fd) close(sound->fd);
sound->fd=-1;
}