# Lecture7: ATMega 2650 Datasheet and 16 bit timer

Vikram Iyer

### **Administrative**

- Lab 1 due date extended to 4/25
  - Everyone should have a partner, lab kit, and a speaker
  - Turn in 1 lab report with both partners names on Canvas
  - Reports for this lab can be brief, the goal is to get in the habit of documenting your code and process for future labs
- Programming assignment 2 will be up soon
  - Bit manipulation, more pointer practice, intro to structs
  - Tried to incorporate feedback from assignment 1 and fix bugs
  - Meant to be fairly straightforward so you can focus on Lab 2

### **Administrative**

- Lab 1 due date extended to 4/25
  - Everyone should have a partner, lab kit, and a speaker
  - Turn in 1 lab report with both partners names on Canvas
  - Reports for this lab can be brief, the goal is to get in the habit of documenting your code and process for future labs
- Programming assignment 2 will be up soon
  - Bit manipulation, more pointer practice, intro to structs
  - Tried to incorporate feedback from assignment 1 and fix bugs
  - Meant to be fairly straightforward so you can focus on Lab 2
- Lab 2 is posted, due 5/9
  - Longer than Lab 1, get started early
  - After today we'll have covered material for Part 1 and 2
  - Part 3 material will be in next couple of lectures



### Last time

- MPU6050 demo
  - What is an IMU and how does it work?
  - Reading datasheets
  - Demo of reading and writing registers to control sensor

# Plan for today

- Walk through ATMega datasheet
  - o Point out where to look for documentation in lab 2
- Details of 16 bit timer counter

# Plan for today

- Walk through ATMega datasheet
  - o Point out where to look for documentation in lab 2
- Details of 16 bit timer counter

# **ATMega2650 Datasheet**

Figure 17-1. 16-bit Timer/Counter Block Diagram<sup>(1)</sup>



Figure 17-1. 16-bit Timer/Counter Block Diagram<sup>(1)</sup>

**Block Diagram** 

Key terms:

"TOP" -- user programable

"MAX" -- 0xFFFF (65535)

"**BOTTOM**" -- 0x0000







Figure 17-1. 16-bit Timer/Counter Block Diagram<sup>(1)</sup>

# **16-bit Timer/Counter**

Combinatorial circuit which sets or clears the output pin.

#### Inputs:

- Match
- WGMn3:0 COMnx1:0 bits
- TOP, BOTTOM

#### Actions:

Set, Clear, Toggle



Figure 17-1. 16-bit Timer/Counter Block Diagram<sup>(1)</sup>



Figure 17-1. 16-bit Timer/Counter Block Diagram<sup>(1)</sup>



Figure 17-1. 16-bit Timer/Counter Block Diagram<sup>(1)</sup>



# **Output Compare Unit**



### **Output Compare Unit**



#### **Clock and Pre-scaler**

**Internal** clock = 16Mhz (Period = 62.5ns)

- Can also count external events
- Can divide the clock by 1, 8, 64, 256, or 1024



|   | А        | В          | С             | D              | Е             | F             | G              | Н             | I             |
|---|----------|------------|---------------|----------------|---------------|---------------|----------------|---------------|---------------|
| 1 |          |            |               |                | 16-bit        |               |                | 8-bit         |               |
| 2 |          | Freq (Hz)  | Period (msec) | Max Time (sec) | Min Freq (Hz) | Max Freq (Hz) | Max Time (sec) | Min Freq (Hz) | Max Freq (Hz) |
| 3 | prescale | 16,000,000 | 0.0000625     | 0.0041         | 488.3         | 8,000,000.00  | 0.00002        | 125000.0      | 8,000,000.00  |
| 4 | 8        | 2,000,000  | 0.0005        | 0.0328         | 61.0          | 1,000,000.00  | 0.00013        | 15625.0       | 1,000,000.00  |
| 5 | 64       | 250,000    | 0.004         | 0.2621         | 7.6           | 125,000.00    | 0.00102        | 1953.1        | 125,000.00    |
| 6 | 256      | 62,500     | 0.016         | 1.0486         | 1.9           | 31,250.00     | 0.00410        | 488.3         | 31,250.00     |
| 7 | 1024     | 15,625     | 0.064         | 4.1943         | 0.5           | 7,812.50      | 0.01638        | 122.1         | 7,812.50      |
| 8 |          |            |               |                |               |               |                |               |               |

Max freq = 1/(2\*Period))

Assuming Toggle Mode

**Table 17-2.** Waveform Generation Mode Bit Description<sup>(1)</sup>

| Mode | WGMn3 | WGMn2<br>(CTCn) | WGMn1<br>(PWMn1) | WGMn0<br>(PWMn0) | Timer/Counter<br>Mode of Operation  | ТОР    | Update of<br>OCRnx at | TOVn Flag<br>Set on |
|------|-------|-----------------|------------------|------------------|-------------------------------------|--------|-----------------------|---------------------|
| 0    | 0     | 0               | 0                | 0                | Normal                              | 0xFFFF | Immediate             | MAX                 |
| 1    | 0     | 0               | 0                | 1                | PWM, Phase Correct, 8-bit           | 0x00FF | TOP                   | воттом              |
| 2    | 0     | 0               | 1                | 0                | PWM, Phase Correct, 9-bit           | 0x01FF | TOP                   | воттом              |
| 3    | 0     | 0               | 1                | 1                | PWM, Phase Correct, 10-bit          | 0x03FF | TOP                   | воттом              |
| 4    | 0     | 1               | 0                | 0                | СТС                                 | OCRnA  | Immediate             | MAX                 |
| 5    | 0     | 1               | 0                | 1                | Fast PWM, 8-bit                     | 0x00FF | воттом                | TOP                 |
| 6    | 0     | 1               | 1                | 0                | Fast PWM, 9-bit                     | 0x01FF | воттом                | TOP                 |
| 7    | 0     | 1               | 1                | 1                | Fast PWM, 10-bit                    | 0x03FF | воттом                | TOP                 |
| 8    | 1     | 0               | 0                | 0                | PWM, Phase and Frequency<br>Correct | ICRn   | воттом                | воттом              |
| 9    | 1     | 0               | 0                | 1                | PWM,Phase and Frequency<br>Correct  | OCRnA  | воттом                | воттом              |
| 10   | 1     | 0               | 1                | 0                | PWM, Phase Correct                  | ICRn   | TOP                   | воттом              |
| 11   | 1     | 0               | 1                | 1                | PWM, Phase Correct                  | OCRnA  | TOP                   | воттом              |
| 12   | 1     | 1               | 0                | 0                | CTC                                 | ICRn   | Immediate             | MAX                 |
| 13   | 1     | 1               | 0                | 1                | (Reserved)                          | _      | -                     | _                   |
| 14   | 1     | 1               | 1                | 0                | Fast PWM                            | ICRn   | воттом                | TOP                 |
| 15   | 1     | 1               | 1                | 1                | Fast PWM                            | OCRnA  | воттом                | TOP                 |

Note: 1. The CTCn and PWMn1:0 bit definition names are obsolete. Use the WGMn2:0 definitions. However, the functionality and location of these bits are compatible with previous versions of the timer.

"Normal"

Count up to 0xFFFF (MAX) **Table 17-2.** Waveform Generation Mode Bit Description<sup>(1)</sup>

| Mode | WGMn3 | WGMn2<br>(CTCn) | WGMn1<br>(PWMn1) | WGMn0<br>(PWMn0) | Timer/Counter<br>Mode of Operation  | ТОР    | Update of<br>OCRnx at | TOVn Flag<br>Set on |
|------|-------|-----------------|------------------|------------------|-------------------------------------|--------|-----------------------|---------------------|
| 0    | 0     | 0               | 0                | 0                | Normal                              | 0xFFFF | Immediate             | MAX                 |
| 1    | 0     | 0               | 0                | 1                | PWM, Phase Correct, 8-bit           | 0x00FF | TOP                   | воттом              |
| 2    | 0     | 0               | 1                | 0                | PWM, Phase Correct, 9-bit           | 0x01FF | TOP                   | воттом              |
| 3    | 0     | 0               | 1                | 1                | PWM, Phase Correct, 10-bit          | 0x03FF | TOP                   | воттом              |
| 4    | 0     | 1               | 0                | 0                | СТС                                 | OCRnA  | Immediate             | MAX                 |
| 5    | 0     | 1               | 0                | 1                | Fast PWM, 8-bit                     | 0x00FF | воттом                | TOP                 |
| 6    | 0     | 1               | 1                | 0                | Fast PWM, 9-bit                     | 0x01FF | воттом                | TOP                 |
| 7    | 0     | 1               | 1                | 1                | Fast PWM, 10-bit                    | 0x03FF | воттом                | TOP                 |
| 8    | 1     | 0               | 0                | 0                | PWM, Phase and Frequency<br>Correct | ICRn   | воттом                | воттом              |
| 9    | 1     | 0               | 0                | 1                | PWM,Phase and Frequency<br>Correct  | OCRnA  | воттом                | воттом              |
| 10   | 1     | 0               | 1                | 0                | PWM, Phase Correct                  | ICRn   | TOP                   | BOTTOM              |
| 11   | 1     | 0               | 1                | 1                | PWM, Phase Correct                  | OCRnA  | TOP                   | BOTTOM              |
| 12   | 1     | 1               | 0                | 0                | СТС                                 | ICRn   | Immediate             | MAX                 |
| 13   | 1     | 1               | 0                | 1                | (Reserved)                          | -      | -                     | _                   |
| 14   | 1     | 1               | 1                | 0                | Fast PWM                            | ICRn   | воттом                | TOP                 |
| 15   | 1     | 1               | 1                | 1                | Fast PWM                            | OCRnA  | воттом                | TOP                 |

Note: 1. The CTCn and PWMn1:0 bit definition names are obsolete. Use the WGMn2:0 definitions. However, the functional ity and location of these bits are compatible with previous versions of the timer.

CTC (Clear Timer on Compare Match) **Table 17-2.** Waveform Generation Mode Bit Description<sup>(1)</sup>

| Mode | WGMn3 | WGMn2<br>(CTCn) | WGMn1<br>(PWMn1) | WGMn0<br>(PWMn0) | Timer/Counter<br>Mode of Operation  | ТОР    | Update of<br>OCRnx at | TOVn Flag<br>Set on |
|------|-------|-----------------|------------------|------------------|-------------------------------------|--------|-----------------------|---------------------|
| 0    | 0     | 0               | 0                | 0                | Normal                              | 0xFFFF | Immediate             | MAX                 |
| 1    | 0     | 0               | 0                | 1                | PWM, Phase Correct, 8-bit           | 0x00FF | TOP                   | воттом              |
| 2    | 0     | 0               | 1                | 0                | PWM, Phase Correct, 9-bit           | 0x01FF | TOP                   | воттом              |
| 3    | 0     | 0               | 1                | 1                | PWM, Phase Correct, 10-bit          | 0x03FF | TOP                   | воттом              |
| 4    | 0     | 1               | 0                | 0                | стс                                 | OCRnA  | Immediate             | MAX                 |
| 5    | 0     | 1               | 0                | 1                | Fast PWM, 8-bit                     | 0x00FF | воттом                | TOP                 |
| 6    | 0     | 1               | 1                | 0                | Fast PWM, 9-bit                     | 0x01FF | воттом                | TOP                 |
| 7    | 0     | 1               | 1                | 1                | Fast PWM, 10-bit                    | 0x03FF | воттом                | TOP                 |
| 8    | 1     | 0               | 0                | 0                | PWM, Phase and Frequency<br>Correct | ICRn   | воттом                | воттом              |
| 9    | 1     | 0               | 0                | 1                | PWM,Phase and Frequency<br>Correct  | OCRnA  | воттом                | воттом              |
| 10   | 1     | 0               | 1                | 0                | PWM, Phase Correct                  | ICRn   | TOP                   | воттом              |
| 11   | 1     | 0               | 1                | 1                | PWM, Phase Correct                  | OCRnA  | TOP                   | воттом              |
| 12   | 1     | 1               | 0                | 0                | СТС                                 | ICRn   | Immediate             | MAX                 |
| 13   | 1     | 1               | 0                | 1                | (Reserved)                          | -      | -                     | -                   |
| 14   | 1     | 1               | 1                | 0                | Fast PWM                            | ICRn   | воттом                | TOP                 |
| 15   | 1     | 1               | 1                | 1                | Fast PWM                            | OCRnA  | воттом                | TOP                 |

