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
045cf8c0
Commit
045cf8c0
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 units of ACImpl::bufsize.
parent
bbbf72dd
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
28 deletions
+28
-28
audio.c
dlls/mmdevapi/audio.c
+28
-28
No files found.
dlls/mmdevapi/audio.c
View file @
045cf8c0
...
@@ -64,7 +64,7 @@ typedef struct ACImpl {
...
@@ -64,7 +64,7 @@ typedef struct ACImpl {
BOOL
init
,
running
;
BOOL
init
,
running
;
CRITICAL_SECTION
*
crst
;
CRITICAL_SECTION
*
crst
;
HANDLE
handle
;
HANDLE
handle
;
DWORD
locked
,
flags
,
bufsize
,
pad
,
padpartial
,
ofs
,
periodsize_frames
,
candisconnect
;
DWORD
locked
,
flags
,
bufsize
_frames
,
pad
,
padpartial
,
ofs
,
periodsize_frames
,
candisconnect
;
BYTE
*
buffer
;
BYTE
*
buffer
;
WAVEFORMATEX
*
pwfx
;
WAVEFORMATEX
*
pwfx
;
ALuint
source
;
ALuint
source
;
...
@@ -387,10 +387,10 @@ static HRESULT AC_OpenRenderAL(ACImpl *This)
...
@@ -387,10 +387,10 @@ static HRESULT AC_OpenRenderAL(ACImpl *This)
static
HRESULT
AC_OpenCaptureAL
(
ACImpl
*
This
)
static
HRESULT
AC_OpenCaptureAL
(
ACImpl
*
This
)
{
{
char
alname
[
MAX_PATH
];
char
alname
[
MAX_PATH
];
ALint
freq
,
size
;
ALint
freq
,
size
_frames
;
freq
=
This
->
pwfx
->
nSamplesPerSec
;
freq
=
This
->
pwfx
->
nSamplesPerSec
;
size
=
This
->
bufsize
;
size
_frames
=
This
->
bufsize_frames
;
alname
[
sizeof
(
alname
)
-
1
]
=
0
;
alname
[
sizeof
(
alname
)
-
1
]
=
0
;
if
(
This
->
dev
)
{
if
(
This
->
dev
)
{
...
@@ -399,11 +399,11 @@ static HRESULT AC_OpenCaptureAL(ACImpl *This)
...
@@ -399,11 +399,11 @@ static HRESULT AC_OpenCaptureAL(ACImpl *This)
}
}
WideCharToMultiByte
(
CP_UNIXCP
,
0
,
This
->
parent
->
alname
,
-
1
,
WideCharToMultiByte
(
CP_UNIXCP
,
0
,
This
->
parent
->
alname
,
-
1
,
alname
,
sizeof
(
alname
)
/
sizeof
(
*
alname
)
-
1
,
NULL
,
NULL
);
alname
,
sizeof
(
alname
)
/
sizeof
(
*
alname
)
-
1
,
NULL
,
NULL
);
This
->
dev
=
palcCaptureOpenDevice
(
alname
,
freq
,
This
->
format
,
size
);
This
->
dev
=
palcCaptureOpenDevice
(
alname
,
freq
,
This
->
format
,
size
_frames
);
if
(
!
This
->
dev
)
{
if
(
!
This
->
dev
)
{
ALCenum
err
=
palcGetError
(
NULL
);
ALCenum
err
=
palcGetError
(
NULL
);
FIXME
(
"Could not open device %s with buf size %u: 0x%04x
\n
"
,
FIXME
(
"Could not open device %s with buf size %u: 0x%04x
\n
"
,
alname
,
This
->
bufsize
,
err
);
alname
,
This
->
bufsize
_frames
,
err
);
return
AUDCLNT_E_DEVICE_IN_USE
;
return
AUDCLNT_E_DEVICE_IN_USE
;
}
}
return
S_OK
;
return
S_OK
;
...
@@ -452,7 +452,8 @@ static HRESULT WINAPI AC_Initialize(IAudioClient *iface, AUDCLNT_SHAREMODE mode,
...
@@ -452,7 +452,8 @@ static HRESULT WINAPI AC_Initialize(IAudioClient *iface, AUDCLNT_SHAREMODE mode,
ACImpl
*
This
=
(
ACImpl
*
)
iface
;
ACImpl
*
This
=
(
ACImpl
*
)
iface
;
HRESULT
hr
=
S_OK
;
HRESULT
hr
=
S_OK
;
WAVEFORMATEX
*
pwfx2
;
WAVEFORMATEX
*
pwfx2
;
REFERENCE_TIME
time
,
bufsize
;
REFERENCE_TIME
time
;
DWORD
bufsize_bytes
;
TRACE
(
"(%p)->(%x,%x,%u,%u,%p,%s)
\n
"
,
This
,
mode
,
flags
,
(
int
)
duration
,
(
int
)
period
,
pwfx
,
debugstr_guid
(
sessionguid
));
TRACE
(
"(%p)->(%x,%x,%u,%u,%p,%s)
\n
"
,
This
,
mode
,
flags
,
(
int
)
duration
,
(
int
)
period
,
pwfx
,
debugstr_guid
(
sessionguid
));
if
(
This
->
init
)
if
(
This
->
init
)
...
@@ -519,11 +520,10 @@ static HRESULT WINAPI AC_Initialize(IAudioClient *iface, AUDCLNT_SHAREMODE mode,
...
@@ -519,11 +520,10 @@ static HRESULT WINAPI AC_Initialize(IAudioClient *iface, AUDCLNT_SHAREMODE mode,
if
(
duration
>
20000000
)
if
(
duration
>
20000000
)
duration
=
20000000
;
duration
=
20000000
;
bufsize
=
duration
/
time
*
This
->
periodsize_frames
;
This
->
bufsize_frames
=
duration
/
time
*
This
->
periodsize_frames
;
if
(
duration
%
time
)
if
(
duration
%
time
)
bufsize
+=
This
->
periodsize_frames
;
This
->
bufsize_frames
+=
This
->
periodsize_frames
;
This
->
bufsize
=
bufsize
;
bufsize_bytes
=
This
->
bufsize_frames
*
pwfx
->
nBlockAlign
;
bufsize
*=
pwfx
->
nBlockAlign
;
This
->
format
=
get_format
(
This
->
pwfx
);
This
->
format
=
get_format
(
This
->
pwfx
);
if
(
This
->
parent
->
flow
==
eRender
)
{
if
(
This
->
parent
->
flow
==
eRender
)
{
...
@@ -563,7 +563,7 @@ static HRESULT WINAPI AC_Initialize(IAudioClient *iface, AUDCLNT_SHAREMODE mode,
...
@@ -563,7 +563,7 @@ static HRESULT WINAPI AC_Initialize(IAudioClient *iface, AUDCLNT_SHAREMODE mode,
goto
out
;
goto
out
;
This
->
candisconnect
=
palcIsExtensionPresent
(
This
->
dev
,
"ALC_EXT_disconnect"
);
This
->
candisconnect
=
palcIsExtensionPresent
(
This
->
dev
,
"ALC_EXT_disconnect"
);
This
->
buffer
=
HeapAlloc
(
GetProcessHeap
(),
0
,
bufsize
);
This
->
buffer
=
HeapAlloc
(
GetProcessHeap
(),
0
,
bufsize
_bytes
);
if
(
!
This
->
buffer
)
{
if
(
!
This
->
buffer
)
{
hr
=
E_OUTOFMEMORY
;
hr
=
E_OUTOFMEMORY
;
goto
out
;
goto
out
;
...
@@ -585,7 +585,7 @@ static HRESULT WINAPI AC_GetBufferSize(IAudioClient *iface, UINT32 *frames)
...
@@ -585,7 +585,7 @@ static HRESULT WINAPI AC_GetBufferSize(IAudioClient *iface, UINT32 *frames)
return
AUDCLNT_E_NOT_INITIALIZED
;
return
AUDCLNT_E_NOT_INITIALIZED
;
if
(
!
frames
)
if
(
!
frames
)
return
E_POINTER
;
return
E_POINTER
;
*
frames
=
This
->
bufsize
;
*
frames
=
This
->
bufsize
_frames
;
return
S_OK
;
return
S_OK
;
}
}
...
@@ -694,8 +694,8 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
...
@@ -694,8 +694,8 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
if
(
This
->
parent
->
flow
==
eCapture
)
{
if
(
This
->
parent
->
flow
==
eCapture
)
{
This
->
pad
+=
This
->
periodsize_frames
;
This
->
pad
+=
This
->
periodsize_frames
;
if
(
This
->
pad
>
This
->
bufsize
)
if
(
This
->
pad
>
This
->
bufsize
_frames
)
This
->
pad
=
This
->
bufsize
;
This
->
pad
=
This
->
bufsize
_frames
;
}
else
{
}
else
{
if
(
This
->
pad
<=
This
->
periodsize_frames
)
{
if
(
This
->
pad
<=
This
->
periodsize_frames
)
{
This
->
pad
=
0
;
This
->
pad
=
0
;
...
@@ -734,7 +734,7 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
...
@@ -734,7 +734,7 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
#endif
#endif
}
}
*
numpad
=
This
->
pad
-
This
->
padpartial
-
played
;
*
numpad
=
This
->
pad
-
This
->
padpartial
-
played
;
if
(
This
->
handle
&&
(
*
numpad
+
This
->
periodsize_frames
)
<=
This
->
bufsize
)
if
(
This
->
handle
&&
(
*
numpad
+
This
->
periodsize_frames
)
<=
This
->
bufsize
_frames
)
SetEvent
(
This
->
handle
);
SetEvent
(
This
->
handle
);
getALError
();
getALError
();
popALContext
();
popALContext
();
...
@@ -744,31 +744,31 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
...
@@ -744,31 +744,31 @@ static HRESULT WINAPI AC_GetCurrentPadding(IAudioClient *iface, UINT32 *numpad)
if
(
avail
)
{
if
(
avail
)
{
DWORD
ofs
=
This
->
ofs
+
This
->
pad
;
DWORD
ofs
=
This
->
ofs
+
This
->
pad
;
BYTE
*
buf1
;
BYTE
*
buf1
;
ofs
%=
This
->
bufsize
;
ofs
%=
This
->
bufsize
_frames
;
buf1
=
This
->
buffer
+
(
ofs
*
block
);
buf1
=
This
->
buffer
+
(
ofs
*
block
);
This
->
laststamp
=
gettime
();
This
->
laststamp
=
gettime
();
if
(
This
->
handle
)
if
(
This
->
handle
)
SetEvent
(
This
->
handle
);
SetEvent
(
This
->
handle
);
if
(
ofs
+
avail
<=
This
->
bufsize
)
if
(
ofs
+
avail
<=
This
->
bufsize
_frames
)
palcCaptureSamples
(
This
->
dev
,
buf1
,
avail
);
palcCaptureSamples
(
This
->
dev
,
buf1
,
avail
);
else
{
else
{
DWORD
part1
=
This
->
bufsize
-
ofs
;
DWORD
part1
=
This
->
bufsize
_frames
-
ofs
;
palcCaptureSamples
(
This
->
dev
,
buf1
,
part1
);
palcCaptureSamples
(
This
->
dev
,
buf1
,
part1
);
palcCaptureSamples
(
This
->
dev
,
This
->
buffer
,
avail
-
part1
);
palcCaptureSamples
(
This
->
dev
,
This
->
buffer
,
avail
-
part1
);
}
}
This
->
pad
+=
avail
;
This
->
pad
+=
avail
;
This
->
frameswritten
+=
avail
;
This
->
frameswritten
+=
avail
;
/* Increase ofs if the app forgets to read */
/* Increase ofs if the app forgets to read */
if
(
This
->
pad
>
This
->
bufsize
)
{
if
(
This
->
pad
>
This
->
bufsize
_frames
)
{
DWORD
rest
;
DWORD
rest
;
WARN
(
"Overflowed! %u
bytes
\n
"
,
This
->
pad
-
This
->
bufsize
);
WARN
(
"Overflowed! %u
frames
\n
"
,
This
->
pad
-
This
->
bufsize_frames
);
This
->
ofs
+=
This
->
pad
-
This
->
bufsize
;
This
->
ofs
+=
This
->
pad
-
This
->
bufsize
_frames
;
rest
=
This
->
ofs
%
This
->
periodsize_frames
;
rest
=
This
->
ofs
%
This
->
periodsize_frames
;
if
(
rest
)
if
(
rest
)
This
->
ofs
+=
This
->
periodsize_frames
-
rest
;
This
->
ofs
+=
This
->
periodsize_frames
-
rest
;
This
->
ofs
%=
This
->
bufsize
;
This
->
ofs
%=
This
->
bufsize
_frames
;
This
->
pad
=
This
->
bufsize
;
This
->
pad
=
This
->
bufsize
_frames
;
}
}
}
}
if
(
This
->
pad
>=
This
->
periodsize_frames
)
if
(
This
->
pad
>=
This
->
periodsize_frames
)
...
@@ -1177,8 +1177,8 @@ static HRESULT WINAPI ACR_GetBuffer(IAudioRenderClient *iface, UINT32 frames, BY
...
@@ -1177,8 +1177,8 @@ static HRESULT WINAPI ACR_GetBuffer(IAudioRenderClient *iface, UINT32 frames, BY
return
AUDCLNT_E_OUT_OF_ORDER
;
return
AUDCLNT_E_OUT_OF_ORDER
;
}
}
AC_GetCurrentPadding
((
IAudioClient
*
)
This
->
parent
,
&
free
);
AC_GetCurrentPadding
((
IAudioClient
*
)
This
->
parent
,
&
free
);
if
(
This
->
parent
->
bufsize
-
free
<
frames
)
{
if
(
This
->
parent
->
bufsize
_frames
-
free
<
frames
)
{
ERR
(
"Too large: %u %u %u
\n
"
,
This
->
parent
->
bufsize
,
free
,
frames
);
ERR
(
"Too large: %u %u %u
\n
"
,
This
->
parent
->
bufsize
_frames
,
free
,
frames
);
return
AUDCLNT_E_BUFFER_TOO_LARGE
;
return
AUDCLNT_E_BUFFER_TOO_LARGE
;
}
}
EnterCriticalSection
(
This
->
parent
->
crst
);
EnterCriticalSection
(
This
->
parent
->
crst
);
...
@@ -1187,7 +1187,7 @@ static HRESULT WINAPI ACR_GetBuffer(IAudioRenderClient *iface, UINT32 frames, BY
...
@@ -1187,7 +1187,7 @@ 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
)
if
(
This
->
parent
->
ofs
+
frames
>
This
->
parent
->
bufsize
_frames
)
This
->
parent
->
ofs
=
0
;
This
->
parent
->
ofs
=
0
;
*
data
=
This
->
parent
->
buffer
+
This
->
parent
->
ofs
*
framesize
;
*
data
=
This
->
parent
->
buffer
+
This
->
parent
->
ofs
*
framesize
;
...
@@ -1201,7 +1201,7 @@ static HRESULT WINAPI ACR_ReleaseBuffer(IAudioRenderClient *iface, UINT32 writte
...
@@ -1201,7 +1201,7 @@ static HRESULT WINAPI ACR_ReleaseBuffer(IAudioRenderClient *iface, UINT32 writte
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
;
DWORD
bufsize
=
This
->
parent
->
bufsize
;
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
;
ALuint
albuf
;
ALuint
albuf
;
...
@@ -1411,7 +1411,7 @@ static HRESULT WINAPI ACC_ReleaseBuffer(IAudioCaptureClient *iface, UINT32 writt
...
@@ -1411,7 +1411,7 @@ static HRESULT WINAPI ACC_ReleaseBuffer(IAudioCaptureClient *iface, UINT32 writt
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
+=
written
;
This
->
parent
->
ofs
%=
This
->
parent
->
bufsize
;
This
->
parent
->
ofs
%=
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