diff options
-rw-r--r-- | chip/lm4/clock.c | 112 | ||||
-rw-r--r-- | chip/stm32/clock-stm32f100.c | 13 | ||||
-rw-r--r-- | chip/stm32/clock-stm32l15x.c | 7 | ||||
-rw-r--r-- | include/clock.h | 4 |
4 files changed, 67 insertions, 69 deletions
diff --git a/chip/lm4/clock.c b/chip/lm4/clock.c index c23dc68b29..357efb276d 100644 --- a/chip/lm4/clock.c +++ b/chip/lm4/clock.c @@ -5,11 +5,10 @@ /* Clocks and power management settings */ -#include "board.h" #include "clock.h" -#include "cpu.h" -#include "config.h" +#include "common.h" #include "console.h" +#include "cpu.h" #include "gpio.h" #include "hooks.h" #include "registers.h" @@ -23,7 +22,9 @@ static int freq; -/* Disable the PLL; run off internal oscillator. */ +/** + * Disable the PLL; run off internal oscillator. + */ static void disable_pll(void) { /* Switch to 16MHz internal oscillator and power down the PLL */ @@ -37,15 +38,18 @@ static void disable_pll(void) freq = INTERNAL_CLOCK; } - -/* Enable the PLL to run at full clock speed. */ +/** + * Enable the PLL to run at full clock speed. + */ static void enable_pll(void) { /* Disable the PLL so we can reconfigure it */ disable_pll(); - /* Enable the PLL (PWRDN is no longer set) and set divider. PLL is - * still bypassed, since it hasn't locked yet. */ + /* + * Enable the PLL (PWRDN is no longer set) and set divider. PLL is + * still bypassed, since it hasn't locked yet. + */ LM4_SYSTEM_RCC = LM4_SYSTEM_RCC_SYSDIV(2) | LM4_SYSTEM_RCC_USESYSDIV | LM4_SYSTEM_RCC_BYPASS | @@ -63,7 +67,7 @@ static void enable_pll(void) freq = PLL_CLOCK; } -int clock_enable_pll(int enable, int notify) +void clock_enable_pll(int enable, int notify) { if (enable) enable_pll(); @@ -73,8 +77,6 @@ int clock_enable_pll(int enable, int notify) /* Notify modules of frequency change */ if (notify) hook_notify(HOOK_FREQ_CHANGE); - - return EC_SUCCESS; } void clock_wait_cycles(uint32_t cycles) @@ -83,17 +85,57 @@ void clock_wait_cycles(uint32_t cycles) " bne 1b\n" :: "r"(cycles)); } - int clock_get_freq(void) { return freq; } +void clock_init(void) +{ + +#ifdef BOARD_bds + /* + * Perform an auto calibration of the internal oscillator using the + * 32.768KHz hibernate clock, unless we've already done so. This is + * only necessary on A2 silicon as on BDS; A3 silicon is all + * factory-trimmed. + */ + if ((LM4_SYSTEM_PIOSCSTAT & 0x300) != 0x100) { + /* Start calibration */ + LM4_SYSTEM_PIOSCCAL = 0x80000000; + LM4_SYSTEM_PIOSCCAL = 0x80000200; + /* Wait for result */ + clock_wait_cycles(16); + while (!(LM4_SYSTEM_PIOSCSTAT & 0x300)) + ; + } +#else + /* + * Only BDS has an external crystal; other boards don't have one, and + * can disable main oscillator control to reduce power consumption. + */ + LM4_SYSTEM_MOSCCTL = 0x04; +#endif + + /* + * TODO: UART seems to glitch unless we wait 500k cycles before + * enabling the PLL, but only if this is a cold boot. Why? UART + * doesn't even use the PLL'd system clock. I've heard rumors the + * Stellaris ROM library does this too, but why? + */ + if (!system_jumped_to_this_image()) + clock_wait_cycles(500000); + + /* Make sure PLL is disabled */ + disable_pll(); +} /*****************************************************************************/ /* Console commands */ -/* Function to measure baseline for power consumption. +#ifdef CONFIG_CMD_SLEEP +/** + * Measure baseline for power consumption. * * Levels : * 0 : CPU running in tight loop @@ -101,7 +143,8 @@ int clock_get_freq(void) * 2 : CPU in sleep mode * 3 : CPU in sleep mode and peripherals gated * 4 : CPU in deep sleep mode - * 5 : CPU in deep sleep mode and peripherals gated */ + * 5 : CPU in deep sleep mode and peripherals gated + */ static int command_sleep(int argc, char **argv) { int level = 0; @@ -203,7 +246,9 @@ DECLARE_CONSOLE_COMMAND(sleep, command_sleep, "[level [clock]]", "Drop into sleep", NULL); +#endif /* CONFIG_CMD_SLEEP */ +#ifdef CONFIG_CMD_PLL static int command_pll(int argc, char **argv) { @@ -247,41 +292,4 @@ DECLARE_CONSOLE_COMMAND(pll, command_pll, "Get/set PLL state", NULL); -/*****************************************************************************/ -/* Initialization */ - -int clock_init(void) -{ - -#ifdef BOARD_bds - /* Perform an auto calibration of the internal oscillator using the - * 32.768KHz hibernate clock, unless we've already done so. This is - * only necessary on A2 silicon as on BDS; A3 silicon is all - * factory-trimmed. */ - if ((LM4_SYSTEM_PIOSCSTAT & 0x300) != 0x100) { - /* Start calibration */ - LM4_SYSTEM_PIOSCCAL = 0x80000000; - LM4_SYSTEM_PIOSCCAL = 0x80000200; - /* Wait for result */ - clock_wait_cycles(16); - while (!(LM4_SYSTEM_PIOSCSTAT & 0x300)) - ; - } -#else - /* Only BDS has an external crystal; other boards don't have one, and - * can disable main oscillator control to reduce power consumption. */ - LM4_SYSTEM_MOSCCTL = 0x04; -#endif - - /* TODO: UART seems to glitch unless we wait 500k cycles before - * enabling the PLL, but only if this is a cold boot. Why? UART - * doesn't even use the PLL'd system clock. I've heard rumors the - * Stellaris ROM library does this too, but why? */ - if (!system_jumped_to_this_image()) - clock_wait_cycles(500000); - - /* Make sure PLL is disabled */ - disable_pll(); - - return EC_SUCCESS; -} +#endif /* CONFIG_CMD_PLL */ diff --git a/chip/stm32/clock-stm32f100.c b/chip/stm32/clock-stm32f100.c index 7809b040cb..1e99e78248 100644 --- a/chip/stm32/clock-stm32f100.c +++ b/chip/stm32/clock-stm32f100.c @@ -5,10 +5,7 @@ /* Clocks and power management settings */ -#include <stdint.h> - #include "atomic.h" -#include "board.h" #include "clock.h" #include "common.h" #include "console.h" @@ -23,14 +20,14 @@ /* Allow serial console to wake up the EC from STOP mode */ /* #define CONFIG_FORCE_CONSOLE_RESUME */ -/** +/* * minimum delay to enter stop mode * STOP mode wakeup time with regulator in low power mode is 5 us. * PLL locking time is 200us. */ #define STOP_MODE_LATENCY 300 /* us */ -/** +/* * RTC clock frequency (connected to LSI clock) * * TODO: crosbug.com/p/12281 calibrate LSI frequency @@ -39,7 +36,7 @@ #define US_PER_RTC_TICK (1000000 / RTC_FREQ) /* On-going actions preventing to go into deep-sleep mode */ -uint32_t sleep_mask; +static uint32_t sleep_mask; void enable_sleep(uint32_t mask) { @@ -227,7 +224,7 @@ void __idle(void) } #endif /* CONFIG_LOW_POWER_IDLE */ -int clock_init(void) +void clock_init(void) { /* * The initial state : @@ -257,8 +254,6 @@ int clock_init(void) /* Enable RTC interrupts */ task_enable_irq(STM32_IRQ_RTC_WAKEUP); task_enable_irq(STM32_IRQ_RTC_ALARM); - - return EC_SUCCESS; } /*****************************************************************************/ diff --git a/chip/stm32/clock-stm32l15x.c b/chip/stm32/clock-stm32l15x.c index f175d4553a..687919f73b 100644 --- a/chip/stm32/clock-stm32l15x.c +++ b/chip/stm32/clock-stm32l15x.c @@ -5,9 +5,6 @@ /* Clocks and power management settings */ -#include <stdint.h> - -#include "board.h" #include "clock.h" #include "common.h" #include "registers.h" @@ -23,7 +20,7 @@ void disable_sleep(uint32_t mask) /* low power mode not implemented */ } -int clock_init(void) +void clock_init(void) { uint32_t tmp_acr; @@ -75,6 +72,4 @@ int clock_init(void) /* wait until the PLL is the clock source */ while ((STM32_RCC_CFGR & 0xc) != 0xc) ; - - return EC_SUCCESS; } diff --git a/include/clock.h b/include/clock.h index 4eb8a5b065..b2e3b81ac1 100644 --- a/include/clock.h +++ b/include/clock.h @@ -13,7 +13,7 @@ /** * Set the CPU clocks and PLLs. */ -int clock_init(void); +void clock_init(void); /** * Return the current clock frequency in Hz. @@ -28,7 +28,7 @@ int clock_get_freq(void); * be 1 unless you're briefly turning on the PLL to work * around a chip errata at init time. */ -int clock_enable_pll(int enable, int notify); +void clock_enable_pll(int enable, int notify); /** * Wait for a number of clock cycles. |