diff options
author | Rocco Marco Guglielmi <roccomarco.guglielmi@live.com> | 2016-06-25 16:55:00 +0000 |
---|---|---|
committer | Rocco Marco Guglielmi <roccomarco.guglielmi@live.com> | 2016-06-25 16:55:00 +0000 |
commit | 7af76933f7bfa86e8b46c13c3741a6aa8ac90ea9 (patch) | |
tree | 8f27b671ed2722b891381552a048ace06f186c66 /os | |
parent | 72874ecdfdd4a65f45f7c1b61dbf54cfe345dafd (diff) | |
download | ChibiOS-7af76933f7bfa86e8b46c13c3741a6aa8ac90ea9.tar.gz ChibiOS-7af76933f7bfa86e8b46c13c3741a6aa8ac90ea9.tar.bz2 ChibiOS-7af76933f7bfa86e8b46c13c3741a6aa8ac90ea9.zip |
Fixed Bug #761.
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@9665 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'os')
-rw-r--r-- | os/hal/ports/STM32/STM32L4xx/hal_lld.c | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/os/hal/ports/STM32/STM32L4xx/hal_lld.c b/os/hal/ports/STM32/STM32L4xx/hal_lld.c index 76433073c..4eea068c9 100644 --- a/os/hal/ports/STM32/STM32L4xx/hal_lld.c +++ b/os/hal/ports/STM32/STM32L4xx/hal_lld.c @@ -88,8 +88,7 @@ static void hal_lld_backup_domain_init(void) { */
void hal_lld_init(void) {
- /* Reset of all peripherals. AHB3 is not reseted because it could have
- been initialized in the board initialization file (board.c).*/
+ /* Reset of all peripherals.*/
rccResetAHB1(~0);
rccResetAHB2(~0);
rccResetAHB3(~0);
@@ -109,15 +108,20 @@ void hal_lld_init(void) { /* Programmable voltage detector enable.*/
#if STM32_PVD_ENABLE
- PWR->CR1 |= PWR_CR1_PVDE | (STM32_PLS & STM32_PLS_MASK);
-#endif /* STM32_PVD_ENABLE */
-
- /* Validating USB VDD.*/
-#if HAL_USE_USB
- PWR->CR2 = PWR_CR2_USV;
+ PWR->CR2 = PWR_CR2_PVDE | (STM32_PLS & STM32_PLS_MASK);
#else
PWR->CR2 = 0;
#endif /* STM32_PVD_ENABLE */
+
+ /* Enabling independent VDDUSB.*/
+#if HAL_USE_USB
+ PWR->CR2 |= PWR_CR2_USV;
+#endif /* HAL_USE_USB */
+
+ /* Enabling independent VDDIO2 required by GPIOG.*/
+#if STM32_HAS_GPIOG
+ PWR->CR2 |= PWR_CR2_IOSV;
+#endif /* STM32_HAS_GPIOG */
}
/**
@@ -198,7 +202,7 @@ void stm32_clock_init(void) { RCC->CR |= RCC_CR_MSIPLLEN;
#endif
- /* Note that MSI range is the MSISRANGE by default which is 4M.*/
+ /* Changing MSIRANGE value. Meanwhile range is set by MSISRANGE which is 4MHz.*/
RCC->CR |= STM32_MSIRANGE;
/* Switching from MSISRANGE to MSIRANGE.*/
|