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
73fc9e74
Commit
73fc9e74
authored
Jul 07, 2023
by
Brendan Shanks
Committed by
Alexandre Julliard
Jul 10, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winecoreaudio: Set zero_bits correctly for large address aware applications on Wow64.
parent
36b715c5
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
14 deletions
+21
-14
coreaudio.c
dlls/winecoreaudio.drv/coreaudio.c
+21
-14
No files found.
dlls/winecoreaudio.drv/coreaudio.c
View file @
73fc9e74
...
@@ -103,6 +103,8 @@ struct coreaudio_stream
...
@@ -103,6 +103,8 @@ struct coreaudio_stream
static
const
REFERENCE_TIME
def_period
=
100000
;
static
const
REFERENCE_TIME
def_period
=
100000
;
static
const
REFERENCE_TIME
min_period
=
50000
;
static
const
REFERENCE_TIME
min_period
=
50000
;
static
ULONG_PTR
zero_bits
=
0
;
static
NTSTATUS
unix_not_implemented
(
void
*
args
)
static
NTSTATUS
unix_not_implemented
(
void
*
args
)
{
{
return
STATUS_SUCCESS
;
return
STATUS_SUCCESS
;
...
@@ -196,6 +198,20 @@ static BOOL device_has_channels(AudioDeviceID device, EDataFlow flow)
...
@@ -196,6 +198,20 @@ static BOOL device_has_channels(AudioDeviceID device, EDataFlow flow)
return
ret
;
return
ret
;
}
}
static
NTSTATUS
unix_process_attach
(
void
*
args
)
{
#ifdef _WIN64
if
(
NtCurrentTeb
()
->
WowTebOffset
)
{
SYSTEM_BASIC_INFORMATION
info
;
NtQuerySystemInformation
(
SystemEmulationBasicInformation
,
&
info
,
sizeof
(
info
),
NULL
);
zero_bits
=
(
ULONG_PTR
)
info
.
HighestUserAddress
|
0x7fffffff
;
}
#endif
return
STATUS_SUCCESS
;
}
static
NTSTATUS
unix_main_loop
(
void
*
args
)
static
NTSTATUS
unix_main_loop
(
void
*
args
)
{
{
struct
main_loop_params
*
params
=
args
;
struct
main_loop_params
*
params
=
args
;
...
@@ -639,15 +655,6 @@ static HRESULT ca_setup_audiounit(EDataFlow dataflow, AudioComponentInstance uni
...
@@ -639,15 +655,6 @@ static HRESULT ca_setup_audiounit(EDataFlow dataflow, AudioComponentInstance uni
return
S_OK
;
return
S_OK
;
}
}
static
ULONG_PTR
zero_bits
(
void
)
{
#ifdef _WIN64
return
!
NtCurrentTeb
()
->
WowTebOffset
?
0
:
0x7fffffff
;
#else
return
0
;
#endif
}
static
AudioDeviceID
dev_id_from_device
(
const
char
*
device
)
static
AudioDeviceID
dev_id_from_device
(
const
char
*
device
)
{
{
return
strtoul
(
device
,
NULL
,
10
);
return
strtoul
(
device
,
NULL
,
10
);
...
@@ -757,7 +764,7 @@ static NTSTATUS unix_create_stream(void *args)
...
@@ -757,7 +764,7 @@ static NTSTATUS unix_create_stream(void *args)
}
}
size
=
stream
->
bufsize_frames
*
stream
->
fmt
->
nBlockAlign
;
size
=
stream
->
bufsize_frames
*
stream
->
fmt
->
nBlockAlign
;
if
(
NtAllocateVirtualMemory
(
GetCurrentProcess
(),
(
void
**
)
&
stream
->
local_buffer
,
zero_bits
()
,
if
(
NtAllocateVirtualMemory
(
GetCurrentProcess
(),
(
void
**
)
&
stream
->
local_buffer
,
zero_bits
,
&
size
,
MEM_COMMIT
,
PAGE_READWRITE
)){
&
size
,
MEM_COMMIT
,
PAGE_READWRITE
)){
params
->
result
=
E_OUTOFMEMORY
;
params
->
result
=
E_OUTOFMEMORY
;
goto
end
;
goto
end
;
...
@@ -1497,7 +1504,7 @@ static NTSTATUS unix_get_render_buffer(void *args)
...
@@ -1497,7 +1504,7 @@ static NTSTATUS unix_get_render_buffer(void *args)
stream
->
tmp_buffer
=
NULL
;
stream
->
tmp_buffer
=
NULL
;
}
}
size
=
params
->
frames
*
stream
->
fmt
->
nBlockAlign
;
size
=
params
->
frames
*
stream
->
fmt
->
nBlockAlign
;
if
(
NtAllocateVirtualMemory
(
GetCurrentProcess
(),
(
void
**
)
&
stream
->
tmp_buffer
,
zero_bits
()
,
if
(
NtAllocateVirtualMemory
(
GetCurrentProcess
(),
(
void
**
)
&
stream
->
tmp_buffer
,
zero_bits
,
&
size
,
MEM_COMMIT
,
PAGE_READWRITE
)){
&
size
,
MEM_COMMIT
,
PAGE_READWRITE
)){
stream
->
tmp_buffer_frames
=
0
;
stream
->
tmp_buffer_frames
=
0
;
params
->
result
=
E_OUTOFMEMORY
;
params
->
result
=
E_OUTOFMEMORY
;
...
@@ -1595,7 +1602,7 @@ static NTSTATUS unix_get_capture_buffer(void *args)
...
@@ -1595,7 +1602,7 @@ static NTSTATUS unix_get_capture_buffer(void *args)
chunk_bytes
=
chunk_frames
*
stream
->
fmt
->
nBlockAlign
;
chunk_bytes
=
chunk_frames
*
stream
->
fmt
->
nBlockAlign
;
if
(
!
stream
->
tmp_buffer
){
if
(
!
stream
->
tmp_buffer
){
size
=
stream
->
period_frames
*
stream
->
fmt
->
nBlockAlign
;
size
=
stream
->
period_frames
*
stream
->
fmt
->
nBlockAlign
;
NtAllocateVirtualMemory
(
GetCurrentProcess
(),
(
void
**
)
&
stream
->
tmp_buffer
,
zero_bits
()
,
NtAllocateVirtualMemory
(
GetCurrentProcess
(),
(
void
**
)
&
stream
->
tmp_buffer
,
zero_bits
,
&
size
,
MEM_COMMIT
,
PAGE_READWRITE
);
&
size
,
MEM_COMMIT
,
PAGE_READWRITE
);
}
}
*
params
->
data
=
stream
->
tmp_buffer
;
*
params
->
data
=
stream
->
tmp_buffer
;
...
@@ -1782,7 +1789,7 @@ static NTSTATUS unix_set_event_handle(void *args)
...
@@ -1782,7 +1789,7 @@ static NTSTATUS unix_set_event_handle(void *args)
unixlib_entry_t
__wine_unix_call_funcs
[]
=
unixlib_entry_t
__wine_unix_call_funcs
[]
=
{
{
unix_
not_implemented
,
unix_
process_attach
,
unix_not_implemented
,
unix_not_implemented
,
unix_main_loop
,
unix_main_loop
,
unix_get_endpoint_ids
,
unix_get_endpoint_ids
,
...
@@ -2177,7 +2184,7 @@ static NTSTATUS unix_wow64_set_event_handle(void *args)
...
@@ -2177,7 +2184,7 @@ static NTSTATUS unix_wow64_set_event_handle(void *args)
unixlib_entry_t
__wine_unix_call_wow64_funcs
[]
=
unixlib_entry_t
__wine_unix_call_wow64_funcs
[]
=
{
{
unix_
not_implemented
,
unix_
process_attach
,
unix_not_implemented
,
unix_not_implemented
,
unix_wow64_main_loop
,
unix_wow64_main_loop
,
unix_wow64_get_endpoint_ids
,
unix_wow64_get_endpoint_ids
,
...
...
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