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
45958834
Commit
45958834
authored
Jun 07, 2021
by
Rémi Bernon
Committed by
Alexandre Julliard
Jun 07, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
hid: Use caps.BitSize to differenciate buttons from values.
Signed-off-by:
Rémi Bernon
<
rbernon@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
c3d8a980
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
18 additions
and
27 deletions
+18
-27
hidp.c
dlls/hid/hidp.c
+18
-18
descriptor.c
dlls/hidclass.sys/descriptor.c
+0
-2
hid.h
include/wine/hid.h
+0
-7
No files found.
dlls/hid/hidp.c
View file @
45958834
...
@@ -203,7 +203,7 @@ NTSTATUS WINAPI HidP_GetButtonCaps(HIDP_REPORT_TYPE ReportType, PHIDP_BUTTON_CAP
...
@@ -203,7 +203,7 @@ NTSTATUS WINAPI HidP_GetButtonCaps(HIDP_REPORT_TYPE ReportType, PHIDP_BUTTON_CAP
{
{
for
(
i
=
0
;
i
<
report
[
j
].
elementCount
&&
u
<
b_count
;
i
++
)
for
(
i
=
0
;
i
<
report
[
j
].
elementCount
&&
u
<
b_count
;
i
++
)
{
{
if
(
elems
[
report
[
j
].
elementIdx
+
i
].
ElementType
==
ButtonElement
)
if
(
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
BitSize
==
1
)
ButtonCaps
[
u
++
]
=
*
(
HIDP_BUTTON_CAPS
*
)
&
elems
[
report
[
j
].
elementIdx
+
i
].
caps
;
ButtonCaps
[
u
++
]
=
*
(
HIDP_BUTTON_CAPS
*
)
&
elems
[
report
[
j
].
elementIdx
+
i
].
caps
;
}
}
}
}
...
@@ -230,7 +230,7 @@ NTSTATUS WINAPI HidP_GetCaps(PHIDP_PREPARSED_DATA PreparsedData,
...
@@ -230,7 +230,7 @@ NTSTATUS WINAPI HidP_GetCaps(PHIDP_PREPARSED_DATA PreparsedData,
static
NTSTATUS
find_usage
(
HIDP_REPORT_TYPE
ReportType
,
USAGE
UsagePage
,
USHORT
LinkCollection
,
static
NTSTATUS
find_usage
(
HIDP_REPORT_TYPE
ReportType
,
USAGE
UsagePage
,
USHORT
LinkCollection
,
USAGE
Usage
,
PHIDP_PREPARSED_DATA
PreparsedData
,
PCHAR
Report
,
USAGE
Usage
,
PHIDP_PREPARSED_DATA
PreparsedData
,
PCHAR
Report
,
WINE_ELEMENT_TYPE
ElementTyp
e
,
WINE_HID_ELEMENT
*
element
)
USHORT
bit_siz
e
,
WINE_HID_ELEMENT
*
element
)
{
{
PWINE_HIDP_PREPARSED_DATA
data
=
(
PWINE_HIDP_PREPARSED_DATA
)
PreparsedData
;
PWINE_HIDP_PREPARSED_DATA
data
=
(
PWINE_HIDP_PREPARSED_DATA
)
PreparsedData
;
WINE_HID_ELEMENT
*
elems
=
HID_ELEMS
(
data
);
WINE_HID_ELEMENT
*
elems
=
HID_ELEMS
(
data
);
...
@@ -270,7 +270,7 @@ static NTSTATUS find_usage(HIDP_REPORT_TYPE ReportType, USAGE UsagePage, USHORT
...
@@ -270,7 +270,7 @@ static NTSTATUS find_usage(HIDP_REPORT_TYPE ReportType, USAGE UsagePage, USHORT
{
{
HIDP_VALUE_CAPS
*
value
=
&
elems
[
report
->
elementIdx
+
i
].
caps
;
HIDP_VALUE_CAPS
*
value
=
&
elems
[
report
->
elementIdx
+
i
].
caps
;
if
(
elems
[
report
->
elementIdx
+
i
].
ElementType
!=
ElementType
||
if
(
(
elems
[
report
->
elementIdx
+
i
].
caps
.
BitSize
==
1
)
!=
(
bit_size
==
1
)
||
value
->
UsagePage
!=
UsagePage
)
value
->
UsagePage
!=
UsagePage
)
continue
;
continue
;
...
@@ -278,13 +278,13 @@ static NTSTATUS find_usage(HIDP_REPORT_TYPE ReportType, USAGE UsagePage, USHORT
...
@@ -278,13 +278,13 @@ static NTSTATUS find_usage(HIDP_REPORT_TYPE ReportType, USAGE UsagePage, USHORT
{
{
*
element
=
elems
[
report
->
elementIdx
+
i
];
*
element
=
elems
[
report
->
elementIdx
+
i
];
element
->
valueStartBit
+=
value
->
BitSize
*
(
Usage
-
value
->
Range
.
UsageMin
);
element
->
valueStartBit
+=
value
->
BitSize
*
(
Usage
-
value
->
Range
.
UsageMin
);
element
->
bitCount
=
elems
[
report
->
elementIdx
+
i
].
ElementType
==
ValueElement
?
value
->
BitSize
:
1
;
element
->
bitCount
=
elems
[
report
->
elementIdx
+
i
].
caps
.
BitSize
;
return
HIDP_STATUS_SUCCESS
;
return
HIDP_STATUS_SUCCESS
;
}
}
else
if
(
value
->
NotRange
.
Usage
==
Usage
)
else
if
(
value
->
NotRange
.
Usage
==
Usage
)
{
{
*
element
=
elems
[
report
->
elementIdx
+
i
];
*
element
=
elems
[
report
->
elementIdx
+
i
];
element
->
bitCount
=
elems
[
report
->
elementIdx
+
i
].
ElementType
==
ValueElement
?
value
->
BitSize
:
1
;
element
->
bitCount
=
elems
[
report
->
elementIdx
+
i
].
caps
.
BitSize
;
return
HIDP_STATUS_SUCCESS
;
return
HIDP_STATUS_SUCCESS
;
}
}
}
}
...
@@ -297,7 +297,7 @@ static LONG sign_extend(ULONG value, const WINE_HID_ELEMENT *element)
...
@@ -297,7 +297,7 @@ static LONG sign_extend(ULONG value, const WINE_HID_ELEMENT *element)
UINT
bit_count
=
element
->
bitCount
;
UINT
bit_count
=
element
->
bitCount
;
if
((
value
&
(
1
<<
(
bit_count
-
1
)))
if
((
value
&
(
1
<<
(
bit_count
-
1
)))
&&
element
->
ElementType
==
ValueElement
&&
element
->
caps
.
BitSize
!=
1
&&
element
->
caps
.
LogicalMin
<
0
)
&&
element
->
caps
.
LogicalMin
<
0
)
{
{
value
-=
(
1
<<
bit_count
);
value
-=
(
1
<<
bit_count
);
...
@@ -326,7 +326,7 @@ NTSTATUS WINAPI HidP_GetScaledUsageValue(HIDP_REPORT_TYPE ReportType, USAGE Usag
...
@@ -326,7 +326,7 @@ NTSTATUS WINAPI HidP_GetScaledUsageValue(HIDP_REPORT_TYPE ReportType, USAGE Usag
TRACE
(
"(%i, %x, %i, %i, %p, %p, %p, %i)
\n
"
,
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
UsageValue
,
TRACE
(
"(%i, %x, %i, %i, %p, %p, %p, %i)
\n
"
,
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
UsageValue
,
PreparsedData
,
Report
,
ReportLength
);
PreparsedData
,
Report
,
ReportLength
);
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
PreparsedData
,
Report
,
ValueElement
,
&
element
);
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
PreparsedData
,
Report
,
0
,
&
element
);
if
(
rc
==
HIDP_STATUS_SUCCESS
)
if
(
rc
==
HIDP_STATUS_SUCCESS
)
{
{
...
@@ -352,7 +352,7 @@ NTSTATUS WINAPI HidP_GetUsageValue(HIDP_REPORT_TYPE ReportType, USAGE UsagePage,
...
@@ -352,7 +352,7 @@ NTSTATUS WINAPI HidP_GetUsageValue(HIDP_REPORT_TYPE ReportType, USAGE UsagePage,
TRACE
(
"(%i, %x, %i, %i, %p, %p, %p, %i)
\n
"
,
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
UsageValue
,
TRACE
(
"(%i, %x, %i, %i, %p, %p, %p, %i)
\n
"
,
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
UsageValue
,
PreparsedData
,
Report
,
ReportLength
);
PreparsedData
,
Report
,
ReportLength
);
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
PreparsedData
,
Report
,
ValueElement
,
&
element
);
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
PreparsedData
,
Report
,
0
,
&
element
);
if
(
rc
==
HIDP_STATUS_SUCCESS
)
if
(
rc
==
HIDP_STATUS_SUCCESS
)
{
{
...
@@ -374,7 +374,7 @@ NTSTATUS WINAPI HidP_GetUsageValueArray(HIDP_REPORT_TYPE ReportType, USAGE Usage
...
@@ -374,7 +374,7 @@ NTSTATUS WINAPI HidP_GetUsageValueArray(HIDP_REPORT_TYPE ReportType, USAGE Usage
TRACE
(
"(%i, %x, %i, %i, %p, %u, %p, %p, %i)
\n
"
,
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
UsageValue
,
TRACE
(
"(%i, %x, %i, %i, %p, %u, %p, %p, %i)
\n
"
,
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
UsageValue
,
UsageValueByteLength
,
PreparsedData
,
Report
,
ReportLength
);
UsageValueByteLength
,
PreparsedData
,
Report
,
ReportLength
);
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
PreparsedData
,
Report
,
ValueElement
,
&
element
);
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
PreparsedData
,
Report
,
0
,
&
element
);
if
(
rc
==
HIDP_STATUS_SUCCESS
)
if
(
rc
==
HIDP_STATUS_SUCCESS
)
{
{
...
@@ -435,7 +435,7 @@ NTSTATUS WINAPI HidP_GetUsages(HIDP_REPORT_TYPE ReportType, USAGE UsagePage, USH
...
@@ -435,7 +435,7 @@ NTSTATUS WINAPI HidP_GetUsages(HIDP_REPORT_TYPE ReportType, USAGE UsagePage, USH
uCount
=
0
;
uCount
=
0
;
for
(
i
=
0
;
i
<
report
->
elementCount
&&
uCount
<
*
UsageLength
;
i
++
)
for
(
i
=
0
;
i
<
report
->
elementCount
&&
uCount
<
*
UsageLength
;
i
++
)
{
{
if
(
elems
[
report
->
elementIdx
+
i
].
ElementType
==
ButtonElement
&&
if
(
elems
[
report
->
elementIdx
+
i
].
caps
.
BitSize
==
1
&&
elems
[
report
->
elementIdx
+
i
].
caps
.
UsagePage
==
UsagePage
)
elems
[
report
->
elementIdx
+
i
].
caps
.
UsagePage
==
UsagePage
)
{
{
int
k
;
int
k
;
...
@@ -514,7 +514,7 @@ NTSTATUS WINAPI HidP_GetValueCaps(HIDP_REPORT_TYPE ReportType, PHIDP_VALUE_CAPS
...
@@ -514,7 +514,7 @@ NTSTATUS WINAPI HidP_GetValueCaps(HIDP_REPORT_TYPE ReportType, PHIDP_VALUE_CAPS
{
{
for
(
i
=
0
;
i
<
report
[
j
].
elementCount
&&
u
<
v_count
;
i
++
)
for
(
i
=
0
;
i
<
report
[
j
].
elementCount
&&
u
<
v_count
;
i
++
)
{
{
if
(
elems
[
report
[
j
].
elementIdx
+
i
].
ElementType
==
ValueElement
)
if
(
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
BitSize
!=
1
)
ValueCaps
[
u
++
]
=
elems
[
report
[
j
].
elementIdx
+
i
].
caps
;
ValueCaps
[
u
++
]
=
elems
[
report
[
j
].
elementIdx
+
i
].
caps
;
}
}
}
}
...
@@ -607,7 +607,7 @@ ULONG WINAPI HidP_MaxUsageListLength(HIDP_REPORT_TYPE ReportType, USAGE UsagePag
...
@@ -607,7 +607,7 @@ ULONG WINAPI HidP_MaxUsageListLength(HIDP_REPORT_TYPE ReportType, USAGE UsagePag
int
j
;
int
j
;
for
(
j
=
0
;
j
<
report
[
i
].
elementCount
;
j
++
)
for
(
j
=
0
;
j
<
report
[
i
].
elementCount
;
j
++
)
{
{
if
(
elems
[
report
[
i
].
elementIdx
+
j
].
ElementType
==
ButtonElement
&&
if
(
elems
[
report
[
i
].
elementIdx
+
j
].
caps
.
BitSize
==
1
&&
(
UsagePage
==
0
||
elems
[
report
[
i
].
elementIdx
+
j
].
caps
.
UsagePage
==
UsagePage
))
(
UsagePage
==
0
||
elems
[
report
[
i
].
elementIdx
+
j
].
caps
.
UsagePage
==
UsagePage
))
{
{
if
(
elems
[
report
[
i
].
elementIdx
+
j
].
caps
.
IsRange
)
if
(
elems
[
report
[
i
].
elementIdx
+
j
].
caps
.
IsRange
)
...
@@ -631,7 +631,7 @@ NTSTATUS WINAPI HidP_SetUsageValue(HIDP_REPORT_TYPE ReportType, USAGE UsagePage,
...
@@ -631,7 +631,7 @@ NTSTATUS WINAPI HidP_SetUsageValue(HIDP_REPORT_TYPE ReportType, USAGE UsagePage,
TRACE
(
"(%i, %x, %i, %i, %i, %p, %p, %i)
\n
"
,
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
UsageValue
,
TRACE
(
"(%i, %x, %i, %i, %i, %p, %p, %i)
\n
"
,
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
UsageValue
,
PreparsedData
,
Report
,
ReportLength
);
PreparsedData
,
Report
,
ReportLength
);
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
PreparsedData
,
Report
,
ValueElement
,
&
element
);
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
Usage
,
PreparsedData
,
Report
,
0
,
&
element
);
if
(
rc
==
HIDP_STATUS_SUCCESS
)
if
(
rc
==
HIDP_STATUS_SUCCESS
)
{
{
...
@@ -657,7 +657,7 @@ NTSTATUS WINAPI HidP_SetUsages(HIDP_REPORT_TYPE ReportType, USAGE UsagePage, USH
...
@@ -657,7 +657,7 @@ NTSTATUS WINAPI HidP_SetUsages(HIDP_REPORT_TYPE ReportType, USAGE UsagePage, USH
for
(
i
=
0
;
i
<
*
UsageLength
;
i
++
)
for
(
i
=
0
;
i
<
*
UsageLength
;
i
++
)
{
{
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
rc
=
find_usage
(
ReportType
,
UsagePage
,
LinkCollection
,
UsageList
[
i
],
PreparsedData
,
Report
,
ButtonElement
,
&
element
);
UsageList
[
i
],
PreparsedData
,
Report
,
1
,
&
element
);
if
(
rc
==
HIDP_STATUS_SUCCESS
)
if
(
rc
==
HIDP_STATUS_SUCCESS
)
{
{
rc
=
set_report_data
((
BYTE
*
)
Report
,
ReportLength
,
rc
=
set_report_data
((
BYTE
*
)
Report
,
ReportLength
,
...
@@ -734,7 +734,7 @@ NTSTATUS WINAPI HidP_GetSpecificButtonCaps(HIDP_REPORT_TYPE ReportType,
...
@@ -734,7 +734,7 @@ NTSTATUS WINAPI HidP_GetSpecificButtonCaps(HIDP_REPORT_TYPE ReportType,
{
{
for
(
i
=
0
;
i
<
report
[
j
].
elementCount
&&
u
<
b_count
;
i
++
)
for
(
i
=
0
;
i
<
report
[
j
].
elementCount
&&
u
<
b_count
;
i
++
)
{
{
if
(
elems
[
report
[
j
].
elementIdx
+
i
].
ElementType
==
ButtonElement
&&
if
(
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
BitSize
==
1
&&
(
UsagePage
==
0
||
UsagePage
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
UsagePage
)
&&
(
UsagePage
==
0
||
UsagePage
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
UsagePage
)
&&
(
LinkCollection
==
0
||
LinkCollection
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
LinkCollection
)
&&
(
LinkCollection
==
0
||
LinkCollection
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
LinkCollection
)
&&
(
Usage
==
0
||
(
(
Usage
==
0
||
(
...
@@ -804,7 +804,7 @@ NTSTATUS WINAPI HidP_GetSpecificValueCaps(HIDP_REPORT_TYPE ReportType,
...
@@ -804,7 +804,7 @@ NTSTATUS WINAPI HidP_GetSpecificValueCaps(HIDP_REPORT_TYPE ReportType,
{
{
for
(
i
=
0
;
i
<
report
[
j
].
elementCount
&&
u
<
v_count
;
i
++
)
for
(
i
=
0
;
i
<
report
[
j
].
elementCount
&&
u
<
v_count
;
i
++
)
{
{
if
(
elems
[
report
[
j
].
elementIdx
+
i
].
ElementType
==
ValueElement
&&
if
(
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
BitSize
!=
1
&&
(
UsagePage
==
0
||
UsagePage
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
UsagePage
)
&&
(
UsagePage
==
0
||
UsagePage
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
UsagePage
)
&&
(
LinkCollection
==
0
||
LinkCollection
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
LinkCollection
)
&&
(
LinkCollection
==
0
||
LinkCollection
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
LinkCollection
)
&&
(
Usage
==
0
||
Usage
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
NotRange
.
Usage
))
(
Usage
==
0
||
Usage
==
elems
[
report
[
j
].
elementIdx
+
i
].
caps
.
NotRange
.
Usage
))
...
@@ -861,7 +861,7 @@ NTSTATUS WINAPI HidP_GetUsagesEx(HIDP_REPORT_TYPE ReportType, USHORT LinkCollect
...
@@ -861,7 +861,7 @@ NTSTATUS WINAPI HidP_GetUsagesEx(HIDP_REPORT_TYPE ReportType, USHORT LinkCollect
for
(
i
=
0
;
i
<
report
->
elementCount
;
i
++
)
for
(
i
=
0
;
i
<
report
->
elementCount
;
i
++
)
{
{
if
(
elems
[
report
->
elementIdx
+
i
].
ElementType
==
ButtonElement
)
if
(
elems
[
report
->
elementIdx
+
i
].
caps
.
BitSize
==
1
)
{
{
int
k
;
int
k
;
WINE_HID_ELEMENT
*
element
=
&
elems
[
report
->
elementIdx
+
i
];
WINE_HID_ELEMENT
*
element
=
&
elems
[
report
->
elementIdx
+
i
];
...
@@ -945,7 +945,7 @@ NTSTATUS WINAPI HidP_GetData(HIDP_REPORT_TYPE ReportType, HIDP_DATA *DataList, U
...
@@ -945,7 +945,7 @@ NTSTATUS WINAPI HidP_GetData(HIDP_REPORT_TYPE ReportType, HIDP_DATA *DataList, U
for
(
i
=
0
;
i
<
report
->
elementCount
;
i
++
)
for
(
i
=
0
;
i
<
report
->
elementCount
;
i
++
)
{
{
WINE_HID_ELEMENT
*
element
=
&
elems
[
report
->
elementIdx
+
i
];
WINE_HID_ELEMENT
*
element
=
&
elems
[
report
->
elementIdx
+
i
];
if
(
element
->
ElementType
==
ButtonElement
)
if
(
element
->
caps
.
BitSize
==
1
)
{
{
int
k
;
int
k
;
for
(
k
=
0
;
k
<
element
->
bitCount
;
k
++
)
for
(
k
=
0
;
k
<
element
->
bitCount
;
k
++
)
...
...
dlls/hidclass.sys/descriptor.c
View file @
45958834
...
@@ -617,8 +617,6 @@ static void build_elements(WINE_HID_REPORT *wine_report, WINE_HID_ELEMENT *elems
...
@@ -617,8 +617,6 @@ static void build_elements(WINE_HID_REPORT *wine_report, WINE_HID_ELEMENT *elems
*
data_index
=
*
data_index
+
1
;
*
data_index
=
*
data_index
+
1
;
}
}
if
(
feature
->
caps
.
BitSize
==
1
)
wine_element
->
ElementType
=
ButtonElement
;
else
wine_element
->
ElementType
=
ValueElement
;
wine_report
->
elementCount
++
;
wine_report
->
elementCount
++
;
}
}
...
...
include/wine/hid.h
View file @
45958834
...
@@ -31,15 +31,8 @@
...
@@ -31,15 +31,8 @@
#define HID_MAGIC 0x8491759
#define HID_MAGIC 0x8491759
typedef
enum
__WINE_ELEMENT_TYPE
{
UnknownElement
=
0
,
ButtonElement
,
ValueElement
,
}
WINE_ELEMENT_TYPE
;
typedef
struct
__WINE_ELEMENT
typedef
struct
__WINE_ELEMENT
{
{
WINE_ELEMENT_TYPE
ElementType
;
UINT
valueStartBit
;
UINT
valueStartBit
;
UINT
bitCount
;
UINT
bitCount
;
HIDP_VALUE_CAPS
caps
;
HIDP_VALUE_CAPS
caps
;
...
...
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