Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
82fff94c
Commit
82fff94c
authored
Dec 21, 2006
by
Ken Thomases
Committed by
Alexandre Julliard
Dec 21, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winecoreaudio: Lift mutex lock/unlock out of wodHelper_PlayPtrNext to caller.
parent
bdbe803c
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
9 additions
and
18 deletions
+9
-18
audio.c
dlls/winmm/winecoreaudio/audio.c
+9
-18
No files found.
dlls/winmm/winecoreaudio/audio.c
View file @
82fff94c
...
@@ -897,14 +897,13 @@ static void wodHelper_CheckForLoopBegin(WINE_WAVEOUT* wwo)
...
@@ -897,14 +897,13 @@ static void wodHelper_CheckForLoopBegin(WINE_WAVEOUT* wwo)
* wodHelper_PlayPtrNext [internal]
* wodHelper_PlayPtrNext [internal]
*
*
* Advance the play pointer to the next waveheader, looping if required.
* Advance the play pointer to the next waveheader, looping if required.
* This is called with the WAVEOUT lock held.
* Call from AudioUnit IO thread can't use Wine debug channels.
* Call from AudioUnit IO thread can't use Wine debug channels.
*/
*/
static
void
wodHelper_PlayPtrNext
(
WINE_WAVEOUT
*
wwo
)
static
void
wodHelper_PlayPtrNext
(
WINE_WAVEOUT
*
wwo
)
{
{
BOOL
didLoopBack
=
FALSE
;
BOOL
didLoopBack
=
FALSE
;
pthread_mutex_lock
(
&
wwo
->
lock
);
wwo
->
dwPartialOffset
=
0
;
wwo
->
dwPartialOffset
=
0
;
if
((
wwo
->
lpPlayPtr
->
dwFlags
&
WHDR_ENDLOOP
)
&&
wwo
->
lpLoopPtr
)
if
((
wwo
->
lpPlayPtr
->
dwFlags
&
WHDR_ENDLOOP
)
&&
wwo
->
lpLoopPtr
)
{
{
...
@@ -930,8 +929,6 @@ static void wodHelper_PlayPtrNext(WINE_WAVEOUT* wwo)
...
@@ -930,8 +929,6 @@ static void wodHelper_PlayPtrNext(WINE_WAVEOUT* wwo)
else
else
wodHelper_CheckForLoopBegin
(
wwo
);
wodHelper_CheckForLoopBegin
(
wwo
);
}
}
pthread_mutex_unlock
(
&
wwo
->
lock
);
}
}
/* if force is TRUE then notify the client that all the headers were completed
/* if force is TRUE then notify the client that all the headers were completed
...
@@ -1406,16 +1403,15 @@ OSStatus CoreAudio_woAudioUnitIOProc(void *inRefCon,
...
@@ -1406,16 +1403,15 @@ OSStatus CoreAudio_woAudioUnitIOProc(void *inRefCon,
{
{
UInt32
buffer
;
UInt32
buffer
;
WINE_WAVEOUT
*
wwo
=
(
WINE_WAVEOUT
*
)
inRefCon
;
WINE_WAVEOUT
*
wwo
=
(
WINE_WAVEOUT
*
)
inRefCon
;
int
nextPtr
=
0
;
int
needNotify
=
0
;
int
needNotify
=
0
;
unsigned
int
dataNeeded
=
ioData
->
mBuffers
[
0
].
mDataByteSize
;
unsigned
int
dataNeeded
=
ioData
->
mBuffers
[
0
].
mDataByteSize
;
unsigned
int
dataProvided
=
0
;
unsigned
int
dataProvided
=
0
;
pthread_mutex_lock
(
&
wwo
->
lock
);
while
(
dataNeeded
>
0
)
while
(
dataNeeded
>
0
)
{
{
pthread_mutex_lock
(
&
wwo
->
lock
);
if
(
wwo
->
state
==
WINE_WS_PLAYING
&&
wwo
->
lpPlayPtr
)
if
(
wwo
->
state
==
WINE_WS_PLAYING
&&
wwo
->
lpPlayPtr
)
{
{
unsigned
int
available
=
wwo
->
lpPlayPtr
->
dwBufferLength
-
wwo
->
dwPartialOffset
;
unsigned
int
available
=
wwo
->
lpPlayPtr
->
dwBufferLength
-
wwo
->
dwPartialOffset
;
...
@@ -1438,9 +1434,10 @@ OSStatus CoreAudio_woAudioUnitIOProc(void *inRefCon,
...
@@ -1438,9 +1434,10 @@ OSStatus CoreAudio_woAudioUnitIOProc(void *inRefCon,
}
}
if
(
available
==
0
)
if
(
available
==
0
)
nextPtr
=
1
;
{
wodHelper_PlayPtrNext
(
wwo
);
needNotify
=
1
;
needNotify
=
1
;
}
}
}
else
else
{
{
...
@@ -1448,16 +1445,10 @@ OSStatus CoreAudio_woAudioUnitIOProc(void *inRefCon,
...
@@ -1448,16 +1445,10 @@ OSStatus CoreAudio_woAudioUnitIOProc(void *inRefCon,
dataProvided
+=
dataNeeded
;
dataProvided
+=
dataNeeded
;
dataNeeded
=
0
;
dataNeeded
=
0
;
}
}
pthread_mutex_unlock
(
&
wwo
->
lock
);
if
(
nextPtr
)
{
wodHelper_PlayPtrNext
(
wwo
);
nextPtr
=
0
;
}
}
}
pthread_mutex_unlock
(
&
wwo
->
lock
);
/* We only fill buffer 0. Set any others that might be requested to 0. */
/* We only fill buffer 0. Set any others that might be requested to 0. */
for
(
buffer
=
1
;
buffer
<
ioData
->
mNumberBuffers
;
buffer
++
)
for
(
buffer
=
1
;
buffer
<
ioData
->
mNumberBuffers
;
buffer
++
)
{
{
...
...
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