Microchip® Advanced Software Framework

 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
USB device descriptors for a single interface

The following structures provide the USB device descriptors required for USB Device with a single interface Vendor Class.

It is ready to use and do not require more definition.

Data Structures

struct  udc_desc_t
 Structure for USB Device Configuration Descriptor. More...
 

Macros

#define UDI_VENDOR_EP_BULK_IN
 
#define UDI_VENDOR_EP_BULK_OUT
 
#define UDI_VENDOR_EP_INTERRUPT_IN   (1 | USB_EP_DIR_IN)
 Endpoint numbers used by vendor interface. More...
 
#define UDI_VENDOR_EP_INTERRUPT_OUT   (2 | USB_EP_DIR_OUT)
 
#define UDI_VENDOR_EP_ISO_IN
 
#define UDI_VENDOR_EP_ISO_OUT
 
#define UDI_VENDOR_IFACE_NUMBER   0
 Interface number is 0 because it is the unique interface. More...
 
#define USB_DEVICE_EP_CTRL_SIZE   64
 Control endpoint size. More...
 
#define USB_DEVICE_NB_INTERFACE   1
 Only one interface for this device. More...
 

Variables

UDC_DESC_STORAGE udc_desc_t udc_desc_fs
 USB Device Configuration Descriptor filled for FS. More...
 
UDC_DESC_STORAGE usb_dev_desc_t udc_device_desc
 USB Device Descriptor. More...
 

UDC structures which contains all USB Device definitions

UDC_DESC_STORAGE udi_api_tudi_apis [USB_DEVICE_NB_INTERFACE]
 Associate an UDI for each USB interface. More...
 
UDC_DESC_STORAGE udc_config_speed_t udc_config_lsfs [1]
 Add UDI with USB Descriptors FS. More...
 
UDC_DESC_STORAGE udc_config_t udc_config
 Add all information about USB Device in global structure for UDC. More...
 

UDD Configuration

#define UDI_VENDOR_EP_NB_INT   ((UDI_VENDOR_EPS_SIZE_INT_FS)?2:0)
 Maximum 6 endpoints used by vendor interface. More...
 
#define UDI_VENDOR_EP_NB_BULK   ((UDI_VENDOR_EPS_SIZE_BULK_FS)?2:0)
 
#define UDI_VENDOR_EP_NB_ISO   ((UDI_VENDOR_EPS_SIZE_ISO_FS)?2:0)
 
#define USB_DEVICE_MAX_EP   (UDI_VENDOR_EP_NB_INT+UDI_VENDOR_EP_NB_BULK+UDI_VENDOR_EP_NB_ISO)
 

#define UDI_VENDOR_EP_BULK_IN
Value:
#define UDI_VENDOR_EPS_SIZE_INT_FS
endpoints size for full speed Note: Disable the endpoints of a type, if size equal 0 ...
Definition: vendor/device/example/conf_usb.h:117
#define USB_EP_DIR_IN
Endpoint transfer direction is IN.
Definition: usb_protocol.h:274
#define UDI_VENDOR_EP_BULK_OUT
Value:
#define USB_EP_DIR_OUT
Endpoint transfer direction is OUT.
Definition: usb_protocol.h:279
#define UDI_VENDOR_EPS_SIZE_INT_FS
endpoints size for full speed Note: Disable the endpoints of a type, if size equal 0 ...
Definition: vendor/device/example/conf_usb.h:117
#define UDI_VENDOR_EP_INTERRUPT_IN   (1 | USB_EP_DIR_IN)

Endpoint numbers used by vendor interface.

Note: The order of endpoint can depend on USB hardware capability when a specific mapping is used on USB DPRAM.

#define UDI_VENDOR_EP_INTERRUPT_OUT   (2 | USB_EP_DIR_OUT)
#define UDI_VENDOR_EP_ISO_IN
Value:
#define UDI_VENDOR_EPS_SIZE_INT_FS
endpoints size for full speed Note: Disable the endpoints of a type, if size equal 0 ...
Definition: vendor/device/example/conf_usb.h:117
#define UDI_VENDOR_EPS_SIZE_BULK_FS
Definition: vendor/device/example/conf_usb.h:118
#define USB_EP_DIR_IN
Endpoint transfer direction is IN.
Definition: usb_protocol.h:274
#define UDI_VENDOR_EP_ISO_OUT
Value:
#define USB_EP_DIR_OUT
Endpoint transfer direction is OUT.
Definition: usb_protocol.h:279
#define UDI_VENDOR_EPS_SIZE_INT_FS
endpoints size for full speed Note: Disable the endpoints of a type, if size equal 0 ...
Definition: vendor/device/example/conf_usb.h:117
#define UDI_VENDOR_EPS_SIZE_BULK_FS
Definition: vendor/device/example/conf_usb.h:118
#define UDI_VENDOR_EP_NB_BULK   ((UDI_VENDOR_EPS_SIZE_BULK_FS)?2:0)
#define UDI_VENDOR_EP_NB_INT   ((UDI_VENDOR_EPS_SIZE_INT_FS)?2:0)

Maximum 6 endpoints used by vendor interface.

#define UDI_VENDOR_EP_NB_ISO   ((UDI_VENDOR_EPS_SIZE_ISO_FS)?2:0)
#define UDI_VENDOR_IFACE_NUMBER   0

Interface number is 0 because it is the unique interface.

#define USB_DEVICE_EP_CTRL_SIZE   64

Control endpoint size.

#define USB_DEVICE_NB_INTERFACE   1

Only one interface for this device.

Initial value:
= {
.confdev_lsfs = &udc_device_desc,
.conf_lsfs = udc_config_lsfs,
}
UDC_DESC_STORAGE usb_dev_desc_t udc_device_desc
USB Device Descriptor.
Definition: udi_msc_desc.c:58
UDC_DESC_STORAGE udc_config_speed_t udc_config_lsfs[1]
Add UDI with USB Descriptors FS.
Definition: udi_msc_desc.c:154

Add all information about USB Device in global structure for UDC.

Global variables of USB Device Descriptor and UDI links.

Initial value:
= {{
}}
UDC_DESC_STORAGE udi_api_t * udi_apis[USB_DEVICE_NB_INTERFACE]
Associate an UDI for each USB interface.
Definition: udi_msc_desc.c:149
Standard USB configuration descriptor structure.
Definition: usb_protocol.h:410
UDC_DESC_STORAGE udc_desc_t udc_desc_fs
USB Device Configuration Descriptor filled for FS.
Definition: udi_msc_desc.c:114
#define UDC_DESC_STORAGE
Defines the memory's location of USB descriptors.
Definition: udc_desc.h:70

Add UDI with USB Descriptors FS.

Initial value:
= {
.conf.bLength = sizeof(usb_conf_desc_t),
.conf.bDescriptorType = USB_DT_CONFIGURATION,
.conf.wTotalLength = LE16(sizeof(udc_desc_t)),
.conf.bNumInterfaces = USB_DEVICE_NB_INTERFACE,
.conf.bConfigurationValue = 1,
.conf.iConfiguration = 0,
.conf.bmAttributes = USB_CONFIG_ATTR_MUST_SET | USB_DEVICE_ATTR,
.udi_vendor = UDI_VENDOR_DESC_FS,
}
Definition: usb_protocol.h:191
#define USB_CONFIG_ATTR_MUST_SET
Must always be set.
Definition: usb_protocol.h:422
Standard USB configuration descriptor structure.
Definition: usb_protocol.h:410
#define LE16(x)
Definition: compiler.h:886
#define UDI_VENDOR_DESC_FS
Content of vendor interface descriptor for full speed only.
Definition: udi_vendor.h:234
#define USB_DEVICE_ATTR
Definition: vendor/device/example/conf_usb.h:54
#define USB_DEVICE_POWER
Definition: vendor/device/example/conf_usb.h:53
#define USB_CONFIG_MAX_POWER(ma)
Max power in mA.
Definition: usb_protocol.h:427
#define USB_DEVICE_NB_INTERFACE
Only one interface for this device.
Definition: udi_vendor_desc.c:55
Structure for USB Device Configuration Descriptor.
Definition: udi_msc_desc.c:106

USB Device Configuration Descriptor filled for FS.

Initial value:
= {
.bLength = sizeof(usb_dev_desc_t),
.bDescriptorType = USB_DT_DEVICE,
.bcdUSB = LE16(USB_V2_0),
.bDeviceClass = 0,
.bDeviceSubClass = 0,
.bDeviceProtocol = 0,
.bMaxPacketSize0 = USB_DEVICE_EP_CTRL_SIZE,
.idVendor = LE16(USB_DEVICE_VENDOR_ID),
.idProduct = LE16(USB_DEVICE_PRODUCT_ID),
.bcdDevice = LE16((USB_DEVICE_MAJOR_VERSION << 8)
.iManufacturer = 0,
.iProduct = 0,
.iSerialNumber = 0,
.bNumConfigurations = 1
}
#define USB_V2_0
Value for field bcdUSB.
Definition: usb_protocol.h:56
Standard USB device descriptor structure.
Definition: usb_protocol.h:313
#define USB_DEVICE_MINOR_VERSION
Definition: vendor/device/example/conf_usb.h:52
Definition: usb_protocol.h:190
#define USB_DEVICE_VENDOR_ID
USB Device Configuration.
Definition: vendor/device/example/conf_usb.h:49
#define USB_DEVICE_PRODUCT_ID
Definition: vendor/device/example/conf_usb.h:50
#define LE16(x)
Definition: compiler.h:886
#define USB_DEVICE_MAJOR_VERSION
Definition: vendor/device/example/conf_usb.h:51
#define USB_DEVICE_EP_CTRL_SIZE
Control endpoint size.
Definition: udi_msc_conf.h:47

USB Device Descriptor.

Pointer on the selected speed device configuration.

Initial value:
= {
}
UDC_DESC_STORAGE udi_api_t udi_api_vendor
Global structure which contains standard UDI API for UDC.
Definition: udi_vendor.c:67

Associate an UDI for each USB interface.