2 * PROJECT: ReactOS Universal Serial Bus Bulk Enhanced Host Controller Interface
3 * LICENSE: GPL - See COPYING in the top level directory
4 * FILE: drivers/usb/hidparse/hidparse.c
7 * Michael Martin (michael.martin@reactos.org)
8 * Johannes Anderwald (johannes.anderwald@reactos.org)
18 PVOID Item
= ExAllocatePool(NonPagedPool
, ItemSize
);
24 RtlZeroMemory(Item
, ItemSize
);
53 RtlZeroMemory(Item
, ItemSize
);
66 RtlCopyMemory(Target
, Source
, Length
);
72 IN LPCSTR FormatStr
, ...)
77 char printbuffer
[1024];
79 va_start(args
, FormatStr
);
80 i
= vsprintf(printbuffer
, FormatStr
, args
);
83 DbgPrint(printbuffer
);
88 HidP_FreeCollectionDescription (
89 IN PHIDP_DEVICE_DESC DeviceDescription
)
96 HidParser_InitParser(AllocFunction
, FreeFunction
, ZeroFunction
, CopyFunction
, DebugFunction
, NULL
, &Parser
);
101 HidParser_FreeCollectionDescription(&Parser
, DeviceDescription
);
109 IN PHIDP_PREPARSED_DATA PreparsedData
,
110 OUT PHIDP_CAPS Capabilities
)
117 HidParser_InitParser(AllocFunction
, FreeFunction
, ZeroFunction
, CopyFunction
, DebugFunction
, PreparsedData
, &Parser
);
122 return HidParser_GetCaps(&Parser
, Capabilities
);
127 HidP_GetCollectionDescription(
128 IN PHIDP_REPORT_DESCRIPTOR ReportDesc
,
130 IN POOL_TYPE PoolType
,
131 OUT PHIDP_DEVICE_DESC DeviceDescription
)
134 HIDPARSER_STATUS Status
;
137 // first allocate the parser
139 Status
= HidParser_AllocateParser(AllocFunction
, FreeFunction
, ZeroFunction
, CopyFunction
, DebugFunction
, &Parser
);
140 if (Status
!= HIDPARSER_STATUS_SUCCESS
)
145 return STATUS_INSUFFICIENT_RESOURCES
;
151 Status
= HidParser_GetCollectionDescription(Parser
, ReportDesc
, DescLength
, PoolType
, DeviceDescription
);
154 // FIXME parser memory leak
162 HidP_MaxUsageListLength(
163 IN HIDP_REPORT_TYPE ReportType
,
164 IN USAGE UsagePage OPTIONAL
,
165 IN PHIDP_PREPARSED_DATA PreparsedData
)
172 ASSERT(ReportType
== HidP_Input
|| ReportType
== HidP_Output
|| ReportType
== HidP_Feature
);
177 HidParser_InitParser(AllocFunction
, FreeFunction
, ZeroFunction
, CopyFunction
, DebugFunction
, PreparsedData
, &Parser
);
183 return HidParser_MaxUsageListLength(&Parser
, ReportType
, UsagePage
);
189 HidP_GetSpecificValueCaps(
190 IN HIDP_REPORT_TYPE ReportType
,
192 IN USHORT LinkCollection
,
194 OUT PHIDP_VALUE_CAPS ValueCaps
,
195 IN OUT PULONG ValueCapsLength
,
196 IN PHIDP_PREPARSED_DATA PreparsedData
)
203 ASSERT(ReportType
== HidP_Input
|| ReportType
== HidP_Output
|| ReportType
== HidP_Feature
);
208 HidParser_InitParser(AllocFunction
, FreeFunction
, ZeroFunction
, CopyFunction
, DebugFunction
, PreparsedData
, &Parser
);
213 return HidParser_GetSpecificValueCaps(&Parser
, ReportType
, UsagePage
, LinkCollection
, Usage
, ValueCaps
, ValueCapsLength
);
220 IN HIDP_REPORT_TYPE ReportType
,
222 IN USHORT LinkCollection OPTIONAL
,
223 OUT USAGE
*UsageList
,
224 IN OUT ULONG
*UsageLength
,
225 IN PHIDP_PREPARSED_DATA PreparsedData
,
227 IN ULONG ReportLength
)
234 ASSERT(ReportType
== HidP_Input
|| ReportType
== HidP_Output
|| ReportType
== HidP_Feature
);
239 HidParser_InitParser(AllocFunction
, FreeFunction
, ZeroFunction
, CopyFunction
, DebugFunction
, PreparsedData
, &Parser
);
244 return HidParser_GetUsages(&Parser
, ReportType
, UsagePage
, LinkCollection
, UsageList
, UsageLength
, Report
, ReportLength
);
248 #undef HidP_GetButtonCaps
253 HidP_UsageListDifference(
254 IN PUSAGE PreviousUsageList
,
255 IN PUSAGE CurrentUsageList
,
256 OUT PUSAGE BreakUsageList
,
257 OUT PUSAGE MakeUsageList
,
258 IN ULONG UsageListLength
)
260 return HidParser_UsageListDifference(PreviousUsageList
, CurrentUsageList
, BreakUsageList
, MakeUsageList
, UsageListLength
);
267 IN HIDP_REPORT_TYPE ReportType
,
268 IN USHORT LinkCollection
,
269 OUT PUSAGE_AND_PAGE ButtonList
,
270 IN OUT ULONG
*UsageLength
,
271 IN PHIDP_PREPARSED_DATA PreparsedData
,
273 IN ULONG ReportLength
)
275 return HidP_GetUsages(ReportType
, HID_USAGE_PAGE_UNDEFINED
, LinkCollection
, (PUSAGE
)ButtonList
, UsageLength
, PreparsedData
, Report
, ReportLength
);
281 HidP_UsageAndPageListDifference(
282 IN PUSAGE_AND_PAGE PreviousUsageList
,
283 IN PUSAGE_AND_PAGE CurrentUsageList
,
284 OUT PUSAGE_AND_PAGE BreakUsageList
,
285 OUT PUSAGE_AND_PAGE MakeUsageList
,
286 IN ULONG UsageListLength
)
288 return HidParser_UsageAndPageListDifference(PreviousUsageList
, CurrentUsageList
, BreakUsageList
, MakeUsageList
, UsageListLength
);
294 HidP_GetScaledUsageValue(
295 IN HIDP_REPORT_TYPE ReportType
,
297 IN USHORT LinkCollection OPTIONAL
,
299 OUT PLONG UsageValue
,
300 IN PHIDP_PREPARSED_DATA PreparsedData
,
302 IN ULONG ReportLength
)
309 ASSERT(ReportType
== HidP_Input
|| ReportType
== HidP_Output
|| ReportType
== HidP_Feature
);
314 HidParser_InitParser(AllocFunction
, FreeFunction
, ZeroFunction
, CopyFunction
, DebugFunction
, PreparsedData
, &Parser
);
317 // get scaled usage value
319 return HidParser_GetScaledUsageValue(&Parser
, ReportType
, UsagePage
, LinkCollection
, Usage
, UsageValue
, Report
, ReportLength
);
326 HIDP_REPORT_TYPE ReportType
,
327 PHIDP_BUTTON_CAPS ButtonCaps
,
328 PUSHORT ButtonCapsLength
,
329 PHIDP_PREPARSED_DATA PreparsedData
)
331 return HidP_GetSpecificButtonCaps(ReportType
, HID_USAGE_PAGE_UNDEFINED
, 0, 0, ButtonCaps
, (PULONG
)ButtonCapsLength
, PreparsedData
);
337 HidP_GetSpecificButtonCaps(
338 IN HIDP_REPORT_TYPE ReportType
,
340 IN USHORT LinkCollection
,
342 OUT PHIDP_BUTTON_CAPS ButtonCaps
,
343 IN OUT PULONG ButtonCapsLength
,
344 IN PHIDP_PREPARSED_DATA PreparsedData
)
348 return STATUS_NOT_IMPLEMENTED
;
355 IN HIDP_REPORT_TYPE ReportType
,
356 OUT PHIDP_DATA DataList
,
357 IN OUT PULONG DataLength
,
358 IN PHIDP_PREPARSED_DATA PreparsedData
,
360 IN ULONG ReportLength
)
364 return STATUS_NOT_IMPLEMENTED
;
370 HidP_GetExtendedAttributes(
371 IN HIDP_REPORT_TYPE ReportType
,
373 IN PHIDP_PREPARSED_DATA PreparsedData
,
374 OUT PHIDP_EXTENDED_ATTRIBUTES Attributes
,
375 IN OUT PULONG LengthAttributes
)
379 return STATUS_NOT_IMPLEMENTED
;
385 HidP_GetLinkCollectionNodes(
386 OUT PHIDP_LINK_COLLECTION_NODE LinkCollectionNodes
,
387 IN OUT PULONG LinkCollectionNodesLength
,
388 IN PHIDP_PREPARSED_DATA PreparsedData
)
392 return STATUS_NOT_IMPLEMENTED
;
399 IN HIDP_REPORT_TYPE ReportType
,
401 IN USHORT LinkCollection
,
403 OUT PULONG UsageValue
,
404 IN PHIDP_PREPARSED_DATA PreparsedData
,
406 IN ULONG ReportLength
)
410 return STATUS_NOT_IMPLEMENTED
;
417 IN USHORT HidPacketLength
,
418 IN PHIDP_PREPARSED_DATA Ppd
,
419 OUT PULONG OutputBuffer
)
423 return STATUS_NOT_IMPLEMENTED
;
429 IN PHIDP_PREPARSED_DATA Ppd
,
430 OUT PULONG OutputBuffer
)
434 return STATUS_NOT_IMPLEMENTED
;
440 HidP_GetUsageValueArray(
441 IN HIDP_REPORT_TYPE ReportType
,
443 IN USHORT LinkCollection OPTIONAL
,
445 OUT PCHAR UsageValue
,
446 IN USHORT UsageValueByteLength
,
447 IN PHIDP_PREPARSED_DATA PreparsedData
,
449 IN ULONG ReportLength
)
453 return STATUS_NOT_IMPLEMENTED
;
461 IN HIDP_REPORT_TYPE ReportType
,
463 IN USHORT LinkCollection
,
465 IN OUT PULONG UsageLength
,
466 IN PHIDP_PREPARSED_DATA PreparsedData
,
468 IN ULONG ReportLength
)
472 return STATUS_NOT_IMPLEMENTED
;
478 HidP_TranslateUsagesToI8042ScanCodes(
479 IN PUSAGE ChangedUsageList
,
480 IN ULONG UsageListLength
,
481 IN HIDP_KEYBOARD_DIRECTION KeyAction
,
482 IN OUT PHIDP_KEYBOARD_MODIFIER_STATE ModifierState
,
483 IN PHIDP_INSERT_SCANCODES InsertCodesProcedure
,
484 IN PVOID InsertCodesContext
)
488 return STATUS_NOT_IMPLEMENTED
;
494 HidP_TranslateUsageAndPagesToI8042ScanCodes(
495 IN PUSAGE_AND_PAGE ChangedUsageList
,
496 IN ULONG UsageListLength
,
497 IN HIDP_KEYBOARD_DIRECTION KeyAction
,
498 IN OUT PHIDP_KEYBOARD_MODIFIER_STATE ModifierState
,
499 IN PHIDP_INSERT_SCANCODES InsertCodesProcedure
,
500 IN PVOID InsertCodesContext
)
504 return STATUS_NOT_IMPLEMENTED
;
511 IN HIDP_REPORT_TYPE ReportType
,
513 IN USHORT LinkCollection
,
515 IN OUT PULONG UsageLength
,
516 IN PHIDP_PREPARSED_DATA PreparsedData
,
518 IN ULONG ReportLength
)
522 return STATUS_NOT_IMPLEMENTED
;
528 HidP_SetUsageValueArray(
529 IN HIDP_REPORT_TYPE ReportType
,
531 IN USHORT LinkCollection OPTIONAL
,
534 IN USHORT UsageValueByteLength
,
535 IN PHIDP_PREPARSED_DATA PreparsedData
,
537 IN ULONG ReportLength
)
541 return STATUS_NOT_IMPLEMENTED
;
548 IN HIDP_REPORT_TYPE ReportType
,
550 IN USHORT LinkCollection
,
553 IN PHIDP_PREPARSED_DATA PreparsedData
,
555 IN ULONG ReportLength
)
559 return STATUS_NOT_IMPLEMENTED
;
565 HidP_SetScaledUsageValue(
566 IN HIDP_REPORT_TYPE ReportType
,
568 IN USHORT LinkCollection OPTIONAL
,
571 IN PHIDP_PREPARSED_DATA PreparsedData
,
573 IN ULONG ReportLength
)
577 return STATUS_NOT_IMPLEMENTED
;
584 IN HIDP_REPORT_TYPE ReportType
,
585 IN PHIDP_DATA DataList
,
586 IN OUT PULONG DataLength
,
587 IN PHIDP_PREPARSED_DATA PreparsedData
,
589 IN ULONG ReportLength
)
593 return STATUS_NOT_IMPLEMENTED
;
599 HidP_MaxDataListLength(
600 IN HIDP_REPORT_TYPE ReportType
,
601 IN PHIDP_PREPARSED_DATA PreparsedData
)
605 return STATUS_NOT_IMPLEMENTED
;
611 HidP_InitializeReportForID(
612 IN HIDP_REPORT_TYPE ReportType
,
614 IN PHIDP_PREPARSED_DATA PreparsedData
,
616 IN ULONG ReportLength
)
620 return STATUS_NOT_IMPLEMENTED
;
623 #undef HidP_GetValueCaps
629 HIDP_REPORT_TYPE ReportType
,
630 PHIDP_VALUE_CAPS ValueCaps
,
631 PULONG ValueCapsLength
,
632 PHIDP_PREPARSED_DATA PreparsedData
)
636 return STATUS_NOT_IMPLEMENTED
;
642 IN PDRIVER_OBJECT DriverObject
,
643 IN PUNICODE_STRING RegPath
)
646 DPRINT1("********* HID PARSE *********\n");
647 return STATUS_SUCCESS
;