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
60ddf0f0
Commit
60ddf0f0
authored
May 02, 2019
by
Jacek Caban
Committed by
Alexandre Julliard
May 02, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntoskrnl.exe/tests: Add CancelIo tests.
Signed-off-by:
Jacek Caban
<
jacek@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
5f10c86d
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
119 additions
and
0 deletions
+119
-0
driver.c
dlls/ntoskrnl.exe/tests/driver.c
+36
-0
driver.h
dlls/ntoskrnl.exe/tests/driver.h
+3
-0
ntoskrnl.c
dlls/ntoskrnl.exe/tests/ntoskrnl.c
+80
-0
No files found.
dlls/ntoskrnl.exe/tests/driver.c
View file @
60ddf0f0
...
@@ -770,6 +770,15 @@ static void WINAPI cancel_irp(DEVICE_OBJECT *device, IRP *irp)
...
@@ -770,6 +770,15 @@ static void WINAPI cancel_irp(DEVICE_OBJECT *device, IRP *irp)
cancel_cnt
++
;
cancel_cnt
++
;
}
}
static
void
WINAPI
cancel_ioctl_irp
(
DEVICE_OBJECT
*
device
,
IRP
*
irp
)
{
IoReleaseCancelSpinLock
(
irp
->
CancelIrql
);
irp
->
IoStatus
.
Status
=
STATUS_CANCELLED
;
irp
->
IoStatus
.
Information
=
0
;
cancel_cnt
++
;
IoCompleteRequest
(
irp
,
IO_NO_INCREMENT
);
}
static
NTSTATUS
WINAPI
cancel_test_completion
(
DEVICE_OBJECT
*
device
,
IRP
*
irp
,
void
*
context
)
static
NTSTATUS
WINAPI
cancel_test_completion
(
DEVICE_OBJECT
*
device
,
IRP
*
irp
,
void
*
context
)
{
{
ok
(
cancel_cnt
==
1
,
"cancel_cnt = %d
\n
"
,
cancel_cnt
);
ok
(
cancel_cnt
==
1
,
"cancel_cnt = %d
\n
"
,
cancel_cnt
);
...
@@ -1505,6 +1514,22 @@ static NTSTATUS test_basic_ioctl(IRP *irp, IO_STACK_LOCATION *stack, ULONG_PTR *
...
@@ -1505,6 +1514,22 @@ static NTSTATUS test_basic_ioctl(IRP *irp, IO_STACK_LOCATION *stack, ULONG_PTR *
return
STATUS_SUCCESS
;
return
STATUS_SUCCESS
;
}
}
static
NTSTATUS
get_cancel_count
(
IRP
*
irp
,
IO_STACK_LOCATION
*
stack
,
ULONG_PTR
*
info
)
{
ULONG
length
=
stack
->
Parameters
.
DeviceIoControl
.
OutputBufferLength
;
char
*
buffer
=
irp
->
AssociatedIrp
.
SystemBuffer
;
if
(
!
buffer
)
return
STATUS_ACCESS_VIOLATION
;
if
(
length
<
sizeof
(
DWORD
))
return
STATUS_BUFFER_TOO_SMALL
;
*
(
DWORD
*
)
buffer
=
cancel_cnt
;
*
info
=
sizeof
(
DWORD
);
return
STATUS_SUCCESS
;
}
static
NTSTATUS
test_load_driver_ioctl
(
IRP
*
irp
,
IO_STACK_LOCATION
*
stack
,
ULONG_PTR
*
info
)
static
NTSTATUS
test_load_driver_ioctl
(
IRP
*
irp
,
IO_STACK_LOCATION
*
stack
,
ULONG_PTR
*
info
)
{
{
BOOL
*
load
=
irp
->
AssociatedIrp
.
SystemBuffer
;
BOOL
*
load
=
irp
->
AssociatedIrp
.
SystemBuffer
;
...
@@ -1549,6 +1574,17 @@ static NTSTATUS WINAPI driver_IoControl(DEVICE_OBJECT *device, IRP *irp)
...
@@ -1549,6 +1574,17 @@ static NTSTATUS WINAPI driver_IoControl(DEVICE_OBJECT *device, IRP *irp)
case
IOCTL_WINETEST_LOAD_DRIVER
:
case
IOCTL_WINETEST_LOAD_DRIVER
:
status
=
test_load_driver_ioctl
(
irp
,
stack
,
&
irp
->
IoStatus
.
Information
);
status
=
test_load_driver_ioctl
(
irp
,
stack
,
&
irp
->
IoStatus
.
Information
);
break
;
break
;
case
IOCTL_WINETEST_RESET_CANCEL
:
cancel_cnt
=
0
;
status
=
STATUS_SUCCESS
;
break
;
case
IOCTL_WINETEST_TEST_CANCEL
:
IoSetCancelRoutine
(
irp
,
cancel_ioctl_irp
);
IoMarkIrpPending
(
irp
);
return
STATUS_PENDING
;
case
IOCTL_WINETEST_GET_CANCEL_COUNT
:
status
=
get_cancel_count
(
irp
,
stack
,
&
irp
->
IoStatus
.
Information
);
break
;
default:
default:
break
;
break
;
}
}
...
...
dlls/ntoskrnl.exe/tests/driver.h
View file @
60ddf0f0
...
@@ -25,6 +25,9 @@
...
@@ -25,6 +25,9 @@
#define IOCTL_WINETEST_BASIC_IOCTL CTL_CODE(FILE_DEVICE_UNKNOWN, 0x800, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_WINETEST_BASIC_IOCTL CTL_CODE(FILE_DEVICE_UNKNOWN, 0x800, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_WINETEST_MAIN_TEST CTL_CODE(FILE_DEVICE_UNKNOWN, 0x801, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_WINETEST_MAIN_TEST CTL_CODE(FILE_DEVICE_UNKNOWN, 0x801, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_WINETEST_LOAD_DRIVER CTL_CODE(FILE_DEVICE_UNKNOWN, 0x802, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_WINETEST_LOAD_DRIVER CTL_CODE(FILE_DEVICE_UNKNOWN, 0x802, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_WINETEST_RESET_CANCEL CTL_CODE(FILE_DEVICE_UNKNOWN, 0x803, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_WINETEST_TEST_CANCEL CTL_CODE(FILE_DEVICE_UNKNOWN, 0x804, METHOD_BUFFERED, FILE_ANY_ACCESS)
#define IOCTL_WINETEST_GET_CANCEL_COUNT CTL_CODE(FILE_DEVICE_UNKNOWN, 0x805, METHOD_BUFFERED, FILE_ANY_ACCESS)
static
const
char
teststr
[]
=
"Wine is not an emulator"
;
static
const
char
teststr
[]
=
"Wine is not an emulator"
;
...
...
dlls/ntoskrnl.exe/tests/ntoskrnl.c
View file @
60ddf0f0
...
@@ -197,6 +197,85 @@ static void test_basic_ioctl(void)
...
@@ -197,6 +197,85 @@ static void test_basic_ioctl(void)
ok
(
!
strcmp
(
buf
,
teststr
),
"got '%s'
\n
"
,
buf
);
ok
(
!
strcmp
(
buf
,
teststr
),
"got '%s'
\n
"
,
buf
);
}
}
static
void
test_cancel_io
(
void
)
{
OVERLAPPED
overlapped
,
overlapped2
;
DWORD
cancel_cnt
;
HANDLE
file
;
BOOL
res
;
overlapped
.
hEvent
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
overlapped2
.
hEvent
=
CreateEventW
(
NULL
,
TRUE
,
FALSE
,
NULL
);
file
=
CreateFileA
(
"
\\\\
.
\\
WineTestDriver"
,
0
,
0
,
NULL
,
OPEN_EXISTING
,
FILE_FLAG_OVERLAPPED
,
NULL
);
ok
(
file
!=
INVALID_HANDLE_VALUE
,
"failed to open device: %u
\n
"
,
GetLastError
());
/* test cancelling all device requests */
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_RESET_CANCEL
,
NULL
,
0
,
NULL
,
0
,
NULL
,
&
overlapped
);
todo_wine
ok
(
res
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
if
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
)
WaitForSingleObject
(
overlapped
.
hEvent
,
INFINITE
);
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_TEST_CANCEL
,
NULL
,
0
,
NULL
,
0
,
NULL
,
&
overlapped
);
ok
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_TEST_CANCEL
,
NULL
,
0
,
NULL
,
0
,
NULL
,
&
overlapped2
);
ok
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
cancel_cnt
=
0xdeadbeef
;
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_GET_CANCEL_COUNT
,
NULL
,
0
,
&
cancel_cnt
,
sizeof
(
cancel_cnt
),
NULL
,
&
overlapped
);
todo_wine
ok
(
res
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
if
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
)
WaitForSingleObject
(
overlapped
.
hEvent
,
INFINITE
);
ok
(
cancel_cnt
==
0
,
"cancel_cnt = %u
\n
"
,
cancel_cnt
);
CancelIo
(
file
);
cancel_cnt
=
0xdeadbeef
;
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_GET_CANCEL_COUNT
,
NULL
,
0
,
&
cancel_cnt
,
sizeof
(
cancel_cnt
),
NULL
,
&
overlapped
);
todo_wine
ok
(
res
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
if
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
)
WaitForSingleObject
(
overlapped
.
hEvent
,
INFINITE
);
todo_wine
ok
(
cancel_cnt
==
2
,
"cancel_cnt = %u
\n
"
,
cancel_cnt
);
/* test cancelling selected overlapped event */
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_RESET_CANCEL
,
NULL
,
0
,
NULL
,
0
,
NULL
,
&
overlapped
);
todo_wine
ok
(
res
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
if
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
)
WaitForSingleObject
(
overlapped
.
hEvent
,
INFINITE
);
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_TEST_CANCEL
,
NULL
,
0
,
NULL
,
0
,
NULL
,
&
overlapped
);
ok
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_TEST_CANCEL
,
NULL
,
0
,
NULL
,
0
,
NULL
,
&
overlapped2
);
ok
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
CancelIoEx
(
file
,
&
overlapped
);
cancel_cnt
=
0xdeadbeef
;
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_GET_CANCEL_COUNT
,
NULL
,
0
,
&
cancel_cnt
,
sizeof
(
cancel_cnt
),
NULL
,
&
overlapped
);
todo_wine
ok
(
res
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
if
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
)
WaitForSingleObject
(
overlapped
.
hEvent
,
INFINITE
);
todo_wine
ok
(
cancel_cnt
==
1
,
"cancel_cnt = %u
\n
"
,
cancel_cnt
);
CancelIoEx
(
file
,
&
overlapped2
);
cancel_cnt
=
0xdeadbeef
;
res
=
DeviceIoControl
(
file
,
IOCTL_WINETEST_GET_CANCEL_COUNT
,
NULL
,
0
,
&
cancel_cnt
,
sizeof
(
cancel_cnt
),
NULL
,
&
overlapped
);
todo_wine
ok
(
res
,
"DeviceIoControl failed: %u
\n
"
,
GetLastError
());
if
(
!
res
&&
GetLastError
()
==
ERROR_IO_PENDING
)
WaitForSingleObject
(
overlapped
.
hEvent
,
INFINITE
);
todo_wine
ok
(
cancel_cnt
==
2
,
"cancel_cnt = %u
\n
"
,
cancel_cnt
);
CloseHandle
(
overlapped
.
hEvent
);
CloseHandle
(
overlapped2
.
hEvent
);
CloseHandle
(
file
);
}
static
void
test_load_driver
(
SC_HANDLE
service
)
static
void
test_load_driver
(
SC_HANDLE
service
)
{
{
SERVICE_STATUS
status
;
SERVICE_STATUS
status
;
...
@@ -268,6 +347,7 @@ START_TEST(ntoskrnl)
...
@@ -268,6 +347,7 @@ START_TEST(ntoskrnl)
test_basic_ioctl
();
test_basic_ioctl
();
main_test
();
main_test
();
test_cancel_io
();
test_load_driver
(
service2
);
test_load_driver
(
service2
);
unload_driver
(
service2
);
unload_driver
(
service2
);
...
...
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