kernel32: Always create file with FILE_READ_ATTRIBUTES access in CreateFile.

Signed-off-by: Jacek Caban <jacek@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Jacek Caban 2018-08-20 19:29:46 +02:00 committed by Alexandre Julliard
parent 8712db6f55
commit 58233b47e0
4 changed files with 49 additions and 6 deletions

View File

@ -5620,7 +5620,6 @@ static void test_file_security(HANDLE token)
ok(file != INVALID_HANDLE_VALUE, "CreateFile error %d\n", GetLastError()); ok(file != INVALID_HANDLE_VALUE, "CreateFile error %d\n", GetLastError());
access = get_obj_access(file); access = get_obj_access(file);
todo_wine
ok(access == (FILE_READ_ATTRIBUTES | SYNCHRONIZE), "expected FILE_READ_ATTRIBUTES | SYNCHRONIZE, got %#x\n", access); ok(access == (FILE_READ_ATTRIBUTES | SYNCHRONIZE), "expected FILE_READ_ATTRIBUTES | SYNCHRONIZE, got %#x\n", access);
bytes = 0xdeadbeef; bytes = 0xdeadbeef;
@ -5637,7 +5636,6 @@ todo_wine
ok(file != INVALID_HANDLE_VALUE, "CreateFile error %d\n", GetLastError()); ok(file != INVALID_HANDLE_VALUE, "CreateFile error %d\n", GetLastError());
access = get_obj_access(file); access = get_obj_access(file);
todo_wine
ok(access == (FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES), "expected FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES, got %#x\n", access); ok(access == (FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES), "expected FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES, got %#x\n", access);
bytes = 0xdeadbeef; bytes = 0xdeadbeef;
@ -5678,7 +5676,6 @@ todo_wine
ok(file != INVALID_HANDLE_VALUE, "CreateFile error %d\n", GetLastError()); ok(file != INVALID_HANDLE_VALUE, "CreateFile error %d\n", GetLastError());
access = get_obj_access(file); access = get_obj_access(file);
todo_wine
ok(access == (FILE_READ_ATTRIBUTES | SYNCHRONIZE), "expected FILE_READ_ATTRIBUTES | SYNCHRONIZE, got %#x\n", access); ok(access == (FILE_READ_ATTRIBUTES | SYNCHRONIZE), "expected FILE_READ_ATTRIBUTES | SYNCHRONIZE, got %#x\n", access);
CloseHandle(file); CloseHandle(file);
@ -5688,7 +5685,6 @@ todo_wine
ok(file != INVALID_HANDLE_VALUE, "CreateFile error %d\n", GetLastError()); ok(file != INVALID_HANDLE_VALUE, "CreateFile error %d\n", GetLastError());
access = get_obj_access(file); access = get_obj_access(file);
todo_wine
ok(access == (FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES), "expected FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES, got %#x\n", access); ok(access == (FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES), "expected FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES, got %#x\n", access);
CloseHandle(file); CloseHandle(file);

View File

