You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							225 lines
						
					
					
						
							10 KiB
						
					
					
				
			
		
		
	
	
							225 lines
						
					
					
						
							10 KiB
						
					
					
				| /*
 | |
|              LUFA Library
 | |
|      Copyright (C) Dean Camera, 2009.
 | |
|               
 | |
|   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
 | |
|   software without specific, written prior permission.
 | |
| 
 | |
|   The author disclaim all warranties with regard to this
 | |
|   software, including all implied warranties of merchantability
 | |
|   and fitness.  In no event shall the author be liable for any
 | |
|   special, indirect or consequential damages or any damages
 | |
|   whatsoever resulting from loss of use, data or profits, whether
 | |
|   in an action of contract, negligence or other tortious action,
 | |
|   arising out of or in connection with the use or performance of
 | |
|   this software.
 | |
| */
 | |
| 
 | |
| /** \file
 | |
|  *
 | |
|  *  Main USB interrupt vector handler. This file manages the main USB interrupt vector, for handling such
 | |
|  *  events as VBUS interrupts (on supported USB AVR models), device connections and disconnections, etc.
 | |
|  */
 | |
| 
 | |
| #ifndef __USBINTERRUPT_H__
 | |
| #define __USBINTERRUPT_H__
 | |
| 
 | |
| 	/* Includes: */
 | |
| 		#include <avr/io.h>
 | |
| 		#include <stdbool.h>
 | |
| 		
 | |
| 		#include "../../../Common/Common.h"
 | |
| 		#include "../LowLevel/LowLevel.h"
 | |
| 		#include "../LowLevel/USBMode.h"
 | |
| 		#include "Events.h"
 | |
| 		
 | |
| 	/* Enable C linkage for C++ Compilers: */
 | |
| 		#if defined(__cplusplus)
 | |
