| 
									
										
										
										
											2013-05-06 12:50:19 +07:00
										 |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |     @file     hal.h | 
					
						
							|  |  |  |     @author   hathach (tinyusb.org) | 
					
						
							| 
									
										
										
										
											2012-12-03 16:51:14 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-06 12:50:19 +07:00
										 |  |  |     @section LICENSE | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Software License Agreement (BSD License) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Copyright (c) 2013, hathach (tinyusb.org) | 
					
						
							|  |  |  |     All rights reserved. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Redistribution and use in source and binary forms, with or without | 
					
						
							|  |  |  |     modification, are permitted provided that the following conditions are met: | 
					
						
							|  |  |  |     1. Redistributions of source code must retain the above copyright | 
					
						
							|  |  |  |     notice, this list of conditions and the following disclaimer. | 
					
						
							|  |  |  |     2. Redistributions in binary form must reproduce the above copyright | 
					
						
							|  |  |  |     notice, this list of conditions and the following disclaimer in the | 
					
						
							|  |  |  |     documentation and/or other materials provided with the distribution. | 
					
						
							|  |  |  |     3. Neither the name of the copyright holders nor the | 
					
						
							|  |  |  |     names of its contributors may be used to endorse or promote products | 
					
						
							|  |  |  |     derived from this software without specific prior written permission. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ''AS IS'' AND ANY | 
					
						
							|  |  |  |     EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | 
					
						
							|  |  |  |     WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | 
					
						
							|  |  |  |     DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY | 
					
						
							|  |  |  |     DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | 
					
						
							|  |  |  |     INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | 
					
						
							|  |  |  |     LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION HOWEVER CAUSED AND | 
					
						
							|  |  |  |     ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
					
						
							|  |  |  |     INCLUDING NEGLIGENCE OR OTHERWISE ARISING IN ANY WAY OUT OF THE USE OF THIS | 
					
						
							|  |  |  |     SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     This file is part of the tinyusb stack. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							| 
									
										
										
										
											2012-12-03 16:51:14 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-25 13:45:57 +07:00
										 |  |  | #ifndef _TUSB_HAL_H_
 | 
					
						
							|  |  |  | #define _TUSB_HAL_H_
 | 
					
						
							| 
									
										
										
										
											2012-12-03 16:51:14 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-25 13:45:57 +07:00
										 |  |  | /** \addtogroup Port Port
 | 
					
						
							|  |  |  |  * @{ | 
					
						
							| 
									
										
										
										
											2013-10-25 17:28:31 +07:00
										 |  |  |  * \defgroup Port_Hal Hardware Abtract Layer (HAL) | 
					
						
							|  |  |  |  * Hardware Abstraction Layer (HAL) is an abstraction layer, between the physical hardware and the tinyusb stack. | 
					
						
							|  |  |  |  * Its function is to hide differences in hardware from most of MCUs, so that most of the stack code does not need to be changed to | 
					
						
							|  |  |  |  * run on systems with a different MCU. | 
					
						
							|  |  |  |  * HAL are sets of routines that emulate some platform-specific details, giving programs direct access to the hardware resources. | 
					
						
							| 
									
										
										
										
											2012-12-03 16:51:14 +07:00
										 |  |  |  *  @{ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-02 14:20:05 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // INCLUDES
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-02-04 13:13:07 +07:00
										 |  |  | #include "tusb_option.h"
 | 
					
						
							| 
									
										
										
										
											2013-04-25 11:00:56 +07:00
										 |  |  | #include "common/primitive_types.h"
 | 
					
						
							| 
									
										
										
										
											2013-03-22 17:08:51 +07:00
										 |  |  | #include "common/errors.h"
 | 
					
						
							| 
									
										
										
										
											2012-12-10 14:58:25 +07:00
										 |  |  | #include "common/compiler/compiler.h"
 | 
					
						
							| 
									
										
										
										
											2012-12-03 16:51:14 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-02 14:20:05 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // HAL API
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // callback from tusb.h
 | 
					
						
							| 
									
										
										
										
											2013-11-06 14:20:45 +07:00
										 |  |  | extern void tusb_isr(uint8_t coreid); | 
					
						
							| 
									
										
										
										
											2013-10-02 14:20:05 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-25 17:28:31 +07:00
										 |  |  | /** \brief    Initialize USB controller hardware
 | 
					
						
							|  |  |  |  * \returns   \ref tusb_error_t type to indicate success or error condition. | 
					
						
							|  |  |  |  * \note      This function is invoked by \ref tusb_init as part of the initialization. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2013-10-02 14:20:05 +07:00
										 |  |  | tusb_error_t hal_init(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-25 17:28:31 +07:00
										 |  |  | /** \brief 			Enable USB Interrupt on a specific USB Controller
 | 
					
						
							| 
									
										
										
										
											2013-11-06 14:20:45 +07:00
										 |  |  |  * \param[in]		coreid	is a zero-based index to identify USB controller's ID | 
					
						
							| 
									
										
										
										
											2013-10-25 17:28:31 +07:00
										 |  |  |  * \note        Some MCUs such as NXP LPC43xx has multiple USB controllers. It is necessary to know which USB controller for | 
					
						
							|  |  |  |  *              those MCUs. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2013-11-06 14:20:45 +07:00
										 |  |  | static inline void hal_interrupt_enable(uint8_t coreid) ATTR_ALWAYS_INLINE; | 
					
						
							| 
									
										
										
										
											2013-10-25 17:28:31 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** \brief 			Disable USB Interrupt on a specific USB Controller
 | 
					
						
							| 
									
										
										
										
											2013-11-06 14:20:45 +07:00
										 |  |  |  * \param[in]		coreid	is a zero-based index to identify USB controller's ID | 
					
						
							| 
									
										
										
										
											2013-10-25 17:28:31 +07:00
										 |  |  |  * \note        Some MCUs such as NXP LPC43xx has multiple USB controllers. It is necessary to know which USB controller for | 
					
						
							|  |  |  |  *              those MCUs. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2013-11-06 14:20:45 +07:00
										 |  |  | static inline void hal_interrupt_disable(uint8_t coreid) ATTR_ALWAYS_INLINE; | 
					
						
							| 
									
										
										
										
											2013-10-02 14:20:05 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // INCLUDE DRIVEN
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2013-11-11 12:48:21 +07:00
										 |  |  | #if MCU == MCU_LPC11UXX
 | 
					
						
							| 
									
										
										
										
											2013-01-22 18:09:58 +07:00
										 |  |  |   #include "hal_lpc11uxx.h"
 | 
					
						
							|  |  |  | #elif MCU == MCU_LPC13UXX
 | 
					
						
							|  |  |  |   #include "hal_lpc13uxx.h"
 | 
					
						
							|  |  |  | #elif MCU == MCU_LPC43XX
 | 
					
						
							|  |  |  |   #include "hal_lpc43xx.h"
 | 
					
						
							| 
									
										
										
										
											2013-06-04 13:36:18 +07:00
										 |  |  | #elif MCU == MCU_LPC175X_6X
 | 
					
						
							|  |  |  |   #include "hal_lpc175x_6x.h"
 | 
					
						
							| 
									
										
										
										
											2013-05-25 16:03:40 +07:00
										 |  |  | #else
 | 
					
						
							|  |  |  |   #error MCU is not defined or supported yet
 | 
					
						
							| 
									
										
										
										
											2013-01-22 18:09:58 +07:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-08 12:12:10 +07:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-01-22 18:09:58 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-10 14:58:25 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-23 10:56:41 +07:00
										 |  |  | static inline bool hal_debugger_is_attached(void) ATTR_PURE ATTR_ALWAYS_INLINE; | 
					
						
							|  |  |  | static inline bool hal_debugger_is_attached(void) | 
					
						
							| 
									
										
										
										
											2013-03-22 17:08:51 +07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-10-25 17:28:31 +07:00
										 |  |  | // TODO check core M3/M4 defined instead
 | 
					
						
							| 
									
										
										
										
											2013-05-31 13:57:57 +07:00
										 |  |  | #if !defined(_TEST_) && !(MCU==MCU_LPC11UXX)
 | 
					
						
							| 
									
										
										
										
											2013-10-02 14:20:05 +07:00
										 |  |  |   return ( (CoreDebug->DHCSR & CoreDebug_DHCSR_C_DEBUGEN_Msk) == CoreDebug_DHCSR_C_DEBUGEN_Msk ); | 
					
						
							| 
									
										
										
										
											2013-03-22 17:08:51 +07:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2013-11-14 14:12:07 +07:00
										 |  |  |   return true; // force to break into breakpoint
 | 
					
						
							| 
									
										
										
										
											2013-03-22 17:08:51 +07:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-23 10:56:41 +07:00
										 |  |  | static inline void hal_debugger_breakpoint(void) ATTR_ALWAYS_INLINE; | 
					
						
							|  |  |  | static inline void hal_debugger_breakpoint(void) | 
					
						
							| 
									
										
										
										
											2013-03-22 17:08:51 +07:00
										 |  |  | { | 
					
						
							|  |  |  | #ifndef _TEST_
 | 
					
						
							|  |  |  |   if (hal_debugger_is_attached()) /* if there is debugger connected */ | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     __asm("BKPT #0\n"); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-03 16:51:14 +07:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  |  } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* _TUSB_HAL_H_ */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @} */ | 
					
						
							| 
									
										
										
										
											2013-10-25 13:45:57 +07:00
										 |  |  | /** @} */ |