



**UNIVERSITÄT PADERBORN**  
*Die Universität der Informationsgesellschaft*

Project Group ‘Racing Car IT’  
AVR Timer Configuration  
Report of manual tests

Peer Adelt

University of Paderborn  
Summer Semester 2012



**Advisers:**

Prof. Dr. Marco Platzner, Tobias Beisel, Sebastian Meisner, Lars Schäfers

## Contents

|          |                                                                  |           |
|----------|------------------------------------------------------------------|-----------|
| <b>1</b> | <b>Introduction</b>                                              | <b>3</b>  |
| <b>2</b> | <b>Oscilloscope tests</b>                                        | <b>4</b>  |
| 2.1      | Normal / Overflow mode . . . . .                                 | 4         |
| 2.1.1    | 8bit timer 0, prescale 1 . . . . .                               | 4         |
| 2.1.2    | 8bit timer 2, prescale 64 . . . . .                              | 5         |
| 2.1.3    | 16bit timer 1, prescale 8 . . . . .                              | 6         |
| 2.1.4    | 16bit timer 3, prescale 1 . . . . .                              | 6         |
| 2.2      | CTC mode . . . . .                                               | 8         |
| 2.2.1    | 8bit timer 0, prescale 1, desired period: 12.4 $\mu$ s . . . . . | 8         |
| 2.2.2    | 8bit timer 2, prescale 64, desired period: 1ms . . . . .         | 9         |
| 2.2.3    | 16bit timer 1, prescale 256, desired period: 1s . . . . .        | 9         |
| 2.2.4    | 16bit timer 3 . . . . .                                          | 10        |
| 2.3      | Fast PWM mode . . . . .                                          | 11        |
| 2.3.1    | 8bit timer 0, prescale 1, base rate 32 $\mu$ s . . . . .         | 11        |
| 2.3.2    | 8bit timer 2, prescale 64, base rate 2048 $\mu$ s . . . . .      | 12        |
| 2.3.3    | 16bit timer 1, prescale 1, base rate 48 $\mu$ s . . . . .        | 13        |
| 2.3.4    | 16bit timer 3 . . . . .                                          | 14        |
| 2.4      | Phase correct PWM mode . . . . .                                 | 15        |
| 2.4.1    | 8bit timer 0, prescale 1024, base rate 65280 $\mu$ s . . . . .   | 15        |
| 2.4.2    | 8bit timer 2, prescale 8, base rate 510 $\mu$ s . . . . .        | 16        |
| 2.4.3    | 16bit timer 1, prescale 1, base rate 50 $\mu$ s . . . . .        | 17        |
| 2.4.4    | 16bit timer 3 . . . . .                                          | 18        |
| <b>3</b> | <b>Conclusions</b>                                               | <b>19</b> |

## 1 Introduction

This document describes the manual tests that have been performed to ensure correct operation of the AVR Timer Configuration Editor and the Code Generator.



It is assumed, that the reader is familiar with the hardware details of the timer modules of the AT90CAN microprocessor family. This document will not explain, what they can do or how they are configured. Please refer to the processor's datasheet for further details.

All tests were performed on the DVK90CAN1 board, which is equipped with the Atmel AVR processor AT90CAN128. The processor was clocked by an 8MHz crystal during all tests. The DVK90CAN1 was stacked on top of the STK500 development board, which acts as a port extender in the test scenarios described below. Since the DVK90CAN1 does not provide access to all processor pins, especially not all pins driven by the waveform generation modes of the timer modules, the use of the STK500 was mandatory.



The STK500 exposed many, but not all pins of the AT90CAN128 microprocessor. The Port E of the processor, which is the one driven by Timer 3, was not accessible at all. Tests for Timer 3 were performed the same way as for Timer 1. The results have been verified with the oscilloscope with its probe held down to the processor pin directly. In this situation though, it was impossible to take photographs of the measurement device. Nevertheless, all tests of Timer 3 passed equally well as those of Timer 1.

## 2 Oscilloscope tests

All tests were performed with an analogous 60 MHz oscilloscope (Model: Oscilloscope 668, Brand: Voltcraft).

