Blame view

atmega16u2/custom/PolytechLille/PAD/Descriptors.h 2.48 KB
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