# APB2 peripheral clock enable register (RCC\_APB2ENR)

| 31         | 30           | 29         | 28         | 27         | 26         | 25         | 24         | 23         | 22         | 21          | 20          | 19         | 18         | 17       | 16         |
|------------|--------------|------------|------------|------------|------------|------------|------------|------------|------------|-------------|-------------|------------|------------|----------|------------|
|            |              |            |            | Res        | erved      |            |            |            |            | TIM11<br>EN | TIM10<br>EN | TIM9<br>EN |            | Reserved | 1          |
|            |              |            |            |            |            |            |            |            |            | rw          | rw          | rw         |            |          |            |
| 15         | 14           | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5           | 4           | 3          | 2          | 1        | 0          |
| ADC3<br>EN | USART<br>1EN | TIM8<br>EN | SPI1<br>EN | TIM1<br>EN | ADC2<br>EN | ADC1<br>EN | IOPG<br>EN | IOPF<br>EN | IOPE<br>EN | IOPD<br>EN  | IOPC<br>EN  | IOPB<br>EN | IOPA<br>EN | Res.     | AFIO<br>EN |
| rw         | rw           | rw         | rw         | rw         | rw         | rw         | rw         | rw         | rw         | rw          | rw          | rw         | rw         |          | rw         |

| Bit  | Fonction | Description                                             |
|------|----------|---------------------------------------------------------|
| 14   | USART1EN | Active la clock pour USART1.                            |
| 12   | SPI1EN   | Active la clock pour SPI1.                              |
| 11   | TIM1EN   | Active la clock pour TIM1.                              |
| 10-9 | ADCxEN   | Active la clock pour les ADCs (ADC1 ou ADC2).           |
| 6-2  | IOPxEN   | Active la clock pour les ports I/O des registres (A-E). |
| 0    | AFIOEN   | Active la clock pour les fonctions I/O                  |

# GPIOx->CRL (x = A...G) PIN du 0 à 7

| 31  | 30     | 29   | 28      | 27  | 26     | 25   | 24     | 23  | 22     | 21   | 20     | 19  | 18     | 17   | 16      |
|-----|--------|------|---------|-----|--------|------|--------|-----|--------|------|--------|-----|--------|------|---------|
| CNF | 7[1:0] | MODE | E7[1:0] | CNF | 3[1:0] | MODE | 6[1:0] | CNF | 5[1:0] | MODE | 5[1:0] | CNF | 4[1:0] | MODE | E4[1:0] |
| 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       |
| CNF | 3[1:0] | MODE | E3[1:0] | CNF | 2[1:0] | MODE | 2[1:0] | CNF | 1[1:0] | MODE | 1[1:0] | CNF | 0[1:0] | MODE | E0[1:0] |
| rw  | rw     | rw   | rw      | rw  | rw     | rw   | rw     | rw  | rw     | rw   | rw     | rw  | rw     | rw   | rw      |

| Bits                                                                 | Nom        | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------------------------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:30,<br>27:26,<br>23:22,<br>19:18,<br>15:14,<br>11:10, 7:6,<br>3:2 | CNFy[1:0]  | Bits de configuration du port x (y=07). En mode entrée (MODE[1:0]=00) : 00: Mode analogique, 01: Entrée flottante (état de réinitialisation), 10: Entrée avec pull-up / pull-down, 11: Réservé. En mode sortie (MODE[1:0] >00): 00: Sortie générale push-pull, 01: Sortie générale à collecteur ouvert, 10: Sortie de fonction alternative Push-pull, 11: Sortie de fonction alternative à collecteur ouvert. |
| 29:28,<br>25:24,<br>21:20,<br>17:16,<br>13:12, 9:8,<br>5:4, 1:0      | MODEy[1:0] | Bits de mode du port x (y=07). 00: Mode entrée (état de réinitialisation), 01: Mode de sortie, vitesse maximale 10 MHz, 10: Mode de sortie, vitesse maximale 2 MHz, 11: Mode de sortie, vitesse maximale 50                                                                                                                                                                                                   |

## GPIOx->CRH (x = A...G) PIN du 8 à 16

