LPCOpen Platform
LPCOpen Platform for NXP LPC Microcontrollers
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
USBD_API_INIT_PARAM_T Struct Reference

USB device stack initilization parameter data structure. More...

#include "usbd_core.h"

Data Fields

uint32_t usb_reg_base
 
uint32_t mem_base
 
uint32_t mem_size
 
uint8_t max_num_ep
 
USB_CB_T USB_Reset_Event
 
USB_CB_T USB_Suspend_Event
 
USB_CB_T USB_Resume_Event
 
USB_CB_T reserved_sbz
 
USB_CB_T USB_SOF_Event
 
USB_PARAM_CB_T USB_WakeUpCfg
 
USB_PARAM_CB_T USB_Power_Event
 
USB_PARAM_CB_T USB_Error_Event
 
USB_CB_T USB_Configure_Event
 
USB_CB_T USB_Interface_Event
 
USB_CB_T USB_Feature_Event
 
uint32_t(* virt_to_phys )(void *vaddr)
 
void(* cache_flush )(uint32_t *start_adr, uint32_t *end_adr)
 

Detailed Description

USB device stack initilization parameter data structure.

This data structure is used to pass initialization parameters to the USB device stack's init function.

Definition at line 147 of file usbd_core.h.

Field Documentation

void(* cache_flush)(uint32_t *start_adr, uint32_t *end_adr)

Reserved parameter for future use. should be set to zero.

Definition at line 278 of file usbd_core.h.

uint8_t max_num_ep

max number of endpoints supported by the USB device controller instance (specified by usb_reg_base field) to which this instance of stack is attached.

Definition at line 158 of file usbd_core.h.

uint32_t mem_base

Base memory location from where the stack can allocate data and buffers.

Note
The memory address set in this field should be accessible by USB DMA controller. Also this value should be aligned on 2048 byte boundary.

Definition at line 150 of file usbd_core.h.

uint32_t mem_size

The size of memory buffer which stack can use.

Note
The mem_size should be greater than the size returned by USBD_HW_API::GetMemSize() routine.

Definition at line 155 of file usbd_core.h.

USB_CB_T reserved_sbz

Reserved parameter should be set to zero.

Definition at line 195 of file usbd_core.h.

USB_CB_T USB_Configure_Event

Event for USB configuration number changed. This event fires when a the USB host changes the selected configuration number. On receiving configuration change request from host, the stack enables/configures the endpoints needed by the new configuration before calling this callback function.

Note
This event is called from USB_ISR context and hence is time-critical. Having delays in this callback will prevent the device from enumerating correctly or operate properly.

Definition at line 250 of file usbd_core.h.

USB_PARAM_CB_T USB_Error_Event

Event for error condition. This event fires when USB device controller detect an error condition in the system.



Parameters
hUsbHandle to the USB device stack.
param1USB device interrupt status register.
Returns
The call back should return ErrorCode_t type to indicate success or error condition.

Definition at line 238 of file usbd_core.h.

USB_CB_T USB_Feature_Event

Event for USB feature changed. This event fires when a the USB host send set/clear feature request. The stack handles this request for USB_FEATURE_REMOTE_WAKEUP, USB_FEATURE_TEST_MODE and USB_FEATURE_ENDPOINT_STALL features only. On receiving feature request from host, the stack handle the request appropriately and then calls this callback function.

Note
This event is called from USB_ISR context and hence is time-critical. Having delays in this callback will prevent the device from enumerating correctly or operate properly.

Definition at line 272 of file usbd_core.h.

USB_CB_T USB_Interface_Event

Event for USB interface setting changed. This event fires when a the USB host changes the interface setting to one of alternate interface settings. On receiving interface change request from host, the stack enables/configures the endpoints needed by the new alternate interface setting before calling this callback function.

Note
This event is called from USB_ISR context and hence is time-critical. Having delays in this callback will prevent the device from enumerating correctly or operate properly.

Definition at line 261 of file usbd_core.h.

USB_PARAM_CB_T USB_Power_Event

Reserved parameter should be set to zero.

Definition at line 228 of file usbd_core.h.

uint32_t usb_reg_base

USB device controller's base register address.

Definition at line 149 of file usbd_core.h.

USB_CB_T USB_Reset_Event

Event for USB interface reset. This event fires when the USB host requests that the device reset its interface. This event fires after the control endpoint has been automatically configured by the library.

Note
This event is called from USB_ISR context and hence is time-critical. Having delays in this callback will prevent the device from enumerating correctly or operate properly.

Definition at line 172 of file usbd_core.h.

USB_CB_T USB_Resume_Event

Event for USB wake up or resume. This event fires when a the USB device interface is suspended and the host wakes up the device by supplying Start Of Frame pulses. This is generally hooked to pull the user application out of a low power state and back into normal operating mode.

Note
This event is called from USB_ISR context and hence is time-critical. Having delays in this callback will cause other system issues.

Definition at line 192 of file usbd_core.h.

USB_CB_T USB_SOF_Event

Event for USB Start Of Frame detection, when enabled. This event fires at the start of each USB frame, once per millisecond in full-speed mode or once per 125 microseconds in high-speed mode, and is synchronized to the USB bus.

This event is time-critical; it is run once per millisecond (full-speed mode) and thus long handlers will significantly degrade device performance. This event should only be enabled when needed to reduce device wake-ups.

Note
This event is not normally active - it must be manually enabled and disabled via the USB interrupt register.

Definition at line 209 of file usbd_core.h.

USB_CB_T USB_Suspend_Event

Event for USB suspend. This event fires when the USB host suspends the device by halting its transmission of Start Of Frame pulses to the device. This is generally hooked in order to move the device over to a low power state until the host wakes up the device.

Note
This event is called from USB_ISR context and hence is time-critical. Having delays in this callback will cause other system issues.

Definition at line 181 of file usbd_core.h.

USB_PARAM_CB_T USB_WakeUpCfg

Event for remote wakeup configururation, when enabled. This event fires when the USB host request the device to configure itself for remote wake-up capability. The USB host sends this request to device which report remote wakeup capable in their device descriptors, before going to low-power state. The application layer should implement this callback if they have any special on board circuit to trigerr remote wake up event.

This event is time-critical; it is run once per millisecond (full-speed mode) and thus long handlers will significantly degrade device performance.



Parameters
hUsbHandle to the USB device stack.
param1When 0 - Clear the wakeup configuration, 1 - Enable the wake-up configuration.
Returns
The call back should return ErrorCode_t type to indicate success or error condition.

Definition at line 225 of file usbd_core.h.

uint32_t(* virt_to_phys)(void *vaddr)

Reserved parameter for future use. should be set to zero.

Definition at line 276 of file usbd_core.h.


The documentation for this struct was generated from the following file: