From 7c65e76ad08acfd37594e966f9afdd17739550c5 Mon Sep 17 00:00:00 2001 From: Kevin O'Connor Date: Tue, 20 Nov 2018 12:17:09 -0500 Subject: [PATCH] avr: Rework hardware pwm pin definitions Simultaneously define the hardware pin and the timer registers. This makes the table a little easier to understand. Signed-off-by: Kevin O'Connor --- src/avr/hard_pwm.c | 104 +++++++++++++++++++++------------------------ 1 file changed, 48 insertions(+), 56 deletions(-) diff --git a/src/avr/hard_pwm.c b/src/avr/hard_pwm.c index 3348a664..96042651 100644 --- a/src/avr/hard_pwm.c +++ b/src/avr/hard_pwm.c @@ -13,6 +13,7 @@ #include "sched.h" // sched_shutdown struct gpio_pwm_info { + uint8_t pin; volatile void *ocr; volatile uint8_t *rega, *regb; uint8_t en_bit, flags; @@ -21,62 +22,54 @@ struct gpio_pwm_info { enum { GP_8BIT=1, GP_AFMT=2 }; static const struct gpio_pwm_info pwm_regs[] PROGMEM = { - { &OCR0A, &TCCR0A, &TCCR0B, 1<= ARRAY_SIZE(pwm_pins)) + const struct gpio_pwm_info *p = pwm_regs; + for (; ; p++) { + if (p >= &pwm_regs[ARRAY_SIZE(pwm_regs)]) shutdown("Not a valid PWM pin"); - if (READP(pwm_pins[chan]) == pin) + if (READP(p->pin) == pin) break; } // Map cycle_time to pwm clock divisor - const struct gpio_pwm_info *p = &pwm_regs[chan]; uint8_t flags = READP(p->flags), cs; if (flags & GP_AFMT) { switch (cycle_time) {