www.pudn.com > reply_1_601840.rar > HIDPI.H


 /*++ 
 
Copyright (c) 1996-1998      Microsoft Corporation 
 
Module Name: 
 
        HIDPI.H 
 
Abstract: 
 
   Public Interface to the HID parsing library. 
 
Environment: 
 
    Kernel & user mode 
 
--*/ 
 
#ifndef   __HIDPI_H__ 
#define   __HIDPI_H__ 
 
#include  
 
// Please include "hidsdi.h" to use the user space (dll / parser) 
// Please include "hidpddi.h" to use the kernel space parser 
 
// 
// Special Link collection values for using the query functions 
// 
// Root collection references the collection at the base of the link 
// collection tree. 
// Unspecifies, references all collections in the link collection tree. 
// 
#define HIDP_LINK_COLLECTION_ROOT ((USHORT) -1) 
#define HIDP_LINK_COLLECTION_UNSPECIFIED ((USHORT) 0) 
 
 
typedef enum _HIDP_REPORT_TYPE 
{ 
    HidP_Input, 
    HidP_Output, 
    HidP_Feature 
} HIDP_REPORT_TYPE; 
 
typedef struct _USAGE_AND_PAGE 
{ 
    USAGE Usage; 
    USAGE UsagePage; 
} USAGE_AND_PAGE, *PUSAGE_AND_PAGE; 
 
#define HidP_IsSameUsageAndPage(u1, u2) ((* (PULONG) &u1) == (* (PULONG) &u2)) 
 
typedef struct _HIDP_BUTTON_CAPS 
{ 
    USAGE    UsagePage; 
    UCHAR    ReportID; 
    BOOLEAN  IsAlias; 
 
    USHORT   BitField; 
    USHORT   LinkCollection;   // A unique internal index pointer 
 
    USAGE    LinkUsage; 
    USAGE    LinkUsagePage; 
 
    BOOLEAN  IsRange; 
    BOOLEAN  IsStringRange; 
    BOOLEAN  IsDesignatorRange; 
    BOOLEAN  IsAbsolute; 
 
    ULONG    Reserved[10]; 
    union { 
        struct { 
            USAGE    UsageMin,         UsageMax; 
            USHORT   StringMin,        StringMax; 
            USHORT   DesignatorMin,    DesignatorMax; 
            USHORT   DataIndexMin,     DataIndexMax; 
        } Range; 
        struct  { 
            USAGE    Usage,            Reserved1; 
            USHORT   StringIndex,      Reserved2; 
            USHORT   DesignatorIndex,  Reserved3; 
            USHORT   DataIndex,        Reserved4; 
        } NotRange; 
    }; 
 
} HIDP_BUTTON_CAPS, *PHIDP_BUTTON_CAPS; 
 
 
typedef struct _HIDP_VALUE_CAPS 
{ 
    USAGE    UsagePage; 
    UCHAR    ReportID; 
    BOOLEAN  IsAlias; 
 
    USHORT   BitField; 
    USHORT   LinkCollection;   // A unique internal index pointer 
 
    USAGE    LinkUsage; 
    USAGE    LinkUsagePage; 
 
    BOOLEAN  IsRange; 
    BOOLEAN  IsStringRange; 
    BOOLEAN  IsDesignatorRange; 
    BOOLEAN  IsAbsolute; 
 
    BOOLEAN  HasNull;        // Does this channel have a null report   union 
    UCHAR    Reserved; 
    USHORT   BitSize;        // How many bits are devoted to this value? 
 
    USHORT   ReportCount;    // See Note below.  Usually set to 1. 
    USHORT   Reserved2[5]; 
 
    ULONG    UnitsExp; 
    ULONG    Units; 
 
    LONG     LogicalMin,       LogicalMax; 
    LONG     PhysicalMin,      PhysicalMax; 
 
    union { 
        struct { 
            USAGE    UsageMin,         UsageMax; 
            USHORT   StringMin,        StringMax; 
            USHORT   DesignatorMin,    DesignatorMax; 
            USHORT   DataIndexMin,     DataIndexMax; 
        } Range; 
 
        struct { 
            USAGE    Usage,            Reserved1; 
            USHORT   StringIndex,      Reserved2; 
            USHORT   DesignatorIndex,  Reserved3; 
            USHORT   DataIndex,        Reserved4; 
        } NotRange; 
    }; 
} HIDP_VALUE_CAPS, *PHIDP_VALUE_CAPS; 
 
// 
// Notes: 
// 
// ReportCount:  When a report descriptor declares an Input, Output, or 
// Feature main item with fewer usage declarations than the report count, then 
// the last usage applies to all remaining unspecified count in that main item. 
// (As an example you might have data that required many fields to describe, 
// possibly buffered bytes.)  In this case, only one value cap structure is 
// allocated for these associtated fields, all with the same usage, and Report 
// Count reflects the number of fields involved.  Normally ReportCount is 1. 
// To access all of the fields in such a value structure would require using 
// HidP_GetUsageValueArray and HidP_SetUsageValueArray.   HidP_GetUsageValue/ 
// HidP_SetScaledUsageValue will also work, however, these functions will only 
// work with the first field of the structure. 
// 
 
// 
// The link collection tree consists of an array of LINK_COLLECTION_NODES 
// where the index into this array is the same as the collection number. 
// 
// Given a collection A which contains a subcollection B, A is defined to be 
// the parent B, and B is defined to be the child. 
// 
// Given collections A, B, and C where B and C are children of A, and B was 
// encountered before C in the report descriptor, B is defined as a sibling of 
// C.  (This implies, of course, that if B is a sibling of C, then C is NOT a 
// sibling of B). 
// 
// B is defined as the NextSibling of C if and only if there exists NO 
// child collection of A, call it D, such that B is a sibling of D and D 
// is a sibling of C. 
// 
// E is defined to be the FirstChild of A if and only if for all children of A, 
// F, that are not equivalent to E, F is a sibling of E. 
// (This implies, of course, that the does not exist a child of A, call it G, 
// where E is a sibling of G).  In other words the first sibling is the last 
// link collection found in the list. 
// 
// In other words, if a collection B is defined within the definition of another 
// collection A, B becomes a child of A.  All collections with the same parent 
// are considered siblings.  The FirstChild of the parent collection, A, will be 
// last collection defined that has A as a parent.  The order of sibling pointers 
// is similarly determined.  When a collection B is defined, it becomes the 
// FirstChild of it's parent collection.  The previously defined FirstChild of the 
// parent collection becomes the NextSibling of the new collection.  As new 
// collections with the same parent are discovered, the chain of sibling is built. 
// 
// With that in mind, the following describes conclusively a data structure 
// that provides direct traversal up, down, and accross the link collection 
// tree. 
// 
// 
typedef struct _HIDP_LINK_COLLECTION_NODE 
{ 
    USAGE    LinkUsage; 
    USAGE    LinkUsagePage; 
    USHORT   Parent; 
    USHORT   NumberOfChildren; 
    USHORT   NextSibling; 
    USHORT   FirstChild; 
    ULONG    CollectionType: 8;  // As defined in 6.2.2.6 of HID spec 
    ULONG    IsAlias : 1; // This link node is an allias of the next link node. 
    ULONG    Reserved: 23; 
    PVOID    UserContext; // The user can hang his coat here. 
} HIDP_LINK_COLLECTION_NODE, *PHIDP_LINK_COLLECTION_NODE; 
 
// 
// When a link collection is described by a delimiter, alias link collection 
// nodes are created.  (One for each usage within the delimiter). 
// The parser assigns each capability description listed above only one 
// link collection. 
// 
// If a control is defined within a collection defined by 
// delimited usages, then that control is said to be within multiple link 
// collections, one for each usage within the open and close delimiter tokens. 
// Such multiple link collecions are said to be aliases.  The first N-1 such 
// collections, listed in the link collection node array, have their IsAlias 
// bit set.  The last such link collection is the link collection index used 
// in the capabilities described above. 
// Clients wishing to set a control in an aliased collection, should walk the 
// collection array once for each time they see the IsAlias flag set, and use 
// the last link collection as the index for the below accessor functions. 
// 
// NB: if IsAlias is set, then NextSibling should be one more than the current 
// link collection node index. 
// 
 
typedef PUCHAR  PHIDP_REPORT_DESCRIPTOR; 
typedef struct _HIDP_PREPARSED_DATA * PHIDP_PREPARSED_DATA; 
 
typedef struct _HIDP_CAPS 
{ 
    USAGE    Usage; 
    USAGE    UsagePage; 
    USHORT   InputReportByteLength; 
    USHORT   OutputReportByteLength; 
    USHORT   FeatureReportByteLength; 
    USHORT   Reserved[17]; 
 
    USHORT   NumberLinkCollectionNodes; 
 
    USHORT   NumberInputButtonCaps; 
    USHORT   NumberInputValueCaps; 
    USHORT   NumberInputDataIndices; 
 
    USHORT   NumberOutputButtonCaps; 
    USHORT   NumberOutputValueCaps; 
    USHORT   NumberOutputDataIndices; 
 
    USHORT   NumberFeatureButtonCaps; 
    USHORT   NumberFeatureValueCaps; 
    USHORT   NumberFeatureDataIndices; 
} HIDP_CAPS, *PHIDP_CAPS; 
 
typedef struct _HIDP_DATA 
{ 
    USHORT  DataIndex; 
    USHORT  Reserved; 
    union { 
        ULONG   RawValue; // for values 
        BOOLEAN On; // for buttons MUST BE TRUE for buttons. 
    }; 
} HIDP_DATA, *PHIDP_DATA; 
// 
// The HIDP_DATA structure is used with HidP_GetData and HidP_SetData 
// functions. 
// 
// The parser contiguously assigns every control (button or value) in a hid 
// device a unique data index from zero to NumberXXXDataIndices -1 , inclusive. 
// This value is found in the HIDP_BUTTON_CAPS and HIDP_VALUE_CAPS structures. 
// 
// Most clients will find the Get/Set Buttons / Value accessor functions 
// sufficient to their needs, as they will allow the clients to access the 
// data known to them while ignoring the other controls. 
// 
// More complex clients, which actually read the Button / Value Caps, and which 
// do a value add service to these routines (EG Direct Input), will need to 
// access all the data in the device without interest in the individual usage 
// or link collection location.  These are the clients that will find 
// HidP_Data useful. 
// 
 
typedef struct _HIDP_UNKNOWN_TOKEN 
{ 
    UCHAR  Token; 
    UCHAR  Reserved[3]; 
    ULONG  BitField; 
} HIDP_UNKNOWN_TOKEN, *PHIDP_UNKNOWN_TOKEN; 
 
typedef struct _HIDP_EXTENDED_ATTRIBUTES 
{ 
    UCHAR   NumGlobalUnknowns; 
    UCHAR   Reserved [3]; 
    PHIDP_UNKNOWN_TOKEN  GlobalUnknowns; 
    // ... Additional attributes 
    ULONG   Data [1]; // variableLength  DO NOT ACCESS THIS FIELD 
} HIDP_EXTENDED_ATTRIBUTES, *PHIDP_EXTENDED_ATTRIBUTES; 
 
NTSTATUS __stdcall 
HidP_GetCaps ( 
   IN      PHIDP_PREPARSED_DATA      PreparsedData, 
   OUT     PHIDP_CAPS                Capabilities 
   ); 
/*++ 
Routine Description: 
   Returns a list of capabilities of a given hid device as described by its 
   preparsed data. 
 
Arguments: 
   PreparsedData    The preparsed data returned from HIDCLASS. 
   Capabilities     a HIDP_CAPS structure 
 
Return Value: 
·  HIDP_STATUS_SUCCESS 
·  HIDP_STATUS_INVALID_PREPARSED_DATA 
--*/ 
 
NTSTATUS __stdcall 
HidP_GetLinkCollectionNodes ( 
   OUT      PHIDP_LINK_COLLECTION_NODE LinkCollectionNodes, 
   IN OUT   PULONG                     LinkCollectionNodesLength, 
   IN       PHIDP_PREPARSED_DATA       PreparsedData 
   ); 
/*++ 
Routine Description: 
   Return a list of PHIDP_LINK_COLLECTION_NODEs used to describe the link 
   collection tree of this hid device.  See the above description of 
   struct _HIDP_LINK_COLLECTION_NODE. 
 
Arguments: 
   LinkCollectionNodes - a caller allocated array into which 
                 HidP_GetLinkCollectionNodes will store the information 
 
   LinKCollectionNodesLength - the caller sets this value to the length of the 
                 the array in terms of number of elements. 
                 HidP_GetLinkCollectionNodes sets this value to the actual 
                 number of elements set. The total number of nodes required to 
                 describe this HID device can be found in the 
                 NumberLinkCollectionNodes field in the HIDP_CAPS structure. 
 
--*/ 
 
NTSTATUS __stdcall 
HidP_GetButtonCaps ( 
   IN       HIDP_REPORT_TYPE     ReportType, 
   OUT      PHIDP_BUTTON_CAPS    ButtonCaps, 
   IN OUT   PUSHORT              ButtonCapsLength, 
   IN       PHIDP_PREPARSED_DATA PreparsedData 
); 
#define HidP_GetButtonCaps(_Type_, _Caps_, _Len_, _Data_) \ 
        HidP_GetSpecificButtonCaps (_Type_, 0, 0, 0, _Caps_, _Len_, _Data_) 
NTSTATUS __stdcall 
HidP_GetSpecificButtonCaps ( 
   IN       HIDP_REPORT_TYPE     ReportType, 
   IN       USAGE                UsagePage,      // Optional (0 => ignore) 
   IN       USHORT               LinkCollection, // Optional (0 => ignore) 
   IN       USAGE                Usage,          // Optional (0 => ignore) 
   OUT      PHIDP_BUTTON_CAPS    ButtonCaps, 
   IN OUT   PUSHORT              ButtonCapsLength, 
   IN       PHIDP_PREPARSED_DATA PreparsedData 
   ); 
/*++ 
Description: 
   HidP_GetButtonCaps returns all the buttons (binary values) that are a part 
   of the given report type for the Hid device represented by the given 
   preparsed data. 
 
Parameters: 
   ReportType  One of HidP_Input, HidP_Output, or HidP_Feature. 
 
   UsagePage   A usage page value used to limit the button caps returned to 
                those on a given usage page.  If set to 0, this parameter is 
                ignored.  Can be used with LinkCollection and Usage parameters 
                to further limit the number of button caps structures returned. 
 
   LinkCollection HIDP_LINK_COLLECTION node array index used to limit the 
                  button caps returned to those buttons in a given link 
                  collection.  If set to 0, this parameter is 
                  ignored.  Can be used with UsagePage and Usage parameters 
                  to further limit the number of button caps structures 
                  returned. 
 
   Usage      A usage value used to limit the button caps returned to those 
               with the specified usage value.  If set to 0, this parameter 
               is ignored.  Can be used with LinkCollection and UsagePage 
               parameters to further limit the number of button caps 
               structures returned. 
 
   ButtonCaps A _HIDP_BUTTON_CAPS array containing information about all the 
               binary values in the given report.  This buffer is provided by 
               the caller. 
 
   ButtonLength   As input, this parameter specifies the length of the 
                  ButtonCaps parameter (array) in number of array elements. 
                  As output, this value is set to indicate how many of those 
                  array elements were filled in by the function.  The maximum number of 
                  button caps that can be returned is found in the HIDP_CAPS 
                  structure.  If HIDP_STATUS_BUFFER_TOO_SMALL is returned, 
                  this value contains the number of array elements needed to 
                  successfully complete the request. 
 
   PreparsedData  The preparsed data returned from HIDCLASS. 
 
 
Return Value 
HidP_GetSpecificButtonCaps returns the following error codes: 
· HIDP_STATUS_SUCCESS. 
· HIDP_STATUS_INVALID_REPORT_TYPE 
· HIDP_STATUS_INVALID_PREPARSED_DATA 
· HIDP_STATUS_BUFFER_TOO_SMALL (all given entries however have been filled in) 
· HIDP_STATUS_USAGE_NOT_FOUND 
--*/ 
 
NTSTATUS __stdcall 
HidP_GetValueCaps ( 
   IN       HIDP_REPORT_TYPE     ReportType, 
   OUT      PHIDP_VALUE_CAPS     ValueCaps, 
   IN OUT   PUSHORT              ValueCapsLength, 
   IN       PHIDP_PREPARSED_DATA PreparsedData 
); 
#define HidP_GetValueCaps(_Type_, _Caps_, _Len_, _Data_) \ 
        HidP_GetSpecificValueCaps (_Type_, 0, 0, 0, _Caps_, _Len_, _Data_) 