Note: 1. The CTCn and PWMn1:0 bit definition names are obsolete. Use the WGMn2:0 definitions. However, the functionality and location of these bits are compatible with previous versions of the timer.

CTC
(Clear Timer on Compare Match)
Count up to

OCRnA (user value)

Set, Clear, or

Set, Clear, or Toggle Output on match (COMnA1:0) Table 17-2. Waveform Generation Mode Bit Description<sup>(1)</sup>

| Mode | WGMn3 | WGMn2<br>(CTCn) | WGMn1<br>(PWMn1) | WGMn0<br>(PWMn0) | Timer/Counter<br>Mode of Operation  | ТОР    | Update of<br>OCRnx at | TOVn Fla<br>Set on |
|------|-------|-----------------|------------------|------------------|-------------------------------------|--------|-----------------------|--------------------|
| 0    | 0     | 0               | 0                | 0                | Normal                              | 0xFFFF | Immediate             | MAX                |
| 1    | 0     | 0               | 0                | 1                | PWM, Phase Correct, 8-bit           | 0x00FF | TOP                   | вотто              |
| 2    | 0     | 0               | 1                | 0                | PWM, Phase Correct, 9-bit           | 0x01FF | TOP                   | вотто              |
| 3    | 0     | 0               | 1                | 1                | PWM, Phase Correct, 10-bit          | 0x03FF | TOP                   | вотто              |
| 4    | 0     | 1               | 0                | 0                | СТС                                 | OCRnA  | Immediate             | MAX                |
| 5    | 0     | 1               | 0                | 1                | Fast PWM, 8-bit                     | 0x00FF | воттом                | TOP                |
| 6    | 0     | 1               | 1                | 0                | Fast PWM, 9-bit                     | 0x01FF | воттом                | TOP                |
| 7    | 0     | 1               | 1                | 1                | Fast PWM, 10-bit                    | 0x03FF | воттом                | TOP                |
| 8    | 1     | 0               | 0                | 0                | PWM, Phase and Frequency<br>Correct | ICRn   | воттом                | вотто              |
| 9    | 1     | 0               | 0                | 1                | PWM,Phase and Frequency<br>Correct  | OCRnA  | воттом                | вотто              |
| 10   | 1     | 0               | 1                | 0                | PWM, Phase Correct                  | ICRn   | TOP                   | вотто              |
| 11   | 1     | 0               | 1                | 1                | PWM, Phase Correct                  | OCRnA  | TOP                   | вотто              |
| 12   | 1     | 1               | 0                | 0                | СТС                                 | ICRn   | Immediate             | MAX                |
| 13   | 1     | 1               | 0                | 1                | (Reserved)                          | _      | -                     | -                  |
| 14   | 1     | 1               | 1                | 0                | Fast PWM                            | ICRn   | воттом                | TOP                |
| 15   | 1     | 1               | 1                | 1                | Fast PWM                            | OCRnA  | воттом                | TOP                |

Note: 1. The CTCn and PWMn1:0 bit definition names are obsolete. Use the WGMn2:0 definitions. However, the functionality and location of these bits are compatible with previous versions of the timer.

Figure 17-6. CTC Mode, Timing Diagram





Figure 17-6. CTC Mode, Timing Diagram



Figure 17-6. CTC Mode, Timing Diagram



Figure 17-6. CTC Mode, Timing Diagram



Figure 17-6. CTC Mode, Timing Diagram





Figure 17-6. CTC Mode, Timing Diagram

Output Period due to "Toggle" mode: your frequency is divided by 2.



"Fast PWM"

Count up to ICRn/OCRnA (MAX), reset to 0x000

Clear output at compare match

**Table 17-2.** Waveform Generation Mode Bit Description<sup>(1)</sup>

WOMEO WOMEN WOMEO

