From ded48cef81a6f9f1f81670667636bf21f2a598e0 Mon Sep 17 00:00:00 2001 From: Scott Allen Date: Fri, 1 Apr 2016 16:27:38 -0400 Subject: [PATCH] Fix setting CPU clock to 8MHz A dedicated #define is used. The PLL prescaler for USB is readjusted. --- src/core/core.cpp | 19 ++++++++++++------- src/core/core.h | 2 +- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/src/core/core.cpp b/src/core/core.cpp index 70489fe..00b7258 100644 --- a/src/core/core.cpp +++ b/src/core/core.cpp @@ -93,9 +93,10 @@ ArduboyCore::ArduboyCore() {} void ArduboyCore::boot() { - #if F_CPU == 8000000L - bootCPUSpeed(); - #endif +#ifdef ARDUBOY_SET_CPU_8MHZ +// ARDUBOY_SET_CPU_8MHZ will be set by the IDE using boards.txt + setCPUSpeed8MHz(); +#endif SPI.begin(); bootPins(); @@ -109,15 +110,19 @@ void ArduboyCore::boot() bootPowerSaving(); } -#if F_CPU == 8000000L -// if we're compiling for 8Mhz we need to slow the CPU down because the -// hardware clock on the Arduboy is 16MHz -void ArduboyCore::bootCPUSpeed() +#ifdef ARDUBOY_SET_CPU_8MHZ +// If we're compiling for 8MHz we need to slow the CPU down because the +// hardware clock on the Arduboy is 16MHz. +// We also need to readjust the PLL prescaler because the Arduino USB code +// likely will have incorrectly set it for an 8MHz hardware clock. +void ArduboyCore::setCPUSpeed8MHz() { uint8_t oldSREG = SREG; cli(); // suspend interrupts + PLLCSR = _BV(PINDIV); // dissable the PLL and set prescale for 16MHz) CLKPR = _BV(CLKPCE); // allow reprogramming clock CLKPR = 1; // set clock divisor to 2 (0b0001) + PLLCSR = _BV(PLLE) | _BV(PINDIV); // enable the PLL (with 16MHz prescale) SREG = oldSREG; // restore interrupts } #endif diff --git a/src/core/core.h b/src/core/core.h index 4f228d6..7bab3b4 100644 --- a/src/core/core.h +++ b/src/core/core.h @@ -283,9 +283,9 @@ protected: void static inline safeMode() __attribute__((always_inline)); // internals + void static inline setCPUSpeed8MHz() __attribute__((always_inline)); void static inline bootOLED() __attribute__((always_inline)); void static inline bootPins() __attribute__((always_inline)); - void static inline bootCPUSpeed() __attribute__((always_inline)); void static inline bootPowerSaving() __attribute__((always_inline));