Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc-2-2
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
videolan
vlc-2-2
Commits
6d6be263
Commit
6d6be263
authored
May 15, 2012
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wasapi: fix COM initialization and deinitialization
parent
d5e4667b
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
46 additions
and
9 deletions
+46
-9
modules/audio_output/wasapi.c
modules/audio_output/wasapi.c
+46
-9
No files found.
modules/audio_output/wasapi.c
View file @
6d6be263
...
@@ -50,7 +50,8 @@ struct aout_sys_t
...
@@ -50,7 +50,8 @@ struct aout_sys_t
{
{
IAudioClient
*
client
;
IAudioClient
*
client
;
IAudioRenderClient
*
render
;
IAudioRenderClient
*
render
;
UINT32
frames
;
UINT32
frames
;
/**< Total buffer size (frames) */
HANDLE
done
;
/**< Semaphore for MTA thread */
};
};
static
void
Play
(
audio_output_t
*
aout
,
block_t
*
block
)
static
void
Play
(
audio_output_t
*
aout
,
block_t
*
block
)
...
@@ -58,6 +59,8 @@ static void Play(audio_output_t *aout, block_t *block)
...
@@ -58,6 +59,8 @@ static void Play(audio_output_t *aout, block_t *block)
aout_sys_t
*
sys
=
aout
->
sys
;
aout_sys_t
*
sys
=
aout
->
sys
;
HRESULT
hr
;
HRESULT
hr
;
CoInitializeEx
(
NULL
,
COINIT_MULTITHREADED
);
while
(
block
->
i_nb_samples
>
0
)
while
(
block
->
i_nb_samples
>
0
)
{
{
UINT32
frames
;
UINT32
frames
;
...
@@ -100,6 +103,7 @@ static void Play(audio_output_t *aout, block_t *block)
...
@@ -100,6 +103,7 @@ static void Play(audio_output_t *aout, block_t *block)
Sleep
(
AOUT_MIN_PREPARE_TIME
/
1000
);
Sleep
(
AOUT_MIN_PREPARE_TIME
/
1000
);
}
}
CoUninitialize
();
block_Release
(
block
);
block_Release
(
block
);
}
}
...
@@ -111,9 +115,11 @@ static void Pause(audio_output_t *aout, bool paused, mtime_t date)
...
@@ -111,9 +115,11 @@ static void Pause(audio_output_t *aout, bool paused, mtime_t date)
if
(
!
paused
)
if
(
!
paused
)
return
;
return
;
CoInitializeEx
(
NULL
,
COINIT_MULTITHREADED
);
hr
=
IAudioClient_Stop
(
sys
->
client
);
hr
=
IAudioClient_Stop
(
sys
->
client
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
msg_Warn
(
aout
,
"cannot stop stream (error 0x%lx)"
,
hr
);
msg_Warn
(
aout
,
"cannot stop stream (error 0x%lx)"
,
hr
);
CoUninitialize
();
(
void
)
date
;
(
void
)
date
;
}
}
...
@@ -125,10 +131,12 @@ static void Flush(audio_output_t *aout, bool wait)
...
@@ -125,10 +131,12 @@ static void Flush(audio_output_t *aout, bool wait)
if
(
wait
)
if
(
wait
)
return
;
/* Not drain implemented */
return
;
/* Not drain implemented */
CoInitializeEx
(
NULL
,
COINIT_MULTITHREADED
);
IAudioClient_Stop
(
sys
->
client
);
IAudioClient_Stop
(
sys
->
client
);
hr
=
IAudioClient_Reset
(
sys
->
client
);
hr
=
IAudioClient_Reset
(
sys
->
client
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
msg_Warn
(
aout
,
"cannot reset stream (error 0x%lx)"
,
hr
);
msg_Warn
(
aout
,
"cannot reset stream (error 0x%lx)"
,
hr
);
CoUninitialize
();
}
}
/*static int VolumeSet(audio_output_t *aout, float vol, bool mute)
/*static int VolumeSet(audio_output_t *aout, float vol, bool mute)
...
@@ -211,6 +219,20 @@ static int vlc_FromWave(const WAVEFORMATEX *restrict wf,
...
@@ -211,6 +219,20 @@ static int vlc_FromWave(const WAVEFORMATEX *restrict wf,
return
0
;
return
0
;
}
}
/* Dummy thread to keep COM MTA alive */
static
void
MTAThread
(
void
*
data
)
{
HANDLE
done
=
data
;
HRESULT
hr
;
hr
=
CoInitializeEx
(
NULL
,
COINIT_MULTITHREADED
);
if
(
unlikely
(
FAILED
(
hr
)))
abort
();
WaitForSingleObject
(
done
,
INFINITE
);
CoUninitialize
();
CloseHandle
(
done
);
}
static
int
Open
(
vlc_object_t
*
obj
)
static
int
Open
(
vlc_object_t
*
obj
)
{
{
audio_output_t
*
aout
=
(
audio_output_t
*
)
obj
;
audio_output_t
*
aout
=
(
audio_output_t
*
)
obj
;
...
@@ -219,10 +241,9 @@ static int Open(vlc_object_t *obj)
...
@@ -219,10 +241,9 @@ static int Open(vlc_object_t *obj)
aout_sys_t
*
sys
=
malloc
(
sizeof
(
*
sys
));
aout_sys_t
*
sys
=
malloc
(
sizeof
(
*
sys
));
if
(
unlikely
(
sys
==
NULL
))
if
(
unlikely
(
sys
==
NULL
))
return
VLC_ENOMEM
;
return
VLC_ENOMEM
;
aout
->
sys
=
sys
;
sys
->
client
=
NULL
;
sys
->
client
=
NULL
;
sys
->
render
=
NULL
;
sys
->
render
=
NULL
;
sys
->
done
=
NULL
;
hr
=
CoInitializeEx
(
NULL
,
COINIT_MULTITHREADED
);
hr
=
CoInitializeEx
(
NULL
,
COINIT_MULTITHREADED
);
if
(
FAILED
(
hr
))
if
(
FAILED
(
hr
))
...
@@ -322,15 +343,30 @@ static int Open(vlc_object_t *obj)
...
@@ -322,15 +343,30 @@ static int Open(vlc_object_t *obj)
goto
error
;
goto
error
;
}
}
sys
->
done
=
CreateSemaphore
(
NULL
,
0
,
1
,
NULL
);
if
(
unlikely
(
sys
->
done
==
NULL
))
goto
error
;
/* Note: thread handle released by CRT, ignore it. */
if
(
_beginthread
(
MTAThread
,
0
,
sys
->
done
)
==
(
uintptr_t
)
-
1
)
goto
error
;
aout
->
format
=
format
;
aout
->
format
=
format
;
aout
->
sys
=
sys
;
aout
->
sys
=
sys
;
aout
->
pf_play
=
Play
;
aout
->
pf_play
=
Play
;
aout
->
pf_pause
=
Pause
;
aout
->
pf_pause
=
Pause
;
aout
->
pf_flush
=
Flush
;
aout
->
pf_flush
=
Flush
;
aout_VolumeNoneInit
(
aout
);
aout_VolumeNoneInit
(
aout
);
CoUninitialize
();
return
VLC_SUCCESS
;
return
VLC_SUCCESS
;
error:
error:
Close
(
obj
);
if
(
sys
->
done
!=
NULL
)
CloseHandle
(
sys
->
done
);
if
(
sys
->
render
!=
NULL
)
IAudioRenderClient_Release
(
sys
->
render
);
if
(
sys
->
client
!=
NULL
)
IAudioClient_Release
(
sys
->
client
);
CoUninitialize
();
free
(
sys
);
return
VLC_EGENERIC
;
return
VLC_EGENERIC
;
}
}
...
@@ -339,10 +375,11 @@ static void Close (vlc_object_t *obj)
...
@@ -339,10 +375,11 @@ static void Close (vlc_object_t *obj)
audio_output_t
*
aout
=
(
audio_output_t
*
)
obj
;
audio_output_t
*
aout
=
(
audio_output_t
*
)
obj
;
aout_sys_t
*
sys
=
aout
->
sys
;
aout_sys_t
*
sys
=
aout
->
sys
;
if
(
sys
->
render
!=
NULL
)
CoInitializeEx
(
NULL
,
COINIT_MULTITHREADED
);
IAudioRenderClient_Release
(
sys
->
render
);
IAudioRenderClient_Release
(
sys
->
render
);
if
(
sys
->
client
!=
NULL
)
IAudioClient_Release
(
sys
->
client
);
IAudioClient_Release
(
sys
->
client
);
/* FIXME: CoUninitialize(); */
CoUninitialize
();
ReleaseSemaphore
(
sys
->
done
,
1
,
NULL
);
/* MTA thread will exit */
free
(
sys
);
free
(
sys
);
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment