1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
2 | /* |
3 | * HID descriptor stuructures |
4 | * Copyright 2020-2021 Advanced Micro Devices, Inc. |
5 | * Authors: Nehal Bakulchandra Shah <Nehal-bakulchandra.shah@amd.com> |
6 | * Sandeep Singh <Sandeep.singh@amd.com> |
7 | * Basavaraj Natikar <Basavaraj.Natikar@amd.com> |
8 | */ |
9 | |
10 | #ifndef AMD_SFH_HID_REPORT_DESCRIPTOR_H |
11 | #define AMD_SFH_HID_REPORT_DESCRIPTOR_H |
12 | |
13 | // Accelerometer 3D Sensor |
14 | static const u8 accel3_report_descriptor[] = { |
15 | 0x05, 0x20, /* Usage page */ |
16 | 0x09, 0x73, /* Motion type Accel 3D */ |
17 | 0xA1, 0x00, /* HID Collection (Physical) */ |
18 | |
19 | //feature reports(xmit/receive) |
20 | 0x85, 1, /* HID Report ID */ |
21 | 0x05, 0x20, /* HID usage page sensor */ |
22 | 0x0A, 0x09, 0x03, /* Sensor property and sensor connection type */ |
23 | 0x15, 0, /* HID logical MIN_8(0) */ |
24 | 0x25, 2, /* HID logical MAX_8(2) */ |
25 | 0x75, 8, /* HID report size(8) */ |
26 | 0x95, 1, /* HID report count(1) */ |
27 | 0xA1, 0x02, /* HID collection (logical) */ |
28 | 0x0A, 0x30, 0x08, /* Sensor property connection type intergated sel*/ |
29 | 0x0A, 0x31, 0x08, /* Sensor property connection type attached sel */ |
30 | 0x0A, 0x32, 0x08, /* Sensor property connection type external sel */ |
31 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
32 | 0xC0, /* HID end collection */ |
33 | 0x0A, 0x16, 0x03, /* HID usage sensor property reporting state */ |
34 | 0x15, 0, /* HID logical Min_8(0) */ |
35 | 0x25, 5, /* HID logical Max_8(5) */ |
36 | 0x75, 8, /* HID report size(8) */ |
37 | 0x95, 1, /* HID report count(1) */ |
38 | 0xA1, 0x02, /* HID collection(logical) */ |
39 | 0x0A, 0x40, 0x08, /* Sensor property report state no events sel */ |
40 | 0x0A, 0x41, 0x08, /* Sensor property report state all events sel */ |
41 | 0x0A, 0x42, 0x08, /* Sensor property report state threshold events sel */ |
42 | 0x0A, 0x43, 0x08, /* Sensor property report state no events wake sel */ |
43 | 0x0A, 0x44, 0x08, /* Sensor property report state all events wake sel */ |
44 | 0x0A, 0x45, 0x08, /* Sensor property report state threshold events wake sel */ |
45 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
46 | 0xC0, /* HID end collection */ |
47 | 0x0A, 0x19, 0x03, /* HID usage sensor property power state */ |
48 | 0x15, 0, /* HID logical Min_8(0) */ |
49 | 0x25, 5, /* HID logical Max_8(5) */ |
50 | 0x75, 8, /* HID report size(8) */ |
51 | 0x95, 1, /* HID report count(1) */ |
52 | 0xA1, 0x02, /* HID collection(logical) */ |
53 | 0x0A, 0x50, 0x08, /* Sensor property power state undefined sel */ |
54 | 0x0A, 0x51, 0x08, /* Sensor property power state D0 full power sel */ |
55 | 0x0A, 0x52, 0x08, /* Sensor property power state D1 low power sel */ |
56 | 0x0A, 0x53, 0x08, /* Sensor property power state D2 standby with wake sel */ |
57 | 0x0A, 0x54, 0x08, /* Sensor property power state D3 sleep with wake sel */ |
58 | 0x0A, 0x55, 0x08, /* Sensor property power state D4 power off sel */ |
59 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
60 | 0xC0, /* HID end collection */ |
61 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
62 | 0x15, 0, /* HID logical Min_8(0) */ |
63 | 0x25, 6, /* HID logical Max_8(6) */ |
64 | 0x75, 8, /* HID report size(8) */ |
65 | 0x95, 1, /* HID report count(1) */ |
66 | 0xA1, 0x02, /* HID collection(logical) */ |
67 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
68 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
69 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
70 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
71 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
72 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
73 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
74 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
75 | 0xC0, /* HID end collection */ |
76 | 0x0A, 0x0E, 0x03, /* HID usage sensor property report interval */ |
77 | 0x15, 0, /* HID logical Min_8(0) */ |
78 | 0x27, 0xFF, 0xFF, 0xFF, 0xFF, /* HID logical Max_32 */ |
79 | |
80 | 0x75, 32, /* HID report size(32) */ |
81 | 0x95, 1, /* HID report count(1) */ |
82 | 0x55, 0, /* HID unit exponent(0) */ |
83 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
84 | 0x0A, 0x52, 0x14, /* Sensor data motion accel and mod change sensitivity ABS) */ |
85 | |
86 | 0x15, 0, /* HID logical Min_8(0) */ |
87 | 0x26, 0xFF, 0xFF, /* HID logical Max_16(0xFF,0xFF) */ |
88 | |
89 | 0x75, 16, /* HID report size(16) */ |
90 | 0x95, 1, /* HID report count(1) */ |
91 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
92 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
93 | 0x0A, 0x52, 0x24, /* HID usage sensor data (motion accel and mod max) */ |
94 | |
95 | 0x16, 0x01, 0x80, /* HID logical Min_16(0x01,0x80) */ |
96 | |
97 | 0x26, 0xFF, 0x7F, /* HID logical Max_16(0xFF,0x7F) */ |
98 | |
99 | 0x75, 16, /* HID report size(16) */ |
100 | 0x95, 1, /* HID report count(1) */ |
101 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
102 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
103 | 0x0A, 0x52, 0x34, /* HID usage sensor data (motion accel and mod min) */ |
104 | |
105 | 0x16, 0x01, 0x80, /* HID logical Min_16(0x01,0x80) */ |
106 | |
107 | 0x26, 0xFF, 0x7F, /* HID logical Max_16(0xFF,0x7F) */ |
108 | |
109 | 0x75, 16, /* HID report size(16) */ |
110 | 0x95, 1, /* HID report count(1) */ |
111 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
112 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
113 | |
114 | //input report (transmit) |
115 | 0x05, 0x20, /* HID usage page sensors */ |
116 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
117 | 0x15, 0, /* HID logical Min_8(0) */ |
118 | 0x25, 6, /* HID logical Max_8(6) */ |
119 | 0x75, 8, /* HID report size(8) */ |
120 | 0x95, 1, /* HID report count (1) */ |
121 | 0xA1, 0x02, /* HID end collection (logical) */ |
122 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
123 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
124 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
125 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
126 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
127 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
128 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
129 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
130 | 0xC0, /* HID end collection */ |
131 | 0x0A, 0x02, 0x02, /* HID usage sensor event */ |
132 | 0x15, 0, /* HID logical Min_8(0) */ |
133 | 0x25, 5, /* HID logical Max_8(5) */ |
134 | 0x75, 8, /* HID report size(8) */ |
135 | 0x95, 1, /* HID report count (1) */ |
136 | 0xA1, 0x02, /* HID end collection (logical) */ |
137 | 0x0A, 0x10, 0x08, /* HID usage sensor event unknown sel */ |
138 | 0x0A, 0x11, 0x08, /* HID usage sensor event state changed sel */ |
139 | 0x0A, 0x12, 0x08, /* HID usage sensor event property changed sel */ |
140 | 0x0A, 0x13, 0x08, /* HID usage sensor event data updated sel */ |
141 | 0x0A, 0x14, 0x08, /* HID usage sensor event poll response sel */ |
142 | 0x0A, 0x15, 0x08, /* HID usage sensor event change sensitivity sel */ |
143 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
144 | 0xC0, /* HID end collection */ |
145 | 0x0A, 0x53, 0x04, /* HID usage sensor data motion Acceleration X axis */ |
146 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
147 | |
148 | 0x27, 0xFF, 0xff, 0XFF, 0XFF, /* HID logical Max_32 */ |
149 | |
150 | 0x75, 32, /* HID report size(32) */ |
151 | 0x95, 1, /* HID report count (1) */ |
152 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
153 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
154 | 0x0A, 0x54, 0x04, /* HID usage sensor data motion Acceleration Y axis */ |
155 | 0x17, 0X00, 0X00, 0x01, 0x80, /* HID logical Min_32 */ |
156 | |
157 | 0x27, 0xFF, 0xFF, 0XFF, 0XFF, /* HID logical Max_32 */ |
158 | |
159 | 0x75, 32, /* HID report size(32) */ |
160 | 0x95, 1, /* HID report count (1) */ |
161 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
162 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
163 | 0x0A, 0x55, 0x04, /* HID usage sensor data motion Acceleration Z axis */ |
164 | 0x17, 0X00, 0X00, 0x01, 0x80, /* HID logical Min_32 */ |
165 | |
166 | 0x27, 0XFF, 0XFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
167 | |
168 | 0x75, 32, /* HID report size(32) */ |
169 | 0x95, 1, /* HID report count (1) */ |
170 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
171 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
172 | |
173 | 0x0A, 0x51, 0x04, /* HID usage sensor data motion state */ |
174 | 0x15, 0, /* HID logical Min_8(0) False = Still*/ |
175 | 0x25, 1, /* HID logical Min_8(1) True = In motion */ |
176 | 0x75, 8, /* HID report size(8) */ |
177 | 0x95, 1, /* HID report count (1) */ |
178 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
179 | 0xC0 /* HID end collection */ |
180 | }; |
181 | |
182 | static const u8 gyro3_report_descriptor[] = { |
183 | 0x05, 0x20, /* Usage page */ |
184 | 0x09, 0x76, /* Motion type Gyro3D */ |
185 | 0xA1, 0x00, /* HID Collection (Physical) */ |
186 | |
187 | 0x85, 2, /* HID Report ID */ |
188 | 0x05, 0x20, /* HID usage page sensor */ |
189 | 0x0A, 0x09, 0x03, /* Sensor property and sensor connection type */ |
190 | 0x15, 0, /* HID logical MIN_8(0) */ |
191 | 0x25, 2, /* HID logical MAX_8(2) */ |
192 | 0x75, 8, /* HID report size(8) */ |
193 | 0x95, 1, /* HID report count(1) */ |
194 | 0xA1, 0x02, /* HID collection (logical) */ |
195 | 0x0A, 0x30, 0x08, /* Sensor property connection type intergated sel */ |
196 | 0x0A, 0x31, 0x08, /* Sensor property connection type attached sel */ |
197 | 0x0A, 0x32, 0x08, /* Sensor property connection type external sel */ |
198 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
199 | 0xC0, /* HID end collection */ |
200 | 0x0A, 0x16, 0x03, /* HID usage sensor property reporting state */ |
201 | 0x15, 0, /* HID logical Min_8(0) */ |
202 | 0x25, 5, /* HID logical Max_8(5) */ |
203 | 0x75, 8, /* HID report size(8) */ |
204 | 0x95, 1, /* HID report count(1) */ |
205 | 0xA1, 0x02, /* HID collection(logical) */ |
206 | 0x0A, 0x40, 0x08, /* Sensor reporting state no events sel */ |
207 | 0x0A, 0x41, 0x08, /* Sensor reporting state all events sel */ |
208 | 0x0A, 0x42, 0x08, /* Sensor reporting state threshold events sel */ |
209 | 0x0A, 0x43, 0x08, /* Sensor reporting state no events wake sel */ |
210 | 0x0A, 0x44, 0x08, /* Sensor reporting state all events wake sel */ |
211 | 0x0A, 0x45, 0x08, /* Sensor reporting state threshold events wake sel */ |
212 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
213 | 0xC0, /* HID end collection */ |
214 | 0x0A, 0x19, 0x03, /* HID usage sensor property power state */ |
215 | 0x15, 0, /* HID logical Min_8(0) */ |
216 | 0x25, 5, /* HID logical Max_8(5) */ |
217 | 0x75, 8, /* HID report size(8) */ |
218 | 0x95, 1, /* HID report count(1) */ |
219 | 0xA1, 0x02, /* HID collection(logical) */ |
220 | 0x0A, 0x50, 0x08, /* Sensor power state undefined sel */ |
221 | 0x0A, 0x51, 0x08, /* Sensor power state D0 full power sel */ |
222 | 0x0A, 0x52, 0x08, /* Sensor power state D1 low power sel */ |
223 | 0x0A, 0x53, 0x08, /* Sensor power state D2 standby with wake sel */ |
224 | 0x0A, 0x54, 0x08, /* Sensor power state D3 sleep with wake sel */ |
225 | 0x0A, 0x55, 0x08, /* Sensor power state D4 power off sel */ |
226 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
227 | 0xC0, /* HID end collection */ |
228 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
229 | 0x15, 0, /* HID logical Min_8(0) */ |
230 | 0x25, 6, /* HID logical Max_8(6) */ |
231 | 0x75, 8, /* HID report size(8) */ |
232 | 0x95, 1, /* HID report count(1) */ |
233 | 0xA1, 0x02, /* HID collection(logical) */ |
234 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
235 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
236 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
237 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
238 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
239 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
240 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
241 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
242 | 0xC0, /* HID end collection */ |
243 | 0x0A, 0x0E, 0x03, /* HID usage sensor property report interval */ |
244 | 0x15, 0, /* HID logical Min_8(0) */ |
245 | 0x27, 0xFF, 0xFF, 0xFF, 0xFF, /* HID logical Max_32 */ |
246 | |
247 | 0x75, 32, /* HID report size(32) */ |
248 | 0x95, 1, /* HID report count(1) */ |
249 | 0x55, 0, /* HID unit exponent(0) */ |
250 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
251 | 0x0A, 0x56, 0x14, /* Angular velocity and mod change sensitivity ABS)*/ |
252 | |
253 | 0x15, 0, /* HID logical Min_8(0) */ |
254 | 0x26, 0xFF, 0xFF, /* HID logical Max_16(0xFF,0xFF) */ |
255 | |
256 | 0x75, 16, /* HID report size(16) */ |
257 | 0x95, 1, /* HID report count(1) */ |
258 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
259 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
260 | 0x0A, 0x56, 0x24, /* Sensor data (motion angular velocity and mod max) */ |
261 | |
262 | 0x16, 0x01, 0x80, /* HID logical Min_16(0x01,0x80) */ |
263 | |
264 | 0x26, 0xFF, 0x7F, /* HID logical Max_16(0xFF,0x7F) */ |
265 | |
266 | 0x75, 16, /* HID report size(16) */ |
267 | 0x95, 1, /* HID report count(1) */ |
268 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
269 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
270 | 0x0A, 0x56, 0x34, /* HID usage sensor data (motion accel and mod min) */ |
271 | |
272 | 0x16, 0x01, 0x80, /* HID logical Min_16(0x01,0x80) */ |
273 | |
274 | 0x26, 0xFF, 0x7F, /* HID logical Max_16(0xFF,0x7F) */ |
275 | |
276 | 0x75, 16, /* HID report size(16) */ |
277 | 0x95, 1, /* HID report count(1) */ |
278 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
279 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
280 | |
281 | //Input reports(transmit) |
282 | 0x05, 0x20, /* HID usage page sensors */ |
283 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
284 | 0x15, 0, /* HID logical Min_8(0) */ |
285 | 0x25, 6, /* HID logical Max_8(6) */ |
286 | 0x75, 8, /* HID report size(8) */ |
287 | 0x95, 1, /* HID report count (1) */ |
288 | 0xA1, 0x02, /* HID end collection (logical) */ |
289 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
290 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
291 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
292 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
293 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
294 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
295 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
296 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
297 | 0xC0, /* HID end collection */ |
298 | 0x0A, 0x02, 0x02, /* HID usage sensor event */ |
299 | 0x15, 0, /* HID logical Min_8(0) */ |
300 | 0x25, 5, /* HID logical Max_8(5) */ |
301 | 0x75, 8, /* HID report size(8) */ |
302 | 0x95, 1, /* HID report count (1) */ |
303 | 0xA1, 0x02, /* HID end collection (logical) */ |
304 | 0x0A, 0x10, 0x08, /* HID usage sensor event unknown sel */ |
305 | 0x0A, 0x11, 0x08, /* HID usage sensor event state changed sel */ |
306 | 0x0A, 0x12, 0x08, /* HID usage sensor event property changed sel */ |
307 | 0x0A, 0x13, 0x08, /* HID usage sensor event data updated sel */ |
308 | 0x0A, 0x14, 0x08, /* HID usage sensor event poll response sel */ |
309 | 0x0A, 0x15, 0x08, /* HID usage sensor event change sensitivity sel */ |
310 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
311 | 0xC0, /* HID end collection */ |
312 | 0x0A, 0x57, 0x04, /* Sensor data motion Angular velocity X axis */ |
313 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
314 | |
315 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
316 | |
317 | 0x75, 32, /* HID report size(32) */ |
318 | 0x95, 1, /* HID report count (1) */ |
319 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
320 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
321 | 0x0A, 0x58, 0x04, /* Sensor data motion Angular velocity Y axis */ |
322 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
323 | |
324 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
325 | |
326 | 0x75, 32, /* HID report size(32) */ |
327 | 0x95, 1, /* HID report count (1) */ |
328 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
329 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
330 | 0x0A, 0x59, 0x04, /* Sensor data motion Angular velocity Z axis */ |
331 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
332 | |
333 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
334 | |
335 | 0x75, 32, /* HID report size(32) */ |
336 | 0x95, 1, /* HID report count (1) */ |
337 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
338 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
339 | |
340 | 0xC0, /* HID end collection */ |
341 | }; |
342 | |
343 | static const u8 comp3_report_descriptor[] = { |
344 | 0x05, 0x20, /* Usage page */ |
345 | 0x09, 0x83, /* Motion type Orientation compass 3D */ |
346 | 0xA1, 0x00, /* HID Collection (Physical) */ |
347 | |
348 | 0x85, 3, /* HID Report ID */ |
349 | 0x05, 0x20, /* HID usage page sensor */ |
350 | 0x0A, 0x09, 0x03, /* Sensor property and sensor connection type */ |
351 | 0x15, 0, /* HID logical MIN_8(0) */ |
352 | 0x25, 2, /* HID logical MAX_8(2) */ |
353 | 0x75, 8, /* HID report size(8) */ |
354 | 0x95, 1, /* HID report count(1) */ |
355 | 0xA1, 0x02, /* HID collection (logical) */ |
356 | 0x0A, 0x30, 0x08, /* Sensor property connection type intergated sel */ |
357 | 0x0A, 0x31, 0x08, /* Sensor property connection type attached sel */ |
358 | 0x0A, 0x32, 0x08, /* Sensor property connection type external sel */ |
359 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
360 | 0xC0, /* HID end collection */ |
361 | 0x0A, 0x16, 0x03, /* HID usage sensor property reporting state */ |
362 | 0x15, 0, /* HID logical Min_8(0) */ |
363 | 0x25, 5, /* HID logical Max_8(5) */ |
364 | 0x75, 8, /* HID report size(8) */ |
365 | 0x95, 1, /* HID report count(1) */ |
366 | 0xA1, 0x02, /* HID collection(logical) */ |
367 | 0x0A, 0x40, 0x08, /* Sensor reporting state no events sel */ |
368 | 0x0A, 0x41, 0x08, /* Sensor reporting state all events sel */ |
369 | 0x0A, 0x42, 0x08, /* Sensor reporting state threshold events sel */ |
370 | 0x0A, 0x43, 0x08, /* Sensor reporting state no events wake sel */ |
371 | 0x0A, 0x44, 0x08, /* Sensor reporting state all events wake sel */ |
372 | 0x0A, 0x45, 0x08, /* Sensor reporting state threshold events wake sel */ |
373 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
374 | 0xC0, /* HID end collection */ |
375 | 0x0A, 0x19, 0x03, /* HID usage sensor property power state */ |
376 | 0x15, 0, /* HID logical Min_8(0) */ |
377 | 0x25, 5, /* HID logical Max_8(5) */ |
378 | 0x75, 8, /* HID report size(8) */ |
379 | 0x95, 1, /* HID report count(1) */ |
380 | 0xA1, 0x02, /* HID collection(logical) */ |
381 | 0x0A, 0x50, 0x08, /* Sensor power state undefined sel */ |
382 | 0x0A, 0x51, 0x08, /* Sensor power state D0 full power sel */ |
383 | 0x0A, 0x52, 0x08, /* Sensor power state D1 low power sel */ |
384 | 0x0A, 0x53, 0x08, /* Sensor power state D2 standby with wake sel */ |
385 | 0x0A, 0x54, 0x08, /* Sensor power state D3 sleep with wake sel */ |
386 | 0x0A, 0x55, 0x08, /* Sensor power state D4 power off sel */ |
387 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
388 | 0xC0, /* HID end collection */ |
389 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
390 | 0x15, 0, /* HID logical Min_8(0) */ |
391 | 0x25, 6, /* HID logical Max_8(6) */ |
392 | 0x75, 8, /* HID report size(8) */ |
393 | 0x95, 1, /* HID report count(1) */ |
394 | 0xA1, 0x02, /* HID collection(logical) */ |
395 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
396 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
397 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
398 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
399 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
400 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
401 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
402 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
403 | 0xC0, /* HID end collection */ |
404 | 0x0A, 0x0E, 0x03, /* HID usage sensor property report interval */ |
405 | 0x15, 0, /* HID logical Min_8(0) */ |
406 | 0x27, 0xFF, 0xFF, 0xFF, 0xFF, /* HID logical Max_32 */ |
407 | 0x75, 32, /* HID report size(32) */ |
408 | 0x95, 1, /* HID report count(1) */ |
409 | 0x55, 0, /* HID unit exponent(0) */ |
410 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
411 | 0x0A, 0x71, 0x14, /* Orientation and mod change sensitivity ABS)*/ |
412 | 0x15, 0, /* HID logical Min_8(0) */ |
413 | 0x26, 0xFF, 0xFF, /* HID logical Max_16(0xFF,0xFF) */ |
414 | 0x75, 16, /* HID report size(16) */ |
415 | 0x95, 1, /* HID report count(1) */ |
416 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
417 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
418 | 0x0A, 0x71, 0x24, /* Sensor data (motion orientation and mod max) */ |
419 | 0x16, 0x01, 0x80, /* HID logical Min_16(0x01,0x80) */ |
420 | 0x26, 0xFF, 0x7F, /* HID logical Max_16(0xFF,0x7F) */ |
421 | 0x75, 16, /* HID report size(16) */ |
422 | 0x95, 1, /* HID report count(1) */ |
423 | 0x55, 0x0F, /* HID unit exponent(0x0F) */ |
424 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
425 | 0x0A, 0x71, 0x34, /* Sensor data (motion orientation and mod min) */ |
426 | 0x16, 0x01, 0x80, /* HID logical Min_16(0x01,0x80) */ |
427 | 0x26, 0xFF, 0x7F, /* HID logical Max_16(0xFF,0x7F) */ |
428 | 0x75, 16, /* HID report size(16) */ |
429 | 0x95, 1, /* HID report count(1) */ |
430 | 0x55, 0x0F, /* HID unit exponent(0x0F) */ |
431 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
432 | 0x0A, 0x84, 0x14, /* Maganetic flux and change sensitivity ABS) */ |
433 | 0x15, 0, /* HID logical Min_8(0) */ |
434 | 0x26, 0xFF, 0xFF, /* HID logical Max_16(0xFF,0xFF) */ |
435 | 0x75, 16, /* HID report size(16) */ |
436 | 0x95, 1, /* HID report count(1) */ |
437 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
438 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
439 | 0x0A, 0x84, 0x24, /* Maganetic flux and mod change sensitivity Max) */ |
440 | 0x16, 0x01, 0x80, /* HID logical Min_16(0x01,0x80) */ |
441 | 0x26, 0xFF, 0x7F, /* HID logical Max_16(0xFF,0x7F) */ |
442 | 0x75, 16, /* HID report size(16) */ |
443 | 0x95, 1, /* HID report count(1) */ |
444 | 0x55, 0x0F, /* HID unit exponent(0x0F) */ |
445 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
446 | 0x0A, 0x84, 0x34, /* Maganetic flux and mod change sensitivity Min */ |
447 | 0x16, 0x01, 0x80, /* HID logical Min_16(0x01,0x80) */ |
448 | 0x26, 0xFF, 0x7F, /* HID logical Max_16(0xFF,0x7F) */ |
449 | 0x75, 16, /* HID report size(16) */ |
450 | 0x95, 1, /* HID report count(1) */ |
451 | 0x55, 0x0F, /* HID unit exponent(0x0F) */ |
452 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
453 | |
454 | //Input reports(transmit) |
455 | 0x05, 0x20, /* HID usage page sensors */ |
456 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
457 | 0x15, 0, /* HID logical Min_8(0) */ |
458 | 0x25, 6, /* HID logical Max_8(6) */ |
459 | 0x75, 8, /* HID report size(8) */ |
460 | 0x95, 1, /* HID report count (1) */ |
461 | 0xA1, 0x02, /* HID end collection (logical) */ |
462 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
463 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
464 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
465 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
466 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
467 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
468 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
469 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
470 | 0xC0, /* HID end collection */ |
471 | 0x0A, 0x02, 0x02, /* HID usage sensor event */ |
472 | 0x15, 0, /* HID logical Min_8(0) */ |
473 | 0x25, 5, /* HID logical Max_8(5) */ |
474 | 0x75, 8, /* HID report size(8) */ |
475 | 0x95, 1, /* HID report count (1) */ |
476 | 0xA1, 0x02, /* HID end collection (logical) */ |
477 | 0x0A, 0x10, 0x08, /* HID usage sensor event unknown sel */ |
478 | 0x0A, 0x11, 0x08, /* HID usage sensor event state changed sel */ |
479 | 0x0A, 0x12, 0x08, /* HID usage sensor event property changed sel */ |
480 | 0x0A, 0x13, 0x08, /* HID usage sensor event data updated sel */ |
481 | 0x0A, 0x14, 0x08, /* HID usage sensor event poll response sel */ |
482 | 0x0A, 0x15, 0x08, /* HID usage sensor event change sensitivity sel */ |
483 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
484 | 0xC0, /* HID end collection */ |
485 | 0x0A, 0x85, 0x04, /* Sensor data orientation magnetic flux X axis */ |
486 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
487 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
488 | 0x75, 32, /* HID report size(32) */ |
489 | 0x95, 1, /* HID report count (1) */ |
490 | 0x55, 0x0D, /* HID unit exponent(0x0D) */ |
491 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
492 | 0x0A, 0x86, 0x04, /* Sensor data orientation magnetic flux Y axis */ |
493 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
494 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
495 | 0x75, 32, /* HID report size(32) */ |
496 | 0x95, 1, /* HID report count (1) */ |
497 | 0x55, 0x0D, /* HID unit exponent(0x0D) */ |
498 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
499 | 0x0A, 0x87, 0x04, /* Sensor data orientation magnetic flux Z axis */ |
500 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
501 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
502 | 0x75, 32, /* HID report size(32) */ |
503 | 0x95, 1, /* HID report count (1) */ |
504 | 0x55, 0x0D, /* HID unit exponent(0x0D) */ |
505 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
506 | 0x0A, 0x88, 0x04, /* Sensor data orientation magnetometer accuracy */ |
507 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
508 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
509 | 0x75, 32, /* HID report size(32) */ |
510 | 0x95, 1, /* HID report count (1) */ |
511 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
512 | 0xC0 /* HID end collection */ |
513 | }; |
514 | |
515 | static const u8 als_report_descriptor[] = { |
516 | 0x05, 0x20, /* HID usage page sensor */ |
517 | 0x09, 0x41, /* HID usage sensor type Ambientlight */ |
518 | 0xA1, 0x00, /* HID Collection (Physical) */ |
519 | |
520 | //feature reports(xmit/receive)// |
521 | 0x85, 4, /* HID Report ID */ |
522 | 0x05, 0x20, /* HID usage page sensor */ |
523 | 0x0A, 0x09, 0x03, /* Sensor property and sensor connection type */ |
524 | 0x15, 0, /* HID logical MIN_8(0) */ |
525 | 0x25, 2, /* HID logical MAX_8(2) */ |
526 | 0x75, 8, /* HID report size(8) */ |
527 | 0x95, 1, /* HID report count(1) */ |
528 | 0xA1, 0x02, /* HID collection (logical) */ |
529 | 0x0A, 0x30, 0x08, /* Sensor property connection type intergated sel */ |
530 | 0x0A, 0x31, 0x08, /* Sensor property connection type attached sel */ |
531 | 0x0A, 0x32, 0x08, /* Sensor property connection type external sel */ |
532 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
533 | 0xC0, /* HID end collection */ |
534 | 0x0A, 0x16, 0x03, /* HID usage sensor property reporting state */ |
535 | 0x15, 0, /* HID logical Min_8(0) */ |
536 | 0x25, 5, /* HID logical Max_8(5) */ |
537 | 0x75, 8, /* HID report size(8) */ |
538 | 0x95, 1, /* HID report count(1) */ |
539 | 0xA1, 0x02, /* HID collection(logical) */ |
540 | 0x0A, 0x40, 0x08, /* Sensor reporting state no events sel */ |
541 | 0x0A, 0x41, 0x08, /* Sensor reporting state all events sel */ |
542 | 0x0A, 0x42, 0x08, /* Sensor reporting state threshold events sel */ |
543 | 0x0A, 0x43, 0x08, /* Sensor reporting state no events wake sel */ |
544 | 0x0A, 0x44, 0x08, /* Sensor reporting state all events wake sel */ |
545 | 0x0A, 0x45, 0x08, /* Sensor reporting state threshold events wake sel */ |
546 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
547 | 0xC0, /* HID end collection */ |
548 | 0x0A, 0x19, 0x03, /* HID usage sensor property power state */ |
549 | 0x15, 0, /* HID logical Min_8(0) */ |
550 | 0x25, 5, /* HID logical Max_8(5) */ |
551 | 0x75, 8, /* HID report size(8) */ |
552 | 0x95, 1, /* HID report count(1) */ |
553 | 0xA1, 0x02, /* HID collection(logical) */ |
554 | 0x0A, 0x50, 0x08, /* Sensor power state undefined sel */ |
555 | 0x0A, 0x51, 0x08, /* Sensor power state D0 full power sel */ |
556 | 0x0A, 0x52, 0x08, /* Sensor power state D1 low power sel */ |
557 | 0x0A, 0x53, 0x08, /* Sensor power state D2 standby with wake sel */ |
558 | 0x0A, 0x54, 0x08, /* Sensor power state D3 sleep with wake sel */ |
559 | 0x0A, 0x55, 0x08, /* Sensor power state D4 power off sel */ |
560 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
561 | 0xC0, /* HID end collection */ |
562 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
563 | 0x15, 0, /* HID logical Min_8(0) */ |
564 | 0x25, 6, /* HID logical Max_8(6) */ |
565 | 0x75, 8, /* HID report size(8) */ |
566 | 0x95, 1, /* HID report count(1) */ |
567 | 0xA1, 0x02, /* HID collection(logical) */ |
568 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
569 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
570 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
571 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
572 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
573 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
574 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
575 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
576 | 0xC0, /* HID end collection */ |
577 | 0x0A, 0x0E, 0x03, /* HID usage sensor property report interval */ |
578 | 0x15, 0, /* HID logical Min_8(0) */ |
579 | 0x27, 0xFF, 0xFF, 0xFF, 0xFF, /* HID logical Max_32 */ |
580 | 0x75, 32, /* HID report size(32) */ |
581 | 0x95, 1, /* HID report count(1) */ |
582 | 0x55, 0, /* HID unit exponent(0) */ |
583 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
584 | 0x0A, 0xD1, 0xE4, /* Light illuminance and sensitivity REL PCT) */ |
585 | 0x15, 0, /* HID logical Min_8(0) */ |
586 | 0x26, 0x10, 0x27, /* HID logical Max_16(0x10,0x27) */ |
587 | 0x75, 16, /* HID report size(16) */ |
588 | 0x95, 1, /* HID report count(1) */ |
589 | 0x55, 0x0E, /* HID unit exponent(0x0E) */ |
590 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
591 | 0x0A, 0xD1, 0x24, /* Sensor data (Light illuminance and mod max) */ |
592 | 0x15, 0, /* HID logical Min_8(0) */ |
593 | 0x26, 0xFF, 0xFF, /* HID logical Max_16(0xFF,0xFF) */ |
594 | 0x75, 16, /* HID report size(16) */ |
595 | 0x95, 1, /* HID report count(1) */ |
596 | 0x55, 0x0F, /* HID unit exponent(0x0F) */ |
597 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
598 | 0x0A, 0xD1, 0x34, /* Sensor data (Light illuminance and mod min) */ |
599 | 0x15, 0, /* HID logical Min_8(0) */ |
600 | 0x26, 0xFF, 0xFF, /* HID logical Max_16(0xFF,0xFF) */ |
601 | 0x75, 16, /* HID report size(16) */ |
602 | 0x95, 1, /* HID report count(1) */ |
603 | 0x55, 0x0F, /* HID unit exponent(0x0F) */ |
604 | 0xB1, 0x02, /* HID feature (Data_Arr_Abs) */ |
605 | |
606 | //Input reports (transmit) |
607 | 0x05, 0x20, /* HID usage page sensors */ |
608 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
609 | 0x15, 0, /* HID logical Min_8(0) */ |
610 | 0x25, 6, /* HID logical Max_8(6) */ |
611 | 0x75, 8, /* HID report size(8) */ |
612 | 0x95, 1, /* HID report count (1) */ |
613 | 0xA1, 0x02, /* HID end collection (logical) */ |
614 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
615 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
616 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
617 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
618 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
619 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
620 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
621 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
622 | 0xC0, /* HID end collection */ |
623 | 0x0A, 0x02, 0x02, /* HID usage sensor event */ |
624 | 0x15, 0, /* HID logical Min_8(0) */ |
625 | 0x25, 5, /* HID logical Max_8(5) */ |
626 | 0x75, 8, /* HID report size(8) */ |
627 | 0x95, 1, /* HID report count (1) */ |
628 | 0xA1, 0x02, /* HID end collection (logical) */ |
629 | 0x0A, 0x10, 0x08, /* HID usage sensor event unknown sel */ |
630 | 0x0A, 0x11, 0x08, /* HID usage sensor event state changed sel */ |
631 | 0x0A, 0x12, 0x08, /* HID usage sensor event property changed sel */ |
632 | 0x0A, 0x13, 0x08, /* HID usage sensor event data updated sel */ |
633 | 0x0A, 0x14, 0x08, /* HID usage sensor event poll response sel */ |
634 | 0x0A, 0x15, 0x08, /* HID usage sensor event change sensitivity sel */ |
635 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
636 | 0xC0, /* HID end collection */ |
637 | 0x0A, 0xD1, 0x04, /* HID usage sensor data light illuminance */ |
638 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
639 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
640 | 0x55, 0x0F, /* HID unit exponent(0x0F) */ |
641 | 0x75, 32, /* HID report size(32) */ |
642 | 0x95, 1, /* HID report count (1) */ |
643 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
644 | 0x0A, 0xD2, 0x04, /* HID usage sensor data light temperature */ |
645 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
646 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
647 | 0x55, 0x0, /* HID unit exponent(0x0) */ |
648 | 0x75, 32, /* HID report size(32) */ |
649 | 0x95, 1, /* HID report count (1) */ |
650 | 0X81, 0x02, /* HID Input (Data_Arr_Abs) */ |
651 | 0x0A, 0xD4, 0x04, /* HID usage sensor data light chromaticity_x */ |
652 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
653 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
654 | 0x55, 0x0, /* HID unit exponent(0x0) */ |
655 | 0x75, 32, /* HID report size(32) */ |
656 | 0x95, 1, /* HID report count(1) */ |
657 | 0X81, 0x02, /* HID Input (Data_Var_Abs) */ |
658 | 0x0A, 0xD5, 0x04, /* HID usage sensor data light chromaticity_y */ |
659 | 0x17, 0x00, 0x00, 0x01, 0x80, /* HID logical Min_32 */ |
660 | 0x27, 0xFF, 0xFF, 0xFF, 0x7F, /* HID logical Max_32 */ |
661 | 0x55, 0x0, /* HID unit exponent(0x0) */ |
662 | 0x75, 32, /* HID report size(32) */ |
663 | 0x95, 1, /* HID report count (1) */ |
664 | 0X81, 0x02, /* HID Input (Data_Var_Abs) */ |
665 | 0xC0 /* HID end collection */ |
666 | }; |
667 | |
668 | /* BIOMETRIC PRESENCE*/ |
669 | static const u8 hpd_report_descriptor[] = { |
670 | 0x05, 0x20, /* Usage page */ |
671 | 0x09, 0x11, /* BIOMETRIC PRESENCE */ |
672 | 0xA1, 0x00, /* HID Collection (Physical) */ |
673 | |
674 | //feature reports(xmit/receive) |
675 | 0x85, 5, /* HID Report ID */ |
676 | 0x05, 0x20, /* HID usage page sensor */ |
677 | 0x0A, 0x09, 0x03, /* Sensor property and sensor connection type */ |
678 | 0x15, 0, /* HID logical MIN_8(0) */ |
679 | 0x25, 2, /* HID logical MAX_8(2) */ |
680 | 0x75, 8, /* HID report size(8) */ |
681 | 0x95, 1, /* HID report count(1) */ |
682 | 0xA1, 0x02, /* HID collection (logical) */ |
683 | 0x0A, 0x30, 0x08, /* Sensor property connection type intergated sel*/ |
684 | 0x0A, 0x31, 0x08, /* Sensor property connection type attached sel */ |
685 | 0x0A, 0x32, 0x08, /* Sensor property connection type external sel */ |
686 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
687 | 0xC0, /* HID end collection */ |
688 | 0x0A, 0x16, 0x03, /* HID usage sensor property reporting state */ |
689 | 0x15, 0, /* HID logical Min_8(0) */ |
690 | 0x25, 5, /* HID logical Max_8(5) */ |
691 | 0x75, 8, /* HID report size(8) */ |
692 | 0x95, 1, /* HID report count(1) */ |
693 | 0xA1, 0x02, /* HID collection(logical) */ |
694 | 0x0A, 0x40, 0x08, /* Sensor property report state no events sel */ |
695 | 0x0A, 0x41, 0x08, /* Sensor property report state all events sel */ |
696 | 0x0A, 0x42, 0x08, /* Sensor property report state threshold events sel */ |
697 | 0x0A, 0x43, 0x08, /* Sensor property report state no events wake sel */ |
698 | 0x0A, 0x44, 0x08, /* Sensor property report state all events wake sel */ |
699 | 0x0A, 0x45, 0x08, /* Sensor property report state threshold events wake sel */ |
700 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
701 | 0xC0, /* HID end collection */ |
702 | 0x0A, 0x19, 0x03, /* HID usage sensor property power state */ |
703 | 0x15, 0, /* HID logical Min_8(0) */ |
704 | 0x25, 5, /* HID logical Max_8(5) */ |
705 | 0x75, 8, /* HID report size(8) */ |
706 | 0x95, 1, /* HID report count(1) */ |
707 | 0xA1, 0x02, /* HID collection(logical) */ |
708 | 0x0A, 0x50, 0x08, /* Sensor property power state undefined sel */ |
709 | 0x0A, 0x51, 0x08, /* Sensor property power state D0 full power sel */ |
710 | 0x0A, 0x52, 0x08, /* Sensor property power state D1 low power sel */ |
711 | 0x0A, 0x53, 0x08, /* Sensor property power state D2 standby with wake sel */ |
712 | 0x0A, 0x54, 0x08, /* Sensor property power state D3 sleep with wake sel */ |
713 | 0x0A, 0x55, 0x08, /* Sensor property power state D4 power off sel */ |
714 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
715 | 0xC0, /* HID end collection */ |
716 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
717 | 0x15, 0, /* HID logical Min_8(0) */ |
718 | 0x25, 6, /* HID logical Max_8(6) */ |
719 | 0x75, 8, /* HID report size(8) */ |
720 | 0x95, 1, /* HID report count(1) */ |
721 | 0xA1, 0x02, /* HID collection(logical) */ |
722 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
723 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
724 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
725 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
726 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
727 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
728 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
729 | 0xB1, 0x00, /* HID feature (Data_Arr_Abs) */ |
730 | 0xC0, /* HID end collection */ |
731 | 0x0A, 0x0E, 0x03, /* HID usage sensor property report interval */ |
732 | 0x15, 0, /* HID logical Min_8(0) */ |
733 | 0x27, 0xFF, 0xFF, 0xFF, 0xFF, /* HID logical Max_32 */ |
734 | |
735 | 0x75, 32, /* HID report size(32) */ |
736 | 0x95, 1, /* HID report count(1) */ |
737 | 0x55, 0, /* HID unit exponent(0) */ |
738 | 0xB1, 0x02, /* HID feature (Data_Var_Abs) */ |
739 | |
740 | //input report (transmit) |
741 | 0x05, 0x20, /* HID usage page sensors */ |
742 | 0x0A, 0x01, 0x02, /* HID usage sensor state */ |
743 | 0x15, 0, /* HID logical Min_8(0) */ |
744 | 0x25, 6, /* HID logical Max_8(6) */ |
745 | 0x75, 8, /* HID report size(8) */ |
746 | 0x95, 1, /* HID report count (1) */ |
747 | 0xA1, 0x02, /* HID end collection (logical) */ |
748 | 0x0A, 0x00, 0x08, /* HID usage sensor state unknown sel */ |
749 | 0x0A, 0x01, 0x08, /* HID usage sensor state ready sel */ |
750 | 0x0A, 0x02, 0x08, /* HID usage sensor state not available sel */ |
751 | 0x0A, 0x03, 0x08, /* HID usage sensor state no data sel */ |
752 | 0x0A, 0x04, 0x08, /* HID usage sensor state initializing sel */ |
753 | 0x0A, 0x05, 0x08, /* HID usage sensor state access denied sel */ |
754 | 0x0A, 0x06, 0x08, /* HID usage sensor state error sel */ |
755 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
756 | 0xC0, /* HID end collection */ |
757 | 0x0A, 0x02, 0x02, /* HID usage sensor event */ |
758 | 0x15, 0, /* HID logical Min_8(0) */ |
759 | 0x25, 5, /* HID logical Max_8(5) */ |
760 | 0x75, 8, /* HID report size(8) */ |
761 | 0x95, 1, /* HID report count (1) */ |
762 | 0xA1, 0x02, /* HID end collection (logical) */ |
763 | 0x0A, 0x10, 0x08, /* HID usage sensor event unknown sel */ |
764 | 0x0A, 0x11, 0x08, /* HID usage sensor event state changed sel */ |
765 | 0x0A, 0x12, 0x08, /* HID usage sensor event property changed sel */ |
766 | 0x0A, 0x13, 0x08, /* HID usage sensor event data updated sel */ |
767 | 0x0A, 0x14, 0x08, /* HID usage sensor event poll response sel */ |
768 | 0x0A, 0x15, 0x08, /* HID usage sensor event change sensitivity sel */ |
769 | 0X81, 0x00, /* HID Input (Data_Arr_Abs) */ |
770 | 0xC0, /* HID end collection */ |
771 | 0x0A, 0xB1, 0x04, /* HID usage sensor data BIOMETRIC HUMAN PRESENCE */ |
772 | 0x15, 0, /* HID logical Min_8(0) */ |
773 | 0x25, 1, /* HID logical Max_8(1) */ |
774 | 0x75, 8, /* HID report size(8) */ |
775 | 0x95, 1, /* HID report count (1) */ |
776 | 0X81, 0x02, /* HID Input (Data_Var_Abs) */ |
777 | 0xC0 /* HID end collection */ |
778 | }; |
779 | #endif |
780 | |