8a7dc1f5
adorian
Seance 4
|
1
2
3
4
5
|
#ifndef _DESCRIPTORS_H_
#define _DESCRIPTORS_H_
/* Includes: */
#include <avr/pgmspace.h>
|
8a7dc1f5
adorian
Seance 4
|
6
7
8
9
10
11
12
13
14
15
16
|
#include <LUFA/Drivers/USB/USB.h>
/* Type Defines: */
/** Type define for the device configuration descriptor structure. This must be defined in the
* application code, as the configuration descriptor contains several sub-descriptors which
* vary between devices, and which describe the device's usage to the host.
*/
typedef struct
{
USB_Descriptor_Configuration_Header_t Config;
|
3a6e8ae8
root
Nettoyage
|
17
18
19
20
21
22
23
|
// PAD Interface
USB_Descriptor_Interface_t PAD_Interface_LED;
USB_Descriptor_Endpoint_t PAD_OUT_LED1;
USB_Descriptor_Endpoint_t PAD_OUT_LED2;
USB_Descriptor_Interface_t PAD_Interface_BUTTON;
USB_Descriptor_Endpoint_t PAD_IN_BUTTON1;
USB_Descriptor_Endpoint_t PAD_IN_BUTTON2;
|
8a7dc1f5
adorian
Seance 4
|
24
25
26
27
28
29
30
31
|
} USB_Descriptor_Configuration_t;
/** Enum for the device interface descriptor IDs within the device. Each interface descriptor
* should have a unique ID index associated with it, which can be used to refer to the
* interface from other descriptors.
*/
enum InterfaceDescriptors_t
{
|
3a6e8ae8
root
Nettoyage
|
32
33
|
INTERFACE_ID_LED = 0,
INTERFACE_ID_BUTTON = 1,
|
8a7dc1f5
adorian
Seance 4
|
34
35
36
37
38
39
40
41
42
43
44
|
};
/** Enum for the device string descriptor IDs within the device. Each string descriptor should
* have a unique ID index associated with it, which can be used to refer to the string from
* other descriptors.
*/
enum StringDescriptors_t
{
STRING_ID_Language = 0, /**< Supported Languages string descriptor ID (must be zero) */
STRING_ID_Manufacturer = 1, /**< Manufacturer string ID */
STRING_ID_Product = 2, /**< Product string ID */
|
3a6e8ae8
root
Nettoyage
|
45
|
STRING_ID_Serial = 3, /**< Serial number string ID */
|
8a7dc1f5
adorian
Seance 4
|
46
47
|
};
|
3a6e8ae8
root
Nettoyage
|
48
|
|
8a7dc1f5
adorian
Seance 4
|
49
|
/* Macros: */
|
3a6e8ae8
root
Nettoyage
|
50
51
52
53
|
/** Endpoint address of the Keyboard HID reporting OUT endpoint. */
#define PAD_OUT_EP_LED1 (ENDPOINT_DIR_OUT | 1)
#define PAD_OUT_EP_LED2 (ENDPOINT_DIR_OUT | 2)
|
8a7dc1f5
adorian
Seance 4
|
54
|
/** Endpoint address of the Keyboard HID reporting IN endpoint. */
|
3a6e8ae8
root
Nettoyage
|
55
56
|
#define PAD_IN_EP_BUTTON1 (ENDPOINT_DIR_IN | 3)
#define PAD_IN_EP_BUTTON2 (ENDPOINT_DIR_IN | 4)
|
8a7dc1f5
adorian
Seance 4
|
57
|
|
3a6e8ae8
root
Nettoyage
|
58
59
|
/** Size in bytes of the Keyboard HID reporting IN and OUT endpoints. */
#define PAD_EPSIZE 1
|
8a7dc1f5
adorian
Seance 4
|
60
61
62
63
64
65
|
/* Function Prototypes: */
uint16_t CALLBACK_USB_GetDescriptor(const uint16_t wValue,
const uint16_t wIndex,
const void** const DescriptorAddress)
ATTR_WARN_UNUSED_RESULT ATTR_NON_NULL_PTR_ARG(3);
|
8a7dc1f5
adorian
Seance 4
|
66
|
#endif
|