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
526fc34a
Commit
526fc34a
authored
May 30, 2022
by
Rémi Bernon
Committed by
Alexandre Julliard
May 31, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Remove tail checking on large blocks.
Signed-off-by:
Rémi Bernon
<
rbernon@codeweavers.com
>
parent
75b78517
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
12 additions
and
45 deletions
+12
-45
heap.c
dlls/kernel32/tests/heap.c
+3
-24
heap.c
dlls/ntdll/heap.c
+9
-21
No files found.
dlls/kernel32/tests/heap.c
View file @
526fc34a
...
@@ -2242,7 +2242,6 @@ static void test_block_layout( HANDLE heap, DWORD global_flags, DWORD heap_flags
...
@@ -2242,7 +2242,6 @@ static void test_block_layout( HANDLE heap, DWORD global_flags, DWORD heap_flags
ok
(
diff
>
expect_size
,
"got diff %#Ix
\n
"
,
diff
);
ok
(
diff
>
expect_size
,
"got diff %#Ix
\n
"
,
diff
);
tail
=
ptr0
[
alloc_size
]
|
ptr1
[
alloc_size
]
|
ptr2
[
alloc_size
];
tail
=
ptr0
[
alloc_size
]
|
ptr1
[
alloc_size
]
|
ptr2
[
alloc_size
];
todo_wine_if
(
heap_flags
&
HEAP_TAIL_CHECKING_ENABLED
)
ok
(
!
tail
,
"got tail
\n
"
);
ok
(
!
tail
,
"got tail
\n
"
);
ret
=
HeapFree
(
heap
,
0
,
ptr2
);
ret
=
HeapFree
(
heap
,
0
,
ptr2
);
...
@@ -2492,29 +2491,9 @@ static void test_heap_checks( DWORD flags )
...
@@ -2492,29 +2491,9 @@ static void test_heap_checks( DWORD flags )
if
(
flags
&
HEAP_TAIL_CHECKING_ENABLED
)
if
(
flags
&
HEAP_TAIL_CHECKING_ENABLED
)
{
{
/* Windows doesn't do tail checking on large blocks */
/* Windows doesn't do tail checking on large blocks */
ok
(
p
[
large_size
]
==
0xab
||
broken
(
p
[
large_size
]
==
0
),
"wrong data %x
\n
"
,
p
[
large_size
]
);
ok
(
p
[
large_size
]
==
0
,
"wrong data %x
\n
"
,
p
[
large_size
]
);
ok
(
p
[
large_size
+
1
]
==
0xab
||
broken
(
p
[
large_size
+
1
]
==
0
),
"wrong data %x
\n
"
,
p
[
large_size
+
1
]
);
ok
(
p
[
large_size
+
1
]
==
0
,
"wrong data %x
\n
"
,
p
[
large_size
+
1
]
);
ok
(
p
[
large_size
+
2
]
==
0xab
||
broken
(
p
[
large_size
+
2
]
==
0
),
"wrong data %x
\n
"
,
p
[
large_size
+
2
]
);
ok
(
p
[
large_size
+
2
]
==
0
,
"wrong data %x
\n
"
,
p
[
large_size
+
2
]
);
if
(
p
[
large_size
]
==
0xab
)
{
p
[
large_size
]
=
0xcc
;
ret
=
HeapValidate
(
GetProcessHeap
(),
0
,
p
);
ok
(
!
ret
,
"HeapValidate succeeded
\n
"
);
/* other calls only check when HEAP_VALIDATE is set */
if
(
flags
&
HEAP_VALIDATE
)
{
size
=
HeapSize
(
GetProcessHeap
(),
0
,
p
);
ok
(
size
==
~
(
SIZE_T
)
0
,
"Wrong size %Iu
\n
"
,
size
);
p2
=
HeapReAlloc
(
GetProcessHeap
(),
0
,
p
,
large_size
-
3
);
ok
(
p2
==
NULL
,
"HeapReAlloc succeeded
\n
"
);
ret
=
HeapFree
(
GetProcessHeap
(),
0
,
p
);
ok
(
!
ret
,
"HeapFree succeeded
\n
"
);
}
p
[
large_size
]
=
0xab
;
}
}
}
ret
=
HeapFree
(
GetProcessHeap
(),
0
,
p
);
ret
=
HeapFree
(
GetProcessHeap
(),
0
,
p
);
...
...
dlls/ntdll/heap.c
View file @
526fc34a
...
@@ -783,7 +783,7 @@ static inline void shrink_used_block( SUBHEAP *subheap, struct block *block, UIN
...
@@ -783,7 +783,7 @@ static inline void shrink_used_block( SUBHEAP *subheap, struct block *block, UIN
static
void
*
allocate_large_block
(
HEAP
*
heap
,
DWORD
flags
,
SIZE_T
size
)
static
void
*
allocate_large_block
(
HEAP
*
heap
,
DWORD
flags
,
SIZE_T
size
)
{
{
ARENA_LARGE
*
arena
;
ARENA_LARGE
*
arena
;
SIZE_T
block_size
=
sizeof
(
*
arena
)
+
ROUND_SIZE
(
size
)
+
HEAP_TAIL_EXTRA_SIZE
(
flags
);
SIZE_T
block_size
=
sizeof
(
*
arena
)
+
ROUND_SIZE
(
size
);
LPVOID
address
=
NULL
;
LPVOID
address
=
NULL
;
if
(
!
(
flags
&
HEAP_GROWABLE
))
return
NULL
;
if
(
!
(
flags
&
HEAP_GROWABLE
))
return
NULL
;
...
@@ -799,8 +799,9 @@ static void *allocate_large_block( HEAP *heap, DWORD flags, SIZE_T size )
...
@@ -799,8 +799,9 @@ static void *allocate_large_block( HEAP *heap, DWORD flags, SIZE_T size )
arena
->
block_size
=
block_size
;
arena
->
block_size
=
block_size
;
arena
->
size
=
ARENA_LARGE_SIZE
;
arena
->
size
=
ARENA_LARGE_SIZE
;
arena
->
magic
=
ARENA_LARGE_MAGIC
;
arena
->
magic
=
ARENA_LARGE_MAGIC
;
mark_block_tail
(
(
char
*
)(
arena
+
1
)
+
size
,
block_size
-
sizeof
(
*
arena
)
-
size
,
flags
);
list_add_tail
(
&
heap
->
large_list
,
&
arena
->
entry
);
list_add_tail
(
&
heap
->
large_list
,
&
arena
->
entry
);
valgrind_make_noaccess
(
(
char
*
)
arena
+
sizeof
(
*
arena
)
+
arena
->
data_size
,
arena
->
block_size
-
sizeof
(
*
arena
)
-
arena
->
data_size
);
return
arena
+
1
;
return
arena
+
1
;
}
}
...
@@ -825,19 +826,17 @@ static void free_large_block( HEAP *heap, void *ptr )
...
@@ -825,19 +826,17 @@ static void free_large_block( HEAP *heap, void *ptr )
static
void
*
realloc_large_block
(
HEAP
*
heap
,
DWORD
flags
,
void
*
ptr
,
SIZE_T
size
)
static
void
*
realloc_large_block
(
HEAP
*
heap
,
DWORD
flags
,
void
*
ptr
,
SIZE_T
size
)
{
{
ARENA_LARGE
*
arena
=
(
ARENA_LARGE
*
)
ptr
-
1
;
ARENA_LARGE
*
arena
=
(
ARENA_LARGE
*
)
ptr
-
1
;
SIZE_T
old_size
=
arena
->
data_size
;
void
*
new_ptr
;
void
*
new_ptr
;
if
(
arena
->
block_size
-
sizeof
(
*
arena
)
>=
size
)
if
(
arena
->
block_size
-
sizeof
(
*
arena
)
>=
size
)
{
{
SIZE_T
unused
=
arena
->
block_size
-
sizeof
(
*
arena
)
-
size
;
/* FIXME: we could remap zero-pages instead */
/* FIXME: we could remap zero-pages instead */
valgrind_notify_resize
(
arena
+
1
,
arena
->
data_size
,
size
);
valgrind_notify_resize
(
arena
+
1
,
old_size
,
size
);
if
(
size
>
arena
->
data_size
)
if
(
size
>
old_size
)
initialize_block
(
(
char
*
)
ptr
+
old_size
,
size
-
old_size
,
0
,
flags
);
initialize_block
(
(
char
*
)
ptr
+
arena
->
data_size
,
size
-
arena
->
data_size
,
unused
,
flags
);
else
mark_block_tail
(
(
char
*
)
ptr
+
size
,
unused
,
flags
);
arena
->
data_size
=
size
;
arena
->
data_size
=
size
;
valgrind_make_noaccess
(
(
char
*
)
arena
+
sizeof
(
*
arena
)
+
arena
->
data_size
,
arena
->
block_size
-
sizeof
(
*
arena
)
-
arena
->
data_size
);
return
ptr
;
return
ptr
;
}
}
if
(
flags
&
HEAP_REALLOC_IN_PLACE_ONLY
)
return
NULL
;
if
(
flags
&
HEAP_REALLOC_IN_PLACE_ONLY
)
return
NULL
;
...
@@ -847,7 +846,7 @@ static void *realloc_large_block( HEAP *heap, DWORD flags, void *ptr, SIZE_T siz
...
@@ -847,7 +846,7 @@ static void *realloc_large_block( HEAP *heap, DWORD flags, void *ptr, SIZE_T siz
return
NULL
;
return
NULL
;
}
}
valgrind_notify_alloc
(
new_ptr
,
size
,
0
);
valgrind_notify_alloc
(
new_ptr
,
size
,
0
);
memcpy
(
new_ptr
,
ptr
,
arena
->
data
_size
);
memcpy
(
new_ptr
,
ptr
,
old
_size
);
valgrind_notify_free
(
ptr
);
valgrind_notify_free
(
ptr
);
free_large_block
(
heap
,
ptr
);
free_large_block
(
heap
,
ptr
);
return
new_ptr
;
return
new_ptr
;
...
@@ -877,12 +876,6 @@ static BOOL validate_large_arena( const HEAP *heap, const ARENA_LARGE *arena )
...
@@ -877,12 +876,6 @@ static BOOL validate_large_arena( const HEAP *heap, const ARENA_LARGE *arena )
err
=
"invalid block header"
;
err
=
"invalid block header"
;
else
if
(
!
contains
(
arena
,
arena
->
block_size
,
arena
+
1
,
arena
->
data_size
))
else
if
(
!
contains
(
arena
,
arena
->
block_size
,
arena
+
1
,
arena
->
data_size
))
err
=
"invalid block size"
;
err
=
"invalid block size"
;
else
if
(
heap
->
flags
&
HEAP_TAIL_CHECKING_ENABLED
)
{
SIZE_T
i
,
unused
=
arena
->
block_size
-
sizeof
(
*
arena
)
-
arena
->
data_size
;
const
unsigned
char
*
data
=
(
const
unsigned
char
*
)(
arena
+
1
)
+
arena
->
data_size
;
for
(
i
=
0
;
i
<
unused
&&
!
err
;
i
++
)
if
(
data
[
i
]
!=
ARENA_TAIL_FILLER
)
err
=
"invalid block tail"
;
}
if
(
err
)
if
(
err
)
{
{
...
@@ -1317,7 +1310,6 @@ static void heap_set_debug_flags( HANDLE handle )
...
@@ -1317,7 +1310,6 @@ static void heap_set_debug_flags( HANDLE handle )
if
(
flags
&
(
HEAP_FREE_CHECKING_ENABLED
|
HEAP_TAIL_CHECKING_ENABLED
))
/* fix existing blocks */
if
(
flags
&
(
HEAP_FREE_CHECKING_ENABLED
|
HEAP_TAIL_CHECKING_ENABLED
))
/* fix existing blocks */
{
{
struct
block
*
block
;
struct
block
*
block
;
ARENA_LARGE
*
large
;
SUBHEAP
*
subheap
;
SUBHEAP
*
subheap
;
LIST_FOR_EACH_ENTRY
(
subheap
,
&
heap
->
subheap_list
,
SUBHEAP
,
entry
)
LIST_FOR_EACH_ENTRY
(
subheap
,
&
heap
->
subheap_list
,
SUBHEAP
,
entry
)
...
@@ -1342,10 +1334,6 @@ static void heap_set_debug_flags( HANDLE handle )
...
@@ -1342,10 +1334,6 @@ static void heap_set_debug_flags( HANDLE handle )
}
}
}
}
}
}
LIST_FOR_EACH_ENTRY
(
large
,
&
heap
->
large_list
,
ARENA_LARGE
,
entry
)
mark_block_tail
(
(
char
*
)(
large
+
1
)
+
large
->
data_size
,
large
->
block_size
-
sizeof
(
*
large
)
-
large
->
data_size
,
flags
);
}
}
if
((
heap
->
flags
&
HEAP_GROWABLE
)
&&
!
heap
->
pending_free
&&
if
((
heap
->
flags
&
HEAP_GROWABLE
)
&&
!
heap
->
pending_free
&&
...
...
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