| 			extern "C" {
 | |
| 		#endif
 | |
| 
 | |
| 	/* Public Interface - May be used in end-application: */
 | |
| 		/* Macros: */
 | |
| 			/** Vector name for the common endpoint and pipe vector. This can be used to write an ISR handler
 | |
| 			 *  for the endpoint and pipe events, to make certain USB functions interrupt rather than poll
 | |
| 			 *  driven.
 | |
| 			 */
 | |
| 			#define ENDPOINT_PIPE_vect                       USB_COM_vect
 | |
| 	
 | |
| 			/** Enables the given USB interrupt vector (such as the ENDPOINT_INT_* and PIPE_INT_* vectors in
 | |
| 			 *  Endpoint.h and Pipe.h).
 | |
| 			 */
 | |
| 			#define USB_INT_Enable(int)              MACROS{ USB_INT_GET_EN_REG(int)   |=   USB_INT_GET_EN_MASK(int);   }MACROE
 | |
| 
 | |
| 			/** Disables the given USB interrupt vector.
 | |
| 			 *
 | |
| 			 *  \see USB_INT_Enable()
 | |
| 			 */
 | |
| 			#define USB_INT_Disable(int)             MACROS{ USB_INT_GET_EN_REG(int)   &= ~(USB_INT_GET_EN_MASK(int));  }MACROE
 | |
| 
 | |
| 			/** Resets the given USB interrupt flag, so that the interrupt is re-primed for the next firing. */
 | |
| 			#define USB_INT_Clear(int)               MACROS{ USB_INT_GET_INT_REG(int)  &= ~(USB_INT_GET_INT_MASK(int)); }MACROE
 | |
| 			
 | |
| 			/** Returns boolean false if the given USB interrupt is disabled, or true if the interrupt is currently
 | |
| 			 *  enabled.
 | |
| 			 */
 | |
| 			#define USB_INT_IsEnabled(int)                 ((USB_INT_GET_EN_REG(int)   &    USB_INT_GET_EN_MASK(int)) ? true : false)
 | |
| 
 | |
| 			/** Returns boolean true if the given interrupt flag is set (i.e. the condition for the interrupt has occurred,
 | |
| 			 *  but the interrupt vector is not neccesarily enabled), otherwise returns false.
 | |
| 			 */
 | |
| 			#define USB_INT_HasOccurred(int)               ((USB_INT_GET_INT_REG(int)  &    USB_INT_GET_INT_MASK(int)) ? true : false)
 | |
| 		
 | |
| 		/* Throwable Events: */
 | |
| 			/** This module raises the USB Connected interrupt when the AVR is attached to a host while in device
 | |
| 			 *  USB mode.
 | |
| 			 *
 | |
| 			 *  \note For the smaller USB AVRs (AT90USBXX2) with limited USB controllers, VBUS is not available to the USB controller.
 | |
| 			 *        this means that the current connection state is derived from the bus suspension and wake up events by default,
 | |
| 			 *        which is not always accurate (host may suspend the bus while still connected). If the actual connection state
 | |
| 			 *        needs to be determined, VBUS should be routed to an external pin, and the auto-detect behaviour turned off by
 | |
| 			 *        passing the NO_LIMITED_CONTROLLER_CONNECT token to the compiler via the -D switch at compile time. The connection
 | |
| 			 *        and disconnection events may be manually fired by RAISE_EVENT(), and the USB_IsConnected global changed manually.
 | |
| 			 */
 | |
| 			RAISES_EVENT(USB_Connect);
 | |
| 
 | |
| 			/** This module raises the USB Disconnected interrupt when the AVR is removed from a host while in
 | |
| 			 *  device USB mode.
 | |
| 			 *
 | |
| 			 *  \note For the smaller USB AVRs (AT90USBXX2) with limited USB controllers, VBUS is not available to the USB controller.
 | |
| 			 *        this means that the current connection state is derived from the bus suspension and wake up events by default,
 | |
| 			 *        which is not always accurate (host may suspend the bus while still connected). If the actual connection state
 | |
| 			 *        needs to be determined, VBUS should be routed to an external pin, and the auto-detect behaviour turned off by
 | |
| 			 *        passing the NO_LIMITED_CONTROLLER_CONNECT token to the compiler via the -D switch at compile time. The connection
 | |
| 			 *        and disconnection events may be manually fired by RAISE_EVENT(), and the USB_IsConnected global changed manually.
 | |
| 			 */
 | |
| 			RAISES_EVENT(USB_Disconnect);
 | |
| 
 | |
| 			#if defined(USB_FULL_CONTROLLER) || defined(USB_MODIFIED_FULL_CONTROLLER) || defined(__DOXYGEN__)
 | |
| 				/** This module raises the VBUS Change event when the current VBUS status (present or not present) has
 | |
| 				 *  changed.
 | |
| 				 *
 | |
| 				 *  \note Not all USB AVR models support VBUS interrupts; this event only exists on supported AVRs.
 | |
| 				 *
 | |
| 				 *  \see Events.h for more information on this event.
 | |
| 				 */
 | |
| 				RAISES_EVENT(USB_VBUSChange);
 | |
| 
 | |
| 				/** This module raises the VBUS Connect event when the VBUS line is powered.
 | |
| 				 *
 | |
| 				 *  \note Not all USB AVR models support VBUS interrupts; this event only exists on supported AVRs.
 | |
| 				 *
 | |
| 				 *  \see Events.h for more information on this event.
 | |
| 				 */
 | |
| 				RAISES_EVENT(USB_VBUSConnect);
 | |
| 
 | |
| 				/** This module raises the VBUS Disconnect event when power is removed from the VBUS line.
 | |
| 				 *
 | |
| 				 *  \note Not all USB AVR models support VBUS interrupts; this event only exists on supported AVRs.
 | |
| 				 *
 | |
| 				 *  \see Events.h for more information on this event.
 | |
| 				 */
 | |
| 				RAISES_EVENT(USB_VBUSDisconnect);
 | |
| 			#endif
 | |
| 
 | |
| 			#if defined(USB_CAN_BE_DEVICE) || defined(__DOXYGEN__)
 | |
| 				/** This module raises the Suspended event when the host suspends the USB interface of the AVR
 | |
| 				 *  whilst running in device mode.
 | |
| 				 *
 | |
| 				 *  \see Events.h for more information on this event.
 | |
| 				 */
 | |
| 				RAISES_EVENT(USB_Suspend);
 | |
| 
 | |
| 				/** This module raises the Wake Up event when the host resumes the USB interface of the AVR
 | |
| 				 *  whilst running in device mode.
 | |
| 				 *
 | |
| 				 *  \see Events.h for more information on this event.
 | |
| 				 */
 | |
| 				RAISES_EVENT(USB_WakeUp);
 | |
| 
 | |
| 				/** This module raises the USB Reset event when the host resets the USB interface of the AVR
 | |
| 				 *  whilst running in device mode.
 | |
| 				 *
 | |
| 				 *  \see Events.h for more information on this event.
 | |
| 				 */
 | |
| 				RAISES_EVENT(USB_Reset);
 | |
| 			#endif
 | |
| 			
 | |
| 			#if defined(USB_CAN_BE_HOST) || defined(__DOXYGEN__)
 | |
| 				/** This module raises the Host Error event when the VBUS line voltage dips below the minimum threshold
 | |
| 				 *  while running in host mode.
 | |
| 				 *
 | |
| 				 *  \note Not all USB AVR models support host mode; this event only exists on supported AVRs.
 | |
| 				 *
 | |
| 				 *  \see Events.h for more information on this event.
 | |
| 				 */
 | |
| 				RAISES_EVENT(USB_HostError);
 | |
| 
 | |
| 				/** This module raises the Device Unattached event when an attached device is removed from the AVR whilst
 | |
| 				 *  running in host mode.
 | |
| 				 *
 | |
| 				 *  \note Not all USB AVR models support host mode; this event only exists on supported AVRs.
 | |
| 				 *
 | |
| 				 *  \see Events.h for more information on this event.
 | |
| 				 */
 | |
| 				RAISES_EVENT(USB_DeviceUnattached);
 | |
| 			#endif
 | |
| 
 | |
| 			#if defined(USB_CAN_BE_BOTH) || defined(__DOXYGEN__)
 | |
| 				/** This module raises the UID Change event when the UID line changes in value on dual-role devices.
 | |
| 				 *
 | |
| 				 *  \note Not all USB AVR models support host mode and thus the UID pin; this event only exists on
 | |
| 				 *        supported AVRs.
 | |
| 				 *
 | |
| 				 *  \see Events.h for more information on this event.
 | |
| 				 */
 | |
| 				RAISES_EVENT(USB_UIDChange);
 | |
| 			#endif
 | |
| 			
 | |
| 	/* Private Interface - For use in library only: */
 | |
| 	#if !defined(__DOXYGEN__)
 | |
| 		/* Macros: */
 | |
| 			#define USB_INT_GET_EN_REG(a, b, c, d)           a
 | |
| 			#define USB_INT_GET_EN_MASK(a, b, c, d)          b
 | |
| 			#define USB_INT_GET_INT_REG(a, b, c, d)          c
 | |
| 			#define USB_INT_GET_INT_MASK(a, b, c, d)         d
 | |
| 
 | |
| 			#define USB_INT_VBUS                             USBCON, (1 << VBUSTE) , USBINT, (1 << VBUSTI)
 | |
| 			#define USB_INT_IDTI                             USBCON, (1 << IDTE)   , USBINT, (1 << IDTI)
 | |
| 			#define USB_INT_WAKEUP                           UDIEN , (1 << WAKEUPE), UDINT , (1 << WAKEUPI)
 | |
| 			#define USB_INT_SUSPEND                          UDIEN , (1 << SUSPE)  , UDINT , (1 << SUSPI)
 | |
| 			#define USB_INT_EORSTI                           UDIEN , (1 << EORSTE) , UDINT , (1 << EORSTI)
 | |
| 			#define USB_INT_DCONNI                           UHIEN , (1 << DCONNE) , UHINT , (1 << DCONNI)
 | |
| 			#define USB_INT_DDISCI                           UHIEN , (1 << DDISCE) , UHINT , (1 << DDISCI)
 | |
| 			#define USB_INT_BCERRI                           OTGIEN, (1 << BCERRE) , OTGINT, (1 << BCERRI)
 | |
| 			#define USB_INT_VBERRI                           OTGIEN, (1 << VBERRE) , OTGINT, (1 << VBERRI)
 | |
| 			#define USB_INT_SOFI                             UDIEN,  (1 << SOFE)   , UDINT , (1 << SOFI)
 | |
| 			#define USB_INT_HSOFI                            UHIEN,  (1 << HSOFE)  , UHINT , (1 << HSOFI)
 | |
| 			#define USB_INT_RSTI                             UHIEN , (1 << RSTE)   , UHINT , (1 << RSTI)
 | |
| 			#define USB_INT_SRPI                             OTGIEN, (1 << SRPE)   , OTGINT, (1 << SRPI)
 | |
| 	
 | |
| 		/* Function Prototypes: */
 | |
| 			void USB_INT_ClearAllInterrupts(void);
 | |
| 			void USB_INT_DisableAllInterrupts(void);
 | |
| 	#endif
 | |
| 	
 | |
| 	/* Disable C linkage for C++ Compilers: */
 | |
| 		#if defined(__cplusplus)
 | |
| 			}
 | |
| 		#endif
 | |
| 		
 | |
| #endif
 |