diff options
author | Daniel Friesel <derf@finalrewind.org> | 2022-01-26 22:01:18 +0100 |
---|---|---|
committer | Daniel Friesel <derf@finalrewind.org> | 2022-01-26 22:01:18 +0100 |
commit | a0e6e8efb208d8b6b21199554ddf21f86c405857 (patch) | |
tree | d7a077026817d283e9ff148ccb6e099d4e770948 | |
parent | c6ba398335daea46ca33ee000534299dc5e4b6b9 (diff) |
atmega2650 timer: Use 16-bit Timer 4, fix setup_hz / setup_khz
-rw-r--r-- | include/arch/atmega2560/driver/timer.h | 26 |
1 files changed, 13 insertions, 13 deletions
diff --git a/include/arch/atmega2560/driver/timer.h b/include/arch/atmega2560/driver/timer.h index 73a8125..c16fbe4 100644 --- a/include/arch/atmega2560/driver/timer.h +++ b/include/arch/atmega2560/driver/timer.h @@ -6,7 +6,7 @@ #include <avr/io.h> #include <avr/interrupt.h> -#define ON_TIMER_INTERRUPT_head ISR(TIMER0_COMPA_vect) { +#define ON_TIMER_INTERRUPT_head ISR(TIMER4_COMPA_vect) { #define ON_TIMER_INTERRUPT_tail } class Timer { @@ -17,24 +17,24 @@ class Timer { public: Timer() {} - inline void setup_khz(uint16_t const frequency) { - OCR0A = frequency ? 255 / frequency : 1; - TCCR0A = _BV(WGM01); - prescaler = _BV(CS01) | _BV(CS00); + inline void setup_khz(uint16_t const frequency) { // 16 MHz base + OCR4A = frequency ? 16000 / frequency : 65535; + TCCR4A = _BV(WGM42); + prescaler = _BV(CS40); } - inline void setup_hz(uint16_t const frequency) { - OCR0A = frequency ? 255 / frequency : 1; - TCCR0A = _BV(WGM01); - prescaler = _BV(CS02) | _BV(CS00); + inline void setup_hz(uint16_t const frequency) { // 16 MHz / 256 == 62.5 kHz base + OCR4A = frequency ? 62500 / frequency : 65535; + TCCR4A = _BV(WGM42); + prescaler = _BV(CS42); } inline void start(unsigned char const interrupt) { - TCNT0 = 0; - TCCR0B = prescaler; + TCNT4 = 0; + TCCR4B = prescaler; if (interrupt) { - TIMSK0 = _BV(OCIE0A); + TIMSK4 = _BV(OCIE4A); } } - inline void stop() { TCCR0B = 0; TIMSK0 = 0; } + inline void stop() { TCCR4B = 0; TIMSK4 = 0; } }; extern Timer timer; |