| 
									
										
										
										
											2018-11-27 18:11:03 -08:00
										 |  |  | /**************************************************************************/ | 
					
						
							|  |  |  | /*!
 | 
					
						
							|  |  |  |  @file    board_metro_m4_express.c | 
					
						
							|  |  |  |  @author  hathach (tinyusb.org) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  @section LICENSE | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Software License Agreement (BSD License) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Copyright (c) 2018, 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 "bsp/board.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "stm32f4xx.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "tusb_option.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | // MACRO TYPEDEF CONSTANT ENUM DECLARATION
 | 
					
						
							|  |  |  | //--------------------------------------------------------------------+
 | 
					
						
							|  |  |  | void board_init(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   // Init the LED on PD14
 | 
					
						
							| 
									
										
										
										
											2019-01-10 10:14:01 -05:00
										 |  |  |   RCC->AHB1ENR |= RCC_AHB1ENR_GPIODEN; | 
					
						
							| 
									
										
										
										
											2019-01-11 10:20:14 -05:00
										 |  |  |   GPIOD->MODER |= GPIO_MODER_MODE14_0; | 
					
						
							| 
									
										
										
										
											2018-11-27 18:11:03 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // USB Clock init
 | 
					
						
							| 
									
										
										
										
											2019-01-11 13:47:44 -05:00
										 |  |  |   // PLL input- 8 MHz (External oscillator clock; HSI clock tolerance isn't
 | 
					
						
							|  |  |  |   // tight enough- 1%, need 0.25%)
 | 
					
						
							|  |  |  |   // VCO input- 1 to 2 MHz (2 MHz, M = 4)
 | 
					
						
							| 
									
										
										
										
											2019-01-11 10:20:14 -05:00
										 |  |  |   // VCO output- 100 to 432 MHz (144 MHz, N = 72)
 | 
					
						
							| 
									
										
										
										
											2019-01-11 13:47:44 -05:00
										 |  |  |   // Main PLL out- <= 180 MHz (18 MHz, P = 3- divides by 8)
 | 
					
						
							| 
									
										
										
										
											2019-01-11 10:20:14 -05:00
										 |  |  |   // USB PLL out- 48 MHz (Q = 3)
 | 
					
						
							| 
									
										
										
										
											2019-01-11 13:47:44 -05:00
										 |  |  |   RCC->PLLCFGR = RCC_PLLCFGR_PLLSRC_HSE | (3 << RCC_PLLCFGR_PLLQ_Pos) | \ | 
					
						
							|  |  |  |     (3 << RCC_PLLCFGR_PLLP_Pos) | (72 << RCC_PLLCFGR_PLLN_Pos) | \ | 
					
						
							|  |  |  |     (4 << RCC_PLLCFGR_PLLM_Pos); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Wait for external clock to become ready
 | 
					
						
							|  |  |  |   RCC->CR |= RCC_CR_HSEON; | 
					
						
							|  |  |  |   while(!(RCC->CR & RCC_CR_HSERDY_Msk)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Wait for PLL to become ready
 | 
					
						
							| 
									
										
										
										
											2019-01-11 10:20:14 -05:00
										 |  |  |   RCC->CR |= RCC_CR_PLLON; | 
					
						
							| 
									
										
										
										
											2019-01-11 13:47:44 -05:00
										 |  |  |   while(!(RCC->CR & RCC_CR_PLLRDY_Msk)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Switch clocks!
 | 
					
						
							|  |  |  |   RCC->CFGR |= RCC_CFGR_SW_1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Notify runtime of frequency change.
 | 
					
						
							|  |  |  |   SystemCoreClockUpdate(); | 
					
						
							|  |  |  |   // Systick init
 | 
					
						
							|  |  |  |   #if CFG_TUSB_OS  == OPT_OS_NONE
 | 
					
						
							|  |  |  |     SysTick_Config(SystemCoreClock / 1000); | 
					
						
							|  |  |  |   #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-11 10:20:14 -05:00
										 |  |  |   RCC->AHB2ENR |= RCC_AHB2ENR_OTGFSEN; | 
					
						
							| 
									
										
										
										
											2018-11-27 18:11:03 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // USB Pin Init
 | 
					
						
							| 
									
										
										
										
											2019-01-13 17:34:09 -05:00
										 |  |  |   // PA9- VUSB, PA10- ID, PA11- DM, PA12- DP
 | 
					
						
							| 
									
										
										
										
											2019-01-11 10:20:14 -05:00
										 |  |  |   // PC0- Power on
 | 
					
						
							| 
									
										
										
										
											2019-01-11 13:47:44 -05:00
										 |  |  |   RCC->AHB1ENR |= RCC_AHB1ENR_GPIOAEN; | 
					
						
							| 
									
										
										
										
											2019-01-13 17:34:09 -05:00
										 |  |  |   GPIOA->MODER |= GPIO_MODER_MODE9_1 | GPIO_MODER_MODE10_1 | \ | 
					
						
							|  |  |  |     GPIO_MODER_MODE11_1 | GPIO_MODER_MODE12_1; | 
					
						
							|  |  |  |   GPIOA->AFR[1] |= (10 << GPIO_AFRH_AFSEL9_Pos) | \ | 
					
						
							|  |  |  |     (10 << GPIO_AFRH_AFSEL10_Pos) | (10 << GPIO_AFRH_AFSEL11_Pos) | \ | 
					
						
							|  |  |  |     (10 << GPIO_AFRH_AFSEL12_Pos); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Pullup required on ID, despite the manual claiming there's an
 | 
					
						
							|  |  |  |   // internal pullup already (page 1245, Rev 17)
 | 
					
						
							|  |  |  |   GPIOA->PUPDR |= GPIO_PUPDR_PUPD10_0; | 
					
						
							| 
									
										
										
										
											2018-11-27 18:11:03 -08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-10 10:14:01 -05:00
										 |  |  | void board_led_control(bool state) | 
					
						
							| 
									
										
										
										
											2018-11-27 18:11:03 -08:00
										 |  |  | { | 
					
						
							|  |  |  |   if (!state) { | 
					
						
							| 
									
										
										
										
											2019-01-10 10:14:01 -05:00
										 |  |  |     GPIOD->BSRR = GPIO_BSRR_BR14; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     GPIOD->BSRR = GPIO_BSRR_BS14; | 
					
						
							| 
									
										
										
										
											2018-11-27 18:11:03 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*------------------------------------------------------------------*/ | 
					
						
							|  |  |  | /* TUSB HAL MILLISECOND
 | 
					
						
							|  |  |  |  *------------------------------------------------------------------*/ | 
					
						
							|  |  |  | #if CFG_TUSB_OS  == OPT_OS_NONE
 | 
					
						
							|  |  |  | volatile uint32_t system_ticks = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void SysTick_Handler (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   system_ticks++; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | uint32_t tusb_hal_millis(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return board_tick2ms(system_ticks); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void HardFault_Handler (void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   asm("bkpt"); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-03-04 10:41:05 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Required by __libc_init_array in startup code if we are compiling using
 | 
					
						
							|  |  |  | // -nostdlib/-nostartfiles.
 | 
					
						
							|  |  |  | void _init(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |