forked from mfulz_github/qmk_firmware
656 lines
35 KiB
C
656 lines
35 KiB
C
/*
|
|
LUFA Library
|
|
Copyright (C) Dean Camera, 2012.
|
|
|
|
dean [at] fourwalledcubicle [dot] com
|
|
www.lufa-lib.org
|
|
*/
|
|
|
|
/*
|
|
Copyright 2012 Dean Camera (dean [at] fourwalledcubicle [dot] com)
|
|
|
|
Permission to use, copy, modify, distribute, and sell this
|
|
software and its documentation for any purpose is hereby granted
|
|
without fee, provided that the above copyright notice appear in
|
|
all copies and that both that the copyright notice and this
|
|
permission notice and warranty disclaimer appear in supporting
|
|
documentation, and that the name of the author not be used in
|
|
advertising or publicity pertaining to distribution of the
|
|
software without specific, written prior permission.
|
|
|
|
The author disclaim all warranties with regard to this
|
|
software, including all implied warranties of merchantability
|
|
and fitness. In no event shall the author be liable for any
|
|
special, indirect or consequential damages or any damages
|
|
whatsoever resulting from loss of use, data or profits, whether
|
|
in an action of contract, negligence or other tortious action,
|
|
arising out of or in connection with the use or performance of
|
|
this software.
|
|
*/
|
|
|
|
/** \file
|
|
* \brief Common definitions and declarations for the library USB HID Class driver.
|
|
*
|
|
* Common definitions and declarations for the library USB HID Class driver.
|
|
*
|
|
* \note This file should not be included directly. It is automatically included as needed by the USB module driver
|
|
* dispatch header located in LUFA/Drivers/USB.h.
|
|
*/
|
|
|
|
/** \ingroup Group_USBClassHID
|
|
* \defgroup Group_USBClassHIDCommon Common Class Definitions
|
|
*
|
|
* \section Sec_ModDescription Module Description
|
|
* Constants, Types and Enum definitions that are common to both Device and Host modes for the USB
|
|
* HID Class.
|
|
*
|
|
* @{
|
|
*/
|
|
|
|
#ifndef _HID_CLASS_COMMON_H_
|
|
#define _HID_CLASS_COMMON_H_
|
|
|
|
/* Includes: */
|
|
#include "../../Core/StdDescriptors.h"
|
|
#include "HIDParser.h"
|
|
|
|
/* Enable C linkage for C++ Compilers: */
|
|
#if defined(__cplusplus)
|
|
extern "C" {
|
|
#endif
|
|
|
|
/* Preprocessor Checks: */
|
|
#if !defined(__INCLUDE_FROM_HID_DRIVER)
|
|
#error Do not include this file directly. Include LUFA/Drivers/USB.h instead.
|
|
#endif
|
|
|
|
/* Macros: */
|
|
/** \name Keyboard Standard Report Modifier Masks */
|
|
//@{
|
|
/** Constant for a keyboard report modifier byte, indicating that the keyboard's left control key is currently pressed. */
|
|
#define HID_KEYBOARD_MODIFIER_LEFTCTRL (1 << 0)
|
|
|
|
/** Constant for a keyboard report modifier byte, indicating that the keyboard's left shift key is currently pressed. */
|
|
#define HID_KEYBOARD_MODIFIER_LEFTSHIFT (1 << 1)
|
|
|
|
/** Constant for a keyboard report modifier byte, indicating that the keyboard's left alt key is currently pressed. */
|
|
#define HID_KEYBOARD_MODIFIER_LEFTALT (1 << 2)
|
|
|
|
/** Constant for a keyboard report modifier byte, indicating that the keyboard's left GUI key is currently pressed. */
|
|
#define HID_KEYBOARD_MODIFIER_LEFTGUI (1 << 3)
|
|
|
|
/** Constant for a keyboard report modifier byte, indicating that the keyboard's right control key is currently pressed. */
|
|
#define HID_KEYBOARD_MODIFIER_RIGHTCTRL (1 << 4)
|
|
|
|
/** Constant for a keyboard report modifier byte, indicating that the keyboard's right shift key is currently pressed. */
|
|
#define HID_KEYBOARD_MODIFIER_RIGHTSHIFT (1 << 5)
|
|
|
|
/** Constant for a keyboard report modifier byte, indicating that the keyboard's right alt key is currently pressed. */
|
|
#define HID_KEYBOARD_MODIFIER_RIGHTALT (1 << 6)
|
|
|
|
/** Constant for a keyboard report modifier byte, indicating that the keyboard's right GUI key is currently pressed. */
|
|
#define HID_KEYBOARD_MODIFIER_RIGHTGUI (1 << 7)
|
|
//@}
|
|
|
|
/** \name Keyboard Standard Report LED Masks */
|
|
//@{
|
|
/** Constant for a keyboard output report LED byte, indicating that the host's NUM LOCK mode is currently set. */
|
|
#define HID_KEYBOARD_LED_NUMLOCK (1 << 0)
|
|
|
|
/** Constant for a keyboard output report LED byte, indicating that the host's CAPS LOCK mode is currently set. */
|
|
#define HID_KEYBOARD_LED_CAPSLOCK (1 << 1)
|
|
|
|
/** Constant for a keyboard output report LED byte, indicating that the host's SCROLL LOCK mode is currently set. */
|
|
#define HID_KEYBOARD_LED_SCROLLLOCK (1 << 2)
|
|
|
|
/** Constant for a keyboard output report LED byte, indicating that the host's KATANA mode is currently set. */
|
|
#define HID_KEYBOARD_LED_KATANA (1 << 3)
|
|
//@}
|
|
|
|
/** \name Keyboard Standard Report Key Scan-codes */
|
|
//@{
|
|
#define HID_KEYBOARD_SC_ERROR_ROLLOVER 0x01
|
|
#define HID_KEYBOARD_SC_POST_FAIL 0x02
|
|
#define HID_KEYBOARD_SC_ERROR_UNDEFINED 0x03
|
|
#define HID_KEYBOARD_SC_A 0x04
|
|
#define HID_KEYBOARD_SC_B 0x05
|
|
#define HID_KEYBOARD_SC_C 0x06
|
|
#define HID_KEYBOARD_SC_D 0x07
|
|
#define HID_KEYBOARD_SC_E 0x08
|
|
#define HID_KEYBOARD_SC_F 0x09
|
|
#define HID_KEYBOARD_SC_G 0x0A
|
|
#define HID_KEYBOARD_SC_H 0x0B
|
|
#define HID_KEYBOARD_SC_I 0x0C
|
|
#define HID_KEYBOARD_SC_J 0x0D
|
|
#define HID_KEYBOARD_SC_K 0x0E
|
|
#define HID_KEYBOARD_SC_L 0x0F
|
|
#define HID_KEYBOARD_SC_M 0x10
|
|
#define HID_KEYBOARD_SC_N 0x11
|
|
#define HID_KEYBOARD_SC_O 0x12
|
|
#define HID_KEYBOARD_SC_P 0x13
|
|
#define HID_KEYBOARD_SC_Q 0x14
|
|
#define HID_KEYBOARD_SC_R 0x15
|
|
#define HID_KEYBOARD_SC_S 0x16
|
|
#define HID_KEYBOARD_SC_T 0x17
|
|
#define HID_KEYBOARD_SC_U 0x18
|
|
#define HID_KEYBOARD_SC_V 0x19
|
|
#define HID_KEYBOARD_SC_W 0x1A
|
|
#define HID_KEYBOARD_SC_X 0x1B
|
|
#define HID_KEYBOARD_SC_Y 0x1C
|
|
#define HID_KEYBOARD_SC_Z 0x1D
|
|
#define HID_KEYBOARD_SC_1_AND_EXCLAMATION 0x1E
|
|
#define HID_KEYBOARD_SC_2_AND_AT 0x1F
|
|
#define HID_KEYBOARD_SC_3_AND_HASHMARK 0x20
|
|
#define HID_KEYBOARD_SC_4_AND_DOLLAR 0x21
|
|
#define HID_KEYBOARD_SC_5_AND_PERCENTAGE 0x22
|
|
#define HID_KEYBOARD_SC_6_AND_CARET 0x23
|
|
#define HID_KEYBOARD_SC_7_AND_AND_AMPERSAND 0x24
|
|
#define HID_KEYBOARD_SC_8_AND_ASTERISK 0x25
|
|
#define HID_KEYBOARD_SC_9_AND_OPENING_PARENTHESIS 0x26
|
|
#define HID_KEYBOARD_SC_0_AND_CLOSING_PARENTHESIS 0x27
|
|
#define HID_KEYBOARD_SC_ENTER 0x28
|
|
#define HID_KEYBOARD_SC_ESCAPE 0x29
|
|
#define HID_KEYBOARD_SC_BACKSPACE 0x2A
|
|
#define HID_KEYBOARD_SC_TAB 0x2B
|
|
#define HID_KEYBOARD_SC_SPACE 0x2C
|
|
#define HID_KEYBOARD_SC_MINUS_AND_UNDERSCORE 0x2D
|
|
#define HID_KEYBOARD_SC_EQUAL_AND_PLUS 0x2E
|
|
#define HID_KEYBOARD_SC_OPENING_BRACKET_AND_OPENING_BRACE 0x2F
|
|
#define HID_KEYBOARD_SC_CLOSING_BRACKET_AND_CLOSING_BRACE 0x30
|
|
#define HID_KEYBOARD_SC_BACKSLASH_AND_PIPE 0x31
|
|
#define HID_KEYBOARD_SC_NON_US_HASHMARK_AND_TILDE 0x32
|
|
#define HID_KEYBOARD_SC_SEMICOLON_AND_COLON 0x33
|
|
#define HID_KEYBOARD_SC_APOSTROPHE_AND_QUOTE 0x34
|
|
#define HID_KEYBOARD_SC_GRAVE_ACCENT_AND_TILDE 0x35
|
|
#define HID_KEYBOARD_SC_COMMA_AND_LESS_THAN_SIGN 0x36
|
|
#define HID_KEYBOARD_SC_DOT_AND_GREATER_THAN_SIGN 0x37
|
|
#define HID_KEYBOARD_SC_SLASH_AND_QUESTION_MARK 0x38
|
|
#define HID_KEYBOARD_SC_CAPS_LOCK 0x39
|
|
#define HID_KEYBOARD_SC_F1 0x3A
|
|
#define HID_KEYBOARD_SC_F2 0x3B
|
|
#define HID_KEYBOARD_SC_F3 0x3C
|
|
#define HID_KEYBOARD_SC_F4 0x3D
|
|
#define HID_KEYBOARD_SC_F5 0x3E
|
|
#define HID_KEYBOARD_SC_F6 0x3F
|
|
#define HID_KEYBOARD_SC_F7 0x40
|
|
#define HID_KEYBOARD_SC_F8 0x41
|
|
#define HID_KEYBOARD_SC_F9 0x42
|
|
#define HID_KEYBOARD_SC_F10 0x43
|
|
#define HID_KEYBOARD_SC_F11 0x44
|
|
#define HID_KEYBOARD_SC_F12 0x45
|
|
#define HID_KEYBOARD_SC_PRINT_SCREEN 0x46
|
|
#define HID_KEYBOARD_SC_SCROLL_LOCK 0x47
|
|
#define HID_KEYBOARD_SC_PAUSE 0x48
|
|
#define HID_KEYBOARD_SC_INSERT 0x49
|
|
#define HID_KEYBOARD_SC_HOME 0x4A
|
|
#define HID_KEYBOARD_SC_PAGE_UP 0x4B
|
|
#define HID_KEYBOARD_SC_DELETE 0x4C
|
|
#define HID_KEYBOARD_SC_END 0x4D
|
|
#define HID_KEYBOARD_SC_PAGE_DOWN 0x4E
|
|
#define HID_KEYBOARD_SC_RIGHT_ARROW 0x4F
|
|
#define HID_KEYBOARD_SC_LEFT_ARROW 0x50
|
|
#define HID_KEYBOARD_SC_DOWN_ARROW 0x51
|
|
#define HID_KEYBOARD_SC_UP_ARROW 0x52
|
|
#define HID_KEYBOARD_SC_NUM_LOCK 0x53
|
|
#define HID_KEYBOARD_SC_KEYPAD_SLASH 0x54
|
|
#define HID_KEYBOARD_SC_KEYPAD_ASTERISK 0x55
|
|
#define HID_KEYBOARD_SC_KEYPAD_MINUS 0x56
|
|
#define HID_KEYBOARD_SC_KEYPAD_PLUS 0x57
|
|
#define HID_KEYBOARD_SC_KEYPAD_ENTER 0x58
|
|
#define HID_KEYBOARD_SC_KEYPAD_1_AND_END 0x59
|
|
#define HID_KEYBOARD_SC_KEYPAD_2_AND_DOWN_ARROW 0x5A
|
|
#define HID_KEYBOARD_SC_KEYPAD_3_AND_PAGE_DOWN 0x5B
|
|
#define HID_KEYBOARD_SC_KEYPAD_4_AND_LEFT_ARROW 0x5C
|
|
#define HID_KEYBOARD_SC_KEYPAD_5 0x5D
|
|
#define HID_KEYBOARD_SC_KEYPAD_6_AND_RIGHT_ARROW 0x5E
|
|
#define HID_KEYBOARD_SC_KEYPAD_7_AND_HOME 0x5F
|
|
#define HID_KEYBOARD_SC_KEYPAD_8_AND_UP_ARROW 0x60
|
|
#define HID_KEYBOARD_SC_KEYPAD_9_AND_PAGE_UP 0x61
|
|
#define HID_KEYBOARD_SC_KEYPAD_0_AND_INSERT 0x62
|
|
#define HID_KEYBOARD_SC_KEYPAD_DOT_AND_DELETE 0x63
|
|
#define HID_KEYBOARD_SC_NON_US_BACKSLASH_AND_PIPE 0x64
|
|
#define HID_KEYBOARD_SC_POWER 0x66
|
|
#define HID_KEYBOARD_SC_EQUAL_SIGN 0x67
|
|
#define HID_KEYBOARD_SC_F13 0x68
|
|
#define HID_KEYBOARD_SC_F14 0x69
|
|
#define HID_KEYBOARD_SC_F15 0x6A
|
|
#define HID_KEYBOARD_SC_F16 0x6B
|
|
#define HID_KEYBOARD_SC_F17 0x6C
|
|
#define HID_KEYBOARD_SC_F18 0x6D
|
|
#define HID_KEYBOARD_SC_F19 0x6E
|
|
#define HID_KEYBOARD_SC_F20 0x6F
|
|
#define HID_KEYBOARD_SC_F21 0x70
|
|
#define HID_KEYBOARD_SC_F22 0x71
|
|
#define HID_KEYBOARD_SC_F23 0x72
|
|
#define HID_KEYBOARD_SC_F24 0x73
|
|
#define HID_KEYBOARD_SC_EXECUTE 0x74
|
|
#define HID_KEYBOARD_SC_HELP 0x75
|
|
#define HID_KEYBOARD_SC_MANU 0x76
|
|
#define HID_KEYBOARD_SC_SELECT 0x77
|
|
#define HID_KEYBOARD_SC_STOP 0x78
|
|
#define HID_KEYBOARD_SC_AGAIN 0x79
|
|
#define HID_KEYBOARD_SC_UNDO 0x7A
|
|
#define HID_KEYBOARD_SC_CUT 0x7B
|
|
#define HID_KEYBOARD_SC_COPY 0x7C
|
|
#define HID_KEYBOARD_SC_PASTE 0x7D
|
|
#define HID_KEYBOARD_SC_FIND 0x7E
|
|
#define HID_KEYBOARD_SC_MUTE 0x7F
|
|
#define HID_KEYBOARD_SC_VOLUME_UP 0x80
|
|
#define HID_KEYBOARD_SC_VOLUME_DOWN 0x81
|
|
#define HID_KEYBOARD_SC_LOCKING_CAPS_LOCK 0x82
|
|
#define HID_KEYBOARD_SC_LOCKING_NUM_LOCK 0x83
|
|
#define HID_KEYBOARD_SC_LOCKING_SCROLL_LOCK 0x84
|
|
#define HID_KEYBOARD_SC_KEYPAD_COMMA 0x85
|
|
#define HID_KEYBOARD_SC_KEYPAD_EQUAL_SIGN 0x86
|
|
#define HID_KEYBOARD_SC_INTERNATIONAL1 0x87
|
|
#define HID_KEYBOARD_SC_INTERNATIONAL2 0x88
|
|
#define HID_KEYBOARD_SC_INTERNATIONAL3 0x89
|
|
#define HID_KEYBOARD_SC_INTERNATIONAL4 0x8A
|
|
#define HID_KEYBOARD_SC_INTERNATIONAL5 0x8B
|
|
#define HID_KEYBOARD_SC_INTERNATIONAL6 0x8C
|
|
#define HID_KEYBOARD_SC_INTERNATIONAL7 0x8D
|
|
#define HID_KEYBOARD_SC_INTERNATIONAL8 0x8E
|
|
#define HID_KEYBOARD_SC_INTERNATIONAL9 0x8F
|
|
#define HID_KEYBOARD_SC_LANG1 0x90
|
|
#define HID_KEYBOARD_SC_LANG2 0x91
|
|
#define HID_KEYBOARD_SC_LANG3 0x92
|
|
#define HID_KEYBOARD_SC_LANG4 0x93
|
|
#define HID_KEYBOARD_SC_LANG5 0x94
|
|
#define HID_KEYBOARD_SC_LANG6 0x95
|
|
#define HID_KEYBOARD_SC_LANG7 0x96
|
|
#define HID_KEYBOARD_SC_LANG8 0x97
|
|
#define HID_KEYBOARD_SC_LANG9 0x98
|
|
#define HID_KEYBOARD_SC_ALTERNATE_ERASE 0x99
|
|
#define HID_KEYBOARD_SC_SISREQ 0x9A
|
|
#define HID_KEYBOARD_SC_CANCEL 0x9B
|
|
#define HID_KEYBOARD_SC_CLEAR 0x9C
|
|
#define HID_KEYBOARD_SC_PRIOR 0x9D
|
|
#define HID_KEYBOARD_SC_RETURN 0x9E
|
|
#define HID_KEYBOARD_SC_SEPARATOR 0x9F
|
|
#define HID_KEYBOARD_SC_OUT 0xA0
|
|
#define HID_KEYBOARD_SC_OPER 0xA1
|
|
#define HID_KEYBOARD_SC_CLEAR_AND_AGAIN 0xA2
|
|
#define HID_KEYBOARD_SC_CRSEL_ANDPROPS 0xA3
|
|
#define HID_KEYBOARD_SC_EXSEL 0xA4
|
|
#define HID_KEYBOARD_SC_KEYPAD_00 0xB0
|
|
#define HID_KEYBOARD_SC_KEYPAD_000 0xB1
|
|
#define HID_KEYBOARD_SC_THOUSANDS_SEPARATOR 0xB2
|
|
#define HID_KEYBOARD_SC_DECIMAL_SEPARATOR 0xB3
|
|
#define HID_KEYBOARD_SC_CURRENCY_UNIT 0xB4
|
|
#define HID_KEYBOARD_SC_CURRENCY_SUB_UNIT 0xB5
|
|
#define HID_KEYBOARD_SC_KEYPAD_OPENING_PARENTHESIS 0xB6
|
|
#define HID_KEYBOARD_SC_KEYPAD_CLOSING_PARENTHESIS 0xB7
|
|
#define HID_KEYBOARD_SC_KEYPAD_OPENING_BRACE 0xB8
|
|
#define HID_KEYBOARD_SC_KEYPAD_CLOSING_BRACE 0xB9
|
|
#define HID_KEYBOARD_SC_KEYPAD_TAB 0xBA
|
|
#define HID_KEYBOARD_SC_KEYPAD_BACKSPACE 0xBB
|
|
#define HID_KEYBOARD_SC_KEYPAD_A 0xBC
|
|
#define HID_KEYBOARD_SC_KEYPAD_B 0xBD
|
|
#define HID_KEYBOARD_SC_KEYPAD_C 0xBE
|
|
#define HID_KEYBOARD_SC_KEYPAD_D 0xBF
|
|
#define HID_KEYBOARD_SC_KEYPAD_E 0xC0
|
|
#define HID_KEYBOARD_SC_KEYPAD_F 0xC1
|
|
#define HID_KEYBOARD_SC_KEYPAD_XOR 0xC2
|
|
#define HID_KEYBOARD_SC_KEYPAD_CARET 0xC3
|
|
#define HID_KEYBOARD_SC_KEYPAD_PERCENTAGE 0xC4
|
|
#define HID_KEYBOARD_SC_KEYPAD_LESS_THAN_SIGN 0xC5
|
|
#define HID_KEYBOARD_SC_KEYPAD_GREATER_THAN_SIGN 0xC6
|
|
#define HID_KEYBOARD_SC_KEYPAD_AMP 0xC7
|
|
#define HID_KEYBOARD_SC_KEYPAD_AMP_AMP 0xC8
|
|
#define HID_KEYBOARD_SC_KEYPAD_PIPE 0xC9
|
|
#define HID_KEYBOARD_SC_KEYPAD_PIPE_PIPE 0xCA
|
|
#define HID_KEYBOARD_SC_KEYPAD_COLON 0xCB
|
|
#define HID_KEYBOARD_SC_KEYPAD_HASHMARK 0xCC
|
|
#define HID_KEYBOARD_SC_KEYPAD_SPACE 0xCD
|
|
#define HID_KEYBOARD_SC_KEYPAD_AT 0xCE
|
|
#define HID_KEYBOARD_SC_KEYPAD_EXCLAMATION_SIGN 0xCF
|
|
#define HID_KEYBOARD_SC_KEYPAD_MEMORY_STORE 0xD0
|
|
#define HID_KEYBOARD_SC_KEYPAD_MEMORY_RECALL 0xD1
|
|
#define HID_KEYBOARD_SC_KEYPAD_MEMORY_CLEAR 0xD2
|
|
#define HID_KEYBOARD_SC_KEYPAD_MEMORY_ADD 0xD3
|
|
#define HID_KEYBOARD_SC_KEYPAD_MEMORY_SUBTRACT 0xD4
|
|
#define HID_KEYBOARD_SC_KEYPAD_MEMORY_MULTIPLY 0xD5
|
|
#define HID_KEYBOARD_SC_KEYPAD_MEMORY_DIVIDE 0xD6
|
|
#define HID_KEYBOARD_SC_KEYPAD_PLUS_AND_MINUS 0xD7
|
|
#define HID_KEYBOARD_SC_KEYPAD_CLEAR 0xD8
|
|
#define HID_KEYBOARD_SC_KEYPAD_CLEAR_ENTRY 0xD9
|
|
#define HID_KEYBOARD_SC_KEYPAD_BINARY 0xDA
|
|
#define HID_KEYBOARD_SC_KEYPAD_OCTAL 0xDB
|
|
#define HID_KEYBOARD_SC_KEYPAD_DECIMAL 0xDC
|
|
#define HID_KEYBOARD_SC_KEYPAD_HEXADECIMAL 0xDD
|
|
#define HID_KEYBOARD_SC_LEFT_CONTROL 0xE0
|
|
#define HID_KEYBOARD_SC_LEFT_SHIFT 0xE1
|
|
#define HID_KEYBOARD_SC_LEFT_ALT 0xE2
|
|
#define HID_KEYBOARD_SC_LEFT_GUI 0xE3
|
|
#define HID_KEYBOARD_SC_RIGHT_CONTROL 0xE4
|
|
#define HID_KEYBOARD_SC_RIGHT_SHIFT 0xE5
|
|
#define HID_KEYBOARD_SC_RIGHT_ALT 0xE6
|
|
#define HID_KEYBOARD_SC_RIGHT_GUI 0xE7
|
|
//@}
|
|
|
|
/** \name Common HID Device Report Descriptors */
|
|
//@{
|
|
/** \hideinitializer
|
|
* A list of HID report item array elements that describe a typical HID USB Joystick. The resulting report
|
|
* descriptor is structured according to the following layout:
|
|
*
|
|
* \code
|
|
* struct
|
|
* {
|
|
* intA_t X; // Signed X axis value
|
|
* intA_t Y; // Signed Y axis value
|
|
* intA_t Z; // Signed Z axis value
|
|
* uintB_t Buttons; // Pressed buttons bitmask
|
|
* } Joystick_Report;
|
|
* \endcode
|
|
*
|
|
* Where \c uintA_t is a type large enough to hold the ranges of the signed \c MinAxisVal and \c MaxAxisVal values,
|
|
* and \c intB_t is a type large enough to hold one bit per button.
|
|
*
|
|
* \param[in] MinAxisVal Minimum logical axis value (16-bit).
|
|
* \param[in] MaxAxisVal Maximum logical axis value (16-bit).
|
|
* \param[in] MinPhysicalVal Minimum physical axis value, for movement resolution calculations (16-bit).
|
|
* \param[in] MaxPhysicalVal Maximum physical axis value, for movement resolution calculations (16-bit).
|
|
* \param[in] Buttons Total number of buttons in the device (8-bit).
|
|
*/
|
|
#define HID_DESCRIPTOR_JOYSTICK(MinAxisVal, MaxAxisVal, MinPhysicalVal, MaxPhysicalVal, Buttons) \
|
|
HID_RI_USAGE_PAGE(8, 0x01), \
|
|
HID_RI_USAGE(8, 0x04), \
|
|
HID_RI_COLLECTION(8, 0x01), \
|
|
HID_RI_USAGE(8, 0x01), \
|
|
HID_RI_COLLECTION(8, 0x00), \
|
|
HID_RI_USAGE(8, 0x30), \
|
|
HID_RI_USAGE(8, 0x31), \
|
|
HID_RI_USAGE(8, 0x32), \
|
|
HID_RI_LOGICAL_MINIMUM(16, MinAxisVal), \
|
|
HID_RI_LOGICAL_MAXIMUM(16, MaxAxisVal), \
|
|
HID_RI_PHYSICAL_MINIMUM(16, MinPhysicalVal), \
|
|
HID_RI_PHYSICAL_MAXIMUM(16, MaxPhysicalVal), \
|
|
HID_RI_REPORT_COUNT(8, 3), \
|
|
HID_RI_REPORT_SIZE(8, ((((MinAxisVal >= -0xFF) && (MaxAxisVal <= 0xFF)) ? 8 : 16))), \
|
|
HID_RI_INPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE), \
|
|
HID_RI_END_COLLECTION(0), \
|
|
HID_RI_USAGE_PAGE(8, 0x09), \
|
|
HID_RI_USAGE_MINIMUM(8, 0x01), \
|
|
HID_RI_USAGE_MAXIMUM(8, Buttons), \
|
|
HID_RI_LOGICAL_MINIMUM(8, 0x00), \
|
|
HID_RI_LOGICAL_MAXIMUM(8, 0x01), \
|
|
HID_RI_REPORT_SIZE(8, 0x01), \
|
|
HID_RI_REPORT_COUNT(8, Buttons), \
|
|
HID_RI_INPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE), \
|
|
HID_RI_REPORT_SIZE(8, (8 - (Buttons % 8))), \
|
|
HID_RI_REPORT_COUNT(8, 0x01), \
|
|
HID_RI_INPUT(8, HID_IOF_CONSTANT), \
|
|
HID_RI_END_COLLECTION(0)
|
|
|
|
/** \hideinitializer
|
|
* A list of HID report item array elements that describe a typical HID USB keyboard. The resulting report descriptor
|
|
* is compatible with \ref USB_KeyboardReport_Data_t when \c MaxKeys is equal to 6. For other values, the report will
|
|
* be structured according to the following layout:
|
|
*
|
|
* \code
|
|
* struct
|
|
* {
|
|
* uint8_t Modifier; // Keyboard modifier byte indicating pressed modifier keys (\c HID_KEYBOARD_MODIFER_* masks)
|
|
* uint8_t Reserved; // Reserved for OEM use, always set to 0.
|
|
* uint8_t KeyCode[MaxKeys]; // Length determined by the number of keys that can be reported
|
|
* } Keyboard_Report;
|
|
* \endcode
|
|
*
|
|
* \param[in] MaxKeys Number of simultaneous keys that can be reported at the one time (8-bit).
|
|
*/
|
|
#define HID_DESCRIPTOR_KEYBOARD(MaxKeys) \
|
|
HID_RI_USAGE_PAGE(8, 0x01), \
|
|
HID_RI_USAGE(8, 0x06), \
|
|
HID_RI_COLLECTION(8, 0x01), \
|
|
HID_RI_USAGE_PAGE(8, 0x07), \
|
|
HID_RI_USAGE_MINIMUM(8, 0xE0), \
|
|
HID_RI_USAGE_MAXIMUM(8, 0xE7), \
|
|
HID_RI_LOGICAL_MINIMUM(8, 0x00), \
|
|
HID_RI_LOGICAL_MAXIMUM(8, 0x01), \
|
|
HID_RI_REPORT_SIZE(8, 0x01), \
|
|
HID_RI_REPORT_COUNT(8, 0x08), \
|
|
HID_RI_INPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE), \
|
|
HID_RI_REPORT_COUNT(8, 0x01), \
|
|
HID_RI_REPORT_SIZE(8, 0x08), \
|
|
HID_RI_INPUT(8, HID_IOF_CONSTANT), \
|
|
HID_RI_USAGE_PAGE(8, 0x08), \
|
|
HID_RI_USAGE_MINIMUM(8, 0x01), \
|
|
HID_RI_USAGE_MAXIMUM(8, 0x05), \
|
|
HID_RI_REPORT_COUNT(8, 0x05), \
|
|
HID_RI_REPORT_SIZE(8, 0x01), \
|
|
HID_RI_OUTPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE | HID_IOF_NON_VOLATILE), \
|
|
HID_RI_REPORT_COUNT(8, 0x01), \
|
|
HID_RI_REPORT_SIZE(8, 0x03), \
|
|
HID_RI_OUTPUT(8, HID_IOF_CONSTANT), \
|
|
HID_RI_LOGICAL_MINIMUM(8, 0x00), \
|
|
HID_RI_LOGICAL_MAXIMUM(8, 0x65), \
|
|
HID_RI_USAGE_PAGE(8, 0x07), \
|
|
HID_RI_USAGE_MINIMUM(8, 0x00), \
|
|
HID_RI_USAGE_MAXIMUM(8, 0x65), \
|
|
HID_RI_REPORT_COUNT(8, MaxKeys), \
|
|
HID_RI_REPORT_SIZE(8, 0x08), \
|
|
HID_RI_INPUT(8, HID_IOF_DATA | HID_IOF_ARRAY | HID_IOF_ABSOLUTE), \
|
|
HID_RI_END_COLLECTION(0)
|
|
|
|
/** \hideinitializer
|
|
* A list of HID report item array elements that describe a typical HID USB mouse. The resulting report descriptor
|
|
* is compatible with \ref USB_MouseReport_Data_t if the \c MinAxisVal and \c MaxAxisVal values fit within a \c int8_t range
|
|
* and the number of Buttons is less than 8. For other values, the report is structured according to the following layout:
|
|
*
|
|
* \code
|
|
* struct
|
|
* {
|
|
* uintA_t Buttons; // Pressed buttons bitmask
|
|
* intB_t X; // X axis value
|
|
* intB_t Y; // Y axis value
|
|
* } Mouse_Report;
|
|
* \endcode
|
|
*
|
|
* Where \c intA_t is a type large enough to hold one bit per button, and \c intB_t is a type large enough to hold the
|
|
* ranges of the signed \c MinAxisVal and \c MaxAxisVal values.
|
|
*
|
|
* \param[in] MinAxisVal Minimum X/Y logical axis value (16-bit).
|
|
* \param[in] MaxAxisVal Maximum X/Y logical axis value (16-bit).
|
|
* \param[in] MinPhysicalVal Minimum X/Y physical axis value, for movement resolution calculations (16-bit).
|
|
* \param[in] MaxPhysicalVal Maximum X/Y physical axis value, for movement resolution calculations (16-bit).
|
|
* \param[in] Buttons Total number of buttons in the device (8-bit).
|
|
* \param[in] AbsoluteCoords Boolean \c true to use absolute X/Y coordinates (e.g. touchscreen).
|
|
*/
|
|
#define HID_DESCRIPTOR_MOUSE(MinAxisVal, MaxAxisVal, MinPhysicalVal, MaxPhysicalVal, Buttons, AbsoluteCoords) \
|
|
HID_RI_USAGE_PAGE(8, 0x01), \
|
|
HID_RI_USAGE(8, 0x02), \
|
|
HID_RI_COLLECTION(8, 0x01), \
|
|
HID_RI_USAGE(8, 0x01), \
|
|
HID_RI_COLLECTION(8, 0x00), \
|
|
HID_RI_USAGE_PAGE(8, 0x09), \
|
|
HID_RI_USAGE_MINIMUM(8, 0x01), \
|
|
HID_RI_USAGE_MAXIMUM(8, Buttons), \
|
|
HID_RI_LOGICAL_MINIMUM(8, 0x00), \
|
|
HID_RI_LOGICAL_MAXIMUM(8, 0x01), \
|
|
HID_RI_REPORT_COUNT(8, Buttons), \
|
|
HID_RI_REPORT_SIZE(8, 0x01), \
|
|
HID_RI_INPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE), \
|
|
HID_RI_REPORT_COUNT(8, 0x01), \
|
|
HID_RI_REPORT_SIZE(8, (8 - (Buttons % 8))), \
|
|
HID_RI_INPUT(8, HID_IOF_CONSTANT), \
|
|
HID_RI_USAGE_PAGE(8, 0x01), \
|
|
HID_RI_USAGE(8, 0x30), \
|
|
HID_RI_USAGE(8, 0x31), \
|
|
HID_RI_LOGICAL_MINIMUM(16, MinAxisVal), \
|
|
HID_RI_LOGICAL_MAXIMUM(16, MaxAxisVal), \
|
|
HID_RI_PHYSICAL_MINIMUM(16, MinPhysicalVal), \
|
|
HID_RI_PHYSICAL_MAXIMUM(16, MaxPhysicalVal), \
|
|
HID_RI_REPORT_COUNT(8, 0x02), \
|
|
HID_RI_REPORT_SIZE(8, ((((MinAxisVal >= -0xFF) && (MaxAxisVal <= 0xFF)) ? 8 : 16))), \
|
|
HID_RI_INPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | (AbsoluteCoords ? HID_IOF_ABSOLUTE : HID_IOF_RELATIVE)), \
|
|
HID_RI_END_COLLECTION(0), \
|
|
HID_RI_END_COLLECTION(0)
|
|
|
|
/** \hideinitializer
|
|
* A list of HID report item array elements that describe a typical Vendor Defined byte array HID report descriptor,
|
|
* used for transporting arbitrary data between the USB host and device via HID reports. The resulting report should be
|
|
* a \c uint8_t byte array of the specified length in both Device to Host (IN) and Host to Device (OUT) directions.
|
|
*
|
|
* \param[in] VendorPageNum Vendor Defined HID Usage Page index, ranging from 0x00 to 0xFF.
|
|
* \param[in] CollectionUsage Vendor Usage for the encompassing report IN and OUT collection, ranging from 0x00 to 0xFF.
|
|
* \param[in] DataINUsage Vendor Usage for the IN report data, ranging from 0x00 to 0xFF.
|
|
* \param[in] DataOUTUsage Vendor Usage for the OUT report data, ranging from 0x00 to 0xFF.
|
|
* \param[in] NumBytes Length of the data IN and OUT reports.
|
|
*/
|
|
#define HID_DESCRIPTOR_VENDOR(VendorPageNum, CollectionUsage, DataINUsage, DataOUTUsage, NumBytes) \
|
|
HID_RI_USAGE_PAGE(16, (0xFF00 | VendorPageNum)), \
|
|
HID_RI_USAGE(8, CollectionUsage), \
|
|
HID_RI_COLLECTION(8, 0x01), \
|
|
HID_RI_USAGE(8, DataINUsage), \
|
|
HID_RI_LOGICAL_MINIMUM(8, 0x00), \
|
|
HID_RI_LOGICAL_MAXIMUM(8, 0xFF), \
|
|
HID_RI_REPORT_SIZE(8, 0x08), \
|
|
HID_RI_REPORT_COUNT(8, NumBytes), \
|
|
HID_RI_INPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE), \
|
|
HID_RI_USAGE(8, DataOUTUsage), \
|
|
HID_RI_LOGICAL_MINIMUM(8, 0x00), \
|
|
HID_RI_LOGICAL_MAXIMUM(8, 0xFF), \
|
|
HID_RI_REPORT_SIZE(8, 0x08), \
|
|
HID_RI_REPORT_COUNT(8, NumBytes), \
|
|
HID_RI_OUTPUT(8, HID_IOF_DATA | HID_IOF_VARIABLE | HID_IOF_ABSOLUTE | HID_IOF_NON_VOLATILE), \
|
|
HID_RI_END_COLLECTION(0)
|
|
//@}
|
|
|
|
/* Type Defines: */
|
|
/** Enum for possible Class, Subclass and Protocol values of device and interface descriptors relating to the HID
|
|
* device class.
|
|
*/
|
|
enum HID_Descriptor_ClassSubclassProtocol_t
|
|
{
|
|
HID_CSCP_HIDClass = 0x03, /**< Descriptor Class value indicating that the device or interface
|
|
* belongs to the HID class.
|
|
*/
|
|
HID_CSCP_NonBootSubclass = 0x00, /**< Descriptor Subclass value indicating that the device or interface
|
|
* does not implement a HID boot protocol.
|
|
*/
|
|
HID_CSCP_BootSubclass = 0x01, /**< Descriptor Subclass value indicating that the device or interface
|
|
* implements a HID boot protocol.
|
|
*/
|
|
HID_CSCP_NonBootProtocol = 0x00, /**< Descriptor Protocol value indicating that the device or interface
|
|
* does not belong to a HID boot protocol.
|
|
*/
|
|
HID_CSCP_KeyboardBootProtocol = 0x01, /**< Descriptor Protocol value indicating that the device or interface
|
|
* belongs to the Keyboard HID boot protocol.
|
|
*/
|
|
HID_CSCP_MouseBootProtocol = 0x02, /**< Descriptor Protocol value indicating that the device or interface
|
|
* belongs to the Mouse HID boot protocol.
|
|
*/
|
|
};
|
|
|
|
/** Enum for the HID class specific control requests that can be issued by the USB bus host. */
|
|
enum HID_ClassRequests_t
|
|
{
|
|
HID_REQ_GetReport = 0x01, /**< HID class-specific Request to get the current HID report from the device. */
|
|
HID_REQ_GetIdle = 0x02, /**< HID class-specific Request to get the current device idle count. */
|
|
HID_REQ_GetProtocol = 0x03, /**< HID class-specific Request to get the current HID report protocol mode. */
|
|
HID_REQ_SetReport = 0x09, /**< HID class-specific Request to set the current HID report to the device. */
|
|
HID_REQ_SetIdle = 0x0A, /**< HID class-specific Request to set the device's idle count. */
|
|
HID_REQ_SetProtocol = 0x0B, /**< HID class-specific Request to set the current HID report protocol mode. */
|
|
};
|
|
|
|
/** Enum for the HID class specific descriptor types. */
|
|
enum HID_DescriptorTypes_t
|
|
{
|
|
HID_DTYPE_HID = 0x21, /**< Descriptor header type value, to indicate a HID class HID descriptor. */
|
|
HID_DTYPE_Report = 0x22, /**< Descriptor header type value, to indicate a HID class HID report descriptor. */
|
|
};
|
|
|
|
/** Enum for the different types of HID reports. */
|
|
enum HID_ReportItemTypes_t
|
|
{
|
|
HID_REPORT_ITEM_In = 0, /**< Indicates that the item is an IN report type. */
|
|
HID_REPORT_ITEM_Out = 1, /**< Indicates that the item is an OUT report type. */
|
|
HID_REPORT_ITEM_Feature = 2, /**< Indicates that the item is a FEATURE report type. */
|
|
};
|
|
|
|
/** \brief HID class-specific HID Descriptor (LUFA naming conventions).
|
|
*
|
|
* Type define for the HID class-specific HID descriptor, to describe the HID device's specifications. Refer to the HID
|
|
* specification for details on the structure elements.
|
|
*
|
|
* \see \ref USB_HID_StdDescriptor_HID_t for the version of this type with standard element names.
|
|
*
|
|
* \note Regardless of CPU architecture, these values should be stored as little endian.
|
|
*/
|
|
typedef struct
|
|
{
|
|
USB_Descriptor_Header_t Header; /**< Regular descriptor header containing the descriptor's type and length. */
|
|
|
|
uint16_t HIDSpec; /**< BCD encoded version that the HID descriptor and device complies to. */
|
|
uint8_t CountryCode; /**< Country code of the localized device, or zero if universal. */
|
|
|
|
uint8_t TotalReportDescriptors; /**< Total number of HID report descriptors for the interface. */
|
|
|
|
uint8_t HIDReportType; /**< Type of HID report, set to \ref HID_DTYPE_Report. */
|
|
uint16_t HIDReportLength; /**< Length of the associated HID report descriptor, in bytes. */
|
|
} ATTR_PACKED USB_HID_Descriptor_HID_t;
|
|
|
|
/** \brief HID class-specific HID Descriptor (USB-IF naming conventions).
|
|
*
|
|
* Type define for the HID class-specific HID descriptor, to describe the HID device's specifications. Refer to the HID
|
|
* specification for details on the structure elements.
|
|
*
|
|
* \see \ref USB_HID_Descriptor_HID_t for the version of this type with non-standard LUFA specific
|
|
* element names.
|
|
*
|
|
* \note Regardless of CPU architecture, these values should be stored as little endian.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t bLength; /**< Size of the descriptor, in bytes. */
|
|
uint8_t bDescriptorType; /**< Type of the descriptor, either a value in \ref USB_DescriptorTypes_t or a value
|
|
* given by the specific class.
|
|
*/
|
|
|
|
uint16_t bcdHID; /**< BCD encoded version that the HID descriptor and device complies to. */
|
|
uint8_t bCountryCode; /**< Country code of the localized device, or zero if universal. */
|
|
|
|
uint8_t bNumDescriptors; /**< Total number of HID report descriptors for the interface. */
|
|
|
|
uint8_t bDescriptorType2; /**< Type of HID report, set to \ref HID_DTYPE_Report. */
|
|
uint16_t wDescriptorLength; /**< Length of the associated HID report descriptor, in bytes. */
|
|
} ATTR_PACKED USB_HID_StdDescriptor_HID_t;
|
|
|
|
/** \brief Standard HID Boot Protocol Mouse Report.
|
|
*
|
|
* Type define for a standard Boot Protocol Mouse report
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t Button; /**< Button mask for currently pressed buttons in the mouse. */
|
|
int8_t X; /**< Current delta X movement of the mouse. */
|
|
int8_t Y; /**< Current delta Y movement on the mouse. */
|
|
} ATTR_PACKED USB_MouseReport_Data_t;
|
|
|
|
/** \brief Standard HID Boot Protocol Keyboard Report.
|
|
*
|
|
* Type define for a standard Boot Protocol Keyboard report
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t Modifier; /**< Keyboard modifier byte, indicating pressed modifier keys (a combination of
|
|
* \c HID_KEYBOARD_MODIFER_* masks).
|
|
*/
|
|
uint8_t Reserved; /**< Reserved for OEM use, always set to 0. */
|
|
uint8_t KeyCode[6]; /**< Key codes of the currently pressed keys. */
|
|
} ATTR_PACKED USB_KeyboardReport_Data_t;
|
|
|
|
/** Type define for the data type used to store HID report descriptor elements. */
|
|
typedef uint8_t USB_Descriptor_HIDReport_Datatype_t;
|
|
|
|
/* Disable C linkage for C++ Compilers: */
|
|
#if defined(__cplusplus)
|
|
}
|
|
#endif
|
|
|
|
#endif
|
|
|
|
/** @} */
|
|
|