X-Git-Url: http://git.linex4red.de/pub/USBasp.git/blobdiff_plain/a789619fbe2cd07347816cc5c168e8f904acca86..d03d6513d0d24cf63225c8d3dfa07675d9107f40:/LUFA/Drivers/USB/HighLevel/USBInterrupt.c?ds=sidebyside diff --git a/LUFA/Drivers/USB/HighLevel/USBInterrupt.c b/LUFA/Drivers/USB/HighLevel/USBInterrupt.c index f0a59edb7..925248d13 100644 --- a/LUFA/Drivers/USB/HighLevel/USBInterrupt.c +++ b/LUFA/Drivers/USB/HighLevel/USBInterrupt.c @@ -1,21 +1,21 @@ /* LUFA Library - Copyright (C) Dean Camera, 2009. + Copyright (C) Dean Camera, 2010. dean [at] fourwalledcubicle [dot] com www.fourwalledcubicle.com */ /* - Copyright 2009 Dean Camera (dean [at] fourwalledcubicle [dot] com) - - Permission to use, copy, modify, and distribute this software - and its documentation for any purpose and without fee is hereby - granted, provided that the above copyright notice appear in all - copies and that both that the copyright notice and this - permission notice and warranty disclaimer appear in supporting - documentation, and that the name of the author not be used in - advertising or publicity pertaining to distribution of the + Copyright 2010 Dean Camera (dean [at] fourwalledcubicle [dot] com) + + Permission to use, copy, modify, distribute, and sell this + software and its documentation for any purpose is hereby granted + without fee, provided that the above copyright notice appear in + all copies and that both that the copyright notice and this + permission notice and warranty disclaimer appear in supporting + documentation, and that the name of the author not be used in + advertising or publicity pertaining to distribution of the software without specific, written prior permission. The author disclaim all warranties with regard to this @@ -28,6 +28,7 @@ this software. */ +#define __INCLUDE_FROM_USB_DRIVER #include "USBInterrupt.h" void USB_INT_DisableAllInterrupts(void) @@ -35,7 +36,7 @@ void USB_INT_DisableAllInterrupts(void) #if defined(USB_SERIES_6_AVR) || defined(USB_SERIES_7_AVR) USBCON &= ~((1 << VBUSTE) | (1 << IDTE)); #elif defined(USB_SERIES_4_AVR) - USBCON &= ~(1 << VBUSTE); + USBCON &= ~(1 << VBUSTE); #endif #if defined(USB_CAN_BE_HOST) @@ -72,36 +73,15 @@ ISR(USB_GEN_vect, ISR_BLOCK) { USB_INT_Clear(USB_INT_VBUS); - EVENT_USB_VBUSChange(); - if (USB_VBUS_GetStatus()) { - EVENT_USB_VBUSConnect(); - - if (USB_DeviceState != DEVICE_STATE_Unattached) - EVENT_USB_Disconnect(); - - USB_ResetInterface(); - USB_DeviceState = DEVICE_STATE_Powered; - EVENT_USB_Connect(); + EVENT_USB_Device_Connect(); } else { - USB_DeviceState = DEVICE_STATE_Unattached; - EVENT_USB_Disconnect(); - - USB_Detach(); - USB_CLK_Freeze(); - - if (!(USB_Options & USB_OPT_MANUAL_PLL)) - USB_PLL_Off(); - - USB_REG_Off(); - - EVENT_USB_VBUSDisconnect(); - - USB_INT_Clear(USB_INT_VBUS); + USB_DeviceState = DEVICE_STATE_Unattached; + EVENT_USB_Device_Disconnect(); } } #endif @@ -120,10 +100,10 @@ ISR(USB_GEN_vect, ISR_BLOCK) #if defined(USB_SERIES_2_AVR) && !defined(NO_LIMITED_CONTROLLER_CONNECT) USB_DeviceState = DEVICE_STATE_Unattached; - EVENT_USB_Disconnect(); + EVENT_USB_Device_Disconnect(); #else USB_DeviceState = DEVICE_STATE_Suspended; - EVENT_USB_Suspend(); + EVENT_USB_Device_Suspend(); #endif } @@ -143,11 +123,11 @@ ISR(USB_GEN_vect, ISR_BLOCK) USB_INT_Enable(USB_INT_SUSPEND); #if defined(USB_SERIES_2_AVR) && !defined(NO_LIMITED_CONTROLLER_CONNECT) - USB_DeviceState = DEVICE_STATE_Powered; - EVENT_USB_Connect(); + USB_DeviceState = (USB_ConfigurationNumber) ? DEVICE_STATE_Configured : DEVICE_STATE_Powered; + EVENT_USB_Device_Connect(); #else USB_DeviceState = (USB_ConfigurationNumber) ? DEVICE_STATE_Configured : DEVICE_STATE_Addressed; - EVENT_USB_WakeUp(); + EVENT_USB_Device_WakeUp(); #endif } @@ -169,10 +149,17 @@ ISR(USB_GEN_vect, ISR_BLOCK) ENDPOINT_BANK_SINGLE); #if defined(INTERRUPT_CONTROL_ENDPOINT) - USB_INT_Enable(USB_INT_ENDPOINT_SETUP); + USB_INT_Enable(USB_INT_RXSTPI); #endif - EVENT_USB_Reset(); + EVENT_USB_Device_Reset(); + } + + if (USB_INT_HasOccurred(USB_INT_SOFI) && USB_INT_IsEnabled(USB_INT_SOFI)) + { + USB_INT_Clear(USB_INT_SOFI); + + EVENT_USB_Device_StartOfFrame(); } #endif @@ -183,8 +170,7 @@ ISR(USB_GEN_vect, ISR_BLOCK) USB_INT_Clear(USB_INT_DCONNI); USB_INT_Disable(USB_INT_DDISCI); - EVENT_USB_DeviceUnattached(); - EVENT_USB_Disconnect(); + EVENT_USB_Host_DeviceUnattached(); USB_ResetInterface(); } @@ -196,8 +182,8 @@ ISR(USB_GEN_vect, ISR_BLOCK) USB_Host_VBUS_Manual_Off(); USB_Host_VBUS_Auto_Off(); - EVENT_USB_HostError(HOST_ERROR_VBusVoltageDip); - EVENT_USB_DeviceUnattached(); + EVENT_USB_Host_HostError(HOST_ERROR_VBusVoltageDip); + EVENT_USB_Host_DeviceUnattached(); USB_HostState = HOST_STATE_Unattached; } @@ -207,7 +193,7 @@ ISR(USB_GEN_vect, ISR_BLOCK) USB_INT_Clear(USB_INT_SRPI); USB_INT_Disable(USB_INT_SRPI); - EVENT_USB_DeviceAttached(); + EVENT_USB_Host_DeviceAttached(); USB_INT_Enable(USB_INT_DDISCI); @@ -218,11 +204,8 @@ ISR(USB_GEN_vect, ISR_BLOCK) { USB_INT_Clear(USB_INT_BCERRI); - EVENT_USB_DeviceEnumerationFailed(HOST_ENUMERROR_NoDeviceDetected, 0); - EVENT_USB_DeviceUnattached(); - - if (USB_HostState != HOST_STATE_Unattached) - EVENT_USB_Disconnect(); + EVENT_USB_Host_DeviceEnumerationFailed(HOST_ENUMERROR_NoDeviceDetected, 0); + EVENT_USB_Host_DeviceUnattached(); USB_ResetInterface(); } @@ -234,32 +217,28 @@ ISR(USB_GEN_vect, ISR_BLOCK) USB_INT_Clear(USB_INT_IDTI); if (USB_DeviceState != DEVICE_STATE_Unattached) - EVENT_USB_Disconnect(); + EVENT_USB_Device_Disconnect(); if (USB_HostState != HOST_STATE_Unattached) - { - EVENT_USB_Disconnect(); - EVENT_USB_DeviceUnattached(); - } - - EVENT_USB_Disconnect(); - - EVENT_USB_UIDChange(); + EVENT_USB_Host_DeviceUnattached(); + USB_CurrentMode = USB_GetUSBModeFromUID(); + EVENT_USB_UIDChange(); + USB_ResetInterface(); } #endif } -#if defined(INTERRUPT_CONTROL_ENDPOINT) +#if defined(INTERRUPT_CONTROL_ENDPOINT) && defined(USB_CAN_BE_DEVICE) ISR(USB_COM_vect, ISR_BLOCK) { uint8_t PrevSelectedEndpoint = Endpoint_GetCurrentEndpoint(); USB_USBTask(); - USB_INT_Clear(USB_INT_ENDPOINT_SETUP); + USB_INT_Clear(USB_INT_RXSTPI); - Endpoint_SelectEndpoint(PrevSelectedEndpoint); + Endpoint_SelectEndpoint(PrevSelectedEndpoint); } #endif