diff options
author | malc | 2009-10-11 04:38:47 +0200 |
---|---|---|
committer | malc | 2009-10-11 04:38:47 +0200 |
commit | 875ef647b03ba0db7656eaf9da66d1e906f2b38d (patch) | |
tree | 10ddca70a111691b9b4ba7a95f37e52d5cb13967 /audio | |
parent | winwave: remove wait object when finalizing DAC voice (diff) | |
download | qemu-875ef647b03ba0db7656eaf9da66d1e906f2b38d.tar.gz qemu-875ef647b03ba0db7656eaf9da66d1e906f2b38d.tar.xz qemu-875ef647b03ba0db7656eaf9da66d1e906f2b38d.zip |
winwave: close event handle and delete wait object after closing HWAVEOUT
To avoid possibly being called back and thus racing.
Signed-off-by: malc <av1474@comtv.ru>
Diffstat (limited to 'audio')
-rw-r--r-- | audio/winwaveaudio.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/audio/winwaveaudio.c b/audio/winwaveaudio.c index 5bbce2abdc..1486da1b95 100644 --- a/audio/winwaveaudio.c +++ b/audio/winwaveaudio.c @@ -263,6 +263,8 @@ static void winwave_fini_out (HWVoiceOut *hw) { WaveVoiceOut *wave = (WaveVoiceOut *) hw; + winwave_anal_close_out (wave); + if (wave->event) { qemu_del_wait_object (wave->event, winwave_poll_out, wave); if (!CloseHandle (wave->event)) { @@ -271,8 +273,6 @@ static void winwave_fini_out (HWVoiceOut *hw) wave->event = NULL; } - winwave_anal_close_out (wave); - qemu_free (wave->pcm_buf); wave->pcm_buf = NULL; |