From 2c8b8ea52962fad5e1f5146ef7cdef600acee6a5 Mon Sep 17 00:00:00 2001 From: hathach Date: Mon, 2 Dec 2013 00:40:10 +0700 Subject: [PATCH] add board lpclink2, able to run device stack without any problems --- demos/bsp/boards/board.h | 7 +- .../embedded_artists/ea4357/board_ea4357.h | 9 +- demos/bsp/boards/lpcxpresso/board_lpclink2.c | 126 ++++++++++ demos/bsp/boards/lpcxpresso/board_lpclink2.h | 68 ++++++ demos/bsp/boards/ngx/board_ngx4330.c | 2 +- demos/device/device_os_none/.cproject | 219 ++++++++++++++---- demos/device/device_os_none/tusb_config.h | 7 +- tinyusb/device/dcd_lpc_11uxx_13uxx.c | 1 - 8 files changed, 381 insertions(+), 58 deletions(-) create mode 100644 demos/bsp/boards/lpcxpresso/board_lpclink2.c create mode 100644 demos/bsp/boards/lpcxpresso/board_lpclink2.h diff --git a/demos/bsp/boards/board.h b/demos/bsp/boards/board.h index 6f9d256c..52fac569 100644 --- a/demos/bsp/boards/board.h +++ b/demos/bsp/boards/board.h @@ -69,6 +69,7 @@ #define BOARD_LPCXPRESSO1769 7 #define BOARD_LPC4357USB 8 +#define BOARD_LPCLINK2 9 //--------------------------------------------------------------------+ // PRINTF TARGET DEFINE @@ -80,9 +81,7 @@ #define PRINTF(...) printf(__VA_ARGS__) -#if BOARD == 0 - #error BOARD is not defined or supported yet -#elif BOARD == BOARD_NGX4330 +#if BOARD == BOARD_NGX4330 #include "ngx/board_ngx4330.h" #elif BOARD == BOARD_LPCXPRESSO1347 #include "lpcxpresso/board_lpcxpresso1347.h" @@ -98,6 +97,8 @@ #include "lpcxpresso/board_lpcxpresso1769.h" #elif BOARD == BOARD_LPC4357USB #include "microbuilder/board_lpc4357usb.h" +#elif BOARD == BOARD_LPCLINK2 + #include "lpcxpresso/board_lpclink2.h" #else #error BOARD is not defined or supported yet #endif diff --git a/demos/bsp/boards/embedded_artists/ea4357/board_ea4357.h b/demos/bsp/boards/embedded_artists/ea4357/board_ea4357.h index da57a0d1..0e2a28d1 100644 --- a/demos/bsp/boards/embedded_artists/ea4357/board_ea4357.h +++ b/demos/bsp/boards/embedded_artists/ea4357/board_ea4357.h @@ -36,12 +36,6 @@ */ /**************************************************************************/ -/** \file - * \brief TBD - * - * \note TBD - */ - /** \ingroup TBD * \defgroup TBD * \brief TBD @@ -65,12 +59,13 @@ #include "../oem_base_board/pca9532.h" // LEDs -//#include "../oem_board/nand.h" +//#include "../oem_board/nand.h"a //#define CFG_PRINTF_TARGET PRINTF_TARGET_SWO #define CFG_PRINTF_TARGET PRINTF_TARGET_UART // FIXME keil's cmsis rtx does not work with UART (work with SWO) +// TODO clean up /*========================================================================= HARDWARE MAC ADDRESS -----------------------------------------------------------------------*/ diff --git a/demos/bsp/boards/lpcxpresso/board_lpclink2.c b/demos/bsp/boards/lpcxpresso/board_lpclink2.c new file mode 100644 index 00000000..8792ee93 --- /dev/null +++ b/demos/bsp/boards/lpcxpresso/board_lpclink2.c @@ -0,0 +1,126 @@ +/**************************************************************************/ +/*! + @file board_lpclink2.c + @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. +*/ +/**************************************************************************/ + +#include "../board.h" + +#if BOARD == BOARD_LPCLINK2 + +#define BOARD_UART_PORT LPC_USART0 +#define BOARD_UART_PIN_PORT 0x0f +#define BOARD_UART_PIN_TX 10 // PF.10 : UART0_TXD +#define BOARD_UART_PIN_RX 11 // PF.11 : UART0_RXD + +#define BOARD_MAX_LEDS 1 + +const static struct { + uint8_t port; + uint8_t pin; +}leds[BOARD_MAX_LEDS] = { {0, 8} }; + +void board_init(void) +{ + CGU_Init(); + +#if TUSB_CFG_OS == TUSB_OS_NONE // TODO may move to main.c + SysTick_Config(CGU_GetPCLKFrequency(CGU_PERIPHERAL_M4CORE) / CFG_TICKS_PER_SECOND); // 1 msec tick timer +#endif + + //------------- USB -------------// + + + //------------- LED -------------// + for (uint8_t i=0; i - - -