NTSTATUS __stdcall 
HidP_GetSpecificValueCaps ( 
   IN       HIDP_REPORT_TYPE     ReportType, 
   IN       USAGE                UsagePage,      // Optional (0 => ignore) 
   IN       USHORT               LinkCollection, // Optional (0 => ignore) 
   IN       USAGE                Usage,          // Optional (0 => ignore) 
   OUT      PHIDP_VALUE_CAPS     ValueCaps, 
   IN OUT   PUSHORT              ValueCapsLength, 
   IN       PHIDP_PREPARSED_DATA PreparsedData 
   ); 
/*++ 
Description: 
   HidP_GetValueCaps returns all the values (non-binary) that are a part 
   of the given report type for the Hid device represented by the given 
   preparsed data. 
 
Parameters: 
   ReportType  One of HidP_Input, HidP_Output, or HidP_Feature. 
 
   UsagePage   A usage page value used to limit the value caps returned to 
                those on a given usage page.  If set to 0, this parameter is 
                ignored.  Can be used with LinkCollection and Usage parameters 
                to further limit the number of value caps structures returned. 
 
   LinkCollection HIDP_LINK_COLLECTION node array index used to limit the 
                  value caps returned to those buttons in a given link 
                  collection.  If set to 0, this parameter is 
                  ignored.  Can be used with UsagePage and Usage parameters 
                  to further limit the number of value caps structures 
                  returned. 
 
   Usage      A usage value used to limit the value caps returned to those 
               with the specified usage value.  If set to 0, this parameter 
               is ignored.  Can be used with LinkCollection and UsagePage 
               parameters to further limit the number of value caps 
               structures returned. 
 
   ValueCaps  A _HIDP_VALUE_CAPS array containing information about all the 
               non-binary values in the given report.  This buffer is provided 
               by the caller. 
 
   ValueLength   As input, this parameter specifies the length of the ValueCaps 
                  parameter (array) in number of array elements.  As output, 
                  this value is set to indicate how many of those array elements 
                  were filled in by the function.  The maximum number of 
                  value caps that can be returned is found in the HIDP_CAPS 
                  structure.  If HIDP_STATUS_BUFFER_TOO_SMALL is returned, 
                  this value contains the number of array elements needed to 
                  successfully complete the request. 
 
   PreparsedData  The preparsed data returned from HIDCLASS. 
 
 
Return Value 
HidP_GetValueCaps returns the following error codes: 
· HIDP_STATUS_SUCCESS. 
· HIDP_STATUS_INVALID_REPORT_TYPE 
· HIDP_STATUS_INVALID_PREPARSED_DATA 
· HIDP_STATUS_BUFFER_TOO_SMALL (all given entries however have been filled in) 
· HIDP_STATUS_USAGE_NOT_FOUND 
 
--*/ 
 
NTSTATUS __stdcall 
HidP_GetExtendedAttributes ( 
    IN      HIDP_REPORT_TYPE            ReportType, 
    IN      USHORT                      DataIndex, 
    IN      PHIDP_PREPARSED_DATA        PreparsedData, 
    OUT     PHIDP_EXTENDED_ATTRIBUTES   Attributes, 
    IN OUT  PULONG                      LengthAttributes 
    ); 
/*++ 
Description: 
    Given a data index from the value or button capabilities of a given control 
    return any extended attributes for the control if any exist. 
 
Parameters: 
    ReportType  One of HidP_Input, HidP_Output, or HidP_Feature. 
 
    DataIndex   The data index for the given control, found in the capabilities 
                structure for that control 
 
    PreparsedData   The preparsed data returned from HIDCLASS. 
 
    Attributes  Pointer to a buffer into which the extended attribute data will 
                be copied. 
 
    LengthAttributes    Length of the given buffer in bytes. 
 
Return Value 
    HIDP_STATUS_SUCCESS 
    HIDP_STATUS_DATA_INDEX_NOT_FOUND 
--*/ 
 
NTSTATUS __stdcall 
HidP_InitializeReportForID ( 
   IN       HIDP_REPORT_TYPE      ReportType, 
   IN       UCHAR                 ReportID, 
   IN       PHIDP_PREPARSED_DATA  PreparsedData, 
   IN OUT   PCHAR                 Report, 
   IN       ULONG                 ReportLength 
   ); 
/*++ 
 
Routine Description: 
 
    Initialize a report based on the given report ID. 
 
Parameters: 
 
    ReportType  One of HidP_Input, HidP_Output, or HidP_Feature. 
 
    PreparasedData  Preparsed data structure returned by HIDCLASS 
 
    Report      Buffer which to set the data into. 
 
    ReportLength Length of Report...Report should be at least as long as the 
                value indicated in the HIDP_CAPS structure for the device and 
                the corresponding ReportType 
 
Return Value 
 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not equal 
                                        to the length specified in HIDP_CAPS 
                                        structure for the given ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
 
--*/ 
 
NTSTATUS __stdcall 
HidP_SetData ( 
   IN       HIDP_REPORT_TYPE      ReportType, 
   IN       PHIDP_DATA            DataList, 
   IN OUT   PULONG                DataLength, 
   IN       PHIDP_PREPARSED_DATA  PreparsedData, 
   IN OUT   PCHAR                 Report, 
   IN       ULONG                 ReportLength 
   ); 
/*++ 
 
Routine Description: 
 
    Please Note: Since usage value arrays deal with multiple fields for 
                 for one usage value, they cannot be used with HidP_SetData 
                 and HidP_GetData.  In this case, 
                 HIDP_STATUS_IS_USAGE_VALUE_ARRAY will be returned. 
 
Parameters: 
 
    ReportType  One of HidP_Input, HidP_Output, or HidP_Feature. 
 
    DataList    Array of HIDP_DATA structures that contains the data values 
                that are to be set into the given report 
 
    DataLength  As input, length in array elements of DataList.  As output, 
                contains the number of data elements set on successful 
                completion or an index into the DataList array to identify 
                the faulting HIDP_DATA value if an error code is returned. 
 
    PreparasedData  Preparsed data structure returned by HIDCLASS 
 
    Report      Buffer which to set the data into. 
 
    ReportLength Length of Report...Report should be at least as long as the 
                value indicated in the HIDP_CAPS structure for the device and 
                the corresponding ReportType 
 
Return Value 
    HidP_SetData returns the following error codes.  The report packet will 
        have all the data set up until the HIDP_DATA structure that caused the 
        error.  DataLength, in the error case, will return this problem index. 
 
· HIDP_STATUS_SUCCESS                -- upon successful insertion of all data 
                                        into the report packet. 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_DATA_INDEX_NOT_FOUND   -- if a HIDP_DATA structure referenced a 
                                        data index that does not exist for this 
                                        device's ReportType 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not equal 
                                        to the length specified in HIDP_CAPS 
                                        structure for the given ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
· HIDP_STATUS_IS_USAGE_VALUE_ARRAY   -- if one of the HIDP_DATA structures 
                                        references a usage value array. 
                                        DataLength will contain the index into 
                                        the array that was invalid 
· HIDP_STATUS_BUTTON_NOT_PRESSED     -- if a HIDP_DATA structure attempted 
                                        to unset a button that was not already 
                                        set in the Report 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- a HIDP_DATA structure was found with 
                                        a valid index value but is contained 
                                        in a different report than the one 
                                        currently being processed 
· HIDP_STATUS_BUFFER_TOO_SMALL       -- if there are not enough entries in 
                                        a given Main Array Item to report all 
                                        buttons that have been requested to be 
                                        set 
--*/ 
 
NTSTATUS __stdcall 
HidP_GetData ( 
   IN       HIDP_REPORT_TYPE      ReportType, 
   OUT      PHIDP_DATA            DataList, 
   IN OUT   PULONG                DataLength, 
   IN       PHIDP_PREPARSED_DATA  PreparsedData, 
   IN       PCHAR                 Report, 
   IN       ULONG                 ReportLength 
   ); 
/*++ 
 
Routine Description: 
 
    Please Note: For obvious reasons HidP_SetData and HidP_GetData will not 
    access UsageValueArrays. 
 
Parameters: 
    ReportType  One of HidP_Input, HidP_Output, or HidP_Feature. 
 
    DataList    Array of HIDP_DATA structures that will receive the data 
                values that are set in the given report 
 
    DataLength  As input, length in array elements of DataList.  As output, 
                contains the number of data elements that were successfully 
                set by HidP_GetData.  The maximum size necessary for DataList 
                can be determined by calling HidP_MaxDataListLength 
 
    PreparasedData  Preparsed data structure returned by HIDCLASS 
 
    Report      Buffer which to set the data into. 
 
    ReportLength Length of Report...Report should be at least as long as the 
                value indicated in the HIDP_CAPS structure for the device and 
                the corresponding ReportType 
 
Return Value 
    HidP_GetData returns the following error codes. 
 
· HIDP_STATUS_SUCCESS                -- upon successful retrieval of all data 
                                        from the report packet. 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not equal 
                                        to the length specified in HIDP_CAPS 
                                        structure for the given ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
· HIDP_STATUS_BUFFER_TOO_SMALL       -- if there are not enough array entries in 
                                        DataList to store all the indice values 
                                        in the given report.  DataLength will 
                                        contain the number of array entries 
                                        required to hold all data 
--*/ 
 
