Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
90fa9967
Commit
90fa9967
authored
Sep 17, 2019
by
Piotr Caban
Committed by
Alexandre Julliard
Sep 17, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winebus.sys: Stop deviceloop_thread to avoid crash on driver unload.
Signed-off-by:
Piotr Caban
<
piotr@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
6ecf912a
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
32 additions
and
7 deletions
+32
-7
bus_udev.c
dlls/winebus.sys/bus_udev.c
+32
-7
No files found.
dlls/winebus.sys/bus_udev.c
View file @
90fa9967
...
@@ -92,6 +92,8 @@ WINE_DECLARE_DEBUG_CHANNEL(hid_report);
...
@@ -92,6 +92,8 @@ WINE_DECLARE_DEBUG_CHANNEL(hid_report);
static
struct
udev
*
udev_context
=
NULL
;
static
struct
udev
*
udev_context
=
NULL
;
static
DWORD
disable_hidraw
=
0
;
static
DWORD
disable_hidraw
=
0
;
static
DWORD
disable_input
=
0
;
static
DWORD
disable_input
=
0
;
static
HANDLE
deviceloop_handle
;
static
int
deviceloop_control
[
2
];
static
const
WCHAR
hidraw_busidW
[]
=
{
'H'
,
'I'
,
'D'
,
'R'
,
'A'
,
'W'
,
0
};
static
const
WCHAR
hidraw_busidW
[]
=
{
'H'
,
'I'
,
'D'
,
'R'
,
'A'
,
'W'
,
0
};
static
const
WCHAR
lnxev_busidW
[]
=
{
'L'
,
'N'
,
'X'
,
'E'
,
'V'
,
0
};
static
const
WCHAR
lnxev_busidW
[]
=
{
'L'
,
'N'
,
'X'
,
'E'
,
'V'
,
0
};
...
@@ -1453,15 +1455,20 @@ static DWORD CALLBACK deviceloop_thread(void *args)
...
@@ -1453,15 +1455,20 @@ static DWORD CALLBACK deviceloop_thread(void *args)
{
{
struct
udev_monitor
*
monitor
;
struct
udev_monitor
*
monitor
;
HANDLE
init_done
=
args
;
HANDLE
init_done
=
args
;
struct
pollfd
pfd
;
struct
pollfd
pfd
[
2
]
;
monitor
=
create_monitor
(
&
pfd
);
pfd
[
1
].
fd
=
deviceloop_control
[
0
];
pfd
[
1
].
events
=
POLLIN
;
pfd
[
1
].
revents
=
0
;
monitor
=
create_monitor
(
&
pfd
[
0
]);
build_initial_deviceset
();
build_initial_deviceset
();
SetEvent
(
init_done
);
SetEvent
(
init_done
);
while
(
monitor
)
while
(
monitor
)
{
{
if
(
poll
(
&
pfd
,
1
,
-
1
)
<=
0
)
continue
;
if
(
poll
(
pfd
,
2
,
-
1
)
<=
0
)
continue
;
if
(
pfd
[
1
].
revents
)
break
;
process_monitor_event
(
monitor
);
process_monitor_event
(
monitor
);
}
}
...
@@ -1474,6 +1481,12 @@ static DWORD CALLBACK deviceloop_thread(void *args)
...
@@ -1474,6 +1481,12 @@ static DWORD CALLBACK deviceloop_thread(void *args)
void
udev_driver_unload
(
void
)
void
udev_driver_unload
(
void
)
{
{
TRACE
(
"Unload Driver
\n
"
);
TRACE
(
"Unload Driver
\n
"
);
write
(
deviceloop_control
[
1
],
"q"
,
1
);
WaitForSingleObject
(
deviceloop_handle
,
INFINITE
);
close
(
deviceloop_control
[
0
]);
close
(
deviceloop_control
[
1
]);
CloseHandle
(
deviceloop_handle
);
}
}
NTSTATUS
udev_driver_init
(
void
)
NTSTATUS
udev_driver_init
(
void
)
...
@@ -1485,10 +1498,16 @@ NTSTATUS udev_driver_init(void)
...
@@ -1485,10 +1498,16 @@ NTSTATUS udev_driver_init(void)
static
const
WCHAR
input_disabledW
[]
=
{
'D'
,
'i'
,
's'
,
'a'
,
'b'
,
'l'
,
'e'
,
'I'
,
'n'
,
'p'
,
'u'
,
't'
,
0
};
static
const
WCHAR
input_disabledW
[]
=
{
'D'
,
'i'
,
's'
,
'a'
,
'b'
,
'l'
,
'e'
,
'I'
,
'n'
,
'p'
,
'u'
,
't'
,
0
};
static
const
UNICODE_STRING
input_disabled
=
{
sizeof
(
input_disabledW
)
-
sizeof
(
WCHAR
),
sizeof
(
input_disabledW
),
(
WCHAR
*
)
input_disabledW
};
static
const
UNICODE_STRING
input_disabled
=
{
sizeof
(
input_disabledW
)
-
sizeof
(
WCHAR
),
sizeof
(
input_disabledW
),
(
WCHAR
*
)
input_disabledW
};
if
(
pipe
(
deviceloop_control
)
!=
0
)
{
ERR
(
"Control pipe creation failed
\n
"
);
return
STATUS_UNSUCCESSFUL
;
}
if
(
!
(
udev_context
=
udev_new
()))
if
(
!
(
udev_context
=
udev_new
()))
{
{
ERR
(
"Can't create udev object
\n
"
);
ERR
(
"Can't create udev object
\n
"
);
return
STATUS_UNSUCCESSFUL
;
goto
error
;
}
}
disable_hidraw
=
check_bus_option
(
&
hidraw_disabled
,
0
);
disable_hidraw
=
check_bus_option
(
&
hidraw_disabled
,
0
);
...
@@ -1511,17 +1530,23 @@ NTSTATUS udev_driver_init(void)
...
@@ -1511,17 +1530,23 @@ NTSTATUS udev_driver_init(void)
result
=
WaitForMultipleObjects
(
2
,
events
,
FALSE
,
INFINITE
);
result
=
WaitForMultipleObjects
(
2
,
events
,
FALSE
,
INFINITE
);
CloseHandle
(
events
[
0
]);
CloseHandle
(
events
[
0
]);
CloseHandle
(
events
[
1
]);
if
(
result
==
WAIT_OBJECT_0
)
if
(
result
==
WAIT_OBJECT_0
)
{
{
deviceloop_handle
=
events
[
1
];
TRACE
(
"Initialization successful
\n
"
);
TRACE
(
"Initialization successful
\n
"
);
return
STATUS_SUCCESS
;
return
STATUS_SUCCESS
;
}
}
CloseHandle
(
events
[
1
]);
error:
error:
ERR
(
"Failed to initialize udev device thread
\n
"
);
ERR
(
"Failed to initialize udev device thread
\n
"
);
udev_unref
(
udev_context
);
close
(
deviceloop_control
[
0
]);
udev_context
=
NULL
;
close
(
deviceloop_control
[
1
]);
if
(
udev_context
)
{
udev_unref
(
udev_context
);
udev_context
=
NULL
;
}
return
STATUS_UNSUCCESSFUL
;
return
STATUS_UNSUCCESSFUL
;
}
}
...
...
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