19.11.1 TC1 Control Register A
Name: | TCCR1A |
Offset: | 0x80 |
Reset: | 0x00 |
Property: | - |
Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |
COM1A[1:0] | COM1B[1:0] | WGM1[1:0] | |||||||
Access | R/W | R/W | R/W | R/W | R/W | R/W | |||
Reset | 0 | 0 | 0 | 0 | 0 | 0 |
Bits 4:5, 6:7 – COM1 Compare Output Mode for Channel
The COM1A[1:0] and COM1B[1:0] control the output compare pins (OC1A and OC1B respectively) behavior. If one or both of the COM1A[1:0] bits are written to one, the OC1A output overrides the normal port functionality of the I/O pin it is connected to. If one or both of the COM1B[1:0] bit are written to one, the OC1B output overrides the normal port functionality of the I/O pin it is connected to. However, note that the Data Direction Register (DDR) bit corresponding to the OC1A or OC1B pin must be set in order to enable the output driver.
When the OC1A or OC1B is connected to the pin, the function of the COM1x[1:0] bits is dependent on the WGM1[3:0] bits setting. The table below shows the COM1x[1:0] bit functionality when the WGM1[3:0] bits are set to a Normal or a CTC mode (non-PWM).
COM1A[1]/COM1B[1] | COM1A[0]/COM1B[0] | Description |
---|---|---|
0 | 0 | Normal port operation, OC1A/OC1B disconnected. |
0 | 1 | Toggle OC1A/OC1B on compare match. |
1 | 0 | Clear OC1A/OC1B on compare match (Set output to low level). |
1 | 1 | Set OC1A/OC1B on compare match (Set output to high level). |
The table below shows the COM1x[1:0] bit functionality when the WGM1[3:0] bits are set to the fast PWM mode.
COM1A[1]/COM1B[1] | COM1A[0]/COM1B[0] | Description |
---|---|---|
0 | 0 | Normal port operation, OC1A/OC1B disconnected. |
0 | 1 | WGM1[3:0] = 14 or 15: Toggle OC1A on compare match, OC1B disconnected (normal port operation). For all other WGM1 settings, normal port operation, OC1A/OC1B disconnected. |
1 | 0 | Clear OC1A/OC1B on compare match, set OC1A/OC1B at BOTTOM (Non-inverting mode) |
1 | 1 | Set OC1A/OC1B on compare match, clear OC1A/OC1B at BOTTOM (Inverting mode) |
- A special case occurs when OCR1A/OCR1B equals TOP and COM1A[1]/COM1B[1] is set. In this case the compare match is ignored, but the set or clear is done at BOTTOM. Refer to Fast PWM Mode for details.
The table below shows the COM1x[1:0] bit functionality when the WGM1[3:0] bits are set to the phase correct or the phase and frequency correct, PWM mode.
COM1A[1]/COM1B[1] | COM1A[0]/COM1B[0] | Description |
---|---|---|
0 | 0 | Normal port operation, OC1A/OC1B disconnected. |
0 | 1 | WGM1[3:0] = 9 or 11: Toggle OC1A on compare match, OC1B disconnected (normal port operation). For all other WGM1 settings, normal port operation, OC1A/OC1B disconnected. |
1 | 0 | Clear OC1A/OC1B on compare match when up-counting. Set OC1A/OC1B on compare match when down-counting. |
1 | 1 | Set OC1A/OC1B on compare match when up-counting. Clear OC1A/OC1B on compare match when down-counting. |
- A special case occurs when OCR1A/OCR1B equals TOP and COM1A[1]/COM1B[1] is set. Refer to Phase Correct PWM Mode for details.
Bits 1:0 – WGM1[1:0] Waveform Generation Mode
Combined with the WGM1[3:2] bits found in the TCCR1B register, these bits control the counting sequence of the counter, the source for maximum (TOP) counter value, and what type of waveform generation to be used. Modes of operation supported by the Timer/Counter unit are; Normal mode (counter), Clear Timer on Compare Match (CTC) mode, and three types of Pulse Width Modulation (PWM) modes. (See Modes of Operation).
Mode |
WGM1[3] |
WGM1[2] (CTC1)(1) |
WGM1[1] (PWM1[1])(1) |
WGM1[0] (PWM1[0])(1) |
Timer/Counter Mode of Operation |
TOP |
Update of OCR1x at |
TOV1 Flag Set on |
---|---|---|---|---|---|---|---|---|
0 | 0 | 0 | 0 | 0 | Normal | 0xFFFF | Immediate | MAX |
1 | 0 | 0 | 0 | 1 | PWM, Phase Correct, 8-bit | 0x00FF | TOP | BOTTOM |
2 | 0 | 0 | 1 | 0 | PWM, Phase Correct, 9-bit | 0x01FF | TOP | BOTTOM |
3 | 0 | 0 | 1 | 1 | PWM, Phase Correct, 10-bit | 0x03FF | TOP | BOTTOM |
4 | 0 | 1 | 0 | 0 | CTC | OCR1A | Immediate | MAX |
5 | 0 | 1 | 0 | 1 | Fast PWM, 8-bit | 0x00FF | BOTTOM | TOP |
6 | 0 | 1 | 1 | 0 | Fast PWM, 9-bit | 0x01FF | BOTTOM | TOP |
7 | 0 | 1 | 1 | 1 | Fast PWM, 10-bit | 0x03FF | BOTTOM | TOP |
8 | 1 | 0 | 0 | 0 | PWM, Phase and Frequency Correct | ICR1 | BOTTOM | BOTTOM |
9 | 1 | 0 | 0 | 1 | PWM, Phase and Frequency Correct | OCR1A | BOTTOM | BOTTOM |
10 | 1 | 0 | 1 | 0 | PWM, Phase Correct | ICR1 | TOP | BOTTOM |
11 | 1 | 0 | 1 | 1 | PWM, Phase Correct | OCR1A | TOP | BOTTOM |
12 | 1 | 1 | 0 | 0 | CTC | ICR1 | Immediate | MAX |
13 | 1 | 1 | 0 | 1 | Reserved | - | - | - |
14 | 1 | 1 | 1 | 0 | Fast PWM | ICR1 | BOTTOM | TOP |
15 | 1 | 1 | 1 | 1 | Fast PWM | OCR1A | BOTTOM | TOP |
- The CTC1 and PWM1[1:0] bit definition names are obsolete. Use the WGM1[3:0] definitions. However, the functionality and location of these bits are compatible with previous versions of the timer.