| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |     @file     board_lpcxpresso1769.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. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-14 00:22:49 +07:00
										 |  |  | #ifdef BOARD_LPCXPRESSO1769
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  | #include "bsp/board.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-29 22:59:00 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-03 19:04:57 +07:00
										 |  |  | #define LED_PORT      0
 | 
					
						
							|  |  |  | #define LED_PIN       22
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define BOARD_UART_PORT   LPC_UART3
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  | /* Pin muxing configuration */ | 
					
						
							| 
									
										
										
										
											2018-12-03 19:04:57 +07:00
										 |  |  | static const PINMUX_GRP_T pinmuxing[] = | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  | 	{0,  0,   IOCON_MODE_INACT | IOCON_FUNC2},	/* TXD3 */ | 
					
						
							|  |  |  | 	{0,  1,   IOCON_MODE_INACT | IOCON_FUNC2},	/* RXD3 */ | 
					
						
							|  |  |  | 	{0,  22,  IOCON_MODE_INACT | IOCON_FUNC0},	/* Led 0 */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Joystick buttons. */ | 
					
						
							|  |  |  | 	{2, 3,  IOCON_MODE_INACT | IOCON_FUNC0},	/* JOYSTICK_UP */ | 
					
						
							|  |  |  | 	{0, 15, IOCON_MODE_INACT | IOCON_FUNC0},	/* JOYSTICK_DOWN */ | 
					
						
							|  |  |  | 	{2, 4,  IOCON_MODE_INACT | IOCON_FUNC0},	/* JOYSTICK_LEFT */ | 
					
						
							|  |  |  | 	{0, 16, IOCON_MODE_INACT | IOCON_FUNC0},	/* JOYSTICK_RIGHT */ | 
					
						
							|  |  |  | 	{0, 17, IOCON_MODE_INACT | IOCON_FUNC0},	/* JOYSTICK_PRESS */ | 
					
						
							| 
									
										
										
										
											2018-12-03 19:04:57 +07:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-03 19:04:57 +07:00
										 |  |  | enum { | 
					
						
							|  |  |  |   BOARD_BUTTON_COUNT = 5 | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* System oscillator rate and RTC oscillator rate */ | 
					
						
							|  |  |  | const uint32_t OscRateIn = 12000000; | 
					
						
							|  |  |  | const uint32_t RTCOscRateIn = 32768; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Invoked by startup code
 | 
					
						
							|  |  |  | void SystemInit(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-12-03 19:04:57 +07:00
										 |  |  |   /* Enable IOCON clock */ | 
					
						
							|  |  |  |   Chip_IOCON_SetPinMuxing(LPC_IOCON, pinmuxing, sizeof(pinmuxing) / sizeof(PINMUX_GRP_T)); | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  |   Chip_SetupXtalClocking(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | void board_init(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  |   SystemCoreClockUpdate(); | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  | #if CFG_TUSB_OS == OPT_OS_NONE
 | 
					
						
							|  |  |  |   SysTick_Config(SystemCoreClock / BOARD_TICKS_HZ); | 
					
						
							| 
									
										
										
										
											2018-11-29 22:59:00 +07:00
										 |  |  | #elif CFG_TUSB_OS == OPT_OS_FREERTOS
 | 
					
						
							|  |  |  |   // If freeRTOS is used, IRQ priority is limit by max syscall ( smaller is higher )
 | 
					
						
							|  |  |  |   NVIC_SetPriority(USB_IRQn, configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY ); | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  |   Chip_GPIO_Init(LPC_GPIO); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  |   //------------- LED -------------//
 | 
					
						
							| 
									
										
										
										
											2018-12-03 19:04:57 +07:00
										 |  |  |   Chip_GPIO_SetPinDIROutput(LPC_GPIO, LED_PORT, LED_PIN); | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   //------------- BUTTON -------------//
 | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  | //  for(uint8_t i=0; i<BOARD_BUTTON_COUNT; i++) GPIO_SetDir(buttons[i].port, BIT_(buttons[i].pin), 0);
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-23 15:25:45 +07:00
										 |  |  | #if TUSB_OPT_DEVICE_ENABLED
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  |   //------------- USB Device -------------//
 | 
					
						
							|  |  |  |   // VBUS sense is wrongly connected to P0_5 (instead of P1_30). So we need to always pull P1_30 to high
 | 
					
						
							|  |  |  |   // so that USB device block can work. However, Device Controller (thus tinyusb) cannot able to determine
 | 
					
						
							|  |  |  |   // if device is disconnected or not
 | 
					
						
							|  |  |  |   PINSEL_ConfigPin( &(PINSEL_CFG_Type) { | 
					
						
							|  |  |  |       .Portnum = 1, .Pinnum = 30, | 
					
						
							|  |  |  |       .Funcnum = 2, .Pinmode = PINSEL_PINMODE_PULLUP} ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   //P0_21 instead of P2_9 as USB connect
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-27 20:48:46 +07:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  |   //------------- UART -------------//
 | 
					
						
							|  |  |  |   PINSEL_CFG_Type PinCfg = | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |       .Portnum   = 0, | 
					
						
							|  |  |  |       .Pinnum    = 0, // TXD is P0.0
 | 
					
						
							|  |  |  |       .Funcnum   = 2, | 
					
						
							|  |  |  |       .OpenDrain = 0, | 
					
						
							|  |  |  |       .Pinmode   = 0 | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 	PINSEL_ConfigPin(&PinCfg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	PinCfg.Portnum = 0; | 
					
						
							|  |  |  | 	PinCfg.Pinnum  = 1; // RXD is P0.1
 | 
					
						
							|  |  |  | 	PINSEL_ConfigPin(&PinCfg); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UART_CFG_Type UARTConfigStruct; | 
					
						
							|  |  |  |   UART_ConfigStructInit(&UARTConfigStruct); | 
					
						
							|  |  |  | 	UARTConfigStruct.Baud_rate = CFG_UART_BAUDRATE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	UART_Init(BOARD_UART_PORT, &UARTConfigStruct); | 
					
						
							|  |  |  | 	UART_TxCmd(BOARD_UART_PORT, ENABLE); // Enable UART Transmit
 | 
					
						
							| 
									
										
										
										
											2018-11-27 20:48:46 +07:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-12-03 19:04:57 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* VBUS is not connected on the NXP LPCXpresso LPC1769, so leave the pin at default setting. */ | 
					
						
							|  |  |  | 	/*Chip_IOCON_PinMux(LPC_IOCON, 1, 30, IOCON_MODE_INACT, IOCON_FUNC2);*/ /* USB VBUS */ | 
					
						
							| 
									
										
										
										
											2018-11-27 20:48:46 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*------------------------------------------------------------------*/ | 
					
						
							|  |  |  | /* TUSB HAL MILLISECOND
 | 
					
						
							|  |  |  |  *------------------------------------------------------------------*/ | 
					
						
							|  |  |  | #if CFG_TUSB_OS == OPT_OS_NONE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | volatile uint32_t system_ticks = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void SysTick_Handler (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   system_ticks++; | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-27 20:48:46 +07:00
										 |  |  | uint32_t tusb_hal_millis(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return board_tick2ms(system_ticks); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // LEDS
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							| 
									
										
										
										
											2018-12-03 19:04:57 +07:00
										 |  |  | void board_led_control(bool state) | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-12-03 19:04:57 +07:00
										 |  |  |   Chip_GPIO_SetPinState(LPC_GPIO, LED_PORT, LED_PIN, state); | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // BUTTONS
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | static bool button_read(uint8_t id) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  | //  return !BIT_TEST_( GPIO_ReadValue(buttons[id].port), buttons[id].pin ); // button is active low
 | 
					
						
							|  |  |  |   return false; | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | uint32_t board_buttons(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   uint32_t result = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-03 17:28:38 +07:00
										 |  |  | //  for(uint8_t i=0; i<BOARD_BUTTON_COUNT; i++) result |= (button_read(i) ? BIT_(i) : 0);
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   return result; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // UART
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | void board_uart_putchar(uint8_t c) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-27 20:48:46 +07:00
										 |  |  | //  UART_Send(BOARD_UART_PORT, &c, 1, BLOCKING);
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | uint8_t  board_uart_getchar(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-11-27 20:48:46 +07:00
										 |  |  | //  return UART_ReceiveByte(BOARD_UART_PORT);
 | 
					
						
							| 
									
										
										
										
											2018-03-02 13:41:35 +07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 |