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:
parent
114c8c5b6d
commit
e12527b895
|
@ -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)
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue