Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
V
vlc
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
Commits
43291e2e
Commit
43291e2e
authored
Feb 04, 2014
by
Rémi Denis-Courmont
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mmdevice: fix restart due to preemption in Start()
parent
bdaac334
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
17 additions
and
11 deletions
+17
-11
modules/audio_output/mmdevice.c
modules/audio_output/mmdevice.c
+17
-11
No files found.
modules/audio_output/mmdevice.c
View file @
43291e2e
...
@@ -642,7 +642,7 @@ static int DeviceSelect(audio_output_t *aout, const char *id)
...
@@ -642,7 +642,7 @@ static int DeviceSelect(audio_output_t *aout, const char *id)
SleepConditionVariableCS
(
&
sys
->
ready
,
&
sys
->
lock
,
INFINITE
);
SleepConditionVariableCS
(
&
sys
->
ready
,
&
sys
->
lock
,
INFINITE
);
LeaveCriticalSection
(
&
sys
->
lock
);
LeaveCriticalSection
(
&
sys
->
lock
);
if
(
sys
->
stream
!=
NULL
)
if
(
sys
->
stream
!=
NULL
&&
sys
->
dev
!=
NULL
)
/* Request restart of stream with the new device */
/* Request restart of stream with the new device */
aout_RestartRequest
(
aout
,
AOUT_RESTART_OUTPUT
);
aout_RestartRequest
(
aout
,
AOUT_RESTART_OUTPUT
);
return
(
sys
->
dev
!=
NULL
)
?
0
:
-
1
;
return
(
sys
->
dev
!=
NULL
)
?
0
:
-
1
;
...
@@ -865,9 +865,12 @@ static int aout_stream_Start(void *func, va_list ap)
...
@@ -865,9 +865,12 @@ static int aout_stream_Start(void *func, va_list ap)
aout_stream_start_t
start
=
func
;
aout_stream_start_t
start
=
func
;
aout_stream_t
*
s
=
va_arg
(
ap
,
aout_stream_t
*
);
aout_stream_t
*
s
=
va_arg
(
ap
,
aout_stream_t
*
);
audio_sample_format_t
*
fmt
=
va_arg
(
ap
,
audio_sample_format_t
*
);
audio_sample_format_t
*
fmt
=
va_arg
(
ap
,
audio_sample_format_t
*
);
HRESULT
*
hr
=
va_arg
(
ap
,
HRESULT
*
);
return
SUCCEEDED
(
start
(
s
,
fmt
,
&
GUID_VLC_AUD_OUT
))
*
hr
=
start
(
s
,
fmt
,
&
GUID_VLC_AUD_OUT
);
?
VLC_SUCCESS
:
VLC_EGENERIC
;
if
(
*
hr
==
AUDCLNT_E_DEVICE_INVALIDATED
)
return
VLC_ETIMEOUT
;
return
SUCCEEDED
(
*
hr
)
?
VLC_SUCCESS
:
VLC_EGENERIC
;
}
}
static
void
aout_stream_Stop
(
void
*
func
,
va_list
ap
)
static
void
aout_stream_Stop
(
void
*
func
,
va_list
ap
)
...
@@ -881,13 +884,8 @@ static void aout_stream_Stop(void *func, va_list ap)
...
@@ -881,13 +884,8 @@ static void aout_stream_Stop(void *func, va_list ap)
static
int
Start
(
audio_output_t
*
aout
,
audio_sample_format_t
*
restrict
fmt
)
static
int
Start
(
audio_output_t
*
aout
,
audio_sample_format_t
*
restrict
fmt
)
{
{
aout_sys_t
*
sys
=
aout
->
sys
;
aout_sys_t
*
sys
=
aout
->
sys
;
if
(
sys
->
dev
==
NULL
)
assert
(
sys
->
stream
==
NULL
);
#if !VLC_WINSTORE_APP
/* Open the default device if required (to deal with restarts) */
if
(
sys
->
dev
==
NULL
&&
FAILED
(
DeviceSelect
(
aout
,
NULL
)))
return
-
1
;
return
-
1
;
#endif
aout_stream_t
*
s
=
vlc_object_create
(
aout
,
sizeof
(
*
s
));
aout_stream_t
*
s
=
vlc_object_create
(
aout
,
sizeof
(
*
s
));
if
(
unlikely
(
s
==
NULL
))
if
(
unlikely
(
s
==
NULL
))
...
@@ -901,8 +899,15 @@ static int Start(audio_output_t *aout, audio_sample_format_t *restrict fmt)
...
@@ -901,8 +899,15 @@ static int Start(audio_output_t *aout, audio_sample_format_t *restrict fmt)
s
->
owner
.
activate
=
ActivateDevice
;
s
->
owner
.
activate
=
ActivateDevice
;
EnterMTA
();
EnterMTA
();
sys
->
module
=
vlc_module_load
(
s
,
"aout stream"
,
NULL
,
false
,
for
(;;)
aout_stream_Start
,
s
,
fmt
);
{
HRESULT
hr
;
sys
->
module
=
vlc_module_load
(
s
,
"aout stream"
,
NULL
,
false
,
aout_stream_Start
,
s
,
fmt
,
&
hr
);
if
(
hr
!=
AUDCLNT_E_DEVICE_INVALIDATED
||
DeviceSelect
(
aout
,
NULL
))
break
;
}
LeaveMTA
();
LeaveMTA
();
if
(
sys
->
module
==
NULL
)
if
(
sys
->
module
==
NULL
)
...
@@ -911,6 +916,7 @@ static int Start(audio_output_t *aout, audio_sample_format_t *restrict fmt)
...
@@ -911,6 +916,7 @@ static int Start(audio_output_t *aout, audio_sample_format_t *restrict fmt)
return
-
1
;
return
-
1
;
}
}
assert
(
sys
->
stream
==
NULL
);
sys
->
stream
=
s
;
sys
->
stream
=
s
;
return
0
;
return
0
;
}
}
...
...
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