summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--chip/lm4/clock.c112
-rw-r--r--chip/stm32/clock-stm32f100.c13
-rw-r--r--chip/stm32/clock-stm32l15x.c7
-rw-r--r--include/clock.h4
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.