EA BaseBoard, playing wav, PC see\'s SD-card through USB port.

Dependencies:   mbed

Committer:
Lerche
Date:
Tue Nov 22 05:45:58 2011 +0000
Revision:
0:fef366d2ed20
Thanks to those who provided EA_WavPlayer and USB_MSC

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Lerche 0:fef366d2ed20 1 /* USBDescriptor.h */
Lerche 0:fef366d2ed20 2 /* Definitions and macros for constructing USB descriptors */
Lerche 0:fef366d2ed20 3 /* Copyright (c) 2011 ARM Limited. All rights reserved. */
Lerche 0:fef366d2ed20 4
Lerche 0:fef366d2ed20 5 /* Standard descriptor types */
Lerche 0:fef366d2ed20 6 #define DEVICE_DESCRIPTOR (1)
Lerche 0:fef366d2ed20 7 #define CONFIGURATION_DESCRIPTOR (2)
Lerche 0:fef366d2ed20 8 #define STRING_DESCRIPTOR (3)
Lerche 0:fef366d2ed20 9 #define INTERFACE_DESCRIPTOR (4)
Lerche 0:fef366d2ed20 10 #define ENDPOINT_DESCRIPTOR (5)
Lerche 0:fef366d2ed20 11 #define QUALIFIER_DESCRIPTOR (6)
Lerche 0:fef366d2ed20 12
Lerche 0:fef366d2ed20 13 /* Standard descriptor lengths */
Lerche 0:fef366d2ed20 14 #define DEVICE_DESCRIPTOR_LENGTH (0x12)
Lerche 0:fef366d2ed20 15 #define CONFIGURATION_DESCRIPTOR_LENGTH (0x09)
Lerche 0:fef366d2ed20 16 #define INTERFACE_DESCRIPTOR_LENGTH (0x09)
Lerche 0:fef366d2ed20 17 #define ENDPOINT_DESCRIPTOR_LENGTH (0x07)
Lerche 0:fef366d2ed20 18
Lerche 0:fef366d2ed20 19
Lerche 0:fef366d2ed20 20 /*string offset*/
Lerche 0:fef366d2ed20 21 #define STRING_OFFSET_LANGID (0)
Lerche 0:fef366d2ed20 22 #define STRING_OFFSET_IMANUFACTURER (1)
Lerche 0:fef366d2ed20 23 #define STRING_OFFSET_IPRODUCT (2)
Lerche 0:fef366d2ed20 24 #define STRING_OFFSET_ISERIAL (3)
Lerche 0:fef366d2ed20 25 #define STRING_OFFSET_ICONFIGURATION (4)
Lerche 0:fef366d2ed20 26 #define STRING_OFFSET_IINTERFACE (5)
Lerche 0:fef366d2ed20 27
Lerche 0:fef366d2ed20 28 /* USB Specification Release Number */
Lerche 0:fef366d2ed20 29 #define USB_VERSION_2_0 (0x0200)
Lerche 0:fef366d2ed20 30
Lerche 0:fef366d2ed20 31 /* Least/Most significant byte of short integer */
Lerche 0:fef366d2ed20 32 #define LSB(n) ((n)&0xff)
Lerche 0:fef366d2ed20 33 #define MSB(n) (((n)&0xff00)>>8)
Lerche 0:fef366d2ed20 34
Lerche 0:fef366d2ed20 35 /* Convert physical endpoint number to descriptor endpoint number */
Lerche 0:fef366d2ed20 36 #define PHY_TO_DESC(endpoint) (((endpoint)>>1) | (((endpoint) & 1) ? 0x80:0))
Lerche 0:fef366d2ed20 37
Lerche 0:fef366d2ed20 38 /* bmAttributes in configuration descriptor */
Lerche 0:fef366d2ed20 39 /* C_RESERVED must always be set */
Lerche 0:fef366d2ed20 40 #define C_RESERVED (1U<<7)
Lerche 0:fef366d2ed20 41 #define C_SELF_POWERED (1U<<6)
Lerche 0:fef366d2ed20 42 #define C_REMOTE_WAKEUP (1U<<5)
Lerche 0:fef366d2ed20 43
Lerche 0:fef366d2ed20 44 /* bMaxPower in configuration descriptor */
Lerche 0:fef366d2ed20 45 #define C_POWER(mA) ((mA)/2)
Lerche 0:fef366d2ed20 46
Lerche 0:fef366d2ed20 47 /* bmAttributes in endpoint descriptor */
Lerche 0:fef366d2ed20 48 #define E_CONTROL (0x00)
Lerche 0:fef366d2ed20 49 #define E_ISOCHRONOUS (0x01)
Lerche 0:fef366d2ed20 50 #define E_BULK (0x02)
Lerche 0:fef366d2ed20 51 #define E_INTERRUPT (0x03)
Lerche 0:fef366d2ed20 52
Lerche 0:fef366d2ed20 53 /* For isochronous endpoints only: */
Lerche 0:fef366d2ed20 54 #define E_NO_SYNCHRONIZATION (0x00)
Lerche 0:fef366d2ed20 55 #define E_ASYNCHRONOUS (0x04)
Lerche 0:fef366d2ed20 56 #define E_ADAPTIVE (0x08)
Lerche 0:fef366d2ed20 57 #define E_SYNCHRONOUS (0x0C)
Lerche 0:fef366d2ed20 58 #define E_DATA (0x00)
Lerche 0:fef366d2ed20 59 #define E_FEEDBACK (0x10)
Lerche 0:fef366d2ed20 60 #define E_IMPLICIT_FEEDBACK (0x20)