Commit 8de57bd5 authored by Alexandre Julliard's avatar Alexandre Julliard

kernel32/tests: Add test cases for reading/writing from an invalid buffer address.

parent 63bff093
...@@ -1673,10 +1673,11 @@ static void test_async_file_errors(void) ...@@ -1673,10 +1673,11 @@ static void test_async_file_errors(void)
static void test_read_write(void) static void test_read_write(void)
{ {
DWORD bytes, ret; DWORD bytes, ret, old_prot;
HANDLE hFile; HANDLE hFile;
char temp_path[MAX_PATH]; char temp_path[MAX_PATH];
char filename[MAX_PATH]; char filename[MAX_PATH];
char *mem;
static const char prefix[] = "pfx"; static const char prefix[] = "pfx";
ret = GetTempPathA(MAX_PATH, temp_path); ret = GetTempPathA(MAX_PATH, temp_path);
...@@ -1726,6 +1727,95 @@ static void test_read_write(void) ...@@ -1726,6 +1727,95 @@ static void test_read_write(void)
"ret = %d, error %d\n", ret, GetLastError()); "ret = %d, error %d\n", ret, GetLastError());
ok(!bytes, "bytes = %d\n", bytes); ok(!bytes, "bytes = %d\n", bytes);
/* test passing protected memory as buffer */
mem = VirtualAlloc( NULL, 0x4000, MEM_COMMIT, PAGE_READWRITE );
ok( mem != NULL, "failed to allocate virtual mem error %u\n", GetLastError() );
ret = WriteFile( hFile, mem, 0x4000, &bytes, NULL );
ok( ret, "WriteFile failed error %u\n", GetLastError() );
ok( bytes == 0x4000, "only wrote %x bytes\n", bytes );
ret = VirtualProtect( mem + 0x2000, 0x2000, PAGE_NOACCESS, &old_prot );
ok( ret, "VirtualProtect failed error %u\n", GetLastError() );
ret = WriteFile( hFile, mem, 0x4000, &bytes, NULL );
ok( !ret, "WriteFile succeeded\n" );
ok( GetLastError() == ERROR_INVALID_USER_BUFFER ||
GetLastError() == ERROR_INVALID_PARAMETER, /* win9x */
"wrong error %u\n", GetLastError() );
ok( bytes == 0, "wrote %x bytes\n", bytes );
ret = WriteFile( (HANDLE)0xdead, mem, 0x4000, &bytes, NULL );
ok( !ret, "WriteFile succeeded\n" );
ok( GetLastError() == ERROR_INVALID_HANDLE || /* handle is checked before buffer on NT */
GetLastError() == ERROR_INVALID_PARAMETER, /* win9x */
"wrong error %u\n", GetLastError() );
ok( bytes == 0, "wrote %x bytes\n", bytes );
ret = VirtualProtect( mem, 0x2000, PAGE_NOACCESS, &old_prot );
ok( ret, "VirtualProtect failed error %u\n", GetLastError() );
ret = WriteFile( hFile, mem, 0x4000, &bytes, NULL );
ok( !ret, "WriteFile succeeded\n" );
ok( GetLastError() == ERROR_INVALID_USER_BUFFER ||
GetLastError() == ERROR_INVALID_PARAMETER, /* win9x */
"wrong error %u\n", GetLastError() );
ok( bytes == 0, "wrote %x bytes\n", bytes );
SetFilePointer( hFile, 0, NULL, FILE_BEGIN );
ret = ReadFile( hFile, mem, 0x4000, &bytes, NULL );
ok( !ret, "ReadFile succeeded\n" );
ok( GetLastError() == ERROR_NOACCESS ||
GetLastError() == ERROR_INVALID_PARAMETER, /* win9x */
"wrong error %u\n", GetLastError() );
ok( bytes == 0, "read %x bytes\n", bytes );
ret = VirtualProtect( mem, 0x2000, PAGE_READONLY, &old_prot );
ok( ret, "VirtualProtect failed error %u\n", GetLastError() );
ret = ReadFile( hFile, mem, 0x4000, &bytes, NULL );
ok( !ret, "ReadFile succeeded\n" );
ok( GetLastError() == ERROR_NOACCESS ||
GetLastError() == ERROR_INVALID_PARAMETER, /* win9x */
"wrong error %u\n", GetLastError() );
ok( bytes == 0, "read %x bytes\n", bytes );
ret = VirtualProtect( mem, 0x2000, PAGE_READWRITE, &old_prot );
ok( ret, "VirtualProtect failed error %u\n", GetLastError() );
ret = ReadFile( hFile, mem, 0x4000, &bytes, NULL );
ok( !ret, "ReadFile succeeded\n" );
ok( GetLastError() == ERROR_NOACCESS ||
GetLastError() == ERROR_INVALID_PARAMETER, /* win9x */
"wrong error %u\n", GetLastError() );
ok( bytes == 0, "read %x bytes\n", bytes );
SetFilePointer( hFile, 0x1234, NULL, FILE_BEGIN );
SetEndOfFile( hFile );
SetFilePointer( hFile, 0, NULL, FILE_BEGIN );
ret = ReadFile( hFile, mem, 0x4000, &bytes, NULL );
ok( !ret, "ReadFile succeeded\n" );
ok( GetLastError() == ERROR_NOACCESS ||
GetLastError() == ERROR_INVALID_PARAMETER, /* win9x */
"wrong error %u\n", GetLastError() );
ok( bytes == 0, "read %x bytes\n", bytes );
ret = ReadFile( hFile, mem, 0x2000, &bytes, NULL );
ok( ret, "ReadFile failed error %u\n", GetLastError() );
ok( bytes == 0x1234, "read %x bytes\n", bytes );
ret = ReadFile( hFile, NULL, 1, &bytes, NULL );
ok( !ret, "ReadFile succeeded\n" );
ok( GetLastError() == ERROR_NOACCESS ||
GetLastError() == ERROR_INVALID_PARAMETER, /* win9x */
"wrong error %u\n", GetLastError() );
ok( bytes == 0, "read %x bytes\n", bytes );
VirtualFree( mem, 0, MEM_FREE );
ret = CloseHandle(hFile); ret = CloseHandle(hFile);
ok( ret, "CloseHandle: error %d\n", GetLastError()); ok( ret, "CloseHandle: error %d\n", GetLastError());
ret = DeleteFileA(filename); ret = DeleteFileA(filename);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment