### General Purpose Timers:

- TIM2-TIM5 ve TIM9-TIM14 genel amaçlı timerlardır.
- 16-bit (TIM3,TIM4) or 32-bit (TIM2,TIM5) yukarı, aşağı, yukarı/aşağı otomatik yeniden yüklenen sayıcılar.
- Prescaler ile frekans 1-65536 sayısına bölünebilr.
- 4' kadar bağımsız kanal her kanaldan
  - Giriş yakalama
  - Çıkış karşılaştırma
  - PWM
  - tek darbe modu çıkış



Kaynak: https://www.youtube.com/watch?v=zkrVHIcLGww







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

Period = (1 + ARR) \* Clock Period = 7 \* Clock Period













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

$$= \frac{1}{2}$$

Period = 2 \* ARR \* Clock Period = 12 \* Clock Period



### TIMx control register 1 (TIMx\_CR1)

Address offset: 0x00

Reset value: 0x0000

| 15 | 14 | 13   | 12   | 11 | 10 | 9   | 8     | 7    | 6  | 5   | 4   | 3   | 2   | 1    | 0   |  |
|----|----|------|------|----|----|-----|-------|------|----|-----|-----|-----|-----|------|-----|--|
|    |    | Poss | nuad |    |    | CKD | [1:0] | ARPE | CI | MS) | DIR | OPM | URS | UDIS | CEN |  |
|    |    | Rese | rveu |    |    | rw  | rw    | rw   | rw | rw  | rw  | rw  | rw  | rw   | rw  |  |

Bit 7 ARPE: Auto-reload preload enable

TIMx\_ARR register is not buffered

1: TIMx\_ARR register is buffered

Bit 0 CEN: Counter enable

Counter disabled

1: Counter enabled

Note: External clock, gated mode and encoder mode can work only if the CEN bit has been previously set by software. However trigger mode can set the CEN bit automatically by hardware.

CEN is cleared automatically in one-pulse mode, when an update event occurs.

#### Bits 6:5 CMS: Center-aligned mode selection

00: Edge-aligned mode. The counter counts up or down depending on the direction bit (DIR).

01: Center-aligned mode 1. The counter counts up and down alternatively. Output compare interrupt flags of channels configured in output (CCxS=00 in TIMx\_CCMRx register) are set only when the counter is counting down.

10: Center-aligned mode 2. The counter counts up and down alternatively. Output compare interrupt flags of channels configured in output (CCxS=00 in TIMx\_CCMRx register) are set only when the counter is counting up.

11: Center-aligned mode 3. The counter counts up and down alternatively. Output compare interrupt flags of channels configured in output (CCxS=00 in TIMx\_CCMRx register) are set both when the counter is counting up or down.

Note: It is not allowed to switch from edge-aligned mode to center-aligned mode as long as the counter is enabled (CEN=1)

#### Bit 4 DIR: Direction

0: Counter used as upcounter

1: Counter used as downcounter

Note: This bit is read only when the timer is configured in Center-aligned mode or Encoder mode.

### TIMx DMA/Interrupt enable register (TIMx\_DIER)

Address offset: 0x0C

Reset value: 0x0000

| 15   | 14  | 13  | 12    | 11    | 10    | 9     | 8   | 7    | 6   | 5   | 4     | 3     | 2     | 1     | 0   |
|------|-----|-----|-------|-------|-------|-------|-----|------|-----|-----|-------|-------|-------|-------|-----|
| Res. | TDE | Res | CC4DE | CC3DE | CC2DE | CC1DE | UDE | Res. | TIE | Res | CC4IE | CC3IE | CC2IE | CC1IE | UIE |
| Res. | rw  | Res | rw    | rw    | rw    | rw    | rw  | Res. | rw  | Res | rw    | rw    | rw    | rw    | rw  |

Bit 3 **CC3IE**: Capture/Compare 3 interrupt enable

0: CC3 interrupt disabled

1: CC3 interrupt enabled

Bit 2 **CC2IE**: Capture/Compare 2 interrupt enable

0: CC2 interrupt disabled1: CC2 interrupt enabled

Bit 1 **CC1IE**: Capture/Compare 1 interrupt enable

0: CC1 interrupt disabled1: CC1 interrupt enabled

Bit 0 **UIE**: Update interrupt enable

0: Update interrupt disabled

1: Update interrupt enabled

### TIMx status register (TIMx\_SR)

Address offset: 0x10

Reset value: 0x0000

| 1        | 5 14     | 13    | 12    | 11    | 10    | 9     | 8     | 7   | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|----------|----------|-------|-------|-------|-------|-------|-------|-----|-------|-------|-------|-------|-------|-------|-------|
| Reserved | CC4OF    | CC3OF | CC2OF | CC10F | Reser | wod   | TIF   | Res | CC4IF | CC3IF | CC2IF | CC1IF | UIF   |       |       |
|          | Reserved |       | rc_w0 | rc_w0 | rc_w0 | rc_w0 | Reser | veu | rc_w0 | Res   | rc_w0 | rc_w0 | rc_w0 | rc_w0 | rc_w0 |

#### Bit 0 **UIF**: Update interrupt flag

- " This bit is set by hardware on an update event. It is cleared by software.
  - 0: No update occurred.
  - 1: Update interrupt pending. This bit is set by hardware when the registers are updated:
- " At overflow or underflow (for TIM2 to TIM5) and if UDIS=0 in the TIMx\_CR1 register.
- When CNT is reinitialized by software using the UG bit in TIMx\_EGR register, if URS=0 and UDIS=0 in the TIMx\_CR1 register.

When CNT is reinitialized by a trigger event (refer to the synchro control register description), if URS=0 and UDIS=0 in the TIMx\_CR1 register.

- Bit 3 CC3IF: Capture/Compare 3 interrupt flag refer to CC1IF description
- Bit 2 CC2IF: Capture/Compare 2 interrupt flag refer to CC1IF description
- Bit 1 CC1IF: Capture/compare 1 interrupt flag

#### If channel CC1 is configured as output:

This flag is set by hardware when the counter matches the compare value, with some exception in center-aligned mode (refer to the CMS bits in the TIMx\_CR1 register description). It is cleared by software.

0: No match

1: The content of the counter TIMx\_CNT matches the content of the TIMx\_CCR1 register. When the contents of TIMx\_CCR1 are greater than the contents of TIMx\_ARR, the CC1IF bit goes high on the counter overflow (in upcounting and up/down-counting modes) or underflow (in downcounting mode)

#### If channel CC1 is configured as input:

This bit is set by hardware on a capture. It is cleared by software or by reading the TIMx\_CCR1 register.

0: No input capture occurred

1: The counter value has been captured in TIMx\_CCR1 register (An edge has been detected on IC1 which matches the selected polarity)

### TIMx capture/compare mode register 1 (TIMx\_CCMR1)

Address offset: 0x18

Reset value: 0x0000

| 1   | 5         | 14 | 13 | 12    | 11     | 10    | 9      | 8      | 7     | 6     | 5        | 4     | 3      | 2     | 1      | 0      |
|-----|-----------|----|----|-------|--------|-------|--------|--------|-------|-------|----------|-------|--------|-------|--------|--------|
| OC2 | 2CE       |    |    | ]     | OC2PE  | OC2FE |        | S[1:0] | OC1CE | (     | OC1M[2:0 | )     | OC1PE  | OC1FE |        | S[1:0] |
|     | IC2F[3:0] |    |    | IC2PS | C[1:0] | 0020  | 5[1.0] |        | IC1F  | [3:0] |          | IC1PS | C[1:0] | 0010  | 5[1.0] |        |
| rv  | N         | rw | rw | rw    | rw     | rw    | rw     | rw     | rw    | rw    | rw       | rw    | rw     | rw    | rw     | rw     |

Bits 6:4 **OC1M**: Output compare 1 mode

110: PWM mode 1 - In upcounting, channel 1 is active as long as TIMx\_CNT<TIMx\_CCR1 else inactive. In downcounting, channel 1 is inactive (OC1REF='0) as long as TIMx\_CNT>TIMx\_CCR1 else active (OC1REF=1).

111: PWM mode 2 - In upcounting, channel 1 is inactive as long as TIMx\_CNT<TIMx\_CCR1 else active. In downcounting, channel 1 is active as long as TIMx\_CNT>TIMx\_CCR1 else inactive.

Note: In PWM mode 1 or 2, the OCREF level changes only when the result of the comparison changes or when the output compare mode switches from "frozen" mode to "PWM" mode.

### TIMx capture/compare enable register (TIMx\_CCER)

Address offset: 0x20

Reset value: 0x0000

| 15    | 14    | 13   | 12   | 11    | 10    | 9    | 8    | 7     | 6     | 5    | 4    | 3     | 2     | 1    | 0    |
|-------|-------|------|------|-------|-------|------|------|-------|-------|------|------|-------|-------|------|------|
| CC4NP | Res.  | CC4P | CC4E | CC3NP | Res.  | CC3P | CC3E | CC2NP | Res.  | CC2P | CC2E | CC1NP | Res.  | CC1P | CC1E |
| rw    | ixes. | rw   | rw   | rw    | 1.65. | rw   | rw   | rw    | 1.65. | rw   | rw   | w     | 1.65. | rw   | rw   |

Bit 0 CC1E: Capture/Compare 1 output enable.

#### CC1 channel configured as output:

0: Off - OC1 is not active

1: On - OC1 signal is output on the corresponding output pin

#### CC1 channel configured as input:

This bit determines if a capture of the counter value can actually be done into the input capture/compare register 1 (TIMx\_CCR1) or not.

0: Capture disabled

1: Capture enabled

### TIMx counter (TIMx\_CNT)

Address offset: 0x24

Reset value: 0x0000 0000

| 31 | 30                               | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | CNT[31:16] (depending on timers) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw | rw                               | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw |
| 15 | 14                               | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | CNT[15:0]                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw | rw                               | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw |

Bits 31:16 CNT[31:16]: High counter value (on TIM2 and TIM5).

Bits 15:0 CNT[15:0]: Counter value

### TIMx prescaler (TIMx\_PSC)

Address offset: 0x28

Reset value: 0x0000

| 15 | 14        | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | PSC[15:0] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw | rw        | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw |

#### Bits 15:0 PSC[15:0]: Prescaler value

The counter clock frequency CK\_CNT is equal to f<sub>CK\_PSC</sub> / (PSC[15:0] + 1).

PSC contains the value to be loaded in the active prescaler register at each update event (including when the counter is cleared through UG bit of TIMx\_EGR register or through trigger controller when configured in "reset mode").

### TIMx auto-reload register (TIMx\_ARR)

Address offset: 0x2C

Reset value: 0xFFFF FFFF

| 31 | 30                               | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----|----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|    | ARR[31:16] (depending on timers) |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw | rw                               | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw |
| 15 | 14                               | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | ARR[15:0]                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| rw | rw                               | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw | rw |

Bits 31:16 ARR[31:16]: High auto-reload value (on TIM2 and TIM5).

Bits 15:0 ARR[15:0]: Auto-reload value

### TIMx capture/compare register 1 (TIMx\_CCR1)

Address offset: 0x34

Reset value: 0x0000 0000

| 31    | 30                                | 29    | 28    | 27    | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-----------------------------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|       | CCR1[31:16] (depending on timers) |       |       |       |       |       |       |       |       |       |       |       |       |       |       |
| rw/ro | rw/ro                             | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro |
|       |                                   |       |       |       |       |       |       |       |       |       |       |       |       |       |       |
| 15    | 14                                | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|       | CCR1[15:0]                        |       |       |       |       |       |       |       |       |       |       |       |       |       |       |
| rw/ro | rw/ro                             | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro | rw/ro |

Bits 31:16 CCR1[31:16]: High Capture/Compare 1 value (on TIM2 and TIM5).

Bits 15:0 CCR1[15:0]: Low Capture/Compare 1 value