1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/sys/include/usb/descriptor.h

225 lines
10 KiB
C

/*
* Copyright (C) 2018 Koen Zandberg <koen@bergzand.net>
*
* This file is subject to the terms and conditions of the GNU Lesser General
* Public License v2.1. See the file LICENSE in the top level directory for
* more details.
*/
/**
* @defgroup usb_descriptor USB descriptors
* @ingroup usb
* @brief Provides USB protocol descriptors and defines for USB frameworks.
* @{
*
* @file
* @brief Definitions for USB protocol messages
*
* @author Koen Zandberg <koen@bergzand.net>
*/
#ifndef USB_DESCRIPTOR_H
#define USB_DESCRIPTOR_H
#include <stdint.h>
#include <stdbool.h>
#ifdef __cplusplus
extern "C" {
#endif
/**
* @name USB standard device request codes (USB 2.0 spec table 9-4)
* @{
*/
#define USB_SETUP_REQ_GET_STATUS 0x00 /**< Status request */
#define USB_SETUP_REQ_CLEAR_FEATURE 0x01 /**< Clear feature */
#define USB_SETUP_REQ_SET_FEATURE 0x03 /**< Set feature */
#define USB_SETUP_REQ_SET_ADDRESS 0x05 /**< Set address */
#define USB_SETUP_REQ_GET_DESCRIPTOR 0x06 /**< Get descriptor */
#define USB_SETUP_REQ_SET_DESCRIPTOR 0x07 /**< Set descriptor */
#define USB_SETUP_REQ_GET_CONFIGURATION 0x08 /**< Get configuration */
#define USB_SETUP_REQ_SET_CONFIGURATION 0x09 /**< Set configuration */
#define USB_SETUP_REQ_GET_INTERFACE 0x0a /**< Get interface */
#define USB_SETUP_REQ_SET_INTERFACE 0x0b /**< Set interface */
#define USB_SETUP_REQ_SYNCH_FRAME 0x0c /**< Synch frame */
/** @} */
/**
* @name USB descriptor types (USB 2.0 spec table 9-5)
* @{
*/
#define USB_TYPE_DESCRIPTOR_DEVICE 0x01 /**< Device descriptor */
#define USB_TYPE_DESCRIPTOR_CONFIGURATION 0x02 /**< Configuration Descriptor */
#define USB_TYPE_DESCRIPTOR_STRING 0x03 /**< String descriptor */
#define USB_TYPE_DESCRIPTOR_INTERFACE 0x04 /**< Interface descriptor */
#define USB_TYPE_DESCRIPTOR_ENDPOINT 0x05 /**< Endpoint descriptor */
#define USB_TYPE_DESCRIPTOR_DEV_QUALIFIER 0x06 /**< Device qualifier */
#define USB_TYPE_DESCRIPTOR_SPEED_CONFIG 0x07 /**< Other speed configuration */
#define USB_TYPE_DESCRIPTOR_IFACE_POWER 0x08 /**< Interface power */
#define USB_TYPE_DESCRIPTOR_INTERFACE_ASSOC 0x0b /**< Interface association */
/** @} */
/**
* @name USB configuration attributes
* @anchor USB_CONF_ATTR
* @{
*/
#define USB_CONF_ATTR_RESERVED 0x80 /**< Reserved bit (always 1) */
#define USB_CONF_ATTR_SELF_POWERED 0x40 /**< Self powered device flag */
#define USB_CONF_ATTR_REM_WAKEUP 0x20 /**< Remote wake-up flag */
/** @} */
/**
* @name USB setup packet requests types
* @{
*/
#define USB_SETUP_REQUEST_DEVICE2HOST 0x80 /**< Request direction
From device to host if
the bit is set */
#define USB_SETUP_REQUEST_RECIPIENT_MASK 0x1f /**< Recipient mask */
#define USB_SETUP_REQUEST_RECIPIENT_DEVICE 0x00 /**< Device request */
#define USB_SETUP_REQUEST_RECIPIENT_INTERFACE 0x01 /**< Interface request */
#define USB_SETUP_REQUEST_RECIPIENT_ENDPOINT 0x02 /**< Endpoint request */
#define USB_SETUP_REQUEST_RECIPIENT_OTHER 0x03 /**< Other type request */
#define USB_SETUP_REQUEST_TYPE_MASK 0x60 /**< Mask to select the type */
#define USB_SETUP_REQUEST_TYPE_STANDARD 0x00 /**< Standard request */
#define USB_SETUP_REQUEST_TYPE_CLASS 0x20 /**< Class request */
#define USB_SETUP_REQUEST_TYPE_VENDOR 0x40 /**< Vendor specific request */
/** @} */
/**
* @brief USB isochronous endpoint interval
*/
#define USB_ENDPOINT_DESCRIPTOR_INTERVAL_ISOCHRONOUS 1
/**
* @name USB device class numbers
* @{
*/
#define USB_CLASS_AUDIO 0x01 /**< Audio device */
#define USB_CLASS_CDC_CONTROL 0x02 /**< CDC control interface */
#define USB_CLASS_HID 0x03 /**< Human Interface device */
#define USB_CLASS_PHYSICAL 0x05 /**< Physical device class */
#define USB_CLASS_IMAGE 0x06 /**< Image device class */
#define USB_CLASS_PRINTER 0x07 /**< Printer device class */
#define USB_CLASS_MASS_STORAGE 0x08 /**< Mass storage device class */
#define USB_CLASS_CDC_DATA 0x0a /**< CDC data specification */
#define USB_CLASS_VENDOR 0xff /**< Vendor specific class */
/** @} */
/**
* @brief USB device descriptor (USB 2.0 spec table 9-8)
*/
typedef struct __attribute__((packed)) {
uint8_t length; /**< Size of this descriptor */
uint8_t type; /**< Descriptor type (@ref USB_TYPE_DESCRIPTOR_DEVICE) */
uint16_t bcd_usb; /**< Binary-coded decimal USB release specification */
uint8_t class; /**< Device class code */
uint8_t subclass; /**< Device subclass code */
uint8_t protocol; /**< Device protocol code */
uint8_t max_packet_size; /**< EP0 max packet size (8, 16, 32 or 64 bytes) */
uint16_t vendor_id; /**< Vendor ID (as assigned by the USB-IF) */
uint16_t product_id; /**< Product ID */
uint16_t bcd_device; /**< Binary-coded decimal device release */
uint8_t manufacturer_idx; /**< Manufacturer string index number */
uint8_t product_idx; /**< Product string index number */
uint8_t serial_idx; /**< Device serial number string index number */
uint8_t num_configurations; /**< Number of possible configurations */
} usb_descriptor_device_t;
/**
* @brief USB configuration descriptor (USB 2.0 spec table 9-10)
*/
typedef struct __attribute__((packed)) {
uint8_t length; /**< Size of this descriptor */
uint8_t type; /**< Descriptor type (@ref USB_TYPE_DESCRIPTOR_CONFIGURATION) */
uint16_t total_length; /**< Total length of the configuration */
uint8_t num_interfaces; /**< Number of interfaces supported by this configuration */
uint8_t val; /**< Value to select this configuration by */
uint8_t idx; /**< Configuration descriptor string index */
uint8_t attributes; /**< Configuration attributes (@ref USB_CONF_ATTR) */
uint8_t max_power; /**< Maximum power consumption in 2mA steps */
} usb_descriptor_configuration_t;
/**
* @brief USB interface descriptor (USB 2.0 spec table 9-12)
*/
typedef struct __attribute__((packed)) {
uint8_t length; /**< Size of this descriptor */
uint8_t type; /**< Descriptor type (@ref USB_TYPE_DESCRIPTOR_INTERFACE) */
uint8_t interface_num; /**< Interface number */
uint8_t alternate_setting; /**< Alternate setting index */
uint8_t num_endpoints; /**< Number of endpoints used by this interface */
uint8_t class; /**< Interface class code as assigned by the USB-IF */
uint8_t subclass; /**< Subclass code as assigned by the USB-IF */
uint8_t protocol; /**< Protocol code */
uint8_t idx; /**< Interface descriptor string index */
} usb_descriptor_interface_t;
/**
* @brief USB endpoint descriptor (USB 2.0 spec table 9-13)
*/
typedef struct __attribute__((packed)) {
uint8_t length; /**< Size of this descriptor */
uint8_t type; /**< Descriptor type (@ref USB_TYPE_DESCRIPTOR_ENDPOINT) */
uint8_t address; /**< Address of the endpoint */
uint8_t attributes; /**< Attributes of the endpoint */
uint16_t max_packet_size; /**< Maximum packet size of the endpoint */
uint8_t interval; /**< Polling interval for the endpoint */
} usb_descriptor_endpoint_t;
/**
* @brief USB string descriptor (USB 2.0 spec table 9-16)
*/
typedef struct __attribute__((packed)) {
uint8_t length; /**< Size of this descriptor */
uint8_t type; /**< String descriptor type */
} usb_descriptor_string_t;
/**
* @brief USB interface association descriptor (Interface Association
* Descriptors table 9-Z)
*/
typedef struct __attribute__((packed)) {
uint8_t length; /**< Size of this descriptor */
uint8_t type; /**< Descriptor type (@ref USB_TYPE_DESCRIPTOR_INTERFACE_ASSOC) */
uint8_t first_interface; /**< Index of the first associated interface */
uint8_t interface_count; /**< Number of associated interfaces */
uint8_t class; /**< Non-zero class code */
uint8_t subclass; /**< Subclass code */
uint8_t protocol; /**< Protocol code */
uint8_t idx; /**< Descriptor string index */
} usb_descriptor_interface_association_t;
/**
* @brief USB setup packet (USB 2.0 spec table 9-2)
*/
typedef struct __attribute__((packed)) {
uint8_t type; /**< Request type */
uint8_t request; /**< Specific request */
uint16_t value; /**< Value word */
uint16_t index; /**< Index/offset word */
uint16_t length; /**< Length of the data stage */
} usb_setup_t;
/**
* @brief getter for setup packet direction
*
* @param[in] pkt setup packet
*
* @return nonzero if it is a read request
* @return zero if it is a write request
*/
static inline bool usb_setup_is_read(usb_setup_t *pkt)
{
return pkt->type & USB_SETUP_REQUEST_DEVICE2HOST;
}
#ifdef __cplusplus
}
#endif
#endif /* USB_DESCRIPTOR_H */
/** @} */