2013-10-16 12:05:48 +07:00
/**************************************************************************/
/*!
@ file board . h
@ author hathach ( tinyusb . org )
@ 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 .
*/
/**************************************************************************/
2014-03-25 13:11:22 +07:00
/** \ingroup group_demo
* \ defgroup group_board Boards Abstraction Layer
2014-03-25 13:00:37 +07:00
* @ { */
2013-10-16 12:05:48 +07:00
# ifndef _TUSB_BOARD_H_
# define _TUSB_BOARD_H_
# ifdef __cplusplus
extern " C " {
# endif
# include <stdint.h>
# include <stdbool.h>
# include "ansi_escape.h"
# include "tusb.h"
//--------------------------------------------------------------------+
// BOARD DEFINE
//--------------------------------------------------------------------+
2014-03-25 13:00:37 +07:00
/** \defgroup group_supported_board Supported Boards
* @ { */
2014-03-25 16:41:50 +07:00
# define BOARD_LPCXPRESSO11U14 1114 ///< LPCXpresso 11u14, some APIs requires the base board
2014-03-25 13:00:37 +07:00
# define BOARD_RF1GHZNODE 1100 ///< LPC11U37 from microbuilder http://www.microbuilder.eu/Blog/13-03-14/LPC1xxx_1GHZ_Wireless_Board_Preview.aspx
# define BOARD_LPCXPRESSO1347 1300 ///< LPCXpresso 1347, some APIs requires the base board
# define BOARD_LPCXPRESSO1769 1700 ///< LPCXpresso 1769, some APIs requires the base board
# define BOARD_NGX4330 4300 ///< NGX 4330 Xplorer
# define BOARD_EA4357 4301 ///< Embedded Artists LPC4357 developer kit
# define BOARD_MCB4300 4302 ///< Keil MCB4300
# define BOARD_HITEX4350 4303 ///< Hitex 4350
2014-03-21 16:42:43 +07:00
# define BOARD_LPC4357USB 4304
2013-10-16 12:05:48 +07:00
2014-03-25 13:00:37 +07:00
# define BOARD_LPCLINK2 4370 ///< LPClink2 uses as LPC4370 development board
/** @} */
2013-10-16 12:05:48 +07:00
//--------------------------------------------------------------------+
// PRINTF TARGET DEFINE
//--------------------------------------------------------------------+
2014-03-25 13:00:37 +07:00
/** \defgroup group_printf Printf Retarget
* \ brief Retarget the standard stdio printf / getchar to other IOs
* @ { */
# define PRINTF_TARGET_SEMIHOST 1 ///< Using the semihost support from toolchain, requires no hardware but is the slowest
# define PRINTF_TARGET_UART 2 ///< Using UART as stdio, this is the default for most of the board
# define PRINTF_TARGET_SWO 3 ///< Using non-instructive serial wire output (SWO), is the best option since it does not slow down MCU but requires supported from debugger and IDE
# define PRINTF_TARGET_NONE 4 ///< Using none at all.
/** @} */
2013-10-16 12:05:48 +07:00
# define PRINTF(...) printf(__VA_ARGS__)
2014-03-25 13:00:37 +07:00
//--------------------------------------------------------------------+
// BOARD INCLUDE
//--------------------------------------------------------------------+
2014-03-25 16:41:50 +07:00
# if BOARD == BOARD_LPCXPRESSO11U14
# include "lpcxpresso/board_lpcxpresso11u14.h"
2013-10-16 12:05:48 +07:00
# elif BOARD == BOARD_RF1GHZNODE
# include "microbuilder/board_rf1ghznode.h"
2014-03-25 16:41:50 +07:00
# elif BOARD == BOARD_LPCXPRESSO1347
# include "lpcxpresso/board_lpcxpresso1347.h"
# elif BOARD == BOARD_LPCXPRESSO1769
# include "lpcxpresso/board_lpcxpresso1769.h"
# elif BOARD == BOARD_NGX4330
# include "ngx/board_ngx4330.h"
2013-10-16 12:05:48 +07:00
# elif BOARD == BOARD_EA4357
2013-11-15 00:01:07 +07:00
# include "embedded_artists/ea4357/board_ea4357.h"
2013-10-16 12:05:48 +07:00
# elif BOARD == BOARD_MCB4300
# include "keil/board_mcb4300.h"
# elif BOARD == BOARD_HITEX4350
# include "hitex/board_hitex4350.h"
# elif BOARD == BOARD_LPC4357USB
# include "microbuilder/board_lpc4357usb.h"
2013-12-02 00:40:10 +07:00
# elif BOARD == BOARD_LPCLINK2
# include "lpcxpresso/board_lpclink2.h"
2013-10-16 12:05:48 +07:00
# else
# error BOARD is not defined or supported yet
# endif
//--------------------------------------------------------------------+
// Common Configuration
//--------------------------------------------------------------------+
2014-03-25 13:00:37 +07:00
# define CFG_UART_BAUDRATE 115200 ///< Baudrate for UART
2013-10-16 12:05:48 +07:00
//--------------------------------------------------------------------+
// Board Common API
//--------------------------------------------------------------------+
2014-03-25 13:00:37 +07:00
/** \defgroup group_board_api Board API
* \ brief All the board must support these APIs .
* @ { */
/// Initialize all required peripherals on board including uart, led, buttons etc ...
2013-10-16 12:05:48 +07:00
void board_init ( void ) ;
2013-12-11 12:13:22 +07:00
2014-03-25 13:00:37 +07:00
/** \brief Turns on and off leds on the board
* \ param [ in ] on_mask Bitmask for LED ' s numbers is turning ON
* \ param [ out ] off_mask Bitmask for LED ' s numbers is turning OFF
* \ note the \ a on_mask is more priority then \ a off_mask , if an led ' s number is present on both .
* It will be turned ON .
*/
2013-10-16 12:05:48 +07:00
void board_leds ( uint32_t on_mask , uint32_t off_mask ) ;
2014-03-25 13:00:37 +07:00
/** \brief Get the current state of the buttons on the board
* \ return Bitmask where a ' 1 ' means active ( pressed ) , a ' 0 ' means inactive .
*/
2014-03-21 16:32:39 +07:00
uint32_t board_buttons ( void ) ;
2013-12-11 12:13:22 +07:00
2014-03-25 13:00:37 +07:00
/** \brief Get a character input from UART
* \ return ASCII code of the input character or zero if none .
*/
2013-10-16 12:05:48 +07:00
uint8_t board_uart_getchar ( void ) ;
2014-03-25 13:00:37 +07:00
/** \brief Send a character to UART
* \ param [ in ] c the character to be sent
*/
2014-03-04 16:31:44 +07:00
void board_uart_putchar ( uint8_t c ) ;
2013-10-16 12:05:48 +07:00
2014-03-25 13:00:37 +07:00
/** @} */
2014-03-21 16:32:39 +07:00
//------------- Board Application -------------//
OSAL_TASK_FUNCTION ( led_blinking_task , p_task_para ) ;
2014-03-06 23:26:40 +07:00
2014-03-25 13:00:37 +07:00
/// Initialize the LED blinking task application. The initial blinking rate is 1 Hert (1 per second)
2014-03-21 16:32:39 +07:00
void led_blinking_init ( void ) ;
2014-03-25 13:00:37 +07:00
/** \brief Change the blinking rate.
* \ param [ in ] ms The interval between on and off .
*/
2014-03-21 16:32:39 +07:00
void led_blinking_set_interval ( uint32_t ms ) ;
2013-10-16 12:05:48 +07:00
# ifdef __cplusplus
}
# endif
# endif /* _TUSB_BOARD_H_ */
/** @} */