

# **CSE331: Microprocessor Interfacing and Embedded Systems**

**Lecture#17: General Purpose Timer (Chapter#15)**  
Spring, 2025

Courtesy: Mohammad A. Qayum, Ph.D.  
ECE, NSU, Dhaka, Bangladesh

# Timer

---

- ▶ Free-run counter (independent of processor)
- ▶ Functions
  - ▶ Input capture
  - ▶ Output compare
  - ▶ Pulse-width modulation (PWM) generation
  - ▶ One-pulse mode output

# Timer: Clock



$$f_{CK\_CNT} = \frac{f_{CL\_PSC}}{PSC + 1}$$

# Timer: Output



# Timer: Input Capture



# Multi-Channel Outputs



# Output Compare



| Output Compare Mode (OCM) | Timer Output (OCREF)      |
|---------------------------|---------------------------|
| 000                       | Frozen                    |
| 001                       | High if CNT == CCR        |
| 010                       | Low if CNT == CCR         |
| 011                       | Toggle if CNT == CCR      |
| 100                       | Forced low (always low)   |
| 101                       | Forced high (always high) |

# PWM Mode



| Mode                              | Counter < Reference | Counter $\geq$ Reference |
|-----------------------------------|---------------------|--------------------------|
| <b>PWM mode 1<br/>(Low True)</b>  | Active              | Inactive                 |
| <b>PWM mode 2<br/>(High True)</b> | Inactive            | Active                   |

# Edge-aligned Mode (Up-counting)

ARR = 6, RCR = 0



$$\begin{aligned}\text{Period} &= (1 + \text{ARR}) * \text{Clock Period} \\ &= 7 * \text{Clock Period}\end{aligned}$$

# Edge-aligned Mode (down-counting)

ARR = 6, RCR = 0



$$\begin{aligned}\text{Period} &= (1 + \text{ARR}) * \text{Clock Period} \\ &= 7 * \text{Clock Period}\end{aligned}$$

# Center-aligned Mode

ARR = 6, RCR = 0



$$\begin{aligned}\text{Period} &= 2 * \text{ARR} * \text{Clock} \\ \text{Period} &= 12 * \text{Clock Period}\end{aligned}$$

# PWM Mode 1 (Low-True)

Mode I

Timer Output =  $\begin{cases} \text{High if counter} < \text{CCR} \\ \text{Low if counter} \geq \text{CCR} \end{cases}$

Upcounting mode, ARR = 6, CCR = 3, RCR = 0



$$\text{Duty Cycle} = \frac{\text{CCR}}{\text{ARR} + 1} = \frac{3}{7}$$

$$\begin{aligned} \text{Period} &= (1 + \text{ARR}) * \text{Clock Period} \\ &= 7 * \text{Clock Period} \end{aligned}$$

# PWM Mode 2 (High-True)

Mode 2

Timer Output =  $\begin{cases} \text{Low if counter} < \text{CCR} \\ \text{High if counter} \geq \text{CCR} \end{cases}$

Upcounting mode, ARR = 6, CCR = 3, RCR = 0



Duty Cycle = 1

$$\frac{\text{CCR}}{\text{ARR} + 1}$$

$$= \frac{4}{7}$$

Period =  $(1 + \text{ARR}) * \text{Clock}$

Period

$$= 7 * \text{Clock Period}$$

# PWM Mode 2 (High-True)

Mode 2

Timer Output =

$\begin{cases} \text{Low if counter} < \text{CCR} \\ \text{High if counter} \geq \text{CCR} \end{cases}$

Upcounting mode, ARR = 6, CCR = 5, RCR = 0



$$\text{Duty Cycle} = 1 - \frac{\text{CCR}}{\text{ARR} + 1} = \frac{2}{7}$$

$$\begin{aligned} \text{Period} &= (1 + \text{ARR}) * \text{Clock Period} \\ &= 7 * \text{Clock Period} \end{aligned}$$

# PWM Mode 2 (High-True)

Mode 2

Timer Output =  $\begin{cases} \text{Low if counter} < \text{CCR} \\ \text{High if counter} \geq \text{CCR} \end{cases}$

Center-aligned mode, ARR = 6, CCR = 3, RCR = 0



$$\text{Duty Cycle} = 1 - \frac{\text{CCR}}{\text{ARR}}$$
$$= \frac{1}{2}$$

$$\text{Period} = 2 * \text{ARR} * \text{Clock Period}$$
$$= 12 * \text{Clock Period}$$

# PWM Mode 2 (High-True)

Mode 2

Timer Output =  $\begin{cases} \text{Low if counter} < \text{CCR} \\ \text{High if counter} \geq \text{CCR} \end{cases}$

Center-aligned mode, ARR = 6, CCR = 1, RCR = 0



$$\begin{aligned}\text{Duty Cycle} &= 1 - \frac{\text{CCR}}{\text{ARR}} \\ &= 1 - \frac{1}{6} \\ &= \frac{5}{6}\end{aligned}$$

$$\begin{aligned}\text{Period} &= 2 * \text{ARR} * \text{Clock Period} \\ &= 12 * \text{Clock Period}\end{aligned}$$

# Input Capture

- ▶ Monitor both rising and falling edge



# Input Capture

- ▶ Monitor only rising edges or only falling edge



# Input Capture



# Input Filtering



# Input Capture Diagram



# Ultrasonic Distance Sensor

---



$$Distance = \frac{Round\ Trip\ Time \times Speed\ of\ Sound}{2}$$

$$= \frac{Round\ Trip\ Time(\mu s) \times 10^{-6} \times 340m/s}{2}$$

$$= \frac{Round\ Trip\ Time(\mu s)}{58}$$

# Ultrasonic Distance Sensor



The echo pulse width corresponds to round-trip time.

$$\text{Distance (cm)} = \frac{\text{Pulse Width} (\mu\text{s})}{58}$$

or

$$\text{Distance (inch)} = \frac{\text{Pulse Width} (\mu\text{s})}{148}$$



If pulse width is 38ms,  
no obstacle is detected.

The sensor can measure a distance between  $2\text{ cm}$  and  $400\text{ cm}$ , with a resolution of  $0.3\text{ cm}$ , and the corresponding echo pulse width is between  $150\text{ }\mu\text{s}$  and  $25\text{ ms}$ . When the sensor detects no object, the echo pulse width is  $38\text{ ms}$ .



Figure 15-29. Trigger and echo signals

# Ultrasonic Distance Sensor



$$\text{Timer 1 Counter Clock} = \frac{\text{Timer 1 Input Clock}}{1 + \text{Prescaler}} = \frac{16 \text{ MHz}}{1 + 159} = 0.1 \text{ MHz}$$

$$\text{PWM Period} = (1 + ARR) \times \text{Counter Clock Period} = (1 + 0xFFFF) \frac{1}{0.1 \text{ MHz}} = 0.655 \text{ s}$$

$$\text{PWM pulse width} = CCR \times \text{Counter Clock Period} = 1 \times \frac{1}{0.1 \text{ MHz}} = 10 \mu s$$



**Figure 15-31. Overflow occurs between two capture events**

Thus, we need a variable (named *overflow* in the following code) that counts the number of overflows within one pulse. The time span can be calculated as follows:

$$\text{Time Span } (\mu\text{s}) = (CCR_{New} - CCR_{Last}) + 65536 \times \text{Overflows}$$



END OF CLASS