ole32: Improve thread safety in DidAlloc().
Signed-off-by: Nikolay Sivov <nsivov@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
08f4b6ee0a
commit
1e3bc9f3a6
|
@ -323,7 +323,7 @@ static SIZE_T WINAPI IMalloc_fnGetSize(IMalloc *iface, void *pv)
|
||||||
*/
|
*/
|
||||||
static INT WINAPI IMalloc_fnDidAlloc(IMalloc *iface, void *mem)
|
static INT WINAPI IMalloc_fnDidAlloc(IMalloc *iface, void *mem)
|
||||||
{
|
{
|
||||||
BOOL spyed_block = FALSE;
|
BOOL spyed_block = FALSE, spy_active = FALSE;
|
||||||
int did_alloc;
|
int did_alloc;
|
||||||
|
|
||||||
TRACE("(%p)\n", mem);
|
TRACE("(%p)\n", mem);
|
||||||
|
@ -335,12 +335,13 @@ static INT WINAPI IMalloc_fnDidAlloc(IMalloc *iface, void *mem)
|
||||||
{
|
{
|
||||||
EnterCriticalSection(&IMalloc32_SpyCS);
|
EnterCriticalSection(&IMalloc32_SpyCS);
|
||||||
spyed_block = !!mallocspy_is_allocation_spyed(mem);
|
spyed_block = !!mallocspy_is_allocation_spyed(mem);
|
||||||
|
spy_active = TRUE;
|
||||||
mem = IMallocSpy_PreDidAlloc(Malloc32.pSpy, mem, spyed_block);
|
mem = IMallocSpy_PreDidAlloc(Malloc32.pSpy, mem, spyed_block);
|
||||||
}
|
}
|
||||||
|
|
||||||
did_alloc = HeapValidate(GetProcessHeap(), 0, mem);
|
did_alloc = HeapValidate(GetProcessHeap(), 0, mem);
|
||||||
|
|
||||||
if (Malloc32.pSpy)
|
if (spy_active)
|
||||||
{
|
{
|
||||||
did_alloc = IMallocSpy_PostDidAlloc(Malloc32.pSpy, mem, spyed_block, did_alloc);
|
did_alloc = IMallocSpy_PostDidAlloc(Malloc32.pSpy, mem, spyed_block, did_alloc);
|
||||||
LeaveCriticalSection(&IMalloc32_SpyCS);
|
LeaveCriticalSection(&IMalloc32_SpyCS);
|
||||||
|
|
Loading…
Reference in New Issue