@ -1582,8 +1582,8 @@ HANDLE WINAPI CreateFileW( LPCWSTR filename, DWORD access, DWORD sharing,
if (sa && sa->bInheritHandle) attr.Attributes |= OBJ_INHERIT; if (sa && sa->bInheritHandle) attr.Attributes |= OBJ_INHERIT;
status = NtCreateFile( &ret, access | SYNCHRONIZE, &attr, &io, NULL, attributes, status = NtCreateFile( &ret, access | SYNCHRONIZE | FILE_READ_ATTRIBUTES, &attr, &io,
sharing, nt_disposition[creation - CREATE_NEW], NULL, attributes, sharing, nt_disposition[creation - CREATE_NEW],
options, NULL, 0 ); options, NULL, 0 );
if (status) if (status)
{ {

View File

@ -666,6 +666,11 @@ static void test_CreateNamedPipe(int pipemode)
test_file_access(hnp, SYNCHRONIZE | READ_CONTROL | FILE_WRITE_ATTRIBUTES test_file_access(hnp, SYNCHRONIZE | READ_CONTROL | FILE_WRITE_ATTRIBUTES
| FILE_WRITE_PROPERTIES | FILE_APPEND_DATA | FILE_WRITE_DATA); | FILE_WRITE_PROPERTIES | FILE_APPEND_DATA | FILE_WRITE_DATA);
hFile = CreateFileA(PIPENAME, 0, 0, NULL, OPEN_EXISTING, 0, 0);
ok(hFile != INVALID_HANDLE_VALUE, "CreateFile failed: %u\n", GetLastError());
test_file_access(hFile, SYNCHRONIZE | FILE_READ_ATTRIBUTES);
CloseHandle(hFile);
CloseHandle(hnp); CloseHandle(hnp);
if (winetest_debug > 1) trace("test_CreateNamedPipe returning\n"); if (winetest_debug > 1) trace("test_CreateNamedPipe returning\n");

View File

@ -113,6 +113,20 @@ static inline BOOL is_signaled( HANDLE obj )
return WaitForSingleObject( obj, 0 ) == WAIT_OBJECT_0; return WaitForSingleObject( obj, 0 ) == WAIT_OBJECT_0;
} }
#define test_file_access(a,b) _test_file_access(__LINE__,a,b)
static void _test_file_access(unsigned line, HANDLE handle, DWORD expected_access)
{
FILE_ACCESS_INFORMATION info;
IO_STATUS_BLOCK io;
NTSTATUS status;
memset(&info, 0x11, sizeof(info));
status = NtQueryInformationFile(handle, &io, &info, sizeof(info), FileAccessInformation);
ok_(__FILE__,line)(status == STATUS_SUCCESS, "expected STATUS_SUCCESS, got %08x\n", status);
ok_(__FILE__,line)(info.AccessFlags == expected_access, "got access %08x expected %08x\n",
info.AccessFlags, expected_access);
}
static const WCHAR testpipe[] = { '\\', '\\', '.', '\\', 'p', 'i', 'p', 'e', '\\', static const WCHAR testpipe[] = { '\\', '\\', '.', '\\', 'p', 'i', 'p', 'e', '\\',
't', 'e', 's', 't', 'p', 'i', 'p', 'e', 0 }; 't', 'e', 's', 't', 'p', 'i', 'p', 'e', 0 };
static const WCHAR testpipe_nt[] = { '\\', '?', '?', '\\', 'p', 'i', 'p', 'e', '\\', static const WCHAR testpipe_nt[] = { '\\', '?', '?', '\\', 'p', 'i', 'p', 'e', '\\',
@ -562,6 +576,7 @@ static void _check_pipe_handle_state(int line, HANDLE handle, ULONG read, ULONG
static void test_filepipeinfo(void) static void test_filepipeinfo(void)
{ {
FILE_PIPE_LOCAL_INFORMATION local_info;
IO_STATUS_BLOCK iosb; IO_STATUS_BLOCK iosb;
OBJECT_ATTRIBUTES attr; OBJECT_ATTRIBUTES attr;
UNICODE_STRING name; UNICODE_STRING name;
@ -726,6 +741,33 @@ static void test_filepipeinfo(void)
check_pipe_handle_state(hServer, 1, 0); check_pipe_handle_state(hServer, 1, 0);
CloseHandle(hServer); CloseHandle(hServer);
res = pNtCreateNamedPipeFile(&hServer,
FILE_READ_DATA | FILE_READ_ATTRIBUTES | FILE_WRITE_ATTRIBUTES | SYNCHRONIZE,
&attr, &iosb, FILE_SHARE_READ | FILE_SHARE_WRITE, FILE_CREATE,
0, 1, 1, 0, 0xFFFFFFFF, 500, 500, &timeout);
ok(!res, "NtCreateNamedPipeFile returned %x\n", res);
res = NtCreateFile(&hClient, SYNCHRONIZE, &attr, &iosb, NULL, 0,
FILE_SHARE_READ|FILE_SHARE_WRITE, FILE_OPEN, 0, NULL, 0 );
ok(!res, "NtCreateFile returned %x\n", res);
test_file_access(hClient, SYNCHRONIZE);
res = pNtQueryInformationFile(hClient, &iosb, &local_info, sizeof(local_info),
FilePipeLocalInformation);
todo_wine
ok(res == STATUS_ACCESS_DENIED,
"NtQueryInformationFile(FilePipeLocalInformation) returned: %x\n", res);
res = pNtQueryInformationFile(hClient, &iosb, &local_info, sizeof(local_info),
FilePipeInformation);
todo_wine
ok(res == STATUS_ACCESS_DENIED,
"NtQueryInformationFile(FilePipeInformation) returned: %x\n", res);
CloseHandle(hClient);
CloseHandle(hServer);
} }
static void WINAPI apc( void *arg, IO_STATUS_BLOCK *iosb, ULONG reserved ) static void WINAPI apc( void *arg, IO_STATUS_BLOCK *iosb, ULONG reserved )