197 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			197 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /**************************************************************************/
 | |
| /*!
 | |
|     @file     std_descriptors.h
 | |
|     @author   hathach (tinyusb.org)
 | |
| 
 | |
|     @section LICENSE
 | |
| 
 | |
|     Software License Agreement (BSD License)
 | |
| 
 | |
|     Copyright (c) 2013, hathach (tinyusb.org)
 | |
|     All rights reserved.
 | |
| 
 | |
|     Redistribution and use in source and binary forms, with or without
 | |
|     modification, are permitted provided that the following conditions are met:
 | |
|     1. Redistributions of source code must retain the above copyright
 | |
|     notice, this list of conditions and the following disclaimer.
 | |
|     2. Redistributions in binary form must reproduce the above copyright
 | |
|     notice, this list of conditions and the following disclaimer in the
 | |
|     documentation and/or other materials provided with the distribution.
 | |
|     3. Neither the name of the copyright holders nor the
 | |
|     names of its contributors may be used to endorse or promote products
 | |
|     derived from this software without specific prior written permission.
 | |
| 
 | |
|     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY
 | |
|     EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 | |
|     WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 | |
|     DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY
 | |
|     DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 | |
|     INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 | |
|     LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION HOWEVER CAUSED AND
 | |
|     ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 | |
|     INCLUDING NEGLIGENCE OR OTHERWISE ARISING IN ANY WAY OUT OF THE USE OF THIS
 | |
|     SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | |
| 
 | |
|     This file is part of the tinyusb stack.
 | |
| */
 | |
| /**************************************************************************/
 | |
| 
 | |
| /** \file
 | |
|  *  \brief Types & Declaration by USB Specs. All documents sources mentioned here (eg section 3.5) is referring to USB 2.0 Specs unless state otherwise
 | |
|  */
 | |
| 
 | |
| /** \defgroup Group_Core Core
 | |
|  * @{
 | |
|  *  \defgroup Group_StdDescriptor Standard Descriptors
 | |
|  *  @{
 | |
|  */
 | |
| 
 | |
| #ifndef _TUSB_STD_DESCRIPTORS_H_
 | |
| #define _TUSB_STD_DESCRIPTORS_H_
 | |
| 
 | |
| #ifdef __cplusplus
 | |
|  extern "C" {
 | |
| #endif
 | |
| 
 | |
| #define STRING_LEN_BYTE2UNICODE(n) (2 + ((n)<<1))
 | |
| 
 | |
| //--------------------------------------------------------------------+
 | |
| // STANDARD DESCRIPTORS
 | |
| //--------------------------------------------------------------------+
 | |
| /// USB Standard Device Descriptor (section 9.6.1, table 9-8)
 | |
| typedef ATTR_PACKED_STRUCT(struct) {
 | |
|   uint8_t  bLength            ; ///< Size of this descriptor in bytes.
 | |
|   uint8_t  bDescriptorType    ; ///< DEVICE Descriptor Type.
 | |
|   uint16_t bcdUSB             ; ///< BUSB Specification Release Number in Binary-Coded Decimal (i.e., 2.10 is 210H). This field identifies the release of the USB Specification with which the device and its descriptors are compliant.
 | |
| 
 | |
|   uint8_t  bDeviceClass       ; ///< Class code (assigned by the USB-IF). \li If this field is reset to zero, each interface within a configuration specifies its own class information and the various interfaces operate independently. \li If this field is set to a value between 1 and FEH, the device supports different class specifications on different interfaces and the interfaces may not operate independently. This value identifies the class definition used for the aggregate interfaces. \li If this field is set to FFH, the device class is vendor-specific.
 | |
|   uint8_t  bDeviceSubClass    ; ///< Subclass code (assigned by the USB-IF). These codes are qualified by the value of the bDeviceClass field. \li If the bDeviceClass field is reset to zero, this field must also be reset to zero. \li If the bDeviceClass field is not set to FFH, all values are reserved for assignment by the USB-IF.
 | |
|   uint8_t  bDeviceProtocol    ; ///< Protocol code (assigned by the USB-IF). These codes are qualified by the value of the bDeviceClass and the bDeviceSubClass fields. If a device supports class-specific protocols on a device basis as opposed to an interface basis, this code identifies the protocols that the device uses as defined by the specification of the device class. \li If this field is reset to zero, the device does not use class-specific protocols on a device basis. However, it may use classspecific protocols on an interface basis. \li If this field is set to FFH, the device uses a vendor-specific protocol on a device basis.
 | |
|   uint8_t  bMaxPacketSize0    ; ///< Maximum packet size for endpoint zero (only 8, 16, 32, or 64 are valid). For HS devices is fixed to 64.
 | |
| 
 | |
|   uint16_t idVendor           ; ///< Vendor ID (assigned by the USB-IF).
 | |
|   uint16_t idProduct          ; ///< Product ID (assigned by the manufacturer).
 | |
|   uint16_t bcdDevice          ; ///< Device release number in binary-coded decimal.
 | |
|   uint8_t  iManufacturer      ; ///< Index of string descriptor describing manufacturer.
 | |
|   uint8_t  iProduct           ; ///< Index of string descriptor describing product.
 | |
|   uint8_t  iSerialNumber      ; ///< Index of string descriptor describing the device's serial number.
 | |
| 
 | |
|   uint8_t  bNumConfigurations ; ///< Number of possible configurations.
 | |
| } tusb_descriptor_device_t;
 | |
| 
 | |
| /// USB Standard Configuration Descriptor (section 9.6.1 table 9-10) */
 | |
| typedef ATTR_PACKED_STRUCT(struct) {
 | |
|   uint8_t  bLength             ; ///< Size of this descriptor in bytes
 | |
|   uint8_t  bDescriptorType     ; ///< CONFIGURATION Descriptor Type
 | |
|   uint16_t wTotalLength        ; ///< Total length of data returned for this configuration. Includes the combined length of all descriptors (configuration, interface, endpoint, and class- or vendor-specific) returned for this configuration.
 | |
| 
 | |
|   uint8_t  bNumInterfaces      ; ///< Number of interfaces supported by this configuration
 | |
|   uint8_t  bConfigurationValue ; ///< Value to use as an argument to the SetConfiguration() request to select this configuration.
 | |
|   uint8_t  iConfiguration      ; ///< Index of string descriptor describing this configuration
 | |
|   uint8_t  bmAttributes        ; ///< Configuration characteristics \n D7: Reserved (set to one)\n D6: Self-powered \n D5: Remote Wakeup \n D4...0: Reserved (reset to zero) \n D7 is reserved and must be set to one for historical reasons. \n A device configuration that uses power from the bus and a local source reports a non-zero value in bMaxPower to indicate the amount of bus power required and sets D6. The actual power source at runtime may be determined using the GetStatus(DEVICE) request (see USB 2.0 spec Section 9.4.5). \n If a device configuration supports remote wakeup, D5 is set to one.
 | |
|   uint8_t  bMaxPower           ; ///< Maximum power consumption of the USB device from the bus in this specific configuration when the device is fully operational. Expressed in 2 mA units (i.e., 50 = 100 mA).
 | |
| } tusb_descriptor_configuration_t;
 | |
| 
 | |
| /// USB Standard Interface Descriptor (section 9.6.1 table 9-12)
 | |
| typedef ATTR_PACKED_STRUCT(struct) {
 | |
|   uint8_t  bLength            ; ///< Size of this descriptor in bytes
 | |
|   uint8_t  bDescriptorType    ; ///< INTERFACE Descriptor Type
 | |
| 
 | |
|   uint8_t  bInterfaceNumber   ; ///< Number of this interface. Zero-based value identifying the index in the array of concurrent interfaces supported by this configuration.
 | |
|   uint8_t  bAlternateSetting  ; ///< Value used to select this alternate setting for the interface identified in the prior field
 | |
|   uint8_t  bNumEndpoints      ; ///< Number of endpoints used by this interface (excluding endpoint zero). If this value is zero, this interface only uses the Default Control Pipe.
 | |
|   uint8_t  bInterfaceClass    ; ///< Class code (assigned by the USB-IF). \li A value of zero is reserved for future standardization. \li If this field is set to FFH, the interface class is vendor-specific. \li All other values are reserved for assignment by the USB-IF.
 | |
|   uint8_t  bInterfaceSubClass ; ///< Subclass code (assigned by the USB-IF). \n These codes are qualified by the value of the bInterfaceClass field. \li If the bInterfaceClass field is reset to zero, this field must also be reset to zero. \li If the bInterfaceClass field is not set to FFH, all values are reserved for assignment by the USB-IF.
 | |
|   uint8_t  bInterfaceProtocol ; ///< Protocol code (assigned by the USB). \n These codes are qualified by the value of the bInterfaceClass and the bInterfaceSubClass fields. If an interface supports class-specific requests, this code identifies the protocols that the device uses as defined by the specification of the device class. \li If this field is reset to zero, the device does not use a class-specific protocol on this interface. \li If this field is set to FFH, the device uses a vendor-specific protocol for this interface.
 | |
|   uint8_t  iInterface         ; ///< Index of string descriptor describing this interface
 | |
| } tusb_descriptor_interface_t;
 | |
| 
 | |
| /// USB Standard Endpoint Descriptor (section 9.6.1 table 9-13)
 | |
| typedef ATTR_PACKED_STRUCT(struct) {
 | |
|   uint8_t  bLength          ; ///< Size of this descriptor in bytes
 | |
|   uint8_t  bDescriptorType  ; ///< ENDPOINT Descriptor Type
 | |
| 
 | |
|   uint8_t  bEndpointAddress ; ///< The address of the endpoint on the USB device described by this descriptor. The address is encoded as follows: \n Bit 3...0: The endpoint number \n Bit 6...4: Reserved, reset to zero \n Bit 7: Direction, ignored for control endpoints 0 = OUT endpoint 1 = IN endpoint.
 | |
| 
 | |
|   ATTR_PACKED_STRUCT(struct) {
 | |
|     uint8_t xfer  : 2;
 | |
|     uint8_t sync  : 2;
 | |
|     uint8_t usage : 2;
 | |
|     uint8_t       : 2;
 | |
|   } bmAttributes     ; ///< This field describes the endpoint's attributes when it is configured using the bConfigurationValue. \n Bits 1..0: Transfer Type \n- 00 = Control \n- 01 = Isochronous \n- 10 = Bulk \n- 11 = Interrupt \n If not an isochronous endpoint, bits 5..2 are reserved and must be set to zero. If isochronous, they are defined as follows: \n Bits 3..2: Synchronization Type \n- 00 = No Synchronization \n- 01 = Asynchronous \n- 10 = Adaptive \n- 11 = Synchronous \n Bits 5..4: Usage Type \n- 00 = Data endpoint \n- 01 = Feedback endpoint \n- 10 = Implicit feedback Data endpoint \n- 11 = Reserved \n Refer to Chapter 5 of USB 2.0 specification for more information. \n All other bits are reserved and must be reset to zero. Reserved bits must be ignored by the host.
 | |
| 
 | |
|   ATTR_PACKED_STRUCT(struct) {
 | |
|     uint16_t size           : 11; ///< Maximum packet size this endpoint is capable of sending or receiving when this configuration is selected. \n For isochronous endpoints, this value is used to reserve the bus time in the schedule, required for the per-(micro)frame data payloads. The pipe may, on an ongoing basis, actually use less bandwidth than that reserved. The device reports, if necessary, the actual bandwidth used via its normal, non-USB defined mechanisms. \n For all endpoints, bits 10..0 specify the maximum packet size (in bytes). \n For high-speed isochronous and interrupt endpoints: \n Bits 12..11 specify the number of additional transaction opportunities per microframe: \n- 00 = None (1 transaction per microframe) \n- 01 = 1 additional (2 per microframe) \n- 10 = 2 additional (3 per microframe) \n- 11 = Reserved \n Bits 15..13 are reserved and must be set to zero.
 | |
|     uint16_t hs_period_mult : 2;
 | |
|     uint16_t : 0;
 | |
|   }wMaxPacketSize;
 | |
| 
 | |
|   uint8_t  bInterval        ; ///< Interval for polling endpoint for data transfers. Expressed in frames or microframes depending on the device operating speed (i.e., either 1 millisecond or 125 us units). \n- For full-/high-speed isochronous endpoints, this value must be in the range from 1 to 16. The bInterval value is used as the exponent for a \f$ 2^(bInterval-1) \f$ value; e.g., a bInterval of 4 means a period of 8 (\f$ 2^(4-1) \f$). \n- For full-/low-speed interrupt endpoints, the value of this field may be from 1 to 255. \n- For high-speed interrupt endpoints, the bInterval value is used as the exponent for a \f$ 2^(bInterval-1) \f$ value; e.g., a bInterval of 4 means a period of 8 (\f$ 2^(4-1) \f$) . This value must be from 1 to 16. \n- For high-speed bulk/control OUT endpoints, the bInterval must specify the maximum NAK rate of the endpoint. A value of 0 indicates the endpoint never NAKs. Other values indicate at most 1 NAK each bInterval number of microframes. This value must be in the range from 0 to 255. \n Refer to Chapter 5 of USB 2.0 specification for more information.
 | |
| } tusb_descriptor_endpoint_t;
 | |
| 
 | |
| /// USB Other Speed Configuration Descriptor (section 9.6.1 table 9-11)
 | |
| typedef ATTR_PACKED_STRUCT(struct) {
 | |
|   uint8_t  bLength             ; ///< Size of descriptor
 | |
|   uint8_t  bDescriptorType     ; ///< Other_speed_Configuration Type
 | |
|   uint16_t wTotalLength        ; ///< Total length of data returned
 | |
| 
 | |
|   uint8_t  bNumInterfaces      ; ///< Number of interfaces supported by this speed configuration
 | |
|   uint8_t  bConfigurationValue ; ///< Value to use to select configuration
 | |
|   uint8_t  IConfiguration      ; ///< Index of string descriptor
 | |
|   uint8_t  bmAttributes        ; ///< Same as Configuration descriptor
 | |
|   uint8_t  bMaxPower           ; ///< Same as Configuration descriptor
 | |
| } tusb_descriptor_other_speed_t;
 | |
| 
 | |
| /// USB Device Qualifier Descriptor (section 9.6.1 table 9-9)
 | |
| typedef ATTR_PACKED_STRUCT(struct) {
 | |
|   uint8_t  bLength            ; ///< Size of descriptor
 | |
|   uint8_t  bDescriptorType    ; ///< Device Qualifier Type
 | |
|   uint16_t bcdUSB             ; ///< USB specification version number (e.g., 0200H for V2.00)
 | |
| 
 | |
|   uint8_t  bDeviceClass       ; ///< Class Code
 | |
|   uint8_t  bDeviceSubClass    ; ///< SubClass Code
 | |
|   uint8_t  bDeviceProtocol    ; ///< Protocol Code
 | |
|   uint8_t  bMaxPacketSize0    ; ///< Maximum packet size for other speed
 | |
|   uint8_t  bNumConfigurations ; ///< Number of Other-speed Configurations
 | |
|   uint8_t  bReserved          ; ///< Reserved for future use, must be zero
 | |
| } tusb_descriptor_device_qualifier_t;
 | |
| 
 | |
| /// USB Interface Association Descriptor (IAD ECN)
 | |
| typedef ATTR_PACKED_STRUCT(struct)
 | |
| {
 | |
|   uint8_t bLength           ; ///< Size of descriptor
 | |
|   uint8_t bDescriptorType   ; ///< Other_speed_Configuration Type
 | |
| 
 | |
|   uint8_t bFirstInterface   ; ///< Index of the first associated interface.
 | |
|   uint8_t bInterfaceCount   ; ///< Total number of associated interfaces.
 | |
| 
 | |
|   uint8_t bFunctionClass    ; ///< Interface class ID.
 | |
|   uint8_t bFunctionSubClass ; ///< Interface subclass ID.
 | |
|   uint8_t bFunctionProtocol ; ///< Interface protocol ID.
 | |
| 
 | |
|   uint8_t iFunction         ; ///< Index of the string descriptor describing the interface association.
 | |
| } tusb_descriptor_interface_association_t;
 | |
| 
 | |
| /// USB Header Descriptor
 | |
| typedef ATTR_PACKED_STRUCT(struct)
 | |
| {
 | |
|   uint8_t  bLength         ; ///< Size of this descriptor in bytes
 | |
|   uint8_t  bDescriptorType ; ///< Descriptor Type
 | |
| } tusb_descriptor_header_t;
 | |
| 
 | |
| typedef ATTR_PACKED_STRUCT(struct)
 | |
| {
 | |
|   uint8_t  bLength         ; ///< Size of this descriptor in bytes
 | |
|   uint8_t  bDescriptorType ; ///< Descriptor Type
 | |
|   uint16_t unicode_string[];
 | |
| } tusb_descriptor_string_t;
 | |
| 
 | |
| #ifdef __cplusplus
 | |
|  }
 | |
| #endif
 | |
| 
 | |
| #endif /* _TUSB_STD_DESCRIPTORS_H_ */
 | |
| 
 | |
| /** @} */
 | |
| /** @} */
 | 
