#include <avr/io.h>
#include <stdbool.h>
#include <stddef.h>
#include "../../../Scheduler/Scheduler.h"
#include "../LowLevel/LowLevel.h"
#include "../LowLevel/HostChapter9.h"
#include "../LowLevel/USBMode.h"
#include "Events.h"
#include "StdDescriptors.h"
Functions | |
RAISES_EVENT (USB_Connect) | |
RAISES_EVENT (USB_DeviceAttached) | |
RAISES_EVENT (USB_DeviceUnattached) | |
RAISES_EVENT (USB_DeviceEnumerationFailed) | |
RAISES_EVENT (USB_DeviceEnumerationComplete) | |
RAISES_EVENT (USB_Disconnect) | |
TASK (USB_USBTask) | |
Variables | |
volatile bool | USB_IsConnected |
volatile bool | USB_IsInitialized |
volatile uint8_t | USB_HostState |
RAISES_EVENT | ( | USB_Disconnect | ) |
This module raises the USB Disconnect event when an attached USB device is removed from the USB bus.
RAISES_EVENT | ( | USB_DeviceEnumerationComplete | ) |
This module raises the USB Device Enumeration Complete event when in host mode, and an attached USB device has been successfully enumerated and ready to be used by the user application.
RAISES_EVENT | ( | USB_DeviceEnumerationFailed | ) |
This module raises the USB Device Enumeration Failed event when in host mode, and an attached USB device has failed to successfully enumerated.
RAISES_EVENT | ( | USB_DeviceUnattached | ) |
This module raises the USB Device Unattached event when in host mode, and a device is removed from the AVR's USB interface.
RAISES_EVENT | ( | USB_DeviceAttached | ) |
This module raises the USB Device Attached event when in host mode, and a device is attached to the AVR's USB interface.
RAISES_EVENT | ( | USB_Connect | ) |
This module raises the USB Connect event when a USB device has been connected whilst in host mode, but not yet enumerated.
TASK | ( | USB_USBTask | ) |
This is the main USB management task. The USB driver requires that this task be executed continuously when the USB system is active (device attached in host mode, or attached to a host in device mode) in order to manage USB communications. This task may be executed inside an RTOS, scheduler (e.g. the simple MyUSB Scheduler), fast timer ISR or the main user application loop.
The USB task must be serviced within 50mS in all modes, when needed. The task may be serviced at all times, or (for minimum CPU consumption):
> In device mode, it may be disabled at startup, enabled on the firing of the USB_Connect event and disabled again on the firing of the USB_Disconnect event.
> In host mode, it may be disabled at startup, enabled on the firing of the USB_DeviceAttached event and disabled again on the firing of the USB_DeviceUnattached event.
volatile uint8_t USB_HostState |
Indicates the current host state machine state. When in host mode, this indicates the state via one of the values of the USB_Host_States_t enum values in Host.h.
This value may be altered by the user application to implement the HOST_STATE_Addressed, HOST_STATE_Configured, HOST_STATE_Ready and HOST_STATE_Suspended states which are not implemented by the library.
volatile bool USB_IsConnected |
Indicates if the USB interface is currently connected to a host if in device mode, or to a device while running in host mode.
volatile bool USB_IsInitialized |
Indicates if the USB interface is currently initialized but not neccesarily connected to a host or device (i.e. if USB_Init() has been run).