diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index ac15783f9..f37799b45 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,3 +1,9 @@
+Sun May 20 13:26:25 2001  Christopher Faylor <cgf@cygnus.com>
+
+	* fhandler_dsp.cc: Reformat to GNU standards.
+	(s_audio): Change to a pointer throughout.
+	(fhandler_dev_dsp::open): Initialize s_audio, if required.
+
 Sat May 19 23:40:00 2001  Corinna Vinschen <corinna@vinschen.de>
 
 	* autoload.cc: Add load statements for `LookupAccountNameW',
diff --git a/winsup/cygwin/fhandler_dsp.cc b/winsup/cygwin/fhandler_dsp.cc
index bdbce7027..c6d96c4e6 100644
--- a/winsup/cygwin/fhandler_dsp.cc
+++ b/winsup/cygwin/fhandler_dsp.cc
@@ -1,11 +1,11 @@
 /* fhandler_dev_dsp: code to emulate OSS sound model /dev/dsp
-
+ 
    Copyright 2001 Red Hat, Inc
-
+ 
    Written by Andy Younger (andy@snoogie.demon.co.uk)
-
+ 
 This file is part of Cygwin.
-
+ 
 This software is a copyrighted work licensed under the terms of the
 Cygwin license.  Please consult the file "CYGWIN_LICENSE" for
 details. */
@@ -22,17 +22,17 @@ details. */
 
 //------------------------------------------------------------------------
 // Simple encapsulation of the win32 audio device.
-// 
-static void CALLBACK wave_callback(HWAVE hWave, UINT msg, DWORD instance, 
-			           DWORD param1, DWORD param2);
+//
+static void CALLBACK wave_callback (HWAVE hWave, UINT msg, DWORD instance,
+				    DWORD param1, DWORD param2);
 class Audio
 {
 public:
   enum { MAX_BLOCKS = 12, BLOCK_SIZE = 16384 };
 
-  Audio ();
-  ~Audio ();
-  
+    Audio ();
+   ~Audio ();
+
   bool open (int rate, int bits, int channels, bool bCallback = false);
   void close ();
   int getvolume ();
@@ -40,14 +40,14 @@ public:
   bool write (const void *pSampleData, int nBytes);
   int blocks ();
   void callback_sampledone (void *pData);
-  void setformat(int format) { formattype_ = format; }
+  void setformat (int format) {formattype_ = format;}
   int numbytesoutput ();
-  
+
 private:
   char *initialisebuffer ();
   void waitforcallback ();
   bool flush ();
-   
+
   HWAVEOUT dev_;
   volatile int nBlocksInQue_;
   int nBytesWritten_;
@@ -60,296 +60,297 @@ private:
   char bigwavebuffer_[MAX_BLOCKS * BLOCK_SIZE];
 };
 
-Audio::Audio()
+Audio::Audio ()
 {
-  int size = BLOCK_SIZE + sizeof(WAVEHDR);
-  
-  InitializeCriticalSection(&lock_);
-  memset(freeblocks_, 0, sizeof(freeblocks_));
+  int size = BLOCK_SIZE + sizeof (WAVEHDR);
+
+  InitializeCriticalSection (&lock_);
+  memset (freeblocks_, 0, sizeof (freeblocks_));
   for (int i = 0; i < MAX_BLOCKS; i++)
     {
-      char *pBuffer = &bigwavebuffer_[ i * size ];
-      memset(pBuffer, 0, size);
+      char *pBuffer = &bigwavebuffer_[i * size];
+      memset (pBuffer, 0, size);
       freeblocks_[i] = pBuffer;
     }
 }
 
-Audio::~Audio()
+Audio::~Audio ()
 {
   if (dev_)
-    close();
-  DeleteCriticalSection(&lock_);
+    close ();
+  DeleteCriticalSection (&lock_);
 }
 
-bool 
-Audio::open(int rate, int bits, int channels, bool bCallback = false)
+bool
+Audio::open (int rate, int bits, int channels, bool bCallback = false)
 {
   WAVEFORMATEX format;
-  int nDevices = waveOutGetNumDevs();
-  
+  int nDevices = waveOutGetNumDevs ();
+
   nBytesWritten_ = 0L;
   bufferIndex_ = 0;
   buffer_ = 0L;
-  debug_printf("number devices %d\n", nDevices); 
+  debug_printf ("number devices %d\n", nDevices);
   if (nDevices <= 0)
     return false;
-  
-  debug_printf("trying to map device freq %d, bits %d, "
-	       "channels %d, callback %d\n", rate, bits, channels, 
-	       bCallback); 
+
+  debug_printf ("trying to map device freq %d, bits %d, "
+		"channels %d, callback %d\n", rate, bits, channels,
+		bCallback);
 
   int bytesperSample = bits / 8;
-  
-  memset(&format, 0, sizeof(format));
+
+  memset (&format, 0, sizeof (format));
   format.wFormatTag = WAVE_FORMAT_PCM;
   format.wBitsPerSample = bits;
   format.nChannels = channels;
   format.nSamplesPerSec = rate;
-  format.nAvgBytesPerSec = format.nSamplesPerSec * format.nChannels * 
-			   bytesperSample;
-  format.nBlockAlign = format.nChannels * bytesperSample;  
+  format.nAvgBytesPerSec = format.nSamplesPerSec * format.nChannels *
+    bytesperSample;
+  format.nBlockAlign = format.nChannels * bytesperSample;
 
   nBlocksInQue_ = 0;
-  HRESULT res = waveOutOpen(&dev_, WAVE_MAPPER, &format, (DWORD)wave_callback,
-			    (DWORD)this, bCallback ? CALLBACK_FUNCTION : 0);
+  HRESULT res = waveOutOpen (&dev_, WAVE_MAPPER, &format, (DWORD) wave_callback,
+			     (DWORD) this, bCallback ? CALLBACK_FUNCTION : 0);
   if (res == S_OK)
     {
-      debug_printf("Sucessfully opened!");
+      debug_printf ("Sucessfully opened!");
       return true;
     }
   else
     {
-      debug_printf("failed to open");
+      debug_printf ("failed to open");
       return false;
     }
 }
 
-void 
-Audio::close()
+void
+Audio::close ()
 {
   if (dev_)
-    {	
-      flush();		// force out last block whatever size..	
+    {
+      flush ();			// force out last block whatever size..
 
-      while (blocks())	// block till finished..
-	waitforcallback();
-      
-      waveOutReset(dev_);
-      waveOutClose(dev_);
+      while (blocks ())		// block till finished..
+	waitforcallback ();
+
+      waveOutReset (dev_);
+      waveOutClose (dev_);
       dev_ = 0L;
     }
   nBytesWritten_ = 0L;
 }
 
 int
-Audio::numbytesoutput()
+Audio::numbytesoutput ()
 {
   return nBytesWritten_;
 }
 
-int 
-Audio::getvolume()
+int
+Audio::getvolume ()
 {
   DWORD volume;
-  
-  waveOutGetVolume(dev_, &volume);
-  return ((volume >> 16) + (volume & 0xffff)) >> 1;    
+
+  waveOutGetVolume (dev_, &volume);
+  return ((volume >> 16) + (volume & 0xffff)) >> 1;
 }
 
-void 
-Audio::setvolume(int newVolume)
+void
+Audio::setvolume (int newVolume)
 {
-  waveOutSetVolume(dev_, (newVolume<<16)|newVolume);    
+  waveOutSetVolume (dev_, (newVolume << 16) | newVolume);
 }
 
 char *
-Audio::initialisebuffer()
+Audio::initialisebuffer ()
 {
-  EnterCriticalSection(&lock_);
+  EnterCriticalSection (&lock_);
   WAVEHDR *pHeader = 0L;
   for (int i = 0; i < MAX_BLOCKS; i++)
     {
       char *pData = freeblocks_[i];
       if (pData)
 	{
-	  pHeader = (WAVEHDR *)pData;    
+	  pHeader = (WAVEHDR *) pData;
 	  if (pHeader->dwFlags & WHDR_DONE)
 	    {
-	      waveOutUnprepareHeader(dev_, pHeader, sizeof(WAVEHDR));   
-	    }	
+	      waveOutUnprepareHeader (dev_, pHeader, sizeof (WAVEHDR));
+	    }
 	  freeblocks_[i] = 0L;
 	  break;
 	}
     }
-  LeaveCriticalSection(&lock_); 
+  LeaveCriticalSection (&lock_);
 
   if (pHeader)
     {
-      memset(pHeader, 0, sizeof(WAVEHDR));
+      memset (pHeader, 0, sizeof (WAVEHDR));
       pHeader->dwBufferLength = BLOCK_SIZE;
-      pHeader->lpData = (LPSTR)(&pHeader[1]);
-      return (char *)pHeader->lpData;
+      pHeader->lpData = (LPSTR) (&pHeader[1]);
+      return (char *) pHeader->lpData;
     }
   return 0L;
 }
 
-bool 
-Audio::write(const void *pSampleData, int nBytes)
+bool
+Audio::write (const void *pSampleData, int nBytes)
 {
   // split up big blocks into smaller BLOCK_SIZE chunks
   while (nBytes > BLOCK_SIZE)
     {
-      write(pSampleData, BLOCK_SIZE);
+      write (pSampleData, BLOCK_SIZE);
       nBytes -= BLOCK_SIZE;
-      pSampleData = (void *)((char *)pSampleData + BLOCK_SIZE);
+      pSampleData = (void *) ((char *) pSampleData + BLOCK_SIZE);
     }
 
   // Block till next sound is flushed
-  if (blocks() == MAX_BLOCKS)
-      waitforcallback();
+  if (blocks () == MAX_BLOCKS)
+    waitforcallback ();
 
   // Allocate new wave buffer if necessary
   if (buffer_ == 0L)
     {
-      buffer_ = initialisebuffer();
+      buffer_ = initialisebuffer ();
       if (buffer_ == 0L)
 	return false;
     }
-  
+
 
   // Handle gathering blocks into larger buffer
   int sizeleft = BLOCK_SIZE - bufferIndex_;
   if (nBytes < sizeleft)
     {
-      memcpy(&buffer_[bufferIndex_], pSampleData, nBytes);
+      memcpy (&buffer_[bufferIndex_], pSampleData, nBytes);
       bufferIndex_ += nBytes;
       nBytesWritten_ += nBytes;
       return true;
     }
-  
-  // flushing when we reach our limit of BLOCK_SIZE 
-  memcpy(&buffer_[bufferIndex_], pSampleData, sizeleft);
+
+  // flushing when we reach our limit of BLOCK_SIZE
+  memcpy (&buffer_[bufferIndex_], pSampleData, sizeleft);
   bufferIndex_ += sizeleft;
-  nBytesWritten_ += sizeleft;	
-  flush();
-      
+  nBytesWritten_ += sizeleft;
+  flush ();
+
   // change pointer to rest of sample, and size accordingly
-  pSampleData = (void *)((char *)pSampleData + sizeleft);
-  nBytes -= sizeleft;	
+  pSampleData = (void *) ((char *) pSampleData + sizeleft);
+  nBytes -= sizeleft;
 
   // if we still have some sample left over write it out
   if (nBytes)
-    return write(pSampleData, nBytes);
-  
+    return write (pSampleData, nBytes);
+
   return true;
 }
 
 // return number of blocks back.
-int 
-Audio::blocks()
+int
+Audio::blocks ()
 {
-  EnterCriticalSection(&lock_);
+  EnterCriticalSection (&lock_);
   int ret = nBlocksInQue_;
-  LeaveCriticalSection(&lock_);
+  LeaveCriticalSection (&lock_);
   return ret;
 }
 
-// This is called on an interupt so use locking.. Note nBlocksInQue_ is 
+// This is called on an interupt so use locking.. Note nBlocksInQue_ is
 // modified by it so we should wrap all references to it in locks.
-void 
-Audio::callback_sampledone(void *pData)
+void
+Audio::callback_sampledone (void *pData)
 {
-  EnterCriticalSection(&lock_);
-  
-  nBlocksInQue_--; 
+  EnterCriticalSection (&lock_);
+
+  nBlocksInQue_--;
   for (int i = 0; i < MAX_BLOCKS; i++)
     if (!freeblocks_[i])
       {
-	freeblocks_[i] = (char *)pData;
+	freeblocks_[i] = (char *) pData;
 	break;
       }
-  
-  LeaveCriticalSection(&lock_);  
+
+  LeaveCriticalSection (&lock_);
 }
 
 void
-Audio::waitforcallback()
+Audio::waitforcallback ()
 {
-  int n = blocks();
+  int n = blocks ();
   if (!n)
-      return;
+    return;
   do
     {
-      Sleep(250);
+      Sleep (250);
     }
-  while (n == blocks());
+  while (n == blocks ());
 }
 
 bool
-Audio::flush()
+Audio::flush ()
 {
   if (!buffer_)
-      return false;
-  
+    return false;
+
   // Send internal buffer out to the soundcard
-  WAVEHDR *pHeader = ((WAVEHDR *)buffer_) - 1;
+  WAVEHDR *pHeader = ((WAVEHDR *) buffer_) - 1;
   pHeader->dwBufferLength = bufferIndex_;
 
   // Quick bit of sample buffer conversion
   if (formattype_ == AFMT_S8)
     {
-      unsigned char *p = ((unsigned char *)buffer_);
+      unsigned char *p = ((unsigned char *) buffer_);
       for (int i = 0; i < bufferIndex_; i++)
-        {
+	{
 	  p[i] -= 0x7f;
-        }
+	}
     }
-  
-  if (waveOutPrepareHeader(dev_, pHeader, sizeof(WAVEHDR)) == S_OK &&
-      waveOutWrite(dev_, pHeader, sizeof (WAVEHDR)) == S_OK)
-    {	    
-      EnterCriticalSection(&lock_);
+
+  if (waveOutPrepareHeader (dev_, pHeader, sizeof (WAVEHDR)) == S_OK &&
+      waveOutWrite (dev_, pHeader, sizeof (WAVEHDR)) == S_OK)
+    {
+      EnterCriticalSection (&lock_);
       nBlocksInQue_++;
-      LeaveCriticalSection(&lock_);
+      LeaveCriticalSection (&lock_);
       bufferIndex_ = 0;
       buffer_ = 0L;
       return true;
     }
   else
     {
-      EnterCriticalSection(&lock_);
+      EnterCriticalSection (&lock_);
       for (int i = 0; i < MAX_BLOCKS; i++)
 	if (!freeblocks_[i])
-	{
-	  freeblocks_[i] = (char *)pHeader;
-	  break;
-        }
-      LeaveCriticalSection(&lock_);
+	  {
+	    freeblocks_[i] = (char *) pHeader;
+	    break;
+	  }
+      LeaveCriticalSection (&lock_);
     }
   return false;
 }
 
 //------------------------------------------------------------------------
 // Call back routine
-static void CALLBACK 
-wave_callback(HWAVE hWave, UINT msg, DWORD instance, DWORD param1, DWORD param2)
+static void CALLBACK
+wave_callback (HWAVE hWave, UINT msg, DWORD instance, DWORD param1,
+	       DWORD param2)
 {
   if (msg == WOM_DONE)
     {
-      Audio *ptr = (Audio *)instance;
-      ptr->callback_sampledone((void *)param1);
+      Audio *ptr = (Audio *) instance;
+      ptr->callback_sampledone ((void *) param1);
     }
 }
-  
+
 //------------------------------------------------------------------------
 // /dev/dsp handler
-static Audio s_audio;	      // static instance of the Audio handler
+static Audio *s_audio;		// static instance of the Audio handler
 
 //------------------------------------------------------------------------
 // wav file detection..
 #pragma pack(1)
 struct wavchunk
-{ 
+{
   char id[4];
   unsigned int len;
 };
@@ -365,40 +366,40 @@ struct wavformat
 #pragma pack()
 
 bool
-fhandler_dev_dsp::setupwav(const char *pData, int nBytes)
+fhandler_dev_dsp::setupwav (const char *pData, int nBytes)
 {
   int len;
   const char *end = pData + nBytes;
 
-  if (!(pData[0] == 'R' && pData[1] == 'I' && 
+  if (!(pData[0] == 'R' && pData[1] == 'I' &&
 	pData[2] == 'F' && pData[3] == 'F'))
     return false;
-  if (!(pData[8]  == 'W' && pData[9]  == 'A' && 
-        pData[10] == 'V' && pData[11] == 'E'))
+  if (!(pData[8] == 'W' && pData[9] == 'A' &&
+	pData[10] == 'V' && pData[11] == 'E'))
     return false;
-  
-  len = *(int *)&pData[4];  
+
+  len = *(int *) &pData[4];
   pData += 12;
   while (len && pData < end)
-    { 
-      wavchunk *pChunk = (wavchunk *)pData;
-      int blklen = pChunk->len;	      
-      if (pChunk->id[0] == 'f' && pChunk->id[1] == 'm' && 
+    {
+      wavchunk * pChunk = (wavchunk *) pData;
+      int blklen = pChunk-> len;
+      if (pChunk->id[0] == 'f' && pChunk->id[1] == 'm' &&
 	  pChunk->id[2] == 't' && pChunk->id[3] == ' ')
 	{
-	  wavformat *format = (wavformat *)(pChunk+1);
-	  if ((char *)(format+1) > end)
+	  wavformat *format = (wavformat *) (pChunk + 1);
+	  if ((char *) (format + 1) > end)
 	    return false;
-      
+
 	  // Open up audio device with correct frequency for wav file
-	  // 
+	  //
 	  // FIXME: should through away all the header & not output
 	  // it to the soundcard.
-	  s_audio.close();
-	  if (s_audio.open(format->dwSamplesPerSec, format->wBitsPerSample,
-			   format->wChannels) == false)
+	  s_audio->close ();
+	  if (s_audio->open (format->dwSamplesPerSec, format->wBitsPerSample,
+			     format->wChannels) == false)
 	    {
-	      s_audio.open(audiofreq_, audiobits_, audiochannels_);
+	      s_audio->open (audiofreq_, audiobits_, audiochannels_);
 	    }
 	  else
 	    {
@@ -409,33 +410,36 @@ fhandler_dev_dsp::setupwav(const char *pData, int nBytes)
 	  return true;
 	}
 
-      pData += blklen + sizeof(wavchunk);
+      pData += blklen + sizeof (wavchunk);
     }
   return false;
 }
 
 //------------------------------------------------------------------------
-fhandler_dev_dsp::fhandler_dev_dsp (const char *name)
-  : fhandler_base (FH_OSS_DSP, name)
+fhandler_dev_dsp::fhandler_dev_dsp (const char *name):
+  fhandler_base (FH_OSS_DSP, name)
 {
-  set_cb (sizeof *this);     
+  set_cb (sizeof *this);
 }
 
-fhandler_dev_dsp::~fhandler_dev_dsp()
+fhandler_dev_dsp::~fhandler_dev_dsp ()
 {
 }
 
 int
 fhandler_dev_dsp::open (const char *path, int flags, mode_t mode = 0)
 {
-  // currently we only support writing    
-  if ((flags & (O_WRONLY|O_RDONLY|O_RDWR)) != O_WRONLY)
+  // currently we only support writing
+  if ((flags & (O_WRONLY | O_RDONLY | O_RDWR)) != O_WRONLY)
     return 0;
-  
-  set_flags(flags);
+
+  set_flags (flags);
+
+  if (!s_audio)
+    s_audio = new Audio;
 
   // Work out initial sample format & frequency
-  if (strcmp(path, "/dev/dsp") == 0L)
+  if (strcmp (path, "/dev/dsp") == 0L)
     {
       // dev/dsp defaults
       audioformat_ = AFMT_S8;
@@ -444,12 +448,12 @@ fhandler_dev_dsp::open (const char *path, int flags, mode_t mode = 0)
       audiochannels_ = 1;
     }
 
-  if (!s_audio.open(audiofreq_, audiobits_, audiochannels_))
-    debug_printf("/dev/dsp: failed to open\n");   
+  if (!s_audio->open (audiofreq_, audiobits_, audiochannels_))
+    debug_printf ("/dev/dsp: failed to open\n");
   else
     {
       set_open_status ();
-      debug_printf("/dev/dsp: successfully opened\n"); 
+      debug_printf ("/dev/dsp: successfully opened\n");
     }
   return 1;
 }
@@ -457,18 +461,18 @@ fhandler_dev_dsp::open (const char *path, int flags, mode_t mode = 0)
 int
 fhandler_dev_dsp::write (const void *ptr, size_t len)
 {
-  if (s_audio.numbytesoutput() == 0)
+  if (s_audio->numbytesoutput () == 0)
     {
       // check for wave file & setup frequencys properly if possible.
-      setupwav((const char *)ptr, len);
- 
+      setupwav ((const char *) ptr, len);
+
       // Open audio device properly with callbacks.
-      s_audio.close();
-      if (!s_audio.open(audiofreq_, audiobits_, audiochannels_, true))
-        return 0;
+      s_audio->close ();
+      if (!s_audio->open (audiofreq_, audiobits_, audiochannels_, true))
+	return 0;
     }
-  
-  s_audio.write(ptr, len);
+
+  s_audio->write (ptr, len);
   return len;
 }
 
@@ -487,16 +491,16 @@ fhandler_dev_dsp::lseek (off_t offset, int whence)
 int
 fhandler_dev_dsp::close (void)
 {
-  s_audio.close();
+  s_audio->close ();
   return 0;
 }
 
 int
 fhandler_dev_dsp::dup (fhandler_base * child)
 {
-  fhandler_dev_dsp *fhc = (fhandler_dev_dsp *)child;
+  fhandler_dev_dsp *fhc = (fhandler_dev_dsp *) child;
 
-  fhc->set_flags(get_flags());
+  fhc->set_flags (get_flags ());
   fhc->audiochannels_ = audiochannels_;
   fhc->audiobits_ = audiobits_;
   fhc->audiofreq_ = audiofreq_;
@@ -504,119 +508,121 @@ fhandler_dev_dsp::dup (fhandler_base * child)
   return 0;
 }
 
-int 
-fhandler_dev_dsp::ioctl(unsigned int cmd, void *ptr)
+int
+fhandler_dev_dsp::ioctl (unsigned int cmd, void *ptr)
 {
-  int *intptr = (int *)ptr;
+  int *intptr = (int *) ptr;
   switch (cmd)
     {
-      #define CASE(a) case a : debug_printf("/dev/dsp: ioctl %s\n", #a); 
-      
-      CASE(SNDCTL_DSP_RESET)
-	  audioformat_ = AFMT_S8;
-	  audiofreq_ = 8000;
-	  audiobits_ = 8;
-	  audiochannels_ = 1;
-	  return 1;
-      
-      CASE(SNDCTL_DSP_GETBLKSIZE)
-	  *intptr = Audio::BLOCK_SIZE;
-	  break;
+#define CASE(a) case a : debug_printf("/dev/dsp: ioctl %s\n", #a);
 
-      CASE(SNDCTL_DSP_SETFMT)	 
-	{
-	  int nBits = 0;
-	  if (*intptr == AFMT_S16_LE)
-	      nBits = 16;
-	  else if (*intptr == AFMT_U8)
-	      nBits = 8;	  
-	  else if (*intptr == AFMT_S8)
-	      nBits = 8;	  
-	  if (nBits)
-	    {
-	      s_audio.setformat(*intptr);
-	      s_audio.close();
-	      if (s_audio.open(audiofreq_, nBits, audiochannels_) == true)
-		{
-		  audiobits_ = nBits;
-		  return 1;
-		}
-	      else
-		{
-		  s_audio.open(audiofreq_, audiobits_, audiochannels_);
-		  return -1;
-		}
-	    }
-	}  break;
-      
-      CASE(SNDCTL_DSP_SPEED)
-	  s_audio.close();
-	  if (s_audio.open(*intptr, audiobits_, audiochannels_) == true)
-	    {
-	      audiofreq_ = *intptr;
-	      return 1;
-	    }
-	  else
-	    {
-	      s_audio.open(audiofreq_, audiobits_, audiochannels_);
-	      return -1;
-	    }
-	  break;
-      
-      CASE(SNDCTL_DSP_STEREO)
-	{
-	  int nChannels = *intptr + 1;
-	  
-	  s_audio.close();
-	  if (s_audio.open(audiofreq_, audiobits_, nChannels) == true)
-	    {
-	      audiochannels_ = nChannels;
-	      return 1;
-	    }
-	  else
-	    {
-	      s_audio.open(audiofreq_, audiobits_, audiochannels_);
-	      return -1;
-	    }
-	} break;
+      CASE (SNDCTL_DSP_RESET)
+	audioformat_ = AFMT_S8;
+	audiofreq_ = 8000;
+	audiobits_ = 8;
+	audiochannels_ = 1;
+	return 1;
 
-      CASE(SNDCTL_DSP_GETOSPACE)
-	{
-	  audio_buf_info *p = (audio_buf_info *)ptr;
-
-	  int nBlocks = s_audio.blocks();
-	  int leftblocks = ((Audio::MAX_BLOCKS - nBlocks)-1);
-	  if (leftblocks < 0) leftblocks = 0;
-	  if (leftblocks > 1)
-	    leftblocks = 1;
-	  int left = leftblocks * Audio::BLOCK_SIZE;
-	 
-	  p->fragments = leftblocks;
-	  p->fragstotal = Audio::MAX_BLOCKS;
-	  p->fragsize = Audio::BLOCK_SIZE;
-	  p->bytes = left;
-
-	  debug_printf("ptr: %p "
-		       "nblocks: %d "
-		       "leftblocks: %d "
-		       "left bytes: %d ", ptr, nBlocks, leftblocks, left);
-	  
-	  
-	  return 1;
-	} break;
-
-      CASE(SNDCTL_DSP_SETFRAGMENT)
-        {
-	  // Fake!! esound & mikmod require this on non PowerPC platforms.
-	  // 
-	  return 1;
-	} break;
-        
-      default:
-	debug_printf("/dev/dsp: ioctl not handled yet! FIXME:\n"); 
+      CASE (SNDCTL_DSP_GETBLKSIZE)
+	*intptr = Audio::BLOCK_SIZE;
 	break;
 
-      #undef CASE
+      CASE (SNDCTL_DSP_SETFMT)
+      {
+	int nBits = 0;
+	if (*intptr == AFMT_S16_LE)
+	  nBits = 16;
+	else if (*intptr == AFMT_U8)
+	  nBits = 8;
+	else if (*intptr == AFMT_S8)
+	  nBits = 8;
+	if (nBits)
+	  {
+	    s_audio->setformat (*intptr);
+	    s_audio->close ();
+	    if (s_audio->open (audiofreq_, nBits, audiochannels_) == true)
+	      {
+		audiobits_ = nBits;
+		return 1;
+	      }
+	    else
+	      {
+		s_audio->open (audiofreq_, audiobits_, audiochannels_);
+		return -1;
+	      }
+	  }
+      }
+      break;
+
+      CASE (SNDCTL_DSP_SPEED)
+	s_audio->close ();
+	if (s_audio->open (*intptr, audiobits_, audiochannels_) == true)
+	  {
+	    audiofreq_ = *intptr;
+	    return 1;
+	  }
+	else
+	  {
+	    s_audio->open (audiofreq_, audiobits_, audiochannels_);
+	    return -1;
+	  }
+	break;
+
+      CASE (SNDCTL_DSP_STEREO)
+      {
+	int nChannels = *intptr + 1;
+
+	s_audio->close ();
+	if (s_audio->open (audiofreq_, audiobits_, nChannels) == true)
+	  {
+	    audiochannels_ = nChannels;
+	    return 1;
+	  }
+	else
+	  {
+	    s_audio->open (audiofreq_, audiobits_, audiochannels_);
+	    return -1;
+	  }
+      }
+      break;
+
+      CASE (SNDCTL_DSP_GETOSPACE)
+      {
+	audio_buf_info *p = (audio_buf_info *) ptr;
+
+	int nBlocks = s_audio->blocks ();
+	int leftblocks = ((Audio::MAX_BLOCKS - nBlocks) - 1);
+	if (leftblocks < 0)
+	  leftblocks = 0;
+	if (leftblocks > 1)
+	  leftblocks = 1;
+	int left = leftblocks * Audio::BLOCK_SIZE;
+
+	p->fragments = leftblocks;
+	p->fragstotal = Audio::MAX_BLOCKS;
+	p->fragsize = Audio::BLOCK_SIZE;
+	p->bytes = left;
+
+	debug_printf ("ptr %p nblocks %d leftblocks %d left bytes %d ",
+		      ptr, nBlocks, leftblocks, left);
+
+	return 1;
+      }
+      break;
+
+      CASE (SNDCTL_DSP_SETFRAGMENT)
+      {
+	// Fake!! esound & mikmod require this on non PowerPC platforms.
+	//
+	return 1;
+      }
+      break;
+
+    default:
+      debug_printf ("/dev/dsp: ioctl not handled yet! FIXME:\n");
+      break;
+
+#undef CASE
     };
   return -1;
 }
@@ -624,6 +630,5 @@ fhandler_dev_dsp::ioctl(unsigned int cmd, void *ptr)
 void
 fhandler_dev_dsp::dump ()
 {
-  paranoid_printf("here, fhandler_dev_dsp");
+  paranoid_printf ("here, fhandler_dev_dsp");
 }
-