ULONG __stdcall 
HidP_MaxDataListLength ( 
   IN HIDP_REPORT_TYPE      ReportType, 
   IN PHIDP_PREPARSED_DATA  PreparsedData 
   ); 
/*++ 
Routine Description: 
 
    This function returns the maximum length of HIDP_DATA elements that 
    HidP_GetData could return for the given report type. 
 
Parameters: 
 
    ReportType  One of HidP_Input, HidP_Output or HidP_Feature. 
 
    PreparsedData    Preparsed data structure returned by HIDCLASS 
 
Return Value: 
 
    The length of the data list array required for the HidP_GetData function 
    call.  If an error occurs (either HIDP_STATUS_INVALID_REPORT_TYPE or 
    HIDP_STATUS_INVALID_PREPARSED_DATA), this function returns 0. 
 
--*/ 
 
#define HidP_SetButtons(Rty, Up, Lco, ULi, ULe, Ppd, Rep, Rle) \ 
        HidP_SetUsages(Rty, Up, Lco, ULi, ULe, Ppd, Rep, Rle) 
 
NTSTATUS __stdcall 
HidP_SetUsages ( 
   IN       HIDP_REPORT_TYPE      ReportType, 
   IN       USAGE                 UsagePage, 
   IN       USHORT                LinkCollection, // Optional 
   IN       PUSAGE                UsageList, 
   IN OUT   PULONG                UsageLength, 
   IN       PHIDP_PREPARSED_DATA  PreparsedData, 
   IN OUT   PCHAR                 Report, 
   IN       ULONG                 ReportLength 
   ); 
/*++ 
 
Routine Description: 
    This function sets binary values (buttons) in a report.  Given an 
    initialized packet of correct length, it modifies the report packet so that 
    each element in the given list of usages has been set in the report packet. 
    For example, in an output report with 5 LED’s, each with a given usage, 
    an application could turn on any subset of these lights by placing their 
    usages in any order into the usage array (UsageList).  HidP_SetUsages would, 
    in turn, set the appropriate bit or add the corresponding byte into the 
    HID Main Array Item. 
 
    A properly initialized Report packet is one of the correct byte length, 
    and all zeros. 
 
    NOTE: A packet that has already been set with a call to a HidP_Set routine 
          can also be passed in.  This routine then sets processes the UsageList 
          in the same fashion but verifies that the ReportID already set in 
          Report matches the report ID for the given usages. 
 
Parameters: 
    ReportType  One of HidP_Input, HidP_Output or HidP_Feature. 
 
    UsagePage   All of the usages in the usage array, which HidP_SetUsages will 
                set in the report, refer to this same usage page. 
                If a client wishes to set usages in a report for multiple 
                usage pages then that client needs to make multiple calls to 
                HidP_SetUsages for each of the usage pages. 
 
    UsageList   A usage array containing the usages that HidP_SetUsages will set in 
                the report packet. 
 
    UsageLength The length of the given usage array in array elements. 
                The parser will set this value to the position in the usage 
                array where it stopped processing.  If successful, UsageLength 
                will be unchanged.  In any error condition, this parameter 
                reflects how many of the usages in the usage list have 
                actually been set by the parser.  This is useful for finding 
                the usage in the list which caused the error. 
 
    PreparsedData The preparsed data recevied from HIDCLASS 
 
    Report      The report packet. 
 
    ReportLength   Length of the given report packet...Must be equal to the 
                   value reported in the HIDP_CAPS structure for the device 
                   and corresponding report type. 
 
Return Value 
    HidP_SetUsages returns the following error codes.  On error, the report packet 
    will be correct up until the usage element that caused the error. 
 
· HIDP_STATUS_SUCCESS                -- upon successful insertion of all usages 
                                        into the report packet. 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- if a usage was found that exists in a 
                                        different report.  If the report is 
                                        zero-initialized on entry the first 
                                        usage in the list will determine which 
                                        report ID is used.  Otherwise, the 
                                        parser will verify that usage matches 
                                        the passed in report's ID 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if the usage does not exist for any 
                                        report (no matter what the report ID) 
                                        for the given report type. 
· HIDP_STATUS_BUFFER_TOO_SMALL       -- if there are not enough entries in a 
                                        given Main Array Item to list all of 
                                        the given usages.  The caller needs 
                                        to split his request into more than 
                                        one call 
--*/ 
 
#define HidP_UnsetButtons(Rty, Up, Lco, ULi, ULe, Ppd, Rep, Rle) \ 
        HidP_UnsetUsages(Rty, Up, Lco, ULi, ULe, Ppd, Rep, Rle) 
 
NTSTATUS __stdcall 
HidP_UnsetUsages ( 
   IN       HIDP_REPORT_TYPE      ReportType, 
   IN       USAGE                 UsagePage, 
   IN       USHORT                LinkCollection, // Optional 
   IN       PUSAGE                UsageList, 
   IN OUT   PULONG                UsageLength, 
   IN       PHIDP_PREPARSED_DATA  PreparsedData, 
   IN OUT   PCHAR                 Report, 
   IN       ULONG                 ReportLength 
   ); 
/*++ 
 
Routine Description: 
    This function unsets (turns off) binary values (buttons) in the report.  Given 
    an initialized packet of correct length, it modifies the report packet so 
    that each element in the given list of usages has been unset in the 
    report packet. 
 
    This function is the "undo" operation for SetUsages.  If the given usage 
    is not already set in the Report, it will return an error code of 
    HIDP_STATUS_BUTTON_NOT_PRESSED.  If the button is pressed, HidP_UnsetUsages 
    will unset the appropriate bit or remove the corresponding index value from 
    the HID Main Array Item. 
 
    A properly initialized Report packet is one of the correct byte length, 
    and all zeros.. 
 
    NOTE: A packet that has already been set with a call to a HidP_Set routine 
          can also be passed in.  This routine then processes the UsageList 
          in the same fashion but verifies that the ReportID already set in 
          Report matches the report ID for the given usages. 
 
Parameters: 
    ReportType  One of HidP_Input, HidP_Output or HidP_Feature. 
 
    UsagePage   All of the usages in the usage array, which HidP_UnsetUsages will 
                unset in the report, refer to this same usage page. 
                If a client wishes to unset usages in a report for multiple 
                usage pages then that client needs to make multiple calls to 
                HidP_UnsetUsages for each of the usage pages. 
 
    UsageList   A usage array containing the usages that HidP_UnsetUsages will 
                unset in the report packet. 
 
    UsageLength The length of the given usage array in array elements. 
                The parser will set this value to the position in the usage 
                array where it stopped processing.  If successful, UsageLength 
                will be unchanged.  In any error condition, this parameter 
                reflects how many of the usages in the usage list have 
                actually been unset by the parser.  This is useful for finding 
                the usage in the list which caused the error. 
 
    PreparsedData The preparsed data recevied from HIDCLASS 
 
    Report      The report packet. 
 
    ReportLength   Length of the given report packet...Must be equal to the 
                   value reported in the HIDP_CAPS structure for the device 
                   and corresponding report type. 
 
Return Value 
    HidP_UnsetUsages returns the following error codes.  On error, the report 
    packet will be correct up until the usage element that caused the error. 
 
· HIDP_STATUS_SUCCESS                -- upon successful "unsetting" of all usages 
                                        in the report packet. 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- if a usage was found that exists in a 
                                        different report.  If the report is 
                                        zero-initialized on entry the first 
                                        usage in the list will determine which 
                                        report ID is used.  Otherwise, the 
                                        parser will verify that usage matches 
                                        the passed in report's ID 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if the usage does not exist for any 
                                        report (no matter what the report ID) 
                                        for the given report type. 
· HIDP_STATUS_BUTTON_NOT_PRESSED     -- if a usage corresponds to a button that 
                                        is not already set in the given report 
--*/ 
 
#define HidP_GetButtons(Rty, UPa, LCo, ULi, ULe, Ppd, Rep, RLe) \ 
        HidP_GetUsages(Rty, UPa, LCo, ULi, ULe, Ppd, Rep, RLe) 
 
NTSTATUS __stdcall 
HidP_GetUsages ( 
   IN       HIDP_REPORT_TYPE     ReportType, 
   IN       USAGE                UsagePage, 
   IN       USHORT               LinkCollection, // Optional 
   OUT      USAGE *              UsageList, 
   IN OUT   ULONG *              UsageLength, 
   IN       PHIDP_PREPARSED_DATA PreparsedData, 
   IN       PCHAR                Report, 
   IN       ULONG                ReportLength 
   ); 
/*++ 
 
Routine Description: 
    This function returns the binary values (buttons) that are set in a HID 
    report.  Given a report packet of correct length, it searches the report 
    packet for each usage for the given usage page and returns them in the 
    usage list. 
 
Parameters: 
    ReportType One of HidP_Input, HidP_Output or HidP_Feature. 
 
    UsagePage  All of the usages in the usage list, which HidP_GetUsages will 
               retrieve in the report, refer to this same usage page. 
               If the client wishes to get usages in a packet for multiple 
               usage pages then that client needs to make multiple calls 
               to HidP_GetUsages. 
 
    LinkCollection  An optional value which can limit which usages are returned 
                    in the UsageList to those usages that exist in a specific 
                    LinkCollection.  A non-zero value indicates the index into 
                    the HIDP_LINK_COLLECITON_NODE list returned by 
                    HidP_GetLinkCollectionNodes of the link collection the 
                    usage should belong to.  A value of 0 indicates this 
                    should value be ignored. 
 
    UsageList  The usage array that will contain all the usages found in 
               the report packet. 
 
    UsageLength The length of the given usage array in array elements. 
                On input, this value describes the length of the usage list. 
                On output, HidP_GetUsages sets this value to the number of 
                usages that was found.  Use HidP_MaxUsageListLength to 
                determine the maximum length needed to return all the usages 
                that a given report packet may contain. 
 
    PreparsedData Preparsed data structure returned by HIDCLASS 
 
    Report       The report packet. 
 
    ReportLength  Length (in bytes) of the given report packet 
 
 
Return Value 
    HidP_GetUsages returns the following error codes: 
 
· HIDP_STATUS_SUCCESS                -- upon successfully retrieving all the 
                                        usages from the report packet 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
· HIDP_STATUS_BUFFER_TOO_SMALL       -- if the UsageList is not big enough to 
                                        hold all the usages found in the report 
                                        packet.  If this is returned, the buffer 
                                        will contain UsageLength number of 
                                        usages.  Use HidP_MaxUsageListLength to 
                                        find the maximum length needed 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- if no usages were found but usages 
                                        that match the UsagePage and 
                                        LinkCollection specified could be found 
                                        in a report with a different report ID 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if there are no usages in a reports for 
                                        the device and ReportType that match the 
                                        UsagePage and LinkCollection that were 
                                        specified 
--*/ 
 
#define HidP_GetButtonsEx(Rty, LCo, BLi, ULe, Ppd, Rep, RLe)  \ 
        HidP_GetUsagesEx(Rty, LCo, BLi, ULe, Ppd, Rep, RLe) 
 
NTSTATUS __stdcall 
HidP_GetUsagesEx ( 
   IN       HIDP_REPORT_TYPE     ReportType, 
   IN       USHORT               LinkCollection, // Optional 
   OUT      PUSAGE_AND_PAGE      ButtonList, 
   IN OUT   ULONG *              UsageLength, 
   IN       PHIDP_PREPARSED_DATA PreparsedData, 
   IN       PCHAR                Report, 
   IN       ULONG                ReportLength 
   ); 
 
/*++ 
 
Routine Description: 
    This function returns the binary values (buttons) in a HID report. 
    Given a report packet of correct length, it searches the report packet 
    for all buttons and returns the UsagePage and Usage for each of the buttons 
    it finds. 
 
Parameters: 
    ReportType  One of HidP_Input, HidP_Output or HidP_Feature. 
 
    LinkCollection  An optional value which can limit which usages are returned 
                    in the ButtonList to those usages that exist in a specific 
                    LinkCollection.  A non-zero value indicates the index into 
                    the HIDP_LINK_COLLECITON_NODE list returned by 
                    HidP_GetLinkCollectionNodes of the link collection the 
                    usage should belong to.  A value of 0 indicates this 
                    should value be ignored. 
 
    ButtonList  An array of USAGE_AND_PAGE structures describing all the 
                buttons currently ``down'' in the device. 
 
    UsageLength The length of the given array in terms of elements. 
                On input, this value describes the length of the list.  On 
                output, HidP_GetUsagesEx sets this value to the number of 
                usages that were found.  Use HidP_MaxUsageListLength to 
                determine the maximum length needed to return all the usages 
                that a given report packet may contain. 
 
    PreparsedData Preparsed data returned by HIDCLASS 
 
    Report       The report packet. 
 
    ReportLength Length (in bytes) of the given report packet. 
 
 
Return Value 
    HidP_GetUsagesEx returns the following error codes: 
 
· HIDP_STATUS_SUCCESS                -- upon successfully retrieving all the 
                                        usages from the report packet 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
· HIDP_STATUS_BUFFER_TOO_SMALL       -- if ButtonList is not big enough to 
                                        hold all the usages found in the report 
                                        packet.  If this is returned, the buffer 
                                        will contain UsageLength number of 
                                        usages.  Use HidP_MaxUsageListLength to 
                                        find the maximum length needed 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- if no usages were found but usages 
                                        that match the specified LinkCollection 
                                        exist in report with a different report 
                                        ID. 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if there are no usages in any reports that 
                                        match the LinkCollection parameter 
--*/ 
 
#define HidP_GetButtonListLength(RTy, UPa, Ppd) \ 
        HidP_GetUsageListLength(Rty, UPa, Ppd) 
 
ULONG __stdcall 
HidP_MaxUsageListLength ( 
   IN HIDP_REPORT_TYPE      ReportType, 
   IN USAGE                 UsagePage, // Optional 
   IN PHIDP_PREPARSED_DATA  PreparsedData 
   ); 
/*++ 
Routine Description: 
    This function returns the maximum number of usages that a call to 
    HidP_GetUsages or HidP_GetUsagesEx could return for a given HID report. 
    If calling for number of usages returned by HidP_GetUsagesEx, use 0 as 
    the UsagePage value. 
 
Parameters: 
    ReportType  One of HidP_Input, HidP_Output or HidP_Feature. 
 
    UsagePage   Specifies the optional UsagePage to query for.  If 0, will 
                return all the maximum number of usage values that could be 
                returned for a given ReportType.   If non-zero, will return 
                the maximum number of usages that would be returned for the 
                ReportType with the given UsagePage. 
 
    PreparsedData Preparsed data returned from HIDCLASS 
 
Return Value: 
    The length of the usage list array required for the HidP_GetUsages or 
    HidP_GetUsagesEx function call.  If an error occurs (such as 
    HIDP_STATUS_INVALID_REPORT_TYPE or HIDP_INVALID_PREPARSED_DATA, this 
    returns 0. 
--*/ 
 
NTSTATUS __stdcall 
HidP_SetUsageValue ( 
   IN       HIDP_REPORT_TYPE     ReportType, 
   IN       USAGE                UsagePage, 
   IN       USHORT               LinkCollection, // Optional 
   IN       USAGE                Usage, 
   IN       ULONG                UsageValue, 
   IN       PHIDP_PREPARSED_DATA PreparsedData, 
   IN OUT   PCHAR                Report, 
   IN       ULONG                ReportLength 
   ); 
/*++ 
Description: 
    HidP_SetUsageValue inserts a value into the HID Report Packet in the field 
    corresponding to the given usage page and usage.  HidP_SetUsageValue 
    casts this value to the appropriate bit length.  If a report packet 
    contains two different fields with the same Usage and UsagePage, 
    they can be distinguished with the optional LinkCollection field value. 
    Using this function sets the raw value into the report packet with 
    no checking done as to whether it actually falls within the logical 
    minimum/logical maximum range.  Use HidP_SetScaledUsageValue for this... 
 
    NOTE: Although the UsageValue parameter is a ULONG, any casting that is 
          done will preserve or sign-extend the value.  The value being set 
          should be considered a LONG value and will be treated as such by 
          this function. 
 
Parameters: 
 
    ReportType  One of HidP_Output or HidP_Feature. 
 
    UsagePage   The usage page to which the given usage refers. 
 
    LinkCollection  (Optional)  This value can be used to differentiate 
                                between two fields that may have the same 
                                UsagePage and Usage but exist in different 
                                collections.  If the link collection value 
                                is zero, this function will set the first field 
                                it finds that matches the usage page and 
                                usage. 
 
    Usage       The usage whose value HidP_SetUsageValue will set. 
 
    UsageValue  The raw value to set in the report buffer.  This value must be within 
                the logical range or if a NULL value this value should be the 
                most negative value that can be represented by the number of bits 
                for this field. 
 
    PreparsedData The preparsed data returned for HIDCLASS 
 
    Report      The report packet. 
 
    ReportLength Length (in bytes) of the given report packet. 
 
 
Return Value: 
    HidP_SetUsageValue returns the following error codes: 
 
· HIDP_STATUS_SUCCESS                -- upon successfully setting the value 
                                        in the report packet 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- the specified usage page, usage and 
                                        link collection exist but exists in 
                                        a report with a different report ID 
                                        than the report being passed in.  To 
                                        set this value, call HidP_SetUsageValue 
                                        again with a zero-initizialed report 
                                        packet 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if the usage page, usage, and link 
                                        collection combination does not exist 
                                        in any reports for this ReportType 
--*/ 
 
NTSTATUS __stdcall 
HidP_SetScaledUsageValue ( 
   IN       HIDP_REPORT_TYPE     ReportType, 
   IN       USAGE                UsagePage, 
   IN       USHORT               LinkCollection, // Optional 
   IN       USAGE                Usage, 
   IN       LONG                 UsageValue, 
   IN       PHIDP_PREPARSED_DATA PreparsedData, 
   IN OUT   PCHAR                Report, 
   IN       ULONG                ReportLength 
   ); 
 
/*++ 
Description: 
    HidP_SetScaledUsageValue inserts the UsageValue into the HID report packet 
    in the field corresponding to the given usage page and usage.  If a report 
    packet contains two different fields with the same Usage and UsagePage, 
    they can be distinguished with the optional LinkCollection field value. 
 
    If the specified field has a defined physical range, this function converts 
    the physical value specified to the corresponding logical value for the 
    report.  If a physical value does not exist, the function will verify that 
    the value specified falls within the logical range and set according. 
 
    If the range checking fails but the field has NULL values, the function will 
    set the field to the defined NULL value (most negative number possible) and 
    return HIDP_STATUS_NULL.  In other words, use this function to set NULL 
    values for a given field by passing in a value that falls outside the 
    physical range if it is defined or the logical range otherwise. 
 
    If the field does not support NULL values, an out of range error will be 
    returned instead. 
 
Parameters: 
 
    ReportType  One of HidP_Output or HidP_Feature. 
 
    UsagePage   The usage page to which the given usage refers. 
 
    LinkCollection  (Optional)  This value can be used to differentiate 
                                between two fields that may have the same 
                                UsagePage and Usage but exist in different 
                                collections.  If the link collection value 
                                is zero, this function will set the first field 
                                it finds that matches the usage page and 
                                usage. 
 
    Usage       The usage whose value HidP_SetScaledUsageValue will set. 
 
    UsageValue  The value to set in the report buffer.  See the routine 
                description above for the different interpretations of this 
                value 
 
    PreparsedData The preparsed data returned from HIDCLASS 
 
    Report      The report packet. 
 
    ReportLength Length (in bytes) of the given report packet. 
 
 
Return Value: 
   HidP_SetScaledUsageValue returns the following error codes: 
 
· HIDP_STATUS_SUCCESS                -- upon successfully setting the value 
                                        in the report packet 
· HIDP_STATUS_NULL                   -- upon successfully setting the value 
                                        in the report packet as a NULL value 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_VALUE_OUT_OF_RANGE     -- if the value specified failed to fall 
                                        within the physical range if it exists 
                                        or within the logical range otherwise 
                                        and the field specified by the usage 
                                        does not allow NULL values 
· HIDP_STATUS_BAD_LOG_PHY_VALUES     -- if the field has a physical range but 
                                        either the logical range is invalid 
                                        (max <= min) or the physical range is 
                                        invalid 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- the specified usage page, usage and 
                                        link collection exist but exists in 
                                        a report with a different report ID 
                                        than the report being passed in.  To 
                                        set this value, call 
                                        HidP_SetScaledUsageValue again with 
                                        a zero-initialized report packet 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if the usage page, usage, and link 
                                        collection combination does not exist 
                                        in any reports for this ReportType 
--*/ 
 
NTSTATUS __stdcall 
HidP_SetUsageValueArray ( 
    IN    HIDP_REPORT_TYPE     ReportType, 
    IN    USAGE                UsagePage, 
    IN    USHORT               LinkCollection, // Optional 
    IN    USAGE                Usage, 
    IN    PCHAR                UsageValue, 
    IN    USHORT               UsageValueByteLength, 
    IN    PHIDP_PREPARSED_DATA PreparsedData, 
    OUT   PCHAR                Report, 
    IN    ULONG                ReportLength 
    ); 
 
/*++ 
Routine Descripton: 
    A usage value array occurs when the last usage in the list of usages 
    describing a main item must be repeated because there are less usages defined 
    than there are report counts declared for the given main item.  In this case 
    a single value cap is allocated for that usage and the report count of that 
    value cap is set to reflect the number of fields to which that usage refers. 
 
    HidP_SetUsageValueArray sets the raw bits for that usage which spans 
    more than one field in a report. 
 
    NOTE: This function currently does not support value arrays where the 
          ReportSize for each of the fields in the array is not a multiple 
          of 8 bits. 
 
          The UsageValue buffer should have the values set as they would appear 
          in the report buffer.  If this function supported non 8-bit multiples 
          for the ReportSize then caller should format the input buffer so that 
          each new value begins at the bit immediately following the last bit 
          of the previous value 
 
Parameters: 
 
    ReportType  One of HidP_Output or HidP_Feature. 
 
    UsagePage   The usage page to which the given usage refers. 
 
    LinkCollection  (Optional)  This value can be used to differentiate 
                                between two fields that may have the same 
                                UsagePage and Usage but exist in different 
                                collections.  If the link collection value 
                                is zero, this function will set the first field 
                                it finds that matches the usage page and 
                                usage. 
 
    Usage       The usage whose value array HidP_SetUsageValueArray will set. 
 
    UsageValue  The buffer with the values to set into the value array. 
                The number of BITS required is found by multiplying the 
                BitSize and ReportCount fields of the Value Cap for this 
                control.  The least significant bit of this control found in the 
                given report will be placed in the least significan bit location 
                of the array given (little-endian format), regardless of whether 
                or not the field is byte alligned or if the BitSize is a multiple 
                of sizeof (CHAR). 
 
                See the above note for current implementation limitations. 
 
    UsageValueByteLength  Length of the UsageValue buffer (in bytes) 
 
    PreparsedData The preparsed data returned from HIDCLASS 
 
    Report      The report packet. 
 
    ReportLength Length (in bytes) of the given report packet. 
 
 
Return Value: 
· HIDP_STATUS_SUCCESS                -- upon successfully setting the value 
                                        array in the report packet 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
· HIDP_STATUS_NOT_VALUE_ARRAY        -- if the control specified is not a 
                                        value array -- a value array will have 
                                        a ReportCount field in the 
                                        HIDP_VALUE_CAPS structure that is > 1 
                                        Use HidP_SetUsageValue instead 
· HIDP_STATUS_BUFFER_TOO_SMALL       -- if the size of the passed in buffer with 
                                        the values to set is too small (ie. has 
                                        fewer values than the number of fields in 
                                        the array 
· HIDP_STATUS_NOT_IMPLEMENTED        -- if the usage value array has field sizes 
                                        that are not multiples of 8 bits, this 
                                        error code is returned since the function 
                                        currently does not handle setting into 
                                        such arrays. 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- the specified usage page, usage and 
                                        link collection exist but exists in 
                                        a report with a different report ID 
                                        than the report being passed in.  To 
                                        set this value, call 
                                        HidP_SetUsageValueArray again with 
                                        a zero-initialized report packet 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if the usage page, usage, and link 
                                        collection combination does not exist 
                                        in any reports for this ReportType 
--*/ 
 
 
NTSTATUS __stdcall 
HidP_GetUsageValue ( 
   IN    HIDP_REPORT_TYPE     ReportType, 
   IN    USAGE                UsagePage, 
   IN    USHORT               LinkCollection, // Optional 
   IN    USAGE                Usage, 
   OUT   PULONG               UsageValue, 
   IN    PHIDP_PREPARSED_DATA PreparsedData, 
   IN    PCHAR                Report, 
   IN    ULONG                ReportLength 
   ); 
 
/* 
Description 
    HidP_GetUsageValue retrieves the value from the HID Report for the usage 
    specified by the combination of usage page, usage and link collection. 
    If a report packet contains two different fields with the same 
    Usage and UsagePage, they can be distinguished with the optional 
    LinkCollection field value. 
 
Parameters: 
 
    ReportType  One of HidP_Input or HidP_Feature. 
 
    UsagePage   The usage page to which the given usage refers. 
 
    LinkCollection  (Optional)  This value can be used to differentiate 
                                between two fields that may have the same 
                                UsagePage and Usage but exist in different 
                                collections.  If the link collection value 
                                is zero, this function will set the first field 
                                it finds that matches the usage page and 
                                usage. 
 
    Usage       The usage whose value HidP_GetUsageValue will retrieve 
 
    UsageValue  The raw value that is set for the specified field in the report 
                buffer. This value will either fall within the logical range 
                or if NULL values are allowed, a number outside the range to 
                indicate a NULL 
 
    PreparsedData The preparsed data returned for HIDCLASS 
 
    Report      The report packet. 
 
    ReportLength Length (in bytes) of the given report packet. 
 
 
Return Value: 
    HidP_GetUsageValue returns the following error codes: 
 
· HIDP_STATUS_SUCCESS                -- upon successfully retrieving the value 
                                        from the report packet 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_REPORT_DOES_NOT_EXIST  -- if there are no reports on this device 
                                        for the given ReportType 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- the specified usage page, usage and 
                                        link collection exist but exists in 
                                        a report with a different report ID 
                                        than the report being passed in.  To 
                                        set this value, call HidP_GetUsageValue 
                                        again with a different report packet 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if the usage page, usage, and link 
                                        collection combination does not exist 
                                        in any reports for this ReportType 
--*/ 
 
 
NTSTATUS __stdcall 
HidP_GetScaledUsageValue ( 
   IN    HIDP_REPORT_TYPE     ReportType, 
   IN    USAGE                UsagePage, 
   IN    USHORT               LinkCollection, // Optional 
   IN    USAGE                Usage, 
   OUT   PLONG                UsageValue, 
   IN    PHIDP_PREPARSED_DATA PreparsedData, 
   IN    PCHAR                Report, 
   IN    ULONG                ReportLength 
   ); 
 
/*++ 
Description 
    HidP_GetScaledUsageValue retrieves a UsageValue from the HID report packet 
    in the field corresponding to the given usage page and usage.  If a report 
    packet contains two different fields with the same Usage and UsagePage, 
    they can be distinguished with the optional LinkCollection field value. 
 
    If the specified field has a defined physical range, this function converts 
    the logical value that exists in the report packet to the corresponding 
    physical value.  If a physical range does not exist, the function will 
    return the logical value.  This function will check to verify that the 
    logical value in the report falls within the declared logical range. 
 
    When doing the conversion between logical and physical values, this 
    function assumes a linear extrapolation between the physical max/min and 
    the logical max/min. (Where logical is the values reported by the device 
    and physical is the value returned by this function).  If the data field 
    size is less than 32 bits, then HidP_GetScaledUsageValue will sign extend 
    the value to 32 bits. 
 
    If the range checking fails but the field has NULL values, the function 
    will set UsageValue to 0 and return HIDP_STATUS_NULL.  Otherwise, it 
    returns a HIDP_STATUS_OUT_OF_RANGE error. 
 
Parameters: 
 
    ReportType  One of HidP_Output or HidP_Feature. 
 
    UsagePage   The usage page to which the given usage refers. 
 
    LinkCollection  (Optional)  This value can be used to differentiate 
                                between two fields that may have the same 
                                UsagePage and Usage but exist in different 
                                collections.  If the link collection value 
                                is zero, this function will retrieve the first 
                                field it finds that matches the usage page 
                                and usage. 
 
    Usage       The usage whose value HidP_GetScaledUsageValue will retrieve 
 
    UsageValue  The value retrieved from the report buffer.  See the routine 
                description above for the different interpretations of this 
                value 
 
    PreparsedData The preparsed data returned from HIDCLASS 
 
    Report      The report packet. 
 
    ReportLength Length (in bytes) of the given report packet. 
 
 
Return Value: 
   HidP_GetScaledUsageValue returns the following error codes: 
 
· HIDP_STATUS_SUCCESS                -- upon successfully retrieving the value 
                                        from the report packet 
· HIDP_STATUS_NULL                   -- if the report packet had a NULL value 
                                        set 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_VALUE_OUT_OF_RANGE     -- if the value retrieved from the packet 
                                        falls outside the logical range and 
                                        the field does not support NULL values 
· HIDP_STATUS_BAD_LOG_PHY_VALUES     -- if the field has a physical range but 
                                        either the logical range is invalid 
                                        (max <= min) or the physical range is 
                                        invalid 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- the specified usage page, usage and 
                                        link collection exist but exists in 
                                        a report with a different report ID 
                                        than the report being passed in.  To 
                                        set this value, call 
                                        HidP_GetScaledUsageValue with a 
                                        different report packet 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if the usage page, usage, and link 
                                        collection combination does not exist 
                                        in any reports for this ReportType 
--*/ 
 
NTSTATUS __stdcall 
HidP_GetUsageValueArray ( 
    IN    HIDP_REPORT_TYPE     ReportType, 
    IN    USAGE                UsagePage, 
    IN    USHORT               LinkCollection, // Optional 
    IN    USAGE                Usage, 
    OUT   PCHAR                UsageValue, 
    IN    USHORT               UsageValueByteLength, 
    IN    PHIDP_PREPARSED_DATA PreparsedData, 
    IN    PCHAR                Report, 
    IN    ULONG                ReportLength 
    ); 
 
/*++ 
Routine Descripton: 
    A usage value array occurs when the last usage in the list of usages 
    describing a main item must be repeated because there are less usages defined 
    than there are report counts declared for the given main item.  In this case 
    a single value cap is allocated for that usage and the report count of that 
    value cap is set to reflect the number of fields to which that usage refers. 
 
    HidP_GetUsageValueArray returns the raw bits for that usage which spans 
    more than one field in a report. 
 
    NOTE: This function currently does not support value arrays where the 
          ReportSize for each of the fields in the array is not a multiple 
          of 8 bits. 
 
          The UsageValue buffer will have the raw values as they are set 
          in the report packet. 
 
Parameters: 
 
    ReportType  One of HidP_Input, HidP_Output or HidP_Feature. 
 
    UsagePage   The usage page to which the given usage refers. 
 
    LinkCollection  (Optional)  This value can be used to differentiate 
                                between two fields that may have the same 
                                UsagePage and Usage but exist in different 
                                collections.  If the link collection value 
                                is zero, this function will set the first field 
                                it finds that matches the usage page and 
                                usage. 
 
   Usage       The usage whose value HidP_GetUsageValueArray will retreive. 
 
   UsageValue  A pointer to an array of characters where the value will be 
               placed.  The number of BITS required is found by multiplying the 
               BitSize and ReportCount fields of the Value Cap for this 
               control.  The least significant bit of this control found in the 
               given report will be placed in the least significant bit location 
               of the buffer (little-endian format), regardless of whether 
               or not the field is byte aligned or if the BitSize is a multiple 
               of sizeof (CHAR). 
 
               See note above about current implementation limitations 
 
   UsageValueByteLength 
               the length of the given UsageValue buffer. 
 
   PreparsedData The preparsed data returned by the HIDCLASS 
 
   Report      The report packet. 
 
   ReportLength   Length of the given report packet. 
 
Return Value: 
 
· HIDP_STATUS_SUCCESS                -- upon successfully retrieving the value 
                                        from the report packet 
· HIDP_STATUS_INVALID_REPORT_TYPE    -- if ReportType is not valid. 
· HIDP_STATUS_INVALID_PREPARSED_DATA -- if PreparsedData is not valid 
· HIDP_STATUS_INVALID_REPORT_LENGTH  -- the length of the report packet is not 
                                        equal to the length specified in 
                                        the HIDP_CAPS structure for the given 
                                        ReportType 
· HIDP_STATUS_NOT_VALUE_ARRAY        -- if the control specified is not a 
                                        value array -- a value array will have 
                                        a ReportCount field in the 
                                        HIDP_VALUE_CAPS structure that is > 1 
                                        Use HidP_GetUsageValue instead 
· HIDP_STATUS_BUFFER_TOO_SMALL       -- if the size of the passed in buffer in 
                                        which to return the array is too small 
                                        (ie. has fewer values than the number of 
                                        fields in the array 
· HIDP_STATUS_NOT_IMPLEMENTED        -- if the usage value array has field sizes 
                                        that are not multiples of 8 bits, this 
                                        error code is returned since the function 
                                        currently does not handle getting values 
                                        from such arrays. 
· HIDP_STATUS_INCOMPATIBLE_REPORT_ID -- the specified usage page, usage and 
                                        link collection exist but exists in 
                                        a report with a different report ID 
                                        than the report being passed in.  To 
                                        set this value, call 
                                        HidP_GetUsageValueArray with a 
                                        different report packet 
· HIDP_STATUS_USAGE_NOT_FOUND        -- if the usage page, usage, and link 
                                        collection combination does not exist 
                                        in any reports for this ReportType 
--*/ 
 
