# HG changeset patch # User Ryan C. Gordon # Date 1163378293 0 # Node ID 579abbb51f800642e1af8b3eff121da0fce6e489 # Parent dbfa1ebd73b018fb892dee497badb15baa9b4945 Merged r2906:2907 from 1.2 branch to trunk: power of two channels in dsp backend. diff -r dbfa1ebd73b0 -r 579abbb51f80 src/audio/dsp/SDL_dspaudio.c --- a/src/audio/dsp/SDL_dspaudio.c Sat Nov 11 06:48:57 2006 +0000 +++ b/src/audio/dsp/SDL_dspaudio.c Mon Nov 13 00:38:13 2006 +0000 @@ -166,6 +166,15 @@ devname = ((iscapture) ? inputDevices[0] : outputDevices[0]); } + /* Make sure fragment size stays a power of 2, or OSS fails. */ + /* I don't know which of these are actually legal values, though... */ + if (this->spec.channels > 8) + this->spec.channels = 8; + else if (this->spec.channels > 4) + this->spec.channels = 4; + else if (this->spec.channels > 2) + this->spec.channels = 2; + /* Initialize all variables that we clean on shutdown */ this->hidden = (struct SDL_PrivateAudioData *) SDL_malloc((sizeof *this->hidden));