LIbreria de soporte para la STM32F103C8T6 "Blue Pill" by Antuliu's Team

Dependents:   STM32-103C8_Plantilla_USB

Committer:
hudakz
Date:
Tue Aug 02 19:37:40 2016 +0000
Revision:
5:9fbbea76d6f6
Parent:
4:306609fe9dc8
Child:
8:2582ee8cc84c
USB clock implemented

Who changed what in which revision?

UserRevisionLine numberNew contents of line
hudakz 4:306609fe9dc8 1 /*
hudakz 4:306609fe9dc8 2 ******************************************************************************
hudakz 4:306609fe9dc8 3 * @file SysClockConf.c
hudakz 4:306609fe9dc8 4 * @author Zoltan Hudak
hudakz 4:306609fe9dc8 5 * @version
hudakz 4:306609fe9dc8 6 * @date 05-July-2016
hudakz 4:306609fe9dc8 7 * @brief System Clock configuration for STM32F103C8T6
hudakz 4:306609fe9dc8 8 ******************************************************************************
hudakz 4:306609fe9dc8 9 * @attention
hudakz 4:306609fe9dc8 10 *
hudakz 4:306609fe9dc8 11 * <h2><center>&copy; COPYRIGHT(c) 2016 Zoltan Hudak <hudakz@inbox.com>
hudakz 4:306609fe9dc8 12 *
hudakz 4:306609fe9dc8 13 * All rights reserved.
hudakz 4:306609fe9dc8 14
hudakz 4:306609fe9dc8 15 This program is free software: you can redistribute it and/or modify
hudakz 4:306609fe9dc8 16 it under the terms of the GNU General Public License as published by
hudakz 4:306609fe9dc8 17 the Free Software Foundation, either version 3 of the License, or
hudakz 4:306609fe9dc8 18 (at your option) any later version.
hudakz 4:306609fe9dc8 19
hudakz 4:306609fe9dc8 20 This program is distributed in the hope that it will be useful,
hudakz 4:306609fe9dc8 21 but WITHOUT ANY WARRANTY; without even the implied warranty of
hudakz 4:306609fe9dc8 22 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
hudakz 4:306609fe9dc8 23 GNU General Public License for more details.
hudakz 4:306609fe9dc8 24
hudakz 4:306609fe9dc8 25 You should have received a copy of the GNU General Public License
hudakz 4:306609fe9dc8 26 along with this program. If not, see <http://www.gnu.org/licenses/>.
hudakz 4:306609fe9dc8 27 */
hudakz 4:306609fe9dc8 28
hudakz 2:534793444c60 29 #include "SysClockConf.h"
hudakz 2:534793444c60 30 #include "mbed.h"
hudakz 2:534793444c60 31
hudakz 5:9fbbea76d6f6 32 bool HSE_SystemClock_Config(void) {
hudakz 2:534793444c60 33 RCC_OscInitTypeDef RCC_OscInitStruct;
hudakz 2:534793444c60 34
hudakz 2:534793444c60 35 RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
hudakz 2:534793444c60 36 RCC_OscInitStruct.HSEState = RCC_HSE_ON;
hudakz 2:534793444c60 37 RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
hudakz 2:534793444c60 38 RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
hudakz 2:534793444c60 39 RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
hudakz 5:9fbbea76d6f6 40 RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;
hudakz 2:534793444c60 41
hudakz 2:534793444c60 42 if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) {
hudakz 2:534793444c60 43 return false;
hudakz 2:534793444c60 44 }
hudakz 2:534793444c60 45
hudakz 2:534793444c60 46 RCC_ClkInitTypeDef RCC_ClkInitStruct;
hudakz 2:534793444c60 47
hudakz 2:534793444c60 48 RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
hudakz 2:534793444c60 49 |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
hudakz 2:534793444c60 50 RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
hudakz 2:534793444c60 51 RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
hudakz 2:534793444c60 52 RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
hudakz 2:534793444c60 53 RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
hudakz 2:534793444c60 54 if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK) {
hudakz 2:534793444c60 55 return false;
hudakz 2:534793444c60 56 }
hudakz 2:534793444c60 57
hudakz 2:534793444c60 58 RCC_PeriphCLKInitTypeDef PeriphClkInit;
hudakz 2:534793444c60 59
hudakz 2:534793444c60 60 PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_ADC|RCC_PERIPHCLK_USB;
hudakz 5:9fbbea76d6f6 61 PeriphClkInit.AdcClockSelection = RCC_ADCPCLK2_DIV6;
hudakz 5:9fbbea76d6f6 62 PeriphClkInit.UsbClockSelection = RCC_USBPLLCLK_DIV1_5;
hudakz 2:534793444c60 63 if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK) {
hudakz 2:534793444c60 64 return false;
hudakz 2:534793444c60 65 }
hudakz 2:534793444c60 66 return true;
hudakz 2:534793444c60 67 }
hudakz 2:534793444c60 68
hudakz 5:9fbbea76d6f6 69 bool confSysClock(void) {
hudakz 2:534793444c60 70 HAL_RCC_DeInit();
hudakz 5:9fbbea76d6f6 71 if (!HSE_SystemClock_Config()) {
hudakz 2:534793444c60 72 return false;
hudakz 2:534793444c60 73 }
hudakz 2:534793444c60 74 SystemCoreClockUpdate();
hudakz 2:534793444c60 75 return true;
hudakz 2:534793444c60 76 }
hudakz 2:534793444c60 77
hudakz 2:534793444c60 78
hudakz 5:9fbbea76d6f6 79