1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

Merge pull request #17242 from bergzand/pr/hid/add_descriptor_defines

usb/hid: Add HID report descriptor defines
This commit is contained in:
benpicco 2022-01-10 12:28:01 +01:00 committed by GitHub
commit f33b3ad10d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 3162 additions and 32 deletions

View File

@ -19,6 +19,7 @@
#include "xtimer.h"
#include "usb/usbus.h"
#include "usb/usbus/hid.h"
#include "usb/usbus/hid_io.h"
#include "fido2/ctap.h"
@ -34,22 +35,22 @@
* CTAP specification (version 20190130) section 8.1.8.2
*/
const uint8_t _hid_report_desc[] = {
0x06, 0xD0, 0xF1, /**< HID_UsagePage ( FIDO_USAGE_PAGE ) */
0x09, 0x01, /**< HID_Usage ( FIDO_USAGE_CTAPHID ) */
0xA1, 0x01, /**< HID_Collection ( HID_Application ) */
0x09, 0x20, /**< HID_Usage ( FIDO_USAGE_DATA_IN ) */
0x15, 0x00, /**< HID_LogicalMin ( 0 ) */
0x26, 0xFF, 0x00, /**< HID_LogicalMaxS ( 0xff ) */
0x75, 0x08, /**< HID_ReportSize ( 8 ) */
0x95, 0x40, /**< HID_ReportCount ( HID_INPUT_REPORT_BYTES ) */
0x81, 0x02, /**< HID_Input ( HID_Data | HID_Absolute | HID_Variable ) */
0x09, 0x21, /**< HID_Usage ( FIDO_USAGE_DATA_OUT ) */
0x15, 0x00, /**< HID_LogicalMin ( 0 ) */
0x26, 0xFF, 0x00, /**< HID_LogicalMaxS ( 0xff ) */
0x75, 0x08, /**< HID_ReportSize ( 8 ) */
0x95, 0x40, /**< HID_ReportCount ( HID_OUTPUT_REPORT_BYTES ) */
0x91, 0x02, /**< HID_Output ( HID_Data | HID_Absolute | HID_Variable ) */
0xC0, /**< HID_EndCollection */
USB_HID_USAGE_PAGE16(USB_HID_USAGE_FIDO),
USB_HID_USAGE(USB_HID_USAGE_FIDO_U2F_AUTHENTICATOR_DEVICE),
USB_HID_COLLECTION(USB_HID_COLLECTION_APPLICATION),
USB_HID_USAGE(USB_HID_USAGE_FIDO_INPUT_REPORT_DATA),
USB_HID_LOGICAL_MIN8(0),
USB_HID_LOGICAL_MAX16(255),
USB_HID_REPORT_SIZE(8),
USB_HID_REPORT_COUNT(CONFIG_USBUS_HID_INTERRUPT_EP_SIZE),
USB_HID_INPUT(0x02),
USB_HID_USAGE(USB_HID_USAGE_FIDO_OUTPUT_REPORT_DATA),
USB_HID_LOGICAL_MIN8(0),
USB_HID_LOGICAL_MAX16(255),
USB_HID_REPORT_SIZE(8),
USB_HID_REPORT_COUNT(CONFIG_USBUS_HID_INTERRUPT_EP_SIZE),
USB_HID_OUTPUT(0x02),
USB_HID_END_COLLECTION,
};
/**

View File

@ -24,6 +24,8 @@
#include <stdint.h>
#include "usb/hid/hid_usage.h"
#ifdef __cplusplus
extern "C" {
#endif
@ -103,6 +105,400 @@ typedef struct __attribute__((packed)){
uint16_t report_length; /**< the total size of the Report descriptor. */
} usb_desc_hid_t;
/**
* @defgroup usb_hid_descriptor USB HID descriptor helpers
* @ingroup usb_hid
*
* @brief USB HID descriptor format helpers
* @{
*/
/**
* @brief HID Main item type
*/
#define USB_HID_ITEM_TYPE_MAIN 0x0
/**
* @brief HID Global item type
*/
#define USB_HID_ITEM_TYPE_GLOBAL 0x1
/**
* @brief HID Local item type
*/
#define USB_HID_ITEM_TYPE_LOCAL 0x2
/**
* @brief HID Input item tag
*/
#define USB_HID_ITEM_TAG_INPUT 0x8
/**
* @brief HID Output item tag
*/
#define USB_HID_ITEM_TAG_OUTPUT 0x9
/**
* @brief HID Collection item tag
*/
#define USB_HID_ITEM_TAG_COLLECTION 0xA
/**
* @brief HID Feature item tag
*/
#define USB_HID_ITEM_TAG_FEATURE 0xB
/**
* @brief HID End Collection item tag
*/
#define USB_HID_ITEM_TAG_COLLECTION_END 0xC
/**
* @brief HID Usage Page item tag
*/
#define USB_HID_ITEM_TAG_USAGE_PAGE 0x0
/**
* @brief HID Logical Minimum item tag
*/
#define USB_HID_ITEM_TAG_LOGICAL_MIN 0x1
/**
* @brief HID Logical Maximum item tag
*/
#define USB_HID_ITEM_TAG_LOGICAL_MAX 0x2
/**
* @brief HID Physical Minimum item tag
*/
#define USB_HID_ITEM_TAG_PHYSICAL_MIN 0x3
/**
* @brief HID Physical Maximum item tag
*/
#define USB_HID_ITEM_TAG_PHYSICAL_MAX 0x4
/**
* @brief HID Unit Exponent item tag
*/
#define USB_HID_ITEM_TAG_UNIT_EXPONENT 0x5
/**
* @brief HID Unit item tag
*/
#define USB_HID_ITEM_TAG_UNIT 0x6
/**
* @brief HID Report Size item tag
*/
#define USB_HID_ITEM_TAG_REPORT_SIZE 0x7
/**
* @brief HID Report ID item tag
*/
#define USB_HID_ITEM_TAG_REPORT_ID 0x8
/**
* @brief HID Report count item tag
*/
#define USB_HID_ITEM_TAG_REPORT_COUNT 0x9
/**
* @brief HID Usage item tag
*/
#define USB_HID_ITEM_TAG_USAGE 0x0
/**
* @brief HID Usage Minimum item tag
*/
#define USB_HID_ITEM_TAG_USAGE_MIN 0x1
/**
* @brief HID Usage Maximum item tag
*/
#define USB_HID_ITEM_TAG_USAGE_MAX 0x2
/**
* @brief Physical collection type
*/
#define USB_HID_COLLECTION_PHYSICAL 0x00
/**
* @brief Application collection type
*/
#define USB_HID_COLLECTION_APPLICATION 0x01
/**
* @brief Logical (interrelated data) collection type
*/
#define USB_HID_COLLECTION_LOGICAL 0x02
/**
* @brief Report collection type
*/
#define USB_HID_COLLECTION_REPORT 0x03
/**
* @brief Named array collection type
*/
#define USB_HID_COLLECTION_NAMED_ARRAY 0x04
/**
* @brief Usage switch collection type
*/
#define USB_HID_COLLECTION_USAGE_SWITCH 0x05
/**
* @brief Modifier switch collection type
*/
#define USB_HID_COLLECTION_USAGE_MOD 0x06
/**
* @brief Defines a HID descriptor short item.
*
* @param tag Item tag
* @param type Item type
* @param size Item data size
*/
#define USB_HID_ITEM(tag, type, size) \
(((tag & 0xF) << 4) | ((type & 0x3) << 2) | (size & 0x3))
/**
* @brief Defines a HID descriptor input item.
*
* @note data length is one byte
*
* @param input Input item flags
*/
#define USB_HID_INPUT(input) \
USB_HID_ITEM(USB_HID_ITEM_TAG_INPUT, USB_HID_ITEM_TYPE_MAIN, 1), \
input
/**
* @brief Defines a HID descriptor output item.
*
* @note data length is one byte
*
* @param output Output item flags
*/
#define USB_HID_OUTPUT(output) \
USB_HID_ITEM(USB_HID_ITEM_TAG_OUTPUT, USB_HID_ITEM_TYPE_MAIN, 1), \
output
/**
* @brief Defines a HID Feature item
*
* @note data length is one byte.
*
* @param feature Feature item data
*/
#define USB_HID_FEATURE(feature) \
USB_HID_ITEM(USB_HID_ITEM_TAG_FEATURE, USB_HID_ITEM_TYPE_MAIN, 1), \
feature
/**
* @brief Defines a HID Collection item
*
* @note data length is one byte.
*
* @param collection Collection item data
*/
#define USB_HID_COLLECTION(collection) \
USB_HID_ITEM(USB_HID_ITEM_TAG_COLLECTION, USB_HID_ITEM_TYPE_MAIN, 1), \
collection
/**
* @brief Defines a HID End Collection item
*/
#define USB_HID_END_COLLECTION \
USB_HID_ITEM(USB_HID_ITEM_TAG_COLLECTION_END, USB_HID_ITEM_TYPE_MAIN, 0)
/**
* @brief Defines a HID Usage Page item.
*
* @note data length is one byte.
*
* @param page Usage Page
*/
#define USB_HID_USAGE_PAGE(page) \
USB_HID_ITEM(USB_HID_ITEM_TAG_USAGE_PAGE, USB_HID_ITEM_TYPE_GLOBAL, 1), \
page
/**
* @brief Defines a HID Usage Page item.
*
* @note data length is two bytes.
*
* @param page Usage page
*/
#define USB_HID_USAGE_PAGE16(page) \
USB_HID_ITEM(USB_HID_ITEM_TAG_USAGE_PAGE, USB_HID_ITEM_TYPE_GLOBAL, 2), \
page & 0xff, (page >> 8)
/**
* @brief Defines a HID Logical Minimum item
*
* @note data length is one byte.
*
* @param minimum Minimum value in logical units
*/
#define USB_HID_LOGICAL_MIN8(minimum) \
USB_HID_ITEM(USB_HID_ITEM_TAG_LOGICAL_MIN, USB_HID_ITEM_TYPE_GLOBAL, 1), \
minimum
/**
* @brief Defines a HID Logical Minimum item
*
* @note data length is two bytes.
*
* @param minimum Minimum value in logical units
*/
#define USB_HID_LOGICAL_MIN16(minimum) \
USB_HID_ITEM(USB_HID_ITEM_TAG_LOGICAL_MIN, USB_HID_ITEM_TYPE_GLOBAL, 2), \
minimum & 0xff, (minimum >> 8)
/**
* @brief Defines a HID Logical Minimum item
*
* @note data length is four bytes.
*
* @param minimum Minimum value in logical units
*/
#define USB_HID_LOGICAL_MIN32(minimum) \
USB_HID_ITEM(USB_HID_ITEM_TAG_LOGICAL_MIN, USB_HID_ITEM_TYPE_GLOBAL, 3), \
minimum & 0xff, \
(minimum >> 8) & 0xff, \
(minimum >> 16) & 0xff, \
(minimum >> 24) & 0xff
/**
* @brief Defines a HID Logical Maximum item
*
* @note data length is one byte.
*
* @param maximum Maximum value in logical units
*/
#define USB_HID_LOGICAL_MAX8(maximum) \
USB_HID_ITEM(USB_HID_ITEM_TAG_LOGICAL_MAX, USB_HID_ITEM_TYPE_GLOBAL, 1), \
maximum
/**
* @brief Defines a HID Logical Maximum item
*
* @note data length is two bytes.
*
* @param maximum Maximum value in logical units
*/
#define USB_HID_LOGICAL_MAX16(maximum) \
USB_HID_ITEM(USB_HID_ITEM_TAG_LOGICAL_MAX, USB_HID_ITEM_TYPE_GLOBAL, 2), \
(maximum & 0xff), (maximum >> 8)
/**
* @brief Defines a HID Logical Maximum item
*
* @note data length is four bytes.
*
* @param maximum Maximum value in logical units
*/
#define USB_HID_LOGICAL_MAX32(maximum) \
USB_HID_ITEM(USB_HID_ITEM_TAG_LOGICAL_MAX, USB_HID_ITEM_TYPE_GLOBAL, 3), \
maximum & 0xff, \
(maximum >> 8) & 0xff, \
(maximum >> 16) & 0xff, \
(maximum >> 24) & 0xff
/**
* @brief Defines a HID Report Size item
*
* @note data length is one byte.
*
* @param size Report field size in bits
*/
#define USB_HID_REPORT_SIZE(size) \
USB_HID_ITEM(USB_HID_ITEM_TAG_REPORT_SIZE, USB_HID_ITEM_TYPE_GLOBAL, 1), \
size
/**
* @brief Defines a HID Report ID item
*
* @note data length is one byte.
*
* @param id Report ID
*/
#define USB_HID_REPORT_ID(id) \
USB_HID_ITEM(USB_HID_ITEM_TAG_REPORT_ID, USB_HID_ITEM_TYPE_GLOBAL, 1), \
id
/**
* @brief Define HID Report Count item
*
* @note data length is one byte.
*
* @param count Number of data fields included in the report
*/
#define USB_HID_REPORT_COUNT(count) \
USB_HID_ITEM(USB_HID_ITEM_TAG_REPORT_COUNT, USB_HID_ITEM_TYPE_GLOBAL, 1), \
count
/**
* @brief Defines a HID Usage Index item
*
* @note data length is one byte.
*
* @param index Number of data fields included in the report
*/
#define USB_HID_USAGE(index) \
USB_HID_ITEM(USB_HID_ITEM_TAG_USAGE, USB_HID_ITEM_TYPE_LOCAL, 1), \
index
/**
* @brief Defines a HID Usage Minimum item
*
* @note data length is one byte.
*
* @param start Starting Usage
*/
#define USB_HID_USAGE_MIN8(start) \
USB_HID_ITEM(USB_HID_ITEM_TAG_USAGE_MIN, USB_HID_ITEM_TYPE_LOCAL, 1), \
start
/**
* @brief Define HID Usage Minimum item with the data length of two bytes.
*
* @note data length is two bytes.
*
* @param start Starting Usage
*/
#define USB_HID_USAGE_MIN16(start) \
USB_HID_ITEM(USB_HID_ITEM_TAG_USAGE_MIN, USB_HID_ITEM_TYPE_LOCAL, 2), \
start & 0xff, (start >> 8) & 0xff
/**
* @brief Defines HID Usage Maximum item
*
* @note data length is one byte.
*
* @param end Ending Usage
*/
#define USB_HID_USAGE_MAX8(end) \
USB_HID_ITEM(USB_HID_ITEM_TAG_USAGE_MAX, USB_HID_ITEM_TYPE_LOCAL, 1), \
end
/**
* @brief Defines HID Usage Maximum item
*
* @note data length is one byte.
*
* @param end Ending Usage
*/
#define USB_HID_USAGE_MAX16(end) \
USB_HID_ITEM(USB_HID_ITEM_TAG_USAGE_MAX, USB_HID_ITEM_TYPE_LOCAL, 2), \
end & 0xff, (end >> 8) & 0xff
/** @} */
#ifdef __cplusplus
}
#endif

File diff suppressed because it is too large Load Diff

View File

@ -30,22 +30,22 @@
(version 20190130) section 8.1.8.2
*/
static const uint8_t report_desc_ctap[] = {
0x06, 0xD0, 0xF1, /* HID_UsagePage ( FIDO_USAGE_PAGE ) */
0x09, 0x01, /* HID_Usage ( FIDO_USAGE_CTAPHID ) */
0xA1, 0x01, /* HID_Collection ( HID_Application ) */
0x09, 0x20, /* HID_Usage ( FIDO_USAGE_DATA_IN ) */
0x15, 0x00, /* HID_LogicalMin ( 0 ) */
0x26, 0xFF, 0x00, /* HID_LogicalMaxS ( 0xff ) */
0x75, 0x08, /* HID_ReportSize ( 8 ) */
0x95, 0x40, /* HID_ReportCount ( HID_INPUT_REPORT_BYTES ) */
0x81, 0x02, /* HID_Input ( HID_Data | HID_Absolute | HID_Variable ) */
0x09, 0x21, /* HID_Usage ( FIDO_USAGE_DATA_OUT ) */
0x15, 0x00, /* HID_LogicalMin ( 0 ) */
0x26, 0xFF, 0x00, /* HID_LogicalMaxS ( 0xff ) */
0x75, 0x08, /* HID_ReportSize ( 8 ) */
0x95, 0x40, /* HID_ReportCount ( HID_OUTPUT_REPORT_BYTES ) */
0x91, 0x02, /* HID_Output ( HID_Data | HID_Absolute | HID_Variable ) */
0xC0, /* HID_EndCollection */
USB_HID_USAGE_PAGE16(USB_HID_USAGE_FIDO),
USB_HID_USAGE(USB_HID_USAGE_FIDO_U2F_AUTHENTICATOR_DEVICE),
USB_HID_COLLECTION(USB_HID_COLLECTION_APPLICATION),
USB_HID_USAGE(USB_HID_USAGE_FIDO_INPUT_REPORT_DATA),
USB_HID_LOGICAL_MIN8(0),
USB_HID_LOGICAL_MAX16(255),
USB_HID_REPORT_SIZE(8),
USB_HID_REPORT_COUNT(CONFIG_USBUS_HID_INTERRUPT_EP_SIZE),
USB_HID_INPUT(0x02),
USB_HID_USAGE(USB_HID_USAGE_FIDO_OUTPUT_REPORT_DATA),
USB_HID_LOGICAL_MIN8(0),
USB_HID_LOGICAL_MAX16(255),
USB_HID_REPORT_SIZE(8),
USB_HID_REPORT_COUNT(CONFIG_USBUS_HID_INTERRUPT_EP_SIZE),
USB_HID_OUTPUT(0x02),
USB_HID_END_COLLECTION,
};
static usbus_t usbus;