### 2.1 Normal / Overflow mode

In normal mode, the timer counts from 0 to MAX and then restarts. This happens in an endless loop. Therefore, the overflow frequency depends on the MAX value as well as the CPU frequency multiplied with the prescale divisor. Since no waveform generation takes place in Overflow mode, it needs to be simulated with software. All tests of this mode take place with interrupts enabled. The overflow interrupt routine will toggle the state of an output pin, which is measured with an oscilloscope to verify the toggle frequency. (See example code below.)

```
1 #include <avr/interrupt.h>
2
3 ...
4
5 ISR(TIMER0_OVF_vect)
6 {
7     // Toggle PB2:
8     PORTB ^= (1<<2);
9 }
```

---

#### 2.1.1 8bit timer 0, prescale 1

|                          |                                                                                                  |
|--------------------------|--------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_overflow_t0                                                                                 |
| <b>Mode:</b>             | Normal / Overflow                                                                                |
| <b>Timer:</b>            | 0 (8bit)                                                                                         |
| <b>Prescale:</b>         | 1                                                                                                |
| <b>Overflow period:</b>  | 32 µs<br>(Time to overflow: $\frac{\text{Prescale} * \text{MAX}}{\text{Frequency}}$ )            |
| <b>Test description:</b> | Output pin is toggled from overflow ISR. The toggle frequency is validated with an oscilloscope. |



Figure 1:  $32\mu s$  overflow rate verified

### 2.1.2 8bit timer 2, prescale 64

|                          |                                                                                                  |
|--------------------------|--------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_overflow_t2                                                                                 |
| <b>Mode:</b>             | Normal / Overflow                                                                                |
| <b>Timer:</b>            | 2 (8bit)                                                                                         |
| <b>Prescale:</b>         | 64                                                                                               |
| <b>Overflow period:</b>  | $2048 \mu s$<br>(Time to overflow: $\frac{\text{Prescale} * \text{MAX}}{\text{Frequency}}$ )     |
| <b>Test description:</b> | Output pin is toggled from overflow ISR. The toggle frequency is validated with an oscilloscope. |



Figure 2:  $2048\mu s$  overflow rate verified

### 2.1.3 16bit timer 1, prescale 8

|                          |                                                                                                  |
|--------------------------|--------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_overflow_t1                                                                                 |
| <b>Mode:</b>             | Normal / Overflow                                                                                |
| <b>Timer:</b>            | 1 (16bit)                                                                                        |
| <b>Prescale:</b>         | 8                                                                                                |
| <b>Overflow period:</b>  | 65536 $\mu$ s<br>(Time to overflow: $\frac{\text{Prescale} * \text{MAX}}{\text{Frequency}}$ )    |
| <b>Test description:</b> | Output pin is toggled from overflow ISR. The toggle frequency is validated with an oscilloscope. |



Figure 3:  $65536\mu\text{s}$  overflow rate verified

### 2.1.4 16bit timer 3, prescale 1

|                          |                                                                                                  |
|--------------------------|--------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_overflow_t3                                                                                 |
| <b>Mode:</b>             | Normal / Overflow                                                                                |
| <b>Timer:</b>            | 3 (16bit)                                                                                        |
| <b>Prescale:</b>         | 1                                                                                                |
| <b>Overflow period:</b>  | 8192 $\mu$ s<br>(Time to overflow: $\frac{\text{Prescale} * \text{MAX}}{\text{Frequency}}$ )     |
| <b>Test description:</b> | Output pin is toggled from overflow ISR. The toggle frequency is validated with an oscilloscope. |



Figure 4:  $8192\mu\text{s}$  overflow rate verified

## 2.2 CTC mode

In CTC mode, the timer runs from 0 to a user defined TOP value (instead of MAX, like in Overflow mode). This happens in an endless loop. Therefore, the compare match frequency depends on the TOP value and CPU frequency multiplied with the prescale divisor. Like in the overflow tests, an output pin will be toggled. The toggle frequency will be validated with an oscilloscope.

### 2.2.1 8bit timer 0, prescale 1, desired period: 12.4 $\mu$ s

|                          |                                                                                                                         |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_ctc_t0                                                                                                             |
| <b>Mode:</b>             | CTC                                                                                                                     |
| <b>Timer:</b>            | 0 (8bit)                                                                                                                |
| <b>Prescale:</b>         | 1                                                                                                                       |
| <b>Top register:</b>     | OCR0A                                                                                                                   |
| <b>Top period:</b>       | 12.375 $\mu$ s (99 ticks)<br>(desired value: 12.4 $\mu$ s,<br>number of timer ticks will get quantized from 99.2 to 99) |
| <b>Test description:</b> | Output pin OC0A (PB7) is toggled by timer hardware.<br>The toggle frequency is validated with an oscilloscope.          |



Figure 5:  $12.375\mu s$  toggle rate verified

### 2.2.2 8bit timer 2, prescale 64, desired period: 1ms

|                          |                                                                                                             |
|--------------------------|-------------------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_ctc_t2                                                                                                 |
| <b>Mode:</b>             | CTC                                                                                                         |
| <b>Timer:</b>            | 2 (8bit)                                                                                                    |
| <b>Prescale:</b>         | 64                                                                                                          |
| <b>Top register:</b>     | OCR2A                                                                                                       |
| <b>Top period:</b>       | 1ms (125 ticks)                                                                                             |
| <b>Test description:</b> | Output pin OC2A (PB4) is toggled by timer hardware. The toggle frequency is validated with an oscilloscope. |



Figure 6: 1ms toggle rate verified

### 2.2.3 16bit timer 1, prescale 256, desired period: 1s

|                          |                                                                                                             |
|--------------------------|-------------------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_ctc_t1                                                                                                 |
| <b>Mode:</b>             | CTC                                                                                                         |
| <b>Timer:</b>            | 1 (16bit)                                                                                                   |
| <b>Prescale:</b>         | 256                                                                                                         |
| <b>Top register:</b>     | OCR1A                                                                                                       |
| <b>Top period:</b>       | 1s (31250 ticks)                                                                                            |
| <b>Test description:</b> | Output pin OC1B (PB6) is toggled by timer hardware. The toggle frequency is validated with an oscilloscope. |



Figure 7: 1s toggle rate verified

#### 2.2.4 16bit timer 3

The same test procedure as for timer 1 was run. Although now photographs have been taken, the test has passed (see section 1 for details).

## 2.3 Fast PWM mode

In Fast PWM mode, the timer runs from 0 to TOP (or MAX, when using 8bit Timers). This happens in an endless loop. Therefore, the PWM base rate depends on the TOP value and CPU frequency multiplied with the prescale divisor. The output pins can be set up to be either set on TOP and cleared on compare match (normal PWM) or cleared on TOP and set on compare match (inverted PWM). The generated PWM waveforms are validated with an oscilloscope.

### 2.3.1 8bit timer 0, prescale 1, base rate 32 $\mu$ s

|                          |                                                                                                                                                                     |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_fpwm_t0                                                                                                                                                        |
| <b>Mode:</b>             | Fast PWM                                                                                                                                                            |
| <b>Timer:</b>            | 0 (8bit)                                                                                                                                                            |
| <b>Prescale:</b>         | 1                                                                                                                                                                   |
| <b>Top register:</b>     | N/A (fixed value 255)                                                                                                                                               |
| <b>Top period:</b>       | 32 $\mu$ s (256 ticks)                                                                                                                                              |
| <b>Duty cycle A:</b>     | 10 $\mu$ s (80 ticks)                                                                                                                                               |
| <b>Duty cycle B:</b>     | N/A                                                                                                                                                                 |
| <b>Duty cycle C:</b>     | N/A                                                                                                                                                                 |
| <b>Test description:</b> | Output pin OC0A (PB7) is controlled by timer hardware to output a non-inverted 10 $\mu$ s/32 $\mu$ s PWM signal. This PWM signal is validated with an oscilloscope. |