| 31   | 30      | 29   | 28      | 27   | 26     | 25   | 24      | 23   | 22     | 21   | 20      | 19   | 18     | 17   | 16      |
|------|---------|------|---------|------|--------|------|---------|------|--------|------|---------|------|--------|------|---------|
| CNF1 | 5[1:0]  | MODE | 15[1:0] | CNF1 | 4[1:0] | MODE | 14[1:0] | CNF1 | 3[1:0] | MODE | 13[1:0] | CNF1 | 2[1:0] | MODE | 12[1:0] |
| 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       |
| CNF1 | 11[1:0] | MODE | 11[1:0] | CNF1 | 0[1:0] | MODE | 10[1:0] | CNF  | 9[1:0] | MODE | E9[1:0] | CNF  | 8[1:0] | MODE | 8[1:0]  |
| rw   | rw      | rw   | rw      | rw   | rw     | rw   | rw      | rw   | rw     | rw   | rw      | rw   | rw     | rw   | rw      |

Fonctionne comme GPIOx->CRL

## GPIOx->IDR (x=A..G)

|   | 31   | 30    | 29    | 28    | 27    | 26    | 25   | 24   | 23     | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|---|------|-------|-------|-------|-------|-------|------|------|--------|------|------|------|------|------|------|------|
|   |      |       |       |       |       |       |      | Res  | served |      |      |      |      |      |      |      |
|   | 15   | 14    | 13    | 12    | 11    | 10    | 9    | 8    | 7      | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| I | DR15 | IDR14 | IDR13 | IDR12 | IDR11 | IDR10 | IDR9 | IDR8 | IDR7   | IDR6 | IDR5 | IDR4 | IDR3 | IDR2 | IDR1 | IDR0 |
|   | г    | г     | г     | г     | г     | г     | г    | r    | г      | r    | г    | r    | г    | r    | г    | г    |

| Bits      | Nom     | Description                                                                                                                       |
|-----------|---------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:1<br>6 | Réservé | Doit être conservé à la valeur de réinitialisation.                                                                               |
| 15:0      | IDRy    | Données d'entrée du port (y=015). Ces bits sont en lecture seule. Ils contiennent la valeur d'entrée du port d'E/S correspondant. |

## **GPIO**x->**ODR** (x = A...G)



Bits 15:0 ODRy: Données de sortie du port (y=0..15)

| Bits      | Nom     | Description                                                                                                                                                                                 |
|-----------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1<br>6 | Réservé | Doit être conservé à la valeur de réinitialisation.                                                                                                                                         |
| 15:0      | ODRy    | Données de sortie du port (y=015). Ces bits peuvent être lus et écrits par le logiciel. Les valeurs écrites dans ces bits déterminent les valeurs de sortie des ports d'E/S correspondants. |

#### **GPIOx->BSRR**

| 31         | 30         | 29         | 28         | 27         | 26         | 25       | 24       | 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
|------------|------------|------------|------------|------------|------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| BR15       | BR14       | BR13       | BR12       | BR11       | BR10       | BR9      | BR8      | BR7      | BR6      | BR5      | BR4      | BR3      | BR2      | BR1      | BR0      |
| w          | w          | w          | w          | w          | w          | w        | w        | w        | w        | w        | w        | w        | w        | w        | w        |
|            |            |            |            |            |            |          |          |          |          |          |          |          |          |          |          |
| 15         | 14         | 13         | 12         | 11         | 10         | 9        | 8        | 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| 15<br>BS15 | 14<br>BS14 | 13<br>BS13 | 12<br>BS12 | 11<br>BS11 | 10<br>BS10 | 9<br>BS9 | 8<br>BS8 | 7<br>BS7 | 6<br>BS6 | 5<br>BS5 | 4<br>BS4 | 3<br>BS3 | 2<br>BS2 | 1<br>BS1 | 0<br>BS0 |

| Bits      | Nom | Description                                                                                                                                                                |
|-----------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:1<br>6 | BRy | Bit de réinitialisation du port x, y (y=015). Ces bits sont en écriture seule  0 : Aucune action sur le bit ODRx correspondant  1 : Réinitialise le bit ODRx correspondant |
| 15:0      | BSy | Bit de configuration du port x, y (y=015). Ces bits sont en écriture seule.  0 : Aucune action sur le bit ODRx correspondant  1 : Définit le bit ODRx correspondant        |

