{\r
NewReportItem.Attributes.Usage.Usage = 0;\r
}\r
- \r
+\r
+ uint8_t ReportSizeIndex = 0;\r
+\r
switch (HIDReportItem & TAG_MASK)\r
{\r
case TAG_MAIN_INPUT:\r
NewReportItem.ItemType = REPORT_ITEM_TYPE_In;\r
- NewReportItem.BitOffset = CurrReportIDInfo->BitsIn;\r
+ NewReportItem.BitOffset = CurrReportIDInfo->ReportSizeBits[REPORT_ITEM_TYPE_In];\r
\r
- CurrReportIDInfo->BitsIn += CurrStateTable->Attributes.BitSize;\r
+ ReportSizeIndex = REPORT_ITEM_TYPE_In;\r
break;\r
case TAG_MAIN_OUTPUT:\r
NewReportItem.ItemType = REPORT_ITEM_TYPE_Out;\r
- NewReportItem.BitOffset = CurrReportIDInfo->BitsOut;\r
+ NewReportItem.BitOffset = CurrReportIDInfo->ReportSizeBits[REPORT_ITEM_TYPE_Out];\r
\r
- CurrReportIDInfo->BitsOut += CurrStateTable->Attributes.BitSize;\r
+ ReportSizeIndex = REPORT_ITEM_TYPE_Out;\r
break;\r
case TAG_MAIN_FEATURE:\r
NewReportItem.ItemType = REPORT_ITEM_TYPE_Feature; \r
- NewReportItem.BitOffset = CurrReportIDInfo->BitsFeature;\r
+ NewReportItem.BitOffset = CurrReportIDInfo->ReportSizeBits[REPORT_ITEM_TYPE_Feature];\r
\r
- CurrReportIDInfo->BitsFeature += CurrStateTable->Attributes.BitSize;\r
+ ReportSizeIndex = REPORT_ITEM_TYPE_Feature;\r
break;\r
}\r
+ \r
+ CurrReportIDInfo->ReportSizeBits[ReportSizeIndex] += CurrStateTable->Attributes.BitSize;\r
\r
+ if (ParserData->LargestReportSizeBits < CurrReportIDInfo->ReportSizeBits[ReportSizeIndex])\r
+ ParserData->LargestReportSizeBits = CurrReportIDInfo->ReportSizeBits[ReportSizeIndex];\r
+ \r
if (!(ReportItemData & IOF_CONSTANT) && CALLBACK_HIDParser_FilterHIDReportItem(&CurrStateTable->Attributes))\r
{ \r
if (ParserData->TotalReportItems == HID_MAX_REPORTITEMS)\r
}\r
}\r
\r
+uint16_t USB_GetHIDReportSize(HID_ReportInfo_t* const ParserData, const uint8_t ReportID, const uint8_t ReportType)\r
+{\r
+ for (uint8_t i = 0; i < HID_MAX_REPORT_IDS; i++)\r
+ {\r
+ if (ParserData->ReportIDSizes[i].ReportID == ReportID)\r
+ return ParserData->ReportIDSizes[i].ReportSizeBits[ReportType];\r
+ }\r
+\r
+ return 0;\r
+}\r
+\r
#endif\r