NTSTATUS __stdcall 
HidP_UsageListDifference ( 
    IN    PUSAGE   PreviousUsageList, 
    IN    PUSAGE   CurrentUsageList, 
    OUT   PUSAGE   BreakUsageList, 
    OUT   PUSAGE   MakeUsageList, 
    IN    ULONG    UsageListLength 
    ); 
/*++ 
Routine Description: 
    This function will return the difference between a two lists of usages 
    (as might be returned from HidP_GetUsages),  In other words, it will return 
    return a list of usages that are in the current list but not the previous 
    list as well as a list of usages that are in the previous list but not 
    the current list. 
 
Parameters: 
 
    PreviousUsageList   The list of usages before. 
    CurrentUsageList    The list of usages now. 
    BreakUsageList      Previous - Current. 
    MakeUsageList       Current - Previous. 
    UsageListLength     Represents the length of the usage lists in array 
                        elements.  If comparing two lists with a differing 
                        number of array elements, this value should be 
                        the size of the larger of the two lists.  Any 
                        zero found with a list indicates an early termination 
                        of the list and any usages found after the first zero 
                        will be ignored. 
--*/ 
 
NTSTATUS __stdcall 
HidP_UsageAndPageListDifference ( 
   IN    PUSAGE_AND_PAGE PreviousUsageList, 
   IN    PUSAGE_AND_PAGE CurrentUsageList, 
   OUT   PUSAGE_AND_PAGE BreakUsageList, 
   OUT   PUSAGE_AND_PAGE MakeUsageList, 
   IN    ULONG           UsageListLength 
   ); 
 
// 
// Produce Make or Break Codes 
// 
typedef enum _HIDP_KEYBOARD_DIRECTION { 
    HidP_Keyboard_Break, 
    HidP_Keyboard_Make 
} HIDP_KEYBOARD_DIRECTION; 
 
// 
// A bitmap of the current shift state of the keyboard when using the 
// below keyboard usages to i8042 translation function. 
// 
typedef struct _HIDP_KEYBOARD_MODIFIER_STATE { 
   union { 
      struct { 
         ULONG LeftControl: 1; 
         ULONG LeftShift: 1; 
         ULONG LeftAlt: 1; 
         ULONG LeftGUI: 1; 
         ULONG RightControl: 1; 
         ULONG RightShift: 1; 
         ULONG RightAlt: 1; 
         ULONG RigthGUI: 1; 
         ULONG CapsLock: 1; 
         ULONG ScollLock: 1; 
         ULONG NumLock: 1; 
         ULONG Reserved: 21; 
      }; 
      ULONG ul; 
   }; 
 
} HIDP_KEYBOARD_MODIFIER_STATE, * PHIDP_KEYBOARD_MODIFIER_STATE; 
 
// 
// A call back function to give the i8042 scan codes to the caller of 
// the below translation function. 
// 
typedef BOOLEAN (* PHIDP_INSERT_SCANCODES) ( 
                  IN PVOID Context,  // Some caller supplied context. 
                  IN PCHAR NewScanCodes, // A list of i8042 scan codes. 
                  IN ULONG Length // the length of the scan codes. 
                  ); 
 
NTSTATUS __stdcall 
HidP_TranslateUsageAndPagesToI8042ScanCodes ( 
    IN     PUSAGE_AND_PAGE               ChangedUsageList, 
    IN     ULONG                         UsageListLength, 
    IN     HIDP_KEYBOARD_DIRECTION       KeyAction, 
    IN OUT PHIDP_KEYBOARD_MODIFIER_STATE ModifierState, 
    IN     PHIDP_INSERT_SCANCODES        InsertCodesProcedure, 
    IN     PVOID                         InsertCodesContext 
    ); 
/*++ 
Routine Description: 
Parameters: 
--*/ 
 
NTSTATUS __stdcall 
HidP_TranslateUsagesToI8042ScanCodes ( 
    IN     PUSAGE                        ChangedUsageList, 
    IN     ULONG                         UsageListLength, 
    IN     HIDP_KEYBOARD_DIRECTION       KeyAction, 
    IN OUT PHIDP_KEYBOARD_MODIFIER_STATE ModifierState, 
    IN     PHIDP_INSERT_SCANCODES        InsertCodesProcedure, 
    IN     PVOID                         InsertCodesContext 
    ); 
/*++ 
Routine Description: 
Parameters: 
--*/ 
 
 
 
// 
// Define NT Status codes with Facility Code of FACILITY_HID_ERROR_CODE 
// 
 
// FACILITY_HID_ERROR_CODE defined in ntstatus.h 
#ifndef FACILITY_HID_ERROR_CODE 
#define FACILITY_HID_ERROR_CODE 0x11 
#endif 
 
#define HIDP_ERROR_CODES(SEV, CODE) \ 
        ((NTSTATUS) (((SEV) << 28) | (FACILITY_HID_ERROR_CODE << 16) | (CODE))) 
 
#define HIDP_STATUS_SUCCESS                  (HIDP_ERROR_CODES(0x0,0)) 
#define HIDP_STATUS_NULL                     (HIDP_ERROR_CODES(0x8,1)) 
#define HIDP_STATUS_INVALID_PREPARSED_DATA   (HIDP_ERROR_CODES(0xC,1)) 
#define HIDP_STATUS_INVALID_REPORT_TYPE      (HIDP_ERROR_CODES(0xC,2)) 
#define HIDP_STATUS_INVALID_REPORT_LENGTH    (HIDP_ERROR_CODES(0xC,3)) 
#define HIDP_STATUS_USAGE_NOT_FOUND          (HIDP_ERROR_CODES(0xC,4)) 
#define HIDP_STATUS_VALUE_OUT_OF_RANGE       (HIDP_ERROR_CODES(0xC,5)) 
#define HIDP_STATUS_BAD_LOG_PHY_VALUES       (HIDP_ERROR_CODES(0xC,6)) 
#define HIDP_STATUS_BUFFER_TOO_SMALL         (HIDP_ERROR_CODES(0xC,7)) 
#define HIDP_STATUS_INTERNAL_ERROR           (HIDP_ERROR_CODES(0xC,8)) 
#define HIDP_STATUS_I8042_TRANS_UNKNOWN      (HIDP_ERROR_CODES(0xC,9)) 
#define HIDP_STATUS_INCOMPATIBLE_REPORT_ID   (HIDP_ERROR_CODES(0xC,0xA)) 
#define HIDP_STATUS_NOT_VALUE_ARRAY          (HIDP_ERROR_CODES(0xC,0xB)) 
#define HIDP_STATUS_IS_VALUE_ARRAY           (HIDP_ERROR_CODES(0xC,0xC)) 
#define HIDP_STATUS_DATA_INDEX_NOT_FOUND     (HIDP_ERROR_CODES(0xC,0xD)) 
#define HIDP_STATUS_DATA_INDEX_OUT_OF_RANGE  (HIDP_ERROR_CODES(0xC,0xE)) 
#define HIDP_STATUS_BUTTON_NOT_PRESSED       (HIDP_ERROR_CODES(0xC,0xF)) 
#define HIDP_STATUS_REPORT_DOES_NOT_EXIST    (HIDP_ERROR_CODES(0xC,0x10)) 
#define HIDP_STATUS_NOT_IMPLEMENTED          (HIDP_ERROR_CODES(0xC,0x20)) 
 
// 
// We blundered this status code. 
// 
#define HIDP_STATUS_I8242_TRANS_UNKNOWN HIDP_STATUS_I8042_TRANS_UNKNOWN 
 
#include  
 
#endif