## General purpose timers 3 registres importants pour comprendre comment ca marche

- Le registre de comptage (TIMx\_CNT) : C'est le registre qui contient la valeur de comptage actuelle du timer. C'est un registre de 16 bits qui peut compter vers le haut, vers le bas, ou les deux en fonction de la configuration. Il peut être lu ou écrit par le logiciel à tout moment, même pendant que le timer est en cours d'exécution.
- Le registre de prédivision (TIMx\_PSC): Ce registre contrôle la division de la source d'horloge pour le timer. C'est un registre de 16 bits qui peut diviser la fréquence d'horloge par n'importe quel facteur entre 1 et 65536. Il peut être modifié à la volée, et la nouvelle valeur de prédivision prendra effet lors du prochain événement de mise à jour.
- Le registre de rechargement automatique (TIMx\_ARR): Ce registre détermine la valeur maximale de comptage du timer. Lorsque le compteur atteint cette valeur, un événement de mise à jour est généré et le timer est réinitialisé à zéro. Ce registre est préchargé, ce qui signifie que lorsqu'il est écrit, la nouvelle valeur est d'abord chargée dans un registre d'ombre. Le contenu du registre d'ombre est transféré dans le registre ARR lors du prochain événement de mise à jour. Cela garantit que la valeur ARR est mise à jour atomiquement, évitant ainsi les problèmes de fonctionnement du timer.

#### **Petits points sur les interruptions :**

 Une interruption est un événement qui arrête temporairement le flux normal d'exécution d'un programme pour exécuter une routine de service d'interruption (ISR) qui gère cet événement.

- Les interruptions sont déclenchées par des événements matériels ou logiciels, tels qu'un signal de chronométrage, une entrée d'horloge ou une demande de périphérique.
- Les interruptions sont utilisées pour traiter rapidement les événements en temps réel, évitant ainsi de perdre des données ou de rater des événements critiques.
- Lorsqu'une interruption est déclenchée, l'ISR correspondante est exécutée, puis le programme principal reprend là où il s'est arrêté.
- Dans les microcontrôleurs STM32, les interruptions sont gérées par un contrôleur d'interruptions (NVIC) qui permet de configurer et de prioriser les interruptions pour chaque périphérique.

## Par exemple:

- La fonction "NVIC\_EnableIRQ(TIM5\_IRQn)" permet d'activer l'interruption correspondant au périphérique TIM5. Cela signifie que lorsque l'interruption est déclenchée, l'ISR correspondante sera exécutée :
- La fonction "void TIM5\_IRQHandler(void)" est l'ISR associée à l'interruption du périphérique TIM5. Cette fonction est exécutée chaque fois que l'interruption TIM5 est déclenchée, ce qui permet d'effectuer un traitement spécifique à cet événement.

## TIMx\_CR1 control register 1

| 15 | 14 | 13   | 12   | 11 | 10 | 9   | 8     | 7    | 6  | 5  | 4   | 3   | 2   | 1    | 0   |  |
|----|----|------|------|----|----|-----|-------|------|----|----|-----|-----|-----|------|-----|--|
|    |    | Rese | d    |    |    | CKE | [1:0] | ARPE | CI | MS | DIR | OPM | URS | UDIS | CEN |  |
|    |    | Rese | iveu |    |    | rw  | rw    | rw   | rw | rw | rw  | rw  | rw  | rw   | rw  |  |

| Bit | Nom                 | Description               |
|-----|---------------------|---------------------------|
|     | CEN                 | Activation du compteur    |
| 0   | Counter<br>disabled | Le compteur est désactivé |
| 1   | Counter enabled     | Le compteur est activé    |

## Interrupt enable register (TIMx\_DIER)

| Bit | Nom   | Description                                                  |  |  |  |  |  |  |  |  |
|-----|-------|--------------------------------------------------------------|--|--|--|--|--|--|--|--|
| 15  | -     | Réservé, doit être maintenu à la valeur de réinitialisation. |  |  |  |  |  |  |  |  |
| 14  | TDE   | Activation de la demande DMA de déclenchement                |  |  |  |  |  |  |  |  |
| 13  | -     | Toujours lu comme 0.                                         |  |  |  |  |  |  |  |  |
| 12  | CC4DE | Activation de la demande DMA de capture/comparaison 4        |  |  |  |  |  |  |  |  |

| 11 | CC3DE | Activation de la demande DMA de capture/comparaison 3        |
|----|-------|--------------------------------------------------------------|
| 10 | CC2DE | Activation de la demande DMA de capture/comparaison 2        |
| 9  | CC1DE | Activation de la demande DMA de capture/comparaison 1        |
| 8  | UDE   | Activation de la demande DMA de mise à jour                  |
| 7  | -     | Réservé, doit être maintenu à la valeur de réinitialisation. |
| 6  | TIE   | Activation de l'interruption de déclenchement                |
| 5  | -     | Réservé, doit être maintenu à la valeur de réinitialisation. |
| 4  | CC4IE | Activation de l'interruption de capture/comparaison 4        |
| 3  | CC3IE | Activation de l'interruption de capture/comparaison 3        |
| 2  | CC2IE | Activation de l'interruption de capture/comparaison 2        |
| 1  | CC1IE | Activation de l'interruption de capture/comparaison 1        |
| 0  | UIE   | Activation de l'interruption de mise à jour                  |

# TIMx status register (TIMx\_SR)

|   | 15       | 14 | 13    | 12    | 11    | 10    | 9        | 8     | 7   | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|---|----------|----|-------|-------|-------|-------|----------|-------|-----|-------|-------|-------|-------|-------|-------|-------|
| Γ | Reserved |    | CC40F | CC3OF | CC2OF | CC10F | Reserved |       | TIF | n     | CC4IF | CC3IF | CC2IF | CC1IF | UIF   |       |
|   |          |    |       | rc_w0 | rc_w0 | rc_w0 | rc_w0    | Reser | ved | rc_w0 | Res   | rc_w0 | rc_w0 | rc_w0 | rc_w0 | rc_w0 |

| Bits  | Nom     | Description                                        |
|-------|---------|----------------------------------------------------|
| 15:13 | Réservé | Doit être maintenu à la valeur de réinitialisation |
| 12    | CC4OF   | Drapeau de surcapture de capture/comparaison 4     |
| 11    | CC3OF   | Drapeau de surcapture de capture/comparaison 3     |
| 10    | CC2OF   | Drapeau de surcapture de capture/comparaison 2     |
| 9     | CC1OF   | Drapeau de surcapture de capture/comparaison 1     |
| 8:7   | Réservé | Doit être maintenu à la valeur de réinitialisation |
| 6     | TIF     | Drapeau d'interruption de déclenchement            |
| 5     | Réservé | Doit être maintenu à la valeur de réinitialisation |
| 4     | CC4IF   | Drapeau d'interruption de capture/comparaison 4    |

| ( | 3 | CC3IF | Drapeau d'interruption de capture/comparaison 3                       |
|---|---|-------|-----------------------------------------------------------------------|
| [ | 2 | CC2IF | Drapeau d'interruption de capture/comparaison 2                       |
|   | 1 | CC1IF | Drapeau d'interruption de capture/comparaison 1                       |
| ( | 0 | UIF   | Drapeau d'interruption de mise à jour. 1 si mise à jour 0 zéro sinon. |

# TIMx prescaler (TIMx\_PSC)

|   | 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 | Nom           | Description                                                                                             |
|------|---------------|---------------------------------------------------------------------------------------------------------|
| 15:0 | PSC[1<br>5:0] | Valeur du prédiviseur. La fréquence du signal de comptage CK_CNT est égale à fCK_PSC / (PSC[15:0] + 1). |

# TIMx\_ARR auto-reload register

| 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 | Nom       | Description                                                   |
|------|-----------|---------------------------------------------------------------|
| 15-0 | ARR[15:0] | Valeur à charger dans le registre de rechargement automatique |