system_stm32.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. /*
  2. * Copyright (C) 2013 by Uwe Bonnes <bon@elektron.ikp.physik.tu-darmstadt.de>
  3. *
  4. * All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. *
  10. * 1. Redistributions of source code must retain the above copyright
  11. * notice, this list of conditions and the following disclaimer.
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in the
  14. * documentation and/or other materials provided with the distribution.
  15. * 3. Neither the name of the copyright holders nor the names of
  16. * contributors may be used to endorse or promote products derived
  17. * from this software without specific prior written permission.
  18. *
  19. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  20. * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  21. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
  22. * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
  23. * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
  24. * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
  25. * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
  26. * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
  27. * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  28. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
  29. * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  30. * SUCH DAMAGE.
  31. *
  32. * For additional information see http://www.ethernut.de/
  33. */
  34. #include <stdint.h>
  35. #include <cfg/arch.h>
  36. #include <arch/cm3/stm/stm32xxxx.h>
  37. #if defined(RCC_CR_MSION)
  38. #define RCC_CR_RESET_VALUE RCC_CR_MSION
  39. #else
  40. #if !defined(RCC_CR_HSITRIM_4)
  41. #define RCC_CR_RESET_VALUE (RCC_CR_HSION | 0x80)
  42. #else
  43. #define RCC_CR_RESET_VALUE (RCC_CR_HSION | RCC_CR_HSITRIM_4)
  44. #endif
  45. #endif
  46. /** @addtogroup STM32_System_Defines
  47. * @{
  48. */
  49. /**
  50. * Initialize the system
  51. *
  52. * @param none
  53. * @return none
  54. *
  55. * @brief Setup the microcontroller system.
  56. * Switch back to default clock state.
  57. *
  58. * We write the default reset values to the appropriated registers.
  59. * Some bits can only be written in certain constellation, so we write
  60. * multiple time, as previous writes prepare these constellations.
  61. * We keep eventual CIR IRQ pendings flags hanging...
  62. */
  63. void SystemInit (void)
  64. {
  65. RCC_TypeDef *rcc = (RCC_TypeDef *) RCC_BASE;
  66. /* FPU settings ---------------------------------------------------------*/
  67. #if (__FPU_PRESENT == 1) && (__FPU_USED == 1)
  68. /* set CP10 and CP11 Full Access */
  69. SCB->CPACR |= ((3UL << 10*2)|(3UL << 11*2));
  70. #endif
  71. /* Disable clock related interrupts*/
  72. rcc->CIR = 0;
  73. /* Switch on HSI Clock */
  74. rcc->CR = RCC_CR_RESET_VALUE;
  75. rcc->CFGR = 0;
  76. /* Now HSEON, CSSON and PLLON should reset*/
  77. rcc->CR = RCC_CR_RESET_VALUE;
  78. #if defined(RCC_PLLCFGR_PLLM)
  79. /* Reset PLLSRC, PLLXTPRE, PLLMUL and USBPRE bits */
  80. rcc->PLLCFGR = 0;
  81. #endif
  82. /* Now HSEBYP should reset*/
  83. rcc->CR = RCC_CR_RESET_VALUE;
  84. #if defined(RCC_CFGR_PLLSRC)
  85. /* Reset PLL bits*/
  86. rcc->CFGR = 0;
  87. #endif
  88. #if defined(RCC_CFGR2_PREDIV1)
  89. rcc->CFGR2 = 0;
  90. #endif
  91. #if defined(RCC_CFGR3_USART1SW1)
  92. rcc->CFGR3 = 0;
  93. #endif
  94. /* Seperate USB and CAN interrupts on F30 */
  95. #if defined(STM32F30X)
  96. rcc->APB2ENR |= RCC_APB2ENR_SYSCFGEN;
  97. SYSCFG_TypeDef *syscfg = (SYSCFG_TypeDef *) SYSCFG_BASE;
  98. syscfg->CFGR1 |= SYSCFG_CFGR1_USB_IT_RMP;
  99. #endif
  100. }
  101. /**
  102. * @}
  103. */