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
66a39678
Commit
66a39678
authored
Nov 07, 2008
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Store correct values in the various limits on all platforms instead of using 0.
parent
b8d46863
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
9 additions
and
6 deletions
+9
-6
virtual.c
dlls/ntdll/virtual.c
+9
-6
No files found.
dlls/ntdll/virtual.c
View file @
66a39678
...
@@ -125,9 +125,9 @@ static void *working_set_limit = (void *)0x7fff0000; /* top of the current wo
...
@@ -125,9 +125,9 @@ static void *working_set_limit = (void *)0x7fff0000; /* top of the current wo
static
UINT
page_shift
;
static
UINT
page_shift
;
static
UINT
page_size
;
static
UINT
page_size
;
static
UINT_PTR
page_mask
;
static
UINT_PTR
page_mask
;
static
void
*
const
address_space_limit
=
0
;
/* no limit needed on other platforms */
static
void
*
address_space_limit
;
static
void
*
const
user_space_limit
=
0
;
/* no limit needed on other platforms */
static
void
*
user_space_limit
;
static
void
*
const
working_set_limit
=
0
;
/* no limit needed on other platforms */
static
void
*
working_set_limit
;
#endif
/* __i386__ */
#endif
/* __i386__ */
#define ROUND_ADDR(addr,mask) \
#define ROUND_ADDR(addr,mask) \
...
@@ -371,7 +371,7 @@ static void add_reserved_area( void *addr, size_t size )
...
@@ -371,7 +371,7 @@ static void add_reserved_area( void *addr, size_t size )
*/
*/
static
inline
int
is_beyond_limit
(
const
void
*
addr
,
size_t
size
,
const
void
*
limit
)
static
inline
int
is_beyond_limit
(
const
void
*
addr
,
size_t
size
,
const
void
*
limit
)
{
{
return
(
limit
&&
(
addr
>=
limit
||
(
const
char
*
)
addr
+
size
>
(
const
char
*
)
limit
)
);
return
(
addr
>=
limit
||
(
const
char
*
)
addr
+
size
>
(
const
char
*
)
limit
);
}
}
...
@@ -623,6 +623,7 @@ struct alloc_area
...
@@ -623,6 +623,7 @@ struct alloc_area
size_t
size
;
size_t
size
;
size_t
mask
;
size_t
mask
;
int
top_down
;
int
top_down
;
void
*
limit
;
void
*
result
;
void
*
result
;
};
};
...
@@ -638,7 +639,7 @@ static int alloc_reserved_area_callback( void *start, size_t size, void *arg )
...
@@ -638,7 +639,7 @@ static int alloc_reserved_area_callback( void *start, size_t size, void *arg )
void
*
end
=
(
char
*
)
start
+
size
;
void
*
end
=
(
char
*
)
start
+
size
;
if
(
start
<
address_space_start
)
start
=
address_space_start
;
if
(
start
<
address_space_start
)
start
=
address_space_start
;
if
(
user_space_limit
&&
end
>
user_space_limit
)
end
=
user_space_
limit
;
if
(
is_beyond_limit
(
start
,
size
,
alloc
->
limit
))
end
=
alloc
->
limit
;
if
(
start
>=
end
)
return
0
;
if
(
start
>=
end
)
return
0
;
/* make sure we don't touch the preloader reserved range */
/* make sure we don't touch the preloader reserved range */
...
@@ -722,6 +723,7 @@ static NTSTATUS map_view( struct file_view **view_ret, void *base, size_t size,
...
@@ -722,6 +723,7 @@ static NTSTATUS map_view( struct file_view **view_ret, void *base, size_t size,
alloc
.
size
=
size
;
alloc
.
size
=
size
;
alloc
.
mask
=
mask
;
alloc
.
mask
=
mask
;
alloc
.
top_down
=
top_down
;
alloc
.
top_down
=
top_down
;
alloc
.
limit
=
user_space_limit
;
if
(
wine_mmap_enum_reserved_areas
(
alloc_reserved_area_callback
,
&
alloc
,
top_down
))
if
(
wine_mmap_enum_reserved_areas
(
alloc_reserved_area_callback
,
&
alloc
,
top_down
))
{
{
ptr
=
alloc
.
result
;
ptr
=
alloc
.
result
;
...
@@ -1209,7 +1211,7 @@ static int alloc_virtual_heap( void *base, size_t size, void *arg )
...
@@ -1209,7 +1211,7 @@ static int alloc_virtual_heap( void *base, size_t size, void *arg )
{
{
void
**
heap_base
=
arg
;
void
**
heap_base
=
arg
;
if
(
address_space_limit
)
address_space_limit
=
max
(
(
char
*
)
address_space_limit
,
(
char
*
)
base
+
size
)
;
if
(
is_beyond_limit
(
base
,
size
,
address_space_limit
))
address_space_limit
=
(
char
*
)
base
+
size
;
if
(
size
<
VIRTUAL_HEAP_SIZE
)
return
0
;
if
(
size
<
VIRTUAL_HEAP_SIZE
)
return
0
;
*
heap_base
=
wine_anon_mmap
(
(
char
*
)
base
+
size
-
VIRTUAL_HEAP_SIZE
,
*
heap_base
=
wine_anon_mmap
(
(
char
*
)
base
+
size
-
VIRTUAL_HEAP_SIZE
,
VIRTUAL_HEAP_SIZE
,
PROT_READ
|
PROT_WRITE
,
MAP_FIXED
);
VIRTUAL_HEAP_SIZE
,
PROT_READ
|
PROT_WRITE
,
MAP_FIXED
);
...
@@ -1232,6 +1234,7 @@ void virtual_init(void)
...
@@ -1232,6 +1234,7 @@ void virtual_init(void)
assert
(
!
(
page_size
&
page_mask
)
);
assert
(
!
(
page_size
&
page_mask
)
);
page_shift
=
0
;
page_shift
=
0
;
while
((
1
<<
page_shift
)
!=
page_size
)
page_shift
++
;
while
((
1
<<
page_shift
)
!=
page_size
)
page_shift
++
;
user_space_limit
=
working_set_limit
=
address_space_limit
=
(
void
*
)
~
page_mask
;
#endif
/* page_mask */
#endif
/* page_mask */
if
((
preload
=
getenv
(
"WINEPRELOADRESERVE"
)))
if
((
preload
=
getenv
(
"WINEPRELOADRESERVE"
)))
{
{
...
...
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