Figure 8: 32  $\mu$ s base rate and 10  $\mu$ s duty cycle verified

### 2.3.2 8bit timer 2, prescale 64, base rate 2048 µs

|                          |                                                                                                                                                                    |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_fpwm_t2                                                                                                                                                       |
| <b>Mode:</b>             | Fast PWM                                                                                                                                                           |
| <b>Timer:</b>            | 2 (8bit)                                                                                                                                                           |
| <b>Prescale:</b>         | 64                                                                                                                                                                 |
| <b>Top register:</b>     | N/A (fixed value 255)                                                                                                                                              |
| <b>Top period:</b>       | 2048 µs (256 ticks)                                                                                                                                                |
| <b>Duty cycle A:</b>     | 304 µs (38 ticks)<br>(desired value: 300 µs,<br>number of timer ticks will get quantized from 37.5 to 38)                                                          |
| <b>Duty cycle B:</b>     | N/A                                                                                                                                                                |
| <b>Duty cycle C:</b>     | N/A                                                                                                                                                                |
| <b>Test description:</b> | Output pin OC2A (PB4) is controlled by timer hardware<br>to output a non-inverted 304 µs/2048 µs PWM signal.<br>This PWM signal is validated with an oscilloscope. |



Figure 9: 2048  $\mu$ s base rate and 304  $\mu$ s duty cycle verified

### 2.3.3 16bit timer 1, prescale 1, base rate 48 $\mu$ s

|                          |                                                                                                                                                                                                  |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_fpwm_t1                                                                                                                                                                                     |
| <b>Mode:</b>             | Fast PWM                                                                                                                                                                                         |
| <b>Timer:</b>            | 1 (16bit)                                                                                                                                                                                        |
| <b>Prescale:</b>         | 1                                                                                                                                                                                                |
| <b>Top register:</b>     | ICR1                                                                                                                                                                                             |
| <b>Top period:</b>       | 48 µs (384 ticks)                                                                                                                                                                                |
| <b>Duty cycle A:</b>     | 43.25 µs (346 ticks)<br>(desired value: 43.2 µs,<br>number of timer ticks will get quantized from 345.6 to<br>346)                                                                               |
| <b>Duty cycle B:</b>     | 38.375 µs (307 ticks)<br>(desired value: 38.4 µs,<br>number of timer ticks will get quantized from 307.2 to<br>307)                                                                              |
| <b>Duty cycle C:</b>     | 33.625 µs (269 ticks)<br>(desired value: 33.6 µs,<br>number of timer ticks will get quantized from 268.8 to<br>269)                                                                              |
| <b>Test description:</b> | Output pins OC1A (PB5), OC1B (PB6) and OC1C (PB7) are controlled by timer hardware to output the non-inverted PWM signals described above. These PWM signals are validated with an oscilloscope. |



Figure 10: 48  $\mu$ s base rate and 43.25  $\mu$ s duty cycle verified



Figure 11: 48  $\mu s$  base rate and 38.375  $\mu s$  duty cycle verified



Figure 12: 48  $\mu s$  base rate and 33.625  $\mu s$  duty cycle verified

### 2.3.4 16bit timer 3

The same test procedure as for timer 1 was run. Although now photographs have been taken, the test has passed (see section 1 for details).

## 2.4 Phase correct PWM mode

In Phase correct PWM mode, the timer runs from 0 to TOP (or MAX, when using 8bit Timers) and then counts down to 0 again. This happens in an endless loop. Therefore, the PWM base rate depends on the TOP value and CPU frequency multiplied with the prescale divisor. The output pins can be set up for normal and inverted PWM. The generated PWM waveforms are validated with an oscilloscope.

### 2.4.1 8bit timer 0, prescale 1024, base rate 65280 $\mu$ s

|                          |                                                                                                                                                    |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_pcpwm_t0                                                                                                                                      |
| <b>Mode:</b>             | Phase correct PWM                                                                                                                                  |
| <b>Timer:</b>            | 0 (8bit)                                                                                                                                           |
| <b>Prescale:</b>         | 1024                                                                                                                                               |
| <b>Top register:</b>     | N/A (fixed value 255)                                                                                                                              |
| <b>Top period:</b>       | 65280 $\mu$ s (256 ticks)                                                                                                                          |
| <b>Duty cycle A:</b>     | 1280 $\mu$ s (5 ticks)                                                                                                                             |
| <b>Duty cycle B:</b>     | N/A                                                                                                                                                |
| <b>Duty cycle C:</b>     | N/A                                                                                                                                                |
| <b>Test description:</b> | Output pin OC0A (PB7) is controlled by timer hardware to output output inverted PWM. The generated PWM waveform is validated with an oscilloscope. |



Figure 13: 65280  $\mu$ s base rate and 1280  $\mu$ s duty cycle verified

### 2.4.2 8bit timer 2, prescale 8, base rate 510 $\mu$ s

|                          |                                                                                                                                                 |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_pcpwm_t2                                                                                                                                   |
| <b>Mode:</b>             | Phase correct PWM                                                                                                                               |
| <b>Timer:</b>            | 2 (8bit)                                                                                                                                        |
| <b>Prescale:</b>         | 8                                                                                                                                               |
| <b>Top register:</b>     | N/A (fixed value 255)                                                                                                                           |
| <b>Top period:</b>       | 510 $\mu$ s (256 ticks)                                                                                                                         |
| <b>Duty cycle A:</b>     | 64 $\mu$ s (32 ticks)                                                                                                                           |
| <b>Duty cycle B:</b>     | N/A                                                                                                                                             |
| <b>Duty cycle C:</b>     | N/A                                                                                                                                             |
| <b>Test description:</b> | Output pin OC2A (PB4) is controlled by timer hardware to output non-inverted PWM. The generated PWM waveform is validated with an oscilloscope. |



Figure 14: 510  $\mu$ s base rate and 64  $\mu$ s duty cycle verified

### 2.4.3 16bit timer 1, prescale 1, base rate 50 $\mu$ s

|                          |                                                                                                                                                                                                                                                             |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>Scenario:</b>         | test_pcpwm_t1                                                                                                                                                                                                                                               |
| <b>Mode:</b>             | Phase correct PWM                                                                                                                                                                                                                                           |
| <b>Timer:</b>            | 1 (16bit)                                                                                                                                                                                                                                                   |
| <b>Prescale:</b>         | 1                                                                                                                                                                                                                                                           |
| <b>Top register:</b>     | ICR1                                                                                                                                                                                                                                                        |
| <b>Top period:</b>       | 50 $\mu$ s (200 ticks)                                                                                                                                                                                                                                      |
| <b>Duty cycle A:</b>     | 48 $\mu$ s (192 ticks)                                                                                                                                                                                                                                      |
| <b>Duty cycle B:</b>     | 42 $\mu$ s (168 ticks)                                                                                                                                                                                                                                      |
| <b>Duty cycle C:</b>     | 36 $\mu$ s (144 ticks)                                                                                                                                                                                                                                      |
| <b>Test description:</b> | Output pins OC1A (PE5), OC1B (PE6) and OC1C (PE7) are controlled by timer hardware to output the PWM signals described above. OC1A and OC1B output inverted PWM, while OC1C outputs non-inverted PWM. These PWM signals are validated with an oscilloscope. |



Figure 15: 50  $\mu$ s base rate and 48  $\mu$ s duty cycle verified



Figure 16: 50  $\mu$ s base rate and 42  $\mu$ s duty cycle verified



Figure 17: 50  $\mu$ s base rate and 36  $\mu$ s duty cycle verified

#### 2.4.4 16bit timer 3

The same test procedure as for timer 1 was run. Although no photographs have been taken, the test has passed (see section 1 for details).

### **3 Conclusions**

With the manual oscilloscope tests it has been shown, that all timer modules work as expected in any supported mode of operation. The test values were chosen randomly to ensure a wide area of test cases being covered.

The measurement accuracy of the oscilloscope used for the tests was sufficiently high to prove, that the value calculation for processor registers as well as the quantization of time periods into register values works as expected.

