/*************************************************************************** * __________ __ ___. * 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 #include #include #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; }