mirror of
git://source.winehq.org/git/wine.git
synced 2024-11-01 09:50:52 +00:00
kernel32: Return success from GlobalReAlloc with locked HGLOBAL pointer.
Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=53474
This commit is contained in:
parent
f43fc5121b
commit
28bc3b0703
2 changed files with 9 additions and 12 deletions
|
@ -195,7 +195,10 @@ HGLOBAL WINAPI GlobalReAlloc( HGLOBAL handle, SIZE_T size, UINT flags )
|
||||||
struct mem_entry *mem;
|
struct mem_entry *mem;
|
||||||
void *ptr;
|
void *ptr;
|
||||||
|
|
||||||
if ((mem = unsafe_mem_from_HLOCAL( handle )) && mem->lock) return 0;
|
if (!(flags & GMEM_MODIFY) && (mem = unsafe_mem_from_HLOCAL( handle )) &&
|
||||||
|
mem->lock && (!size || (flags & GMEM_DISCARDABLE)))
|
||||||
|
return 0;
|
||||||
|
|
||||||
if (!(handle = LocalReAlloc( handle, size, flags ))) return 0;
|
if (!(handle = LocalReAlloc( handle, size, flags ))) return 0;
|
||||||
|
|
||||||
/* GlobalReAlloc allows changing GMEM_FIXED to GMEM_MOVEABLE with GMEM_MODIFY */
|
/* GlobalReAlloc allows changing GMEM_FIXED to GMEM_MOVEABLE with GMEM_MODIFY */
|
||||||
|
|
|
@ -1817,21 +1817,17 @@ static void test_GlobalAlloc(void)
|
||||||
if (!(flags & GMEM_MODIFY) && ((flags & GMEM_DISCARDABLE) || !(flags & GMEM_MOVEABLE)))
|
if (!(flags & GMEM_MODIFY) && ((flags & GMEM_DISCARDABLE) || !(flags & GMEM_MOVEABLE)))
|
||||||
ok( !tmp_mem, "GlobalReAlloc succeeded\n" );
|
ok( !tmp_mem, "GlobalReAlloc succeeded\n" );
|
||||||
else
|
else
|
||||||
{
|
|
||||||
todo_wine
|
|
||||||
ok( tmp_mem == mem, "GlobalReAlloc returned %p, error %lu\n", tmp_mem, GetLastError() );
|
ok( tmp_mem == mem, "GlobalReAlloc returned %p, error %lu\n", tmp_mem, GetLastError() );
|
||||||
}
|
|
||||||
entry = *mem_entry_from_HANDLE( mem );
|
entry = *mem_entry_from_HANDLE( mem );
|
||||||
if ((flags & GMEM_DISCARDABLE) && (flags & GMEM_MODIFY)) expect_entry.flags |= 4;
|
if ((flags & GMEM_DISCARDABLE) && (flags & GMEM_MODIFY)) expect_entry.flags |= 4;
|
||||||
if (flags == GMEM_MOVEABLE)
|
if (flags == GMEM_MOVEABLE)
|
||||||
todo_wine ok( entry.ptr != expect_entry.ptr, "got unexpected ptr %p\n", entry.ptr );
|
ok( entry.ptr != expect_entry.ptr, "got unexpected ptr %p\n", entry.ptr );
|
||||||
else
|
else
|
||||||
ok( entry.ptr == expect_entry.ptr, "got ptr %p\n", entry.ptr );
|
ok( entry.ptr == expect_entry.ptr, "got ptr %p\n", entry.ptr );
|
||||||
todo_wine_if((flags & GMEM_MODIFY) && (flags & GMEM_MOVEABLE) && flags != (GMEM_MODIFY | GMEM_MOVEABLE))
|
|
||||||
ok( entry.flags == expect_entry.flags, "got flags %#Ix was %#Ix\n", entry.flags, expect_entry.flags );
|
ok( entry.flags == expect_entry.flags, "got flags %#Ix was %#Ix\n", entry.flags, expect_entry.flags );
|
||||||
size = GlobalSize( mem );
|
size = GlobalSize( mem );
|
||||||
if (flags == GMEM_MOVEABLE)
|
if (flags == GMEM_MOVEABLE)
|
||||||
todo_wine ok( size == 512, "GlobalSize returned %Iu\n", size );
|
ok( size == 512, "GlobalSize returned %Iu\n", size );
|
||||||
else
|
else
|
||||||
ok( size == 10, "GlobalSize returned %Iu\n", size );
|
ok( size == 10, "GlobalSize returned %Iu\n", size );
|
||||||
|
|
||||||
|
@ -1852,17 +1848,16 @@ static void test_GlobalAlloc(void)
|
||||||
if (!(flags & GMEM_MODIFY) && (flags & GMEM_DISCARDABLE))
|
if (!(flags & GMEM_MODIFY) && (flags & GMEM_DISCARDABLE))
|
||||||
ok( !tmp_mem, "GlobalReAlloc succeeded\n" );
|
ok( !tmp_mem, "GlobalReAlloc succeeded\n" );
|
||||||
else
|
else
|
||||||
todo_wine ok( tmp_mem == mem, "GlobalReAlloc returned %p, error %lu\n", tmp_mem, GetLastError() );
|
ok( tmp_mem == mem, "GlobalReAlloc returned %p, error %lu\n", tmp_mem, GetLastError() );
|
||||||
entry = *mem_entry_from_HANDLE( mem );
|
entry = *mem_entry_from_HANDLE( mem );
|
||||||
if ((flags & GMEM_DISCARDABLE) && (flags & GMEM_MODIFY)) expect_entry.flags |= 4;
|
if ((flags & GMEM_DISCARDABLE) && (flags & GMEM_MODIFY)) expect_entry.flags |= 4;
|
||||||
ok( entry.ptr == expect_entry.ptr, "got ptr %p was %p\n", entry.ptr, expect_entry.ptr );
|
ok( entry.ptr == expect_entry.ptr, "got ptr %p was %p\n", entry.ptr, expect_entry.ptr );
|
||||||
todo_wine_if((flags & GMEM_DISCARDABLE) && (flags & GMEM_MODIFY))
|
|
||||||
ok( entry.flags == expect_entry.flags, "got flags %#Ix was %#Ix\n", entry.flags, expect_entry.flags );
|
ok( entry.flags == expect_entry.flags, "got flags %#Ix was %#Ix\n", entry.flags, expect_entry.flags );
|
||||||
size = GlobalSize( mem );
|
size = GlobalSize( mem );
|
||||||
if ((flags & GMEM_DISCARDABLE) || (flags & GMEM_MODIFY))
|
if ((flags & GMEM_DISCARDABLE) || (flags & GMEM_MODIFY))
|
||||||
ok( size == 12, "GlobalSize returned %Iu\n", size );
|
ok( size == 12, "GlobalSize returned %Iu\n", size );
|
||||||
else
|
else
|
||||||
todo_wine_if(!(flags & GMEM_MODIFY)) ok( size == 10, "GlobalSize returned %Iu\n", size );
|
ok( size == 10, "GlobalSize returned %Iu\n", size );
|
||||||
|
|
||||||
ret = GlobalUnlock( mem );
|
ret = GlobalUnlock( mem );
|
||||||
ok( !ret, "GlobalUnlock succeeded\n" );
|
ok( !ret, "GlobalUnlock succeeded\n" );
|
||||||
|
@ -1879,13 +1874,12 @@ static void test_GlobalAlloc(void)
|
||||||
|
|
||||||
tmp_mem = GlobalReAlloc( mem, 0, flags );
|
tmp_mem = GlobalReAlloc( mem, 0, flags );
|
||||||
if (flags & GMEM_MODIFY)
|
if (flags & GMEM_MODIFY)
|
||||||
todo_wine ok( tmp_mem == mem, "GlobalReAlloc returned %p, error %lu\n", tmp_mem, GetLastError() );
|
ok( tmp_mem == mem, "GlobalReAlloc returned %p, error %lu\n", tmp_mem, GetLastError() );
|
||||||
else
|
else
|
||||||
ok( !tmp_mem, "GlobalReAlloc succeeded\n" );
|
ok( !tmp_mem, "GlobalReAlloc succeeded\n" );
|
||||||
entry = *mem_entry_from_HANDLE( mem );
|
entry = *mem_entry_from_HANDLE( mem );
|
||||||
if ((flags & GMEM_DISCARDABLE) && (flags & GMEM_MODIFY)) expect_entry.flags |= 4;
|
if ((flags & GMEM_DISCARDABLE) && (flags & GMEM_MODIFY)) expect_entry.flags |= 4;
|
||||||
ok( entry.ptr == expect_entry.ptr, "got ptr %p was %p\n", entry.ptr, expect_entry.ptr );
|
ok( entry.ptr == expect_entry.ptr, "got ptr %p was %p\n", entry.ptr, expect_entry.ptr );
|
||||||
todo_wine_if((flags & GMEM_MODIFY) && (flags & GMEM_DISCARDABLE))
|
|
||||||
ok( entry.flags == expect_entry.flags, "got flags %#Ix was %#Ix\n", entry.flags, expect_entry.flags );
|
ok( entry.flags == expect_entry.flags, "got flags %#Ix was %#Ix\n", entry.flags, expect_entry.flags );
|
||||||
size = GlobalSize( mem );
|
size = GlobalSize( mem );
|
||||||
ok( size == 12, "GlobalSize returned %Iu\n", size );
|
ok( size == 12, "GlobalSize returned %Iu\n", size );
|
||||||
|
|
Loading…
Reference in a new issue