| Mode | WGMn3 | WGMn2<br>(CTCn) | WGMn1<br>(PWMn1) | WGMn0<br>(PWMn0) | Timer/Counter<br>Mode of Operation  | ТОР    | Update of<br>OCRnx at | TOVn Flag<br>Set on |
|------|-------|-----------------|------------------|------------------|-------------------------------------|--------|-----------------------|---------------------|
| 0    | 0     | 0               | 0                | 0                | Normal                              | 0xFFFF | Immediate             | MAX                 |
| 1    | 0     | 0               | 0                | 1                | PWM, Phase Correct, 8-bit           | 0x00FF | TOP                   | воттом              |
| 2    | 0     | 0               | 1                | 0                | PWM, Phase Correct, 9-bit           | 0x01FF | TOP                   | воттом              |
| 3    | 0     | 0               | 1                | 1                | PWM, Phase Correct, 10-bit          | 0x03FF | TOP                   | воттом              |
| 4    | 0     | 1               | 0                | 0                | СТС                                 | OCRnA  | Immediate             | MAX                 |
| 5    | 0     | 1               | 0                | 1                | Fast PWM, 8-bit                     | 0x00FF | воттом                | TOP                 |
| 6    | 0     | 1               | 1                | 0                | Fast PWM, 9-bit                     | 0x01FF | воттом                | TOP                 |
| 7    | 0     | 1               | 1                | 1                | Fast PWM, 10-bit                    | 0x03FF | воттом                | TOP                 |
| 8    | 1     | 0               | 0                | 0                | PWM, Phase and Frequency<br>Correct | ICRn   | воттом                | воттом              |
| 9    | 1     | 0               | 0                | 1                | PWM,Phase and Frequency<br>Correct  | OCRnA  | воттом                | воттом              |
| 10   | 1     | 0               | 1                | 0                | PWM, Phase Correct                  | ICRn   | TOP                   | воттом              |
| 11   | 1     | 0               | 1                | 1                | PWM, Phase Correct                  | OCRnA  | TOP                   | воттом              |
| 12   | 1     | 1               | 0                | 0                | СТС                                 | ICRn   | Immediate             | MAX                 |
| 13   | 1     | 1               | 0                | 1                | (Reserved)                          | _      | -                     | _                   |
| 14   | 1     | 1               | 1                | 0                | Fast PWM                            | ICRn   | воттом                | TOP                 |
| 15   | 1     | 1               | 1                | 1                | Fast PWM                            | OCRnA  | воттом                | TOP                 |

Note: 1. The CTCn and PWMn1:0 bit definition names are obsolete. Use the WGMn2:0 definitions. However, the function ity and location of these bits are compatible with previous versions of the timer.

# **Duty Cycle (PWM) Control**

- PWM = Pulse Width Modulation
- Switch on and off "quickly"
- "Quickly" means faster than process can react.
- Effective output is time average of on-off signal.
- For this application replace "5V" with power for any device.



Figure 17-7. Fast PWM Mode, Timing Diagram



Figure 17-7. Fast PWM Mode, Timing Diagram



Figure 17-7. Fast PWM Mode, Timing Diagram



Figure 17-7. Fast PWM Mode, Timing Diagram



Figure 17-7. Fast PWM Mode, Timing Diagram



## **Programming Steps: Setup**

- 1) Enable Timer (Arduino automatically does it already)
  - (write zero to a **Power Reduction Register** bit. "1" turns Timer/Counter off) (p55,56)
- 1) Figure out what clock frequency (prescaler setting) you want to use.
- 2) Select a Mode using the 3 control registers (TCCRnA, TCCRnB, TCCRnC)
- 3) set/clear Waveform Generation Mode bits:
  - WGMn0 --- WGMn3 (two different registers)
    - a) TCCRnA: Compare Mode and partial WG Modes
    - b) TCCRnB: partial WG Modes and Clock/Prescaler select.
    - c) "n" is your counter number.
- 4) Set your ISR and enable interrupts. (LATER)

# **Programming Steps: Setup**

- 5) Figure out the compare count you need and set it in OCRnA
- 6) Enable or disable timer hardware output with **DDRx** (data direction register for the output pin).