| 
									
										
										
										
											2019-03-20 16:11:42 +07:00
										 |  |  | /* 
 | 
					
						
							|  |  |  |  * The MIT License (MIT) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (c) 2018, hathach (tinyusb.org) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Permission is hereby granted, free of charge, to any person obtaining a copy | 
					
						
							|  |  |  |  * of this software and associated documentation files (the "Software"), to deal | 
					
						
							|  |  |  |  * in the Software without restriction, including without limitation the rights | 
					
						
							|  |  |  |  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | 
					
						
							|  |  |  |  * copies of the Software, and to permit persons to whom the Software is | 
					
						
							|  |  |  |  * furnished to do so, subject to the following conditions: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The above copyright notice and this permission notice shall be included in | 
					
						
							|  |  |  |  * all copies or substantial portions of the Software. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 
					
						
							|  |  |  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
					
						
							|  |  |  |  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | 
					
						
							|  |  |  |  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
					
						
							|  |  |  |  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | 
					
						
							|  |  |  |  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | 
					
						
							|  |  |  |  * THE SOFTWARE. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of the TinyUSB stack. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-11-27 18:11:03 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-22 22:06:48 +07:00
										 |  |  | #include "../board.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-27 18:11:03 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "stm32f4xx.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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(); | 
					
						
							| 
									
										
										
										
											2019-03-23 16:51:07 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-01-11 13:47:44 -05:00
										 |  |  |   #if CFG_TUSB_OS  == OPT_OS_NONE
 | 
					
						
							| 
									
										
										
										
											2019-03-23 16:51:07 +07:00
										 |  |  |   // 1ms tick timer
 | 
					
						
							|  |  |  |   SysTick_Config(SystemCoreClock / 1000); | 
					
						
							| 
									
										
										
										
											2019-01-11 13:47:44 -05:00
										 |  |  |   #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-04-02 18:16:04 +07:00
										 |  |  | void board_led_write(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
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 02:16:54 +07:00
										 |  |  | uint32_t board_button_read(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   // TODO implement
 | 
					
						
							|  |  |  |   return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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++; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-23 22:31:07 +07:00
										 |  |  | uint32_t board_millis(void) | 
					
						
							| 
									
										
										
										
											2019-03-23 16:51:07 +07:00
										 |  |  | { | 
					
						
							|  |  |  |   return system_ticks; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-11-27 18:11:03 -08:00
										 |  |  | #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) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |