.comp = {
[AVR_TIMER_COMPA] = {
.r_ocr = OCR0,
- .com = { AVR_IO_REGBIT(TCCR0, COM00), AVR_IO_REGBIT(TCCR0, COM01) },
+ .com = AVR_IO_REGBITS(TCCR0, COM00, 0x3),
.com_pin = AVR_IO_REGBIT(PORTB, PB4),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE0),
[AVR_TIMER_COMPA] = {
.r_ocr = OCR1AL,
.r_ocrh = OCR1AH, // 16 bits timers have two bytes of it
- .com = { AVR_IO_REGBIT(TCCR1A, COM1A0), AVR_IO_REGBIT(TCCR1A, COM1A1) },
+ .com = AVR_IO_REGBITS(TCCR1A, COM1A0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTB, PB5),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE1A),
[AVR_TIMER_COMPB] = {
.r_ocr = OCR1BL,
.r_ocrh = OCR1BH,
- .com = { AVR_IO_REGBIT(TCCR1A, COM1B0), AVR_IO_REGBIT(TCCR1A, COM1B1) },
+ .com = AVR_IO_REGBITS(TCCR1A, COM1B0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTB, PB6),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE1B),
[AVR_TIMER_COMPC] = {
.r_ocr = OCR1CL,
.r_ocrh = OCR1CH,
- .com = { AVR_IO_REGBIT(TCCR1A, COM1C0), AVR_IO_REGBIT(TCCR1A, COM1C1) },
+ .com = AVR_IO_REGBITS(TCCR1A, COM1C0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTB, PB7), // same as timer2
.interrupt = {
.enable = AVR_IO_REGBIT(ETIMSK, OCIE1C),
.comp = {
[AVR_TIMER_COMPA] = {
.r_ocr = OCR2,
- .com = { AVR_IO_REGBIT(TCCR2, COM20), AVR_IO_REGBIT(TCCR2, COM21) },
+ .com = AVR_IO_REGBITS(TCCR2, COM20, 0x3),
.com_pin = AVR_IO_REGBIT(PORTB, PB7), // same as timer1C
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE2),
[AVR_TIMER_COMPA] = {
.r_ocr = OCR3AL,
.r_ocrh = OCR3AH, // 16 bits timers have two bytes of it
- .com = { AVR_IO_REGBIT(TCCR3A, COM3A0), AVR_IO_REGBIT(TCCR3A, COM3A1) },
+ .com = AVR_IO_REGBITS(TCCR3A, COM3A0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTE, PE3),
.interrupt = {
.enable = AVR_IO_REGBIT(ETIMSK, OCIE3A),
[AVR_TIMER_COMPB] = {
.r_ocr = OCR3BL,
.r_ocrh = OCR3BH,
- .com = { AVR_IO_REGBIT(TCCR3A, COM3B0), AVR_IO_REGBIT(TCCR3A, COM3B1) },
+ .com = AVR_IO_REGBITS(TCCR3A, COM3B0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTE, PE4),
.interrupt = {
.enable = AVR_IO_REGBIT(ETIMSK, OCIE3B),
[AVR_TIMER_COMPC] = {
.r_ocr = OCR3CL,
.r_ocrh = OCR3CH,
- .com = { AVR_IO_REGBIT(TCCR3A, COM3C0), AVR_IO_REGBIT(TCCR3A, COM3C1) },
+ .com = AVR_IO_REGBITS(TCCR3A, COM3C0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTE, PE5),
.interrupt = {
.enable = AVR_IO_REGBIT(ETIMSK, OCIE3C),
.comp = {
[AVR_TIMER_COMPA] = {
.r_ocr = OCR0A,
+ .com = AVR_IO_REGBITS(TCCR0A, COM0A0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTB, 3),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK0, OCIE0A),
.raised = AVR_IO_REGBIT(TIFR0, OCF0A),
},
[AVR_TIMER_COMPB] = {
.r_ocr = OCR0B,
+ .com = AVR_IO_REGBITS(TCCR0A, COM0B0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTB, 4),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK0, OCIE0B),
.raised = AVR_IO_REGBIT(TIFR0, OCF0B),
[AVR_TIMER_COMPA] = {
.r_ocr = OCR1AL,
.r_ocrh = OCR1AH, // 16 bits timers have two bytes of it
+ .com = AVR_IO_REGBITS(TCCR1A, COM1A0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTD, 5),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK1, OCIE1A),
.raised = AVR_IO_REGBIT(TIFR1, OCF1A),
[AVR_TIMER_COMPB] = {
.r_ocr = OCR1BL,
.r_ocrh = OCR1BH,
+ .com = AVR_IO_REGBITS(TCCR1A, COM1B0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTD, 4),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK1, OCIE1B),
.raised = AVR_IO_REGBIT(TIFR1, OCF1B),
.comp = {
[AVR_TIMER_COMPA] = {
.r_ocr = OCR2A,
+ .com = AVR_IO_REGBITS(TCCR2A, COM2A0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTD, 7),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK2, OCIE2A),
.raised = AVR_IO_REGBIT(TIFR2, OCF2A),
},
[AVR_TIMER_COMPB] = {
.r_ocr = OCR2B,
+ .com = AVR_IO_REGBITS(TCCR2A, COM2B0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTD, 6),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK2, OCIE2B),
.raised = AVR_IO_REGBIT(TIFR2, OCF2B),
.comp = {
[AVR_TIMER_COMPA] = {
.r_ocr = OCR0A,
- .com = { AVR_IO_REGBIT(TCCR0A, COM0A0), AVR_IO_REGBIT(TCCR0A, COM0A1) },
+ .com = AVR_IO_REGBITS(TCCR0A, COM0A0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTD, 6),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK0, OCIE0A),
},
[AVR_TIMER_COMPB] = {
.r_ocr = OCR0B,
- .com = { AVR_IO_REGBIT(TCCR0A, COM0B0), AVR_IO_REGBIT(TCCR0A, COM0B1) },
+ .com = AVR_IO_REGBITS(TCCR0A, COM0B0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTD, 5),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK0, OCIE0B),
[AVR_TIMER_COMPA] = {
.r_ocr = OCR1AL,
.r_ocrh = OCR1AH, // 16 bits timers have two bytes of it
- .com = { AVR_IO_REGBIT(TCCR1A, COM1A0), AVR_IO_REGBIT(TCCR1A, COM1A1) },
+ .com = AVR_IO_REGBITS(TCCR1A, COM1A0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTB, 1),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK1, OCIE1A),
[AVR_TIMER_COMPB] = {
.r_ocr = OCR1BL,
.r_ocrh = OCR1BH,
- .com = { AVR_IO_REGBIT(TCCR1A, COM1B0), AVR_IO_REGBIT(TCCR1A, COM1B1) },
+ .com = AVR_IO_REGBITS(TCCR1A, COM1B0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTB, 2),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK1, OCIE1B),
.comp = {
[AVR_TIMER_COMPA] = {
.r_ocr = OCR2A,
- .com = { AVR_IO_REGBIT(TCCR2A, COM2A0), AVR_IO_REGBIT(TCCR2A, COM2A1) },
+ .com = AVR_IO_REGBITS(TCCR2A, COM2A0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTB, 3),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK2, OCIE2A),
},
[AVR_TIMER_COMPB] = {
.r_ocr = OCR2B,
- .com = { AVR_IO_REGBIT(TCCR2A, COM2B0), AVR_IO_REGBIT(TCCR2A, COM2B1) },
+ .com = AVR_IO_REGBITS(TCCR2A, COM2B0, 0x3),
.com_pin = AVR_IO_REGBIT(PORTD, 3),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK2, OCIE2B),
.comp = {
[AVR_TIMER_COMPA] = {
.r_ocr = OCR0A,
+ .com = AVR_IO_REGBITS(TCCR0A, COM0A0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTB, 2),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE0A),
.raised = AVR_IO_REGBIT(TIFR, OCF0A),
},
[AVR_TIMER_COMPB] = {
.r_ocr = OCR0B,
+ .com = AVR_IO_REGBITS(TCCR0A, COM0B0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTD, 5),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE0B),
.raised = AVR_IO_REGBIT(TIFR, OCF0B),
[AVR_TIMER_COMPA] = {
.r_ocr = OCR1AL,
.r_ocrh = OCR1AH, // 16 bits timers have two bytes of it
+ .com = AVR_IO_REGBITS(TCCR1A, COM1A0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTB, 3),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE1A),
.raised = AVR_IO_REGBIT(TIFR, OCF1A),
[AVR_TIMER_COMPB] = {
.r_ocr = OCR1BL,
.r_ocrh = OCR1BH,
+ .com = AVR_IO_REGBITS(TCCR1A, COM1A0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTB, 4),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE1B),
.raised = AVR_IO_REGBIT(TIFR, OCF1B),
.comp = {
[AVR_TIMER_COMPA] = {
.r_ocr = OCR0A,
+ .com = AVR_IO_REGBITS(TCCR0A, COM0A0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTB, 0),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE0A),
.raised = AVR_IO_REGBIT(TIFR, OCF0A),
},
[AVR_TIMER_COMPB] = {
.r_ocr = OCR0B,
+ .com = AVR_IO_REGBITS(TCCR0A, COM0B0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTB, 1),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE0B),
.raised = AVR_IO_REGBIT(TIFR, OCF0B),
.comp = {
[AVR_TIMER_COMPA] = {
.r_ocr = OCR1A,
+ .com = AVR_IO_REGBITS(TCCR1, COM1A0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTB, 1),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE1A),
.raised = AVR_IO_REGBIT(TIFR, OCF1A),
},
[AVR_TIMER_COMPB] = {
.r_ocr = OCR1B,
+ .com = AVR_IO_REGBITS(GTCCR, COM1B0, 0x3),
+ .com_pin = AVR_IO_REGBIT(PORTB, 4),
.interrupt = {
.enable = AVR_IO_REGBIT(TIMSK, OCIE1B),
.raised = AVR_IO_REGBIT(TIFR, OCF1B),