orl(AR9170_TIMER_REG_INTERRUPT, BIT(timer));
}
+void clock_set(enum cpu_clock_t _clock, bool on)
+{
+ /*
+ * Word of Warning!
+ * This setting does more than just mess with the CPU Clock.
+ * So watch out, if you need _stable_ timer interrupts.
+ */
+
+ fw.ticks_per_msec = GET_VAL(AR9170_PWR_PLL_ADDAC_DIV, get(AR9170_PWR_REG_PLL_ADDAC)) >> 1;
+
+ set(AR9170_PWR_REG_CLOCK_SEL, (uint32_t) ((on ? 0x70 : 0x600) | _clock));
+}
+
static void init(void)
{
led_init();
* we put _start() there with the linker script carl9170.lds.
*/
-void start(void)
+void __section(boot) start(void)
{
clock_set(AHB_40MHZ_OSC, true);