2013-05-06 07:50:19 +02:00
|
|
|
/**************************************************************************/
|
|
|
|
/*!
|
|
|
|
@file hal.h
|
|
|
|
@author hathach (tinyusb.org)
|
2012-12-03 10:51:14 +01:00
|
|
|
|
2013-05-06 07:50:19 +02: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 10:51:14 +01:00
|
|
|
|
2013-10-25 08:45:57 +02:00
|
|
|
#ifndef _TUSB_HAL_H_
|
|
|
|
#define _TUSB_HAL_H_
|
2012-12-03 10:51:14 +01:00
|
|
|
|
2013-10-25 08:45:57 +02:00
|
|
|
/** \addtogroup Port Port
|
|
|
|
* @{
|
2013-10-25 12:28:31 +02: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 10:51:14 +01:00
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2013-10-02 09:20:05 +02:00
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
// INCLUDES
|
|
|
|
//--------------------------------------------------------------------+
|
2013-02-04 07:13:07 +01:00
|
|
|
#include "tusb_option.h"
|
2013-04-25 06:00:56 +02:00
|
|
|
#include "common/primitive_types.h"
|
2013-03-22 11:08:51 +01:00
|
|
|
#include "common/errors.h"
|
2012-12-10 08:58:25 +01:00
|
|
|
#include "common/compiler/compiler.h"
|
2012-12-03 10:51:14 +01:00
|
|
|
|
2013-10-02 09:20:05 +02:00
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
// HAL API
|
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
// callback from tusb.h
|
2013-11-06 08:20:45 +01:00
|
|
|
extern void tusb_isr(uint8_t coreid);
|
2013-10-02 09:20:05 +02:00
|
|
|
|
2013-10-25 12:28:31 +02: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 09:20:05 +02:00
|
|
|
tusb_error_t hal_init(void);
|
|
|
|
|
2013-10-25 12:28:31 +02:00
|
|
|
/** \brief Enable USB Interrupt on a specific USB Controller
|
2013-11-06 08:20:45 +01:00
|
|
|
* \param[in] coreid is a zero-based index to identify USB controller's ID
|
2013-10-25 12:28:31 +02: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 08:20:45 +01:00
|
|
|
static inline void hal_interrupt_enable(uint8_t coreid) ATTR_ALWAYS_INLINE;
|
2013-10-25 12:28:31 +02:00
|
|
|
|
|
|
|
/** \brief Disable USB Interrupt on a specific USB Controller
|
2013-11-06 08:20:45 +01:00
|
|
|
* \param[in] coreid is a zero-based index to identify USB controller's ID
|
2013-10-25 12:28:31 +02: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 08:20:45 +01:00
|
|
|
static inline void hal_interrupt_disable(uint8_t coreid) ATTR_ALWAYS_INLINE;
|
2013-10-02 09:20:05 +02:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------+
|
|
|
|
// INCLUDE DRIVEN
|
|
|
|
//--------------------------------------------------------------------+
|
2013-01-22 12:09:58 +01:00
|
|
|
#if MCU == 0
|
2013-05-25 11:03:40 +02:00
|
|
|
#error MCU is not defined or supported yet
|
2013-01-22 12:09:58 +01:00
|
|
|
#elif MCU == MCU_LPC11UXX
|
|
|
|
#include "hal_lpc11uxx.h"
|
|
|
|
#elif MCU == MCU_LPC13UXX
|
|
|
|
#include "hal_lpc13uxx.h"
|
|
|
|
#elif MCU == MCU_LPC43XX
|
|
|
|
#include "hal_lpc43xx.h"
|
2013-06-04 08:36:18 +02:00
|
|
|
#elif MCU == MCU_LPC175X_6X
|
|
|
|
#include "hal_lpc175x_6x.h"
|
2013-05-25 11:03:40 +02:00
|
|
|
#else
|
|
|
|
#error MCU is not defined or supported yet
|
2013-01-22 12:09:58 +01:00
|
|
|
#endif
|
|
|
|
|
2013-02-08 06:12:10 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
2013-01-22 12:09:58 +01:00
|
|
|
|
2012-12-10 08:58:25 +01:00
|
|
|
|
2013-03-23 04:56:41 +01: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 11:08:51 +01:00
|
|
|
{
|
2013-10-25 12:28:31 +02:00
|
|
|
// TODO check core M3/M4 defined instead
|
2013-05-31 08:57:57 +02:00
|
|
|
#if !defined(_TEST_) && !(MCU==MCU_LPC11UXX)
|
2013-10-02 09:20:05 +02:00
|
|
|
return ( (CoreDebug->DHCSR & CoreDebug_DHCSR_C_DEBUGEN_Msk) == CoreDebug_DHCSR_C_DEBUGEN_Msk );
|
2013-03-22 11:08:51 +01:00
|
|
|
#else
|
|
|
|
return false;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2013-03-23 04:56:41 +01:00
|
|
|
static inline void hal_debugger_breakpoint(void) ATTR_ALWAYS_INLINE;
|
|
|
|
static inline void hal_debugger_breakpoint(void)
|
2013-03-22 11:08:51 +01:00
|
|
|
{
|
|
|
|
#ifndef _TEST_
|
|
|
|
if (hal_debugger_is_attached()) /* if there is debugger connected */
|
|
|
|
{
|
|
|
|
__asm("BKPT #0\n");
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2012-12-03 10:51:14 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _TUSB_HAL_H_ */
|
|
|
|
|
|
|
|
/** @} */
|
2013-10-25 08:45:57 +02:00
|
|
|
/** @} */
|