avr: Move prescaler and sleep initialization from timer.c to main.c

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2017-08-06 19:26:48 -04:00
parent 114c8c5b6d
commit e12527b895
2 changed files with 21 additions and 11 deletions

View File

@ -39,6 +39,27 @@ dynmem_end(void)
* Misc functions * Misc functions
****************************************************************/ ****************************************************************/
// Initialize the clock prescaler (if necessary)
void
prescaler_init(void)
{
if (CONFIG_AVR_CLKPR != -1 && (uint8_t)CONFIG_AVR_CLKPR != CLKPR) {
irqstatus_t flag = irq_save();
CLKPR = 0x80;
CLKPR = CONFIG_AVR_CLKPR;
irq_restore(flag);
}
}
DECL_INIT(prescaler_init);
// The "sleep" instruction should cause the processor to enter "idle mode"
void
sleep_init(void)
{
SMCR = 0x01;
}
DECL_INIT(sleep_init);
// Optimized crc16_ccitt for the avr processor // Optimized crc16_ccitt for the avr processor
uint16_t uint16_t
crc16_ccitt(char *buf, uint8_t len) crc16_ccitt(char *buf, uint8_t len)

View File

@ -91,14 +91,6 @@ DECL_SHUTDOWN(timer_reset);
void void
timer_init(void) timer_init(void)
{ {
if (CONFIG_AVR_CLKPR != -1 && (uint8_t)CONFIG_AVR_CLKPR != CLKPR) {
// Program the clock prescaler
irqstatus_t flag = irq_save();
CLKPR = 0x80;
CLKPR = CONFIG_AVR_CLKPR;
irq_restore(flag);
}
// no outputs // no outputs
TCCR1A = 0; TCCR1A = 0;
// Normal Mode // Normal Mode
@ -110,9 +102,6 @@ timer_init(void)
// enable interrupt // enable interrupt
TIMSK1 = 1<<OCIE1A; TIMSK1 = 1<<OCIE1A;
irq_restore(flag); irq_restore(flag);
// Enable idle on sleep instruction
SMCR = 0x01;
} }
DECL_INIT(timer_init); DECL_INIT(timer_init);