Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
0b608d0f
Commit
0b608d0f
authored
Jan 04, 2011
by
Andrew Eikum
Committed by
Alexandre Julliard
Jan 05, 2011
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
mmdevapi: Be explicit about the units of ACImpl::ofs.
parent
045cf8c0
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
22 additions
and
21 deletions
+22
-21
audio.c
dlls/mmdevapi/audio.c
+22
-21
No files found.
dlls/mmdevapi/audio.c
View file @
0b608d0f
...
@@ -64,7 +64,8 @@ typedef struct ACImpl {
...
@@ -64,7 +64,8 @@ typedef struct ACImpl {
BOOL
init
,
running
;
BOOL
init
,
running
;
CRITICAL_SECTION
*
crst
;
CRITICAL_SECTION
*
crst
;
HANDLE
handle
;
HANDLE
handle
;
DWORD
locked
,
flags
,
bufsize_frames
,
pad
,
padpartial
,
ofs
,
periodsize_frames
,
candisconnect
;
DWORD
locked
,
flags
,
candisconnect
;
DWORD
bufsize_frames
,
ofs_frames
,
periodsize_frames
,
pad
,
padpartial
;
BYTE
*
buffer
;
BYTE
*
buffer
;
WAVEFORMATEX
*
pwfx
;
WAVEFORMATEX
*
pwfx
;
ALuint
source
;
ALuint
source
;
...
@@ -665,7 +666,7 @@ static int disconnected(ACImpl *This)
...
@@ -665,7 +666,7 @@ static int disconnected(ACImpl *This)
return
1
;
return
1
;
WARN
(
"Emptying buffer after newly reconnected!
\n
"
);
WARN
(
"Emptying buffer after newly reconnected!
\n
"
);
This
->
pad
=
This
->
ofs
=
0
;
This
->
pad
=
This
->
ofs
_frames
=
0
;
if
(
This
->
running
)
if
(
This
->
running
)
palcCaptureStart
(
This
->
dev
);
palcCaptureStart
(
This
->
dev
);
}
}
...
@@ -742,18 +743,18 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
...
@@ -742,18 +743,18 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
DWORD
block
=
This
->
pwfx
->
nBlockAlign
;
DWORD
block
=
This
->
pwfx
->
nBlockAlign
;
palcGetIntegerv
(
This
->
dev
,
ALC_CAPTURE_SAMPLES
,
1
,
&
avail
);
palcGetIntegerv
(
This
->
dev
,
ALC_CAPTURE_SAMPLES
,
1
,
&
avail
);
if
(
avail
)
{
if
(
avail
)
{
DWORD
ofs
=
This
->
of
s
+
This
->
pad
;
DWORD
ofs
_frames
=
This
->
ofs_frame
s
+
This
->
pad
;
BYTE
*
buf1
;
BYTE
*
buf1
;
ofs
%=
This
->
bufsize_frames
;
ofs
_frames
%=
This
->
bufsize_frames
;
buf1
=
This
->
buffer
+
(
ofs
*
block
);
buf1
=
This
->
buffer
+
(
ofs
_frames
*
block
);
This
->
laststamp
=
gettime
();
This
->
laststamp
=
gettime
();
if
(
This
->
handle
)
if
(
This
->
handle
)
SetEvent
(
This
->
handle
);
SetEvent
(
This
->
handle
);
if
(
ofs
+
avail
<=
This
->
bufsize_frames
)
if
(
ofs
_frames
+
avail
<=
This
->
bufsize_frames
)
palcCaptureSamples
(
This
->
dev
,
buf1
,
avail
);
palcCaptureSamples
(
This
->
dev
,
buf1
,
avail
);
else
{
else
{
DWORD
part1
=
This
->
bufsize_frames
-
ofs
;
DWORD
part1
=
This
->
bufsize_frames
-
ofs
_frames
;
palcCaptureSamples
(
This
->
dev
,
buf1
,
part1
);
palcCaptureSamples
(
This
->
dev
,
buf1
,
part1
);
palcCaptureSamples
(
This
->
dev
,
This
->
buffer
,
avail
-
part1
);
palcCaptureSamples
(
This
->
dev
,
This
->
buffer
,
avail
-
part1
);
}
}
...
@@ -763,11 +764,11 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
...
@@ -763,11 +764,11 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
if
(
This
->
pad
>
This
->
bufsize_frames
)
{
if
(
This
->
pad
>
This
->
bufsize_frames
)
{
DWORD
rest
;
DWORD
rest
;
WARN
(
"Overflowed! %u frames
\n
"
,
This
->
pad
-
This
->
bufsize_frames
);
WARN
(
"Overflowed! %u frames
\n
"
,
This
->
pad
-
This
->
bufsize_frames
);
This
->
ofs
+=
This
->
pad
-
This
->
bufsize_frames
;
This
->
ofs
_frames
+=
This
->
pad
-
This
->
bufsize_frames
;
rest
=
This
->
ofs
%
This
->
periodsize_frames
;
rest
=
This
->
ofs
_frames
%
This
->
periodsize_frames
;
if
(
rest
)
if
(
rest
)
This
->
ofs
+=
This
->
periodsize_frames
-
rest
;
This
->
ofs
_frames
+=
This
->
periodsize_frames
-
rest
;
This
->
ofs
%=
This
->
bufsize_frames
;
This
->
ofs
_frames
%=
This
->
bufsize_frames
;
This
->
pad
=
This
->
bufsize_frames
;
This
->
pad
=
This
->
bufsize_frames
;
}
}
}
}
...
@@ -1015,7 +1016,7 @@ static HRESULT WINAPI AC_Reset(IAudioClient *iface)
...
@@ -1015,7 +1016,7 @@ static HRESULT WINAPI AC_Reset(IAudioClient *iface)
palcCaptureSamples
(
This
->
dev
,
This
->
buffer
,
avail
);
palcCaptureSamples
(
This
->
dev
,
This
->
buffer
,
avail
);
}
}
This
->
pad
=
This
->
padpartial
=
0
;
This
->
pad
=
This
->
padpartial
=
0
;
This
->
ofs
=
0
;
This
->
ofs
_frames
=
0
;
This
->
frameswritten
=
0
;
This
->
frameswritten
=
0
;
out:
out:
LeaveCriticalSection
(
This
->
crst
);
LeaveCriticalSection
(
This
->
crst
);
...
@@ -1187,9 +1188,9 @@ static HRESULT WINAPI ACR_GetBuffer(IAudioRenderClient *iface, UINT32 frames, BY
...
@@ -1187,9 +1188,9 @@ static HRESULT WINAPI ACR_GetBuffer(IAudioRenderClient *iface, UINT32 frames, BY
/* Exact offset doesn't matter, offset could be 0 forever
/* Exact offset doesn't matter, offset could be 0 forever
* but increasing it is easier to debug */
* but increasing it is easier to debug */
if
(
This
->
parent
->
ofs
+
frames
>
This
->
parent
->
bufsize_frames
)
if
(
This
->
parent
->
ofs
_frames
+
frames
>
This
->
parent
->
bufsize_frames
)
This
->
parent
->
ofs
=
0
;
This
->
parent
->
ofs
_frames
=
0
;
*
data
=
This
->
parent
->
buffer
+
This
->
parent
->
ofs
*
framesize
;
*
data
=
This
->
parent
->
buffer
+
This
->
parent
->
ofs
_frames
*
framesize
;
LeaveCriticalSection
(
This
->
parent
->
crst
);
LeaveCriticalSection
(
This
->
parent
->
crst
);
return
S_OK
;
return
S_OK
;
...
@@ -1200,7 +1201,7 @@ static HRESULT WINAPI ACR_ReleaseBuffer(IAudioRenderClient *iface, UINT32 writte
...
@@ -1200,7 +1201,7 @@ static HRESULT WINAPI ACR_ReleaseBuffer(IAudioRenderClient *iface, UINT32 writte
ACRender
*
This
=
(
ACRender
*
)
iface
;
ACRender
*
This
=
(
ACRender
*
)
iface
;
BYTE
*
buf
=
This
->
parent
->
buffer
;
BYTE
*
buf
=
This
->
parent
->
buffer
;
DWORD
framesize
=
This
->
parent
->
pwfx
->
nBlockAlign
;
DWORD
framesize
=
This
->
parent
->
pwfx
->
nBlockAlign
;
DWORD
ofs
=
This
->
parent
->
ofs
;
DWORD
ofs
=
This
->
parent
->
ofs
_frames
;
DWORD
bufsize
=
This
->
parent
->
bufsize_frames
;
DWORD
bufsize
=
This
->
parent
->
bufsize_frames
;
DWORD
freq
=
This
->
parent
->
pwfx
->
nSamplesPerSec
;
DWORD
freq
=
This
->
parent
->
pwfx
->
nSamplesPerSec
;
DWORD
bpp
=
This
->
parent
->
pwfx
->
wBitsPerSample
;
DWORD
bpp
=
This
->
parent
->
pwfx
->
wBitsPerSample
;
...
@@ -1226,8 +1227,8 @@ static HRESULT WINAPI ACR_ReleaseBuffer(IAudioRenderClient *iface, UINT32 writte
...
@@ -1226,8 +1227,8 @@ static HRESULT WINAPI ACR_ReleaseBuffer(IAudioRenderClient *iface, UINT32 writte
EnterCriticalSection
(
This
->
parent
->
crst
);
EnterCriticalSection
(
This
->
parent
->
crst
);
This
->
parent
->
ofs
+=
written
;
This
->
parent
->
ofs
_frames
+=
written
;
This
->
parent
->
ofs
%=
bufsize
;
This
->
parent
->
ofs
_frames
%=
bufsize
;
This
->
parent
->
pad
+=
written
;
This
->
parent
->
pad
+=
written
;
This
->
parent
->
frameswritten
+=
written
;
This
->
parent
->
frameswritten
+=
written
;
This
->
parent
->
locked
=
0
;
This
->
parent
->
locked
=
0
;
...
@@ -1384,7 +1385,7 @@ static HRESULT WINAPI ACC_GetBuffer(IAudioCaptureClient *iface, BYTE **data, UIN
...
@@ -1384,7 +1385,7 @@ static HRESULT WINAPI ACC_GetBuffer(IAudioCaptureClient *iface, BYTE **data, UIN
if
(
This
->
parent
->
locked
)
if
(
This
->
parent
->
locked
)
goto
out
;
goto
out
;
IAudioCaptureClient_GetNextPacketSize
(
iface
,
frames
);
IAudioCaptureClient_GetNextPacketSize
(
iface
,
frames
);
ofs
=
This
->
parent
->
ofs
;
ofs
=
This
->
parent
->
ofs
_frames
;
if
(
ofs
%
This
->
parent
->
periodsize_frames
)
if
(
ofs
%
This
->
parent
->
periodsize_frames
)
ERR
(
"Unaligned offset %u with %u
\n
"
,
ofs
,
This
->
parent
->
periodsize_frames
);
ERR
(
"Unaligned offset %u with %u
\n
"
,
ofs
,
This
->
parent
->
periodsize_frames
);
*
data
=
This
->
parent
->
buffer
+
ofs
*
block
;
*
data
=
This
->
parent
->
buffer
+
ofs
*
block
;
...
@@ -1410,8 +1411,8 @@ static HRESULT WINAPI ACC_ReleaseBuffer(IAudioCaptureClient *iface, UINT32 writt
...
@@ -1410,8 +1411,8 @@ static HRESULT WINAPI ACC_ReleaseBuffer(IAudioCaptureClient *iface, UINT32 writt
EnterCriticalSection
(
This
->
parent
->
crst
);
EnterCriticalSection
(
This
->
parent
->
crst
);
if
(
!
written
||
written
==
This
->
parent
->
locked
)
{
if
(
!
written
||
written
==
This
->
parent
->
locked
)
{
This
->
parent
->
locked
=
0
;
This
->
parent
->
locked
=
0
;
This
->
parent
->
ofs
+=
written
;
This
->
parent
->
ofs
_frames
+=
written
;
This
->
parent
->
ofs
%=
This
->
parent
->
bufsize_frames
;
This
->
parent
->
ofs
_frames
%=
This
->
parent
->
bufsize_frames
;
This
->
parent
->
pad
-=
written
;
This
->
parent
->
pad
-=
written
;
}
else
if
(
!
This
->
parent
->
locked
)
}
else
if
(
!
This
->
parent
->
locked
)
hr
=
AUDCLNT_E_OUT_OF_ORDER
;
hr
=
AUDCLNT_E_OUT_OF_ORDER
;
...
...
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