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
68c6c7d9
Commit
68c6c7d9
authored
Aug 18, 2021
by
Rémi Bernon
Committed by
Alexandre Julliard
Aug 18, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winebus.sys: Introduce a new start_device callback.
Signed-off-by:
Rémi Bernon
<
rbernon@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
cfddd2c1
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
53 additions
and
5 deletions
+53
-5
bus.h
dlls/winebus.sys/bus.h
+1
-0
bus_iohid.c
dlls/winebus.sys/bus_iohid.c
+6
-0
bus_sdl.c
dlls/winebus.sys/bus_sdl.c
+6
-0
bus_udev.c
dlls/winebus.sys/bus_udev.c
+12
-0
main.c
dlls/winebus.sys/main.c
+28
-5
No files found.
dlls/winebus.sys/bus.h
View file @
68c6c7d9
...
@@ -39,6 +39,7 @@ typedef struct
...
@@ -39,6 +39,7 @@ typedef struct
{
{
void
(
*
free_device
)(
DEVICE_OBJECT
*
device
);
void
(
*
free_device
)(
DEVICE_OBJECT
*
device
);
int
(
*
compare_platform_device
)(
DEVICE_OBJECT
*
device
,
void
*
platform_dev
);
int
(
*
compare_platform_device
)(
DEVICE_OBJECT
*
device
,
void
*
platform_dev
);
NTSTATUS
(
*
start_device
)(
DEVICE_OBJECT
*
device
);
NTSTATUS
(
*
get_reportdescriptor
)(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
);
NTSTATUS
(
*
get_reportdescriptor
)(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
);
NTSTATUS
(
*
get_string
)(
DEVICE_OBJECT
*
device
,
DWORD
index
,
WCHAR
*
buffer
,
DWORD
length
);
NTSTATUS
(
*
get_string
)(
DEVICE_OBJECT
*
device
,
DWORD
index
,
WCHAR
*
buffer
,
DWORD
length
);
NTSTATUS
(
*
begin_report_processing
)(
DEVICE_OBJECT
*
device
);
NTSTATUS
(
*
begin_report_processing
)(
DEVICE_OBJECT
*
device
);
...
...
dlls/winebus.sys/bus_iohid.c
View file @
68c6c7d9
...
@@ -148,6 +148,11 @@ static int compare_platform_device(DEVICE_OBJECT *device, void *platform_dev)
...
@@ -148,6 +148,11 @@ static int compare_platform_device(DEVICE_OBJECT *device, void *platform_dev)
return
0
;
return
0
;
}
}
static
NTSTATUS
start_device
(
DEVICE_OBJECT
*
device
)
{
return
STATUS_SUCCESS
;
}
static
NTSTATUS
get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
)
static
NTSTATUS
get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
)
{
{
struct
platform_private
*
private
=
impl_from_DEVICE_OBJECT
(
device
);
struct
platform_private
*
private
=
impl_from_DEVICE_OBJECT
(
device
);
...
@@ -274,6 +279,7 @@ static const platform_vtbl iohid_vtbl =
...
@@ -274,6 +279,7 @@ static const platform_vtbl iohid_vtbl =
{
{
free_device
,
free_device
,
compare_platform_device
,
compare_platform_device
,
start_device
,
get_reportdescriptor
,
get_reportdescriptor
,
get_string
,
get_string
,
begin_report_processing
,
begin_report_processing
,
...
...
dlls/winebus.sys/bus_sdl.c
View file @
68c6c7d9
...
@@ -487,6 +487,11 @@ static int compare_platform_device(DEVICE_OBJECT *device, void *context)
...
@@ -487,6 +487,11 @@ static int compare_platform_device(DEVICE_OBJECT *device, void *context)
return
impl_from_DEVICE_OBJECT
(
device
)
->
id
-
PtrToUlong
(
context
);
return
impl_from_DEVICE_OBJECT
(
device
)
->
id
-
PtrToUlong
(
context
);
}
}
static
NTSTATUS
start_device
(
DEVICE_OBJECT
*
device
)
{
return
STATUS_SUCCESS
;
}
static
NTSTATUS
get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
)
static
NTSTATUS
get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
)
{
{
struct
platform_private
*
ext
=
impl_from_DEVICE_OBJECT
(
device
);
struct
platform_private
*
ext
=
impl_from_DEVICE_OBJECT
(
device
);
...
@@ -596,6 +601,7 @@ static const platform_vtbl sdl_vtbl =
...
@@ -596,6 +601,7 @@ static const platform_vtbl sdl_vtbl =
{
{
free_device
,
free_device
,
compare_platform_device
,
compare_platform_device
,
start_device
,
get_reportdescriptor
,
get_reportdescriptor
,
get_string
,
get_string
,
begin_report_processing
,
begin_report_processing
,
...
...
dlls/winebus.sys/bus_udev.c
View file @
68c6c7d9
...
@@ -558,6 +558,11 @@ static int compare_platform_device(DEVICE_OBJECT *device, void *platform_dev)
...
@@ -558,6 +558,11 @@ static int compare_platform_device(DEVICE_OBJECT *device, void *platform_dev)
return
strcmp
(
udev_device_get_syspath
(
dev1
),
udev_device_get_syspath
(
dev2
));
return
strcmp
(
udev_device_get_syspath
(
dev1
),
udev_device_get_syspath
(
dev2
));
}
}
static
NTSTATUS
hidraw_start_device
(
DEVICE_OBJECT
*
device
)
{
return
STATUS_SUCCESS
;
}
static
NTSTATUS
hidraw_get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
)
static
NTSTATUS
hidraw_get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
)
{
{
#ifdef HAVE_LINUX_HIDRAW_H
#ifdef HAVE_LINUX_HIDRAW_H
...
@@ -818,6 +823,7 @@ static const platform_vtbl hidraw_vtbl =
...
@@ -818,6 +823,7 @@ static const platform_vtbl hidraw_vtbl =
{
{
hidraw_free_device
,
hidraw_free_device
,
compare_platform_device
,
compare_platform_device
,
hidraw_start_device
,
hidraw_get_reportdescriptor
,
hidraw_get_reportdescriptor
,
hidraw_get_string
,
hidraw_get_string
,
begin_report_processing
,
begin_report_processing
,
...
@@ -854,6 +860,11 @@ static void lnxev_free_device(DEVICE_OBJECT *device)
...
@@ -854,6 +860,11 @@ static void lnxev_free_device(DEVICE_OBJECT *device)
udev_device_unref
(
ext
->
base
.
udev_device
);
udev_device_unref
(
ext
->
base
.
udev_device
);
}
}
static
NTSTATUS
lnxev_start_device
(
DEVICE_OBJECT
*
device
)
{
return
STATUS_SUCCESS
;
}
static
NTSTATUS
lnxev_get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
)
static
NTSTATUS
lnxev_get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
out_length
)
{
{
struct
wine_input_private
*
ext
=
input_impl_from_DEVICE_OBJECT
(
device
);
struct
wine_input_private
*
ext
=
input_impl_from_DEVICE_OBJECT
(
device
);
...
@@ -967,6 +978,7 @@ static NTSTATUS lnxev_set_feature_report(DEVICE_OBJECT *device, UCHAR id, BYTE *
...
@@ -967,6 +978,7 @@ static NTSTATUS lnxev_set_feature_report(DEVICE_OBJECT *device, UCHAR id, BYTE *
static
const
platform_vtbl
lnxev_vtbl
=
{
static
const
platform_vtbl
lnxev_vtbl
=
{
lnxev_free_device
,
lnxev_free_device
,
compare_platform_device
,
compare_platform_device
,
lnxev_start_device
,
lnxev_get_reportdescriptor
,
lnxev_get_reportdescriptor
,
lnxev_get_string
,
lnxev_get_string
,
lnxev_begin_report_processing
,
lnxev_begin_report_processing
,
...
...
dlls/winebus.sys/main.c
View file @
68c6c7d9
...
@@ -109,11 +109,17 @@ struct pnp_device
...
@@ -109,11 +109,17 @@ struct pnp_device
DEVICE_OBJECT
*
device
;
DEVICE_OBJECT
*
device
;
};
};
enum
device_state
{
DEVICE_STATE_STOPPED
,
DEVICE_STATE_STARTED
,
DEVICE_STATE_REMOVED
,
};
struct
device_extension
struct
device_extension
{
{
CRITICAL_SECTION
cs
;
CRITICAL_SECTION
cs
;
enum
device_state
state
;
BOOL
removed
;
struct
pnp_device
*
pnp_device
;
struct
pnp_device
*
pnp_device
;
...
@@ -480,6 +486,11 @@ static void mouse_free_device(DEVICE_OBJECT *device)
...
@@ -480,6 +486,11 @@ static void mouse_free_device(DEVICE_OBJECT *device)
{
{
}
}
static
NTSTATUS
mouse_start_device
(
DEVICE_OBJECT
*
device
)
{
return
STATUS_SUCCESS
;
}
static
NTSTATUS
mouse_get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
ret_length
)
static
NTSTATUS
mouse_get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
ret_length
)
{
{
TRACE
(
"buffer %p, length %u.
\n
"
,
buffer
,
length
);
TRACE
(
"buffer %p, length %u.
\n
"
,
buffer
,
length
);
...
@@ -528,6 +539,7 @@ static NTSTATUS mouse_set_feature_report(DEVICE_OBJECT *device, UCHAR id, BYTE *
...
@@ -528,6 +539,7 @@ static NTSTATUS mouse_set_feature_report(DEVICE_OBJECT *device, UCHAR id, BYTE *
static
const
platform_vtbl
mouse_vtbl
=
static
const
platform_vtbl
mouse_vtbl
=
{
{
.
free_device
=
mouse_free_device
,
.
free_device
=
mouse_free_device
,
.
start_device
=
mouse_start_device
,
.
get_reportdescriptor
=
mouse_get_reportdescriptor
,
.
get_reportdescriptor
=
mouse_get_reportdescriptor
,
.
get_string
=
mouse_get_string
,
.
get_string
=
mouse_get_string
,
.
begin_report_processing
=
mouse_begin_report_processing
,
.
begin_report_processing
=
mouse_begin_report_processing
,
...
@@ -555,6 +567,11 @@ static void keyboard_free_device(DEVICE_OBJECT *device)
...
@@ -555,6 +567,11 @@ static void keyboard_free_device(DEVICE_OBJECT *device)
{
{
}
}
static
NTSTATUS
keyboard_start_device
(
DEVICE_OBJECT
*
device
)
{
return
STATUS_SUCCESS
;
}
static
NTSTATUS
keyboard_get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
ret_length
)
static
NTSTATUS
keyboard_get_reportdescriptor
(
DEVICE_OBJECT
*
device
,
BYTE
*
buffer
,
DWORD
length
,
DWORD
*
ret_length
)
{
{
TRACE
(
"buffer %p, length %u.
\n
"
,
buffer
,
length
);
TRACE
(
"buffer %p, length %u.
\n
"
,
buffer
,
length
);
...
@@ -603,6 +620,7 @@ static NTSTATUS keyboard_set_feature_report(DEVICE_OBJECT *device, UCHAR id, BYT
...
@@ -603,6 +620,7 @@ static NTSTATUS keyboard_set_feature_report(DEVICE_OBJECT *device, UCHAR id, BYT
static
const
platform_vtbl
keyboard_vtbl
=
static
const
platform_vtbl
keyboard_vtbl
=
{
{
.
free_device
=
keyboard_free_device
,
.
free_device
=
keyboard_free_device
,
.
start_device
=
keyboard_start_device
,
.
get_reportdescriptor
=
keyboard_get_reportdescriptor
,
.
get_reportdescriptor
=
keyboard_get_reportdescriptor
,
.
get_string
=
keyboard_get_string
,
.
get_string
=
keyboard_get_string
,
.
begin_report_processing
=
keyboard_begin_report_processing
,
.
begin_report_processing
=
keyboard_begin_report_processing
,
...
@@ -695,13 +713,18 @@ static NTSTATUS pdo_pnp_dispatch(DEVICE_OBJECT *device, IRP *irp)
...
@@ -695,13 +713,18 @@ static NTSTATUS pdo_pnp_dispatch(DEVICE_OBJECT *device, IRP *irp)
break
;
break
;
case
IRP_MN_START_DEVICE
:
case
IRP_MN_START_DEVICE
:
status
=
STATUS_SUCCESS
;
EnterCriticalSection
(
&
ext
->
cs
);
if
(
ext
->
state
!=
DEVICE_STATE_STOPPED
)
status
=
STATUS_SUCCESS
;
else
if
(
ext
->
state
==
DEVICE_STATE_REMOVED
)
status
=
STATUS_DELETE_PENDING
;
else
if
(
!
(
status
=
ext
->
vtbl
->
start_device
(
device
)))
ext
->
state
=
DEVICE_STATE_STARTED
;
else
ERR
(
"failed to start device %p, status %#x
\n
"
,
device
,
status
);
LeaveCriticalSection
(
&
ext
->
cs
);
break
;
break
;
case
IRP_MN_SURPRISE_REMOVAL
:
case
IRP_MN_SURPRISE_REMOVAL
:
EnterCriticalSection
(
&
ext
->
cs
);
EnterCriticalSection
(
&
ext
->
cs
);
remove_pending_irps
(
device
);
remove_pending_irps
(
device
);
ext
->
removed
=
TRUE
;
ext
->
state
=
DEVICE_STATE_REMOVED
;
LeaveCriticalSection
(
&
ext
->
cs
);
LeaveCriticalSection
(
&
ext
->
cs
);
status
=
STATUS_SUCCESS
;
status
=
STATUS_SUCCESS
;
break
;
break
;
...
@@ -834,7 +857,7 @@ static NTSTATUS WINAPI hid_internal_dispatch(DEVICE_OBJECT *device, IRP *irp)
...
@@ -834,7 +857,7 @@ static NTSTATUS WINAPI hid_internal_dispatch(DEVICE_OBJECT *device, IRP *irp)
EnterCriticalSection
(
&
ext
->
cs
);
EnterCriticalSection
(
&
ext
->
cs
);
if
(
ext
->
removed
)
if
(
ext
->
state
==
DEVICE_STATE_REMOVED
)
{
{
LeaveCriticalSection
(
&
ext
->
cs
);
LeaveCriticalSection
(
&
ext
->
cs
);
irp
->
IoStatus
.
Status
=
STATUS_DELETE_PENDING
;
irp
->
IoStatus
.
Status
=
STATUS_DELETE_PENDING
;
...
...
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