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
0b4266c7
Commit
0b4266c7
authored
May 31, 2022
by
Rémi Bernon
Committed by
Alexandre Julliard
May 31, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Call valgrind alloc notifications at the topmost level.
Signed-off-by:
Rémi Bernon
<
rbernon@codeweavers.com
>
parent
3f52b3a7
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
18 additions
and
22 deletions
+18
-22
heap.c
dlls/ntdll/heap.c
+18
-22
No files found.
dlls/ntdll/heap.c
View file @
0b4266c7
...
@@ -377,7 +377,7 @@ static inline void initialize_block( void *ptr, SIZE_T size, SIZE_T unused, DWOR
...
@@ -377,7 +377,7 @@ static inline void initialize_block( void *ptr, SIZE_T size, SIZE_T unused, DWOR
}
}
/* notify that a new block of memory has been allocated for debugging purposes */
/* notify that a new block of memory has been allocated for debugging purposes */
static
inline
void
notify_alloc
(
void
*
ptr
,
SIZE_T
size
,
BOOL
init
)
static
inline
void
valgrind_notify_alloc
(
void
const
*
ptr
,
SIZE_T
size
,
BOOL
init
)
{
{
#ifdef VALGRIND_MALLOCLIKE_BLOCK
#ifdef VALGRIND_MALLOCLIKE_BLOCK
VALGRIND_MALLOCLIKE_BLOCK
(
ptr
,
size
,
0
,
init
);
VALGRIND_MALLOCLIKE_BLOCK
(
ptr
,
size
,
0
,
init
);
...
@@ -385,14 +385,14 @@ static inline void notify_alloc( void *ptr, SIZE_T size, BOOL init )
...
@@ -385,14 +385,14 @@ static inline void notify_alloc( void *ptr, SIZE_T size, BOOL init )
}
}
/* notify that a block of memory has been freed for debugging purposes */
/* notify that a block of memory has been freed for debugging purposes */
static
inline
void
notify_free
(
void
const
*
ptr
)
static
inline
void
valgrind_
notify_free
(
void
const
*
ptr
)
{
{
#ifdef VALGRIND_FREELIKE_BLOCK
#ifdef VALGRIND_FREELIKE_BLOCK
VALGRIND_FREELIKE_BLOCK
(
ptr
,
0
);
VALGRIND_FREELIKE_BLOCK
(
ptr
,
0
);
#endif
#endif
}
}
static
inline
void
notify_realloc
(
void
const
*
ptr
,
SIZE_T
size_old
,
SIZE_T
size_new
)
static
inline
void
valgrind_notify_resize
(
void
const
*
ptr
,
SIZE_T
size_old
,
SIZE_T
size_new
)
{
{
#ifdef VALGRIND_RESIZEINPLACE_BLOCK
#ifdef VALGRIND_RESIZEINPLACE_BLOCK
/* zero is not a valid size */
/* zero is not a valid size */
...
@@ -400,7 +400,7 @@ static inline void notify_realloc( void const *ptr, SIZE_T size_old, SIZE_T size
...
@@ -400,7 +400,7 @@ static inline void notify_realloc( void const *ptr, SIZE_T size_old, SIZE_T size
#endif
#endif
}
}
static
void
notify_free_all
(
SUBHEAP
*
subheap
)
static
void
valgrind_
notify_free_all
(
SUBHEAP
*
subheap
)
{
{
#ifdef VALGRIND_FREELIKE_BLOCK
#ifdef VALGRIND_FREELIKE_BLOCK
struct
block
*
block
;
struct
block
*
block
;
...
@@ -411,7 +411,7 @@ static void notify_free_all( SUBHEAP *subheap )
...
@@ -411,7 +411,7 @@ static void notify_free_all( SUBHEAP *subheap )
for
(
block
=
first_block
(
subheap
);
block
;
block
=
next_block
(
subheap
,
block
))
for
(
block
=
first_block
(
subheap
);
block
;
block
=
next_block
(
subheap
,
block
))
{
{
if
(
block_get_flags
(
block
)
&
BLOCK_FLAG_FREE
)
continue
;
if
(
block_get_flags
(
block
)
&
BLOCK_FLAG_FREE
)
continue
;
if
(
block_get_type
(
block
)
==
ARENA_INUSE_MAGIC
)
notify_free
(
block
+
1
);
if
(
block_get_type
(
block
)
==
ARENA_INUSE_MAGIC
)
valgrind_
notify_free
(
block
+
1
);
}
}
#endif
#endif
}
}
...
@@ -801,7 +801,6 @@ static void *allocate_large_block( HEAP *heap, DWORD flags, SIZE_T size )
...
@@ -801,7 +801,6 @@ static void *allocate_large_block( HEAP *heap, DWORD flags, SIZE_T size )
arena
->
magic
=
ARENA_LARGE_MAGIC
;
arena
->
magic
=
ARENA_LARGE_MAGIC
;
mark_block_tail
(
(
char
*
)(
arena
+
1
)
+
size
,
block_size
-
sizeof
(
*
arena
)
-
size
,
flags
);
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
);
notify_alloc
(
arena
+
1
,
size
,
flags
&
HEAP_ZERO_MEMORY
);
return
arena
+
1
;
return
arena
+
1
;
}
}
...
@@ -833,11 +832,7 @@ static void *realloc_large_block( HEAP *heap, DWORD flags, void *ptr, SIZE_T siz
...
@@ -833,11 +832,7 @@ static void *realloc_large_block( HEAP *heap, DWORD flags, void *ptr, SIZE_T siz
SIZE_T
unused
=
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 */
#ifdef VALGRIND_RESIZEINPLACE_BLOCK
valgrind_notify_resize
(
arena
+
1
,
arena
->
data_size
,
size
);
if
(
RUNNING_ON_VALGRIND
)
notify_realloc
(
arena
+
1
,
arena
->
data_size
,
size
);
else
#endif
if
(
size
>
arena
->
data_size
)
if
(
size
>
arena
->
data_size
)
initialize_block
(
(
char
*
)
ptr
+
arena
->
data_size
,
size
-
arena
->
data_size
,
unused
,
flags
);
initialize_block
(
(
char
*
)
ptr
+
arena
->
data_size
,
size
-
arena
->
data_size
,
unused
,
flags
);
else
else
...
@@ -851,9 +846,10 @@ static void *realloc_large_block( HEAP *heap, DWORD flags, void *ptr, SIZE_T siz
...
@@ -851,9 +846,10 @@ static void *realloc_large_block( HEAP *heap, DWORD flags, void *ptr, SIZE_T siz
WARN
(
"Could not allocate block for %08lx bytes
\n
"
,
size
);
WARN
(
"Could not allocate block for %08lx bytes
\n
"
,
size
);
return
NULL
;
return
NULL
;
}
}
valgrind_notify_alloc
(
new_ptr
,
size
,
0
);
memcpy
(
new_ptr
,
ptr
,
arena
->
data_size
);
memcpy
(
new_ptr
,
ptr
,
arena
->
data_size
);
valgrind_notify_free
(
ptr
);
free_large_block
(
heap
,
ptr
);
free_large_block
(
heap
,
ptr
);
notify_free
(
ptr
);
return
new_ptr
;
return
new_ptr
;
}
}
...
@@ -1473,13 +1469,13 @@ HANDLE WINAPI RtlDestroyHeap( HANDLE heap )
...
@@ -1473,13 +1469,13 @@ HANDLE WINAPI RtlDestroyHeap( HANDLE heap )
LIST_FOR_EACH_ENTRY_SAFE
(
subheap
,
next
,
&
heapPtr
->
subheap_list
,
SUBHEAP
,
entry
)
LIST_FOR_EACH_ENTRY_SAFE
(
subheap
,
next
,
&
heapPtr
->
subheap_list
,
SUBHEAP
,
entry
)
{
{
if
(
subheap
==
&
heapPtr
->
subheap
)
continue
;
/* do this one last */
if
(
subheap
==
&
heapPtr
->
subheap
)
continue
;
/* do this one last */
notify_free_all
(
subheap
);
valgrind_
notify_free_all
(
subheap
);
list_remove
(
&
subheap
->
entry
);
list_remove
(
&
subheap
->
entry
);
size
=
0
;
size
=
0
;
addr
=
ROUND_ADDR
(
subheap
,
COMMIT_MASK
);
addr
=
ROUND_ADDR
(
subheap
,
COMMIT_MASK
);
NtFreeVirtualMemory
(
NtCurrentProcess
(),
&
addr
,
&
size
,
MEM_RELEASE
);
NtFreeVirtualMemory
(
NtCurrentProcess
(),
&
addr
,
&
size
,
MEM_RELEASE
);
}
}
notify_free_all
(
&
heapPtr
->
subheap
);
valgrind_
notify_free_all
(
&
heapPtr
->
subheap
);
size
=
0
;
size
=
0
;
addr
=
heap
;
addr
=
heap
;
NtFreeVirtualMemory
(
NtCurrentProcess
(),
&
addr
,
&
size
,
MEM_RELEASE
);
NtFreeVirtualMemory
(
NtCurrentProcess
(),
&
addr
,
&
size
,
MEM_RELEASE
);
...
@@ -1510,8 +1506,6 @@ static NTSTATUS heap_allocate( HEAP *heap, ULONG flags, SIZE_T size, void **ret
...
@@ -1510,8 +1506,6 @@ static NTSTATUS heap_allocate( HEAP *heap, ULONG flags, SIZE_T size, void **ret
block_set_type
(
block
,
ARENA_INUSE_MAGIC
);
block_set_type
(
block
,
ARENA_INUSE_MAGIC
);
shrink_used_block
(
subheap
,
block
,
0
,
old_block_size
,
block_size
,
size
);
shrink_used_block
(
subheap
,
block
,
0
,
old_block_size
,
block_size
,
size
);
notify_alloc
(
block
+
1
,
size
,
flags
&
HEAP_ZERO_MEMORY
);
initialize_block
(
block
+
1
,
size
,
block
->
unused_bytes
,
flags
);
initialize_block
(
block
+
1
,
size
,
block
->
unused_bytes
,
flags
);
*
ret
=
block
+
1
;
*
ret
=
block
+
1
;
...
@@ -1536,6 +1530,8 @@ void *WINAPI DECLSPEC_HOTPATCH RtlAllocateHeap( HANDLE heap, ULONG flags, SIZE_T
...
@@ -1536,6 +1530,8 @@ void *WINAPI DECLSPEC_HOTPATCH RtlAllocateHeap( HANDLE heap, ULONG flags, SIZE_T
heap_unlock
(
heapPtr
,
flags
);
heap_unlock
(
heapPtr
,
flags
);
}
}
if
(
!
status
)
valgrind_notify_alloc
(
ptr
,
size
,
flags
&
HEAP_ZERO_MEMORY
);
TRACE
(
"heap %p, flags %#x, size %#Ix, return %p, status %#x.
\n
"
,
heap
,
flags
,
size
,
ptr
,
status
);
TRACE
(
"heap %p, flags %#x, size %#Ix, return %p, status %#x.
\n
"
,
heap
,
flags
,
size
,
ptr
,
status
);
heap_set_status
(
heapPtr
,
flags
,
status
);
heap_set_status
(
heapPtr
,
flags
,
status
);
return
ptr
;
return
ptr
;
...
@@ -1547,9 +1543,6 @@ static NTSTATUS heap_free( HEAP *heap, void *ptr )
...
@@ -1547,9 +1543,6 @@ static NTSTATUS heap_free( HEAP *heap, void *ptr )
ARENA_INUSE
*
block
;
ARENA_INUSE
*
block
;
SUBHEAP
*
subheap
;
SUBHEAP
*
subheap
;
/* Inform valgrind we are trying to free memory, so it can throw up an error message */
notify_free
(
ptr
);
if
(
!
(
block
=
unsafe_block_from_ptr
(
heap
,
ptr
,
&
subheap
)))
return
STATUS_INVALID_PARAMETER
;
if
(
!
(
block
=
unsafe_block_from_ptr
(
heap
,
ptr
,
&
subheap
)))
return
STATUS_INVALID_PARAMETER
;
if
(
!
subheap
)
free_large_block
(
heap
,
ptr
);
if
(
!
subheap
)
free_large_block
(
heap
,
ptr
);
else
free_used_block
(
subheap
,
block
);
else
free_used_block
(
subheap
,
block
);
...
@@ -1567,6 +1560,8 @@ BOOLEAN WINAPI DECLSPEC_HOTPATCH RtlFreeHeap( HANDLE heap, ULONG flags, void *pt
...
@@ -1567,6 +1560,8 @@ BOOLEAN WINAPI DECLSPEC_HOTPATCH RtlFreeHeap( HANDLE heap, ULONG flags, void *pt
if
(
!
ptr
)
return
TRUE
;
if
(
!
ptr
)
return
TRUE
;
valgrind_notify_free
(
ptr
);
if
(
!
(
heapPtr
=
HEAP_GetPtr
(
heap
)))
if
(
!
(
heapPtr
=
HEAP_GetPtr
(
heap
)))
status
=
STATUS_INVALID_PARAMETER
;
status
=
STATUS_INVALID_PARAMETER
;
else
else
...
@@ -1614,23 +1609,24 @@ static NTSTATUS heap_reallocate( HEAP *heap, ULONG flags, void *ptr, SIZE_T size
...
@@ -1614,23 +1609,24 @@ static NTSTATUS heap_reallocate( HEAP *heap, ULONG flags, void *ptr, SIZE_T size
list_remove
(
&
entry
->
entry
);
list_remove
(
&
entry
->
entry
);
old_block_size
+=
block_get_size
(
next
);
old_block_size
+=
block_get_size
(
next
);
if
(
!
subheap_commit
(
subheap
,
block
,
block_size
))
return
STATUS_NO_MEMORY
;
if
(
!
subheap_commit
(
subheap
,
block
,
block_size
))
return
STATUS_NO_MEMORY
;
notify_realloc
(
block
+
1
,
old_size
,
size
);
valgrind_notify_resize
(
block
+
1
,
old_size
,
size
);
shrink_used_block
(
subheap
,
block
,
block_get_flags
(
block
),
old_block_size
,
block_size
,
size
);
shrink_used_block
(
subheap
,
block
,
block_get_flags
(
block
),
old_block_size
,
block_size
,
size
);
}
}
else
else
{
{
if
(
flags
&
HEAP_REALLOC_IN_PLACE_ONLY
)
return
STATUS_NO_MEMORY
;
if
(
flags
&
HEAP_REALLOC_IN_PLACE_ONLY
)
return
STATUS_NO_MEMORY
;
if
((
status
=
heap_allocate
(
heap
,
flags
&
~
HEAP_ZERO_MEMORY
,
size
,
ret
)))
return
status
;
if
((
status
=
heap_allocate
(
heap
,
flags
&
~
HEAP_ZERO_MEMORY
,
size
,
ret
)))
return
status
;
valgrind_notify_alloc
(
*
ret
,
size
,
0
);
memcpy
(
*
ret
,
block
+
1
,
old_size
);
memcpy
(
*
ret
,
block
+
1
,
old_size
);
if
(
flags
&
HEAP_ZERO_MEMORY
)
memset
(
(
char
*
)
*
ret
+
old_size
,
0
,
size
-
old_size
);
if
(
flags
&
HEAP_ZERO_MEMORY
)
memset
(
(
char
*
)
*
ret
+
old_size
,
0
,
size
-
old_size
);
notify_free
(
ptr
);
valgrind_
notify_free
(
ptr
);
free_used_block
(
subheap
,
block
);
free_used_block
(
subheap
,
block
);
return
STATUS_SUCCESS
;
return
STATUS_SUCCESS
;
}
}
}
}
else
else
{
{
notify_realloc
(
block
+
1
,
old_size
,
size
);
valgrind_notify_resize
(
block
+
1
,
old_size
,
size
);
shrink_used_block
(
subheap
,
block
,
block_get_flags
(
block
),
old_block_size
,
block_size
,
size
);
shrink_used_block
(
subheap
,
block
,
block_get_flags
(
block
),
old_block_size
,
block_size
,
size
);
}
}
...
...
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