# HG changeset patch # User faust3 # Date 1106313779 0 # Node ID 6fb9eca97d414da610c4118f6487502bdf80aaa2 # Parent d1023c2b041472a1747406422a735b6a1f5ec780 support immed flag, always initialize write_offset, min_free_space doesn't seem to be required anymore after Florian Dietrichs patches diff -r d1023c2b0414 -r 6fb9eca97d41 libao2/ao_dsound.c --- a/libao2/ao_dsound.c Fri Jan 21 12:14:48 2005 +0000 +++ b/libao2/ao_dsound.c Fri Jan 21 13:22:59 2005 +0000 @@ -114,7 +114,7 @@ static LPDIRECTSOUNDBUFFER hdsbuf = NULL; ///secondary direct sound buffer (stream buffer) static int buffer_size = 0; ///size in bytes of the direct sound buffer static int write_offset = 0; ///offset of the write cursor in the direct sound buffer -static int min_free_space = 4096; ///if the free space is below this value get_space() will return 0 +static int min_free_space = 0; ///if the free space is below this value get_space() will return 0 static int device_num = 0; ///wanted device number static GUID device; ///guid of the device @@ -481,6 +481,7 @@ dsbdesc.dwBufferBytes = ao_data.buffersize; dsbdesc.lpwfxFormat = (WAVEFORMATEX *)&wformat; buffer_size = dsbdesc.dwBufferBytes; + write_offset = 0; ao_data.outburst = wformat.Format.nBlockAlign * 512; // create primary buffer and set its format @@ -546,11 +547,17 @@ /** \brief close audio device -\param immed stop playback immediately, currently not supported +\param immed stop playback immediately */ static void uninit(int immed) { - reset(); + if(immed)reset(); + else{ + DWORD status; + IDirectSoundBuffer_Play(hdsbuf, 0, 0, 0); + while(!IDirectSoundBuffer_GetStatus(hdsbuf,&status) && (status&DSBSTATUS_PLAYING)) + usec_sleep(20000); + } DestroyBuffer(); UninitDirectSound(); }