

# Smart Car Parking Management System

Generated by Doxygen 1.9.1

Author: **Mr. Mohamed Ali Haoufa**

Documentation version: 1.0

Date: September 21th, 2024

@Copyright (c) 2024. All rights reserved.



---

|                                                |           |
|------------------------------------------------|-----------|
| <b>1 PIR-Sensor-Library-for-Proteus</b>        | <b>1</b>  |
| <b>2 Module Index</b>                          | <b>3</b>  |
| 2.1 Modules . . . . .                          | 3         |
| <b>3 Class Index</b>                           | <b>9</b>  |
| 3.1 Class List . . . . .                       | 9         |
| <b>4 File Index</b>                            | <b>13</b> |
| 4.1 File List . . . . .                        | 13        |
| <b>5 Module Documentation</b>                  | <b>15</b> |
| 5.1 AT24C1024B EEPROM Driver . . . . .         | 15        |
| 5.1.1 Detailed Description . . . . .           | 15        |
| 5.2 EEPROM Constants . . . . .                 | 15        |
| 5.2.1 Detailed Description . . . . .           | 16        |
| 5.2.2 Macro Definition Documentation . . . . . | 16        |
| 5.2.2.1 EEPROM_Slave_address . . . . .         | 16        |
| 5.3 API Function Prototypes . . . . .          | 16        |
| 5.3.1 Detailed Description . . . . .           | 16        |
| 5.3.2 Function Documentation . . . . .         | 16        |
| 5.3.2.1 EEPROM_Init() . . . . .                | 17        |
| 5.3.2.2 EEPROM_Read_byte() . . . . .           | 17        |
| 5.3.2.3 EEPROM_Write_NBytes() . . . . .        | 18        |
| 5.4 KEYPAD Driver . . . . .                    | 18        |
| 5.4.1 Detailed Description . . . . .           | 19        |
| 5.4.2 Macro Definition Documentation . . . . . | 19        |
| 5.4.2.1 KEYPAD_PORT . . . . .                  | 19        |
| 5.5 API Function Prototypes . . . . .          | 20        |
| 5.5.1 Detailed Description . . . . .           | 20        |
| 5.5.2 Function Documentation . . . . .         | 20        |
| 5.5.2.1 keypad_Get_Pressed_Key() . . . . .     | 20        |
| 5.5.2.2 keypad_init() . . . . .                | 21        |
| 5.6 LCD Driver . . . . .                       | 22        |
| 5.6.1 Detailed Description . . . . .           | 22        |
| 5.6.2 Enumeration Type Documentation . . . . . | 22        |
| 5.6.2.1 LCD_MODE_t . . . . .                   | 22        |
| 5.6.2.2 LCD_ROWS_t . . . . .                   | 23        |
| 5.7 LCD Commands . . . . .                     | 23        |
| 5.7.1 Detailed Description . . . . .           | 24        |
| 5.8 LCD Row Positions . . . . .                | 24        |
| 5.8.1 Detailed Description . . . . .           | 25        |
| 5.9 API Function Prototypes . . . . .          | 25        |
| 5.9.1 Detailed Description . . . . .           | 25        |

---

|                                                      |    |
|------------------------------------------------------|----|
| 5.9.2 Function Documentation . . . . .               | 25 |
| 5.9.2.1 LCD_Init() . . . . .                         | 25 |
| 5.9.2.2 LCD_Send_Char() . . . . .                    | 26 |
| 5.9.2.3 LCD_Send_Char_Pos() . . . . .                | 27 |
| 5.9.2.4 LCD_Send_Command() . . . . .                 | 28 |
| 5.9.2.5 LCD_Send_Enable_Signal() . . . . .           | 28 |
| 5.9.2.6 LCD_Send_String() . . . . .                  | 29 |
| 5.9.2.7 LCD_Send_String_Pos() . . . . .              | 30 |
| 5.9.2.8 LCD_Set_Cursor() . . . . .                   | 30 |
| 5.10 LED Driver . . . . .                            | 31 |
| 5.10.1 Detailed Description . . . . .                | 32 |
| 5.11 Enum for specifying the LED mode. . . . .       | 32 |
| 5.11.1 Detailed Description . . . . .                | 33 |
| 5.11.2 Enumeration Type Documentation . . . . .      | 33 |
| 5.11.2.1 LED_Mode_t . . . . .                        | 33 |
| 5.12 Structure for configuring an LED. . . . .       | 33 |
| 5.12.1 Detailed Description . . . . .                | 33 |
| 5.13 API Function Prototypes . . . . .               | 33 |
| 5.13.1 Detailed Description . . . . .                | 34 |
| 5.13.2 Function Documentation . . . . .              | 34 |
| 5.13.2.1 LED_Init() . . . . .                        | 34 |
| 5.13.2.2 LED_Toggle() . . . . .                      | 35 |
| 5.13.2.3 LED_TurnOff() . . . . .                     | 36 |
| 5.13.2.4 LED_TurnOn() . . . . .                      | 36 |
| 5.14 SERVO MOTOR Driver . . . . .                    | 37 |
| 5.14.1 Detailed Description . . . . .                | 37 |
| 5.15 Macros for the servo motor directions . . . . . | 38 |
| 5.15.1 Detailed Description . . . . .                | 38 |
| 5.16 API Function Prototypes . . . . .               | 38 |
| 5.16.1 Detailed Description . . . . .                | 39 |
| 5.16.2 Function Documentation . . . . .              | 39 |
| 5.16.2.1 Servo1_Entry_Gate() . . . . .               | 39 |
| 5.16.2.2 Servo1_Entry_Gate_Init() . . . . .          | 40 |
| 5.16.2.3 Servo2_Exit_Gate() . . . . .                | 40 |
| 5.16.2.4 Servo2_Exit_Gate_Init() . . . . .           | 41 |
| 5.17 CMSIS Global Defines . . . . .                  | 42 |
| 5.18 Defines and Type Definitions . . . . .          | 42 |
| 5.18.1 Detailed Description . . . . .                | 42 |
| 5.19 Status and Control Registers . . . . .          | 43 |
| 5.19.1 Detailed Description . . . . .                | 44 |
| 5.19.2 Macro Definition Documentation . . . . .      | 44 |
| 5.19.2.1 APSR_C_Msk . . . . .                        | 44 |

---

|                                                            |    |
|------------------------------------------------------------|----|
| 5.19.2.2 APSR_C_Pos . . . . .                              | 44 |
| 5.19.2.3 APSR_GE_Msk . . . . .                             | 44 |
| 5.19.2.4 APSR_GE_Pos . . . . .                             | 45 |
| 5.19.2.5 APSR_N_Msk . . . . .                              | 45 |
| 5.19.2.6 APSR_N_Pos . . . . .                              | 45 |
| 5.19.2.7 APSR_Q_Msk . . . . .                              | 45 |
| 5.19.2.8 APSR_Q_Pos . . . . .                              | 45 |
| 5.19.2.9 APSR_V_Msk . . . . .                              | 45 |
| 5.19.2.10 APSR_V_Pos . . . . .                             | 45 |
| 5.19.2.11 APSR_Z_Msk . . . . .                             | 45 |
| 5.19.2.12 APSR_Z_Pos . . . . .                             | 46 |
| 5.19.2.13 CONTROL_FPCA_Msk . . . . .                       | 46 |
| 5.19.2.14 CONTROL_FPCA_Pos . . . . .                       | 46 |
| 5.19.2.15 CONTROL_nPRIV_Msk . . . . .                      | 46 |
| 5.19.2.16 CONTROL_nPRIV_Pos . . . . .                      | 46 |
| 5.19.2.17 CONTROL_SPSEL_Msk . . . . .                      | 46 |
| 5.19.2.18 CONTROL_SPSEL_Pos . . . . .                      | 46 |
| 5.19.2.19 IPSR_ISR_Msk . . . . .                           | 46 |
| 5.19.2.20 IPSR_ISR_Pos . . . . .                           | 47 |
| 5.19.2.21 xPSR_C_Msk . . . . .                             | 47 |
| 5.19.2.22 xPSR_C_Pos . . . . .                             | 47 |
| 5.19.2.23 xPSR_GE_Msk . . . . .                            | 47 |
| 5.19.2.24 xPSR_GE_Pos . . . . .                            | 47 |
| 5.19.2.25 xPSR_ISR_Msk . . . . .                           | 47 |
| 5.19.2.26 xPSR_ISR_Pos . . . . .                           | 47 |
| 5.19.2.27 xPSR_IT_Msk . . . . .                            | 47 |
| 5.19.2.28 xPSR_IT_Pos . . . . .                            | 48 |
| 5.19.2.29 xPSR_N_Msk . . . . .                             | 48 |
| 5.19.2.30 xPSR_N_Pos . . . . .                             | 48 |
| 5.19.2.31 xPSR_Q_Msk . . . . .                             | 48 |
| 5.19.2.32 xPSR_Q_Pos . . . . .                             | 48 |
| 5.19.2.33 xPSR_T_Msk . . . . .                             | 48 |
| 5.19.2.34 xPSR_T_Pos . . . . .                             | 48 |
| 5.19.2.35 xPSR_V_Msk . . . . .                             | 48 |
| 5.19.2.36 xPSR_V_Pos . . . . .                             | 49 |
| 5.19.2.37 xPSR_Z_Msk . . . . .                             | 49 |
| 5.19.2.38 xPSR_Z_Pos . . . . .                             | 49 |
| 5.20 Nested Vectored Interrupt Controller (NVIC) . . . . . | 49 |
| 5.20.1 Detailed Description . . . . .                      | 50 |
| 5.20.2 Macro Definition Documentation . . . . .            | 50 |
| 5.20.2.1 NVIC_STIR_INTID_Msk . . . . .                     | 50 |
| 5.20.2.2 NVIC_STIR_INTID_Pos . . . . .                     | 50 |

---

|                                                 |    |
|-------------------------------------------------|----|
| 5.21 System Control Block (SCB) . . . . .       | 50 |
| 5.21.1 Detailed Description . . . . .           | 53 |
| 5.21.2 Macro Definition Documentation . . . . . | 53 |
| 5.21.2.1 SCB_AIRCR_ENDIANESS_Msk . . . . .      | 53 |
| 5.21.2.2 SCB_AIRCR_ENDIANESS_Pos . . . . .      | 53 |
| 5.21.2.3 SCB_AIRCR_PRIGROUP_Msk . . . . .       | 53 |
| 5.21.2.4 SCB_AIRCR_PRIGROUP_Pos . . . . .       | 53 |
| 5.21.2.5 SCB_AIRCR_SYSRESETREQ_Msk . . . . .    | 54 |
| 5.21.2.6 SCB_AIRCR_SYSRESETREQ_Pos . . . . .    | 54 |
| 5.21.2.7 SCB_AIRCR_VECTCLRACTIVE_Msk . . . . .  | 54 |
| 5.21.2.8 SCB_AIRCR_VECTCLRACTIVE_Pos . . . . .  | 54 |
| 5.21.2.9 SCB_AIRCR_VECTKEY_Msk . . . . .        | 54 |
| 5.21.2.10 SCB_AIRCR_VECTKEY_Pos . . . . .       | 54 |
| 5.21.2.11 SCB_AIRCR_VECTKEYSTAT_Msk . . . . .   | 54 |
| 5.21.2.12 SCB_AIRCR_VECTKEYSTAT_Pos . . . . .   | 54 |
| 5.21.2.13 SCB_AIRCR_VECTRESET_Msk . . . . .     | 55 |
| 5.21.2.14 SCB_AIRCR_VECTRESET_Pos . . . . .     | 55 |
| 5.21.2.15 SCB_CCR_BFHFMIGN_Msk . . . . .        | 55 |
| 5.21.2.16 SCB_CCR_BFHFMIGN_Pos . . . . .        | 55 |
| 5.21.2.17 SCB_CCR_DIV_0_TRP_Msk . . . . .       | 55 |
| 5.21.2.18 SCB_CCR_DIV_0_TRP_Pos . . . . .       | 55 |
| 5.21.2.19 SCB_CCR_NONBASETHRDENA_Msk . . . . .  | 55 |
| 5.21.2.20 SCB_CCR_NONBASETHRDENA_Pos . . . . .  | 55 |
| 5.21.2.21 SCB_CCR_STKALIGN_Msk . . . . .        | 56 |
| 5.21.2.22 SCB_CCR_STKALIGN_Pos . . . . .        | 56 |
| 5.21.2.23 SCB_CCR_UNALIGN_TRP_Msk . . . . .     | 56 |
| 5.21.2.24 SCB_CCR_UNALIGN_TRP_Pos . . . . .     | 56 |
| 5.21.2.25 SCB_CCR_USERSETMPEND_Msk . . . . .    | 56 |
| 5.21.2.26 SCB_CCR_USERSETMPEND_Pos . . . . .    | 56 |
| 5.21.2.27 SCB_CFSR_BUSFAULTSR_Msk . . . . .     | 56 |
| 5.21.2.28 SCB_CFSR_BUSFAULTSR_Pos . . . . .     | 56 |
| 5.21.2.29 SCB_CFSR_MEMFAULTSR_Msk . . . . .     | 57 |
| 5.21.2.30 SCB_CFSR_MEMFAULTSR_Pos . . . . .     | 57 |
| 5.21.2.31 SCB_CFSR_USGFAULTSR_Msk . . . . .     | 57 |
| 5.21.2.32 SCB_CFSR_USGFAULTSR_Pos . . . . .     | 57 |
| 5.21.2.33 SCB_CPUID_ARCHITECTURE_Msk . . . . .  | 57 |
| 5.21.2.34 SCB_CPUID_ARCHITECTURE_Pos . . . . .  | 57 |
| 5.21.2.35 SCB_CPUID_IMPLEMENTER_Msk . . . . .   | 57 |
| 5.21.2.36 SCB_CPUID_IMPLEMENTER_Pos . . . . .   | 57 |
| 5.21.2.37 SCB_CPUID_PARTNO_Msk . . . . .        | 58 |
| 5.21.2.38 SCB_CPUID_PARTNO_Pos . . . . .        | 58 |
| 5.21.2.39 SCB_CPUID_REVISION_Msk . . . . .      | 58 |

|                                              |    |
|----------------------------------------------|----|
| 5.21.2.40 SCB_CPUID_REVISION_Pos . . . . .   | 58 |
| 5.21.2.41 SCB_CPUID_VARIANT_Msk . . . . .    | 58 |
| 5.21.2.42 SCB_CPUID_VARIANT_Pos . . . . .    | 58 |
| 5.21.2.43 SCB_DFSR_BKPT_Msk . . . . .        | 58 |
| 5.21.2.44 SCB_DFSR_BKPT_Pos . . . . .        | 58 |
| 5.21.2.45 SCB_DFSR_DWTTRAP_Msk . . . . .     | 59 |
| 5.21.2.46 SCB_DFSR_DWTTRAP_Pos . . . . .     | 59 |
| 5.21.2.47 SCB_DFSR_EXTERNAL_Msk . . . . .    | 59 |
| 5.21.2.48 SCB_DFSR_EXTERNAL_Pos . . . . .    | 59 |
| 5.21.2.49 SCB_DFSR_HALTED_Msk . . . . .      | 59 |
| 5.21.2.50 SCB_DFSR_HALTED_Pos . . . . .      | 59 |
| 5.21.2.51 SCB_DFSR_VCATCH_Msk . . . . .      | 59 |
| 5.21.2.52 SCB_DFSR_VCATCH_Pos . . . . .      | 59 |
| 5.21.2.53 SCB_HFSR_DEBUGEVT_Msk . . . . .    | 60 |
| 5.21.2.54 SCB_HFSR_DEBUGEVT_Pos . . . . .    | 60 |
| 5.21.2.55 SCB_HFSR_FORCED_Msk . . . . .      | 60 |
| 5.21.2.56 SCB_HFSR_FORCED_Pos . . . . .      | 60 |
| 5.21.2.57 SCB_HFSR_VECTTBL_Msk . . . . .     | 60 |
| 5.21.2.58 SCB_HFSR_VECTTBL_Pos . . . . .     | 60 |
| 5.21.2.59 SCB_ICSR_ISRPENDING_Msk . . . . .  | 60 |
| 5.21.2.60 SCB_ICSR_ISRPENDING_Pos . . . . .  | 60 |
| 5.21.2.61 SCB_ICSR_ISRPREEMPT_Msk . . . . .  | 61 |
| 5.21.2.62 SCB_ICSR_ISRPREEMPT_Pos . . . . .  | 61 |
| 5.21.2.63 SCB_ICSR_NMIPENDSET_Msk . . . . .  | 61 |
| 5.21.2.64 SCB_ICSR_NMIPENDSET_Pos . . . . .  | 61 |
| 5.21.2.65 SCB_ICSR_PENDSTCLR_Msk . . . . .   | 61 |
| 5.21.2.66 SCB_ICSR_PENDSTCLR_Pos . . . . .   | 61 |
| 5.21.2.67 SCB_ICSR_PENDSTSET_Msk . . . . .   | 61 |
| 5.21.2.68 SCB_ICSR_PENDSTSET_Pos . . . . .   | 61 |
| 5.21.2.69 SCB_ICSR_PENDSVCLR_Msk . . . . .   | 62 |
| 5.21.2.70 SCB_ICSR_PENDSVCLR_Pos . . . . .   | 62 |
| 5.21.2.71 SCB_ICSR_PENDSVSET_Msk . . . . .   | 62 |
| 5.21.2.72 SCB_ICSR_PENDSVSET_Pos . . . . .   | 62 |
| 5.21.2.73 SCB_ICSR_RETTOBASE_Msk . . . . .   | 62 |
| 5.21.2.74 SCB_ICSR_RETTOBASE_Pos . . . . .   | 62 |
| 5.21.2.75 SCB_ICSR_VECTACTIVE_Msk . . . . .  | 62 |
| 5.21.2.76 SCB_ICSR_VECTACTIVE_Pos . . . . .  | 62 |
| 5.21.2.77 SCB_ICSR_VECTPENDING_Msk . . . . . | 63 |
| 5.21.2.78 SCB_ICSR_VECTPENDING_Pos . . . . . | 63 |
| 5.21.2.79 SCB_SCR_SEVONPEND_Msk . . . . .    | 63 |
| 5.21.2.80 SCB_SCR_SEVONPEND_Pos . . . . .    | 63 |
| 5.21.2.81 SCB_SCR_SLEEPDEEP_Msk . . . . .    | 63 |

---

|                                                    |    |
|----------------------------------------------------|----|
| 5.21.2.82 SCB_SCR_SLEEPDEEP_Pos . . . . .          | 63 |
| 5.21.2.83 SCB_SCR_SLEEPONEXIT_Msk . . . . .        | 63 |
| 5.21.2.84 SCB_SCR_SLEEPONEXIT_Pos . . . . .        | 63 |
| 5.21.2.85 SCB_SHCSR_BUSFAULTACT_Msk . . . . .      | 64 |
| 5.21.2.86 SCB_SHCSR_BUSFAULTACT_Pos . . . . .      | 64 |
| 5.21.2.87 SCB_SHCSR_BUSFAULTENA_Msk . . . . .      | 64 |
| 5.21.2.88 SCB_SHCSR_BUSFAULTENA_Pos . . . . .      | 64 |
| 5.21.2.89 SCB_SHCSR_BUSFAULTPENDED_Msk . . . . .   | 64 |
| 5.21.2.90 SCB_SHCSR_BUSFAULTPENDED_Pos . . . . .   | 64 |
| 5.21.2.91 SCB_SHCSR_MEMFAULTACT_Msk . . . . .      | 64 |
| 5.21.2.92 SCB_SHCSR_MEMFAULTACT_Pos . . . . .      | 64 |
| 5.21.2.93 SCB_SHCSR_MEMFAULTENA_Msk . . . . .      | 65 |
| 5.21.2.94 SCB_SHCSR_MEMFAULTENA_Pos . . . . .      | 65 |
| 5.21.2.95 SCB_SHCSR_MEMFAULTPENDED_Msk . . . . .   | 65 |
| 5.21.2.96 SCB_SHCSR_MEMFAULTPENDED_Pos . . . . .   | 65 |
| 5.21.2.97 SCB_SHCSR_MONITORACT_Msk . . . . .       | 65 |
| 5.21.2.98 SCB_SHCSR_MONITORACT_Pos . . . . .       | 65 |
| 5.21.2.99 SCB_SHCSR_PENDSVACT_Msk . . . . .        | 65 |
| 5.21.2.100 SCB_SHCSR_PENDSVACT_Pos . . . . .       | 65 |
| 5.21.2.101 SCB_SHCSR_SVCALLACT_Msk . . . . .       | 66 |
| 5.21.2.102 SCB_SHCSR_SVCALLACT_Pos . . . . .       | 66 |
| 5.21.2.103 SCB_SHCSR_SVCALLPENDED_Msk . . . . .    | 66 |
| 5.21.2.104 SCB_SHCSR_SVCALLPENDED_Pos . . . . .    | 66 |
| 5.21.2.105 SCB_SHCSR_SYSTICKACT_Msk . . . . .      | 66 |
| 5.21.2.106 SCB_SHCSR_SYSTICKACT_Pos . . . . .      | 66 |
| 5.21.2.107 SCB_SHCSR_USGFAULTACT_Msk . . . . .     | 66 |
| 5.21.2.108 SCB_SHCSR_USGFAULTACT_Pos . . . . .     | 66 |
| 5.21.2.109 SCB_SHCSR_USGFAULTENA_Msk . . . . .     | 67 |
| 5.21.2.110 SCB_SHCSR_USGFAULTENA_Pos . . . . .     | 67 |
| 5.21.2.111 SCB_SHCSR_USGFAULTPENDED_Msk . . . . .  | 67 |
| 5.21.2.112 SCB_SHCSR_USGFAULTPENDED_Pos . . . . .  | 67 |
| 5.21.2.113 SCB_VTOR_TBLOFF_Msk . . . . .           | 67 |
| 5.21.2.114 SCB_VTOR_TBLOFF_Pos . . . . .           | 67 |
| 5.22 System Controls not in SCB (SCnSCB) . . . . . | 67 |
| 5.22.1 Detailed Description . . . . .              | 68 |
| 5.22.2 Macro Definition Documentation . . . . .    | 68 |
| 5.22.2.1 SCnSCB_ACTLR_DISDEFWBUF_Msk . . . . .     | 68 |
| 5.22.2.2 SCnSCB_ACTLR_DISDEFWBUF_Pos . . . . .     | 68 |
| 5.22.2.3 SCnSCB_ACTLR_DISFOLD_Msk . . . . .        | 68 |
| 5.22.2.4 SCnSCB_ACTLR_DISFOLD_Pos . . . . .        | 69 |
| 5.22.2.5 SCnSCB_ACTLR_DISFPCA_Msk . . . . .        | 69 |
| 5.22.2.6 SCnSCB_ACTLR_DISFPCA_Pos . . . . .        | 69 |

---

---

|                                                      |    |
|------------------------------------------------------|----|
| 5.22.2.7 SCnSCB_ACTLR_DISMCYCINT_Msk . . . . .       | 69 |
| 5.22.2.8 SCnSCB_ACTLR_DISMCYCINT_Pos . . . . .       | 69 |
| 5.22.2.9 SCnSCB_ACTLR_DISOOFP_Msk . . . . .          | 69 |
| 5.22.2.10 SCnSCB_ACTLR_DISOOFP_Pos . . . . .         | 69 |
| 5.22.2.11 SCnSCB_ICTR_INTLINESNUM_Msk . . . . .      | 69 |
| 5.22.2.12 SCnSCB_ICTR_INTLINESNUM_Pos . . . . .      | 70 |
| 5.23 System Tick Timer (SysTick) . . . . .           | 70 |
| 5.23.1 Detailed Description . . . . .                | 71 |
| 5.23.2 Macro Definition Documentation . . . . .      | 71 |
| 5.23.2.1 SysTick_CALIB_NOREF_Msk . . . . .           | 71 |
| 5.23.2.2 SysTick_CALIB_NOREF_Pos . . . . .           | 71 |
| 5.23.2.3 SysTick_CALIB_SKEW_Msk . . . . .            | 71 |
| 5.23.2.4 SysTick_CALIB_SKEW_Pos . . . . .            | 71 |
| 5.23.2.5 SysTick_CALIB_TENMS_Msk . . . . .           | 71 |
| 5.23.2.6 SysTick_CALIB_TENMS_Pos . . . . .           | 71 |
| 5.23.2.7 SysTick_CTRL_CLKSOURCE_Msk . . . . .        | 72 |
| 5.23.2.8 SysTick_CTRL_CLKSOURCE_Pos . . . . .        | 72 |
| 5.23.2.9 SysTick_CTRL_COUNTFLAG_Msk . . . . .        | 72 |
| 5.23.2.10 SysTick_CTRL_COUNTFLAG_Pos . . . . .       | 72 |
| 5.23.2.11 SysTick_CTRL_ENABLE_Msk . . . . .          | 72 |
| 5.23.2.12 SysTick_CTRL_ENABLE_Pos . . . . .          | 72 |
| 5.23.2.13 SysTick_CTRL_TICKINT_Msk . . . . .         | 72 |
| 5.23.2.14 SysTick_CTRL_TICKINT_Pos . . . . .         | 72 |
| 5.23.2.15 SysTick_LOAD_RELOAD_Msk . . . . .          | 73 |
| 5.23.2.16 SysTick_LOAD_RELOAD_Pos . . . . .          | 73 |
| 5.23.2.17 SysTick_VAL_CURRENT_Msk . . . . .          | 73 |
| 5.23.2.18 SysTick_VAL_CURRENT_Pos . . . . .          | 73 |
| 5.24 Instrumentation Trace Macrocell (ITM) . . . . . | 73 |
| 5.24.1 Detailed Description . . . . .                | 74 |
| 5.24.2 Macro Definition Documentation . . . . .      | 74 |
| 5.24.2.1 ITM_IMCR_INTEGRATION_Msk . . . . .          | 74 |
| 5.24.2.2 ITM_IMCR_INTEGRATION_Pos . . . . .          | 75 |
| 5.24.2.3 ITM_IRR_ATREADYM_Msk . . . . .              | 75 |
| 5.24.2.4 ITM_IRR_ATREADYM_Pos . . . . .              | 75 |
| 5.24.2.5 ITM_IWR_ATVALIDM_Msk . . . . .              | 75 |
| 5.24.2.6 ITM_IWR_ATVALIDM_Pos . . . . .              | 75 |
| 5.24.2.7 ITM_LSR_Access_Msk . . . . .                | 75 |
| 5.24.2.8 ITM_LSR_Access_Pos . . . . .                | 75 |
| 5.24.2.9 ITM_LSR_BytAcc_Msk . . . . .                | 75 |
| 5.24.2.10 ITM_LSR_BytAcc_Pos . . . . .               | 76 |
| 5.24.2.11 ITM_LSR_Present_Msk . . . . .              | 76 |
| 5.24.2.12 ITM_LSR_Present_Pos . . . . .              | 76 |

|                                                 |    |
|-------------------------------------------------|----|
| 5.24.2.13 ITM_TCR_BUSY_Msk . . . . .            | 76 |
| 5.24.2.14 ITM_TCR_BUSY_Pos . . . . .            | 76 |
| 5.24.2.15 ITM_TCR_DWTENA_Msk . . . . .          | 76 |
| 5.24.2.16 ITM_TCR_DWTENA_Pos . . . . .          | 76 |
| 5.24.2.17 ITM_TCR_GTSFREQ_Msk . . . . .         | 76 |
| 5.24.2.18 ITM_TCR_GTSFREQ_Pos . . . . .         | 77 |
| 5.24.2.19 ITM_TCR_ITMENA_Msk . . . . .          | 77 |
| 5.24.2.20 ITM_TCR_ITMENA_Pos . . . . .          | 77 |
| 5.24.2.21 ITM_TCR_SWOENA_Msk . . . . .          | 77 |
| 5.24.2.22 ITM_TCR_SWOENA_Pos . . . . .          | 77 |
| 5.24.2.23 ITM_TCR_SYNCENA_Msk . . . . .         | 77 |
| 5.24.2.24 ITM_TCR_SYNCENA_Pos . . . . .         | 77 |
| 5.24.2.25 ITM_TCR_TraceBusID_Msk . . . . .      | 77 |
| 5.24.2.26 ITM_TCR_TraceBusID_Pos . . . . .      | 78 |
| 5.24.2.27 ITM_TCR_TSENA_Msk . . . . .           | 78 |
| 5.24.2.28 ITM_TCR_TSENA_Pos . . . . .           | 78 |
| 5.24.2.29 ITM_TCR_TSPrescale_Msk . . . . .      | 78 |
| 5.24.2.30 ITM_TCR_TSPrescale_Pos . . . . .      | 78 |
| 5.24.2.31 ITM_TPR_PRIVMASK_Msk . . . . .        | 78 |
| 5.24.2.32 ITM_TPR_PRIVMASK_Pos . . . . .        | 78 |
| 5.25 Data Watchpoint and Trace (DWT) . . . . .  | 79 |
| 5.25.1 Detailed Description . . . . .           | 80 |
| 5.25.2 Macro Definition Documentation . . . . . | 80 |
| 5.25.2.1 DWT_CPICNT_CPICNT_Msk . . . . .        | 81 |
| 5.25.2.2 DWT_CPICNT_CPICNT_Pos . . . . .        | 81 |
| 5.25.2.3 DWT_CTRL_CPIEVTEA_Msk . . . . .        | 81 |
| 5.25.2.4 DWT_CTRL_CPIEVTEA_Pos . . . . .        | 81 |
| 5.25.2.5 DWT_CTRL_CYCCNTENA_Msk . . . . .       | 81 |
| 5.25.2.6 DWT_CTRL_CYCCNTENA_Pos . . . . .       | 81 |
| 5.25.2.7 DWT_CTRL_CYCEVTEA_Msk . . . . .        | 81 |
| 5.25.2.8 DWT_CTRL_CYCEVTEA_Pos . . . . .        | 81 |
| 5.25.2.9 DWT_CTRL_CYCTAP_Msk . . . . .          | 82 |
| 5.25.2.10 DWT_CTRL_CYCTAP_Pos . . . . .         | 82 |
| 5.25.2.11 DWT_CTRL_EXCEVTENA_Msk . . . . .      | 82 |
| 5.25.2.12 DWT_CTRL_EXCEVTENA_Pos . . . . .      | 82 |
| 5.25.2.13 DWT_CTRL_EXCTRCENA_Msk . . . . .      | 82 |
| 5.25.2.14 DWT_CTRL_EXCTRCENA_Pos . . . . .      | 82 |
| 5.25.2.15 DWT_CTRL_FOLDEVTENA_Msk . . . . .     | 82 |
| 5.25.2.16 DWT_CTRL_FOLDEVTENA_Pos . . . . .     | 82 |
| 5.25.2.17 DWT_CTRL_LSUEVTENA_Msk . . . . .      | 83 |
| 5.25.2.18 DWT_CTRL_LSUEVTENA_Pos . . . . .      | 83 |
| 5.25.2.19 DWT_CTRL_NOCYCCNT_Msk . . . . .       | 83 |

---

|                                                 |    |
|-------------------------------------------------|----|
| 5.25.2.20 DWT_CTRL_NOCYCCNT_Pos . . . . .       | 83 |
| 5.25.2.21 DWT_CTRL_NOEXTTRIG_Msk . . . . .      | 83 |
| 5.25.2.22 DWT_CTRL_NOEXTTRIG_Pos . . . . .      | 83 |
| 5.25.2.23 DWT_CTRL_NOPRFCNT_Msk . . . . .       | 83 |
| 5.25.2.24 DWT_CTRL_NOPRFCNT_Pos . . . . .       | 83 |
| 5.25.2.25 DWT_CTRL_NOTRCPKT_Msk . . . . .       | 84 |
| 5.25.2.26 DWT_CTRL_NOTRCPKT_Pos . . . . .       | 84 |
| 5.25.2.27 DWT_CTRL_NUMCOMP_Msk . . . . .        | 84 |
| 5.25.2.28 DWT_CTRL_NUMCOMP_Pos . . . . .        | 84 |
| 5.25.2.29 DWT_CTRL_PCSAMPLENA_Msk . . . . .     | 84 |
| 5.25.2.30 DWT_CTRL_PCSAMPLENA_Pos . . . . .     | 84 |
| 5.25.2.31 DWT_CTRL_POSTINIT_Msk . . . . .       | 84 |
| 5.25.2.32 DWT_CTRL_POSTINIT_Pos . . . . .       | 84 |
| 5.25.2.33 DWT_CTRL_POSTPRESET_Msk . . . . .     | 85 |
| 5.25.2.34 DWT_CTRL_POSTPRESET_Pos . . . . .     | 85 |
| 5.25.2.35 DWT_CTRL_SLEEPEVTENA_Msk . . . . .    | 85 |
| 5.25.2.36 DWT_CTRL_SLEEPEVTENA_Pos . . . . .    | 85 |
| 5.25.2.37 DWT_CTRL_SYNCTAP_Msk . . . . .        | 85 |
| 5.25.2.38 DWT_CTRL_SYNCTAP_Pos . . . . .        | 85 |
| 5.25.2.39 DWT_EXCCNT_EXCCNT_Msk . . . . .       | 85 |
| 5.25.2.40 DWT_EXCCNT_EXCCNT_Pos . . . . .       | 85 |
| 5.25.2.41 DWT_FOLDCNT_FOLDCNT_Msk . . . . .     | 86 |
| 5.25.2.42 DWT_FOLDCNT_FOLDCNT_Pos . . . . .     | 86 |
| 5.25.2.43 DWT_FUNCTION_CYCMATCH_Msk . . . . .   | 86 |
| 5.25.2.44 DWT_FUNCTION_CYCMATCH_Pos . . . . .   | 86 |
| 5.25.2.45 DWT_FUNCTION_DATAVADDR0_Msk . . . . . | 86 |
| 5.25.2.46 DWT_FUNCTION_DATAVADDR0_Pos . . . . . | 86 |
| 5.25.2.47 DWT_FUNCTION_DATAVADDR1_Msk . . . . . | 86 |
| 5.25.2.48 DWT_FUNCTION_DATAVADDR1_Pos . . . . . | 86 |
| 5.25.2.49 DWT_FUNCTION_DATAVMATCH_Msk . . . . . | 87 |
| 5.25.2.50 DWT_FUNCTION_DATAVMATCH_Pos . . . . . | 87 |
| 5.25.2.51 DWT_FUNCTION_DATAVSIZE_Msk . . . . .  | 87 |
| 5.25.2.52 DWT_FUNCTION_DATAVSIZE_Pos . . . . .  | 87 |
| 5.25.2.53 DWT_FUNCTION_EMITRANGE_Msk . . . . .  | 87 |
| 5.25.2.54 DWT_FUNCTION_EMITRANGE_Pos . . . . .  | 87 |
| 5.25.2.55 DWT_FUNCTION_FUNCTION_Msk . . . . .   | 87 |
| 5.25.2.56 DWT_FUNCTION_FUNCTION_Pos . . . . .   | 87 |
| 5.25.2.57 DWT_FUNCTION_LNK1ENA_Msk . . . . .    | 88 |
| 5.25.2.58 DWT_FUNCTION_LNK1ENA_Pos . . . . .    | 88 |
| 5.25.2.59 DWT_FUNCTION_MATCHED_Msk . . . . .    | 88 |
| 5.25.2.60 DWT_FUNCTION_MATCHED_Pos . . . . .    | 88 |
| 5.25.2.61 DWT_LSUCNT_LSUCNT_Msk . . . . .       | 88 |

---

|                                                 |    |
|-------------------------------------------------|----|
| 5.25.2.62 DWT_LSUCNT_LSUCNT_Pos . . . . .       | 88 |
| 5.25.2.63 DWT_MASK_MASK_Msk . . . . .           | 88 |
| 5.25.2.64 DWT_MASK_MASK_Pos . . . . .           | 88 |
| 5.25.2.65 DWT_SLEEPCNT_SLEEPCNT_Msk . . . . .   | 89 |
| 5.25.2.66 DWT_SLEEPCNT_SLEEPCNT_Pos . . . . .   | 89 |
| 5.26 Trace Port Interface (TPI) . . . . .       | 89 |
| 5.26.1 Detailed Description . . . . .           | 91 |
| 5.26.2 Macro Definition Documentation . . . . . | 91 |
| 5.26.2.1 TPI_ACPR_PRESCALER_Msk . . . . .       | 91 |
| 5.26.2.2 TPI_ACPR_PRESCALER_Pos . . . . .       | 91 |
| 5.26.2.3 TPI_DEVID_AsynClkIn_Msk . . . . .      | 91 |
| 5.26.2.4 TPI_DEVID_AsynClkIn_Pos . . . . .      | 91 |
| 5.26.2.5 TPI_DEVID_MANCVALID_Msk . . . . .      | 91 |
| 5.26.2.6 TPI_DEVID_MANCVALID_Pos . . . . .      | 91 |
| 5.26.2.7 TPI_DEVID_MinBufSz_Msk . . . . .       | 92 |
| 5.26.2.8 TPI_DEVID_MinBufSz_Pos . . . . .       | 92 |
| 5.26.2.9 TPI_DEVID_NrTraceInput_Msk . . . . .   | 92 |
| 5.26.2.10 TPI_DEVID_NrTraceInput_Pos . . . . .  | 92 |
| 5.26.2.11 TPI_DEVID_NRZVALID_Msk . . . . .      | 92 |
| 5.26.2.12 TPI_DEVID_NRZVALID_Pos . . . . .      | 92 |
| 5.26.2.13 TPI_DEVID_PTINVALID_Msk . . . . .     | 92 |
| 5.26.2.14 TPI_DEVID_PTINVALID_Pos . . . . .     | 92 |
| 5.26.2.15 TPI_DEVTYPE_MajorType_Msk . . . . .   | 93 |
| 5.26.2.16 TPI_DEVTYPE_MajorType_Pos . . . . .   | 93 |
| 5.26.2.17 TPI_DEVTYPE_SubType_Msk . . . . .     | 93 |
| 5.26.2.18 TPI_DEVTYPE_SubType_Pos . . . . .     | 93 |
| 5.26.2.19 TPI_FFCR_EnFCont_Msk . . . . .        | 93 |
| 5.26.2.20 TPI_FFCR_EnFCont_Pos . . . . .        | 93 |
| 5.26.2.21 TPI_FFCR_TrigIn_Msk . . . . .         | 93 |
| 5.26.2.22 TPI_FFCR_TrigIn_Pos . . . . .         | 93 |
| 5.26.2.23 TPI_FFSR_FInProg_Msk . . . . .        | 94 |
| 5.26.2.24 TPI_FFSR_FInProg_Pos . . . . .        | 94 |
| 5.26.2.25 TPI_FFSR_FtNonStop_Msk . . . . .      | 94 |
| 5.26.2.26 TPI_FFSR_FtNonStop_Pos . . . . .      | 94 |
| 5.26.2.27 TPI_FFSR_FtStopped_Msk . . . . .      | 94 |
| 5.26.2.28 TPI_FFSR_FtStopped_Pos . . . . .      | 94 |
| 5.26.2.29 TPI_FFSR_TCPresent_Msk . . . . .      | 94 |
| 5.26.2.30 TPI_FFSR_TCPresent_Pos . . . . .      | 94 |
| 5.26.2.31 TPI_FIFO0_ETM0_Msk . . . . .          | 95 |
| 5.26.2.32 TPI_FIFO0_ETM0_Pos . . . . .          | 95 |
| 5.26.2.33 TPI_FIFO0_ETM1_Msk . . . . .          | 95 |
| 5.26.2.34 TPI_FIFO0_ETM1_Pos . . . . .          | 95 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.26.2.35 TPI_FIFO0_ETM2_Msk . . . . .          | 95  |
| 5.26.2.36 TPI_FIFO0_ETM2_Pos . . . . .          | 95  |
| 5.26.2.37 TPI_FIFO0_ETM_ATVALID_Msk . . . . .   | 95  |
| 5.26.2.38 TPI_FIFO0_ETM_ATVALID_Pos . . . . .   | 95  |
| 5.26.2.39 TPI_FIFO0_ETM_bytecount_Msk . . . . . | 96  |
| 5.26.2.40 TPI_FIFO0_ETM_bytecount_Pos . . . . . | 96  |
| 5.26.2.41 TPI_FIFO0_ITM_ATVALID_Msk . . . . .   | 96  |
| 5.26.2.42 TPI_FIFO0_ITM_ATVALID_Pos . . . . .   | 96  |
| 5.26.2.43 TPI_FIFO0_ITM_bytecount_Msk . . . . . | 96  |
| 5.26.2.44 TPI_FIFO0_ITM_bytecount_Pos . . . . . | 96  |
| 5.26.2.45 TPI_FIFO1_ETM_ATVALID_Msk . . . . .   | 96  |
| 5.26.2.46 TPI_FIFO1_ETM_ATVALID_Pos . . . . .   | 96  |
| 5.26.2.47 TPI_FIFO1_ETM_bytecount_Msk . . . . . | 97  |
| 5.26.2.48 TPI_FIFO1_ETM_bytecount_Pos . . . . . | 97  |
| 5.26.2.49 TPI_FIFO1_ITM0_Msk . . . . .          | 97  |
| 5.26.2.50 TPI_FIFO1_ITM0_Pos . . . . .          | 97  |
| 5.26.2.51 TPI_FIFO1_ITM1_Msk . . . . .          | 97  |
| 5.26.2.52 TPI_FIFO1_ITM1_Pos . . . . .          | 97  |
| 5.26.2.53 TPI_FIFO1_ITM2_Msk . . . . .          | 97  |
| 5.26.2.54 TPI_FIFO1_ITM2_Pos . . . . .          | 97  |
| 5.26.2.55 TPI_FIFO1_ITM_ATVALID_Msk . . . . .   | 98  |
| 5.26.2.56 TPI_FIFO1_ITM_ATVALID_Pos . . . . .   | 98  |
| 5.26.2.57 TPI_FIFO1_ITM_bytecount_Msk . . . . . | 98  |
| 5.26.2.58 TPI_FIFO1_ITM_bytecount_Pos . . . . . | 98  |
| 5.26.2.59 TPI_ITATBCTR0_ATREADY_Msk . . . . .   | 98  |
| 5.26.2.60 TPI_ITATBCTR0_ATREADY_Pos . . . . .   | 98  |
| 5.26.2.61 TPI_ITATBCTR2_ATREADY_Msk . . . . .   | 98  |
| 5.26.2.62 TPI_ITATBCTR2_ATREADY_Pos . . . . .   | 98  |
| 5.26.2.63 TPI_ITCTRL_Mode_Msk . . . . .         | 99  |
| 5.26.2.64 TPI_ITCTRL_Mode_Pos . . . . .         | 99  |
| 5.26.2.65 TPI_SPPR_TXMODE_Msk . . . . .         | 99  |
| 5.26.2.66 TPI_SPPR_TXMODE_Pos . . . . .         | 99  |
| 5.26.2.67 TPI_TRIGGER_TRIGGER_Msk . . . . .     | 99  |
| 5.26.2.68 TPI_TRIGGER_TRIGGER_Pos . . . . .     | 99  |
| 5.27 Core Debug Registers (CoreDebug) . . . . . | 99  |
| 5.27.1 Detailed Description . . . . .           | 101 |
| 5.27.2 Macro Definition Documentation . . . . . | 101 |
| 5.27.2.1 CoreDebug_DCRSR_REGSEL_Msk . . . . .   | 101 |
| 5.27.2.2 CoreDebug_DCRSR_REGSEL_Pos . . . . .   | 101 |
| 5.27.2.3 CoreDebug_DCRSR_REGWnR_Msk . . . . .   | 101 |
| 5.27.2.4 CoreDebug_DCRSR_REGWnR_Pos . . . . .   | 101 |
| 5.27.2.5 CoreDebug_DEMCR_MON_EN_Msk . . . . .   | 102 |

---

|                                                      |     |
|------------------------------------------------------|-----|
| 5.27.2.6 CoreDebug_DEMCR_MON_EN_Pos . . . . .        | 102 |
| 5.27.2.7 CoreDebug_DEMCR_MON_PEND_Msk . . . . .      | 102 |
| 5.27.2.8 CoreDebug_DEMCR_MON_PEND_Pos . . . . .      | 102 |
| 5.27.2.9 CoreDebug_DEMCR_MON_REQ_Msk . . . . .       | 102 |
| 5.27.2.10 CoreDebug_DEMCR_MON_REQ_Pos . . . . .      | 102 |
| 5.27.2.11 CoreDebug_DEMCR_MON_STEP_Msk . . . . .     | 102 |
| 5.27.2.12 CoreDebug_DEMCR_MON_STEP_Pos . . . . .     | 102 |
| 5.27.2.13 CoreDebug_DEMCR_TRCENA_Msk . . . . .       | 103 |
| 5.27.2.14 CoreDebug_DEMCR_TRCENA_Pos . . . . .       | 103 |
| 5.27.2.15 CoreDebug_DEMCR_VC_BUSERR_Msk . . . . .    | 103 |
| 5.27.2.16 CoreDebug_DEMCR_VC_BUSERR_Pos . . . . .    | 103 |
| 5.27.2.17 CoreDebug_DEMCR_VC_CHKERR_Msk . . . . .    | 103 |
| 5.27.2.18 CoreDebug_DEMCR_VC_CHKERR_Pos . . . . .    | 103 |
| 5.27.2.19 CoreDebug_DEMCR_VC_CORERESET_Msk . . . . . | 103 |
| 5.27.2.20 CoreDebug_DEMCR_VC_CORERESET_Pos . . . . . | 103 |
| 5.27.2.21 CoreDebug_DEMCR_VC_HARDERR_Msk . . . . .   | 104 |
| 5.27.2.22 CoreDebug_DEMCR_VC_HARDERR_Pos . . . . .   | 104 |
| 5.27.2.23 CoreDebug_DEMCR_VC_INTERR_Msk . . . . .    | 104 |
| 5.27.2.24 CoreDebug_DEMCR_VC_INTERR_Pos . . . . .    | 104 |
| 5.27.2.25 CoreDebug_DEMCR_VC_MMERR_Msk . . . . .     | 104 |
| 5.27.2.26 CoreDebug_DEMCR_VC_MMERR_Pos . . . . .     | 104 |
| 5.27.2.27 CoreDebug_DEMCR_VC_NOCPERR_Msk . . . . .   | 104 |
| 5.27.2.28 CoreDebug_DEMCR_VC_NOCPERR_Pos . . . . .   | 104 |
| 5.27.2.29 CoreDebug_DEMCR_VC_STATERR_Msk . . . . .   | 105 |
| 5.27.2.30 CoreDebug_DEMCR_VC_STATERR_Pos . . . . .   | 105 |
| 5.27.2.31 CoreDebug_DHCSR_C_DEBUGEN_Msk . . . . .    | 105 |
| 5.27.2.32 CoreDebug_DHCSR_C_DEBUGEN_Pos . . . . .    | 105 |
| 5.27.2.33 CoreDebug_DHCSR_C_HALT_Msk . . . . .       | 105 |
| 5.27.2.34 CoreDebug_DHCSR_C_HALT_Pos . . . . .       | 105 |
| 5.27.2.35 CoreDebug_DHCSR_C_MASKINTS_Msk . . . . .   | 105 |
| 5.27.2.36 CoreDebug_DHCSR_C_MASKINTS_Pos . . . . .   | 105 |
| 5.27.2.37 CoreDebug_DHCSR_C_SNAPSTALL_Msk . . . . .  | 106 |
| 5.27.2.38 CoreDebug_DHCSR_C_SNAPSTALL_Pos . . . . .  | 106 |
| 5.27.2.39 CoreDebug_DHCSR_C_STEP_Msk . . . . .       | 106 |
| 5.27.2.40 CoreDebug_DHCSR_C_STEP_Pos . . . . .       | 106 |
| 5.27.2.41 CoreDebug_DHCSR_DBGKEY_Msk . . . . .       | 106 |
| 5.27.2.42 CoreDebug_DHCSR_DBGKEY_Pos . . . . .       | 106 |
| 5.27.2.43 CoreDebug_DHCSR_S_HALT_Msk . . . . .       | 106 |
| 5.27.2.44 CoreDebug_DHCSR_S_HALT_Pos . . . . .       | 106 |
| 5.27.2.45 CoreDebug_DHCSR_S_LOCKUP_Msk . . . . .     | 107 |
| 5.27.2.46 CoreDebug_DHCSR_S_LOCKUP_Pos . . . . .     | 107 |
| 5.27.2.47 CoreDebug_DHCSR_S_REGRDY_Msk . . . . .     | 107 |

---

|                                                     |     |
|-----------------------------------------------------|-----|
| 5.27.2.48 CoreDebug_DHCSR_S_REGRDY_Pos . . . . .    | 107 |
| 5.27.2.49 CoreDebug_DHCSR_S_RESET_ST_Msk . . . . .  | 107 |
| 5.27.2.50 CoreDebug_DHCSR_S_RESET_ST_Pos . . . . .  | 107 |
| 5.27.2.51 CoreDebug_DHCSR_S_RETIRE_ST_Msk . . . . . | 107 |
| 5.27.2.52 CoreDebug_DHCSR_S_RETIRE_ST_Pos . . . . . | 107 |
| 5.27.2.53 CoreDebug_DHCSR_S_SLEEP_Msk . . . . .     | 108 |
| 5.27.2.54 CoreDebug_DHCSR_S_SLEEP_Pos . . . . .     | 108 |
| 5.28 Core Definitions . . . . .                     | 108 |
| 5.28.1 Detailed Description . . . . .               | 109 |
| 5.28.2 Macro Definition Documentation . . . . .     | 109 |
| 5.28.2.1 CoreDebug . . . . .                        | 109 |
| 5.28.2.2 CoreDebug_BASE . . . . .                   | 109 |
| 5.28.2.3 DWT . . . . .                              | 109 |
| 5.28.2.4 DWT_BASE . . . . .                         | 109 |
| 5.28.2.5 ITM . . . . .                              | 109 |
| 5.28.2.6 ITM_BASE . . . . .                         | 110 |
| 5.28.2.7 NVIC . . . . .                             | 110 |
| 5.28.2.8 NVIC_BASE . . . . .                        | 110 |
| 5.28.2.9 SCB . . . . .                              | 110 |
| 5.28.2.10 SCB_BASE . . . . .                        | 110 |
| 5.28.2.11 SCnSCB . . . . .                          | 110 |
| 5.28.2.12 SCS_BASE . . . . .                        | 110 |
| 5.28.2.13 SysTick . . . . .                         | 111 |
| 5.28.2.14 SysTick_BASE . . . . .                    | 111 |
| 5.28.2.15 TPI . . . . .                             | 111 |
| 5.28.2.16 TPI_BASE . . . . .                        | 111 |
| 5.29 Functions and Instructions Reference . . . . . | 111 |
| 5.29.1 Detailed Description . . . . .               | 112 |
| 5.30 NVIC Functions . . . . .                       | 112 |
| 5.30.1 Detailed Description . . . . .               | 113 |
| 5.30.2 Function Documentation . . . . .             | 113 |
| 5.30.2.1 NVIC_ClearPendingIRQ() . . . . .           | 113 |
| 5.30.2.2 NVIC_DecodePriority() . . . . .            | 113 |
| 5.30.2.3 NVIC_DisableIRQ() . . . . .                | 114 |
| 5.30.2.4 NVIC_EnableIRQ() . . . . .                 | 114 |
| 5.30.2.5 NVIC_EncodePriority() . . . . .            | 114 |
| 5.30.2.6 NVIC_GetActive() . . . . .                 | 115 |
| 5.30.2.7 NVIC_GetPendingIRQ() . . . . .             | 115 |
| 5.30.2.8 NVIC_GetPriority() . . . . .               | 115 |
| 5.30.2.9 NVIC_GetPriorityGrouping() . . . . .       | 116 |
| 5.30.2.10 NVIC_SetPendingIRQ() . . . . .            | 116 |
| 5.30.2.11 NVIC_SetPriority() . . . . .              | 116 |

---

|                                       |     |
|---------------------------------------|-----|
| 5.30.2.12 NVIC_SetPriorityGrouping()  | 117 |
| 5.30.2.13 NVIC_SystemReset()          | 117 |
| 5.31 SysTick Functions                | 118 |
| 5.31.1 Detailed Description           | 118 |
| 5.31.2 Function Documentation         | 118 |
| 5.31.2.1 SysTick_Config()             | 118 |
| 5.32 ITM Functions                    | 119 |
| 5.32.1 Detailed Description           | 123 |
| 5.32.2 Macro Definition Documentation | 123 |
| 5.32.2.1 ITM_RXBUFFER_EMPTY           | 123 |
| 5.32.3 Function Documentation         | 123 |
| 5.32.3.1 ITM_CheckChar()              | 123 |
| 5.32.3.2 ITM_ReceiveChar()            | 124 |
| 5.32.3.3 ITM_SendChar()               | 124 |
| 5.32.4 Variable Documentation         | 124 |
| 5.32.4.1 _reserved0 [1/8]             | 124 |
| 5.32.4.2 [2/8]                        | 125 |
| 5.32.4.3 _reserved0 [3/8]             | 125 |
| 5.32.4.4 [4/8]                        | 125 |
| 5.32.4.5 _reserved0 [5/8]             | 125 |
| 5.32.4.6 [6/8]                        | 125 |
| 5.32.4.7 _reserved0 [7/8]             | 125 |
| 5.32.4.8 [8/8]                        | 125 |
| 5.32.4.9 _reserved1 [1/4]             | 126 |
| 5.32.4.10 [2/4]                       | 126 |
| 5.32.4.11 [3/4]                       | 126 |
| 5.32.4.12 _reserved1 [4/4]            | 126 |
| 5.32.4.13 ACPR                        | 126 |
| 5.32.4.14 ACTLR                       | 126 |
| 5.32.4.15 ADR                         | 126 |
| 5.32.4.16 AFSR                        | 127 |
| 5.32.4.17 AIRCR                       | 127 |
| 5.32.4.18 [1/4]                       | 127 |
| 5.32.4.19 [2/4]                       | 127 |
| 5.32.4.20 [3/4]                       | 127 |
| 5.32.4.21 [4/4]                       | 127 |
| 5.32.4.22 BFAR                        | 127 |
| 5.32.4.23 C [1/4]                     | 128 |
| 5.32.4.24 [2/4]                       | 128 |
| 5.32.4.25 C [3/4]                     | 128 |
| 5.32.4.26 [4/4]                       | 128 |
| 5.32.4.27 CALIB                       | 128 |

---

|                                |     |
|--------------------------------|-----|
| 5.32.4.28 CCR . . . . .        | 128 |
| 5.32.4.29 CFSR . . . . .       | 128 |
| 5.32.4.30 CID0 . . . . .       | 129 |
| 5.32.4.31 CID1 . . . . .       | 129 |
| 5.32.4.32 CID2 . . . . .       | 129 |
| 5.32.4.33 CID3 . . . . .       | 129 |
| 5.32.4.34 CLAIMCLR . . . . .   | 129 |
| 5.32.4.35 CLAIMSET . . . . .   | 129 |
| 5.32.4.36 COMP0 . . . . .      | 129 |
| 5.32.4.37 COMP1 . . . . .      | 130 |
| 5.32.4.38 COMP2 . . . . .      | 130 |
| 5.32.4.39 COMP3 . . . . .      | 130 |
| 5.32.4.40 CPACR . . . . .      | 130 |
| 5.32.4.41 CPICNT . . . . .     | 130 |
| 5.32.4.42 CPUID . . . . .      | 130 |
| 5.32.4.43 CSPSR . . . . .      | 130 |
| 5.32.4.44 CTRL [1/2] . . . . . | 131 |
| 5.32.4.45 CTRL [2/2] . . . . . | 131 |
| 5.32.4.46 CYCCNT . . . . .     | 131 |
| 5.32.4.47 DCRDR . . . . .      | 131 |
| 5.32.4.48 DCRSR . . . . .      | 131 |
| 5.32.4.49 DEMCR . . . . .      | 131 |
| 5.32.4.50 DEVID . . . . .      | 131 |
| 5.32.4.51 DEVTYPE . . . . .    | 132 |
| 5.32.4.52 DFR . . . . .        | 132 |
| 5.32.4.53 DFSR . . . . .       | 132 |
| 5.32.4.54 DHCSR . . . . .      | 132 |
| 5.32.4.55 EXCCNT . . . . .     | 132 |
| 5.32.4.56 FFCR . . . . .       | 132 |
| 5.32.4.57 FFSR . . . . .       | 132 |
| 5.32.4.58 FIFO0 . . . . .      | 133 |
| 5.32.4.59 FIFO1 . . . . .      | 133 |
| 5.32.4.60 FOLDCNT . . . . .    | 133 |
| 5.32.4.61 FPCA [1/2] . . . . . | 133 |
| 5.32.4.62 [2/2] . . . . .      | 133 |
| 5.32.4.63 FSCR . . . . .       | 133 |
| 5.32.4.64 FUNCTION0 . . . . .  | 133 |
| 5.32.4.65 FUNCTION1 . . . . .  | 134 |
| 5.32.4.66 FUNCTION2 . . . . .  | 134 |
| 5.32.4.67 FUNCTION3 . . . . .  | 134 |
| 5.32.4.68 [1/4] . . . . .      | 134 |
| 5.32.4.69 GE [2/4] . . . . .   | 134 |

---

|                                  |     |
|----------------------------------|-----|
| 5.32.4.70 GE [3/4] . . . . .     | 134 |
| 5.32.4.71 [4/4] . . . . .        | 134 |
| 5.32.4.72 HFSR . . . . .         | 135 |
| 5.32.4.73 IABR . . . . .         | 135 |
| 5.32.4.74 ICER . . . . .         | 135 |
| 5.32.4.75 ICPR . . . . .         | 135 |
| 5.32.4.76 ICSR . . . . .         | 135 |
| 5.32.4.77 ICTR . . . . .         | 135 |
| 5.32.4.78 IMCR . . . . .         | 135 |
| 5.32.4.79 IP . . . . .           | 136 |
| 5.32.4.80 IRR . . . . .          | 136 |
| 5.32.4.81 ISAR . . . . .         | 136 |
| 5.32.4.82 ISER . . . . .         | 136 |
| 5.32.4.83 ISPR . . . . .         | 136 |
| 5.32.4.84 ISR [1/4] . . . . .    | 136 |
| 5.32.4.85 [2/4] . . . . .        | 136 |
| 5.32.4.86 ISR [3/4] . . . . .    | 137 |
| 5.32.4.87 [4/4] . . . . .        | 137 |
| 5.32.4.88 IT [1/2] . . . . .     | 137 |
| 5.32.4.89 [2/2] . . . . .        | 137 |
| 5.32.4.90 ITATBCTR0 . . . . .    | 137 |
| 5.32.4.91 ITATBCTR2 . . . . .    | 137 |
| 5.32.4.92 ITCTRL . . . . .       | 137 |
| 5.32.4.93 ITM_RxBuffer . . . . . | 138 |
| 5.32.4.94 IWR . . . . .          | 138 |
| 5.32.4.95 LAR . . . . .          | 138 |
| 5.32.4.96 LOAD . . . . .         | 138 |
| 5.32.4.97 LSR . . . . .          | 138 |
| 5.32.4.98 LSUCNT . . . . .       | 138 |
| 5.32.4.99 MASK0 . . . . .        | 138 |
| 5.32.4.100 MASK1 . . . . .       | 139 |
| 5.32.4.101 MASK2 . . . . .       | 139 |
| 5.32.4.102 MASK3 . . . . .       | 139 |
| 5.32.4.103 MMFAR . . . . .       | 139 |
| 5.32.4.104 MMFR . . . . .        | 139 |
| 5.32.4.105 [1/4] . . . . .       | 139 |
| 5.32.4.106 N [2/4] . . . . .     | 139 |
| 5.32.4.107 [3/4] . . . . .       | 140 |
| 5.32.4.108 N [4/4] . . . . .     | 140 |
| 5.32.4.109 nPRIV [1/2] . . . . . | 140 |
| 5.32.4.110 [2/2] . . . . .       | 140 |
| 5.32.4.111 PCSR . . . . .        | 140 |

---

|                                  |     |
|----------------------------------|-----|
| 5.32.4.112 PFR . . . . .         | 140 |
| 5.32.4.113 PID0 . . . . .        | 140 |
| 5.32.4.114 PID1 . . . . .        | 141 |
| 5.32.4.115 PID2 . . . . .        | 141 |
| 5.32.4.116 PID3 . . . . .        | 141 |
| 5.32.4.117 PID4 . . . . .        | 141 |
| 5.32.4.118 PID5 . . . . .        | 141 |
| 5.32.4.119 PID6 . . . . .        | 141 |
| 5.32.4.120 PID7 . . . . .        | 141 |
| 5.32.4.121 . . . . .             | 141 |
| 5.32.4.122 [1/4] . . . . .       | 142 |
| 5.32.4.123 Q [2/4] . . . . .     | 142 |
| 5.32.4.124 [3/4] . . . . .       | 142 |
| 5.32.4.125 Q [4/4] . . . . .     | 142 |
| 5.32.4.126 SCR . . . . .         | 142 |
| 5.32.4.127 SHCSR . . . . .       | 142 |
| 5.32.4.128 SHP . . . . .         | 142 |
| 5.32.4.129 SLEEPCNT . . . . .    | 143 |
| 5.32.4.130 SPPR . . . . .        | 143 |
| 5.32.4.131 SPSEL [1/2] . . . . . | 143 |
| 5.32.4.132 [2/2] . . . . .       | 143 |
| 5.32.4.133 SSPSR . . . . .       | 143 |
| 5.32.4.134 STIR . . . . .        | 143 |
| 5.32.4.135 [1/2] . . . . .       | 143 |
| 5.32.4.136 T [2/2] . . . . .     | 144 |
| 5.32.4.137 TCR . . . . .         | 144 |
| 5.32.4.138 TER . . . . .         | 144 |
| 5.32.4.139 TPR . . . . .         | 144 |
| 5.32.4.140 TRIGGER . . . . .     | 144 |
| 5.32.4.141 u16 [1/2] . . . . .   | 144 |
| 5.32.4.142 [2/2] . . . . .       | 144 |
| 5.32.4.143 u32 [1/2] . . . . .   | 145 |
| 5.32.4.144 [2/2] . . . . .       | 145 |
| 5.32.4.145 [1/2] . . . . .       | 145 |
| 5.32.4.146 u8 [2/2] . . . . .    | 145 |
| 5.32.4.147 [1/4] . . . . .       | 145 |
| 5.32.4.148 V [2/4] . . . . .     | 145 |
| 5.32.4.149 [3/4] . . . . .       | 145 |
| 5.32.4.150 V [4/4] . . . . .     | 146 |
| 5.32.4.151 VAL . . . . .         | 146 |
| 5.32.4.152 VTOR . . . . .        | 146 |
| 5.32.4.153 w [1/4] . . . . .     | 146 |

---

|                                                     |     |
|-----------------------------------------------------|-----|
| 5.32.4.154 w [2/4] . . . . .                        | 146 |
| 5.32.4.155 w [3/4] . . . . .                        | 146 |
| 5.32.4.156 w [4/4] . . . . .                        | 146 |
| 5.32.4.157 Z [1/4] . . . . .                        | 147 |
| 5.32.4.158 [2/4] . . . . .                          | 147 |
| 5.32.4.159 [3/4] . . . . .                          | 147 |
| 5.32.4.160 Z [4/4] . . . . .                        | 147 |
| 5.33 CMSIS Core Register Access Functions . . . . . | 147 |
| 5.34 CMSIS Core Instruction Interface . . . . .     | 148 |
| 5.35 CMSIS SIMD Intrinsics . . . . .                | 148 |
| 5.36 Platform Standard Types . . . . .              | 148 |
| 5.36.1 Detailed Description . . . . .               | 149 |
| 5.36.2 Macro Definition Documentation . . . . .     | 150 |
| 5.36.2.1 CPU_BIT_ORDER . . . . .                    | 150 |
| 5.36.2.2 CPU_BYTE_ORDER . . . . .                   | 150 |
| 5.36.2.3 CPU_TYPE . . . . .                         | 150 |
| 5.36.2.4 CPU_TYPE_16 . . . . .                      | 150 |
| 5.36.2.5 CPU_TYPE_32 . . . . .                      | 150 |
| 5.36.2.6 CPU_TYPE_64 . . . . .                      | 150 |
| 5.36.2.7 CPU_TYPE_8 . . . . .                       | 151 |
| 5.36.2.8 FALSE . . . . .                            | 151 |
| 5.36.2.9 FLAG_RESET . . . . .                       | 151 |
| 5.36.2.10 FLAG_SET . . . . .                        | 151 |
| 5.36.2.11 HIGH_BYTE_FIRST . . . . .                 | 151 |
| 5.36.2.12 LOW_BYTE_FIRST . . . . .                  | 151 |
| 5.36.2.13 LSB_FIRST . . . . .                       | 151 |
| 5.36.2.14 MSB_FIRST . . . . .                       | 152 |
| 5.36.2.15 RESET . . . . .                           | 152 |
| 5.36.2.16 SET . . . . .                             | 152 |
| 5.36.2.17 TRUE . . . . .                            | 152 |
| 5.36.3 Typedef Documentation . . . . .              | 152 |
| 5.36.3.1 boolean . . . . .                          | 152 |
| 5.36.3.2 ConstVoidPtr . . . . .                     | 152 |
| 5.36.3.3 float32 . . . . .                          | 153 |
| 5.36.3.4 float64 . . . . .                          | 153 |
| 5.36.3.5 sint16 . . . . .                           | 153 |
| 5.36.3.6 sint16_least . . . . .                     | 153 |
| 5.36.3.7 sint32 . . . . .                           | 153 |
| 5.36.3.8 sint32_least . . . . .                     | 153 |
| 5.36.3.9 sint64 . . . . .                           | 153 |
| 5.36.3.10 sint8 . . . . .                           | 154 |
| 5.36.3.11 sint8_least . . . . .                     | 154 |

---

|                                                     |     |
|-----------------------------------------------------|-----|
| 5.36.3.12 uint16 . . . . .                          | 154 |
| 5.36.3.13 uint16_least . . . . .                    | 154 |
| 5.36.3.14 uint32 . . . . .                          | 154 |
| 5.36.3.15 uint32_least . . . . .                    | 154 |
| 5.36.3.16 uint64 . . . . .                          | 154 |
| 5.36.3.17 uint8 . . . . .                           | 154 |
| 5.36.3.18 uint8_least . . . . .                     | 155 |
| 5.36.3.19 VoidPtr . . . . .                         | 155 |
| 5.36.3.20 vuint16_t . . . . .                       | 155 |
| 5.36.3.21 vuint32_t . . . . .                       | 155 |
| 5.36.3.22 vuint8_t . . . . .                        | 155 |
| 5.37 STM32F401xx MCU Header File . . . . .          | 156 |
| 5.37.1 Detailed Description . . . . .               | 157 |
| 5.38 Memory Base Addresses . . . . .                | 157 |
| 5.38.1 Detailed Description . . . . .               | 157 |
| 5.39 Cortex-M4 Peripherals Base Addresses . . . . . | 157 |
| 5.39.1 Detailed Description . . . . .               | 158 |
| 5.40 AHB Peripherals Base Addresses . . . . .       | 158 |
| 5.40.1 Detailed Description . . . . .               | 158 |
| 5.41 APB2 Peripherals Base Addresses . . . . .      | 158 |
| 5.41.1 Detailed Description . . . . .               | 159 |
| 5.42 APB1 Peripherals Base Addresses . . . . .      | 159 |
| 5.42.1 Detailed Description . . . . .               | 160 |
| 5.43 Peripheral Register Definitions . . . . .      | 160 |
| 5.43.1 Detailed Description . . . . .               | 161 |
| 5.44 NVIC Register Map . . . . .                    | 161 |
| 5.44.1 Detailed Description . . . . .               | 161 |
| 5.45 SCB Register Map . . . . .                     | 162 |
| 5.45.1 Detailed Description . . . . .               | 162 |
| 5.46 SysTick Timer Register Map . . . . .           | 162 |
| 5.46.1 Detailed Description . . . . .               | 162 |
| 5.47 GPIO Register Map . . . . .                    | 163 |
| 5.47.1 Detailed Description . . . . .               | 163 |
| 5.48 RCC Register Map . . . . .                     | 163 |
| 5.48.1 Detailed Description . . . . .               | 163 |
| 5.49 EXTI Register Map . . . . .                    | 164 |
| 5.49.1 Detailed Description . . . . .               | 164 |
| 5.50 SYSCFG Register Map . . . . .                  | 164 |
| 5.50.1 Detailed Description . . . . .               | 164 |
| 5.51 USART Register Map . . . . .                   | 165 |
| 5.51.1 Detailed Description . . . . .               | 165 |
| 5.52 SPI Register Map . . . . .                     | 165 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.52.1 Detailed Description . . . . .           | 165 |
| 5.53 I2C Register Map . . . . .                 | 166 |
| 5.53.1 Detailed Description . . . . .           | 166 |
| 5.54 CRC Register Map . . . . .                 | 166 |
| 5.54.1 Detailed Description . . . . .           | 166 |
| 5.55 TIM1 Register Map . . . . .                | 167 |
| 5.55.1 Detailed Description . . . . .           | 167 |
| 5.56 Peripheral Instances . . . . .             | 167 |
| 5.56.1 Detailed Description . . . . .           | 169 |
| 5.57 NVIC Instance . . . . .                    | 169 |
| 5.57.1 Detailed Description . . . . .           | 169 |
| 5.57.2 Macro Definition Documentation . . . . . | 169 |
| 5.57.2.1 NVIC . . . . .                         | 169 |
| 5.58 SCB Instance . . . . .                     | 169 |
| 5.58.1 Detailed Description . . . . .           | 170 |
| 5.58.2 Macro Definition Documentation . . . . . | 170 |
| 5.58.2.1 SCB . . . . .                          | 170 |
| 5.59 SysTick Timer Instance . . . . .           | 170 |
| 5.59.1 Detailed Description . . . . .           | 170 |
| 5.59.2 Macro Definition Documentation . . . . . | 170 |
| 5.59.2.1 STK . . . . .                          | 171 |
| 5.60 GPIO Instances . . . . .                   | 171 |
| 5.60.1 Detailed Description . . . . .           | 171 |
| 5.60.2 Macro Definition Documentation . . . . . | 171 |
| 5.60.2.1 GPIOA . . . . .                        | 171 |
| 5.60.2.2 GPIOB . . . . .                        | 172 |
| 5.60.2.3 GPIOC . . . . .                        | 172 |
| 5.60.2.4 GPIOD . . . . .                        | 172 |
| 5.60.2.5 GPIOE . . . . .                        | 172 |
| 5.61 RCC Instance . . . . .                     | 172 |
| 5.61.1 Detailed Description . . . . .           | 172 |
| 5.61.2 Macro Definition Documentation . . . . . | 173 |
| 5.61.2.1 RCC . . . . .                          | 173 |
| 5.62 EXTI Instance . . . . .                    | 173 |
| 5.62.1 Detailed Description . . . . .           | 173 |
| 5.62.2 Macro Definition Documentation . . . . . | 173 |
| 5.62.2.1 EXTI . . . . .                         | 173 |
| 5.63 SYSCFG Instance . . . . .                  | 174 |
| 5.63.1 Detailed Description . . . . .           | 174 |
| 5.63.2 Macro Definition Documentation . . . . . | 174 |
| 5.63.2.1 SYSCFG . . . . .                       | 174 |
| 5.64 Timer Instances . . . . .                  | 174 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.64.1 Detailed Description . . . . .           | 175 |
| 5.64.2 Macro Definition Documentation . . . . . | 175 |
| 5.64.2.1 TIM1 . . . . .                         | 175 |
| 5.64.2.2 TIM2 . . . . .                         | 175 |
| 5.65 USART Instances . . . . .                  | 175 |
| 5.65.1 Detailed Description . . . . .           | 176 |
| 5.65.2 Macro Definition Documentation . . . . . | 176 |
| 5.65.2.1 USART1 . . . . .                       | 176 |
| 5.65.2.2 USART2 . . . . .                       | 176 |
| 5.65.2.3 USART6 . . . . .                       | 176 |
| 5.66 SPI Instances . . . . .                    | 176 |
| 5.66.1 Detailed Description . . . . .           | 177 |
| 5.66.2 Macro Definition Documentation . . . . . | 177 |
| 5.66.2.1 SPI1 . . . . .                         | 177 |
| 5.66.2.2 SPI2 . . . . .                         | 177 |
| 5.67 I2C Instances . . . . .                    | 177 |
| 5.67.1 Detailed Description . . . . .           | 177 |
| 5.67.2 Macro Definition Documentation . . . . . | 178 |
| 5.67.2.1 I2C1 . . . . .                         | 178 |
| 5.67.2.2 I2C2 . . . . .                         | 178 |
| 5.68 CRC Instance . . . . .                     | 178 |
| 5.68.1 Detailed Description . . . . .           | 178 |
| 5.68.2 Macro Definition Documentation . . . . . | 178 |
| 5.68.2.1 CRC . . . . .                          | 179 |
| 5.69 I2C Registers . . . . .                    | 179 |
| 5.69.1 Detailed Description . . . . .           | 179 |
| 5.70 I2C CR1 Register Bit Definitions . . . . . | 180 |
| 5.70.1 Detailed Description . . . . .           | 181 |
| 5.70.2 Macro Definition Documentation . . . . . | 181 |
| 5.70.2.1 I2C_CR1_ACK . . . . .                  | 181 |
| 5.70.2.2 I2C_CR1_ACK_Msk . . . . .              | 181 |
| 5.70.2.3 I2C_CR1_ACK_Pos . . . . .              | 182 |
| 5.70.2.4 I2C_CR1_ALERT . . . . .                | 182 |
| 5.70.2.5 I2C_CR1_ALERT_Msk . . . . .            | 182 |
| 5.70.2.6 I2C_CR1_ALERT_Pos . . . . .            | 182 |
| 5.70.2.7 I2C_CR1_ENARP . . . . .                | 182 |
| 5.70.2.8 I2C_CR1_ENARP_Msk . . . . .            | 182 |
| 5.70.2.9 I2C_CR1_ENARP_Pos . . . . .            | 182 |
| 5.70.2.10 I2C_CR1_ENGC . . . . .                | 183 |
| 5.70.2.11 I2C_CR1_ENGC_Msk . . . . .            | 183 |
| 5.70.2.12 I2C_CR1_ENGC_Pos . . . . .            | 183 |
| 5.70.2.13 I2C_CR1_ENPEC . . . . .               | 183 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.70.2.14 I2C_CR1_ENPEC_Msk . . . . .           | 183 |
| 5.70.2.15 I2C_CR1_ENPEC_Pos . . . . .           | 183 |
| 5.70.2.16 I2C_CR1_NOSTRETCH . . . . .           | 183 |
| 5.70.2.17 I2C_CR1_NOSTRETCH_Msk . . . . .       | 184 |
| 5.70.2.18 I2C_CR1_NOSTRETCH_Pos . . . . .       | 184 |
| 5.70.2.19 I2C_CR1_PE . . . . .                  | 184 |
| 5.70.2.20 I2C_CR1_PE_Msk . . . . .              | 184 |
| 5.70.2.21 I2C_CR1_PE_Pos . . . . .              | 184 |
| 5.70.2.22 I2C_CR1_PEC . . . . .                 | 184 |
| 5.70.2.23 I2C_CR1_PEC_Msk . . . . .             | 184 |
| 5.70.2.24 I2C_CR1_PEC_Pos . . . . .             | 185 |
| 5.70.2.25 I2C_CR1_POS . . . . .                 | 185 |
| 5.70.2.26 I2C_CR1_POS_Msk . . . . .             | 185 |
| 5.70.2.27 I2C_CR1_POS_Pos . . . . .             | 185 |
| 5.70.2.28 I2C_CR1_SMBTYPE . . . . .             | 185 |
| 5.70.2.29 I2C_CR1_SMBTYPE_Msk . . . . .         | 185 |
| 5.70.2.30 I2C_CR1_SMBTYPE_Pos . . . . .         | 185 |
| 5.70.2.31 I2C_CR1_SMBUS . . . . .               | 186 |
| 5.70.2.32 I2C_CR1_SMBUS_Msk . . . . .           | 186 |
| 5.70.2.33 I2C_CR1_SMBUS_Pos . . . . .           | 186 |
| 5.70.2.34 I2C_CR1_START . . . . .               | 186 |
| 5.70.2.35 I2C_CR1_START_Msk . . . . .           | 186 |
| 5.70.2.36 I2C_CR1_START_Pos . . . . .           | 186 |
| 5.70.2.37 I2C_CR1_STOP . . . . .                | 186 |
| 5.70.2.38 I2C_CR1_STOP_Msk . . . . .            | 187 |
| 5.70.2.39 I2C_CR1_STOP_Pos . . . . .            | 187 |
| 5.70.2.40 I2C_CR1_SWRST . . . . .               | 187 |
| 5.70.2.41 I2C_CR1_SWRST_Msk . . . . .           | 187 |
| 5.70.2.42 I2C_CR1_SWRST_Pos . . . . .           | 187 |
| 5.71 I2C CR2 Register Bit Definitions . . . . . | 187 |
| 5.71.1 Detailed Description . . . . .           | 188 |
| 5.71.2 Macro Definition Documentation . . . . . | 188 |
| 5.71.2.1 I2C_CR2_DMAEN . . . . .                | 188 |
| 5.71.2.2 I2C_CR2_DMAEN_Msk . . . . .            | 188 |
| 5.71.2.3 I2C_CR2_DMAEN_Pos . . . . .            | 189 |
| 5.71.2.4 I2C_CR2_FREQ . . . . .                 | 189 |
| 5.71.2.5 I2C_CR2_FREQ_Msk . . . . .             | 189 |
| 5.71.2.6 I2C_CR2_FREQ_Pos . . . . .             | 189 |
| 5.71.2.7 I2C_CR2_ITBUFEN . . . . .              | 189 |
| 5.71.2.8 I2C_CR2_ITBUFEN_Msk . . . . .          | 189 |
| 5.71.2.9 I2C_CR2_ITBUFEN_Pos . . . . .          | 189 |
| 5.71.2.10 I2C_CR2_ITERREN . . . . .             | 190 |

---

|                                                  |     |
|--------------------------------------------------|-----|
| 5.71.2.11 I2C_CR2_ITERREN_Msk . . . . .          | 190 |
| 5.71.2.12 I2C_CR2_ITERREN_Pos . . . . .          | 190 |
| 5.71.2.13 I2C_CR2 ITEVTEN . . . . .              | 190 |
| 5.71.2.14 I2C_CR2 ITEVTEN_Msk . . . . .          | 190 |
| 5.71.2.15 I2C_CR2 ITEVTEN_Pos . . . . .          | 190 |
| 5.71.2.16 I2C_CR2_LAST . . . . .                 | 190 |
| 5.71.2.17 I2C_CR2_LAST_Msk . . . . .             | 191 |
| 5.71.2.18 I2C_CR2_LAST_Pos . . . . .             | 191 |
| 5.72 I2C OAR2 Register Bit Definitions . . . . . | 191 |
| 5.72.1 Detailed Description . . . . .            | 191 |
| 5.72.2 Macro Definition Documentation . . . . .  | 191 |
| 5.72.2.1 I2C_OAR2_ADD2 . . . . .                 | 192 |
| 5.72.2.2 I2C_OAR2_ADD2_Msk . . . . .             | 192 |
| 5.72.2.3 I2C_OAR2_ADD2_Pos . . . . .             | 192 |
| 5.72.2.4 I2C_OAR2_ENDUAL . . . . .               | 192 |
| 5.72.2.5 I2C_OAR2_ENDUAL_Msk . . . . .           | 192 |
| 5.72.2.6 I2C_OAR2_ENDUAL_Pos . . . . .           | 192 |
| 5.73 I2C SR1 Register Bit Definitions . . . . .  | 192 |
| 5.73.1 Detailed Description . . . . .            | 193 |
| 5.73.2 Macro Definition Documentation . . . . .  | 193 |
| 5.73.2.1 I2C_SR1_ADD10 . . . . .                 | 194 |
| 5.73.2.2 I2C_SR1_ADD10_Msk . . . . .             | 194 |
| 5.73.2.3 I2C_SR1_ADD10_Pos . . . . .             | 194 |
| 5.73.2.4 I2C_SR1_ADDR . . . . .                  | 194 |
| 5.73.2.5 I2C_SR1_ADDR_Msk . . . . .              | 194 |
| 5.73.2.6 I2C_SR1_ADDR_Pos . . . . .              | 194 |
| 5.73.2.7 I2C_SR1_AF . . . . .                    | 194 |
| 5.73.2.8 I2C_SR1_AF_Msk . . . . .                | 194 |
| 5.73.2.9 I2C_SR1_AF_Pos . . . . .                | 195 |
| 5.73.2.10 I2C_SR1_ARLO . . . . .                 | 195 |
| 5.73.2.11 I2C_SR1_ARLO_Msk . . . . .             | 195 |
| 5.73.2.12 I2C_SR1_ARLO_Pos . . . . .             | 195 |
| 5.73.2.13 I2C_SR1_BERR . . . . .                 | 195 |
| 5.73.2.14 I2C_SR1_BERR_Msk . . . . .             | 195 |
| 5.73.2.15 I2C_SR1_BERR_Pos . . . . .             | 195 |
| 5.73.2.16 I2C_SR1_BTF . . . . .                  | 195 |
| 5.73.2.17 I2C_SR1_BTF_Msk . . . . .              | 196 |
| 5.73.2.18 I2C_SR1_BTF_Pos . . . . .              | 196 |
| 5.73.2.19 I2C_SR1_OVR . . . . .                  | 196 |
| 5.73.2.20 I2C_SR1_OVR_Msk . . . . .              | 196 |
| 5.73.2.21 I2C_SR1_OVR_Pos . . . . .              | 196 |
| 5.73.2.22 I2C_SR1_PECERR . . . . .               | 196 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.73.2.23 I2C_SR1_PECERR_Msk . . . . .          | 196 |
| 5.73.2.24 I2C_SR1_PECERR_Pos . . . . .          | 196 |
| 5.73.2.25 I2C_SR1_RXNE . . . . .                | 197 |
| 5.73.2.26 I2C_SR1_RXNE_Msk . . . . .            | 197 |
| 5.73.2.27 I2C_SR1_RXNE_Pos . . . . .            | 197 |
| 5.73.2.28 I2C_SR1_SB . . . . .                  | 197 |
| 5.73.2.29 I2C_SR1_SB_Msk . . . . .              | 197 |
| 5.73.2.30 I2C_SR1_SB_Pos . . . . .              | 197 |
| 5.73.2.31 I2C_SR1_SMBALERT . . . . .            | 197 |
| 5.73.2.32 I2C_SR1_SMBALERT_Msk . . . . .        | 198 |
| 5.73.2.33 I2C_SR1_SMBALERT_Pos . . . . .        | 198 |
| 5.73.2.34 I2C_SR1_STOPF . . . . .               | 198 |
| 5.73.2.35 I2C_SR1_STOPF_Msk . . . . .           | 198 |
| 5.73.2.36 I2C_SR1_STOPF_Pos . . . . .           | 198 |
| 5.73.2.37 I2C_SR1_TIMEOUT . . . . .             | 198 |
| 5.73.2.38 I2C_SR1_TIMEOUT_Msk . . . . .         | 198 |
| 5.73.2.39 I2C_SR1_TIMEOUT_Pos . . . . .         | 198 |
| 5.73.2.40 I2C_SR1_TXE . . . . .                 | 199 |
| 5.73.2.41 I2C_SR1_TXE_Msk . . . . .             | 199 |
| 5.73.2.42 I2C_SR1_TXE_Pos . . . . .             | 199 |
| 5.74 I2C SR2 Register Bit Definitions . . . . . | 199 |
| 5.74.1 Detailed Description . . . . .           | 200 |
| 5.74.2 Macro Definition Documentation . . . . . | 200 |
| 5.74.2.1 I2C_SR2_BUSY . . . . .                 | 200 |
| 5.74.2.2 I2C_SR2_BUSY_Msk . . . . .             | 200 |
| 5.74.2.3 I2C_SR2_BUSY_Pos . . . . .             | 200 |
| 5.74.2.4 I2C_SR2_DUALF . . . . .                | 200 |
| 5.74.2.5 I2C_SR2_DUALF_Msk . . . . .            | 200 |
| 5.74.2.6 I2C_SR2_DUALF_Pos . . . . .            | 201 |
| 5.74.2.7 I2C_SR2_GENCALL . . . . .              | 201 |
| 5.74.2.8 I2C_SR2_GENCALL_Msk . . . . .          | 201 |
| 5.74.2.9 I2C_SR2_GENCALL_Pos . . . . .          | 201 |
| 5.74.2.10 I2C_SR2_MSL . . . . .                 | 201 |
| 5.74.2.11 I2C_SR2_MSL_Msk . . . . .             | 201 |
| 5.74.2.12 I2C_SR2_MSL_Pos . . . . .             | 201 |
| 5.74.2.13 I2C_SR2_PEC . . . . .                 | 202 |
| 5.74.2.14 I2C_SR2_PEC_Msk . . . . .             | 202 |
| 5.74.2.15 I2C_SR2_PEC_Pos . . . . .             | 202 |
| 5.74.2.16 I2C_SR2_SMBDEFAULT . . . . .          | 202 |
| 5.74.2.17 I2C_SR2_SMBDEFAULT_Msk . . . . .      | 202 |
| 5.74.2.18 I2C_SR2_SMBDEFAULT_Pos . . . . .      | 202 |
| 5.74.2.19 I2C_SR2_SMBHOST . . . . .             | 202 |

---

|                                                     |     |
|-----------------------------------------------------|-----|
| 5.74.2.20 I2C_SR2_SMBHOST_Msk . . . . .             | 202 |
| 5.74.2.21 I2C_SR2_SMBHOST_Pos . . . . .             | 203 |
| 5.74.2.22 I2C_SR2_TRA . . . . .                     | 203 |
| 5.74.2.23 I2C_SR2_TRA_Msk . . . . .                 | 203 |
| 5.74.2.24 I2C_SR2_TRA_Pos . . . . .                 | 203 |
| 5.75 I2C CCR Register Bit Definitions . . . . .     | 203 |
| 5.75.1 Detailed Description . . . . .               | 204 |
| 5.75.2 Macro Definition Documentation . . . . .     | 204 |
| 5.75.2.1 I2C_CCR_CCR . . . . .                      | 204 |
| 5.75.2.2 I2C_CCR_CCR_Msk . . . . .                  | 204 |
| 5.75.2.3 I2C_CCR_CCR_Pos . . . . .                  | 204 |
| 5.75.2.4 I2C_CCR_DUTY . . . . .                     | 204 |
| 5.75.2.5 I2C_CCR_DUTY_Msk . . . . .                 | 204 |
| 5.75.2.6 I2C_CCR_DUTY_Pos . . . . .                 | 204 |
| 5.76 I2C TRISE Register Bit Definitions . . . . .   | 205 |
| 5.76.1 Detailed Description . . . . .               | 205 |
| 5.76.2 Macro Definition Documentation . . . . .     | 205 |
| 5.76.2.1 I2C_TRISE_TRISE . . . . .                  | 205 |
| 5.76.2.2 I2C_TRISE_TRISE_Msk . . . . .              | 205 |
| 5.76.2.3 I2C_TRISE_TRISE_Pos . . . . .              | 205 |
| 5.77 RCC Bit Position Definitions . . . . .         | 206 |
| 5.77.1 Detailed Description . . . . .               | 207 |
| 5.78 RCC_CR Bit Position Definitions . . . . .      | 207 |
| 5.78.1 Detailed Description . . . . .               | 208 |
| 5.78.2 Macro Definition Documentation . . . . .     | 208 |
| 5.78.2.1 RCC_CR_CSSON . . . . .                     | 208 |
| 5.78.2.2 RCC_CR_HSEBYP . . . . .                    | 208 |
| 5.78.2.3 RCC_CR_HSEON . . . . .                     | 208 |
| 5.78.2.4 RCC_CR_HSERDY . . . . .                    | 208 |
| 5.78.2.5 RCC_CR_HSICAL . . . . .                    | 209 |
| 5.78.2.6 RCC_CR_HSION . . . . .                     | 209 |
| 5.78.2.7 RCC_CR_HSIRDY . . . . .                    | 209 |
| 5.78.2.8 RCC_CR_HSITRIM . . . . .                   | 209 |
| 5.78.2.9 RCC_CR_PLLI2SON . . . . .                  | 209 |
| 5.78.2.10 RCC_CR_PLLI2SRDY . . . . .                | 209 |
| 5.78.2.11 RCC_CR_PLLON . . . . .                    | 209 |
| 5.78.2.12 RCC_CR_PLLRDY . . . . .                   | 209 |
| 5.78.2.13 RCC_CR_PLLSAION . . . . .                 | 210 |
| 5.78.2.14 RCC_CR_PLLSAIRDY . . . . .                | 210 |
| 5.79 RCC_PLLCFGR Bit Position Definitions . . . . . | 210 |
| 5.79.1 Detailed Description . . . . .               | 210 |
| 5.79.2 Macro Definition Documentation . . . . .     | 210 |

---

|                                                  |     |
|--------------------------------------------------|-----|
| 5.79.2.1 RCC_PLLCFGR_PLLM . . . . .              | 211 |
| 5.79.2.2 RCC_PLLCFGR_PLLN . . . . .              | 211 |
| 5.79.2.3 RCC_PLLCFGR_PLLP . . . . .              | 211 |
| 5.79.2.4 RCC_PLLCFGR_PLLQ . . . . .              | 211 |
| 5.79.2.5 RCC_PLLCFGR_PLLSRC . . . . .            | 211 |
| 5.80 RCC_CFGR Bit Position Definitions . . . . . | 211 |
| 5.80.1 Detailed Description . . . . .            | 212 |
| 5.80.2 Macro Definition Documentation . . . . .  | 212 |
| 5.80.2.1 RCC_CFGR_HPRE . . . . .                 | 212 |
| 5.80.2.2 RCC_CFGR_I2SSRC . . . . .               | 212 |
| 5.80.2.3 RCC_CFGR_MCO1 . . . . .                 | 212 |
| 5.80.2.4 RCC_CFGR_MCO1PRE . . . . .              | 212 |
| 5.80.2.5 RCC_CFGR_MCO2 . . . . .                 | 213 |
| 5.80.2.6 RCC_CFGR_MCO2PRE . . . . .              | 213 |
| 5.80.2.7 RCC_CFGR_PPRE1 . . . . .                | 213 |
| 5.80.2.8 RCC_CFGR_PPRE2 . . . . .                | 213 |
| 5.80.2.9 RCC_CFGR_RTCPRE . . . . .               | 213 |
| 5.80.2.10 RCC_CFGR_SW . . . . .                  | 213 |
| 5.80.2.11 RCC_CFGR_SWS . . . . .                 | 213 |
| 5.81 RCC_CIR Bit Position Definitions . . . . .  | 214 |
| 5.81.1 Detailed Description . . . . .            | 214 |
| 5.81.2 Macro Definition Documentation . . . . .  | 214 |
| 5.81.2.1 RCC_CIR_CSSF . . . . .                  | 215 |
| 5.81.2.2 RCC_CIR_HSERDYC . . . . .               | 215 |
| 5.81.2.3 RCC_CIR_HSERDYF . . . . .               | 215 |
| 5.81.2.4 RCC_CIR_HSERDYIE . . . . .              | 215 |
| 5.81.2.5 RCC_CIR_HSIRDYC . . . . .               | 215 |
| 5.81.2.6 RCC_CIR_HSIRDYF . . . . .               | 215 |
| 5.81.2.7 RCC_CIR_HSIRDYIE . . . . .              | 215 |
| 5.81.2.8 RCC_CIR_LSERDYC . . . . .               | 215 |
| 5.81.2.9 RCC_CIR_LSERDYF . . . . .               | 216 |
| 5.81.2.10 RCC_CIR_LSERDYIE . . . . .             | 216 |
| 5.81.2.11 RCC_CIR_LSIRDYC . . . . .              | 216 |
| 5.81.2.12 RCC_CIR_LSIRDYF . . . . .              | 216 |
| 5.81.2.13 RCC_CIR_LSIRDYIE . . . . .             | 216 |
| 5.81.2.14 RCC_CIR_PLLI2SRDYC . . . . .           | 216 |
| 5.81.2.15 RCC_CIR_PLLI2SRDYF . . . . .           | 216 |
| 5.81.2.16 RCC_CIR_PLLI2SRDYIE . . . . .          | 216 |
| 5.81.2.17 RCC_CIR_PLLRDYC . . . . .              | 217 |
| 5.81.2.18 RCC_CIR_PLLRDYF . . . . .              | 217 |
| 5.81.2.19 RCC_CIR_PLLRDYIE . . . . .             | 217 |
| 5.81.2.20 RCC_CIR_PLLSAIRDYC . . . . .           | 217 |

---

|                                                      |     |
|------------------------------------------------------|-----|
| 5.81.2.21 RCC_CIR_PLLSAIRDYF . . . . .               | 217 |
| 5.81.2.22 RCC_CIR_PLLSAIRDYIE . . . . .              | 217 |
| 5.82 RCC_AHB1RSTR Bit Position Definitions . . . . . | 217 |
| 5.82.1 Detailed Description . . . . .                | 218 |
| 5.82.2 Macro Definition Documentation . . . . .      | 218 |
| 5.82.2.1 RCC_AHB1RSTR_CRC . . . . .                  | 218 |
| 5.82.2.2 RCC_AHB1RSTR_DMA1 . . . . .                 | 218 |
| 5.82.2.3 RCC_AHB1RSTR_DMA2 . . . . .                 | 218 |
| 5.82.2.4 RCC_AHB1RSTR_ETHMAC . . . . .               | 219 |
| 5.82.2.5 RCC_AHB1RSTR_GPIOA . . . . .                | 219 |
| 5.82.2.6 RCC_AHB1RSTR_GPIOB . . . . .                | 219 |
| 5.82.2.7 RCC_AHB1RSTR_GPIOC . . . . .                | 219 |
| 5.82.2.8 RCC_AHB1RSTR_GPIOD . . . . .                | 219 |
| 5.82.2.9 RCC_AHB1RSTR_GPIOE . . . . .                | 219 |
| 5.82.2.10 RCC_AHB1RSTR_GPIOF . . . . .               | 219 |
| 5.82.2.11 RCC_AHB1RSTR_GPIOG . . . . .               | 219 |
| 5.82.2.12 RCC_AHB1RSTR_GPIOH . . . . .               | 220 |
| 5.82.2.13 RCC_AHB1RSTR_GPIOI . . . . .               | 220 |
| 5.82.2.14 RCC_AHB1RSTR_OTGHS . . . . .               | 220 |
| 5.82.2.15 RCC_AHB1RSTR_OTGHSULPI . . . . .           | 220 |
| 5.83 RCC_AHB2RSTR Bit Position Definitions . . . . . | 220 |
| 5.83.1 Detailed Description . . . . .                | 221 |
| 5.83.2 Macro Definition Documentation . . . . .      | 221 |
| 5.83.2.1 RCC_AHB2RSTR_CRYP . . . . .                 | 221 |
| 5.83.2.2 RCC_AHB2RSTR_DCMI . . . . .                 | 221 |
| 5.83.2.3 RCC_AHB2RSTR_HASH . . . . .                 | 221 |
| 5.83.2.4 RCC_AHB2RSTR_OTGFS . . . . .                | 221 |
| 5.83.2.5 RCC_AHB2RSTR_RNG . . . . .                  | 221 |
| 5.84 RCC_AHB3RSTR Bit Position Definitions . . . . . | 222 |
| 5.84.1 Detailed Description . . . . .                | 222 |
| 5.84.2 Macro Definition Documentation . . . . .      | 222 |
| 5.84.2.1 RCC_AHB3RSTR_FSMC . . . . .                 | 222 |
| 5.85 RCC_APB1RSTR Bit Position Definitions . . . . . | 222 |
| 5.85.1 Detailed Description . . . . .                | 223 |
| 5.85.2 Macro Definition Documentation . . . . .      | 223 |
| 5.85.2.1 RCC_APB1RSTR_CAN1 . . . . .                 | 223 |
| 5.85.2.2 RCC_APB1RSTR_CAN2 . . . . .                 | 223 |
| 5.85.2.3 RCC_APB1RSTR_DAC . . . . .                  | 224 |
| 5.85.2.4 RCC_APB1RSTR_I2C1 . . . . .                 | 224 |
| 5.85.2.5 RCC_APB1RSTR_I2C2 . . . . .                 | 224 |
| 5.85.2.6 RCC_APB1RSTR_I2C3 . . . . .                 | 224 |
| 5.85.2.7 RCC_APB1RSTR_PWR . . . . .                  | 224 |

---

|                                                       |     |
|-------------------------------------------------------|-----|
| 5.85.2.8 RCC_APB1RSTR_SPI2 . . . . .                  | 224 |
| 5.85.2.9 RCC_APB1RSTR_SPI3 . . . . .                  | 224 |
| 5.85.2.10 RCC_APB1RSTR_TIM12 . . . . .                | 224 |
| 5.85.2.11 RCC_APB1RSTR_TIM13 . . . . .                | 225 |
| 5.85.2.12 RCC_APB1RSTR_TIM14 . . . . .                | 225 |
| 5.85.2.13 RCC_APB1RSTR_TIM2 . . . . .                 | 225 |
| 5.85.2.14 RCC_APB1RSTR_TIM3 . . . . .                 | 225 |
| 5.85.2.15 RCC_APB1RSTR_TIM4 . . . . .                 | 225 |
| 5.85.2.16 RCC_APB1RSTR_TIM5 . . . . .                 | 225 |
| 5.85.2.17 RCC_APB1RSTR_TIM6 . . . . .                 | 225 |
| 5.85.2.18 RCC_APB1RSTR_TIM7 . . . . .                 | 225 |
| 5.85.2.19 RCC_APB1RSTR_UART4 . . . . .                | 226 |
| 5.85.2.20 RCC_APB1RSTR_UART5 . . . . .                | 226 |
| 5.85.2.21 RCC_APB1RSTR_UART7 . . . . .                | 226 |
| 5.85.2.22 RCC_APB1RSTR_UART8 . . . . .                | 226 |
| 5.85.2.23 RCC_APB1RSTR_USART2 . . . . .               | 226 |
| 5.85.2.24 RCC_APB1RSTR_USART3 . . . . .               | 226 |
| 5.85.2.25 RCC_APB1RSTR_WWDG . . . . .                 | 226 |
| 5.86 RCC_APB2RSTR Bit Position Definitions . . . . .  | 227 |
| 5.86.1 Detailed Description . . . . .                 | 227 |
| 5.86.2 Macro Definition Documentation . . . . .       | 227 |
| 5.86.2.1 RCC_APB2RSTR_ADC . . . . .                   | 227 |
| 5.86.2.2 RCC_APB2RSTR_SDIO . . . . .                  | 227 |
| 5.86.2.3 RCC_APB2RSTR_SPI1 . . . . .                  | 228 |
| 5.86.2.4 RCC_APB2RSTR_SYSCFG . . . . .                | 228 |
| 5.86.2.5 RCC_APB2RSTR_TIM1 . . . . .                  | 228 |
| 5.86.2.6 RCC_APB2RSTR_TIM10 . . . . .                 | 228 |
| 5.86.2.7 RCC_APB2RSTR_TIM11 . . . . .                 | 228 |
| 5.86.2.8 RCC_APB2RSTR_TIM8 . . . . .                  | 228 |
| 5.86.2.9 RCC_APB2RSTR_TIM9 . . . . .                  | 228 |
| 5.86.2.10 RCC_APB2RSTR_USART1 . . . . .               | 228 |
| 5.86.2.11 RCC_APB2RSTR_USART6 . . . . .               | 229 |
| 5.87 RCC_AHB1LPENR Bit Position Definitions . . . . . | 229 |
| 5.87.1 Detailed Description . . . . .                 | 229 |
| 5.87.2 Macro Definition Documentation . . . . .       | 229 |
| 5.87.2.1 RCC_AHB1LPENR_CRCEN . . . . .                | 230 |
| 5.87.2.2 RCC_AHB1LPENR_DMA1LPEN . . . . .             | 230 |
| 5.87.2.3 RCC_AHB1LPENR_DMA2LPEN . . . . .             | 230 |
| 5.87.2.4 RCC_AHB1LPENR_ETHMACLPEN . . . . .           | 230 |
| 5.87.2.5 RCC_AHB1LPENR_ETHMACPTPLPEN . . . . .        | 230 |
| 5.87.2.6 RCC_AHB1LPENR_ETHMACRXLPEN . . . . .         | 230 |
| 5.87.2.7 RCC_AHB1LPENR_ETHMACTXLPEN . . . . .         | 230 |

---

|                                                       |     |
|-------------------------------------------------------|-----|
| 5.87.2.8 RCC_AHB1LPENR_GPIOALPEN . . . . .            | 230 |
| 5.87.2.9 RCC_AHB1LPENR_GPIOBLPEN . . . . .            | 231 |
| 5.87.2.10 RCC_AHB1LPENR_GPIOCLPEN . . . . .           | 231 |
| 5.87.2.11 RCC_AHB1LPENR_GPIODLPEN . . . . .           | 231 |
| 5.87.2.12 RCC_AHB1LPENR_GPIOELPEN . . . . .           | 231 |
| 5.87.2.13 RCC_AHB1LPENR_GPIOFLPEN . . . . .           | 231 |
| 5.87.2.14 RCC_AHB1LPENR_GPIOGLPEN . . . . .           | 231 |
| 5.87.2.15 RCC_AHB1LPENR_GPIOHLPEN . . . . .           | 231 |
| 5.87.2.16 RCC_AHB1LPENR_GPIOILPEN . . . . .           | 231 |
| 5.87.2.17 RCC_AHB1LPENR_OTGHSHULPI . . . . .          | 232 |
| 5.87.2.18 RCC_AHB1LPENR_OTGHSHPEN . . . . .           | 232 |
| 5.88 RCC_AHB2LPENR Bit Position Definitions . . . . . | 232 |
| 5.88.1 Detailed Description . . . . .                 | 232 |
| 5.88.2 Macro Definition Documentation . . . . .       | 232 |
| 5.88.2.1 RCC_AHB2LPENR_CRYPLPEN . . . . .             | 232 |
| 5.88.2.2 RCC_AHB2LPENR_DCMILPEN . . . . .             | 233 |
| 5.88.2.3 RCC_AHB2LPENR_HASHLPEN . . . . .             | 233 |
| 5.88.2.4 RCC_AHB2LPENR_OTGFSLPEN . . . . .            | 233 |
| 5.88.2.5 RCC_AHB2LPENR_RNGLPEN . . . . .              | 233 |
| 5.89 RCC_AHB3LPENR Bit Position Definitions . . . . . | 233 |
| 5.89.1 Detailed Description . . . . .                 | 233 |
| 5.89.2 Macro Definition Documentation . . . . .       | 234 |
| 5.89.2.1 RCC_AHB3LPENR_FSMCLPEN . . . . .             | 234 |
| 5.90 RCC_APB1LPENR Bit Position Definitions . . . . . | 234 |
| 5.90.1 Detailed Description . . . . .                 | 235 |
| 5.90.2 Macro Definition Documentation . . . . .       | 235 |
| 5.90.2.1 RCC_APB1LPENR_CAN1LPEN . . . . .             | 235 |
| 5.90.2.2 RCC_APB1LPENR_CAN2LPEN . . . . .             | 235 |
| 5.90.2.3 RCC_APB1LPENR_DACLPEN . . . . .              | 235 |
| 5.90.2.4 RCC_APB1LPENR_I2C1LPEN . . . . .             | 235 |
| 5.90.2.5 RCC_APB1LPENR_I2C2LPEN . . . . .             | 235 |
| 5.90.2.6 RCC_APB1LPENR_I2C3LPEN . . . . .             | 235 |
| 5.90.2.7 RCC_APB1LPENR_PWRLPEN . . . . .              | 236 |
| 5.90.2.8 RCC_APB1LPENR_SPI2LPEN . . . . .             | 236 |
| 5.90.2.9 RCC_APB1LPENR_SPI3LPEN . . . . .             | 236 |
| 5.90.2.10 RCC_APB1LPENR_TIM12LPEN . . . . .           | 236 |
| 5.90.2.11 RCC_APB1LPENR_TIM13LPEN . . . . .           | 236 |
| 5.90.2.12 RCC_APB1LPENR_TIM14LPEN . . . . .           | 236 |
| 5.90.2.13 RCC_APB1LPENR_TIM2LPEN . . . . .            | 236 |
| 5.90.2.14 RCC_APB1LPENR_TIM3LPEN . . . . .            | 236 |
| 5.90.2.15 RCC_APB1LPENR_TIM4LPEN . . . . .            | 237 |
| 5.90.2.16 RCC_APB1LPENR_TIM5LPEN . . . . .            | 237 |

---

|                                                       |     |
|-------------------------------------------------------|-----|
| 5.90.2.17 RCC_APB1LPENR_TIM6LPEN . . . . .            | 237 |
| 5.90.2.18 RCC_APB1LPENR_TIM7LPEN . . . . .            | 237 |
| 5.90.2.19 RCC_APB1LPENR_UART4LPEN . . . . .           | 237 |
| 5.90.2.20 RCC_APB1LPENR_UART5LPEN . . . . .           | 237 |
| 5.90.2.21 RCC_APB1LPENR_UART7LPEN . . . . .           | 237 |
| 5.90.2.22 RCC_APB1LPENR_UART8LPEN . . . . .           | 237 |
| 5.90.2.23 RCC_APB1LPENR_USART2LPEN . . . . .          | 238 |
| 5.90.2.24 RCC_APB1LPENR_USART3LPEN . . . . .          | 238 |
| 5.90.2.25 RCC_APB1LPENR_WWDGLPEN . . . . .            | 238 |
| 5.91 RCC_APB2LPENR Bit Position Definitions . . . . . | 238 |
| 5.91.1 Detailed Description . . . . .                 | 239 |
| 5.91.2 Macro Definition Documentation . . . . .       | 239 |
| 5.91.2.1 RCC_APB2LPENR_ADCLPEN . . . . .              | 239 |
| 5.91.2.2 RCC_APB2LPENR_SDIOLPEN . . . . .             | 239 |
| 5.91.2.3 RCC_APB2LPENR_SPI1LPEN . . . . .             | 239 |
| 5.91.2.4 RCC_APB2LPENR_SYSCFGLPEN . . . . .           | 239 |
| 5.91.2.5 RCC_APB2LPENR_TIM10LPEN . . . . .            | 239 |
| 5.91.2.6 RCC_APB2LPENR_TIM11LPEN . . . . .            | 239 |
| 5.91.2.7 RCC_APB2LPENR_TIM1LPEN . . . . .             | 240 |
| 5.91.2.8 RCC_APB2LPENR_TIM8LPEN . . . . .             | 240 |
| 5.91.2.9 RCC_APB2LPENR_TIM9LPEN . . . . .             | 240 |
| 5.91.2.10 RCC_APB2LPENR_USART1LPEN . . . . .          | 240 |
| 5.91.2.11 RCC_APB2LPENR_USART6LPEN . . . . .          | 240 |
| 5.92 RCC_BDCR Bit Position Definitions . . . . .      | 240 |
| 5.92.1 Detailed Description . . . . .                 | 241 |
| 5.92.2 Macro Definition Documentation . . . . .       | 241 |
| 5.92.2.1 RCC_BDCR_BDRST . . . . .                     | 241 |
| 5.92.2.2 RCC_BDCR_LSEBYP . . . . .                    | 241 |
| 5.92.2.3 RCC_BDCR_LSEON . . . . .                     | 241 |
| 5.92.2.4 RCC_BDCR_LSERDY . . . . .                    | 241 |
| 5.92.2.5 RCC_BDCR_RTCEN . . . . .                     | 241 |
| 5.92.2.6 RCC_BDCR_RTCSEL . . . . .                    | 242 |
| 5.93 RCC_CSR Bit Position Definitions . . . . .       | 242 |
| 5.93.1 Detailed Description . . . . .                 | 242 |
| 5.93.2 Macro Definition Documentation . . . . .       | 242 |
| 5.93.2.1 RCC_CSR_IWDGRSTF . . . . .                   | 242 |
| 5.93.2.2 RCC_CSR_LPWRRSTF . . . . .                   | 243 |
| 5.93.2.3 RCC_CSR_LSION . . . . .                      | 243 |
| 5.93.2.4 RCC_CSR_LSIRDY . . . . .                     | 243 |
| 5.93.2.5 RCC_CSR_OBLRSTF . . . . .                    | 243 |
| 5.93.2.6 RCC_CSR_PINRSTF . . . . .                    | 243 |
| 5.93.2.7 RCC_CSR_PORRSTF . . . . .                    | 243 |

|                                                            |     |
|------------------------------------------------------------|-----|
| 5.93.2.8 RCC_CSR_RMVF . . . . .                            | 243 |
| 5.93.2.9 RCC_CSR_SFTRSTF . . . . .                         | 243 |
| 5.93.2.10 RCC_CSR_WWDGRSTF . . . . .                       | 244 |
| 5.94 RCC_SSCGR Bit Position Definitions . . . . .          | 244 |
| 5.94.1 Detailed Description . . . . .                      | 244 |
| 5.94.2 Macro Definition Documentation . . . . .            | 244 |
| 5.94.2.1 RCC_SSCGR_INCSTEP . . . . .                       | 244 |
| 5.94.2.2 RCC_SSCGR_MODPER . . . . .                        | 244 |
| 5.94.2.3 RCC_SSCGR_SPREADSEL . . . . .                     | 245 |
| 5.94.2.4 RCC_SSCGR_SSCGEN . . . . .                        | 245 |
| 5.95 RCC_PLLI2SCFGR Bit Position Definitions . . . . .     | 245 |
| 5.95.1 Detailed Description . . . . .                      | 245 |
| 5.95.2 Macro Definition Documentation . . . . .            | 245 |
| 5.95.2.1 RCC_PLLI2SCFGR_PLLI2SN . . . . .                  | 245 |
| 5.95.2.2 RCC_PLLI2SCFGR_PLLI2SR . . . . .                  | 246 |
| 5.96 GPIO Base Address to Code Conversion Macros . . . . . | 246 |
| 5.96.1 Detailed Description . . . . .                      | 246 |
| 5.96.2 Macro Definition Documentation . . . . .            | 246 |
| 5.96.2.1 GPIO_BASEADDR_TO_CODE . . . . .                   | 246 |
| 5.97 GPIO Driver . . . . .                                 | 247 |
| 5.97.1 Detailed Description . . . . .                      | 248 |
| 5.98 GPIO Pin Numbers . . . . .                            | 248 |
| 5.98.1 Detailed Description . . . . .                      | 249 |
| 5.99 GPIO Pin Modes . . . . .                              | 249 |
| 5.99.1 Detailed Description . . . . .                      | 250 |
| 5.99.2 Macro Definition Documentation . . . . .            | 250 |
| 5.99.2.1 GPIO_MODE_AF_INPUT . . . . .                      | 250 |
| 5.99.2.2 GPIO_MODE_INPUT_FLO . . . . .                     | 250 |
| 5.99.2.3 GPIO_MODE_INPUT_PD . . . . .                      | 250 |
| 5.99.2.4 GPIO_MODE_INPUT_PU . . . . .                      | 250 |
| 5.99.2.5 GPIO_MODE_OUTPUT_AF_OD . . . . .                  | 250 |
| 5.99.2.6 GPIO_MODE_OUTPUT_AF_PP . . . . .                  | 250 |
| 5.99.2.7 GPIO_MODE_OUTPUT_OD . . . . .                     | 251 |
| 5.99.2.8 GPIO_MODE_OUTPUT_PP . . . . .                     | 251 |
| 5.100 GPIO Pin Speeds . . . . .                            | 251 |
| 5.100.1 Detailed Description . . . . .                     | 251 |
| 5.100.2 Macro Definition Documentation . . . . .           | 251 |
| 5.100.2.1 GPIO_SPEED_10M . . . . .                         | 251 |
| 5.100.2.2 GPIO_SPEED_2M . . . . .                          | 252 |
| 5.100.2.3 GPIO_SPEED_50M . . . . .                         | 252 |
| 5.101 GPIO Pin States . . . . .                            | 252 |
| 5.101.1 Detailed Description . . . . .                     | 252 |

---

|                                                       |     |
|-------------------------------------------------------|-----|
| 5.101.2 Macro Definition Documentation . . . . .      | 252 |
| 5.101.2.1 GPIO_PIN_RESET . . . . .                    | 252 |
| 5.101.2.2 GPIO_PIN_SET . . . . .                      | 253 |
| 5.102 GPIO Return Lock Status . . . . .               | 253 |
| 5.102.1 Detailed Description . . . . .                | 253 |
| 5.102.2 Macro Definition Documentation . . . . .      | 253 |
| 5.102.2.1 GPIO_RETURN_LOCK_ERROR . . . . .            | 253 |
| 5.102.2.2 GPIO_RETURN_LOCK_OK . . . . .               | 253 |
| 5.103 GPIO Pin Modes . . . . .                        | 254 |
| 5.103.1 Detailed Description . . . . .                | 254 |
| 5.103.2 Macro Definition Documentation . . . . .      | 254 |
| 5.103.2.1 GPIO_MODE_ALTFN . . . . .                   | 254 |
| 5.103.2.2 GPIO_MODE_ANALOG . . . . .                  | 254 |
| 5.103.2.3 GPIO_MODE_IN . . . . .                      | 255 |
| 5.103.2.4 GPIO_MODE_IT_FT . . . . .                   | 255 |
| 5.103.2.5 GPIO_MODE_IT_RFT . . . . .                  | 255 |
| 5.103.2.6 GPIO_MODE_IT_RT . . . . .                   | 255 |
| 5.103.2.7 GPIO_MODE_OUT . . . . .                     | 255 |
| 5.104 GPIO Output Speeds . . . . .                    | 255 |
| 5.104.1 Detailed Description . . . . .                | 256 |
| 5.104.2 Macro Definition Documentation . . . . .      | 256 |
| 5.104.2.1 GPIO_SPEED_FAST . . . . .                   | 256 |
| 5.104.2.2 GPIO_SPEED_HIGH . . . . .                   | 256 |
| 5.104.2.3 GPIO_SPEED_LOW . . . . .                    | 256 |
| 5.104.2.4 GPIO_SPEED_MEDIUM . . . . .                 | 256 |
| 5.105 GPIO Pull-up/Pull-down Configurations . . . . . | 257 |
| 5.105.1 Detailed Description . . . . .                | 257 |
| 5.105.2 Macro Definition Documentation . . . . .      | 257 |
| 5.105.2.1 GPIO_NO_PUPD . . . . .                      | 257 |
| 5.105.2.2 GPIO_PIN_PD . . . . .                       | 257 |
| 5.105.2.3 GPIO_PIN_PU . . . . .                       | 257 |
| 5.106 GPIO Output Types . . . . .                     | 258 |
| 5.106.1 Detailed Description . . . . .                | 258 |
| 5.106.2 Macro Definition Documentation . . . . .      | 258 |
| 5.106.2.1 GPIO_OP_TYPE_OD . . . . .                   | 258 |
| 5.106.2.2 GPIO_OP_TYPE_PP . . . . .                   | 258 |
| 5.107 API Function Prototypes . . . . .               | 259 |
| 5.107.1 Detailed Description . . . . .                | 259 |
| 5.107.2 Function Documentation . . . . .              | 259 |
| 5.107.2.1 MCAL_GPIO_DelInit() . . . . .               | 259 |
| 5.107.2.2 MCAL_GPIO_Init() . . . . .                  | 260 |
| 5.107.2.3 MCAL_GPIO_LockPin() . . . . .               | 261 |

---

|                                           |     |
|-------------------------------------------|-----|
| 5.107.2.4 MCAL_GPIO_ReadPin()             | 262 |
| 5.107.2.5 MCAL_GPIO_ReadPort()            | 263 |
| 5.107.2.6 MCAL_GPIO_TogglePin()           | 264 |
| 5.107.2.7 MCAL_GPIO_TogglePort()          | 265 |
| 5.107.2.8 MCAL_GPIO_WritePin()            | 265 |
| 5.107.2.9 MCAL_GPIO_WritePort()           | 266 |
| 5.108 I2C Driver                          | 267 |
| 5.108.1 Detailed Description              | 269 |
| 5.108.2 Enumeration Type Documentation    | 269 |
| 5.108.2.1 FlagStatus                      | 269 |
| 5.108.2.2 Functional_State                | 269 |
| 5.108.2.3 I2C_Direction                   | 270 |
| 5.108.2.4 Repeated_Start                  | 270 |
| 5.108.2.5 Slave_State                     | 270 |
| 5.108.2.6 Status                          | 271 |
| 5.108.2.7 StopCondition                   | 271 |
| 5.109 I2C Speed Definitions               | 271 |
| 5.109.1 Detailed Description              | 272 |
| 5.109.2 Macro Definition Documentation    | 272 |
| 5.109.2.1 I2C_SCK_FM_200K                 | 272 |
| 5.109.2.2 I2C_SCK_FM_400K                 | 272 |
| 5.109.2.3 I2C_SCK_SM_100K                 | 272 |
| 5.109.2.4 I2C_SCK_SM_50K                  | 272 |
| 5.110 I2C Stretch Mode Definitions        | 273 |
| 5.110.1 Detailed Description              | 273 |
| 5.110.2 Macro Definition Documentation    | 273 |
| 5.110.2.1 I2C_StretchMode_disabled        | 273 |
| 5.110.2.2 I2C_StretchMode_enabled         | 273 |
| 5.111 I2C Mode Definitions                | 273 |
| 5.111.1 Detailed Description              | 274 |
| 5.111.2 Macro Definition Documentation    | 274 |
| 5.111.2.1 I2C_Mode_I2C                    | 274 |
| 5.111.2.2 I2C_Mode_SMBus                  | 274 |
| 5.112 I2C Addressing Modes                | 274 |
| 5.112.1 Detailed Description              | 275 |
| 5.112.2 Macro Definition Documentation    | 275 |
| 5.112.2.1 I2C_Addressing_Slave_10bits     | 275 |
| 5.112.2.2 I2C_Addressing_Slave_7bits      | 275 |
| 5.113 I2C Acknowledge Control Definitions | 275 |
| 5.113.1 Detailed Description              | 275 |
| 5.113.2 Macro Definition Documentation    | 276 |
| 5.113.2.1 I2C_Ack_Control_Disable         | 276 |

---

|                                                     |     |
|-----------------------------------------------------|-----|
| 5.113.2.2 I2C_Ack_Control_Enable . . . . .          | 276 |
| 5.114 I2C General Call Enable Definitions . . . . . | 276 |
| 5.114.1 Detailed Description . . . . .              | 276 |
| 5.114.2 Macro Definition Documentation . . . . .    | 276 |
| 5.114.2.1 I2C_ENGC_Disable . . . . .                | 277 |
| 5.114.2.2 I2C_ENGC_Enable . . . . .                 | 277 |
| 5.115 API Function Prototypes . . . . .             | 277 |
| 5.115.1 Detailed Description . . . . .              | 278 |
| 5.115.2 Function Documentation . . . . .            | 278 |
| 5.115.2.1 I2C_ACKnowledgeConfig() . . . . .         | 278 |
| 5.115.2.2 I2C_Generate_Start() . . . . .            | 278 |
| 5.115.2.3 I2C_Generate_Stop() . . . . .             | 279 |
| 5.115.2.4 I2C_Get_FlagStatus() . . . . .            | 279 |
| 5.115.2.5 I2C_SendAddress() . . . . .               | 280 |
| 5.115.2.6 MCAL_I2C_Deinit() . . . . .               | 281 |
| 5.115.2.7 MCAL_I2C_Init() . . . . .                 | 281 |
| 5.115.2.8 MCAL_I2C_Master_Rx() . . . . .            | 282 |
| 5.115.2.9 MCAL_I2C_Master_Tx() . . . . .            | 282 |
| 5.115.2.10 MCAL_I2C_Set_GPIO() . . . . .            | 283 |
| 5.115.2.11 MCAL_I2C_Slave_SendData() . . . . .      | 284 |
| 5.115.2.12 MCAL_I2C_SlaveReceiveData() . . . . .    | 284 |
| 5.116 NVIC Driver . . . . .                         | 285 |
| 5.116.1 Detailed Description . . . . .              | 286 |
| 5.117 NVIC Register Definitions . . . . .           | 287 |
| 5.117.1 Detailed Description . . . . .              | 287 |
| 5.118 NVIC Configuration Macros . . . . .           | 287 |
| 5.118.1 Detailed Description . . . . .              | 288 |
| 5.119 Interrupt Status . . . . .                    | 288 |
| 5.119.1 Detailed Description . . . . .              | 288 |
| 5.120 Priority Groups . . . . .                     | 288 |
| 5.120.1 Detailed Description . . . . .              | 289 |
| 5.121 Interrupt Priorities . . . . .                | 289 |
| 5.121.1 Detailed Description . . . . .              | 290 |
| 5.122 Interrupt Requests . . . . .                  | 290 |
| 5.122.1 Detailed Description . . . . .              | 291 |
| 5.123 API Function Prototypes . . . . .             | 291 |
| 5.123.1 Detailed Description . . . . .              | 292 |
| 5.123.2 Function Documentation . . . . .            | 292 |
| 5.123.2.1 MCAL_NVIC_ClearPendingIRQ() . . . . .     | 292 |
| 5.123.2.2 MCAL_NVIC_DisableIRQ() . . . . .          | 293 |
| 5.123.2.3 MCAL_NVIC_EnableIRQ() . . . . .           | 293 |
| 5.123.2.4 MCAL_NVIC_GetActive() . . . . .           | 294 |

---

|                                            |     |
|--------------------------------------------|-----|
| 5.123.2.5 MCAL_NVIC_GetPendingIRQ()        | 295 |
| 5.123.2.6 MCAL_NVIC_GetPriority()          | 295 |
| 5.123.2.7 MCAL_NVIC_GetPriorityGrouping()  | 296 |
| 5.123.2.8 MCAL_NVIC_SetPendingIRQ()        | 297 |
| 5.123.2.9 MCAL_NVIC_SetPriority()          | 298 |
| 5.123.2.10 MCAL_NVIC_SetPriorityGrouping() | 299 |
| 5.123.2.11 MCAL_NVIC_SystemReset()         | 299 |
| 5.124 NVIC IRQ Enable/Disable Macros       | 300 |
| 5.124.1 Detailed Description               | 301 |
| 5.124.2 Macro Definition Documentation     | 301 |
| 5.124.2.1 NVIC IRQ10_EXTI4_Disable         | 301 |
| 5.124.2.2 NVIC IRQ10_EXTI4_Enable          | 301 |
| 5.124.2.3 NVIC IRQ23_EXTI5_9_Disable       | 302 |
| 5.124.2.4 NVIC IRQ23_EXTI5_9_Enable        | 302 |
| 5.124.2.5 NVIC IRQ31_I2C1_EV_Disable       | 302 |
| 5.124.2.6 NVIC IRQ31_I2C1_EV_Enable        | 302 |
| 5.124.2.7 NVIC IRQ32_I2C1_ER_Disable       | 302 |
| 5.124.2.8 NVIC IRQ32_I2C1_ER_Enable        | 302 |
| 5.124.2.9 NVIC IRQ33_I2C2_EV_Disable       | 302 |
| 5.124.2.10 NVIC IRQ33_I2C2_EV_Enable       | 303 |
| 5.124.2.11 NVIC IRQ34_I2C2_ER_Enable       | 303 |
| 5.124.2.12 NVIC IRQ35_SPI1_Disable         | 303 |
| 5.124.2.13 NVIC IRQ35_SPI1_Enable          | 303 |
| 5.124.2.14 NVIC IRQ36_SPI2_Enable          | 303 |
| 5.124.2.15 NVIC IRQ37_USART1_Disable       | 303 |
| 5.124.2.16 NVIC IRQ37_USART1_Enable        | 303 |
| 5.124.2.17 NVIC IRQ38_USART2_Disable       | 304 |
| 5.124.2.18 NVIC IRQ38_USART2_Enable        | 304 |
| 5.124.2.19 NVIC IRQ39_USART3_Enable        | 304 |
| 5.124.2.20 NVIC IRQ40_EXTI10_15_Enable     | 304 |
| 5.124.2.21 NVIC IRQ6_EXTI0_Disable         | 304 |
| 5.124.2.22 NVIC IRQ6_EXTI0_Enable          | 304 |
| 5.124.2.23 NVIC IRQ7_EXTI1_Disable         | 304 |
| 5.124.2.24 NVIC IRQ7_EXTI1_Enable          | 305 |
| 5.124.2.25 NVIC IRQ8_EXTI2_Disable         | 305 |
| 5.124.2.26 NVIC IRQ8_EXTI2_Enable          | 305 |
| 5.124.2.27 NVIC IRQ9_EXTI3_Disable         | 305 |
| 5.124.2.28 NVIC IRQ9_EXTI3_Enable          | 305 |
| 5.125 RCC Driver                           | 305 |
| 5.125.1 Detailed Description               | 306 |
| 5.126 Clock Source Selection               | 306 |
| 5.126.1 Detailed Description               | 306 |

---

|                                                  |     |
|--------------------------------------------------|-----|
| 5.126.2 Macro Definition Documentation . . . . . | 306 |
| 5.126.2.1 HSE_CLK . . . . .                      | 306 |
| 5.126.2.2 HSE_VALUE . . . . .                    | 307 |
| 5.126.2.3 HSI_RC_CLK . . . . .                   | 307 |
| 5.126.2.4 HSI_VALUE . . . . .                    | 307 |
| 5.126.2.5 RCC_PLLCFGR_PLLSRC_HSE . . . . .       | 307 |
| 5.126.2.6 RCC_SELECT_HSE . . . . .               | 307 |
| 5.126.2.7 RCC_SELECT_HSI . . . . .               | 307 |
| 5.126.2.8 RCC_SELECT_PLL . . . . .               | 307 |
| 5.127 Peripheral Selection . . . . .             | 308 |
| 5.127.1 Detailed Description . . . . .           | 308 |
| 5.127.2 Macro Definition Documentation . . . . . | 308 |
| 5.127.2.1 RCC_CRC . . . . .                      | 308 |
| 5.127.2.2 RCC_GPIOA . . . . .                    | 308 |
| 5.127.2.3 RCC_GPIOB . . . . .                    | 309 |
| 5.127.2.4 RCC_GPIOC . . . . .                    | 309 |
| 5.127.2.5 RCC_GPIOD . . . . .                    | 309 |
| 5.127.2.6 RCC_GPIOE . . . . .                    | 309 |
| 5.127.2.7 RCC_I2C1 . . . . .                     | 309 |
| 5.127.2.8 RCC_I2C2 . . . . .                     | 309 |
| 5.127.2.9 RCC_SPI1 . . . . .                     | 309 |
| 5.127.2.10 RCC_SPI2 . . . . .                    | 309 |
| 5.127.2.11 RCC_SYSCFG . . . . .                  | 310 |
| 5.127.2.12 RCC_TIM2 . . . . .                    | 310 |
| 5.127.2.13 RCC_USART1 . . . . .                  | 310 |
| 5.127.2.14 RCC_USART2 . . . . .                  | 310 |
| 5.127.2.15 RCC_USART6 . . . . .                  | 310 |
| 5.128 API Function Prototypes . . . . .          | 310 |
| 5.128.1 Detailed Description . . . . .           | 311 |
| 5.128.2 Function Documentation . . . . .         | 311 |
| 5.128.2.1 MCAL_RCC_Enable_Peripheral() . . . . . | 311 |
| 5.128.2.2 MCAL_RCC_GetHCLKFreq() . . . . .       | 311 |
| 5.128.2.3 MCAL_RCC_GetPCLK1Freq() . . . . .      | 312 |
| 5.128.2.4 MCAL_RCC_GetPCLK2Freq() . . . . .      | 313 |
| 5.128.2.5 MCAL_RCC_GetSYS_CLKFreq() . . . . .    | 313 |
| 5.128.2.6 MCAL_RCC_Reset_Peripheral() . . . . .  | 314 |
| 5.128.2.7 MCAL_RCC_Select_Clock() . . . . .      | 314 |
| 5.128.2.8 RCC_GetPLLOutputClock() . . . . .      | 314 |
| 5.129 SPI Driver . . . . .                       | 315 |
| 5.129.1 Detailed Description . . . . .           | 316 |
| 5.129.2 Enumeration Type Documentation . . . . . | 316 |
| 5.129.2.1 SPI_PollingMechanism . . . . .         | 316 |

---

|                                                          |     |
|----------------------------------------------------------|-----|
| 5.130 SPI Mode Definitions . . . . .                     | 317 |
| 5.130.1 Detailed Description . . . . .                   | 317 |
| 5.130.2 Macro Definition Documentation . . . . .         | 317 |
| 5.130.2.1 SPI_Mode_Master . . . . .                      | 317 |
| 5.130.2.2 SPI_Mode_Slave . . . . .                       | 317 |
| 5.131 SPI Communication Mode Definitions . . . . .       | 317 |
| 5.131.1 Detailed Description . . . . .                   | 318 |
| 5.131.2 Macro Definition Documentation . . . . .         | 318 |
| 5.131.2.1 SPI_Direction_1line_Receive_only . . . . .     | 318 |
| 5.131.2.2 SPI_Direction_1line_Transmit_only . . . . .    | 318 |
| 5.131.2.3 SPI_Direction_2lines . . . . .                 | 318 |
| 5.131.2.4 SPI_Direction_2lines_RX_Only . . . . .         | 318 |
| 5.132 SPI Payload Length Definitions . . . . .           | 318 |
| 5.132.1 Detailed Description . . . . .                   | 319 |
| 5.132.2 Macro Definition Documentation . . . . .         | 319 |
| 5.132.2.1 SPI_Payload_Length_16bit . . . . .             | 319 |
| 5.132.2.2 SPI_Payload_Length_8bit . . . . .              | 319 |
| 5.133 SPI Frame Format Definitions . . . . .             | 319 |
| 5.133.1 Detailed Description . . . . .                   | 319 |
| 5.133.2 Macro Definition Documentation . . . . .         | 319 |
| 5.133.2.1 SPI_Frame_Format_LSB . . . . .                 | 320 |
| 5.133.2.2 SPI_Frame_Format_MSB . . . . .                 | 320 |
| 5.134 SPI Clock Polarity Definitions . . . . .           | 320 |
| 5.134.1 Detailed Description . . . . .                   | 320 |
| 5.134.2 Macro Definition Documentation . . . . .         | 320 |
| 5.134.2.1 SPI_Clock_Polarity_High_Idle . . . . .         | 320 |
| 5.134.2.2 SPI_Clock_Polarity_Low_Idle . . . . .          | 321 |
| 5.135 SPI Clock Phase Definitions . . . . .              | 321 |
| 5.135.1 Detailed Description . . . . .                   | 321 |
| 5.135.2 Macro Definition Documentation . . . . .         | 321 |
| 5.135.2.1 SPI_Clock_Phase_Leading . . . . .              | 321 |
| 5.135.2.2 SPI_Clock_Phase_Trailing . . . . .             | 321 |
| 5.136 SPI NSS Definitions . . . . .                      | 322 |
| 5.136.1 Detailed Description . . . . .                   | 322 |
| 5.136.2 Macro Definition Documentation . . . . .         | 322 |
| 5.136.2.1 SPI_NSS_Hard_Master_SS_No_output . . . . .     | 322 |
| 5.136.2.2 SPI_NSS_Hard_Master_SS_Output_Enable . . . . . | 322 |
| 5.136.2.3 SPI_NSS_Hard_Slave . . . . .                   | 322 |
| 5.136.2.4 SPI_NSS_Internal_Soft_Reset . . . . .          | 323 |
| 5.136.2.5 SPI_NSS_Internal_Soft_Set . . . . .            | 323 |
| 5.137 SPI Prescaler Definitions . . . . .                | 323 |
| 5.137.1 Detailed Description . . . . .                   | 323 |

---

|                                                    |     |
|----------------------------------------------------|-----|
| 5.137.2 Macro Definition Documentation . . . . .   | 323 |
| 5.137.2.1 SPI_Prescaler_By128 . . . . .            | 323 |
| 5.137.2.2 SPI_Prescaler_By16 . . . . .             | 324 |
| 5.137.2.3 SPI_Prescaler_By2 . . . . .              | 324 |
| 5.137.2.4 SPI_Prescaler_By256 . . . . .            | 324 |
| 5.137.2.5 SPI_Prescaler_By32 . . . . .             | 324 |
| 5.137.2.6 SPI_Prescaler_By4 . . . . .              | 324 |
| 5.137.2.7 SPI_Prescaler_By64 . . . . .             | 324 |
| 5.137.2.8 SPI_Prescaler_By8 . . . . .              | 324 |
| 5.138 SPI IRQ Enable Definitions . . . . .         | 325 |
| 5.138.1 Detailed Description . . . . .             | 325 |
| 5.138.2 Macro Definition Documentation . . . . .   | 325 |
| 5.138.2.1 SPI_IRQ_Enable_Err . . . . .             | 325 |
| 5.138.2.2 SPI_IRQ_Enable_None . . . . .            | 325 |
| 5.138.2.3 SPI_IRQ_Enable_Rx_Only . . . . .         | 325 |
| 5.138.2.4 SPI_IRQ_Enable_Tx_Only . . . . .         | 326 |
| 5.139 API Function Prototypes . . . . .            | 326 |
| 5.139.1 Detailed Description . . . . .             | 326 |
| 5.139.2 Function Documentation . . . . .           | 326 |
| 5.139.2.1 MCAL_SPI_DelInit() . . . . .             | 326 |
| 5.139.2.2 MCAL_SPI_GPIO_Set_Pins() . . . . .       | 327 |
| 5.139.2.3 MCAL_SPI_Init() . . . . .                | 328 |
| 5.139.2.4 MCAL_SPI_ReceiveData() . . . . .         | 329 |
| 5.139.2.5 MCAL_SPI_SendData() . . . . .            | 329 |
| 5.139.2.6 MCAL_SPI_Tx_Rx() . . . . .               | 330 |
| 5.140 SYSTICK Driver . . . . .                     | 331 |
| 5.140.1 Detailed Description . . . . .             | 332 |
| 5.140.2 Macro Definition Documentation . . . . .   | 332 |
| 5.140.2.1 STK_FCPU . . . . .                       | 332 |
| 5.141 SysTick Interrupt Configuration . . . . .    | 332 |
| 5.141.1 Detailed Description . . . . .             | 332 |
| 5.141.2 Macro Definition Documentation . . . . .   | 332 |
| 5.141.2.1 STK_INTERRUPT_DISABLED . . . . .         | 332 |
| 5.141.2.2 STK_INTERRUPT_ENABLED . . . . .          | 333 |
| 5.142 SysTick Clock Configuration . . . . .        | 333 |
| 5.142.1 Detailed Description . . . . .             | 333 |
| 5.142.2 Macro Definition Documentation . . . . .   | 333 |
| 5.142.2.1 STK_CLK_AHB . . . . .                    | 333 |
| 5.142.2.2 STK_CLK_AHB_8 . . . . .                  | 333 |
| 5.143 SysTick Running Mode Configuration . . . . . | 334 |
| 5.143.1 Detailed Description . . . . .             | 334 |
| 5.143.2 Macro Definition Documentation . . . . .   | 334 |

---

|                                                      |     |
|------------------------------------------------------|-----|
| 5.143.2.1 STK_ONE_SHOT_MODE . . . . .                | 334 |
| 5.143.2.2 STK_PERIODIC_MODE . . . . .                | 334 |
| 5.144 API Function Prototypes . . . . .              | 334 |
| 5.144.1 Detailed Description . . . . .               | 335 |
| 5.144.2 Function Documentation . . . . .             | 335 |
| 5.144.2.1 MCAL_STK_Config() . . . . .                | 335 |
| 5.144.2.2 MCAL_STK_Delay() . . . . .                 | 336 |
| 5.144.2.3 MCAL_STK_Delay1ms() . . . . .              | 337 |
| 5.144.2.4 MCAL_STK_SetCallback() . . . . .           | 337 |
| 5.144.2.5 MCAL_STK_SetReload() . . . . .             | 338 |
| 5.144.2.6 MCAL_STK_StartTimer() . . . . .            | 338 |
| 5.144.2.7 MCAL_STK_StopTimer() . . . . .             | 339 |
| 5.145 TIMER Driver . . . . .                         | 339 |
| 5.145.1 Detailed Description . . . . .               | 340 |
| 5.146 TIM2 Register group . . . . .                  | 340 |
| 5.146.1 Detailed Description . . . . .               | 341 |
| 5.146.2 Macro Definition Documentation . . . . .     | 341 |
| 5.146.2.1 TIM2_TIMER_BASE . . . . .                  | 341 |
| 5.147 API Function Prototypes . . . . .              | 341 |
| 5.147.1 Detailed Description . . . . .               | 342 |
| 5.147.2 Function Documentation . . . . .             | 342 |
| 5.147.2.1 dms() . . . . .                            | 342 |
| 5.147.2.2 dus() . . . . .                            | 342 |
| 5.147.2.3 Timer2_init() . . . . .                    | 343 |
| 5.148 USART Driver . . . . .                         | 344 |
| 5.148.1 Detailed Description . . . . .               | 344 |
| 5.149 Enumeration and Structures for USART . . . . . | 344 |
| 5.149.1 Detailed Description . . . . .               | 345 |
| 5.150 Macros for USART Configuration . . . . .       | 345 |
| 5.150.1 Detailed Description . . . . .               | 346 |
| 5.151 API Function Prototypes . . . . .              | 346 |
| 5.151.1 Detailed Description . . . . .               | 347 |
| 5.151.2 Function Documentation . . . . .             | 347 |
| 5.151.2.1 MCAL_USART_DeInit() . . . . .              | 347 |
| 5.151.2.2 MCAL_USART_GPIO_Set_Pins() . . . . .       | 347 |
| 5.151.2.3 MCAL_USART_Init() . . . . .                | 348 |
| 5.151.2.4 MCAL_USART_ReceiveBuffer() . . . . .       | 349 |
| 5.151.2.5 MCAL_USART_ReceiveData() . . . . .         | 349 |
| 5.151.2.6 MCAL_USART_SendData() . . . . .            | 349 |
| 5.151.2.7 MCAL_USART_SendString() . . . . .          | 350 |
| 5.151.2.8 MCAL_USART_Wait_TC() . . . . .             | 350 |
| 5.152 Application States . . . . .                   | 350 |

---

|                                                         |     |
|---------------------------------------------------------|-----|
| 5.152.1 Detailed Description . . . . .                  | 352 |
| 5.152.2 Enumeration Type Documentation . . . . .        | 352 |
| 5.152.2.1 STATES . . . . .                              | 352 |
| 5.152.3 Function Documentation . . . . .                | 352 |
| 5.152.3.1 STATE_API() [1/6] . . . . .                   | 353 |
| 5.152.3.2 STATE_API() [2/6] . . . . .                   | 353 |
| 5.152.3.3 STATE_API() [3/6] . . . . .                   | 353 |
| 5.152.3.4 STATE_API() [4/6] . . . . .                   | 353 |
| 5.152.3.5 STATE_API() [5/6] . . . . .                   | 353 |
| 5.152.3.6 STATE_API() [6/6] . . . . .                   | 353 |
| 5.152.4 Variable Documentation . . . . .                | 354 |
| 5.152.4.1 fp_App_State_Handler . . . . .                | 354 |
| 5.152.4.2 Free_Slots . . . . .                          | 354 |
| 5.153 Includes . . . . .                                | 354 |
| 5.154 State Macros . . . . .                            | 355 |
| 5.154.1 Detailed Description . . . . .                  | 355 |
| 5.154.2 Macro Definition Documentation . . . . .        | 355 |
| 5.154.2.1 STATE_API . . . . .                           | 355 |
| 5.154.2.2 STATE_NAME . . . . .                          | 356 |
| 5.155 Prototypes . . . . .                              | 356 |
| 5.155.1 Detailed Description . . . . .                  | 356 |
| 5.155.2 Variable Documentation . . . . .                | 356 |
| 5.155.2.1 fp_App_State_Handler . . . . .                | 357 |
| 5.156 State Handlers . . . . .                          | 357 |
| 5.156.1 Detailed Description . . . . .                  | 357 |
| 5.156.2 Function Documentation . . . . .                | 358 |
| 5.156.2.1 STATE_API() [1/6] . . . . .                   | 358 |
| 5.156.2.2 STATE_API() [2/6] . . . . .                   | 358 |
| 5.156.2.3 STATE_API() [3/6] . . . . .                   | 358 |
| 5.156.2.4 STATE_API() [4/6] . . . . .                   | 358 |
| 5.156.2.5 STATE_API() [5/6] . . . . .                   | 358 |
| 5.156.2.6 STATE_API() [6/6] . . . . .                   | 359 |
| 5.157 ECU Definitions and APIs . . . . .                | 359 |
| 5.157.1 Detailed Description . . . . .                  | 360 |
| 5.158 Enum representing the result of ID check. . . . . | 360 |
| 5.158.1 Detailed Description . . . . .                  | 360 |
| 5.158.2 Enumeration Type Documentation . . . . .        | 360 |
| 5.158.2.1 ID_Check_Result . . . . .                     | 360 |
| 5.159 Configuration Macros . . . . .                    | 360 |
| 5.159.1 Detailed Description . . . . .                  | 361 |
| 5.160 ECU APIs . . . . .                                | 361 |
| 5.160.1 Detailed Description . . . . .                  | 362 |

---

|                                                  |     |
|--------------------------------------------------|-----|
| 5.160.2 Function Documentation . . . . .         | 362 |
| 5.160.2.1 Admin_Init() . . . . .                 | 363 |
| 5.160.2.2 Check_Flag() . . . . .                 | 363 |
| 5.160.2.3 Check_ID() . . . . .                   | 364 |
| 5.160.2.4 Check_Password() . . . . .             | 364 |
| 5.160.2.5 combineArrays() . . . . .              | 365 |
| 5.160.2.6 ECU_Init() . . . . .                   | 365 |
| 5.160.2.7 Enter_Gate_Open() . . . . .            | 366 |
| 5.160.2.8 Exit_Gate_Open() . . . . .             | 366 |
| 5.160.2.9 Flag_SET_RESET() . . . . .             | 367 |
| 5.160.2.10 Trigger_Alarm() . . . . .             | 367 |
| 5.160.2.11 UserLCD_PrintFreeSlots() . . . . .    | 368 |
| 5.160.2.12 Wrong_RFID() . . . . .                | 369 |
| 5.161 Functions_Declarations . . . . .           | 369 |
| 5.161.1 Detailed Description . . . . .           | 370 |
| 5.162 Global_Variables_Definitions . . . . .     | 370 |
| 5.162.1 Detailed Description . . . . .           | 370 |
| 5.162.2 Macro Definition Documentation . . . . . | 370 |
| 5.162.2.1 SIZE1 . . . . .                        | 371 |
| 5.162.3 Variable Documentation . . . . .         | 371 |
| 5.162.3.1 Exit_Flag . . . . .                    | 371 |
| 5.162.3.2 Free_Slots . . . . .                   | 371 |
| 5.162.3.3 Print_Slots_LCD_Flag . . . . .         | 371 |
| 5.163 API_Definitions . . . . .                  | 371 |
| 5.163.1 Detailed Description . . . . .           | 372 |
| 5.163.2 Function Documentation . . . . .         | 372 |
| 5.163.2.1 Admin_Init() . . . . .                 | 372 |
| 5.163.2.2 Check_Flag() . . . . .                 | 373 |
| 5.163.2.3 Check_ID() . . . . .                   | 373 |
| 5.163.2.4 Check_Password() . . . . .             | 374 |
| 5.163.2.5 combineArrays() . . . . .              | 374 |
| 5.163.2.6 ECU_Init() . . . . .                   | 375 |
| 5.163.2.7 Enter_Gate_Open() . . . . .            | 375 |
| 5.163.2.8 Enter_UART_CallBack() . . . . .        | 375 |
| 5.163.2.9 Exit_Gate_Open() . . . . .             | 376 |
| 5.163.2.10 Exit_UART_CallBack() . . . . .        | 376 |
| 5.163.2.11 Flag_SET_RESET() . . . . .            | 377 |
| 5.163.2.12 Trigger_Alarm() . . . . .             | 377 |
| 5.163.2.13 UserLCD_PrintFreeSlots() . . . . .    | 377 |
| 5.163.2.14 Wrong_RFID() . . . . .                | 378 |
| 5.164 CMSIS . . . . .                            | 379 |
| 5.164.1 Detailed Description . . . . .           | 398 |

---

|                                                        |     |
|--------------------------------------------------------|-----|
| 5.164.1.1 MISRA-C:2004 Compliance Exceptions . . . . . | 398 |
| 5.164.2 Macro Definition Documentation . . . . .       | 398 |
| 5.164.2.1 __CM4_CMSIS_VERSION . . . . .                | 398 |
| 5.164.2.2 __CM4_CMSIS_VERSION_MAIN . . . . .           | 398 |
| 5.164.2.3 __CM4_CMSIS_VERSION_SUB . . . . .            | 398 |
| 5.164.2.4 __CORE_CM4_H_DEPENDANT . . . . .             | 399 |
| 5.164.2.5 __CORTEX_M . . . . .                         | 399 |
| 5.164.2.6 __I . . . . .                                | 399 |
| 5.164.2.7 __IO . . . . .                               | 399 |
| 5.164.2.8 __O . . . . .                                | 399 |
| 5.164.2.9 APSR_C_Msk . . . . .                         | 399 |
| 5.164.2.10 APSR_C_Pos . . . . .                        | 399 |
| 5.164.2.11 APSR_GE_Msk . . . . .                       | 400 |
| 5.164.2.12 APSR_GE_Pos . . . . .                       | 400 |
| 5.164.2.13 APSR_N_Msk . . . . .                        | 400 |
| 5.164.2.14 APSR_N_Pos . . . . .                        | 400 |
| 5.164.2.15 APSR_Q_Msk . . . . .                        | 400 |
| 5.164.2.16 APSR_Q_Pos . . . . .                        | 400 |
| 5.164.2.17 APSR_V_Msk . . . . .                        | 400 |
| 5.164.2.18 APSR_V_Pos . . . . .                        | 400 |
| 5.164.2.19 APSR_Z_Msk . . . . .                        | 401 |
| 5.164.2.20 APSR_Z_Pos . . . . .                        | 401 |
| 5.164.2.21 CONTROL_FPCA_Msk . . . . .                  | 401 |
| 5.164.2.22 CONTROL_FPCA_Pos . . . . .                  | 401 |
| 5.164.2.23 CONTROL_nPRIV_Msk . . . . .                 | 401 |
| 5.164.2.24 CONTROL_nPRIV_Pos . . . . .                 | 401 |
| 5.164.2.25 CONTROL_SPSEL_Msk . . . . .                 | 401 |
| 5.164.2.26 CONTROL_SPSEL_Pos . . . . .                 | 401 |
| 5.164.2.27 CoreDebug . . . . .                         | 402 |
| 5.164.2.28 CoreDebug_BASE . . . . .                    | 402 |
| 5.164.2.29 CoreDebug_DCRSR_REGSEL_Msk . . . . .        | 402 |
| 5.164.2.30 CoreDebug_DCRSR_REGSEL_Pos . . . . .        | 402 |
| 5.164.2.31 CoreDebug_DCRSR_REGWnR_Msk . . . . .        | 402 |
| 5.164.2.32 CoreDebug_DCRSR_REGWnR_Pos . . . . .        | 402 |
| 5.164.2.33 CoreDebug DEMCR_MON_EN_Msk . . . . .        | 402 |
| 5.164.2.34 CoreDebug DEMCR_MON_EN_Pos . . . . .        | 403 |
| 5.164.2.35 CoreDebug DEMCR_MON_PEND_Msk . . . . .      | 403 |
| 5.164.2.36 CoreDebug DEMCR_MON_PEND_Pos . . . . .      | 403 |
| 5.164.2.37 CoreDebug DEMCR_MON_REQ_Msk . . . . .       | 403 |
| 5.164.2.38 CoreDebug DEMCR_MON_REQ_Pos . . . . .       | 403 |
| 5.164.2.39 CoreDebug DEMCR_MON_STEP_Msk . . . . .      | 403 |
| 5.164.2.40 CoreDebug DEMCR_MON_STEP_Pos . . . . .      | 403 |

|                                                       |     |
|-------------------------------------------------------|-----|
| 5.164.2.41 CoreDebug_DEMCR_TRCENA_Msk . . . . .       | 403 |
| 5.164.2.42 CoreDebug_DEMCR_TRCENA_Pos . . . . .       | 404 |
| 5.164.2.43 CoreDebug_DEMCR_VC_BUSERR_Msk . . . . .    | 404 |
| 5.164.2.44 CoreDebug_DEMCR_VC_BUSERR_Pos . . . . .    | 404 |
| 5.164.2.45 CoreDebug_DEMCR_VC_CHKERR_Msk . . . . .    | 404 |
| 5.164.2.46 CoreDebug_DEMCR_VC_CHKERR_Pos . . . . .    | 404 |
| 5.164.2.47 CoreDebug_DEMCR_VC_CORERESET_Msk . . . . . | 404 |
| 5.164.2.48 CoreDebug_DEMCR_VC_CORERESET_Pos . . . . . | 404 |
| 5.164.2.49 CoreDebug_DEMCR_VC_HARDERR_Msk . . . . .   | 404 |
| 5.164.2.50 CoreDebug_DEMCR_VC_HARDERR_Pos . . . . .   | 405 |
| 5.164.2.51 CoreDebug_DEMCR_VC_INTERR_Msk . . . . .    | 405 |
| 5.164.2.52 CoreDebug_DEMCR_VC_INTERR_Pos . . . . .    | 405 |
| 5.164.2.53 CoreDebug_DEMCR_VC_MMERR_Msk . . . . .     | 405 |
| 5.164.2.54 CoreDebug_DEMCR_VC_MMERR_Pos . . . . .     | 405 |
| 5.164.2.55 CoreDebug_DEMCR_VC_NOCPERR_Msk . . . . .   | 405 |
| 5.164.2.56 CoreDebug_DEMCR_VC_NOCPERR_Pos . . . . .   | 405 |
| 5.164.2.57 CoreDebug_DEMCR_VC_STATERR_Msk . . . . .   | 405 |
| 5.164.2.58 CoreDebug_DEMCR_VC_STATERR_Pos . . . . .   | 406 |
| 5.164.2.59 CoreDebug_DHCSR_C_DEBUGEN_Msk . . . . .    | 406 |
| 5.164.2.60 CoreDebug_DHCSR_C_DEBUGEN_Pos . . . . .    | 406 |
| 5.164.2.61 CoreDebug_DHCSR_C_HALT_Msk . . . . .       | 406 |
| 5.164.2.62 CoreDebug_DHCSR_C_HALT_Pos . . . . .       | 406 |
| 5.164.2.63 CoreDebug_DHCSR_C_MASKINTS_Msk . . . . .   | 406 |
| 5.164.2.64 CoreDebug_DHCSR_C_MASKINTS_Pos . . . . .   | 406 |
| 5.164.2.65 CoreDebug_DHCSR_C_SNAPSTALL_Msk . . . . .  | 406 |
| 5.164.2.66 CoreDebug_DHCSR_C_SNAPSTALL_Pos . . . . .  | 407 |
| 5.164.2.67 CoreDebug_DHCSR_C_STEP_Msk . . . . .       | 407 |
| 5.164.2.68 CoreDebug_DHCSR_C_STEP_Pos . . . . .       | 407 |
| 5.164.2.69 CoreDebug_DHCSR_DBGKEY_Msk . . . . .       | 407 |
| 5.164.2.70 CoreDebug_DHCSR_DBGKEY_Pos . . . . .       | 407 |
| 5.164.2.71 CoreDebug_DHCSR_S_HALT_Msk . . . . .       | 407 |
| 5.164.2.72 CoreDebug_DHCSR_S_HALT_Pos . . . . .       | 407 |
| 5.164.2.73 CoreDebug_DHCSR_S_LOCKUP_Msk . . . . .     | 407 |
| 5.164.2.74 CoreDebug_DHCSR_S_LOCKUP_Pos . . . . .     | 408 |
| 5.164.2.75 CoreDebug_DHCSR_S_REGRDY_Msk . . . . .     | 408 |
| 5.164.2.76 CoreDebug_DHCSR_S_REGRDY_Pos . . . . .     | 408 |
| 5.164.2.77 CoreDebug_DHCSR_S_RESET_ST_Msk . . . . .   | 408 |
| 5.164.2.78 CoreDebug_DHCSR_S_RESET_ST_Pos . . . . .   | 408 |
| 5.164.2.79 CoreDebug_DHCSR_S_RETIRE_ST_Msk . . . . .  | 408 |
| 5.164.2.80 CoreDebug_DHCSR_S_RETIRE_ST_Pos . . . . .  | 408 |
| 5.164.2.81 CoreDebug_DHCSR_S_SLEEP_Msk . . . . .      | 408 |
| 5.164.2.82 CoreDebug_DHCSR_S_SLEEP_Pos . . . . .      | 409 |

---

|                                                |     |
|------------------------------------------------|-----|
| 5.164.2.83 DWT . . . . .                       | 409 |
| 5.164.2.84 DWT_BASE . . . . .                  | 409 |
| 5.164.2.85 DWT_CPICNT_CPICNT_Msk . . . . .     | 409 |
| 5.164.2.86 DWT_CPICNT_CPICNT_Pos . . . . .     | 409 |
| 5.164.2.87 DWT_CTRL_CPIEVTENA_Msk . . . . .    | 409 |
| 5.164.2.88 DWT_CTRL_CPIEVTENA_Pos . . . . .    | 409 |
| 5.164.2.89 DWT_CTRL_CYCCNTENA_Msk . . . . .    | 410 |
| 5.164.2.90 DWT_CTRL_CYCCNTENA_Pos . . . . .    | 410 |
| 5.164.2.91 DWT_CTRL_CYCEVTENA_Msk . . . . .    | 410 |
| 5.164.2.92 DWT_CTRL_CYCEVTENA_Pos . . . . .    | 410 |
| 5.164.2.93 DWT_CTRL_CYCTAP_Msk . . . . .       | 410 |
| 5.164.2.94 DWT_CTRL_CYCTAP_Pos . . . . .       | 410 |
| 5.164.2.95 DWT_CTRL_EXCEVTENA_Msk . . . . .    | 410 |
| 5.164.2.96 DWT_CTRL_EXCEVTENA_Pos . . . . .    | 410 |
| 5.164.2.97 DWT_CTRL_EXCTRCENA_Msk . . . . .    | 411 |
| 5.164.2.98 DWT_CTRL_EXCTRCENA_Pos . . . . .    | 411 |
| 5.164.2.99 DWT_CTRL_FOLDEVTENA_Msk . . . . .   | 411 |
| 5.164.2.100 DWT_CTRL_FOLDEVTENA_Pos . . . . .  | 411 |
| 5.164.2.101 DWT_CTRL_LSUEVTENA_Msk . . . . .   | 411 |
| 5.164.2.102 DWT_CTRL_LSUEVTENA_Pos . . . . .   | 411 |
| 5.164.2.103 DWT_CTRL_NOCYCCNT_Msk . . . . .    | 411 |
| 5.164.2.104 DWT_CTRL_NOCYCCNT_Pos . . . . .    | 411 |
| 5.164.2.105 DWT_CTRL_NOEXTTRIG_Msk . . . . .   | 412 |
| 5.164.2.106 DWT_CTRL_NOEXTTRIG_Pos . . . . .   | 412 |
| 5.164.2.107 DWT_CTRL_NOPRFCNT_Msk . . . . .    | 412 |
| 5.164.2.108 DWT_CTRL_NOPRFCNT_Pos . . . . .    | 412 |
| 5.164.2.109 DWT_CTRL_NOTRPCPKT_Msk . . . . .   | 412 |
| 5.164.2.110 DWT_CTRL_NOTRPCPKT_Pos . . . . .   | 412 |
| 5.164.2.111 DWT_CTRL_NUMCOMP_Msk . . . . .     | 412 |
| 5.164.2.112 DWT_CTRL_NUMCOMP_Pos . . . . .     | 412 |
| 5.164.2.113 DWT_CTRL_PCSAMPLENA_Msk . . . . .  | 413 |
| 5.164.2.114 DWT_CTRL_PCSAMPLENA_Pos . . . . .  | 413 |
| 5.164.2.115 DWT_CTRL_POSTINIT_Msk . . . . .    | 413 |
| 5.164.2.116 DWT_CTRL_POSTINIT_Pos . . . . .    | 413 |
| 5.164.2.117 DWT_CTRL_POSTPRESET_Msk . . . . .  | 413 |
| 5.164.2.118 DWT_CTRL_POSTPRESET_Pos . . . . .  | 413 |
| 5.164.2.119 DWT_CTRL_SLEEPEVTENA_Msk . . . . . | 413 |
| 5.164.2.120 DWT_CTRL_SLEEPEVTENA_Pos . . . . . | 413 |
| 5.164.2.121 DWT_CTRL_SYNCTAP_Msk . . . . .     | 414 |
| 5.164.2.122 DWT_CTRL_SYNCTAP_Pos . . . . .     | 414 |
| 5.164.2.123 DWT_EXCCNT_EXCCNT_Msk . . . . .    | 414 |
| 5.164.2.124 DWT_EXCCNT_EXCCNT_Pos . . . . .    | 414 |

---

|                                                   |     |
|---------------------------------------------------|-----|
| 5.164.2.125 DWT_FOLDCNT_FOLDCNT_Msk . . . . .     | 414 |
| 5.164.2.126 DWT_FOLDCNT_FOLDCNT_Pos . . . . .     | 414 |
| 5.164.2.127 DWT_FUNCTION_CYCMATCH_Msk . . . . .   | 414 |
| 5.164.2.128 DWT_FUNCTION_CYCMATCH_Pos . . . . .   | 414 |
| 5.164.2.129 DWT_FUNCTION_DATAVADDR0_Msk . . . . . | 415 |
| 5.164.2.130 DWT_FUNCTION_DATAVADDR0_Pos . . . . . | 415 |
| 5.164.2.131 DWT_FUNCTION_DATAVADDR1_Msk . . . . . | 415 |
| 5.164.2.132 DWT_FUNCTION_DATAVADDR1_Pos . . . . . | 415 |
| 5.164.2.133 DWT_FUNCTION_DATAVMATCH_Msk . . . . . | 415 |
| 5.164.2.134 DWT_FUNCTION_DATAVMATCH_Pos . . . . . | 415 |
| 5.164.2.135 DWT_FUNCTION_DATAVSIZE_Msk . . . . .  | 415 |
| 5.164.2.136 DWT_FUNCTION_DATAVSIZE_Pos . . . . .  | 415 |
| 5.164.2.137 DWT_FUNCTION_EMITRANGE_Msk . . . . .  | 416 |
| 5.164.2.138 DWT_FUNCTION_EMITRANGE_Pos . . . . .  | 416 |
| 5.164.2.139 DWT_FUNCTION_FUNCTION_Msk . . . . .   | 416 |
| 5.164.2.140 DWT_FUNCTION_FUNCTION_Pos . . . . .   | 416 |
| 5.164.2.141 DWT_FUNCTION_LNK1ENA_Msk . . . . .    | 416 |
| 5.164.2.142 DWT_FUNCTION_LNK1ENA_Pos . . . . .    | 416 |
| 5.164.2.143 DWT_FUNCTION_MATCHED_Msk . . . . .    | 416 |
| 5.164.2.144 DWT_FUNCTION_MATCHED_Pos . . . . .    | 416 |
| 5.164.2.145 DWT_LSUCNT_LSUCNT_Msk . . . . .       | 417 |
| 5.164.2.146 DWT_LSUCNT_LSUCNT_Pos . . . . .       | 417 |
| 5.164.2.147 DWT_MASK_MASK_Msk . . . . .           | 417 |
| 5.164.2.148 DWT_MASK_MASK_Pos . . . . .           | 417 |
| 5.164.2.149 DWT_SLEEPCNT_SLEEPCNT_Msk . . . . .   | 417 |
| 5.164.2.150 DWT_SLEEPCNT_SLEEPCNT_Pos . . . . .   | 417 |
| 5.164.2.151 IPSR_ISR_Msk . . . . .                | 417 |
| 5.164.2.152 IPSR_ISR_Pos . . . . .                | 417 |
| 5.164.2.153 ITM . . . . .                         | 418 |
| 5.164.2.154 ITM_BASE . . . . .                    | 418 |
| 5.164.2.155 ITM_IMCR_INTEGRATION_Msk . . . . .    | 418 |
| 5.164.2.156 ITM_IMCR_INTEGRATION_Pos . . . . .    | 418 |
| 5.164.2.157 ITM_IRR_ATREADYM_Msk . . . . .        | 418 |
| 5.164.2.158 ITM_IRR_ATREADYM_Pos . . . . .        | 418 |
| 5.164.2.159 ITM_IWR_ATVALIDM_Msk . . . . .        | 418 |
| 5.164.2.160 ITM_IWR_ATVALIDM_Pos . . . . .        | 419 |
| 5.164.2.161 ITM_LSR_Access_Msk . . . . .          | 419 |
| 5.164.2.162 ITM_LSR_Access_Pos . . . . .          | 419 |
| 5.164.2.163 ITM_LSR_BytAcc_Msk . . . . .          | 419 |
| 5.164.2.164 ITM_LSR_BytAcc_Pos . . . . .          | 419 |
| 5.164.2.165 ITM_LSR_Present_Msk . . . . .         | 419 |
| 5.164.2.166 ITM_LSR_Present_Pos . . . . .         | 419 |

---

|                                                   |     |
|---------------------------------------------------|-----|
| 5.164.2.167 ITM_RXBUFFER_EMPTY . . . . .          | 419 |
| 5.164.2.168 ITM_TCR_BUSY_Msk . . . . .            | 420 |
| 5.164.2.169 ITM_TCR_BUSY_Pos . . . . .            | 420 |
| 5.164.2.170 ITM_TCR_DWTENA_Msk . . . . .          | 420 |
| 5.164.2.171 ITM_TCR_DWTENA_Pos . . . . .          | 420 |
| 5.164.2.172 ITM_TCR_GTSFREQ_Msk . . . . .         | 420 |
| 5.164.2.173 ITM_TCR_GTSFREQ_Pos . . . . .         | 420 |
| 5.164.2.174 ITM_TCR_ITMENA_Msk . . . . .          | 420 |
| 5.164.2.175 ITM_TCR_ITMENA_Pos . . . . .          | 420 |
| 5.164.2.176 ITM_TCR_SWOENA_Msk . . . . .          | 421 |
| 5.164.2.177 ITM_TCR_SWOENA_Pos . . . . .          | 421 |
| 5.164.2.178 ITM_TCR_SYNCENA_Msk . . . . .         | 421 |
| 5.164.2.179 ITM_TCR_SYNCENA_Pos . . . . .         | 421 |
| 5.164.2.180 ITM_TCR_TraceBusID_Msk . . . . .      | 421 |
| 5.164.2.181 ITM_TCR_TraceBusID_Pos . . . . .      | 421 |
| 5.164.2.182 ITM_TCR_TSENA_Msk . . . . .           | 421 |
| 5.164.2.183 ITM_TCR_TSENA_Pos . . . . .           | 421 |
| 5.164.2.184 ITM_TCR_TSPrescale_Msk . . . . .      | 422 |
| 5.164.2.185 ITM_TCR_TSPrescale_Pos . . . . .      | 422 |
| 5.164.2.186 ITM_TPR_PRIVMASK_Msk . . . . .        | 422 |
| 5.164.2.187 ITM_TPR_PRIVMASK_Pos . . . . .        | 422 |
| 5.164.2.188 NVIC . . . . .                        | 422 |
| 5.164.2.189 NVIC_BASE . . . . .                   | 422 |
| 5.164.2.190 NVIC_STIR_INTID_Msk . . . . .         | 422 |
| 5.164.2.191 NVIC_STIR_INTID_Pos . . . . .         | 423 |
| 5.164.2.192 SCB . . . . .                         | 423 |
| 5.164.2.193 SCB_AIRCR_ENDIANESS_Msk . . . . .     | 423 |
| 5.164.2.194 SCB_AIRCR_ENDIANESS_Pos . . . . .     | 423 |
| 5.164.2.195 SCB_AIRCR_PRIGROUP_Msk . . . . .      | 423 |
| 5.164.2.196 SCB_AIRCR_PRIGROUP_Pos . . . . .      | 423 |
| 5.164.2.197 SCB_AIRCR_SYSRESETREQ_Msk . . . . .   | 423 |
| 5.164.2.198 SCB_AIRCR_SYSRESETREQ_Pos . . . . .   | 424 |
| 5.164.2.199 SCB_AIRCR_VECTCLRACTIVE_Msk . . . . . | 424 |
| 5.164.2.200 SCB_AIRCR_VECTCLRACTIVE_Pos . . . . . | 424 |
| 5.164.2.201 SCB_AIRCR_VECTKEY_Msk . . . . .       | 424 |
| 5.164.2.202 SCB_AIRCR_VECTKEY_Pos . . . . .       | 424 |
| 5.164.2.203 SCB_AIRCR_VECTKEYSTAT_Msk . . . . .   | 424 |
| 5.164.2.204 SCB_AIRCR_VECTKEYSTAT_Pos . . . . .   | 424 |
| 5.164.2.205 SCB_AIRCR_VECTRESET_Msk . . . . .     | 424 |
| 5.164.2.206 SCB_AIRCR_VECTRESET_Pos . . . . .     | 425 |
| 5.164.2.207 SCB_BASE . . . . .                    | 425 |
| 5.164.2.208 SCB_CCR_BFHFNIGN_Msk . . . . .        | 425 |

|                                                  |     |
|--------------------------------------------------|-----|
| 5.164.2.209 SCB_CCR_BFHFMIGN_Pos . . . . .       | 425 |
| 5.164.2.210 SCB_CCR_DIV_0_TRP_Msk . . . . .      | 425 |
| 5.164.2.211 SCB_CCR_DIV_0_TRP_Pos . . . . .      | 425 |
| 5.164.2.212 SCB_CCR_NONBASETHRDENA_Msk . . . . . | 425 |
| 5.164.2.213 SCB_CCR_NONBASETHRDENA_Pos . . . . . | 426 |
| 5.164.2.214 SCB_CCR_STKALIGN_Msk . . . . .       | 426 |
| 5.164.2.215 SCB_CCR_STKALIGN_Pos . . . . .       | 426 |
| 5.164.2.216 SCB_CCR_UNALIGN_TRP_Msk . . . . .    | 426 |
| 5.164.2.217 SCB_CCR_UNALIGN_TRP_Pos . . . . .    | 426 |
| 5.164.2.218 SCB_CCR_USERSETPEND_Msk . . . . .    | 426 |
| 5.164.2.219 SCB_CCR_USERSETPEND_Pos . . . . .    | 426 |
| 5.164.2.220 SCB_CFSR_BUSFAULTSR_Msk . . . . .    | 426 |
| 5.164.2.221 SCB_CFSR_BUSFAULTSR_Pos . . . . .    | 427 |
| 5.164.2.222 SCB_CFSR_MEMFAULTSR_Msk . . . . .    | 427 |
| 5.164.2.223 SCB_CFSR_MEMFAULTSR_Pos . . . . .    | 427 |
| 5.164.2.224 SCB_CFSR_USGFAULTSR_Msk . . . . .    | 427 |
| 5.164.2.225 SCB_CFSR_USGFAULTSR_Pos . . . . .    | 427 |
| 5.164.2.226 SCB_CPUID_ARCHITECTURE_Msk . . . . . | 427 |
| 5.164.2.227 SCB_CPUID_ARCHITECTURE_Pos . . . . . | 427 |
| 5.164.2.228 SCB_CPUID_IMPLEMENTER_Msk . . . . .  | 427 |
| 5.164.2.229 SCB_CPUID_IMPLEMENTER_Pos . . . . .  | 428 |
| 5.164.2.230 SCB_CPUID_PARTNO_Msk . . . . .       | 428 |
| 5.164.2.231 SCB_CPUID_PARTNO_Pos . . . . .       | 428 |
| 5.164.2.232 SCB_CPUID_REVISION_Msk . . . . .     | 428 |
| 5.164.2.233 SCB_CPUID_REVISION_Pos . . . . .     | 428 |
| 5.164.2.234 SCB_CPUID_VARIANT_Msk . . . . .      | 428 |
| 5.164.2.235 SCB_CPUID_VARIANT_Pos . . . . .      | 428 |
| 5.164.2.236 SCB_DFSR_BKPT_Msk . . . . .          | 428 |
| 5.164.2.237 SCB_DFSR_BKPT_Pos . . . . .          | 429 |
| 5.164.2.238 SCB_DFSR_DWTTRAP_Msk . . . . .       | 429 |
| 5.164.2.239 SCB_DFSR_DWTTRAP_Pos . . . . .       | 429 |
| 5.164.2.240 SCB_DFSR_EXTERNAL_Msk . . . . .      | 429 |
| 5.164.2.241 SCB_DFSR_EXTERNAL_Pos . . . . .      | 429 |
| 5.164.2.242 SCB_DFSR_HALTED_Msk . . . . .        | 429 |
| 5.164.2.243 SCB_DFSR_HALTED_Pos . . . . .        | 429 |
| 5.164.2.244 SCB_DFSR_VCATCH_Msk . . . . .        | 429 |
| 5.164.2.245 SCB_DFSR_VCATCH_Pos . . . . .        | 430 |
| 5.164.2.246 SCB_HFSR_DEBUGEVT_Msk . . . . .      | 430 |
| 5.164.2.247 SCB_HFSR_DEBUGEVT_Pos . . . . .      | 430 |
| 5.164.2.248 SCB_HFSR_FORCED_Msk . . . . .        | 430 |
| 5.164.2.249 SCB_HFSR_FORCED_Pos . . . . .        | 430 |
| 5.164.2.250 SCB_HFSR_VECTTBL_Msk . . . . .       | 430 |

---

|                                                    |     |
|----------------------------------------------------|-----|
| 5.164.2.251 SCB_HFSR_VECTTBL_Pos . . . . .         | 430 |
| 5.164.2.252 SCB_ICSR_ISRPENDING_Msk . . . . .      | 430 |
| 5.164.2.253 SCB_ICSR_ISRPENDING_Pos . . . . .      | 431 |
| 5.164.2.254 SCB_ICSR_ISRPREEMPT_Msk . . . . .      | 431 |
| 5.164.2.255 SCB_ICSR_ISRPREEMPT_Pos . . . . .      | 431 |
| 5.164.2.256 SCB_ICSR_NMIPENDSET_Msk . . . . .      | 431 |
| 5.164.2.257 SCB_ICSR_NMIPENDSET_Pos . . . . .      | 431 |
| 5.164.2.258 SCB_ICSR_PENDSTCLR_Msk . . . . .       | 431 |
| 5.164.2.259 SCB_ICSR_PENDSTCLR_Pos . . . . .       | 431 |
| 5.164.2.260 SCB_ICSR_PENDSTSET_Msk . . . . .       | 431 |
| 5.164.2.261 SCB_ICSR_PENDSTSET_Pos . . . . .       | 432 |
| 5.164.2.262 SCB_ICSR_PENDSVCLR_Msk . . . . .       | 432 |
| 5.164.2.263 SCB_ICSR_PENDSVCLR_Pos . . . . .       | 432 |
| 5.164.2.264 SCB_ICSR_PENDSVSET_Msk . . . . .       | 432 |
| 5.164.2.265 SCB_ICSR_PENDSVSET_Pos . . . . .       | 432 |
| 5.164.2.266 SCB_ICSR_RETTOBASE_Msk . . . . .       | 432 |
| 5.164.2.267 SCB_ICSR_RETTOBASE_Pos . . . . .       | 432 |
| 5.164.2.268 SCB_ICSR_VECTACTIVE_Msk . . . . .      | 432 |
| 5.164.2.269 SCB_ICSR_VECTACTIVE_Pos . . . . .      | 433 |
| 5.164.2.270 SCB_ICSR_VECTPENDING_Msk . . . . .     | 433 |
| 5.164.2.271 SCB_ICSR_VECTPENDING_Pos . . . . .     | 433 |
| 5.164.2.272 SCB_SCR_SEVONPEND_Msk . . . . .        | 433 |
| 5.164.2.273 SCB_SCR_SEVONPEND_Pos . . . . .        | 433 |
| 5.164.2.274 SCB_SCR_SLEEPDEEP_Msk . . . . .        | 433 |
| 5.164.2.275 SCB_SCR_SLEEPDEEP_Pos . . . . .        | 433 |
| 5.164.2.276 SCB_SCR_SLEEPONEXIT_Msk . . . . .      | 433 |
| 5.164.2.277 SCB_SCR_SLEEPONEXIT_Pos . . . . .      | 434 |
| 5.164.2.278 SCB_SHCSR_BUSFAULTACT_Msk . . . . .    | 434 |
| 5.164.2.279 SCB_SHCSR_BUSFAULTACT_Pos . . . . .    | 434 |
| 5.164.2.280 SCB_SHCSR_BUSFAULTENA_Msk . . . . .    | 434 |
| 5.164.2.281 SCB_SHCSR_BUSFAULTENA_Pos . . . . .    | 434 |
| 5.164.2.282 SCB_SHCSR_BUSFAULTPENDED_Msk . . . . . | 434 |
| 5.164.2.283 SCB_SHCSR_BUSFAULTPENDED_Pos . . . . . | 434 |
| 5.164.2.284 SCB_SHCSR_MEMFAULTACT_Msk . . . . .    | 434 |
| 5.164.2.285 SCB_SHCSR_MEMFAULTACT_Pos . . . . .    | 435 |
| 5.164.2.286 SCB_SHCSR_MEMFAULTENA_Msk . . . . .    | 435 |
| 5.164.2.287 SCB_SHCSR_MEMFAULTENA_Pos . . . . .    | 435 |
| 5.164.2.288 SCB_SHCSR_MEMFAULTPENDED_Msk . . . . . | 435 |
| 5.164.2.289 SCB_SHCSR_MEMFAULTPENDED_Pos . . . . . | 435 |
| 5.164.2.290 SCB_SHCSR_MONITORACT_Msk . . . . .     | 435 |
| 5.164.2.291 SCB_SHCSR_MONITORACT_Pos . . . . .     | 435 |
| 5.164.2.292 SCB_SHCSR_PENDSVACT_Msk . . . . .      | 435 |

---

|                                                    |     |
|----------------------------------------------------|-----|
| 5.164.2.293 SCB_SHCSR_PENDSVACT_Pos . . . . .      | 436 |
| 5.164.2.294 SCB_SHCSR_SVCALLACT_Msk . . . . .      | 436 |
| 5.164.2.295 SCB_SHCSR_SVCALLACT_Pos . . . . .      | 436 |
| 5.164.2.296 SCB_SHCSR_SVCALLPENDED_Msk . . . . .   | 436 |
| 5.164.2.297 SCB_SHCSR_SVCALLPENDED_Pos . . . . .   | 436 |
| 5.164.2.298 SCB_SHCSR_SYSTICKACT_Msk . . . . .     | 436 |
| 5.164.2.299 SCB_SHCSR_SYSTICKACT_Pos . . . . .     | 436 |
| 5.164.2.300 SCB_SHCSR_USGFAULTACT_Msk . . . . .    | 436 |
| 5.164.2.301 SCB_SHCSR_USGFAULTACT_Pos . . . . .    | 437 |
| 5.164.2.302 SCB_SHCSR_USGFAULTENA_Msk . . . . .    | 437 |
| 5.164.2.303 SCB_SHCSR_USGFAULTENA_Pos . . . . .    | 437 |
| 5.164.2.304 SCB_SHCSR_USGFAULTPENDED_Msk . . . . . | 437 |
| 5.164.2.305 SCB_SHCSR_USGFAULTPENDED_Pos . . . . . | 437 |
| 5.164.2.306 SCB_VTOR_TBLOFF_Msk . . . . .          | 437 |
| 5.164.2.307 SCB_VTOR_TBLOFF_Pos . . . . .          | 437 |
| 5.164.2.308 SCnSCB . . . . .                       | 437 |
| 5.164.2.309 SCnSCB_ACTLR_DISDEFWBUF_Msk . . . . .  | 438 |
| 5.164.2.310 SCnSCB_ACTLR_DISDEFWBUF_Pos . . . . .  | 438 |
| 5.164.2.311 SCnSCB_ACTLR_DISFOLD_Msk . . . . .     | 438 |
| 5.164.2.312 SCnSCB_ACTLR_DISFOLD_Pos . . . . .     | 438 |
| 5.164.2.313 SCnSCB_ACTLR_DISFPCA_Msk . . . . .     | 438 |
| 5.164.2.314 SCnSCB_ACTLR_DISFPCA_Pos . . . . .     | 438 |
| 5.164.2.315 SCnSCB_ACTLR_DISMCYCINT_Msk . . . . .  | 438 |
| 5.164.2.316 SCnSCB_ACTLR_DISMCYCINT_Pos . . . . .  | 438 |
| 5.164.2.317 SCnSCB_ACTLR_DISOOPF_Msk . . . . .     | 439 |
| 5.164.2.318 SCnSCB_ACTLR_DISOOPF_Pos . . . . .     | 439 |
| 5.164.2.319 SCnSCB_ICTR_INTLINESNUM_Msk . . . . .  | 439 |
| 5.164.2.320 SCnSCB_ICTR_INTLINESNUM_Pos . . . . .  | 439 |
| 5.164.2.321 SCS_BASE . . . . .                     | 439 |
| 5.164.2.322 SysTick . . . . .                      | 439 |
| 5.164.2.323 SysTick_BASE . . . . .                 | 439 |
| 5.164.2.324 SysTick_CALIB_NOREF_Msk . . . . .      | 440 |
| 5.164.2.325 SysTick_CALIB_NOREF_Pos . . . . .      | 440 |
| 5.164.2.326 SysTick_CALIB_SKEW_Msk . . . . .       | 440 |
| 5.164.2.327 SysTick_CALIB_SKEW_Pos . . . . .       | 440 |
| 5.164.2.328 SysTick_CALIB_TENMS_Msk . . . . .      | 440 |
| 5.164.2.329 SysTick_CALIB_TENMS_Pos . . . . .      | 440 |
| 5.164.2.330 SysTick_CTRL_CLKSOURCE_Msk . . . . .   | 440 |
| 5.164.2.331 SysTick_CTRL_CLKSOURCE_Pos . . . . .   | 440 |
| 5.164.2.332 SysTick_CTRL_COUNTFLAG_Msk . . . . .   | 441 |
| 5.164.2.333 SysTick_CTRL_COUNTFLAG_Pos . . . . .   | 441 |
| 5.164.2.334 SysTick_CTRL_ENABLE_Msk . . . . .      | 441 |

---

|                                                  |     |
|--------------------------------------------------|-----|
| 5.164.2.335 SysTick_CTRL_ENABLE_Pos . . . . .    | 441 |
| 5.164.2.336 SysTick_CTRL_TICKINT_Msk . . . . .   | 441 |
| 5.164.2.337 SysTick_CTRL_TICKINT_Pos . . . . .   | 441 |
| 5.164.2.338 SysTick_LOAD_RELOAD_Msk . . . . .    | 441 |
| 5.164.2.339 SysTick_LOAD_RELOAD_Pos . . . . .    | 441 |
| 5.164.2.340 SysTick_VAL_CURRENT_Msk . . . . .    | 442 |
| 5.164.2.341 SysTick_VAL_CURRENT_Pos . . . . .    | 442 |
| 5.164.2.342 TPI . . . . .                        | 442 |
| 5.164.2.343 TPI_ACPR_PRESCALER_Msk . . . . .     | 442 |
| 5.164.2.344 TPI_ACPR_PRESCALER_Pos . . . . .     | 442 |
| 5.164.2.345 TPI_BASE . . . . .                   | 442 |
| 5.164.2.346 TPI_DEVID_AsynClkIn_Msk . . . . .    | 442 |
| 5.164.2.347 TPI_DEVID_AsynClkIn_Pos . . . . .    | 443 |
| 5.164.2.348 TPI_DEVID_MANCVALID_Msk . . . . .    | 443 |
| 5.164.2.349 TPI_DEVID_MANCVALID_Pos . . . . .    | 443 |
| 5.164.2.350 TPI_DEVID_MinBufSz_Msk . . . . .     | 443 |
| 5.164.2.351 TPI_DEVID_MinBufSz_Pos . . . . .     | 443 |
| 5.164.2.352 TPI_DEVID_NrTraceInput_Msk . . . . . | 443 |
| 5.164.2.353 TPI_DEVID_NrTraceInput_Pos . . . . . | 443 |
| 5.164.2.354 TPI_DEVID_NRZVALID_Msk . . . . .     | 443 |
| 5.164.2.355 TPI_DEVID_NRZVALID_Pos . . . . .     | 444 |
| 5.164.2.356 TPI_DEVID_PTINVALID_Msk . . . . .    | 444 |
| 5.164.2.357 TPI_DEVID_PTINVALID_Pos . . . . .    | 444 |
| 5.164.2.358 TPI_DEVTYPE_MajorType_Msk . . . . .  | 444 |
| 5.164.2.359 TPI_DEVTYPE_MajorType_Pos . . . . .  | 444 |
| 5.164.2.360 TPI_DEVTYPE_SubType_Msk . . . . .    | 444 |
| 5.164.2.361 TPI_DEVTYPE_SubType_Pos . . . . .    | 444 |
| 5.164.2.362 TPI_FFCR_EnFCont_Msk . . . . .       | 444 |
| 5.164.2.363 TPI_FFCR_EnFCont_Pos . . . . .       | 445 |
| 5.164.2.364 TPI_FFCR_TrigIn_Msk . . . . .        | 445 |
| 5.164.2.365 TPI_FFCR_TrigIn_Pos . . . . .        | 445 |
| 5.164.2.366 TPI_FFSR_FInProg_Msk . . . . .       | 445 |
| 5.164.2.367 TPI_FFSR_FInProg_Pos . . . . .       | 445 |
| 5.164.2.368 TPI_FFSR_FtNonStop_Msk . . . . .     | 445 |
| 5.164.2.369 TPI_FFSR_FtNonStop_Pos . . . . .     | 445 |
| 5.164.2.370 TPI_FFSR_FtStopped_Msk . . . . .     | 445 |
| 5.164.2.371 TPI_FFSR_FtStopped_Pos . . . . .     | 446 |
| 5.164.2.372 TPI_FFSR_TCPresent_Msk . . . . .     | 446 |
| 5.164.2.373 TPI_FFSR_TCPresent_Pos . . . . .     | 446 |
| 5.164.2.374 TPI_FIFO0_ETM0_Msk . . . . .         | 446 |
| 5.164.2.375 TPI_FIFO0_ETM0_Pos . . . . .         | 446 |
| 5.164.2.376 TPI_FIFO0_ETM1_Msk . . . . .         | 446 |

---

|                                                   |     |
|---------------------------------------------------|-----|
| 5.164.2.377 TPI_FIFO0_ETM1_Pos . . . . .          | 446 |
| 5.164.2.378 TPI_FIFO0_ETM2_Msk . . . . .          | 446 |
| 5.164.2.379 TPI_FIFO0_ETM2_Pos . . . . .          | 447 |
| 5.164.2.380 TPI_FIFO0_ETM_ATVALID_Msk . . . . .   | 447 |
| 5.164.2.381 TPI_FIFO0_ETM_ATVALID_Pos . . . . .   | 447 |
| 5.164.2.382 TPI_FIFO0_ETM_bytecount_Msk . . . . . | 447 |
| 5.164.2.383 TPI_FIFO0_ETM_bytecount_Pos . . . . . | 447 |
| 5.164.2.384 TPI_FIFO0_ITM_ATVALID_Msk . . . . .   | 447 |
| 5.164.2.385 TPI_FIFO0_ITM_ATVALID_Pos . . . . .   | 447 |
| 5.164.2.386 TPI_FIFO0_ITM_bytecount_Msk . . . . . | 447 |
| 5.164.2.387 TPI_FIFO0_ITM_bytecount_Pos . . . . . | 448 |
| 5.164.2.388 TPI_FIFO1_ETM_ATVALID_Msk . . . . .   | 448 |
| 5.164.2.389 TPI_FIFO1_ETM_ATVALID_Pos . . . . .   | 448 |
| 5.164.2.390 TPI_FIFO1_ETM_bytecount_Msk . . . . . | 448 |
| 5.164.2.391 TPI_FIFO1_ETM_bytecount_Pos . . . . . | 448 |
| 5.164.2.392 TPI_FIFO1_ITM0_Msk . . . . .          | 448 |
| 5.164.2.393 TPI_FIFO1_ITM0_Pos . . . . .          | 448 |
| 5.164.2.394 TPI_FIFO1_ITM1_Msk . . . . .          | 448 |
| 5.164.2.395 TPI_FIFO1_ITM1_Pos . . . . .          | 449 |
| 5.164.2.396 TPI_FIFO1_ITM2_Msk . . . . .          | 449 |
| 5.164.2.397 TPI_FIFO1_ITM2_Pos . . . . .          | 449 |
| 5.164.2.398 TPI_FIFO1_ITM_ATVALID_Msk . . . . .   | 449 |
| 5.164.2.399 TPI_FIFO1_ITM_ATVALID_Pos . . . . .   | 449 |
| 5.164.2.400 TPI_FIFO1_ITM_bytecount_Msk . . . . . | 449 |
| 5.164.2.401 TPI_FIFO1_ITM_bytecount_Pos . . . . . | 449 |
| 5.164.2.402 TPI_ITATBCTR0_ATREADY_Msk . . . . .   | 449 |
| 5.164.2.403 TPI_ITATBCTR0_ATREADY_Pos . . . . .   | 450 |
| 5.164.2.404 TPI_ITATBCTR2_ATREADY_Msk . . . . .   | 450 |
| 5.164.2.405 TPI_ITATBCTR2_ATREADY_Pos . . . . .   | 450 |
| 5.164.2.406 TPI_ITCTRL_Mode_Msk . . . . .         | 450 |
| 5.164.2.407 TPI_ITCTRL_Mode_Pos . . . . .         | 450 |
| 5.164.2.408 TPI_SPPR_TXMODE_Msk . . . . .         | 450 |
| 5.164.2.409 TPI_SPPR_TXMODE_Pos . . . . .         | 450 |
| 5.164.2.410 TPI_TRIGGER_TRIGGER_Msk . . . . .     | 450 |
| 5.164.2.411 TPI_TRIGGER_TRIGGER_Pos . . . . .     | 451 |
| 5.164.2.412 xPSR_C_Msk . . . . .                  | 451 |
| 5.164.2.413 xPSR_C_Pos . . . . .                  | 451 |
| 5.164.2.414 xPSR_GE_Msk . . . . .                 | 451 |
| 5.164.2.415 xPSR_GE_Pos . . . . .                 | 451 |
| 5.164.2.416 xPSR_ISR_Msk . . . . .                | 451 |
| 5.164.2.417 xPSR_ISR_Pos . . . . .                | 451 |
| 5.164.2.418 xPSR_IT_Msk . . . . .                 | 451 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.164.2.419 xPSR_IT_Pos . . . . .               | 452 |
| 5.164.2.420 xPSR_N_Msk . . . . .                | 452 |
| 5.164.2.421 xPSR_N_Pos . . . . .                | 452 |
| 5.164.2.422 xPSR_Q_Msk . . . . .                | 452 |
| 5.164.2.423 xPSR_Q_Pos . . . . .                | 452 |
| 5.164.2.424 xPSR_T_Msk . . . . .                | 452 |
| 5.164.2.425 xPSR_T_Pos . . . . .                | 452 |
| 5.164.2.426 xPSR_V_Msk . . . . .                | 452 |
| 5.164.2.427 xPSR_V_Pos . . . . .                | 453 |
| 5.164.2.428 xPSR_Z_Msk . . . . .                | 453 |
| 5.164.2.429 xPSR_Z_Pos . . . . .                | 453 |
| 5.164.3 Function Documentation . . . . .        | 453 |
| 5.164.3.1 ITM_CheckChar() . . . . .             | 453 |
| 5.164.3.2 ITM_ReceiveChar() . . . . .           | 453 |
| 5.164.3.3 ITM_SendChar() . . . . .              | 454 |
| 5.164.3.4 NVIC_ClearPendingIRQ() . . . . .      | 454 |
| 5.164.3.5 NVIC_DecodePriority() . . . . .       | 454 |
| 5.164.3.6 NVIC_DisableIRQ() . . . . .           | 455 |
| 5.164.3.7 NVIC_EnableIRQ() . . . . .            | 455 |
| 5.164.3.8 NVIC_EncodePriority() . . . . .       | 455 |
| 5.164.3.9 NVIC_GetActive() . . . . .            | 457 |
| 5.164.3.10 NVIC_GetPendingIRQ() . . . . .       | 457 |
| 5.164.3.11 NVIC_GetPriority() . . . . .         | 458 |
| 5.164.3.12 NVIC_GetPriorityGrouping() . . . . . | 458 |
| 5.164.3.13 NVIC_SetPendingIRQ() . . . . .       | 458 |
| 5.164.3.14 NVIC_SetPriority() . . . . .         | 459 |
| 5.164.3.15 NVIC_SetPriorityGrouping() . . . . . | 459 |
| 5.164.3.16 NVIC_SystemReset() . . . . .         | 459 |
| 5.164.3.17 SysTick_Config() . . . . .           | 460 |
| 5.164.3.18 SysTick_Handler() . . . . .          | 460 |
| 5.164.4 Variable Documentation . . . . .        | 461 |
| 5.164.4.1 ACR . . . . .                         | 461 |
| 5.164.4.2 AFR . . . . .                         | 461 |
| 5.164.4.3 AHB1ENR . . . . .                     | 461 |
| 5.164.4.4 AHB1LPENR . . . . .                   | 461 |
| 5.164.4.5 AHB1RSTR . . . . .                    | 461 |
| 5.164.4.6 AHB2ENR . . . . .                     | 461 |
| 5.164.4.7 AHB2LPENR . . . . .                   | 462 |
| 5.164.4.8 AHB2RSTR . . . . .                    | 462 |
| 5.164.4.9 AHB3ENR . . . . .                     | 462 |
| 5.164.4.10 AHB3LPENR . . . . .                  | 462 |
| 5.164.4.11 AHB3RSTR . . . . .                   | 462 |

---

|                                |     |
|--------------------------------|-----|
| 5.164.4.12 ALRMAR . . . . .    | 462 |
| 5.164.4.13 ALRMASSR . . . . .  | 462 |
| 5.164.4.14 ALRMBR . . . . .    | 462 |
| 5.164.4.15 ALRBSSR . . . . .   | 463 |
| 5.164.4.16 AMTCR . . . . .     | 463 |
| 5.164.4.17 APB1ENR . . . . .   | 463 |
| 5.164.4.18 APB1FZ . . . . .    | 463 |
| 5.164.4.19 APB1LPENR . . . . . | 463 |
| 5.164.4.20 APB1RSTR . . . . .  | 463 |
| 5.164.4.21 APB2ENR . . . . .   | 463 |
| 5.164.4.22 APB2FZ . . . . .    | 463 |
| 5.164.4.23 APB2LPENR . . . . . | 464 |
| 5.164.4.24 APB2RSTR . . . . .  | 464 |
| 5.164.4.25 ARG . . . . .       | 464 |
| 5.164.4.26 ARR . . . . .       | 464 |
| 5.164.4.27 AWCR . . . . .      | 464 |
| 5.164.4.28 BCCR . . . . .      | 464 |
| 5.164.4.29 BDCR . . . . .      | 464 |
| 5.164.4.30 BDTR . . . . .      | 464 |
| 5.164.4.31 BFCR . . . . .      | 465 |
| 5.164.4.32 BGCLUT . . . . .    | 465 |
| 5.164.4.33 BGCMAR . . . . .    | 465 |
| 5.164.4.34 BGCOLR . . . . .    | 465 |
| 5.164.4.35 BGMAR . . . . .     | 465 |
| 5.164.4.36 BGOR . . . . .      | 465 |
| 5.164.4.37 BGPFCCR . . . . .   | 465 |
| 5.164.4.38 BKP0R . . . . .     | 465 |
| 5.164.4.39 BKP10R . . . . .    | 466 |
| 5.164.4.40 BKP11R . . . . .    | 466 |
| 5.164.4.41 BKP12R . . . . .    | 466 |
| 5.164.4.42 BKP13R . . . . .    | 466 |
| 5.164.4.43 BKP14R . . . . .    | 466 |
| 5.164.4.44 BKP15R . . . . .    | 466 |
| 5.164.4.45 BKP16R . . . . .    | 466 |
| 5.164.4.46 BKP17R . . . . .    | 466 |
| 5.164.4.47 BKP18R . . . . .    | 467 |
| 5.164.4.48 BKP19R . . . . .    | 467 |
| 5.164.4.49 BKP1R . . . . .     | 467 |
| 5.164.4.50 BKP2R . . . . .     | 467 |
| 5.164.4.51 BKP3R . . . . .     | 467 |
| 5.164.4.52 BKP4R . . . . .     | 467 |
| 5.164.4.53 BKP5R . . . . .     | 467 |

|                      |     |
|----------------------|-----|
| 5.164.4.54 BKP6R     | 467 |
| 5.164.4.55 BKP7R     | 468 |
| 5.164.4.56 BKP8R     | 468 |
| 5.164.4.57 BKP9R     | 468 |
| 5.164.4.58 BPCR      | 468 |
| 5.164.4.59 BRR       | 468 |
| 5.164.4.60 BSRRH     | 468 |
| 5.164.4.61 BSRRL     | 468 |
| 5.164.4.62 BTR       | 469 |
| 5.164.4.63 CACR      | 469 |
| 5.164.4.64 CALIBR    | 469 |
| 5.164.4.65 CALR      | 469 |
| 5.164.4.66 CCER      | 469 |
| 5.164.4.67 CCMR1     | 469 |
| 5.164.4.68 CCMR2     | 469 |
| 5.164.4.69 CCR [1/2] | 470 |
| 5.164.4.70 CCR [2/2] | 470 |
| 5.164.4.71 CCR1      | 470 |
| 5.164.4.72 CCR2      | 470 |
| 5.164.4.73 CCR3      | 470 |
| 5.164.4.74 CCR4      | 470 |
| 5.164.4.75 CDR       | 470 |
| 5.164.4.76 CDSR      | 470 |
| 5.164.4.77 CFBAR     | 471 |
| 5.164.4.78 CFBLNR    | 471 |
| 5.164.4.79 CFBLR     | 471 |
| 5.164.4.80 CFGR      | 471 |
| 5.164.4.81 CFR       | 471 |
| 5.164.4.82 CIR       | 471 |
| 5.164.4.83 CKCR      | 471 |
| 5.164.4.84 CKGATENR  | 471 |
| 5.164.4.85 CLKCR     | 472 |
| 5.164.4.86 CLRFR     | 472 |
| 5.164.4.87 CLUTWR    | 472 |
| 5.164.4.88 CMD       | 472 |
| 5.164.4.89 CMPCR     | 472 |
| 5.164.4.90 CNT       | 472 |
| 5.164.4.91 CPSR      | 472 |
| 5.164.4.92 CR [1/15] | 473 |
| 5.164.4.93 CR [2/15] | 473 |
| 5.164.4.94 CR [3/15] | 473 |
| 5.164.4.95 CR [4/15] | 473 |

---

|                                  |     |
|----------------------------------|-----|
| 5.164.4.96 CR [5/15] . . . . .   | 473 |
| 5.164.4.97 CR [6/15] . . . . .   | 473 |
| 5.164.4.98 CR [7/15] . . . . .   | 473 |
| 5.164.4.99 CR [8/15] . . . . .   | 474 |
| 5.164.4.100 CR [9/15] . . . . .  | 474 |
| 5.164.4.101 CR [10/15] . . . . . | 474 |
| 5.164.4.102 CR [11/15] . . . . . | 474 |
| 5.164.4.103 CR [12/15] . . . . . | 474 |
| 5.164.4.104 CR [13/15] . . . . . | 474 |
| 5.164.4.105 CR [14/15] . . . . . | 474 |
| 5.164.4.106 CR [15/15] . . . . . | 475 |
| 5.164.4.107 CR1 [1/6] . . . . .  | 475 |
| 5.164.4.108 CR1 [2/6] . . . . .  | 475 |
| 5.164.4.109 CR1 [3/6] . . . . .  | 475 |
| 5.164.4.110 CR1 [4/6] . . . . .  | 475 |
| 5.164.4.111 CR1 [5/6] . . . . .  | 475 |
| 5.164.4.112 CR1 [6/6] . . . . .  | 475 |
| 5.164.4.113 CR2 [1/6] . . . . .  | 475 |
| 5.164.4.114 CR2 [2/6] . . . . .  | 476 |
| 5.164.4.115 CR2 [3/6] . . . . .  | 476 |
| 5.164.4.116 CR2 [4/6] . . . . .  | 476 |
| 5.164.4.117 CR2 [5/6] . . . . .  | 476 |
| 5.164.4.118 CR2 [6/6] . . . . .  | 476 |
| 5.164.4.119 CR3 . . . . .        | 476 |
| 5.164.4.120 CRCPR . . . . .      | 476 |
| 5.164.4.121 CSGCM0R . . . . .    | 476 |
| 5.164.4.122 CSGCM1R . . . . .    | 477 |
| 5.164.4.123 CSGCM2R . . . . .    | 477 |
| 5.164.4.124 CSGCM3R . . . . .    | 477 |
| 5.164.4.125 CSGCM4R . . . . .    | 477 |
| 5.164.4.126 CSGCM5R . . . . .    | 477 |
| 5.164.4.127 CSGCM6R . . . . .    | 477 |
| 5.164.4.128 CSGCM7R . . . . .    | 477 |
| 5.164.4.129 CSGCMCCM0R . . . . . | 477 |
| 5.164.4.130 CSGCMCCM1R . . . . . | 478 |
| 5.164.4.131 CSGCMCCM2R . . . . . | 478 |
| 5.164.4.132 CSGCMCCM3R . . . . . | 478 |
| 5.164.4.133 CSGCMCCM4R . . . . . | 478 |
| 5.164.4.134 CSGCMCCM5R . . . . . | 478 |
| 5.164.4.135 CSGCMCCM6R . . . . . | 478 |
| 5.164.4.136 CSGCMCCM7R . . . . . | 478 |
| 5.164.4.137 CSR [1/4] . . . . .  | 478 |

---

|                        |     |
|------------------------|-----|
| 5.164.4.138 CSR [2/4]  | 479 |
| 5.164.4.139 CSR [3/4]  | 479 |
| 5.164.4.140 CSR [4/4]  | 479 |
| 5.164.4.141 CWSIZER    | 479 |
| 5.164.4.142 CWSTRTR    | 479 |
| 5.164.4.143 DCCR       | 479 |
| 5.164.4.144 DCKCFGR    | 479 |
| 5.164.4.145 DCKCFGR2   | 479 |
| 5.164.4.146 DCOUNT     | 480 |
| 5.164.4.147 DCR        | 480 |
| 5.164.4.148 DCTRL      | 480 |
| 5.164.4.149 DHR12L1    | 480 |
| 5.164.4.150 DHR12L2    | 480 |
| 5.164.4.151 DHR12LD    | 480 |
| 5.164.4.152 DHR12R1    | 480 |
| 5.164.4.153 DHR12R2    | 480 |
| 5.164.4.154 DHR12RD    | 481 |
| 5.164.4.155 DHR8R1     | 481 |
| 5.164.4.156 DHR8R2     | 481 |
| 5.164.4.157 DHR8RD     | 481 |
| 5.164.4.158 DIER       | 481 |
| 5.164.4.159 DIN        | 481 |
| 5.164.4.160 DLEN       | 481 |
| 5.164.4.161 DMACR      | 482 |
| 5.164.4.162 DMAR       | 482 |
| 5.164.4.163 DOR1       | 482 |
| 5.164.4.164 DOR2       | 482 |
| 5.164.4.165 DOUT       | 482 |
| 5.164.4.166 DR [1/10]  | 482 |
| 5.164.4.167 DR [2/10]  | 482 |
| 5.164.4.168 DR [3/10]  | 482 |
| 5.164.4.169 DR [4/10]  | 483 |
| 5.164.4.170 DR [5/10]  | 483 |
| 5.164.4.171 DR [6/10]  | 483 |
| 5.164.4.172 DR [7/10]  | 483 |
| 5.164.4.173 DR [8/10]  | 483 |
| 5.164.4.174 DR [9/10]  | 483 |
| 5.164.4.175 DR [10/10] | 483 |
| 5.164.4.176 DTIMER     | 483 |
| 5.164.4.177 EGR        | 484 |
| 5.164.4.178 EMR        | 484 |
| 5.164.4.179 ESCR       | 484 |

---

|                                 |     |
|---------------------------------|-----|
| 5.164.4.180 ESR . . . . .       | 484 |
| 5.164.4.181 ESUR . . . . .      | 484 |
| 5.164.4.182 EXTICR . . . . .    | 484 |
| 5.164.4.183 FA1R . . . . .      | 484 |
| 5.164.4.184 FCR . . . . .       | 485 |
| 5.164.4.185 FFA1R . . . . .     | 485 |
| 5.164.4.186 FGCLUT . . . . .    | 485 |
| 5.164.4.187 FGCMAR . . . . .    | 485 |
| 5.164.4.188 FGCOLR . . . . .    | 485 |
| 5.164.4.189 FGMAR . . . . .     | 485 |
| 5.164.4.190 FGOR . . . . .      | 485 |
| 5.164.4.191 FGPFCCR . . . . .   | 486 |
| 5.164.4.192 FIFO . . . . .      | 486 |
| 5.164.4.193 FIFOCNT . . . . .   | 486 |
| 5.164.4.194 FLTR . . . . .      | 486 |
| 5.164.4.195 FM1R . . . . .      | 486 |
| 5.164.4.196 FMR . . . . .       | 486 |
| 5.164.4.197 FR1 . . . . .       | 486 |
| 5.164.4.198 FR2 . . . . .       | 487 |
| 5.164.4.199 FRCR . . . . .      | 487 |
| 5.164.4.200 FS1R . . . . .      | 487 |
| 5.164.4.201 FTSR . . . . .      | 487 |
| 5.164.4.202 GCR [1/2] . . . . . | 487 |
| 5.164.4.203 GCR [2/2] . . . . . | 487 |
| 5.164.4.204 GTPR . . . . .      | 487 |
| 5.164.4.205 HIFCR . . . . .     | 488 |
| 5.164.4.206 HISR . . . . .      | 488 |
| 5.164.4.207 HR [1/2] . . . . .  | 488 |
| 5.164.4.208 HR [2/2] . . . . .  | 488 |
| 5.164.4.209 HTR . . . . .       | 488 |
| 5.164.4.210 I2SCFGR . . . . .   | 488 |
| 5.164.4.211 I2SPR . . . . .     | 488 |
| 5.164.4.212 ICR [1/3] . . . . . | 489 |
| 5.164.4.213 ICR [2/3] . . . . . | 489 |
| 5.164.4.214 ICR [3/3] . . . . . | 489 |
| 5.164.4.215 IDCODE . . . . .    | 489 |
| 5.164.4.216 IDR [1/2] . . . . . | 489 |
| 5.164.4.217 IDR [2/2] . . . . . | 489 |
| 5.164.4.218 IER [1/3] . . . . . | 489 |
| 5.164.4.219 IER [2/3] . . . . . | 490 |
| 5.164.4.220 IER [3/3] . . . . . | 490 |
| 5.164.4.221 IFCR . . . . .      | 490 |

|                                    |     |
|------------------------------------|-----|
| 5.164.4.222 IMR [1/3] . . . . .    | 490 |
| 5.164.4.223 IMR [2/3] . . . . .    | 490 |
| 5.164.4.224 IMR [3/3] . . . . .    | 490 |
| 5.164.4.225 IMSCR . . . . .        | 490 |
| 5.164.4.226 ISR [1/3] . . . . .    | 491 |
| 5.164.4.227 ISR [2/3] . . . . .    | 491 |
| 5.164.4.228 ISR [3/3] . . . . .    | 491 |
| 5.164.4.229 ITM_RxBuffer . . . . . | 491 |
| 5.164.4.230 IV0LR . . . . .        | 491 |
| 5.164.4.231 IV0RR . . . . .        | 491 |
| 5.164.4.232 IV1LR . . . . .        | 491 |
| 5.164.4.233 IV1RR . . . . .        | 492 |
| 5.164.4.234 JDR1 . . . . .         | 492 |
| 5.164.4.235 JDR2 . . . . .         | 492 |
| 5.164.4.236 JDR3 . . . . .         | 492 |
| 5.164.4.237 JDR4 . . . . .         | 492 |
| 5.164.4.238 JOFR1 . . . . .        | 492 |
| 5.164.4.239 JOFR2 . . . . .        | 492 |
| 5.164.4.240 JOFR3 . . . . .        | 492 |
| 5.164.4.241 JOFR4 . . . . .        | 493 |
| 5.164.4.242 JSQR . . . . .         | 493 |
| 5.164.4.243 K0LR . . . . .         | 493 |
| 5.164.4.244 K0RR . . . . .         | 493 |
| 5.164.4.245 K1LR . . . . .         | 493 |
| 5.164.4.246 K1RR . . . . .         | 493 |
| 5.164.4.247 K2LR . . . . .         | 493 |
| 5.164.4.248 K2RR . . . . .         | 493 |
| 5.164.4.249 K3LR . . . . .         | 494 |
| 5.164.4.250 K3RR . . . . .         | 494 |
| 5.164.4.251 KEYR . . . . .         | 494 |
| 5.164.4.252 KR . . . . .           | 494 |
| 5.164.4.253 LCKR . . . . .         | 494 |
| 5.164.4.254 LIFCR . . . . .        | 494 |
| 5.164.4.255 LIPCR . . . . .        | 494 |
| 5.164.4.256 LISR . . . . .         | 495 |
| 5.164.4.257 LTR . . . . .          | 495 |
| 5.164.4.258 LWR . . . . .          | 495 |
| 5.164.4.259 M0AR . . . . .         | 495 |
| 5.164.4.260 M1AR . . . . .         | 495 |
| 5.164.4.261 MASK . . . . .         | 495 |
| 5.164.4.262 MCR . . . . .          | 495 |
| 5.164.4.263 MEMRMP . . . . .       | 496 |

---

|                                        |     |
|----------------------------------------|-----|
| 5.164.4.264 MISR [1/2] . . . . .       | 496 |
| 5.164.4.265 MISR [2/2] . . . . .       | 496 |
| 5.164.4.266 MODER . . . . .            | 496 |
| 5.164.4.267 MSR . . . . .              | 496 |
| 5.164.4.268 NDTR . . . . .             | 496 |
| 5.164.4.269 NLR . . . . .              | 496 |
| 5.164.4.270 OAR1 . . . . .             | 497 |
| 5.164.4.271 OAR2 . . . . .             | 497 |
| 5.164.4.272 OCOLR . . . . .            | 497 |
| 5.164.4.273 ODR . . . . .              | 497 |
| 5.164.4.274 OMAR . . . . .             | 497 |
| 5.164.4.275 OOR . . . . .              | 497 |
| 5.164.4.276 OPFCCR . . . . .           | 497 |
| 5.164.4.277 OPTCR . . . . .            | 498 |
| 5.164.4.278 OPTCR1 . . . . .           | 498 |
| 5.164.4.279 OPTKEYR . . . . .          | 498 |
| 5.164.4.280 OR . . . . .               | 498 |
| 5.164.4.281 OSPEEDR . . . . .          | 498 |
| 5.164.4.282 OTYPER . . . . .           | 498 |
| 5.164.4.283 PAR . . . . .              | 498 |
| 5.164.4.284 PFCR . . . . .             | 499 |
| 5.164.4.285 PLLCFGR . . . . .          | 499 |
| 5.164.4.286 PLLI2SCFGR . . . . .       | 499 |
| 5.164.4.287 PLLSAICFGR . . . . .       | 499 |
| 5.164.4.288 PMC . . . . .              | 499 |
| 5.164.4.289 POWER . . . . .            | 499 |
| 5.164.4.290 PR [1/2] . . . . .         | 499 |
| 5.164.4.291 PR [2/2] . . . . .         | 500 |
| 5.164.4.292 PRER . . . . .             | 500 |
| 5.164.4.293 PSC . . . . .              | 500 |
| 5.164.4.294 PUPDR . . . . .            | 500 |
| 5.164.4.295 RCR . . . . .              | 500 |
| 5.164.4.296 RDHR . . . . .             | 500 |
| 5.164.4.297 RDLR . . . . .             | 500 |
| 5.164.4.298 RDTR . . . . .             | 501 |
| 5.164.4.299 RESERVED [1/3] . . . . .   | 501 |
| 5.164.4.300 RESERVED [2/3] . . . . .   | 501 |
| 5.164.4.301 RESERVED [3/3] . . . . .   | 501 |
| 5.164.4.302 RESERVED0 [1/10] . . . . . | 501 |
| 5.164.4.303 RESERVED0 [2/10] . . . . . | 501 |
| 5.164.4.304 RESERVED0 [3/10] . . . . . | 501 |
| 5.164.4.305 RESERVED0 [4/10] . . . . . | 502 |

|                                         |     |
|-----------------------------------------|-----|
| 5.164.4.306 RESERVED0 [5/10] . . . . .  | 502 |
| 5.164.4.307 RESERVED0 [6/10] . . . . .  | 502 |
| 5.164.4.308 RESERVED0 [7/10] . . . . .  | 502 |
| 5.164.4.309 RESERVED0 [8/10] . . . . .  | 502 |
| 5.164.4.310 RESERVED0 [9/10] . . . . .  | 502 |
| 5.164.4.311 RESERVED0 [10/10] . . . . . | 502 |
| 5.164.4.312 RESERVED1 [1/10] . . . . .  | 503 |
| 5.164.4.313 RESERVED1 [2/10] . . . . .  | 503 |
| 5.164.4.314 RESERVED1 [3/10] . . . . .  | 503 |
| 5.164.4.315 RESERVED1 [4/10] . . . . .  | 503 |
| 5.164.4.316 RESERVED1 [5/10] . . . . .  | 503 |
| 5.164.4.317 RESERVED1 [6/10] . . . . .  | 503 |
| 5.164.4.318 RESERVED1 [7/10] . . . . .  | 503 |
| 5.164.4.319 RESERVED1 [8/10] . . . . .  | 504 |
| 5.164.4.320 RESERVED1 [9/10] . . . . .  | 504 |
| 5.164.4.321 RESERVED1 [10/10] . . . . . | 504 |
| 5.164.4.322 RESERVED10 . . . . .        | 504 |
| 5.164.4.323 RESERVED11 . . . . .        | 504 |
| 5.164.4.324 RESERVED12 . . . . .        | 504 |
| 5.164.4.325 RESERVED13 . . . . .        | 504 |
| 5.164.4.326 RESERVED14 . . . . .        | 505 |
| 5.164.4.327 RESERVED2 [1/7] . . . . .   | 505 |
| 5.164.4.328 RESERVED2 [2/7] . . . . .   | 505 |
| 5.164.4.329 RESERVED2 [3/7] . . . . .   | 505 |
| 5.164.4.330 RESERVED2 [4/7] . . . . .   | 505 |
| 5.164.4.331 RESERVED2 [5/7] . . . . .   | 505 |
| 5.164.4.332 RESERVED2 [6/7] . . . . .   | 505 |
| 5.164.4.333 RESERVED2 [7/7] . . . . .   | 506 |
| 5.164.4.334 RESERVED3 [1/7] . . . . .   | 506 |
| 5.164.4.335 RESERVED3 [2/7] . . . . .   | 506 |
| 5.164.4.336 RESERVED3 [3/7] . . . . .   | 506 |
| 5.164.4.337 RESERVED3 [4/7] . . . . .   | 506 |
| 5.164.4.338 RESERVED3 [5/7] . . . . .   | 506 |
| 5.164.4.339 RESERVED3 [6/7] . . . . .   | 506 |
| 5.164.4.340 RESERVED3 [7/7] . . . . .   | 507 |
| 5.164.4.341 RESERVED4 [1/6] . . . . .   | 507 |
| 5.164.4.342 RESERVED4 [2/6] . . . . .   | 507 |
| 5.164.4.343 RESERVED4 [3/6] . . . . .   | 507 |
| 5.164.4.344 RESERVED4 [4/6] . . . . .   | 507 |
| 5.164.4.345 RESERVED4 [5/6] . . . . .   | 507 |
| 5.164.4.346 RESERVED4 [6/6] . . . . .   | 507 |
| 5.164.4.347 RESERVED5 [1/6] . . . . .   | 508 |

---

|                                       |     |
|---------------------------------------|-----|
| 5.164.4.348 RESERVED5 [2/6] . . . . . | 508 |
| 5.164.4.349 RESERVED5 [3/6] . . . . . | 508 |
| 5.164.4.350 RESERVED5 [4/6] . . . . . | 508 |
| 5.164.4.351 RESERVED5 [5/6] . . . . . | 508 |
| 5.164.4.352 RESERVED5 [6/6] . . . . . | 508 |
| 5.164.4.353 RESERVED6 [1/5] . . . . . | 508 |
| 5.164.4.354 RESERVED6 [2/5] . . . . . | 509 |
| 5.164.4.355 RESERVED6 [3/5] . . . . . | 509 |
| 5.164.4.356 RESERVED6 [4/5] . . . . . | 509 |
| 5.164.4.357 RESERVED6 [5/5] . . . . . | 509 |
| 5.164.4.358 RESERVED7 [1/4] . . . . . | 509 |
| 5.164.4.359 RESERVED7 [2/4] . . . . . | 509 |
| 5.164.4.360 RESERVED7 [3/4] . . . . . | 509 |
| 5.164.4.361 RESERVED7 [4/4] . . . . . | 510 |
| 5.164.4.362 RESERVED8 [1/3] . . . . . | 510 |
| 5.164.4.363 RESERVED8 [2/3] . . . . . | 510 |
| 5.164.4.364 RESERVED8 [3/3] . . . . . | 510 |
| 5.164.4.365 RESERVED9 [1/2] . . . . . | 510 |
| 5.164.4.366 RESERVED9 [2/2] . . . . . | 510 |
| 5.164.4.367 RESP1 . . . . .           | 510 |
| 5.164.4.368 RESP2 . . . . .           | 511 |
| 5.164.4.369 RESP3 . . . . .           | 511 |
| 5.164.4.370 RESP4 . . . . .           | 511 |
| 5.164.4.371 RESPCMD . . . . .         | 511 |
| 5.164.4.372 RF0R . . . . .            | 511 |
| 5.164.4.373 RF1R . . . . .            | 511 |
| 5.164.4.374 RIR . . . . .             | 511 |
| 5.164.4.375 RISR [1/2] . . . . .      | 512 |
| 5.164.4.376 RISR [2/2] . . . . .      | 512 |
| 5.164.4.377 RLR . . . . .             | 512 |
| 5.164.4.378 RTSR . . . . .            | 512 |
| 5.164.4.379 RXCRCR . . . . .          | 512 |
| 5.164.4.380 sFIFOMailBox . . . . .    | 512 |
| 5.164.4.381 sFilterRegister . . . . . | 512 |
| 5.164.4.382 SHIFTR . . . . .          | 513 |
| 5.164.4.383 SLOTR . . . . .           | 513 |
| 5.164.4.384 SMCR . . . . .            | 513 |
| 5.164.4.385 SMPR1 . . . . .           | 513 |
| 5.164.4.386 SMPR2 . . . . .           | 513 |
| 5.164.4.387 SQR1 . . . . .            | 513 |
| 5.164.4.388 SQR2 . . . . .            | 513 |
| 5.164.4.389 SQR3 . . . . .            | 513 |

|                                  |     |
|----------------------------------|-----|
| 5.164.4.390 SR [1/13] . . . . .  | 514 |
| 5.164.4.391 SR [2/13] . . . . .  | 514 |
| 5.164.4.392 SR [3/13] . . . . .  | 514 |
| 5.164.4.393 SR [4/13] . . . . .  | 514 |
| 5.164.4.394 SR [5/13] . . . . .  | 514 |
| 5.164.4.395 SR [6/13] . . . . .  | 514 |
| 5.164.4.396 SR [7/13] . . . . .  | 514 |
| 5.164.4.397 SR [8/13] . . . . .  | 514 |
| 5.164.4.398 SR [9/13] . . . . .  | 515 |
| 5.164.4.399 SR [10/13] . . . . . | 515 |
| 5.164.4.400 SR [11/13] . . . . . | 515 |
| 5.164.4.401 SR [12/13] . . . . . | 515 |
| 5.164.4.402 SR [13/13] . . . . . | 515 |
| 5.164.4.403 SR1 . . . . .        | 515 |
| 5.164.4.404 SR2 . . . . .        | 515 |
| 5.164.4.405 SRCR . . . . .       | 516 |
| 5.164.4.406 SSCGR . . . . .      | 516 |
| 5.164.4.407 SSCR . . . . .       | 516 |
| 5.164.4.408 SSR . . . . .        | 516 |
| 5.164.4.409 STA . . . . .        | 516 |
| 5.164.4.410 STR . . . . .        | 516 |
| 5.164.4.411 sTxMailBox . . . . . | 516 |
| 5.164.4.412 SWIER . . . . .      | 517 |
| 5.164.4.413 SWTRIGR . . . . .    | 517 |
| 5.164.4.414 TAFCR . . . . .      | 517 |
| 5.164.4.415 TDHR . . . . .       | 517 |
| 5.164.4.416 TDLR . . . . .       | 517 |
| 5.164.4.417 TDTR . . . . .       | 517 |
| 5.164.4.418 TIR . . . . .        | 517 |
| 5.164.4.419 TR . . . . .         | 517 |
| 5.164.4.420 TRISE . . . . .      | 518 |
| 5.164.4.421 TSDR . . . . .       | 518 |
| 5.164.4.422 TSR . . . . .        | 518 |
| 5.164.4.423 TSSSR . . . . .      | 518 |
| 5.164.4.424 TSTR . . . . .       | 518 |
| 5.164.4.425 TWCR . . . . .       | 518 |
| 5.164.4.426 TXCRCR . . . . .     | 518 |
| 5.164.4.427 WHPCR . . . . .      | 519 |
| 5.164.4.428 WPR . . . . .        | 519 |
| 5.164.4.429 WUTR . . . . .       | 519 |
| 5.164.4.430 WVPCR . . . . .      | 519 |
| 5.165 Stm32f4xx . . . . .        | 519 |

---

|                                                        |     |
|--------------------------------------------------------|-----|
| 5.165.1 Detailed Description . . . . .                 | 520 |
| 5.166 Library_configuration_section . . . . .          | 520 |
| 5.166.1 Detailed Description . . . . .                 | 520 |
| 5.166.2 Macro Definition Documentation . . . . .       | 520 |
| 5.166.2.1 __STM32F4XX_STDPERIPH_VERSION . . . . .      | 521 |
| 5.166.2.2 __STM32F4XX_STDPERIPH_VERSION_MAIN . . . . . | 521 |
| 5.166.2.3 __STM32F4XX_STDPERIPH_VERSION_RC . . . . .   | 521 |
| 5.166.2.4 __STM32F4XX_STDPERIPH_VERSION_SUB1 . . . . . | 521 |
| 5.166.2.5 __STM32F4XX_STDPERIPH_VERSION_SUB2 . . . . . | 521 |
| 5.166.2.6 HSE_STARTUP_TIMEOUT . . . . .                | 521 |
| 5.166.2.7 HSE_VALUE . . . . .                          | 522 |
| 5.166.2.8 HSI_VALUE . . . . .                          | 522 |
| 5.167 Configuration_section_for_CMSIS . . . . .        | 522 |
| 5.167.1 Detailed Description . . . . .                 | 523 |
| 5.167.2 Macro Definition Documentation . . . . .       | 523 |
| 5.167.2.1 __CM4_REV . . . . .                          | 523 |
| 5.167.2.2 __FPU_PRESENT . . . . .                      | 523 |
| 5.167.2.3 __MPU_PRESENT . . . . .                      | 524 |
| 5.167.2.4 __NVIC_PRIO_BITS . . . . .                   | 524 |
| 5.167.2.5 __Vendor_SysTickConfig . . . . .             | 524 |
| 5.167.3 Enumeration Type Documentation . . . . .       | 524 |
| 5.167.3.1 IRQn . . . . .                               | 524 |
| 5.168 Exported_types . . . . .                         | 527 |
| 5.168.1 Detailed Description . . . . .                 | 528 |
| 5.168.2 Typedef Documentation . . . . .                | 528 |
| 5.168.2.1 s32 . . . . .                                | 528 |
| 5.168.2.2 sc16 . . . . .                               | 528 |
| 5.168.2.3 sc32 . . . . .                               | 528 |
| 5.168.2.4 sc8 . . . . .                                | 528 |
| 5.168.2.5 uc16 . . . . .                               | 528 |
| 5.168.2.6 uc32 . . . . .                               | 528 |
| 5.168.2.7 uc8 . . . . .                                | 529 |
| 5.168.2.8 vsc16 . . . . .                              | 529 |
| 5.168.2.9 vsc32 . . . . .                              | 529 |
| 5.168.2.10 vsc8 . . . . .                              | 529 |
| 5.168.2.11 vuc16 . . . . .                             | 529 |
| 5.168.2.12 vuc32 . . . . .                             | 529 |
| 5.168.2.13 vuc8 . . . . .                              | 529 |
| 5.168.3 Enumeration Type Documentation . . . . .       | 529 |
| 5.168.3.1 FlagStatus . . . . .                         | 529 |
| 5.169 Peripheral_registers_structures . . . . .        | 530 |
| 5.169.1 Detailed Description . . . . .                 | 532 |

---

|                                                      |     |
|------------------------------------------------------|-----|
| 5.170 Peripheral_memory_map . . . . .                | 532 |
| 5.170.1 Detailed Description . . . . .               | 534 |
| 5.170.2 Macro Definition Documentation . . . . .     | 534 |
| 5.170.2.1 AHB2PERIPH_BASE . . . . .                  | 534 |
| 5.170.2.2 BKPSRAM_BASE . . . . .                     | 534 |
| 5.170.2.3 BKPSRAM_BB_BASE . . . . .                  | 534 |
| 5.170.2.4 CCMDATARAM_BASE . . . . .                  | 535 |
| 5.170.2.5 CCMDATARAM_BB_BASE . . . . .               | 535 |
| 5.170.2.6 DMA2D_BASE . . . . .                       | 535 |
| 5.170.2.7 FLASH_BASE . . . . .                       | 535 |
| 5.170.2.8 GPIOA_BASE . . . . .                       | 535 |
| 5.170.2.9 PERIPH_BASE . . . . .                      | 535 |
| 5.170.2.10 PERIPH_BB_BASE . . . . .                  | 535 |
| 5.170.2.11 SRAM1_BASE . . . . .                      | 536 |
| 5.170.2.12 SRAM1_BB_BASE . . . . .                   | 536 |
| 5.170.2.13 SRAM_BB_BASE . . . . .                    | 536 |
| 5.170.2.14 UART8_BASE . . . . .                      | 536 |
| 5.171 Peripheral_declaration . . . . .               | 536 |
| 5.171.1 Detailed Description . . . . .               | 539 |
| 5.172 Exported_constants . . . . .                   | 539 |
| 5.172.1 Detailed Description . . . . .               | 539 |
| 5.173 Peripheral_Registers_Bits_Definition . . . . . | 539 |
| 5.173.1 Detailed Description . . . . .               | 623 |
| 5.173.2 Macro Definition Documentation . . . . .     | 623 |
| 5.173.2.1 ADC_CCR_ADCPRE . . . . .                   | 623 |
| 5.173.2.2 ADC_CCR_ADCPRE_0 . . . . .                 | 623 |
| 5.173.2.3 ADC_CCR_ADCPRE_1 . . . . .                 | 624 |
| 5.173.2.4 ADC_CCR_DDS . . . . .                      | 624 |
| 5.173.2.5 ADC_CCR_DELAY . . . . .                    | 624 |
| 5.173.2.6 ADC_CCR_DELAY_0 . . . . .                  | 624 |
| 5.173.2.7 ADC_CCR_DELAY_1 . . . . .                  | 624 |
| 5.173.2.8 ADC_CCR_DELAY_2 . . . . .                  | 624 |
| 5.173.2.9 ADC_CCR_DELAY_3 . . . . .                  | 624 |
| 5.173.2.10 ADC_CCR_DMA . . . . .                     | 624 |
| 5.173.2.11 ADC_CCR_DMA_0 . . . . .                   | 625 |
| 5.173.2.12 ADC_CCR_DMA_1 . . . . .                   | 625 |
| 5.173.2.13 ADC_CCR_MULTI . . . . .                   | 625 |
| 5.173.2.14 ADC_CCR_MULTI_0 . . . . .                 | 625 |
| 5.173.2.15 ADC_CCR_MULTI_1 . . . . .                 | 625 |
| 5.173.2.16 ADC_CCR_MULTI_2 . . . . .                 | 625 |
| 5.173.2.17 ADC_CCR_MULTI_3 . . . . .                 | 625 |
| 5.173.2.18 ADC_CCR_MULTI_4 . . . . .                 | 625 |

---

|                                        |     |
|----------------------------------------|-----|
| 5.173.2.19 ADC_CCR_TSVREFE . . . . .   | 626 |
| 5.173.2.20 ADC_CCR_VBATE . . . . .     | 626 |
| 5.173.2.21 ADC_CDR_DATA1 . . . . .     | 626 |
| 5.173.2.22 ADC_CDR_DATA2 . . . . .     | 626 |
| 5.173.2.23 ADC_CR1_AWDCH . . . . .     | 626 |
| 5.173.2.24 ADC_CR1_AWDCH_0 . . . . .   | 626 |
| 5.173.2.25 ADC_CR1_AWDCH_1 . . . . .   | 626 |
| 5.173.2.26 ADC_CR1_AWDCH_2 . . . . .   | 626 |
| 5.173.2.27 ADC_CR1_AWDCH_3 . . . . .   | 627 |
| 5.173.2.28 ADC_CR1_AWDCH_4 . . . . .   | 627 |
| 5.173.2.29 ADC_CR1_AWDEN . . . . .     | 627 |
| 5.173.2.30 ADC_CR1_AWDIE . . . . .     | 627 |
| 5.173.2.31 ADC_CR1_AWDSGL . . . . .    | 627 |
| 5.173.2.32 ADC_CR1_DISCEN . . . . .    | 627 |
| 5.173.2.33 ADC_CR1_DISCNUM . . . . .   | 627 |
| 5.173.2.34 ADC_CR1_DISCNUM_0 . . . . . | 628 |
| 5.173.2.35 ADC_CR1_DISCNUM_1 . . . . . | 628 |
| 5.173.2.36 ADC_CR1_DISCNUM_2 . . . . . | 628 |
| 5.173.2.37 ADC_CR1_EOCIE . . . . .     | 628 |
| 5.173.2.38 ADC_CR1_JAUTO . . . . .     | 628 |
| 5.173.2.39 ADC_CR1_JAWDEN . . . . .    | 628 |
| 5.173.2.40 ADC_CR1_JDISCEN . . . . .   | 628 |
| 5.173.2.41 ADC_CR1_JEOCIE . . . . .    | 629 |
| 5.173.2.42 ADC_CR1_OVRIE . . . . .     | 629 |
| 5.173.2.43 ADC_CR1_RES . . . . .       | 629 |
| 5.173.2.44 ADC_CR1_RES_0 . . . . .     | 629 |
| 5.173.2.45 ADC_CR1_RES_1 . . . . .     | 629 |
| 5.173.2.46 ADC_CR1_SCAN . . . . .      | 629 |
| 5.173.2.47 ADC_CR2_ADON . . . . .      | 629 |
| 5.173.2.48 ADC_CR2_ALIGN . . . . .     | 630 |
| 5.173.2.49 ADC_CR2_CONT . . . . .      | 630 |
| 5.173.2.50 ADC_CR2_DDS . . . . .       | 630 |
| 5.173.2.51 ADC_CR2_DMA . . . . .       | 630 |
| 5.173.2.52 ADC_CR2_EOCS . . . . .      | 630 |
| 5.173.2.53 ADC_CR2_EXTEN . . . . .     | 630 |
| 5.173.2.54 ADC_CR2_EXTEN_0 . . . . .   | 630 |
| 5.173.2.55 ADC_CR2_EXTEN_1 . . . . .   | 631 |
| 5.173.2.56 ADC_CR2_EXTSEL . . . . .    | 631 |
| 5.173.2.57 ADC_CR2_EXTSEL_0 . . . . .  | 631 |
| 5.173.2.58 ADC_CR2_EXTSEL_1 . . . . .  | 631 |
| 5.173.2.59 ADC_CR2_EXTSEL_2 . . . . .  | 631 |
| 5.173.2.60 ADC_CR2_EXTSEL_3 . . . . .  | 631 |

---

|                                         |     |
|-----------------------------------------|-----|
| 5.173.2.61 ADC_CR2_JEXTEN . . . . .     | 631 |
| 5.173.2.62 ADC_CR2_JEXTEN_0 . . . . .   | 631 |
| 5.173.2.63 ADC_CR2_JEXTEN_1 . . . . .   | 632 |
| 5.173.2.64 ADC_CR2_JEXTSEL . . . . .    | 632 |
| 5.173.2.65 ADC_CR2_JEXTSEL_0 . . . . .  | 632 |
| 5.173.2.66 ADC_CR2_JEXTSEL_1 . . . . .  | 632 |
| 5.173.2.67 ADC_CR2_JEXTSEL_2 . . . . .  | 632 |
| 5.173.2.68 ADC_CR2_JEXTSEL_3 . . . . .  | 632 |
| 5.173.2.69 ADC_CR2_JSWSTART . . . . .   | 632 |
| 5.173.2.70 ADC_CR2_SWSTART . . . . .    | 632 |
| 5.173.2.71 ADC_CSR_AWD1 . . . . .       | 633 |
| 5.173.2.72 ADC_CSR_AWD2 . . . . .       | 633 |
| 5.173.2.73 ADC_CSR_AWD3 . . . . .       | 633 |
| 5.173.2.74 ADC_CSR_EOC1 . . . . .       | 633 |
| 5.173.2.75 ADC_CSR_EOC2 . . . . .       | 633 |
| 5.173.2.76 ADC_CSR_EOC3 . . . . .       | 633 |
| 5.173.2.77 ADC_CSR_JEOC1 . . . . .      | 633 |
| 5.173.2.78 ADC_CSR_JEOC2 . . . . .      | 633 |
| 5.173.2.79 ADC_CSR_JEOC3 . . . . .      | 634 |
| 5.173.2.80 ADC_CSR_JSTRT1 . . . . .     | 634 |
| 5.173.2.81 ADC_CSR_JSTRT2 . . . . .     | 634 |
| 5.173.2.82 ADC_CSR_JSTRT3 . . . . .     | 634 |
| 5.173.2.83 ADC_CSR_OVR1 . . . . .       | 634 |
| 5.173.2.84 ADC_CSR_OVR2 . . . . .       | 634 |
| 5.173.2.85 ADC_CSR_OVR3 . . . . .       | 634 |
| 5.173.2.86 ADC_CSR_STRT1 . . . . .      | 634 |
| 5.173.2.87 ADC_CSR_STRT2 . . . . .      | 635 |
| 5.173.2.88 ADC_CSR_STRT3 . . . . .      | 635 |
| 5.173.2.89 ADC_DR_ADC2DATA . . . . .    | 635 |
| 5.173.2.90 ADC_DR_DATA . . . . .        | 635 |
| 5.173.2.91 ADC_HTR_HT . . . . .         | 635 |
| 5.173.2.92 ADC_JDR1_JDATA . . . . .     | 635 |
| 5.173.2.93 ADC_JDR2_JDATA . . . . .     | 635 |
| 5.173.2.94 ADC_JDR3_JDATA . . . . .     | 635 |
| 5.173.2.95 ADC_JDR4_JDATA . . . . .     | 636 |
| 5.173.2.96 ADC_JOFR1_JOFFSET1 . . . . . | 636 |
| 5.173.2.97 ADC_JOFR2_JOFFSET2 . . . . . | 636 |
| 5.173.2.98 ADC_JOFR3_JOFFSET3 . . . . . | 636 |
| 5.173.2.99 ADC_JOFR4_JOFFSET4 . . . . . | 636 |
| 5.173.2.100 ADC_JSQR_JL . . . . .       | 636 |
| 5.173.2.101 ADC_JSQR_JL_0 . . . . .     | 636 |
| 5.173.2.102 ADC_JSQR_JL_1 . . . . .     | 636 |

---

|                                         |     |
|-----------------------------------------|-----|
| 5.173.2.103 ADC_JSQR_JSQ1 . . . . .     | 637 |
| 5.173.2.104 ADC_JSQR_JSQ1_0 . . . . .   | 637 |
| 5.173.2.105 ADC_JSQR_JSQ1_1 . . . . .   | 637 |
| 5.173.2.106 ADC_JSQR_JSQ1_2 . . . . .   | 637 |
| 5.173.2.107 ADC_JSQR_JSQ1_3 . . . . .   | 637 |
| 5.173.2.108 ADC_JSQR_JSQ1_4 . . . . .   | 637 |
| 5.173.2.109 ADC_JSQR_JSQ2 . . . . .     | 637 |
| 5.173.2.110 ADC_JSQR_JSQ2_0 . . . . .   | 637 |
| 5.173.2.111 ADC_JSQR_JSQ2_1 . . . . .   | 638 |
| 5.173.2.112 ADC_JSQR_JSQ2_2 . . . . .   | 638 |
| 5.173.2.113 ADC_JSQR_JSQ2_3 . . . . .   | 638 |
| 5.173.2.114 ADC_JSQR_JSQ2_4 . . . . .   | 638 |
| 5.173.2.115 ADC_JSQR_JSQ3 . . . . .     | 638 |
| 5.173.2.116 ADC_JSQR_JSQ3_0 . . . . .   | 638 |
| 5.173.2.117 ADC_JSQR_JSQ3_1 . . . . .   | 638 |
| 5.173.2.118 ADC_JSQR_JSQ3_2 . . . . .   | 638 |
| 5.173.2.119 ADC_JSQR_JSQ3_3 . . . . .   | 639 |
| 5.173.2.120 ADC_JSQR_JSQ3_4 . . . . .   | 639 |
| 5.173.2.121 ADC_JSQR_JSQ4 . . . . .     | 639 |
| 5.173.2.122 ADC_JSQR_JSQ4_0 . . . . .   | 639 |
| 5.173.2.123 ADC_JSQR_JSQ4_1 . . . . .   | 639 |
| 5.173.2.124 ADC_JSQR_JSQ4_2 . . . . .   | 639 |
| 5.173.2.125 ADC_JSQR_JSQ4_3 . . . . .   | 639 |
| 5.173.2.126 ADC_JSQR_JSQ4_4 . . . . .   | 639 |
| 5.173.2.127 ADC_LTR_LT . . . . .        | 640 |
| 5.173.2.128 ADC_SMPR1_SMP10 . . . . .   | 640 |
| 5.173.2.129 ADC_SMPR1_SMP10_0 . . . . . | 640 |
| 5.173.2.130 ADC_SMPR1_SMP10_1 . . . . . | 640 |
| 5.173.2.131 ADC_SMPR1_SMP10_2 . . . . . | 640 |
| 5.173.2.132 ADC_SMPR1_SMP11 . . . . .   | 640 |
| 5.173.2.133 ADC_SMPR1_SMP11_0 . . . . . | 640 |
| 5.173.2.134 ADC_SMPR1_SMP11_1 . . . . . | 640 |
| 5.173.2.135 ADC_SMPR1_SMP11_2 . . . . . | 641 |
| 5.173.2.136 ADC_SMPR1_SMP12 . . . . .   | 641 |
| 5.173.2.137 ADC_SMPR1_SMP12_0 . . . . . | 641 |
| 5.173.2.138 ADC_SMPR1_SMP12_1 . . . . . | 641 |
| 5.173.2.139 ADC_SMPR1_SMP12_2 . . . . . | 641 |
| 5.173.2.140 ADC_SMPR1_SMP13 . . . . .   | 641 |
| 5.173.2.141 ADC_SMPR1_SMP13_0 . . . . . | 641 |
| 5.173.2.142 ADC_SMPR1_SMP13_1 . . . . . | 641 |
| 5.173.2.143 ADC_SMPR1_SMP13_2 . . . . . | 642 |
| 5.173.2.144 ADC_SMPR1_SMP14 . . . . .   | 642 |

---

|                                         |     |
|-----------------------------------------|-----|
| 5.173.2.145 ADC_SMPR1_SMP14_0 . . . . . | 642 |
| 5.173.2.146 ADC_SMPR1_SMP14_1 . . . . . | 642 |
| 5.173.2.147 ADC_SMPR1_SMP14_2 . . . . . | 642 |
| 5.173.2.148 ADC_SMPR1_SMP15 . . . . .   | 642 |
| 5.173.2.149 ADC_SMPR1_SMP15_0 . . . . . | 642 |
| 5.173.2.150 ADC_SMPR1_SMP15_1 . . . . . | 642 |
| 5.173.2.151 ADC_SMPR1_SMP15_2 . . . . . | 643 |
| 5.173.2.152 ADC_SMPR1_SMP16 . . . . .   | 643 |
| 5.173.2.153 ADC_SMPR1_SMP16_0 . . . . . | 643 |
| 5.173.2.154 ADC_SMPR1_SMP16_1 . . . . . | 643 |
| 5.173.2.155 ADC_SMPR1_SMP16_2 . . . . . | 643 |
| 5.173.2.156 ADC_SMPR1_SMP17 . . . . .   | 643 |
| 5.173.2.157 ADC_SMPR1_SMP17_0 . . . . . | 643 |
| 5.173.2.158 ADC_SMPR1_SMP17_1 . . . . . | 643 |
| 5.173.2.159 ADC_SMPR1_SMP17_2 . . . . . | 644 |
| 5.173.2.160 ADC_SMPR1_SMP18 . . . . .   | 644 |
| 5.173.2.161 ADC_SMPR1_SMP18_0 . . . . . | 644 |
| 5.173.2.162 ADC_SMPR1_SMP18_1 . . . . . | 644 |
| 5.173.2.163 ADC_SMPR1_SMP18_2 . . . . . | 644 |
| 5.173.2.164 ADC_SMPR2_SMP0 . . . . .    | 644 |
| 5.173.2.165 ADC_SMPR2_SMP0_0 . . . . .  | 644 |
| 5.173.2.166 ADC_SMPR2_SMP0_1 . . . . .  | 644 |
| 5.173.2.167 ADC_SMPR2_SMP0_2 . . . . .  | 645 |
| 5.173.2.168 ADC_SMPR2_SMP1 . . . . .    | 645 |
| 5.173.2.169 ADC_SMPR2_SMP1_0 . . . . .  | 645 |
| 5.173.2.170 ADC_SMPR2_SMP1_1 . . . . .  | 645 |
| 5.173.2.171 ADC_SMPR2_SMP1_2 . . . . .  | 645 |
| 5.173.2.172 ADC_SMPR2_SMP2 . . . . .    | 645 |
| 5.173.2.173 ADC_SMPR2_SMP2_0 . . . . .  | 645 |
| 5.173.2.174 ADC_SMPR2_SMP2_1 . . . . .  | 645 |
| 5.173.2.175 ADC_SMPR2_SMP2_2 . . . . .  | 646 |
| 5.173.2.176 ADC_SMPR2_SMP3 . . . . .    | 646 |
| 5.173.2.177 ADC_SMPR2_SMP3_0 . . . . .  | 646 |
| 5.173.2.178 ADC_SMPR2_SMP3_1 . . . . .  | 646 |
| 5.173.2.179 ADC_SMPR2_SMP3_2 . . . . .  | 646 |
| 5.173.2.180 ADC_SMPR2_SMP4 . . . . .    | 646 |
| 5.173.2.181 ADC_SMPR2_SMP4_0 . . . . .  | 646 |
| 5.173.2.182 ADC_SMPR2_SMP4_1 . . . . .  | 646 |
| 5.173.2.183 ADC_SMPR2_SMP4_2 . . . . .  | 647 |
| 5.173.2.184 ADC_SMPR2_SMP5 . . . . .    | 647 |
| 5.173.2.185 ADC_SMPR2_SMP5_0 . . . . .  | 647 |
| 5.173.2.186 ADC_SMPR2_SMP5_1 . . . . .  | 647 |

---

|                                        |     |
|----------------------------------------|-----|
| 5.173.2.187 ADC_SMPR2_SMP5_2 . . . . . | 647 |
| 5.173.2.188 ADC_SMPR2_SMP6 . . . . .   | 647 |
| 5.173.2.189 ADC_SMPR2_SMP6_0 . . . . . | 647 |
| 5.173.2.190 ADC_SMPR2_SMP6_1 . . . . . | 647 |
| 5.173.2.191 ADC_SMPR2_SMP6_2 . . . . . | 648 |
| 5.173.2.192 ADC_SMPR2_SMP7 . . . . .   | 648 |
| 5.173.2.193 ADC_SMPR2_SMP7_0 . . . . . | 648 |
| 5.173.2.194 ADC_SMPR2_SMP7_1 . . . . . | 648 |
| 5.173.2.195 ADC_SMPR2_SMP7_2 . . . . . | 648 |
| 5.173.2.196 ADC_SMPR2_SMP8 . . . . .   | 648 |
| 5.173.2.197 ADC_SMPR2_SMP8_0 . . . . . | 648 |
| 5.173.2.198 ADC_SMPR2_SMP8_1 . . . . . | 648 |
| 5.173.2.199 ADC_SMPR2_SMP8_2 . . . . . | 649 |
| 5.173.2.200 ADC_SMPR2_SMP9 . . . . .   | 649 |
| 5.173.2.201 ADC_SMPR2_SMP9_0 . . . . . | 649 |
| 5.173.2.202 ADC_SMPR2_SMP9_1 . . . . . | 649 |
| 5.173.2.203 ADC_SMPR2_SMP9_2 . . . . . | 649 |
| 5.173.2.204 ADC_SQR1_L . . . . .       | 649 |
| 5.173.2.205 ADC_SQR1_L_0 . . . . .     | 649 |
| 5.173.2.206 ADC_SQR1_L_1 . . . . .     | 649 |
| 5.173.2.207 ADC_SQR1_L_2 . . . . .     | 650 |
| 5.173.2.208 ADC_SQR1_L_3 . . . . .     | 650 |
| 5.173.2.209 ADC_SQR1_SQ13 . . . . .    | 650 |
| 5.173.2.210 ADC_SQR1_SQ13_0 . . . . .  | 650 |
| 5.173.2.211 ADC_SQR1_SQ13_1 . . . . .  | 650 |
| 5.173.2.212 ADC_SQR1_SQ13_2 . . . . .  | 650 |
| 5.173.2.213 ADC_SQR1_SQ13_3 . . . . .  | 650 |
| 5.173.2.214 ADC_SQR1_SQ13_4 . . . . .  | 650 |
| 5.173.2.215 ADC_SQR1_SQ14 . . . . .    | 651 |
| 5.173.2.216 ADC_SQR1_SQ14_0 . . . . .  | 651 |
| 5.173.2.217 ADC_SQR1_SQ14_1 . . . . .  | 651 |
| 5.173.2.218 ADC_SQR1_SQ14_2 . . . . .  | 651 |
| 5.173.2.219 ADC_SQR1_SQ14_3 . . . . .  | 651 |
| 5.173.2.220 ADC_SQR1_SQ14_4 . . . . .  | 651 |
| 5.173.2.221 ADC_SQR1_SQ15 . . . . .    | 651 |
| 5.173.2.222 ADC_SQR1_SQ15_0 . . . . .  | 651 |
| 5.173.2.223 ADC_SQR1_SQ15_1 . . . . .  | 652 |
| 5.173.2.224 ADC_SQR1_SQ15_2 . . . . .  | 652 |
| 5.173.2.225 ADC_SQR1_SQ15_3 . . . . .  | 652 |
| 5.173.2.226 ADC_SQR1_SQ15_4 . . . . .  | 652 |
| 5.173.2.227 ADC_SQR1_SQ16 . . . . .    | 652 |
| 5.173.2.228 ADC_SQR1_SQ16_0 . . . . .  | 652 |

---

|                                       |     |
|---------------------------------------|-----|
| 5.173.2.229 ADC_SQR1_SQ16_1 . . . . . | 652 |
| 5.173.2.230 ADC_SQR1_SQ16_2 . . . . . | 652 |
| 5.173.2.231 ADC_SQR1_SQ16_3 . . . . . | 653 |
| 5.173.2.232 ADC_SQR1_SQ16_4 . . . . . | 653 |
| 5.173.2.233 ADC_SQR2_SQ10 . . . . .   | 653 |
| 5.173.2.234 ADC_SQR2_SQ10_0 . . . . . | 653 |
| 5.173.2.235 ADC_SQR2_SQ10_1 . . . . . | 653 |
| 5.173.2.236 ADC_SQR2_SQ10_2 . . . . . | 653 |
| 5.173.2.237 ADC_SQR2_SQ10_3 . . . . . | 653 |
| 5.173.2.238 ADC_SQR2_SQ10_4 . . . . . | 653 |
| 5.173.2.239 ADC_SQR2_SQ11 . . . . .   | 654 |
| 5.173.2.240 ADC_SQR2_SQ11_0 . . . . . | 654 |
| 5.173.2.241 ADC_SQR2_SQ11_1 . . . . . | 654 |
| 5.173.2.242 ADC_SQR2_SQ11_2 . . . . . | 654 |
| 5.173.2.243 ADC_SQR2_SQ11_3 . . . . . | 654 |
| 5.173.2.244 ADC_SQR2_SQ11_4 . . . . . | 654 |
| 5.173.2.245 ADC_SQR2_SQ12 . . . . .   | 654 |
| 5.173.2.246 ADC_SQR2_SQ12_0 . . . . . | 654 |
| 5.173.2.247 ADC_SQR2_SQ12_1 . . . . . | 655 |
| 5.173.2.248 ADC_SQR2_SQ12_2 . . . . . | 655 |
| 5.173.2.249 ADC_SQR2_SQ12_3 . . . . . | 655 |
| 5.173.2.250 ADC_SQR2_SQ12_4 . . . . . | 655 |
| 5.173.2.251 ADC_SQR2_SQ7 . . . . .    | 655 |
| 5.173.2.252 ADC_SQR2_SQ7_0 . . . . .  | 655 |
| 5.173.2.253 ADC_SQR2_SQ7_1 . . . . .  | 655 |
| 5.173.2.254 ADC_SQR2_SQ7_2 . . . . .  | 655 |
| 5.173.2.255 ADC_SQR2_SQ7_3 . . . . .  | 656 |
| 5.173.2.256 ADC_SQR2_SQ7_4 . . . . .  | 656 |
| 5.173.2.257 ADC_SQR2_SQ8 . . . . .    | 656 |
| 5.173.2.258 ADC_SQR2_SQ8_0 . . . . .  | 656 |
| 5.173.2.259 ADC_SQR2_SQ8_1 . . . . .  | 656 |
| 5.173.2.260 ADC_SQR2_SQ8_2 . . . . .  | 656 |
| 5.173.2.261 ADC_SQR2_SQ8_3 . . . . .  | 656 |
| 5.173.2.262 ADC_SQR2_SQ8_4 . . . . .  | 656 |
| 5.173.2.263 ADC_SQR2_SQ9 . . . . .    | 657 |
| 5.173.2.264 ADC_SQR2_SQ9_0 . . . . .  | 657 |
| 5.173.2.265 ADC_SQR2_SQ9_1 . . . . .  | 657 |
| 5.173.2.266 ADC_SQR2_SQ9_2 . . . . .  | 657 |
| 5.173.2.267 ADC_SQR2_SQ9_3 . . . . .  | 657 |
| 5.173.2.268 ADC_SQR2_SQ9_4 . . . . .  | 657 |
| 5.173.2.269 ADC_SQR3_SQ1 . . . . .    | 657 |
| 5.173.2.270 ADC_SQR3_SQ1_0 . . . . .  | 657 |

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.271 ADC_SQR3_SQ1_1 . . . . . | 658 |
| 5.173.2.272 ADC_SQR3_SQ1_2 . . . . . | 658 |
| 5.173.2.273 ADC_SQR3_SQ1_3 . . . . . | 658 |
| 5.173.2.274 ADC_SQR3_SQ1_4 . . . . . | 658 |
| 5.173.2.275 ADC_SQR3_SQ2 . . . . .   | 658 |
| 5.173.2.276 ADC_SQR3_SQ2_0 . . . . . | 658 |
| 5.173.2.277 ADC_SQR3_SQ2_1 . . . . . | 658 |
| 5.173.2.278 ADC_SQR3_SQ2_2 . . . . . | 658 |
| 5.173.2.279 ADC_SQR3_SQ2_3 . . . . . | 659 |
| 5.173.2.280 ADC_SQR3_SQ2_4 . . . . . | 659 |
| 5.173.2.281 ADC_SQR3_SQ3 . . . . .   | 659 |
| 5.173.2.282 ADC_SQR3_SQ3_0 . . . . . | 659 |
| 5.173.2.283 ADC_SQR3_SQ3_1 . . . . . | 659 |
| 5.173.2.284 ADC_SQR3_SQ3_2 . . . . . | 659 |
| 5.173.2.285 ADC_SQR3_SQ3_3 . . . . . | 659 |
| 5.173.2.286 ADC_SQR3_SQ3_4 . . . . . | 659 |
| 5.173.2.287 ADC_SQR3_SQ4 . . . . .   | 660 |
| 5.173.2.288 ADC_SQR3_SQ4_0 . . . . . | 660 |
| 5.173.2.289 ADC_SQR3_SQ4_1 . . . . . | 660 |
| 5.173.2.290 ADC_SQR3_SQ4_2 . . . . . | 660 |
| 5.173.2.291 ADC_SQR3_SQ4_3 . . . . . | 660 |
| 5.173.2.292 ADC_SQR3_SQ4_4 . . . . . | 660 |
| 5.173.2.293 ADC_SQR3_SQ5 . . . . .   | 660 |
| 5.173.2.294 ADC_SQR3_SQ5_0 . . . . . | 660 |
| 5.173.2.295 ADC_SQR3_SQ5_1 . . . . . | 661 |
| 5.173.2.296 ADC_SQR3_SQ5_2 . . . . . | 661 |
| 5.173.2.297 ADC_SQR3_SQ5_3 . . . . . | 661 |
| 5.173.2.298 ADC_SQR3_SQ5_4 . . . . . | 661 |
| 5.173.2.299 ADC_SQR3_SQ6 . . . . .   | 661 |
| 5.173.2.300 ADC_SQR3_SQ6_0 . . . . . | 661 |
| 5.173.2.301 ADC_SQR3_SQ6_1 . . . . . | 661 |
| 5.173.2.302 ADC_SQR3_SQ6_2 . . . . . | 661 |
| 5.173.2.303 ADC_SQR3_SQ6_3 . . . . . | 662 |
| 5.173.2.304 ADC_SQR3_SQ6_4 . . . . . | 662 |
| 5.173.2.305 ADC_SR_AWD . . . . .     | 662 |
| 5.173.2.306 ADC_SR_EOC . . . . .     | 662 |
| 5.173.2.307 ADC_SR_JEOC . . . . .    | 662 |
| 5.173.2.308 ADC_SR_JSTRT . . . . .   | 662 |
| 5.173.2.309 ADC_SR_OVR . . . . .     | 662 |
| 5.173.2.310 ADC_SR_STRT . . . . .    | 663 |
| 5.173.2.311 CAN_BTR_BRP . . . . .    | 663 |
| 5.173.2.312 CAN_BTR_LBKM . . . . .   | 663 |

---

---

|                                     |     |
|-------------------------------------|-----|
| 5.173.2.313 CAN_BTR_SILM . . . . .  | 663 |
| 5.173.2.314 CAN_BTR_SJW . . . . .   | 663 |
| 5.173.2.315 CAN_BTR_TS1 . . . . .   | 663 |
| 5.173.2.316 CAN_BTR_TS2 . . . . .   | 663 |
| 5.173.2.317 CAN_ESR_BOFF . . . . .  | 664 |
| 5.173.2.318 CAN_ESR_EPVF . . . . .  | 664 |
| 5.173.2.319 CAN_ESR_EWGF . . . . .  | 664 |
| 5.173.2.320 CAN_ESR_LEC . . . . .   | 664 |
| 5.173.2.321 CAN_ESR_LEC_0 . . . . . | 664 |
| 5.173.2.322 CAN_ESR_LEC_1 . . . . . | 664 |
| 5.173.2.323 CAN_ESR_LEC_2 . . . . . | 664 |
| 5.173.2.324 CAN_ESR_REC . . . . .   | 664 |
| 5.173.2.325 CAN_ESR_TEC . . . . .   | 665 |
| 5.173.2.326 CAN_F0R1_FB0 . . . . .  | 665 |
| 5.173.2.327 CAN_F0R1_FB1 . . . . .  | 665 |
| 5.173.2.328 CAN_F0R1_FB10 . . . . . | 665 |
| 5.173.2.329 CAN_F0R1_FB11 . . . . . | 665 |
| 5.173.2.330 CAN_F0R1_FB12 . . . . . | 665 |
| 5.173.2.331 CAN_F0R1_FB13 . . . . . | 665 |
| 5.173.2.332 CAN_F0R1_FB14 . . . . . | 665 |
| 5.173.2.333 CAN_F0R1_FB15 . . . . . | 666 |
| 5.173.2.334 CAN_F0R1_FB16 . . . . . | 666 |
| 5.173.2.335 CAN_F0R1_FB17 . . . . . | 666 |
| 5.173.2.336 CAN_F0R1_FB18 . . . . . | 666 |
| 5.173.2.337 CAN_F0R1_FB19 . . . . . | 666 |
| 5.173.2.338 CAN_F0R1_FB2 . . . . .  | 666 |
| 5.173.2.339 CAN_F0R1_FB20 . . . . . | 666 |
| 5.173.2.340 CAN_F0R1_FB21 . . . . . | 666 |
| 5.173.2.341 CAN_F0R1_FB22 . . . . . | 667 |
| 5.173.2.342 CAN_F0R1_FB23 . . . . . | 667 |
| 5.173.2.343 CAN_F0R1_FB24 . . . . . | 667 |
| 5.173.2.344 CAN_F0R1_FB25 . . . . . | 667 |
| 5.173.2.345 CAN_F0R1_FB26 . . . . . | 667 |
| 5.173.2.346 CAN_F0R1_FB27 . . . . . | 667 |
| 5.173.2.347 CAN_F0R1_FB28 . . . . . | 667 |
| 5.173.2.348 CAN_F0R1_FB29 . . . . . | 667 |
| 5.173.2.349 CAN_F0R1_FB3 . . . . .  | 668 |
| 5.173.2.350 CAN_F0R1_FB30 . . . . . | 668 |
| 5.173.2.351 CAN_F0R1_FB31 . . . . . | 668 |
| 5.173.2.352 CAN_F0R1_FB4 . . . . .  | 668 |
| 5.173.2.353 CAN_F0R1_FB5 . . . . .  | 668 |
| 5.173.2.354 CAN_F0R1_FB6 . . . . .  | 668 |

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.355 CAN_F0R1_FB7 . . . . .   | 668 |
| 5.173.2.356 CAN_F0R1_FB8 . . . . .   | 668 |
| 5.173.2.357 CAN_F0R1_FB9 . . . . .   | 669 |
| 5.173.2.358 CAN_F0R2_FB0 . . . . .   | 669 |
| 5.173.2.359 CAN_F0R2_FB1 . . . . .   | 669 |
| 5.173.2.360 CAN_F0R2_FB10 . . . . .  | 669 |
| 5.173.2.361 CAN_F0R2_FB11 . . . . .  | 669 |
| 5.173.2.362 CAN_F0R2_FB12 . . . . .  | 669 |
| 5.173.2.363 CAN_F0R2_FB13 . . . . .  | 669 |
| 5.173.2.364 CAN_F0R2_FB14 . . . . .  | 669 |
| 5.173.2.365 CAN_F0R2_FB15 . . . . .  | 670 |
| 5.173.2.366 CAN_F0R2_FB16 . . . . .  | 670 |
| 5.173.2.367 CAN_F0R2_FB17 . . . . .  | 670 |
| 5.173.2.368 CAN_F0R2_FB18 . . . . .  | 670 |
| 5.173.2.369 CAN_F0R2_FB19 . . . . .  | 670 |
| 5.173.2.370 CAN_F0R2_FB2 . . . . .   | 670 |
| 5.173.2.371 CAN_F0R2_FB20 . . . . .  | 670 |
| 5.173.2.372 CAN_F0R2_FB21 . . . . .  | 670 |
| 5.173.2.373 CAN_F0R2_FB22 . . . . .  | 671 |
| 5.173.2.374 CAN_F0R2_FB23 . . . . .  | 671 |
| 5.173.2.375 CAN_F0R2_FB24 . . . . .  | 671 |
| 5.173.2.376 CAN_F0R2_FB25 . . . . .  | 671 |
| 5.173.2.377 CAN_F0R2_FB26 . . . . .  | 671 |
| 5.173.2.378 CAN_F0R2_FB27 . . . . .  | 671 |
| 5.173.2.379 CAN_F0R2_FB28 . . . . .  | 671 |
| 5.173.2.380 CAN_F0R2_FB29 . . . . .  | 671 |
| 5.173.2.381 CAN_F0R2_FB3 . . . . .   | 672 |
| 5.173.2.382 CAN_F0R2_FB30 . . . . .  | 672 |
| 5.173.2.383 CAN_F0R2_FB31 . . . . .  | 672 |
| 5.173.2.384 CAN_F0R2_FB4 . . . . .   | 672 |
| 5.173.2.385 CAN_F0R2_FB5 . . . . .   | 672 |
| 5.173.2.386 CAN_F0R2_FB6 . . . . .   | 672 |
| 5.173.2.387 CAN_F0R2_FB7 . . . . .   | 672 |
| 5.173.2.388 CAN_F0R2_FB8 . . . . .   | 672 |
| 5.173.2.389 CAN_F0R2_FB9 . . . . .   | 673 |
| 5.173.2.390 CAN_F10R1_FB0 . . . . .  | 673 |
| 5.173.2.391 CAN_F10R1_FB1 . . . . .  | 673 |
| 5.173.2.392 CAN_F10R1_FB10 . . . . . | 673 |
| 5.173.2.393 CAN_F10R1_FB11 . . . . . | 673 |
| 5.173.2.394 CAN_F10R1_FB12 . . . . . | 673 |
| 5.173.2.395 CAN_F10R1_FB13 . . . . . | 673 |
| 5.173.2.396 CAN_F10R1_FB14 . . . . . | 673 |

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.397 CAN_F10R1_FB15 . . . . . | 674 |
| 5.173.2.398 CAN_F10R1_FB16 . . . . . | 674 |
| 5.173.2.399 CAN_F10R1_FB17 . . . . . | 674 |
| 5.173.2.400 CAN_F10R1_FB18 . . . . . | 674 |
| 5.173.2.401 CAN_F10R1_FB19 . . . . . | 674 |
| 5.173.2.402 CAN_F10R1_FB2 . . . . .  | 674 |
| 5.173.2.403 CAN_F10R1_FB20 . . . . . | 674 |
| 5.173.2.404 CAN_F10R1_FB21 . . . . . | 674 |
| 5.173.2.405 CAN_F10R1_FB22 . . . . . | 675 |
| 5.173.2.406 CAN_F10R1_FB23 . . . . . | 675 |
| 5.173.2.407 CAN_F10R1_FB24 . . . . . | 675 |
| 5.173.2.408 CAN_F10R1_FB25 . . . . . | 675 |
| 5.173.2.409 CAN_F10R1_FB26 . . . . . | 675 |
| 5.173.2.410 CAN_F10R1_FB27 . . . . . | 675 |
| 5.173.2.411 CAN_F10R1_FB28 . . . . . | 675 |
| 5.173.2.412 CAN_F10R1_FB29 . . . . . | 675 |
| 5.173.2.413 CAN_F10R1_FB3 . . . . .  | 676 |
| 5.173.2.414 CAN_F10R1_FB30 . . . . . | 676 |
| 5.173.2.415 CAN_F10R1_FB31 . . . . . | 676 |
| 5.173.2.416 CAN_F10R1_FB4 . . . . .  | 676 |
| 5.173.2.417 CAN_F10R1_FB5 . . . . .  | 676 |
| 5.173.2.418 CAN_F10R1_FB6 . . . . .  | 676 |
| 5.173.2.419 CAN_F10R1_FB7 . . . . .  | 676 |
| 5.173.2.420 CAN_F10R1_FB8 . . . . .  | 676 |
| 5.173.2.421 CAN_F10R1_FB9 . . . . .  | 677 |
| 5.173.2.422 CAN_F10R2_FB0 . . . . .  | 677 |
| 5.173.2.423 CAN_F10R2_FB1 . . . . .  | 677 |
| 5.173.2.424 CAN_F10R2_FB10 . . . . . | 677 |
| 5.173.2.425 CAN_F10R2_FB11 . . . . . | 677 |
| 5.173.2.426 CAN_F10R2_FB12 . . . . . | 677 |
| 5.173.2.427 CAN_F10R2_FB13 . . . . . | 677 |
| 5.173.2.428 CAN_F10R2_FB14 . . . . . | 677 |
| 5.173.2.429 CAN_F10R2_FB15 . . . . . | 678 |
| 5.173.2.430 CAN_F10R2_FB16 . . . . . | 678 |
| 5.173.2.431 CAN_F10R2_FB17 . . . . . | 678 |
| 5.173.2.432 CAN_F10R2_FB18 . . . . . | 678 |
| 5.173.2.433 CAN_F10R2_FB19 . . . . . | 678 |
| 5.173.2.434 CAN_F10R2_FB2 . . . . .  | 678 |
| 5.173.2.435 CAN_F10R2_FB20 . . . . . | 678 |
| 5.173.2.436 CAN_F10R2_FB21 . . . . . | 678 |
| 5.173.2.437 CAN_F10R2_FB22 . . . . . | 679 |
| 5.173.2.438 CAN_F10R2_FB23 . . . . . | 679 |

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.439 CAN_F10R2_FB24 . . . . . | 679 |
| 5.173.2.440 CAN_F10R2_FB25 . . . . . | 679 |
| 5.173.2.441 CAN_F10R2_FB26 . . . . . | 679 |
| 5.173.2.442 CAN_F10R2_FB27 . . . . . | 679 |
| 5.173.2.443 CAN_F10R2_FB28 . . . . . | 679 |
| 5.173.2.444 CAN_F10R2_FB29 . . . . . | 679 |
| 5.173.2.445 CAN_F10R2_FB3 . . . . .  | 680 |
| 5.173.2.446 CAN_F10R2_FB30 . . . . . | 680 |
| 5.173.2.447 CAN_F10R2_FB31 . . . . . | 680 |
| 5.173.2.448 CAN_F10R2_FB4 . . . . .  | 680 |
| 5.173.2.449 CAN_F10R2_FB5 . . . . .  | 680 |
| 5.173.2.450 CAN_F10R2_FB6 . . . . .  | 680 |
| 5.173.2.451 CAN_F10R2_FB7 . . . . .  | 680 |
| 5.173.2.452 CAN_F10R2_FB8 . . . . .  | 680 |
| 5.173.2.453 CAN_F10R2_FB9 . . . . .  | 681 |
| 5.173.2.454 CAN_F11R1_FB0 . . . . .  | 681 |
| 5.173.2.455 CAN_F11R1_FB1 . . . . .  | 681 |
| 5.173.2.456 CAN_F11R1_FB10 . . . . . | 681 |
| 5.173.2.457 CAN_F11R1_FB11 . . . . . | 681 |
| 5.173.2.458 CAN_F11R1_FB12 . . . . . | 681 |
| 5.173.2.459 CAN_F11R1_FB13 . . . . . | 681 |
| 5.173.2.460 CAN_F11R1_FB14 . . . . . | 681 |
| 5.173.2.461 CAN_F11R1_FB15 . . . . . | 682 |
| 5.173.2.462 CAN_F11R1_FB16 . . . . . | 682 |
| 5.173.2.463 CAN_F11R1_FB17 . . . . . | 682 |
| 5.173.2.464 CAN_F11R1_FB18 . . . . . | 682 |
| 5.173.2.465 CAN_F11R1_FB19 . . . . . | 682 |
| 5.173.2.466 CAN_F11R1_FB2 . . . . .  | 682 |
| 5.173.2.467 CAN_F11R1_FB20 . . . . . | 682 |
| 5.173.2.468 CAN_F11R1_FB21 . . . . . | 682 |
| 5.173.2.469 CAN_F11R1_FB22 . . . . . | 683 |
| 5.173.2.470 CAN_F11R1_FB23 . . . . . | 683 |
| 5.173.2.471 CAN_F11R1_FB24 . . . . . | 683 |
| 5.173.2.472 CAN_F11R1_FB25 . . . . . | 683 |
| 5.173.2.473 CAN_F11R1_FB26 . . . . . | 683 |
| 5.173.2.474 CAN_F11R1_FB27 . . . . . | 683 |
| 5.173.2.475 CAN_F11R1_FB28 . . . . . | 683 |
| 5.173.2.476 CAN_F11R1_FB29 . . . . . | 683 |
| 5.173.2.477 CAN_F11R1_FB3 . . . . .  | 684 |
| 5.173.2.478 CAN_F11R1_FB30 . . . . . | 684 |
| 5.173.2.479 CAN_F11R1_FB31 . . . . . | 684 |
| 5.173.2.480 CAN_F11R1_FB4 . . . . .  | 684 |

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.481 CAN_F11R1_FB5 . . . . .  | 684 |
| 5.173.2.482 CAN_F11R1_FB6 . . . . .  | 684 |
| 5.173.2.483 CAN_F11R1_FB7 . . . . .  | 684 |
| 5.173.2.484 CAN_F11R1_FB8 . . . . .  | 684 |
| 5.173.2.485 CAN_F11R1_FB9 . . . . .  | 685 |
| 5.173.2.486 CAN_F11R2_FB0 . . . . .  | 685 |
| 5.173.2.487 CAN_F11R2_FB1 . . . . .  | 685 |
| 5.173.2.488 CAN_F11R2_FB10 . . . . . | 685 |
| 5.173.2.489 CAN_F11R2_FB11 . . . . . | 685 |
| 5.173.2.490 CAN_F11R2_FB12 . . . . . | 685 |
| 5.173.2.491 CAN_F11R2_FB13 . . . . . | 685 |
| 5.173.2.492 CAN_F11R2_FB14 . . . . . | 685 |
| 5.173.2.493 CAN_F11R2_FB15 . . . . . | 686 |
| 5.173.2.494 CAN_F11R2_FB16 . . . . . | 686 |
| 5.173.2.495 CAN_F11R2_FB17 . . . . . | 686 |
| 5.173.2.496 CAN_F11R2_FB18 . . . . . | 686 |
| 5.173.2.497 CAN_F11R2_FB19 . . . . . | 686 |
| 5.173.2.498 CAN_F11R2_FB2 . . . . .  | 686 |
| 5.173.2.499 CAN_F11R2_FB20 . . . . . | 686 |
| 5.173.2.500 CAN_F11R2_FB21 . . . . . | 686 |
| 5.173.2.501 CAN_F11R2_FB22 . . . . . | 687 |
| 5.173.2.502 CAN_F11R2_FB23 . . . . . | 687 |
| 5.173.2.503 CAN_F11R2_FB24 . . . . . | 687 |
| 5.173.2.504 CAN_F11R2_FB25 . . . . . | 687 |
| 5.173.2.505 CAN_F11R2_FB26 . . . . . | 687 |
| 5.173.2.506 CAN_F11R2_FB27 . . . . . | 687 |
| 5.173.2.507 CAN_F11R2_FB28 . . . . . | 687 |
| 5.173.2.508 CAN_F11R2_FB29 . . . . . | 687 |
| 5.173.2.509 CAN_F11R2_FB3 . . . . .  | 688 |
| 5.173.2.510 CAN_F11R2_FB30 . . . . . | 688 |
| 5.173.2.511 CAN_F11R2_FB31 . . . . . | 688 |
| 5.173.2.512 CAN_F11R2_FB4 . . . . .  | 688 |
| 5.173.2.513 CAN_F11R2_FB5 . . . . .  | 688 |
| 5.173.2.514 CAN_F11R2_FB6 . . . . .  | 688 |
| 5.173.2.515 CAN_F11R2_FB7 . . . . .  | 688 |
| 5.173.2.516 CAN_F11R2_FB8 . . . . .  | 688 |
| 5.173.2.517 CAN_F11R2_FB9 . . . . .  | 689 |
| 5.173.2.518 CAN_F12R1_FB0 . . . . .  | 689 |
| 5.173.2.519 CAN_F12R1_FB1 . . . . .  | 689 |
| 5.173.2.520 CAN_F12R1_FB10 . . . . . | 689 |
| 5.173.2.521 CAN_F12R1_FB11 . . . . . | 689 |
| 5.173.2.522 CAN_F12R1_FB12 . . . . . | 689 |

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.523 CAN_F12R1_FB13 . . . . . | 689 |
| 5.173.2.524 CAN_F12R1_FB14 . . . . . | 689 |
| 5.173.2.525 CAN_F12R1_FB15 . . . . . | 690 |
| 5.173.2.526 CAN_F12R1_FB16 . . . . . | 690 |
| 5.173.2.527 CAN_F12R1_FB17 . . . . . | 690 |
| 5.173.2.528 CAN_F12R1_FB18 . . . . . | 690 |
| 5.173.2.529 CAN_F12R1_FB19 . . . . . | 690 |
| 5.173.2.530 CAN_F12R1_FB2 . . . . .  | 690 |
| 5.173.2.531 CAN_F12R1_FB20 . . . . . | 690 |
| 5.173.2.532 CAN_F12R1_FB21 . . . . . | 690 |
| 5.173.2.533 CAN_F12R1_FB22 . . . . . | 691 |
| 5.173.2.534 CAN_F12R1_FB23 . . . . . | 691 |
| 5.173.2.535 CAN_F12R1_FB24 . . . . . | 691 |
| 5.173.2.536 CAN_F12R1_FB25 . . . . . | 691 |
| 5.173.2.537 CAN_F12R1_FB26 . . . . . | 691 |
| 5.173.2.538 CAN_F12R1_FB27 . . . . . | 691 |
| 5.173.2.539 CAN_F12R1_FB28 . . . . . | 691 |
| 5.173.2.540 CAN_F12R1_FB29 . . . . . | 691 |
| 5.173.2.541 CAN_F12R1_FB3 . . . . .  | 692 |
| 5.173.2.542 CAN_F12R1_FB30 . . . . . | 692 |
| 5.173.2.543 CAN_F12R1_FB31 . . . . . | 692 |
| 5.173.2.544 CAN_F12R1_FB4 . . . . .  | 692 |
| 5.173.2.545 CAN_F12R1_FB5 . . . . .  | 692 |
| 5.173.2.546 CAN_F12R1_FB6 . . . . .  | 692 |
| 5.173.2.547 CAN_F12R1_FB7 . . . . .  | 692 |
| 5.173.2.548 CAN_F12R1_FB8 . . . . .  | 692 |
| 5.173.2.549 CAN_F12R1_FB9 . . . . .  | 693 |
| 5.173.2.550 CAN_F12R2_FB0 . . . . .  | 693 |
| 5.173.2.551 CAN_F12R2_FB1 . . . . .  | 693 |
| 5.173.2.552 CAN_F12R2_FB10 . . . . . | 693 |
| 5.173.2.553 CAN_F12R2_FB11 . . . . . | 693 |
| 5.173.2.554 CAN_F12R2_FB12 . . . . . | 693 |
| 5.173.2.555 CAN_F12R2_FB13 . . . . . | 693 |
| 5.173.2.556 CAN_F12R2_FB14 . . . . . | 693 |
| 5.173.2.557 CAN_F12R2_FB15 . . . . . | 694 |
| 5.173.2.558 CAN_F12R2_FB16 . . . . . | 694 |
| 5.173.2.559 CAN_F12R2_FB17 . . . . . | 694 |
| 5.173.2.560 CAN_F12R2_FB18 . . . . . | 694 |
| 5.173.2.561 CAN_F12R2_FB19 . . . . . | 694 |
| 5.173.2.562 CAN_F12R2_FB2 . . . . .  | 694 |
| 5.173.2.563 CAN_F12R2_FB20 . . . . . | 694 |
| 5.173.2.564 CAN_F12R2_FB21 . . . . . | 694 |

|                            |     |
|----------------------------|-----|
| 5.173.2.565 CAN_F12R2_FB22 | 695 |
| 5.173.2.566 CAN_F12R2_FB23 | 695 |
| 5.173.2.567 CAN_F12R2_FB24 | 695 |
| 5.173.2.568 CAN_F12R2_FB25 | 695 |
| 5.173.2.569 CAN_F12R2_FB26 | 695 |
| 5.173.2.570 CAN_F12R2_FB27 | 695 |
| 5.173.2.571 CAN_F12R2_FB28 | 695 |
| 5.173.2.572 CAN_F12R2_FB29 | 695 |
| 5.173.2.573 CAN_F12R2_FB3  | 696 |
| 5.173.2.574 CAN_F12R2_FB30 | 696 |
| 5.173.2.575 CAN_F12R2_FB31 | 696 |
| 5.173.2.576 CAN_F12R2_FB4  | 696 |
| 5.173.2.577 CAN_F12R2_FB5  | 696 |
| 5.173.2.578 CAN_F12R2_FB6  | 696 |
| 5.173.2.579 CAN_F12R2_FB7  | 696 |
| 5.173.2.580 CAN_F12R2_FB8  | 696 |
| 5.173.2.581 CAN_F12R2_FB9  | 697 |
| 5.173.2.582 CAN_F13R1_FB0  | 697 |
| 5.173.2.583 CAN_F13R1_FB1  | 697 |
| 5.173.2.584 CAN_F13R1_FB10 | 697 |
| 5.173.2.585 CAN_F13R1_FB11 | 697 |
| 5.173.2.586 CAN_F13R1_FB12 | 697 |
| 5.173.2.587 CAN_F13R1_FB13 | 697 |
| 5.173.2.588 CAN_F13R1_FB14 | 697 |
| 5.173.2.589 CAN_F13R1_FB15 | 698 |
| 5.173.2.590 CAN_F13R1_FB16 | 698 |
| 5.173.2.591 CAN_F13R1_FB17 | 698 |
| 5.173.2.592 CAN_F13R1_FB18 | 698 |
| 5.173.2.593 CAN_F13R1_FB19 | 698 |
| 5.173.2.594 CAN_F13R1_FB2  | 698 |
| 5.173.2.595 CAN_F13R1_FB20 | 698 |
| 5.173.2.596 CAN_F13R1_FB21 | 698 |
| 5.173.2.597 CAN_F13R1_FB22 | 699 |
| 5.173.2.598 CAN_F13R1_FB23 | 699 |
| 5.173.2.599 CAN_F13R1_FB24 | 699 |
| 5.173.2.600 CAN_F13R1_FB25 | 699 |
| 5.173.2.601 CAN_F13R1_FB26 | 699 |
| 5.173.2.602 CAN_F13R1_FB27 | 699 |
| 5.173.2.603 CAN_F13R1_FB28 | 699 |
| 5.173.2.604 CAN_F13R1_FB29 | 699 |
| 5.173.2.605 CAN_F13R1_FB3  | 700 |
| 5.173.2.606 CAN_F13R1_FB30 | 700 |

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.607 CAN_F13R1_FB31 . . . . . | 700 |
| 5.173.2.608 CAN_F13R1_FB4 . . . . .  | 700 |
| 5.173.2.609 CAN_F13R1_FB5 . . . . .  | 700 |
| 5.173.2.610 CAN_F13R1_FB6 . . . . .  | 700 |
| 5.173.2.611 CAN_F13R1_FB7 . . . . .  | 700 |
| 5.173.2.612 CAN_F13R1_FB8 . . . . .  | 700 |
| 5.173.2.613 CAN_F13R1_FB9 . . . . .  | 701 |
| 5.173.2.614 CAN_F13R2_FB0 . . . . .  | 701 |
| 5.173.2.615 CAN_F13R2_FB1 . . . . .  | 701 |
| 5.173.2.616 CAN_F13R2_FB10 . . . . . | 701 |
| 5.173.2.617 CAN_F13R2_FB11 . . . . . | 701 |
| 5.173.2.618 CAN_F13R2_FB12 . . . . . | 701 |
| 5.173.2.619 CAN_F13R2_FB13 . . . . . | 701 |
| 5.173.2.620 CAN_F13R2_FB14 . . . . . | 701 |
| 5.173.2.621 CAN_F13R2_FB15 . . . . . | 702 |
| 5.173.2.622 CAN_F13R2_FB16 . . . . . | 702 |
| 5.173.2.623 CAN_F13R2_FB17 . . . . . | 702 |
| 5.173.2.624 CAN_F13R2_FB18 . . . . . | 702 |
| 5.173.2.625 CAN_F13R2_FB19 . . . . . | 702 |
| 5.173.2.626 CAN_F13R2_FB2 . . . . .  | 702 |
| 5.173.2.627 CAN_F13R2_FB20 . . . . . | 702 |
| 5.173.2.628 CAN_F13R2_FB21 . . . . . | 702 |
| 5.173.2.629 CAN_F13R2_FB22 . . . . . | 703 |
| 5.173.2.630 CAN_F13R2_FB23 . . . . . | 703 |
| 5.173.2.631 CAN_F13R2_FB24 . . . . . | 703 |
| 5.173.2.632 CAN_F13R2_FB25 . . . . . | 703 |
| 5.173.2.633 CAN_F13R2_FB26 . . . . . | 703 |
| 5.173.2.634 CAN_F13R2_FB27 . . . . . | 703 |
| 5.173.2.635 CAN_F13R2_FB28 . . . . . | 703 |
| 5.173.2.636 CAN_F13R2_FB29 . . . . . | 703 |
| 5.173.2.637 CAN_F13R2_FB3 . . . . .  | 704 |
| 5.173.2.638 CAN_F13R2_FB30 . . . . . | 704 |
| 5.173.2.639 CAN_F13R2_FB31 . . . . . | 704 |
| 5.173.2.640 CAN_F13R2_FB4 . . . . .  | 704 |
| 5.173.2.641 CAN_F13R2_FB5 . . . . .  | 704 |
| 5.173.2.642 CAN_F13R2_FB6 . . . . .  | 704 |
| 5.173.2.643 CAN_F13R2_FB7 . . . . .  | 704 |
| 5.173.2.644 CAN_F13R2_FB8 . . . . .  | 704 |
| 5.173.2.645 CAN_F13R2_FB9 . . . . .  | 705 |
| 5.173.2.646 CAN_F1R1_FB0 . . . . .   | 705 |
| 5.173.2.647 CAN_F1R1_FB1 . . . . .   | 705 |
| 5.173.2.648 CAN_F1R1_FB10 . . . . .  | 705 |

---

|                                     |     |
|-------------------------------------|-----|
| 5.173.2.649 CAN_F1R1_FB11 . . . . . | 705 |
| 5.173.2.650 CAN_F1R1_FB12 . . . . . | 705 |
| 5.173.2.651 CAN_F1R1_FB13 . . . . . | 705 |
| 5.173.2.652 CAN_F1R1_FB14 . . . . . | 705 |
| 5.173.2.653 CAN_F1R1_FB15 . . . . . | 706 |
| 5.173.2.654 CAN_F1R1_FB16 . . . . . | 706 |
| 5.173.2.655 CAN_F1R1_FB17 . . . . . | 706 |
| 5.173.2.656 CAN_F1R1_FB18 . . . . . | 706 |
| 5.173.2.657 CAN_F1R1_FB19 . . . . . | 706 |
| 5.173.2.658 CAN_F1R1_FB2 . . . . .  | 706 |
| 5.173.2.659 CAN_F1R1_FB20 . . . . . | 706 |
| 5.173.2.660 CAN_F1R1_FB21 . . . . . | 706 |
| 5.173.2.661 CAN_F1R1_FB22 . . . . . | 707 |
| 5.173.2.662 CAN_F1R1_FB23 . . . . . | 707 |
| 5.173.2.663 CAN_F1R1_FB24 . . . . . | 707 |
| 5.173.2.664 CAN_F1R1_FB25 . . . . . | 707 |
| 5.173.2.665 CAN_F1R1_FB26 . . . . . | 707 |
| 5.173.2.666 CAN_F1R1_FB27 . . . . . | 707 |
| 5.173.2.667 CAN_F1R1_FB28 . . . . . | 707 |
| 5.173.2.668 CAN_F1R1_FB29 . . . . . | 707 |
| 5.173.2.669 CAN_F1R1_FB3 . . . . .  | 708 |
| 5.173.2.670 CAN_F1R1_FB30 . . . . . | 708 |
| 5.173.2.671 CAN_F1R1_FB31 . . . . . | 708 |
| 5.173.2.672 CAN_F1R1_FB4 . . . . .  | 708 |
| 5.173.2.673 CAN_F1R1_FB5 . . . . .  | 708 |
| 5.173.2.674 CAN_F1R1_FB6 . . . . .  | 708 |
| 5.173.2.675 CAN_F1R1_FB7 . . . . .  | 708 |
| 5.173.2.676 CAN_F1R1_FB8 . . . . .  | 708 |
| 5.173.2.677 CAN_F1R1_FB9 . . . . .  | 709 |
| 5.173.2.678 CAN_F1R2_FB0 . . . . .  | 709 |
| 5.173.2.679 CAN_F1R2_FB1 . . . . .  | 709 |
| 5.173.2.680 CAN_F1R2_FB10 . . . . . | 709 |
| 5.173.2.681 CAN_F1R2_FB11 . . . . . | 709 |
| 5.173.2.682 CAN_F1R2_FB12 . . . . . | 709 |
| 5.173.2.683 CAN_F1R2_FB13 . . . . . | 709 |
| 5.173.2.684 CAN_F1R2_FB14 . . . . . | 709 |
| 5.173.2.685 CAN_F1R2_FB15 . . . . . | 710 |
| 5.173.2.686 CAN_F1R2_FB16 . . . . . | 710 |
| 5.173.2.687 CAN_F1R2_FB17 . . . . . | 710 |
| 5.173.2.688 CAN_F1R2_FB18 . . . . . | 710 |
| 5.173.2.689 CAN_F1R2_FB19 . . . . . | 710 |
| 5.173.2.690 CAN_F1R2_FB2 . . . . .  | 710 |

---

|                                     |     |
|-------------------------------------|-----|
| 5.173.2.691 CAN_F1R2_FB20 . . . . . | 710 |
| 5.173.2.692 CAN_F1R2_FB21 . . . . . | 710 |
| 5.173.2.693 CAN_F1R2_FB22 . . . . . | 711 |
| 5.173.2.694 CAN_F1R2_FB23 . . . . . | 711 |
| 5.173.2.695 CAN_F1R2_FB24 . . . . . | 711 |
| 5.173.2.696 CAN_F1R2_FB25 . . . . . | 711 |
| 5.173.2.697 CAN_F1R2_FB26 . . . . . | 711 |
| 5.173.2.698 CAN_F1R2_FB27 . . . . . | 711 |
| 5.173.2.699 CAN_F1R2_FB28 . . . . . | 711 |
| 5.173.2.700 CAN_F1R2_FB29 . . . . . | 711 |
| 5.173.2.701 CAN_F1R2_FB3 . . . . .  | 712 |
| 5.173.2.702 CAN_F1R2_FB30 . . . . . | 712 |
| 5.173.2.703 CAN_F1R2_FB31 . . . . . | 712 |
| 5.173.2.704 CAN_F1R2_FB4 . . . . .  | 712 |
| 5.173.2.705 CAN_F1R2_FB5 . . . . .  | 712 |
| 5.173.2.706 CAN_F1R2_FB6 . . . . .  | 712 |
| 5.173.2.707 CAN_F1R2_FB7 . . . . .  | 712 |
| 5.173.2.708 CAN_F1R2_FB8 . . . . .  | 712 |
| 5.173.2.709 CAN_F1R2_FB9 . . . . .  | 713 |
| 5.173.2.710 CAN_F2R1_FB0 . . . . .  | 713 |
| 5.173.2.711 CAN_F2R1_FB1 . . . . .  | 713 |
| 5.173.2.712 CAN_F2R1_FB10 . . . . . | 713 |
| 5.173.2.713 CAN_F2R1_FB11 . . . . . | 713 |
| 5.173.2.714 CAN_F2R1_FB12 . . . . . | 713 |
| 5.173.2.715 CAN_F2R1_FB13 . . . . . | 713 |
| 5.173.2.716 CAN_F2R1_FB14 . . . . . | 713 |
| 5.173.2.717 CAN_F2R1_FB15 . . . . . | 714 |
| 5.173.2.718 CAN_F2R1_FB16 . . . . . | 714 |
| 5.173.2.719 CAN_F2R1_FB17 . . . . . | 714 |
| 5.173.2.720 CAN_F2R1_FB18 . . . . . | 714 |
| 5.173.2.721 CAN_F2R1_FB19 . . . . . | 714 |
| 5.173.2.722 CAN_F2R1_FB2 . . . . .  | 714 |
| 5.173.2.723 CAN_F2R1_FB20 . . . . . | 714 |
| 5.173.2.724 CAN_F2R1_FB21 . . . . . | 714 |
| 5.173.2.725 CAN_F2R1_FB22 . . . . . | 715 |
| 5.173.2.726 CAN_F2R1_FB23 . . . . . | 715 |
| 5.173.2.727 CAN_F2R1_FB24 . . . . . | 715 |
| 5.173.2.728 CAN_F2R1_FB25 . . . . . | 715 |
| 5.173.2.729 CAN_F2R1_FB26 . . . . . | 715 |
| 5.173.2.730 CAN_F2R1_FB27 . . . . . | 715 |
| 5.173.2.731 CAN_F2R1_FB28 . . . . . | 715 |
| 5.173.2.732 CAN_F2R1_FB29 . . . . . | 715 |

|                                     |     |
|-------------------------------------|-----|
| 5.173.2.733 CAN_F2R1_FB3 . . . . .  | 716 |
| 5.173.2.734 CAN_F2R1_FB30 . . . . . | 716 |
| 5.173.2.735 CAN_F2R1_FB31 . . . . . | 716 |
| 5.173.2.736 CAN_F2R1_FB4 . . . . .  | 716 |
| 5.173.2.737 CAN_F2R1_FB5 . . . . .  | 716 |
| 5.173.2.738 CAN_F2R1_FB6 . . . . .  | 716 |
| 5.173.2.739 CAN_F2R1_FB7 . . . . .  | 716 |
| 5.173.2.740 CAN_F2R1_FB8 . . . . .  | 716 |
| 5.173.2.741 CAN_F2R1_FB9 . . . . .  | 717 |
| 5.173.2.742 CAN_F2R2_FB0 . . . . .  | 717 |
| 5.173.2.743 CAN_F2R2_FB1 . . . . .  | 717 |
| 5.173.2.744 CAN_F2R2_FB10 . . . . . | 717 |
| 5.173.2.745 CAN_F2R2_FB11 . . . . . | 717 |
| 5.173.2.746 CAN_F2R2_FB12 . . . . . | 717 |
| 5.173.2.747 CAN_F2R2_FB13 . . . . . | 717 |
| 5.173.2.748 CAN_F2R2_FB14 . . . . . | 717 |
| 5.173.2.749 CAN_F2R2_FB15 . . . . . | 718 |
| 5.173.2.750 CAN_F2R2_FB16 . . . . . | 718 |
| 5.173.2.751 CAN_F2R2_FB17 . . . . . | 718 |
| 5.173.2.752 CAN_F2R2_FB18 . . . . . | 718 |
| 5.173.2.753 CAN_F2R2_FB19 . . . . . | 718 |
| 5.173.2.754 CAN_F2R2_FB2 . . . . .  | 718 |
| 5.173.2.755 CAN_F2R2_FB20 . . . . . | 718 |
| 5.173.2.756 CAN_F2R2_FB21 . . . . . | 718 |
| 5.173.2.757 CAN_F2R2_FB22 . . . . . | 719 |
| 5.173.2.758 CAN_F2R2_FB23 . . . . . | 719 |
| 5.173.2.759 CAN_F2R2_FB24 . . . . . | 719 |
| 5.173.2.760 CAN_F2R2_FB25 . . . . . | 719 |
| 5.173.2.761 CAN_F2R2_FB26 . . . . . | 719 |
| 5.173.2.762 CAN_F2R2_FB27 . . . . . | 719 |
| 5.173.2.763 CAN_F2R2_FB28 . . . . . | 719 |
| 5.173.2.764 CAN_F2R2_FB29 . . . . . | 719 |
| 5.173.2.765 CAN_F2R2_FB3 . . . . .  | 720 |
| 5.173.2.766 CAN_F2R2_FB30 . . . . . | 720 |
| 5.173.2.767 CAN_F2R2_FB31 . . . . . | 720 |
| 5.173.2.768 CAN_F2R2_FB4 . . . . .  | 720 |
| 5.173.2.769 CAN_F2R2_FB5 . . . . .  | 720 |
| 5.173.2.770 CAN_F2R2_FB6 . . . . .  | 720 |
| 5.173.2.771 CAN_F2R2_FB7 . . . . .  | 720 |
| 5.173.2.772 CAN_F2R2_FB8 . . . . .  | 720 |
| 5.173.2.773 CAN_F2R2_FB9 . . . . .  | 721 |
| 5.173.2.774 CAN_F3R1_FB0 . . . . .  | 721 |

---

|                                     |     |
|-------------------------------------|-----|
| 5.173.2.775 CAN_F3R1_FB1 . . . . .  | 721 |
| 5.173.2.776 CAN_F3R1_FB10 . . . . . | 721 |
| 5.173.2.777 CAN_F3R1_FB11 . . . . . | 721 |
| 5.173.2.778 CAN_F3R1_FB12 . . . . . | 721 |
| 5.173.2.779 CAN_F3R1_FB13 . . . . . | 721 |
| 5.173.2.780 CAN_F3R1_FB14 . . . . . | 721 |
| 5.173.2.781 CAN_F3R1_FB15 . . . . . | 722 |
| 5.173.2.782 CAN_F3R1_FB16 . . . . . | 722 |
| 5.173.2.783 CAN_F3R1_FB17 . . . . . | 722 |
| 5.173.2.784 CAN_F3R1_FB18 . . . . . | 722 |
| 5.173.2.785 CAN_F3R1_FB19 . . . . . | 722 |
| 5.173.2.786 CAN_F3R1_FB2 . . . . .  | 722 |
| 5.173.2.787 CAN_F3R1_FB20 . . . . . | 722 |
| 5.173.2.788 CAN_F3R1_FB21 . . . . . | 722 |
| 5.173.2.789 CAN_F3R1_FB22 . . . . . | 723 |
| 5.173.2.790 CAN_F3R1_FB23 . . . . . | 723 |
| 5.173.2.791 CAN_F3R1_FB24 . . . . . | 723 |
| 5.173.2.792 CAN_F3R1_FB25 . . . . . | 723 |
| 5.173.2.793 CAN_F3R1_FB26 . . . . . | 723 |
| 5.173.2.794 CAN_F3R1_FB27 . . . . . | 723 |
| 5.173.2.795 CAN_F3R1_FB28 . . . . . | 723 |
| 5.173.2.796 CAN_F3R1_FB29 . . . . . | 723 |
| 5.173.2.797 CAN_F3R1_FB3 . . . . .  | 724 |
| 5.173.2.798 CAN_F3R1_FB30 . . . . . | 724 |
| 5.173.2.799 CAN_F3R1_FB31 . . . . . | 724 |
| 5.173.2.800 CAN_F3R1_FB4 . . . . .  | 724 |
| 5.173.2.801 CAN_F3R1_FB5 . . . . .  | 724 |
| 5.173.2.802 CAN_F3R1_FB6 . . . . .  | 724 |
| 5.173.2.803 CAN_F3R1_FB7 . . . . .  | 724 |
| 5.173.2.804 CAN_F3R1_FB8 . . . . .  | 724 |
| 5.173.2.805 CAN_F3R1_FB9 . . . . .  | 725 |
| 5.173.2.806 CAN_F3R2_FB0 . . . . .  | 725 |
| 5.173.2.807 CAN_F3R2_FB1 . . . . .  | 725 |
| 5.173.2.808 CAN_F3R2_FB10 . . . . . | 725 |
| 5.173.2.809 CAN_F3R2_FB11 . . . . . | 725 |
| 5.173.2.810 CAN_F3R2_FB12 . . . . . | 725 |
| 5.173.2.811 CAN_F3R2_FB13 . . . . . | 725 |
| 5.173.2.812 CAN_F3R2_FB14 . . . . . | 725 |
| 5.173.2.813 CAN_F3R2_FB15 . . . . . | 726 |
| 5.173.2.814 CAN_F3R2_FB16 . . . . . | 726 |
| 5.173.2.815 CAN_F3R2_FB17 . . . . . | 726 |
| 5.173.2.816 CAN_F3R2_FB18 . . . . . | 726 |

---

|                                     |     |
|-------------------------------------|-----|
| 5.173.2.817 CAN_F3R2_FB19 . . . . . | 726 |
| 5.173.2.818 CAN_F3R2_FB2 . . . . .  | 726 |
| 5.173.2.819 CAN_F3R2_FB20 . . . . . | 726 |
| 5.173.2.820 CAN_F3R2_FB21 . . . . . | 726 |
| 5.173.2.821 CAN_F3R2_FB22 . . . . . | 727 |
| 5.173.2.822 CAN_F3R2_FB23 . . . . . | 727 |
| 5.173.2.823 CAN_F3R2_FB24 . . . . . | 727 |
| 5.173.2.824 CAN_F3R2_FB25 . . . . . | 727 |
| 5.173.2.825 CAN_F3R2_FB26 . . . . . | 727 |
| 5.173.2.826 CAN_F3R2_FB27 . . . . . | 727 |
| 5.173.2.827 CAN_F3R2_FB28 . . . . . | 727 |
| 5.173.2.828 CAN_F3R2_FB29 . . . . . | 727 |
| 5.173.2.829 CAN_F3R2_FB3 . . . . .  | 728 |
| 5.173.2.830 CAN_F3R2_FB30 . . . . . | 728 |
| 5.173.2.831 CAN_F3R2_FB31 . . . . . | 728 |
| 5.173.2.832 CAN_F3R2_FB4 . . . . .  | 728 |
| 5.173.2.833 CAN_F3R2_FB5 . . . . .  | 728 |
| 5.173.2.834 CAN_F3R2_FB6 . . . . .  | 728 |
| 5.173.2.835 CAN_F3R2_FB7 . . . . .  | 728 |
| 5.173.2.836 CAN_F3R2_FB8 . . . . .  | 728 |
| 5.173.2.837 CAN_F3R2_FB9 . . . . .  | 729 |
| 5.173.2.838 CAN_F4R1_FB0 . . . . .  | 729 |
| 5.173.2.839 CAN_F4R1_FB1 . . . . .  | 729 |
| 5.173.2.840 CAN_F4R1_FB10 . . . . . | 729 |
| 5.173.2.841 CAN_F4R1_FB11 . . . . . | 729 |
| 5.173.2.842 CAN_F4R1_FB12 . . . . . | 729 |
| 5.173.2.843 CAN_F4R1_FB13 . . . . . | 729 |
| 5.173.2.844 CAN_F4R1_FB14 . . . . . | 729 |
| 5.173.2.845 CAN_F4R1_FB15 . . . . . | 730 |
| 5.173.2.846 CAN_F4R1_FB16 . . . . . | 730 |
| 5.173.2.847 CAN_F4R1_FB17 . . . . . | 730 |
| 5.173.2.848 CAN_F4R1_FB18 . . . . . | 730 |
| 5.173.2.849 CAN_F4R1_FB19 . . . . . | 730 |
| 5.173.2.850 CAN_F4R1_FB2 . . . . .  | 730 |
| 5.173.2.851 CAN_F4R1_FB20 . . . . . | 730 |
| 5.173.2.852 CAN_F4R1_FB21 . . . . . | 730 |
| 5.173.2.853 CAN_F4R1_FB22 . . . . . | 731 |
| 5.173.2.854 CAN_F4R1_FB23 . . . . . | 731 |
| 5.173.2.855 CAN_F4R1_FB24 . . . . . | 731 |
| 5.173.2.856 CAN_F4R1_FB25 . . . . . | 731 |
| 5.173.2.857 CAN_F4R1_FB26 . . . . . | 731 |
| 5.173.2.858 CAN_F4R1_FB27 . . . . . | 731 |

---

|                                     |     |
|-------------------------------------|-----|
| 5.173.2.859 CAN_F4R1_FB28 . . . . . | 731 |
| 5.173.2.860 CAN_F4R1_FB29 . . . . . | 731 |
| 5.173.2.861 CAN_F4R1_FB3 . . . . .  | 732 |
| 5.173.2.862 CAN_F4R1_FB30 . . . . . | 732 |
| 5.173.2.863 CAN_F4R1_FB31 . . . . . | 732 |
| 5.173.2.864 CAN_F4R1_FB4 . . . . .  | 732 |
| 5.173.2.865 CAN_F4R1_FB5 . . . . .  | 732 |
| 5.173.2.866 CAN_F4R1_FB6 . . . . .  | 732 |
| 5.173.2.867 CAN_F4R1_FB7 . . . . .  | 732 |
| 5.173.2.868 CAN_F4R1_FB8 . . . . .  | 732 |
| 5.173.2.869 CAN_F4R1_FB9 . . . . .  | 733 |
| 5.173.2.870 CAN_F4R2_FB0 . . . . .  | 733 |
| 5.173.2.871 CAN_F4R2_FB1 . . . . .  | 733 |
| 5.173.2.872 CAN_F4R2_FB10 . . . . . | 733 |
| 5.173.2.873 CAN_F4R2_FB11 . . . . . | 733 |
| 5.173.2.874 CAN_F4R2_FB12 . . . . . | 733 |
| 5.173.2.875 CAN_F4R2_FB13 . . . . . | 733 |
| 5.173.2.876 CAN_F4R2_FB14 . . . . . | 733 |
| 5.173.2.877 CAN_F4R2_FB15 . . . . . | 734 |
| 5.173.2.878 CAN_F4R2_FB16 . . . . . | 734 |
| 5.173.2.879 CAN_F4R2_FB17 . . . . . | 734 |
| 5.173.2.880 CAN_F4R2_FB18 . . . . . | 734 |
| 5.173.2.881 CAN_F4R2_FB19 . . . . . | 734 |
| 5.173.2.882 CAN_F4R2_FB2 . . . . .  | 734 |
| 5.173.2.883 CAN_F4R2_FB20 . . . . . | 734 |
| 5.173.2.884 CAN_F4R2_FB21 . . . . . | 734 |
| 5.173.2.885 CAN_F4R2_FB22 . . . . . | 735 |
| 5.173.2.886 CAN_F4R2_FB23 . . . . . | 735 |
| 5.173.2.887 CAN_F4R2_FB24 . . . . . | 735 |
| 5.173.2.888 CAN_F4R2_FB25 . . . . . | 735 |
| 5.173.2.889 CAN_F4R2_FB26 . . . . . | 735 |
| 5.173.2.890 CAN_F4R2_FB27 . . . . . | 735 |
| 5.173.2.891 CAN_F4R2_FB28 . . . . . | 735 |
| 5.173.2.892 CAN_F4R2_FB29 . . . . . | 735 |
| 5.173.2.893 CAN_F4R2_FB3 . . . . .  | 736 |
| 5.173.2.894 CAN_F4R2_FB30 . . . . . | 736 |
| 5.173.2.895 CAN_F4R2_FB31 . . . . . | 736 |
| 5.173.2.896 CAN_F4R2_FB4 . . . . .  | 736 |
| 5.173.2.897 CAN_F4R2_FB5 . . . . .  | 736 |
| 5.173.2.898 CAN_F4R2_FB6 . . . . .  | 736 |
| 5.173.2.899 CAN_F4R2_FB7 . . . . .  | 736 |
| 5.173.2.900 CAN_F4R2_FB8 . . . . .  | 736 |

---

|                                     |     |
|-------------------------------------|-----|
| 5.173.2.901 CAN_F4R2_FB9 . . . . .  | 737 |
| 5.173.2.902 CAN_F5R1_FB0 . . . . .  | 737 |
| 5.173.2.903 CAN_F5R1_FB1 . . . . .  | 737 |
| 5.173.2.904 CAN_F5R1_FB10 . . . . . | 737 |
| 5.173.2.905 CAN_F5R1_FB11 . . . . . | 737 |
| 5.173.2.906 CAN_F5R1_FB12 . . . . . | 737 |
| 5.173.2.907 CAN_F5R1_FB13 . . . . . | 737 |
| 5.173.2.908 CAN_F5R1_FB14 . . . . . | 737 |
| 5.173.2.909 CAN_F5R1_FB15 . . . . . | 738 |
| 5.173.2.910 CAN_F5R1_FB16 . . . . . | 738 |
| 5.173.2.911 CAN_F5R1_FB17 . . . . . | 738 |
| 5.173.2.912 CAN_F5R1_FB18 . . . . . | 738 |
| 5.173.2.913 CAN_F5R1_FB19 . . . . . | 738 |
| 5.173.2.914 CAN_F5R1_FB2 . . . . .  | 738 |
| 5.173.2.915 CAN_F5R1_FB20 . . . . . | 738 |
| 5.173.2.916 CAN_F5R1_FB21 . . . . . | 738 |
| 5.173.2.917 CAN_F5R1_FB22 . . . . . | 739 |
| 5.173.2.918 CAN_F5R1_FB23 . . . . . | 739 |
| 5.173.2.919 CAN_F5R1_FB24 . . . . . | 739 |
| 5.173.2.920 CAN_F5R1_FB25 . . . . . | 739 |
| 5.173.2.921 CAN_F5R1_FB26 . . . . . | 739 |
| 5.173.2.922 CAN_F5R1_FB27 . . . . . | 739 |
| 5.173.2.923 CAN_F5R1_FB28 . . . . . | 739 |
| 5.173.2.924 CAN_F5R1_FB29 . . . . . | 739 |
| 5.173.2.925 CAN_F5R1_FB3 . . . . .  | 740 |
| 5.173.2.926 CAN_F5R1_FB30 . . . . . | 740 |
| 5.173.2.927 CAN_F5R1_FB31 . . . . . | 740 |
| 5.173.2.928 CAN_F5R1_FB4 . . . . .  | 740 |
| 5.173.2.929 CAN_F5R1_FB5 . . . . .  | 740 |
| 5.173.2.930 CAN_F5R1_FB6 . . . . .  | 740 |
| 5.173.2.931 CAN_F5R1_FB7 . . . . .  | 740 |
| 5.173.2.932 CAN_F5R1_FB8 . . . . .  | 740 |
| 5.173.2.933 CAN_F5R1_FB9 . . . . .  | 741 |
| 5.173.2.934 CAN_F5R2_FB0 . . . . .  | 741 |
| 5.173.2.935 CAN_F5R2_FB1 . . . . .  | 741 |
| 5.173.2.936 CAN_F5R2_FB10 . . . . . | 741 |
| 5.173.2.937 CAN_F5R2_FB11 . . . . . | 741 |
| 5.173.2.938 CAN_F5R2_FB12 . . . . . | 741 |
| 5.173.2.939 CAN_F5R2_FB13 . . . . . | 741 |
| 5.173.2.940 CAN_F5R2_FB14 . . . . . | 741 |
| 5.173.2.941 CAN_F5R2_FB15 . . . . . | 742 |
| 5.173.2.942 CAN_F5R2_FB16 . . . . . | 742 |

---

|                                     |     |
|-------------------------------------|-----|
| 5.173.2.943 CAN_F5R2_FB17 . . . . . | 742 |
| 5.173.2.944 CAN_F5R2_FB18 . . . . . | 742 |
| 5.173.2.945 CAN_F5R2_FB19 . . . . . | 742 |
| 5.173.2.946 CAN_F5R2_FB2 . . . . .  | 742 |
| 5.173.2.947 CAN_F5R2_FB20 . . . . . | 742 |
| 5.173.2.948 CAN_F5R2_FB21 . . . . . | 742 |
| 5.173.2.949 CAN_F5R2_FB22 . . . . . | 743 |
| 5.173.2.950 CAN_F5R2_FB23 . . . . . | 743 |
| 5.173.2.951 CAN_F5R2_FB24 . . . . . | 743 |
| 5.173.2.952 CAN_F5R2_FB25 . . . . . | 743 |
| 5.173.2.953 CAN_F5R2_FB26 . . . . . | 743 |
| 5.173.2.954 CAN_F5R2_FB27 . . . . . | 743 |
| 5.173.2.955 CAN_F5R2_FB28 . . . . . | 743 |
| 5.173.2.956 CAN_F5R2_FB29 . . . . . | 743 |
| 5.173.2.957 CAN_F5R2_FB3 . . . . .  | 744 |
| 5.173.2.958 CAN_F5R2_FB30 . . . . . | 744 |
| 5.173.2.959 CAN_F5R2_FB31 . . . . . | 744 |
| 5.173.2.960 CAN_F5R2_FB4 . . . . .  | 744 |
| 5.173.2.961 CAN_F5R2_FB5 . . . . .  | 744 |
| 5.173.2.962 CAN_F5R2_FB6 . . . . .  | 744 |
| 5.173.2.963 CAN_F5R2_FB7 . . . . .  | 744 |
| 5.173.2.964 CAN_F5R2_FB8 . . . . .  | 744 |
| 5.173.2.965 CAN_F5R2_FB9 . . . . .  | 745 |
| 5.173.2.966 CAN_F6R1_FB0 . . . . .  | 745 |
| 5.173.2.967 CAN_F6R1_FB1 . . . . .  | 745 |
| 5.173.2.968 CAN_F6R1_FB10 . . . . . | 745 |
| 5.173.2.969 CAN_F6R1_FB11 . . . . . | 745 |
| 5.173.2.970 CAN_F6R1_FB12 . . . . . | 745 |
| 5.173.2.971 CAN_F6R1_FB13 . . . . . | 745 |
| 5.173.2.972 CAN_F6R1_FB14 . . . . . | 745 |
| 5.173.2.973 CAN_F6R1_FB15 . . . . . | 746 |
| 5.173.2.974 CAN_F6R1_FB16 . . . . . | 746 |
| 5.173.2.975 CAN_F6R1_FB17 . . . . . | 746 |
| 5.173.2.976 CAN_F6R1_FB18 . . . . . | 746 |
| 5.173.2.977 CAN_F6R1_FB19 . . . . . | 746 |
| 5.173.2.978 CAN_F6R1_FB2 . . . . .  | 746 |
| 5.173.2.979 CAN_F6R1_FB20 . . . . . | 746 |
| 5.173.2.980 CAN_F6R1_FB21 . . . . . | 746 |
| 5.173.2.981 CAN_F6R1_FB22 . . . . . | 747 |
| 5.173.2.982 CAN_F6R1_FB23 . . . . . | 747 |
| 5.173.2.983 CAN_F6R1_FB24 . . . . . | 747 |
| 5.173.2.984 CAN_F6R1_FB25 . . . . . | 747 |

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.985 CAN_F6R1_FB26 . . . . .  | 747 |
| 5.173.2.986 CAN_F6R1_FB27 . . . . .  | 747 |
| 5.173.2.987 CAN_F6R1_FB28 . . . . .  | 747 |
| 5.173.2.988 CAN_F6R1_FB29 . . . . .  | 747 |
| 5.173.2.989 CAN_F6R1_FB3 . . . . .   | 748 |
| 5.173.2.990 CAN_F6R1_FB30 . . . . .  | 748 |
| 5.173.2.991 CAN_F6R1_FB31 . . . . .  | 748 |
| 5.173.2.992 CAN_F6R1_FB4 . . . . .   | 748 |
| 5.173.2.993 CAN_F6R1_FB5 . . . . .   | 748 |
| 5.173.2.994 CAN_F6R1_FB6 . . . . .   | 748 |
| 5.173.2.995 CAN_F6R1_FB7 . . . . .   | 748 |
| 5.173.2.996 CAN_F6R1_FB8 . . . . .   | 748 |
| 5.173.2.997 CAN_F6R1_FB9 . . . . .   | 749 |
| 5.173.2.998 CAN_F6R2_FB0 . . . . .   | 749 |
| 5.173.2.999 CAN_F6R2_FB1 . . . . .   | 749 |
| 5.173.2.1000 CAN_F6R2_FB10 . . . . . | 749 |
| 5.173.2.1001 CAN_F6R2_FB11 . . . . . | 749 |
| 5.173.2.1002 CAN_F6R2_FB12 . . . . . | 749 |
| 5.173.2.1003 CAN_F6R2_FB13 . . . . . | 749 |
| 5.173.2.1004 CAN_F6R2_FB14 . . . . . | 749 |
| 5.173.2.1005 CAN_F6R2_FB15 . . . . . | 750 |
| 5.173.2.1006 CAN_F6R2_FB16 . . . . . | 750 |
| 5.173.2.1007 CAN_F6R2_FB17 . . . . . | 750 |
| 5.173.2.1008 CAN_F6R2_FB18 . . . . . | 750 |
| 5.173.2.1009 CAN_F6R2_FB19 . . . . . | 750 |
| 5.173.2.1010 CAN_F6R2_FB2 . . . . .  | 750 |
| 5.173.2.1011 CAN_F6R2_FB20 . . . . . | 750 |
| 5.173.2.1012 CAN_F6R2_FB21 . . . . . | 750 |
| 5.173.2.1013 CAN_F6R2_FB22 . . . . . | 751 |
| 5.173.2.1014 CAN_F6R2_FB23 . . . . . | 751 |
| 5.173.2.1015 CAN_F6R2_FB24 . . . . . | 751 |
| 5.173.2.1016 CAN_F6R2_FB25 . . . . . | 751 |
| 5.173.2.1017 CAN_F6R2_FB26 . . . . . | 751 |
| 5.173.2.1018 CAN_F6R2_FB27 . . . . . | 751 |
| 5.173.2.1019 CAN_F6R2_FB28 . . . . . | 751 |
| 5.173.2.1020 CAN_F6R2_FB29 . . . . . | 751 |
| 5.173.2.1021 CAN_F6R2_FB3 . . . . .  | 752 |
| 5.173.2.1022 CAN_F6R2_FB30 . . . . . | 752 |
| 5.173.2.1023 CAN_F6R2_FB31 . . . . . | 752 |
| 5.173.2.1024 CAN_F6R2_FB4 . . . . .  | 752 |
| 5.173.2.1025 CAN_F6R2_FB5 . . . . .  | 752 |
| 5.173.2.1026 CAN_F6R2_FB6 . . . . .  | 752 |

---

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.1027 CAN_F6R2_FB7 . . . . .  | 752 |
| 5.173.2.1028 CAN_F6R2_FB8 . . . . .  | 752 |
| 5.173.2.1029 CAN_F6R2_FB9 . . . . .  | 753 |
| 5.173.2.1030 CAN_F7R1_FB0 . . . . .  | 753 |
| 5.173.2.1031 CAN_F7R1_FB1 . . . . .  | 753 |
| 5.173.2.1032 CAN_F7R1_FB10 . . . . . | 753 |
| 5.173.2.1033 CAN_F7R1_FB11 . . . . . | 753 |
| 5.173.2.1034 CAN_F7R1_FB12 . . . . . | 753 |
| 5.173.2.1035 CAN_F7R1_FB13 . . . . . | 753 |
| 5.173.2.1036 CAN_F7R1_FB14 . . . . . | 753 |
| 5.173.2.1037 CAN_F7R1_FB15 . . . . . | 754 |
| 5.173.2.1038 CAN_F7R1_FB16 . . . . . | 754 |
| 5.173.2.1039 CAN_F7R1_FB17 . . . . . | 754 |
| 5.173.2.1040 CAN_F7R1_FB18 . . . . . | 754 |
| 5.173.2.1041 CAN_F7R1_FB19 . . . . . | 754 |
| 5.173.2.1042 CAN_F7R1_FB2 . . . . .  | 754 |
| 5.173.2.1043 CAN_F7R1_FB20 . . . . . | 754 |
| 5.173.2.1044 CAN_F7R1_FB21 . . . . . | 754 |
| 5.173.2.1045 CAN_F7R1_FB22 . . . . . | 755 |
| 5.173.2.1046 CAN_F7R1_FB23 . . . . . | 755 |
| 5.173.2.1047 CAN_F7R1_FB24 . . . . . | 755 |
| 5.173.2.1048 CAN_F7R1_FB25 . . . . . | 755 |
| 5.173.2.1049 CAN_F7R1_FB26 . . . . . | 755 |
| 5.173.2.1050 CAN_F7R1_FB27 . . . . . | 755 |
| 5.173.2.1051 CAN_F7R1_FB28 . . . . . | 755 |
| 5.173.2.1052 CAN_F7R1_FB29 . . . . . | 755 |
| 5.173.2.1053 CAN_F7R1_FB3 . . . . .  | 756 |
| 5.173.2.1054 CAN_F7R1_FB30 . . . . . | 756 |
| 5.173.2.1055 CAN_F7R1_FB31 . . . . . | 756 |
| 5.173.2.1056 CAN_F7R1_FB4 . . . . .  | 756 |
| 5.173.2.1057 CAN_F7R1_FB5 . . . . .  | 756 |
| 5.173.2.1058 CAN_F7R1_FB6 . . . . .  | 756 |
| 5.173.2.1059 CAN_F7R1_FB7 . . . . .  | 756 |
| 5.173.2.1060 CAN_F7R1_FB8 . . . . .  | 756 |
| 5.173.2.1061 CAN_F7R1_FB9 . . . . .  | 757 |
| 5.173.2.1062 CAN_F7R2_FB0 . . . . .  | 757 |
| 5.173.2.1063 CAN_F7R2_FB1 . . . . .  | 757 |
| 5.173.2.1064 CAN_F7R2_FB10 . . . . . | 757 |
| 5.173.2.1065 CAN_F7R2_FB11 . . . . . | 757 |
| 5.173.2.1066 CAN_F7R2_FB12 . . . . . | 757 |
| 5.173.2.1067 CAN_F7R2_FB13 . . . . . | 757 |
| 5.173.2.1068 CAN_F7R2_FB14 . . . . . | 757 |

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.1069 CAN_F7R2_FB15 . . . . . | 758 |
| 5.173.2.1070 CAN_F7R2_FB16 . . . . . | 758 |
| 5.173.2.1071 CAN_F7R2_FB17 . . . . . | 758 |
| 5.173.2.1072 CAN_F7R2_FB18 . . . . . | 758 |
| 5.173.2.1073 CAN_F7R2_FB19 . . . . . | 758 |
| 5.173.2.1074 CAN_F7R2_FB2 . . . . .  | 758 |
| 5.173.2.1075 CAN_F7R2_FB20 . . . . . | 758 |
| 5.173.2.1076 CAN_F7R2_FB21 . . . . . | 758 |
| 5.173.2.1077 CAN_F7R2_FB22 . . . . . | 759 |
| 5.173.2.1078 CAN_F7R2_FB23 . . . . . | 759 |
| 5.173.2.1079 CAN_F7R2_FB24 . . . . . | 759 |
| 5.173.2.1080 CAN_F7R2_FB25 . . . . . | 759 |
| 5.173.2.1081 CAN_F7R2_FB26 . . . . . | 759 |
| 5.173.2.1082 CAN_F7R2_FB27 . . . . . | 759 |
| 5.173.2.1083 CAN_F7R2_FB28 . . . . . | 759 |
| 5.173.2.1084 CAN_F7R2_FB29 . . . . . | 759 |
| 5.173.2.1085 CAN_F7R2_FB3 . . . . .  | 760 |
| 5.173.2.1086 CAN_F7R2_FB30 . . . . . | 760 |
| 5.173.2.1087 CAN_F7R2_FB31 . . . . . | 760 |
| 5.173.2.1088 CAN_F7R2_FB4 . . . . .  | 760 |
| 5.173.2.1089 CAN_F7R2_FB5 . . . . .  | 760 |
| 5.173.2.1090 CAN_F7R2_FB6 . . . . .  | 760 |
| 5.173.2.1091 CAN_F7R2_FB7 . . . . .  | 760 |
| 5.173.2.1092 CAN_F7R2_FB8 . . . . .  | 760 |
| 5.173.2.1093 CAN_F7R2_FB9 . . . . .  | 761 |
| 5.173.2.1094 CAN_F8R1_FB0 . . . . .  | 761 |
| 5.173.2.1095 CAN_F8R1_FB1 . . . . .  | 761 |
| 5.173.2.1096 CAN_F8R1_FB10 . . . . . | 761 |
| 5.173.2.1097 CAN_F8R1_FB11 . . . . . | 761 |
| 5.173.2.1098 CAN_F8R1_FB12 . . . . . | 761 |
| 5.173.2.1099 CAN_F8R1_FB13 . . . . . | 761 |
| 5.173.2.1100 CAN_F8R1_FB14 . . . . . | 761 |
| 5.173.2.1101 CAN_F8R1_FB15 . . . . . | 762 |
| 5.173.2.1102 CAN_F8R1_FB16 . . . . . | 762 |
| 5.173.2.1103 CAN_F8R1_FB17 . . . . . | 762 |
| 5.173.2.1104 CAN_F8R1_FB18 . . . . . | 762 |
| 5.173.2.1105 CAN_F8R1_FB19 . . . . . | 762 |
| 5.173.2.1106 CAN_F8R1_FB2 . . . . .  | 762 |
| 5.173.2.1107 CAN_F8R1_FB20 . . . . . | 762 |
| 5.173.2.1108 CAN_F8R1_FB21 . . . . . | 762 |
| 5.173.2.1109 CAN_F8R1_FB22 . . . . . | 763 |
| 5.173.2.1110 CAN_F8R1_FB23 . . . . . | 763 |

|                            |     |
|----------------------------|-----|
| 5.173.2.1111 CAN_F8R1_FB24 | 763 |
| 5.173.2.1112 CAN_F8R1_FB25 | 763 |
| 5.173.2.1113 CAN_F8R1_FB26 | 763 |
| 5.173.2.1114 CAN_F8R1_FB27 | 763 |
| 5.173.2.1115 CAN_F8R1_FB28 | 763 |
| 5.173.2.1116 CAN_F8R1_FB29 | 763 |
| 5.173.2.1117 CAN_F8R1_FB3  | 764 |
| 5.173.2.1118 CAN_F8R1_FB30 | 764 |
| 5.173.2.1119 CAN_F8R1_FB31 | 764 |
| 5.173.2.1120 CAN_F8R1_FB4  | 764 |
| 5.173.2.1121 CAN_F8R1_FB5  | 764 |
| 5.173.2.1122 CAN_F8R1_FB6  | 764 |
| 5.173.2.1123 CAN_F8R1_FB7  | 764 |
| 5.173.2.1124 CAN_F8R1_FB8  | 764 |
| 5.173.2.1125 CAN_F8R1_FB9  | 765 |
| 5.173.2.1126 CAN_F8R2_FB0  | 765 |
| 5.173.2.1127 CAN_F8R2_FB1  | 765 |
| 5.173.2.1128 CAN_F8R2_FB10 | 765 |
| 5.173.2.1129 CAN_F8R2_FB11 | 765 |
| 5.173.2.1130 CAN_F8R2_FB12 | 765 |
| 5.173.2.1131 CAN_F8R2_FB13 | 765 |
| 5.173.2.1132 CAN_F8R2_FB14 | 765 |
| 5.173.2.1133 CAN_F8R2_FB15 | 766 |
| 5.173.2.1134 CAN_F8R2_FB16 | 766 |
| 5.173.2.1135 CAN_F8R2_FB17 | 766 |
| 5.173.2.1136 CAN_F8R2_FB18 | 766 |
| 5.173.2.1137 CAN_F8R2_FB19 | 766 |
| 5.173.2.1138 CAN_F8R2_FB2  | 766 |
| 5.173.2.1139 CAN_F8R2_FB20 | 766 |
| 5.173.2.1140 CAN_F8R2_FB21 | 766 |
| 5.173.2.1141 CAN_F8R2_FB22 | 767 |
| 5.173.2.1142 CAN_F8R2_FB23 | 767 |
| 5.173.2.1143 CAN_F8R2_FB24 | 767 |
| 5.173.2.1144 CAN_F8R2_FB25 | 767 |
| 5.173.2.1145 CAN_F8R2_FB26 | 767 |
| 5.173.2.1146 CAN_F8R2_FB27 | 767 |
| 5.173.2.1147 CAN_F8R2_FB28 | 767 |
| 5.173.2.1148 CAN_F8R2_FB29 | 767 |
| 5.173.2.1149 CAN_F8R2_FB3  | 768 |
| 5.173.2.1150 CAN_F8R2_FB30 | 768 |
| 5.173.2.1151 CAN_F8R2_FB31 | 768 |
| 5.173.2.1152 CAN_F8R2_FB4  | 768 |

---

|                                      |     |
|--------------------------------------|-----|
| 5.173.2.1153 CAN_F8R2_FB5 . . . . .  | 768 |
| 5.173.2.1154 CAN_F8R2_FB6 . . . . .  | 768 |
| 5.173.2.1155 CAN_F8R2_FB7 . . . . .  | 768 |
| 5.173.2.1156 CAN_F8R2_FB8 . . . . .  | 768 |
| 5.173.2.1157 CAN_F8R2_FB9 . . . . .  | 769 |
| 5.173.2.1158 CAN_F9R1_FB0 . . . . .  | 769 |
| 5.173.2.1159 CAN_F9R1_FB1 . . . . .  | 769 |
| 5.173.2.1160 CAN_F9R1_FB10 . . . . . | 769 |
| 5.173.2.1161 CAN_F9R1_FB11 . . . . . | 769 |
| 5.173.2.1162 CAN_F9R1_FB12 . . . . . | 769 |
| 5.173.2.1163 CAN_F9R1_FB13 . . . . . | 769 |
| 5.173.2.1164 CAN_F9R1_FB14 . . . . . | 769 |
| 5.173.2.1165 CAN_F9R1_FB15 . . . . . | 770 |
| 5.173.2.1166 CAN_F9R1_FB16 . . . . . | 770 |
| 5.173.2.1167 CAN_F9R1_FB17 . . . . . | 770 |
| 5.173.2.1168 CAN_F9R1_FB18 . . . . . | 770 |
| 5.173.2.1169 CAN_F9R1_FB19 . . . . . | 770 |
| 5.173.2.1170 CAN_F9R1_FB2 . . . . .  | 770 |
| 5.173.2.1171 CAN_F9R1_FB20 . . . . . | 770 |
| 5.173.2.1172 CAN_F9R1_FB21 . . . . . | 770 |
| 5.173.2.1173 CAN_F9R1_FB22 . . . . . | 771 |
| 5.173.2.1174 CAN_F9R1_FB23 . . . . . | 771 |
| 5.173.2.1175 CAN_F9R1_FB24 . . . . . | 771 |
| 5.173.2.1176 CAN_F9R1_FB25 . . . . . | 771 |
| 5.173.2.1177 CAN_F9R1_FB26 . . . . . | 771 |
| 5.173.2.1178 CAN_F9R1_FB27 . . . . . | 771 |
| 5.173.2.1179 CAN_F9R1_FB28 . . . . . | 771 |
| 5.173.2.1180 CAN_F9R1_FB29 . . . . . | 771 |
| 5.173.2.1181 CAN_F9R1_FB3 . . . . .  | 772 |
| 5.173.2.1182 CAN_F9R1_FB30 . . . . . | 772 |
| 5.173.2.1183 CAN_F9R1_FB31 . . . . . | 772 |
| 5.173.2.1184 CAN_F9R1_FB4 . . . . .  | 772 |
| 5.173.2.1185 CAN_F9R1_FB5 . . . . .  | 772 |
| 5.173.2.1186 CAN_F9R1_FB6 . . . . .  | 772 |
| 5.173.2.1187 CAN_F9R1_FB7 . . . . .  | 772 |
| 5.173.2.1188 CAN_F9R1_FB8 . . . . .  | 772 |
| 5.173.2.1189 CAN_F9R1_FB9 . . . . .  | 773 |
| 5.173.2.1190 CAN_F9R2_FB0 . . . . .  | 773 |
| 5.173.2.1191 CAN_F9R2_FB1 . . . . .  | 773 |
| 5.173.2.1192 CAN_F9R2_FB10 . . . . . | 773 |
| 5.173.2.1193 CAN_F9R2_FB11 . . . . . | 773 |
| 5.173.2.1194 CAN_F9R2_FB12 . . . . . | 773 |

---

|                                        |     |
|----------------------------------------|-----|
| 5.173.2.1195 CAN_F9R2_FB13 . . . . .   | 773 |
| 5.173.2.1196 CAN_F9R2_FB14 . . . . .   | 773 |
| 5.173.2.1197 CAN_F9R2_FB15 . . . . .   | 774 |
| 5.173.2.1198 CAN_F9R2_FB16 . . . . .   | 774 |
| 5.173.2.1199 CAN_F9R2_FB17 . . . . .   | 774 |
| 5.173.2.1200 CAN_F9R2_FB18 . . . . .   | 774 |
| 5.173.2.1201 CAN_F9R2_FB19 . . . . .   | 774 |
| 5.173.2.1202 CAN_F9R2_FB2 . . . . .    | 774 |
| 5.173.2.1203 CAN_F9R2_FB20 . . . . .   | 774 |
| 5.173.2.1204 CAN_F9R2_FB21 . . . . .   | 774 |
| 5.173.2.1205 CAN_F9R2_FB22 . . . . .   | 775 |
| 5.173.2.1206 CAN_F9R2_FB23 . . . . .   | 775 |
| 5.173.2.1207 CAN_F9R2_FB24 . . . . .   | 775 |
| 5.173.2.1208 CAN_F9R2_FB25 . . . . .   | 775 |
| 5.173.2.1209 CAN_F9R2_FB26 . . . . .   | 775 |
| 5.173.2.1210 CAN_F9R2_FB27 . . . . .   | 775 |
| 5.173.2.1211 CAN_F9R2_FB28 . . . . .   | 775 |
| 5.173.2.1212 CAN_F9R2_FB29 . . . . .   | 775 |
| 5.173.2.1213 CAN_F9R2_FB3 . . . . .    | 776 |
| 5.173.2.1214 CAN_F9R2_FB30 . . . . .   | 776 |
| 5.173.2.1215 CAN_F9R2_FB31 . . . . .   | 776 |
| 5.173.2.1216 CAN_F9R2_FB4 . . . . .    | 776 |
| 5.173.2.1217 CAN_F9R2_FB5 . . . . .    | 776 |
| 5.173.2.1218 CAN_F9R2_FB6 . . . . .    | 776 |
| 5.173.2.1219 CAN_F9R2_FB7 . . . . .    | 776 |
| 5.173.2.1220 CAN_F9R2_FB8 . . . . .    | 776 |
| 5.173.2.1221 CAN_F9R2_FB9 . . . . .    | 777 |
| 5.173.2.1222 CAN_FA1R_FACT . . . . .   | 777 |
| 5.173.2.1223 CAN_FA1R_FACT0 . . . . .  | 777 |
| 5.173.2.1224 CAN_FA1R_FACT1 . . . . .  | 777 |
| 5.173.2.1225 CAN_FA1R_FACT10 . . . . . | 777 |
| 5.173.2.1226 CAN_FA1R_FACT11 . . . . . | 777 |
| 5.173.2.1227 CAN_FA1R_FACT12 . . . . . | 777 |
| 5.173.2.1228 CAN_FA1R_FACT13 . . . . . | 777 |
| 5.173.2.1229 CAN_FA1R_FACT2 . . . . .  | 778 |
| 5.173.2.1230 CAN_FA1R_FACT3 . . . . .  | 778 |
| 5.173.2.1231 CAN_FA1R_FACT4 . . . . .  | 778 |
| 5.173.2.1232 CAN_FA1R_FACT5 . . . . .  | 778 |
| 5.173.2.1233 CAN_FA1R_FACT6 . . . . .  | 778 |
| 5.173.2.1234 CAN_FA1R_FACT7 . . . . .  | 778 |
| 5.173.2.1235 CAN_FA1R_FACT8 . . . . .  | 778 |
| 5.173.2.1236 CAN_FA1R_FACT9 . . . . .  | 778 |

---

|                                        |     |
|----------------------------------------|-----|
| 5.173.2.1237 CAN_FFA1R_FFA . . . . .   | 779 |
| 5.173.2.1238 CAN_FFA1R_FFA0 . . . . .  | 779 |
| 5.173.2.1239 CAN_FFA1R_FFA1 . . . . .  | 779 |
| 5.173.2.1240 CAN_FFA1R_FFA10 . . . . . | 779 |
| 5.173.2.1241 CAN_FFA1R_FFA11 . . . . . | 779 |
| 5.173.2.1242 CAN_FFA1R_FFA12 . . . . . | 779 |
| 5.173.2.1243 CAN_FFA1R_FFA13 . . . . . | 779 |
| 5.173.2.1244 CAN_FFA1R_FFA2 . . . . .  | 779 |
| 5.173.2.1245 CAN_FFA1R_FFA3 . . . . .  | 780 |
| 5.173.2.1246 CAN_FFA1R_FFA4 . . . . .  | 780 |
| 5.173.2.1247 CAN_FFA1R_FFA5 . . . . .  | 780 |
| 5.173.2.1248 CAN_FFA1R_FFA6 . . . . .  | 780 |
| 5.173.2.1249 CAN_FFA1R_FFA7 . . . . .  | 780 |
| 5.173.2.1250 CAN_FFA1R_FFA8 . . . . .  | 780 |
| 5.173.2.1251 CAN_FFA1R_FFA9 . . . . .  | 780 |
| 5.173.2.1252 CAN_FM1R_FBM . . . . .    | 780 |
| 5.173.2.1253 CAN_FM1R_FBM0 . . . . .   | 781 |
| 5.173.2.1254 CAN_FM1R_FBM1 . . . . .   | 781 |
| 5.173.2.1255 CAN_FM1R_FBM10 . . . . .  | 781 |
| 5.173.2.1256 CAN_FM1R_FBM11 . . . . .  | 781 |
| 5.173.2.1257 CAN_FM1R_FBM12 . . . . .  | 781 |
| 5.173.2.1258 CAN_FM1R_FBM13 . . . . .  | 781 |
| 5.173.2.1259 CAN_FM1R_FBM2 . . . . .   | 781 |
| 5.173.2.1260 CAN_FM1R_FBM3 . . . . .   | 781 |
| 5.173.2.1261 CAN_FM1R_FBM4 . . . . .   | 782 |
| 5.173.2.1262 CAN_FM1R_FBM5 . . . . .   | 782 |
| 5.173.2.1263 CAN_FM1R_FBM6 . . . . .   | 782 |
| 5.173.2.1264 CAN_FM1R_FBM7 . . . . .   | 782 |
| 5.173.2.1265 CAN_FM1R_FBM8 . . . . .   | 782 |
| 5.173.2.1266 CAN_FM1R_FBM9 . . . . .   | 782 |
| 5.173.2.1267 CAN_FMR_FINIT . . . . .   | 782 |
| 5.173.2.1268 CAN_FS1R_FSC . . . . .    | 782 |
| 5.173.2.1269 CAN_FS1R_FSC0 . . . . .   | 783 |
| 5.173.2.1270 CAN_FS1R_FSC1 . . . . .   | 783 |
| 5.173.2.1271 CAN_FS1R_FSC10 . . . . .  | 783 |
| 5.173.2.1272 CAN_FS1R_FSC11 . . . . .  | 783 |
| 5.173.2.1273 CAN_FS1R_FSC12 . . . . .  | 783 |
| 5.173.2.1274 CAN_FS1R_FSC13 . . . . .  | 783 |
| 5.173.2.1275 CAN_FS1R_FSC2 . . . . .   | 783 |
| 5.173.2.1276 CAN_FS1R_FSC3 . . . . .   | 783 |
| 5.173.2.1277 CAN_FS1R_FSC4 . . . . .   | 784 |
| 5.173.2.1278 CAN_FS1R_FSC5 . . . . .   | 784 |

---

|                                        |     |
|----------------------------------------|-----|
| 5.173.2.1279 CAN_FS1R_FSC6 . . . . .   | 784 |
| 5.173.2.1280 CAN_FS1R_FSC7 . . . . .   | 784 |
| 5.173.2.1281 CAN_FS1R_FSC8 . . . . .   | 784 |
| 5.173.2.1282 CAN_FS1R_FSC9 . . . . .   | 784 |
| 5.173.2.1283 CAN_IER_BOFIE . . . . .   | 784 |
| 5.173.2.1284 CAN_IER_EPVIE . . . . .   | 784 |
| 5.173.2.1285 CAN_IER_ERRIE . . . . .   | 785 |
| 5.173.2.1286 CAN_IER_EWGLIE . . . . .  | 785 |
| 5.173.2.1287 CAN_IER_FFIIE0 . . . . .  | 785 |
| 5.173.2.1288 CAN_IER_FFIIE1 . . . . .  | 785 |
| 5.173.2.1289 CAN_IER_FMPIE0 . . . . .  | 785 |
| 5.173.2.1290 CAN_IER_FMPIE1 . . . . .  | 785 |
| 5.173.2.1291 CAN_IER_FOVIE0 . . . . .  | 785 |
| 5.173.2.1292 CAN_IER_FOVIE1 . . . . .  | 785 |
| 5.173.2.1293 CAN_IER_LECIE . . . . .   | 786 |
| 5.173.2.1294 CAN_IER_SLKIE . . . . .   | 786 |
| 5.173.2.1295 CAN_IER_TMEIE . . . . .   | 786 |
| 5.173.2.1296 CAN_IER_WKUIE . . . . .   | 786 |
| 5.173.2.1297 CAN_MCR_ABOM . . . . .    | 786 |
| 5.173.2.1298 CAN_MCR_AWUM . . . . .    | 786 |
| 5.173.2.1299 CAN_MCR_INRQ . . . . .    | 786 |
| 5.173.2.1300 CAN_MCR_NART . . . . .    | 786 |
| 5.173.2.1301 CAN_MCR_RESET . . . . .   | 787 |
| 5.173.2.1302 CAN_MCR_RFLM . . . . .    | 787 |
| 5.173.2.1303 CAN_MCR_SLEEP . . . . .   | 787 |
| 5.173.2.1304 CAN_MCR_TTCM . . . . .    | 787 |
| 5.173.2.1305 CAN_MCR_TXFP . . . . .    | 787 |
| 5.173.2.1306 CAN_MSR_ERRI . . . . .    | 787 |
| 5.173.2.1307 CAN_MSR_INAK . . . . .    | 787 |
| 5.173.2.1308 CAN_MSR_RX . . . . .      | 787 |
| 5.173.2.1309 CAN_MSR_RXM . . . . .     | 788 |
| 5.173.2.1310 CAN_MSR_SAMP . . . . .    | 788 |
| 5.173.2.1311 CAN_MSR_SLAK . . . . .    | 788 |
| 5.173.2.1312 CAN_MSR_SLAKI . . . . .   | 788 |
| 5.173.2.1313 CAN_MSR_TXM . . . . .     | 788 |
| 5.173.2.1314 CAN_MSR_WKUI . . . . .    | 788 |
| 5.173.2.1315 CAN_RDH0R_DATA4 . . . . . | 788 |
| 5.173.2.1316 CAN_RDH0R_DATA5 . . . . . | 788 |
| 5.173.2.1317 CAN_RDH0R_DATA6 . . . . . | 789 |
| 5.173.2.1318 CAN_RDH0R_DATA7 . . . . . | 789 |
| 5.173.2.1319 CAN_RDH1R_DATA4 . . . . . | 789 |
| 5.173.2.1320 CAN_RDH1R_DATA5 . . . . . | 789 |

---

|                                        |     |
|----------------------------------------|-----|
| 5.173.2.1321 CAN_RDH1R_DATA6 . . . . . | 789 |
| 5.173.2.1322 CAN_RDH1R_DATA7 . . . . . | 789 |
| 5.173.2.1323 CAN_RDL0R_DATA0 . . . . . | 789 |
| 5.173.2.1324 CAN_RDL0R_DATA1 . . . . . | 789 |
| 5.173.2.1325 CAN_RDL0R_DATA2 . . . . . | 790 |
| 5.173.2.1326 CAN_RDL0R_DATA3 . . . . . | 790 |
| 5.173.2.1327 CAN_RDL1R_DATA0 . . . . . | 790 |
| 5.173.2.1328 CAN_RDL1R_DATA1 . . . . . | 790 |
| 5.173.2.1329 CAN_RDL1R_DATA2 . . . . . | 790 |
| 5.173.2.1330 CAN_RDL1R_DATA3 . . . . . | 790 |
| 5.173.2.1331 CAN_RDT0R_DLC . . . . .   | 790 |
| 5.173.2.1332 CAN_RDT0R_FMI . . . . .   | 790 |
| 5.173.2.1333 CAN_RDT0R_TIME . . . . .  | 791 |
| 5.173.2.1334 CAN_RDT1R_DLC . . . . .   | 791 |
| 5.173.2.1335 CAN_RDT1R_FMI . . . . .   | 791 |
| 5.173.2.1336 CAN_RDT1R_TIME . . . . .  | 791 |
| 5.173.2.1337 CAN_RF0R_FMP0 . . . . .   | 791 |
| 5.173.2.1338 CAN_RF0R_FOVR0 . . . . .  | 791 |
| 5.173.2.1339 CAN_RF0R_FULL0 . . . . .  | 791 |
| 5.173.2.1340 CAN_RF0R_RFOM0 . . . . .  | 791 |
| 5.173.2.1341 CAN_RF1R_FMP1 . . . . .   | 792 |
| 5.173.2.1342 CAN_RF1R_FOVR1 . . . . .  | 792 |
| 5.173.2.1343 CAN_RF1R_FULL1 . . . . .  | 792 |
| 5.173.2.1344 CAN_RF1R_RFOM1 . . . . .  | 792 |
| 5.173.2.1345 CAN_RI0R_EXID . . . . .   | 792 |
| 5.173.2.1346 CAN_RI0R_IDE . . . . .    | 792 |
| 5.173.2.1347 CAN_RI0R_RTR . . . . .    | 792 |
| 5.173.2.1348 CAN_RI0R_STID . . . . .   | 792 |
| 5.173.2.1349 CAN_RI1R_EXID . . . . .   | 793 |
| 5.173.2.1350 CAN_RI1R_IDE . . . . .    | 793 |
| 5.173.2.1351 CAN_RI1R_RTR . . . . .    | 793 |
| 5.173.2.1352 CAN_RI1R_STID . . . . .   | 793 |
| 5.173.2.1353 CAN_TDH0R_DATA4 . . . . . | 793 |
| 5.173.2.1354 CAN_TDH0R_DATA5 . . . . . | 793 |
| 5.173.2.1355 CAN_TDH0R_DATA6 . . . . . | 793 |
| 5.173.2.1356 CAN_TDH0R_DATA7 . . . . . | 793 |
| 5.173.2.1357 CAN_TDH1R_DATA4 . . . . . | 794 |
| 5.173.2.1358 CAN_TDH1R_DATA5 . . . . . | 794 |
| 5.173.2.1359 CAN_TDH1R_DATA6 . . . . . | 794 |
| 5.173.2.1360 CAN_TDH1R_DATA7 . . . . . | 794 |
| 5.173.2.1361 CAN_TDH2R_DATA4 . . . . . | 794 |
| 5.173.2.1362 CAN_TDH2R_DATA5 . . . . . | 794 |

---

---

|                                        |     |
|----------------------------------------|-----|
| 5.173.2.1363 CAN_TDH2R_DATA6 . . . . . | 794 |
| 5.173.2.1364 CAN_TDH2R_DATA7 . . . . . | 794 |
| 5.173.2.1365 CAN_TDL0R_DATA0 . . . . . | 795 |
| 5.173.2.1366 CAN_TDL0R_DATA1 . . . . . | 795 |
| 5.173.2.1367 CAN_TDL0R_DATA2 . . . . . | 795 |
| 5.173.2.1368 CAN_TDL0R_DATA3 . . . . . | 795 |
| 5.173.2.1369 CAN_TDL1R_DATA0 . . . . . | 795 |
| 5.173.2.1370 CAN_TDL1R_DATA1 . . . . . | 795 |
| 5.173.2.1371 CAN_TDL1R_DATA2 . . . . . | 795 |
| 5.173.2.1372 CAN_TDL1R_DATA3 . . . . . | 795 |
| 5.173.2.1373 CAN_TDL2R_DATA0 . . . . . | 796 |
| 5.173.2.1374 CAN_TDL2R_DATA1 . . . . . | 796 |
| 5.173.2.1375 CAN_TDL2R_DATA2 . . . . . | 796 |
| 5.173.2.1376 CAN_TDL2R_DATA3 . . . . . | 796 |
| 5.173.2.1377 CAN_TDT0R_DLC . . . . .   | 796 |
| 5.173.2.1378 CAN_TDT0R_TGT . . . . .   | 796 |
| 5.173.2.1379 CAN_TDT0R_TIME . . . . .  | 796 |
| 5.173.2.1380 CAN_TDT1R_DLC . . . . .   | 796 |
| 5.173.2.1381 CAN_TDT1R_TGT . . . . .   | 797 |
| 5.173.2.1382 CAN_TDT1R_TIME . . . . .  | 797 |
| 5.173.2.1383 CAN_TDT2R_DLC . . . . .   | 797 |
| 5.173.2.1384 CAN_TDT2R_TGT . . . . .   | 797 |
| 5.173.2.1385 CAN_TDT2R_TIME . . . . .  | 797 |
| 5.173.2.1386 CAN_TI0R_EXID . . . . .   | 797 |
| 5.173.2.1387 CAN_TI0R_IDE . . . . .    | 797 |
| 5.173.2.1388 CAN_TI0R_RTR . . . . .    | 797 |
| 5.173.2.1389 CAN_TI0R_STID . . . . .   | 798 |
| 5.173.2.1390 CAN_TI0R_TXRQ . . . . .   | 798 |
| 5.173.2.1391 CAN_TI1R_EXID . . . . .   | 798 |
| 5.173.2.1392 CAN_TI1R_IDE . . . . .    | 798 |
| 5.173.2.1393 CAN_TI1R_RTR . . . . .    | 798 |
| 5.173.2.1394 CAN_TI1R_STID . . . . .   | 798 |
| 5.173.2.1395 CAN_TI1R_TXRQ . . . . .   | 798 |
| 5.173.2.1396 CAN_TI2R_EXID . . . . .   | 798 |
| 5.173.2.1397 CAN_TI2R_IDE . . . . .    | 799 |
| 5.173.2.1398 CAN_TI2R_RTR . . . . .    | 799 |
| 5.173.2.1399 CAN_TI2R_STID . . . . .   | 799 |
| 5.173.2.1400 CAN_TI2R_TXRQ . . . . .   | 799 |
| 5.173.2.1401 CAN_TSR_ABRQ0 . . . . .   | 799 |
| 5.173.2.1402 CAN_TSR_ABRQ1 . . . . .   | 799 |
| 5.173.2.1403 CAN_TSR_ABRQ2 . . . . .   | 799 |
| 5.173.2.1404 CAN_TSR_ALST0 . . . . .   | 799 |

---

|                                         |     |
|-----------------------------------------|-----|
| 5.173.2.1405 CAN_TSR_ALST1 . . . . .    | 800 |
| 5.173.2.1406 CAN_TSR_ALST2 . . . . .    | 800 |
| 5.173.2.1407 CAN_TSR_CODE . . . . .     | 800 |
| 5.173.2.1408 CAN_TSR_LOW . . . . .      | 800 |
| 5.173.2.1409 CAN_TSR_LOW0 . . . . .     | 800 |
| 5.173.2.1410 CAN_TSR_LOW1 . . . . .     | 800 |
| 5.173.2.1411 CAN_TSR_LOW2 . . . . .     | 800 |
| 5.173.2.1412 CAN_TSR_RQCP0 . . . . .    | 800 |
| 5.173.2.1413 CAN_TSR_RQCP1 . . . . .    | 801 |
| 5.173.2.1414 CAN_TSR_RQCP2 . . . . .    | 801 |
| 5.173.2.1415 CAN_TSR_TERR0 . . . . .    | 801 |
| 5.173.2.1416 CAN_TSR_TERR1 . . . . .    | 801 |
| 5.173.2.1417 CAN_TSR_TERR2 . . . . .    | 801 |
| 5.173.2.1418 CAN_TSR_TME . . . . .      | 801 |
| 5.173.2.1419 CAN_TSR_TME0 . . . . .     | 801 |
| 5.173.2.1420 CAN_TSR_TME1 . . . . .     | 801 |
| 5.173.2.1421 CAN_TSR_TME2 . . . . .     | 802 |
| 5.173.2.1422 CAN_TSR_TXOK0 . . . . .    | 802 |
| 5.173.2.1423 CAN_TSR_TXOK1 . . . . .    | 802 |
| 5.173.2.1424 CAN_TSR_TXOK2 . . . . .    | 802 |
| 5.173.2.1425 CRC_CR_RESET . . . . .     | 802 |
| 5.173.2.1426 CRC_DR_DR . . . . .        | 802 |
| 5.173.2.1427 CRC_IDR_IDR . . . . .      | 802 |
| 5.173.2.1428 DAC_CR_BOFF1 . . . . .     | 802 |
| 5.173.2.1429 DAC_CR_BOFF2 . . . . .     | 803 |
| 5.173.2.1430 DAC_CR_DMAEN1 . . . . .    | 803 |
| 5.173.2.1431 DAC_CR_DMAEN2 . . . . .    | 803 |
| 5.173.2.1432 DAC_CR_DMAUDRIE1 . . . . . | 803 |
| 5.173.2.1433 DAC_CR_DMAUDRIE2 . . . . . | 803 |
| 5.173.2.1434 DAC_CR_EN1 . . . . .       | 803 |
| 5.173.2.1435 DAC_CR_EN2 . . . . .       | 803 |
| 5.173.2.1436 DAC_CR_MAMP1 . . . . .     | 803 |
| 5.173.2.1437 DAC_CR_MAMP1_0 . . . . .   | 804 |
| 5.173.2.1438 DAC_CR_MAMP1_1 . . . . .   | 804 |
| 5.173.2.1439 DAC_CR_MAMP1_2 . . . . .   | 804 |
| 5.173.2.1440 DAC_CR_MAMP1_3 . . . . .   | 804 |
| 5.173.2.1441 DAC_CR_MAMP2 . . . . .     | 804 |
| 5.173.2.1442 DAC_CR_MAMP2_0 . . . . .   | 804 |
| 5.173.2.1443 DAC_CR_MAMP2_1 . . . . .   | 804 |
| 5.173.2.1444 DAC_CR_MAMP2_2 . . . . .   | 804 |
| 5.173.2.1445 DAC_CR_MAMP2_3 . . . . .   | 805 |
| 5.173.2.1446 DAC_CR_TEN1 . . . . .      | 805 |

---

|                                                |     |
|------------------------------------------------|-----|
| 5.173.2.1447 DAC_CR_TEN2 . . . . .             | 805 |
| 5.173.2.1448 DAC_CR_TSEL1 . . . . .            | 805 |
| 5.173.2.1449 DAC_CR_TSEL1_0 . . . . .          | 805 |
| 5.173.2.1450 DAC_CR_TSEL1_1 . . . . .          | 805 |
| 5.173.2.1451 DAC_CR_TSEL1_2 . . . . .          | 805 |
| 5.173.2.1452 DAC_CR_TSEL2 . . . . .            | 805 |
| 5.173.2.1453 DAC_CR_TSEL2_0 . . . . .          | 806 |
| 5.173.2.1454 DAC_CR_TSEL2_1 . . . . .          | 806 |
| 5.173.2.1455 DAC_CR_TSEL2_2 . . . . .          | 806 |
| 5.173.2.1456 DAC_CR_WAVE1 . . . . .            | 806 |
| 5.173.2.1457 DAC_CR_WAVE1_0 . . . . .          | 806 |
| 5.173.2.1458 DAC_CR_WAVE1_1 . . . . .          | 806 |
| 5.173.2.1459 DAC_CR_WAVE2 . . . . .            | 806 |
| 5.173.2.1460 DAC_CR_WAVE2_0 . . . . .          | 806 |
| 5.173.2.1461 DAC_CR_WAVE2_1 . . . . .          | 807 |
| 5.173.2.1462 DAC_DHR12L1_DACC1DHR . . . . .    | 807 |
| 5.173.2.1463 DAC_DHR12L2_DACC2DHR . . . . .    | 807 |
| 5.173.2.1464 DAC_DHR12LD_DACC1DHR . . . . .    | 807 |
| 5.173.2.1465 DAC_DHR12LD_DACC2DHR . . . . .    | 807 |
| 5.173.2.1466 DAC_DHR12R1_DACC1DHR . . . . .    | 807 |
| 5.173.2.1467 DAC_DHR12R2_DACC2DHR . . . . .    | 807 |
| 5.173.2.1468 DAC_DHR12RD_DACC1DHR . . . . .    | 807 |
| 5.173.2.1469 DAC_DHR12RD_DACC2DHR . . . . .    | 808 |
| 5.173.2.1470 DAC_DHR8R1_DACC1DHR . . . . .     | 808 |
| 5.173.2.1471 DAC_DHR8R2_DACC2DHR . . . . .     | 808 |
| 5.173.2.1472 DAC_DHR8RD_DACC1DHR . . . . .     | 808 |
| 5.173.2.1473 DAC_DHR8RD_DACC2DHR . . . . .     | 808 |
| 5.173.2.1474 DAC_DOR1_DACC1DOR . . . . .       | 808 |
| 5.173.2.1475 DAC_DOR2_DACC2DOR . . . . .       | 808 |
| 5.173.2.1476 DAC_SR_DMAUDR1 . . . . .          | 808 |
| 5.173.2.1477 DAC_SR_DMAUDR2 . . . . .          | 809 |
| 5.173.2.1478 DAC_SWTRIGR_SWTRIG1 . . . . .     | 809 |
| 5.173.2.1479 DAC_SWTRIGR_SWTRIG2 . . . . .     | 809 |
| 5.173.2.1480 DBGMCU_CR_TRACE_MODE_0 . . . . .  | 809 |
| 5.173.2.1481 DBGMCU_CR_TRACE_MODE_1 . . . . .  | 809 |
| 5.173.2.1482 DFSDM_CHAWSCDR_AWFORD . . . . .   | 809 |
| 5.173.2.1483 DFSDM_CHAWSCDR_AWFORD_0 . . . . . | 809 |
| 5.173.2.1484 DFSDM_CHAWSCDR_AWFORD_1 . . . . . | 809 |
| 5.173.2.1485 DFSDM_CHAWSCDR_AWFOSR . . . . .   | 810 |
| 5.173.2.1486 DFSDM_CHAWSCDR_BKSCD . . . . .    | 810 |
| 5.173.2.1487 DFSDM_CHAWSCDR_SCDT . . . . .     | 810 |
| 5.173.2.1488 DFSDM_CHCFG1_CHEN . . . . .       | 810 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.173.2.1489 DFSDM_CHCFG1_CHINSEL . . . . .     | 810 |
| 5.173.2.1490 DFSDM_CHCFG1_CKABEN . . . . .      | 810 |
| 5.173.2.1491 DFSDM_CHCFG1_CKOUTDIV . . . . .    | 810 |
| 5.173.2.1492 DFSDM_CHCFG1_CKOUTSRC . . . . .    | 810 |
| 5.173.2.1493 DFSDM_CHCFG1_DATMPX . . . . .      | 811 |
| 5.173.2.1494 DFSDM_CHCFG1_DATMPX_0 . . . . .    | 811 |
| 5.173.2.1495 DFSDM_CHCFG1_DATMPX_1 . . . . .    | 811 |
| 5.173.2.1496 DFSDM_CHCFG1_DATPACK . . . . .     | 811 |
| 5.173.2.1497 DFSDM_CHCFG1_DATPACK_0 . . . . .   | 811 |
| 5.173.2.1498 DFSDM_CHCFG1_DATPACK_1 . . . . .   | 811 |
| 5.173.2.1499 DFSDM_CHCFG1_DFSDMEN . . . . .     | 811 |
| 5.173.2.1500 DFSDM_CHCFG1_SCDEN . . . . .       | 811 |
| 5.173.2.1501 DFSDM_CHCFG1_SITP . . . . .        | 812 |
| 5.173.2.1502 DFSDM_CHCFG1_SITP_0 . . . . .      | 812 |
| 5.173.2.1503 DFSDM_CHCFG1_SITP_1 . . . . .      | 812 |
| 5.173.2.1504 DFSDM_CHCFG1_SPICKSEL . . . . .    | 812 |
| 5.173.2.1505 DFSDM_CHCFG1_SPICKSEL_0 . . . . .  | 812 |
| 5.173.2.1506 DFSDM_CHCFG1_SPICKSEL_1 . . . . .  | 812 |
| 5.173.2.1507 DFSDM_CHCFG2_DTRBS . . . . .       | 812 |
| 5.173.2.1508 DFSDM_CHCFG2_OFFSET . . . . .      | 812 |
| 5.173.2.1509 DFSDM_CHDATINR_INDATA0 . . . . .   | 813 |
| 5.173.2.1510 DFSDM_CHDATINR_INDATA1 . . . . .   | 813 |
| 5.173.2.1511 DFSDM_CHWDATR_WDATA . . . . .      | 813 |
| 5.173.2.1512 DFSDM_FLTAWCFR_CLRAWHTF . . . . .  | 813 |
| 5.173.2.1513 DFSDM_FLTAWCFR_CLRAWLTF . . . . .  | 813 |
| 5.173.2.1514 DFSDM_FLTAWHTR_AWHT . . . . .      | 813 |
| 5.173.2.1515 DFSDM_FLTAWHTR_BKAWH . . . . .     | 813 |
| 5.173.2.1516 DFSDM_FLTAWLTR_AWLT . . . . .      | 813 |
| 5.173.2.1517 DFSDM_FLTAWLTR_BKAWL . . . . .     | 814 |
| 5.173.2.1518 DFSDM_FLTAWSR_AWHTF . . . . .      | 814 |
| 5.173.2.1519 DFSDM_FLTAWSR_AWLTF . . . . .      | 814 |
| 5.173.2.1520 DFSDM_FLTCNVTIMR_CNVCONT . . . . . | 814 |
| 5.173.2.1521 DFSDM_FLTCR1_AWFSEL . . . . .      | 814 |
| 5.173.2.1522 DFSDM_FLTCR1_DFEN . . . . .        | 814 |
| 5.173.2.1523 DFSDM_FLTCR1_FAST . . . . .        | 814 |
| 5.173.2.1524 DFSDM_FLTCR1_JDMAEN . . . . .      | 814 |
| 5.173.2.1525 DFSDM_FLTCR1_JEXTEN . . . . .      | 815 |
| 5.173.2.1526 DFSDM_FLTCR1_JEXTEN_0 . . . . .    | 815 |
| 5.173.2.1527 DFSDM_FLTCR1_JEXTEN_1 . . . . .    | 815 |
| 5.173.2.1528 DFSDM_FLTCR1_JEXTSEL . . . . .     | 815 |
| 5.173.2.1529 DFSDM_FLTCR1_JEXTSEL_0 . . . . .   | 815 |
| 5.173.2.1530 DFSDM_FLTCR1_JEXTSEL_1 . . . . .   | 815 |

---

|                                               |     |
|-----------------------------------------------|-----|
| 5.173.2.1531 DFSDM_FLTCR1_JEXTSEL_2 . . . . . | 815 |
| 5.173.2.1532 DFSDM_FLTCR1_JSCAN . . . . .     | 815 |
| 5.173.2.1533 DFSDM_FLTCR1_JSWSTART . . . . .  | 816 |
| 5.173.2.1534 DFSDM_FLTCR1_JSYNC . . . . .     | 816 |
| 5.173.2.1535 DFSDM_FLTCR1_RCH . . . . .       | 816 |
| 5.173.2.1536 DFSDM_FLTCR1_RCONT . . . . .     | 816 |
| 5.173.2.1537 DFSDM_FLTCR1_RDMAEN . . . . .    | 816 |
| 5.173.2.1538 DFSDM_FLTCR1_RSWSTART . . . . .  | 816 |
| 5.173.2.1539 DFSDM_FLTCR1_RSYNC . . . . .     | 816 |
| 5.173.2.1540 DFSDM_FLTCR2_AWDCH . . . . .     | 817 |
| 5.173.2.1541 DFSDM_FLTCR2_AWDIE . . . . .     | 817 |
| 5.173.2.1542 DFSDM_FLTCR2_CKABIE . . . . .    | 817 |
| 5.173.2.1543 DFSDM_FLTCR2_EXCH . . . . .      | 817 |
| 5.173.2.1544 DFSDM_FLTCR2_JEOCIE . . . . .    | 817 |
| 5.173.2.1545 DFSDM_FLTCR2_JOVRIE . . . . .    | 817 |
| 5.173.2.1546 DFSDM_FLTCR2_REOCIE . . . . .    | 817 |
| 5.173.2.1547 DFSDM_FLTCR2_ROVRIE . . . . .    | 817 |
| 5.173.2.1548 DFSDM_FLTCR2_SCDIE . . . . .     | 818 |
| 5.173.2.1549 DFSDM_FLTEXMAX_EXMAX . . . . .   | 818 |
| 5.173.2.1550 DFSDM_FLTEXMAX_EXMAXCH . . . . . | 818 |
| 5.173.2.1551 DFSDM_FLTEXMIN_EXMIN . . . . .   | 818 |
| 5.173.2.1552 DFSDM_FLTEXMIN_EXMINCH . . . . . | 818 |
| 5.173.2.1553 DFSDM_FLTFCR_FORD . . . . .      | 818 |
| 5.173.2.1554 DFSDM_FLTFCR_FORD_0 . . . . .    | 818 |
| 5.173.2.1555 DFSDM_FLTFCR_FORD_1 . . . . .    | 818 |
| 5.173.2.1556 DFSDM_FLTFCR_FORD_2 . . . . .    | 819 |
| 5.173.2.1557 DFSDM_FLTFCR_FOSR . . . . .      | 819 |
| 5.173.2.1558 DFSDM_FLTFCR_IOSR . . . . .      | 819 |
| 5.173.2.1559 DFSDM_FLTICR_CLRCKABF . . . . .  | 819 |
| 5.173.2.1560 DFSDM_FLTICR_CLRJOVRF . . . . .  | 819 |
| 5.173.2.1561 DFSDM_FLTICR_CLRRROVRF . . . . . | 819 |
| 5.173.2.1562 DFSDM_FLTICR_CLRSCSDF . . . . .  | 819 |
| 5.173.2.1563 DFSDM_FLTISR_AWDF . . . . .      | 819 |
| 5.173.2.1564 DFSDM_FLTISR_CKABF . . . . .     | 820 |
| 5.173.2.1565 DFSDM_FLTISR_JCIP . . . . .      | 820 |
| 5.173.2.1566 DFSDM_FLTISR_JEOCF . . . . .     | 820 |
| 5.173.2.1567 DFSDM_FLTISR_JOVRF . . . . .     | 820 |
| 5.173.2.1568 DFSDM_FLTISR_RCIP . . . . .      | 820 |
| 5.173.2.1569 DFSDM_FLTISR_REOCF . . . . .     | 820 |
| 5.173.2.1570 DFSDM_FLTISR_ROVRF . . . . .     | 820 |
| 5.173.2.1571 DFSDM_FLTISR_SCDF . . . . .      | 820 |
| 5.173.2.1572 DFSDM_FLTJCHGR_JCHG . . . . .    | 821 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.173.2.1573 DFSDM_FLTJDATAR_JDATA . . . . .    | 821 |
| 5.173.2.1574 DFSDM_FLTJDATAR_JDATACH . . . . .  | 821 |
| 5.173.2.1575 DFSDM_FLTRDATAR_RDATA . . . . .    | 821 |
| 5.173.2.1576 DFSDM_FLTRDATAR_RDATAACH . . . . . | 821 |
| 5.173.2.1577 DFSDM_FLTRDATAR_RPEND . . . . .    | 821 |
| 5.173.2.1578 DMA2D_AMTCR_DT . . . . .           | 821 |
| 5.173.2.1579 DMA2D_AMTCR_EN . . . . .           | 821 |
| 5.173.2.1580 DMA2D_BGCMAR_MA . . . . .          | 822 |
| 5.173.2.1581 DMA2D_BGCOLR_BLUE . . . . .        | 822 |
| 5.173.2.1582 DMA2D_BGCOLR_GREEN . . . . .       | 822 |
| 5.173.2.1583 DMA2D_BGCOLR_RED . . . . .         | 822 |
| 5.173.2.1584 DMA2D_BGMAR_MA . . . . .           | 822 |
| 5.173.2.1585 DMA2D_BGOR_LO . . . . .            | 822 |
| 5.173.2.1586 DMA2D_BGPFCCR_ALPHA . . . . .      | 822 |
| 5.173.2.1587 DMA2D_BGPFCCR_AM . . . . .         | 822 |
| 5.173.2.1588 DMA2D_BGPFCCR_AM_0 . . . . .       | 823 |
| 5.173.2.1589 DMA2D_BGPFCCR_AM_1 . . . . .       | 823 |
| 5.173.2.1590 DMA2D_BGPFCCR_CCM . . . . .        | 823 |
| 5.173.2.1591 DMA2D_BGPFCCR_CM . . . . .         | 823 |
| 5.173.2.1592 DMA2D_BGPFCCR_CM_0 . . . . .       | 823 |
| 5.173.2.1593 DMA2D_BGPFCCR_CM_1 . . . . .       | 823 |
| 5.173.2.1594 DMA2D_BGPFCCR_CM_2 . . . . .       | 823 |
| 5.173.2.1595 DMA2D_BGPFCCR_CS . . . . .         | 823 |
| 5.173.2.1596 DMA2D_BGPFCCR_START . . . . .      | 824 |
| 5.173.2.1597 DMA2D_CR_ABORT . . . . .           | 824 |
| 5.173.2.1598 DMA2D_CR_CAEIE . . . . .           | 824 |
| 5.173.2.1599 DMA2D_CR_CEIE . . . . .            | 824 |
| 5.173.2.1600 DMA2D_CR_CTCIE . . . . .           | 824 |
| 5.173.2.1601 DMA2D_CR_MODE . . . . .            | 824 |
| 5.173.2.1602 DMA2D_CR_START . . . . .           | 824 |
| 5.173.2.1603 DMA2D_CR_SUSP . . . . .            | 824 |
| 5.173.2.1604 DMA2D_CR_TCIE . . . . .            | 825 |
| 5.173.2.1605 DMA2D_CR_TEIE . . . . .            | 825 |
| 5.173.2.1606 DMA2D_CR_TWIE . . . . .            | 825 |
| 5.173.2.1607 DMA2D_FGCMAR_MA . . . . .          | 825 |
| 5.173.2.1608 DMA2D_FGCOLR_BLUE . . . . .        | 825 |
| 5.173.2.1609 DMA2D_FGCOLR_GREEN . . . . .       | 825 |
| 5.173.2.1610 DMA2D_FGCOLR_RED . . . . .         | 825 |
| 5.173.2.1611 DMA2D_FGMAR_MA . . . . .           | 825 |
| 5.173.2.1612 DMA2D_FGOR_LO . . . . .            | 826 |
| 5.173.2.1613 DMA2D_FGPFCCR_ALPHA . . . . .      | 826 |
| 5.173.2.1614 DMA2D_FGPFCCR_AM . . . . .         | 826 |

---

|                                       |     |
|---------------------------------------|-----|
| 5.173.2.1615 DMA2D_FGPFCCR_AM_0       | 826 |
| 5.173.2.1616 DMA2D_FGPFCCR_AM_1       | 826 |
| 5.173.2.1617 DMA2D_FGPFCCR_CCM        | 826 |
| 5.173.2.1618 DMA2D_FGPFCCR_CM         | 826 |
| 5.173.2.1619 DMA2D_FGPFCCR_CM_0       | 826 |
| 5.173.2.1620 DMA2D_FGPFCCR_CM_1       | 827 |
| 5.173.2.1621 DMA2D_FGPFCCR_CM_2       | 827 |
| 5.173.2.1622 DMA2D_FGPFCCR_CM_3 [1/2] | 827 |
| 5.173.2.1623 DMA2D_FGPFCCR_CM_3 [2/2] | 827 |
| 5.173.2.1624 DMA2D_FGPFCCR_CS         | 827 |
| 5.173.2.1625 DMA2D_FGPFCCR_START      | 827 |
| 5.173.2.1626 DMA2D_IFCR_CAEIF         | 827 |
| 5.173.2.1627 DMA2D_IFCR_CCEIF         | 828 |
| 5.173.2.1628 DMA2D_IFCR_CCTCIF        | 828 |
| 5.173.2.1629 DMA2D_IFCR_CTCIF         | 828 |
| 5.173.2.1630 DMA2D_IFCR_CTEIF         | 828 |
| 5.173.2.1631 DMA2D_IFCR_CTWIF         | 828 |
| 5.173.2.1632 DMA2D_IFSR_CCAEIF        | 828 |
| 5.173.2.1633 DMA2D_IFSR_CCEIF         | 828 |
| 5.173.2.1634 DMA2D_IFSR_CCTCIF        | 829 |
| 5.173.2.1635 DMA2D_IFSR_CTCIF         | 829 |
| 5.173.2.1636 DMA2D_IFSR_CTEIF         | 829 |
| 5.173.2.1637 DMA2D_IFSR_CTWIF         | 829 |
| 5.173.2.1638 DMA2D_ISR_CAEIF          | 829 |
| 5.173.2.1639 DMA2D_ISR_CEIF           | 829 |
| 5.173.2.1640 DMA2D_ISR_CTCIF          | 829 |
| 5.173.2.1641 DMA2D_ISR_TCIF           | 830 |
| 5.173.2.1642 DMA2D_ISR_TEIF           | 830 |
| 5.173.2.1643 DMA2D_ISR_TWIF           | 830 |
| 5.173.2.1644 DMA2D_LWR_LW             | 830 |
| 5.173.2.1645 DMA2D_NLR_NL             | 830 |
| 5.173.2.1646 DMA2D_NLR_PL             | 830 |
| 5.173.2.1647 DMA2D_OCOLR_ALPHA_1      | 830 |
| 5.173.2.1648 DMA2D_OCOLR_ALPHA_3      | 830 |
| 5.173.2.1649 DMA2D_OCOLR_ALPHA_4      | 831 |
| 5.173.2.1650 DMA2D_OCOLR_BLUE_1       | 831 |
| 5.173.2.1651 DMA2D_OCOLR_BLUE_2       | 831 |
| 5.173.2.1652 DMA2D_OCOLR_BLUE_3       | 831 |
| 5.173.2.1653 DMA2D_OCOLR_BLUE_4       | 831 |
| 5.173.2.1654 DMA2D_OCOLR_GREEN_1      | 831 |
| 5.173.2.1655 DMA2D_OCOLR_GREEN_2      | 831 |
| 5.173.2.1656 DMA2D_OCOLR_GREEN_3      | 832 |

---

|                                            |     |
|--------------------------------------------|-----|
| 5.173.2.1657 DMA2D_OCOLR_GREEN_4 . . . . . | 832 |
| 5.173.2.1658 DMA2D_OCOLR_RED_1 . . . . .   | 832 |
| 5.173.2.1659 DMA2D_OCOLR_RED_2 . . . . .   | 832 |
| 5.173.2.1660 DMA2D_OCOLR_RED_3 . . . . .   | 832 |
| 5.173.2.1661 DMA2D_OCOLR_RED_4 . . . . .   | 832 |
| 5.173.2.1662 DMA2D_OMAR_MA . . . . .       | 832 |
| 5.173.2.1663 DMA2D_OOR_LO . . . . .        | 833 |
| 5.173.2.1664 DMA2D_OPFCCR_CM . . . . .     | 833 |
| 5.173.2.1665 DMA2D_OPFCCR_CM_0 . . . . .   | 833 |
| 5.173.2.1666 DMA2D_OPFCCR_CM_1 . . . . .   | 833 |
| 5.173.2.1667 DMA2D_OPFCCR_CM_2 . . . . .   | 833 |
| 5.173.2.1668 ETH_MACCR_BL . . . . .        | 833 |
| 5.173.2.1669 EXTI_EMR_MR0 . . . . .        | 833 |
| 5.173.2.1670 EXTI_EMR_MR1 . . . . .        | 834 |
| 5.173.2.1671 EXTI_EMR_MR10 . . . . .       | 834 |
| 5.173.2.1672 EXTI_EMR_MR11 . . . . .       | 834 |
| 5.173.2.1673 EXTI_EMR_MR12 . . . . .       | 834 |
| 5.173.2.1674 EXTI_EMR_MR13 . . . . .       | 834 |
| 5.173.2.1675 EXTI_EMR_MR14 . . . . .       | 834 |
| 5.173.2.1676 EXTI_EMR_MR15 . . . . .       | 834 |
| 5.173.2.1677 EXTI_EMR_MR16 . . . . .       | 834 |
| 5.173.2.1678 EXTI_EMR_MR17 . . . . .       | 835 |
| 5.173.2.1679 EXTI_EMR_MR18 . . . . .       | 835 |
| 5.173.2.1680 EXTI_EMR_MR19 . . . . .       | 835 |
| 5.173.2.1681 EXTI_EMR_MR2 . . . . .        | 835 |
| 5.173.2.1682 EXTI_EMR_MR23 . . . . .       | 835 |
| 5.173.2.1683 EXTI_EMR_MR3 . . . . .        | 835 |
| 5.173.2.1684 EXTI_EMR_MR4 . . . . .        | 835 |
| 5.173.2.1685 EXTI_EMR_MR5 . . . . .        | 835 |
| 5.173.2.1686 EXTI_EMR_MR6 . . . . .        | 836 |
| 5.173.2.1687 EXTI_EMR_MR7 . . . . .        | 836 |
| 5.173.2.1688 EXTI_EMR_MR8 . . . . .        | 836 |
| 5.173.2.1689 EXTI_EMR_MR9 . . . . .        | 836 |
| 5.173.2.1690 EXTI_FTSR_TR0 . . . . .       | 836 |
| 5.173.2.1691 EXTI_FTSR_TR1 . . . . .       | 836 |
| 5.173.2.1692 EXTI_FTSR_TR10 . . . . .      | 836 |
| 5.173.2.1693 EXTI_FTSR_TR11 . . . . .      | 836 |
| 5.173.2.1694 EXTI_FTSR_TR12 . . . . .      | 837 |
| 5.173.2.1695 EXTI_FTSR_TR13 . . . . .      | 837 |
| 5.173.2.1696 EXTI_FTSR_TR14 . . . . .      | 837 |
| 5.173.2.1697 EXTI_FTSR_TR15 . . . . .      | 837 |
| 5.173.2.1698 EXTI_FTSR_TR16 . . . . .      | 837 |

|                                       |     |
|---------------------------------------|-----|
| 5.173.2.1699 EXTI_FTSR_TR17 . . . . . | 837 |
| 5.173.2.1700 EXTI_FTSR_TR18 . . . . . | 837 |
| 5.173.2.1701 EXTI_FTSR_TR19 . . . . . | 837 |
| 5.173.2.1702 EXTI_FTSR_TR2 . . . . .  | 838 |
| 5.173.2.1703 EXTI_FTSR_TR23 . . . . . | 838 |
| 5.173.2.1704 EXTI_FTSR_TR3 . . . . .  | 838 |
| 5.173.2.1705 EXTI_FTSR_TR4 . . . . .  | 838 |
| 5.173.2.1706 EXTI_FTSR_TR5 . . . . .  | 838 |
| 5.173.2.1707 EXTI_FTSR_TR6 . . . . .  | 838 |
| 5.173.2.1708 EXTI_FTSR_TR7 . . . . .  | 838 |
| 5.173.2.1709 EXTI_FTSR_TR8 . . . . .  | 838 |
| 5.173.2.1710 EXTI_FTSR_TR9 . . . . .  | 839 |
| 5.173.2.1711 EXTI_IMR_MR0 . . . . .   | 839 |
| 5.173.2.1712 EXTI_IMR_MR1 . . . . .   | 839 |
| 5.173.2.1713 EXTI_IMR_MR10 . . . . .  | 839 |
| 5.173.2.1714 EXTI_IMR_MR11 . . . . .  | 839 |
| 5.173.2.1715 EXTI_IMR_MR12 . . . . .  | 839 |
| 5.173.2.1716 EXTI_IMR_MR13 . . . . .  | 839 |
| 5.173.2.1717 EXTI_IMR_MR14 . . . . .  | 839 |
| 5.173.2.1718 EXTI_IMR_MR15 . . . . .  | 840 |
| 5.173.2.1719 EXTI_IMR_MR16 . . . . .  | 840 |
| 5.173.2.1720 EXTI_IMR_MR17 . . . . .  | 840 |
| 5.173.2.1721 EXTI_IMR_MR18 . . . . .  | 840 |
| 5.173.2.1722 EXTI_IMR_MR19 . . . . .  | 840 |
| 5.173.2.1723 EXTI_IMR_MR2 . . . . .   | 840 |
| 5.173.2.1724 EXTI_IMR_MR23 . . . . .  | 840 |
| 5.173.2.1725 EXTI_IMR_MR3 . . . . .   | 840 |
| 5.173.2.1726 EXTI_IMR_MR4 . . . . .   | 841 |
| 5.173.2.1727 EXTI_IMR_MR5 . . . . .   | 841 |
| 5.173.2.1728 EXTI_IMR_MR6 . . . . .   | 841 |
| 5.173.2.1729 EXTI_IMR_MR7 . . . . .   | 841 |
| 5.173.2.1730 EXTI_IMR_MR8 . . . . .   | 841 |
| 5.173.2.1731 EXTI_IMR_MR9 . . . . .   | 841 |
| 5.173.2.1732 EXTI_PR_PR0 . . . . .    | 841 |
| 5.173.2.1733 EXTI_PR_PR1 . . . . .    | 841 |
| 5.173.2.1734 EXTI_PR_PR10 . . . . .   | 842 |
| 5.173.2.1735 EXTI_PR_PR11 . . . . .   | 842 |
| 5.173.2.1736 EXTI_PR_PR12 . . . . .   | 842 |
| 5.173.2.1737 EXTI_PR_PR13 . . . . .   | 842 |
| 5.173.2.1738 EXTI_PR_PR14 . . . . .   | 842 |
| 5.173.2.1739 EXTI_PR_PR15 . . . . .   | 842 |
| 5.173.2.1740 EXTI_PR_PR16 . . . . .   | 842 |

---

|                                           |     |
|-------------------------------------------|-----|
| 5.173.2.1741 EXTI_PR_PR17 . . . . .       | 842 |
| 5.173.2.1742 EXTI_PR_PR18 . . . . .       | 843 |
| 5.173.2.1743 EXTI_PR_PR19 . . . . .       | 843 |
| 5.173.2.1744 EXTI_PR_PR2 . . . . .        | 843 |
| 5.173.2.1745 EXTI_PR_PR23 . . . . .       | 843 |
| 5.173.2.1746 EXTI_PR_PR3 . . . . .        | 843 |
| 5.173.2.1747 EXTI_PR_PR4 . . . . .        | 843 |
| 5.173.2.1748 EXTI_PR_PR5 . . . . .        | 843 |
| 5.173.2.1749 EXTI_PR_PR6 . . . . .        | 843 |
| 5.173.2.1750 EXTI_PR_PR7 . . . . .        | 844 |
| 5.173.2.1751 EXTI_PR_PR8 . . . . .        | 844 |
| 5.173.2.1752 EXTI_PR_PR9 . . . . .        | 844 |
| 5.173.2.1753 EXTI_RTSR_TR0 . . . . .      | 844 |
| 5.173.2.1754 EXTI_RTSR_TR1 . . . . .      | 844 |
| 5.173.2.1755 EXTI_RTSR_TR10 . . . . .     | 844 |
| 5.173.2.1756 EXTI_RTSR_TR11 . . . . .     | 844 |
| 5.173.2.1757 EXTI_RTSR_TR12 . . . . .     | 844 |
| 5.173.2.1758 EXTI_RTSR_TR13 . . . . .     | 845 |
| 5.173.2.1759 EXTI_RTSR_TR14 . . . . .     | 845 |
| 5.173.2.1760 EXTI_RTSR_TR15 . . . . .     | 845 |
| 5.173.2.1761 EXTI_RTSR_TR16 . . . . .     | 845 |
| 5.173.2.1762 EXTI_RTSR_TR17 . . . . .     | 845 |
| 5.173.2.1763 EXTI_RTSR_TR18 . . . . .     | 845 |
| 5.173.2.1764 EXTI_RTSR_TR19 . . . . .     | 845 |
| 5.173.2.1765 EXTI_RTSR_TR2 . . . . .      | 845 |
| 5.173.2.1766 EXTI_RTSR_TR23 . . . . .     | 846 |
| 5.173.2.1767 EXTI_RTSR_TR3 . . . . .      | 846 |
| 5.173.2.1768 EXTI_RTSR_TR4 . . . . .      | 846 |
| 5.173.2.1769 EXTI_RTSR_TR5 . . . . .      | 846 |
| 5.173.2.1770 EXTI_RTSR_TR6 . . . . .      | 846 |
| 5.173.2.1771 EXTI_RTSR_TR7 . . . . .      | 846 |
| 5.173.2.1772 EXTI_RTSR_TR8 . . . . .      | 846 |
| 5.173.2.1773 EXTI_RTSR_TR9 . . . . .      | 846 |
| 5.173.2.1774 EXTI_SWIER_SWIER0 . . . . .  | 847 |
| 5.173.2.1775 EXTI_SWIER_SWIER1 . . . . .  | 847 |
| 5.173.2.1776 EXTI_SWIER_SWIER10 . . . . . | 847 |
| 5.173.2.1777 EXTI_SWIER_SWIER11 . . . . . | 847 |
| 5.173.2.1778 EXTI_SWIER_SWIER12 . . . . . | 847 |
| 5.173.2.1779 EXTI_SWIER_SWIER13 . . . . . | 847 |
| 5.173.2.1780 EXTI_SWIER_SWIER14 . . . . . | 847 |
| 5.173.2.1781 EXTI_SWIER_SWIER15 . . . . . | 847 |
| 5.173.2.1782 EXTI_SWIER_SWIER16 . . . . . | 848 |

---

|                                           |     |
|-------------------------------------------|-----|
| 5.173.2.1783 EXTI_SWIER_SWIER17 . . . . . | 848 |
| 5.173.2.1784 EXTI_SWIER_SWIER18 . . . . . | 848 |
| 5.173.2.1785 EXTI_SWIER_SWIER19 . . . . . | 848 |
| 5.173.2.1786 EXTI_SWIER_SWIER2 . . . . .  | 848 |
| 5.173.2.1787 EXTI_SWIER_SWIER23 . . . . . | 848 |
| 5.173.2.1788 EXTI_SWIER_SWIER3 . . . . .  | 848 |
| 5.173.2.1789 EXTI_SWIER_SWIER4 . . . . .  | 848 |
| 5.173.2.1790 EXTI_SWIER_SWIER5 . . . . .  | 849 |
| 5.173.2.1791 EXTI_SWIER_SWIER6 . . . . .  | 849 |
| 5.173.2.1792 EXTI_SWIER_SWIER7 . . . . .  | 849 |
| 5.173.2.1793 EXTI_SWIER_SWIER8 . . . . .  | 849 |
| 5.173.2.1794 EXTI_SWIER_SWIER9 . . . . .  | 849 |
| 5.173.2.1795 I2C_CCR_CCR . . . . .        | 849 |
| 5.173.2.1796 I2C_CCR_DUTY . . . . .       | 849 |
| 5.173.2.1797 I2C_CCR_FS . . . . .         | 850 |
| 5.173.2.1798 I2C_CR1_ACK . . . . .        | 850 |
| 5.173.2.1799 I2C_CR1_ALERT . . . . .      | 850 |
| 5.173.2.1800 I2C_CR1_ENARP . . . . .      | 850 |
| 5.173.2.1801 I2C_CR1_ENGC . . . . .       | 850 |
| 5.173.2.1802 I2C_CR1_ENPEC . . . . .      | 850 |
| 5.173.2.1803 I2C_CR1_NOSTRETCH . . . . .  | 850 |
| 5.173.2.1804 I2C_CR1_PE . . . . .         | 851 |
| 5.173.2.1805 I2C_CR1_PEC . . . . .        | 851 |
| 5.173.2.1806 I2C_CR1_POS . . . . .        | 851 |
| 5.173.2.1807 I2C_CR1_SMBTYPE . . . . .    | 851 |
| 5.173.2.1808 I2C_CR1_SMBUS . . . . .      | 851 |
| 5.173.2.1809 I2C_CR1_START . . . . .      | 851 |
| 5.173.2.1810 I2C_CR1_STOP . . . . .       | 851 |
| 5.173.2.1811 I2C_CR1_SWRST . . . . .      | 852 |
| 5.173.2.1812 I2C_CR2_DMAEN . . . . .      | 852 |
| 5.173.2.1813 I2C_CR2_FREQ . . . . .       | 852 |
| 5.173.2.1814 I2C_CR2_FREQ_0 . . . . .     | 852 |
| 5.173.2.1815 I2C_CR2_FREQ_1 . . . . .     | 852 |
| 5.173.2.1816 I2C_CR2_FREQ_2 . . . . .     | 852 |
| 5.173.2.1817 I2C_CR2_FREQ_3 . . . . .     | 852 |
| 5.173.2.1818 I2C_CR2_FREQ_4 . . . . .     | 853 |
| 5.173.2.1819 I2C_CR2_FREQ_5 . . . . .     | 853 |
| 5.173.2.1820 I2C_CR2_ITBUFEN . . . . .    | 853 |
| 5.173.2.1821 I2C_CR2_ITERREN . . . . .    | 853 |
| 5.173.2.1822 I2C_CR2 ITEVTEN . . . . .    | 853 |
| 5.173.2.1823 I2C_CR2_LAST . . . . .       | 853 |
| 5.173.2.1824 I2C_DR_DR . . . . .          | 853 |

---

|                                           |     |
|-------------------------------------------|-----|
| 5.173.2.1825 I2C_FLTR_ANOFF . . . . .     | 854 |
| 5.173.2.1826 I2C_FLTR_DNF . . . . .       | 854 |
| 5.173.2.1827 I2C_OAR1_ADD0 . . . . .      | 854 |
| 5.173.2.1828 I2C_OAR1_ADD1 . . . . .      | 854 |
| 5.173.2.1829 I2C_OAR1_ADD1_7 . . . . .    | 854 |
| 5.173.2.1830 I2C_OAR1_ADD2 . . . . .      | 854 |
| 5.173.2.1831 I2C_OAR1_ADD3 . . . . .      | 854 |
| 5.173.2.1832 I2C_OAR1_ADD4 . . . . .      | 854 |
| 5.173.2.1833 I2C_OAR1_ADD5 . . . . .      | 855 |
| 5.173.2.1834 I2C_OAR1_ADD6 . . . . .      | 855 |
| 5.173.2.1835 I2C_OAR1_ADD7 . . . . .      | 855 |
| 5.173.2.1836 I2C_OAR1_ADD8 . . . . .      | 855 |
| 5.173.2.1837 I2C_OAR1_ADD8_9 . . . . .    | 855 |
| 5.173.2.1838 I2C_OAR1_ADD9 . . . . .      | 855 |
| 5.173.2.1839 I2C_OAR1_ADDMODE . . . . .   | 855 |
| 5.173.2.1840 I2C_OAR2_ADD2 . . . . .      | 855 |
| 5.173.2.1841 I2C_OAR2_ENDUAL . . . . .    | 856 |
| 5.173.2.1842 I2C_SR1_ADD10 . . . . .      | 856 |
| 5.173.2.1843 I2C_SR1_ADDR . . . . .       | 856 |
| 5.173.2.1844 I2C_SR1_AF . . . . .         | 856 |
| 5.173.2.1845 I2C_SR1_ARLO . . . . .       | 856 |
| 5.173.2.1846 I2C_SR1_BERR . . . . .       | 856 |
| 5.173.2.1847 I2C_SR1_BTF . . . . .        | 856 |
| 5.173.2.1848 I2C_SR1_OVR . . . . .        | 857 |
| 5.173.2.1849 I2C_SR1_PECERR . . . . .     | 857 |
| 5.173.2.1850 I2C_SR1_RXNE . . . . .       | 857 |
| 5.173.2.1851 I2C_SR1_SB . . . . .         | 857 |
| 5.173.2.1852 I2C_SR1_SMBALERT . . . . .   | 857 |
| 5.173.2.1853 I2C_SR1_STOPF . . . . .      | 857 |
| 5.173.2.1854 I2C_SR1_TIMEOUT . . . . .    | 857 |
| 5.173.2.1855 I2C_SR1_TXE . . . . .        | 858 |
| 5.173.2.1856 I2C_SR2_BUSY . . . . .       | 858 |
| 5.173.2.1857 I2C_SR2_DUALF . . . . .      | 858 |
| 5.173.2.1858 I2C_SR2_GENCALL . . . . .    | 858 |
| 5.173.2.1859 I2C_SR2_MSL . . . . .        | 858 |
| 5.173.2.1860 I2C_SR2_PEC . . . . .        | 858 |
| 5.173.2.1861 I2C_SR2_SMBDEFAULT . . . . . | 858 |
| 5.173.2.1862 I2C_SR2_SMBHOST . . . . .    | 859 |
| 5.173.2.1863 I2C_SR2_TRA . . . . .        | 859 |
| 5.173.2.1864 I2C_TRISE_TRISE . . . . .    | 859 |
| 5.173.2.1865 IWDG_KR_KEY . . . . .        | 859 |
| 5.173.2.1866 IWDG_PR_PR . . . . .         | 859 |

---

|                                          |     |
|------------------------------------------|-----|
| 5.173.2.1867 IWDG_PR_PR_0 . . . . .      | 859 |
| 5.173.2.1868 IWDG_PR_PR_1 . . . . .      | 859 |
| 5.173.2.1869 IWDG_PR_PR_2 . . . . .      | 860 |
| 5.173.2.1870 IWDG_RLR_RL . . . . .       | 860 |
| 5.173.2.1871 IWDG_SR_PVU . . . . .       | 860 |
| 5.173.2.1872 IWDG_SR_RVU . . . . .       | 860 |
| 5.173.2.1873 LTDC_AWCR_AAH . . . . .     | 860 |
| 5.173.2.1874 LTDC_AWCR_AAW . . . . .     | 860 |
| 5.173.2.1875 LTDC_BCCR_BCBLUE . . . . .  | 860 |
| 5.173.2.1876 LTDC_BCCR_BCGREEN . . . . . | 861 |
| 5.173.2.1877 LTDC_BCCR_BCRED . . . . .   | 861 |
| 5.173.2.1878 LTDC_BPCR_AHBP . . . . .    | 861 |
| 5.173.2.1879 LTDC_BPCR_AVBP . . . . .    | 861 |
| 5.173.2.1880 LTDC_CDSR_HDES . . . . .    | 861 |
| 5.173.2.1881 LTDC_CDSR_HSYNCS . . . . .  | 861 |
| 5.173.2.1882 LTDC_CDSR_VDES . . . . .    | 861 |
| 5.173.2.1883 LTDC_CDSR_VSYNCS . . . . .  | 861 |
| 5.173.2.1884 LTDC_CPSR_CXPOS . . . . .   | 862 |
| 5.173.2.1885 LTDC_CPSR_CYPOS . . . . .   | 862 |
| 5.173.2.1886 LTDC_GCR_DBW . . . . .      | 862 |
| 5.173.2.1887 LTDC_GCR_DEN . . . . .      | 862 |
| 5.173.2.1888 LTDC_GCR_DEPOL . . . . .    | 862 |
| 5.173.2.1889 LTDC_GCR_DGW . . . . .      | 862 |
| 5.173.2.1890 LTDC_GCR_DRW . . . . .      | 862 |
| 5.173.2.1891 LTDC_GCR_HSPOL . . . . .    | 862 |
| 5.173.2.1892 LTDC_GCR_LTDCEN . . . . .   | 863 |
| 5.173.2.1893 LTDC_GCR_PCPOL . . . . .    | 863 |
| 5.173.2.1894 LTDC_GCR_VSPOL . . . . .    | 863 |
| 5.173.2.1895 LTDC_ICR_CFUIF . . . . .    | 863 |
| 5.173.2.1896 LTDC_ICR_CLIF . . . . .     | 863 |
| 5.173.2.1897 LTDC_ICR_CRRIF . . . . .    | 863 |
| 5.173.2.1898 LTDC_ICR_CTERRIF . . . . .  | 863 |
| 5.173.2.1899 LTDC_IER_FUIE . . . . .     | 863 |
| 5.173.2.1900 LTDC_IER_LIE . . . . .      | 864 |
| 5.173.2.1901 LTDC_IER_RRIE . . . . .     | 864 |
| 5.173.2.1902 LTDC_IER_TERRIE . . . . .   | 864 |
| 5.173.2.1903 LTDC_ISR_FUIF . . . . .     | 864 |
| 5.173.2.1904 LTDC_ISR_LIF . . . . .      | 864 |
| 5.173.2.1905 LTDC_ISR_RRIF . . . . .     | 864 |
| 5.173.2.1906 LTDC_ISR_TERRIF . . . . .   | 864 |
| 5.173.2.1907 LTDC_LIPCR_LIPOS . . . . .  | 864 |
| 5.173.2.1908 LTDC_LxBFCR_BF1 . . . . .   | 865 |

---

|                                              |     |
|----------------------------------------------|-----|
| 5.173.2.1909 LTDC_LxBFCR_BF2 . . . . .       | 865 |
| 5.173.2.1910 LTDC_LxCACR_CONSTA . . . . .    | 865 |
| 5.173.2.1911 LTDC_LxCFBAR_CFBADD . . . . .   | 865 |
| 5.173.2.1912 LTDC_LxCFBLNR_CFBLNBR . . . . . | 865 |
| 5.173.2.1913 LTDC_LxCFBLR_CFBLL . . . . .    | 865 |
| 5.173.2.1914 LTDC_LxCFBLR_CFBP . . . . .     | 865 |
| 5.173.2.1915 LTDC_LxCKCR_CKBLUE . . . . .    | 865 |
| 5.173.2.1916 LTDC_LxCKCR_CKGREEN . . . . .   | 866 |
| 5.173.2.1917 LTDC_LxCKCR_CKRED . . . . .     | 866 |
| 5.173.2.1918 LTDC_LxCLUTWR_BLUE . . . . .    | 866 |
| 5.173.2.1919 LTDC_LxCLUTWR_CLUTADD . . . . . | 866 |
| 5.173.2.1920 LTDC_LxCLUTWR_GREEN . . . . .   | 866 |
| 5.173.2.1921 LTDC_LxCLUTWR_RED . . . . .     | 866 |
| 5.173.2.1922 LTDC_LxCR_CLUTEN . . . . .      | 866 |
| 5.173.2.1923 LTDC_LxCR_COLKEN . . . . .      | 866 |
| 5.173.2.1924 LTDC_LxCR_LEN . . . . .         | 867 |
| 5.173.2.1925 LTDC_LxDCCR_DCALPHA . . . . .   | 867 |
| 5.173.2.1926 LTDC_LxDCCR_DCBLUE . . . . .    | 867 |
| 5.173.2.1927 LTDC_LxDCCR_DCGREEN . . . . .   | 867 |
| 5.173.2.1928 LTDC_LxDCCR_DCRED . . . . .     | 867 |
| 5.173.2.1929 LTDC_LxPFCR_PF . . . . .        | 867 |
| 5.173.2.1930 LTDC_LxWHPCR_WHSPPOS . . . . .  | 867 |
| 5.173.2.1931 LTDC_LxWHPCR_WHSTPOS . . . . .  | 867 |
| 5.173.2.1932 LTDC_LxWVPCR_WVSPPOS . . . . .  | 868 |
| 5.173.2.1933 LTDC_LxWVPCR_WVSTPOS . . . . .  | 868 |
| 5.173.2.1934 LTDC_SRCR_IMR . . . . .         | 868 |
| 5.173.2.1935 LTDC_SRCR_VBR . . . . .         | 868 |
| 5.173.2.1936 LTDC_SSCR_HSW . . . . .         | 868 |
| 5.173.2.1937 LTDC_SSCR_VSH . . . . .         | 868 |
| 5.173.2.1938 LTDC_TWCR_TOTALH . . . . .      | 868 |
| 5.173.2.1939 LTDC_TWCR_TOTALW . . . . .      | 868 |
| 5.173.2.1940 PWR_CR_ADCDC1 . . . . .         | 869 |
| 5.173.2.1941 PWR_CR_CSBF . . . . .           | 869 |
| 5.173.2.1942 PWR_CR_CWUF . . . . .           | 869 |
| 5.173.2.1943 PWR_CR_DBP . . . . .            | 869 |
| 5.173.2.1944 PWR_CR_FISSR . . . . .          | 869 |
| 5.173.2.1945 PWR_CR_FMSSR . . . . .          | 869 |
| 5.173.2.1946 PWR_CR_FPDS . . . . .           | 869 |
| 5.173.2.1947 PWR_CR_LPDS . . . . .           | 870 |
| 5.173.2.1948 PWR_CR_LPLVDS . . . . .         | 870 |
| 5.173.2.1949 PWR_CR_LPUDS . . . . .          | 870 |
| 5.173.2.1950 PWR_CR_MRLVDS . . . . .         | 870 |

---

---

|                                             |     |
|---------------------------------------------|-----|
| 5.173.2.1951 PWR_CR_MRUDS . . . . .         | 870 |
| 5.173.2.1952 PWR_CR_ODEN . . . . .          | 870 |
| 5.173.2.1953 PWR_CR_ODSWEN . . . . .        | 870 |
| 5.173.2.1954 PWR_CR_PDDS . . . . .          | 871 |
| 5.173.2.1955 PWR_CR_PLS . . . . .           | 871 |
| 5.173.2.1956 PWR_CR_PLS_0 . . . . .         | 871 |
| 5.173.2.1957 PWR_CR_PLS_1 . . . . .         | 871 |
| 5.173.2.1958 PWR_CR_PLS_2 . . . . .         | 871 |
| 5.173.2.1959 PWR_CR_PLS_LEV0 . . . . .      | 871 |
| 5.173.2.1960 PWR_CR_PLS_LEV1 . . . . .      | 871 |
| 5.173.2.1961 PWR_CR_PLS_LEV2 . . . . .      | 872 |
| 5.173.2.1962 PWR_CR_PLS_LEV3 . . . . .      | 872 |
| 5.173.2.1963 PWR_CR_PLS_LEV4 . . . . .      | 872 |
| 5.173.2.1964 PWR_CR_PLS_LEV5 . . . . .      | 872 |
| 5.173.2.1965 PWR_CR_PLS_LEV6 . . . . .      | 872 |
| 5.173.2.1966 PWR_CR_PLS_LEV7 . . . . .      | 872 |
| 5.173.2.1967 PWR_CR_PVDE . . . . .          | 872 |
| 5.173.2.1968 PWR_CR_UDEN . . . . .          | 873 |
| 5.173.2.1969 PWR_CR_UDEN_0 . . . . .        | 873 |
| 5.173.2.1970 PWR_CR_UDEN_1 . . . . .        | 873 |
| 5.173.2.1971 PWR_CR_VOS . . . . .           | 873 |
| 5.173.2.1972 PWR_CR_VOS_0 . . . . .         | 873 |
| 5.173.2.1973 PWR_CR_VOS_1 . . . . .         | 873 |
| 5.173.2.1974 PWR_CSR_BRE . . . . .          | 873 |
| 5.173.2.1975 PWR_CSR_BRR . . . . .          | 874 |
| 5.173.2.1976 PWR_CSR_EWUP . . . . .         | 874 |
| 5.173.2.1977 PWR_CSR_ODRDY . . . . .        | 874 |
| 5.173.2.1978 PWR_CSR_ODSWRDY . . . . .      | 874 |
| 5.173.2.1979 PWR_CSR_PVDO . . . . .         | 874 |
| 5.173.2.1980 PWR_CSR_SBF . . . . .          | 874 |
| 5.173.2.1981 PWR_CSR_UDSWRDY . . . . .      | 874 |
| 5.173.2.1982 PWR_CSR_VOSRDY . . . . .       | 875 |
| 5.173.2.1983 PWR_CSR_WUF . . . . .          | 875 |
| 5.173.2.1984 PWR_CSR_WUPP . . . . .         | 875 |
| 5.173.2.1985 RCC_CFGR_HPRE . . . . .        | 875 |
| 5.173.2.1986 RCC_CFGR_HPRE_0 . . . . .      | 875 |
| 5.173.2.1987 RCC_CFGR_HPRE_1 . . . . .      | 875 |
| 5.173.2.1988 RCC_CFGR_HPRE_2 . . . . .      | 875 |
| 5.173.2.1989 RCC_CFGR_HPRE_3 . . . . .      | 876 |
| 5.173.2.1990 RCC_CFGR_HPRE_DIV1 . . . . .   | 876 |
| 5.173.2.1991 RCC_CFGR_HPRE_DIV128 . . . . . | 876 |
| 5.173.2.1992 RCC_CFGR_HPRE_DIV16 . . . . .  | 876 |

---

|                                             |     |
|---------------------------------------------|-----|
| 5.173.2.1993 RCC_CFGR_HPRE_DIV2 . . . . .   | 876 |
| 5.173.2.1994 RCC_CFGR_HPRE_DIV256 . . . . . | 876 |
| 5.173.2.1995 RCC_CFGR_HPRE_DIV4 . . . . .   | 876 |
| 5.173.2.1996 RCC_CFGR_HPRE_DIV512 . . . . . | 876 |
| 5.173.2.1997 RCC_CFGR_HPRE_DIV64 . . . . .  | 877 |
| 5.173.2.1998 RCC_CFGR_HPRE_DIV8 . . . . .   | 877 |
| 5.173.2.1999 RCC_CFGR_PPRE1 . . . . .       | 877 |
| 5.173.2.2000 RCC_CFGR_PPRE1_0 . . . . .     | 877 |
| 5.173.2.2001 RCC_CFGR_PPRE1_1 . . . . .     | 877 |
| 5.173.2.2002 RCC_CFGR_PPRE1_2 . . . . .     | 877 |
| 5.173.2.2003 RCC_CFGR_PPRE1_DIV1 . . . . .  | 877 |
| 5.173.2.2004 RCC_CFGR_PPRE1_DIV16 . . . . . | 877 |
| 5.173.2.2005 RCC_CFGR_PPRE1_DIV2 . . . . .  | 878 |
| 5.173.2.2006 RCC_CFGR_PPRE1_DIV4 . . . . .  | 878 |
| 5.173.2.2007 RCC_CFGR_PPRE1_DIV8 . . . . .  | 878 |
| 5.173.2.2008 RCC_CFGR_PPRE2 . . . . .       | 878 |
| 5.173.2.2009 RCC_CFGR_PPRE2_0 . . . . .     | 878 |
| 5.173.2.2010 RCC_CFGR_PPRE2_1 . . . . .     | 878 |
| 5.173.2.2011 RCC_CFGR_PPRE2_2 . . . . .     | 878 |
| 5.173.2.2012 RCC_CFGR_PPRE2_DIV1 . . . . .  | 878 |
| 5.173.2.2013 RCC_CFGR_PPRE2_DIV16 . . . . . | 879 |
| 5.173.2.2014 RCC_CFGR_PPRE2_DIV2 . . . . .  | 879 |
| 5.173.2.2015 RCC_CFGR_PPRE2_DIV4 . . . . .  | 879 |
| 5.173.2.2016 RCC_CFGR_PPRE2_DIV8 . . . . .  | 879 |
| 5.173.2.2017 RCC_CFGR_RTCPRE_4 . . . . .    | 879 |
| 5.173.2.2018 RCC_CFGR_SW . . . . .          | 879 |
| 5.173.2.2019 RCC_CFGR_SW_0 . . . . .        | 879 |
| 5.173.2.2020 RCC_CFGR_SW_1 . . . . .        | 879 |
| 5.173.2.2021 RCC_CFGR_SW_HSE . . . . .      | 880 |
| 5.173.2.2022 RCC_CFGR_SW_HSI . . . . .      | 880 |
| 5.173.2.2023 RCC_CFGR_SW_PLL . . . . .      | 880 |
| 5.173.2.2024 RCC_CFGR_SWS . . . . .         | 880 |
| 5.173.2.2025 RCC_CFGR_SWS_0 . . . . .       | 880 |
| 5.173.2.2026 RCC_CFGR_SWS_1 . . . . .       | 880 |
| 5.173.2.2027 RCC_CFGR_SWS_HSE . . . . .     | 880 |
| 5.173.2.2028 RCC_CFGR_SWS_HSI . . . . .     | 880 |
| 5.173.2.2029 RCC_CFGR_SWS_PLL . . . . .     | 881 |
| 5.173.2.2030 RCC_CR_HSICAL_0 . . . . .      | 881 |
| 5.173.2.2031 RCC_CR_HSICAL_1 . . . . .      | 881 |
| 5.173.2.2032 RCC_CR_HSICAL_2 . . . . .      | 881 |
| 5.173.2.2033 RCC_CR_HSICAL_3 . . . . .      | 881 |
| 5.173.2.2034 RCC_CR_HSICAL_4 . . . . .      | 881 |

---

---

|                                            |     |
|--------------------------------------------|-----|
| 5.173.2.2035 RCC_CR_HSICAL_5 . . . . .     | 881 |
| 5.173.2.2036 RCC_CR_HSICAL_6 . . . . .     | 882 |
| 5.173.2.2037 RCC_CR_HSICAL_7 . . . . .     | 882 |
| 5.173.2.2038 RCC_CR_HSITRIM_0 . . . . .    | 882 |
| 5.173.2.2039 RCC_CR_HSITRIM_1 . . . . .    | 882 |
| 5.173.2.2040 RCC_CR_HSITRIM_2 . . . . .    | 882 |
| 5.173.2.2041 RCC_CR_HSITRIM_3 . . . . .    | 882 |
| 5.173.2.2042 RCC_CR_HSITRIM_4 . . . . .    | 882 |
| 5.173.2.2043 SAI_GCR_SYNCIN . . . . .      | 882 |
| 5.173.2.2044 SAI_GCR_SYNCIN_0 . . . . .    | 883 |
| 5.173.2.2045 SAI_GCR_SYNCIN_1 . . . . .    | 883 |
| 5.173.2.2046 SAI_GCR_SYNCOUT . . . . .     | 883 |
| 5.173.2.2047 SAI_GCR_SYNCOUT_0 . . . . .   | 883 |
| 5.173.2.2048 SAI_GCR_SYNCOUT_1 . . . . .   | 883 |
| 5.173.2.2049 SAI_xCLRFR_CAFSDET . . . . .  | 883 |
| 5.173.2.2050 SAI_xCLRFR_CCNRDY . . . . .   | 883 |
| 5.173.2.2051 SAI_xCLRFR_CFREQ . . . . .    | 884 |
| 5.173.2.2052 SAI_xCLRFR_CLFSDET . . . . .  | 884 |
| 5.173.2.2053 SAI_xCLRFR_CMUTEDET . . . . . | 884 |
| 5.173.2.2054 SAI_xCLRFR_COVRUDR . . . . .  | 884 |
| 5.173.2.2055 SAI_xCLRFR_CWCKCFG . . . . .  | 884 |
| 5.173.2.2056 SAI_xCR1_CKSTR . . . . .      | 884 |
| 5.173.2.2057 SAI_xCR1_DMAEN . . . . .      | 884 |
| 5.173.2.2058 SAI_xCR1_DS . . . . .         | 885 |
| 5.173.2.2059 SAI_xCR1_DS_0 . . . . .       | 885 |
| 5.173.2.2060 SAI_xCR1_DS_1 . . . . .       | 885 |
| 5.173.2.2061 SAI_xCR1_DS_2 . . . . .       | 885 |
| 5.173.2.2062 SAI_xCR1 LSBFIRST . . . . .   | 885 |
| 5.173.2.2063 SAI_xCR1_MCKDIV . . . . .     | 885 |
| 5.173.2.2064 SAI_xCR1_MCKDIV_0 . . . . .   | 885 |
| 5.173.2.2065 SAI_xCR1_MCKDIV_1 . . . . .   | 886 |
| 5.173.2.2066 SAI_xCR1_MCKDIV_2 . . . . .   | 886 |
| 5.173.2.2067 SAI_xCR1_MCKDIV_3 . . . . .   | 886 |
| 5.173.2.2068 SAI_xCR1_MODE . . . . .       | 886 |
| 5.173.2.2069 SAI_xCR1_MODE_0 . . . . .     | 886 |
| 5.173.2.2070 SAI_xCR1_MODE_1 . . . . .     | 886 |
| 5.173.2.2071 SAI_xCR1_MONO . . . . .       | 886 |
| 5.173.2.2072 SAI_xCR1_NODIV . . . . .      | 887 |
| 5.173.2.2073 SAI_xCR1_OUTDRV . . . . .     | 887 |
| 5.173.2.2074 SAI_xCR1_PRTCFG . . . . .     | 887 |
| 5.173.2.2075 SAI_xCR1_PRTCFG_0 . . . . .   | 887 |
| 5.173.2.2076 SAI_xCR1_PRTCFG_1 . . . . .   | 887 |

---

|                                           |     |
|-------------------------------------------|-----|
| 5.173.2.2077 SAI_xCR1_SAIEN . . . . .     | 887 |
| 5.173.2.2078 SAI_xCR1_SYNCEN . . . . .    | 887 |
| 5.173.2.2079 SAI_xCR1_SYNCEN_0 . . . . .  | 888 |
| 5.173.2.2080 SAI_xCR1_SYNCEN_1 . . . . .  | 888 |
| 5.173.2.2081 SAI_xCR2_COMP . . . . .      | 888 |
| 5.173.2.2082 SAI_xCR2_COMP_0 . . . . .    | 888 |
| 5.173.2.2083 SAI_xCR2_COMP_1 . . . . .    | 888 |
| 5.173.2.2084 SAI_xCR2_CPL . . . . .       | 888 |
| 5.173.2.2085 SAI_xCR2_FFLUSH . . . . .    | 888 |
| 5.173.2.2086 SAI_xCR2_FTH . . . . .       | 889 |
| 5.173.2.2087 SAI_xCR2_FTH_0 . . . . .     | 889 |
| 5.173.2.2088 SAI_xCR2_FTH_1 . . . . .     | 889 |
| 5.173.2.2089 SAI_xCR2_MUTE . . . . .      | 889 |
| 5.173.2.2090 SAI_xCR2_MUTECNT . . . . .   | 889 |
| 5.173.2.2091 SAI_xCR2_MUTECNT_0 . . . . . | 889 |
| 5.173.2.2092 SAI_xCR2_MUTECNT_1 . . . . . | 889 |
| 5.173.2.2093 SAI_xCR2_MUTECNT_2 . . . . . | 890 |
| 5.173.2.2094 SAI_xCR2_MUTECNT_3 . . . . . | 890 |
| 5.173.2.2095 SAI_xCR2_MUTECNT_4 . . . . . | 890 |
| 5.173.2.2096 SAI_xCR2_MUTECNT_5 . . . . . | 890 |
| 5.173.2.2097 SAI_xCR2_MUTEVAL . . . . .   | 890 |
| 5.173.2.2098 SAI_xCR2_TRIS . . . . .      | 890 |
| 5.173.2.2099 SAI_xFRCR_FRL . . . . .      | 890 |
| 5.173.2.2100 SAI_xFRCR_FRL_0 . . . . .    | 891 |
| 5.173.2.2101 SAI_xFRCR_FRL_1 . . . . .    | 891 |
| 5.173.2.2102 SAI_xFRCR_FRL_2 . . . . .    | 891 |
| 5.173.2.2103 SAI_xFRCR_FRL_3 . . . . .    | 891 |
| 5.173.2.2104 SAI_xFRCR_FRL_4 . . . . .    | 891 |
| 5.173.2.2105 SAI_xFRCR_FRL_5 . . . . .    | 891 |
| 5.173.2.2106 SAI_xFRCR_FRL_6 . . . . .    | 891 |
| 5.173.2.2107 SAI_xFRCR_FRL_7 . . . . .    | 891 |
| 5.173.2.2108 SAI_xFRCR_FSALL . . . . .    | 892 |
| 5.173.2.2109 SAI_xFRCR_FSALL_0 . . . . .  | 892 |
| 5.173.2.2110 SAI_xFRCR_FSALL_1 . . . . .  | 892 |
| 5.173.2.2111 SAI_xFRCR_FSALL_2 . . . . .  | 892 |
| 5.173.2.2112 SAI_xFRCR_FSALL_3 . . . . .  | 892 |
| 5.173.2.2113 SAI_xFRCR_FSALL_4 . . . . .  | 892 |
| 5.173.2.2114 SAI_xFRCR_FSALL_5 . . . . .  | 892 |
| 5.173.2.2115 SAI_xFRCR_FSALL_6 . . . . .  | 893 |
| 5.173.2.2116 SAI_xFRCR_FSDEF . . . . .    | 893 |
| 5.173.2.2117 SAI_xFRCR_FSOFF . . . . .    | 893 |
| 5.173.2.2118 SAI_xFRCR_FSPOL . . . . .    | 893 |

|                                            |     |
|--------------------------------------------|-----|
| 5.173.2.2119 SAI_xIMR_AFSDETIE . . . . .   | 893 |
| 5.173.2.2120 SAI_xIMR_CNRDYIE . . . . .    | 893 |
| 5.173.2.2121 SAI_xIMR_FREQIE . . . . .     | 893 |
| 5.173.2.2122 SAI_xIMR_LFSDETIE . . . . .   | 894 |
| 5.173.2.2123 SAI_xIMR_MUTEDETIE . . . . .  | 894 |
| 5.173.2.2124 SAI_xIMR_OVRUDRIE . . . . .   | 894 |
| 5.173.2.2125 SAI_xIMR_WCKCFGIE . . . . .   | 894 |
| 5.173.2.2126 SAI_xSLOTR_FBOFF . . . . .    | 894 |
| 5.173.2.2127 SAI_xSLOTR_FBOFF_0 . . . . .  | 894 |
| 5.173.2.2128 SAI_xSLOTR_FBOFF_1 . . . . .  | 894 |
| 5.173.2.2129 SAI_xSLOTR_FBOFF_2 . . . . .  | 895 |
| 5.173.2.2130 SAI_xSLOTR_FBOFF_3 . . . . .  | 895 |
| 5.173.2.2131 SAI_xSLOTR_FBOFF_4 . . . . .  | 895 |
| 5.173.2.2132 SAI_xSLOTR_NBSLOT . . . . .   | 895 |
| 5.173.2.2133 SAI_xSLOTR_NBSLOT_0 . . . . . | 895 |
| 5.173.2.2134 SAI_xSLOTR_NBSLOT_1 . . . . . | 895 |
| 5.173.2.2135 SAI_xSLOTR_NBSLOT_2 . . . . . | 895 |
| 5.173.2.2136 SAI_xSLOTR_NBSLOT_3 . . . . . | 896 |
| 5.173.2.2137 SAI_xSLOTR_SLOTEN . . . . .   | 896 |
| 5.173.2.2138 SAI_xSLOTR_SLOTsz . . . . .   | 896 |
| 5.173.2.2139 SAI_xSLOTR_SLOTsz_0 . . . . . | 896 |
| 5.173.2.2140 SAI_xSLOTR_SLOTsz_1 . . . . . | 896 |
| 5.173.2.2141 SAI_xSR_AFSDET . . . . .      | 896 |
| 5.173.2.2142 SAI_xSR_CNRDY . . . . .       | 896 |
| 5.173.2.2143 SAI_xSR_FLVL . . . . .        | 897 |
| 5.173.2.2144 SAI_xSR_FLVL_0 . . . . .      | 897 |
| 5.173.2.2145 SAI_xSR_FLVL_1 . . . . .      | 897 |
| 5.173.2.2146 SAI_xSR_FLVL_2 . . . . .      | 897 |
| 5.173.2.2147 SAI_xSR_FREQ . . . . .        | 897 |
| 5.173.2.2148 SAI_xSR_LFSDET . . . . .      | 897 |
| 5.173.2.2149 SAI_xSR_MUTEDET . . . . .     | 897 |
| 5.173.2.2150 SAI_xSR_OVRUDR . . . . .      | 898 |
| 5.173.2.2151 SAI_xSR_WCKCFG . . . . .      | 898 |
| 5.173.2.2152 SDIO_ARG_CMDARG . . . . .     | 898 |
| 5.173.2.2153 SDIO_CLKCR_BYPASS . . . . .   | 898 |
| 5.173.2.2154 SDIO_CLKCR_CLKDIV . . . . .   | 898 |
| 5.173.2.2155 SDIO_CLKCR_CLKEN . . . . .    | 898 |
| 5.173.2.2156 SDIO_CLKCR_HWFC_EN . . . . .  | 898 |
| 5.173.2.2157 SDIO_CLKCR_NEGEDGE . . . . .  | 899 |
| 5.173.2.2158 SDIO_CLKCR_PWRSAV . . . . .   | 899 |
| 5.173.2.2159 SDIO_CLKCR_WIDBUS . . . . .   | 899 |
| 5.173.2.2160 SDIO_CLKCR_WIDBUS_0 . . . . . | 899 |

---

|                                                |     |
|------------------------------------------------|-----|
| 5.173.2.2161 SDIO_CLKCR_WIDBUS_1 . . . . .     | 899 |
| 5.173.2.2162 SDIO_CMD_CEATACMD . . . . .       | 899 |
| 5.173.2.2163 SDIO_CMD_CMDINDEX . . . . .       | 899 |
| 5.173.2.2164 SDIO_CMD_CPSMEN . . . . .         | 900 |
| 5.173.2.2165 SDIO_CMD_ENCMDCOMPL . . . . .     | 900 |
| 5.173.2.2166 SDIO_CMD_NIEN . . . . .           | 900 |
| 5.173.2.2167 SDIO_CMD_SDIOSUSPEND . . . . .    | 900 |
| 5.173.2.2168 SDIO_CMD_WAITINT . . . . .        | 900 |
| 5.173.2.2169 SDIO_CMD_WAITPEND . . . . .       | 900 |
| 5.173.2.2170 SDIO_CMD_WAITRESP . . . . .       | 900 |
| 5.173.2.2171 SDIO_CMD_WAITRESP_0 . . . . .     | 901 |
| 5.173.2.2172 SDIO_CMD_WAITRESP_1 . . . . .     | 901 |
| 5.173.2.2173 SDIO_DCOUNT_DATACOUNT . . . . .   | 901 |
| 5.173.2.2174 SDIO_DCTRL_DBLOCKSIZE . . . . .   | 901 |
| 5.173.2.2175 SDIO_DCTRL_DBLOCKSIZE_0 . . . . . | 901 |
| 5.173.2.2176 SDIO_DCTRL_DBLOCKSIZE_1 . . . . . | 901 |
| 5.173.2.2177 SDIO_DCTRL_DBLOCKSIZE_2 . . . . . | 901 |
| 5.173.2.2178 SDIO_DCTRL_DBLOCKSIZE_3 . . . . . | 901 |
| 5.173.2.2179 SDIO_DCTRL_DMAEN . . . . .        | 902 |
| 5.173.2.2180 SDIO_DCTRL_DTDIR . . . . .        | 902 |
| 5.173.2.2181 SDIO_DCTRL_DTEN . . . . .         | 902 |
| 5.173.2.2182 SDIO_DCTRL_DTMODE . . . . .       | 902 |
| 5.173.2.2183 SDIO_DCTRL_RWMOD . . . . .        | 902 |
| 5.173.2.2184 SDIO_DCTRL_RWSTART . . . . .      | 902 |
| 5.173.2.2185 SDIO_DCTRL_RWSTOP . . . . .       | 902 |
| 5.173.2.2186 SDIO_DCTRL_SDIOEN . . . . .       | 903 |
| 5.173.2.2187 SDIO_DLLEN_DATALENGTH . . . . .   | 903 |
| 5.173.2.2188 SDIO_DTIMER_DATATIME . . . . .    | 903 |
| 5.173.2.2189 SDIO_FIFO_FIFODATA . . . . .      | 903 |
| 5.173.2.2190 SDIO_FIFOCNT_FIFOCOUNT . . . . .  | 903 |
| 5.173.2.2191 SDIO_ICR_CCRCFAILC . . . . .      | 903 |
| 5.173.2.2192 SDIO_ICR_CEATAENDC . . . . .      | 903 |
| 5.173.2.2193 SDIO_ICR_CMDRENDC . . . . .       | 904 |
| 5.173.2.2194 SDIO_ICR_CMDSENTC . . . . .       | 904 |
| 5.173.2.2195 SDIO_ICR_CTIMEOUTC . . . . .      | 904 |
| 5.173.2.2196 SDIO_ICR_DATAENDC . . . . .       | 904 |
| 5.173.2.2197 SDIO_ICR_DBCKENDC . . . . .       | 904 |
| 5.173.2.2198 SDIO_ICR_DCRCFAILC . . . . .      | 904 |
| 5.173.2.2199 SDIO_ICR_DTIMEOUTC . . . . .      | 904 |
| 5.173.2.2200 SDIO_ICR_RXOVERRC . . . . .       | 905 |
| 5.173.2.2201 SDIO_ICR_SDIOITC . . . . .        | 905 |
| 5.173.2.2202 SDIO_ICR_STBITERRC . . . . .      | 905 |

---

---

|                                               |     |
|-----------------------------------------------|-----|
| 5.173.2.2203 SDIO_ICR_TXUNDERRC . . . . .     | 905 |
| 5.173.2.2204 SDIO_MASK_CCRCFAILIE . . . . .   | 905 |
| 5.173.2.2205 SDIO_MASK_CEATAENDIE . . . . .   | 905 |
| 5.173.2.2206 SDIO_MASK_CMDACTIE . . . . .     | 905 |
| 5.173.2.2207 SDIO_MASK_CMDRENDIE . . . . .    | 906 |
| 5.173.2.2208 SDIO_MASK_CMDSENTIE . . . . .    | 906 |
| 5.173.2.2209 SDIO_MASK_CTIMEOUTIE . . . . .   | 906 |
| 5.173.2.2210 SDIO_MASK_DATAENDIE . . . . .    | 906 |
| 5.173.2.2211 SDIO_MASK_DBCKENDIE . . . . .    | 906 |
| 5.173.2.2212 SDIO_MASK_DCRCFAILIE . . . . .   | 906 |
| 5.173.2.2213 SDIO_MASK_DTIMEOUTIE . . . . .   | 906 |
| 5.173.2.2214 SDIO_MASK_RXACTIE . . . . .      | 907 |
| 5.173.2.2215 SDIO_MASK_RXDAVLIE . . . . .     | 907 |
| 5.173.2.2216 SDIO_MASK_RXFIFOEIE . . . . .    | 907 |
| 5.173.2.2217 SDIO_MASK_RXFIFOFIE . . . . .    | 907 |
| 5.173.2.2218 SDIO_MASK_RXFIFOHFIE . . . . .   | 907 |
| 5.173.2.2219 SDIO_MASK_RXOVERRIE . . . . .    | 907 |
| 5.173.2.2220 SDIO_MASK_SDIOITIE . . . . .     | 907 |
| 5.173.2.2221 SDIO_MASK_STBITERRIE . . . . .   | 908 |
| 5.173.2.2222 SDIO_MASK_TXACTIE . . . . .      | 908 |
| 5.173.2.2223 SDIO_MASK_TXDAVLIE . . . . .     | 908 |
| 5.173.2.2224 SDIO_MASK_TXFIFOEIE . . . . .    | 908 |
| 5.173.2.2225 SDIO_MASK_TXFIFOFIE . . . . .    | 908 |
| 5.173.2.2226 SDIO_MASK_TXFIFOHEIE . . . . .   | 908 |
| 5.173.2.2227 SDIO_MASK_TXUNDERRIE . . . . .   | 908 |
| 5.173.2.2228 SDIO_POWER_PWRCTRL . . . . .     | 909 |
| 5.173.2.2229 SDIO_POWER_PWRCTRL_0 . . . . .   | 909 |
| 5.173.2.2230 SDIO_POWER_PWRCTRL_1 . . . . .   | 909 |
| 5.173.2.2231 SDIO_RESP0_CARDSTATUS0 . . . . . | 909 |
| 5.173.2.2232 SDIO_RESP1_CARDSTATUS1 . . . . . | 909 |
| 5.173.2.2233 SDIO_RESP2_CARDSTATUS2 . . . . . | 909 |
| 5.173.2.2234 SDIO_RESP3_CARDSTATUS3 . . . . . | 909 |
| 5.173.2.2235 SDIO_RESP4_CARDSTATUS4 . . . . . | 909 |
| 5.173.2.2236 SDIO_RESPCMD_RESPCMD . . . . .   | 910 |
| 5.173.2.2237 SDIO_STA_CCRCFAIL . . . . .      | 910 |
| 5.173.2.2238 SDIO_STA_CEATAEND . . . . .      | 910 |
| 5.173.2.2239 SDIO_STA_CMDACT . . . . .        | 910 |
| 5.173.2.2240 SDIO_STA_CMDREND . . . . .       | 910 |
| 5.173.2.2241 SDIO_STA_CMDSENT . . . . .       | 910 |
| 5.173.2.2242 SDIO_STA_CTIMEOUT . . . . .      | 910 |
| 5.173.2.2243 SDIO_STA_DATAEND . . . . .       | 911 |
| 5.173.2.2244 SDIO_STA_DBCKEND . . . . .       | 911 |

---

|                                          |     |
|------------------------------------------|-----|
| 5.173.2.2245 SDIO_STA_DCRCFAIL . . . . . | 911 |
| 5.173.2.2246 SDIO_STA_DTIMEOUT . . . . . | 911 |
| 5.173.2.2247 SDIO_STA_RXACT . . . . .    | 911 |
| 5.173.2.2248 SDIO_STA_RXDAVL . . . . .   | 911 |
| 5.173.2.2249 SDIO_STA_RXFIFOE . . . . .  | 911 |
| 5.173.2.2250 SDIO_STA_RXFIFOF . . . . .  | 912 |
| 5.173.2.2251 SDIO_STA_RXFIFOHF . . . . . | 912 |
| 5.173.2.2252 SDIO_STA_RXOVERR . . . . .  | 912 |
| 5.173.2.2253 SDIO_STA_SDIOIT . . . . .   | 912 |
| 5.173.2.2254 SDIO_STA_STBITERR . . . . . | 912 |
| 5.173.2.2255 SDIO_STA_TXACT . . . . .    | 912 |
| 5.173.2.2256 SDIO_STA_TXDAVL . . . . .   | 912 |
| 5.173.2.2257 SDIO_STA_TXFIFOE . . . . .  | 913 |
| 5.173.2.2258 SDIO_STA_TXFIFOF . . . . .  | 913 |
| 5.173.2.2259 SDIO_STA_TXFIFOHE . . . . . | 913 |
| 5.173.2.2260 SDIO_STA_TXUNDERR . . . . . | 913 |
| 5.173.2.2261 SPI_CR1_BIDIMODE . . . . .  | 913 |
| 5.173.2.2262 SPI_CR1_BIDIOE . . . . .    | 913 |
| 5.173.2.2263 SPI_CR1_BR . . . . .        | 913 |
| 5.173.2.2264 SPI_CR1_BR_0 . . . . .      | 914 |
| 5.173.2.2265 SPI_CR1_BR_1 . . . . .      | 914 |
| 5.173.2.2266 SPI_CR1_BR_2 . . . . .      | 914 |
| 5.173.2.2267 SPI_CR1_CPHA . . . . .      | 914 |
| 5.173.2.2268 SPI_CR1_CPOL . . . . .      | 914 |
| 5.173.2.2269 SPI_CR1_CRCEN . . . . .     | 914 |
| 5.173.2.2270 SPI_CR1_CRCNEXT . . . . .   | 914 |
| 5.173.2.2271 SPI_CR1_DFF . . . . .       | 915 |
| 5.173.2.2272 SPI_CR1_LSBFIRST . . . . .  | 915 |
| 5.173.2.2273 SPI_CR1_MSTR . . . . .      | 915 |
| 5.173.2.2274 SPI_CR1_RXONLY . . . . .    | 915 |
| 5.173.2.2275 SPI_CR1_SPE . . . . .       | 915 |
| 5.173.2.2276 SPI_CR1_SSI . . . . .       | 915 |
| 5.173.2.2277 SPI_CR1_SSM . . . . .       | 915 |
| 5.173.2.2278 SPI_CR2_ERRIE . . . . .     | 916 |
| 5.173.2.2279 SPI_CR2_RXDMAEN . . . . .   | 916 |
| 5.173.2.2280 SPI_CR2_RXNEIE . . . . .    | 916 |
| 5.173.2.2281 SPI_CR2_SSOE . . . . .      | 916 |
| 5.173.2.2282 SPI_CR2_TXDMAEN . . . . .   | 916 |
| 5.173.2.2283 SPI_CR2_TXEIE . . . . .     | 916 |
| 5.173.2.2284 SPI_CRCPR_CRCPOLY . . . . . | 916 |
| 5.173.2.2285 SPI_DR_DR . . . . .         | 917 |
| 5.173.2.2286 SPI_I2SCFGR_CHLEN . . . . . | 917 |

---

|                                                |     |
|------------------------------------------------|-----|
| 5.173.2.2287 SPI_I2SCFGR_CKPOL . . . . .       | 917 |
| 5.173.2.2288 SPI_I2SCFGR_DATLEN . . . . .      | 917 |
| 5.173.2.2289 SPI_I2SCFGR_DATLEN_0 . . . . .    | 917 |
| 5.173.2.2290 SPI_I2SCFGR_DATLEN_1 . . . . .    | 917 |
| 5.173.2.2291 SPI_I2SCFGR_I2SCFG . . . . .      | 917 |
| 5.173.2.2292 SPI_I2SCFGR_I2SCFG_0 . . . . .    | 918 |
| 5.173.2.2293 SPI_I2SCFGR_I2SCFG_1 . . . . .    | 918 |
| 5.173.2.2294 SPI_I2SCFGR_I2SE . . . . .        | 918 |
| 5.173.2.2295 SPI_I2SCFGR_I2SMOD . . . . .      | 918 |
| 5.173.2.2296 SPI_I2SCFGR_I2SSTD . . . . .      | 918 |
| 5.173.2.2297 SPI_I2SCFGR_I2SSTD_0 . . . . .    | 918 |
| 5.173.2.2298 SPI_I2SCFGR_I2SSTD_1 . . . . .    | 918 |
| 5.173.2.2299 SPI_I2SCFGR_PCMSYNC . . . . .     | 919 |
| 5.173.2.2300 SPI_I2SPR_I2SDIV . . . . .        | 919 |
| 5.173.2.2301 SPI_I2SPR_MCKOE . . . . .         | 919 |
| 5.173.2.2302 SPI_I2SPR_ODD . . . . .           | 919 |
| 5.173.2.2303 SPI_RXCRCR_RXCRC . . . . .        | 919 |
| 5.173.2.2304 SPI_SR_BSY . . . . .              | 919 |
| 5.173.2.2305 SPI_SR_CHSIDE . . . . .           | 919 |
| 5.173.2.2306 SPI_SR_CRCERR . . . . .           | 920 |
| 5.173.2.2307 SPI_SR_MODF . . . . .             | 920 |
| 5.173.2.2308 SPI_SR_OVR . . . . .              | 920 |
| 5.173.2.2309 SPI_SR_RXNE . . . . .             | 920 |
| 5.173.2.2310 SPI_SR_TXE . . . . .              | 920 |
| 5.173.2.2311 SPI_SR_UDR . . . . .              | 920 |
| 5.173.2.2312 SPI_TXCRCR_TXCRC . . . . .        | 920 |
| 5.173.2.2313 SYSCFG_CMPCR_CMP_PD . . . . .     | 921 |
| 5.173.2.2314 SYSCFG_CMPCR_READY . . . . .      | 921 |
| 5.173.2.2315 SYSCFG_EXTICR1_EXTI0 . . . . .    | 921 |
| 5.173.2.2316 SYSCFG_EXTICR1_EXTI0_PA . . . . . | 921 |
| 5.173.2.2317 SYSCFG_EXTICR1_EXTI0_PB . . . . . | 921 |
| 5.173.2.2318 SYSCFG_EXTICR1_EXTI0_PC . . . . . | 921 |
| 5.173.2.2319 SYSCFG_EXTICR1_EXTI0_PD . . . . . | 921 |
| 5.173.2.2320 SYSCFG_EXTICR1_EXTI0_PE . . . . . | 922 |
| 5.173.2.2321 SYSCFG_EXTICR1_EXTI0_PF . . . . . | 922 |
| 5.173.2.2322 SYSCFG_EXTICR1_EXTI0_PG . . . . . | 922 |
| 5.173.2.2323 SYSCFG_EXTICR1_EXTI0_PH . . . . . | 922 |
| 5.173.2.2324 SYSCFG_EXTICR1_EXTI0_PI . . . . . | 922 |
| 5.173.2.2325 SYSCFG_EXTICR1_EXTI0_PJ . . . . . | 922 |
| 5.173.2.2326 SYSCFG_EXTICR1_EXTI0_PK . . . . . | 922 |
| 5.173.2.2327 SYSCFG_EXTICR1_EXTI1 . . . . .    | 922 |
| 5.173.2.2328 SYSCFG_EXTICR1_EXTI1_PA . . . . . | 923 |

|                                                |     |
|------------------------------------------------|-----|
| 5.173.2.2329 SYSCFG_EXTICR1_EXTI1_PB . . . . . | 923 |
| 5.173.2.2330 SYSCFG_EXTICR1_EXTI1_PC . . . . . | 923 |
| 5.173.2.2331 SYSCFG_EXTICR1_EXTI1_PD . . . . . | 923 |
| 5.173.2.2332 SYSCFG_EXTICR1_EXTI1_PE . . . . . | 923 |
| 5.173.2.2333 SYSCFG_EXTICR1_EXTI1_PF . . . . . | 923 |
| 5.173.2.2334 SYSCFG_EXTICR1_EXTI1_PG . . . . . | 923 |
| 5.173.2.2335 SYSCFG_EXTICR1_EXTI1_PH . . . . . | 924 |
| 5.173.2.2336 SYSCFG_EXTICR1_EXTI1_PI . . . . . | 924 |
| 5.173.2.2337 SYSCFG_EXTICR1_EXTI1_PJ . . . . . | 924 |
| 5.173.2.2338 SYSCFG_EXTICR1_EXTI1_PK . . . . . | 924 |
| 5.173.2.2339 SYSCFG_EXTICR1_EXTI2 . . . . .    | 924 |
| 5.173.2.2340 SYSCFG_EXTICR1_EXTI2_PA . . . . . | 924 |
| 5.173.2.2341 SYSCFG_EXTICR1_EXTI2_PB . . . . . | 924 |
| 5.173.2.2342 SYSCFG_EXTICR1_EXTI2_PC . . . . . | 925 |
| 5.173.2.2343 SYSCFG_EXTICR1_EXTI2_PD . . . . . | 925 |
| 5.173.2.2344 SYSCFG_EXTICR1_EXTI2_PE . . . . . | 925 |
| 5.173.2.2345 SYSCFG_EXTICR1_EXTI2_PF . . . . . | 925 |
| 5.173.2.2346 SYSCFG_EXTICR1_EXTI2_PG . . . . . | 925 |
| 5.173.2.2347 SYSCFG_EXTICR1_EXTI2_PH . . . . . | 925 |
| 5.173.2.2348 SYSCFG_EXTICR1_EXTI2_PI . . . . . | 925 |
| 5.173.2.2349 SYSCFG_EXTICR1_EXTI2_PJ . . . . . | 925 |
| 5.173.2.2350 SYSCFG_EXTICR1_EXTI2_PK . . . . . | 926 |
| 5.173.2.2351 SYSCFG_EXTICR1_EXTI3 . . . . .    | 926 |
| 5.173.2.2352 SYSCFG_EXTICR1_EXTI3_PA . . . . . | 926 |
| 5.173.2.2353 SYSCFG_EXTICR1_EXTI3_PB . . . . . | 926 |
| 5.173.2.2354 SYSCFG_EXTICR1_EXTI3_PC . . . . . | 926 |
| 5.173.2.2355 SYSCFG_EXTICR1_EXTI3_PD . . . . . | 926 |
| 5.173.2.2356 SYSCFG_EXTICR1_EXTI3_PE . . . . . | 926 |
| 5.173.2.2357 SYSCFG_EXTICR1_EXTI3_PF . . . . . | 927 |
| 5.173.2.2358 SYSCFG_EXTICR1_EXTI3_PG . . . . . | 927 |
| 5.173.2.2359 SYSCFG_EXTICR1_EXTI3_PH . . . . . | 927 |
| 5.173.2.2360 SYSCFG_EXTICR1_EXTI3_PI . . . . . | 927 |
| 5.173.2.2361 SYSCFG_EXTICR1_EXTI3_PJ . . . . . | 927 |
| 5.173.2.2362 SYSCFG_EXTICR1_EXTI3_PK . . . . . | 927 |
| 5.173.2.2363 SYSCFG_EXTICR2_EXTI4 . . . . .    | 927 |
| 5.173.2.2364 SYSCFG_EXTICR2_EXTI4_PA . . . . . | 928 |
| 5.173.2.2365 SYSCFG_EXTICR2_EXTI4_PB . . . . . | 928 |
| 5.173.2.2366 SYSCFG_EXTICR2_EXTI4_PC . . . . . | 928 |
| 5.173.2.2367 SYSCFG_EXTICR2_EXTI4_PD . . . . . | 928 |
| 5.173.2.2368 SYSCFG_EXTICR2_EXTI4_PE . . . . . | 928 |
| 5.173.2.2369 SYSCFG_EXTICR2_EXTI4_PF . . . . . | 928 |
| 5.173.2.2370 SYSCFG_EXTICR2_EXTI4_PG . . . . . | 928 |

|                                                 |     |
|-------------------------------------------------|-----|
| 5.173.2.2371 SYSCFG_EXTICR2_EXTI4_PH . . . . .  | 929 |
| 5.173.2.2372 SYSCFG_EXTICR2_EXTI4_PI . . . . .  | 929 |
| 5.173.2.2373 SYSCFG_EXTICR2_EXTI4_PJ . . . . .  | 929 |
| 5.173.2.2374 SYSCFG_EXTICR2_EXTI4_PK . . . . .  | 929 |
| 5.173.2.2375 SYSCFG_EXTICR2_EXTI5 . . . . .     | 929 |
| 5.173.2.2376 SYSCFG_EXTICR2_EXTI5_PA . . . . .  | 929 |
| 5.173.2.2377 SYSCFG_EXTICR2_EXTI5_PB . . . . .  | 929 |
| 5.173.2.2378 SYSCFG_EXTICR2_EXTI5_PC . . . . .  | 930 |
| 5.173.2.2379 SYSCFG_EXTICR2_EXTI5_PD . . . . .  | 930 |
| 5.173.2.2380 SYSCFG_EXTICR2_EXTI5_PE . . . . .  | 930 |
| 5.173.2.2381 SYSCFG_EXTICR2_EXTI5_PF . . . . .  | 930 |
| 5.173.2.2382 SYSCFG_EXTICR2_EXTI5_PG . . . . .  | 930 |
| 5.173.2.2383 SYSCFG_EXTICR2_EXTI5_PH . . . . .  | 930 |
| 5.173.2.2384 SYSCFG_EXTICR2_EXTI5_PI . . . . .  | 930 |
| 5.173.2.2385 SYSCFG_EXTICR2_EXTI5_PJ . . . . .  | 930 |
| 5.173.2.2386 SYSCFG_EXTICR2_EXTI5_PK . . . . .  | 931 |
| 5.173.2.2387 SYSCFG_EXTICR2_EXTI6 . . . . .     | 931 |
| 5.173.2.2388 SYSCFG_EXTICR2_EXTI6_PA . . . . .  | 931 |
| 5.173.2.2389 SYSCFG_EXTICR2_EXTI6_PB . . . . .  | 931 |
| 5.173.2.2390 SYSCFG_EXTICR2_EXTI6_PC . . . . .  | 931 |
| 5.173.2.2391 SYSCFG_EXTICR2_EXTI6_PD . . . . .  | 931 |
| 5.173.2.2392 SYSCFG_EXTICR2_EXTI6_PE . . . . .  | 931 |
| 5.173.2.2393 SYSCFG_EXTICR2_EXTI6_PF . . . . .  | 932 |
| 5.173.2.2394 SYSCFG_EXTICR2_EXTI6_PG . . . . .  | 932 |
| 5.173.2.2395 SYSCFG_EXTICR2_EXTI6_PH . . . . .  | 932 |
| 5.173.2.2396 SYSCFG_EXTICR2_EXTI6_PI . . . . .  | 932 |
| 5.173.2.2397 SYSCFG_EXTICR2_EXTI6_PJ . . . . .  | 932 |
| 5.173.2.2398 SYSCFG_EXTICR2_EXTI6_PK . . . . .  | 932 |
| 5.173.2.2399 SYSCFG_EXTICR2_EXTI7 . . . . .     | 932 |
| 5.173.2.2400 SYSCFG_EXTICR2_EXTI7_PA . . . . .  | 933 |
| 5.173.2.2401 SYSCFG_EXTICR2_EXTI7_PB . . . . .  | 933 |
| 5.173.2.2402 SYSCFG_EXTICR2_EXTI7_PC . . . . .  | 933 |
| 5.173.2.2403 SYSCFG_EXTICR2_EXTI7_PD . . . . .  | 933 |
| 5.173.2.2404 SYSCFG_EXTICR2_EXTI7_PE . . . . .  | 933 |
| 5.173.2.2405 SYSCFG_EXTICR2_EXTI7_PF . . . . .  | 933 |
| 5.173.2.2406 SYSCFG_EXTICR2_EXTI7_PG . . . . .  | 933 |
| 5.173.2.2407 SYSCFG_EXTICR2_EXTI7_PH . . . . .  | 934 |
| 5.173.2.2408 SYSCFG_EXTICR2_EXTI7_PI . . . . .  | 934 |
| 5.173.2.2409 SYSCFG_EXTICR2_EXTI7_PJ . . . . .  | 934 |
| 5.173.2.2410 SYSCFG_EXTICR2_EXTI7_PK . . . . .  | 934 |
| 5.173.2.2411 SYSCFG_EXTICR3_EXTI10 . . . . .    | 934 |
| 5.173.2.2412 SYSCFG_EXTICR3_EXTI10_PA . . . . . | 934 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.173.2.2413 SYSCFG_EXTICR3_EXTI10_PB . . . . . | 934 |
| 5.173.2.2414 SYSCFG_EXTICR3_EXTI10_PC . . . . . | 935 |
| 5.173.2.2415 SYSCFG_EXTICR3_EXTI10_PD . . . . . | 935 |
| 5.173.2.2416 SYSCFG_EXTICR3_EXTI10_PE . . . . . | 935 |
| 5.173.2.2417 SYSCFG_EXTICR3_EXTI10_PF . . . . . | 935 |
| 5.173.2.2418 SYSCFG_EXTICR3_EXTI10_PG . . . . . | 935 |
| 5.173.2.2419 SYSCFG_EXTICR3_EXTI10_PH . . . . . | 935 |
| 5.173.2.2420 SYSCFG_EXTICR3_EXTI10_PI . . . . . | 935 |
| 5.173.2.2421 SYSCFG_EXTICR3_EXTI10_PJ . . . . . | 935 |
| 5.173.2.2422 SYSCFG_EXTICR3_EXTI11 . . . . .    | 936 |
| 5.173.2.2423 SYSCFG_EXTICR3_EXTI11_PA . . . . . | 936 |
| 5.173.2.2424 SYSCFG_EXTICR3_EXTI11_PB . . . . . | 936 |
| 5.173.2.2425 SYSCFG_EXTICR3_EXTI11_PC . . . . . | 936 |
| 5.173.2.2426 SYSCFG_EXTICR3_EXTI11_PD . . . . . | 936 |
| 5.173.2.2427 SYSCFG_EXTICR3_EXTI11_PE . . . . . | 936 |
| 5.173.2.2428 SYSCFG_EXTICR3_EXTI11_PF . . . . . | 936 |
| 5.173.2.2429 SYSCFG_EXTICR3_EXTI11_PG . . . . . | 937 |
| 5.173.2.2430 SYSCFG_EXTICR3_EXTI11_PH . . . . . | 937 |
| 5.173.2.2431 SYSCFG_EXTICR3_EXTI11_PI . . . . . | 937 |
| 5.173.2.2432 SYSCFG_EXTICR3_EXTI11_PJ . . . . . | 937 |
| 5.173.2.2433 SYSCFG_EXTICR3_EXTI8 . . . . .     | 937 |
| 5.173.2.2434 SYSCFG_EXTICR3_EXTI8_PA . . . . .  | 937 |
| 5.173.2.2435 SYSCFG_EXTICR3_EXTI8_PB . . . . .  | 937 |
| 5.173.2.2436 SYSCFG_EXTICR3_EXTI8_PC . . . . .  | 938 |
| 5.173.2.2437 SYSCFG_EXTICR3_EXTI8_PD . . . . .  | 938 |
| 5.173.2.2438 SYSCFG_EXTICR3_EXTI8_PE . . . . .  | 938 |
| 5.173.2.2439 SYSCFG_EXTICR3_EXTI8_PF . . . . .  | 938 |
| 5.173.2.2440 SYSCFG_EXTICR3_EXTI8_PG . . . . .  | 938 |
| 5.173.2.2441 SYSCFG_EXTICR3_EXTI8_PH . . . . .  | 938 |
| 5.173.2.2442 SYSCFG_EXTICR3_EXTI8_PI . . . . .  | 938 |
| 5.173.2.2443 SYSCFG_EXTICR3_EXTI8_PJ . . . . .  | 938 |
| 5.173.2.2444 SYSCFG_EXTICR3_EXTI9 . . . . .     | 939 |
| 5.173.2.2445 SYSCFG_EXTICR3_EXTI9_PA . . . . .  | 939 |
| 5.173.2.2446 SYSCFG_EXTICR3_EXTI9_PB . . . . .  | 939 |
| 5.173.2.2447 SYSCFG_EXTICR3_EXTI9_PC . . . . .  | 939 |
| 5.173.2.2448 SYSCFG_EXTICR3_EXTI9_PD . . . . .  | 939 |
| 5.173.2.2449 SYSCFG_EXTICR3_EXTI9_PE . . . . .  | 939 |
| 5.173.2.2450 SYSCFG_EXTICR3_EXTI9_PF . . . . .  | 939 |
| 5.173.2.2451 SYSCFG_EXTICR3_EXTI9_PG . . . . .  | 940 |
| 5.173.2.2452 SYSCFG_EXTICR3_EXTI9_PH . . . . .  | 940 |
| 5.173.2.2453 SYSCFG_EXTICR3_EXTI9_PI . . . . .  | 940 |
| 5.173.2.2454 SYSCFG_EXTICR3_EXTI9_PJ . . . . .  | 940 |

|                                                 |     |
|-------------------------------------------------|-----|
| 5.173.2.2455 SYSCFG_EXTICR4_EXTI12 . . . . .    | 940 |
| 5.173.2.2456 SYSCFG_EXTICR4_EXTI12_PA . . . . . | 940 |
| 5.173.2.2457 SYSCFG_EXTICR4_EXTI12_PB . . . . . | 940 |
| 5.173.2.2458 SYSCFG_EXTICR4_EXTI12_PC . . . . . | 941 |
| 5.173.2.2459 SYSCFG_EXTICR4_EXTI12_PD . . . . . | 941 |
| 5.173.2.2460 SYSCFG_EXTICR4_EXTI12_PE . . . . . | 941 |
| 5.173.2.2461 SYSCFG_EXTICR4_EXTI12_PF . . . . . | 941 |
| 5.173.2.2462 SYSCFG_EXTICR4_EXTI12_PG . . . . . | 941 |
| 5.173.2.2463 SYSCFG_EXTICR4_EXTI12_PH . . . . . | 941 |
| 5.173.2.2464 SYSCFG_EXTICR4_EXTI12_PI . . . . . | 941 |
| 5.173.2.2465 SYSCFG_EXTICR4_EXTI12_PJ . . . . . | 941 |
| 5.173.2.2466 SYSCFG_EXTICR4_EXTI13 . . . . .    | 942 |
| 5.173.2.2467 SYSCFG_EXTICR4_EXTI13_PA . . . . . | 942 |
| 5.173.2.2468 SYSCFG_EXTICR4_EXTI13_PB . . . . . | 942 |
| 5.173.2.2469 SYSCFG_EXTICR4_EXTI13_PC . . . . . | 942 |
| 5.173.2.2470 SYSCFG_EXTICR4_EXTI13_PD . . . . . | 942 |
| 5.173.2.2471 SYSCFG_EXTICR4_EXTI13_PE . . . . . | 942 |
| 5.173.2.2472 SYSCFG_EXTICR4_EXTI13_PF . . . . . | 942 |
| 5.173.2.2473 SYSCFG_EXTICR4_EXTI13_PG . . . . . | 943 |
| 5.173.2.2474 SYSCFG_EXTICR4_EXTI13_PH . . . . . | 943 |
| 5.173.2.2475 SYSCFG_EXTICR4_EXTI13_PI . . . . . | 943 |
| 5.173.2.2476 SYSCFG_EXTICR4_EXTI13_PJ . . . . . | 943 |
| 5.173.2.2477 SYSCFG_EXTICR4_EXTI14 . . . . .    | 943 |
| 5.173.2.2478 SYSCFG_EXTICR4_EXTI14_PA . . . . . | 943 |
| 5.173.2.2479 SYSCFG_EXTICR4_EXTI14_PB . . . . . | 943 |
| 5.173.2.2480 SYSCFG_EXTICR4_EXTI14_PC . . . . . | 944 |
| 5.173.2.2481 SYSCFG_EXTICR4_EXTI14_PD . . . . . | 944 |
| 5.173.2.2482 SYSCFG_EXTICR4_EXTI14_PE . . . . . | 944 |
| 5.173.2.2483 SYSCFG_EXTICR4_EXTI14_PF . . . . . | 944 |
| 5.173.2.2484 SYSCFG_EXTICR4_EXTI14_PG . . . . . | 944 |
| 5.173.2.2485 SYSCFG_EXTICR4_EXTI14_PH . . . . . | 944 |
| 5.173.2.2486 SYSCFG_EXTICR4_EXTI14_PI . . . . . | 944 |
| 5.173.2.2487 SYSCFG_EXTICR4_EXTI14_PJ . . . . . | 944 |
| 5.173.2.2488 SYSCFG_EXTICR4_EXTI15 . . . . .    | 945 |
| 5.173.2.2489 SYSCFG_EXTICR4_EXTI15_PA . . . . . | 945 |
| 5.173.2.2490 SYSCFG_EXTICR4_EXTI15_PB . . . . . | 945 |
| 5.173.2.2491 SYSCFG_EXTICR4_EXTI15_PC . . . . . | 945 |
| 5.173.2.2492 SYSCFG_EXTICR4_EXTI15_PD . . . . . | 945 |
| 5.173.2.2493 SYSCFG_EXTICR4_EXTI15_PE . . . . . | 945 |
| 5.173.2.2494 SYSCFG_EXTICR4_EXTI15_PF . . . . . | 945 |
| 5.173.2.2495 SYSCFG_EXTICR4_EXTI15_PG . . . . . | 946 |
| 5.173.2.2496 SYSCFG_EXTICR4_EXTI15_PH . . . . . | 946 |

---

|                                                 |     |
|-------------------------------------------------|-----|
| 5.173.2.2497 SYSCFG_EXTICR4_EXTI15_PI . . . . . | 946 |
| 5.173.2.2498 SYSCFG_EXTICR4_EXTI15_PJ . . . . . | 946 |
| 5.173.2.2499 SYSCFG_MEMRMP_FB_MODE . . . . .    | 946 |
| 5.173.2.2500 SYSCFG_MEMRMP_MEM_MODE . . . . .   | 946 |
| 5.173.2.2501 SYSCFG_MEMRMP_MEM_MODE_0 . . . . . | 946 |
| 5.173.2.2502 SYSCFG_MEMRMP_MEM_MODE_1 . . . . . | 946 |
| 5.173.2.2503 SYSCFG_MEMRMP_MEM_MODE_2 . . . . . | 947 |
| 5.173.2.2504 SYSCFG_MEMRMP_SWP_FMC . . . . .    | 947 |
| 5.173.2.2505 SYSCFG_MEMRMP_SWP_FMC_0 . . . . .  | 947 |
| 5.173.2.2506 SYSCFG_MEMRMP_SWP_FMC_1 . . . . .  | 947 |
| 5.173.2.2507 SYSCFG_PMC_ADC1DC2 . . . . .       | 947 |
| 5.173.2.2508 SYSCFG_PMC_ADC2DC2 . . . . .       | 947 |
| 5.173.2.2509 SYSCFG_PMC_ADC3DC2 . . . . .       | 947 |
| 5.173.2.2510 SYSCFG_PMC_ADCxDC2 . . . . .       | 948 |
| 5.173.2.2511 SYSCFG_PMC_MII_RMII_SEL . . . . .  | 948 |
| 5.173.2.2512 TIM_ARR_ARR . . . . .              | 948 |
| 5.173.2.2513 TIM_BDTR_AOE . . . . .             | 948 |
| 5.173.2.2514 TIM_BDTR_BKE . . . . .             | 948 |
| 5.173.2.2515 TIM_BDTR_BKP . . . . .             | 948 |
| 5.173.2.2516 TIM_BDTR_DTG . . . . .             | 948 |
| 5.173.2.2517 TIM_BDTR_DTG_0 . . . . .           | 949 |
| 5.173.2.2518 TIM_BDTR_DTG_1 . . . . .           | 949 |
| 5.173.2.2519 TIM_BDTR_DTG_2 . . . . .           | 949 |
| 5.173.2.2520 TIM_BDTR_DTG_3 . . . . .           | 949 |
| 5.173.2.2521 TIM_BDTR_DTG_4 . . . . .           | 949 |
| 5.173.2.2522 TIM_BDTR_DTG_5 . . . . .           | 949 |
| 5.173.2.2523 TIM_BDTR_DTG_6 . . . . .           | 949 |
| 5.173.2.2524 TIM_BDTR_DTG_7 . . . . .           | 949 |
| 5.173.2.2525 TIM_BDTR_LOCK . . . . .            | 950 |
| 5.173.2.2526 TIM_BDTR_LOCK_0 . . . . .          | 950 |
| 5.173.2.2527 TIM_BDTR_LOCK_1 . . . . .          | 950 |
| 5.173.2.2528 TIM_BDTR_MOE . . . . .             | 950 |
| 5.173.2.2529 TIM_BDTR_OSSI . . . . .            | 950 |
| 5.173.2.2530 TIM_BDTR_OSSR . . . . .            | 950 |
| 5.173.2.2531 TIM_CCER_CC1E . . . . .            | 950 |
| 5.173.2.2532 TIM_CCER_CC1NE . . . . .           | 951 |
| 5.173.2.2533 TIM_CCER_CC1NP . . . . .           | 951 |
| 5.173.2.2534 TIM_CCER_CC1P . . . . .            | 951 |
| 5.173.2.2535 TIM_CCER_CC2E . . . . .            | 951 |
| 5.173.2.2536 TIM_CCER_CC2NE . . . . .           | 951 |
| 5.173.2.2537 TIM_CCER_CC2NP . . . . .           | 951 |
| 5.173.2.2538 TIM_CCER_CC2P . . . . .            | 951 |

|                                           |     |
|-------------------------------------------|-----|
| 5.173.2.2539 TIM_CCER_CC3E . . . . .      | 952 |
| 5.173.2.2540 TIM_CCER_CC3NE . . . . .     | 952 |
| 5.173.2.2541 TIM_CCER_CC3NP . . . . .     | 952 |
| 5.173.2.2542 TIM_CCER_CC3P . . . . .      | 952 |
| 5.173.2.2543 TIM_CCER_CC4E . . . . .      | 952 |
| 5.173.2.2544 TIM_CCER_CC4NP . . . . .     | 952 |
| 5.173.2.2545 TIM_CCER_CC4P . . . . .      | 952 |
| 5.173.2.2546 TIM_CCMR1_CC1S . . . . .     | 953 |
| 5.173.2.2547 TIM_CCMR1_CC1S_0 . . . . .   | 953 |
| 5.173.2.2548 TIM_CCMR1_CC1S_1 . . . . .   | 953 |
| 5.173.2.2549 TIM_CCMR1_CC2S . . . . .     | 953 |
| 5.173.2.2550 TIM_CCMR1_CC2S_0 . . . . .   | 953 |
| 5.173.2.2551 TIM_CCMR1_CC2S_1 . . . . .   | 953 |
| 5.173.2.2552 TIM_CCMR1_IC1F . . . . .     | 953 |
| 5.173.2.2553 TIM_CCMR1_IC1F_0 . . . . .   | 954 |
| 5.173.2.2554 TIM_CCMR1_IC1F_1 . . . . .   | 954 |
| 5.173.2.2555 TIM_CCMR1_IC1F_2 . . . . .   | 954 |
| 5.173.2.2556 TIM_CCMR1_IC1F_3 . . . . .   | 954 |
| 5.173.2.2557 TIM_CCMR1_IC1PSC . . . . .   | 954 |
| 5.173.2.2558 TIM_CCMR1_IC1PSC_0 . . . . . | 954 |
| 5.173.2.2559 TIM_CCMR1_IC1PSC_1 . . . . . | 954 |
| 5.173.2.2560 TIM_CCMR1_IC2F . . . . .     | 954 |
| 5.173.2.2561 TIM_CCMR1_IC2F_0 . . . . .   | 955 |
| 5.173.2.2562 TIM_CCMR1_IC2F_1 . . . . .   | 955 |
| 5.173.2.2563 TIM_CCMR1_IC2F_2 . . . . .   | 955 |
| 5.173.2.2564 TIM_CCMR1_IC2F_3 . . . . .   | 955 |
| 5.173.2.2565 TIM_CCMR1_IC2PSC . . . . .   | 955 |
| 5.173.2.2566 TIM_CCMR1_IC2PSC_0 . . . . . | 955 |
| 5.173.2.2567 TIM_CCMR1_IC2PSC_1 . . . . . | 955 |
| 5.173.2.2568 TIM_CCMR1_OC1CE . . . . .    | 956 |
| 5.173.2.2569 TIM_CCMR1_OC1FE . . . . .    | 956 |
| 5.173.2.2570 TIM_CCMR1_OC1M . . . . .     | 956 |
| 5.173.2.2571 TIM_CCMR1_OC1M_0 . . . . .   | 956 |
| 5.173.2.2572 TIM_CCMR1_OC1M_1 . . . . .   | 956 |
| 5.173.2.2573 TIM_CCMR1_OC1M_2 . . . . .   | 956 |
| 5.173.2.2574 TIM_CCMR1_OC1PE . . . . .    | 956 |
| 5.173.2.2575 TIM_CCMR1_OC2CE . . . . .    | 957 |
| 5.173.2.2576 TIM_CCMR1_OC2FE . . . . .    | 957 |
| 5.173.2.2577 TIM_CCMR1_OC2M . . . . .     | 957 |
| 5.173.2.2578 TIM_CCMR1_OC2M_0 . . . . .   | 957 |
| 5.173.2.2579 TIM_CCMR1_OC2M_1 . . . . .   | 957 |
| 5.173.2.2580 TIM_CCMR1_OC2M_2 . . . . .   | 957 |

---

|                                           |     |
|-------------------------------------------|-----|
| 5.173.2.2581 TIM_CCMR1_OC2PE . . . . .    | 957 |
| 5.173.2.2582 TIM_CCMR2_CC3S . . . . .     | 958 |
| 5.173.2.2583 TIM_CCMR2_CC3S_0 . . . . .   | 958 |
| 5.173.2.2584 TIM_CCMR2_CC3S_1 . . . . .   | 958 |
| 5.173.2.2585 TIM_CCMR2_CC4S . . . . .     | 958 |
| 5.173.2.2586 TIM_CCMR2_CC4S_0 . . . . .   | 958 |
| 5.173.2.2587 TIM_CCMR2_CC4S_1 . . . . .   | 958 |
| 5.173.2.2588 TIM_CCMR2_IC3F . . . . .     | 958 |
| 5.173.2.2589 TIM_CCMR2_IC3F_0 . . . . .   | 959 |
| 5.173.2.2590 TIM_CCMR2_IC3F_1 . . . . .   | 959 |
| 5.173.2.2591 TIM_CCMR2_IC3F_2 . . . . .   | 959 |
| 5.173.2.2592 TIM_CCMR2_IC3F_3 . . . . .   | 959 |
| 5.173.2.2593 TIM_CCMR2_IC3PSC . . . . .   | 959 |
| 5.173.2.2594 TIM_CCMR2_IC3PSC_0 . . . . . | 959 |
| 5.173.2.2595 TIM_CCMR2_IC3PSC_1 . . . . . | 959 |
| 5.173.2.2596 TIM_CCMR2_IC4F . . . . .     | 959 |
| 5.173.2.2597 TIM_CCMR2_IC4F_0 . . . . .   | 960 |
| 5.173.2.2598 TIM_CCMR2_IC4F_1 . . . . .   | 960 |
| 5.173.2.2599 TIM_CCMR2_IC4F_2 . . . . .   | 960 |
| 5.173.2.2600 TIM_CCMR2_IC4F_3 . . . . .   | 960 |
| 5.173.2.2601 TIM_CCMR2_IC4PSC . . . . .   | 960 |
| 5.173.2.2602 TIM_CCMR2_IC4PSC_0 . . . . . | 960 |
| 5.173.2.2603 TIM_CCMR2_IC4PSC_1 . . . . . | 960 |
| 5.173.2.2604 TIM_CCMR2_OC3CE . . . . .    | 960 |
| 5.173.2.2605 TIM_CCMR2_OC3FE . . . . .    | 961 |
| 5.173.2.2606 TIM_CCMR2_OC3M . . . . .     | 961 |
| 5.173.2.2607 TIM_CCMR2_OC3M_0 . . . . .   | 961 |
| 5.173.2.2608 TIM_CCMR2_OC3M_1 . . . . .   | 961 |
| 5.173.2.2609 TIM_CCMR2_OC3M_2 . . . . .   | 961 |
| 5.173.2.2610 TIM_CCMR2_OC3PE . . . . .    | 961 |
| 5.173.2.2611 TIM_CCMR2_OC4CE . . . . .    | 961 |
| 5.173.2.2612 TIM_CCMR2_OC4FE . . . . .    | 962 |
| 5.173.2.2613 TIM_CCMR2_OC4M . . . . .     | 962 |
| 5.173.2.2614 TIM_CCMR2_OC4M_0 . . . . .   | 962 |
| 5.173.2.2615 TIM_CCMR2_OC4M_1 . . . . .   | 962 |
| 5.173.2.2616 TIM_CCMR2_OC4M_2 . . . . .   | 962 |
| 5.173.2.2617 TIM_CCMR2_OC4PE . . . . .    | 962 |
| 5.173.2.2618 TIM_CCR1_CCR1 . . . . .      | 962 |
| 5.173.2.2619 TIM_CCR2_CCR2 . . . . .      | 963 |
| 5.173.2.2620 TIM_CCR3_CCR3 . . . . .      | 963 |
| 5.173.2.2621 TIM_CCR4_CCR4 . . . . .      | 963 |
| 5.173.2.2622 TIM_CNT_CNT . . . . .        | 963 |

---

|                                       |     |
|---------------------------------------|-----|
| 5.173.2.2623 TIM_CR1_ARPE . . . . .   | 963 |
| 5.173.2.2624 TIM_CR1_CEN . . . . .    | 963 |
| 5.173.2.2625 TIM_CR1_CKD . . . . .    | 963 |
| 5.173.2.2626 TIM_CR1_CKD_0 . . . . .  | 964 |
| 5.173.2.2627 TIM_CR1_CKD_1 . . . . .  | 964 |
| 5.173.2.2628 TIM_CR1_CMS . . . . .    | 964 |
| 5.173.2.2629 TIM_CR1_CMS_0 . . . . .  | 964 |
| 5.173.2.2630 TIM_CR1_CMS_1 . . . . .  | 964 |
| 5.173.2.2631 TIM_CR1_DIR . . . . .    | 964 |
| 5.173.2.2632 TIM_CR1_OPM . . . . .    | 964 |
| 5.173.2.2633 TIM_CR1_UDIS . . . . .   | 965 |
| 5.173.2.2634 TIM_CR1_URS . . . . .    | 965 |
| 5.173.2.2635 TIM_CR2_CCDS . . . . .   | 965 |
| 5.173.2.2636 TIM_CR2_CCPC . . . . .   | 965 |
| 5.173.2.2637 TIM_CR2_CCUS . . . . .   | 965 |
| 5.173.2.2638 TIM_CR2_MMS . . . . .    | 965 |
| 5.173.2.2639 TIM_CR2_MMS_0 . . . . .  | 965 |
| 5.173.2.2640 TIM_CR2_MMS_1 . . . . .  | 966 |
| 5.173.2.2641 TIM_CR2_MMS_2 . . . . .  | 966 |
| 5.173.2.2642 TIM_CR2_OIS1 . . . . .   | 966 |
| 5.173.2.2643 TIM_CR2_OIS1N . . . . .  | 966 |
| 5.173.2.2644 TIM_CR2_OIS2 . . . . .   | 966 |
| 5.173.2.2645 TIM_CR2_OIS2N . . . . .  | 966 |
| 5.173.2.2646 TIM_CR2_OIS3 . . . . .   | 966 |
| 5.173.2.2647 TIM_CR2_OIS3N . . . . .  | 967 |
| 5.173.2.2648 TIM_CR2_OIS4 . . . . .   | 967 |
| 5.173.2.2649 TIM_CR2_TI1S . . . . .   | 967 |
| 5.173.2.2650 TIM_DCR_DBAA . . . . .   | 967 |
| 5.173.2.2651 TIM_DCR_DBAA_0 . . . . . | 967 |
| 5.173.2.2652 TIM_DCR_DBAA_1 . . . . . | 967 |
| 5.173.2.2653 TIM_DCR_DBAA_2 . . . . . | 967 |
| 5.173.2.2654 TIM_DCR_DBAA_3 . . . . . | 968 |
| 5.173.2.2655 TIM_DCR_DBAA_4 . . . . . | 968 |
| 5.173.2.2656 TIM_DCR_DBBL . . . . .   | 968 |
| 5.173.2.2657 TIM_DCR_DBBL_0 . . . . . | 968 |
| 5.173.2.2658 TIM_DCR_DBBL_1 . . . . . | 968 |
| 5.173.2.2659 TIM_DCR_DBBL_2 . . . . . | 968 |
| 5.173.2.2660 TIM_DCR_DBBL_3 . . . . . | 968 |
| 5.173.2.2661 TIM_DCR_DBBL_4 . . . . . | 968 |
| 5.173.2.2662 TIM_DIER_BIE . . . . .   | 969 |
| 5.173.2.2663 TIM_DIER_CC1DE . . . . . | 969 |
| 5.173.2.2664 TIM_DIER_CC1IE . . . . . | 969 |

---

|                                          |     |
|------------------------------------------|-----|
| 5.173.2.2665 TIM_DIER_CC2DE . . . . .    | 969 |
| 5.173.2.2666 TIM_DIER_CC2IE . . . . .    | 969 |
| 5.173.2.2667 TIM_DIER_CC3DE . . . . .    | 969 |
| 5.173.2.2668 TIM_DIER_CC3IE . . . . .    | 969 |
| 5.173.2.2669 TIM_DIER_CC4DE . . . . .    | 970 |
| 5.173.2.2670 TIM_DIER_CC4IE . . . . .    | 970 |
| 5.173.2.2671 TIM_DIER_COMDE . . . . .    | 970 |
| 5.173.2.2672 TIM_DIER_COMIE . . . . .    | 970 |
| 5.173.2.2673 TIM_DIER_TDE . . . . .      | 970 |
| 5.173.2.2674 TIM_DIER_TIE . . . . .      | 970 |
| 5.173.2.2675 TIM_DIER_UDE . . . . .      | 970 |
| 5.173.2.2676 TIM_DIER_UIE . . . . .      | 971 |
| 5.173.2.2677 TIM_DMAR_DMAB . . . . .     | 971 |
| 5.173.2.2678 TIM_EGR_BG . . . . .        | 971 |
| 5.173.2.2679 TIM_EGR_CC1G . . . . .      | 971 |
| 5.173.2.2680 TIM_EGR_CC2G . . . . .      | 971 |
| 5.173.2.2681 TIM_EGR_CC3G . . . . .      | 971 |
| 5.173.2.2682 TIM_EGR_CC4G . . . . .      | 971 |
| 5.173.2.2683 TIM_EGR_COMG . . . . .      | 972 |
| 5.173.2.2684 TIM_EGR_TG . . . . .        | 972 |
| 5.173.2.2685 TIM_EGR_UG . . . . .        | 972 |
| 5.173.2.2686 TIM_OR_ITR1_RMP . . . . .   | 972 |
| 5.173.2.2687 TIM_OR_ITR1_RMP_0 . . . . . | 972 |
| 5.173.2.2688 TIM_OR_ITR1_RMP_1 . . . . . | 972 |
| 5.173.2.2689 TIM_OR_TI4_RMP . . . . .    | 972 |
| 5.173.2.2690 TIM_OR_TI4_RMP_0 . . . . .  | 973 |
| 5.173.2.2691 TIM_OR_TI4_RMP_1 . . . . .  | 973 |
| 5.173.2.2692 TIM_PSC_PSC . . . . .       | 973 |
| 5.173.2.2693 TIM_RCR_REP . . . . .       | 973 |
| 5.173.2.2694 TIM_SMCR_ECE . . . . .      | 973 |
| 5.173.2.2695 TIM_SMCR ETF . . . . .      | 973 |
| 5.173.2.2696 TIM_SMCR ETF_0 . . . . .    | 973 |
| 5.173.2.2697 TIM_SMCR ETF_1 . . . . .    | 974 |
| 5.173.2.2698 TIM_SMCR ETF_2 . . . . .    | 974 |
| 5.173.2.2699 TIM_SMCR ETF_3 . . . . .    | 974 |
| 5.173.2.2700 TIM_SMCR ETP . . . . .      | 974 |
| 5.173.2.2701 TIM_SMCR ETPS . . . . .     | 974 |
| 5.173.2.2702 TIM_SMCR ETPS_0 . . . . .   | 974 |
| 5.173.2.2703 TIM_SMCR ETPS_1 . . . . .   | 974 |
| 5.173.2.2704 TIM_SMCR MSM . . . . .      | 974 |
| 5.173.2.2705 TIM_SMCR SMS . . . . .      | 975 |
| 5.173.2.2706 TIM_SMCR SMS_0 . . . . .    | 975 |

---

|                                               |     |
|-----------------------------------------------|-----|
| 5.173.2.2707 TIM_SMCR_SMS_1 . . . . .         | 975 |
| 5.173.2.2708 TIM_SMCR_SMS_2 . . . . .         | 975 |
| 5.173.2.2709 TIM_SMCR_TS . . . . .            | 975 |
| 5.173.2.2710 TIM_SMCR_TS_0 . . . . .          | 975 |
| 5.173.2.2711 TIM_SMCR_TS_1 . . . . .          | 975 |
| 5.173.2.2712 TIM_SMCR_TS_2 . . . . .          | 976 |
| 5.173.2.2713 TIM_SR_BIF . . . . .             | 976 |
| 5.173.2.2714 TIM_SR_CC1IF . . . . .           | 976 |
| 5.173.2.2715 TIM_SR_CC1OF . . . . .           | 976 |
| 5.173.2.2716 TIM_SR_CC2IF . . . . .           | 976 |
| 5.173.2.2717 TIM_SR_CC2OF . . . . .           | 976 |
| 5.173.2.2718 TIM_SR_CC3IF . . . . .           | 976 |
| 5.173.2.2719 TIM_SR_CC3OF . . . . .           | 977 |
| 5.173.2.2720 TIM_SR_CC4IF . . . . .           | 977 |
| 5.173.2.2721 TIM_SR_CC4OF . . . . .           | 977 |
| 5.173.2.2722 TIM_SR_COMIF . . . . .           | 977 |
| 5.173.2.2723 TIM_SR_TIF . . . . .             | 977 |
| 5.173.2.2724 TIM_SR_UIF . . . . .             | 977 |
| 5.173.2.2725 USART_BRR_DIV_Fraction . . . . . | 977 |
| 5.173.2.2726 USART_BRR_DIV_Mantissa . . . . . | 978 |
| 5.173.2.2727 USART_CR1_IDLEIE . . . . .       | 978 |
| 5.173.2.2728 USART_CR1_M . . . . .            | 978 |
| 5.173.2.2729 USART_CR1_OVER8 . . . . .        | 978 |
| 5.173.2.2730 USART_CR1_PCE . . . . .          | 978 |
| 5.173.2.2731 USART_CR1_PEIE . . . . .         | 978 |
| 5.173.2.2732 USART_CR1_PS . . . . .           | 978 |
| 5.173.2.2733 USART_CR1_RE . . . . .           | 979 |
| 5.173.2.2734 USART_CR1_RWU . . . . .          | 979 |
| 5.173.2.2735 USART_CR1_RXNEIE . . . . .       | 979 |
| 5.173.2.2736 USART_CR1_SBK . . . . .          | 979 |
| 5.173.2.2737 USART_CR1_TCIE . . . . .         | 979 |
| 5.173.2.2738 USART_CR1_TE . . . . .           | 979 |
| 5.173.2.2739 USART_CR1_TXEIE . . . . .        | 979 |
| 5.173.2.2740 USART_CR1 UE . . . . .           | 980 |
| 5.173.2.2741 USART_CR1_WAKE . . . . .         | 980 |
| 5.173.2.2742 USART_CR2_ADD . . . . .          | 980 |
| 5.173.2.2743 USART_CR2_CLKEN . . . . .        | 980 |
| 5.173.2.2744 USART_CR2_CPHA . . . . .         | 980 |
| 5.173.2.2745 USART_CR2_CPOL . . . . .         | 980 |
| 5.173.2.2746 USART_CR2_LBCL . . . . .         | 980 |
| 5.173.2.2747 USART_CR2_LBDIE . . . . .        | 981 |
| 5.173.2.2748 USART_CR2_LBDL . . . . .         | 981 |

|                                         |     |
|-----------------------------------------|-----|
| 5.173.2.2749 USART_CR2_LINEN . . . . .  | 981 |
| 5.173.2.2750 USART_CR2_STOP . . . . .   | 981 |
| 5.173.2.2751 USART_CR2_STOP_0 . . . . . | 981 |
| 5.173.2.2752 USART_CR2_STOP_1 . . . . . | 981 |
| 5.173.2.2753 USART_CR3_CTSE . . . . .   | 981 |
| 5.173.2.2754 USART_CR3_CTSIE . . . . .  | 982 |
| 5.173.2.2755 USART_CR3_DMAR . . . . .   | 982 |
| 5.173.2.2756 USART_CR3_DMAT . . . . .   | 982 |
| 5.173.2.2757 USART_CR3_EIE . . . . .    | 982 |
| 5.173.2.2758 USART_CR3_HDSEL . . . . .  | 982 |
| 5.173.2.2759 USART_CR3_IREN . . . . .   | 982 |
| 5.173.2.2760 USART_CR3_IRLP . . . . .   | 982 |
| 5.173.2.2761 USART_CR3_NACK . . . . .   | 983 |
| 5.173.2.2762 USART_CR3_ONEBIT . . . . . | 983 |
| 5.173.2.2763 USART_CR3_RTSE . . . . .   | 983 |
| 5.173.2.2764 USART_CR3_SCEN . . . . .   | 983 |
| 5.173.2.2765 USART_DR_DR . . . . .      | 983 |
| 5.173.2.2766 USART_GTPR_GT . . . . .    | 983 |
| 5.173.2.2767 USART_GTPR_PSC . . . . .   | 983 |
| 5.173.2.2768 USART_GTPR_PSC_0 . . . . . | 984 |
| 5.173.2.2769 USART_GTPR_PSC_1 . . . . . | 984 |
| 5.173.2.2770 USART_GTPR_PSC_2 . . . . . | 984 |
| 5.173.2.2771 USART_GTPR_PSC_3 . . . . . | 984 |
| 5.173.2.2772 USART_GTPR_PSC_4 . . . . . | 984 |
| 5.173.2.2773 USART_GTPR_PSC_5 . . . . . | 984 |
| 5.173.2.2774 USART_GTPR_PSC_6 . . . . . | 984 |
| 5.173.2.2775 USART_GTPR_PSC_7 . . . . . | 984 |
| 5.173.2.2776 USART_SR_CTS . . . . .     | 985 |
| 5.173.2.2777 USART_SR_FE . . . . .      | 985 |
| 5.173.2.2778 USART_SR_IDLE . . . . .    | 985 |
| 5.173.2.2779 USART_SR_LBD . . . . .     | 985 |
| 5.173.2.2780 USART_SR_NE . . . . .      | 985 |
| 5.173.2.2781 USART_SR_ORE . . . . .     | 985 |
| 5.173.2.2782 USART_SR_PE . . . . .      | 985 |
| 5.173.2.2783 USART_SR_RXNE . . . . .    | 986 |
| 5.173.2.2784 USART_SR_TC . . . . .      | 986 |
| 5.173.2.2785 USART_SR_TXE . . . . .     | 986 |
| 5.173.2.2786 WWDG_CFR_EWI . . . . .     | 986 |
| 5.173.2.2787 WWDG_CFR_W . . . . .       | 986 |
| 5.173.2.2788 WWDG_CFR_W_0 . . . . .     | 986 |
| 5.173.2.2789 WWDG_CFR_W_1 . . . . .     | 986 |
| 5.173.2.2790 WWDG_CFR_W_2 . . . . .     | 987 |

---

|                                                           |     |
|-----------------------------------------------------------|-----|
| 5.173.2.2791 WWDG_CFR_W_3 . . . . .                       | 987 |
| 5.173.2.2792 WWDG_CFR_W_4 . . . . .                       | 987 |
| 5.173.2.2793 WWDG_CFR_W_5 . . . . .                       | 987 |
| 5.173.2.2794 WWDG_CFR_W_6 . . . . .                       | 987 |
| 5.173.2.2795 WWDG_CFR_WDGTB . . . . .                     | 987 |
| 5.173.2.2796 WWDG_CFR_WDGTB_0 . . . . .                   | 987 |
| 5.173.2.2797 WWDG_CFR_WDGTB_1 . . . . .                   | 987 |
| 5.173.2.2798 WWDG_CR_T . . . . .                          | 988 |
| 5.173.2.2799 WWDG_CR_T_0 . . . . .                        | 988 |
| 5.173.2.2800 WWDG_CR_T_1 . . . . .                        | 988 |
| 5.173.2.2801 WWDG_CR_T_2 . . . . .                        | 988 |
| 5.173.2.2802 WWDG_CR_T_3 . . . . .                        | 988 |
| 5.173.2.2803 WWDG_CR_T_4 . . . . .                        | 988 |
| 5.173.2.2804 WWDG_CR_T_5 . . . . .                        | 988 |
| 5.173.2.2805 WWDG_CR_T_6 . . . . .                        | 988 |
| 5.173.2.2806 WWDG_CR_WDGA . . . . .                       | 989 |
| 5.173.2.2807 WWDG_SR_EWIF . . . . .                       | 989 |
| 5.174 Exported_macro . . . . .                            | 989 |
| 5.174.1 Detailed Description . . . . .                    | 990 |
| 5.175 Stm32f4xx_system . . . . .                          | 990 |
| 5.175.1 Detailed Description . . . . .                    | 991 |
| 5.176 STM32F4xx_System_Includes . . . . .                 | 991 |
| 5.177 STM32F4xx_System_Exported_types . . . . .           | 991 |
| 5.177.1 Detailed Description . . . . .                    | 992 |
| 5.177.2 Variable Documentation . . . . .                  | 992 |
| 5.177.2.1 SystemCoreClock . . . . .                       | 992 |
| 5.178 STM32F4xx_System_Exported_Constants . . . . .       | 992 |
| 5.179 STM32F4xx_System_Exported_Macros . . . . .          | 992 |
| 5.180 STM32F4xx_System_Exported_Functions . . . . .       | 992 |
| 5.180.1 Detailed Description . . . . .                    | 993 |
| 5.180.2 Function Documentation . . . . .                  | 993 |
| 5.180.2.1 SystemCoreClockUpdate() . . . . .               | 993 |
| 5.180.2.2 SystemInit() . . . . .                          | 994 |
| 5.181 STM32F4xx_System_Private_Includes . . . . .         | 994 |
| 5.182 STM32F4xx_System_Private_TypesDefinitions . . . . . | 994 |
| 5.183 STM32F4xx_System_Private_Defines . . . . .          | 995 |
| 5.183.1 Detailed Description . . . . .                    | 995 |
| 5.183.2 Macro Definition Documentation . . . . .          | 995 |
| 5.183.2.1 VECT_TAB_OFFSET . . . . .                       | 995 |
| 5.184 STM32F4xx_System_Private_Macros . . . . .           | 995 |
| 5.185 STM32F4xx_System_Private_Variables . . . . .        | 996 |
| 5.185.1 Detailed Description . . . . .                    | 996 |

|                                                             |            |
|-------------------------------------------------------------|------------|
| 5.186 STM32F4xx_System_Private_FunctionPrototypes . . . . . | 996        |
| 5.186.1 Detailed Description . . . . .                      | 996        |
| 5.187 STM32F4xx_System_Private_Functions . . . . .          | 996        |
| 5.187.1 Detailed Description . . . . .                      | 997        |
| 5.187.2 Function Documentation . . . . .                    | 997        |
| 5.187.2.1 SystemCoreClockUpdate() . . . . .                 | 997        |
| 5.187.2.2 SystemInit() . . . . .                            | 998        |
| <b>6 Class Documentation</b> . . . . .                      | <b>999</b> |
| 6.1 ADC_Common_TypeDef Struct Reference . . . . .           | 999        |
| 6.2 ADC_TypeDef Struct Reference . . . . .                  | 999        |
| 6.2.1 Detailed Description . . . . .                        | 1000       |
| 6.3 APSR_Type Union Reference . . . . .                     | 1000       |
| 6.3.1 Detailed Description . . . . .                        | 1000       |
| 6.4 CAN_FIFOMailBox_TypeDef Struct Reference . . . . .      | 1000       |
| 6.4.1 Detailed Description . . . . .                        | 1001       |
| 6.5 CAN_FilterRegister_TypeDef Struct Reference . . . . .   | 1001       |
| 6.5.1 Detailed Description . . . . .                        | 1001       |
| 6.6 CAN_TxMailBox_TypeDef Struct Reference . . . . .        | 1001       |
| 6.6.1 Detailed Description . . . . .                        | 1002       |
| 6.7 CAN_TypeDef Struct Reference . . . . .                  | 1002       |
| 6.7.1 Detailed Description . . . . .                        | 1003       |
| 6.8 CONTROL_Type Union Reference . . . . .                  | 1003       |
| 6.8.1 Detailed Description . . . . .                        | 1003       |
| 6.9 CoreDebug_TypeDef Struct Reference . . . . .            | 1003       |
| 6.9.1 Detailed Description . . . . .                        | 1004       |
| 6.10 CRC_TypeDef Struct Reference . . . . .                 | 1004       |
| 6.10.1 Detailed Description . . . . .                       | 1004       |
| 6.10.2 Member Data Documentation . . . . .                  | 1004       |
| 6.10.2.1 CR . . . . .                                       | 1004       |
| 6.10.2.2 DR . . . . .                                       | 1005       |
| 6.10.2.3 IDR . . . . .                                      | 1005       |
| 6.10.2.4 INIT . . . . .                                     | 1005       |
| 6.10.2.5 POL . . . . .                                      | 1005       |
| 6.10.2.6 RESERVED . . . . .                                 | 1005       |
| 6.10.2.7 SR . . . . .                                       | 1005       |
| 6.11 CRYP_TypeDef Struct Reference . . . . .                | 1005       |
| 6.11.1 Detailed Description . . . . .                       | 1006       |
| 6.12 DAC_TypeDef Struct Reference . . . . .                 | 1006       |
| 6.12.1 Detailed Description . . . . .                       | 1007       |
| 6.13 DBGMCU_TypeDef Struct Reference . . . . .              | 1007       |
| 6.13.1 Detailed Description . . . . .                       | 1007       |

---

|                                                    |      |
|----------------------------------------------------|------|
| 6.14 DCMI_TypeDef Struct Reference . . . . .       | 1008 |
| 6.14.1 Detailed Description . . . . .              | 1008 |
| 6.15 DMA2D_TypeDef Struct Reference . . . . .      | 1008 |
| 6.15.1 Detailed Description . . . . .              | 1009 |
| 6.16 DMA_Stream_TypeDef Struct Reference . . . . . | 1009 |
| 6.16.1 Detailed Description . . . . .              | 1009 |
| 6.17 DMA_TypeDef Struct Reference . . . . .        | 1010 |
| 6.18 DWT_Type Struct Reference . . . . .           | 1010 |
| 6.18.1 Detailed Description . . . . .              | 1011 |
| 6.19 ETH_TypeDef Struct Reference . . . . .        | 1011 |
| 6.19.1 Detailed Description . . . . .              | 1012 |
| 6.20 EXTI_TypeDef Struct Reference . . . . .       | 1012 |
| 6.20.1 Detailed Description . . . . .              | 1013 |
| 6.20.2 Member Data Documentation . . . . .         | 1013 |
| 6.20.2.1 EMR . . . . .                             | 1013 |
| 6.20.2.2 FTSR . . . . .                            | 1013 |
| 6.20.2.3 IMR . . . . .                             | 1013 |
| 6.20.2.4 PR . . . . .                              | 1013 |
| 6.20.2.5 RTSR . . . . .                            | 1014 |
| 6.20.2.6 SWIER . . . . .                           | 1014 |
| 6.21 FLASH_TypeDef Struct Reference . . . . .      | 1014 |
| 6.21.1 Detailed Description . . . . .              | 1014 |
| 6.22 GPIO_PinConfig_t Struct Reference . . . . .   | 1014 |
| 6.22.1 Detailed Description . . . . .              | 1015 |
| 6.22.2 Member Data Documentation . . . . .         | 1015 |
| 6.22.2.1 GPIO_MODE . . . . .                       | 1015 |
| 6.22.2.2 GPIO_PinAltFunMode . . . . .              | 1015 |
| 6.22.2.3 GPIO_PinNumber . . . . .                  | 1015 |
| 6.22.2.4 GPIO_PinOType . . . . .                   | 1015 |
| 6.22.2.5 GPIO_PinPuPdControl . . . . .             | 1016 |
| 6.22.2.6 GPIO_PinSpeed . . . . .                   | 1016 |
| 6.23 GPIO_TypeDef Struct Reference . . . . .       | 1016 |
| 6.23.1 Detailed Description . . . . .              | 1016 |
| 6.23.2 Member Data Documentation . . . . .         | 1017 |
| 6.23.2.1 AFR . . . . .                             | 1017 |
| 6.23.2.2 BSRR . . . . .                            | 1017 |
| 6.23.2.3 IDR . . . . .                             | 1017 |
| 6.23.2.4 LCKR . . . . .                            | 1017 |
| 6.23.2.5 MODER . . . . .                           | 1017 |
| 6.23.2.6 ODR . . . . .                             | 1017 |
| 6.23.2.7 OSPEEDR . . . . .                         | 1017 |
| 6.23.2.8 OTYPER . . . . .                          | 1018 |

---

|                                                     |      |
|-----------------------------------------------------|------|
| 6.23.2.9 PUPDR . . . . .                            | 1018 |
| 6.24 HASH_DIGEST_TypeDef Struct Reference . . . . . | 1018 |
| 6.24.1 Detailed Description . . . . .               | 1018 |
| 6.25 HASH_TypeDef Struct Reference . . . . .        | 1018 |
| 6.25.1 Detailed Description . . . . .               | 1019 |
| 6.26 I2C_TypeDef Struct Reference . . . . .         | 1019 |
| 6.26.1 Detailed Description . . . . .               | 1020 |
| 6.26.2 Member Data Documentation . . . . .          | 1020 |
| 6.26.2.1 CCR . . . . .                              | 1020 |
| 6.26.2.2 CR1 . . . . .                              | 1020 |
| 6.26.2.3 CR2 . . . . .                              | 1020 |
| 6.26.2.4 DR . . . . .                               | 1020 |
| 6.26.2.5 OAR1 . . . . .                             | 1020 |
| 6.26.2.6 OAR2 . . . . .                             | 1020 |
| 6.26.2.7 SR1 . . . . .                              | 1021 |
| 6.26.2.8 SR2 . . . . .                              | 1021 |
| 6.26.2.9 TRISE . . . . .                            | 1021 |
| 6.27 IPSR_Type Union Reference . . . . .            | 1021 |
| 6.27.1 Detailed Description . . . . .               | 1021 |
| 6.28 ITM_TypeDef Struct Reference . . . . .         | 1022 |
| 6.28.1 Detailed Description . . . . .               | 1022 |
| 6.29 IWDG_TypeDef Struct Reference . . . . .        | 1023 |
| 6.29.1 Detailed Description . . . . .               | 1023 |
| 6.30 LCD_t Struct Reference . . . . .               | 1023 |
| 6.30.1 Detailed Description . . . . .               | 1024 |
| 6.30.2 Member Data Documentation . . . . .          | 1024 |
| 6.30.2.1 D0_PIN . . . . .                           | 1024 |
| 6.30.2.2 D1_PIN . . . . .                           | 1024 |
| 6.30.2.3 D2_PIN . . . . .                           | 1024 |
| 6.30.2.4 D3_PIN . . . . .                           | 1025 |
| 6.30.2.5 D4_PIN . . . . .                           | 1025 |
| 6.30.2.6 D5_PIN . . . . .                           | 1025 |
| 6.30.2.7 D6_PIN . . . . .                           | 1025 |
| 6.30.2.8 D7_PIN . . . . .                           | 1025 |
| 6.30.2.9 Display_Mode . . . . .                     | 1025 |
| 6.30.2.10 EN_PIN . . . . .                          | 1025 |
| 6.30.2.11 Entry_Mode . . . . .                      | 1025 |
| 6.30.2.12 GPIO_PORT . . . . .                       | 1026 |
| 6.30.2.13 Mode . . . . .                            | 1026 |
| 6.30.2.14 Rows . . . . .                            | 1026 |
| 6.30.2.15 RS_PIN . . . . .                          | 1026 |
| 6.31 LED_cfg_t Struct Reference . . . . .           | 1026 |

|                                                    |      |
|----------------------------------------------------|------|
| 6.31.1 Member Data Documentation . . . . .         | 1027 |
| 6.31.1.1 LED_Mode . . . . .                        | 1027 |
| 6.31.1.2 LED_Pin . . . . .                         | 1027 |
| 6.31.1.3 LED_Port . . . . .                        | 1027 |
| 6.32 LTDC_Layer_TypeDef Struct Reference . . . . . | 1027 |
| 6.32.1 Detailed Description . . . . .              | 1028 |
| 6.33 LTDC_TypeDef Struct Reference . . . . .       | 1028 |
| 6.33.1 Detailed Description . . . . .              | 1029 |
| 6.34 NVIC_Type Struct Reference . . . . .          | 1029 |
| 6.34.1 Detailed Description . . . . .              | 1029 |
| 6.35 NVIC_TypeDef Struct Reference . . . . .       | 1029 |
| 6.35.1 Member Data Documentation . . . . .         | 1030 |
| 6.35.1.1 IABR . . . . .                            | 1030 |
| 6.35.1.2 ICER . . . . .                            | 1030 |
| 6.35.1.3 ICPR . . . . .                            | 1030 |
| 6.35.1.4 IP . . . . .                              | 1030 |
| 6.35.1.5 ISER . . . . .                            | 1030 |
| 6.35.1.6 ISPR . . . . .                            | 1030 |
| 6.35.1.7 RESERVED0 . . . . .                       | 1030 |
| 6.35.1.8 RESERVED1 . . . . .                       | 1031 |
| 6.35.1.9 RESERVED2 . . . . .                       | 1031 |
| 6.35.1.10 RESERVED3 . . . . .                      | 1031 |
| 6.35.1.11 RESERVED4 . . . . .                      | 1031 |
| 6.35.1.12 RESERVED5 . . . . .                      | 1031 |
| 6.35.1.13 STIR . . . . .                           | 1031 |
| 6.36 PWR_TypeDef Struct Reference . . . . .        | 1031 |
| 6.36.1 Detailed Description . . . . .              | 1032 |
| 6.37 RCC_TypeDef Struct Reference . . . . .        | 1032 |
| 6.37.1 Detailed Description . . . . .              | 1033 |
| 6.37.2 Member Data Documentation . . . . .         | 1033 |
| 6.37.2.1 AHB1ENR . . . . .                         | 1033 |
| 6.37.2.2 AHB1LPENR . . . . .                       | 1034 |
| 6.37.2.3 AHB1RSTR . . . . .                        | 1034 |
| 6.37.2.4 AHB2ENR . . . . .                         | 1034 |
| 6.37.2.5 AHB2LPENR . . . . .                       | 1034 |
| 6.37.2.6 AHB2RSTR . . . . .                        | 1034 |
| 6.37.2.7 APB1ENR . . . . .                         | 1034 |
| 6.37.2.8 APB1LPENR . . . . .                       | 1034 |
| 6.37.2.9 APB1RSTR . . . . .                        | 1034 |
| 6.37.2.10 APB2ENR . . . . .                        | 1035 |
| 6.37.2.11 APB2LPENR . . . . .                      | 1035 |
| 6.37.2.12 APB2RSTR . . . . .                       | 1035 |

---

|                                                     |      |
|-----------------------------------------------------|------|
| 6.37.2.13 BDCR . . . . .                            | 1035 |
| 6.37.2.14 CFGR . . . . .                            | 1035 |
| 6.37.2.15 CIR . . . . .                             | 1035 |
| 6.37.2.16 CR . . . . .                              | 1035 |
| 6.37.2.17 CSR . . . . .                             | 1035 |
| 6.37.2.18 DCKCFGREG . . . . .                       | 1036 |
| 6.37.2.19 PLLCFGREG . . . . .                       | 1036 |
| 6.37.2.20 PLLI2SCFGREG . . . . .                    | 1036 |
| 6.37.2.21 RESERVED0 . . . . .                       | 1036 |
| 6.37.2.22 RESERVED1 . . . . .                       | 1036 |
| 6.37.2.23 RESERVED2 . . . . .                       | 1036 |
| 6.37.2.24 RESERVED3 . . . . .                       | 1036 |
| 6.37.2.25 RESERVED4 . . . . .                       | 1036 |
| 6.37.2.26 RESERVED5 . . . . .                       | 1037 |
| 6.37.2.27 RESERVED6 . . . . .                       | 1037 |
| 6.37.2.28 RESERVED7 . . . . .                       | 1037 |
| 6.37.2.29 SSCGR . . . . .                           | 1037 |
| 6.38 RNG_TypeDef Struct Reference . . . . .         | 1037 |
| 6.38.1 Detailed Description . . . . .               | 1037 |
| 6.39 RTC_TypeDef Struct Reference . . . . .         | 1038 |
| 6.39.1 Detailed Description . . . . .               | 1039 |
| 6.40 S_I2C_Config_t Struct Reference . . . . .      | 1039 |
| 6.40.1 Detailed Description . . . . .               | 1039 |
| 6.40.2 Member Data Documentation . . . . .          | 1039 |
| 6.40.2.1 General_Call_Address_Detection . . . . .   | 1040 |
| 6.40.2.2 I2C_Ack_Conrol . . . . .                   | 1040 |
| 6.40.2.3 I2C_Mode . . . . .                         | 1040 |
| 6.40.2.4 I2C_Slave_address . . . . .                | 1040 |
| 6.40.2.5 I2C_Speed . . . . .                        | 1040 |
| 6.40.2.6 I2C_stretchmode . . . . .                  | 1040 |
| 6.40.2.7 P_Slave_Event_CallBack . . . . .           | 1040 |
| 6.41 S_I2C_Slave_address Struct Reference . . . . . | 1041 |
| 6.41.1 Detailed Description . . . . .               | 1041 |
| 6.41.2 Member Data Documentation . . . . .          | 1041 |
| 6.41.2.1 Enable_Dual_Address . . . . .              | 1041 |
| 6.41.2.2 I2C_Addressing_Mode . . . . .              | 1041 |
| 6.41.2.3 PrimaryAddress . . . . .                   | 1041 |
| 6.41.2.4 SecondaryAddress . . . . .                 | 1041 |
| 6.42 S_IRQ_SRC Struct Reference . . . . .           | 1042 |
| 6.42.1 Detailed Description . . . . .               | 1042 |
| 6.42.2 Member Data Documentation . . . . .          | 1042 |
| 6.42.2.1 ERRI . . . . .                             | 1042 |

---

|                                                   |      |
|---------------------------------------------------|------|
| 6.42.2.2 Reserved . . . . .                       | 1042 |
| 6.42.2.3 RXE . . . . .                            | 1042 |
| 6.42.2.4 TXE . . . . .                            | 1043 |
| 6.43 S_SPI_Config_t Struct Reference . . . . .    | 1043 |
| 6.43.1 Detailed Description . . . . .             | 1043 |
| 6.43.2 Member Data Documentation . . . . .        | 1043 |
| 6.43.2.1 Clock_Phase . . . . .                    | 1043 |
| 6.43.2.2 Clock_Polarity . . . . .                 | 1044 |
| 6.43.2.3 Communication_Mode . . . . .             | 1044 |
| 6.43.2.4 Device_Mode . . . . .                    | 1044 |
| 6.43.2.5 Frame_Format . . . . .                   | 1044 |
| 6.43.2.6 IRQ_Enable . . . . .                     | 1044 |
| 6.43.2.7 NSS . . . . .                            | 1044 |
| 6.43.2.8 P_IRQ_CallBack . . . . .                 | 1044 |
| 6.43.2.9 Payload_Length . . . . .                 | 1044 |
| 6.43.2.10 SPI_Prescaler . . . . .                 | 1045 |
| 6.44 SAI_Block_TypeDef Struct Reference . . . . . | 1045 |
| 6.45 SAI_TypeDef Struct Reference . . . . .       | 1045 |
| 6.45.1 Detailed Description . . . . .             | 1045 |
| 6.46 SCB_Type Struct Reference . . . . .          | 1046 |
| 6.46.1 Detailed Description . . . . .             | 1046 |
| 6.47 SCB_TypeDef Struct Reference . . . . .       | 1046 |
| 6.47.1 Member Data Documentation . . . . .        | 1047 |
| 6.47.1.1 AIRCR . . . . .                          | 1047 |
| 6.47.1.2 BFAR . . . . .                           | 1047 |
| 6.47.1.3 CCR . . . . .                            | 1047 |
| 6.47.1.4 CFSR . . . . .                           | 1047 |
| 6.47.1.5 CPUID . . . . .                          | 1047 |
| 6.47.1.6 HFSR . . . . .                           | 1047 |
| 6.47.1.7 ICSR . . . . .                           | 1047 |
| 6.47.1.8 MMAR . . . . .                           | 1048 |
| 6.47.1.9 RESERVED . . . . .                       | 1048 |
| 6.47.1.10 SCR . . . . .                           | 1048 |
| 6.47.1.11 SHCSR . . . . .                         | 1048 |
| 6.47.1.12 SHP . . . . .                           | 1048 |
| 6.47.1.13 VTOR . . . . .                          | 1048 |
| 6.48 SCnSCB_Type Struct Reference . . . . .       | 1048 |
| 6.48.1 Detailed Description . . . . .             | 1049 |
| 6.49 SDIO_TypeDef Struct Reference . . . . .      | 1049 |
| 6.49.1 Detailed Description . . . . .             | 1049 |
| 6.50 SPI_TypeDef Struct Reference . . . . .       | 1050 |
| 6.50.1 Detailed Description . . . . .             | 1050 |

|                                                 |      |
|-------------------------------------------------|------|
| 6.50.2 Member Data Documentation . . . . .      | 1050 |
| 6.50.2.1 CR1 . . . . .                          | 1050 |
| 6.50.2.2 CR2 . . . . .                          | 1051 |
| 6.50.2.3 CRCPR . . . . .                        | 1051 |
| 6.50.2.4 DR . . . . .                           | 1051 |
| 6.50.2.5 I2SCFGR . . . . .                      | 1051 |
| 6.50.2.6 I2SPR . . . . .                        | 1051 |
| 6.50.2.7 RXCRCR . . . . .                       | 1051 |
| 6.50.2.8 SR . . . . .                           | 1051 |
| 6.50.2.9 TXCRCR . . . . .                       | 1052 |
| 6.51 STK_config_t Struct Reference . . . . .    | 1052 |
| 6.51.1 Detailed Description . . . . .           | 1052 |
| 6.51.2 Member Data Documentation . . . . .      | 1052 |
| 6.51.2.1 Callback_Function . . . . .            | 1052 |
| 6.51.2.2 clock_config . . . . .                 | 1052 |
| 6.51.2.3 interrupt_config . . . . .             | 1053 |
| 6.51.2.4 reload_value . . . . .                 | 1053 |
| 6.51.2.5 running_mode . . . . .                 | 1053 |
| 6.52 STK_TypeDef Struct Reference . . . . .     | 1053 |
| 6.52.1 Member Data Documentation . . . . .      | 1053 |
| 6.52.1.1 CALIB . . . . .                        | 1053 |
| 6.52.1.2 CTRL . . . . .                         | 1053 |
| 6.52.1.3 LOAD . . . . .                         | 1054 |
| 6.52.1.4 VAL . . . . .                          | 1054 |
| 6.53 SYSCFG_RegDef_t Struct Reference . . . . . | 1054 |
| 6.53.1 Member Data Documentation . . . . .      | 1054 |
| 6.53.1.1 CFGR . . . . .                         | 1054 |
| 6.53.1.2 CMPCR . . . . .                        | 1054 |
| 6.53.1.3 EXTICR . . . . .                       | 1055 |
| 6.53.1.4 MEMRMP . . . . .                       | 1055 |
| 6.53.1.5 PMC . . . . .                          | 1055 |
| 6.53.1.6 RESERVED1 . . . . .                    | 1055 |
| 6.53.1.7 RESERVED2 . . . . .                    | 1055 |
| 6.54 SYSCFG_TypeDef Struct Reference . . . . .  | 1055 |
| 6.54.1 Detailed Description . . . . .           | 1056 |
| 6.55 SysTick_Type Struct Reference . . . . .    | 1056 |
| 6.55.1 Detailed Description . . . . .           | 1056 |
| 6.56 TIM1_TypeDef Struct Reference . . . . .    | 1056 |
| 6.56.1 Member Data Documentation . . . . .      | 1057 |
| 6.56.1.1 ARR . . . . .                          | 1057 |
| 6.56.1.2 BDTR . . . . .                         | 1057 |
| 6.56.1.3 CCER . . . . .                         | 1057 |

---

|                                                     |             |
|-----------------------------------------------------|-------------|
| 6.56.1.4 CCMR1 . . . . .                            | 1057        |
| 6.56.1.5 CCMR2 . . . . .                            | 1057        |
| 6.56.1.6 CCR1 . . . . .                             | 1057        |
| 6.56.1.7 CCR2 . . . . .                             | 1057        |
| 6.56.1.8 CCR3 . . . . .                             | 1058        |
| 6.56.1.9 CCR4 . . . . .                             | 1058        |
| 6.56.1.10 CNT . . . . .                             | 1058        |
| 6.56.1.11 CR1 . . . . .                             | 1058        |
| 6.56.1.12 CR2 . . . . .                             | 1058        |
| 6.56.1.13 DCR . . . . .                             | 1058        |
| 6.56.1.14 DIER . . . . .                            | 1058        |
| 6.56.1.15 DMAR . . . . .                            | 1058        |
| 6.56.1.16 EGR . . . . .                             | 1059        |
| 6.56.1.17 OR . . . . .                              | 1059        |
| 6.56.1.18 PSC . . . . .                             | 1059        |
| 6.56.1.19 RCR . . . . .                             | 1059        |
| 6.56.1.20 SMCR . . . . .                            | 1059        |
| 6.56.1.21 SR . . . . .                              | 1059        |
| 6.57 TIM_TypeDef Struct Reference . . . . .         | 1059        |
| 6.57.1 Detailed Description . . . . .               | 1060        |
| 6.58 TPI_TypeDef Struct Reference . . . . .         | 1060        |
| 6.58.1 Detailed Description . . . . .               | 1061        |
| 6.59 USART_cfg_t Struct Reference . . . . .         | 1061        |
| 6.59.1 Detailed Description . . . . .               | 1062        |
| 6.60 USART_TypeDef Struct Reference . . . . .       | 1062        |
| 6.60.1 Detailed Description . . . . .               | 1062        |
| 6.60.2 Member Data Documentation . . . . .          | 1062        |
| 6.60.2.1 BRR . . . . .                              | 1063        |
| 6.60.2.2 CR1 . . . . .                              | 1063        |
| 6.60.2.3 CR2 . . . . .                              | 1063        |
| 6.60.2.4 CR3 . . . . .                              | 1063        |
| 6.60.2.5 DR . . . . .                               | 1063        |
| 6.60.2.6 GTPR . . . . .                             | 1063        |
| 6.60.2.7 SR . . . . .                               | 1063        |
| 6.61 WWDG_TypeDef Struct Reference . . . . .        | 1064        |
| 6.61.1 Detailed Description . . . . .               | 1064        |
| 6.62 xPSR_TypeDef Union Reference . . . . .         | 1064        |
| 6.62.1 Detailed Description . . . . .               | 1064        |
| <b>7 File Documentation</b>                         | <b>1065</b> |
| 7.1 bsp/Inc/eeprom_flash.h File Reference . . . . . | 1065        |
| 7.1.1 Detailed Description . . . . .                | 1066        |

|                                                                        |      |
|------------------------------------------------------------------------|------|
| 7.2 bsp/Inc/keypad_driver.h File Reference . . . . .                   | 1067 |
| 7.2.1 Detailed Description . . . . .                                   | 1068 |
| 7.3 bsp/Inc/lcd_driver.h File Reference . . . . .                      | 1069 |
| 7.3.1 Detailed Description . . . . .                                   | 1072 |
| 7.4 bsp/Inc/led_driver.h File Reference . . . . .                      | 1072 |
| 7.4.1 Detailed Description . . . . .                                   | 1074 |
| 7.5 bsp/Src/eeprom_flash.c File Reference . . . . .                    | 1074 |
| 7.5.1 Detailed Description . . . . .                                   | 1075 |
| 7.6 bsp/Src/keypad_driver.c File Reference . . . . .                   | 1075 |
| 7.6.1 Detailed Description . . . . .                                   | 1076 |
| 7.7 bsp/Src/lcd_driver.c File Reference . . . . .                      | 1076 |
| 7.7.1 Detailed Description . . . . .                                   | 1077 |
| 7.8 bsp/Src/led_driver.c File Reference . . . . .                      | 1078 |
| 7.8.1 Detailed Description . . . . .                                   | 1078 |
| 7.9 CMSIS/Inc/core_cm4.h File Reference . . . . .                      | 1079 |
| 7.9.1 Detailed Description . . . . .                                   | 1089 |
| 7.10 CMSIS/Inc/core_cmFunc.h File Reference . . . . .                  | 1089 |
| 7.10.1 Detailed Description . . . . .                                  | 1089 |
| 7.11 CMSIS/Inc/core_cmlInstr.h File Reference . . . . .                | 1090 |
| 7.11.1 Detailed Description . . . . .                                  | 1090 |
| 7.12 CMSIS/Inc/core_cmSimd.h File Reference . . . . .                  | 1091 |
| 7.12.1 Detailed Description . . . . .                                  | 1091 |
| 7.13 CMSIS/Inc/stm32f4xx.h File Reference . . . . .                    | 1092 |
| 7.13.1 Detailed Description . . . . .                                  | 1183 |
| 7.14 CMSIS/Inc/system_stm32f4xx.h File Reference . . . . .             | 1184 |
| 7.14.1 Detailed Description . . . . .                                  | 1185 |
| 7.15 drivers/Inc/Platform_Types.h File Reference . . . . .             | 1185 |
| 7.15.1 Detailed Description . . . . .                                  | 1187 |
| 7.16 drivers/Inc/stm32f401xx.h File Reference . . . . .                | 1187 |
| 7.16.1 Detailed Description . . . . .                                  | 1196 |
| 7.17 drivers/Inc/stm32f401xx_gpio_driver.h File Reference . . . . .    | 1197 |
| 7.17.1 Detailed Description . . . . .                                  | 1199 |
| 7.18 drivers/Inc/stm32f401xx_i2c_driver.h File Reference . . . . .     | 1200 |
| 7.18.1 Detailed Description . . . . .                                  | 1202 |
| 7.19 drivers/Inc/stm32f401xx_nvic_driver.h File Reference . . . . .    | 1202 |
| 7.19.1 Detailed Description . . . . .                                  | 1206 |
| 7.20 drivers/Inc/stm32f401xx_rcc_driver.h File Reference . . . . .     | 1207 |
| 7.20.1 Detailed Description . . . . .                                  | 1208 |
| 7.21 drivers/Inc/stm32f401xx_spi_driver.h File Reference . . . . .     | 1209 |
| 7.21.1 Detailed Description . . . . .                                  | 1211 |
| 7.22 drivers/Inc/stm32f401xx_systick_driver.h File Reference . . . . . | 1211 |
| 7.22.1 Detailed Description . . . . .                                  | 1212 |

|                                                                       |      |
|-----------------------------------------------------------------------|------|
| 7.23 drivers/Inc/stm32f401xx_timer_driver.h File Reference . . . . .  | 1213 |
| 7.23.1 Detailed Description . . . . .                                 | 1214 |
| 7.24 drivers/Inc/stm32f401xx_usart_driver.h File Reference . . . . .  | 1215 |
| 7.24.1 Detailed Description . . . . .                                 | 1217 |
| 7.25 drivers/Src/stm32f401xx_gpio_driver.c File Reference . . . . .   | 1217 |
| 7.25.1 Detailed Description . . . . .                                 | 1218 |
| 7.26 drivers/Src/stm32f401xx_i2c_driver.c File Reference . . . . .    | 1218 |
| 7.26.1 Detailed Description . . . . .                                 | 1219 |
| 7.26.2 Macro Definition Documentation . . . . .                       | 1220 |
| 7.26.2.1 I2C1_Index . . . . .                                         | 1220 |
| 7.26.2.2 I2C2_Index . . . . .                                         | 1220 |
| 7.26.3 Variable Documentation . . . . .                               | 1220 |
| 7.26.3.1 Global_I2C_Config . . . . .                                  | 1220 |
| 7.27 drivers/Src/stm32f401xx_spi_driver.c File Reference . . . . .    | 1220 |
| 7.27.1 Detailed Description . . . . .                                 | 1221 |
| 7.27.2 Macro Definition Documentation . . . . .                       | 1222 |
| 7.27.2.1 SPI1_Index . . . . .                                         | 1222 |
| 7.27.2.2 SPI2_Index . . . . .                                         | 1222 |
| 7.27.2.3 SPI_SR_RXNE . . . . .                                        | 1222 |
| 7.27.2.4 SPI_SR_TXE . . . . .                                         | 1222 |
| 7.27.3 Function Documentation . . . . .                               | 1222 |
| 7.27.3.1 SPI1_IRQHandler() . . . . .                                  | 1222 |
| 7.27.3.2 SPI2_IRQHandler() . . . . .                                  | 1223 |
| 7.27.4 Variable Documentation . . . . .                               | 1223 |
| 7.27.4.1 Global_SPI_Config . . . . .                                  | 1223 |
| 7.28 Inc/app_states.h File Reference . . . . .                        | 1223 |
| 7.28.1 Detailed Description . . . . .                                 | 1225 |
| 7.29 Inc/ecu.h File Reference . . . . .                               | 1225 |
| 7.29.1 Detailed Description . . . . .                                 | 1227 |
| 7.30 Src/app_states.c File Reference . . . . .                        | 1228 |
| 7.30.1 Detailed Description . . . . .                                 | 1229 |
| 7.31 Src/ecu.c File Reference . . . . .                               | 1229 |
| 7.31.1 Detailed Description . . . . .                                 | 1230 |
| 7.32 Src/sysmem.c File Reference . . . . .                            | 1231 |
| 7.32.1 Detailed Description . . . . .                                 | 1232 |
| 7.32.2 Function Documentation . . . . .                               | 1232 |
| 7.32.2.1 _sbrk() . . . . .                                            | 1232 |
| 7.33 Src/system_stm32f4xx.c File Reference . . . . .                  | 1233 |
| 7.33.1 Detailed Description . . . . .                                 | 1234 |
| 7.33.2 5. This file configures the system clock as follows: . . . . . | 1234 |
| 7.33.2.1 Supported STM32F40xxx/41xxx devices . . . . .                | 1235 |
| 7.33.2.2 System Clock source   PLL (HSE) . . . . .                    | 1235 |

---

|                                                       |      |
|-------------------------------------------------------|------|
| 7.33.2.3 SYSCLK(Hz)   168000000                       | 1235 |
| 7.33.2.4 HCLK(Hz)   168000000                         | 1235 |
| 7.33.2.5 AHB Prescaler   1                            | 1235 |
| 7.33.2.6 APB1 Prescaler   4                           | 1235 |
| 7.33.2.7 APB2 Prescaler   2                           | 1235 |
| 7.33.2.8 HSE Frequency(Hz)   25000000                 | 1235 |
| 7.33.2.9 PLL_M   25                                   | 1235 |
| 7.33.2.10 PLL_N   336                                 | 1235 |
| 7.33.2.11 PLL_P   2                                   | 1235 |
| 7.33.2.12 PLL_Q   7                                   | 1235 |
| 7.33.2.13 PLLI2S_N   NA                               | 1235 |
| 7.33.2.14 PLLI2S_R   NA                               | 1235 |
| 7.33.2.15 I2S input clock   NA                        | 1235 |
| 7.33.2.16 VDD(V)   3.3                                | 1235 |
| 7.33.2.17 Main regulator output voltage   Scale1 mode | 1235 |
| 7.33.2.18 Flash Latency(WS)   5                       | 1235 |
| 7.33.2.19 Prefetch Buffer   ON                        | 1235 |
| 7.33.2.20 Instruction cache   ON                      | 1235 |
| 7.33.2.21 Data cache   ON                             | 1235 |
| 7.33.2.22 SDIO and RNG clock                          | 1236 |
| 7.33.3 =====                                          | 1236 |
| 7.33.3.1 Supported STM32F42xxx/43xxx devices          | 1236 |
| 7.33.3.2 System Clock source   PLL (HSE)              | 1236 |
| 7.33.3.3 SYSCLK(Hz)   180000000                       | 1236 |
| 7.33.3.4 HCLK(Hz)   180000000                         | 1236 |
| 7.33.3.5 AHB Prescaler   1                            | 1236 |
| 7.33.3.6 APB1 Prescaler   4                           | 1236 |
| 7.33.3.7 APB2 Prescaler   2                           | 1236 |
| 7.33.3.8 HSE Frequency(Hz)   25000000                 | 1236 |
| 7.33.3.9 PLL_M   25                                   | 1236 |
| 7.33.3.10 PLL_N   360                                 | 1236 |
| 7.33.3.11 PLL_P   2                                   | 1236 |
| 7.33.3.12 PLL_Q   7                                   | 1236 |
| 7.33.3.13 PLLI2S_N   NA                               | 1236 |
| 7.33.3.14 PLLI2S_R   NA                               | 1236 |
| 7.33.3.15 I2S input clock   NA                        | 1236 |
| 7.33.3.16 VDD(V)   3.3                                | 1236 |
| 7.33.3.17 Main regulator output voltage   Scale1 mode | 1236 |
| 7.33.3.18 Flash Latency(WS)   5                       | 1236 |
| 7.33.3.19 Prefetch Buffer   ON                        | 1236 |
| 7.33.3.20 Instruction cache   ON                      | 1236 |
| 7.33.3.21 Data cache   ON                             | 1236 |

|                                                                 |             |
|-----------------------------------------------------------------|-------------|
| 7.33.3.22 SDIO and RNG clock   . . . . .                        | 1237        |
| <b>7.33.4 ======</b>                                            | <b>1237</b> |
| 7.33.4.1 Supported STM32F401xx devices . . . . .                | 1237        |
| 7.33.4.2 System Clock source   PLL (HSE) . . . . .              | 1237        |
| 7.33.4.3 SYCLK(Hz)   84000000 . . . . .                         | 1237        |
| 7.33.4.4 HCLK(Hz)   84000000 . . . . .                          | 1237        |
| 7.33.4.5 AHB Prescaler   1 . . . . .                            | 1237        |
| 7.33.4.6 APB1 Prescaler   2 . . . . .                           | 1237        |
| 7.33.4.7 APB2 Prescaler   1 . . . . .                           | 1237        |
| 7.33.4.8 HSE Frequency(Hz)   25000000 . . . . .                 | 1237        |
| 7.33.4.9 PLL_M   25 . . . . .                                   | 1237        |
| 7.33.4.10 PLL_N   336 . . . . .                                 | 1237        |
| 7.33.4.11 PLL_P   4 . . . . .                                   | 1237        |
| 7.33.4.12 PLL_Q   7 . . . . .                                   | 1237        |
| 7.33.4.13 PLLI2S_N   NA . . . . .                               | 1237        |
| 7.33.4.14 PLLI2S_R   NA . . . . .                               | 1237        |
| 7.33.4.15 I2S input clock   NA . . . . .                        | 1237        |
| 7.33.4.16 VDD(V)   3.3 . . . . .                                | 1237        |
| 7.33.4.17 Main regulator output voltage   Scale1 mode . . . . . | 1237        |
| 7.33.4.18 Flash Latency(WS)   2 . . . . .                       | 1237        |
| 7.33.4.19 Prefetch Buffer   ON . . . . .                        | 1237        |
| 7.33.4.20 Instruction cache   ON . . . . .                      | 1237        |
| 7.33.4.21 Data cache   ON . . . . .                             | 1237        |
| 7.33.4.22 SDIO and RNG clock   . . . . .                        | 1238        |
| <b>7.33.5 ======</b>                                            | <b>1238</b> |
| 7.33.5.1 Supported STM32F411xx/STM32F410xx devices . . . . .    | 1238        |
| 7.33.5.2 System Clock source   PLL (HSI) . . . . .              | 1238        |
| 7.33.5.3 SYCLK(Hz)   100000000 . . . . .                        | 1238        |
| 7.33.5.4 HCLK(Hz)   100000000 . . . . .                         | 1238        |
| 7.33.5.5 AHB Prescaler   1 . . . . .                            | 1238        |
| 7.33.5.6 APB1 Prescaler   2 . . . . .                           | 1238        |
| 7.33.5.7 APB2 Prescaler   1 . . . . .                           | 1238        |
| 7.33.5.8 HSI Frequency(Hz)   16000000 . . . . .                 | 1238        |
| 7.33.5.9 PLL_M   16 . . . . .                                   | 1238        |
| 7.33.5.10 PLL_N   400 . . . . .                                 | 1238        |
| 7.33.5.11 PLL_P   4 . . . . .                                   | 1238        |
| 7.33.5.12 PLL_Q   7 . . . . .                                   | 1238        |
| 7.33.5.13 PLLI2S_N   NA . . . . .                               | 1238        |
| 7.33.5.14 PLLI2S_R   NA . . . . .                               | 1238        |
| 7.33.5.15 I2S input clock   NA . . . . .                        | 1238        |
| 7.33.5.16 VDD(V)   3.3 . . . . .                                | 1238        |
| 7.33.5.17 Main regulator output voltage   Scale1 mode . . . . . | 1238        |

---

|                                                                 |      |
|-----------------------------------------------------------------|------|
| 7.33.5.18 Flash Latency(WS)   3 . . . . .                       | 1238 |
| 7.33.5.19 Prefetch Buffer   ON . . . . .                        | 1238 |
| 7.33.5.20 Instruction cache   ON . . . . .                      | 1238 |
| 7.33.5.21 Data cache   ON . . . . .                             | 1238 |
| 7.33.5.22 SDIO and RNG clock   . . . . .                        | 1239 |
| 7.33.6 ===== . . . . .                                          | 1239 |
| 7.33.6.1 Supported STM32F446xx devices . . . . .                | 1239 |
| 7.33.6.2 System Clock source   PLL (HSE) . . . . .              | 1239 |
| 7.33.6.3 SYSCLK(Hz)   180000000 . . . . .                       | 1239 |
| 7.33.6.4 HCLK(Hz)   180000000 . . . . .                         | 1239 |
| 7.33.6.5 AHB Prescaler   1 . . . . .                            | 1239 |
| 7.33.6.6 APB1 Prescaler   4 . . . . .                           | 1239 |
| 7.33.6.7 APB2 Prescaler   2 . . . . .                           | 1239 |
| 7.33.6.8 HSE Frequency(Hz)   8000000 . . . . .                  | 1239 |
| 7.33.6.9 PLL_M   8 . . . . .                                    | 1239 |
| 7.33.6.10 PLL_N   360 . . . . .                                 | 1239 |
| 7.33.6.11 PLL_P   2 . . . . .                                   | 1239 |
| 7.33.6.12 PLL_Q   7 . . . . .                                   | 1239 |
| 7.33.6.13 PLL_R   NA . . . . .                                  | 1239 |
| 7.33.6.14 PLLI2S_M   NA . . . . .                               | 1239 |
| 7.33.6.15 PLLI2S_N   NA . . . . .                               | 1239 |
| 7.33.6.16 PLLI2S_P   NA . . . . .                               | 1239 |
| 7.33.6.17 PLLI2S_Q   NA . . . . .                               | 1239 |
| 7.33.6.18 PLLI2S_R   NA . . . . .                               | 1239 |
| 7.33.6.19 I2S input clock   NA . . . . .                        | 1239 |
| 7.33.6.20 VDD(V)   3.3 . . . . .                                | 1239 |
| 7.33.6.21 Main regulator output voltage   Scale1 mode . . . . . | 1239 |
| 7.33.6.22 Flash Latency(WS)   5 . . . . .                       | 1239 |
| 7.33.6.23 Prefetch Buffer   ON . . . . .                        | 1239 |
| 7.33.6.24 Instruction cache   ON . . . . .                      | 1239 |
| 7.33.6.25 Data cache   ON . . . . .                             | 1239 |
| 7.33.6.26 SDIO and RNG clock   . . . . .                        | 1240 |

## **Chapter 1**

# **PIR-Sensor-Library-for-Proteus**



# Chapter 2

## Module Index

### 2.1 Modules

Here is a list of all modules:

|                                                 |     |
|-------------------------------------------------|-----|
| AT24C1024B EEPROM Driver . . . . .              | 15  |
| EEPROM Constants . . . . .                      | 15  |
| API Function Prototypes . . . . .               | 16  |
| KEYPAD Driver . . . . .                         | 18  |
| API Function Prototypes . . . . .               | 20  |
| LCD Driver . . . . .                            | 22  |
| LCD Commands . . . . .                          | 23  |
| LCD Row Positions . . . . .                     | 24  |
| API Function Prototypes . . . . .               | 25  |
| LED Driver . . . . .                            | 31  |
| Enum for specifying the LED mode. . . . .       | 32  |
| Structure for configuring an LED. . . . .       | 33  |
| API Function Prototypes . . . . .               | 33  |
| SERVO MOTOR Driver . . . . .                    | 37  |
| Macros for the servo motor directions . . . . . | 38  |
| API Function Prototypes . . . . .               | 38  |
| Platform Standard Types . . . . .               | 148 |
| STM32F401xx MCU Header File . . . . .           | 156 |
| Memory Base Addresses . . . . .                 | 157 |
| Cortex-M4 Peripherals Base Addresses . . . . .  | 157 |
| AHB Peripherals Base Addresses . . . . .        | 158 |
| APB2 Peripherals Base Addresses . . . . .       | 158 |
| APB1 Peripherals Base Addresses . . . . .       | 159 |
| Peripheral Register Definitions . . . . .       | 160 |
| NVIC Register Map . . . . .                     | 161 |
| SCB Register Map . . . . .                      | 162 |
| SysTick Timer Register Map . . . . .            | 162 |
| GPIO Register Map . . . . .                     | 163 |
| RCC Register Map . . . . .                      | 163 |
| EXTI Register Map . . . . .                     | 164 |
| SYSCFG Register Map . . . . .                   | 164 |
| USART Register Map . . . . .                    | 165 |
| SPI Register Map . . . . .                      | 165 |
| I2C Register Map . . . . .                      | 166 |

|                                                       |     |
|-------------------------------------------------------|-----|
| CRC Register Map . . . . .                            | 166 |
| TIM1 Register Map . . . . .                           | 167 |
| Peripheral Instances . . . . .                        | 167 |
| NVIC Instance . . . . .                               | 169 |
| SCB Instance . . . . .                                | 169 |
| SysTick Timer Instance . . . . .                      | 170 |
| GPIO Instances . . . . .                              | 171 |
| RCC Instance . . . . .                                | 172 |
| EXTI Instance . . . . .                               | 173 |
| SYSCFG Instance . . . . .                             | 174 |
| Timer Instances . . . . .                             | 174 |
| USART Instances . . . . .                             | 175 |
| SPI Instances . . . . .                               | 176 |
| I2C Instances . . . . .                               | 177 |
| CRC Instance . . . . .                                | 178 |
| I2C Registers . . . . .                               | 179 |
| I2C CR1 Register Bit Definitions . . . . .            | 180 |
| I2C CR2 Register Bit Definitions . . . . .            | 187 |
| I2C OAR2 Register Bit Definitions . . . . .           | 191 |
| I2C SR1 Register Bit Definitions . . . . .            | 192 |
| I2C SR2 Register Bit Definitions . . . . .            | 199 |
| I2C CCR Register Bit Definitions . . . . .            | 203 |
| I2C TRISE Register Bit Definitions . . . . .          | 205 |
| RCC Bit Position Definitions . . . . .                | 206 |
| RCC_CR Bit Position Definitions . . . . .             | 207 |
| RCC_PLLCFGR Bit Position Definitions . . . . .        | 210 |
| RCC_CFGR Bit Position Definitions . . . . .           | 211 |
| RCC_CIR Bit Position Definitions . . . . .            | 214 |
| RCC_AHB1RSTR Bit Position Definitions . . . . .       | 217 |
| RCC_AHB2RSTR Bit Position Definitions . . . . .       | 220 |
| RCC_AHB3RSTR Bit Position Definitions . . . . .       | 222 |
| RCC_APB1RSTR Bit Position Definitions . . . . .       | 222 |
| RCC_APB2RSTR Bit Position Definitions . . . . .       | 227 |
| RCC_AHB1LPENR Bit Position Definitions . . . . .      | 229 |
| RCC_AHB2LPENR Bit Position Definitions . . . . .      | 232 |
| RCC_AHB3LPENR Bit Position Definitions . . . . .      | 233 |
| RCC_APB1LPENR Bit Position Definitions . . . . .      | 234 |
| RCC_APB2LPENR Bit Position Definitions . . . . .      | 238 |
| RCC_BDCR Bit Position Definitions . . . . .           | 240 |
| RCC_CSR Bit Position Definitions . . . . .            | 242 |
| RCC_SSCGR Bit Position Definitions . . . . .          | 244 |
| RCC_PLLI2SCFGR Bit Position Definitions . . . . .     | 245 |
| GPIO Base Address to Code Conversion Macros . . . . . | 246 |
| GPIO Driver . . . . .                                 | 247 |
| GPIO Pin Numbers . . . . .                            | 248 |
| GPIO Pin Modes . . . . .                              | 249 |
| GPIO Pin Speeds . . . . .                             | 251 |
| GPIO Pin States . . . . .                             | 252 |
| GPIO Return Lock Status . . . . .                     | 253 |
| GPIO Pin Modes . . . . .                              | 254 |
| GPIO Output Speeds . . . . .                          | 255 |
| GPIO Pull-up/Pull-down Configurations . . . . .       | 257 |
| GPIO Output Types . . . . .                           | 258 |
| API Function Prototypes . . . . .                     | 259 |
| I2C Driver . . . . .                                  | 267 |
| I2C Speed Definitions . . . . .                       | 271 |
| I2C Stretch Mode Definitions . . . . .                | 273 |

|                                                   |     |
|---------------------------------------------------|-----|
| I2C Mode Definitions . . . . .                    | 273 |
| I2C Addressing Modes . . . . .                    | 274 |
| I2C Acknowledge Control Definitions . . . . .     | 275 |
| I2C General Call Enable Definitions . . . . .     | 276 |
| API Function Prototypes . . . . .                 | 277 |
| NVIC Driver . . . . .                             | 285 |
| NVIC Register Definitions . . . . .               | 287 |
| NVIC Configuration Macros . . . . .               | 287 |
| Interrupt Status . . . . .                        | 288 |
| Priority Groups . . . . .                         | 288 |
| Interrupt Priorities . . . . .                    | 289 |
| Interrupt Requests . . . . .                      | 290 |
| API Function Prototypes . . . . .                 | 291 |
| NVIC IRQ Enable/Disable Macros . . . . .          | 300 |
| RCC Driver . . . . .                              | 305 |
| Clock Source Selection . . . . .                  | 306 |
| Peripheral Selection . . . . .                    | 308 |
| API Function Prototypes . . . . .                 | 310 |
| SPI Driver . . . . .                              | 315 |
| SPI Mode Definitions . . . . .                    | 317 |
| SPI Communication Mode Definitions . . . . .      | 317 |
| SPI Payload Length Definitions . . . . .          | 318 |
| SPI Frame Format Definitions . . . . .            | 319 |
| SPI Clock Polarity Definitions . . . . .          | 320 |
| SPI Clock Phase Definitions . . . . .             | 321 |
| SPI NSS Definitions . . . . .                     | 322 |
| SPI Prescaler Definitions . . . . .               | 323 |
| SPI IRQ Enable Definitions . . . . .              | 325 |
| API Function Prototypes . . . . .                 | 326 |
| SYSTICK Driver . . . . .                          | 331 |
| SysTick Interrupt Configuration . . . . .         | 332 |
| SysTick Clock Configuration . . . . .             | 333 |
| SysTick Running Mode Configuration . . . . .      | 334 |
| API Function Prototypes . . . . .                 | 334 |
| TIMER Driver . . . . .                            | 339 |
| TIM2 Register group . . . . .                     | 340 |
| API Function Prototypes . . . . .                 | 341 |
| USART Driver . . . . .                            | 344 |
| Enumeration and Structures for USART . . . . .    | 344 |
| Macros for USART Configuration . . . . .          | 345 |
| API Function Prototypes . . . . .                 | 346 |
| Application States . . . . .                      | 350 |
| Includes . . . . .                                | 354 |
| State Macros . . . . .                            | 355 |
| Prototypes . . . . .                              | 356 |
| State Handlers . . . . .                          | 357 |
| ECU Definitions and APIs . . . . .                | 359 |
| Includes . . . . .                                | 354 |
| Enum representing the result of ID check. . . . . | 360 |
| Configuration Macros . . . . .                    | 360 |
| ECU APIs . . . . .                                | 361 |
| Functions_Declarations . . . . .                  | 369 |
| Global_Variables_Definitions . . . . .            | 370 |
| API_Definitions . . . . .                         | 371 |
| CMSIS . . . . .                                   | 379 |
| CMSIS Global Defines . . . . .                    | 42  |

|                                                       |     |
|-------------------------------------------------------|-----|
| Defines and Type Definitions . . . . .                | 42  |
| Status and Control Registers . . . . .                | 43  |
| Nested Vectored Interrupt Controller (NVIC) . . . . . | 49  |
| System Control Block (SCB) . . . . .                  | 50  |
| System Controls not in SCB (SCnSCB) . . . . .         | 67  |
| System Tick Timer (SysTick) . . . . .                 | 70  |
| Instrumentation Trace Macrocell (ITM) . . . . .       | 73  |
| Data Watchpoint and Trace (DWT) . . . . .             | 79  |
| Trace Port Interface (TPI) . . . . .                  | 89  |
| Core Debug Registers (CoreDebug) . . . . .            | 99  |
| Core Definitions . . . . .                            | 108 |
| Functions and Instructions Reference . . . . .        | 111 |
| NVIC Functions . . . . .                              | 112 |
| SysTick Functions . . . . .                           | 118 |
| ITM Functions . . . . .                               | 119 |
| CMSIS Core Register Access Functions . . . . .        | 147 |
| NVIC Functions . . . . .                              | 112 |
| SysTick Functions . . . . .                           | 118 |
| ITM Functions . . . . .                               | 119 |
| Status and Control Registers . . . . .                | 43  |
| Nested Vectored Interrupt Controller (NVIC) . . . . . | 49  |
| System Control Block (SCB) . . . . .                  | 50  |
| System Controls not in SCB (SCnSCB) . . . . .         | 67  |
| System Tick Timer (SysTick) . . . . .                 | 70  |
| Instrumentation Trace Macrocell (ITM) . . . . .       | 73  |
| Data Watchpoint and Trace (DWT) . . . . .             | 79  |
| Trace Port Interface (TPI) . . . . .                  | 89  |
| Core Debug Registers (CoreDebug) . . . . .            | 99  |
| Core Definitions . . . . .                            | 108 |
| Functions and Instructions Reference . . . . .        | 111 |
| NVIC Functions . . . . .                              | 112 |
| SysTick Functions . . . . .                           | 118 |
| ITM Functions . . . . .                               | 119 |
| CMSIS Core Register Access Functions . . . . .        | 147 |
| NVIC Functions . . . . .                              | 112 |
| SysTick Functions . . . . .                           | 118 |
| ITM Functions . . . . .                               | 119 |
| CMSIS Core Register Access Functions . . . . .        | 147 |
| CMSIS Core Instruction Interface . . . . .            | 148 |
| CMSIS SIMD Intrinsics . . . . .                       | 148 |
| Stm32f4xx . . . . .                                   | 519 |
| Library_configuration_section . . . . .               | 520 |
| Configuration_section_for_CMSIS . . . . .             | 522 |
| Exported_types . . . . .                              | 527 |
| Peripheral_registers_structures . . . . .             | 530 |
| Peripheral_memory_map . . . . .                       | 532 |
| Peripheral_declaration . . . . .                      | 536 |
| Exported_constants . . . . .                          | 539 |
| Peripheral_Registers_Bits_Definition . . . . .        | 539 |
| Exported_macro . . . . .                              | 989 |
| Stm32f4xx_system . . . . .                            | 990 |
| STM32F4xx_System_Includes . . . . .                   | 991 |
| STM32F4xx_System_Exported_types . . . . .             | 991 |
| STM32F4xx_System_Exported_Constants . . . . .         | 992 |
| STM32F4xx_System_Exported_Macros . . . . .            | 992 |
| STM32F4xx_System_Exported_Functions . . . . .         | 992 |
| STM32F4xx_System_Private_Includes . . . . .           | 994 |
| STM32F4xx_System_Private_TypesDefinitions . . . . .   | 994 |

|                                                       |     |
|-------------------------------------------------------|-----|
| STM32F4xx_System_Private_Defines . . . . .            | 995 |
| STM32F4xx_System_Private_Macros . . . . .             | 995 |
| STM32F4xx_System_Private_Variables . . . . .          | 996 |
| STM32F4xx_System_Private_FunctionPrototypes . . . . . | 996 |
| STM32F4xx_System_Private_Functions . . . . .          | 996 |



# Chapter 3

## Class Index

### 3.1 Class List

Here are the classes, structs, unions and interfaces with brief descriptions:

|                                                                       |      |
|-----------------------------------------------------------------------|------|
| <a href="#">ADC_Common_TypeDef</a> . . . . .                          | 999  |
| <a href="#">ADC_TypeDef</a>                                           |      |
| Analog to Digital Converter                                           |      |
| 999                                                                   |      |
| <a href="#">APSR_Type</a>                                             |      |
| Union type to access the Application Program Status Register (APSR)   | 1000 |
| <a href="#">CAN_FIFOMailBox_TypeDef</a>                               |      |
| Controller Area Network FIFOMailBox                                   | 1000 |
| <a href="#">CAN_FilterRegister_TypeDef</a>                            |      |
| Controller Area Network FilterRegister                                | 1001 |
| <a href="#">CAN_TxMailBox_TypeDef</a>                                 |      |
| Controller Area Network TxMailBox                                     | 1001 |
| <a href="#">CAN_TypeDef</a>                                           |      |
| Controller Area Network                                               | 1002 |
| <a href="#">CONTROL_Type</a>                                          |      |
| Union type to access the Control Registers (CONTROL)                  | 1003 |
| <a href="#">CoreDebug_Type</a>                                        |      |
| Structure type to access the Core Debug Register (CoreDebug)          | 1003 |
| <a href="#">CRC_TypeDef</a>                                           |      |
| CRC calculation unit                                                  | 1004 |
| <a href="#">CRYP_TypeDef</a>                                          |      |
| Crypto Processor                                                      | 1005 |
| <a href="#">DAC_TypeDef</a>                                           |      |
| Digital to Analog Converter                                           | 1006 |
| <a href="#">DBGMCU_TypeDef</a>                                        |      |
| Debug MCU                                                             | 1007 |
| <a href="#">DCMI_TypeDef</a>                                          |      |
| DCMI                                                                  | 1008 |
| <a href="#">DMA2D_TypeDef</a>                                         |      |
| DMA2D Controller                                                      | 1008 |
| <a href="#">DMA_Stream_TypeDef</a>                                    |      |
| DMA Controller                                                        | 1009 |
| <a href="#">DMA_TypeDef</a>                                           |      |
| Structure type to access the Data Watchpoint and Trace Register (DWT) | 1010 |
| <a href="#">DWT_Type</a>                                              |      |

|                            |                                                                                       |      |
|----------------------------|---------------------------------------------------------------------------------------|------|
| <b>ETH_TypeDef</b>         | Ethernet MAC . . . . .                                                                | 1011 |
| <b>EXTI_TypeDef</b>        | External Interrupt/Event Controller . . . . .                                         | 1012 |
| <b>FLASH_TypeDef</b>       | FLASH Registers . . . . .                                                             | 1014 |
| <b>GPIO_PinConfig_t</b>    | Configuration structure for GPIO pins . . . . .                                       | 1014 |
| <b>GPIO_TypeDef</b>        | General Purpose I/O . . . . .                                                         | 1016 |
| <b>HASH_DIGEST_TypeDef</b> | HASH_DIGEST . . . . .                                                                 | 1018 |
| <b>HASH_TypeDef</b>        | HASH . . . . .                                                                        | 1018 |
| <b>I2C_TypeDef</b>         | Inter-integrated Circuit Interface . . . . .                                          | 1019 |
| <b>IPSR_Type</b>           | Union type to access the Interrupt Program Status Register (IPSR) . . . . .           | 1021 |
| <b>ITM_Type</b>            | Structure type to access the Instrumentation Trace Macrocell Register (ITM) . . . . . | 1022 |
| <b>IWDG_TypeDef</b>        | Independent WATCHDOG . . . . .                                                        | 1023 |
| <b>LCD_t</b>               | Structure for configuring the LCD . . . . .                                           | 1023 |
| <b>LED_cfg_t</b>           | . . . . .                                                                             | 1026 |
| <b>LTDC_Layer_TypeDef</b>  | LCD-TFT Display layer x Controller . . . . .                                          | 1027 |
| <b>LTDC_TypeDef</b>        | LCD-TFT Display Controller . . . . .                                                  | 1028 |
| <b>NVIC_Type</b>           | Structure type to access the Nested Vectored Interrupt Controller (NVIC) . . . . .    | 1029 |
| <b>NVIC_TypeDef</b>        | . . . . .                                                                             | 1029 |
| <b>PWR_TypeDef</b>         | Power Control . . . . .                                                               | 1031 |
| <b>RCC_TypeDef</b>         | Reset and Clock Control . . . . .                                                     | 1032 |
| <b>RNG_TypeDef</b>         | RNG . . . . .                                                                         | 1037 |
| <b>RTC_TypeDef</b>         | Real-Time Clock . . . . .                                                             | 1038 |
| <b>S_I2C_Config_t</b>      | Structure for I2C configuration . . . . .                                             | 1039 |
| <b>S_I2C_Slave_address</b> | Structure for I2C slave address configuration . . . . .                               | 1041 |
| <b>S_IRQ_SRC</b>           | Structure to identify the source of SPI interrupts . . . . .                          | 1042 |
| <b>S_SPI_Config_t</b>      | Configuration structure for SPI . . . . .                                             | 1043 |
| <b>SAI_Block_TypeDef</b>   | . . . . .                                                                             | 1045 |
| <b>SAI_TypeDef</b>         | Serial Audio Interface . . . . .                                                      | 1045 |
| <b>SCB_Type</b>            | Structure type to access the System Control Block (SCB) . . . . .                     | 1046 |
| <b>SCB_TypeDef</b>         | . . . . .                                                                             | 1046 |
| <b>SCnSCB_Type</b>         | Structure type to access the System Control and ID Register not in the SCB . . . . .  | 1048 |
| <b>SDIO_TypeDef</b>        | SD host Interface . . . . .                                                           | 1049 |

|                                 |                                                                                                                  |      |
|---------------------------------|------------------------------------------------------------------------------------------------------------------|------|
| <a href="#">SPI_TypeDef</a>     | Serial Peripheral Interface . . . . .                                                                            | 1050 |
| <a href="#">STK_config_t</a>    | SysTick Configuration Structure Definition . . . . .                                                             | 1052 |
| <a href="#">STK_TypeDef</a>     | . . . . .                                                                                                        | 1053 |
| <a href="#">SYSCFG_RegDef_t</a> | . . . . .                                                                                                        | 1054 |
| <a href="#">SYSCFG_TypeDef</a>  | System configuration controller . . . . .                                                                        | 1055 |
| <a href="#">SysTick_Type</a>    | Structure type to access the System Timer (SysTick) . . . . .                                                    | 1056 |
| <a href="#">TIM1_TypeDef</a>    | . . . . .                                                                                                        | 1056 |
| <a href="#">TIM_TypeDef</a>     | TIM . . . . .                                                                                                    | 1059 |
| <a href="#">TPI_Type</a>        | Structure type to access the Trace Port Interface Register (TPI) . . . . .                                       | 1060 |
| <a href="#">USART_cfg_t</a>     | Configuration structure for USART (Universal Synchronous Asynchronous Receiver Transmitter) peripheral . . . . . | 1061 |
| <a href="#">USART_TypeDef</a>   | Universal Synchronous Asynchronous Receiver Transmitter . . . . .                                                | 1062 |
| <a href="#">WWDG_TypeDef</a>    | Window WATCHDOG . . . . .                                                                                        | 1064 |
| <a href="#">xPSR_Type</a>       | Union type to access the Special-Purpose Program Status Registers (xPSR) . . . . .                               | 1064 |



# Chapter 4

## File Index

### 4.1 File List

Here is a list of all documented files with brief descriptions:

|                              |                                                                                                                                                                                              |      |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| bsp/Inc/eeprom_flash.h       | Header file for EEPROM flash memory operations . . . . .                                                                                                                                     | 1065 |
| bsp/Inc/keypad_driver.h      | Header file for the STM32F401xx microcontroller keypad driver . . . . .                                                                                                                      | 1067 |
| bsp/Inc/lcd_driver.h         | Header file for the STM32F401xx microcontroller LCD driver . . . . .                                                                                                                         | 1069 |
| bsp/Inc/led_driver.h         | Header file for the STM32F401xx microcontroller LED driver . . . . .                                                                                                                         | 1072 |
| bsp/Inc/servo_motor_driver.h | . . . . .                                                                                                                                                                                    | ??   |
| bsp/Src/eeprom_flash.c       | Implementation of EEPROM flash memory operations for STM32F401xx MCU . . . . .                                                                                                               | 1074 |
| bsp/Src/keypad_driver.c      | Source file for the keypad driver, implementing functionality to initialize and read input from a keypad connected to the STM32F401xx MCU . . . . .                                          | 1075 |
| bsp/Src/lcd_driver.c         | Contains functions for controlling an LCD using an STM32F401xx MCU . . . . .                                                                                                                 | 1076 |
| bsp/Src/led_driver.c         | LED Driver Functions for STM32F401xx MCU . . . . .                                                                                                                                           | 1078 |
| CMSIS/Inc/core_cm4.h         | CMSIS Cortex-M4 Core Peripheral Access Layer Header File . . . . .                                                                                                                           | 1079 |
| CMSIS/Inc/core_cmFunc.h      | CMSIS Cortex-M Core Function Access Header File . . . . .                                                                                                                                    | 1089 |
| CMSIS/Inc/core_cmlInstr.h    | CMSIS Cortex-M Core Instruction Access Header File . . . . .                                                                                                                                 | 1090 |
| CMSIS/Inc/core_cmSimd.h      | CMSIS Cortex-M SIMD Header File . . . . .                                                                                                                                                    | 1091 |
| CMSIS/Inc/stm32f4xx.h        | CMSIS Cortex-M4 Device Peripheral Access Layer Header File. This file contains all the peripheral register's definitions, bits definitions and memory mapping for STM32F4xx devices.<br>1092 |      |
| CMSIS/Inc/stm32f4xx_it.h     | . . . . .                                                                                                                                                                                    | ??   |
| CMSIS/Inc/system_stm32f4xx.h | CMSIS Cortex-M4 Device System Source File for STM32F4xx devices.<br>1184                                                                                                                     |      |
| drivers/Inc/Platform_Types.h | Defines data types and macros for STM32F401xx microcontrollers . . . . .                                                                                                                     | 1185 |

|                                                                                                                                                                                                                                             |      |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| drivers/Inc/stm32f401xx.h                                                                                                                                                                                                                   |      |
| Header file containing all the necessary information about the STM32F401xx MCU . . . . .                                                                                                                                                    | 1187 |
| drivers/Inc/stm32f401xx_gpio_driver.h                                                                                                                                                                                                       |      |
| Header file for GPIO driver for STM32F401xx microcontroller . . . . .                                                                                                                                                                       | 1197 |
| drivers/Inc/stm32f401xx_i2c_driver.h                                                                                                                                                                                                        |      |
| Header file for STM32F401xx I2C driver . . . . .                                                                                                                                                                                            | 1200 |
| drivers/Inc/stm32f401xx_nvic_driver.h                                                                                                                                                                                                       |      |
| Header file for NVIC (Nested Vectored Interrupt Controller) driver for STM32F401xx microcontroller . . . . .                                                                                                                                | 1202 |
| drivers/Inc/stm32f401xx_rcc_driver.h                                                                                                                                                                                                        |      |
| Header file for RCC (Reset and Clock Control) driver for STM32F401xx MCU . . . . .                                                                                                                                                          | 1207 |
| drivers/Inc/stm32f401xx_spi_driver.h                                                                                                                                                                                                        |      |
| This file contains definitions and function prototypes for the STM32F401xx SPI driver . . . . .                                                                                                                                             | 1209 |
| drivers/Inc/stm32f401xx_systick_driver.h                                                                                                                                                                                                    |      |
| Header file for configuring and controlling the SysTick timer in the STM32F401xx MCU. This file contains the necessary structures, macros, and function prototypes for SysTick initialization, configuration, and handling delays . . . . . | 1211 |
| drivers/Inc/stm32f401xx_timer_driver.h                                                                                                                                                                                                      |      |
| Header file providing timer functionalities for the STM32F401xx MCU. This file contains the necessary definitions, macros, and functions to manage Timer 2 (TIM2) in the STM32F401xx microcontroller . . . . .                              | 1213 |
| drivers/Inc/stm32f401xx_usart_driver.h                                                                                                                                                                                                      |      |
| USART driver header file for STM32F401 series microcontrollers . . . . .                                                                                                                                                                    | 1215 |
| drivers/Src/stm32f401xx_gpio_driver.c                                                                                                                                                                                                       |      |
| GPIO driver for STM32F401xx microcontroller . . . . .                                                                                                                                                                                       | 1217 |
| drivers/Src/stm32f401xx_i2c_driver.c                                                                                                                                                                                                        |      |
| I2C Peripheral Driver Implementation for STM32F103C6 . . . . .                                                                                                                                                                              | 1218 |
| drivers/Src/stm32f401xx_spi_driver.c                                                                                                                                                                                                        |      |
| Contains the implementation of the SPI driver APIs for STM32F401 . . . . .                                                                                                                                                                  | 1220 |
| Inc/app_states.h                                                                                                                                                                                                                            |      |
| Header file containing definitions and macros for managing application states on the STM32F401xx MCU . . . . .                                                                                                                              | 1223 |
| Inc/ecu.h                                                                                                                                                                                                                                   |      |
| Header file containing all the necessary information about the STM32F401xx MCU . . . . .                                                                                                                                                    | 1225 |
| Src/app_states.c                                                                                                                                                                                                                            |      |
| Application state machine implementation for managing entry/exit gates and parking slots using the STM32F401xx MCU . . . . .                                                                                                                | 1228 |
| Src/ecu.c                                                                                                                                                                                                                                   |      |
| Header file containing all necessary information and functionality for managing STM32F401xx MCU-based peripherals . . . . .                                                                                                                 | 1229 |
| Src/sysmem.c                                                                                                                                                                                                                                |      |
| STM32CubeIDE System Memory calls file . . . . .                                                                                                                                                                                             | 1231 |
| Src/system_stm32f4xx.c                                                                                                                                                                                                                      |      |
| CMSIS Cortex-M4 Device Peripheral Access Layer System Source File. This file contains the system clock configuration for STM32F4xx devices . . . . .                                                                                        | 1233 |

# Chapter 5

## Module Documentation

### 5.1 AT24C1024B EEPROM Driver

AT24C1024B EEPROM driver for STM32F401xx MCUs.

Collaboration diagram for AT24C1024B EEPROM Driver:



#### Modules

- [EEPROM Constants](#)
- [API Function Prototypes](#)

#### 5.1.1 Detailed Description

AT24C1024B EEPROM driver for STM32F401xx MCUs.

### 5.2 EEPROM Constants

Collaboration diagram for EEPROM Constants:



## Macros

- `#define EEPROM_Slave_address 0x50`  
*AT24C1024B EEPROM slave address for I2C communication.*

### 5.2.1 Detailed Description

### 5.2.2 Macro Definition Documentation

#### 5.2.2.1 EEPROM\_Slave\_address

```
#define EEPROM_Slave_address 0x50
```

AT24C1024B EEPROM slave address for I2C communication.

This address is used to identify the AT24C1024B EEPROM device on the I2C bus.

## 5.3 API Function Prototypes

Collaboration diagram for API Function Prototypes:



## Functions

- `void EEPROM_Init (void)`  
*Initializes the EEPROM for communication.*
- `unsigned char EEPROM_Write_NBytes (unsigned int Memory_address, unsigned char *bytes, uint8_t Data_Length)`  
*Writes multiple bytes to the EEPROM.*
- `unsigned char EEPROM_Read_byte (unsigned int Memory_address, uint8_t *dataout, uint8_t datalen)`  
*Reads a byte from the EEPROM.*

### 5.3.1 Detailed Description

### 5.3.2 Function Documentation

### 5.3.2.1 EEPROM\_Init()

```
void EEPROM_Init (
    void )
```

Initializes the EEPROM for communication.

This function sets up the necessary configuration to communicate with the EEPROM over I2C. It should be called before any read or write operations are performed.

Initializes the EEPROM for communication.

This function configures the I2C1 peripheral of the STM32F401xx MCU for communication with the EEPROM. It sets up the I2C speed, address detection, and other relevant parameters.

- Configures PB6 as I2C1\_SCL and PB7 as I2C1\_SDA.
- Enables general call address detection.
- Enables acknowledgment control.
- Sets I2C speed to 100kHz.
- Configures I2C mode and stretch mode.

### 5.3.2.2 EEPROM\_Read\_byte()

```
unsigned char EEPROM_Read_byte (
    unsigned int Memory_address,
    uint8_t * dataout,
    uint8_t datalen )
```

Reads a byte from the EEPROM.

This function reads a single byte of data from a specified memory address in the EEPROM.

#### Parameters

|     |                       |                                                                                |
|-----|-----------------------|--------------------------------------------------------------------------------|
| in  | <i>Memory_address</i> | The address in the EEPROM from which to read the data.                         |
| out | <i>dataout</i>        | Pointer to a variable where the read byte will be stored.                      |
| in  | <i>datalen</i>        | The number of bytes to read. In this case, should be 1 for a single byte read. |

#### Returns

Status of the read operation. Returns 0 for success, non-zero for failure.

This function reads a single byte from a specified memory address in the EEPROM.

#### Parameters

|     |                       |                                                              |
|-----|-----------------------|--------------------------------------------------------------|
| in  | <i>Memory_address</i> | The address in the EEPROM from which to read the data.       |
| out | <i>dataout</i>        | Pointer to a variable where the read byte will be stored.    |
| in  | <i>datalen</i>        | The number of bytes to read. For this function, should be 1. |

Generated by Doxygen

**Returns**

Status of the read operation. Returns 0 for success.

< High byte of the memory address

< Low byte of the memory address

**5.3.2.3 EEPROM\_Write\_NBytes()**

```
unsigned char EEPROM_Write_NBytes (
    unsigned int Memory_address,
    unsigned char * bytes,
    uint8_t Data_Length )
```

Writes multiple bytes to the EEPROM.

This function writes a block of data to a specified memory address in the EEPROM.

**Parameters**

|    |                       |                                                                    |
|----|-----------------------|--------------------------------------------------------------------|
| in | <i>Memory_address</i> | The starting address in the EEPROM where the data will be written. |
| in | <i>bytes</i>          | Pointer to the data buffer to be written to the EEPROM.            |
| in | <i>Data_Length</i>    | The number of bytes to write to the EEPROM.                        |

**Returns**

Status of the write operation. Returns 0 for success, non-zero for failure.

Writes multiple bytes to the EEPROM.

This function writes multiple bytes to a specified memory address in the EEPROM.

**Parameters**

|    |                       |                                                                |
|----|-----------------------|----------------------------------------------------------------|
| in | <i>Memory_address</i> | The starting address in the EEPROM where data will be written. |
| in | <i>bytes</i>          | Pointer to the data buffer to be written to the EEPROM.        |
| in | <i>Data_Length</i>    | The number of bytes to write.                                  |

**Returns**

Status of the write operation. Returns 0 for success.

< High byte of the memory address

< Low byte of the memory address

**5.4 KEYPAD Driver**

Driver for interfacing with a keypad for STM32F401xx MCUs.

Collaboration diagram for KEYPAD Driver:



## Modules

- [API Function Prototypes](#)

## Macros

- `#define KEYPAD_PORT GPIOE`  
*Defines the GPIO port and pins for the keypad.*
- `#define KEYPAD_ROWS 4`
- `#define ROW0 GPIO_PIN_0`
- `#define ROW1 GPIO_PIN_1`
- `#define ROW2 GPIO_PIN_3`
- `#define ROW3 GPIO_PIN_4`
- `#define KEYPAD_COLS 3`
- `#define COL0 GPIO_PIN_5`
- `#define COL1 GPIO_PIN_6`
- `#define COL2 GPIO_PIN_7`

### 5.4.1 Detailed Description

Driver for interfacing with a keypad for STM32F401xx MCUs.

### 5.4.2 Macro Definition Documentation

#### 5.4.2.1 KEYPAD\_PORT

```
#define KEYPAD_PORT GPIOE
```

Defines the GPIO port and pins for the keypad.

The following macros are used to configure the keypad:

- KEYPAD\_PORT: GPIO port used for the keypad.
- KEYPAD\_ROWS: Number of rows in the keypad.
- ROW0, ROW1, ROW2, ROW3: GPIO pins for each row.
- KEYPAD\_COLS: Number of columns in the keypad.
- COL0, COL1, COL2: GPIO pins for each column.

## 5.5 API Function Prototypes

Collaboration diagram for API Function Prototypes:



### Functions

- void `keypad_init` (void)  
*Initializes the keypad.*
- `uint8 keypad_Get_Pressed_Key` (void)  
*Checks for a pressed key and returns its value.*

#### 5.5.1 Detailed Description

#### 5.5.2 Function Documentation

##### 5.5.2.1 `keypad_Get_Pressed_Key()`

```
uint8 keypad_Get_Pressed_Key (
    void )
```

Checks for a pressed key and returns its value.

This function scans the keypad to determine if any key is pressed and returns the corresponding key value. If no key is pressed, it returns the value 'F'.

##### Parameters

|     |             |  |
|-----|-------------|--|
| in  | <i>None</i> |  |
| out | <i>None</i> |  |

##### Returns

`uint8` Value of the pressed key, or 'F' if no key is pressed.

**Note**

None

Checks for a pressed key and returns its value.

This function scans the keypad to detect any pressed key and returns the corresponding character. If no key is pressed, it returns 'F'.

**Returns**

Value of the pressed key, or 'F' if no key is pressed.

### 5.5.2.2 keypad\_init()

```
void keypad_init (
    void )
```

Initializes the keypad.

This function configures the GPIO pins for the keypad as defined by the macros in the "Macros Configuration" section. It sets up the keypad for operation by initializing the necessary hardware.

**Parameters**

|     |             |  |
|-----|-------------|--|
| in  | <i>None</i> |  |
| out | <i>None</i> |  |

**Returns**

None

**Note**

User must define GPIO pins for rows and columns in Keypad\_PINS\_define.

Initializes the keypad.

This function sets up the GPIO pins for keypad rows as outputs and columns as inputs. It also sets the default state of the rows to low and configures pull-down resistors for the column pins.

**Returns**

None

**Note**

User must define GPIO pins for rows and columns in Keypad\_PINS\_define.

## 5.6 LCD Driver

LCD (Liquid Crystal Display) driver for STM32F401xx MCUs.

Collaboration diagram for LCD Driver:



### Modules

- [LCD Commands](#)
- [LCD Row Positions](#)
- [API Function Prototypes](#)

### Classes

- struct [LCD\\_t](#)  
*Structure for configuring the LCD.*

### Enumerations

- enum [LCD\\_MODE\\_t](#) { [LCD\\_8BIT](#) , [LCD\\_4BIT](#) }  
*Enum for specifying the LCD mode.*
- enum [LCD\\_ROWS\\_t](#) { [LCD\\_2ROWS](#) , [LCD\\_4ROWS](#) }  
*Enum for specifying the number of rows on the LCD.*

#### 5.6.1 Detailed Description

LCD (Liquid Crystal Display) driver for STM32F401xx MCUs.

#### 5.6.2 Enumeration Type Documentation

##### 5.6.2.1 LCD\_MODE\_t

```
enum LCD\_MODE\_t
```

Enum for specifying the LCD mode.

## Enumerator

|          |                                   |
|----------|-----------------------------------|
| LCD_8BIT | 8-bit mode for LCD communication. |
| LCD_4BIT | 4-bit mode for LCD communication. |

**5.6.2.2 LCD\_ROWS\_t**

```
enum LCD_ROWS_t
```

Enum for specifying the number of rows on the LCD.

## Enumerator

|           |                  |
|-----------|------------------|
| LCD_2ROWS | LCD with 2 rows. |
| LCD_4ROWS | LCD with 4 rows. |

**5.7 LCD Commands**

Collaboration diagram for LCD Commands:

**Macros**

- #define [LCD\\_CLEAR\\_DISPLAY](#) (0x01)  
*Command to clear the LCD display.*
- #define [LCD\\_RETURN\\_HOME](#) (0x02)  
*Command to return the cursor to the home position.*
- #define [LCD\\_ENTRY\\_MODE\\_DEC\\_SHIFT\\_OFF](#) (0x04)  
*Command to set the entry mode to decrement and shift off.*
- #define [LCD\\_ENTRY\\_MODE\\_DEC\\_SHIFT\\_ON](#) (0x05)  
*Command to set the entry mode to decrement and shift on.*
- #define [LCD\\_ENTRY\\_MODE\\_INC\\_SHIFT\\_OFF](#) (0x06)  
*Command to set the entry mode to increment and shift off.*
- #define [LCD\\_ENTRY\\_MODE\\_INC\\_SHIFT\\_ON](#) (0x07)  
*Command to set the entry mode to increment and shift on.*
- #define [LCD\\_CURSOR\\_MOVE\\_SHIFT\\_LEFT](#) (0x10)

- `#define LCD_CURSOR_MOVE_SHIFT_RIGHT (0x14)`

*Command to move the cursor left.*
- `#define LCD_DISPLAY_SHIFT_LEFT (0x18)`

*Command to move the cursor right.*
- `#define LCD_DISPLAY_SHIFT_RIGHT (0x1C)`

*Command to shift the display left.*
- `#define LCD_DISPLAY_ON_UNDERLINE_OFF_CURSOR_OFF (0x0C)`

*Command to turn on the display with underline off and cursor off.*
- `#define LCD_DISPLAY_ON_UNDERLINE_OFF_CURSOR_ON (0x0D)`

*Command to turn on the display with underline off and cursor on.*
- `#define LCD_DISPLAY_ON_UNDERLINE_ON_CURSOR_OFF (0x0E)`

*Command to turn on the display with underline on and cursor off.*
- `#define LCD_DISPLAY_ON_UNDERLINE_ON_CURSOR_ON (0x0F)`

*Command to turn on the display with underline on and cursor on.*
- `#define LCD_DISPLAY_OFF_CURSOR_OFF (0x08)`

*Command to turn off the display with cursor off.*
- `#define LCD_8BIT_MODE_2_LINE (0x38)`

*Command to set the display in 8-bit mode with 2 lines.*
- `#define LCD_4BIT_MODE_2_LINE (0x28)`

*Command to set the display in 4-bit mode with 2 lines.*

### 5.7.1 Detailed Description

## 5.8 LCD Row Positions

Collaboration diagram for LCD Row Positions:



## Macros

- `#define LCD_FIRST_ROW (0x80)`

*Command to set the cursor position to the first row.*
- `#define LCD_SECOND_ROW (0xC0)`

*Command to set the cursor position to the second row.*
- `#define LCD_THIRD_ROW (0x94)`

*Command to set the cursor position to the third row.*
- `#define LCD_FOURTH_ROW (0xD4)`

*Command to set the cursor position to the fourth row.*

### 5.8.1 Detailed Description

## 5.9 API Function Prototypes

Collaboration diagram for API Function Prototypes:



### Functions

- void `LCD_Init (LCD_t *LCD_cfg)`  
*Initializes the LCD with user-defined configurations.*
- void `LCD_Send_Command (LCD_t *LCD_cfg, uint8 command)`  
*Sends a command to the LCD to be executed.*
- void `LCD_Send_Char (LCD_t *LCD_cfg, uint8 Char)`  
*Sends a character to the LCD to be displayed.*
- void `LCD_Send_Char_Pos (LCD_t *LCD_cfg, uint8 Char, uint8 row, uint8 column)`  
*Sends a character to the LCD to be displayed at a specific location.*
- void `LCD_Send_String (LCD_t *LCD_cfg, uint8 *string)`  
*Sends a string to the LCD to be displayed.*
- void `LCD_Send_String_Pos (LCD_t *LCD_cfg, uint8 *string, uint8 row, uint8 column)`  
*Sends a string to the LCD to be displayed at a specific location.*
- void `LCD_Send_Enable_Signal (LCD_t *LCD_cfg)`  
*Sends an enable signal to the LCD.*
- void `LCD_Set_Cursor (LCD_t *LCD_cfg, uint8 row, uint8 column)`  
*Sets the location of the cursor on the LCD.*

### 5.9.1 Detailed Description

### 5.9.2 Function Documentation

#### 5.9.2.1 LCD\_Init()

```
void LCD_Init (
    LCD_t * LCD_cfg )
```

Initializes the LCD with user-defined configurations.

This function sets up the LCD based on the configuration specified in the provided structure. It initializes the LCD in the mode and row settings defined by the user.

**Parameters**

|    |                |                                                        |
|----|----------------|--------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration. |
|----|----------------|--------------------------------------------------------|

**Returns**

None

**Note**

User must set configurations using the [LCD Commands](#) macros.

Initializes the LCD with user-defined configurations.

**Parameters**

|    |                |                                                        |
|----|----------------|--------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration. |
|----|----------------|--------------------------------------------------------|

This function initializes the LCD by setting up the GPIO pins, sending function set commands, and configuring display and entry modes. It also clears the display.

**Note**

User must set configurations as defined in `LCD_CONFIG_define`.

**5.9.2.2 LCD\_Send\_Char()**

```
void LCD_Send_Char (
    LCD_t * LCD_cfg,
    uint8 Char )
```

Sends a character to the LCD to be displayed.

This function sends an ASCII character to the LCD to be displayed at the current cursor position.

**Parameters**

|    |                |                                                        |
|----|----------------|--------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration. |
| in | <i>Char</i>    | ASCII character to be displayed on the screen.         |

**Returns**

None

**Note**

None

**Parameters**

|    |                |                                                        |
|----|----------------|--------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration. |
| in | <i>Char</i>    | ASCII character to be displayed.                       |

This function sends a character to the LCD to be displayed. The character is sent in either 8-bit or 4-bit mode depending on the LCD configuration.

**5.9.2.3 LCD\_Send\_Char\_Pos()**

```
void LCD_Send_Char_Pos (
    LCD_t * LCD_cfg,
    uint8 Char,
    uint8 row,
    uint8 column )
```

Sends a character to the LCD to be displayed at a specific location.

This function sends an ASCII character to the LCD to be displayed at a specific row and column location.

**Parameters**

|    |                |                                                                                              |
|----|----------------|----------------------------------------------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration.                                       |
| in | <i>Char</i>    | ASCII character to be displayed on the screen.                                               |
| in | <i>row</i>     | Row number where the character should be displayed (see <a href="#">LCD Row Positions</a> ). |
| in | <i>column</i>  | Column number where the character should be displayed (1...16).                              |

**Returns**

None

**Note**

None

**Parameters**

|    |                |                                                                                          |
|----|----------------|------------------------------------------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration.                                   |
| in | <i>Char</i>    | ASCII character to be displayed on the screen.                                           |
| in | <i>row</i>     | Selects the row number of the displayed character ( <a href="#">LCD Row Positions</a> ). |
| in | <i>column</i>  | Selects the column number of the displayed character (1...16).                           |

**Returns**

None

This function sets the cursor to the specified row and column and sends the given character to the LCD for display.

#### 5.9.2.4 LCD\_Send\_Command()

```
void LCD_Send_Command (
    LCD_t * LCD_cfg,
    uint8 command )
```

Sends a command to the LCD to be executed.

This function sends a command to the LCD to perform a specific action, such as clearing the display or shifting the cursor.

##### Parameters

|    |                |                                                             |
|----|----------------|-------------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration.      |
| in | <i>command</i> | Command to be executed (see <a href="#">LCD Commands</a> ). |

##### Returns

None

##### Note

None

Sends a command to the LCD to be executed.

##### Parameters

|    |                |                                                                     |
|----|----------------|---------------------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration.              |
| in | <i>command</i> | Command to be executed as defined in <a href="#">LCD Commands</a> . |

This function sends a command to the LCD for execution. The command is sent in either 8-bit or 4-bit mode depending on the LCD configuration.

#### 5.9.2.5 LCD\_Send\_Enable\_Signal()

```
void LCD_Send_Enable_Signal (
    LCD_t * LCD_cfg )
```

Sends an enable signal to the LCD.

This function triggers the enable signal to the LCD, which is necessary for executing commands and data transfers. The signal is typically sent for a short duration to latch the data or command on the LCD.

##### Parameters

|    |                |                                                        |
|----|----------------|--------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration. |
|----|----------------|--------------------------------------------------------|

**Returns**

None

**Note**

This function assumes that the enable pin is properly configured in the `LCD_cfg` structure.

**Parameters**

|    |                      |                                                        |
|----|----------------------|--------------------------------------------------------|
| in | <code>LCD_cfg</code> | Pointer to the structure containing LCD configuration. |
|----|----------------------|--------------------------------------------------------|

**Returns**

None

This function generates an enable pulse for the LCD by toggling the enable pin.

### 5.9.2.6 `LCD_Send_String()`

```
void LCD_Send_String (
    LCD_t * LCD_cfg,
    uint8 * string )
```

Sends a string to the LCD to be displayed.

This function sends a string of characters to the LCD to be displayed from the current cursor position.

**Parameters**

|    |                      |                                                               |
|----|----------------------|---------------------------------------------------------------|
| in | <code>LCD_cfg</code> | Pointer to the structure containing LCD configuration.        |
| in | <code>string</code>  | Pointer to a string of characters to be displayed on the LCD. |

**Returns**

None

**Note**

None

**Parameters**

|    |                      |                                                               |
|----|----------------------|---------------------------------------------------------------|
| in | <code>LCD_cfg</code> | Pointer to the structure containing LCD configuration.        |
| in | <code>string</code>  | Pointer to a string of characters to be displayed on the LCD. |

**Returns**

None

This function sends a string to the LCD, character by character, until the null-terminator is encountered.

**5.9.2.7 LCD\_Send\_String\_Pos()**

```
void LCD_Send_String_Pos (
    LCD_t * LCD_cfg,
    uint8 * string,
    uint8 row,
    uint8 column )
```

Sends a string to the LCD to be displayed at a specific location.

This function sends a string of characters to the LCD to be displayed at a specific row and column location.

**Parameters**

|    |                |                                                                                           |
|----|----------------|-------------------------------------------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration.                                    |
| in | <i>string</i>  | Pointer to a string of characters to be displayed on the LCD.                             |
| in | <i>row</i>     | Row number where the string should be displayed (see <a href="#">LCD Row Positions</a> ). |
| in | <i>column</i>  | Column number where the string should be displayed (1...16).                              |

**Returns**

None

**Note**

None

**Parameters**

|    |                |                                                                                          |
|----|----------------|------------------------------------------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration.                                   |
| in | <i>string</i>  | Pointer to a string of characters to be displayed on the LCD.                            |
| in | <i>row</i>     | Selects the row number of the displayed character ( <a href="#">LCD Row Positions</a> ). |
| in | <i>column</i>  | Selects the column number of the displayed character (1...16).                           |

**Returns**

None

This function sets the cursor to the specified row and column, then sends the given string to the LCD for display.

**5.9.2.8 LCD\_Set\_Cursor()**

```
void LCD_Set_Cursor (
    LCD_t * LCD_cfg,
```

```
    uint8 row,  
    uint8 column )
```

Sets the location of the cursor on the LCD.

This function positions the cursor to the specified row and column on the LCD. This is useful for placing characters at specific locations on the display.

#### Parameters

|    |                |                                                                                             |
|----|----------------|---------------------------------------------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration.                                      |
| in | <i>row</i>     | Selects the row number of the displayed character (see <a href="#">LCD Row Positions</a> ). |
| in | <i>column</i>  | Selects the column number of the displayed character (1...16).                              |

#### Returns

None

#### Note

This function assumes that the LCD is initialized and configured correctly according to the `LCD_cfg` structure.

#### Parameters

|    |                |                                                                                          |
|----|----------------|------------------------------------------------------------------------------------------|
| in | <i>LCD_cfg</i> | Pointer to the structure containing LCD configuration.                                   |
| in | <i>row</i>     | Selects the row number of the displayed character ( <a href="#">LCD Row Positions</a> ). |
| in | <i>column</i>  | Selects the column number of the displayed character (1...16).                           |

#### Returns

None

This function sets the cursor position to the specified row and column by sending the appropriate command to the LCD.

## 5.10 LED Driver

LED driver for STM32F401xx MCUs.

Collaboration diagram for LED Driver:



## Modules

- [Enum for specifying the LED mode.](#)
- [Structure for configuring an LED.](#)
- [API Function Prototypes](#)

### 5.10.1 Detailed Description

LED driver for STM32F401xx MCUs.

## 5.11 Enum for specifying the LED mode.

Collaboration diagram for Enum for specifying the LED mode.:



## Enumerations

- enum [LED\\_Mode\\_t](#) { [LED\\_Active\\_High](#) , [LED\\_Active\\_Low](#) , [LED\\_Mode\\_max](#) }

### 5.11.1 Detailed Description

### 5.11.2 Enumeration Type Documentation

#### 5.11.2.1 LED\_Mode\_t

```
enum LED_Mode_t
```

##### Enumerator

|                 |                                          |
|-----------------|------------------------------------------|
| LED_Active_High | LED is active when the GPIO pin is high. |
| LED_Active_Low  | LED is active when the GPIO pin is low.  |
| LED_Mode_max    | Maximum value for LED mode enumeration.  |

## 5.12 Structure for configuring an LED.

Collaboration diagram for Structure for configuring an LED.:



## Classes

- struct [LED\\_cfg\\_t](#)

### 5.12.1 Detailed Description

## 5.13 API Function Prototypes

Collaboration diagram for API Function Prototypes:



## Functions

- void `LED_Init` (const `LED_cfg_t` \*led\_cfg)  
*Initializes the LED with the specified configuration.*
- void `LED_TurnOn` (const `LED_cfg_t` \*led\_cfg)  
*Turns on the LED.*
- void `LED_TurnOff` (const `LED_cfg_t` \*led\_cfg)  
*Turns off the LED.*
- void `LED_Toggle` (const `LED_cfg_t` \*led\_cfg)  
*Toggles the state of the LED.*

### 5.13.1 Detailed Description

### 5.13.2 Function Documentation

#### 5.13.2.1 `LED_Init()`

```
void LED_Init (
    const LED_cfg_t * led_cfg )
```

Initializes the LED with the specified configuration.

This function configures the GPIO pin according to the settings provided in the `led_cfg` structure. The LED is initially off after initialization.

##### Parameters

|    |                      |                                                         |
|----|----------------------|---------------------------------------------------------|
| in | <code>led_cfg</code> | Pointer to the structure holding the LED configuration. |
|----|----------------------|---------------------------------------------------------|

##### Returns

None

##### Note

Ensure that the GPIO port and pin configuration in `led_cfg` are correctly set before calling this function.

Initializes the LED with the specified configuration.

##### Parameters

|    |                      |                                                         |
|----|----------------------|---------------------------------------------------------|
| in | <code>led_cfg</code> | Pointer to the structure holding the LED configuration. |
|----|----------------------|---------------------------------------------------------|

**Returns**

None

This function initializes the LED by configuring the GPIO pin according to the settings specified in the `led_cfg` structure. The LED is initially turned off based on its mode (active high or active low).

- If the LED mode is `LED_Active_High`, the LED is turned off by setting the GPIO pin to reset.
- If the LED mode is `LED_Active_Low`, the LED is turned off by setting the GPIO pin to set.

### 5.13.2.2 LED\_Toggle()

```
void LED_Toggle (
    const LED_cfg_t * led_cfg )
```

Toggles the state of the LED.

This function changes the LED state from on to off or off to on by toggling the GPIO pin according to the configuration provided in `led_cfg`.

**Parameters**

|    |                      |                                                         |
|----|----------------------|---------------------------------------------------------|
| in | <code>led_cfg</code> | Pointer to the structure holding the LED configuration. |
|----|----------------------|---------------------------------------------------------|

**Returns**

None

**Note**

The behavior of this function depends on the LED mode configured in `led_cfg`. For `LED_Active_High`, the pin is toggled between high and low; for `LED_Active_Low`, the pin is toggled between low and high.

Toggles the state of the LED.

**Parameters**

|    |                      |                                                         |
|----|----------------------|---------------------------------------------------------|
| in | <code>led_cfg</code> | Pointer to the structure holding the LED configuration. |
|----|----------------------|---------------------------------------------------------|

**Returns**

None

This function toggles the state of the LED by changing the state of the GPIO pin. The LED's state is switched between on and off.

### 5.13.2.3 LED\_TurnOff()

```
void LED_TurnOff (
    const LED_cfg_t * led_cfg )
```

Turns off the LED.

This function sets the GPIO pin to the appropriate state to turn off the LED based on the configuration provided in `led_cfg`.

#### Parameters

|    |                      |                                                         |
|----|----------------------|---------------------------------------------------------|
| in | <code>led_cfg</code> | Pointer to the structure holding the LED configuration. |
|----|----------------------|---------------------------------------------------------|

#### Returns

None

#### Note

The behavior of this function depends on the LED mode configured in `led_cfg`. For `LED_Active_High`, the pin is set low; for `LED_Active_Low`, the pin is set high.

#### Parameters

|    |                      |                                                         |
|----|----------------------|---------------------------------------------------------|
| in | <code>led_cfg</code> | Pointer to the structure holding the LED configuration. |
|----|----------------------|---------------------------------------------------------|

#### Returns

None

This function turns off the LED based on its mode. If the mode is active high, the GPIO pin is reset. If the mode is active low, the GPIO pin is set.

### 5.13.2.4 LED\_TurnOn()

```
void LED_TurnOn (
    const LED_cfg_t * led_cfg )
```

Turns on the LED.

This function sets the GPIO pin to the appropriate state to turn on the LED based on the configuration provided in `led_cfg`.

#### Parameters

|    |                      |                                                         |
|----|----------------------|---------------------------------------------------------|
| in | <code>led_cfg</code> | Pointer to the structure holding the LED configuration. |
|----|----------------------|---------------------------------------------------------|

**Returns**

None

**Note**

The behavior of this function depends on the LED mode configured in `led_cfg`. For `LED_Active_High`, the pin is set high; for `LED_Active_Low`, the pin is set low.

**Parameters**

|    |                      |                                                         |
|----|----------------------|---------------------------------------------------------|
| in | <code>led_cfg</code> | Pointer to the structure holding the LED configuration. |
|----|----------------------|---------------------------------------------------------|

**Returns**

None

This function turns on the LED based on its mode. If the mode is active high, the GPIO pin is set. If the mode is active low, the GPIO pin is reset.

## 5.14 SERVO MOTOR Driver

SERVO MOTOR driver for STM32F401xx MCUs.

Collaboration diagram for SERVO MOTOR Driver:



## Modules

- Macros for the servo motor directions
- API Function Prototypes

### 5.14.1 Detailed Description

SERVO MOTOR driver for STM32F401xx MCUs.

## 5.15 Macros for the servo motor directions

Collaboration diagram for Macros for the servo motor directions:



### Macros

- #define SERVO\_UP 0  
*Macro for the servo motor direction to move the gate upwards.*
- #define SERVO\_DOWN 1  
*Macro for the servo motor direction to move the gate downwards.*

#### 5.15.1 Detailed Description

## 5.16 API Function Prototypes

Collaboration diagram for API Function Prototypes:



### Functions

- void Servo1\_Entry\_Gate\_Init (void)  
*Initializes the servo motor for the entry gate.*
- void Servo1\_Entry\_Gate (uint8 Direction)  
*Controls the servo motor for the entry gate.*
- void Servo2\_Exit\_Gate\_Init (void)  
*Initializes the servo motor for the exit gate.*
- void Servo2\_Exit\_Gate (uint8 Direction)  
*Controls the servo motor for the exit gate.*

### 5.16.1 Detailed Description

### 5.16.2 Function Documentation

#### 5.16.2.1 Servo1\_Entry\_Gate()

```
void Servo1_Entry_Gate (
    uint8 Direction )
```

Controls the servo motor for the entry gate.

This function sets the servo motor to the specified direction (up or down) based on the `Direction` parameter.

#### Parameters

|    |                        |                                                                                                                                            |
|----|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in | <code>Direction</code> | Specifies the direction of the servo motor. This can be either SERVO_UP to move the gate upwards or SERVO_DOWN to move the gate downwards. |
|----|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|

#### Returns

None

#### Note

Ensure that `Servo1_Entry_Gate_Init()` is called prior to using this function.

Controls the servo motor for the entry gate.

#### Parameters

|    |                        |                                                                  |
|----|------------------------|------------------------------------------------------------------|
| in | <code>Direction</code> | Direction for the servo motor movement (SERVO_UP or SERVO_DOWN). |
|----|------------------------|------------------------------------------------------------------|

#### Returns

None

This function controls the servo motor connected to pin B8 to either move the entry gate up or down.

- If `Direction` is SERVO\_UP, the servo moves to +90 degrees.
- If `Direction` is SERVO\_DOWN, the servo moves to -90 degrees. The movement duration is controlled by setting the pin high, waiting for the required duration, and then setting the pin low.

### 5.16.2.2 Servo1\_Entry\_Gate\_Init()

```
void Servo1_Entry_Gate_Init (
    void )
```

Initializes the servo motor for the entry gate.

This function configures the necessary GPIO and timer settings for controlling the servo motor associated with the entry gate.

#### Returns

None

#### Note

This function must be called before operating the entry gate servo motor.

Initializes the servo motor for the entry gate.

#### Parameters

|      |                                 |
|------|---------------------------------|
| None | <input type="button" value=""/> |
|------|---------------------------------|

#### Returns

None

This function configures the GPIO pin B8 as an output pin to control Servo Motor 1. The pin configuration includes setting the mode to output, push-pull operation type, no pull-up/pull-down, and fast speed.

### 5.16.2.3 Servo2\_Exit\_Gate()

```
void Servo2_Exit_Gate (
    uint8 Direction )
```

Controls the servo motor for the exit gate.

This function sets the servo motor to the specified direction (up or down) based on the *Direction* parameter.

#### Parameters

|    |                  |                                                                                                                                            |
|----|------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| in | <i>Direction</i> | Specifies the direction of the servo motor. This can be either SERVO_UP to move the gate upwards or SERVO_DOWN to move the gate downwards. |
|----|------------------|--------------------------------------------------------------------------------------------------------------------------------------------|

#### Returns

None

**Note**

Ensure that `Servo2_Exit_Gate_Init()` is called prior to using this function.

Controls the servo motor for the exit gate.

**Parameters**

|    |                  |                                                                  |
|----|------------------|------------------------------------------------------------------|
| in | <i>Direction</i> | Direction for the servo motor movement (SERVO_UP or SERVO_DOWN). |
|----|------------------|------------------------------------------------------------------|

**Returns**

None

This function controls the servo motor connected to pin B9 to either move the exit gate up or down.

- If *Direction* is SERVO\_UP, the servo moves to +90 degrees.
- If *Direction* is SERVO\_DOWN, the servo moves to -90 degrees. The movement duration is controlled by setting the pin high, waiting for the required duration, and then setting the pin low.

#### 5.16.2.4 Servo2\_Exit\_Gate\_Init()

```
void Servo2_Exit_Gate_Init (
    void )
```

Initializes the servo motor for the exit gate.

This function configures the necessary GPIO and timer settings for controlling the servo motor associated with the exit gate.

**Returns**

None

**Note**

This function must be called before operating the exit gate servo motor.

Initializes the servo motor for the exit gate.

**Parameters**

|             |                          |
|-------------|--------------------------|
| <i>None</i> | <input type="checkbox"/> |
|-------------|--------------------------|

**Returns**

None

This function configures the GPIO pin B9 as an output pin to control Servo Motor 2. The pin configuration includes setting the mode to output, push-pull operation type, no pull-up/pull-down, and fast speed.

## 5.17 CMSIS Global Defines

Collaboration diagram for CMSIS Global Defines:



**IO Type Qualifiers** are used

- to specify the access to peripheral variables.
- for automatic generation of peripheral register debug information.

## 5.18 Defines and Type Definitions

Type definitions and defines for Cortex-M processor based devices.

Collaboration diagram for Defines and Type Definitions:



## Modules

- Status and Control Registers  
*Core Register type definitions.*

### 5.18.1 Detailed Description

Type definitions and defines for Cortex-M processor based devices.

## 5.19 Status and Control Registers

Core Register type definitions.

Collaboration diagram for Status and Control Registers:



## Modules

- [Nested Vectored Interrupt Controller \(NVIC\)](#)

*Type definitions for the NVIC Registers.*

## Classes

- union [APSR\\_Type](#)  
*Union type to access the Application Program Status Register (APSR).*
- union [IPSR\\_Type](#)  
*Union type to access the Interrupt Program Status Register (IPSR).*
- union [xPSR\\_Type](#)  
*Union type to access the Special-Purpose Program Status Registers (xPSR).*
- union [CONTROL\\_Type](#)  
*Union type to access the Control Registers (CONTROL).*
  
- #define [APSR\\_N\\_Pos](#) 31
- #define [APSR\\_N\\_Msk](#) (1UL << [APSR\\_N\\_Pos](#))
- #define [APSR\\_Z\\_Pos](#) 30
- #define [APSR\\_Z\\_Msk](#) (1UL << [APSR\\_Z\\_Pos](#))
- #define [APSR\\_C\\_Pos](#) 29
- #define [APSR\\_C\\_Msk](#) (1UL << [APSR\\_C\\_Pos](#))
- #define [APSR\\_V\\_Pos](#) 28
- #define [APSR\\_V\\_Msk](#) (1UL << [APSR\\_V\\_Pos](#))
- #define [APSR\\_Q\\_Pos](#) 27
- #define [APSR\\_Q\\_Msk](#) (1UL << [APSR\\_Q\\_Pos](#))
- #define [APSR\\_GE\\_Pos](#) 16
- #define [APSR\\_GE\\_Msk](#) (0xFUL << [APSR\\_GE\\_Pos](#))
- #define [IPSR\\_ISR\\_Pos](#) 0
- #define [IPSR\\_ISR\\_Msk](#) (0x1FFUL /\*<< [IPSR\\_ISR\\_Pos\\*/\)](#)
- #define [xPSR\\_N\\_Pos](#) 31
- #define [xPSR\\_N\\_Msk](#) (1UL << [xPSR\\_N\\_Pos](#))
- #define [xPSR\\_Z\\_Pos](#) 30
- #define [xPSR\\_Z\\_Msk](#) (1UL << [xPSR\\_Z\\_Pos](#))
- #define [xPSR\\_C\\_Pos](#) 29
- #define [xPSR\\_C\\_Msk](#) (1UL << [xPSR\\_C\\_Pos](#))

- #define xPSR\_V\_Pos 28
- #define xPSR\_V\_Msk (1UL << xPSR\_V\_Pos)
- #define xPSR\_Q\_Pos 27
- #define xPSR\_Q\_Msk (1UL << xPSR\_Q\_Pos)
- #define xPSR\_IT\_Pos 25
- #define xPSR\_IT\_Msk (3UL << xPSR\_IT\_Pos)
- #define xPSR\_T\_Pos 24
- #define xPSR\_T\_Msk (1UL << xPSR\_T\_Pos)
- #define xPSR\_GE\_Pos 16
- #define xPSR\_GE\_Msk (0xFUL << xPSR\_GE\_Pos)
- #define xPSR\_ISR\_Pos 0
- #define xPSR\_ISR\_Msk (0x1FFUL /\*<< xPSR\_ISR\_Pos\*/)
- #define CONTROL\_FPCA\_Pos 2
- #define CONTROL\_FPCA\_Msk (1UL << CONTROL\_FPCA\_Pos)
- #define CONTROL\_SPSEL\_Pos 1
- #define CONTROL\_SPSEL\_Msk (1UL << CONTROL\_SPSEL\_Pos)
- #define CONTROL\_nPRIV\_Pos 0
- #define CONTROL\_nPRIV\_Msk (1UL /\*<< CONTROL\_nPRIV\_Pos\*/)

### 5.19.1 Detailed Description

Core Register type definitions.

### 5.19.2 Macro Definition Documentation

#### 5.19.2.1 APSR\_C\_Msk

```
#define APSR_C_Msk (1UL << APSR_C_Pos)
```

APSR: C Mask

#### 5.19.2.2 APSR\_C\_Pos

```
#define APSR_C_Pos 29
```

APSR: C Position

#### 5.19.2.3 APSR\_GE\_Msk

```
#define APSR_GE_Msk (0xFUL << APSR_GE_Pos)
```

APSR: GE Mask

#### 5.19.2.4 APSR\_GE\_Pos

```
#define APSR_GE_Pos 16
```

APSR: GE Position

#### 5.19.2.5 APSR\_N\_Msk

```
#define APSR_N_Msk (1UL << APSR_N_Pos)
```

APSR: N Mask

#### 5.19.2.6 APSR\_N\_Pos

```
#define APSR_N_Pos 31
```

APSR: N Position

#### 5.19.2.7 APSR\_Q\_Msk

```
#define APSR_Q_Msk (1UL << APSR_Q_Pos)
```

APSR: Q Mask

#### 5.19.2.8 APSR\_Q\_Pos

```
#define APSR_Q_Pos 27
```

APSR: Q Position

#### 5.19.2.9 APSR\_V\_Msk

```
#define APSR_V_Msk (1UL << APSR_V_Pos)
```

APSR: V Mask

#### 5.19.2.10 APSR\_V\_Pos

```
#define APSR_V_Pos 28
```

APSR: V Position

#### 5.19.2.11 APSR\_Z\_Msk

```
#define APSR_Z_Msk (1UL << APSR_Z_Pos)
```

APSR: Z Mask

### 5.19.2.12 APSR\_Z\_Pos

```
#define APSR_Z_Pos 30
```

APSR: Z Position

### 5.19.2.13 CONTROL\_FPCA\_Msk

```
#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos)
```

CONTROL: FPCA Mask

### 5.19.2.14 CONTROL\_FPCA\_Pos

```
#define CONTROL_FPCA_Pos 2
```

CONTROL: FPCA Position

### 5.19.2.15 CONTROL\_nPRIV\_Msk

```
#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/)
```

CONTROL: nPRIV Mask

### 5.19.2.16 CONTROL\_nPRIV\_Pos

```
#define CONTROL_nPRIV_Pos 0
```

CONTROL: nPRIV Position

### 5.19.2.17 CONTROL\_SPSEL\_Msk

```
#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos)
```

CONTROL: SPSEL Mask

### 5.19.2.18 CONTROL\_SPSEL\_Pos

```
#define CONTROL_SPSEL_Pos 1
```

CONTROL: SPSEL Position

### 5.19.2.19 IPSR\_ISR\_Msk

```
#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/)
```

IPSR: ISR Mask

**5.19.2.20 IPSR\_ISR\_Pos**

```
#define IPSR_ISR_Pos 0
```

IPSR: ISR Position

**5.19.2.21 xPSR\_C\_Msk**

```
#define xPSR_C_Msk (1UL << xPSR_C_Pos)
```

xPSR: C Mask

**5.19.2.22 xPSR\_C\_Pos**

```
#define xPSR_C_Pos 29
```

xPSR: C Position

**5.19.2.23 xPSR\_GE\_Msk**

```
#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos)
```

xPSR: GE Mask

**5.19.2.24 xPSR\_GE\_Pos**

```
#define xPSR_GE_Pos 16
```

xPSR: GE Position

**5.19.2.25 xPSR\_ISR\_Msk**

```
#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/)
```

xPSR: ISR Mask

**5.19.2.26 xPSR\_ISR\_Pos**

```
#define xPSR_ISR_Pos 0
```

xPSR: ISR Position

**5.19.2.27 xPSR\_IT\_Msk**

```
#define xPSR_IT_Msk (3UL << xPSR_IT_Pos)
```

xPSR: IT Mask

### 5.19.2.28 xPSR\_IT\_Pos

```
#define xPSR_IT_Pos 25
```

xPSR: IT Position

### 5.19.2.29 xPSR\_N\_Msk

```
#define xPSR_N_Msk (1UL << xPSR_N_Pos)
```

xPSR: N Mask

### 5.19.2.30 xPSR\_N\_Pos

```
#define xPSR_N_Pos 31
```

xPSR: N Position

### 5.19.2.31 xPSR\_Q\_Msk

```
#define xPSR_Q_Msk (1UL << xPSR_Q_Pos)
```

xPSR: Q Mask

### 5.19.2.32 xPSR\_Q\_Pos

```
#define xPSR_Q_Pos 27
```

xPSR: Q Position

### 5.19.2.33 xPSR\_T\_Msk

```
#define xPSR_T_Msk (1UL << xPSR_T_Pos)
```

xPSR: T Mask

### 5.19.2.34 xPSR\_T\_Pos

```
#define xPSR_T_Pos 24
```

xPSR: T Position

### 5.19.2.35 xPSR\_V\_Msk

```
#define xPSR_V_Msk (1UL << xPSR_V_Pos)
```

xPSR: V Mask

### 5.19.2.36 xPSR\_V\_Pos

```
#define xPSR_V_Pos 28
```

xPSR: V Position

### 5.19.2.37 xPSR\_Z\_Msk

```
#define xPSR_Z_Msk (1UL << xPSR_Z_Pos)
```

xPSR: Z Mask

### 5.19.2.38 xPSR\_Z\_Pos

```
#define xPSR_Z_Pos 30
```

xPSR: Z Position

## 5.20 Nested Vectored Interrupt Controller (NVIC)

Type definitions for the NVIC Registers.

Collaboration diagram for Nested Vectored Interrupt Controller (NVIC):



## Modules

- [System Control Block \(SCB\)](#)

*Type definitions for the System Control Block Registers.*

## Classes

- struct [NVIC\\_Type](#)

*Structure type to access the Nested Vectored Interrupt Controller (NVIC).*

- #define [NVIC\\_STIR\\_INTID\\_Pos](#) 0
- #define [NVIC\\_STIR\\_INTID\\_Msk](#) (0x1FFUL /\*<< [NVIC\\_STIR\\_INTID\\_Pos](#)\*/)

### 5.20.1 Detailed Description

Type definitions for the NVIC Registers.

### 5.20.2 Macro Definition Documentation

#### 5.20.2.1 NVIC\_STIR\_INTID\_Msk

```
#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/)
```

STIR: INTLINESNUM Mask

#### 5.20.2.2 NVIC\_STIR\_INTID\_Pos

```
#define NVIC_STIR_INTID_Pos 0
```

STIR: INTLINESNUM Position

## 5.21 System Control Block (SCB)

Type definitions for the System Control Block Registers.

Collaboration diagram for System Control Block (SCB):



## Modules

- [System Controls not in SCB \(SCnSCB\)](#)

*Type definitions for the System Control and ID Register not in the SCB.*

## Classes

- struct `SCB_Type`

*Structure type to access the System Control Block (SCB).*
- `#define SCB_CPUID_IMPLEMENTER_Pos 24`
- `#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos)`
- `#define SCB_CPUID_VARIANT_Pos 20`
- `#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos)`
- `#define SCB_CPUID_ARCHITECTURE_Pos 16`
- `#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos)`
- `#define SCB_CPUID_PARTNO_Pos 4`
- `#define SCB_CPUID_PARTNO_Msk (0xFFFFUL << SCB_CPUID_PARTNO_Pos)`
- `#define SCB_CPUID_REVISION_Pos 0`
- `#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/)`
- `#define SCB_ICSR_NMIPENDSET_Pos 31`
- `#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos)`
- `#define SCB_ICSR_PENDSVSET_Pos 28`
- `#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos)`
- `#define SCB_ICSR_PENDSVCLR_Pos 27`
- `#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos)`
- `#define SCB_ICSR_PENDSTSET_Pos 26`
- `#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos)`
- `#define SCB_ICSR_PENDSTCLR_Pos 25`
- `#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos)`
- `#define SCB_ICSR_ISRPREEMPT_Pos 23`
- `#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos)`
- `#define SCB_ICSR_ISRPENDING_Pos 22`
- `#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos)`
- `#define SCB_ICSR_VECTPENDING_Pos 12`
- `#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos)`
- `#define SCB_ICSR_RETTOBASE_Pos 11`
- `#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos)`
- `#define SCB_ICSR_VECTACTIVE_Pos 0`
- `#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/)`
- `#define SCB_VTOR_TBLOFF_Pos 7`
- `#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos)`
- `#define SCB_AIRCR_VECTKEY_Pos 16`
- `#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos)`
- `#define SCB_AIRCR_VECTKEYSTAT_Pos 16`
- `#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos)`
- `#define SCB_AIRCR_ENDIANESS_Pos 15`
- `#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos)`
- `#define SCB_AIRCR_PRIGROUP_Pos 8`
- `#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos)`
- `#define SCB_AIRCR_SYSRESETREQ_Pos 2`
- `#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos)`
- `#define SCB_AIRCR_VECTCLRACTIVE_Pos 1`
- `#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos)`
- `#define SCB_AIRCR_VECTRESET_Pos 0`
- `#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/)`
- `#define SCB_SCR_SEVONPEND_Pos 4`
- `#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos)`
- `#define SCB_SCR_SLEEPDEEP_Pos 2`

- #define SCB\_SCR\_SLEEPDEEP\_Msk (1UL << SCB\_SCR\_SLEEPDEEP\_Pos)
- #define SCB\_SCR\_SLEEPONEXIT\_Pos 1
- #define SCB\_SCR\_SLEEPONEXIT\_Msk (1UL << SCB\_SCR\_SLEEPONEXIT\_Pos)
- #define SCB\_CCR\_STKALIGN\_Pos 9
- #define SCB\_CCR\_STKALIGN\_Msk (1UL << SCB\_CCR\_STKALIGN\_Pos)
- #define SCB\_CCR\_BFHFNIGN\_Pos 8
- #define SCB\_CCR\_BFHFNIGN\_Msk (1UL << SCB\_CCR\_BFHFNIGN\_Pos)
- #define SCB\_CCR\_DIV\_0\_TRP\_Pos 4
- #define SCB\_CCR\_DIV\_0\_TRP\_Msk (1UL << SCB\_CCR\_DIV\_0\_TRP\_Pos)
- #define SCB\_CCR\_UNALIGN\_TRP\_Pos 3
- #define SCB\_CCR\_UNALIGN\_TRP\_Msk (1UL << SCB\_CCR\_UNALIGN\_TRP\_Pos)
- #define SCB\_CCR\_USERSETMPEND\_Pos 1
- #define SCB\_CCR\_USERSETMPEND\_Msk (1UL << SCB\_CCR\_USERSETMPEND\_Pos)
- #define SCB\_CCR\_NONBASETHRDENA\_Pos 0
- #define SCB\_CCR\_NONBASETHRDENA\_Msk (1UL /\*<< SCB\_CCR\_NONBASETHRDENA\_Pos\*/)
- #define SCB\_SHCSR\_USGFAULTENA\_Pos 18
- #define SCB\_SHCSR\_USGFAULTENA\_Msk (1UL << SCB\_SHCSR\_USGFAULTENA\_Pos)
- #define SCB\_SHCSR\_BUSFAULTENA\_Pos 17
- #define SCB\_SHCSR\_BUSFAULTENA\_Msk (1UL << SCB\_SHCSR\_BUSFAULTENA\_Pos)
- #define SCB\_SHCSR\_MEMFAULTENA\_Pos 16
- #define SCB\_SHCSR\_MEMFAULTENA\_Msk (1UL << SCB\_SHCSR\_MEMFAULTENA\_Pos)
- #define SCB\_SHCSR\_SVCALLPENDED\_Pos 15
- #define SCB\_SHCSR\_SVCALLPENDED\_Msk (1UL << SCB\_SHCSR\_SVCALLPENDED\_Pos)
- #define SCB\_SHCSR\_BUSFAULTPENDED\_Pos 14
- #define SCB\_SHCSR\_BUSFAULTPENDED\_Msk (1UL << SCB\_SHCSR\_BUSFAULTPENDED\_Pos)
- #define SCB\_SHCSR\_MEMFAULTPENDED\_Pos 13
- #define SCB\_SHCSR\_MEMFAULTPENDED\_Msk (1UL << SCB\_SHCSR\_MEMFAULTPENDED\_Pos)
- #define SCB\_SHCSR\_USGFAULTPENDED\_Pos 12
- #define SCB\_SHCSR\_USGFAULTPENDED\_Msk (1UL << SCB\_SHCSR\_USGFAULTPENDED\_Pos)
- #define SCB\_SHCSR\_SYSTICKACT\_Pos 11
- #define SCB\_SHCSR\_SYSTICKACT\_Msk (1UL << SCB\_SHCSR\_SYSTICKACT\_Pos)
- #define SCB\_SHCSR\_PENDSVACT\_Pos 10
- #define SCB\_SHCSR\_PENDSVACT\_Msk (1UL << SCB\_SHCSR\_PENDSVACT\_Pos)
- #define SCB\_SHCSR\_MONITORACT\_Pos 8
- #define SCB\_SHCSR\_MONITORACT\_Msk (1UL << SCB\_SHCSR\_MONITORACT\_Pos)
- #define SCB\_SHCSR\_SVCALLACT\_Pos 7
- #define SCB\_SHCSR\_SVCALLACT\_Msk (1UL << SCB\_SHCSR\_SVCALLACT\_Pos)
- #define SCB\_SHCSR\_USGFAULTACT\_Pos 3
- #define SCB\_SHCSR\_USGFAULTACT\_Msk (1UL << SCB\_SHCSR\_USGFAULTACT\_Pos)
- #define SCB\_SHCSR\_BUSFAULTACT\_Pos 1
- #define SCB\_SHCSR\_BUSFAULTACT\_Msk (1UL << SCB\_SHCSR\_BUSFAULTACT\_Pos)
- #define SCB\_SHCSR\_MEMFAULTACT\_Pos 0
- #define SCB\_SHCSR\_MEMFAULTACT\_Msk (1UL /\*<< SCB\_SHCSR\_MEMFAULTACT\_Pos\*/)
- #define SCB\_CFSR\_USGFAULTSR\_Pos 16
- #define SCB\_CFSR\_USGFAULTSR\_Msk (0xFFFFUL << SCB\_CFSR\_USGFAULTSR\_Pos)
- #define SCB\_CFSR\_BUSFAULTSR\_Pos 8
- #define SCB\_CFSR\_BUSFAULTSR\_Msk (0xFFUL << SCB\_CFSR\_BUSFAULTSR\_Pos)
- #define SCB\_CFSR\_MEMFAULTSR\_Pos 0
- #define SCB\_CFSR\_MEMFAULTSR\_Msk (0xFFUL /\*<< SCB\_CFSR\_MEMFAULTSR\_Pos\*/)
- #define SCB\_HFSR\_DEBUGEVT\_Pos 31
- #define SCB\_HFSR\_DEBUGEVT\_Msk (1UL << SCB\_HFSR\_DEBUGEVT\_Pos)
- #define SCB\_HFSR\_FORCED\_Pos 30
- #define SCB\_HFSR\_FORCED\_Msk (1UL << SCB\_HFSR\_FORCED\_Pos)
- #define SCB\_HFSR\_VECTTBL\_Pos 1
- #define SCB\_HFSR\_VECTTBL\_Msk (1UL << SCB\_HFSR\_VECTTBL\_Pos)

- #define SCB\_DFSR\_EXTERNAL\_Pos 4
- #define SCB\_DFSR\_EXTERNAL\_Msk (1UL << SCB\_DFSR\_EXTERNAL\_Pos)
- #define SCB\_DFSR\_VCATCH\_Pos 3
- #define SCB\_DFSR\_VCATCH\_Msk (1UL << SCB\_DFSR\_VCATCH\_Pos)
- #define SCB\_DFSR\_DWTTRAP\_Pos 2
- #define SCB\_DFSR\_DWTTRAP\_Msk (1UL << SCB\_DFSR\_DWTTRAP\_Pos)
- #define SCB\_DFSR\_BKPT\_Pos 1
- #define SCB\_DFSR\_BKPT\_Msk (1UL << SCB\_DFSR\_BKPT\_Pos)
- #define SCB\_DFSR\_HALTED\_Pos 0
- #define SCB\_DFSR\_HALTED\_Msk (1UL /\*<< SCB\_DFSR\_HALTED\_Pos\*/)

### 5.21.1 Detailed Description

Type definitions for the System Control Block Registers.

### 5.21.2 Macro Definition Documentation

#### 5.21.2.1 SCB\_AIRCR\_ENDIANESS\_Msk

```
#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos)
```

SCB AIRCR: ENDIANESS Mask

#### 5.21.2.2 SCB\_AIRCR\_ENDIANESS\_Pos

```
#define SCB_AIRCR_ENDIANESS_Pos 15
```

SCB AIRCR: ENDIANESS Position

#### 5.21.2.3 SCB\_AIRCR\_PRIGROUP\_Msk

```
#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos)
```

SCB AIRCR: PRIGROUP Mask

#### 5.21.2.4 SCB\_AIRCR\_PRIGROUP\_Pos

```
#define SCB_AIRCR_PRIGROUP_Pos 8
```

SCB AIRCR: PRIGROUP Position

### 5.21.2.5 SCB\_AIRCR\_SYSRESETREQ\_Msk

```
#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos)
```

SCB AIRCR: SYSRESETREQ Mask

### 5.21.2.6 SCB\_AIRCR\_SYSRESETREQ\_Pos

```
#define SCB_AIRCR_SYSRESETREQ_Pos 2
```

SCB AIRCR: SYSRESETREQ Position

### 5.21.2.7 SCB\_AIRCR\_VECTCLRACTIVE\_Msk

```
#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos)
```

SCB AIRCR: VECTCLRACTIVE Mask

### 5.21.2.8 SCB\_AIRCR\_VECTCLRACTIVE\_Pos

```
#define SCB_AIRCR_VECTCLRACTIVE_Pos 1
```

SCB AIRCR: VECTCLRACTIVE Position

### 5.21.2.9 SCB\_AIRCR\_VECTKEY\_Msk

```
#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos)
```

SCB AIRCR: VECTKEY Mask

### 5.21.2.10 SCB\_AIRCR\_VECTKEY\_Pos

```
#define SCB_AIRCR_VECTKEY_Pos 16
```

SCB AIRCR: VECTKEY Position

### 5.21.2.11 SCB\_AIRCR\_VECTKEYSTAT\_Msk

```
#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos)
```

SCB AIRCR: VECTKEYSTAT Mask

### 5.21.2.12 SCB\_AIRCR\_VECTKEYSTAT\_Pos

```
#define SCB_AIRCR_VECTKEYSTAT_Pos 16
```

SCB AIRCR: VECTKEYSTAT Position

### 5.21.2.13 SCB\_AIRCR\_VECTRESET\_Msk

```
#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/)
```

SCB AIRCR: VECTRESET Mask

### 5.21.2.14 SCB\_AIRCR\_VECTRESET\_Pos

```
#define SCB_AIRCR_VECTRESET_Pos 0
```

SCB AIRCR: VECTRESET Position

### 5.21.2.15 SCB\_CCR\_BFHFNIGN\_Msk

```
#define SCB_CCR_BFHFNIGN_Msk (1UL << SCB_CCR_BFHFNIGN_Pos)
```

SCB CCR: BFHFNMIGN Mask

### 5.21.2.16 SCB\_CCR\_BFHFNIGN\_Pos

```
#define SCB_CCR_BFHFNIGN_Pos 8
```

SCB CCR: BFHFNMIGN Position

### 5.21.2.17 SCB\_CCR\_DIV\_0\_TRP\_Msk

```
#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos)
```

SCB CCR: DIV\_0\_TRP Mask

### 5.21.2.18 SCB\_CCR\_DIV\_0\_TRP\_Pos

```
#define SCB_CCR_DIV_0_TRP_Pos 4
```

SCB CCR: DIV\_0\_TRP Position

### 5.21.2.19 SCB\_CCR\_NONBASETHRDENA\_Msk

```
#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/)
```

SCB CCR: NONBASETHRDENA Mask

### 5.21.2.20 SCB\_CCR\_NONBASETHRDENA\_Pos

```
#define SCB_CCR_NONBASETHRDENA_Pos 0
```

SCB CCR: NONBASETHRDENA Position

### 5.21.2.21 SCB\_CCR\_STKALIGN\_Msk

```
#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos)
```

SCB CCR: STKALIGN Mask

### 5.21.2.22 SCB\_CCR\_STKALIGN\_Pos

```
#define SCB_CCR_STKALIGN_Pos 9
```

SCB CCR: STKALIGN Position

### 5.21.2.23 SCB\_CCR\_UNALIGN\_TRP\_Msk

```
#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos)
```

SCB CCR: UNALIGN\_TRP Mask

### 5.21.2.24 SCB\_CCR\_UNALIGN\_TRP\_Pos

```
#define SCB_CCR_UNALIGN_TRP_Pos 3
```

SCB CCR: UNALIGN\_TRP Position

### 5.21.2.25 SCB\_CCR\_USERSETMPEND\_Msk

```
#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos)
```

SCB CCR: USERSETMPEND Mask

### 5.21.2.26 SCB\_CCR\_USERSETMPEND\_Pos

```
#define SCB_CCR_USERSETMPEND_Pos 1
```

SCB CCR: USERSETMPEND Position

### 5.21.2.27 SCB\_CFSR\_BUSFAULTSR\_Msk

```
#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos)
```

SCB CFSR: Bus Fault Status Register Mask

### 5.21.2.28 SCB\_CFSR\_BUSFAULTSR\_Pos

```
#define SCB_CFSR_BUSFAULTSR_Pos 8
```

SCB CFSR: Bus Fault Status Register Position

### 5.21.2.29 SCB\_CFSR\_MEMFAULTSR\_Msk

```
#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/)
```

SCB CFSR: Memory Manage Fault Status Register Mask

### 5.21.2.30 SCB\_CFSR\_MEMFAULTSR\_Pos

```
#define SCB_CFSR_MEMFAULTSR_Pos 0
```

SCB CFSR: Memory Manage Fault Status Register Position

### 5.21.2.31 SCB\_CFSR\_USGFAULTSR\_Msk

```
#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos)
```

SCB CFSR: Usage Fault Status Register Mask

### 5.21.2.32 SCB\_CFSR\_USGFAULTSR\_Pos

```
#define SCB_CFSR_USGFAULTSR_Pos 16
```

SCB CFSR: Usage Fault Status Register Position

### 5.21.2.33 SCB\_CPUID\_ARCHITECTURE\_Msk

```
#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos)
```

SCB CPUID: ARCHITECTURE Mask

### 5.21.2.34 SCB\_CPUID\_ARCHITECTURE\_Pos

```
#define SCB_CPUID_ARCHITECTURE_Pos 16
```

SCB CPUID: ARCHITECTURE Position

### 5.21.2.35 SCB\_CPUID\_IMPLEMENTER\_Msk

```
#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos)
```

SCB CPUID: IMPLEMENTER Mask

### 5.21.2.36 SCB\_CPUID\_IMPLEMENTER\_Pos

```
#define SCB_CPUID_IMPLEMENTER_Pos 24
```

SCB CPUID: IMPLEMENTER Position

### 5.21.2.37 SCB\_CPUID\_PARTNO\_Msk

```
#define SCB_CPUID_PARTNO_Msk (0xFFFFUL << SCB_CPUID_PARTNO_Pos)
```

SCB CPUID: PARTNO Mask

### 5.21.2.38 SCB\_CPUID\_PARTNO\_Pos

```
#define SCB_CPUID_PARTNO_Pos 4
```

SCB CPUID: PARTNO Position

### 5.21.2.39 SCB\_CPUID\_REVISION\_Msk

```
#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/)
```

SCB CPUID: REVISION Mask

### 5.21.2.40 SCB\_CPUID\_REVISION\_Pos

```
#define SCB_CPUID_REVISION_Pos 0
```

SCB CPUID: REVISION Position

### 5.21.2.41 SCB\_CPUID\_VARIANT\_Msk

```
#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos)
```

SCB CPUID: VARIANT Mask

### 5.21.2.42 SCB\_CPUID\_VARIANT\_Pos

```
#define SCB_CPUID_VARIANT_Pos 20
```

SCB CPUID: VARIANT Position

### 5.21.2.43 SCB\_DFSR\_BKPT\_Msk

```
#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos)
```

SCB DFSR: BKPT Mask

### 5.21.2.44 SCB\_DFSR\_BKPT\_Pos

```
#define SCB_DFSR_BKPT_Pos 1
```

SCB DFSR: BKPT Position

### 5.21.2.45 SCB\_DFSR\_DWTTRAP\_Msk

```
#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos)
```

SCB DFSR: DWTTRAP Mask

### 5.21.2.46 SCB\_DFSR\_DWTTRAP\_Pos

```
#define SCB_DFSR_DWTTRAP_Pos 2
```

SCB DFSR: DWTTRAP Position

### 5.21.2.47 SCB\_DFSR\_EXTERNAL\_Msk

```
#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos)
```

SCB DFSR: EXTERNAL Mask

### 5.21.2.48 SCB\_DFSR\_EXTERNAL\_Pos

```
#define SCB_DFSR_EXTERNAL_Pos 4
```

SCB DFSR: EXTERNAL Position

### 5.21.2.49 SCB\_DFSR\_HALTED\_Msk

```
#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/)
```

SCB DFSR: HALTED Mask

### 5.21.2.50 SCB\_DFSR\_HALTED\_Pos

```
#define SCB_DFSR_HALTED_Pos 0
```

SCB DFSR: HALTED Position

### 5.21.2.51 SCB\_DFSR\_VCATCH\_Msk

```
#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos)
```

SCB DFSR: VCATCH Mask

### 5.21.2.52 SCB\_DFSR\_VCATCH\_Pos

```
#define SCB_DFSR_VCATCH_Pos 3
```

SCB DFSR: VCATCH Position

### 5.21.2.53 SCB\_HFSR\_DEBUGEV<sub>T</sub>\_Msk

```
#define SCB_HFSR_DEBUGEVT_Msk (1UL << SCB_HFSR_DEBUGEVT_Pos)
```

SCB HFSR: DEBUGEV<sub>T</sub> Mask

### 5.21.2.54 SCB\_HFSR\_DEBUGEV<sub>T</sub>\_Pos

```
#define SCB_HFSR_DEBUGEVT_Pos 31
```

SCB HFSR: DEBUGEV<sub>T</sub> Position

### 5.21.2.55 SCB\_HFSR\_FORCED\_Msk

```
#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos)
```

SCB HFSR: FORCED Mask

### 5.21.2.56 SCB\_HFSR\_FORCED\_Pos

```
#define SCB_HFSR_FORCED_Pos 30
```

SCB HFSR: FORCED Position

### 5.21.2.57 SCB\_HFSR\_VECTTBL\_Msk

```
#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos)
```

SCB HFSR: VECTTBL Mask

### 5.21.2.58 SCB\_HFSR\_VECTTBL\_Pos

```
#define SCB_HFSR_VECTTBL_Pos 1
```

SCB HFSR: VECTTBL Position

### 5.21.2.59 SCB\_ICSR\_ISRPENDING\_Msk

```
#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos)
```

SCB ICSR: ISRPENDING Mask

### 5.21.2.60 SCB\_ICSR\_ISRPENDING\_Pos

```
#define SCB_ICSR_ISRPENDING_Pos 22
```

SCB ICSR: ISRPENDING Position

### 5.21.2.61 SCB\_ICSR\_ISRPREEMPT\_Msk

```
#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos)
```

SCB ICSR: ISRPREEMPT Mask

### 5.21.2.62 SCB\_ICSR\_ISRPREEMPT\_Pos

```
#define SCB_ICSR_ISRPREEMPT_Pos 23
```

SCB ICSR: ISRPREEMPT Position

### 5.21.2.63 SCB\_ICSR\_NMIPENDSET\_Msk

```
#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos)
```

SCB ICSR: NMIPENDSET Mask

### 5.21.2.64 SCB\_ICSR\_NMIPENDSET\_Pos

```
#define SCB_ICSR_NMIPENDSET_Pos 31
```

SCB ICSR: NMIPENDSET Position

### 5.21.2.65 SCB\_ICSR\_PENDSTCLR\_Msk

```
#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos)
```

SCB ICSR: PENDSTCLR Mask

### 5.21.2.66 SCB\_ICSR\_PENDSTCLR\_Pos

```
#define SCB_ICSR_PENDSTCLR_Pos 25
```

SCB ICSR: PENDSTCLR Position

### 5.21.2.67 SCB\_ICSR\_PENDSTSET\_Msk

```
#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos)
```

SCB ICSR: PENDSTSET Mask

### 5.21.2.68 SCB\_ICSR\_PENDSTSET\_Pos

```
#define SCB_ICSR_PENDSTSET_Pos 26
```

SCB ICSR: PENDSTSET Position

### 5.21.2.69 SCB\_ICSR\_PENDSVCLR\_Msk

```
#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos)
```

SCB ICSR: PENDSVCLR Mask

### 5.21.2.70 SCB\_ICSR\_PENDSVCLR\_Pos

```
#define SCB_ICSR_PENDSVCLR_Pos 27
```

SCB ICSR: PENDSVCLR Position

### 5.21.2.71 SCB\_ICSR\_PENDSVSET\_Msk

```
#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos)
```

SCB ICSR: PENDSVSET Mask

### 5.21.2.72 SCB\_ICSR\_PENDSVSET\_Pos

```
#define SCB_ICSR_PENDSVSET_Pos 28
```

SCB ICSR: PENDSVSET Position

### 5.21.2.73 SCB\_ICSR\_RETTOBASE\_Msk

```
#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos)
```

SCB ICSR: RETTOBASE Mask

### 5.21.2.74 SCB\_ICSR\_RETTOBASE\_Pos

```
#define SCB_ICSR_RETTOBASE_Pos 11
```

SCB ICSR: RETTOBASE Position

### 5.21.2.75 SCB\_ICSR\_VECTACTIVE\_Msk

```
#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/)
```

SCB ICSR: VECTACTIVE Mask

### 5.21.2.76 SCB\_ICSR\_VECTACTIVE\_Pos

```
#define SCB_ICSR_VECTACTIVE_Pos 0
```

SCB ICSR: VECTACTIVE Position

**5.21.2.77 SCB\_ICSR\_VECTPENDING\_Msk**

```
#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos)
```

SCB ICSR: VECTPENDING Mask

**5.21.2.78 SCB\_ICSR\_VECTPENDING\_Pos**

```
#define SCB_ICSR_VECTPENDING_Pos 12
```

SCB ICSR: VECTPENDING Position

**5.21.2.79 SCB\_SCR\_SEVONPEND\_Msk**

```
#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos)
```

SCB SCR: SEVONPEND Mask

**5.21.2.80 SCB\_SCR\_SEVONPEND\_Pos**

```
#define SCB_SCR_SEVONPEND_Pos 4
```

SCB SCR: SEVONPEND Position

**5.21.2.81 SCB\_SCR\_SLEEPDEEP\_Msk**

```
#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos)
```

SCB SCR: SLEEPDEEP Mask

**5.21.2.82 SCB\_SCR\_SLEEPDEEP\_Pos**

```
#define SCB_SCR_SLEEPDEEP_Pos 2
```

SCB SCR: SLEEPDEEP Position

**5.21.2.83 SCB\_SCR\_SLEEPONEXIT\_Msk**

```
#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos)
```

SCB SCR: SLEEPONEXIT Mask

**5.21.2.84 SCB\_SCR\_SLEEPONEXIT\_Pos**

```
#define SCB_SCR_SLEEPONEXIT_Pos 1
```

SCB SCR: SLEEPONEXIT Position

### 5.21.2.85 SCB\_SHCSR\_BUSFAULTACT\_Msk

```
#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos)
```

SCB SHCSR: BUSFAULTACT Mask

### 5.21.2.86 SCB\_SHCSR\_BUSFAULTACT\_Pos

```
#define SCB_SHCSR_BUSFAULTACT_Pos 1
```

SCB SHCSR: BUSFAULTACT Position

### 5.21.2.87 SCB\_SHCSR\_BUSFAULTENA\_Msk

```
#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos)
```

SCB SHCSR: BUSFAULTENA Mask

### 5.21.2.88 SCB\_SHCSR\_BUSFAULTENA\_Pos

```
#define SCB_SHCSR_BUSFAULTENA_Pos 17
```

SCB SHCSR: BUSFAULTENA Position

### 5.21.2.89 SCB\_SHCSR\_BUSFAULTPENDED\_Msk

```
#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos)
```

SCB SHCSR: BUSFAULTPENDED Mask

### 5.21.2.90 SCB\_SHCSR\_BUSFAULTPENDED\_Pos

```
#define SCB_SHCSR_BUSFAULTPENDED_Pos 14
```

SCB SHCSR: BUSFAULTPENDED Position

### 5.21.2.91 SCB\_SHCSR\_MEMFAULTACT\_Msk

```
#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/)
```

SCB SHCSR: MEMFAULTACT Mask

### 5.21.2.92 SCB\_SHCSR\_MEMFAULTACT\_Pos

```
#define SCB_SHCSR_MEMFAULTACT_Pos 0
```

SCB SHCSR: MEMFAULTACT Position

**5.21.2.93 SCB\_SHCSR\_MEMFAULTENA\_Msk**

```
#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos)
```

SCB SHCSR: MEMFAULTENA Mask

**5.21.2.94 SCB\_SHCSR\_MEMFAULTENA\_Pos**

```
#define SCB_SHCSR_MEMFAULTENA_Pos 16
```

SCB SHCSR: MEMFAULTENA Position

**5.21.2.95 SCB\_SHCSR\_MEMFAULTPENDED\_Msk**

```
#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos)
```

SCB SHCSR: MEMFAULTPENDED Mask

**5.21.2.96 SCB\_SHCSR\_MEMFAULTPENDED\_Pos**

```
#define SCB_SHCSR_MEMFAULTPENDED_Pos 13
```

SCB SHCSR: MEMFAULTPENDED Position

**5.21.2.97 SCB\_SHCSR\_MONITORACT\_Msk**

```
#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos)
```

SCB SHCSR: MONITORACT Mask

**5.21.2.98 SCB\_SHCSR\_MONITORACT\_Pos**

```
#define SCB_SHCSR_MONITORACT_Pos 8
```

SCB SHCSR: MONITORACT Position

**5.21.2.99 SCB\_SHCSR\_PENDSVACT\_Msk**

```
#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos)
```

SCB SHCSR: PENDSVACT Mask

**5.21.2.100 SCB\_SHCSR\_PENDSVACT\_Pos**

```
#define SCB_SHCSR_PENDSVACT_Pos 10
```

SCB SHCSR: PENDSVACT Position

### 5.21.2.101 SCB\_SHCSR\_SVCALLACT\_Msk

```
#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos)
```

SCB SHCSR: SVCALLACT Mask

### 5.21.2.102 SCB\_SHCSR\_SVCALLACT\_Pos

```
#define SCB_SHCSR_SVCALLACT_Pos 7
```

SCB SHCSR: SVCALLACT Position

### 5.21.2.103 SCB\_SHCSR\_SVCALLPENDED\_Msk

```
#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos)
```

SCB SHCSR: SVCALLPENDED Mask

### 5.21.2.104 SCB\_SHCSR\_SVCALLPENDED\_Pos

```
#define SCB_SHCSR_SVCALLPENDED_Pos 15
```

SCB SHCSR: SVCALLPENDED Position

### 5.21.2.105 SCB\_SHCSR\_SYSTICKACT\_Msk

```
#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos)
```

SCB SHCSR: SYSTICKACT Mask

### 5.21.2.106 SCB\_SHCSR\_SYSTICKACT\_Pos

```
#define SCB_SHCSR_SYSTICKACT_Pos 11
```

SCB SHCSR: SYSTICKACT Position

### 5.21.2.107 SCB\_SHCSR\_USGFAULTACT\_Msk

```
#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos)
```

SCB SHCSR: USGFAULTACT Mask

### 5.21.2.108 SCB\_SHCSR\_USGFAULTACT\_Pos

```
#define SCB_SHCSR_USGFAULTACT_Pos 3
```

SCB SHCSR: USGFAULTACT Position

**5.21.2.109 SCB\_SHCSR\_USGFAULTENA\_Msk**

```
#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos)
```

SCB SHCSR: USGFAULTENA Mask

**5.21.2.110 SCB\_SHCSR\_USGFAULTENA\_Pos**

```
#define SCB_SHCSR_USGFAULTENA_Pos 18
```

SCB SHCSR: USGFAULTENA Position

**5.21.2.111 SCB\_SHCSR\_USGFAULTPENDED\_Msk**

```
#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos)
```

SCB SHCSR: USGFAULTPENDED Mask

**5.21.2.112 SCB\_SHCSR\_USGFAULTPENDED\_Pos**

```
#define SCB_SHCSR_USGFAULTPENDED_Pos 12
```

SCB SHCSR: USGFAULTPENDED Position

**5.21.2.113 SCB\_VTOR\_TBLOFF\_Msk**

```
#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFFUL << SCB_VTOR_TBLOFF_Pos)
```

SCB VTOR: TBLOFF Mask

**5.21.2.114 SCB\_VTOR\_TBLOFF\_Pos**

```
#define SCB_VTOR_TBLOFF_Pos 7
```

SCB VTOR: TBLOFF Position

**5.22 System Controls not in SCB (SCnSCB)**

Type definitions for the System Control and ID Register not in the SCB.

Collaboration diagram for System Controls not in SCB (SCnSCB):



## Modules

- [System Tick Timer \(SysTick\)](#)

*Type definitions for the System Timer Registers.*

## Classes

- struct [SCnSCB\\_Type](#)

*Structure type to access the System Control and ID Register not in the SCB.*

- `#define SCnSCB_ICTR_INTLINESNUM_Pos 0`
- `#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/)`
- `#define SCnSCB_ACTLR_DISOOFP_Pos 9`
- `#define SCnSCB_ACTLR_DISOOFP_Msk (1UL << SCnSCB_ACTLR_DISOOFP_Pos)`
- `#define SCnSCB_ACTLR_DISFPCA_Pos 8`
- `#define SCnSCB_ACTLR_DISFPCA_Msk (1UL << SCnSCB_ACTLR_DISFPCA_Pos)`
- `#define SCnSCB_ACTLR_DISFOLD_Pos 2`
- `#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos)`
- `#define SCnSCB_ACTLR_DISDEFWBUF_Pos 1`
- `#define SCnSCB_ACTLR_DISDEFWBUF_Msk (1UL << SCnSCB_ACTLR_DISDEFWBUF_Pos)`
- `#define SCnSCB_ACTLR_DISMCYCINT_Pos 0`
- `#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/)`

### 5.22.1 Detailed Description

Type definitions for the System Control and ID Register not in the SCB.

### 5.22.2 Macro Definition Documentation

#### 5.22.2.1 SCnSCB\_ACTLR\_DISDEFWBUF\_Msk

```
#define SCnSCB_ACTLR_DISDEFWBUF_Msk (1UL << SCnSCB_ACTLR_DISDEFWBUF_Pos)
```

ACTLR: DISDEFWBUF Mask

#### 5.22.2.2 SCnSCB\_ACTLR\_DISDEFWBUF\_Pos

```
#define SCnSCB_ACTLR_DISDEFWBUF_Pos 1
```

ACTLR: DISDEFWBUF Position

#### 5.22.2.3 SCnSCB\_ACTLR\_DISFOLD\_Msk

```
#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos)
```

ACTLR: DISFOLD Mask

#### 5.22.2.4 SCnSCB\_ACTLR\_DISFOLD\_Pos

```
#define SCnSCB_ACTLR_DISFOLD_Pos 2
```

ACTLR: DISFOLD Position

#### 5.22.2.5 SCnSCB\_ACTLR\_DISFPCA\_Msk

```
#define SCnSCB_ACTLR_DISFPCA_Msk (1UL << SCnSCB_ACTLR_DISFPCA_Pos)
```

ACTLR: DISFPCA Mask

#### 5.22.2.6 SCnSCB\_ACTLR\_DISFPCA\_Pos

```
#define SCnSCB_ACTLR_DISFPCA_Pos 8
```

ACTLR: DISFPCA Position

#### 5.22.2.7 SCnSCB\_ACTLR\_DISMCYCINT\_Msk

```
#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/)
```

ACTLR: DISMCYCINT Mask

#### 5.22.2.8 SCnSCB\_ACTLR\_DISMCYCINT\_Pos

```
#define SCnSCB_ACTLR_DISMCYCINT_Pos 0
```

ACTLR: DISMCYCINT Position

#### 5.22.2.9 SCnSCB\_ACTLR\_DISOOFP\_Msk

```
#define SCnSCB_ACTLR_DISOOFP_Msk (1UL << SCnSCB_ACTLR_DISOOFP_Pos)
```

ACTLR: DISOOFP Mask

#### 5.22.2.10 SCnSCB\_ACTLR\_DISOOFP\_Pos

```
#define SCnSCB_ACTLR_DISOOFP_Pos 9
```

ACTLR: DISOOFP Position

#### 5.22.2.11 SCnSCB\_ICTR\_INTLINESNUM\_Msk

```
#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/)
```

ICTR: INTLINESNUM Mask

### 5.22.2.12 SCnSCB\_ICTR\_INTLINESNUM\_Pos

```
#define SCnSCB_ICTR_INTLINESNUM_Pos 0
```

ICTR: INTLINESNUM Position

## 5.23 System Tick Timer (SysTick)

Type definitions for the System Timer Registers.

Collaboration diagram for System Tick Timer (SysTick):



## Modules

- Instrumentation Trace Macrocell (ITM)

*Type definitions for the Instrumentation Trace Macrocell (ITM)*

## Classes

- struct [SysTick\\_Type](#)

*Structure type to access the System Timer (SysTick).*

- #define [SysTick\\_CTRL\\_COUNTFLAG\\_Pos](#) 16
- #define [SysTick\\_CTRL\\_COUNTFLAG\\_Msk](#) (1UL << [SysTick\\_CTRL\\_COUNTFLAG\\_Pos](#))
- #define [SysTick\\_CTRL\\_CLKSOURCE\\_Pos](#) 2
- #define [SysTick\\_CTRL\\_CLKSOURCE\\_Msk](#) (1UL << [SysTick\\_CTRL\\_CLKSOURCE\\_Pos](#))
- #define [SysTick\\_CTRL\\_TICKINT\\_Pos](#) 1
- #define [SysTick\\_CTRL\\_TICKINT\\_Msk](#) (1UL << [SysTick\\_CTRL\\_TICKINT\\_Pos](#))
- #define [SysTick\\_CTRL\\_ENABLE\\_Pos](#) 0
- #define [SysTick\\_CTRL\\_ENABLE\\_Msk](#) (1UL /\*<< [SysTick\\_CTRL\\_ENABLE\\_Pos\\*/\)](#)
- #define [SysTick\\_LOAD\\_RELOAD\\_Pos](#) 0
- #define [SysTick\\_LOAD\\_RELOAD\\_Msk](#) (0xFFFFFFFFUL /\*<< [SysTick\\_LOAD\\_RELOAD\\_Pos\\*/\)](#)
- #define [SysTick\\_VAL\\_CURRENT\\_Pos](#) 0
- #define [SysTick\\_VAL\\_CURRENT\\_Msk](#) (0xFFFFFFFFUL /\*<< [SysTick\\_VAL\\_CURRENT\\_Pos\\*/\)](#)
- #define [SysTick\\_CALIB\\_NOREF\\_Pos](#) 31
- #define [SysTick\\_CALIB\\_NOREF\\_Msk](#) (1UL << [SysTick\\_CALIB\\_NOREF\\_Pos](#))
- #define [SysTick\\_CALIB\\_SKEW\\_Pos](#) 30
- #define [SysTick\\_CALIB\\_SKEW\\_Msk](#) (1UL << [SysTick\\_CALIB\\_SKEW\\_Pos](#))
- #define [SysTick\\_CALIB\\_TENMS\\_Pos](#) 0
- #define [SysTick\\_CALIB\\_TENMS\\_Msk](#) (0xFFFFFFFFUL /\*<< [SysTick\\_CALIB\\_TENMS\\_Pos\\*/\)](#)

### 5.23.1 Detailed Description

Type definitions for the System Timer Registers.

### 5.23.2 Macro Definition Documentation

#### 5.23.2.1 SysTick\_CALIB\_NOREF\_Msk

```
#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos)
```

SysTick CALIB: NOREF Mask

#### 5.23.2.2 SysTick\_CALIB\_NOREF\_Pos

```
#define SysTick_CALIB_NOREF_Pos 31
```

SysTick CALIB: NOREF Position

#### 5.23.2.3 SysTick\_CALIB\_SKEW\_Msk

```
#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos)
```

SysTick CALIB: SKEW Mask

#### 5.23.2.4 SysTick\_CALIB\_SKEW\_Pos

```
#define SysTick_CALIB_SKEW_Pos 30
```

SysTick CALIB: SKEW Position

#### 5.23.2.5 SysTick\_CALIB\_TENMS\_Msk

```
#define SysTick_CALIB_TENMS_Msk (0xFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/)
```

SysTick CALIB: TENMS Mask

#### 5.23.2.6 SysTick\_CALIB\_TENMS\_Pos

```
#define SysTick_CALIB_TENMS_Pos 0
```

SysTick CALIB: TENMS Position

### 5.23.2.7 SysTick\_CTRL\_CLKSOURCE\_Msk

```
#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos)
```

SysTick CTRL: CLKSOURCE Mask

### 5.23.2.8 SysTick\_CTRL\_CLKSOURCE\_Pos

```
#define SysTick_CTRL_CLKSOURCE_Pos 2
```

SysTick CTRL: CLKSOURCE Position

### 5.23.2.9 SysTick\_CTRL\_COUNTFLAG\_Msk

```
#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos)
```

SysTick CTRL: COUNTFLAG Mask

### 5.23.2.10 SysTick\_CTRL\_COUNTFLAG\_Pos

```
#define SysTick_CTRL_COUNTFLAG_Pos 16
```

SysTick CTRL: COUNTFLAG Position

### 5.23.2.11 SysTick\_CTRL\_ENABLE\_Msk

```
#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/)
```

SysTick CTRL: ENABLE Mask

### 5.23.2.12 SysTick\_CTRL\_ENABLE\_Pos

```
#define SysTick_CTRL_ENABLE_Pos 0
```

SysTick CTRL: ENABLE Position

### 5.23.2.13 SysTick\_CTRL\_TICKINT\_Msk

```
#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos)
```

SysTick CTRL: TICKINT Mask

### 5.23.2.14 SysTick\_CTRL\_TICKINT\_Pos

```
#define SysTick_CTRL_TICKINT_Pos 1
```

SysTick CTRL: TICKINT Position

### 5.23.2.15 SysTick\_LOAD\_RELOAD\_Msk

```
#define SysTick_LOAD_RELOAD_Msk (0xFFFFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/)
```

SysTick LOAD: RELOAD Mask

### 5.23.2.16 SysTick\_LOAD\_RELOAD\_Pos

```
#define SysTick_LOAD_RELOAD_Pos 0
```

SysTick LOAD: RELOAD Position

### 5.23.2.17 SysTick\_VAL\_CURRENT\_Msk

```
#define SysTick_VAL_CURRENT_Msk (0xFFFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/)
```

SysTick VAL: CURRENT Mask

### 5.23.2.18 SysTick\_VAL\_CURRENT\_Pos

```
#define SysTick_VAL_CURRENT_Pos 0
```

SysTick VAL: CURRENT Position

## 5.24 Instrumentation Trace Macrocell (ITM)

Type definitions for the Instrumentation Trace Macrocell (ITM)

Collaboration diagram for Instrumentation Trace Macrocell (ITM):



## Modules

- [Data Watchpoint and Trace \(DWT\)](#)

*Type definitions for the Data Watchpoint and Trace (DWT)*

## Classes

- struct `ITM_Type`  
*Structure type to access the Instrumentation Trace Macrocell Register (ITM).*
- `#define ITM_TPR_PRIVMASK_Pos 0`
- `#define ITM_TPR_PRIVMASK_Msk (0xFUL /*<< ITM_TPR_PRIVMASK_Pos*/)`
- `#define ITM_TCR_BUSY_Pos 23`
- `#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos)`
- `#define ITM_TCR_TraceBusID_Pos 16`
- `#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos)`
- `#define ITM_TCR_GTSFREQ_Pos 10`
- `#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos)`
- `#define ITM_TCR_TSPrescale_Pos 8`
- `#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos)`
- `#define ITM_TCR_SWOENA_Pos 4`
- `#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos)`
- `#define ITM_TCR_DWTENA_Pos 3`
- `#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos)`
- `#define ITM_TCR_SYNCENA_Pos 2`
- `#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos)`
- `#define ITM_TCR_TSENA_Pos 1`
- `#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos)`
- `#define ITM_TCR_ITMENA_Pos 0`
- `#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/)`
- `#define ITM_IWR_ATVALIDM_Pos 0`
- `#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/)`
- `#define ITM_IRR_ATREADYM_Pos 0`
- `#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/)`
- `#define ITM_IMCR_INTEGRATION_Pos 0`
- `#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/)`
- `#define ITM_LSR_ByteAcc_Pos 2`
- `#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos)`
- `#define ITM_LSR_Access_Pos 1`
- `#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos)`
- `#define ITM_LSR_Present_Pos 0`
- `#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/)`

### 5.24.1 Detailed Description

Type definitions for the Instrumentation Trace Macrocell (ITM)

### 5.24.2 Macro Definition Documentation

#### 5.24.2.1 ITM\_IMCR\_INTEGRATION\_Msk

```
#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/)
```

ITM IMCR: INTEGRATION Mask

### 5.24.2.2 ITM\_IMCR\_INTEGRATION\_Pos

```
#define ITM_IMCR_INTEGRATION_Pos 0
```

ITM IMCR: INTEGRATION Position

### 5.24.2.3 ITM\_IRR\_ATREADYM\_Msk

```
#define ITM_IRR_ATREADYM_Msk (1UL /*<< ITM_IRR_ATREADYM_Pos*/)
```

ITM IRR: ATREADYM Mask

### 5.24.2.4 ITM\_IRR\_ATREADYM\_Pos

```
#define ITM_IRR_ATREADYM_Pos 0
```

ITM IRR: ATREADYM Position

### 5.24.2.5 ITM\_IWR\_ATVALIDM\_Msk

```
#define ITM_IWR_ATVALIDM_Msk (1UL /*<< ITM_IWR_ATVALIDM_Pos*/)
```

ITM IWR: ATVALIDM Mask

### 5.24.2.6 ITM\_IWR\_ATVALIDM\_Pos

```
#define ITM_IWR_ATVALIDM_Pos 0
```

ITM IWR: ATVALIDM Position

### 5.24.2.7 ITM\_LSR\_Access\_Msk

```
#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos)
```

ITM LSR: Access Mask

### 5.24.2.8 ITM\_LSR\_Access\_Pos

```
#define ITM_LSR_Access_Pos 1
```

ITM LSR: Access Position

### 5.24.2.9 ITM\_LSR\_BytAcc\_Msk

```
#define ITM_LSR_BytAcc_Msk (1UL << ITM_LSR_BytAcc_Pos)
```

ITM LSR: ByteAcc Mask

### 5.24.2.10 ITM\_LSR\_ByteAcc\_Pos

```
#define ITM_LSR_ByteAcc_Pos 2
```

ITM LSR: ByteAcc Position

### 5.24.2.11 ITM\_LSR\_Present\_Msk

```
#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/)
```

ITM LSR: Present Mask

### 5.24.2.12 ITM\_LSR\_Present\_Pos

```
#define ITM_LSR_Present_Pos 0
```

ITM LSR: Present Position

### 5.24.2.13 ITM\_TCR\_BUSY\_Msk

```
#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos)
```

ITM TCR: BUSY Mask

### 5.24.2.14 ITM\_TCR\_BUSY\_Pos

```
#define ITM_TCR_BUSY_Pos 23
```

ITM TCR: BUSY Position

### 5.24.2.15 ITM\_TCR\_DWTENA\_Msk

```
#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos)
```

ITM TCR: DWTENA Mask

### 5.24.2.16 ITM\_TCR\_DWTENA\_Pos

```
#define ITM_TCR_DWTENA_Pos 3
```

ITM TCR: DWTENA Position

### 5.24.2.17 ITM\_TCR\_GTSFREQ\_Msk

```
#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos)
```

ITM TCR: Global timestamp frequency Mask

### 5.24.2.18 ITM\_TCR\_GTSFREQ\_Pos

```
#define ITM_TCR_GTSFREQ_Pos 10
```

ITM TCR: Global timestamp frequency Position

### 5.24.2.19 ITM\_TCR\_ITMENA\_Msk

```
#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/)
```

ITM TCR: ITM Enable bit Mask

### 5.24.2.20 ITM\_TCR\_ITMENA\_Pos

```
#define ITM_TCR_ITMENA_Pos 0
```

ITM TCR: ITM Enable bit Position

### 5.24.2.21 ITM\_TCR\_SWOENA\_Msk

```
#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos)
```

ITM TCR: SWOENA Mask

### 5.24.2.22 ITM\_TCR\_SWOENA\_Pos

```
#define ITM_TCR_SWOENA_Pos 4
```

ITM TCR: SWOENA Position

### 5.24.2.23 ITM\_TCR\_SYNCENA\_Msk

```
#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos)
```

ITM TCR: SYNCENA Mask

### 5.24.2.24 ITM\_TCR\_SYNCENA\_Pos

```
#define ITM_TCR_SYNCENA_Pos 2
```

ITM TCR: SYNCENA Position

### 5.24.2.25 ITM\_TCR\_TraceBusID\_Msk

```
#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos)
```

ITM TCR: ATBID Mask

### 5.24.2.26 ITM\_TCR\_TraceBusID\_Pos

```
#define ITM_TCR_TraceBusID_Pos 16
```

ITM TCR: ATBID Position

### 5.24.2.27 ITM\_TCR\_TSENA\_Msk

```
#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos)
```

ITM TCR: TSENA Mask

### 5.24.2.28 ITM\_TCR\_TSENA\_Pos

```
#define ITM_TCR_TSENA_Pos 1
```

ITM TCR: TSENA Position

### 5.24.2.29 ITM\_TCR\_TSPrescale\_Msk

```
#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos)
```

ITM TCR: TSPrescale Mask

### 5.24.2.30 ITM\_TCR\_TSPrescale\_Pos

```
#define ITM_TCR_TSPrescale_Pos 8
```

ITM TCR: TSPrescale Position

### 5.24.2.31 ITM\_TPR\_PRIVMASK\_Msk

```
#define ITM_TPR_PRIVMASK_Msk (0xFUL /*<< ITM_TPR_PRIVMASK_Pos*/)
```

ITM TPR: PRIVMASK Mask

### 5.24.2.32 ITM\_TPR\_PRIVMASK\_Pos

```
#define ITM_TPR_PRIVMASK_Pos 0
```

ITM TPR: PRIVMASK Position

## 5.25 Data Watchpoint and Trace (DWT)

Type definitions for the Data Watchpoint and Trace (DWT)

Collaboration diagram for Data Watchpoint and Trace (DWT):



### Modules

- [Trace Port Interface \(TPI\)](#)

*Type definitions for the Trace Port Interface (TPI)*

### Classes

- struct [DWT\\_Type](#)

*Structure type to access the Data Watchpoint and Trace Register (DWT).*

- #define [DWT\\_CTRL\\_NUMCOMP\\_Pos](#) 28
- #define [DWT\\_CTRL\\_NUMCOMP\\_Msk](#) (0xFUL << [DWT\\_CTRL\\_NUMCOMP\\_Pos](#))
- #define [DWT\\_CTRL\\_NOTRCPKT\\_Pos](#) 27
- #define [DWT\\_CTRL\\_NOTRCPKT\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_NOTRCPKT\\_Pos](#))
- #define [DWT\\_CTRL\\_NOEXTTRIG\\_Pos](#) 26
- #define [DWT\\_CTRL\\_NOEXTTRIG\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_NOEXTTRIG\\_Pos](#))
- #define [DWT\\_CTRL\\_NOCYCCNT\\_Pos](#) 25
- #define [DWT\\_CTRL\\_NOCYCCNT\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_NOCYCCNT\\_Pos](#))
- #define [DWT\\_CTRL\\_NOPRFCNT\\_Pos](#) 24
- #define [DWT\\_CTRL\\_NOPRFCNT\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_NOPRFCNT\\_Pos](#))
- #define [DWT\\_CTRL\\_CYCEVTENA\\_Pos](#) 22
- #define [DWT\\_CTRL\\_CYCEVTENA\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_CYCEVTENA\\_Pos](#))
- #define [DWT\\_CTRL\\_FOLDEVTENA\\_Pos](#) 21
- #define [DWT\\_CTRL\\_FOLDEVTENA\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_FOLDEVTENA\\_Pos](#))
- #define [DWT\\_CTRL\\_LSUEVTENA\\_Pos](#) 20
- #define [DWT\\_CTRL\\_LSUEVTENA\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_LSUEVTENA\\_Pos](#))
- #define [DWT\\_CTRL\\_SLEEPEVTENA\\_Pos](#) 19
- #define [DWT\\_CTRL\\_SLEEPEVTENA\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_SLEEPEVTENA\\_Pos](#))
- #define [DWT\\_CTRL\\_EXCEVTENA\\_Pos](#) 18
- #define [DWT\\_CTRL\\_EXCEVTENA\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_EXCEVTENA\\_Pos](#))
- #define [DWT\\_CTRL\\_CPIEVTENA\\_Pos](#) 17
- #define [DWT\\_CTRL\\_CPIEVTENA\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_CPIEVTENA\\_Pos](#))
- #define [DWT\\_CTRL\\_EXCTRCENA\\_Pos](#) 16
- #define [DWT\\_CTRL\\_EXCTRCENA\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_EXCTRCENA\\_Pos](#))
- #define [DWT\\_CTRL\\_PCSAMPLENA\\_Pos](#) 12
- #define [DWT\\_CTRL\\_PCSAMPLENA\\_Msk](#) (0x1UL << [DWT\\_CTRL\\_PCSAMPLENA\\_Pos](#))
- #define [DWT\\_CTRL\\_SYNCTAP\\_Pos](#) 10

- #define DWT\_CTRL\_SYNCTAP\_Msk (0x3UL << DWT\_CTRL\_SYNCTAP\_Pos)
- #define DWT\_CTRL\_CYCTAP\_Pos 9
- #define DWT\_CTRL\_CYCTAP\_Msk (0x1UL << DWT\_CTRL\_CYCTAP\_Pos)
- #define DWT\_CTRL\_POSTINIT\_Pos 5
- #define DWT\_CTRL\_POSTINIT\_Msk (0xFUL << DWT\_CTRL\_POSTINIT\_Pos)
- #define DWT\_CTRL\_POSTRESET\_Pos 1
- #define DWT\_CTRL\_POSTRESET\_Msk (0xFUL << DWT\_CTRL\_POSTRESET\_Pos)
- #define DWT\_CTRL\_CYCCNTENA\_Pos 0
- #define DWT\_CTRL\_CYCCNTENA\_Msk (0x1UL /\*<< DWT\_CTRL\_CYCCNTENA\_Pos\*/)
- #define DWT\_CPLICNT\_CPLICNT\_Pos 0
- #define DWT\_CPLICNT\_CPLICNT\_Msk (0xFFUL /\*<< DWT\_CPLICNT\_CPLICNT\_Pos\*/)
- #define DWT\_EXCCNT\_EXCCNT\_Pos 0
- #define DWT\_EXCCNT\_EXCCNT\_Msk (0xFFUL /\*<< DWT\_EXCCNT\_EXCCNT\_Pos\*/)
- #define DWT\_SLEEPCNT\_SLEEPCNT\_Pos 0
- #define DWT\_SLEEPCNT\_SLEEPCNT\_Msk (0xFFUL /\*<< DWT\_SLEEPCNT\_SLEEPCNT\_Pos\*/)
- #define DWT\_LSUCNT\_LSUCNT\_Pos 0
- #define DWT\_LSUCNT\_LSUCNT\_Msk (0xFFUL /\*<< DWT\_LSUCNT\_LSUCNT\_Pos\*/)
- #define DWT\_FOLDCNT\_FOLDCNT\_Pos 0
- #define DWT\_FOLDCNT\_FOLDCNT\_Msk (0xFFUL /\*<< DWT\_FOLDCNT\_FOLDCNT\_Pos\*/)
- #define DWT\_MASK\_MASK\_Pos 0
- #define DWT\_MASK\_MASK\_Msk (0x1FUL /\*<< DWT\_MASK\_MASK\_Pos\*/)
- #define DWT\_FUNCTION\_MATCHED\_Pos 24
- #define DWT\_FUNCTION\_MATCHED\_Msk (0x1UL << DWT\_FUNCTION\_MATCHED\_Pos)
- #define DWT\_FUNCTION\_DATAVADDR1\_Pos 16
- #define DWT\_FUNCTION\_DATAVADDR1\_Msk (0xFUL << DWT\_FUNCTION\_DATAVADDR1\_Pos)
- #define DWT\_FUNCTION\_DATAVADDR0\_Pos 12
- #define DWT\_FUNCTION\_DATAVADDR0\_Msk (0xFUL << DWT\_FUNCTION\_DATAVADDR0\_Pos)
- #define DWT\_FUNCTION\_DATAVSIZE\_Pos 10
- #define DWT\_FUNCTION\_DATAVSIZE\_Msk (0x3UL << DWT\_FUNCTION\_DATAVSIZE\_Pos)
- #define DWT\_FUNCTION\_LNK1ENA\_Pos 9
- #define DWT\_FUNCTION\_LNK1ENA\_Msk (0x1UL << DWT\_FUNCTION\_LNK1ENA\_Pos)
- #define DWT\_FUNCTION\_DATAVMATCH\_Pos 8
- #define DWT\_FUNCTION\_DATAVMATCH\_Msk (0x1UL << DWT\_FUNCTION\_DATAVMATCH\_Pos)
- #define DWT\_FUNCTION\_CYCMATCH\_Pos 7
- #define DWT\_FUNCTION\_CYCMATCH\_Msk (0x1UL << DWT\_FUNCTION\_CYCMATCH\_Pos)
- #define DWT\_FUNCTION\_EMITRANGE\_Pos 5
- #define DWT\_FUNCTION\_EMITRANGE\_Msk (0x1UL << DWT\_FUNCTION\_EMITRANGE\_Pos)
- #define DWT\_FUNCTION\_FUNCTION\_Pos 0
- #define DWT\_FUNCTION\_FUNCTION\_Msk (0xFUL /\*<< DWT\_FUNCTION\_FUNCTION\_Pos\*/)

### 5.25.1 Detailed Description

Type definitions for the Data Watchpoint and Trace (DWT)

### 5.25.2 Macro Definition Documentation

### 5.25.2.1 DWT\_CPICNT\_CPICNT\_Msk

```
#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/)
```

DWT CPICNT: CPICNT Mask

### 5.25.2.2 DWT\_CPICNT\_CPICNT\_Pos

```
#define DWT_CPICNT_CPICNT_Pos 0
```

DWT CPICNT: CPICNT Position

### 5.25.2.3 DWT\_CTRL\_CPIEVTENA\_Msk

```
#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos)
```

DWT CTRL: CPIEVTENA Mask

### 5.25.2.4 DWT\_CTRL\_CPIEVTENA\_Pos

```
#define DWT_CTRL_CPIEVTENA_Pos 17
```

DWT CTRL: CPIEVTENA Position

### 5.25.2.5 DWT\_CTRL\_CYCCNTENA\_Msk

```
#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/)
```

DWT CTRL: CYCCNTENA Mask

### 5.25.2.6 DWT\_CTRL\_CYCCNTENA\_Pos

```
#define DWT_CTRL_CYCCNTENA_Pos 0
```

DWT CTRL: CYCCNTENA Position

### 5.25.2.7 DWT\_CTRL\_CYCEVTENA\_Msk

```
#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos)
```

DWT CTRL: CYCEVTENA Mask

### 5.25.2.8 DWT\_CTRL\_CYCEVTENA\_Pos

```
#define DWT_CTRL_CYCEVTENA_Pos 22
```

DWT CTRL: CYCEVTENA Position

### 5.25.2.9 DWT\_CTRL\_CYCTAP\_Msk

```
#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos)
```

DWT CTRL: CYCTAP Mask

### 5.25.2.10 DWT\_CTRL\_CYCTAP\_Pos

```
#define DWT_CTRL_CYCTAP_Pos 9
```

DWT CTRL: CYCTAP Position

### 5.25.2.11 DWT\_CTRL\_EXCEVTENA\_Msk

```
#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos)
```

DWT CTRL: EXCEVTENA Mask

### 5.25.2.12 DWT\_CTRL\_EXCEVTENA\_Pos

```
#define DWT_CTRL_EXCEVTENA_Pos 18
```

DWT CTRL: EXCEVTENA Position

### 5.25.2.13 DWT\_CTRL\_EXCTRCENA\_Msk

```
#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos)
```

DWT CTRL: EXCTRCENA Mask

### 5.25.2.14 DWT\_CTRL\_EXCTRCENA\_Pos

```
#define DWT_CTRL_EXCTRCENA_Pos 16
```

DWT CTRL: EXCTRCENA Position

### 5.25.2.15 DWT\_CTRL\_FOLDEVTENA\_Msk

```
#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos)
```

DWT CTRL: FOLDEVTENA Mask

### 5.25.2.16 DWT\_CTRL\_FOLDEVTENA\_Pos

```
#define DWT_CTRL_FOLDEVTENA_Pos 21
```

DWT CTRL: FOLDEVTENA Position

### 5.25.2.17 DWT\_CTRL\_LSUEVTENA\_Msk

```
#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos)
```

DWT CTRL: LSUEVTENA Mask

### 5.25.2.18 DWT\_CTRL\_LSUEVTENA\_Pos

```
#define DWT_CTRL_LSUEVTENA_Pos 20
```

DWT CTRL: LSUEVTENA Position

### 5.25.2.19 DWT\_CTRL\_NOCYCCNT\_Msk

```
#define DWT_CTRL_NOCYCCNT_Msk (0x1UL << DWT_CTRL_NOCYCCNT_Pos)
```

DWT CTRL: NOCYCCNT Mask

### 5.25.2.20 DWT\_CTRL\_NOCYCCNT\_Pos

```
#define DWT_CTRL_NOCYCCNT_Pos 25
```

DWT CTRL: NOCYCCNT Position

### 5.25.2.21 DWT\_CTRL\_NOEXTTRIG\_Msk

```
#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos)
```

DWT CTRL: NOEXTTRIG Mask

### 5.25.2.22 DWT\_CTRL\_NOEXTTRIG\_Pos

```
#define DWT_CTRL_NOEXTTRIG_Pos 26
```

DWT CTRL: NOEXTTRIG Position

### 5.25.2.23 DWT\_CTRL\_NOPRFCNT\_Msk

```
#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos)
```

DWT CTRL: NOPRFCNT Mask

### 5.25.2.24 DWT\_CTRL\_NOPRFCNT\_Pos

```
#define DWT_CTRL_NOPRFCNT_Pos 24
```

DWT CTRL: NOPRFCNT Position

### 5.25.2.25 DWT\_CTRL\_NOTRCPKT\_Msk

```
#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos)
```

DWT CTRL: NOTRCPKT Mask

### 5.25.2.26 DWT\_CTRL\_NOTRCPKT\_Pos

```
#define DWT_CTRL_NOTRCPKT_Pos 27
```

DWT CTRL: NOTRCPKT Position

### 5.25.2.27 DWT\_CTRL\_NUMCOMP\_Msk

```
#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos)
```

DWT CTRL: NUMCOMP Mask

### 5.25.2.28 DWT\_CTRL\_NUMCOMP\_Pos

```
#define DWT_CTRL_NUMCOMP_Pos 28
```

DWT CTRL: NUMCOMP Position

### 5.25.2.29 DWT\_CTRL\_PCSAMPLENA\_Msk

```
#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos)
```

DWT CTRL: PCSAMPLENA Mask

### 5.25.2.30 DWT\_CTRL\_PCSAMPLENA\_Pos

```
#define DWT_CTRL_PCSAMPLENA_Pos 12
```

DWT CTRL: PCSAMPLENA Position

### 5.25.2.31 DWT\_CTRL\_POSTINIT\_Msk

```
#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos)
```

DWT CTRL: POSTINIT Mask

### 5.25.2.32 DWT\_CTRL\_POSTINIT\_Pos

```
#define DWT_CTRL_POSTINIT_Pos 5
```

DWT CTRL: POSTINIT Position

### 5.25.2.33 DWT\_CTRL\_POSTPRESET\_Msk

```
#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos)
```

DWT CTRL: POSTPRESET Mask

### 5.25.2.34 DWT\_CTRL\_POSTPRESET\_Pos

```
#define DWT_CTRL_POSTPRESET_Pos 1
```

DWT CTRL: POSTPRESET Position

### 5.25.2.35 DWT\_CTRL\_SLEEPEVTENA\_Msk

```
#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos)
```

DWT CTRL: SLEEPEVTENA Mask

### 5.25.2.36 DWT\_CTRL\_SLEEPEVTENA\_Pos

```
#define DWT_CTRL_SLEEPEVTENA_Pos 19
```

DWT CTRL: SLEEPEVTENA Position

### 5.25.2.37 DWT\_CTRL\_SYNCTAP\_Msk

```
#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos)
```

DWT CTRL: SYNCTAP Mask

### 5.25.2.38 DWT\_CTRL\_SYNCTAP\_Pos

```
#define DWT_CTRL_SYNCTAP_Pos 10
```

DWT CTRL: SYNCTAP Position

### 5.25.2.39 DWT\_EXCCNT\_EXCCNT\_Msk

```
#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/)
```

DWT EXCCNT: EXCCNT Mask

### 5.25.2.40 DWT\_EXCCNT\_EXCCNT\_Pos

```
#define DWT_EXCCNT_EXCCNT_Pos 0
```

DWT EXCCNT: EXCCNT Position

#### 5.25.2.41 DWT\_FOLDCNT\_FOLDCNT\_Msk

```
#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/)
```

DWT FOLDCNT: FOLDCNT Mask

#### 5.25.2.42 DWT\_FOLDCNT\_FOLDCNT\_Pos

```
#define DWT_FOLDCNT_FOLDCNT_Pos 0
```

DWT FOLDCNT: FOLDCNT Position

#### 5.25.2.43 DWT\_FUNCTION\_CYCMATCH\_Msk

```
#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos)
```

DWT FUNCTION: CYCMATCH Mask

#### 5.25.2.44 DWT\_FUNCTION\_CYCMATCH\_Pos

```
#define DWT_FUNCTION_CYCMATCH_Pos 7
```

DWT FUNCTION: CYCMATCH Position

#### 5.25.2.45 DWT\_FUNCTION\_DATAVADDR0\_Msk

```
#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos)
```

DWT FUNCTION: DATAVADDR0 Mask

#### 5.25.2.46 DWT\_FUNCTION\_DATAVADDR0\_Pos

```
#define DWT_FUNCTION_DATAVADDR0_Pos 12
```

DWT FUNCTION: DATAVADDR0 Position

#### 5.25.2.47 DWT\_FUNCTION\_DATAVADDR1\_Msk

```
#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos)
```

DWT FUNCTION: DATAVADDR1 Mask

#### 5.25.2.48 DWT\_FUNCTION\_DATAVADDR1\_Pos

```
#define DWT_FUNCTION_DATAVADDR1_Pos 16
```

DWT FUNCTION: DATAVADDR1 Position

### 5.25.2.49 DWT\_FUNCTION\_DATAVMATCH\_Msk

```
#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos)
```

DWT FUNCTION: DATAVMATCH Mask

### 5.25.2.50 DWT\_FUNCTION\_DATAVMATCH\_Pos

```
#define DWT_FUNCTION_DATAVMATCH_Pos 8
```

DWT FUNCTION: DATAVMATCH Position

### 5.25.2.51 DWT\_FUNCTION\_DATAVSIZE\_Msk

```
#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos)
```

DWT FUNCTION: DATAVSIZE Mask

### 5.25.2.52 DWT\_FUNCTION\_DATAVSIZE\_Pos

```
#define DWT_FUNCTION_DATAVSIZE_Pos 10
```

DWT FUNCTION: DATAVSIZE Position

### 5.25.2.53 DWT\_FUNCTION\_EMITRANGE\_Msk

```
#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos)
```

DWT FUNCTION: EMITRANGE Mask

### 5.25.2.54 DWT\_FUNCTION\_EMITRANGE\_Pos

```
#define DWT_FUNCTION_EMITRANGE_Pos 5
```

DWT FUNCTION: EMITRANGE Position

### 5.25.2.55 DWT\_FUNCTION\_FUNCTION\_Msk

```
#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/)
```

DWT FUNCTION: FUNCTION Mask

### 5.25.2.56 DWT\_FUNCTION\_FUNCTION\_Pos

```
#define DWT_FUNCTION_FUNCTION_Pos 0
```

DWT FUNCTION: FUNCTION Position

### 5.25.2.57 DWT\_FUNCTION\_LNK1ENA\_Msk

```
#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos)
```

DWT FUNCTION: LNK1ENA Mask

### 5.25.2.58 DWT\_FUNCTION\_LNK1ENA\_Pos

```
#define DWT_FUNCTION_LNK1ENA_Pos 9
```

DWT FUNCTION: LNK1ENA Position

### 5.25.2.59 DWT\_FUNCTION\_MATCHED\_Msk

```
#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos)
```

DWT FUNCTION: MATCHED Mask

### 5.25.2.60 DWT\_FUNCTION\_MATCHED\_Pos

```
#define DWT_FUNCTION_MATCHED_Pos 24
```

DWT FUNCTION: MATCHED Position

### 5.25.2.61 DWT\_LSUCNT\_LSUCNT\_Msk

```
#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/)
```

DWT LSUCNT: LSUCNT Mask

### 5.25.2.62 DWT\_LSUCNT\_LSUCNT\_Pos

```
#define DWT_LSUCNT_LSUCNT_Pos 0
```

DWT LSUCNT: LSUCNT Position

### 5.25.2.63 DWT\_MASK\_MASK\_Msk

```
#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/)
```

DWT MASK: MASK Mask

### 5.25.2.64 DWT\_MASK\_MASK\_Pos

```
#define DWT_MASK_MASK_Pos 0
```

DWT MASK: MASK Position

### 5.25.2.65 DWT\_SLEEPCNT\_SLEEPCNT\_Msk

```
#define DWT_SLEEPCNT_SLEEPCNT_Msk (0xFFUL /*<< DWT_SLEEPCNT_SLEEPCNT_Pos*/)
```

DWT SLEEPCNT: SLEEPCNT Mask

### 5.25.2.66 DWT\_SLEEPCNT\_SLEEPCNT\_Pos

```
#define DWT_SLEEPCNT_SLEEPCNT_Pos 0
```

DWT SLEEPCNT: SLEEPCNT Position

## 5.26 Trace Port Interface (TPI)

Type definitions for the Trace Port Interface (TPI)

Collaboration diagram for Trace Port Interface (TPI):



## Modules

- [Core Debug Registers \(CoreDebug\)](#)

*Type definitions for the Core Debug Registers.*

## Classes

- struct [TPI\\_Type](#)

*Structure type to access the Trace Port Interface Register (TPI).*

- #define [TPI\\_ACPR\\_PRESCALER\\_Pos](#) 0
- #define [TPI\\_ACPR\\_PRESCALER\\_Msk](#) (0x1FFFUL /\*<< [TPI\\_ACPR\\_PRESCALER\\_Pos](#)\*/)
- #define [TPI\\_SPPR\\_TXMODE\\_Pos](#) 0
- #define [TPI\\_SPPR\\_TXMODE\\_Msk](#) (0x3UL /\*<< [TPI\\_SPPR\\_TXMODE\\_Pos](#)\*/)
- #define [TPI\\_FFSR\\_FtNonStop\\_Pos](#) 3
- #define [TPI\\_FFSR\\_FtNonStop\\_Msk](#) (0x1UL << [TPI\\_FFSR\\_FtNonStop\\_Pos](#))
- #define [TPI\\_FFSR\\_TCPresent\\_Pos](#) 2
- #define [TPI\\_FFSR\\_TCPresent\\_Msk](#) (0x1UL << [TPI\\_FFSR\\_TCPresent\\_Pos](#))
- #define [TPI\\_FFSR\\_FtStopped\\_Pos](#) 1
- #define [TPI\\_FFSR\\_FtStopped\\_Msk](#) (0x1UL << [TPI\\_FFSR\\_FtStopped\\_Pos](#))
- #define [TPI\\_FFSR\\_FInProg\\_Pos](#) 0
- #define [TPI\\_FFSR\\_FInProg\\_Msk](#) (0x1UL /\*<< [TPI\\_FFSR\\_FInProg\\_Pos](#)\*/)

- #define TPI\_FFCR\_TrigIn\_Pos 8
- #define TPI\_FFCR\_TrigIn\_Msk (0x1UL << TPI\_FFCR\_TrigIn\_Pos)
- #define TPI\_FFCR\_EnFCont\_Pos 1
- #define TPI\_FFCR\_EnFCont\_Msk (0x1UL << TPI\_FFCR\_EnFCont\_Pos)
- #define TPI\_TRIGGER\_TRIGGER\_Pos 0
- #define TPI\_TRIGGER\_TRIGGER\_Msk (0x1UL /\*<< TPI\_TRIGGER\_TRIGGER\_Pos\*/)
- #define TPI\_FIFO0\_ITM\_ATVALID\_Pos 29
- #define TPI\_FIFO0\_ITM\_ATVALID\_Msk (0x3UL << TPI\_FIFO0\_ITM\_ATVALID\_Pos)
- #define TPI\_FIFO0\_ITM\_bytectcount\_Pos 27
- #define TPI\_FIFO0\_ITM\_bytectcount\_Msk (0x3UL << TPI\_FIFO0\_ITM\_bytectcount\_Pos)
- #define TPI\_FIFO0\_ETM\_ATVALID\_Pos 26
- #define TPI\_FIFO0\_ETM\_ATVALID\_Msk (0x3UL << TPI\_FIFO0\_ETM\_ATVALID\_Pos)
- #define TPI\_FIFO0\_ETM\_bytectcount\_Pos 24
- #define TPI\_FIFO0\_ETM\_bytectcount\_Msk (0x3UL << TPI\_FIFO0\_ETM\_bytectcount\_Pos)
- #define TPI\_FIFO0\_ETM2\_Pos 16
- #define TPI\_FIFO0\_ETM2\_Msk (0xFFUL << TPI\_FIFO0\_ETM2\_Pos)
- #define TPI\_FIFO0\_ETM1\_Pos 8
- #define TPI\_FIFO0\_ETM1\_Msk (0xFFUL << TPI\_FIFO0\_ETM1\_Pos)
- #define TPI\_FIFO0\_ETM0\_Pos 0
- #define TPI\_FIFO0\_ETM0\_Msk (0xFFUL /\*<< TPI\_FIFO0\_ETM0\_Pos\*/)
- #define TPI\_ITATBCTR2\_ATREADY\_Pos 0
- #define TPI\_ITATBCTR2\_ATREADY\_Msk (0x1UL /\*<< TPI\_ITATBCTR2\_ATREADY\_Pos\*/)
- #define TPI\_FIFO1\_ITM\_ATVALID\_Pos 29
- #define TPI\_FIFO1\_ITM\_ATVALID\_Msk (0x3UL << TPI\_FIFO1\_ITM\_ATVALID\_Pos)
- #define TPI\_FIFO1\_ITM\_bytectcount\_Pos 27
- #define TPI\_FIFO1\_ITM\_bytectcount\_Msk (0x3UL << TPI\_FIFO1\_ITM\_bytectcount\_Pos)
- #define TPI\_FIFO1\_ETM\_ATVALID\_Pos 26
- #define TPI\_FIFO1\_ETM\_ATVALID\_Msk (0x3UL << TPI\_FIFO1\_ETM\_ATVALID\_Pos)
- #define TPI\_FIFO1\_ETM\_bytectcount\_Pos 24
- #define TPI\_FIFO1\_ETM\_bytectcount\_Msk (0x3UL << TPI\_FIFO1\_ETM\_bytectcount\_Pos)
- #define TPI\_FIFO1\_ITM2\_Pos 16
- #define TPI\_FIFO1\_ITM2\_Msk (0xFFUL << TPI\_FIFO1\_ITM2\_Pos)
- #define TPI\_FIFO1\_ITM1\_Pos 8
- #define TPI\_FIFO1\_ITM1\_Msk (0xFFUL << TPI\_FIFO1\_ITM1\_Pos)
- #define TPI\_FIFO1\_ITM0\_Pos 0
- #define TPI\_FIFO1\_ITM0\_Msk (0xFFUL /\*<< TPI\_FIFO1\_ITM0\_Pos\*/)
- #define TPI\_ITATBCTR0\_ATREADY\_Pos 0
- #define TPI\_ITATBCTR0\_ATREADY\_Msk (0x1UL /\*<< TPI\_ITATBCTR0\_ATREADY\_Pos\*/)
- #define TPI\_ITCTRL\_Mode\_Pos 0
- #define TPI\_ITCTRL\_Mode\_Msk (0x1UL /\*<< TPI\_ITCTRL\_Mode\_Pos\*/)
- #define TPI\_DEVID\_NRZVALID\_Pos 11
- #define TPI\_DEVID\_NRZVALID\_Msk (0x1UL << TPI\_DEVID\_NRZVALID\_Pos)
- #define TPI\_DEVID\_MANCVALID\_Pos 10
- #define TPI\_DEVID\_MANCVALID\_Msk (0x1UL << TPI\_DEVID\_MANCVALID\_Pos)
- #define TPI\_DEVID\_PTINVALID\_Pos 9
- #define TPI\_DEVID\_PTINVALID\_Msk (0x1UL << TPI\_DEVID\_PTINVALID\_Pos)
- #define TPI\_DEVID\_MinBufSz\_Pos 6
- #define TPI\_DEVID\_MinBufSz\_Msk (0x7UL << TPI\_DEVID\_MinBufSz\_Pos)
- #define TPI\_DEVID\_AsynClkln\_Pos 5
- #define TPI\_DEVID\_AsynClkln\_Msk (0x1UL << TPI\_DEVID\_AsynClkln\_Pos)
- #define TPI\_DEVID\_NrTraceInput\_Pos 0
- #define TPI\_DEVID\_NrTraceInput\_Msk (0xFUL /\*<< TPI\_DEVID\_NrTraceInput\_Pos\*/)
- #define TPI\_DEVTYPE\_MajorType\_Pos 4
- #define TPI\_DEVTYPE\_MajorType\_Msk (0xFUL << TPI\_DEVTYPE\_MajorType\_Pos)
- #define TPI\_DEVTYPE\_SubType\_Pos 0
- #define TPI\_DEVTYPE\_SubType\_Msk (0xFUL /\*<< TPI\_DEVTYPE\_SubType\_Pos\*/)

### 5.26.1 Detailed Description

Type definitions for the Trace Port Interface (TPI)

### 5.26.2 Macro Definition Documentation

#### 5.26.2.1 TPI\_ACPR\_PRESCALER\_Msk

```
#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/)
```

TPI ACPR: PRESCALER Mask

#### 5.26.2.2 TPI\_ACPR\_PRESCALER\_Pos

```
#define TPI_ACPR_PRESCALER_Pos 0
```

TPI ACPR: PRESCALER Position

#### 5.26.2.3 TPI\_DEVID\_AsynClkIn\_Msk

```
#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos)
```

TPI DEVID: AsynClkIn Mask

#### 5.26.2.4 TPI\_DEVID\_AsynClkIn\_Pos

```
#define TPI_DEVID_AsynClkIn_Pos 5
```

TPI DEVID: AsynClkIn Position

#### 5.26.2.5 TPI\_DEVID\_MANCVALID\_Msk

```
#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos)
```

TPI DEVID: MANCVALID Mask

#### 5.26.2.6 TPI\_DEVID\_MANCVALID\_Pos

```
#define TPI_DEVID_MANCVALID_Pos 10
```

TPI DEVID: MANCVALID Position

### 5.26.2.7 TPI\_DEVID\_MinBufSz\_Msk

```
#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos)
```

TPI DEVID: MinBufSz Mask

### 5.26.2.8 TPI\_DEVID\_MinBufSz\_Pos

```
#define TPI_DEVID_MinBufSz_Pos 6
```

TPI DEVID: MinBufSz Position

### 5.26.2.9 TPI\_DEVID\_NrTraceInput\_Msk

```
#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/)
```

TPI DEVID: NrTraceInput Mask

### 5.26.2.10 TPI\_DEVID\_NrTraceInput\_Pos

```
#define TPI_DEVID_NrTraceInput_Pos 0
```

TPI DEVID: NrTraceInput Position

### 5.26.2.11 TPI\_DEVID\_NRZVALID\_Msk

```
#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos)
```

TPI DEVID: NRZVALID Mask

### 5.26.2.12 TPI\_DEVID\_NRZVALID\_Pos

```
#define TPI_DEVID_NRZVALID_Pos 11
```

TPI DEVID: NRZVALID Position

### 5.26.2.13 TPI\_DEVID\_PTINVALID\_Msk

```
#define TPI_DEVID_PTINVALID_Msk (0x1UL << TPI_DEVID_PTINVALID_Pos)
```

TPI DEVID: PTINVALID Mask

### 5.26.2.14 TPI\_DEVID\_PTINVALID\_Pos

```
#define TPI_DEVID_PTINVALID_Pos 9
```

TPI DEVID: PTINVALID Position

### 5.26.2.15 TPI\_DEVTYPE\_MajorType\_Msk

```
#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos)
```

TPI DEVTYPE: MajorType Mask

### 5.26.2.16 TPI\_DEVTYPE\_MajorType\_Pos

```
#define TPI_DEVTYPE_MajorType_Pos 4
```

TPI DEVTYPE: MajorType Position

### 5.26.2.17 TPI\_DEVTYPE\_SubType\_Msk

```
#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/)
```

TPI DEVTYPE: SubType Mask

### 5.26.2.18 TPI\_DEVTYPE\_SubType\_Pos

```
#define TPI_DEVTYPE_SubType_Pos 0
```

TPI DEVTYPE: SubType Position

### 5.26.2.19 TPI\_FFCR\_EnFCont\_Msk

```
#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos)
```

TPI FFCR: EnFCont Mask

### 5.26.2.20 TPI\_FFCR\_EnFCont\_Pos

```
#define TPI_FFCR_EnFCont_Pos 1
```

TPI FFCR: EnFCont Position

### 5.26.2.21 TPI\_FFCR\_TrigIn\_Msk

```
#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos)
```

TPI FFCR: TrigIn Mask

### 5.26.2.22 TPI\_FFCR\_TrigIn\_Pos

```
#define TPI_FFCR_TrigIn_Pos 8
```

TPI FFCR: TrigIn Position

### 5.26.2.23 TPI\_FFSR\_FInProg\_Msk

```
#define TPI_FFSR_FInProg_Msk (0x1UL /*<< TPI_FFSR_FInProg_Pos*/)
```

TPI FFSR: FInProg Mask

### 5.26.2.24 TPI\_FFSR\_FInProg\_Pos

```
#define TPI_FFSR_FInProg_Pos 0
```

TPI FFSR: FInProg Position

### 5.26.2.25 TPI\_FFSR\_FtNonStop\_Msk

```
#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos)
```

TPI FFSR: FtNonStop Mask

### 5.26.2.26 TPI\_FFSR\_FtNonStop\_Pos

```
#define TPI_FFSR_FtNonStop_Pos 3
```

TPI FFSR: FtNonStop Position

### 5.26.2.27 TPI\_FFSR\_FtStopped\_Msk

```
#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos)
```

TPI FFSR: FtStopped Mask

### 5.26.2.28 TPI\_FFSR\_FtStopped\_Pos

```
#define TPI_FFSR_FtStopped_Pos 1
```

TPI FFSR: FtStopped Position

### 5.26.2.29 TPI\_FFSR\_TCPresent\_Msk

```
#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos)
```

TPI FFSR: TCPresent Mask

### 5.26.2.30 TPI\_FFSR\_TCPresent\_Pos

```
#define TPI_FFSR_TCPresent_Pos 2
```

TPI FFSR: TCPresent Position

### 5.26.2.31 TPI\_FIFO0\_ETM0\_Msk

```
#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/)
```

TPI FIFO0: ETM0 Mask

### 5.26.2.32 TPI\_FIFO0\_ETM0\_Pos

```
#define TPI_FIFO0_ETM0_Pos 0
```

TPI FIFO0: ETM0 Position

### 5.26.2.33 TPI\_FIFO0\_ETM1\_Msk

```
#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos)
```

TPI FIFO0: ETM1 Mask

### 5.26.2.34 TPI\_FIFO0\_ETM1\_Pos

```
#define TPI_FIFO0_ETM1_Pos 8
```

TPI FIFO0: ETM1 Position

### 5.26.2.35 TPI\_FIFO0\_ETM2\_Msk

```
#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos)
```

TPI FIFO0: ETM2 Mask

### 5.26.2.36 TPI\_FIFO0\_ETM2\_Pos

```
#define TPI_FIFO0_ETM2_Pos 16
```

TPI FIFO0: ETM2 Position

### 5.26.2.37 TPI\_FIFO0\_ETM\_ATVALID\_Msk

```
#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos)
```

TPI FIFO0: ETM\_ATVALID Mask

### 5.26.2.38 TPI\_FIFO0\_ETM\_ATVALID\_Pos

```
#define TPI_FIFO0_ETM_ATVALID_Pos 26
```

TPI FIFO0: ETM\_ATVALID Position

### 5.26.2.39 TPI\_FIFO0\_ETM\_bytecount\_Msk

```
#define TPI_FIFO0_ETM_bytecount_Msk (0x3UL << TPI_FIFO0_ETM_bytecount_Pos)
```

TPI FIFO0: ETM\_bytecount Mask

### 5.26.2.40 TPI\_FIFO0\_ETM\_bytecount\_Pos

```
#define TPI_FIFO0_ETM_bytecount_Pos 24
```

TPI FIFO0: ETM\_bytecount Position

### 5.26.2.41 TPI\_FIFO0\_ITM\_ATVALID\_Msk

```
#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos)
```

TPI FIFO0: ITM\_ATVALID Mask

### 5.26.2.42 TPI\_FIFO0\_ITM\_ATVALID\_Pos

```
#define TPI_FIFO0_ITM_ATVALID_Pos 29
```

TPI FIFO0: ITM\_ATVALID Position

### 5.26.2.43 TPI\_FIFO0\_ITM\_bytecount\_Msk

```
#define TPI_FIFO0_ITM_bytecount_Msk (0x3UL << TPI_FIFO0_ITM_bytecount_Pos)
```

TPI FIFO0: ITM\_bytecount Mask

### 5.26.2.44 TPI\_FIFO0\_ITM\_bytecount\_Pos

```
#define TPI_FIFO0_ITM_bytecount_Pos 27
```

TPI FIFO0: ITM\_bytecount Position

### 5.26.2.45 TPI\_FIFO1\_ETM\_ATVALID\_Msk

```
#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos)
```

TPI FIFO1: ETM\_ATVALID Mask

### 5.26.2.46 TPI\_FIFO1\_ETM\_ATVALID\_Pos

```
#define TPI_FIFO1_ETM_ATVALID_Pos 26
```

TPI FIFO1: ETM\_ATVALID Position

### 5.26.2.47 TPI\_FIFO1\_ETM\_bytecount\_Msk

```
#define TPI_FIFO1_ETM_bytecount_Msk (0x3UL << TPI_FIFO1_ETM_bytecount_Pos)
```

TPI FIFO1: ETM\_bytecount Mask

### 5.26.2.48 TPI\_FIFO1\_ETM\_bytecount\_Pos

```
#define TPI_FIFO1_ETM_bytecount_Pos 24
```

TPI FIFO1: ETM\_bytecount Position

### 5.26.2.49 TPI\_FIFO1\_ITM0\_Msk

```
#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/)
```

TPI FIFO1: ITM0 Mask

### 5.26.2.50 TPI\_FIFO1\_ITM0\_Pos

```
#define TPI_FIFO1_ITM0_Pos 0
```

TPI FIFO1: ITM0 Position

### 5.26.2.51 TPI\_FIFO1\_ITM1\_Msk

```
#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos)
```

TPI FIFO1: ITM1 Mask

### 5.26.2.52 TPI\_FIFO1\_ITM1\_Pos

```
#define TPI_FIFO1_ITM1_Pos 8
```

TPI FIFO1: ITM1 Position

### 5.26.2.53 TPI\_FIFO1\_ITM2\_Msk

```
#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos)
```

TPI FIFO1: ITM2 Mask

### 5.26.2.54 TPI\_FIFO1\_ITM2\_Pos

```
#define TPI_FIFO1_ITM2_Pos 16
```

TPI FIFO1: ITM2 Position

### 5.26.2.55 TPI\_FIFO1\_ITM\_ATVALID\_Msk

```
#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos)
```

TPI FIFO1: ITM\_ATVALID Mask

### 5.26.2.56 TPI\_FIFO1\_ITM\_ATVALID\_Pos

```
#define TPI_FIFO1_ITM_ATVALID_Pos 29
```

TPI FIFO1: ITM\_ATVALID Position

### 5.26.2.57 TPI\_FIFO1\_ITM\_bytecount\_Msk

```
#define TPI_FIFO1_ITM_bytecount_Msk (0x3UL << TPI_FIFO1_ITM_bytecount_Pos)
```

TPI FIFO1: ITM\_bytecount Mask

### 5.26.2.58 TPI\_FIFO1\_ITM\_bytecount\_Pos

```
#define TPI_FIFO1_ITM_bytecount_Pos 27
```

TPI FIFO1: ITM\_bytecount Position

### 5.26.2.59 TPI\_ITATBCTR0\_ATREADY\_Msk

```
#define TPI_ITATBCTR0_ATREADY_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY_Pos*/)
```

TPI ITATBCTR0: ATREADY Mask

### 5.26.2.60 TPI\_ITATBCTR0\_ATREADY\_Pos

```
#define TPI_ITATBCTR0_ATREADY_Pos 0
```

TPI ITATBCTR0: ATREADY Position

### 5.26.2.61 TPI\_ITATBCTR2\_ATREADY\_Msk

```
#define TPI_ITATBCTR2_ATREADY_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY_Pos*/)
```

TPI ITATBCTR2: ATREADY Mask

### 5.26.2.62 TPI\_ITATBCTR2\_ATREADY\_Pos

```
#define TPI_ITATBCTR2_ATREADY_Pos 0
```

TPI ITATBCTR2: ATREADY Position

### 5.26.2.63 TPI\_ITCTRL\_Mode\_Msk

```
#define TPI_ITCTRL_Mode_Msk (0x1UL /*<< TPI_ITCTRL_Mode_Pos*/)
```

TPI ITCTRL: Mode Mask

### 5.26.2.64 TPI\_ITCTRL\_Mode\_Pos

```
#define TPI_ITCTRL_Mode_Pos 0
```

TPI ITCTRL: Mode Position

### 5.26.2.65 TPI\_SPPR\_TXMODE\_Msk

```
#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/)
```

TPI SPPR: TXMODE Mask

### 5.26.2.66 TPI\_SPPR\_TXMODE\_Pos

```
#define TPI_SPPR_TXMODE_Pos 0
```

TPI SPPR: TXMODE Position

### 5.26.2.67 TPI\_TRIGGER\_TRIGGER\_Msk

```
#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/)
```

TPI TRIGGER: TRIGGER Mask

### 5.26.2.68 TPI\_TRIGGER\_TRIGGER\_Pos

```
#define TPI_TRIGGER_TRIGGER_Pos 0
```

TPI TRIGGER: TRIGGER Position

## 5.27 Core Debug Registers (CoreDebug)

Type definitions for the Core Debug Registers.

Collaboration diagram for Core Debug Registers (CoreDebug):



## Modules

- Core Definitions

*Definitions for base addresses, unions, and structures.*

## Classes

- struct `CoreDebug_Type`

*Structure type to access the Core Debug Register (CoreDebug).*

- #define `CoreDebug_DHCSR_DBGKEY_Pos` 16
- #define `CoreDebug_DHCSR_DBGKEY_Msk` (0xFFFFUL << `CoreDebug_DHCSR_DBGKEY_Pos`)
- #define `CoreDebug_DHCSR_S_RESET_ST_Pos` 25
- #define `CoreDebug_DHCSR_S_RESET_ST_Msk` (1UL << `CoreDebug_DHCSR_S_RESET_ST_Pos`)
- #define `CoreDebug_DHCSR_S_RETIRE_ST_Pos` 24
- #define `CoreDebug_DHCSR_S_RETIRE_ST_Msk` (1UL << `CoreDebug_DHCSR_S_RETIRE_ST_Pos`)
- #define `CoreDebug_DHCSR_S_LOCKUP_Pos` 19
- #define `CoreDebug_DHCSR_S_LOCKUP_Msk` (1UL << `CoreDebug_DHCSR_S_LOCKUP_Pos`)
- #define `CoreDebug_DHCSR_S_SLEEP_Pos` 18
- #define `CoreDebug_DHCSR_S_SLEEP_Msk` (1UL << `CoreDebug_DHCSR_S_SLEEP_Pos`)
- #define `CoreDebug_DHCSR_S_HALT_Pos` 17
- #define `CoreDebug_DHCSR_S_HALT_Msk` (1UL << `CoreDebug_DHCSR_S_HALT_Pos`)
- #define `CoreDebug_DHCSR_S_REGRDY_Pos` 16
- #define `CoreDebug_DHCSR_S_REGRDY_Msk` (1UL << `CoreDebug_DHCSR_S_REGRDY_Pos`)
- #define `CoreDebug_DHCSR_C_SNAPSTALL_Pos` 5
- #define `CoreDebug_DHCSR_C_SNAPSTALL_Msk` (1UL << `CoreDebug_DHCSR_C_SNAPSTALL_Pos`)
- #define `CoreDebug_DHCSR_C_MASKINTS_Pos` 3
- #define `CoreDebug_DHCSR_C_MASKINTS_Msk` (1UL << `CoreDebug_DHCSR_C_MASKINTS_Pos`)
- #define `CoreDebug_DHCSR_C_STEP_Pos` 2
- #define `CoreDebug_DHCSR_C_STEP_Msk` (1UL << `CoreDebug_DHCSR_C_STEP_Pos`)
- #define `CoreDebug_DHCSR_C_HALT_Pos` 1
- #define `CoreDebug_DHCSR_C_HALT_Msk` (1UL << `CoreDebug_DHCSR_C_HALT_Pos`)
- #define `CoreDebug_DHCSR_C_DEBUGEN_Pos` 0
- #define `CoreDebug_DHCSR_C_DEBUGEN_Msk` (1UL /\*<< `CoreDebug_DHCSR_C_DEBUGEN_Pos*/)`
- #define `CoreDebug_DCRSR_REGWnR_Pos` 16
- #define `CoreDebug_DCRSR_REGWnR_Msk` (1UL << `CoreDebug_DCRSR_REGWnR_Pos`)
- #define `CoreDebug_DCRSR_REGSEL_Pos` 0
- #define `CoreDebug_DCRSR_REGSEL_Msk` (0x1FUL /\*<< `CoreDebug_DCRSR_REGSEL_Pos*/)`
- #define `CoreDebug_DEMCR_TRCENA_Pos` 24
- #define `CoreDebug_DEMCR_TRCENA_Msk` (1UL << `CoreDebug_DEMCR_TRCENA_Pos`)
- #define `CoreDebug_DEMCR_MON_REQ_Pos` 19
- #define `CoreDebug_DEMCR_MON_REQ_Msk` (1UL << `CoreDebug_DEMCR_MON_REQ_Pos`)
- #define `CoreDebug_DEMCR_MON_STEP_Pos` 18
- #define `CoreDebug_DEMCR_MON_STEP_Msk` (1UL << `CoreDebug_DEMCR_MON_STEP_Pos`)
- #define `CoreDebug_DEMCR_MON_PEND_Pos` 17
- #define `CoreDebug_DEMCR_MON_PEND_Msk` (1UL << `CoreDebug_DEMCR_MON_PEND_Pos`)
- #define `CoreDebug_DEMCR_MON_EN_Pos` 16
- #define `CoreDebug_DEMCR_MON_EN_Msk` (1UL << `CoreDebug_DEMCR_MON_EN_Pos`)
- #define `CoreDebug_DEMCR_VC_HARDERR_Pos` 10
- #define `CoreDebug_DEMCR_VC_HARDERR_Msk` (1UL << `CoreDebug_DEMCR_VC_HARDERR_Pos`)
- #define `CoreDebug_DEMCR_VC_INTERR_Pos` 9
- #define `CoreDebug_DEMCR_VC_INTERR_Msk` (1UL << `CoreDebug_DEMCR_VC_INTERR_Pos`)
- #define `CoreDebug_DEMCR_VC_BUSERR_Pos` 8

- #define CoreDebug\_DEMCR\_VC\_BUSERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_BUSERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_STATERR\_Pos 7
- #define CoreDebug\_DEMCR\_VC\_STATERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_STATERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_CHKERR\_Pos 6
- #define CoreDebug\_DEMCR\_VC\_CHKERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_CHKERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos 5
- #define CoreDebug\_DEMCR\_VC\_NOCPERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_MMERR\_Pos 4
- #define CoreDebug\_DEMCR\_VC\_MMERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_MMERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_CORERESET\_Pos 0
- #define CoreDebug\_DEMCR\_VC\_CORERESET\_Msk (1UL /\*<< CoreDebug\_DEMCR\_VC\_CORERESET\_Pos\*/)

### 5.27.1 Detailed Description

Type definitions for the Core Debug Registers.

### 5.27.2 Macro Definition Documentation

#### 5.27.2.1 CoreDebug\_DCRSR\_REGSEL\_Msk

```
#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)
```

CoreDebug DCRSR: REGSEL Mask

#### 5.27.2.2 CoreDebug\_DCRSR\_REGSEL\_Pos

```
#define CoreDebug_DCRSR_REGSEL_Pos 0
```

CoreDebug DCRSR: REGSEL Position

#### 5.27.2.3 CoreDebug\_DCRSR\_REGWnR\_Msk

```
#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos)
```

CoreDebug DCRSR: REGWnR Mask

#### 5.27.2.4 CoreDebug\_DCRSR\_REGWnR\_Pos

```
#define CoreDebug_DCRSR_REGWnR_Pos 16
```

CoreDebug DCRSR: REGWnR Position

### 5.27.2.5 CoreDebug\_DEMCR\_MON\_EN\_Msk

```
#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos)
```

CoreDebug DEMCR: MON\_EN Mask

### 5.27.2.6 CoreDebug\_DEMCR\_MON\_EN\_Pos

```
#define CoreDebug_DEMCR_MON_EN_Pos 16
```

CoreDebug DEMCR: MON\_EN Position

### 5.27.2.7 CoreDebug\_DEMCR\_MON\_PEND\_Msk

```
#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos)
```

CoreDebug DEMCR: MON\_PEND Mask

### 5.27.2.8 CoreDebug\_DEMCR\_MON\_PEND\_Pos

```
#define CoreDebug_DEMCR_MON_PEND_Pos 17
```

CoreDebug DEMCR: MON\_PEND Position

### 5.27.2.9 CoreDebug\_DEMCR\_MON\_REQ\_Msk

```
#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos)
```

CoreDebug DEMCR: MON\_REQ Mask

### 5.27.2.10 CoreDebug\_DEMCR\_MON\_REQ\_Pos

```
#define CoreDebug_DEMCR_MON_REQ_Pos 19
```

CoreDebug DEMCR: MON\_REQ Position

### 5.27.2.11 CoreDebug\_DEMCR\_MON\_STEP\_Msk

```
#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos)
```

CoreDebug DEMCR: MON\_STEP Mask

### 5.27.2.12 CoreDebug\_DEMCR\_MON\_STEP\_Pos

```
#define CoreDebug_DEMCR_MON_STEP_Pos 18
```

CoreDebug DEMCR: MON\_STEP Position

### 5.27.2.13 CoreDebug\_DEMCR\_TRCENA\_Msk

```
#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos)
```

CoreDebug DEMCR: TRCENA Mask

### 5.27.2.14 CoreDebug\_DEMCR\_TRCENA\_Pos

```
#define CoreDebug_DEMCR_TRCENA_Pos 24
```

CoreDebug DEMCR: TRCENA Position

### 5.27.2.15 CoreDebug\_DEMCR\_VC\_BUSERR\_Msk

```
#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos)
```

CoreDebug DEMCR: VC\_BUSERR Mask

### 5.27.2.16 CoreDebug\_DEMCR\_VC\_BUSERR\_Pos

```
#define CoreDebug_DEMCR_VC_BUSERR_Pos 8
```

CoreDebug DEMCR: VC\_BUSERR Position

### 5.27.2.17 CoreDebug\_DEMCR\_VC\_CHKERR\_Msk

```
#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos)
```

CoreDebug DEMCR: VC\_CHKERR Mask

### 5.27.2.18 CoreDebug\_DEMCR\_VC\_CHKERR\_Pos

```
#define CoreDebug_DEMCR_VC_CHKERR_Pos 6
```

CoreDebug DEMCR: VC\_CHKERR Position

### 5.27.2.19 CoreDebug\_DEMCR\_VC\_CORERESET\_Msk

```
#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)
```

CoreDebug DEMCR: VC\_CORERESET Mask

### 5.27.2.20 CoreDebug\_DEMCR\_VC\_CORERESET\_Pos

```
#define CoreDebug_DEMCR_VC_CORERESET_Pos 0
```

CoreDebug DEMCR: VC\_CORERESET Position

### 5.27.2.21 CoreDebug\_DEMCR\_VC\_HARDERR\_Msk

```
#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)
```

CoreDebug DEMCR: VC\_HARDERR Mask

### 5.27.2.22 CoreDebug\_DEMCR\_VC\_HARDERR\_Pos

```
#define CoreDebug_DEMCR_VC_HARDERR_Pos 10
```

CoreDebug DEMCR: VC\_HARDERR Position

### 5.27.2.23 CoreDebug\_DEMCR\_VC\_INTERR\_Msk

```
#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos)
```

CoreDebug DEMCR: VC\_INTERR Mask

### 5.27.2.24 CoreDebug\_DEMCR\_VC\_INTERR\_Pos

```
#define CoreDebug_DEMCR_VC_INTERR_Pos 9
```

CoreDebug DEMCR: VC\_INTERR Position

### 5.27.2.25 CoreDebug\_DEMCR\_VC\_MMERR\_Msk

```
#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos)
```

CoreDebug DEMCR: VC\_MMERR Mask

### 5.27.2.26 CoreDebug\_DEMCR\_VC\_MMERR\_Pos

```
#define CoreDebug_DEMCR_VC_MMERR_Pos 4
```

CoreDebug DEMCR: VC\_MMERR Position

### 5.27.2.27 CoreDebug\_DEMCR\_VC\_NOCPERR\_Msk

```
#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos)
```

CoreDebug DEMCR: VC\_NOCPERR Mask

### 5.27.2.28 CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos

```
#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5
```

CoreDebug DEMCR: VC\_NOCPERR Position

### 5.27.2.29 CoreDebug\_DEMCR\_VC\_STATERR\_Msk

```
#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos)
```

CoreDebug DEMCR: VC\_STATERR Mask

### 5.27.2.30 CoreDebug\_DEMCR\_VC\_STATERR\_Pos

```
#define CoreDebug_DEMCR_VC_STATERR_Pos 7
```

CoreDebug DEMCR: VC\_STATERR Position

### 5.27.2.31 CoreDebug\_DHCSR\_C\_DEBUGEN\_Msk

```
#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)
```

CoreDebug DHCSR: C\_DEBUGEN Mask

### 5.27.2.32 CoreDebug\_DHCSR\_C\_DEBUGEN\_Pos

```
#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0
```

CoreDebug DHCSR: C\_DEBUGEN Position

### 5.27.2.33 CoreDebug\_DHCSR\_C\_HALT\_Msk

```
#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos)
```

CoreDebug DHCSR: C\_HALT Mask

### 5.27.2.34 CoreDebug\_DHCSR\_C\_HALT\_Pos

```
#define CoreDebug_DHCSR_C_HALT_Pos 1
```

CoreDebug DHCSR: C\_HALT Position

### 5.27.2.35 CoreDebug\_DHCSR\_C\_MASKINTS\_Msk

```
#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)
```

CoreDebug DHCSR: C\_MASKINTS Mask

### 5.27.2.36 CoreDebug\_DHCSR\_C\_MASKINTS\_Pos

```
#define CoreDebug_DHCSR_C_MASKINTS_Pos 3
```

CoreDebug DHCSR: C\_MASKINTS Position

### 5.27.2.37 CoreDebug\_DHCSR\_C\_SNAPSTALL\_Msk

```
#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos)
```

CoreDebug DHCSR: C\_SNAPSTALL Mask

### 5.27.2.38 CoreDebug\_DHCSR\_C\_SNAPSTALL\_Pos

```
#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5
```

CoreDebug DHCSR: C\_SNAPSTALL Position

### 5.27.2.39 CoreDebug\_DHCSR\_C\_STEP\_Msk

```
#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos)
```

CoreDebug DHCSR: C\_STEP Mask

### 5.27.2.40 CoreDebug\_DHCSR\_C\_STEP\_Pos

```
#define CoreDebug_DHCSR_C_STEP_Pos 2
```

CoreDebug DHCSR: C\_STEP Position

### 5.27.2.41 CoreDebug\_DHCSR\_DBGKEY\_Msk

```
#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)
```

CoreDebug DHCSR: DBGKEY Mask

### 5.27.2.42 CoreDebug\_DHCSR\_DBGKEY\_Pos

```
#define CoreDebug_DHCSR_DBGKEY_Pos 16
```

CoreDebug DHCSR: DBGKEY Position

### 5.27.2.43 CoreDebug\_DHCSR\_S\_HALT\_Msk

```
#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos)
```

CoreDebug DHCSR: S\_HALT Mask

### 5.27.2.44 CoreDebug\_DHCSR\_S\_HALT\_Pos

```
#define CoreDebug_DHCSR_S_HALT_Pos 17
```

CoreDebug DHCSR: S\_HALT Position

### 5.27.2.45 CoreDebug\_DHCSR\_S\_LOCKUP\_Msk

```
#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)
```

CoreDebug DHCSR: S\_LOCKUP Mask

### 5.27.2.46 CoreDebug\_DHCSR\_S\_LOCKUP\_Pos

```
#define CoreDebug_DHCSR_S_LOCKUP_Pos 19
```

CoreDebug DHCSR: S\_LOCKUP Position

### 5.27.2.47 CoreDebug\_DHCSR\_S\_REGRDY\_Msk

```
#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)
```

CoreDebug DHCSR: S\_REGRDY Mask

### 5.27.2.48 CoreDebug\_DHCSR\_S\_REGRDY\_Pos

```
#define CoreDebug_DHCSR_S_REGRDY_Pos 16
```

CoreDebug DHCSR: S\_REGRDY Position

### 5.27.2.49 CoreDebug\_DHCSR\_S\_RESET\_ST\_Msk

```
#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)
```

CoreDebug DHCSR: S\_RESET\_ST Mask

### 5.27.2.50 CoreDebug\_DHCSR\_S\_RESET\_ST\_Pos

```
#define CoreDebug_DHCSR_S_RESET_ST_Pos 25
```

CoreDebug DHCSR: S\_RESET\_ST Position

### 5.27.2.51 CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Msk

```
#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)
```

CoreDebug DHCSR: S\_RETIRE\_ST Mask

### 5.27.2.52 CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Pos

```
#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24
```

CoreDebug DHCSR: S\_RETIRE\_ST Position

### 5.27.2.53 CoreDebug\_DHCSR\_S\_SLEEP\_Msk

```
#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)
```

CoreDebug DHCSR: S\_SLEEP Mask

### 5.27.2.54 CoreDebug\_DHCSR\_S\_SLEEP\_Pos

```
#define CoreDebug_DHCSR_S_SLEEP_Pos 18
```

CoreDebug DHCSR: S\_SLEEP Position

## 5.28 Core Definitions

Definitions for base addresses, unions, and structures.

Collaboration diagram for Core Definitions:



## Modules

- [Functions and Instructions Reference](#)
- [NVIC Functions](#)

*Functions that manage interrupts and exceptions via the NVIC.*

- #define SCS\_BASE (0xE000E000UL)
- #define ITM\_BASE (0xE0000000UL)
- #define DWT\_BASE (0xE0001000UL)
- #define TPI\_BASE (0xE0040000UL)
- #define CoreDebug\_BASE (0xE000EDF0UL)
- #define SysTick\_BASE (SCS\_BASE + 0x0010UL)
- #define NVIC\_BASE (SCS\_BASE + 0x0100UL)
- #define SCB\_BASE (SCS\_BASE + 0x0D00UL)
- #define SCnSCB ((SCnSCB\_Type \*) SCS\_BASE )
- #define SCB ((SCB\_Type \*) SCB\_BASE )
- #define SysTick ((SysTick\_Type \*) SysTick\_BASE )
- #define NVIC ((NVIC\_Type \*) NVIC\_BASE )
- #define ITM ((ITM\_Type \*) ITM\_BASE )
- #define DWT ((DWT\_Type \*) DWT\_BASE )
- #define TPI ((TPI\_Type \*) TPI\_BASE )
- #define CoreDebug ((CoreDebug\_Type \*) CoreDebug\_BASE)

### 5.28.1 Detailed Description

Definitions for base addresses, unions, and structures.

### 5.28.2 Macro Definition Documentation

#### 5.28.2.1 CoreDebug

```
#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE)
```

Core Debug configuration struct

#### 5.28.2.2 CoreDebug\_BASE

```
#define CoreDebug_BASE (0xE000EDF0UL)
```

Core Debug Base Address

#### 5.28.2.3 DWT

```
#define DWT ((DWT_Type *) DWT_BASE )
```

DWT configuration struct

#### 5.28.2.4 DWT\_BASE

```
#define DWT_BASE (0xE0001000UL)
```

DWT Base Address

#### 5.28.2.5 ITM

```
#define ITM ((ITM_Type *) ITM_BASE )
```

ITM configuration struct

### 5.28.2.6 ITM\_BASE

```
#define ITM_BASE (0xE0000000UL)
```

ITM Base Address

### 5.28.2.7 NVIC

```
#define NVIC ((NVIC_Type *) NVIC_BASE )
```

NVIC configuration struct

### 5.28.2.8 NVIC\_BASE

```
#define NVIC_BASE (SCS_BASE + 0x0100UL)
```

NVIC Base Address

### 5.28.2.9 SCB

```
#define SCB ((SCB_Type *) SCB_BASE )
```

SCB configuration struct

### 5.28.2.10 SCB\_BASE

```
#define SCB_BASE (SCS_BASE + 0x0D00UL)
```

System Control Block Base Address

### 5.28.2.11 SCnSCB

```
#define SCnSCB ((SCnSCB_Type *) SCS_BASE )
```

System control Register not in SCB

### 5.28.2.12 SCS\_BASE

```
#define SCS_BASE (0xE000E000UL)
```

System Control Space Base Address

### 5.28.2.13 SysTick

```
#define SysTick ((SysTick_Type *) SysTick_BASE )
```

SysTick configuration struct

### 5.28.2.14 SysTick\_BASE

```
#define SysTick_BASE (SCS_BASE + 0x0010UL)
```

SysTick Base Address

### 5.28.2.15 TPI

```
#define TPI ((TPI_Type *) TPI_BASE )
```

TPI configuration struct

### 5.28.2.16 TPI\_BASE

```
#define TPI_BASE (0xE0040000UL)
```

TPI Base Address

## 5.29 Functions and Instructions Reference

Collaboration diagram for Functions and Instructions Reference:



## Modules

- [NVIC Functions](#)  
*Functions that manage interrupts and exceptions via the NVIC.*
- [CMSIS Core Register Access Functions](#)

### 5.29.1 Detailed Description

## 5.30 NVIC Functions

Functions that manage interrupts and exceptions via the NVIC.

Collaboration diagram for NVIC Functions:



## Modules

- [SysTick Functions](#)

*Functions that configure the System.*

- `__STATIC_INLINE void NVIC_SetPriorityGrouping (uint32_t PriorityGroup)`  
*Set Priority Grouping.*
- `__STATIC_INLINE uint32_t NVIC_GetPriorityGrouping (void)`  
*Get Priority Grouping.*
- `__STATIC_INLINE void NVIC_EnableIRQ (IRQn_Type IRQn)`  
*Enable External Interrupt.*
- `__STATIC_INLINE void NVIC_DisableIRQ (IRQn_Type IRQn)`  
*Disable External Interrupt.*
- `__STATIC_INLINE uint32_t NVIC_GetPendingIRQ (IRQn_Type IRQn)`  
*Get Pending Interrupt.*
- `__STATIC_INLINE void NVIC_SetPendingIRQ (IRQn_Type IRQn)`  
*Set Pending Interrupt.*
- `__STATIC_INLINE void NVIC_ClearPendingIRQ (IRQn_Type IRQn)`  
*Clear Pending Interrupt.*
- `__STATIC_INLINE uint32_t NVIC_GetActive (IRQn_Type IRQn)`  
*Get Active Interrupt.*
- `__STATIC_INLINE void NVIC_SetPriority (IRQn_Type IRQn, uint32_t priority)`  
*Set Interrupt Priority.*
- `__STATIC_INLINE uint32_t NVIC_GetPriority (IRQn_Type IRQn)`  
*Get Interrupt Priority.*
- `__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority)`  
*Encode Priority.*
- `__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t *pPreemptPriority, uint32_t *pSubPriority)`  
*Decode Priority.*
- `__STATIC_INLINE void NVIC_SystemReset (void)`  
*System Reset.*

### 5.30.1 Detailed Description

Functions that manage interrupts and exceptions via the NVIC.

### 5.30.2 Function Documentation

#### 5.30.2.1 NVIC\_ClearPendingIRQ()

```
__STATIC_INLINE void NVIC_ClearPendingIRQ (
    IRQn_Type IRQn )
```

Clear Pending Interrupt.

The function clears the pending bit of an external interrupt.

##### Parameters

|    |             |                                                      |
|----|-------------|------------------------------------------------------|
| in | <i>IRQn</i> | External interrupt number. Value cannot be negative. |
|----|-------------|------------------------------------------------------|

#### 5.30.2.2 NVIC\_DecodePriority()

```
__STATIC_INLINE void NVIC_DecodePriority (
    uint32_t Priority,
    uint32_t PriorityGroup,
    uint32_t * pPreemptPriority,
    uint32_t * pSubPriority )
```

Decode Priority.

The function decodes an interrupt priority value with a given priority group to preemptive priority value and subpriority value. In case of a conflict between priority grouping and available priority bits (`__NVIC_PRIO_BITS`) the smallest possible priority group is set.

##### Parameters

|     |                         |                                                                                               |
|-----|-------------------------|-----------------------------------------------------------------------------------------------|
| in  | <i>Priority</i>         | Priority value, which can be retrieved with the function <a href="#">NVIC_GetPriority()</a> . |
| in  | <i>PriorityGroup</i>    | Used priority group.                                                                          |
| out | <i>pPreemptPriority</i> | Preemptive priority value (starting from 0).                                                  |
| out | <i>pSubPriority</i>     | Subpriority value (starting from 0).                                                          |

### 5.30.2.3 NVIC\_DisableIRQ()

```
__STATIC_INLINE void NVIC_DisableIRQ (
    IRQn_Type IRQn )
```

Disable External Interrupt.

The function disables a device-specific interrupt in the NVIC interrupt controller.

#### Parameters

|    |             |                                                      |
|----|-------------|------------------------------------------------------|
| in | <i>IRQn</i> | External interrupt number. Value cannot be negative. |
|----|-------------|------------------------------------------------------|

### 5.30.2.4 NVIC\_EnableIRQ()

```
__STATIC_INLINE void NVIC_EnableIRQ (
    IRQn_Type IRQn )
```

Enable External Interrupt.

The function enables a device-specific interrupt in the NVIC interrupt controller.

#### Parameters

|    |             |                                                      |
|----|-------------|------------------------------------------------------|
| in | <i>IRQn</i> | External interrupt number. Value cannot be negative. |
|----|-------------|------------------------------------------------------|

### 5.30.2.5 NVIC\_EncodePriority()

```
__STATIC_INLINE uint32_t NVIC_EncodePriority (
    uint32_t PriorityGroup,
    uint32_t PreemptPriority,
    uint32_t SubPriority )
```

Encode Priority.

The function encodes the priority for an interrupt with the given priority group, preemptive priority value, and subpriority value. In case of a conflict between priority grouping and available priority bits (`__NVIC_PRIO_BITS`), the smallest possible priority group is set.

#### Parameters

|    |                        |                                              |
|----|------------------------|----------------------------------------------|
| in | <i>PriorityGroup</i>   | Used priority group.                         |
| in | <i>PreemptPriority</i> | Preemptive priority value (starting from 0). |
| in | <i>SubPriority</i>     | Subpriority value (starting from 0).         |

**Returns**

Encoded priority. Value can be used in the function [NVIC\\_SetPriority\(\)](#).

### 5.30.2.6 NVIC\_GetActive()

```
__STATIC_INLINE uint32_t NVIC_GetActive (
    IRQn_Type IRQn )
```

Get Active Interrupt.

The function reads the active register in NVIC and returns the active bit.

**Parameters**

|    |      |                   |
|----|------|-------------------|
| in | IRQn | Interrupt number. |
|----|------|-------------------|

**Returns**

0 Interrupt status is not active.

1 Interrupt status is active.

### 5.30.2.7 NVIC\_GetPendingIRQ()

```
__STATIC_INLINE uint32_t NVIC_GetPendingIRQ (
    IRQn_Type IRQn )
```

Get Pending Interrupt.

The function reads the pending register in the NVIC and returns the pending bit for the specified interrupt.

**Parameters**

|    |      |                   |
|----|------|-------------------|
| in | IRQn | Interrupt number. |
|----|------|-------------------|

**Returns**

0 Interrupt status is not pending.

1 Interrupt status is pending.

### 5.30.2.8 NVIC\_GetPriority()

```
__STATIC_INLINE uint32_t NVIC_GetPriority (
    IRQn_Type IRQn )
```

Get Interrupt Priority.

The function reads the priority of an interrupt. The interrupt number can be positive to specify an external (device specific) interrupt, or negative to specify an internal (core) interrupt.

#### Parameters

|    |             |                   |
|----|-------------|-------------------|
| in | <i>IRQn</i> | Interrupt number. |
|----|-------------|-------------------|

#### Returns

Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller.

### 5.30.2.9 NVIC\_GetPriorityGrouping()

```
__STATIC_INLINE uint32_t NVIC_GetPriorityGrouping (
    void )
```

Get Priority Grouping.

The function reads the priority grouping field from the NVIC Interrupt Controller.

#### Returns

Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field).

### 5.30.2.10 NVIC\_SetPendingIRQ()

```
__STATIC_INLINE void NVIC_SetPendingIRQ (
    IRQn_Type IRQn )
```

Set Pending Interrupt.

The function sets the pending bit of an external interrupt.

#### Parameters

|    |             |                                             |
|----|-------------|---------------------------------------------|
| in | <i>IRQn</i> | Interrupt number. Value cannot be negative. |
|----|-------------|---------------------------------------------|

### 5.30.2.11 NVIC\_SetPriority()

```
__STATIC_INLINE void NVIC_SetPriority (
```

```
IRQn_Type IRQn,
uint32_t priority )
```

Set Interrupt Priority.

The function sets the priority of an interrupt.

#### Note

The priority cannot be set for every core interrupt.

#### Parameters

|    |                 |                   |
|----|-----------------|-------------------|
| in | <i>IRQn</i>     | Interrupt number. |
| in | <i>priority</i> | Priority to set.  |

### 5.30.2.12 NVIC\_SetPriorityGrouping()

```
__STATIC_INLINE void NVIC_SetPriorityGrouping (
    uint32_t PriorityGroup )
```

Set Priority Grouping.

The function sets the priority grouping field using the required unlock sequence. The parameter PriorityGroup is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. Only values from 0..7 are used. In case of a conflict between priority grouping and available priority bits (`__NVIC_PRIO_BITS`), the smallest possible priority group is set.

#### Parameters

|    |                      |                          |
|----|----------------------|--------------------------|
| in | <i>PriorityGroup</i> | Priority grouping field. |
|----|----------------------|--------------------------|

### 5.30.2.13 NVIC\_SystemReset()

```
__STATIC_INLINE void NVIC_SystemReset (
    void )
```

System Reset.

The function initiates a system reset request to reset the MCU.

## 5.31 SysTick Functions

Functions that configure the System.

Collaboration diagram for SysTick Functions:



### Modules

- [ITM Functions](#)  
*Functions that access the ITM debug interface.*
- `__STATIC_INLINE uint32_t SysTick_Config (uint32_t ticks)`  
*System Tick Configuration.*

#### 5.31.1 Detailed Description

Functions that configure the System.

#### 5.31.2 Function Documentation

##### 5.31.2.1 [SysTick\\_Config\(\)](#)

```
__STATIC_INLINE uint32_t SysTick_Config (
    uint32_t ticks )
```

System Tick Configuration.

The function initializes the System Timer and its interrupt, and starts the System Tick Timer. Counter is in free running mode to generate periodic interrupts.

##### Parameters

|    |              |                                         |
|----|--------------|-----------------------------------------|
| in | <i>ticks</i> | Number of ticks between two interrupts. |
|----|--------------|-----------------------------------------|

**Returns**

- 0 Function succeeded.
- 1 Function failed.

**Note**

When the variable `__Vendor_SysTickConfig` is set to 1, then the function `SysTick_Config` is not included. In this case, the file `device.h` must contain a vendor-specific implementation of this function.

## 5.32 ITM Functions

Functions that access the ITM debug interface.

Collaboration diagram for ITM Functions:



## Variables

- `uint32_t APSR_Type::_reserved0:16`
- `uint32_t APSR_Type::GE:4`
- `uint32_t APSR_Type::_reserved1:7`
- `uint32_t APSR_Type::Q:1`
- `uint32_t APSR_Type::V:1`
- `uint32_t APSR_Type::C:1`
- `uint32_t APSR_Type::Z:1`
- `uint32_t APSR_Type::N:1`
- struct {
  - `uint32_t APSR_Type::_reserved0:16`
  - `uint32_t APSR_Type::GE:4`
  - `uint32_t APSR_Type::_reserved1:7`
  - `uint32_t APSR_Type::Q:1`
  - `uint32_t APSR_Type::V:1`
  - `uint32_t APSR_Type::C:1`
  - `uint32_t APSR_Type::Z:1`
  - `uint32_t APSR_Type::N:1`}
- `} APSR_Type::b`
- `uint32_t APSR_Type::w`
- `uint32_t IPSR_Type::ISR:9`
- `uint32_t IPSR_Type::_reserved0:23`

- struct {
  - uint32\_t **IPSR\_Type::ISR**:9
  - uint32\_t **IPSR\_Type::\_reserved0**:23
} **IPSR\_Type::b**
  
- uint32\_t **IPSR\_Type::w**
- uint32\_t **xPSR\_Type::ISR**:9
- uint32\_t **xPSR\_Type::\_reserved0**:7
- uint32\_t **xPSR\_Type::GE**:4
- uint32\_t **xPSR\_Type::\_reserved1**:4
- uint32\_t **xPSR\_Type::T**:1
- uint32\_t **xPSR\_Type::IT**:2
- uint32\_t **xPSR\_Type::Q**:1
- uint32\_t **xPSR\_Type::V**:1
- uint32\_t **xPSR\_Type::C**:1
- uint32\_t **xPSR\_Type::Z**:1
- uint32\_t **xPSR\_Type::N**:1
- struct {
  - uint32\_t **xPSR\_Type::ISR**:9
  - uint32\_t **xPSR\_Type::\_reserved0**:7
  - uint32\_t **xPSR\_Type::GE**:4
  - uint32\_t **xPSR\_Type::\_reserved1**:4
  - uint32\_t **xPSR\_Type::T**:1
  - uint32\_t **xPSR\_Type::IT**:2
  - uint32\_t **xPSR\_Type::Q**:1
  - uint32\_t **xPSR\_Type::V**:1
  - uint32\_t **xPSR\_Type::C**:1
  - uint32\_t **xPSR\_Type::Z**:1
  - uint32\_t **xPSR\_Type::N**:1
} **xPSR\_Type::b**
  
- uint32\_t **xPSR\_Type::w**
- uint32\_t **CONTROL\_Type::nPRIV**:1
- uint32\_t **CONTROL\_Type::SPSEL**:1
- uint32\_t **CONTROL\_Type::FPCA**:1
- uint32\_t **CONTROL\_Type::\_reserved0**:29
- struct {
  - uint32\_t **CONTROL\_Type::nPRIV**:1
  - uint32\_t **CONTROL\_Type::SPSEL**:1
  - uint32\_t **CONTROL\_Type::FPCA**:1
  - uint32\_t **CONTROL\_Type::\_reserved0**:29
} **CONTROL\_Type::b**
  
- uint32\_t **CONTROL\_Type::w**
- **\_IO** uint32\_t **NVIC\_Type::ISER** [8]
- uint32\_t **NVIC\_Type::RESERVED0** [24]
- **\_IO** uint32\_t **NVIC\_Type::ICER** [8]
- uint32\_t **NVIC\_Type::RSERVED1** [24]
- **\_IO** uint32\_t **NVIC\_Type::ISPR** [8]
- uint32\_t **NVIC\_Type::RESERVED2** [24]
- **\_IO** uint32\_t **NVIC\_Type::ICPR** [8]
- uint32\_t **NVIC\_Type::RESERVED3** [24]
- **\_IO** uint32\_t **NVIC\_Type::IABR** [8]
- uint32\_t **NVIC\_Type::RESERVED4** [56]
- **\_IO** uint8\_t **NVIC\_Type::IP** [240]
- uint32\_t **NVIC\_Type::RESERVED5** [644]

- `_O uint32_t NVIC_Type::STIR`
- `_I uint32_t SCB_Type::CPUID`
- `_IO uint32_t SCB_Type::ICSR`
- `_IO uint32_t SCB_Type::VTOR`
- `_IO uint32_t SCB_Type::AIRCR`
- `_IO uint32_t SCB_Type::SCR`
- `_IO uint32_t SCB_Type::CCR`
- `_IO uint8_t SCB_Type::SHP [12]`
- `_IO uint32_t SCB_Type::SHCSR`
- `_IO uint32_t SCB_Type::CSR`
- `_IO uint32_t SCB_Type::HFSR`
- `_IO uint32_t SCB_Type::DFSR`
- `_IO uint32_t SCB_Type::MMFAR`
- `_IO uint32_t SCB_Type::BFAR`
- `_IO uint32_t SCB_Type::AFSR`
- `_I uint32_t SCB_Type::PFR [2]`
- `_I uint32_t SCB_Type::DFR`
- `_I uint32_t SCB_Type::ADR`
- `_I uint32_t SCB_Type::MMFR [4]`
- `_I uint32_t SCB_Type::ISAR [5]`
- `uint32_t SCB_Type::RESERVED0 [5]`
- `_IO uint32_t SCB_Type::CPACR`
- `uint32_t SCnSCB_Type::RESERVED0 [1]`
- `_I uint32_t SCnSCB_Type::ICTR`
- `_IO uint32_t SCnSCB_Type::ACTLR`
- `_IO uint32_t SysTick_Type::CTRL`
- `_IO uint32_t SysTick_Type::LOAD`
- `_IO uint32_t SysTick_Type::VAL`
- `_I uint32_t SysTick_Type::CALIB`
- `_O uint8_t ITM_Type::u8`
- `_O uint16_t ITM_Type::u16`
- `_O uint32_t ITM_Type::u32`
- union {
  - `_O uint8_t ITM_Type::u8`
  - `_O uint16_t ITM_Type::u16`
  - `_O uint32_t ITM_Type::u32`}
- `ITM_Type::PORT [32]`
- `uint32_t ITM_Type::RESERVED0 [864]`
- `_IO uint32_t ITM_Type::TER`
- `uint32_t ITM_Type::RESERVED1 [15]`
- `_IO uint32_t ITM_Type::TPR`
- `uint32_t ITM_Type::RESERVED2 [15]`
- `_IO uint32_t ITM_Type::TCR`
- `uint32_t ITM_Type::RESERVED3 [29]`
- `_O uint32_t ITM_Type::IWR`
- `_I uint32_t ITM_Type::IRR`
- `_IO uint32_t ITM_Type::IMCR`
- `uint32_t ITM_Type::RESERVED4 [43]`
- `_O uint32_t ITM_Type::LAR`
- `_I uint32_t ITM_Type::LSR`
- `uint32_t ITM_Type::RESERVED5 [6]`
- `_I uint32_t ITM_Type::PID4`
- `_I uint32_t ITM_Type::PID5`
- `_I uint32_t ITM_Type::PID6`

- `__I uint32_t ITM_Type::PID7`
- `__I uint32_t ITM_Type::PID0`
- `__I uint32_t ITM_Type::PID1`
- `__I uint32_t ITM_Type::PID2`
- `__I uint32_t ITM_Type::PID3`
- `__I uint32_t ITM_Type::CID0`
- `__I uint32_t ITM_Type::CID1`
- `__I uint32_t ITM_Type::CID2`
- `__I uint32_t ITM_Type::CID3`
- `__IO uint32_t DWT_Type::CTRL`
- `__IO uint32_t DWT_Type::CYCCNT`
- `__IO uint32_t DWT_Type::CPICNT`
- `__IO uint32_t DWT_Type::EXCCNT`
- `__IO uint32_t DWT_Type::SLEEPCNT`
- `__IO uint32_t DWT_Type::LSUCNT`
- `__IO uint32_t DWT_Type::FOLDCNT`
- `__I uint32_t DWT_Type::PCSR`
- `__IO uint32_t DWT_Type::COMP0`
- `__IO uint32_t DWT_Type::MASK0`
- `__IO uint32_t DWT_Type::FUNCTION0`
- `uint32_t DWT_Type::RESERVED0 [1]`
- `__IO uint32_t DWT_Type::COMP1`
- `__IO uint32_t DWT_Type::MASK1`
- `__IO uint32_t DWT_Type::FUNCTION1`
- `uint32_t DWT_Type::RESERVED1 [1]`
- `__IO uint32_t DWT_Type::COMP2`
- `__IO uint32_t DWT_Type::MASK2`
- `__IO uint32_t DWT_Type::FUNCTION2`
- `uint32_t DWT_Type::RESERVED2 [1]`
- `__IO uint32_t DWT_Type::COMP3`
- `__IO uint32_t DWT_Type::MASK3`
- `__IO uint32_t DWT_Type::FUNCTION3`
- `__IO uint32_t TPI_Type::SSPSR`
- `__IO uint32_t TPI_Type::CSPSR`
- `uint32_t TPI_Type::RESERVED0 [2]`
- `__IO uint32_t TPI_Type::ACPR`
- `uint32_t TPI_Type::RESERVED1 [55]`
- `__IO uint32_t TPI_Type::SPPR`
- `uint32_t TPI_Type::RESERVED2 [131]`
- `__I uint32_t TPI_Type::FFSR`
- `__IO uint32_t TPI_Type::FFCR`
- `__I uint32_t TPI_Type::FSCR`
- `uint32_t TPI_Type::RESERVED3 [759]`
- `__I uint32_t TPI_Type::TRIGGER`
- `__I uint32_t TPI_Type::FIFO0`
- `__I uint32_t TPI_Type::ITATBCTR2`
- `uint32_t TPI_Type::RESERVED4 [1]`
- `__I uint32_t TPI_Type::ITATBCTR0`
- `__I uint32_t TPI_Type::FIFO1`
- `__IO uint32_t TPI_Type::ITCTRL`
- `uint32_t TPI_Type::RESERVED5 [39]`
- `__IO uint32_t TPI_Type::CLAIMSET`
- `__IO uint32_t TPI_Type::CLAIMCLR`
- `uint32_t TPI_Type::RESERVED7 [8]`
- `__I uint32_t TPI_Type::DEVID`

- `__I uint32_t TPI_Type::DEVTYPE`
- `__IO uint32_t CoreDebug_Type::DHCSR`
- `__O uint32_t CoreDebug_Type::DCRSR`
- `__IO uint32_t CoreDebug_Type::DCRDR`
- `__IO uint32_t CoreDebug_Type::DEMCR`
  
- volatile int32\_t `ITM_RxBuffer`
- `__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch)`  
*ITM Send Character.*
- `__STATIC_INLINE int32_t ITM_ReceiveChar (void)`  
*ITM Receive Character.*
- `__STATIC_INLINE int32_t ITM_CheckChar (void)`  
*ITM Check Character.*
- `#define ITM_RXBUFFER_EMPTY 0x5AA55AA5`

### 5.32.1 Detailed Description

Functions that access the ITM debug interface.

### 5.32.2 Macro Definition Documentation

#### 5.32.2.1 ITM\_RXBUFFER\_EMPTY

```
#define ITM_RXBUFFER_EMPTY 0x5AA55AA5
```

Value identifying `ITM_RxBuffer` is ready for next character.

### 5.32.3 Function Documentation

#### 5.32.3.1 ITM\_CheckChar()

```
__STATIC_INLINE int32_t ITM_CheckChar (
    void )
```

ITM Check Character.

The function checks whether a character is pending for reading in the variable `ITM_RxBuffer`.

##### Returns

0 No character available.

1 Character available.

### 5.32.3.2 ITM\_ReceiveChar()

```
__STATIC_INLINE int32_t ITM_ReceiveChar (
    void )
```

ITM Receive Character.

The function inputs a character via the external variable [ITM\\_RxBuffer](#).

#### Returns

Received character.  
-1 No character pending.

### 5.32.3.3 ITM\_SendChar()

```
__STATIC_INLINE uint32_t ITM_SendChar (
    uint32_t ch )
```

ITM Send Character.

The function transmits a character via the ITM channel 0, and

- Just returns when no debugger is connected that has booked the output.
- Is blocking when a debugger is connected, but the previous character sent has not been transmitted.

#### Parameters

|    |    |                        |
|----|----|------------------------|
| in | ch | Character to transmit. |
|----|----|------------------------|

#### Returns

Character to transmit.

## 5.32.4 Variable Documentation

### 5.32.4.1 \_reserved0 [1/8]

```
uint32_t APSR_Type::_reserved0
```

bit: 0..15 Reserved

**5.32.4.2 [2/8]**

```
uint32_t { ... } ::_reserved0
```

bit: 0..15 Reserved

**5.32.4.3 \_reserved0 [3/8]**

```
uint32_t IPSR_Type::_reserved0
```

bit: 9..31 Reserved

**5.32.4.4 [4/8]**

```
uint32_t { ... } ::_reserved0
```

bit: 9..31 Reserved

**5.32.4.5 \_reserved0 [5/8]**

```
uint32_t xPSR_Type::_reserved0
```

bit: 9..15 Reserved

**5.32.4.6 [6/8]**

```
uint32_t { ... } ::_reserved0
```

bit: 9..15 Reserved

**5.32.4.7 \_reserved0 [7/8]**

```
uint32_t CONTROL_Type::_reserved0
```

bit: 3..31 Reserved

**5.32.4.8 [8/8]**

```
uint32_t { ... } ::_reserved0
```

bit: 3..31 Reserved

**5.32.4.9 \_reserved1 [1/4]**

```
uint32_t APSR_Type::_reserved1
```

bit: 20..26 Reserved

**5.32.4.10 [2/4]**

```
uint32_t { ... } ::_reserved1
```

bit: 20..26 Reserved

**5.32.4.11 [3/4]**

```
uint32_t { ... } ::_reserved1
```

bit: 20..23 Reserved

**5.32.4.12 \_reserved1 [4/4]**

```
uint32_t xPSR_Type::_reserved1
```

bit: 20..23 Reserved

**5.32.4.13 ACPR**

`__IO uint32_t TPI_Type::ACPR`

Offset: 0x010 (R/W) Asynchronous Clock Prescaler Register

**5.32.4.14 ACTLR**

`__IO uint32_t SCnSCB_Type::ACTLR`

Offset: 0x008 (R/W) Auxiliary Control Register

**5.32.4.15 ADR**

`__I uint32_t SCB_Type::ADR`

Offset: 0x04C (R/ ) Auxiliary Feature Register

**5.32.4.16 AFSR**

```
__IO uint32_t SCB_Type::AFSR
```

Offset: 0x03C (R/W) Auxiliary Fault Status Register

**5.32.4.17 AIRCR**

```
__IO uint32_t SCB_Type::AIRCR
```

Offset: 0x00C (R/W) Application Interrupt and Reset Control Register

**5.32.4.18 [1/4]**

```
struct { ... } APSR_Type::b
```

Structure used for bit access

**5.32.4.19 [2/4]**

```
struct { ... } IPSR_Type::b
```

Structure used for bit access

**5.32.4.20 [3/4]**

```
struct { ... } xPSR_Type::b
```

Structure used for bit access

**5.32.4.21 [4/4]**

```
struct { ... } CONTROL_Type::b
```

Structure used for bit access

**5.32.4.22 BFAR**

```
__IO uint32_t SCB_Type::BFAR
```

Offset: 0x038 (R/W) BusFault Address Register

**5.32.4.23 C [1/4]**

```
uint32_t APSR_Type::C
```

bit: 29 Carry condition code flag

**5.32.4.24 [2/4]**

```
uint32_t { ... } ::C
```

bit: 29 Carry condition code flag

**5.32.4.25 C [3/4]**

```
uint32_t xPSR_Type::C
```

bit: 29 Carry condition code flag

**5.32.4.26 [4/4]**

```
uint32_t { ... } ::C
```

bit: 29 Carry condition code flag

**5.32.4.27 CALIB**

```
__I uint32_t SysTick_Type::CALIB
```

Offset: 0x00C (R/ ) SysTick Calibration Register

**5.32.4.28 CCR**

```
__IO uint32_t SCB_Type::CCR
```

Offset: 0x014 (R/W) Configuration Control Register

**5.32.4.29 CFSR**

```
__IO uint32_t SCB_Type::CFSR
```

Offset: 0x028 (R/W) Configurable Fault Status Register

**5.32.4.30 CID0**

```
__I uint32_t ITM_Type::CID0
```

Offset: 0xFF0 (R/ ) ITM Component Identification Register #0

**5.32.4.31 CID1**

```
__I uint32_t ITM_Type::CID1
```

Offset: 0xFF4 (R/ ) ITM Component Identification Register #1

**5.32.4.32 CID2**

```
__I uint32_t ITM_Type::CID2
```

Offset: 0xFF8 (R/ ) ITM Component Identification Register #2

**5.32.4.33 CID3**

```
__I uint32_t ITM_Type::CID3
```

Offset: 0xFFC (R/ ) ITM Component Identification Register #3

**5.32.4.34 CLAIMCLR**

```
__IO uint32_t TPI_Type::CLAIMCLR
```

Offset: 0xFA4 (R/W) Claim tag clear

**5.32.4.35 CLAIMSET**

```
__IO uint32_t TPI_Type::CLAIMSET
```

Offset: 0xFA0 (R/W) Claim tag set

**5.32.4.36 COMP0**

```
__IO uint32_t DWT_Type::COMP0
```

Offset: 0x020 (R/W) Comparator Register 0

#### 5.32.4.37 COMP1

`__IO uint32_t DWT_Type::COMP1`

Offset: 0x030 (R/W) Comparator Register 1

#### 5.32.4.38 COMP2

`__IO uint32_t DWT_Type::COMP2`

Offset: 0x040 (R/W) Comparator Register 2

#### 5.32.4.39 COMP3

`__IO uint32_t DWT_Type::COMP3`

Offset: 0x050 (R/W) Comparator Register 3

#### 5.32.4.40 CPACR

`__IO uint32_t SCB_Type::CPACR`

Offset: 0x088 (R/W) Coprocessor Access Control Register

#### 5.32.4.41 CPICNT

`__IO uint32_t DWT_Type::CPICNT`

Offset: 0x008 (R/W) CPI Count Register

#### 5.32.4.42 CPUID

`__I uint32_t SCB_Type::CPUID`

Offset: 0x000 (R/ ) CPUID Base Register

#### 5.32.4.43 CSPSR

`__IO uint32_t TPI_Type::CSPSR`

Offset: 0x004 (R/W) Current Parallel Port Size Register

**5.32.4.44 CTRL [1/2]**

```
__IO uint32_t SysTick_Type::CTRL
```

Offset: 0x000 (R/W) SysTick Control and Status Register

**5.32.4.45 CTRL [2/2]**

```
__IO uint32_t DWT_Type::CTRL
```

Offset: 0x000 (R/W) Control Register

**5.32.4.46 CYCCNT**

```
__IO uint32_t DWT_Type::CYCCNT
```

Offset: 0x004 (R/W) Cycle Count Register

**5.32.4.47 DCRDR**

```
__IO uint32_t CoreDebug_Type::DCRDR
```

Offset: 0x008 (R/W) Debug Core Register Data Register

**5.32.4.48 DCRSR**

```
__IO uint32_t CoreDebug_Type::DCRSR
```

Offset: 0x004 ( /W) Debug Core Register Selector Register

**5.32.4.49 DEMCR**

```
__IO uint32_t CoreDebug_Type::DEMCR
```

Offset: 0x00C (R/W) Debug Exception and Monitor Control Register

**5.32.4.50 DEVID**

```
__I uint32_t TPI_Type::DEVID
```

Offset: 0xFC8 (R/ ) TPIU\_DEVID

#### 5.32.4.51 DEVTYPE

`__I uint32_t TPI_Type::DEVTYPE`

Offset: 0xFCC (R/ ) TPIU\_DEVTYPE

#### 5.32.4.52 DFR

`__I uint32_t SCB_Type::DFR`

Offset: 0x048 (R/ ) Debug Feature Register

#### 5.32.4.53 DFSR

`__IO uint32_t SCB_Type::DFSR`

Offset: 0x030 (R/W) Debug Fault Status Register

#### 5.32.4.54 DHCSR

`__IO uint32_t CoreDebug_Type::DHCSR`

Offset: 0x000 (R/W) Debug Halting Control and Status Register

#### 5.32.4.55 EXCCNT

`__IO uint32_t DWT_Type::EXCCNT`

Offset: 0x00C (R/W) Exception Overhead Count Register

#### 5.32.4.56 FFCR

`__IO uint32_t TPI_Type::FFCR`

Offset: 0x304 (R/W) Formatter and Flush Control Register

#### 5.32.4.57 FFSR

`__I uint32_t TPI_Type::FFSR`

Offset: 0x300 (R/ ) Formatter and Flush Status Register

**5.32.4.58 FIFO0**

```
__I uint32_t TPI_Type::FIFO0
```

Offset: 0xEEC (R/ ) Integration ETM Data

**5.32.4.59 FIFO1**

```
__I uint32_t TPI_Type::FIFO1
```

Offset: 0xEFC (R/ ) Integration ITM Data

**5.32.4.60 FOLDCNT**

```
__IO uint32_t DWT_Type::FOLDCNT
```

Offset: 0x018 (R/W) Folded-instruction Count Register

**5.32.4.61 FPCA [1/2]**

```
uint32_t CONTROL_Type::FPCA
```

bit: 2 FP extension active flag

**5.32.4.62 [2/2]**

```
uint32_t { ... } ::FPCA
```

bit: 2 FP extension active flag

**5.32.4.63 FSCR**

```
__I uint32_t TPI_Type::FSCR
```

Offset: 0x308 (R/ ) Formatter Synchronization Counter Register

**5.32.4.64 FUNCTION0**

```
__IO uint32_t DWT_Type::FUNCTION0
```

Offset: 0x028 (R/W) Function Register 0

### 5.32.4.65 FUNCTION1

`__IO uint32_t DWT_Type::FUNCTION1`

Offset: 0x038 (R/W) Function Register 1

### 5.32.4.66 FUNCTION2

`__IO uint32_t DWT_Type::FUNCTION2`

Offset: 0x048 (R/W) Function Register 2

### 5.32.4.67 FUNCTION3

`__IO uint32_t DWT_Type::FUNCTION3`

Offset: 0x058 (R/W) Function Register 3

#### 5.32.4.68 [1/4]

`uint32_t { ... } ::GE`

bit: 16..19 Greater than or Equal flags

#### 5.32.4.69 GE [2/4]

`uint32_t APSR_Type::GE`

bit: 16..19 Greater than or Equal flags

#### 5.32.4.70 GE [3/4]

`uint32_t xPSR_Type::GE`

bit: 16..19 Greater than or Equal flags

#### 5.32.4.71 [4/4]

`uint32_t { ... } ::GE`

bit: 16..19 Greater than or Equal flags

#### 5.32.4.72 HFSR

`__IO uint32_t SCB_Type::HFSR`

Offset: 0x02C (R/W) HardFault Status Register

#### 5.32.4.73 IABR

`__IO uint32_t NVIC_Type::IABR[8]`

Offset: 0x200 (R/W) Interrupt Active bit Register

#### 5.32.4.74 ICER

`__IO uint32_t NVIC_Type::ICER[8]`

Offset: 0x080 (R/W) Interrupt Clear Enable Register

#### 5.32.4.75 ICPR

`__IO uint32_t NVIC_Type::ICPR[8]`

Offset: 0x180 (R/W) Interrupt Clear Pending Register

#### 5.32.4.76 ICSR

`__IO uint32_t SCB_Type::ICSR`

Offset: 0x004 (R/W) Interrupt Control and State Register

#### 5.32.4.77 ICTR

`__I uint32_t SCnSCB_Type::ICTR`

Offset: 0x004 (R/ ) Interrupt Controller Type Register

#### 5.32.4.78 IMCR

`__IO uint32_t ITM_Type::IMCR`

Offset: 0xF00 (R/W) ITM Integration Mode Control Register

#### 5.32.4.79 IP

```
__IO uint8_t NVIC_Type::IP[240]
```

Offset: 0x300 (R/W) Interrupt Priority Register (8Bit wide)

#### 5.32.4.80 IRR

```
__I uint32_t ITM_Type::IRR
```

Offset: 0xEFC (R/ ) ITM Integration Read Register

#### 5.32.4.81 ISAR

```
__I uint32_t SCB_Type::ISAR[5]
```

Offset: 0x060 (R/ ) Instruction Set Attributes Register

#### 5.32.4.82 ISER

```
__IO uint32_t NVIC_Type::ISER[8]
```

Offset: 0x000 (R/W) Interrupt Set Enable Register

#### 5.32.4.83 ISPR

```
__IO uint32_t NVIC_Type::ISPR[8]
```

Offset: 0x100 (R/W) Interrupt Set Pending Register

#### 5.32.4.84 ISR [1/4]

```
uint32_t IPSR_Type::ISR
```

bit: 0.. 8 Exception number

#### 5.32.4.85 [2/4]

```
uint32_t { ... } ::ISR
```

bit: 0.. 8 Exception number

**5.32.4.86 ISR [3/4]**

```
uint32_t xPSR_Type::ISR
```

bit: 0.. 8 Exception number

**5.32.4.87 [4/4]**

```
uint32_t { ... } ::ISR
```

bit: 0.. 8 Exception number

**5.32.4.88 IT [1/2]**

```
uint32_t xPSR_Type::IT
```

bit: 25..26 saved IT state (read 0)

**5.32.4.89 [2/2]**

```
uint32_t { ... } ::IT
```

bit: 25..26 saved IT state (read 0)

**5.32.4.90 ITATBCTR0**

```
I uint32_t TPI_Type::ITATBCTR0
```

Offset: 0xEF8 (R/ ) ITATBCTR0

**5.32.4.91 ITATBCTR2**

```
I uint32_t TPI_Type::ITATBCTR2
```

Offset: 0xEF0 (R/ ) ITATBCTR2

**5.32.4.92 ITCTRL**

```
IO uint32_t TPI_Type::ITCTRL
```

Offset: 0xF00 (R/W) Integration Mode Control

### 5.32.4.93 ITM\_RxBuffer

```
volatile int32_t ITM_RxBuffer [extern]
```

External variable to receive characters.

### 5.32.4.94 IWR

```
__IO uint32_t ITM_Type::IWR
```

Offset: 0xEF8 ( /W) ITM Integration Write Register

### 5.32.4.95 LAR

```
__IO uint32_t ITM_Type::LAR
```

Offset: 0xFB0 ( /W) ITM Lock Access Register

### 5.32.4.96 LOAD

```
__IO uint32_t SysTick_Type::LOAD
```

Offset: 0x004 (R/W) SysTick Reload Value Register

### 5.32.4.97 LSR

```
__I uint32_t ITM_Type::LSR
```

Offset: 0xFB4 (R/ ) ITM Lock Status Register

### 5.32.4.98 LSUCNT

```
__IO uint32_t DWT_Type::LSUCNT
```

Offset: 0x014 (R/W) LSU Count Register

### 5.32.4.99 MASK0

```
__IO uint32_t DWT_Type::MASK0
```

Offset: 0x024 (R/W) Mask Register 0

**5.32.4.100 MASK1**

```
__IO uint32_t DWT_Type::MASK1
```

Offset: 0x034 (R/W) Mask Register 1

**5.32.4.101 MASK2**

```
__IO uint32_t DWT_Type::MASK2
```

Offset: 0x044 (R/W) Mask Register 2

**5.32.4.102 MASK3**

```
__IO uint32_t DWT_Type::MASK3
```

Offset: 0x054 (R/W) Mask Register 3

**5.32.4.103 MMFAR**

```
__IO uint32_t SCB_Type::MMFAR
```

Offset: 0x034 (R/W) MemManage Fault Address Register

**5.32.4.104 MMFR**

```
__I uint32_t SCB_Type::MMFR[4]
```

Offset: 0x050 (R/ ) Memory Model Feature Register

**5.32.4.105 [1/4]**

```
uint32_t { ... } ::N
```

bit: 31 Negative condition code flag

**5.32.4.106 N [2/4]**

```
uint32_t APSR_Type::N
```

bit: 31 Negative condition code flag

**5.32.4.107 [3/4]**

```
uint32_t { ... } ::N
```

bit: 31 Negative condition code flag

**5.32.4.108 N [4/4]**

```
uint32_t xPSR_Type::N
```

bit: 31 Negative condition code flag

**5.32.4.109 nPRIV [1/2]**

```
uint32_t CONTROL_Type::nPRIV
```

bit: 0 Execution privilege in Thread mode

**5.32.4.110 [2/2]**

```
uint32_t { ... } ::nPRIV
```

bit: 0 Execution privilege in Thread mode

**5.32.4.111 PCSR**

[\\_\\_I](#) uint32\_t DWT\_Type::PCSR

Offset: 0x01C (R/ ) Program Counter Sample Register

**5.32.4.112 PFR**

[\\_\\_I](#) uint32\_t SCB\_Type::PFR[2]

Offset: 0x040 (R/ ) Processor Feature Register

**5.32.4.113 PID0**

[\\_\\_I](#) uint32\_t ITM\_Type::PID0

Offset: 0xFE0 (R/ ) ITM Peripheral Identification Register #0

**5.32.4.114 PID1**

`__I uint32_t ITM_Type::PID1`

Offset: 0xFE4 (R/ ) ITM Peripheral Identification Register #1

**5.32.4.115 PID2**

`__I uint32_t ITM_Type::PID2`

Offset: 0xFE8 (R/ ) ITM Peripheral Identification Register #2

**5.32.4.116 PID3**

`__I uint32_t ITM_Type::PID3`

Offset: 0xFEC (R/ ) ITM Peripheral Identification Register #3

**5.32.4.117 PID4**

`__I uint32_t ITM_Type::PID4`

Offset: 0xFD0 (R/ ) ITM Peripheral Identification Register #4

**5.32.4.118 PID5**

`__I uint32_t ITM_Type::PID5`

Offset: 0xFD4 (R/ ) ITM Peripheral Identification Register #5

**5.32.4.119 PID6**

`__I uint32_t ITM_Type::PID6`

Offset: 0xFD8 (R/ ) ITM Peripheral Identification Register #6

**5.32.4.120 PID7**

`__I uint32_t ITM_Type::PID7`

Offset: 0xFDC (R/ ) ITM Peripheral Identification Register #7

**5.32.4.121**

`__O { ... } ITM_Type::PORT[32]`

Offset: 0x000 ( /W) ITM Stimulus Port Registers

**5.32.4.122 [1/4]**

```
uint32_t { ... } ::Q
```

bit: 27 Saturation condition flag

**5.32.4.123 Q [2/4]**

```
uint32_t APSR_Type::Q
```

bit: 27 Saturation condition flag

**5.32.4.124 [3/4]**

```
uint32_t { ... } ::Q
```

bit: 27 Saturation condition flag

**5.32.4.125 Q [4/4]**

```
uint32_t xPSR_Type::Q
```

bit: 27 Saturation condition flag

**5.32.4.126 SCR**

```
IO uint32_t SCB_Type::SCR
```

Offset: 0x010 (R/W) System Control Register

**5.32.4.127 SHCSR**

```
IO uint32_t SCB_Type::SHCSR
```

Offset: 0x024 (R/W) System Handler Control and State Register

**5.32.4.128 SHP**

```
IO uint8_t SCB_Type::SHP[12]
```

Offset: 0x018 (R/W) System Handlers Priority Registers (4-7, 8-11, 12-15)

**5.32.4.129 SLEEPCNT**

```
__IO uint32_t DWT_Type::SLEEPCNT
```

Offset: 0x010 (R/W) Sleep Count Register

**5.32.4.130 SPPR**

```
__IO uint32_t TPI_Type::SPPR
```

Offset: 0x0F0 (R/W) Selected Pin Protocol Register

**5.32.4.131 SPSEL [1/2]**

```
uint32_t CONTROL_Type::SPSEL
```

bit: 1 Stack to be used

**5.32.4.132 [2/2]**

```
uint32_t { ... } ::SPSEL
```

bit: 1 Stack to be used

**5.32.4.133 SSPSR**

```
__IO uint32_t TPI_Type::SSPSR
```

Offset: 0x000 (R/ ) Supported Parallel Port Size Register

**5.32.4.134 STIR**

```
__O uint32_t NVIC_Type::STIR
```

Offset: 0xE00 ( /W) Software Trigger Interrupt Register

**5.32.4.135 [1/2]**

```
uint32_t { ... } ::T
```

bit: 24 Thumb bit (read 0)

**5.32.4.136 T [2/2]**

```
uint32_t xPSR_Type::T
```

bit: 24 Thumb bit (read 0)

**5.32.4.137 TCR**

```
__IO uint32_t ITM_Type::TCR
```

Offset: 0xE80 (R/W) ITM Trace Control Register

**5.32.4.138 TER**

```
__IO uint32_t ITM_Type::TER
```

Offset: 0xE00 (R/W) ITM Trace Enable Register

**5.32.4.139 TPR**

```
__IO uint32_t ITM_Type::TPR
```

Offset: 0xE40 (R/W) ITM Trace Privilege Register

**5.32.4.140 TRIGGER**

```
__I uint32_t TPI_Type::TRIGGER
```

Offset: 0xEE8 (R/) TRIGGER

**5.32.4.141 u16 [1/2]**

```
__O uint16_t ITM_Type::u16
```

Offset: 0x000 ( /W) ITM Stimulus Port 16-bit

**5.32.4.142 [2/2]**

```
__O { ... } ::u16
```

Offset: 0x000 ( /W) ITM Stimulus Port 16-bit

**5.32.4.143 u32 [1/2]**

`__O uint32_t ITM_Type::u32`

Offset: 0x000 ( /W) ITM Stimulus Port 32-bit

**5.32.4.144 [2/2]**

`__O { ... } ::u32`

Offset: 0x000 ( /W) ITM Stimulus Port 32-bit

**5.32.4.145 [1/2]**

`__O { ... } ::u8`

Offset: 0x000 ( /W) ITM Stimulus Port 8-bit

**5.32.4.146 u8 [2/2]**

`__O uint8_t ITM_Type::u8`

Offset: 0x000 ( /W) ITM Stimulus Port 8-bit

**5.32.4.147 [1/4]**

`uint32_t { ... } ::V`

bit: 28 Overflow condition code flag

**5.32.4.148 V [2/4]**

`uint32_t APSR_Type::V`

bit: 28 Overflow condition code flag

**5.32.4.149 [3/4]**

`uint32_t { ... } ::V`

bit: 28 Overflow condition code flag

**5.32.4.150 V [4/4]**

```
uint32_t xPSR_Type::V
```

bit: 28 Overflow condition code flag

**5.32.4.151 VAL**

```
__IO uint32_t SysTick_Type::VAL
```

Offset: 0x008 (R/W) SysTick Current Value Register

**5.32.4.152 VTOR**

```
__IO uint32_t SCB_Type::VTOR
```

Offset: 0x008 (R/W) Vector Table Offset Register

**5.32.4.153 w [1/4]**

```
uint32_t APSR_Type::w
```

Type used for word access

**5.32.4.154 w [2/4]**

```
uint32_t IPSR_Type::w
```

Type used for word access

**5.32.4.155 w [3/4]**

```
uint32_t xPSR_Type::w
```

Type used for word access

**5.32.4.156 w [4/4]**

```
uint32_t CONTROL_Type::w
```

Type used for word access

**5.32.4.157 Z [1/4]**

```
uint32_t APSR_Type::Z
```

bit: 30 Zero condition code flag

**5.32.4.158 [2/4]**

```
uint32_t { ... } ::Z
```

bit: 30 Zero condition code flag

**5.32.4.159 [3/4]**

```
uint32_t { ... } ::Z
```

bit: 30 Zero condition code flag

**5.32.4.160 Z [4/4]**

```
uint32_t xPSR_Type::Z
```

bit: 30 Zero condition code flag

## 5.33 CMSIS Core Register Access Functions

Collaboration diagram for CMSIS Core Register Access Functions:



## 5.34 CMSIS Core Instruction Interface

Collaboration diagram for CMSIS Core Instruction Interface:



Access to dedicated instructions

## 5.35 CMSIS SIMD Intrinsics

Collaboration diagram for CMSIS SIMD Intrinsics:



Access to dedicated SIMD instructions

## 5.36 Platform Standard Types

Defines standard platform types for STM32F4xx microcontrollers.

### Macros

- #define `CPU_TYPE_8` 8  
*CPU Type Definitions.*
- #define `CPU_TYPE_16` 16
- #define `CPU_TYPE_32` 32
- #define `CPU_TYPE_64` 64
- #define `MSB_FIRST` 0  
*Bit Order Definitions.*
- #define `LSB_FIRST` 1

- #define HIGH\_BYTE\_FIRST 0
  - Byte Order Definitions.*
- #define LOW\_BYTE\_FIRST 1
- #define CPU\_TYPE CPU\_TYPE\_32
  - Selected CPU Characteristics.*
- #define CPU\_BIT\_ORDER LSB\_FIRST
- #define CPU\_BYTE\_ORDER LOW\_BYTE\_FIRST
- #define TRUE 1
  - Boolean Constants.*
- #define FALSE 0
- #define SET TRUE
- #define RESET FALSE
- #define FLAG\_SET SET
- #define FLAG\_RESET RESET

## Typedefs

- typedef unsigned char boolean
  - Standard Data Types.*
- typedef signed char sint8
- typedef unsigned char uint8
- typedef signed short sint16
- typedef unsigned short uint16
- typedef signed long sint32
- typedef signed long long sint64
- typedef unsigned long uint32
- typedef unsigned long long uint64
- typedef unsigned long uint8\_least
  - Least Type Definitions.*
- typedef unsigned long uint16\_least
- typedef unsigned long uint32\_least
- typedef signed long sint8\_least
- typedef signed long sint16\_least
- typedef signed long sint32\_least
- typedef float float32
  - Floating-Point Types.*
- typedef double float64
- typedef void \* VoidPtr
  - Pointer Types.*
- typedef const void \* ConstVoidPtr
- typedef volatile unsigned char vuint8\_t
  - Volatile Types.*
- typedef volatile unsigned short vuint16\_t
- typedef volatile unsigned long vuint32\_t

### 5.36.1 Detailed Description

Defines standard platform types for STM32F4xx microcontrollers.

## 5.36.2 Macro Definition Documentation

### 5.36.2.1 CPU\_BIT\_ORDER

```
#define CPU_BIT_ORDER LSB_FIRST
```

Bit order: Least Significant Bit first

### 5.36.2.2 CPU\_BYTE\_ORDER

```
#define CPU_BYTE_ORDER LOW_BYTE_FIRST
```

Byte order: Low byte first

### 5.36.2.3 CPU\_TYPE

```
#define CPU_TYPE CPU_TYPE_32
```

Selected CPU Characteristics.

Defines the CPU characteristics used in this file. 32-bit CPU

### 5.36.2.4 CPU\_TYPE\_16

```
#define CPU_TYPE_16 16
```

16-bit CPU

### 5.36.2.5 CPU\_TYPE\_32

```
#define CPU_TYPE_32 32
```

32-bit CPU

### 5.36.2.6 CPU\_TYPE\_64

```
#define CPU_TYPE_64 64
```

64-bit CPU

### 5.36.2.7 CPU\_TYPE\_8

```
#define CPU_TYPE_8 8
```

CPU Type Definitions.

Defines the different CPU types supported. 8-bit CPU

### 5.36.2.8 FALSE

```
#define FALSE 0
```

Boolean false

### 5.36.2.9 FLAG\_RESET

```
#define FLAG_RESET RESET
```

Flag reset macro

### 5.36.2.10 FLAG\_SET

```
#define FLAG_SET SET
```

Flag set macro

### 5.36.2.11 HIGH\_BYTE\_FIRST

```
#define HIGH_BYTE_FIRST 0
```

Byte Order Definitions.

Defines the byte order conventions. High byte first

### 5.36.2.12 LOW\_BYTE\_FIRST

```
#define LOW_BYTE_FIRST 1
```

Low byte first

### 5.36.2.13 LSB\_FIRST

```
#define LSB_FIRST 1
```

Least Significant Bit first

### 5.36.2.14 MSB\_FIRST

```
#define MSB_FIRST 0
```

Bit Order Definitions.

Defines the bit order conventions. Most Significant Bit first

### 5.36.2.15 RESET

```
#define RESET FALSE
```

Reset macro

### 5.36.2.16 SET

```
#define SET TRUE
```

Set macro

### 5.36.2.17 TRUE

```
#define TRUE 1
```

Boolean Constants.

Defines standard boolean constants. Boolean true

## 5.36.3 Typedef Documentation

### 5.36.3.1 boolean

```
typedef unsigned char boolean
```

Standard Data Types.

Defines standard data types used across the platform. Boolean type, 1 byte

### 5.36.3.2 ConstVoidPtr

```
typedef const void* ConstVoidPtr
```

Constant generic pointer type

### 5.36.3.3 float32

```
typedef float float32
```

Floating-Point Types.

Defines floating-point data types. 32-bit floating point

### 5.36.3.4 float64

```
typedef double float64
```

64-bit floating point

### 5.36.3.5 sint16

```
typedef signed short sint16
```

Signed 16-bit integer

### 5.36.3.6 sint16\_least

```
typedef signed long sint16_least
```

Signed minimum 16-bit integer

### 5.36.3.7 sint32

```
typedef signed long sint32
```

Signed 32-bit integer

### 5.36.3.8 sint32\_least

```
typedef signed long sint32_least
```

Signed minimum 32-bit integer

### 5.36.3.9 sint64

```
typedef signed long long sint64
```

Signed 64-bit integer

### 5.36.3.10 sint8

```
typedef signed char sint8
```

Signed 8-bit integer

### 5.36.3.11 sint8\_least

```
typedef signed long sint8_least
```

Signed minimum 8-bit integer

### 5.36.3.12 uint16

```
typedef unsigned short uint16
```

Unsigned 16-bit integer

### 5.36.3.13 uint16\_least

```
typedef unsigned long uint16_least
```

Unsigned minimum 16-bit integer

### 5.36.3.14 uint32

```
typedef unsigned long uint32
```

Unsigned 32-bit integer

### 5.36.3.15 uint32\_least

```
typedef unsigned long uint32_least
```

Unsigned minimum 32-bit integer

### 5.36.3.16 uint64

```
typedef unsigned long long uint64
```

Unsigned 64-bit integer

### 5.36.3.17 uint8

```
typedef unsigned char uint8
```

Unsigned 8-bit integer

**5.36.3.18 uint8\_least**

```
typedef unsigned long uint8_least
```

Least Type Definitions.

Defines types with the minimum size constraints useful for memory-limited systems. Unsigned minimum 8-bit integer

**5.36.3.19 VoidPtr**

```
typedef void* VoidPtr
```

Pointer Types.

Defines generic pointer types. Generic pointer type

**5.36.3.20 vuint16\_t**

```
typedef volatile unsigned short vuint16_t
```

Volatile 16-bit unsigned integer

**5.36.3.21 vuint32\_t**

```
typedef volatile unsigned long vuint32_t
```

Volatile 32-bit unsigned integer

**5.36.3.22 vuint8\_t**

```
typedef volatile unsigned char vuint8_t
```

Volatile Types.

Defines volatile data types used for hardware registers. Volatile 8-bit unsigned integer

## 5.37 STM32F401xx MCU Header File

Header file containing all the necessary information about the STM32F401xx MCU.

Collaboration diagram for STM32F401xx MCU Header File:



## Modules

- [Memory Base Addresses](#)
- [Cortex-M4 Peripherals Base Addresses](#)
- [AHB Peripherals Base Addresses](#)
- [APB2 Peripherals Base Addresses](#)
- [APB1 Peripherals Base Addresses](#)
- [Peripheral Register Definitions](#)

*Structures defining the register layouts for various peripherals.*

- [Peripheral Instances](#)

*Peripheral instances for various hardware modules in the STM32 microcontroller.*

- [I2C Registers](#)

*Bit definitions for the I2C peripheral registers.*

- [RCC Bit Position Definitions](#)

*Bit position definitions for various registers in the RCC peripheral.*

- [GPIO Base Address to Code Conversion Macros](#)

*Macros for converting GPIO base addresses to corresponding port codes.*

### 5.37.1 Detailed Description

Header file containing all the necessary information about the STM32F401xx MCU.

## 5.38 Memory Base Addresses

Collaboration diagram for Memory Base Addresses:



### Macros

- `#define FLASH_MEMORY_BASE 0x08000000UL`  
*Base address of Flash memory.*
- `#define SYSTEM_MEMORY_BASE 0x1FFFF000UL`  
*Base address of System memory.*
- `#define SRAM_MEMORY_BASE 0x20000000UL`  
*Base address of SRAM memory.*
- `#define PERIPHERALS_BASE 0x40000000UL`  
*Base address of Peripheral registers.*
- `#define CORTEX_M4_INTERNAL_BASE 0xE0000000UL`  
*Base address of Cortex-M4 internal peripherals.*

### 5.38.1 Detailed Description

## 5.39 Cortex-M4 Peripherals Base Addresses

Collaboration diagram for Cortex-M4 Peripherals Base Addresses:



## Macros

- `#define NVIC_BASE 0xE000E100UL`  
*Base address of NVIC (Nested Vectored Interrupt Controller)*
- `#define SCB_BASE 0xE000ED00UL`  
*Base address of System Control Block (SCB)*
- `#define STK_BASE 0xE000E010UL`  
*Base address of SysTick Timer.*

### 5.39.1 Detailed Description

## 5.40 AHB Peripherals Base Addresses

Collaboration diagram for AHB Peripherals Base Addresses:



## Macros

- `#define RCC_BASE 0x40023800UL`  
*Base address of RCC (Reset and Clock Control)*
- `#define CRC_BASE 0x40023000UL`  
*Base address of CRC (Cyclic Redundancy Check)*

### 5.40.1 Detailed Description

## 5.41 APB2 Peripherals Base Addresses

Collaboration diagram for APB2 Peripherals Base Addresses:



## Macros

- `#define GPIOA_BASE 0x40020000UL`  
*Base address of GPIOA (General Purpose I/O port A)*
- `#define GPIOB_BASE 0x40020400UL`  
*Base address of GPIOB (General Purpose I/O port B)*
- `#define GPIOC_BASE 0x40020800UL`  
*Base address of GPIOC (General Purpose I/O port C)*
- `#define GPIOD_BASE 0x40020C00UL`  
*Base address of GPIOD (General Purpose I/O port D)*
- `#define GPIOE_BASE 0x40021000UL`  
*Base address of GPIOE (General Purpose I/O port E)*
- `#define EXTI_BASE 0x40013C00UL`  
*Base address of EXTI (External Interrupt/Event Controller)*
- `#define TIM1_BASE 0x40010000UL`  
*Base address of TIM1 (Timer 1)*
- `#define TIM2_BASE 0x40000000UL`  
*Base address of TIM2 (Timer 2)*
- `#define USART1_BASE 0x40011000UL`  
*Base address of USART1 (Universal Synchronous/Asynchronous Receiver Transmitter 1)*
- `#define USART6_BASE 0x40011400UL`  
*Base address of USART6 (Universal Synchronous/Asynchronous Receiver Transmitter 6)*
- `#define SPI1_BASE 0x40013000UL`  
*Base address of SPI1 (Serial Peripheral Interface 1)*
- `#define SYSCFG_BASE 0x40013800UL`  
*Base address of SYSCFG (System Configuration Controller)*

### 5.41.1 Detailed Description

## 5.42 APB1 Peripherals Base Addresses

Collaboration diagram for APB1 Peripherals Base Addresses:



## Macros

- `#define USART2_BASE 0x40004400UL`  
*Base address of USART2 (Universal Synchronous/Asynchronous Receiver Transmitter 2)*
- `#define SPI2_BASE 0x40003800UL`  
*Base address of SPI2 (Serial Peripheral Interface 2)*
- `#define I2C1_BASE 0x40005400UL`  
*Base address of I2C1 (Inter-Integrated Circuit 1)*
- `#define I2C2_BASE 0x40005800UL`  
*Base address of I2C2 (Inter-Integrated Circuit 2)*

### 5.42.1 Detailed Description

## 5.43 Peripheral Register Definitions

Structures defining the register layouts for various peripherals.

Collaboration diagram for Peripheral Register Definitions:



## Modules

- [NVIC Register Map](#)  
*NVIC (Nested Vectored Interrupt Controller) Register Map.*
- [SCB Register Map](#)  
*SCB (System Control Block) Register Map.*
- [SysTick Timer Register Map](#)  
*SysTick Timer Register Map.*
- [GPIO Register Map](#)  
*GPIO (General-Purpose Input/Output) Register Map.*
- [RCC Register Map](#)  
*RCC (Reset and Clock Control) Register Map.*
- [EXTI Register Map](#)  
*EXTI (External Interrupts) Register Map.*
- [SYSCFG Register Map](#)  
*SYSCFG (System Configuration) Register Map.*
- [USART Register Map](#)

*USART (Universal Synchronous Asynchronous Receiver Transmitter) Register Map.*

- [SPI Register Map](#)

*SPI (Serial Peripheral Interface) Register Map.*

- [I2C Register Map](#)

*I2C (Inter-Integrated Circuit) Register Map.*

- [CRC Register Map](#)

*CRC (Cyclic Redundancy Check) Register Map.*

- [TIM1 Register Map](#)

*TIM1 (Timer 1) Register Map.*

### 5.43.1 Detailed Description

Structures defining the register layouts for various peripherals.

## 5.44 NVIC Register Map

NVIC (Nested Vectored Interrupt Controller) Register Map.

Collaboration diagram for NVIC Register Map:



### Classes

- struct [NVIC\\_TypeDef](#)

### 5.44.1 Detailed Description

NVIC (Nested Vectored Interrupt Controller) Register Map.

## 5.45 SCB Register Map

SCB (System Control Block) Register Map.

Collaboration diagram for SCB Register Map:



### Classes

- struct [SCB\\_TypeDef](#)

#### 5.45.1 Detailed Description

SCB (System Control Block) Register Map.

## 5.46 SysTick Timer Register Map

SysTick Timer Register Map.

Collaboration diagram for SysTick Timer Register Map:



### Classes

- struct [STK\\_TypeDef](#)

#### 5.46.1 Detailed Description

SysTick Timer Register Map.

## 5.47 GPIO Register Map

GPIO (General-Purpose Input/Output) Register Map.

Collaboration diagram for GPIO Register Map:



### Classes

- struct [GPIO\\_TypeDef](#)

*General Purpose I/O.*

### 5.47.1 Detailed Description

GPIO (General-Purpose Input/Output) Register Map.

## 5.48 RCC Register Map

RCC (Reset and Clock Control) Register Map.

Collaboration diagram for RCC Register Map:



### Classes

- struct [RCC\\_TypeDef](#)

*Reset and Clock Control.*

### 5.48.1 Detailed Description

RCC (Reset and Clock Control) Register Map.

## 5.49 EXTI Register Map

EXTI (External Interrupts) Register Map.

Collaboration diagram for EXTI Register Map:



### Classes

- struct [EXTI\\_TypeDef](#)  
*External Interrupt/Event Controller.*

#### 5.49.1 Detailed Description

EXTI (External Interrupts) Register Map.

## 5.50 SYSCFG Register Map

SYSCFG (System Configuration) Register Map.

Collaboration diagram for SYSCFG Register Map:



### Classes

- struct [SYSCFG\\_RegDef\\_t](#)

#### 5.50.1 Detailed Description

SYSCFG (System Configuration) Register Map.

## 5.51 USART Register Map

USART (Universal Synchronous Asynchronous Receiver Transmitter) Register Map.

Collaboration diagram for USART Register Map:



### Classes

- struct [USART\\_TypeDef](#)  
*Universal Synchronous Asynchronous Receiver Transmitter.*

#### 5.51.1 Detailed Description

USART (Universal Synchronous Asynchronous Receiver Transmitter) Register Map.

## 5.52 SPI Register Map

SPI (Serial Peripheral Interface) Register Map.

Collaboration diagram for SPI Register Map:



### Classes

- struct [SPI\\_TypeDef](#)  
*Serial Peripheral Interface.*

#### 5.52.1 Detailed Description

SPI (Serial Peripheral Interface) Register Map.

## 5.53 I2C Register Map

I2C (Inter-Integrated Circuit) Register Map.

Collaboration diagram for I2C Register Map:



### Classes

- struct [I2C\\_TypeDef](#)  
*Inter-integrated Circuit Interface.*

#### 5.53.1 Detailed Description

I2C (Inter-Integrated Circuit) Register Map.

## 5.54 CRC Register Map

CRC (Cyclic Redundancy Check) Register Map.

Collaboration diagram for CRC Register Map:



### Classes

- struct [CRC\\_TypeDef](#)  
*CRC calculation unit.*

#### 5.54.1 Detailed Description

CRC (Cyclic Redundancy Check) Register Map.

## 5.55 TIM1 Register Map

TIM1 (Timer 1) Register Map.

Collaboration diagram for TIM1 Register Map:



### Classes

- struct [TIM1\\_TypeDef](#)

#### 5.55.1 Detailed Description

TIM1 (Timer 1) Register Map.

## 5.56 Peripheral Instances

Peripheral instances for various hardware modules in the STM32 microcontroller.

Collaboration diagram for Peripheral Instances:



## Modules

- **NVIC Instance**  
*Instance of the Nested Vectored Interrupt Controller (NVIC).*
- **SCB Instance**  
*Instance of the System Control Block (SCB).*
- **SysTick Timer Instance**  
*Instance of the SysTick Timer.*
- **GPIO Instances**  
*Instances of the General-Purpose Input/Output (GPIO) ports.*
- **RCC Instance**  
*Instance of the Reset and Clock Control (RCC).*
- **EXTI Instance**  
*Instance of the External Interrupts (EXTI).*
- **SYSCFG Instance**  
*Instance of the System Configuration (SYSCFG).*
- **Timer Instances**  
*Instances of the Timers (TIM1 and TIM2).*
- **USART Instances**  
*Instances of the Universal Synchronous Asynchronous Receiver Transmitters (USART1, USART2, and USART6).*
- **SPI Instances**  
*Instances of the Serial Peripheral Interfaces (SPI1 and SPI2).*
- **I2C Instances**  
*Instances of the Inter-Integrated Circuits (I2C1 and I2C2).*
- **CRC Instance**  
*Instance of the Cyclic Redundancy Check (CRC).*

### 5.56.1 Detailed Description

Peripheral instances for various hardware modules in the STM32 microcontroller.

## 5.57 NVIC Instance

Instance of the Nested Vectored Interrupt Controller (NVIC).

Collaboration diagram for NVIC Instance:



### Macros

- `#define NVIC ((NVIC_TypeDef*)NVIC_BASE)`

### 5.57.1 Detailed Description

Instance of the Nested Vectored Interrupt Controller (NVIC).

### 5.57.2 Macro Definition Documentation

#### 5.57.2.1 NVIC

```
#define NVIC ((NVIC_TypeDef*)NVIC_BASE)
```

Pointer to the NVIC registers.

## 5.58 SCB Instance

Instance of the System Control Block (SCB).

Collaboration diagram for SCB Instance:



## Macros

- `#define SCB ((SCB_TypeDef*)SCB_BASE)`

### 5.58.1 Detailed Description

Instance of the System Control Block (SCB).

### 5.58.2 Macro Definition Documentation

#### 5.58.2.1 SCB

```
#define SCB ((SCB_TypeDef*) SCB_BASE)
```

Pointer to the SCB registers.

## 5.59 SysTick Timer Instance

Instance of the SysTick Timer.

Collaboration diagram for SysTick Timer Instance:



## Macros

- `#define STK ((STK_TypeDef*)STK_BASE)`

### 5.59.1 Detailed Description

Instance of the SysTick Timer.

### 5.59.2 Macro Definition Documentation

### 5.59.2.1 STK

```
#define STK ((STK_TypeDef*)STK_BASE)
```

Pointer to the SysTick Timer registers.

## 5.60 GPIO Instances

Instances of the General-Purpose Input/Output (GPIO) ports.

Collaboration diagram for GPIO Instances:



### Macros

- `#define GPIOA ((GPIO_TypeDef*)GPIOA_BASE)`
- `#define GPIOB ((GPIO_TypeDef*)GPIOB_BASE)`
- `#define GPIOC ((GPIO_TypeDef*)GPIOC_BASE)`
- `#define GPIOD ((GPIO_TypeDef*)GPIOD_BASE)`
- `#define GPIOE ((GPIO_TypeDef*)GPIOE_BASE)`

### 5.60.1 Detailed Description

Instances of the General-Purpose Input/Output (GPIO) ports.

### 5.60.2 Macro Definition Documentation

#### 5.60.2.1 GPIOA

```
#define GPIOA ((GPIO_TypeDef*)GPIOA_BASE)
```

Pointer to GPIOA registers.

### 5.60.2.2 GPIOB

```
#define GPIOB ((GPIO_TypeDef*)GPIOB_BASE)
```

Pointer to GPIOB registers.

### 5.60.2.3 GPIOC

```
#define GPIOC ((GPIO_TypeDef*)GPIOC_BASE)
```

Pointer to GPIOC registers.

### 5.60.2.4 GPIOD

```
#define GPIOD ((GPIO_TypeDef*)GPIOD_BASE)
```

Pointer to GPIOD registers.

### 5.60.2.5 GPIOE

```
#define GPIOE ((GPIO_TypeDef*)GPIOE_BASE)
```

Pointer to GPIOE registers.

## 5.61 RCC Instance

Instance of the Reset and Clock Control (RCC).

Collaboration diagram for RCC Instance:



## Macros

- `#define RCC ((RCC_TypeDef*)RCC_BASE)`

### 5.61.1 Detailed Description

Instance of the Reset and Clock Control (RCC).

### 5.61.2 Macro Definition Documentation

#### 5.61.2.1 RCC

```
#define RCC ((RCC_TypeDef*) RCC_BASE)
```

Pointer to the RCC registers.

## 5.62 EXTI Instance

Instance of the External Interrupts (EXTI).

Collaboration diagram for EXTI Instance:



### Macros

- `#define EXTI ((EXTI_TypeDef*)EXTI_BASE)`

#### 5.62.1 Detailed Description

Instance of the External Interrupts (EXTI).

### 5.62.2 Macro Definition Documentation

#### 5.62.2.1 EXTI

```
#define EXTI ((EXTI_TypeDef*)EXTI_BASE)
```

Pointer to the EXTI registers.

## 5.63 SYSCFG Instance

Instance of the System Configuration (SYSCFG).

Collaboration diagram for SYSCFG Instance:



### Macros

- `#define SYSCFG ((SYSCFG_RegDef_t*)SYSCFG_BASE)`

#### 5.63.1 Detailed Description

Instance of the System Configuration (SYSCFG).

#### 5.63.2 Macro Definition Documentation

##### 5.63.2.1 SYSCFG

```
#define SYSCFG ((SYSCFG_RegDef_t*)SYSCFG_BASE)
```

Pointer to the SYSCFG registers.

## 5.64 Timer Instances

Instances of the Timers (TIM1 and TIM2).

Collaboration diagram for Timer Instances:



## Macros

- `#define TIM1 ((TIM1_TypeDef*)TIM1_BASE)`
- `#define TIM2 ((TIM1_TypeDef*)TIM2_BASE)`

### 5.64.1 Detailed Description

Instances of the Timers (TIM1 and TIM2).

### 5.64.2 Macro Definition Documentation

#### 5.64.2.1 TIM1

```
#define TIM1 ((TIM1_TypeDef*)TIM1_BASE)
```

Pointer to TIM1 registers.

#### 5.64.2.2 TIM2

```
#define TIM2 ((TIM1_TypeDef*)TIM2_BASE)
```

Pointer to TIM2 registers.

## 5.65 USART Instances

Instances of the Universal Synchronous Asynchronous Receiver Transmitters (USART1, USART2, and USART6).

Collaboration diagram for USART Instances:



## Macros

- `#define USART1 ((USART_TypeDef*)USART1_BASE)`
- `#define USART2 ((USART_TypeDef*)USART2_BASE)`
- `#define USART6 ((USART_TypeDef*)USART6_BASE)`

### 5.65.1 Detailed Description

Instances of the Universal Synchronous Asynchronous Receiver Transmitters (USART1, USART2, and USART6).

### 5.65.2 Macro Definition Documentation

#### 5.65.2.1 USART1

```
#define USART1 ((USART_TypeDef*)USART1_BASE)
```

Pointer to USART1 registers.

#### 5.65.2.2 USART2

```
#define USART2 ((USART_TypeDef*)USART2_BASE)
```

Pointer to USART2 registers.

#### 5.65.2.3 USART6

```
#define USART6 ((USART_TypeDef*)USART6_BASE)
```

Pointer to USART6 registers.

## 5.66 SPI Instances

Instances of the Serial Peripheral Interfaces (SPI1 and SPI2).

Collaboration diagram for SPI Instances:



## Macros

- #define SPI1 ((SPI\_TypeDef\*)SPI1\_BASE)
- #define SPI2 ((SPI\_TypeDef\*)SPI2\_BASE)

### 5.66.1 Detailed Description

Instances of the Serial Peripheral Interfaces (SPI1 and SPI2).

### 5.66.2 Macro Definition Documentation

#### 5.66.2.1 SPI1

```
#define SPI1 ((SPI_TypeDef*) SPI1_BASE)
```

Pointer to SPI1 registers.

#### 5.66.2.2 SPI2

```
#define SPI2 ((SPI_TypeDef*) SPI2_BASE)
```

Pointer to SPI2 registers.

## 5.67 I2C Instances

Instances of the Inter-Integrated Circuits (I2C1 and I2C2).

Collaboration diagram for I2C Instances:



### Macros

- #define I2C1 ((I2C\_TypeDef\*)I2C1\_BASE)
- #define I2C2 ((I2C\_TypeDef\*)I2C2\_BASE)

### 5.67.1 Detailed Description

Instances of the Inter-Integrated Circuits (I2C1 and I2C2).

## 5.67.2 Macro Definition Documentation

### 5.67.2.1 I2C1

```
#define I2C1 ((I2C_TypeDef*)I2C1_BASE)
```

Pointer to I2C1 registers.

### 5.67.2.2 I2C2

```
#define I2C2 ((I2C_TypeDef*)I2C2_BASE)
```

Pointer to I2C2 registers.

## 5.68 CRC Instance

Instance of the Cyclic Redundancy Check (CRC).

Collaboration diagram for CRC Instance:



### Macros

- #define CRC ((CRC\_TypeDef\*)CRC\_BASE)

### 5.68.1 Detailed Description

Instance of the Cyclic Redundancy Check (CRC).

### 5.68.2 Macro Definition Documentation

### 5.68.2.1 CRC

```
#define CRC ((CRC_TypeDef*) CRC_BASE)
```

Pointer to the CRC registers.

## 5.69 I2C Registers

Bit definitions for the I2C peripheral registers.

Collaboration diagram for I2C Registers:



## Modules

- [I2C CR1 Register Bit Definitions](#)  
*Bit definitions for the I2C Control Register 1 (CR1).*
- [I2C CR2 Register Bit Definitions](#)  
*Bit definitions for the I2C Control Register 2 (CR2).*
- [I2C OAR2 Register Bit Definitions](#)
- [I2C SR1 Register Bit Definitions](#)
- [I2C SR2 Register Bit Definitions](#)
- [I2C CCR Register Bit Definitions](#)
- [I2C TRISE Register Bit Definitions](#)

### 5.69.1 Detailed Description

Bit definitions for the I2C peripheral registers.

## 5.70 I2C CR1 Register Bit Definitions

Bit definitions for the I2C Control Register 1 (CR1).

Collaboration diagram for I2C CR1 Register Bit Definitions:



### Macros

- #define `I2C_CR1_PE_Pos` (0U)
 

*Position and mask for the Peripheral Enable bit in the I2C\_CR1 register.*
- #define `I2C_CR1_PE_Msk` (0x1UL << `I2C_CR1_PE_Pos`)
 

`I2C_CR1_PE` I2C\_CR1\_PE\_Msk
- #define `I2C_CR1_SMBUS_Pos` (1U)
 

*Position and mask for the SMBus Mode bit in the I2C\_CR1 register.*
- #define `I2C_CR1_SMBUS_Msk` (0x1UL << `I2C_CR1_SMBUS_Pos`)
 

`I2C_CR1_SMBUS` I2C\_CR1\_SMBUS\_Msk
- #define `I2C_CR1_SMBTYPE_Pos` (3U)
 

*Position and mask for the SMBus Type bit in the I2C\_CR1 register.*
- #define `I2C_CR1_SMBTYPE_Msk` (0x1UL << `I2C_CR1_SMBTYPE_Pos`)
 

`I2C_CR1_SMBTYPE` I2C\_CR1\_SMBTYPE\_Msk
- #define `I2C_CR1_ENARP_Pos` (4U)
 

*Position and mask for the ARP Enable bit in the I2C\_CR1 register.*
- #define `I2C_CR1_ENARP_Msk` (0x1UL << `I2C_CR1_ENARP_Pos`)
 

`I2C_CR1_ENARP` I2C\_CR1\_ENARP\_Msk
- #define `I2C_CR1_ENPEC_Pos` (5U)
 

*Position and mask for the PEC Enable bit in the I2C\_CR1 register.*
- #define `I2C_CR1_ENPEC_Msk` (0x1UL << `I2C_CR1_ENPEC_Pos`)
 

`I2C_CR1_ENPEC` I2C\_CR1\_ENPEC\_Msk
- #define `I2C_CR1_ENGC_Pos` (6U)
 

*Position and mask for the General Call Enable bit in the I2C\_CR1 register.*
- #define `I2C_CR1_ENGC_Msk` (0x1UL << `I2C_CR1_ENGC_Pos`)
 

`I2C_CR1_ENGC` I2C\_CR1\_ENGC\_Msk
- #define `I2C_CR1_NOSTRETCH_Pos` (7U)
 

*Position and mask for the Clock Stretching Disable bit in the I2C\_CR1 register.*
- #define `I2C_CR1_NOSTRETCH_Msk` (0x1UL << `I2C_CR1_NOSTRETCH_Pos`)
 

`I2C_CR1_NOSTRETCH` I2C\_CR1\_NOSTRETCH\_Msk
- #define `I2C_CR1_START_Pos` (8U)
 

*Position and mask for the Start Generation bit in the I2C\_CR1 register.*
- #define `I2C_CR1_START_Msk` (0x1UL << `I2C_CR1_START_Pos`)
 

`I2C_CR1_START` I2C\_CR1\_START\_Msk
- #define `I2C_CR1_STOP_Pos` (9U)

*Position and mask for the Stop Generation bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_STOP\_Msk (0x1UL << I2C\_CR1\_STOP\_Pos)
- #define I2C\_CR1\_STOP I2C\_CR1\_STOP\_Msk
- #define I2C\_CR1\_ACK\_Pos (10U)

*Position and mask for the Acknowledge Enable bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_ACK\_Msk (0x1UL << I2C\_CR1\_ACK\_Pos)
- #define I2C\_CR1\_ACK I2C\_CR1\_ACK\_Msk
- #define I2C\_CR1\_POS\_Pos (11U)

*Position and mask for the Acknowledge/PEC Position bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_POS\_Msk (0x1UL << I2C\_CR1\_POS\_Pos)
- #define I2C\_CR1\_POS I2C\_CR1\_POS\_Msk
- #define I2C\_CR1\_PEC\_Pos (12U)

*Position and mask for the Packet Error Checking bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_PEC\_Msk (0x1UL << I2C\_CR1\_PEC\_Pos)
- #define I2C\_CR1\_PEC I2C\_CR1\_PEC\_Msk
- #define I2C\_CR1\_ALERT\_Pos (13U)

*Position and mask for the SMBus Alert bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_ALERT\_Msk (0x1UL << I2C\_CR1\_ALERT\_Pos)
- #define I2C\_CR1\_ALERT I2C\_CR1\_ALERT\_Msk
- #define I2C\_CR1\_SWRST\_Pos (15U)

*Position and mask for the Software Reset bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_SWRST\_Msk (0x1UL << I2C\_CR1\_SWRST\_Pos)
- #define I2C\_CR1\_SWRST I2C\_CR1\_SWRST\_Msk

## 5.70.1 Detailed Description

Bit definitions for the I2C Control Register 1 (CR1).

## 5.70.2 Macro Definition Documentation

### 5.70.2.1 I2C\_CR1\_ACK

```
#define I2C_CR1_ACK I2C_CR1_ACK_Msk
```

Acknowledge Enable

### 5.70.2.2 I2C\_CR1\_ACK\_Msk

```
#define I2C_CR1_ACK_Msk (0x1UL << I2C_CR1_ACK_Pos)
```

Bit mask for Acknowledge Enable

### 5.70.2.3 I2C\_CR1\_ACK\_Pos

```
#define I2C_CR1_ACK_Pos (10U)
```

Position and mask for the Acknowledge Enable bit in the I2C\_CR1 register.

Position of Acknowledge Enable bit

### 5.70.2.4 I2C\_CR1\_ALERT

```
#define I2C_CR1_ALERT I2C_CR1_ALERT_Msk
```

SMBus Alert

### 5.70.2.5 I2C\_CR1\_ALERT\_Msk

```
#define I2C_CR1_ALERT_Msk (0x1UL << I2C_CR1_ALERT_Pos)
```

Bit mask for SMBus Alert

### 5.70.2.6 I2C\_CR1\_ALERT\_Pos

```
#define I2C_CR1_ALERT_Pos (13U)
```

Position and mask for the SMBus Alert bit in the I2C\_CR1 register.

Position of SMBus Alert bit

### 5.70.2.7 I2C\_CR1\_ENARP

```
#define I2C_CR1_ENARP I2C_CR1_ENARP_Msk
```

ARP Enable

### 5.70.2.8 I2C\_CR1\_ENARP\_Msk

```
#define I2C_CR1_ENARP_Msk (0x1UL << I2C_CR1_ENARP_Pos)
```

Bit mask for ARP Enable

### 5.70.2.9 I2C\_CR1\_ENARP\_Pos

```
#define I2C_CR1_ENARP_Pos (4U)
```

Position and mask for the ARP Enable bit in the I2C\_CR1 register.

Position of ARP Enable bit

### 5.70.2.10 I2C\_CR1\_ENGC

```
#define I2C_CR1_ENGC I2C_CR1_ENGC_Msk
```

General Call Enable

### 5.70.2.11 I2C\_CR1\_ENGC\_Msk

```
#define I2C_CR1_ENGC_Msk (0x1UL << I2C_CR1_ENGC_Pos)
```

Bit mask for General Call Enable

### 5.70.2.12 I2C\_CR1\_ENGC\_Pos

```
#define I2C_CR1_ENGC_Pos (6U)
```

Position and mask for the General Call Enable bit in the I2C\_CR1 register.

Position of General Call Enable bit

### 5.70.2.13 I2C\_CR1\_ENPEC

```
#define I2C_CR1_ENPEC I2C_CR1_ENPEC_Msk
```

PEC Enable

### 5.70.2.14 I2C\_CR1\_ENPEC\_Msk

```
#define I2C_CR1_ENPEC_Msk (0x1UL << I2C_CR1_ENPEC_Pos)
```

Bit mask for PEC Enable

### 5.70.2.15 I2C\_CR1\_ENPEC\_Pos

```
#define I2C_CR1_ENPEC_Pos (5U)
```

Position and mask for the PEC Enable bit in the I2C\_CR1 register.

Position of PEC Enable bit

### 5.70.2.16 I2C\_CR1\_NOSTRETCH

```
#define I2C_CR1_NOSTRETCH I2C_CR1_NOSTRETCH_Msk
```

Clock Stretching Disable (Slave mode)

### 5.70.2.17 I2C\_CR1\_NOSTRETCH\_Msk

```
#define I2C_CR1_NOSTRETCH_Msk (0x1UL << I2C_CR1_NOSTRETCH_Pos)
```

Bit mask for Clock Stretching Disable

### 5.70.2.18 I2C\_CR1\_NOSTRETCH\_Pos

```
#define I2C_CR1_NOSTRETCH_Pos (7U)
```

Position and mask for the Clock Stretching Disable bit in the I2C\_CR1 register.

Position of Clock Stretching Disable bit

### 5.70.2.19 I2C\_CR1\_PE

```
#define I2C_CR1_PE I2C_CR1_PE_Msk
```

Peripheral Enable

### 5.70.2.20 I2C\_CR1\_PE\_Msk

```
#define I2C_CR1_PE_Msk (0x1UL << I2C_CR1_PE_Pos)
```

Bit mask for Peripheral Enable

### 5.70.2.21 I2C\_CR1\_PE\_Pos

```
#define I2C_CR1_PE_Pos (0U)
```

Position and mask for the Peripheral Enable bit in the I2C\_CR1 register.

Position of Peripheral Enable bit

### 5.70.2.22 I2C\_CR1\_PEC

```
#define I2C_CR1_PEC I2C_CR1_PEC_Msk
```

Packet Error Checking

### 5.70.2.23 I2C\_CR1\_PEC\_Msk

```
#define I2C_CR1_PEC_Msk (0x1UL << I2C_CR1_PEC_Pos)
```

Bit mask for Packet Error Checking

### 5.70.2.24 I2C\_CR1\_PEC\_Pos

```
#define I2C_CR1_PEC_Pos (12U)
```

Position and mask for the Packet Error Checking bit in the I2C\_CR1 register.

Position of Packet Error Checking bit

### 5.70.2.25 I2C\_CR1\_POS

```
#define I2C_CR1_POS I2C_CR1_POS_Msk
```

Acknowledge/PEC Position (for data reception)

### 5.70.2.26 I2C\_CR1\_POS\_Msk

```
#define I2C_CR1_POS_Msk (0x1UL << I2C_CR1_POS_Pos)
```

Bit mask for Acknowledge/PEC Position

### 5.70.2.27 I2C\_CR1\_POS\_Pos

```
#define I2C_CR1_POS_Pos (11U)
```

Position and mask for the Acknowledge/PEC Position bit in the I2C\_CR1 register.

Position of Acknowledge/PEC Position bit

### 5.70.2.28 I2C\_CR1\_SMBTYPE

```
#define I2C_CR1_SMBTYPE I2C_CR1_SMBTYPE_Msk
```

SMBus Type

### 5.70.2.29 I2C\_CR1\_SMBTYPE\_Msk

```
#define I2C_CR1_SMBTYPE_Msk (0x1UL << I2C_CR1_SMBTYPE_Pos)
```

Bit mask for SMBus Type

### 5.70.2.30 I2C\_CR1\_SMBTYPE\_Pos

```
#define I2C_CR1_SMBTYPE_Pos (3U)
```

Position and mask for the SMBus Type bit in the I2C\_CR1 register.

Position of SMBus Type bit

### 5.70.2.31 I2C\_CR1\_SMBUS

```
#define I2C_CR1_SMBUS I2C_CR1_SMBUS_Msk
```

SMBus Mode

### 5.70.2.32 I2C\_CR1\_SMBUS\_Msk

```
#define I2C_CR1_SMBUS_Msk (0x1UL << I2C_CR1_SMBUS_Pos)
```

Bit mask for SMBus Mode

### 5.70.2.33 I2C\_CR1\_SMBUS\_Pos

```
#define I2C_CR1_SMBUS_Pos (1U)
```

Position and mask for the SMBus Mode bit in the I2C\_CR1 register.

Position of SMBus Mode bit

### 5.70.2.34 I2C\_CR1\_START

```
#define I2C_CR1_START I2C_CR1_START_Msk
```

Start Generation

### 5.70.2.35 I2C\_CR1\_START\_Msk

```
#define I2C_CR1_START_Msk (0x1UL << I2C_CR1_START_Pos)
```

Bit mask for Start Generation

### 5.70.2.36 I2C\_CR1\_START\_Pos

```
#define I2C_CR1_START_Pos (8U)
```

Position and mask for the Start Generation bit in the I2C\_CR1 register.

Position of Start Generation bit

### 5.70.2.37 I2C\_CR1\_STOP

```
#define I2C_CR1_STOP I2C_CR1_STOP_Msk
```

Stop Generation

### 5.70.2.38 I2C\_CR1\_STOP\_Msk

```
#define I2C_CR1_STOP_Msk (0x1UL << I2C_CR1_STOP_Pos)
```

Bit mask for Stop Generation

### 5.70.2.39 I2C\_CR1\_STOP\_Pos

```
#define I2C_CR1_STOP_Pos (9U)
```

Position and mask for the Stop Generation bit in the I2C\_CR1 register.

Position of Stop Generation bit

### 5.70.2.40 I2C\_CR1\_SWRST

```
#define I2C_CR1_SWRST I2C_CR1_SWRST_Msk
```

Software Reset

### 5.70.2.41 I2C\_CR1\_SWRST\_Msk

```
#define I2C_CR1_SWRST_Msk (0x1UL << I2C_CR1_SWRST_Pos)
```

Bit mask for Software Reset

### 5.70.2.42 I2C\_CR1\_SWRST\_Pos

```
#define I2C_CR1_SWRST_Pos (15U)
```

Position and mask for the Software Reset bit in the I2C\_CR1 register.

Position of Software Reset bit

## 5.71 I2C CR2 Register Bit Definitions

Bit definitions for the I2C Control Register 2 (CR2).

Collaboration diagram for I2C CR2 Register Bit Definitions:



## Macros

- `#define I2C_CR2_FREQ_Pos (0U)`  
*Position and mask for the Peripheral Clock Frequency bits in the I2C\_CR2 register.*
- `#define I2C_CR2_FREQ_Msk (0x3FUL << I2C_CR2_FREQ_Pos)`
- `#define I2C_CR2_FREQ I2C_CR2_FREQ_Msk`
- `#define I2C_CR2_ITERREN_Pos (8U)`  
*Position and mask for the Error Interrupt Enable bit in the I2C\_CR2 register.*
- `#define I2C_CR2_ITERREN_Msk (0x1UL << I2C_CR2_ITERREN_Pos)`
- `#define I2C_CR2_ITERREN I2C_CR2_ITERREN_Msk`
- `#define I2C_CR2_IYTEVTEN_Pos (9U)`  
*Position and mask for the Event Interrupt Enable bit in the I2C\_CR2 register.*
- `#define I2C_CR2_IYTEVTEN_Msk (0x1UL << I2C_CR2_IYTEVTEN_Pos)`
- `#define I2C_CR2_IYTEVTEN I2C_CR2_IYTEVTEN_Msk`
- `#define I2C_CR2_ITBUFEN_Pos (10U)`  
*Position and mask for the Buffer Interrupt Enable bit in the I2C\_CR2 register.*
- `#define I2C_CR2_ITBUFEN_Msk (0x1UL << I2C_CR2_ITBUFEN_Pos)`
- `#define I2C_CR2_ITBUFEN I2C_CR2_ITBUFEN_Msk`
- `#define I2C_CR2_DMAEN_Pos (11U)`  
*Position and mask for the DMA Requests Enable bit in the I2C\_CR2 register.*
- `#define I2C_CR2_DMAEN_Msk (0x1UL << I2C_CR2_DMAEN_Pos)`
- `#define I2C_CR2_DMAEN I2C_CR2_DMAEN_Msk`
- `#define I2C_CR2_LAST_Pos (12U)`  
*Position and mask for the Last DMA Transfer bit in the I2C\_CR2 register.*
- `#define I2C_CR2_LAST_Msk (0x1UL << I2C_CR2_LAST_Pos)`
- `#define I2C_CR2_LAST I2C_CR2_LAST_Msk`

### 5.71.1 Detailed Description

Bit definitions for the I2C Control Register 2 (CR2).

### 5.71.2 Macro Definition Documentation

#### 5.71.2.1 I2C\_CR2\_DMAEN

```
#define I2C_CR2_DMAEN I2C_CR2_DMAEN_Msk
```

DMA Requests Enable

#### 5.71.2.2 I2C\_CR2\_DMAEN\_Msk

```
#define I2C_CR2_DMAEN_Msk (0x1UL << I2C_CR2_DMAEN_Pos)
```

Bit mask for DMA Requests Enable

### 5.71.2.3 I2C\_CR2\_DMAEN\_Pos

```
#define I2C_CR2_DMAEN_Pos (11U)
```

Position and mask for the DMA Requests Enable bit in the I2C\_CR2 register.

Position of DMA Requests Enable bit

### 5.71.2.4 I2C\_CR2\_FREQ

```
#define I2C_CR2_FREQ I2C_CR2_FREQ_Msk
```

Peripheral Clock Frequency

### 5.71.2.5 I2C\_CR2\_FREQ\_Msk

```
#define I2C_CR2_FREQ_Msk (0x3FUL << I2C_CR2_FREQ_Pos)
```

Bit mask for Peripheral Clock Frequency

### 5.71.2.6 I2C\_CR2\_FREQ\_Pos

```
#define I2C_CR2_FREQ_Pos (0U)
```

Position and mask for the Peripheral Clock Frequency bits in the I2C\_CR2 register.

Position of Peripheral Clock Frequency bits

### 5.71.2.7 I2C\_CR2\_ITBUFEN

```
#define I2C_CR2_ITBUFEN I2C_CR2_ITBUFEN_Msk
```

Buffer Interrupt Enable

### 5.71.2.8 I2C\_CR2\_ITBUFEN\_Msk

```
#define I2C_CR2_ITBUFEN_Msk (0x1UL << I2C_CR2_ITBUFEN_Pos)
```

Bit mask for Buffer Interrupt Enable

### 5.71.2.9 I2C\_CR2\_ITBUFEN\_Pos

```
#define I2C_CR2_ITBUFEN_Pos (10U)
```

Position and mask for the Buffer Interrupt Enable bit in the I2C\_CR2 register.

Position of Buffer Interrupt Enable bit

### 5.71.2.10 I2C\_CR2\_ITERREN

```
#define I2C_CR2_ITERREN I2C_CR2_ITERREN_Msk
```

Error Interrupt Enable

### 5.71.2.11 I2C\_CR2\_ITERREN\_Msk

```
#define I2C_CR2_ITERREN_Msk (0x1UL << I2C_CR2_ITERREN_Pos)
```

Bit mask for Error Interrupt Enable

### 5.71.2.12 I2C\_CR2\_ITERREN\_Pos

```
#define I2C_CR2_ITERREN_Pos (8U)
```

Position and mask for the Error Interrupt Enable bit in the I2C\_CR2 register.

Position of Error Interrupt Enable bit

### 5.71.2.13 I2C\_CR2\_Itevtten

```
#define I2C_CR2_Itevtten I2C_CR2_Itevtten_Msk
```

Event Interrupt Enable

### 5.71.2.14 I2C\_CR2\_Itevtten\_Msk

```
#define I2C_CR2_Itevtten_Msk (0x1UL << I2C_CR2_Itevtten_Pos)
```

Bit mask for Event Interrupt Enable

### 5.71.2.15 I2C\_CR2\_Itevtten\_Pos

```
#define I2C_CR2_Itevtten_Pos (9U)
```

Position and mask for the Event Interrupt Enable bit in the I2C\_CR2 register.

Position of Event Interrupt Enable bit

### 5.71.2.16 I2C\_CR2\_LAST

```
#define I2C_CR2_LAST I2C_CR2_LAST_Msk
```

Last DMA Transfer

### 5.71.2.17 I2C\_CR2\_LAST\_Msk

```
#define I2C_CR2_LAST_Msk (0x1UL << I2C_CR2_LAST_Pos)
```

Bit mask for Last DMA Transfer

### 5.71.2.18 I2C\_CR2\_LAST\_Pos

```
#define I2C_CR2_LAST_Pos (12U)
```

Position and mask for the Last DMA Transfer bit in the I2C\_CR2 register.

Position of Last DMA Transfer bit

## 5.72 I2C OAR2 Register Bit Definitions

Collaboration diagram for I2C OAR2 Register Bit Definitions:



## Macros

- #define I2C\_OAR2\_ENDUAL\_Pos (0U)  
*Bit definitions for the I2C\_OAR2 register.*
- #define I2C\_OAR2\_ENDUAL\_Msk (0x1UL << I2C\_OAR2\_ENDUAL\_Pos)
- #define I2C\_OAR2\_ENDUAL\_I2C\_OAR2\_ENDUAL\_Msk
- #define I2C\_OAR2\_ADD2\_Pos (1U)
- #define I2C\_OAR2\_ADD2\_Msk (0x1UL << I2C\_OAR2\_ADD2\_Pos)
- #define I2C\_OAR2\_ADD2\_I2C\_OAR2\_ADD2\_Msk

### 5.72.1 Detailed Description

### 5.72.2 Macro Definition Documentation

### 5.72.2.1 I2C\_OAR2\_ADD2

```
#define I2C_OAR2_ADD2 I2C_OAR2_ADD2_Msk
```

Second Address bit

### 5.72.2.2 I2C\_OAR2\_ADD2\_Msk

```
#define I2C_OAR2_ADD2_Msk (0x1UL << I2C_OAR2_ADD2_Pos)
```

Bit mask for Second Address bit

### 5.72.2.3 I2C\_OAR2\_ADD2\_Pos

```
#define I2C_OAR2_ADD2_Pos (1U)
```

Position of Second Address bit

### 5.72.2.4 I2C\_OAR2\_ENDUAL

```
#define I2C_OAR2_ENDUAL I2C_OAR2_ENDUAL_Msk
```

Dual Addressing Mode Enable

### 5.72.2.5 I2C\_OAR2\_ENDUAL\_Msk

```
#define I2C_OAR2_ENDUAL_Msk (0x1UL << I2C_OAR2_ENDUAL_Pos)
```

Bit mask for Dual Addressing Mode Enable

### 5.72.2.6 I2C\_OAR2\_ENDUAL\_Pos

```
#define I2C_OAR2_ENDUAL_Pos (0U)
```

Bit definitions for the I2C\_OAR2 register.

Position of Dual Addressing Mode Enable bit

## 5.73 I2C SR1 Register Bit Definitions

Collaboration diagram for I2C SR1 Register Bit Definitions:



## Macros

- `#define I2C_SR1_SB_Pos (0U)`  
*Bit definitions for the I2C\_SR1 register.*
- `#define I2C_SR1_SB_Msk (0x1UL << I2C_SR1_SB_Pos)`
- `#define I2C_SR1_SB I2C_SR1_SB_Msk`
- `#define I2C_SR1_ADDR_Pos (1U)`
- `#define I2C_SR1_ADDR_Msk (0x1UL << I2C_SR1_ADDR_Pos)`
- `#define I2C_SR1_ADDR I2C_SR1_ADDR_Msk`
- `#define I2C_SR1_BTF_Pos (2U)`
- `#define I2C_SR1_BTF_Msk (0x1UL << I2C_SR1_BTF_Pos)`
- `#define I2C_SR1_BTF I2C_SR1_BTF_Msk`
- `#define I2C_SR1_ADD10_Pos (3U)`
- `#define I2C_SR1_ADD10_Msk (0x1UL << I2C_SR1_ADD10_Pos)`
- `#define I2C_SR1_ADD10 I2C_SR1_ADD10_Msk`
- `#define I2C_SR1_STOPF_Pos (4U)`
- `#define I2C_SR1_STOPF_Msk (0x1UL << I2C_SR1_STOPF_Pos)`
- `#define I2C_SR1_STOPF I2C_SR1_STOPF_Msk`
- `#define I2C_SR1_RXNE_Pos (6U)`
- `#define I2C_SR1_RXNE_Msk (0x1UL << I2C_SR1_RXNE_Pos)`
- `#define I2C_SR1_RXNE I2C_SR1_RXNE_Msk`
- `#define I2C_SR1_TXE_Pos (7U)`
- `#define I2C_SR1_TXE_Msk (0x1UL << I2C_SR1_TXE_Pos)`
- `#define I2C_SR1_TXE I2C_SR1_TXE_Msk`
- `#define I2C_SR1_BERR_Pos (8U)`
- `#define I2C_SR1_BERR_Msk (0x1UL << I2C_SR1_BERR_Pos)`
- `#define I2C_SR1_BERR I2C_SR1_BERR_Msk`
- `#define I2C_SR1_ARLO_Pos (9U)`
- `#define I2C_SR1_ARLO_Msk (0x1UL << I2C_SR1_ARLO_Pos)`
- `#define I2C_SR1_ARLO I2C_SR1_ARLO_Msk`
- `#define I2C_SR1_AF_Pos (10U)`
- `#define I2C_SR1_AF_Msk (0x1UL << I2C_SR1_AF_Pos)`
- `#define I2C_SR1_AF I2C_SR1_AF_Msk`
- `#define I2C_SR1_OVR_Pos (11U)`
- `#define I2C_SR1_OVR_Msk (0x1UL << I2C_SR1_OVR_Pos)`
- `#define I2C_SR1_OVR I2C_SR1_OVR_Msk`
- `#define I2C_SR1_PECERR_Pos (12U)`
- `#define I2C_SR1_PECERR_Msk (0x1UL << I2C_SR1_PECERR_Pos)`
- `#define I2C_SR1_PECERR I2C_SR1_PECERR_Msk`
- `#define I2C_SR1_TIMEOUT_Pos (14U)`
- `#define I2C_SR1_TIMEOUT_Msk (0x1UL << I2C_SR1_TIMEOUT_Pos)`
- `#define I2C_SR1_TIMEOUT I2C_SR1_TIMEOUT_Msk`
- `#define I2C_SR1_SMBALERT_Pos (15U)`
- `#define I2C_SR1_SMBALERT_Msk (0x1UL << I2C_SR1_SMBALERT_Pos)`
- `#define I2C_SR1_SMBALERT I2C_SR1_SMBALERT_Msk`

### 5.73.1 Detailed Description

### 5.73.2 Macro Definition Documentation

### 5.73.2.1 I2C\_SR1\_ADD10

```
#define I2C_SR1_ADD10 I2C_SR1_ADD10_Msk
```

10-bit Address Header Sent (Master mode)

### 5.73.2.2 I2C\_SR1\_ADD10\_Msk

```
#define I2C_SR1_ADD10_Msk (0x1UL << I2C_SR1_ADD10_Pos)
```

Bit mask for 10-bit Address Header Sent

### 5.73.2.3 I2C\_SR1\_ADD10\_Pos

```
#define I2C_SR1_ADD10_Pos (3U)
```

Position of 10-bit Address Header Sent (Master mode)

### 5.73.2.4 I2C\_SR1\_ADDR

```
#define I2C_SR1_ADDR I2C_SR1_ADDR_Msk
```

Address Sent (Master mode) or Matched (Slave mode)

### 5.73.2.5 I2C\_SR1\_ADDR\_Msk

```
#define I2C_SR1_ADDR_Msk (0x1UL << I2C_SR1_ADDR_Pos)
```

Bit mask for Address Sent or Matched

### 5.73.2.6 I2C\_SR1\_ADDR\_Pos

```
#define I2C_SR1_ADDR_Pos (1U)
```

Position of Address Sent (Master mode) or Matched (Slave mode)

### 5.73.2.7 I2C\_SR1\_AF

```
#define I2C_SR1_AF I2C_SR1_AF_Msk
```

Acknowledge Failure

### 5.73.2.8 I2C\_SR1\_AF\_Msk

```
#define I2C_SR1_AF_Msk (0x1UL << I2C_SR1_AF_Pos)
```

Bit mask for Acknowledge Failure

**5.73.2.9 I2C\_SR1\_AF\_Pos**

```
#define I2C_SR1_AF_Pos (10U)
```

Position of Acknowledge Failure bit

**5.73.2.10 I2C\_SR1\_ARLO**

```
#define I2C_SR1_ARLO I2C_SR1_ARLO_Msk
```

Arbitration Lost (Master mode)

**5.73.2.11 I2C\_SR1\_ARLO\_Msk**

```
#define I2C_SR1_ARLO_Msk (0x1UL << I2C_SR1_ARLO_Pos)
```

Bit mask for Arbitration Lost (Master mode)

**5.73.2.12 I2C\_SR1\_ARLO\_Pos**

```
#define I2C_SR1_ARLO_Pos (9U)
```

Position of Arbitration Lost (Master mode)

**5.73.2.13 I2C\_SR1\_BERR**

```
#define I2C_SR1_BERR I2C_SR1_BERR_Msk
```

Bus Error

**5.73.2.14 I2C\_SR1\_BERR\_Msk**

```
#define I2C_SR1_BERR_Msk (0x1UL << I2C_SR1_BERR_Pos)
```

Bit mask for Bus Error

**5.73.2.15 I2C\_SR1\_BERR\_Pos**

```
#define I2C_SR1_BERR_Pos (8U)
```

Position of Bus Error bit

**5.73.2.16 I2C\_SR1\_BTF**

```
#define I2C_SR1_BTF I2C_SR1_BTF_Msk
```

Byte Transfer Finished

### 5.73.2.17 I2C\_SR1\_BTF\_Msk

```
#define I2C_SR1_BTF_Msk (0x1UL << I2C_SR1_BTF_Pos)
```

Bit mask for Byte Transfer Finished

### 5.73.2.18 I2C\_SR1\_BTF\_Pos

```
#define I2C_SR1_BTF_Pos (2U)
```

Position of Byte Transfer Finished bit

### 5.73.2.19 I2C\_SR1\_OVR

```
#define I2C_SR1_OVR I2C_SR1_OVR_Msk
```

Overrun/Underrun

### 5.73.2.20 I2C\_SR1\_OVR\_Msk

```
#define I2C_SR1_OVR_Msk (0x1UL << I2C_SR1_OVR_Pos)
```

Bit mask for Overrun/Underrun

### 5.73.2.21 I2C\_SR1\_OVR\_Pos

```
#define I2C_SR1_OVR_Pos (11U)
```

Position of Overrun/Underrun bit

### 5.73.2.22 I2C\_SR1\_PECERR

```
#define I2C_SR1_PECERR I2C_SR1_PECERR_Msk
```

PEC Error in Reception

### 5.73.2.23 I2C\_SR1\_PECERR\_Msk

```
#define I2C_SR1_PECERR_Msk (0x1UL << I2C_SR1_PECERR_Pos)
```

Bit mask for PEC Error in Reception

### 5.73.2.24 I2C\_SR1\_PECERR\_Pos

```
#define I2C_SR1_PECERR_Pos (12U)
```

Position of PEC Error in Reception bit

### 5.73.2.25 I2C\_SR1\_RXNE

```
#define I2C_SR1_RXNE I2C_SR1_RXNE_Msk
```

Data Register Not Empty (Receiver)

### 5.73.2.26 I2C\_SR1\_RXNE\_Msk

```
#define I2C_SR1_RXNE_Msk (0x1UL << I2C_SR1_RXNE_Pos)
```

Bit mask for Data Register Not Empty (Receiver)

### 5.73.2.27 I2C\_SR1\_RXNE\_Pos

```
#define I2C_SR1_RXNE_Pos (6U)
```

Position of Data Register Not Empty (Receiver)

### 5.73.2.28 I2C\_SR1\_SB

```
#define I2C_SR1_SB I2C_SR1_SB_Msk
```

Start Bit (Master mode)

### 5.73.2.29 I2C\_SR1\_SB\_Msk

```
#define I2C_SR1_SB_Msk (0x1UL << I2C_SR1_SB_Pos)
```

Bit mask for Start Bit (Master mode)

### 5.73.2.30 I2C\_SR1\_SB\_Pos

```
#define I2C_SR1_SB_Pos (0U)
```

Bit definitions for the I2C\_SR1 register.

Position of Start Bit (Master mode)

### 5.73.2.31 I2C\_SR1\_SMBALERT

```
#define I2C_SR1_SMBALERT I2C_SR1_SMBALERT_Msk
```

SMBus Alert

### 5.73.2.32 I2C\_SR1\_SMBALERT\_Msk

```
#define I2C_SR1_SMBALERT_Msk (0x1UL << I2C_SR1_SMBALERT_Pos)
```

Bit mask for SMBus Alert

### 5.73.2.33 I2C\_SR1\_SMBALERT\_Pos

```
#define I2C_SR1_SMBALERT_Pos (15U)
```

Position of SMBus Alert bit

### 5.73.2.34 I2C\_SR1\_STOPF

```
#define I2C_SR1_STOPF I2C_SR1_STOPF_Msk
```

Stop Detection (Slave mode)

### 5.73.2.35 I2C\_SR1\_STOPF\_Msk

```
#define I2C_SR1_STOPF_Msk (0x1UL << I2C_SR1_STOPF_Pos)
```

Bit mask for Stop Detection (Slave mode)

### 5.73.2.36 I2C\_SR1\_STOPF\_Pos

```
#define I2C_SR1_STOPF_Pos (4U)
```

Position of Stop Detection (Slave mode)

### 5.73.2.37 I2C\_SR1\_TIMEOUT

```
#define I2C_SR1_TIMEOUT I2C_SR1_TIMEOUT_Msk
```

Timeout or Tlow Error

### 5.73.2.38 I2C\_SR1\_TIMEOUT\_Msk

```
#define I2C_SR1_TIMEOUT_Msk (0x1UL << I2C_SR1_TIMEOUT_Pos)
```

Bit mask for Timeout or Tlow Error

### 5.73.2.39 I2C\_SR1\_TIMEOUT\_Pos

```
#define I2C_SR1_TIMEOUT_Pos (14U)
```

Position of Timeout or Tlow Error bit

### 5.73.2.40 I2C\_SR1\_TXE

```
#define I2C_SR1_TXE I2C_SR1_TXE_Msk
```

Data Register Empty (Transmitter)

### 5.73.2.41 I2C\_SR1\_TXE\_Msk

```
#define I2C_SR1_TXE_Msk (0x1UL << I2C_SR1_TXE_Pos)
```

Bit mask for Data Register Empty (Transmitter)

### 5.73.2.42 I2C\_SR1\_TXE\_Pos

```
#define I2C_SR1_TXE_Pos (7U)
```

Position of Data Register Empty (Transmitter)

## 5.74 I2C SR2 Register Bit Definitions

Collaboration diagram for I2C SR2 Register Bit Definitions:



## Macros

- #define I2C\_SR2\_MSL\_Pos (0U)
 

*Bit definitions for the I2C\_SR2 register.*
- #define I2C\_SR2\_MSL\_Msk (0x1UL << I2C\_SR2\_MSL\_Pos)
- #define I2C\_SR2\_MSL I2C\_SR2\_MSL\_Msk
- #define I2C\_SR2\_BUSY\_Pos (1U)
- #define I2C\_SR2\_BUSY\_Msk (0x1UL << I2C\_SR2\_BUSY\_Pos)
- #define I2C\_SR2\_BUSY I2C\_SR2\_BUSY\_Msk
- #define I2C\_SR2\_TRA\_Pos (2U)
- #define I2C\_SR2\_TRA\_Msk (0x1UL << I2C\_SR2\_TRA\_Pos)
- #define I2C\_SR2\_TRA I2C\_SR2\_TRA\_Msk
- #define I2C\_SR2\_GENCALL\_Pos (4U)
- #define I2C\_SR2\_GENCALL\_Msk (0x1UL << I2C\_SR2\_GENCALL\_Pos)
- #define I2C\_SR2\_GENCALL I2C\_SR2\_GENCALL\_Msk
- #define I2C\_SR2\_SMBDEFAULT\_Pos (5U)

- #define I2C\_SR2\_SMBDEFAULT\_Msk (0x1UL << I2C\_SR2\_SMBDEFAULT\_Pos)
- #define I2C\_SR2\_SMBDEFAULT I2C\_SR2\_SMBDEFAULT\_Msk
- #define I2C\_SR2\_SMBHOST\_Pos (6U)
- #define I2C\_SR2\_SMBHOST\_Msk (0x1UL << I2C\_SR2\_SMBHOST\_Pos)
- #define I2C\_SR2\_SMBHOST I2C\_SR2\_SMBHOST\_Msk
- #define I2C\_SR2\_DUALF\_Pos (7U)
- #define I2C\_SR2\_DUALF\_Msk (0x1UL << I2C\_SR2\_DUALF\_Pos)
- #define I2C\_SR2\_DUALF I2C\_SR2\_DUALF\_Msk
- #define I2C\_SR2\_PEC\_Pos (8U)
- #define I2C\_SR2\_PEC\_Msk (0xFFUL << I2C\_SR2\_PEC\_Pos)
- #define I2C\_SR2\_PEC I2C\_SR2\_PEC\_Msk

### 5.74.1 Detailed Description

### 5.74.2 Macro Definition Documentation

#### 5.74.2.1 I2C\_SR2\_BUSY

```
#define I2C_SR2_BUSY I2C_SR2_BUSY_Msk
```

Bus Busy

#### 5.74.2.2 I2C\_SR2\_BUSY\_Msk

```
#define I2C_SR2_BUSY_Msk (0x1UL << I2C_SR2_BUSY_Pos)
```

Bit mask for Bus Busy

#### 5.74.2.3 I2C\_SR2\_BUSY\_Pos

```
#define I2C_SR2_BUSY_Pos (1U)
```

Position of Bus Busy bit

#### 5.74.2.4 I2C\_SR2\_DUALF

```
#define I2C_SR2_DUALF I2C_SR2_DUALF_Msk
```

Dual Flag (Slave mode)

#### 5.74.2.5 I2C\_SR2\_DUALF\_Msk

```
#define I2C_SR2_DUALF_Msk (0x1UL << I2C_SR2_DUALF_Pos)
```

Bit mask for Dual Flag (Slave mode)

### 5.74.2.6 I2C\_SR2\_DUALF\_Pos

```
#define I2C_SR2_DUALF_Pos (7U)
```

Position of Dual Flag (Slave mode) bit

### 5.74.2.7 I2C\_SR2\_GENCALL

```
#define I2C_SR2_GENCALL I2C_SR2_GENCALL_Msk
```

General Call Address (Slave mode)

### 5.74.2.8 I2C\_SR2\_GENCALL\_Msk

```
#define I2C_SR2_GENCALL_Msk (0x1UL << I2C_SR2_GENCALL_Pos)
```

Bit mask for General Call Address (Slave mode)

### 5.74.2.9 I2C\_SR2\_GENCALL\_Pos

```
#define I2C_SR2_GENCALL_Pos (4U)
```

Position of General Call Address (Slave mode) bit

### 5.74.2.10 I2C\_SR2\_MSL

```
#define I2C_SR2_MSL I2C_SR2_MSL_Msk
```

Master/Slave

### 5.74.2.11 I2C\_SR2\_MSL\_Msk

```
#define I2C_SR2_MSL_Msk (0x1UL << I2C_SR2_MSL_Pos)
```

Bit mask for Master/Slave

### 5.74.2.12 I2C\_SR2\_MSL\_Pos

```
#define I2C_SR2_MSL_Pos (0U)
```

Bit definitions for the I2C\_SR2 register.

Position of Master/Slave bit

### 5.74.2.13 I2C\_SR2\_PEC

```
#define I2C_SR2_PEC I2C_SR2_PEC_Msk
```

PEC Register (Slave mode)

### 5.74.2.14 I2C\_SR2\_PEC\_Msk

```
#define I2C_SR2_PEC_Msk (0xFFUL << I2C_SR2_PEC_Pos)
```

Bit mask for PEC Register (Slave mode)

### 5.74.2.15 I2C\_SR2\_PEC\_Pos

```
#define I2C_SR2_PEC_Pos (8U)
```

Position of PEC Register (Slave mode) bit

### 5.74.2.16 I2C\_SR2\_SMBDEFAULT

```
#define I2C_SR2_SMBDEFAULT I2C_SR2_SMBDEFAULT_Msk
```

SMBus Device Default Address (Slave mode)

### 5.74.2.17 I2C\_SR2\_SMBDEFAULT\_Msk

```
#define I2C_SR2_SMBDEFAULT_Msk (0x1UL << I2C_SR2_SMBDEFAULT_Pos)
```

Bit mask for SMBus Device Default Address (Slave mode)

### 5.74.2.18 I2C\_SR2\_SMBDEFAULT\_Pos

```
#define I2C_SR2_SMBDEFAULT_Pos (5U)
```

Position of SMBus Device Default Address (Slave mode) bit

### 5.74.2.19 I2C\_SR2\_SMBHOST

```
#define I2C_SR2_SMBHOST I2C_SR2_SMBHOST_Msk
```

SMBus Host Header (Slave mode)

### 5.74.2.20 I2C\_SR2\_SMBHOST\_Msk

```
#define I2C_SR2_SMBHOST_Msk (0x1UL << I2C_SR2_SMBHOST_Pos)
```

Bit mask for SMBus Host Header (Slave mode)

#### 5.74.2.21 I2C\_SR2\_SMBHOST\_Pos

```
#define I2C_SR2_SMBHOST_Pos (6U)
```

Position of SMBus Host Header (Slave mode) bit

#### 5.74.2.22 I2C\_SR2\_TRA

```
#define I2C_SR2_TRA I2C_SR2_TRA_Msk
```

Transmitter/Receiver

#### 5.74.2.23 I2C\_SR2\_TRA\_Msk

```
#define I2C_SR2_TRA_Msk (0x1UL << I2C_SR2_TRA_Pos)
```

Bit mask for Transmitter/Receiver

#### 5.74.2.24 I2C\_SR2\_TRA\_Pos

```
#define I2C_SR2_TRA_Pos (2U)
```

Position of Transmitter/Receiver bit

## 5.75 I2C CCR Register Bit Definitions

Collaboration diagram for I2C CCR Register Bit Definitions:



## Macros

- #define I2C\_CCR\_CCR\_Pos (0U)  
*Bit definitions for the I2C\_CCR register.*
- #define I2C\_CCR\_CCR\_Msk (0xFFFFUL << I2C\_CCR\_CCR\_Pos)
- #define I2C\_CCR\_CCR I2C\_CCR\_CCR\_Msk
- #define I2C\_CCR\_DUTY\_Pos (14U)
- #define I2C\_CCR\_DUTY\_Msk (0x1UL << I2C\_CCR\_DUTY\_Pos)
- #define I2C\_CCR\_DUTY I2C\_CCR\_DUTY\_Msk

### 5.75.1 Detailed Description

### 5.75.2 Macro Definition Documentation

#### 5.75.2.1 I2C\_CCR\_CCR

```
#define I2C_CCR_CCR I2C_CCR_CCR_Msk
```

Clock Control Register

#### 5.75.2.2 I2C\_CCR\_CCR\_Msk

```
#define I2C_CCR_CCR_Msk (0xFFFFUL << I2C_CCR_CCR_Pos)
```

Bit mask for Clock Control Register

#### 5.75.2.3 I2C\_CCR\_CCR\_Pos

```
#define I2C_CCR_CCR_Pos (0U)
```

Bit definitions for the I2C\_CCR register.

Position of Clock Control Register

#### 5.75.2.4 I2C\_CCR\_DUTY

```
#define I2C_CCR_DUTY I2C_CCR_DUTY_Msk
```

Duty Cycle bit

#### 5.75.2.5 I2C\_CCR\_DUTY\_Msk

```
#define I2C_CCR_DUTY_Msk (0x1UL << I2C_CCR_DUTY_Pos)
```

Bit mask for Duty Cycle bit

#### 5.75.2.6 I2C\_CCR\_DUTY\_Pos

```
#define I2C_CCR_DUTY_Pos (14U)
```

Position of Duty Cycle bit

## 5.76 I2C TRISE Register Bit Definitions

Collaboration diagram for I2C TRISE Register Bit Definitions:



### Macros

- `#define I2C_TRISE_TRISE_Pos (0U)`  
*Bit definitions for the I2C\_TRISE register.*
- `#define I2C_TRISE_TRISE_Msk (0x3FUL << I2C_TRISE_TRISE_Pos)`
- `#define I2C_TRISE_TRISE I2C_TRISE_TRISE_Msk`

#### 5.76.1 Detailed Description

#### 5.76.2 Macro Definition Documentation

##### 5.76.2.1 I2C\_TRISE\_TRISE

```
#define I2C_TRISE_TRISE I2C_TRISE_TRISE_Msk
```

TRISE bits

##### 5.76.2.2 I2C\_TRISE\_TRISE\_Msk

```
#define I2C_TRISE_TRISE_Msk (0x3FUL << I2C_TRISE_TRISE_Pos)
```

Bit mask for TRISE bits

##### 5.76.2.3 I2C\_TRISE\_TRISE\_Pos

```
#define I2C_TRISE_TRISE_Pos (0U)
```

Bit definitions for the I2C\_TRISE register.

Position of TRISE bits

## 5.77 RCC Bit Position Definitions

Bit position definitions for various registers in the RCC peripheral.

Collaboration diagram for RCC Bit Position Definitions:



## Modules

- [RCC\\_CR Bit Position Definitions](#)  
*Bit position definitions for RCC\_CR register.*
- [RCC\\_PLLCFGGR Bit Position Definitions](#)

- [RCC\\_CFGR Bit Position Definitions](#)  
*Bit position definitions for RCC\_PLLCFGR register.*
- [RCC\\_CIR Bit Position Definitions](#)  
*Bit position definitions for RCC\_CIR register.*
- [RCC\\_AHB1RSTR Bit Position Definitions](#)  
*Bit position definitions for RCC\_AHB1RSTR register.*
- [RCC\\_AHB2RSTR Bit Position Definitions](#)  
*Bit position definitions for RCC\_AHB2RSTR register.*
- [RCC\\_AHB3RSTR Bit Position Definitions](#)  
*Bit position definitions for RCC\_AHB3RSTR register.*
- [RCC\\_APB1RSTR Bit Position Definitions](#)  
*Bit position definitions for RCC\_APB1RSTR register.*
- [RCC\\_APB2RSTR Bit Position Definitions](#)  
*Bit position definitions for RCC\_APB2RSTR register.*
- [RCC\\_AHB1LPENR Bit Position Definitions](#)  
*Bit position definitions for RCC\_AHB1LPENR register.*
- [RCC\\_AHB2LPENR Bit Position Definitions](#)  
*Bit position definitions for RCC\_AHB2LPENR register.*
- [RCC\\_AHB3LPENR Bit Position Definitions](#)  
*Bit position definitions for RCC\_AHB3LPENR register.*
- [RCC\\_APB1LPENR Bit Position Definitions](#)  
*Bit position definitions for RCC\_APB1LPENR register.*
- [RCC\\_APB2LPENR Bit Position Definitions](#)  
*Bit position definitions for RCC\_APB2LPENR register.*
- [RCC\\_BDCR Bit Position Definitions](#)  
*Bit position definitions for RCC\_BDCR register.*
- [RCC\\_CSR Bit Position Definitions](#)  
*Bit position definitions for RCC\_CSR register.*
- [RCC\\_SSCGR Bit Position Definitions](#)  
*Bit position definitions for RCC\_SSCGR register.*
- [RCC\\_PLLI2SCFGR Bit Position Definitions](#)  
*Bit position definitions for RCC\_PLLI2SCFGR register.*

### 5.77.1 Detailed Description

Bit position definitions for various registers in the RCC peripheral.

## 5.78 RCC\_CR Bit Position Definitions

Bit position definitions for RCC\_CR register.

Collaboration diagram for RCC\_CR Bit Position Definitions:



## Macros

- #define RCC\_CR\_HSION 0
- #define RCC\_CR\_HSIRDY 1
- #define RCC\_CR\_HSITRIM 3
- #define RCC\_CR\_HSICAL 8
- #define RCC\_CR\_HSEON 16
- #define RCC\_CR\_HSERDY 17
- #define RCC\_CR\_HSEBYP 18
- #define RCC\_CR\_CSSON 19
- #define RCC\_CR\_PLLON 24
- #define RCC\_CR\_PLLRDY 25
- #define RCC\_CR\_PLLI2SON 26
- #define RCC\_CR\_PLLI2SRDY 27
- #define RCC\_CR\_PLLSAION 28
- #define RCC\_CR\_PLLSAIRDY 29

### 5.78.1 Detailed Description

Bit position definitions for RCC\_CR register.

### 5.78.2 Macro Definition Documentation

#### 5.78.2.1 RCC\_CR\_CSSON

```
#define RCC_CR_CSSON 19
```

Clock Security System Enable

#### 5.78.2.2 RCC\_CR\_HSEBYP

```
#define RCC_CR_HSEBYP 18
```

HSE Oscillator Bypass

#### 5.78.2.3 RCC\_CR\_HSEON

```
#define RCC_CR_HSEON 16
```

HSE Oscillator Enable

#### 5.78.2.4 RCC\_CR\_HSERDY

```
#define RCC_CR_HSERDY 17
```

HSE Oscillator Ready

### 5.78.2.5 RCC\_CR\_HSICAL

```
#define RCC_CR_HSICAL 8
```

HSI Oscillator Calibration

### 5.78.2.6 RCC\_CR\_HSION

```
#define RCC_CR_HSION 0
```

HSI Oscillator Enable

### 5.78.2.7 RCC\_CR\_HSIRDY

```
#define RCC_CR_HSIRDY 1
```

HSI Oscillator Ready

### 5.78.2.8 RCC\_CR\_HSITRIM

```
#define RCC_CR_HSITRIM 3
```

HSI Oscillator Trimming

### 5.78.2.9 RCC\_CR\_PLLI2SON

```
#define RCC_CR_PLLI2SON 26
```

PLL2S Enable

### 5.78.2.10 RCC\_CR\_PLLI2SRDY

```
#define RCC_CR_PLLI2SRDY 27
```

PLL2S Ready

### 5.78.2.11 RCC\_CR\_PLLON

```
#define RCC_CR_PLLON 24
```

Main PLL Enable

### 5.78.2.12 RCC\_CR\_PLLRDY

```
#define RCC_CR_PLLRDY 25
```

Main PLL Ready

### 5.78.2.13 RCC\_CR\_PLLSAION

```
#define RCC_CR_PLLSAION 28
```

PLLSAI Enable

### 5.78.2.14 RCC\_CR\_PLLSAIRDY

```
#define RCC_CR_PLLSAIRDY 29
```

PLLSAI Ready

## 5.79 RCC\_PLLCFGR Bit Position Definitions

Bit position definitions for RCC\_PLLCFGR register.

Collaboration diagram for RCC\_PLLCFGR Bit Position Definitions:



### Macros

- #define RCC\_PLLCFGR\_PLLM 0
- #define RCC\_PLLCFGR\_PLLN 6
- #define RCC\_PLLCFGR\_PLLP 16
- #define RCC\_PLLCFGR\_PLLSRC 22
- #define RCC\_PLLCFGR\_PLLQ 24

### 5.79.1 Detailed Description

Bit position definitions for RCC\_PLLCFGR register.

### 5.79.2 Macro Definition Documentation

### 5.79.2.1 RCC\_PLLCFGR\_PLLM

```
#define RCC_PLLCFGR_PLLM 0
```

Main PLL Division Factor for PLL VCO

### 5.79.2.2 RCC\_PLLCFGR\_PLLN

```
#define RCC_PLLCFGR_PLLN 6
```

Main PLL Multiplication Factor for VCO

### 5.79.2.3 RCC\_PLLCFGR\_PLLP

```
#define RCC_PLLCFGR_PLLP 16
```

Main PLL Division Factor for Main System Clock

### 5.79.2.4 RCC\_PLLCFGR\_PLLQ

```
#define RCC_PLLCFGR_PLLQ 24
```

Main PLLQ Division Factor for PLLI2S Clock Output

### 5.79.2.5 RCC\_PLLCFGR\_PLLSRC

```
#define RCC_PLLCFGR_PLLSRC 22
```

Main PLL, PLLI2S, and PLLSAI Entry Clock Source

## 5.80 RCC\_CFGR Bit Position Definitions

Bit position definitions for RCC\_CFGR register.

Collaboration diagram for RCC\_CFGR Bit Position Definitions:



## Macros

- #define RCC\_CFGR\_SW 0
- #define RCC\_CFGR\_SWS 2
- #define RCC\_CFGR\_HPRE 4
- #define RCC\_CFGR\_PPREG 10
- #define RCC\_CFGR\_PPREG2 13
- #define RCC\_CFGR\_RTCPPREG 16
- #define RCC\_CFGR\_MCO1 21
- #define RCC\_CFGR\_I2SSRC 23
- #define RCC\_CFGR\_MCO1PPREG 24
- #define RCC\_CFGR\_MCO2PPREG 27
- #define RCC\_CFGR\_MCO2 30

### 5.80.1 Detailed Description

Bit position definitions for RCC\_CFGR register.

### 5.80.2 Macro Definition Documentation

#### 5.80.2.1 RCC\_CFGR\_HPRE

```
#define RCC_CFGR_HPRE 4
```

AHB Prescaler

#### 5.80.2.2 RCC\_CFGR\_I2SSRC

```
#define RCC_CFGR_I2SSRC 23
```

I2S APB2 Clock Source Selection

#### 5.80.2.3 RCC\_CFGR\_MCO1

```
#define RCC_CFGR_MCO1 21
```

Microcontroller Clock Output 1

#### 5.80.2.4 RCC\_CFGR\_MCO1PPREG

```
#define RCC_CFGR_MCO1PPREG 24
```

MCO1 Prescaler

### 5.80.2.5 RCC\_CFGR\_MCO2

```
#define RCC_CFGR_MCO2 30
```

Microcontroller Clock Output 2

### 5.80.2.6 RCC\_CFGR\_MCO2PRE

```
#define RCC_CFGR_MCO2PRE 27
```

MCO2 Prescaler

### 5.80.2.7 RCC\_CFGR\_PPREG1

```
#define RCC_CFGR_PPREG1 10
```

APB1 Low-Speed Prescaler (APB1CLK)

### 5.80.2.8 RCC\_CFGR\_PPREG2

```
#define RCC_CFGR_PPREG2 13
```

APB2 High-Speed Prescaler (APB2CLK)

### 5.80.2.9 RCC\_CFGR\_RTCPRE

```
#define RCC_CFGR_RTCPRE 16
```

HSE division factor for RTC clock

### 5.80.2.10 RCC\_CFGR\_SW

```
#define RCC_CFGR_SW 0
```

System Clock Switch

### 5.80.2.11 RCC\_CFGR\_SWS

```
#define RCC_CFGR_SWS 2
```

System Clock Switch Status

## 5.81 RCC\_CIR Bit Position Definitions

Bit position definitions for RCC\_CIR register.

Collaboration diagram for RCC\_CIR Bit Position Definitions:



### Macros

- #define RCC\_CIR\_LSIRDYF 0
- #define RCC\_CIR\_LSERDYF 1
- #define RCC\_CIR\_HSIRDYF 2
- #define RCC\_CIR\_HSERDYF 3
- #define RCC\_CIR\_PLLRDYF 4
- #define RCC\_CIR\_PLLI2SRDYF 5
- #define RCC\_CIR\_PLLSAIRDYF 6
- #define RCC\_CIR\_CSSF 7
- #define RCC\_CIR\_LSIRDYIE 8
- #define RCC\_CIR\_LSERDYIE 9
- #define RCC\_CIR\_HSIRDYIE 10
- #define RCC\_CIR\_HSERDYIE 11
- #define RCC\_CIR\_PLLRDYIE 12
- #define RCC\_CIR\_PLLI2SRDYIE 13
- #define RCC\_CIR\_PLLSAIRDYIE 14
- #define RCC\_CIR\_LSIRDYC 16
- #define RCC\_CIR\_LSERDYC 17
- #define RCC\_CIR\_HSIRDYC 18
- #define RCC\_CIR\_HSERDYC 19
- #define RCC\_CIR\_PLLRDYC 20
- #define RCC\_CIR\_PLLI2SRDYC 21
- #define RCC\_CIR\_PLLSAIRDYC 22

### 5.81.1 Detailed Description

Bit position definitions for RCC\_CIR register.

### 5.81.2 Macro Definition Documentation

### 5.81.2.1 RCC\_CIR\_CSSF

```
#define RCC_CIR_CSSF 7
```

Clock Security System Interrupt flag

### 5.81.2.2 RCC\_CIR\_HSERDYC

```
#define RCC_CIR_HSERDYC 19
```

HSE Ready Interrupt Clear

### 5.81.2.3 RCC\_CIR\_HSERDYF

```
#define RCC_CIR_HSERDYF 3
```

HSE Ready Interrupt flag

### 5.81.2.4 RCC\_CIR\_HSERDYIE

```
#define RCC_CIR_HSERDYIE 11
```

HSE Ready Interrupt Enable

### 5.81.2.5 RCC\_CIR\_HSIRDYC

```
#define RCC_CIR_HSIRDYC 18
```

HSI Ready Interrupt Clear

### 5.81.2.6 RCC\_CIR\_HSIRDYF

```
#define RCC_CIR_HSIRDYF 2
```

HSI Ready Interrupt flag

### 5.81.2.7 RCC\_CIR\_HSIRDYIE

```
#define RCC_CIR_HSIRDYIE 10
```

HSI Ready Interrupt Enable

### 5.81.2.8 RCC\_CIR\_LSERDYC

```
#define RCC_CIR_LSERDYC 17
```

LSE Ready Interrupt Clear

### 5.81.2.9 RCC\_CIR\_LSERDYF

```
#define RCC_CIR_LSERDYF 1
```

LSE Ready Interrupt flag

### 5.81.2.10 RCC\_CIR\_LSERDYIE

```
#define RCC_CIR_LSERDYIE 9
```

LSE Ready Interrupt Enable

### 5.81.2.11 RCC\_CIR\_LSIRDYC

```
#define RCC_CIR_LSIRDYC 16
```

LSI Ready Interrupt Clear

### 5.81.2.12 RCC\_CIR\_LSIRDYF

```
#define RCC_CIR_LSIRDYF 0
```

LSI Ready Interrupt flag

### 5.81.2.13 RCC\_CIR\_LSIRDYIE

```
#define RCC_CIR_LSIRDYIE 8
```

LSI Ready Interrupt Enable

### 5.81.2.14 RCC\_CIR\_PLLI2SRDYC

```
#define RCC_CIR_PLLI2SRDYC 21
```

PLL2S Ready Interrupt Clear

### 5.81.2.15 RCC\_CIR\_PLLI2SRDYF

```
#define RCC_CIR_PLLI2SRDYF 5
```

PLL2S Ready Interrupt flag

### 5.81.2.16 RCC\_CIR\_PLLI2SRDYIE

```
#define RCC_CIR_PLLI2SRDYIE 13
```

PLL2S Ready Interrupt Enable

### 5.81.2.17 RCC\_CIR\_PLLRDYC

```
#define RCC_CIR_PLLRDYC 20
```

PLL Ready Interrupt Clear

### 5.81.2.18 RCC\_CIR\_PLLRDYF

```
#define RCC_CIR_PLLRDYF 4
```

PLL Ready Interrupt flag

### 5.81.2.19 RCC\_CIR\_PLLRDYIE

```
#define RCC_CIR_PLLRDYIE 12
```

PLL Ready Interrupt Enable

### 5.81.2.20 RCC\_CIR\_PLLSAIRDYC

```
#define RCC_CIR_PLLSAIRDYC 22
```

PLLSAI Ready Interrupt Clear

### 5.81.2.21 RCC\_CIR\_PLLSAIRDYF

```
#define RCC_CIR_PLLSAIRDYF 6
```

PLLSAI Ready Interrupt flag

### 5.81.2.22 RCC\_CIR\_PLLSAIRDYIE

```
#define RCC_CIR_PLLSAIRDYIE 14
```

PLLSAI Ready Interrupt Enable

## 5.82 RCC\_AHB1RSTR Bit Position Definitions

Bit position definitions for RCC\_AHB1RSTR register.

Collaboration diagram for RCC\_AHB1RSTR Bit Position Definitions:



## Macros

- #define RCC\_AHB1RSTR\_GPIOA 0
- #define RCC\_AHB1RSTR\_GPIOB 1
- #define RCC\_AHB1RSTR\_GPIOC 2
- #define RCC\_AHB1RSTR\_GPIOD 3
- #define RCC\_AHB1RSTR\_GPIOE 4
- #define RCC\_AHB1RSTR\_GPIOF 5
- #define RCC\_AHB1RSTR\_GPIOG 6
- #define RCC\_AHB1RSTR\_GPIOH 7
- #define RCC\_AHB1RSTR\_GPIOI 8
- #define RCC\_AHB1RSTR\_CRC 12
- #define RCC\_AHB1RSTR\_DMA1 21
- #define RCC\_AHB1RSTR\_DMA2 22
- #define RCC\_AHB1RSTR\_ETHMAC 25
- #define RCC\_AHB1RSTR\_OTGHS 29
- #define RCC\_AHB1RSTR\_OTGHSULPI 30

### 5.82.1 Detailed Description

Bit position definitions for RCC\_AHB1RSTR register.

### 5.82.2 Macro Definition Documentation

#### 5.82.2.1 RCC\_AHB1RSTR\_CRC

```
#define RCC_AHB1RSTR_CRC 12
```

CRC Reset

#### 5.82.2.2 RCC\_AHB1RSTR\_DMA1

```
#define RCC_AHB1RSTR_DMA1 21
```

DMA1 Reset

#### 5.82.2.3 RCC\_AHB1RSTR\_DMA2

```
#define RCC_AHB1RSTR_DMA2 22
```

DMA2 Reset

### 5.82.2.4 RCC\_AHB1RSTR\_ETHMAC

```
#define RCC_AHB1RSTR_ETHMAC 25
```

Ethernet MAC Reset

### 5.82.2.5 RCC\_AHB1RSTR\_GPIOA

```
#define RCC_AHB1RSTR_GPIOA 0
```

GPIOA Reset

### 5.82.2.6 RCC\_AHB1RSTR\_GPIOB

```
#define RCC_AHB1RSTR_GPIOB 1
```

GPIOB Reset

### 5.82.2.7 RCC\_AHB1RSTR\_GPIOC

```
#define RCC_AHB1RSTR_GPIOC 2
```

GPIOC Reset

### 5.82.2.8 RCC\_AHB1RSTR\_GPIOD

```
#define RCC_AHB1RSTR_GPIOD 3
```

GPIOD Reset

### 5.82.2.9 RCC\_AHB1RSTR\_GPIOE

```
#define RCC_AHB1RSTR_GPIOE 4
```

GPIOE Reset

### 5.82.2.10 RCC\_AHB1RSTR\_GPIOF

```
#define RCC_AHB1RSTR_GPIOF 5
```

GPIOF Reset

### 5.82.2.11 RCC\_AHB1RSTR\_GPIOG

```
#define RCC_AHB1RSTR_GPIOG 6
```

GPIOG Reset

### 5.82.2.12 RCC\_AHB1RSTR\_GPIOH

```
#define RCC_AHB1RSTR_GPIOH 7
```

GPIOH Reset

### 5.82.2.13 RCC\_AHB1RSTR\_GPIOI

```
#define RCC_AHB1RSTR_GPIOI 8
```

GPIOI Reset

### 5.82.2.14 RCC\_AHB1RSTR\_OTGHS

```
#define RCC_AHB1RSTR_OTGHS 29
```

USB OTG HS Reset

### 5.82.2.15 RCC\_AHB1RSTR\_OTGHSULPI

```
#define RCC_AHB1RSTR_OTGHSULPI 30
```

USB OTG HS ULPI Reset

## 5.83 RCC\_AHB2RSTR Bit Position Definitions

Bit position definitions for RCC\_AHB2RSTR register.

Collaboration diagram for RCC\_AHB2RSTR Bit Position Definitions:



## Macros

- #define RCC\_AHB2RSTR\_DCMI 0
- #define RCC\_AHB2RSTR\_CRYP 4
- #define RCC\_AHB2RSTR\_HASH 5
- #define RCC\_AHB2RSTR\_RNG 6
- #define RCC\_AHB2RSTR\_OTGFS 7

### 5.83.1 Detailed Description

Bit position definitions for RCC\_AHB2RSTR register.

### 5.83.2 Macro Definition Documentation

#### 5.83.2.1 RCC\_AHB2RSTR\_CRYP

```
#define RCC_AHB2RSTR_CRYP 4
```

CRYP Reset

#### 5.83.2.2 RCC\_AHB2RSTR\_DCMI

```
#define RCC_AHB2RSTR_DCMI 0
```

DCMI Reset

#### 5.83.2.3 RCC\_AHB2RSTR\_HASH

```
#define RCC_AHB2RSTR_HASH 5
```

HASH Reset

#### 5.83.2.4 RCC\_AHB2RSTR\_OTGFS

```
#define RCC_AHB2RSTR_OTGFS 7
```

USB OTG FS Reset

#### 5.83.2.5 RCC\_AHB2RSTR\_RNG

```
#define RCC_AHB2RSTR_RNG 6
```

RNG Reset

## 5.84 RCC\_AHB3RSTR Bit Position Definitions

Bit position definitions for RCC\_AHB3RSTR register.

Collaboration diagram for RCC\_AHB3RSTR Bit Position Definitions:



### Macros

- #define RCC\_AHB3RSTR\_FSMC 0

#### 5.84.1 Detailed Description

Bit position definitions for RCC\_AHB3RSTR register.

#### 5.84.2 Macro Definition Documentation

##### 5.84.2.1 RCC\_AHB3RSTR\_FSMC

```
#define RCC_AHB3RSTR_FSMC 0
```

FSMC Reset

## 5.85 RCC\_APB1RSTR Bit Position Definitions

Bit position definitions for RCC\_APB1RSTR register.

Collaboration diagram for RCC\_APB1RSTR Bit Position Definitions:



## Macros

- #define RCC\_APB1RSTR\_TIM2 0
- #define RCC\_APB1RSTR\_TIM3 1
- #define RCC\_APB1RSTR\_TIM4 2
- #define RCC\_APB1RSTR\_TIM5 3
- #define RCC\_APB1RSTR\_TIM6 4
- #define RCC\_APB1RSTR\_TIM7 5
- #define RCC\_APB1RSTR\_TIM12 6
- #define RCC\_APB1RSTR\_TIM13 7
- #define RCC\_APB1RSTR\_TIM14 8
- #define RCC\_APB1RSTR\_WWDG 11
- #define RCC\_APB1RSTR\_SPI2 14
- #define RCC\_APB1RSTR\_SPI3 15
- #define RCC\_APB1RSTR\_USART2 17
- #define RCC\_APB1RSTR\_USART3 18
- #define RCC\_APB1RSTR\_UART4 19
- #define RCC\_APB1RSTR\_UART5 20
- #define RCC\_APB1RSTR\_I2C1 21
- #define RCC\_APB1RSTR\_I2C2 22
- #define RCC\_APB1RSTR\_I2C3 23
- #define RCC\_APB1RSTR\_CAN1 25
- #define RCC\_APB1RSTR\_CAN2 26
- #define RCC\_APB1RSTR\_PWR 28
- #define RCC\_APB1RSTR\_DAC 29
- #define RCC\_APB1RSTR\_UART7 30
- #define RCC\_APB1RSTR\_UART8 31

### 5.85.1 Detailed Description

Bit position definitions for RCC\_APB1RSTR register.

### 5.85.2 Macro Definition Documentation

#### 5.85.2.1 RCC\_APB1RSTR\_CAN1

```
#define RCC_APB1RSTR_CAN1 25
```

CAN1 Reset

#### 5.85.2.2 RCC\_APB1RSTR\_CAN2

```
#define RCC_APB1RSTR_CAN2 26
```

CAN2 Reset

### 5.85.2.3 RCC\_APB1RSTR\_DAC

```
#define RCC_APB1RSTR_DAC 29
```

DAC Reset

### 5.85.2.4 RCC\_APB1RSTR\_I2C1

```
#define RCC_APB1RSTR_I2C1 21
```

I2C1 Reset

### 5.85.2.5 RCC\_APB1RSTR\_I2C2

```
#define RCC_APB1RSTR_I2C2 22
```

I2C2 Reset

### 5.85.2.6 RCC\_APB1RSTR\_I2C3

```
#define RCC_APB1RSTR_I2C3 23
```

I2C3 Reset

### 5.85.2.7 RCC\_APB1RSTR\_PWR

```
#define RCC_APB1RSTR_PWR 28
```

Power Interface Reset

### 5.85.2.8 RCC\_APB1RSTR\_SPI2

```
#define RCC_APB1RSTR_SPI2 14
```

SPI2 Reset

### 5.85.2.9 RCC\_APB1RSTR\_SPI3

```
#define RCC_APB1RSTR_SPI3 15
```

SPI3 Reset

### 5.85.2.10 RCC\_APB1RSTR\_TIM12

```
#define RCC_APB1RSTR_TIM12 6
```

TIM12 Reset

**5.85.2.11 RCC\_APB1RSTR\_TIM13**

```
#define RCC_APB1RSTR_TIM13 7
```

TIM13 Reset

**5.85.2.12 RCC\_APB1RSTR\_TIM14**

```
#define RCC_APB1RSTR_TIM14 8
```

TIM14 Reset

**5.85.2.13 RCC\_APB1RSTR\_TIM2**

```
#define RCC_APB1RSTR_TIM2 0
```

TIM2 Reset

**5.85.2.14 RCC\_APB1RSTR\_TIM3**

```
#define RCC_APB1RSTR_TIM3 1
```

TIM3 Reset

**5.85.2.15 RCC\_APB1RSTR\_TIM4**

```
#define RCC_APB1RSTR_TIM4 2
```

TIM4 Reset

**5.85.2.16 RCC\_APB1RSTR\_TIM5**

```
#define RCC_APB1RSTR_TIM5 3
```

TIM5 Reset

**5.85.2.17 RCC\_APB1RSTR\_TIM6**

```
#define RCC_APB1RSTR_TIM6 4
```

TIM6 Reset

**5.85.2.18 RCC\_APB1RSTR\_TIM7**

```
#define RCC_APB1RSTR_TIM7 5
```

TIM7 Reset

### 5.85.2.19 RCC\_APB1RSTR\_UART4

```
#define RCC_APB1RSTR_UART4 19
```

UART4 Reset

### 5.85.2.20 RCC\_APB1RSTR\_UART5

```
#define RCC_APB1RSTR_UART5 20
```

UART5 Reset

### 5.85.2.21 RCC\_APB1RSTR\_UART7

```
#define RCC_APB1RSTR_UART7 30
```

UART7 Reset

### 5.85.2.22 RCC\_APB1RSTR\_UART8

```
#define RCC_APB1RSTR_UART8 31
```

UART8 Reset

### 5.85.2.23 RCC\_APB1RSTR\_USART2

```
#define RCC_APB1RSTR_USART2 17
```

USART2 Reset

### 5.85.2.24 RCC\_APB1RSTR\_USART3

```
#define RCC_APB1RSTR_USART3 18
```

USART3 Reset

### 5.85.2.25 RCC\_APB1RSTR\_WWDG

```
#define RCC_APB1RSTR_WWDG 11
```

WWDG Reset

## 5.86 RCC\_APB2RSTR Bit Position Definitions

Bit position definitions for RCC\_APB2RSTR register.

Collaboration diagram for RCC\_APB2RSTR Bit Position Definitions:



### Macros

- #define RCC\_APB2RSTR\_TIM1 0
- #define RCC\_APB2RSTR\_TIM8 1
- #define RCC\_APB2RSTR\_USART1 4
- #define RCC\_APB2RSTR\_USART6 5
- #define RCC\_APB2RSTR\_ADC 8
- #define RCC\_APB2RSTR\_SDIO 11
- #define RCC\_APB2RSTR\_SPI1 12
- #define RCC\_APB2RSTR\_SYSCFG 14
- #define RCC\_APB2RSTR\_TIM9 16
- #define RCC\_APB2RSTR\_TIM10 17
- #define RCC\_APB2RSTR\_TIM11 18

### 5.86.1 Detailed Description

Bit position definitions for RCC\_APB2RSTR register.

### 5.86.2 Macro Definition Documentation

#### 5.86.2.1 RCC\_APB2RSTR\_ADC

```
#define RCC_APB2RSTR_ADC 8
```

ADC Reset

#### 5.86.2.2 RCC\_APB2RSTR\_SDIO

```
#define RCC_APB2RSTR_SDIO 11
```

SDIO Reset

### 5.86.2.3 RCC\_APB2RSTR\_SPI1

```
#define RCC_APB2RSTR_SPI1 12
```

SPI1 Reset

### 5.86.2.4 RCC\_APB2RSTR\_SYSCFG

```
#define RCC_APB2RSTR_SYSCFG 14
```

System Configuration Controller Reset

### 5.86.2.5 RCC\_APB2RSTR\_TIM1

```
#define RCC_APB2RSTR_TIM1 0
```

TIM1 Reset

### 5.86.2.6 RCC\_APB2RSTR\_TIM10

```
#define RCC_APB2RSTR_TIM10 17
```

TIM10 Reset

### 5.86.2.7 RCC\_APB2RSTR\_TIM11

```
#define RCC_APB2RSTR_TIM11 18
```

TIM11 Reset

### 5.86.2.8 RCC\_APB2RSTR\_TIM8

```
#define RCC_APB2RSTR_TIM8 1
```

TIM8 Reset

### 5.86.2.9 RCC\_APB2RSTR\_TIM9

```
#define RCC_APB2RSTR_TIM9 16
```

TIM9 Reset

### 5.86.2.10 RCC\_APB2RSTR\_USART1

```
#define RCC_APB2RSTR_USART1 4
```

USART1 Reset

### 5.86.2.11 RCC\_APB2RSTR\_USART6

```
#define RCC_APB2RSTR_USART6 5
```

USART6 Reset

## 5.87 RCC\_AHB1LPENR Bit Position Definitions

Bit position definitions for RCC\_AHB1LPENR register.

Collaboration diagram for RCC\_AHB1LPENR Bit Position Definitions:



### Macros

- #define RCC\_AHB1LPENR\_GPIOALPEN 0
- #define RCC\_AHB1LPENR\_GPIOBLPEN 1
- #define RCC\_AHB1LPENR\_GPIOCLPEN 2
- #define RCC\_AHB1LPENR\_GPIODLPEN 3
- #define RCC\_AHB1LPENR\_GPIOELPEN 4
- #define RCC\_AHB1LPENR\_GPIOFLPEN 5
- #define RCC\_AHB1LPENR\_GPIOGLPEN 6
- #define RCC\_AHB1LPENR\_GPIOHLPEN 7
- #define RCC\_AHB1LPENR\_GPIOILPEN 8
- #define RCC\_AHB1LPENR\_CRCEN 12
- #define RCC\_AHB1LPENR\_DMA1LPEN 21
- #define RCC\_AHB1LPENR\_DMA2LPEN 22
- #define RCC\_AHB1LPENR\_ETHMACLPEN 25
- #define RCC\_AHB1LPENR\_ETHMACTXLPEN 26
- #define RCC\_AHB1LPENR\_ETHMACRXLPEN 27
- #define RCC\_AHB1LPENR\_ETHMACPTPLPEN 28
- #define RCC\_AHB1LPENR\_OTGHSLPEN 29
- #define RCC\_AHB1LPENR\_OTGHSHULPI 30

### 5.87.1 Detailed Description

Bit position definitions for RCC\_AHB1LPENR register.

### 5.87.2 Macro Definition Documentation

### 5.87.2.1 RCC\_AHB1LPENR\_CRCEN

```
#define RCC_AHB1LPENR_CRCEN 12
```

CRC Peripheral Clock in Low Power Mode Enable

### 5.87.2.2 RCC\_AHB1LPENR\_DMA1LPEN

```
#define RCC_AHB1LPENR_DMA1LPEN 21
```

DMA1 Peripheral Clock in Low Power Mode Enable

### 5.87.2.3 RCC\_AHB1LPENR\_DMA2LPEN

```
#define RCC_AHB1LPENR_DMA2LPEN 22
```

DMA2 Peripheral Clock in Low Power Mode Enable

### 5.87.2.4 RCC\_AHB1LPENR\_ETHMACLPEN

```
#define RCC_AHB1LPENR_ETHMACLPEN 25
```

Ethernet MAC Peripheral Clock in Low Power Mode Enable

### 5.87.2.5 RCC\_AHB1LPENR\_ETHMACPTPLPEN

```
#define RCC_AHB1LPENR_ETHMACPTPLPEN 28
```

Ethernet MAC PTP Peripheral Clock in Low Power Mode Enable

### 5.87.2.6 RCC\_AHB1LPENR\_ETHMACRXLPEN

```
#define RCC_AHB1LPENR_ETHMACRXLPEN 27
```

Ethernet MAC Receive Peripheral Clock in Low Power Mode Enable

### 5.87.2.7 RCC\_AHB1LPENR\_ETHMACTXLPEN

```
#define RCC_AHB1LPENR_ETHMACTXLPEN 26
```

Ethernet MAC Transmit Peripheral Clock in Low Power Mode Enable

### 5.87.2.8 RCC\_AHB1LPENR\_GPIOALPEN

```
#define RCC_AHB1LPENR_GPIOALPEN 0
```

GPIOA Peripheral Clock in Low Power Mode Enable

**5.87.2.9 RCC\_AHB1LPENR\_GPIOBLPEN**

```
#define RCC_AHB1LPENR_GPIOBLPEN 1
```

GPIOB Peripheral Clock in Low Power Mode Enable

**5.87.2.10 RCC\_AHB1LPENR\_GPIOCLPEN**

```
#define RCC_AHB1LPENR_GPIOCLPEN 2
```

GPIOC Peripheral Clock in Low Power Mode Enable

**5.87.2.11 RCC\_AHB1LPENR\_GPIODLPEN**

```
#define RCC_AHB1LPENR_GPIODLPEN 3
```

GPIOD Peripheral Clock in Low Power Mode Enable

**5.87.2.12 RCC\_AHB1LPENR\_GPIOELPEN**

```
#define RCC_AHB1LPENR_GPIOELPEN 4
```

GPIOE Peripheral Clock in Low Power Mode Enable

**5.87.2.13 RCC\_AHB1LPENR\_GPIOFLPEN**

```
#define RCC_AHB1LPENR_GPIOFLPEN 5
```

GPIOF Peripheral Clock in Low Power Mode Enable

**5.87.2.14 RCC\_AHB1LPENR\_GPIOGLPEN**

```
#define RCC_AHB1LPENR_GPIOGLPEN 6
```

GPIOG Peripheral Clock in Low Power Mode Enable

**5.87.2.15 RCC\_AHB1LPENR\_GPIOHLPEN**

```
#define RCC_AHB1LPENR_GPIOHLPEN 7
```

GPIOH Peripheral Clock in Low Power Mode Enable

**5.87.2.16 RCC\_AHB1LPENR\_GPIOILPEN**

```
#define RCC_AHB1LPENR_GPIOILPEN 8
```

GPIOI Peripheral Clock in Low Power Mode Enable

### 5.87.2.17 RCC\_AHB1LPENR\_OTGHSHULPI

```
#define RCC_AHB1LPENR_OTGHSHULPI 30
```

USB OTG HS ULPI Peripheral Clock in Low Power Mode Enable

### 5.87.2.18 RCC\_AHB1LPENR\_OTGHSLPEN

```
#define RCC_AHB1LPENR_OTGHSLPEN 29
```

USB OTG HS Peripheral Clock in Low Power Mode Enable

## 5.88 RCC\_AHB2LPENR Bit Position Definitions

Bit position definitions for RCC\_AHB2LPENR register.

Collaboration diagram for RCC\_AHB2LPENR Bit Position Definitions:



### Macros

- #define RCC\_AHB2LPENR\_DCMILPEN 0
- #define RCC\_AHB2LPENR\_CRYPLPEN 4
- #define RCC\_AHB2LPENR\_HASHLPEN 5
- #define RCC\_AHB2LPENR\_RNGLPEN 6
- #define RCC\_AHB2LPENR\_OTGFSLPEN 7

### 5.88.1 Detailed Description

Bit position definitions for RCC\_AHB2LPENR register.

### 5.88.2 Macro Definition Documentation

#### 5.88.2.1 RCC\_AHB2LPENR\_CRYPLPEN

```
#define RCC_AHB2LPENR_CRYPLPEN 4
```

CRYP Peripheral Clock in Low Power Mode Enable

### 5.88.2.2 RCC\_AHB2LPENR\_DCMILPEN

```
#define RCC_AHB2LPENR_DCMILPEN 0
```

DCMI Peripheral Clock in Low Power Mode Enable

### 5.88.2.3 RCC\_AHB2LPENR\_HASHLPEN

```
#define RCC_AHB2LPENR_HASHLPEN 5
```

HASH Peripheral Clock in Low Power Mode Enable

### 5.88.2.4 RCC\_AHB2LPENR\_OTGFSLPEN

```
#define RCC_AHB2LPENR_OTGFSLPEN 7
```

USB OTG FS Peripheral Clock in Low Power Mode Enable

### 5.88.2.5 RCC\_AHB2LPENR\_RNGLPEN

```
#define RCC_AHB2LPENR_RNGLPEN 6
```

RNG Peripheral Clock in Low Power Mode Enable

## 5.89 RCC\_AHB3LPENR Bit Position Definitions

Bit position definitions for RCC\_AHB3LPENR register.

Collaboration diagram for RCC\_AHB3LPENR Bit Position Definitions:



## Macros

- #define RCC\_AHB3LPENR\_FSMCLPEN 0

### 5.89.1 Detailed Description

Bit position definitions for RCC\_AHB3LPENR register.

## 5.89.2 Macro Definition Documentation

### 5.89.2.1 RCC\_AHB3LPENR\_FSMCLPEN

```
#define RCC_AHB3LPENR_FSMCLPEN 0
```

FSMC Peripheral Clock in Low Power Mode Enable

## 5.90 RCC\_APB1LPENR Bit Position Definitions

Bit position definitions for RCC\_APB1LPENR register.

Collaboration diagram for RCC\_APB1LPENR Bit Position Definitions:



### Macros

- #define RCC\_APB1LPENR\_TIM2LPEN 0
- #define RCC\_APB1LPENR\_TIM3LPEN 1
- #define RCC\_APB1LPENR\_TIM4LPEN 2
- #define RCC\_APB1LPENR\_TIM5LPEN 3
- #define RCC\_APB1LPENR\_TIM6LPEN 4
- #define RCC\_APB1LPENR\_TIM7LPEN 5
- #define RCC\_APB1LPENR\_TIM12LPEN 6
- #define RCC\_APB1LPENR\_TIM13LPEN 7
- #define RCC\_APB1LPENR\_TIM14LPEN 8
- #define RCC\_APB1LPENR\_WWDGLPEN 11
- #define RCC\_APB1LPENR\_SPI2LPEN 14
- #define RCC\_APB1LPENR\_SPI3LPEN 15
- #define RCC\_APB1LPENR\_USART2LPEN 17
- #define RCC\_APB1LPENR\_USART3LPEN 18
- #define RCC\_APB1LPENR\_UART4LPEN 19
- #define RCC\_APB1LPENR\_UART5LPEN 20
- #define RCC\_APB1LPENR\_I2C1LPEN 21
- #define RCC\_APB1LPENR\_I2C2LPEN 22
- #define RCC\_APB1LPENR\_I2C3LPEN 23
- #define RCC\_APB1LPENR\_CAN1LPEN 25
- #define RCC\_APB1LPENR\_CAN2LPEN 26
- #define RCC\_APB1LPENR\_PWRLPEN 28
- #define RCC\_APB1LPENR\_DACLPEN 29
- #define RCC\_APB1LPENR\_UART7LPEN 30
- #define RCC\_APB1LPENR\_UART8LPEN 31

### 5.90.1 Detailed Description

Bit position definitions for RCC\_APB1LPENR register.

### 5.90.2 Macro Definition Documentation

#### 5.90.2.1 RCC\_APB1LPENR\_CAN1LPEN

```
#define RCC_APB1LPENR_CAN1LPEN 25
```

CAN1 Peripheral Clock in Low Power Mode Enable

#### 5.90.2.2 RCC\_APB1LPENR\_CAN2LPEN

```
#define RCC_APB1LPENR_CAN2LPEN 26
```

CAN2 Peripheral Clock in Low Power Mode Enable

#### 5.90.2.3 RCC\_APB1LPENR\_DACLPEN

```
#define RCC_APB1LPENR_DACLPEN 29
```

DAC Peripheral Clock in Low Power Mode Enable

#### 5.90.2.4 RCC\_APB1LPENR\_I2C1LPEN

```
#define RCC_APB1LPENR_I2C1LPEN 21
```

I2C1 Peripheral Clock in Low Power Mode Enable

#### 5.90.2.5 RCC\_APB1LPENR\_I2C2LPEN

```
#define RCC_APB1LPENR_I2C2LPEN 22
```

I2C2 Peripheral Clock in Low Power Mode Enable

#### 5.90.2.6 RCC\_APB1LPENR\_I2C3LPEN

```
#define RCC_APB1LPENR_I2C3LPEN 23
```

I2C3 Peripheral Clock in Low Power Mode Enable

### 5.90.2.7 RCC\_APB1LPENR\_PWRLPEN

```
#define RCC_APB1LPENR_PWRLPEN 28
```

Power Interface Peripheral Clock in Low Power Mode Enable

### 5.90.2.8 RCC\_APB1LPENR\_SPI2LPEN

```
#define RCC_APB1LPENR_SPI2LPEN 14
```

SPI2 Peripheral Clock in Low Power Mode Enable

### 5.90.2.9 RCC\_APB1LPENR\_SPI3LPEN

```
#define RCC_APB1LPENR_SPI3LPEN 15
```

SPI3 Peripheral Clock in Low Power Mode Enable

### 5.90.2.10 RCC\_APB1LPENR\_TIM12LPEN

```
#define RCC_APB1LPENR_TIM12LPEN 6
```

TIM12 Peripheral Clock in Low Power Mode Enable

### 5.90.2.11 RCC\_APB1LPENR\_TIM13LPEN

```
#define RCC_APB1LPENR_TIM13LPEN 7
```

TIM13 Peripheral Clock in Low Power Mode Enable

### 5.90.2.12 RCC\_APB1LPENR\_TIM14LPEN

```
#define RCC_APB1LPENR_TIM14LPEN 8
```

TIM14 Peripheral Clock in Low Power Mode Enable

### 5.90.2.13 RCC\_APB1LPENR\_TIM2LPEN

```
#define RCC_APB1LPENR_TIM2LPEN 0
```

TIM2 Peripheral Clock in Low Power Mode Enable

### 5.90.2.14 RCC\_APB1LPENR\_TIM3LPEN

```
#define RCC_APB1LPENR_TIM3LPEN 1
```

TIM3 Peripheral Clock in Low Power Mode Enable

**5.90.2.15 RCC\_APB1LPENR\_TIM4LPEN**

```
#define RCC_APB1LPENR_TIM4LPEN 2
```

TIM4 Peripheral Clock in Low Power Mode Enable

**5.90.2.16 RCC\_APB1LPENR\_TIM5LPEN**

```
#define RCC_APB1LPENR_TIM5LPEN 3
```

TIM5 Peripheral Clock in Low Power Mode Enable

**5.90.2.17 RCC\_APB1LPENR\_TIM6LPEN**

```
#define RCC_APB1LPENR_TIM6LPEN 4
```

TIM6 Peripheral Clock in Low Power Mode Enable

**5.90.2.18 RCC\_APB1LPENR\_TIM7LPEN**

```
#define RCC_APB1LPENR_TIM7LPEN 5
```

TIM7 Peripheral Clock in Low Power Mode Enable

**5.90.2.19 RCC\_APB1LPENR\_UART4LPEN**

```
#define RCC_APB1LPENR_UART4LPEN 19
```

UART4 Peripheral Clock in Low Power Mode Enable

**5.90.2.20 RCC\_APB1LPENR\_UART5LPEN**

```
#define RCC_APB1LPENR_UART5LPEN 20
```

UART5 Peripheral Clock in Low Power Mode Enable

**5.90.2.21 RCC\_APB1LPENR\_UART7LPEN**

```
#define RCC_APB1LPENR_UART7LPEN 30
```

UART7 Peripheral Clock in Low Power Mode Enable

**5.90.2.22 RCC\_APB1LPENR\_UART8LPEN**

```
#define RCC_APB1LPENR_UART8LPEN 31
```

UART8 Peripheral Clock in Low Power Mode Enable

### 5.90.2.23 RCC\_APB1LPENR\_USART2LPEN

```
#define RCC_APB1LPENR_USART2LPEN 17
```

USART2 Peripheral Clock in Low Power Mode Enable

### 5.90.2.24 RCC\_APB1LPENR\_USART3LPEN

```
#define RCC_APB1LPENR_USART3LPEN 18
```

USART3 Peripheral Clock in Low Power Mode Enable

### 5.90.2.25 RCC\_APB1LPENR\_WWDGLPEN

```
#define RCC_APB1LPENR_WWDGLPEN 11
```

WWDG Peripheral Clock in Low Power Mode Enable

## 5.91 RCC\_APB2LPENR Bit Position Definitions

Bit position definitions for RCC\_APB2LPENR register.

Collaboration diagram for RCC\_APB2LPENR Bit Position Definitions:



## Macros

- #define RCC\_APB2LPENR\_TIM1LPEN 0
- #define RCC\_APB2LPENR\_TIM8LPEN 1
- #define RCC\_APB2LPENR\_USART1LPEN 4
- #define RCC\_APB2LPENR\_USART6LPEN 5
- #define RCC\_APB2LPENR\_ADCLPEN 8
- #define RCC\_APB2LPENR\_SDIOLPEN 11
- #define RCC\_APB2LPENR\_SPI1LPEN 12
- #define RCC\_APB2LPENR\_SYSCFGLPEN 14
- #define RCC\_APB2LPENR\_TIM9LPEN 16
- #define RCC\_APB2LPENR\_TIM10LPEN 17
- #define RCC\_APB2LPENR\_TIM11LPEN 18

### 5.91.1 Detailed Description

Bit position definitions for RCC\_APB2LPENR register.

### 5.91.2 Macro Definition Documentation

#### 5.91.2.1 RCC\_APB2LPENR\_ADCLPEN

```
#define RCC_APB2LPENR_ADCLPEN 8
```

ADC Peripheral Clock in Low Power Mode Enable

#### 5.91.2.2 RCC\_APB2LPENR\_SDIOLPEN

```
#define RCC_APB2LPENR_SDIOLPEN 11
```

SDIO Peripheral Clock in Low Power Mode Enable

#### 5.91.2.3 RCC\_APB2LPENR\_SPI1LPEN

```
#define RCC_APB2LPENR_SPI1LPEN 12
```

SPI1 Peripheral Clock in Low Power Mode Enable

#### 5.91.2.4 RCC\_APB2LPENR\_SYSCFGLPEN

```
#define RCC_APB2LPENR_SYSCFGLPEN 14
```

System Configuration Controller Peripheral Clock in Low Power Mode Enable

#### 5.91.2.5 RCC\_APB2LPENR\_TIM10LPEN

```
#define RCC_APB2LPENR_TIM10LPEN 17
```

TIM10 Peripheral Clock in Low Power Mode Enable

#### 5.91.2.6 RCC\_APB2LPENR\_TIM11LPEN

```
#define RCC_APB2LPENR_TIM11LPEN 18
```

TIM11 Peripheral Clock in Low Power Mode Enable

### 5.91.2.7 RCC\_APB2LPENR\_TIM1LPEN

```
#define RCC_APB2LPENR_TIM1LPEN 0
```

TIM1 Peripheral Clock in Low Power Mode Enable

### 5.91.2.8 RCC\_APB2LPENR\_TIM8LPEN

```
#define RCC_APB2LPENR_TIM8LPEN 1
```

TIM8 Peripheral Clock in Low Power Mode Enable

### 5.91.2.9 RCC\_APB2LPENR\_TIM9LPEN

```
#define RCC_APB2LPENR_TIM9LPEN 16
```

TIM9 Peripheral Clock in Low Power Mode Enable

### 5.91.2.10 RCC\_APB2LPENR\_USART1LPEN

```
#define RCC_APB2LPENR_USART1LPEN 4
```

USART1 Peripheral Clock in Low Power Mode Enable

### 5.91.2.11 RCC\_APB2LPENR\_USART6LPEN

```
#define RCC_APB2LPENR_USART6LPEN 5
```

USART6 Peripheral Clock in Low Power Mode Enable

## 5.92 RCC\_BDCR Bit Position Definitions

Bit position definitions for RCC\_BDCR register.

Collaboration diagram for RCC\_BDCR Bit Position Definitions:



## Macros

- #define RCC\_BDCR\_LSEON 0
- #define RCC\_BDCR\_LSERDY 1
- #define RCC\_BDCR\_LSEBYP 2
- #define RCC\_BDCR\_RTCSEL 8
- #define RCC\_BDCR\_RTCEN 15
- #define RCC\_BDCR\_BDRST 16

### 5.92.1 Detailed Description

Bit position definitions for RCC\_BDCR register.

### 5.92.2 Macro Definition Documentation

#### 5.92.2.1 RCC\_BDCR\_BDRST

```
#define RCC_BDCR_BDRST 16
```

Backup Domain Software Reset

#### 5.92.2.2 RCC\_BDCR\_LSEBYP

```
#define RCC_BDCR_LSEBYP 2
```

External Low-Speed Oscillator Bypass

#### 5.92.2.3 RCC\_BDCR\_LSEON

```
#define RCC_BDCR_LSEON 0
```

External Low-Speed Oscillator Enable

#### 5.92.2.4 RCC\_BDCR\_LSERDY

```
#define RCC_BDCR_LSERDY 1
```

External Low-Speed Oscillator Ready

#### 5.92.2.5 RCC\_BDCR\_RTCEN

```
#define RCC_BDCR_RTCEN 15
```

RTC Clock Enable

### 5.92.2.6 RCC\_BDCR\_RTCSEL

```
#define RCC_BDCR_RTCSEL 8
```

RTC Clock Source Selection

## 5.93 RCC\_CSR Bit Position Definitions

Bit position definitions for RCC\_CSR register.

Collaboration diagram for RCC\_CSR Bit Position Definitions:



### Macros

- #define RCC\_CSR\_LSION 0
- #define RCC\_CSR\_LSIRDY 1
- #define RCC\_CSR\_RMVF 24
- #define RCC\_CSR\_OBLRSTF 25
- #define RCC\_CSR\_PINRSTF 26
- #define RCC\_CSR\_PORRSTF 27
- #define RCC\_CSR\_SFTRSTF 28
- #define RCC\_CSR\_IWDGRSTF 29
- #define RCC\_CSR\_WWDGRSTF 30
- #define RCC\_CSR\_LPWRRSTF 31

### 5.93.1 Detailed Description

Bit position definitions for RCC\_CSR register.

### 5.93.2 Macro Definition Documentation

#### 5.93.2.1 RCC\_CSR\_IWDGRSTF

```
#define RCC_CSR_IWDGRSTF 29
```

Independent Watchdog Reset Flag

### 5.93.2.2 RCC\_CSR\_LPWRRSTF

```
#define RCC_CSR_LPWRRSTF 31
```

Low-Power Reset Flag

### 5.93.2.3 RCC\_CSR\_LSION

```
#define RCC_CSR_LSION 0
```

Internal Low-Speed Oscillator Enable

### 5.93.2.4 RCC\_CSR\_LSIRDY

```
#define RCC_CSR_LSIRDY 1
```

Internal Low-Speed Oscillator Ready

### 5.93.2.5 RCC\_CSR\_OBLRSTF

```
#define RCC_CSR_OBLRSTF 25
```

Option Byte Loader Reset Flag

### 5.93.2.6 RCC\_CSR\_PINRSTF

```
#define RCC_CSR_PINRSTF 26
```

PIN Reset Flag

### 5.93.2.7 RCC\_CSR\_PORRSTF

```
#define RCC_CSR_PORRSTF 27
```

POR/PDR Reset Flag

### 5.93.2.8 RCC\_CSR\_RMVF

```
#define RCC_CSR_RMVF 24
```

Remove Reset Flag

### 5.93.2.9 RCC\_CSR\_SFTRSTF

```
#define RCC_CSR_SFTRSTF 28
```

Software Reset Flag

### 5.93.2.10 RCC\_CSR\_WWDGRSTF

```
#define RCC_CSR_WWDGRSTF 30
```

Window Watchdog Reset Flag

## 5.94 RCC\_SSCGR Bit Position Definitions

Bit position definitions for RCC\_SSCGR register.

Collaboration diagram for RCC\_SSCGR Bit Position Definitions:



### Macros

- #define RCC\_SSCGR\_MODPER 0
- #define RCC\_SSCGR\_INCSTEP 13
- #define RCC\_SSCGR\_SPREADSEL 15
- #define RCC\_SSCGR\_SSCGEN 31

### 5.94.1 Detailed Description

Bit position definitions for RCC\_SSCGR register.

### 5.94.2 Macro Definition Documentation

#### 5.94.2.1 RCC\_SSCGR\_INCSTEP

```
#define RCC_SSCGR_INCSTEP 13
```

Increase Step

#### 5.94.2.2 RCC\_SSCGR\_MODPER

```
#define RCC_SSCGR_MODPER 0
```

Modulation Period

### 5.94.2.3 RCC\_SSCGR\_SPREADSEL

```
#define RCC_SSCGR_SPREADSEL 15
```

Spread Select

### 5.94.2.4 RCC\_SSCGR\_SSCEGEN

```
#define RCC_SSCGR_SSCEGEN 31
```

Spread Spectrum Clock Generation Enable

## 5.95 RCC\_PLLI2SCFGR Bit Position Definitions

Bit position definitions for RCC\_PLLI2SCFGR register.

Collaboration diagram for RCC\_PLLI2SCFGR Bit Position Definitions:



### Macros

- #define RCC\_PLLI2SCFGR\_PLLI2SN 6
- #define RCC\_PLLI2SCFGR\_PLLI2SR 28

### 5.95.1 Detailed Description

Bit position definitions for RCC\_PLLI2SCFGR register.

### 5.95.2 Macro Definition Documentation

#### 5.95.2.1 RCC\_PLLI2SCFGR\_PLLI2SN

```
#define RCC_PLLI2SCFGR_PLLI2SN 6
```

PLL2S N Factor

### 5.95.2.2 RCC\_PLLI2SCFGR\_PLLI2SR

```
#define RCC_PLLI2SCFGR_PLLI2SR 28
```

PLL2S R Factor

## 5.96 GPIO Base Address to Code Conversion Macros

Macros for converting GPIO base addresses to corresponding port codes.

Collaboration diagram for GPIO Base Address to Code Conversion Macros:



### Macros

- `#define GPIO_BASEADDR_TO_CODE(x)`  
*Macro to convert GPIO base address to port code.*

#### 5.96.1 Detailed Description

Macros for converting GPIO base addresses to corresponding port codes.

#### 5.96.2 Macro Definition Documentation

##### 5.96.2.1 GPIO\_BASEADDR\_TO\_CODE

```
#define GPIO_BASEADDR_TO_CODE(
    x )
```

###### Value:

```
(     (x == GPIOA)?0:\\
(x == GPIOB)?1:\\
(x == GPIOC)?2:\\
(x == GPIOD)?3:\\
(x == GPIOE)?4:0 )
```

Macro to convert GPIO base address to port code.

**Parameters**

|   |                     |
|---|---------------------|
| x | GPIOx base address. |
|---|---------------------|

**Returns**

Corresponding port code for the given GPIO base address.

## 5.97 GPIO Driver

GPIO driver APIs for STM32F401xx MCU.

Collaboration diagram for GPIO Driver:



## Modules

- [GPIO Pin Numbers](#)  
*Defines the GPIO pin numbers.*
- [GPIO Pin Modes](#)  
*Defines the GPIO pin modes.*
- [GPIO Pin Speeds](#)  
*Defines the GPIO pin speeds.*
- [GPIO Pin States](#)  
*Defines the GPIO pin states.*
- [GPIO Return Lock Status](#)  
*Defines the return status for GPIO lock operations.*
- [GPIO Pin Modes](#)  
*Defines possible GPIO pin modes.*
- [GPIO Output Speeds](#)  
*Defines possible GPIO pin output speeds.*
- [GPIO Pull-up/Pull-down Configurations](#)  
*Defines possible GPIO pin pull-up and pull-down configurations.*
- [GPIO Output Types](#)  
*Defines possible GPIO pin output types.*
- [API Function Prototypes](#)

## Classes

- struct [GPIO\\_PinConfig\\_t](#)  
*Configuration structure for GPIO pins.*

### 5.97.1 Detailed Description

GPIO driver APIs for STM32F401xx MCU.

## 5.98 GPIO Pin Numbers

Defines the GPIO pin numbers.

Collaboration diagram for GPIO Pin Numbers:



## Macros

- #define **GPIO\_PIN\_0** 0
- #define **GPIO\_PIN\_1** 1
- #define **GPIO\_PIN\_2** 2
- #define **GPIO\_PIN\_3** 3
- #define **GPIO\_PIN\_4** 4
- #define **GPIO\_PIN\_5** 5
- #define **GPIO\_PIN\_6** 6
- #define **GPIO\_PIN\_7** 7
- #define **GPIO\_PIN\_8** 8
- #define **GPIO\_PIN\_9** 9
- #define **GPIO\_PIN\_10** 10
- #define **GPIO\_PIN\_11** 11
- #define **GPIO\_PIN\_12** 12
- #define **GPIO\_PIN\_13** 13
- #define **GPIO\_PIN\_14** 14
- #define **GPIO\_PIN\_15** 15
- #define **GPIO\_PIN\_ALL** ((**uint16**)0xFFFF)

### 5.98.1 Detailed Description

Defines the GPIO pin numbers.

## 5.99 GPIO Pin Modes

Defines the GPIO pin modes.

Collaboration diagram for GPIO Pin Modes:



## Macros

- #define **GPIO\_MODE\_INPUT\_FLO** 0x00000001U
- #define **GPIO\_MODE\_INPUT\_PU** 0x00000002U
- #define **GPIO\_MODE\_INPUT\_PD** 0x00000003U
- #define **GPIO\_MODE\_OUTPUT\_PP** 0x00000004U
- #define **GPIO\_MODE\_OUTPUT\_OD** 0x00000005U
- #define **GPIO\_MODE\_OUTPUT\_AF\_PP** 0x00000006U
- #define **GPIO\_MODE\_OUTPUT\_AF\_OD** 0x00000007U
- #define **GPIO\_MODE\_AF\_INPUT** 0x00000008U

### 5.99.1 Detailed Description

Defines the GPIO pin modes.

### 5.99.2 Macro Definition Documentation

#### 5.99.2.1 `GPIO_MODE_AF_INPUT`

```
#define GPIO_MODE_AF_INPUT 0x00000008U
```

Alternate function input

#### 5.99.2.2 `GPIO_MODE_INPUT_FLO`

```
#define GPIO_MODE_INPUT_FLO 0x00000001U
```

Floating input

#### 5.99.2.3 `GPIO_MODE_INPUT_PD`

```
#define GPIO_MODE_INPUT_PD 0x00000003U
```

Input with pull-down

#### 5.99.2.4 `GPIO_MODE_INPUT_PU`

```
#define GPIO_MODE_INPUT_PU 0x00000002U
```

Input with pull-up

#### 5.99.2.5 `GPIO_MODE_OUTPUT_AF_OD`

```
#define GPIO_MODE_OUTPUT_AF_OD 0x00000007U
```

Alternate function output open-drain

#### 5.99.2.6 `GPIO_MODE_OUTPUT_AF_PP`

```
#define GPIO_MODE_OUTPUT_AF_PP 0x00000006U
```

Alternate function output push-pull

### 5.99.2.7 GPIO\_MODE\_OUTPUT\_OD

```
#define GPIO_MODE_OUTPUT_OD 0x00000005U
```

General purpose output open-drain

### 5.99.2.8 GPIO\_MODE\_OUTPUT\_PP

```
#define GPIO_MODE_OUTPUT_PP 0x00000004U
```

General purpose output push-pull

## 5.100 GPIO Pin Speeds

Defines the GPIO pin speeds.

Collaboration diagram for GPIO Pin Speeds:



## Macros

- #define GPIO\_SPEED\_10M 0x00000001U
- #define GPIO\_SPEED\_2M 0x00000002U
- #define GPIO\_SPEED\_50M 0x00000003U

### 5.100.1 Detailed Description

Defines the GPIO pin speeds.

### 5.100.2 Macro Definition Documentation

#### 5.100.2.1 GPIO\_SPEED\_10M

```
#define GPIO_SPEED_10M 0x00000001U
```

Output mode, max speed 10 MHz

### 5.100.2.2 GPIO\_SPEED\_2M

```
#define GPIO_SPEED_2M 0x00000002U
```

Output mode, max speed 2 MHz

### 5.100.2.3 GPIO\_SPEED\_50M

```
#define GPIO_SPEED_50M 0x00000003U
```

Output mode, max speed 50 MHz

## 5.101 GPIO Pin States

Defines the GPIO pin states.

Collaboration diagram for GPIO Pin States:



### Macros

- #define GPIO\_PIN\_SET 1
- #define GPIO\_PIN\_RESET 0

### 5.101.1 Detailed Description

Defines the GPIO pin states.

### 5.101.2 Macro Definition Documentation

#### 5.101.2.1 GPIO\_PIN\_RESET

```
#define GPIO_PIN_RESET 0
```

GPIO Pin reset state

### 5.101.2.2 GPIO\_PIN\_SET

```
#define GPIO_PIN_SET 1
```

GPIO Pin set state

## 5.102 GPIO Return Lock Status

Defines the return status for GPIO lock operations.

Collaboration diagram for GPIO Return Lock Status:



### Macros

- #define GPIO\_RETURN\_LOCK\_OK 1
- #define GPIO\_RETURN\_LOCK\_ERROR 0

### 5.102.1 Detailed Description

Defines the return status for GPIO lock operations.

### 5.102.2 Macro Definition Documentation

#### 5.102.2.1 GPIO\_RETURN\_LOCK\_ERROR

```
#define GPIO_RETURN_LOCK_ERROR 0
```

GPIO pin configuration lock failed

#### 5.102.2.2 GPIO\_RETURN\_LOCK\_OK

```
#define GPIO_RETURN_LOCK_OK 1
```

GPIO pin configuration is locked successfully

## 5.103 GPIO Pin Modes

Defines possible GPIO pin modes.

Collaboration diagram for GPIO Pin Modes:



### Macros

- #define GPIO\_MODE\_IN 0
- #define GPIO\_MODE\_OUT 1
- #define GPIO\_MODE\_ALTFN 2
- #define GPIO\_MODE\_ANALOG 3
- #define GPIO\_MODE\_IT\_FT 4
- #define GPIO\_MODE\_IT\_RT 5
- #define GPIO\_MODE\_IT\_RFT 6

### 5.103.1 Detailed Description

Defines possible GPIO pin modes.

### 5.103.2 Macro Definition Documentation

#### 5.103.2.1 GPIO\_MODE\_ALTFN

```
#define GPIO_MODE_ALTFN 2
```

GPIO Alternate Function mode

#### 5.103.2.2 GPIO\_MODE\_ANALOG

```
#define GPIO_MODE_ANALOG 3
```

GPIO Analog mode

### 5.103.2.3 GPIO\_MODE\_IN

```
#define GPIO_MODE_IN 0
```

GPIO Input mode

### 5.103.2.4 GPIO\_MODE\_IT\_FT

```
#define GPIO_MODE_IT_FT 4
```

GPIO Interrupt Falling-Edge Trigger mode

### 5.103.2.5 GPIO\_MODE\_IT\_RFT

```
#define GPIO_MODE_IT_RFT 6
```

GPIO Interrupt Rising-Falling Edge Trigger mode

### 5.103.2.6 GPIO\_MODE\_IT\_RT

```
#define GPIO_MODE_IT_RT 5
```

GPIO Interrupt Rising-Edge Trigger mode

### 5.103.2.7 GPIO\_MODE\_OUT

```
#define GPIO_MODE_OUT 1
```

GPIO Output mode

## 5.104 GPIO Output Speeds

Defines possible GPIO pin output speeds.

Collaboration diagram for GPIO Output Speeds:



## Macros

- #define GPIO\_SPEED\_LOW 0
- #define GPIO\_SPEED\_MEDIUM 1
- #define GPIO\_SPEED\_FAST 2
- #define GPIO\_SPEED\_HIGH 3

### 5.104.1 Detailed Description

Defines possible GPIO pin output speeds.

### 5.104.2 Macro Definition Documentation

#### 5.104.2.1 GPIO\_SPEED\_FAST

```
#define GPIO_SPEED_FAST 2
```

GPIO Output speed Fast

#### 5.104.2.2 GPIO\_SPEED\_HIGH

```
#define GPIO_SPEED_HIGH 3
```

GPIO Output speed High

#### 5.104.2.3 GPIO\_SPEED\_LOW

```
#define GPIO_SPEED_LOW 0
```

GPIO Output speed Low

#### 5.104.2.4 GPIO\_SPEED\_MEDIUM

```
#define GPIO_SPEED_MEDIUM 1
```

GPIO Output speed Medium

## 5.105 GPIO Pull-up/Pull-down Configurations

Defines possible GPIO pin pull-up and pull-down configurations.

Collaboration diagram for GPIO Pull-up/Pull-down Configurations:



### Macros

- `#define GPIO_NO_PUPD 0`
- `#define GPIO_PIN_PU 1`
- `#define GPIO_PIN_PD 2`

#### 5.105.1 Detailed Description

Defines possible GPIO pin pull-up and pull-down configurations.

#### 5.105.2 Macro Definition Documentation

##### 5.105.2.1 GPIO\_NO\_PUPD

```
#define GPIO_NO_PUPD 0
```

No pull-up/pull-down configuration

##### 5.105.2.2 GPIO\_PIN\_PD

```
#define GPIO_PIN_PD 2
```

GPIO Pull-down configuration

##### 5.105.2.3 GPIO\_PIN\_PU

```
#define GPIO_PIN_PU 1
```

GPIO Pull-up configuration

## 5.106 GPIO Output Types

Defines possible GPIO pin output types.

Collaboration diagram for GPIO Output Types:



### Macros

- `#define GPIO_OP_TYPE_PP 0`
- `#define GPIO_OP_TYPE_OD 1`

#### 5.106.1 Detailed Description

Defines possible GPIO pin output types.

#### 5.106.2 Macro Definition Documentation

##### 5.106.2.1 GPIO\_OP\_TYPE\_OD

```
#define GPIO_OP_TYPE_OD 1
```

GPIO Output type Open-Drain mode

##### 5.106.2.2 GPIO\_OP\_TYPE\_PP

```
#define GPIO_OP_TYPE_PP 0
```

GPIO Output type Push-Pull mode

## 5.107 API Function Prototypes

Collaboration diagram for API Function Prototypes:



### Functions

- void **MCAL\_GPIO\_Init** (**GPIO\_TypeDef** \*GPIOx, **GPIO\_PinConfig\_t** \*PinConfig)  
*Initializes the specified GPIO pin according to the provided configuration.*
- void **MCAL\_GPIO\_DeInit** (**GPIO\_TypeDef** \*GPIOx)  
*Resets the specified GPIO port.*
- **uint8 MCAL\_GPIO\_ReadPin** (**GPIO\_TypeDef** \*GPIOx, **uint16** PinNumber)  
*Reads the value of a specified GPIO pin.*
- **uint16 MCAL\_GPIO\_ReadPort** (**GPIO\_TypeDef** \*GPIOx)  
*Reads the value of the entire GPIO port.*
- void **MCAL\_GPIO\_WritePin** (**GPIO\_TypeDef** \*GPIOx, **uint16** PinNumber, **uint8** Value)  
*Writes a value to a specified GPIO pin.*
- void **MCAL\_GPIO\_WritePort** (**GPIO\_TypeDef** \*GPIOx, **uint16** Value)  
*Writes a value to the entire GPIO port.*
- void **MCAL\_GPIO\_TogglePin** (**GPIO\_TypeDef** \*GPIOx, **uint16** PinNumber)  
*Toggles the state of a specified GPIO pin.*
- void **MCAL\_GPIO\_TogglePort** (**GPIO\_TypeDef** \*GPIOx)  
*Toggles the value of a specific GPIO Port.*
- **uint8 MCAL\_GPIO\_LockPin** (**GPIO\_TypeDef** \*GPIOx, **uint16** PinNumber)  
*Locks the configuration of a specific GPIO pin to prevent further changes.*

### 5.107.1 Detailed Description

### 5.107.2 Function Documentation

#### 5.107.2.1 MCAL\_GPIO\_DeInit()

```
void MCAL_GPIO_DeInit (
    GPIO_TypeDef * GPIOx )
```

Resets the specified GPIO port.

This function resets the GPIO port, clearing all configuration settings.

**Parameters**

|    |              |                                              |
|----|--------------|----------------------------------------------|
| in | <i>GPIOx</i> | Pointer to the GPIO peripheral base address. |
|----|--------------|----------------------------------------------|

**Return values**

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

**Note**

This function does not affect other GPIO ports.

This function resets the GPIO port by toggling the appropriate reset bit in the RCC\_AHB1RSTR register.

**Parameters**

|    |              |                                                                    |
|----|--------------|--------------------------------------------------------------------|
| in | <i>GPIOx</i> | The GPIO peripheral to be reset (e.g., GPIOA, GPIOB, GPIOC, etc.). |
|----|--------------|--------------------------------------------------------------------|

**Returns**

None

**Note**

None

**5.107.2.2 MCAL\_GPIO\_Init()**

```
void MCAL_GPIO_Init (
    GPIO_TypeDef * GPIOx,
    GPIO_PinConfig_t * PinConfig )
```

Initializes the specified GPIO pin according to the provided configuration.

This function configures the GPIO pin based on the parameters specified in the [GPIO\\_PinConfig\\_t](#) structure. It is essential to enable the RCC clock for the corresponding GPIO port before calling this function.

**Parameters**

|    |                  |                                                                                           |
|----|------------------|-------------------------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | Pointer to the GPIO peripheral base address.                                              |
| in | <i>PinConfig</i> | Pointer to a <a href="#">GPIO_PinConfig_t</a> structure containing the pin configuration. |

**Return values**

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

**Note**

This function configures the GPIO pins and their associated settings.

This function sets up the GPIO pin mode, output type, speed, pull-up/pull-down resistors, and alternate function if needed.

**Parameters**

|    |                  |                                                                                                           |
|----|------------------|-----------------------------------------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | The GPIO peripheral to be initialized (e.g., GPIOA, GPIOB, GPIOC, etc.).                                  |
| in | <i>PinConfig</i> | Pointer to a <a href="#">GPIO_PinConfig_t</a> structure containing the configuration details for the pin. |

**Returns**

None

**Note**

It is mandatory to enable the RCC clock for the corresponding GPIO port before initialization.

**5.107.2.3 MCAL\_GPIO\_LockPin()**

```
uint8 MCAL_GPIO_LockPin (
    GPIO_TypeDef * GPIOx,
    uint16 PinNumber )
```

Locks the configuration of a specific GPIO pin to prevent further changes.

This function locks the configuration of the specified GPIO pin. Once locked, the pin's configuration cannot be modified until the reset of the device. This is useful for protecting the pin configuration from accidental changes.

**Parameters**

|    |                  |                                                                                                                                                                 |
|----|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | Pointer to the GPIO peripheral base address. This parameter can be one of the following values depending on the device used: GPIOA, GPIOB, GPIOC, GPIOD, GPIOE. |
| in | <i>PinNumber</i> | The number of the pin to lock. This parameter should be a value defined in <a href="#">GPIO Pin Numbers</a> .                                                   |

**Return values**

|              |                                                                                                                                        |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------|
| <i>uint8</i> | Returns GPIO_RETURN_LOCK_OK if the pin configuration is successfully locked, or GPIO_RETURN_LOCK_ERROR if the locking operation fails. |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------|

**Note**

Ensure that the pin's configuration is correctly set before calling this function, as the configuration cannot be changed once locked.

Locks the configuration of a specific GPIO pin to prevent further changes.

This function implements a locking mechanism to prevent further changes to the configuration of a specified GPIO pin. The locking sequence must be followed to successfully lock the pin configuration.

#### Parameters

|    |                  |                                                                                        |
|----|------------------|----------------------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | The GPIO peripheral to be used (e.g., GPIOA, GPIOB, GPIOC, etc.).                      |
| in | <i>PinNumber</i> | The pin number to be locked, specified according to <a href="#">GPIO Pin Numbers</a> . |

#### Return values

|              |                                                                                                                                                                |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>uint8</i> | Returns <code>GPIO_RETURN_LOCK_OK</code> if the pin configuration is successfully locked, or <code>GPIO_RETURN_LOCK_ERROR</code> if the locking process fails. |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### Note

The locking sequence is as follows:

- Write 1 to the lock key bit.
- Write 0 to the lock key bit.
- Write 1 to the lock key bit.
- Read the lock key bit (should be 0).
- Optionally, read the lock key bit again (should be 1 to confirm the lock).

The value of the lock bits (LCK[15:0]) must not change during this sequence, otherwise, the lock process will be aborted.

#### 5.107.2.4 MCAL\_GPIO\_ReadPin()

```
uint8 MCAL_GPIO_ReadPin (
    GPIO_TypeDef * GPIOx,
    uint16 PinNumber )
```

Reads the value of a specified GPIO pin.

This function retrieves the current state of the specified GPIO pin.

#### Parameters

|    |                  |                                                                                                               |
|----|------------------|---------------------------------------------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | Pointer to the GPIO peripheral base address.                                                                  |
| in | <i>PinNumber</i> | The number of the pin to read. This parameter should be a value defined in <a href="#">GPIO Pin Numbers</a> . |

#### Return values

|              |                                                                                                             |
|--------------|-------------------------------------------------------------------------------------------------------------|
| <i>uint8</i> | The state of the GPIO pin. This value can be one of the values defined in <a href="#">GPIO Pin States</a> . |
|--------------|-------------------------------------------------------------------------------------------------------------|

#### Note

This function reads the input value of the pin.

Reads the value of a specified GPIO pin.

This function reads the input data register to retrieve the value of the specified GPIO pin.

#### Parameters

|    |                  |                                                                           |
|----|------------------|---------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | The GPIO peripheral from which to read (e.g., GPIOA, GPIOB, GPIOC, etc.). |
| in | <i>PinNumber</i> | The pin number to be read (e.g., GPIO_PIN_0, GPIO_PIN_1, etc.).           |

#### Returns

The value of the specified pin (0 or 1).

#### Note

None

### 5.107.2.5 MCAL\_GPIO\_ReadPort()

```
uint16 MCAL_GPIO_ReadPort (
    GPIO_TypeDef * GPIOx )
```

Reads the value of the entire GPIO port.

This function retrieves the current state of all the pins in the specified GPIO port.

#### Parameters

|    |              |                                              |
|----|--------------|----------------------------------------------|
| in | <i>GPIOx</i> | Pointer to the GPIO peripheral base address. |
|----|--------------|----------------------------------------------|

#### Return values

|               |                                    |
|---------------|------------------------------------|
| <i>uint16</i> | The state of the entire GPIO port. |
|---------------|------------------------------------|

#### Note

This function reads the input values of all pins in the port.

Reads the value of the entire GPIO port.

This function reads the input data register to retrieve the value of all the pins in the specified GPIO port.

#### Parameters

|    |              |                                                                           |
|----|--------------|---------------------------------------------------------------------------|
| in | <i>GPIOx</i> | The GPIO peripheral from which to read (e.g., GPIOA, GPIOB, GPIOC, etc.). |
|----|--------------|---------------------------------------------------------------------------|

**Returns**

The value of the entire port.

**Note**

None

**5.107.2.6 MCAL\_GPIO\_TogglePin()**

```
void MCAL_GPIO_TogglePin (
    GPIO_TypeDef * GPIOx,
    uint16 PinNumber )
```

Toggles the state of a specified GPIO pin.

This function toggles the output state of the specified GPIO pin.

**Parameters**

|    |                  |                                                                                                                 |
|----|------------------|-----------------------------------------------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | Pointer to the GPIO peripheral base address.                                                                    |
| in | <i>PinNumber</i> | The number of the pin to toggle. This parameter should be a value defined in <a href="#">GPIO Pin Numbers</a> . |

**Return values**

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

**Note**

This function changes the state of the pin from high to low or low to high.

Toggles the state of a specified GPIO pin.

This function inverts the state of the specified GPIO pin.

**Parameters**

|    |                  |                                                                          |
|----|------------------|--------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | The GPIO peripheral to which to write (e.g., GPIOA, GPIOB, GPIOC, etc.). |
| in | <i>PinNumber</i> | The pin number to be toggled (e.g., GPIO_PIN_0, GPIO_PIN_1, etc.).       |

**Returns**

None

**Note**

None

### 5.107.2.7 MCAL\_GPIO\_TogglePort()

```
void MCAL_GPIO_TogglePort (
    GPIO_TypeDef * GPIOx )
```

Toggles the value of a specific GPIO Port.

Toggles the state of all pins in the specified GPIO port.

This function inverts the state of the specified GPIO Port.

#### Parameters

|    |       |                                                                          |
|----|-------|--------------------------------------------------------------------------|
| in | GPIOx | The GPIO peripheral to which to write (e.g., GPIOA, GPIOB, GPIOC, etc.). |
|----|-------|--------------------------------------------------------------------------|

#### Returns

None

#### Note

None

This function toggles the output state of each pin in the given GPIO port. If a pin is high, it will be set to low, and if it is low, it will be set to high.

#### Parameters

|    |       |                                                                                                                                                                 |
|----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| in | GPIOx | Pointer to the GPIO peripheral base address. This parameter can be one of the following values depending on the device used: GPIOA, GPIOB, GPIOC, GPIOD, GPIOE. |
|----|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|

#### Return values

|      |  |
|------|--|
| None |  |
|------|--|

#### Note

This function affects all pins in the specified GPIO port.

### 5.107.2.8 MCAL\_GPIO\_WritePin()

```
void MCAL_GPIO_WritePin (
    GPIO_TypeDef * GPIOx,
    uint16 PinNumber,
    uint8 Value )
```

Writes a value to a specified GPIO pin.

This function sets the state of the specified GPIO pin to the provided value.

**Parameters**

|    |                  |                                                                                                                        |
|----|------------------|------------------------------------------------------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | Pointer to the GPIO peripheral base address.                                                                           |
| in | <i>PinNumber</i> | The number of the pin to write to. This parameter should be a value defined in <a href="#">GPIO Pin Numbers</a> .      |
| in | <i>Value</i>     | The value to write to the pin. This parameter should be one of the values defined in <a href="#">GPIO Pin States</a> . |

**Return values**

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

**Note**

This function sets the output value of the pin.

Writes a value to a specified GPIO pin.

This function sets or clears the specified GPIO pin according to the provided value.

**Parameters**

|    |                  |                                                                          |
|----|------------------|--------------------------------------------------------------------------|
| in | <i>GPIOx</i>     | The GPIO peripheral to which to write (e.g., GPIOA, GPIOB, GPIOC, etc.). |
| in | <i>PinNumber</i> | The pin number to be written (e.g., GPIO_PIN_0, GPIO_PIN_1, etc.).       |
| in | <i>Value</i>     | The value to be written (either GPIO_PIN_SET or GPIO_PIN_RESET).         |

**Returns**

*None*

**Note**

*None*

**5.107.2.9 MCAL\_GPIO\_WritePort()**

```
void MCAL_GPIO_WritePort (
    GPIO_TypeDef * GPIOx,
    uint16 Value )
```

Writes a value to the entire GPIO port.

This function sets the state of all the pins in the specified GPIO port to the provided value.

**Parameters**

|    |              |                                                                                                      |
|----|--------------|------------------------------------------------------------------------------------------------------|
| in | <i>GPIOx</i> | Pointer to the GPIO peripheral base address.                                                         |
| in | <i>Value</i> | The value to write to the port. This parameter is a 16-bit value representing the state of each pin. |

**Return values**

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

**Note**

This function sets the output values of all pins in the port.

This function sets the output data register of the specified GPIO port to the provided value.

**Parameters**

|    |              |                                                                          |
|----|--------------|--------------------------------------------------------------------------|
| in | <i>GPIOx</i> | The GPIO peripheral to which to write (e.g., GPIOA, GPIOB, GPIOC, etc.). |
| in | <i>Value</i> | The value to be written to the entire port.                              |

**Returns**

None

**Note**

None

## 5.108 I2C Driver

I2C driver APIs for STM32F401xx MCU.

Collaboration diagram for I2C Driver:



## Modules

- I2C Speed Definitions
- I2C Stretch Mode Definitions
- I2C Mode Definitions
- I2C Addressing Modes
- I2C Acknowledge Control Definitions
- I2C General Call Enable Definitions
- API Function Prototypes

## Classes

- struct [S\\_I2C\\_Slave\\_address](#)  
*Structure for I2C slave address configuration.*
- struct [S\\_I2C\\_Config\\_t](#)  
*Structure for I2C configuration.*

## Enumerations

- enum `Slave_State` {  
    I2C\_EV\_Stop , I2C\_Error\_AF , I2C\_Ev\_Address\_Matched , I2C\_Ev\_Data\_Req ,  
    I2C\_Ev\_Data\_RCV }  
    *Enumeration for I2C slave states.*
- enum `StopCondition` { `WithStop` , `WithoutStop` }  
    *Enumeration for I2C stop condition.*
- enum `Repeated_Start` { `Start` , `Repeated` }  
    *Enumeration for I2C repeated start condition.*
- enum `Functional_State` { `DISABLE` , `ENABLE` }  
    *Enumeration for functional state.*
- enum `FlagStatus` { `RESET` = 0 , `SET` = !`RESET` , `Reset` , `Set` }  
    *Enumeration for flag status.*
- enum `Status` {  
    I2C\_Flag\_Busy , EV5 , EV6 , EV7 ,  
    EV8 , EV8\_1 , Master\_Byte\_Transmitting = (uint32\_t)(0x00070080) }  
    *Enumeration for I2C status flags.*
- enum `I2C_Direction` { `I2C_Direction_Transmitter` , `I2C_Direction_Receiver` }  
    *Enumeration for I2C direction.*

### 5.108.1 Detailed Description

I2C driver APIs for STM32F401xx MCU.

### 5.108.2 Enumeration Type Documentation

#### 5.108.2.1 FlagStatus

```
enum FlagStatus
```

Enumeration for flag status.

Enumerator

|       |                |
|-------|----------------|
| Reset | Flag is reset. |
| Set   | Flag is set.   |

#### 5.108.2.2 Functional\_State

```
enum Functional_State
```

Enumeration for functional state.

**Enumerator**

|         |                            |
|---------|----------------------------|
| DISABLE | Disable the functionality. |
| ENABLE  | Enable the functionality.  |

**5.108.2.3 I2C\_Direction**

```
enum I2C_Direction
```

Enumeration for I2C direction.

**Enumerator**

|                           |                   |
|---------------------------|-------------------|
| I2C_Direction_Transmitter | Transmitter mode. |
| I2C_Direction_Receiver    | Receiver mode.    |

**5.108.2.4 Repeated\_Start**

```
enum Repeated_Start
```

Enumeration for I2C repeated start condition.

**Enumerator**

|          |                                        |
|----------|----------------------------------------|
| Start    | Start condition is generated.          |
| Repeated | Repeated start condition is generated. |

**5.108.2.5 Slave\_State**

```
enum Slave_State
```

Enumeration for I2C slave states.

**Enumerator**

|                        |                                        |
|------------------------|----------------------------------------|
| I2C_EV_Stop            | Stop condition detected.               |
| I2C_Error_AF           | Acknowledge failure error.             |
| I2C_Ev_Address_Matched | Address matched event.                 |
| I2C_Ev_Data_Req        | Data request event (Slave_Send_Data).  |
| I2C_Ev_Data_RCV        | Data received event (Slave_Read_Data). |

### 5.108.2.6 Status

```
enum Status
```

Enumeration for I2C status flags.

Enumerator

|                          |                                                             |
|--------------------------|-------------------------------------------------------------|
| I2C_Flag_Busy            | I2C is busy.                                                |
| EV5                      | Event 5: Start bit transmitted.                             |
| EV6                      | Event 6: Address sent.                                      |
| EV7                      | Event 7: Data register not empty.                           |
| EV8                      | Event 8: Transmit data register empty.                      |
| EV8_1                    | Event 8_1: Transmit data register empty, write Data1 in DR. |
| Master_Byte_Transmitting | Master mode, byte transmitting.                             |

### 5.108.2.7 StopCondition

```
enum StopCondition
```

Enumeration for I2C stop condition.

Enumerator

|             |                                                 |
|-------------|-------------------------------------------------|
| WithStop    | Stop condition is generated after the transfer. |
| WithoutStop | Stop condition is not generated.                |

## 5.109 I2C Speed Definitions

Collaboration diagram for I2C Speed Definitions:



## Macros

- #define I2C\_SCK\_SM\_50K (0x50000UL)
- #define I2C\_SCK\_SM\_100K (100000UL)
- #define I2C\_SCK\_FM\_200K (200000UL)
- #define I2C\_SCK\_FM\_400K (400000UL)

### 5.109.1 Detailed Description

Defines for I2C clock speeds.

### 5.109.2 Macro Definition Documentation

#### 5.109.2.1 I2C\_SCK\_FM\_200K

```
#define I2C_SCK_FM_200K (200000UL)
```

Fast mode 200 kHz clock speed (not supported yet).

#### 5.109.2.2 I2C\_SCK\_FM\_400K

```
#define I2C_SCK_FM_400K (400000UL)
```

Fast mode 400 kHz clock speed (not supported yet).

#### 5.109.2.3 I2C\_SCK\_SM\_100K

```
#define I2C_SCK_SM_100K (100000UL)
```

Standard mode 100 kHz clock speed.

#### 5.109.2.4 I2C\_SCK\_SM\_50K

```
#define I2C_SCK_SM_50K (0x50000UL)
```

Standard mode 50 kHz clock speed.

## 5.110 I2C Stretch Mode Definitions

Collaboration diagram for I2C Stretch Mode Definitions:



### Macros

- `#define I2C_StripMode_enabled 0x00000000U`
- `#define I2C_StripMode_disabled I2C_CR1_NOSTRETCH`

#### 5.110.1 Detailed Description

Defines for I2C clock stretching mode.

#### 5.110.2 Macro Definition Documentation

##### 5.110.2.1 I2C\_StripMode\_disabled

```
#define I2C_StripMode_disabled I2C_CR1_NOSTRETCH
```

Clock stretching disabled.

##### 5.110.2.2 I2C\_StripMode\_enabled

```
#define I2C_StripMode_enabled 0x00000000U
```

Clock stretching enabled.

## 5.111 I2C Mode Definitions

Collaboration diagram for I2C Mode Definitions:



## Macros

- #define I2C\_Mode\_I2C 0
- #define I2C\_Mode\_SMBus I2C\_CR1\_SMBUS

### 5.111.1 Detailed Description

Defines for I2C and SMBus modes.

### 5.111.2 Macro Definition Documentation

#### 5.111.2.1 I2C\_Mode\_I2C

```
#define I2C_Mode_I2C 0
```

I2C mode.

#### 5.111.2.2 I2C\_Mode\_SMBus

```
#define I2C_Mode_SMBus I2C_CR1_SMBUS
```

SMBus mode.

## 5.112 I2C Addressing Modes

Collaboration diagram for I2C Addressing Modes:



## Macros

- #define I2C\_Addressing\_Slave\_7bits 0
- #define I2C\_Addressing\_Slave\_10bits (uint16\_t)(1<<15)

### 5.112.1 Detailed Description

Defines for I2C slave addressing modes.

### 5.112.2 Macro Definition Documentation

#### 5.112.2.1 I2C\_Addressing\_Slave\_10bits

```
#define I2C_Addressing_Slave_10bits (uint16_t)(1<<15)
```

10-bit addressing mode.

#### 5.112.2.2 I2C\_Addressing\_Slave\_7bits

```
#define I2C_Addressing_Slave_7bits 0
```

7-bit addressing mode.

## 5.113 I2C Acknowledge Control Definitions

Collaboration diagram for I2C Acknowledge Control Definitions:



### Macros

- #define I2C\_Ack\_Control\_Enable I2C\_CR1\_ACK
- #define I2C\_Ack\_Control\_Disable 0

### 5.113.1 Detailed Description

Defines for I2C acknowledge control.

### 5.113.2 Macro Definition Documentation

#### 5.113.2.1 I2C\_Ack\_Control\_Disable

```
#define I2C_Ack_Control_Disable 0
```

Acknowledge disabled.

#### 5.113.2.2 I2C\_Ack\_Control\_Enable

```
#define I2C_Ack_Control_Enable I2C_CR1_ACK
```

Acknowledge enabled.

## 5.114 I2C General Call Enable Definitions

Collaboration diagram for I2C General Call Enable Definitions:



### Macros

- #define I2C\_ENGC\_Enable I2C\_CR1\_ENGC
- #define I2C\_ENGC\_Disable 0x00

#### 5.114.1 Detailed Description

Defines for enabling or disabling general call.

#### 5.114.2 Macro Definition Documentation

### 5.114.2.1 I2C\_ENGC\_Disable

```
#define I2C_ENGC_Disable 0x00
```

General call disabled.

### 5.114.2.2 I2C\_ENGC\_Enable

```
#define I2C_ENGC_Enable I2C_CR1_ENGC
```

General call enabled.

## 5.115 API Function Prototypes

Collaboration diagram for API Function Prototypes:



## Functions

- void [MCAL\\_I2C\\_Init \(I2C\\_TypeDef \\*I2Cx, S\\_I2C\\_Config\\_t \\*I2C\\_Init\\_Struct\)](#)  
*Initializes the I2C peripheral.*
- void [MCAL\\_I2C\\_Deinit \(I2C\\_TypeDef \\*I2Cx\)](#)  
*Deinitializes the I2C peripheral.*
- void [MCAL\\_I2C\\_Set\\_GPIO \(I2C\\_TypeDef \\*I2Cx\)](#)  
*Sets the GPIO configuration for I2C.*
- void [MCAL\\_I2C\\_Master\\_Tx \(I2C\\_TypeDef \\*I2Cx, uint16\\_t SlaveAdd, uint8\\_t \\*dataout, uint32\\_t datalen, StopCondition Stop, Repeated\\_Start start\)](#)  
*Transmits data from the master to the slave.*
- void [MCAL\\_I2C\\_Master\\_Rx \(I2C\\_TypeDef \\*I2Cx, uint16\\_t SlaveAdd, uint8\\_t \\*dataout, uint32\\_t datalen, StopCondition Stop, Repeated\\_Start start\)](#)  
*Receives data from the master.*
- void [MCAL\\_I2C\\_Slave\\_SendData \(I2C\\_TypeDef \\*I2Cx, uint8\\_t data\)](#)  
*Sends data from the slave.*
- uint8\_t [MCAL\\_I2C\\_SlaveReceiveData \(I2C\\_TypeDef \\*I2Cx\)](#)  
*Receives data in slave mode.*
- void [I2C\\_Generate\\_Start \(I2C\\_TypeDef \\*I2Cx, Functional\\_State state, Repeated\\_Start start\)](#)  
*Generates a start condition on the I2C bus.*
- FlagStatus [I2C\\_Get\\_FlagStatus \(I2C\\_TypeDef \\*I2Cx, Status flag\)](#)  
*Gets the status of a specific flag.*
- void [I2C\\_SendAddress \(I2C\\_TypeDef \\*I2Cx, uint16\\_t SlaveAddress, I2C\\_Direction I2C\\_Direction\)](#)  
*Sends an address to the I2C bus.*
- void [I2C\\_Generate\\_Stop \(I2C\\_TypeDef \\*I2Cx, Functional\\_State NewState\)](#)  
*Generates a stop condition on the I2C bus.*
- void [I2C\\_ACKnowledgeConfig \(I2C\\_TypeDef \\*I2Cx, Functional\\_State NewState\)](#)  
*Configures the I2C acknowledge feature.*

### 5.115.1 Detailed Description

### 5.115.2 Function Documentation

#### 5.115.2.1 I2C\_ACKnowledgeConfig()

```
void I2C_ACKnowledgeConfig (
    I2C_TypeDef * I2Cx,
    Functional_State NewState )
```

Configures the I2C acknowledge feature.

This function configures the acknowledge feature for the I2C bus.

#### Parameters

|    |                 |                                                        |
|----|-----------------|--------------------------------------------------------|
| in | <i>I2Cx</i>     | Pointer to the I2C peripheral (I2C1, I2C2, etc.).      |
| in | <i>NewState</i> | Specifies whether to enable or disable acknowledgment. |

Configures the I2C acknowledge feature.

This function enables or disables the acknowledgment feature of the I2C peripheral.

#### Parameters

|                 |                                                |
|-----------------|------------------------------------------------|
| <i>I2Cx</i>     | Pointer to the I2C peripheral instance.        |
| <i>NewState</i> | The state to enable or disable acknowledgment. |

#### 5.115.2.2 I2C\_Generate\_Start()

```
void I2C_Generate_Start (
    I2C_TypeDef * I2Cx,
    Functional_State state,
    Repeated_Start start )
```

Generates a start condition on the I2C bus.

This function generates a start condition on the I2C bus.

#### Parameters

|    |              |                                                             |
|----|--------------|-------------------------------------------------------------|
| in | <i>I2Cx</i>  | Pointer to the I2C peripheral (I2C1, I2C2, etc.).           |
| in | <i>state</i> | Specifies whether to enable or disable the start condition. |
| in | <i>start</i> | Specifies whether to generate a repeated start condition.   |

Generates a start condition on the I2C bus.

This function sets the START bit in the I2C\_CR1 register to generate a start condition. If the start condition is repeated, it waits for the I2C bus to be free before generating the start condition.

#### Parameters

|              |                                                           |
|--------------|-----------------------------------------------------------|
| <i>I2Cx</i>  | Pointer to the I2C peripheral instance.                   |
| <i>state</i> | The state to enable or disable the start condition.       |
| <i>start</i> | Indicates whether to generate a repeated start condition. |

### 5.115.2.3 I2C\_Generate\_Stop()

```
void I2C_Generate_Stop (
    I2C_TypeDef * I2Cx,
    Functional_State NewState )
```

Generates a stop condition on the I2C bus.

This function generates a stop condition on the I2C bus.

#### Parameters

|           |                 |                                                            |
|-----------|-----------------|------------------------------------------------------------|
| <i>in</i> | <i>I2Cx</i>     | Pointer to the I2C peripheral (I2C1, I2C2, etc.).          |
| <i>in</i> | <i>NewState</i> | Specifies whether to enable or disable the stop condition. |

This function sets the STOP bit in the I2C\_CR1 register to generate a stop condition.

#### Parameters

|                 |                                                    |
|-----------------|----------------------------------------------------|
| <i>I2Cx</i>     | Pointer to the I2C peripheral instance.            |
| <i>NewState</i> | The state to enable or disable the stop condition. |

### 5.115.2.4 I2C\_Get\_FlagStatus()

```
FlagStatus I2C_Get_FlagStatus (
    I2C_TypeDef * I2Cx,
    Status flag )
```

Gets the status of a specific flag.

This function checks the status of a specific I2C flag.

#### Parameters

|           |             |                                                   |
|-----------|-------------|---------------------------------------------------|
| <i>in</i> | <i>I2Cx</i> | Pointer to the I2C peripheral (I2C1, I2C2, etc.). |
| <i>in</i> | <i>flag</i> | The flag to check.                                |

**Returns**

The status of the flag (Set or Reset).

Gets the status of a specific flag.

This function returns the status of the specified I2C flag.

**Parameters**

|             |                                         |
|-------------|-----------------------------------------|
| <i>I2Cx</i> | Pointer to the I2C peripheral instance. |
| <i>flag</i> | The flag to check.                      |

**Returns**

FlagStatus The status of the specified flag (Set or Reset).

**5.115.2.5 I2C\_SendAddress()**

```
void I2C_SendAddress (
    I2C_TypeDef * I2Cx,
    uint16_t SlaveAddress,
    I2C_Direction Direction )
```

Sends an address to the I2C bus.

This function sends an address to the I2C bus.

**Parameters**

|           |                      |                                                               |
|-----------|----------------------|---------------------------------------------------------------|
| <i>in</i> | <i>I2Cx</i>          | Pointer to the I2C peripheral (I2C1, I2C2, etc.).             |
| <i>in</i> | <i>SlaveAddress</i>  | The address of the I2C slave.                                 |
| <i>in</i> | <i>I2C_Direction</i> | The direction of the data transfer (transmitter or receiver). |

Sends an address to the I2C bus.

This function sends the 7-bit slave address along with the read/write bit to the I2C peripheral.

**Parameters**

|                     |                                                       |
|---------------------|-------------------------------------------------------|
| <i>I2Cx</i>         | Pointer to the I2C peripheral instance.               |
| <i>SlaveAddress</i> | The 7-bit slave address to be sent.                   |
| <i>Direction</i>    | The direction of communication (transmit or receive). |

### 5.115.2.6 MCAL\_I2C\_Deinit()

```
void MCAL_I2C_Deinit (
    I2C_TypeDef * I2Cx )
```

Deinitializes the I2C peripheral.

This function deinitializes the I2C peripheral and resets it to its default state.

#### Parameters

|    |      |                                                   |
|----|------|---------------------------------------------------|
| in | I2Cx | Pointer to the I2C peripheral (I2C1, I2C2, etc.). |
|----|------|---------------------------------------------------|

Deinitializes the I2C peripheral.

#### Parameters

|      |                                               |
|------|-----------------------------------------------|
| I2Cx | Pointer to the I2C peripheral (I2C1 or I2C2). |
|------|-----------------------------------------------|

#### Return values

|      |  |
|------|--|
| None |  |
|------|--|

#### Note

This function disables the I2C peripheral and resets its configuration.

### 5.115.2.7 MCAL\_I2C\_Init()

```
void MCAL_I2C_Init (
    I2C_TypeDef * I2Cx,
    S_I2C_Config_t * I2C_Init_Struct )
```

Initializes the I2C peripheral.

This function initializes the I2C peripheral with the provided configuration.

#### Parameters

|    |                 |                                                                |
|----|-----------------|----------------------------------------------------------------|
| in | I2Cx            | Pointer to the I2C peripheral (I2C1, I2C2, etc.).              |
| in | I2C_Init_Struct | Pointer to the configuration structure for the I2C peripheral. |
|    | I2Cx            | Pointer to the I2C peripheral (I2C1 or I2C2).                  |
|    | I2C_Init_Struct | Pointer to the I2C initialization structure.                   |

#### Return values

|      |  |
|------|--|
| None |  |
|------|--|

**Note**

This function configures the I2C peripheral according to the specified parameters and enables the I2C peripheral.

**5.115.2.8 MCAL\_I2C\_Master\_Rx()**

```
void MCAL_I2C_Master_Rx (
    I2C_TypeDef * I2Cx,
    uint16_t SlaveAdd,
    uint8_t * dataout,
    uint32_t datalen,
    StopCondition Stop,
    Repeated_Start start )
```

Receives data from the master.

This function receives data from the I2C master.

**Parameters**

|     |                 |                                                           |
|-----|-----------------|-----------------------------------------------------------|
| in  | <i>I2Cx</i>     | Pointer to the I2C peripheral (I2C1, I2C2, etc.).         |
| in  | <i>SlaveAdd</i> | Address of the I2C slave.                                 |
| out | <i>dataout</i>  | Pointer to the buffer where received data will be stored. |
| in  | <i>datalen</i>  | Length of the data to be received.                        |
| in  | <i>Stop</i>     | Specifies whether to generate a stop condition.           |
| in  | <i>start</i>    | Specifies whether to generate a repeated start condition. |

Receives data from the master.

This function initiates a start condition, sends the address of the slave device for receiving, and then receives data. It supports optional stop conditions after the reception.

**Parameters**

|                 |                                                                 |
|-----------------|-----------------------------------------------------------------|
| <i>I2Cx</i>     | Pointer to the I2C peripheral instance.                         |
| <i>SlaveAdd</i> | The 7-bit address of the slave device.                          |
| <i>dataout</i>  | Pointer to the buffer where received data will be stored.       |
| <i>datalen</i>  | The number of data bytes to receive.                            |
| <i>Stop</i>     | Indicates whether to generate a stop condition after reception. |
| <i>start</i>    | Indicates whether to generate a repeated start condition.       |

**5.115.2.9 MCAL\_I2C\_Master\_Tx()**

```
void MCAL_I2C_Master_Tx (
    I2C_TypeDef * I2Cx,
```

```
    uint16_t SlaveAdd,
    uint8_t * dataout,
    uint32_t datalen,
    StopCondition Stop,
    Repeated_Start start )
```

Transmits data from the master to the slave.

This function sends data from the I2C master to a specified I2C slave.

#### Parameters

|    |                 |                                                           |
|----|-----------------|-----------------------------------------------------------|
| in | <i>I2Cx</i>     | Pointer to the I2C peripheral (I2C1, I2C2, etc.).         |
| in | <i>SlaveAdd</i> | Address of the I2C slave.                                 |
| in | <i>dataout</i>  | Pointer to the data to be transmitted.                    |
| in | <i>datalen</i>  | Length of the data to be transmitted.                     |
| in | <i>Stop</i>     | Specifies whether to generate a stop condition.           |
| in | <i>start</i>    | Specifies whether to generate a repeated start condition. |

Transmits data from the master to the slave.

This function initiates a start condition, sends the address of the slave device, and then transmits data. It supports optional repeated start conditions and the generation of a stop condition after the transmission.

#### Parameters

|                 |                                                                    |
|-----------------|--------------------------------------------------------------------|
| <i>I2Cx</i>     | Pointer to the I2C peripheral instance.                            |
| <i>SlaveAdd</i> | The 7-bit address of the slave device.                             |
| <i>dataout</i>  | Pointer to the data buffer to be transmitted.                      |
| <i>datalen</i>  | The number of data bytes to transmit.                              |
| <i>Stop</i>     | Indicates whether to generate a stop condition after transmission. |
| <i>start</i>    | Indicates whether to generate a repeated start condition.          |

### 5.115.2.10 MCAL\_I2C\_Set\_GPIO()

```
void MCAL_I2C_Set_GPIO (
    I2C_TypeDef * I2Cx )
```

Sets the GPIO configuration for I2C.

This function configures the GPIO pins associated with the I2C peripheral.

#### Parameters

|    |             |                                                   |
|----|-------------|---------------------------------------------------|
| in | <i>I2Cx</i> | Pointer to the I2C peripheral (I2C1, I2C2, etc.). |
|----|-------------|---------------------------------------------------|

Sets the GPIO configuration for I2C.

**Parameters**

|             |                                               |
|-------------|-----------------------------------------------|
| <i>I2Cx</i> | Pointer to the I2C peripheral (I2C1 or I2C2). |
|-------------|-----------------------------------------------|

**Return values**

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

**Note**

This function configures the GPIO pins associated with the I2C peripheral for alternate function mode, open-drain configuration, and the appropriate alternate function number.

**5.115.2.11 MCAL\_I2C\_Slave\_SendData()**

```
void MCAL_I2C_Slave_SendData (
    I2C_TypeDef * I2Cx,
    uint8_t data )
```

Sends data from the slave.

This function sends data from the I2C slave to the master.

**Parameters**

|    |             |                                                   |
|----|-------------|---------------------------------------------------|
| in | <i>I2Cx</i> | Pointer to the I2C peripheral (I2C1, I2C2, etc.). |
| in | <i>data</i> | Data to be sent by the slave.                     |

Sends data from the slave.

This function sends a byte of data from the I2C slave device.

**Parameters**

|             |                                         |
|-------------|-----------------------------------------|
| <i>I2Cx</i> | Pointer to the I2C peripheral instance. |
| <i>data</i> | The byte of data to be sent.            |

**5.115.2.12 MCAL\_I2C\_SlaveReceiveData()**

```
uint8_t MCAL_I2C_SlaveReceiveData (
    I2C_TypeDef * I2Cx )
```

Receives data in slave mode.

This function receives data from the I2C master in slave mode.

**Parameters**

|    |             |                                                   |
|----|-------------|---------------------------------------------------|
| in | <i>I2Cx</i> | Pointer to the I2C peripheral (I2C1, I2C2, etc.). |
|----|-------------|---------------------------------------------------|

**Returns**

The received data.

Receives data in slave mode.

This function receives a byte of data from the I2C slave device.

**Parameters**

|             |                                         |
|-------------|-----------------------------------------|
| <i>I2Cx</i> | Pointer to the I2C peripheral instance. |
|-------------|-----------------------------------------|

**Returns**

`uint8_t` The received byte of data.

## 5.116 NVIC Driver

NVIC driver APIs for STM32F401xx MCU.

Collaboration diagram for NVIC Driver:



## Modules

- [NVIC Register Definitions](#)  
*Macros for accessing NVIC registers.*
- [NVIC Configuration Macros](#)
- [Interrupt Status](#)
- [Priority Groups](#)
- [Interrupt Priorities](#)
- [Interrupt Requests](#)
- [API Function Prototypes](#)
- [NVIC IRQ Enable/Disable Macros](#)

*Macros for enabling and disabling NVIC IRQ for different peripherals.*

### 5.116.1 Detailed Description

NVIC driver APIs for STM32F401xx MCU.

## 5.117 NVIC Register Definitions

Macros for accessing NVIC registers.

Collaboration diagram for NVIC Register Definitions:



### Macros

- `#define NVIC_ISER0 (*(volatile uint32_t *) (NVIC_BASE + 0x0))`  
*Interrupt Set Enable Register 0 (ISER0) Used to enable interrupts 0 to 31. Write a 1 to the corresponding bit position to enable an interrupt.*
- `#define NVIC_ISER1 (*(volatile uint32_t *) (NVIC_BASE + 0x4))`  
*Interrupt Set Enable Register 1 (ISER1) Used to enable interrupts 32 to 63. Write a 1 to the corresponding bit position to enable an interrupt.*
- `#define NVIC_ISER2 (*(volatile uint32_t *) (NVIC_BASE + 0x8))`  
*Interrupt Set Enable Register 2 (ISER2) Used to enable interrupts 64 to 95. Write a 1 to the corresponding bit position to enable an interrupt.*
- `#define NVIC_ICER0 (*(volatile uint32_t *) (NVIC_BASE + 0x80))`  
*Interrupt Clear Enable Register 0 (ICER0) Used to disable interrupts 0 to 31. Write a 1 to the corresponding bit position to disable an interrupt.*
- `#define NVIC_ICER1 (*(volatile uint32_t *) (NVIC_BASE + 0x84))`  
*Interrupt Clear Enable Register 1 (ICER1) Used to disable interrupts 32 to 63. Write a 1 to the corresponding bit position to disable an interrupt.*
- `#define NVIC_ICER2 (*(volatile uint32_t *) (NVIC_BASE + 0x88))`  
*Interrupt Clear Enable Register 2 (ICER2) Used to disable interrupts 64 to 95. Write a 1 to the corresponding bit position to disable an interrupt.*

### 5.117.1 Detailed Description

Macros for accessing NVIC registers.

## 5.118 NVIC Configuration Macros

Collaboration diagram for NVIC Configuration Macros:



## Macros

- #define **SCB\_VECTKEY** 0x05FA0000UL  
*Vector key for setting priority grouping in NVIC.*
- #define **SCB\_VECTKEY\_MASK** 0xFFFF0000UL  
*Mask for vector key.*
- #define **NVIC\_PRIGROUP\_SET\_MASK** 0x700UL  
*Mask for setting NVIC priority grouping.*
- #define **NVIC\_PRIGROUP\_CLEAR\_MASK** 0xFFFFF8FFUL  
*Mask for clearing NVIC priority grouping.*

### 5.118.1 Detailed Description

## 5.119 Interrupt Status

Collaboration diagram for Interrupt Status:



## Macros

- #define **NVIC\_INTERRUPT\_ACTIVE** 1UL  
*Status indicating an active interrupt.*
- #define **NVIC\_INTERRUPT\_INACTIVE** 0UL  
*Status indicating an inactive interrupt.*

### 5.119.1 Detailed Description

## 5.120 Priority Groups

Collaboration diagram for Priority Groups:



## Macros

- `#define NVIC_PRIO_16GRP_0SUBGRP 0x300U`  
*Priority grouping configuration for 16 groups and 0 subgroups.*
- `#define NVIC_PRIO_8GRP_2SUBGRP 0x400U`  
*Priority grouping configuration for 8 groups and 2 subgroups.*
- `#define NVIC_PRIO_4GRP_4SUBGRP 0x500U`  
*Priority grouping configuration for 4 groups and 4 subgroups.*
- `#define NVIC_PRIO_2GRP_8SUBGRP 0x600U`  
*Priority grouping configuration for 2 groups and 8 subgroups.*
- `#define NVIC_PRIO_0GRP_8SUBGRP 0x700U`  
*Priority grouping configuration for 0 groups and 8 subgroups.*

### 5.120.1 Detailed Description

## 5.121 Interrupt Priorities

Collaboration diagram for Interrupt Priorities:



## Macros

- `#define NVIC_PRIO_0000 0x00U`  
*Priority level 0.*
- `#define NVIC_PRIO_0001 0x10U`  
*Priority level 1.*
- `#define NVIC_PRIO_0010 0x20U`  
*Priority level 2.*
- `#define NVIC_PRIO_0011 0x30U`  
*Priority level 3.*
- `#define NVIC_PRIO_0100 0x40U`  
*Priority level 4.*
- `#define NVIC_PRIO_0101 0x50U`  
*Priority level 5.*
- `#define NVIC_PRIO_0110 0x60U`  
*Priority level 6.*
- `#define NVIC_PRIO_0111 0x70U`  
*Priority level 7.*
- `#define NVIC_PRIO_1000 0x80U`  
*Priority level 8.*

- #define `NVIC_PRIO_1001` 0x90U  
*Priority level 9.*
- #define `NVIC_PRIO_1010` 0xA0U  
*Priority level 10.*
- #define `NVIC_PRIO_1011` 0xB0U  
*Priority level 11.*
- #define `NVIC_PRIO_1100` 0xC0U  
*Priority level 12.*
- #define `NVIC_PRIO_1101` 0xD0U  
*Priority level 13.*
- #define `NVIC_PRIO_1110` 0xE0U  
*Priority level 14.*
- #define `NVIC_PRIO_1111` 0xF0U  
*Priority level 15.*

### 5.121.1 Detailed Description

## 5.122 Interrupt Requests

Collaboration diagram for Interrupt Requests:



## Macros

- #define `EXTI0_IRQ` 6  
*External Interrupt Request 0.*
- #define `EXTI1_IRQ` 7  
*External Interrupt Request 1.*
- #define `EXTI2_IRQ` 8  
*External Interrupt Request 2.*
- #define `EXTI3_IRQ` 9  
*External Interrupt Request 3.*
- #define `EXTI4_IRQ` 10  
*External Interrupt Request 4.*
- #define `EXTI5_IRQ` 23  
*External Interrupt Request 5.*
- #define `EXTI6_IRQ` 23  
*External Interrupt Request 6.*
- #define `EXTI7_IRQ` 23  
*External Interrupt Request 7.*

- #define `EXTI8_IRQ` 23  
*External Interrupt Request 8.*
- #define `EXTI9_IRQ` 23  
*External Interrupt Request 9.*
- #define `EXTI10_IRQ` 40  
*External Interrupt Request 10.*
- #define `EXTI11_IRQ` 40  
*External Interrupt Request 11.*
- #define `EXTI12_IRQ` 40  
*External Interrupt Request 12.*
- #define `EXTI13_IRQ` 40  
*External Interrupt Request 13.*
- #define `EXTI14_IRQ` 40  
*External Interrupt Request 14.*
- #define `EXTI15_IRQ` 40  
*External Interrupt Request 15.*
- #define `USART1_IRQ` 37  
*USART1 Interrupt Request.*
- #define `USART2_IRQ` 38  
*USART2 Interrupt Request.*
- #define `USART6_IRQ` 71  
*USART6 Interrupt Request.*
- #define `SPI1_IRQ` 35  
*SPI1 Interrupt Request.*
- #define `SPI2_IRQ` 36  
*SPI2 Interrupt Request.*
- #define `I2C1_EV_IRQ` 31  
*I2C1 Event Interrupt Request.*
- #define `I2C1_ER_IRQ` 32  
*I2C1 Error Interrupt Request.*
- #define `I2C2_EV_IRQ` 33  
*I2C2 Event Interrupt Request.*
- #define `I2C2_ER_IRQ` 34  
*I2C2 Error Interrupt Request.*

### 5.122.1 Detailed Description

## 5.123 API Function Prototypes

Collaboration diagram for API Function Prototypes:



## Functions

- void [MCAL\\_NVIC\\_SetPriorityGrouping](#) (`uint32 priority_grouping`)
 

*Set the priority grouping for the NVIC.*
- `uint32 MCAL_NVIC_GetPriorityGrouping` (`void`)
 

*Get the current priority grouping configuration of the NVIC.*
- void [MCAL\\_NVIC\\_EnableIRQ](#) (`uint8 IRQn`)
 

*Enable a specified IRQ.*
- void [MCAL\\_NVIC\\_DisableIRQ](#) (`uint8 IRQn`)
 

*Disable a specified IRQ.*
- `uint8 MCAL_NVIC_GetPendingIRQ` (`uint8 IRQn`)
 

*Get the pending status of a specified IRQ.*
- void [MCAL\\_NVIC\\_SetPendingIRQ](#) (`uint8 IRQn`)
 

*Set the pending status of a specified IRQ.*
- void [MCAL\\_NVIC\\_ClearPendingIRQ](#) (`uint8 IRQn`)
 

*Clear the pending status of a specified IRQ.*
- `uint8 MCAL_NVIC_GetActive` (`uint8 IRQn`)
 

*Get the active status of a specified IRQ.*
- void [MCAL\\_NVIC\\_SetPriority](#) (`uint8 IRQn, uint8 priority`)
 

*Set the priority of a specified IRQ.*
- `uint8 MCAL_NVIC_GetPriority` (`uint8 IRQn`)
 

*Retrieves the priority level of a specified IRQn.*
- void [MCAL\\_NVIC\\_SystemReset](#) (`void`)
 

*Performs a system reset.*

### 5.123.1 Detailed Description

### 5.123.2 Function Documentation

#### 5.123.2.1 MCAL\_NVIC\_ClearPendingIRQ()

```
void MCAL_NVIC_ClearPendingIRQ (
    uint8 IRQn )
```

Clear the pending status of a specified IRQ.

##### Parameters

|                   |                                                                                     |
|-------------------|-------------------------------------------------------------------------------------|
| <code>IRQn</code> | IRQ number to clear pending status as defined in <a href="#">Interrupt Requests</a> |
|-------------------|-------------------------------------------------------------------------------------|

##### Returns

None

Clear the pending status of a specified IRQ.

**Parameters**

|             |                                                                                                                  |
|-------------|------------------------------------------------------------------------------------------------------------------|
| <i>IRQn</i> | Number of interrupt request as defined in vector table or in <a href="#">Interrupt_Requests_Numbers_define</a> . |
|-------------|------------------------------------------------------------------------------------------------------------------|

**Returns**

None

**Note**

None

**5.123.2.2 MCAL\_NVIC\_DisableIRQ()**

```
void MCAL_NVIC_DisableIRQ (
    uint8 IRQn )
```

Disable a specified IRQ.

**Parameters**

|             |                                                                        |
|-------------|------------------------------------------------------------------------|
| <i>IRQn</i> | IRQ number to disable as defined in <a href="#">Interrupt Requests</a> |
|-------------|------------------------------------------------------------------------|

**Returns**

None

Disable a specified IRQ.

**Parameters**

|             |                                                                                                                  |
|-------------|------------------------------------------------------------------------------------------------------------------|
| <i>IRQn</i> | Number of interrupt request as defined in vector table or in <a href="#">Interrupt_Requests_Numbers_define</a> . |
|-------------|------------------------------------------------------------------------------------------------------------------|

**Returns**

None

**Note**

None

**5.123.2.3 MCAL\_NVIC\_EnableIRQ()**

```
void MCAL_NVIC_EnableIRQ (
    uint8 IRQn )
```

Enable a specified IRQ.

**Parameters**

|             |                                                                       |
|-------------|-----------------------------------------------------------------------|
| <i>IRQn</i> | IRQ number to enable as defined in <a href="#">Interrupt Requests</a> |
|-------------|-----------------------------------------------------------------------|

**Returns**

None

Enable a specified IRQ.

**Parameters**

|             |                                                                                                                  |
|-------------|------------------------------------------------------------------------------------------------------------------|
| <i>IRQn</i> | Number of interrupt request as defined in vector table or in <a href="#">Interrupt_Requests_Numbers_define</a> . |
|-------------|------------------------------------------------------------------------------------------------------------------|

**Returns**

None

**Note**

None

#### 5.123.2.4 MCAL\_NVIC\_GetActive()

```
uint8 MCAL_NVIC_GetActive (
    uint8 IRQn )
```

Get the active status of a specified IRQ.

**Parameters**

|             |                                                                      |
|-------------|----------------------------------------------------------------------|
| <i>IRQn</i> | IRQ number to check as defined in <a href="#">Interrupt Requests</a> |
|-------------|----------------------------------------------------------------------|

**Returns**

1 if IRQ is active, 0 otherwise

Get the active status of a specified IRQ.

**Parameters**

|             |                                                                                                                  |
|-------------|------------------------------------------------------------------------------------------------------------------|
| <i>IRQn</i> | Number of interrupt request as defined in vector table or in <a href="#">Interrupt_Requests_Numbers_define</a> . |
|-------------|------------------------------------------------------------------------------------------------------------------|

**Returns**

1 if IRQn is active, 0 otherwise.

**Note**

None

### 5.123.2.5 MCAL\_NVIC\_GetPendingIRQ()

```
uint8 MCAL_NVIC_GetPendingIRQ (
    uint8 IRQn )
```

Get the pending status of a specified IRQ.

**Parameters**

|             |                                                                      |
|-------------|----------------------------------------------------------------------|
| <i>IRQn</i> | IRQ number to check as defined in <a href="#">Interrupt Requests</a> |
|-------------|----------------------------------------------------------------------|

**Returns**

1 if IRQ is pending, 0 otherwise

Get the pending status of a specified IRQ.

**Parameters**

|             |                                                                                                                  |
|-------------|------------------------------------------------------------------------------------------------------------------|
| <i>IRQn</i> | Number of interrupt request as defined in vector table or in <a href="#">Interrupt_Requests_Numbers_define</a> . |
|-------------|------------------------------------------------------------------------------------------------------------------|

**Returns**

1 if IRQn is pending, 0 otherwise.

**Note**

None

### 5.123.2.6 MCAL\_NVIC\_GetPriority()

```
uint8 MCAL_NVIC_GetPriority (
    uint8 IRQn )
```

Retrieves the priority level of a specified IRQn.

This function reads the priority level assigned to the interrupt request number (IRQn). The priority value returned should be one of the defined values in [Interrupt\\_Priorities\\_define](#).

**Parameters**

|     |             |                                                                                                                    |
|-----|-------------|--------------------------------------------------------------------------------------------------------------------|
| in  | <i>IRQn</i> | The interrupt request number as defined in the vector table or in <code>Interrupt_Requests_Numbers_define</code> . |
| out | <i>None</i> |                                                                                                                    |

**Returns**

`uint8` The priority value for the specified IRQn.

**Note**

None

Retrieves the priority level of a specified IRQn.

**Parameters**

|             |                                                                                                               |
|-------------|---------------------------------------------------------------------------------------------------------------|
| <i>IRQn</i> | Number of interrupt request as defined in vector table or in <code>Interrupt_Requests_Numbers_define</code> . |
|-------------|---------------------------------------------------------------------------------------------------------------|

**Returns**

Priority level of the interrupt.

**Note**

None

**5.123.2.7 MCAL\_NVIC\_GetPriorityGrouping()**

```
uint32 MCAL_NVIC_GetPriorityGrouping (
    void )
```

Get the current priority grouping configuration of the NVIC.

**Returns**

Current priority grouping configuration as defined in [Priority Groups](#)

Get the current priority grouping configuration of the NVIC.

**Returns**

Configuration of priority grouping as defined in `priority_groups_define`.

**Note**

None

### 5.123.2.8 MCAL\_NVIC\_SetPendingIRQ()

```
void MCAL_NVIC_SetPendingIRQ (
    uint8 IRQn )
```

Set the pending status of a specified IRQ.

**Parameters**

|             |                                                                               |
|-------------|-------------------------------------------------------------------------------|
| <i>IRQn</i> | IRQ number to set as pending as defined in <a href="#">Interrupt Requests</a> |
|-------------|-------------------------------------------------------------------------------|

**Returns**

None

Set the pending status of a specified IRQ.

**Parameters**

|             |                                                                                                                  |
|-------------|------------------------------------------------------------------------------------------------------------------|
| <i>IRQn</i> | Number of interrupt request as defined in vector table or in <a href="#">Interrupt_Requests_Numbers_define</a> . |
|-------------|------------------------------------------------------------------------------------------------------------------|

**Returns**

None

**Note**

None

**5.123.2.9 MCAL\_NVIC\_SetPriority()**

```
void MCAL_NVIC_SetPriority (
    uint8 IRQn,
    uint8 priority )
```

Set the priority of a specified IRQ.

**Parameters**

|                 |                                                                                           |
|-----------------|-------------------------------------------------------------------------------------------|
| <i>IRQn</i>     | IRQ number for which to set the priority as defined in <a href="#">Interrupt Requests</a> |
| <i>priority</i> | Priority level to set as defined in <a href="#">Interrupt Priorities</a>                  |

**Returns**

None

Set the priority of a specified IRQ.

**Parameters**

|                 |                                                                                                                  |
|-----------------|------------------------------------------------------------------------------------------------------------------|
| <i>IRQn</i>     | Number of interrupt request as defined in vector table or in <a href="#">Interrupt_Requests_Numbers_define</a> . |
| <i>priority</i> | Priority level of the interrupt as defined in <a href="#">Interrupt_Priorities_define</a> .                      |

**Returns**

None

**Note**

None

**5.123.2.10 MCAL\_NVIC\_SetPriorityGrouping()**

```
void MCAL_NVIC_SetPriorityGrouping (
    uint32 priority_grouping )
```

Set the priority grouping for the NVIC.

**Parameters**

|                          |                                                                               |
|--------------------------|-------------------------------------------------------------------------------|
| <i>priority_grouping</i> | Priority grouping configuration as defined in <a href="#">Priority Groups</a> |
|--------------------------|-------------------------------------------------------------------------------|

**Returns**

None

Set the priority grouping for the NVIC.

**Parameters**

|                          |                                                                                        |
|--------------------------|----------------------------------------------------------------------------------------|
| <i>priority_grouping</i> | Configuration of priority grouping as defined in <code>priority_groups_define</code> . |
|--------------------------|----------------------------------------------------------------------------------------|

**Returns**

None

**Note**

None

**5.123.2.11 MCAL\_NVIC\_SystemReset()**

```
void MCAL_NVIC_SystemReset (
    void )
```

Performs a system reset.

This function resets the entire system. It does not alter the priority grouping configuration.

**Parameters**

|     |             |  |
|-----|-------------|--|
| in  | <i>None</i> |  |
| out | <i>None</i> |  |

**Returns**

None

**Note**

The priority groups remain unchanged after the system reset.

**Parameters**

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

**Returns**

None

**Note**

Keeps priority grouping configuration unchanged.

## 5.124 NVIC IRQ Enable/Disable Macros

Macros for enabling and disabling NVIC IRQ for different peripherals.

Collaboration diagram for NVIC IRQ Enable/Disable Macros:



### Macros

- #define NVIC\_IRQ6\_EXTI0\_Enable (NVIC\_ISER0 |= (1<<6))
- #define NVIC\_IRQ7\_EXTI1\_Enable (NVIC\_ISER0 |= (1<<7))
- #define NVIC\_IRQ8\_EXTI2\_Enable (NVIC\_ISER0 |= (1<<8))
- #define NVIC\_IRQ9\_EXTI3\_Enable (NVIC\_ISER0 |= (1<<9))
- #define NVIC\_IRQ10\_EXTI4\_Enable (NVIC\_ISER0 |= (1<<10))

- #define NVIC\_IRQ23\_EXTI5\_9\_Enable (NVIC\_ISERO |= (1<<23))
- #define NVIC\_IRQ40\_EXTI10\_15\_Enable (NVIC\_ISER1 |= (1<<8))
- #define NVIC\_IRQ6\_EXTI0\_Disable (NVIC\_ICERO |= (1<<6))
- #define NVIC\_IRQ7\_EXTI1\_Disable (NVIC\_ICERO |= (1<<7))
- #define NVIC\_IRQ8\_EXTI2\_Disable (NVIC\_ICERO |= (1<<8))
- #define NVIC\_IRQ9\_EXTI3\_Disable (NVIC\_ICERO |= (1<<9))
- #define NVIC\_IRQ10\_EXTI4\_Disable (NVIC\_ICERO |= (1<<10))
- #define NVIC\_IRQ23\_EXTI5\_9\_Disable (NVIC\_ICERO |= (1<<23))
- #define **NVIC\_IRQ40\_EXTI10\_15\_Disable** (NVIC\_ICER1 |= (1<<8))
- #define NVIC\_IRQ37\_USART1\_Enable (NVIC\_ISER1 |= 1<<(USART1\_IRQ - 32))
- #define NVIC\_IRQ38\_USART2\_Enable (NVIC\_ISER1 |= 1<<(USART2\_IRQ - 32))
- #define NVIC\_IRQ39\_USART3\_Enable (NVIC\_ISER1 |= 1<<(USART3\_IRQ - 32))
- #define NVIC\_IRQ37\_USART1\_Disable (NVIC\_ICER1 |= 1<<(USART1\_IRQ - 32))
- #define NVIC\_IRQ38\_USART2\_Disable (NVIC\_ICER1 |= 1<<(USART2\_IRQ - 32))
- #define **NVIC\_IRQ39\_USART3\_Disable** (NVIC\_ICER1 |= 1<<(USART3\_IRQ - 32))
- #define NVIC\_IRQ35\_SPI1\_Enable (NVIC\_ISER1 |= 1<<(SPI1\_IRQ - 32))
- #define NVIC\_IRQ36\_SPI2\_Enable (NVIC\_ISER1 |= 1<<(SPI2\_IRQ - 32))
- #define NVIC\_IRQ35\_SPI1\_Disable (NVIC\_ICER1 &= ~ (1<<(SPI1\_IRQ - 32)))
- #define **NVIC\_IRQ36\_SPI2\_Disable** (NVIC\_ICER1 &= ~ (1<<(SPI2\_IRQ - 32)))
- #define NVIC\_IRQ31\_I2C1\_EV\_Enable (NVIC\_ISER0 |= 1<<(I2C1\_EV\_IRQ))
- #define NVIC\_IRQ32\_I2C1\_ER\_Enable (NVIC\_ISER1 |= 1<<(I2C1\_ER\_IRQ - 32))
- #define NVIC\_IRQ33\_I2C2\_EV\_Enable (NVIC\_ISER1 |= 1<<(I2C2\_EV\_IRQ - 32))
- #define NVIC\_IRQ34\_I2C2\_ER\_Enable (NVIC\_ISER1 |= 1<<(I2C2\_ER\_IRQ - 32))
- #define NVIC\_IRQ31\_I2C1\_EV\_Disable (NVIC\_ICER0 &= ~ (1<<(I2C1\_EV\_IRQ)))
- #define NVIC\_IRQ32\_I2C1\_ER\_Disable (NVIC\_ICER1 &= ~ (1<<(I2C1\_ER\_IRQ - 32)))
- #define NVIC\_IRQ33\_I2C2\_EV\_Disable (NVIC\_ICER1 &= ~ (1<<(I2C2\_EV\_IRQ - 32)))
- #define **NVIC\_IRQ34\_I2C2\_ER\_Disable** (NVIC\_ICER1 &= ~ (1<<(I2C2\_ER\_IRQ - 32)))

### 5.124.1 Detailed Description

Macros for enabling and disabling NVIC IRQ for different peripherals.

These macros are used to enable or disable NVIC IRQ for EXTI, USART, SPI, and I2C peripherals.

### 5.124.2 Macro Definition Documentation

#### 5.124.2.1 NVIC\_IRQ10\_EXTI4\_Disable

```
#define NVIC_IRQ10_EXTI4_Disable (NVIC_ICERO |= (1<<10))
```

Disable EXTI Line 5 to 9 interrupt (clear bit 23 in NVIC\_ICER0 register).

#### 5.124.2.2 NVIC\_IRQ10\_EXTI4\_Enable

```
#define NVIC_IRQ10_EXTI4_Enable (NVIC_ISER0 |= (1<<10))
```

Enable EXTI Line 5 to 9 interrupt (set bit 23 in NVIC\_ISER0 register).

### 5.124.2.3 NVIC IRQ23 EXTI5\_9 Disable

```
#define NVIC_IRQ23_EXTI5_9_Disable (NVIC_ICERO |= (1<<23))
```

Disable EXTI Line 10 to 15 interrupt (clear bit 8 in NVIC\_ICER1 register).

### 5.124.2.4 NVIC IRQ23 EXTI5\_9 Enable

```
#define NVIC_IRQ23_EXTI5_9_Enable (NVIC_ISERO |= (1<<23))
```

Enable EXTI Line 10 to 15 interrupt (set bit 8 in NVIC\_ISER1 register).

### 5.124.2.5 NVIC IRQ31\_I2C1\_EV Disable

```
#define NVIC_IRQ31_I2C1_EV_Disable (NVIC_ICERO &= ~(1<<(I2C1_EV_IRQ)))
```

Disable I2C1 error interrupt (clear bit in NVIC\_ICER1 for I2C1\_ER\_IRQ).

### 5.124.2.6 NVIC IRQ31\_I2C1\_EV Enable

```
#define NVIC_IRQ31_I2C1_EV_Enable (NVIC_ISERO |= 1<<(I2C1_EV_IRQ))
```

< Enable I2C1 event interrupt (set bit in NVIC\_ISER0 for I2C1\_EV\_IRQ). Enable I2C1 error interrupt (set bit in NVIC\_ISER1 for I2C1\_ER\_IRQ).

### 5.124.2.7 NVIC IRQ32\_I2C1\_ER Disable

```
#define NVIC_IRQ32_I2C1_ER_Disable (NVIC_ICER1 &= ~(1<<(I2C1_ER_IRQ - 32)))
```

Disable I2C2 event interrupt (clear bit in NVIC\_ICER1 for I2C2\_EV\_IRQ).

### 5.124.2.8 NVIC IRQ32\_I2C1\_ER Enable

```
#define NVIC_IRQ32_I2C1_ER_Enable (NVIC_ISER1 |= 1<<(I2C1_ER_IRQ - 32))
```

Enable I2C2 event interrupt (set bit in NVIC\_ISER1 for I2C2\_EV\_IRQ).

### 5.124.2.9 NVIC IRQ33\_I2C2\_EV Disable

```
#define NVIC_IRQ33_I2C2_EV_Disable (NVIC_ICER1 &= ~(1<<(I2C2_EV_IRQ - 32)))
```

Disable I2C2 error interrupt (clear bit in NVIC\_ICER1 for I2C2\_ER\_IRQ).

### 5.124.2.10 NVIC\_IRQ33\_I2C2\_EV\_Enable

```
#define NVIC_IRQ33_I2C2_EV_Enable (NVIC_ISER1 |= 1<<(I2C2_EV_IRQ - 32))
```

Enable I2C2 error interrupt (set bit in NVIC\_ISER1 for I2C2\_ER\_IRQ).

### 5.124.2.11 NVIC\_IRQ34\_I2C2\_ER\_Enable

```
#define NVIC_IRQ34_I2C2_ER_Enable (NVIC_ISER1 |= 1<<(I2C2_ER_IRQ - 32))
```

Disable I2C1 event interrupt (clear bit in NVIC\_ICER0 for I2C1\_EV\_IRQ).

### 5.124.2.12 NVIC\_IRQ35\_SPI1\_Disable

```
#define NVIC_IRQ35_SPI1_Disable (NVIC_ICER1 &= ~ (1<<(SPI1_IRQ - 32)))
```

Disable SPI2 interrupt (clear bit in NVIC\_ICER1 for SPI2 IRQ).

### 5.124.2.13 NVIC\_IRQ35\_SPI1\_Enable

```
#define NVIC_IRQ35_SPI1_Enable (NVIC_ISER1 |= 1<<(SPI1_IRQ - 32))
```

< Enable SPI1 interrupt (set bit in NVIC\_ISER1 for SPI1 IRQ). Enable SPI2 interrupt (set bit in NVIC\_ISER1 for SPI2 IRQ).

### 5.124.2.14 NVIC\_IRQ36\_SPI2\_Enable

```
#define NVIC_IRQ36_SPI2_Enable (NVIC_ISER1 |= 1<<(SPI2_IRQ - 32))
```

Disable SPI1 interrupt (clear bit in NVIC\_ICER1 for SPI1 IRQ).

### 5.124.2.15 NVIC\_IRQ37\_USART1\_Disable

```
#define NVIC_IRQ37_USART1_Disable (NVIC_ICER1 |= 1<<(USART1_IRQ - 32))
```

Disable USART2 interrupt (clear bit in NVIC\_ICER1 for USART2 IRQ).

### 5.124.2.16 NVIC\_IRQ37\_USART1\_Enable

```
#define NVIC_IRQ37_USART1_Enable (NVIC_ISER1 |= 1<<(USART1_IRQ - 32))
```

< Enable USART1 interrupt (set bit in NVIC\_ISER1 for USART1 IRQ). Enable USART2 interrupt (set bit in NVIC\_ISER1 for USART2 IRQ).

### 5.124.2.17 NVIC\_IRQ38\_USART2\_Disable

```
#define NVIC_IRQ38_USART2_Disable (NVIC_ICER1 |= 1<<(USART2_IRQ - 32))
```

Disable USART3 interrupt (clear bit in NVIC\_ICER1 for USART3 IRQ).

### 5.124.2.18 NVIC\_IRQ38\_USART2\_Enable

```
#define NVIC_IRQ38_USART2_Enable (NVIC_ISER1 |= 1<<(USART2_IRQ - 32))
```

Enable USART3 interrupt (set bit in NVIC\_ISER1 for USART3 IRQ).

### 5.124.2.19 NVIC\_IRQ39\_USART3\_Enable

```
#define NVIC_IRQ39_USART3_Enable (NVIC_ISER1 |= 1<<(USART3_IRQ - 32))
```

Disable USART1 interrupt (clear bit in NVIC\_ICER1 for USART1 IRQ).

### 5.124.2.20 NVIC\_IRQ40\_EXTI10\_15\_Enable

```
#define NVIC_IRQ40_EXTI10_15_Enable (NVIC_ISER1 |= (1<<8))
```

Disable EXTI Line 0 interrupt (clear bit 6 in NVIC\_ICER0 register).

### 5.124.2.21 NVIC\_IRQ6\_EXTI0\_Disable

```
#define NVIC_IRQ6_EXTI0_Disable (NVIC_ICERO |= (1<<6))
```

Disable EXTI Line 1 interrupt (clear bit 7 in NVIC\_ICER0 register).

### 5.124.2.22 NVIC\_IRQ6\_EXTI0\_Enable

```
#define NVIC_IRQ6_EXTI0_Enable (NVIC_ISERO |= (1<<6))
```

< Enable EXTI Line 0 interrupt (set bit 6 in NVIC\_ISER0 register). Enable EXTI Line 1 interrupt (set bit 7 in NVIC\_ISER0 register).

### 5.124.2.23 NVIC\_IRQ7\_EXTI1\_Disable

```
#define NVIC_IRQ7_EXTI1_Disable (NVIC_ICERO |= (1<<7))
```

Disable EXTI Line 2 interrupt (clear bit 8 in NVIC\_ICER0 register).

#### 5.124.2.24 NVIC\_IRQ7\_EXTI1\_Enable

```
#define NVIC_IRQ7_EXTI1_Enable (NVIC_ISER0 |= (1<<7))
```

Enable EXTI Line 2 interrupt (set bit 8 in NVIC\_ISER0 register).

#### 5.124.2.25 NVIC\_IRQ8\_EXTI2\_Disable

```
#define NVIC_IRQ8_EXTI2_Disable (NVIC_ICER0 |= (1<<8))
```

Disable EXTI Line 3 interrupt (clear bit 9 in NVIC\_ICER0 register).

#### 5.124.2.26 NVIC\_IRQ8\_EXTI2\_Enable

```
#define NVIC_IRQ8_EXTI2_Enable (NVIC_ISER0 |= (1<<8))
```

Enable EXTI Line 3 interrupt (set bit 9 in NVIC\_ISER0 register).

#### 5.124.2.27 NVIC\_IRQ9\_EXTI3\_Disable

```
#define NVIC_IRQ9_EXTI3_Disable (NVIC_ICER0 |= (1<<9))
```

Disable EXTI Line 4 interrupt (clear bit 10 in NVIC\_ICER0 register).

#### 5.124.2.28 NVIC\_IRQ9\_EXTI3\_Enable

```
#define NVIC_IRQ9_EXTI3_Enable (NVIC_ISER0 |= (1<<9))
```

Enable EXTI Line 4 interrupt (set bit 10 in NVIC\_ISER0 register).

## 5.125 RCC Driver

RCC driver APIs for STM32F401xx MCU.

Collaboration diagram for RCC Driver:



## Modules

- [Clock Source Selection](#)
- [Peripheral Selection](#)
- [API Function Prototypes](#)

### 5.125.1 Detailed Description

RCC driver APIs for STM32F401xx MCU.

## 5.126 Clock Source Selection

Collaboration diagram for Clock Source Selection:



## Macros

- [#define RCC\\_PLLCFGR\\_PLLSRC\\_HSE \(\(uint32\\_t\)0x00400000\)](#)
- [#define HSI\\_VALUE 16000000U](#)
- [#define HSE\\_VALUE 8000000U](#)
- [#define HSI\\_RC\\_CLK 8000000UL](#)
- [#define HSE\\_CLK 8000000UL](#)
- [#define RCC\\_SELECT\\_HSI \(\(uint8\\_t\)0x00\)](#)
- [#define RCC\\_SELECT\\_HSE \(\(uint8\\_t\)0x01\)](#)
- [#define RCC\\_SELECT\\_PLL \(\(uint8\\_t\)0x02\)](#)

### 5.126.1 Detailed Description

### 5.126.2 Macro Definition Documentation

#### 5.126.2.1 HSE\_CLK

```
#define HSE_CLK 8000000UL
```

External Oscillator Clock Source (8 MHz)

### 5.126.2.2 HSE\_VALUE

```
#define HSE_VALUE 8000000U
```

External High-Speed Oscillator frequency (8 MHz)

### 5.126.2.3 HSI\_RC\_CLK

```
#define HSI_RC_CLK 8000000UL
```

RC Clock Source (8 MHz)

### 5.126.2.4 HSI\_VALUE

```
#define HSI_VALUE 16000000U
```

Internal High-Speed Oscillator frequency (16 MHz)

### 5.126.2.5 RCC\_PLLCFGR\_PLLSRC\_HSE

```
#define RCC_PLLCFGR_PLLSRC_HSE ((uint32_t)0x00400000)
```

PLL source is HSE (High-Speed External)

### 5.126.2.6 RCC\_SELECT\_HSE

```
#define RCC_SELECT_HSE ((uint8_t)0x01)
```

Select HSE as clock source

### 5.126.2.7 RCC\_SELECT\_HSI

```
#define RCC_SELECT_HSI ((uint8_t)0x00)
```

Select HSI as clock source

### 5.126.2.8 RCC\_SELECT\_PLL

```
#define RCC_SELECT_PLL ((uint8_t)0x02)
```

Select PLL as clock source

## 5.127 Peripheral Selection

Collaboration diagram for Peripheral Selection:



### Macros

- #define RCC\_GPIOA ((uint8\_t)0x00)
- #define RCC\_GPIOB ((uint8\_t)0x01)
- #define RCC\_GPIOC ((uint8\_t)0x02)
- #define RCC\_GPIOD ((uint8\_t)0x03)
- #define RCC\_GPIOE ((uint8\_t)0x04)
- #define RCC\_USART1 ((uint8\_t)0x08)
- #define RCC\_USART2 ((uint8\_t)0x09)
- #define RCC\_USART6 ((uint8\_t)0xA)
- #define RCC\_SPI1 ((uint8\_t)0xB)
- #define RCC\_SPI2 ((uint8\_t)0xC)
- #define RCC\_I2C1 ((uint8\_t)0xD)
- #define RCC\_I2C2 ((uint8\_t)0xE)
- #define RCC\_CRC ((uint8\_t)0xF)
- #define RCC\_TIM2 ((uint8\_t)0x10)
- #define RCC\_SYSCFG ((uint8\_t)0x11)

### 5.127.1 Detailed Description

### 5.127.2 Macro Definition Documentation

#### 5.127.2.1 RCC\_CRC

```
#define RCC_CRC ((uint8_t)0x0F)
```

CRC Peripheral

#### 5.127.2.2 RCC\_GPIOA

```
#define RCC_GPIOA ((uint8_t)0x00)
```

GPIOA Peripheral

**5.127.2.3 RCC\_GPIOB**

```
#define RCC_GPIOB ((uint8_t)0x01)
```

GPIOB Peripheral

**5.127.2.4 RCC\_GPIOC**

```
#define RCC_GPIOC ((uint8_t)0x02)
```

GPIOC Peripheral

**5.127.2.5 RCC\_GPIOD**

```
#define RCC_GPIOD ((uint8_t)0x03)
```

GPIOD Peripheral

**5.127.2.6 RCC\_GPIOE**

```
#define RCC_GPIOE ((uint8_t)0x04)
```

GPIOE Peripheral

**5.127.2.7 RCC\_I2C1**

```
#define RCC_I2C1 ((uint8_t)0x0D)
```

I2C1 Peripheral

**5.127.2.8 RCC\_I2C2**

```
#define RCC_I2C2 ((uint8_t)0x0E)
```

I2C2 Peripheral

**5.127.2.9 RCC\_SPI1**

```
#define RCC_SPI1 ((uint8_t)0x0B)
```

SPI1 Peripheral

**5.127.2.10 RCC\_SPI2**

```
#define RCC_SPI2 ((uint8_t)0x0C)
```

SPI2 Peripheral

### 5.127.2.11 RCC\_SYSCFG

```
#define RCC_SYSCFG ((uint8_t)0x11)
```

SYSCFG Peripheral

### 5.127.2.12 RCC\_TIM2

```
#define RCC_TIM2 ((uint8_t)0x10)
```

TIM2 Peripheral

### 5.127.2.13 RCC\_USART1

```
#define RCC_USART1 ((uint8_t)0x08)
```

USART1 Peripheral

### 5.127.2.14 RCC\_USART2

```
#define RCC_USART2 ((uint8_t)0x09)
```

USART2 Peripheral

### 5.127.2.15 RCC\_USART6

```
#define RCC_USART6 ((uint8_t)0x0A)
```

USART6 Peripheral

## 5.128 API Function Prototypes

Collaboration diagram for API Function Prototypes:



## Functions

- void [MCAL\\_RCC\\_Select\\_Clock](#) (uint8\_t clock)  
*Select the clock source for the MCU.*
- void [MCAL\\_RCC\\_Enable\\_Peripheral](#) (uint8\_t peripheral)  
*Enable the clock for a specific peripheral.*
- void [MCAL\\_RCC\\_Reset\\_Peripheral](#) (uint8\_t peripheral)  
*Reset a specific peripheral.*
- uint32\_t [MCAL\\_RCC\\_GetSYS\\_CLKFreq](#) (void)  
*Get the frequency of the system clock.*
- uint32\_t [MCAL\\_RCC\\_GetHCLKFreq](#) (void)  
*Get the frequency of the AHB bus clock.*
- uint32\_t [MCAL\\_RCC\\_GetPCLK1Freq](#) (void)  
*Get the frequency of the APB1 bus clock.*
- uint32\_t [MCAL\\_RCC\\_GetPCLK2Freq](#) (void)  
*Get the frequency of the APB2 bus clock.*
- uint32\_t [RCC\\_GetPLLOutputClock](#) (void)  
*Get the frequency of the PLL (Phase-Locked Loop) output clock.*

### 5.128.1 Detailed Description

### 5.128.2 Function Documentation

#### 5.128.2.1 MCAL\_RCC\_Enable\_Peripheral()

```
void MCAL_RCC_Enable_Peripheral (
    uint8_t peripheral )
```

Enable the clock for a specific peripheral.

This function enables the clock for the specified peripheral.

##### Parameters

|    |                   |                                                                            |
|----|-------------------|----------------------------------------------------------------------------|
| in | <i>peripheral</i> | Peripheral to enable, as defined in <a href="#">Peripheral Selection</a> . |
|----|-------------------|----------------------------------------------------------------------------|

##### Returns

None

#### 5.128.2.2 MCAL\_RCC\_GetHCLKFreq()

```
uint32_t MCAL_RCC_GetHCLKFreq (
    void )
```

Get the frequency of the AHB bus clock.

This function retrieves the frequency of the AHB (Advanced High-performance Bus) clock.

#### Returns

Frequency of the AHB bus clock in Hertz.

Get the frequency of the AHB bus clock.

This function calculates and returns the frequency of the AHB bus clock (HCLK) in Hz.

#### Parameters

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

#### Returns

Frequency of the AHB bus clock in Hz.

### 5.128.2.3 MCAL\_RCC\_GetPCLK1Freq()

```
uint32_t MCAL_RCC_GetPCLK1Freq (
    void )
```

Get the frequency of the APB1 bus clock.

This function retrieves the frequency of the APB1 (Advanced Peripheral Bus 1) clock.

#### Returns

Frequency of the APB1 bus clock in Hertz.

Get the frequency of the APB1 bus clock.

This function calculates and returns the frequency of the APB1 bus clock (PCLK1) in Hz.

#### Parameters

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

#### Returns

Frequency of the APB1 bus clock in Hz.

#### 5.128.2.4 MCAL\_RCC\_GetPCLK2Freq()

```
uint32_t MCAL_RCC_GetPCLK2Freq (
    void )
```

Get the frequency of the APB2 bus clock.

This function retrieves the frequency of the APB2 (Advanced Peripheral Bus 2) clock.

##### Returns

Frequency of the APB2 bus clock in Hertz.

Get the frequency of the APB2 bus clock.

This function calculates and returns the frequency of the APB2 bus clock (PCLK2) in Hz.

##### Parameters

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

##### Returns

Frequency of the APB2 bus clock in Hz.

#### 5.128.2.5 MCAL\_RCC\_GetSYS\_CLKFreq()

```
uint32_t MCAL_RCC_GetSYS_CLKFreq (
    void )
```

Get the frequency of the system clock.

This function retrieves the frequency of the system clock (SYSCLK).

##### Returns

Frequency of the system clock in Hertz.

Get the frequency of the system clock.

This function calculates and returns the frequency of the system clock (SYSCLK) in Hz.

##### Parameters

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

Frequency of the system clock in Hz.

### 5.128.2.6 MCAL\_RCC\_Reset\_Peripheral()

```
void MCAL_RCC_Reset_Peripheral (
    uint8_t peripheral )
```

Reset a specific peripheral.

This function resets the specified peripheral.

**Parameters**

|    |                   |                                                                           |
|----|-------------------|---------------------------------------------------------------------------|
| in | <i>peripheral</i> | Peripheral to reset, as defined in <a href="#">Peripheral Selection</a> . |
|----|-------------------|---------------------------------------------------------------------------|

**Returns**

None

### 5.128.2.7 MCAL\_RCC\_Select\_Clock()

```
void MCAL_RCC_Select_Clock (
    uint8_t clock )
```

Select the clock source for the MCU.

This function configures the clock source used by the microcontroller.

**Parameters**

|    |              |                                                                                |
|----|--------------|--------------------------------------------------------------------------------|
| in | <i>clock</i> | Clock source to select, as defined in <a href="#">Clock Source Selection</a> . |
|----|--------------|--------------------------------------------------------------------------------|

**Returns**

None

### 5.128.2.8 RCC\_GetPLLOutputClock()

```
uint32_t RCC_GetPLLOutputClock (
    void )
```

Get the frequency of the PLL (Phase-Locked Loop) output clock.

This function calculates and returns the frequency of the PLL output clock.

**Returns**

Frequency of the PLL output clock in Hertz.

This function calculates and returns the frequency of the PLL output clock.

**Returns**

The PLL output clock frequency in Hertz.

## 5.129 SPI Driver

SPI driver APIs for STM32F401xx MCU.

Collaboration diagram for SPI Driver:



## Modules

- SPI Mode Definitions
- SPI Communication Mode Definitions
- SPI Payload Length Definitions
- SPI Frame Format Definitions
- SPI Clock Polarity Definitions
- SPI Clock Phase Definitions
- SPI NSS Definitions
- SPI Prescaler Definitions
- SPI IRQ Enable Definitions
- API Function Prototypes

## Classes

- struct [S\\_IRQ\\_SRC](#)  
*Structure to identify the source of SPI interrupts.*
- struct [S\\_SPI\\_Config\\_t](#)  
*Configuration structure for SPI.*

## Enumerations

- enum [SPI\\_PollingMechanism](#) { Enabled , Disabled }
- Enumeration for SPI polling mechanisms.*

### 5.129.1 Detailed Description

SPI driver APIs for STM32F401xx MCU.

### 5.129.2 Enumeration Type Documentation

#### 5.129.2.1 SPI\_PollingMechanism

enum [SPI\\_PollingMechanism](#)

Enumeration for SPI polling mechanisms.

##### Enumerator

|          |                     |
|----------|---------------------|
| Enabled  | Polling is enabled  |
| Disabled | Polling is disabled |

## 5.130 SPI Mode Definitions

Collaboration diagram for SPI Mode Definitions:



### Macros

- `#define SPI_Mode_Master (0x1<<2)`
- `#define SPI_Mode_Slave (0x00000000U)`

#### 5.130.1 Detailed Description

#### 5.130.2 Macro Definition Documentation

##### 5.130.2.1 SPI\_Mode\_Master

```
#define SPI_Mode_Master (0x1<<2)
```

SPI master mode

##### 5.130.2.2 SPI\_Mode\_Slave

```
#define SPI_Mode_Slave (0x00000000U)
```

SPI slave mode

## 5.131 SPI Communication Mode Definitions

Collaboration diagram for SPI Communication Mode Definitions:



## Macros

- #define SPI\_Direction\_2lines (0x00000000U)
- #define SPI\_Direction\_2lines\_RX\_Only (0x1<<10)
- #define SPI\_Direction\_1line\_Receive\_only (0x1<<15)
- #define SPI\_Direction\_1line\_Transmit\_only ((0x1<<15)|(0x1<<14))

### 5.131.1 Detailed Description

### 5.131.2 Macro Definition Documentation

#### 5.131.2.1 SPI\_Direction\_1line\_Receive\_only

```
#define SPI_Direction_1line_Receive_only (0x1<<15)
```

1-line receive only mode

#### 5.131.2.2 SPI\_Direction\_1line\_Transmit\_only

```
#define SPI_Direction_1line_Transmit_only ((0x1<<15)|(0x1<<14))
```

1-line transmit only mode

#### 5.131.2.3 SPI\_Direction\_2lines

```
#define SPI_Direction_2lines (0x00000000U)
```

2-line communication mode

#### 5.131.2.4 SPI\_Direction\_2lines\_RX\_Only

```
#define SPI_Direction_2lines_RX_Only (0x1<<10)
```

2-line RX only mode

## 5.132 SPI Payload Length Definitions

Collaboration diagram for SPI Payload Length Definitions:



## Macros

- `#define SPI_Payload_Length_8bit (0x00000000U)`
- `#define SPI_Payload_Length_16bit (0x1<<11)`

### 5.132.1 Detailed Description

### 5.132.2 Macro Definition Documentation

#### 5.132.2.1 SPI\_Payload\_Length\_16bit

```
#define SPI_Payload_Length_16bit (0x1<<11)
```

16-bit payload length

#### 5.132.2.2 SPI\_Payload\_Length\_8bit

```
#define SPI_Payload_Length_8bit (0x00000000U)
```

8-bit payload length

## 5.133 SPI Frame Format Definitions

Collaboration diagram for SPI Frame Format Definitions:



## Macros

- `#define SPI_Frame_Format_MSB (0x00000000U)`
- `#define SPI_Frame_Format_LSB (0x1<<7)`

### 5.133.1 Detailed Description

### 5.133.2 Macro Definition Documentation

### 5.133.2.1 SPI\_Frame\_Format\_LSB

```
#define SPI_Frame_Format_LSB (0x1<<7)
```

LSB first frame format

### 5.133.2.2 SPI\_Frame\_Format\_MSB

```
#define SPI_Frame_Format_MSB (0x00000000U)
```

MSB first frame format

## 5.134 SPI Clock Polarity Definitions

Collaboration diagram for SPI Clock Polarity Definitions:



### Macros

- #define SPI\_Clock\_Polarity\_Low\_Idle (0x00000000U)
- #define SPI\_Clock\_Polarity\_High\_Idle (0x1<<1)

### 5.134.1 Detailed Description

### 5.134.2 Macro Definition Documentation

#### 5.134.2.1 SPI\_Clock\_Polarity\_High\_Idle

```
#define SPI_Clock_Polarity_High_Idle (0x1<<1)
```

Clock polarity idle high

### 5.134.2.2 SPI\_Clock\_Polarity\_Low\_Idle

```
#define SPI_Clock_Polarity_Low_Idle (0x00000000U)
```

Clock polarity idle low

## 5.135 SPI Clock Phase Definitions

Collaboration diagram for SPI Clock Phase Definitions:



### Macros

- `#define SPI_Clock_Phase_Leading (0x00000000U)`
- `#define SPI_Clock_Phase_Trailing (0x1)`

### 5.135.1 Detailed Description

### 5.135.2 Macro Definition Documentation

#### 5.135.2.1 SPI\_Clock\_Phase\_Leading

```
#define SPI_Clock_Phase_Leading (0x00000000U)
```

Clock phase leading edge

#### 5.135.2.2 SPI\_Clock\_Phase\_Trailing

```
#define SPI_Clock_Phase_Trailing (0x1)
```

Clock phase trailing edge

## 5.136 SPI NSS Definitions

Collaboration diagram for SPI NSS Definitions:



### Macros

- #define SPI\_NSS\_Hard\_Slave (0x00000000U)
- #define SPI\_NSS\_Hard\_Master\_SS\_Output\_Enable (0x1<<2)
- #define SPI\_NSS\_Hard\_Master\_SS\_No\_output (0x00000000U)
- #define SPI\_NSS\_Internal\_Soft\_Reset (0x1<<9)
- #define SPI\_NSS\_Internal\_Soft\_Set ((0x1<<9)|(0x1<<8))

#### 5.136.1 Detailed Description

#### 5.136.2 Macro Definition Documentation

##### 5.136.2.1 SPI\_NSS\_Hard\_Master\_SS\_No\_output

```
#define SPI_NSS_Hard_Master_SS_No_output (0x00000000U)
```

NSS managed by hardware in master mode with SS output disabled

##### 5.136.2.2 SPI\_NSS\_Hard\_Master\_SS\_Output\_Enable

```
#define SPI_NSS_Hard_Master_SS_Output_Enable (0x1<<2)
```

NSS managed by hardware in master mode with SS output enabled

##### 5.136.2.3 SPI\_NSS\_Hard\_Slave

```
#define SPI_NSS_Hard_Slave (0x00000000U)
```

NSS managed by hardware in slave mode

#### 5.136.2.4 SPI\_NSS\_Internal\_Soft\_Reset

```
#define SPI_NSS_Internal_Soft_Reset (0x1<<9)
```

NSS managed by software with internal reset

#### 5.136.2.5 SPI\_NSS\_Internal\_Soft\_Set

```
#define SPI_NSS_Internal_Soft_Set ((0x1<<9)|(0x1<<8))
```

NSS managed by software with internal set

## 5.137 SPI Prescaler Definitions

Collaboration diagram for SPI Prescaler Definitions:



### Macros

- #define SPI\_Prescaler\_By2 (0x00000000U)
- #define SPI\_Prescaler\_By4 (0b001<<3)
- #define SPI\_Prescaler\_By8 (0b010<<3)
- #define SPI\_Prescaler\_By16 (0b011<<3)
- #define SPI\_Prescaler\_By32 (0b100<<3)
- #define SPI\_Prescaler\_By64 (0b101<<3)
- #define SPI\_Prescaler\_By128 (0b110<<3)
- #define SPI\_Prescaler\_By256 (0b111<<3)

### 5.137.1 Detailed Description

### 5.137.2 Macro Definition Documentation

#### 5.137.2.1 SPI\_Prescaler\_By128

```
#define SPI_Prescaler_By128 (0b110<<3)
```

SPI prescaler divided by 128

### 5.137.2.2 SPI\_Prescaler\_By16

```
#define SPI_Prescaler_By16 (0b011<<3)
```

SPI prescaler divided by 16

### 5.137.2.3 SPI\_Prescaler\_By2

```
#define SPI_Prescaler_By2 (0x00000000U)
```

SPI prescaler divided by 2

### 5.137.2.4 SPI\_Prescaler\_By256

```
#define SPI_Prescaler_By256 (0b111<<3)
```

SPI prescaler divided by 256

### 5.137.2.5 SPI\_Prescaler\_By32

```
#define SPI_Prescaler_By32 (0b100<<3)
```

SPI prescaler divided by 32

### 5.137.2.6 SPI\_Prescaler\_By4

```
#define SPI_Prescaler_By4 (0b001<<3)
```

SPI prescaler divided by 4

### 5.137.2.7 SPI\_Prescaler\_By64

```
#define SPI_Prescaler_By64 (0b101<<3)
```

SPI prescaler divided by 64

### 5.137.2.8 SPI\_Prescaler\_By8

```
#define SPI_Prescaler_By8 (0b010<<3)
```

SPI prescaler divided by 8

## 5.138 SPI IRQ Enable Definitions

Collaboration diagram for SPI IRQ Enable Definitions:



### Macros

- #define SPI\_IRQ\_Enable\_None (uint32\_t)(0)
- #define SPI\_IRQ\_Enable\_Tx\_Only (uint32\_t)(1<<7)
- #define SPI\_IRQ\_Enable\_Rx\_Only (uint32\_t)(1<<6)
- #define SPI\_IRQ\_Enable\_Err (uint32\_t)(1<<5)

#### 5.138.1 Detailed Description

#### 5.138.2 Macro Definition Documentation

##### 5.138.2.1 SPI\_IRQ\_Enable\_Err

```
#define SPI_IRQ_Enable_Err (uint32_t) (1<<5)
```

Enable Error interrupt

##### 5.138.2.2 SPI\_IRQ\_Enable\_None

```
#define SPI_IRQ_Enable_None (uint32_t) (0)
```

No IRQ enabled

##### 5.138.2.3 SPI\_IRQ\_Enable\_Rx\_Only

```
#define SPI_IRQ_Enable_Rx_Only (uint32_t) (1<<6)
```

Enable RX interrupt

#### 5.138.2.4 SPI\_IRQ\_Enable\_Tx\_Only

```
#define SPI_IRQ_Enable_Tx_Only (uint32_t)(1<<7)
```

Enable TX interrupt

### 5.139 API Function Prototypes

Collaboration diagram for API Function Prototypes:



### Functions

- void [MCAL\\_SPI\\_Init](#) (SPI\_TypeDef \*SPIx, [S\\_SPI\\_Config\\_t](#) \*Config)  
*Initializes the SPI peripheral according to the specified configuration.*
- void [MCAL\\_SPI\\_DeInit](#) (SPI\_TypeDef \*SPIx)  
*Deinitializes the SPI peripheral.*
- void [MCAL\\_SPI\\_GPIO\\_Set\\_Pins](#) (SPI\_TypeDef \*SPIx)  
*Configures the GPIO pins used for SPI communication.*
- void [MCAL\\_SPI\\_SendData](#) (SPI\_TypeDef \*SPIx, uint16\_t \*pTXBuffer, enum [SPI\\_PollingMechanism](#) Polling\_En)  
*Sends data through SPI.*
- void [MCAL\\_SPI\\_ReceiveData](#) (SPI\_TypeDef \*SPIx, uint16\_t \*pRXBuffer, enum [SPI\\_PollingMechanism](#) Polling\_En)  
*Receives data from SPI.*
- void [MCAL\\_SPI\\_Tx\\_Rx](#) (SPI\_TypeDef \*SPIx, uint16\_t \*TX\_RX\_pBuffer, enum [SPI\\_PollingMechanism](#) Polling\_En)  
*Transmits and receives data through SPI.*

#### 5.139.1 Detailed Description

#### 5.139.2 Function Documentation

##### 5.139.2.1 MCAL\_SPI\_DeInit()

```
void MCAL_SPI_DeInit (
    SPI_TypeDef * SPIx )
```

Deinitializes the SPI peripheral.

**Parameters**

|             |                                                      |
|-------------|------------------------------------------------------|
| <i>SPIx</i> | Pointer to the SPI peripheral register base address. |
|-------------|------------------------------------------------------|

This function resets the SPI peripheral and disables its interrupt.

**Parameters**

|    |             |                                                               |
|----|-------------|---------------------------------------------------------------|
| in | <i>SPIx</i> | Pointer to the SPI peripheral (SPI1 or SPI2) to deinitialize. |
|----|-------------|---------------------------------------------------------------|

**Return values**

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

**Note**

This function disables the SPI peripheral clock and IRQ.

### 5.139.2.2 MCAL\_SPI\_GPIO\_Set\_Pins()

```
void MCAL_SPI_GPIO_Set_Pins (   
    SPI_TypeDef * SPIx )
```

Configures the GPIO pins used for SPI communication.

**Parameters**

|             |                                                      |
|-------------|------------------------------------------------------|
| <i>SPIx</i> | Pointer to the SPI peripheral register base address. |
|-------------|------------------------------------------------------|

Configures the GPIO pins used for SPI communication.

This function configures the necessary GPIO pins for SPI communication (NSS, SCK, MISO, MOSI) according to the selected SPI peripheral (SPI1 or SPI2) and the device mode (Master or Slave).

**Parameters**

|    |             |                                               |
|----|-------------|-----------------------------------------------|
| in | <i>SPIx</i> | Pointer to the SPI peripheral (SPI1 or SPI2). |
|----|-------------|-----------------------------------------------|

**Note**

This function sets the alternate function for the pins used in SPI communication.

**Return values**

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

### 5.139.2.3 MCAL\_SPI\_Init()

```
void MCAL_SPI_Init (
    SPI_TypeDef * SPIx,
    S_SPI_Config_t * Config )
```

Initializes the SPI peripheral according to the specified configuration.

#### Parameters

|               |                                                      |
|---------------|------------------------------------------------------|
| <i>SPIx</i>   | Pointer to the SPI peripheral register base address. |
| <i>Config</i> | Pointer to the SPI configuration structure.          |

Initializes the SPI peripheral according to the specified configuration.

This function configures the SPI peripheral according to the provided configuration.

#### Parameters

|    |               |                                                             |
|----|---------------|-------------------------------------------------------------|
| in | <i>SPIx</i>   | Pointer to the SPI peripheral (SPI1 or SPI2) to initialize. |
| in | <i>Config</i> | Pointer to the SPI configuration structure.                 |

#### Return values

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

#### Note

This function enables the SPI peripheral clock and configures the SPI registers according to the specified settings.

```
< Temporary register for SPI CR1 configuration
< Temporary register for SPI CR2 configuration
< Enable SPI bit in CR1
< Set device mode (Master/Slave)
< Set communication mode (Full Duplex/Transmit/Receive)
< Set frame format (MSB/LSB)
< Set payload length (8-bit/16-bit)
< Set clock polarity
< Set clock phase
< Set SPI prescaler
```

### 5.139.2.4 MCAL\_SPI\_ReceiveData()

```
void MCAL_SPI_ReceiveData (
    SPI_TypeDef * SPIx,
    uint16_t * pRXBuffer,
    enum SPI_PollingMechanism Polling_En )
```

Receives data from SPI.

#### Parameters

|                   |                                                           |
|-------------------|-----------------------------------------------------------|
| <i>SPIx</i>       | Pointer to the SPI peripheral register base address.      |
| <i>pRXBuffer</i>  | Pointer to the buffer where received data will be stored. |
| <i>Polling_En</i> | Specifies whether polling is enabled or disabled.         |

Receives data from SPI.

This function receives data from the SPI peripheral. It can operate in polling mode or non-polling mode.

#### Parameters

|    |                   |                                                                    |
|----|-------------------|--------------------------------------------------------------------|
| in | <i>SPIx</i>       | Pointer to the SPI peripheral (SPI1 or SPI2) to use for reception. |
| in | <i>pRXBuffer</i>  | Pointer to the buffer where received data will be stored.          |
| in | <i>Polling_En</i> | Indicates whether polling is enabled or not.                       |

#### Return values

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

#### Note

In polling mode, the function waits until the RXNE flag is set before reading data from the data register.

< Wait until RXNE flag is set

< Receive data

### 5.139.2.5 MCAL\_SPI\_SendData()

```
void MCAL_SPI_SendData (
    SPI_TypeDef * SPIx,
    uint16_t * pTXBuffer,
    enum SPI_PollingMechanism Polling_En )
```

Sends data through SPI.

#### Parameters

|                   |                                                              |
|-------------------|--------------------------------------------------------------|
| <i>SPIx</i>       | Pointer to the SPI peripheral register base address.         |
| <i>pTXBuffer</i>  | Pointer to the buffer containing the data to be transmitted. |
| <i>Polling_En</i> | Specifies whether polling is enabled or disabled.            |

Sends data through SPI.

This function transmits data via the SPI peripheral. It can operate in polling mode or non-polling mode.

#### Parameters

|    |                   |                                                                       |
|----|-------------------|-----------------------------------------------------------------------|
| in | <i>SPIx</i>       | Pointer to the SPI peripheral (SPI1 or SPI2) to use for transmission. |
| in | <i>pTXBuffer</i>  | Pointer to the data buffer to transmit.                               |
| in | <i>Polling_En</i> | Indicates whether polling is enabled or not.                          |

#### Return values

|             |  |
|-------------|--|
| <i>None</i> |  |
|-------------|--|

#### Note

In polling mode, the function waits until the TXE flag is set before writing data to the data register.

< Wait until TXE flag is set

< Send data

### 5.139.2.6 MCAL\_SPI\_Tx\_Rx()

```
void MCAL_SPI_Tx_Rx (
    SPI_TypeDef * SPIx,
    uint16_t * TX_RX_pBuffer,
    enum SPI_PollingMechanism Polling_En )
```

Transmits and receives data through SPI.

#### Parameters

|                      |                                                                                                 |
|----------------------|-------------------------------------------------------------------------------------------------|
| <i>SPIx</i>          | Pointer to the SPI peripheral register base address.                                            |
| <i>TX_RX_pBuffer</i> | Pointer to the buffer containing data to be transmitted and where received data will be stored. |
| <i>Polling_En</i>    | Specifies whether polling is enabled or disabled.                                               |

Transmits and receives data through SPI.

This function handles the transmission and reception of data through the specified SPI peripheral. It writes data to the SPI data register and waits for the transmission and reception to complete.

#### Parameters

|         |                      |                                                              |
|---------|----------------------|--------------------------------------------------------------|
| in      | <i>SPIx</i>          | Pointer to the SPI peripheral (SPI1 or SPI2).                |
| in, out | <i>TX_RX_pBuffer</i> | Pointer to the data buffer for transmission and reception.   |
| in      | <i>Polling_En</i>    | Specifies whether polling should be used (Enabled/Disabled). |

Return values

None

## 5.140 SYSTICK Driver

SYSTICK driver APIs for STM32F401xx MCU.

Collaboration diagram for SYSTICK Driver:



### Modules

- SysTick Interrupt Configuration
- SysTick Clock Configuration
- SysTick Running Mode Configuration
- API Function Prototypes

### Classes

- struct [STK\\_config\\_t](#)  
*SysTick Configuration Structure Definition.*

### Macros

- #define [STK\\_INTERRUPT\\_MASK](#) 0x02UL  
*Interrupt enable/disable mask for the SysTick timer.*
- #define [STK\\_CLK\\_MASK](#) 0x04UL  
*Clock source mask for the SysTick timer.*
- #define [STK\\_RELOAD\\_MASK](#) 0x00FFFFFFUL  
*Reload value mask for the SysTick timer.*
- #define [STK\\_FCPU](#) 80000000UL  
*CPU frequency definition for the SysTick timer.*

### 5.140.1 Detailed Description

SYSTICK driver APIs for STM32F401xx MCU.

### 5.140.2 Macro Definition Documentation

#### 5.140.2.1 STK\_FCPU

```
#define STK_FCPU 80000000UL
```

CPU frequency definition for the SysTick timer.

8 MHz CPU frequency

## 5.141 SysTick Interrupt Configuration

Collaboration diagram for SysTick Interrupt Configuration:



### Macros

- #define STK\_INTERRUPT\_ENABLED 0x02UL
- #define STK\_INTERRUPT\_DISABLED 0x00UL

### 5.141.1 Detailed Description

### 5.141.2 Macro Definition Documentation

#### 5.141.2.1 STK\_INTERRUPT\_DISABLED

```
#define STK_INTERRUPT_DISABLED 0x00UL
```

Disable SysTick interrupt

### 5.141.2.2 STK\_INTERRUPT\_ENABLED

```
#define STK_INTERRUPT_ENABLED 0x02UL
```

Enable SysTick interrupt

## 5.142 SysTick Clock Configuration

Collaboration diagram for SysTick Clock Configuration:



### Macros

- `#define STK_CLK_AHB 0x04UL`
- `#define STK_CLK_AHB_8 0x00UL`

### 5.142.1 Detailed Description

### 5.142.2 Macro Definition Documentation

#### 5.142.2.1 STK\_CLK\_AHB

```
#define STK_CLK_AHB 0x04UL
```

SysTick clock sourced from AHB

#### 5.142.2.2 STK\_CLK\_AHB\_8

```
#define STK_CLK_AHB_8 0x00UL
```

SysTick clock sourced from AHB/8

## 5.143 SysTick Running Mode Configuration

Collaboration diagram for SysTick Running Mode Configuration:



### Macros

- `#define STK_PERIODIC_MODE 0x01U`
- `#define STK_ONE_SHOT_MODE 0x00U`

#### 5.143.1 Detailed Description

#### 5.143.2 Macro Definition Documentation

##### 5.143.2.1 STK\_ONE\_SHOT\_MODE

```
#define STK_ONE_SHOT_MODE 0x00U
```

One-shot mode for SysTick

##### 5.143.2.2 STK\_PERIODIC\_MODE

```
#define STK_PERIODIC_MODE 0x01U
```

Periodic mode for SysTick

## 5.144 API Function Prototypes

Collaboration diagram for API Function Prototypes:



## Functions

- void **MCAL\_STK\_Config** (**STK\_config\_t** \*\_cfg)  
*Configures the SysTick timer with the specified parameters.*
- void **MCAL\_STK\_SetReload** (**uint32** value)  
*Sets the reload value for the SysTick timer.*
- void **MCAL\_STK\_SetCallback** (**void(\*pfCallback)(void)**)  
*Sets the callback function for the SysTick timer interrupt.*
- void **MCAL\_STK\_StartTimer** ()  
*Starts the SysTick timer.*
- void **MCAL\_STK\_StopTimer** ()  
*Stops the SysTick timer.*
- void **MCAL\_STK\_Delay** (**uint32** delay\_ticks)  
*Delays the system by a specified number of ticks using the SysTick timer.*
- void **MCAL\_STK\_Delay1ms** (**uint32** delay\_ms)  
*Delays the system by a specified number of milliseconds.*

### 5.144.1 Detailed Description

### 5.144.2 Function Documentation

#### 5.144.2.1 MCAL\_STK\_Config()

```
void MCAL_STK_Config (
    STK_config_t * _cfg )
```

Configures the SysTick timer with the specified parameters.

This function configures the SysTick timer's clock source, interrupt settings, and reload value based on the input configuration structure.

#### Parameters

|    |      |                                                                         |
|----|------|-------------------------------------------------------------------------|
| in | _cfg | Pointer to the configuration structure containing the SysTick settings. |
|----|------|-------------------------------------------------------------------------|

#### Returns

None

#### Note

The SysTick timer is stopped when this function is called. It must be re-enabled manually.

Configures the SysTick timer with the specified parameters.

This function initializes the SysTick timer based on the provided configuration. It sets up the clock source, interrupt enable status, reload value, and callback function if interrupts are enabled.

**Parameters**

|    |      |                                                                  |
|----|------|------------------------------------------------------------------|
| in | _cfg | Pointer to a struct containing SysTick configuration parameters. |
|----|------|------------------------------------------------------------------|

**Returns**

None

**Note**

This function stops the timer; you need to re-enable it after configuration.

**5.144.2.2 MCAL\_STK\_Delay()**

```
void MCAL_STK_Delay (
    uint32 delay_ticks )
```

Delays the system by a specified number of ticks using the SysTick timer.

This function uses the SysTick timer to generate a delay for a specified number of ticks. After the delay, the timer configuration and reload value are restored.

**Parameters**

|    |             |                               |
|----|-------------|-------------------------------|
| in | delay_ticks | The number of ticks to delay. |
|----|-------------|-------------------------------|

**Returns**

None

Delays the system by a specified number of ticks using the SysTick timer.

This function generates a delay based on the number of SysTick timer ticks specified. It temporarily disables the SysTick timer, sets the reload value, and waits for the timer to expire before restoring the previous configuration.

**Parameters**

|    |             |                           |
|----|-------------|---------------------------|
| in | delay_ticks | Number of ticks to delay. |
|----|-------------|---------------------------|

**Returns**

None

### 5.144.2.3 MCAL\_STK\_Delay1ms()

```
void MCAL_STK_Delay1ms (
    uint32 delay_ms )
```

Delays the system by a specified number of milliseconds.

This function generates a delay for the specified number of milliseconds using the SysTick timer. The user must define the system frequency (stk\_cpu\_freq\_define) to ensure accurate delays.

#### Parameters

|    |                 |                                      |
|----|-----------------|--------------------------------------|
| in | <i>delay_ms</i> | The number of milliseconds to delay. |
|----|-----------------|--------------------------------------|

#### Returns

None

Delays the system by a specified number of milliseconds.

This function generates a delay of the specified number of milliseconds by repeatedly calling MCAL\_STK\_Delay for each millisecond.

#### Parameters

|    |                 |                                  |
|----|-----------------|----------------------------------|
| in | <i>delay_ms</i> | Number of milliseconds to delay. |
|----|-----------------|----------------------------------|

#### Returns

None

#### Note

The user must define the frequency of the SysTick timer in stk\_cpu\_freq\_define.

### 5.144.2.4 MCAL\_STK\_SetCallback()

```
void MCAL_STK_SetCallback (
    void(*)(void) pfCallback )
```

Sets the callback function for the SysTick timer interrupt.

This function assigns a user-defined callback function that will be executed when the SysTick interrupt is triggered.

#### Parameters

|    |                   |                                                                       |
|----|-------------------|-----------------------------------------------------------------------|
| in | <i>pfCallback</i> | Pointer to the callback function to be executed on SysTick interrupt. |
|----|-------------------|-----------------------------------------------------------------------|

**Returns**

None

This function allows the user to specify a function that will be called when the SysTick timer interrupt occurs.

**Parameters**

|    |                   |                                   |
|----|-------------------|-----------------------------------|
| in | <i>pfCallback</i> | Pointer to the callback function. |
|----|-------------------|-----------------------------------|

**Returns**

None

**5.144.2.5 MCAL\_STK\_SetReload()**

```
void MCAL_STK_SetReload (
    uint32 value )
```

Sets the reload value for the SysTick timer.

This function sets the reload value which determines the SysTick timer's period.

**Parameters**

|    |              |                             |
|----|--------------|-----------------------------|
| in | <i>value</i> | The reload value to be set. |
|----|--------------|-----------------------------|

**Returns**

None

Sets the reload value for the SysTick timer.

This function sets the value that the SysTick timer counts down from before generating an interrupt.

**Parameters**

|    |              |                                          |
|----|--------------|------------------------------------------|
| in | <i>value</i> | The value to be set as the reload value. |
|----|--------------|------------------------------------------|

**Returns**

None

**5.144.2.6 MCAL\_STK\_StartTimer()**

```
void MCAL_STK_StartTimer ( )
```

Starts the SysTick timer.

This function starts the SysTick timer. The timer must be configured using [MCAL\\_STK\\_Config\(\)](#) before starting it unless default values are used.

#### Returns

None

This function initializes and starts the SysTick timer. The timer will begin counting from the reload value.

#### Parameters

|    |             |  |
|----|-------------|--|
| in | <i>None</i> |  |
|----|-------------|--|

#### Returns

None

#### Note

`MCAL_STK_Config` should be called first to configure the SysTick timer unless default values are acceptable.

### 5.144.2.7 MCAL\_STK\_StopTimer()

```
void MCAL_STK_StopTimer ( )
```

Stops the SysTick timer.

This function stops the SysTick timer, halting its operation until restarted.

#### Returns

None

This function stops the SysTick timer, halting the countdown and disabling interrupts.

#### Parameters

|    |             |  |
|----|-------------|--|
| in | <i>None</i> |  |
|----|-------------|--|

#### Returns

None

## 5.145 TIMER Driver

TIMER driver APIs for STM32F401xx MCU.

Collaboration diagram for TIMER Driver:



## Modules

- [TIM2 Register group](#)  
*TIM2 Register group.*
- [API Function Prototypes](#)

### 5.145.1 Detailed Description

TIMER driver APIs for STM32F401xx MCU.

## 5.146 TIM2 Register group

TIM2 Register group.

Collaboration diagram for TIM2 Register group:



## Macros

- `#define RCC_APB1ENR *(volatile uint32 *) (RCC_BASE + 0x40)`  
*Enable the APB1 peripheral clock for TIM2.*
- `#define RCC_APB2ENR *(volatile uint32 *) (RCC_BASE + 0x44)`  
*Enable the APB2 peripheral clock for TIM2.*
- `#define TIM2_TIMER_BASE 0x40000000`  
*TIM2\_Register TIM2 Register Base Addresses and Offsets.*

- `#define TIM2_CR1 *(volatile uint32 *) (TIM2_TIMER_BASE + 0x00)`  
*Control register 1 (CR1) for TIM2.*
- `#define TIM2_DIER *(volatile uint32 *) (TIM2_TIMER_BASE + 0x0C)`  
*DMA/interrupt enable register (DIER) for TIM2.*
- `#define TIM2_SR *(volatile uint32 *) (TIM2_TIMER_BASE + 0x10)`  
*Status register (SR) for TIM2.*
- `#define TIM2_CNT *(volatile uint32 *) (TIM2_TIMER_BASE + 0x24)`  
*Counter register (CNT) for TIM2.*
- `#define TIM2_PSC *(volatile uint32 *) (TIM2_TIMER_BASE + 0x28)`  
*Prescaler register (PSC) for TIM2.*
- `#define TIM2_ARR *(volatile uint32 *) (TIM2_TIMER_BASE + 0x2C)`  
*Auto-reload register (ARR) for TIM2.*

### 5.146.1 Detailed Description

TIM2 Register group.

### 5.146.2 Macro Definition Documentation

#### 5.146.2.1 TIM2\_TIMER\_BASE

```
#define TIM2_TIMER_BASE 0x40000000
```

TIM2\_Register TIM2 Register Base Addresses and Offsets.

Base address of TIM2

## 5.147 API Function Prototypes

Collaboration diagram for API Function Prototypes:



## Functions

- void `Timer2_init` (void)  
*Initialize Timer 2 (TIM2) for basic timing functionalities.*
- void `dus` (int us)  
*Delay execution for a specified number of microseconds.*
- void `dms` (int ms)  
*Delay execution for a specified number of milliseconds.*

### 5.147.1 Detailed Description

### 5.147.2 Function Documentation

#### 5.147.2.1 dms()

```
void dms (
    int ms )
```

Delay execution for a specified number of milliseconds.

This function uses TIM2 to generate a delay in milliseconds.

##### Parameters

|                 |                                  |
|-----------------|----------------------------------|
| <code>ms</code> | Number of milliseconds to delay. |
|-----------------|----------------------------------|

Delay execution for a specified number of milliseconds.

This function generates a delay by repeatedly calling the `dus` function for each millisecond required. It effectively creates a delay by generating multiple microsecond delays.

##### Parameters

|                 |                 |                                  |
|-----------------|-----------------|----------------------------------|
| <code>in</code> | <code>ms</code> | Number of milliseconds to delay. |
|-----------------|-----------------|----------------------------------|

##### Returns

None

#### 5.147.2.2 dus()

```
void dus (
    int us )
```

Delay execution for a specified number of microseconds.

This function uses TIM2 to generate a delay in microseconds.

**Parameters**

|           |                                  |
|-----------|----------------------------------|
| <i>us</i> | Number of microseconds to delay. |
|-----------|----------------------------------|

Delay execution for a specified number of microseconds.

This function generates a delay by counting timer ticks for the specified number of microseconds using Timer2. The timer is reset and counts up until the desired delay duration is reached.

**Parameters**

|           |           |                                  |
|-----------|-----------|----------------------------------|
| <i>in</i> | <i>us</i> | Number of microseconds to delay. |
|-----------|-----------|----------------------------------|

**Returns**

None

### 5.147.2.3 Timer2\_init()

```
void Timer2_init (
    void )
```

Initialize Timer 2 (TIM2) for basic timing functionalities.

This function configures the TIM2 peripheral with the necessary prescaler and auto-reload values, enabling it to function as a basic timer for timing and delay applications.

Initialize Timer 2 (TIM2) for basic timing functionalities.

This function configures Timer2 with a prescaler and auto-reload register to generate interrupts at a specific interval. The timer is set to produce a delay of 50 milliseconds based on the configured settings.

**Parameters**

|           |             |  |
|-----------|-------------|--|
| <i>in</i> | <i>None</i> |  |
|-----------|-------------|--|

**Returns**

None

**Note**

The function enables the clock for Timer2, sets the prescaler to achieve a 1 MHz clock input, and configures the auto-reload register for a delay of 50 milliseconds. The timer is started, and the function waits until the timer's update interrupt flag is set.

## 5.148 USART Driver

USART peripheral driver for STM32F401 microcontrollers.

Collaboration diagram for USART Driver:



### Modules

- Enumeration and Structures for USART
- Macros for USART Configuration
- API Function Prototypes

### Classes

- struct [USART\\_cfg\\_t](#)  
*Configuration structure for USART (Universal Synchronous Asynchronous Receiver Transmitter) peripheral.*

#### 5.148.1 Detailed Description

USART peripheral driver for STM32F401 microcontrollers.

## 5.149 Enumeration and Structures for USART

Collaboration diagram for Enumeration and Structures for USART:



## Enumerations

- enum **Polling\_Mechanism** { **enable** , **disable** }
- Enumeration for Polling Mechanism.*

### 5.149.1 Detailed Description

## 5.150 Macros for USART Configuration

Collaboration diagram for Macros for USART Configuration:



## Macros

- #define **UART\_Mode\_RX** ((uint32\_t)(1UL << 2))  
*USART Mode Definitions.*
- #define **UART\_Mode\_TX** ((uint32\_t)(1UL << 3))
- #define **UART\_Mode\_TX\_RX** ((uint32\_t)(1UL << 2 | 1UL << 3))
- #define **UART\_BaudRate\_2400** 2400  
*Baud Rate Definitions.*
- #define **UART\_BaudRate\_9600** 9600
- #define **UART\_BaudRate\_19200** 19200
- #define **UART\_BaudRate\_57600** 57600
- #define **UART\_BaudRate\_115200** 115200
- #define **UART\_BaudRate\_230400** 230400
- #define **UART\_BaudRate\_460800** 460800
- #define **UART\_BaudRate\_921600** 921600
- #define **UART\_BaudRate\_2250000** 2250000
- #define **UART\_BaudRate\_4500000** 4500000
- #define **UART\_Payload\_Length\_8B** ((uint32\_t)(0))  
*Payload Length Definitions.*
- #define **UART\_Payload\_Length\_9B** ((uint32\_t)(1UL << 12))
- #define **UART\_Parity\_NONE** ((uint32\_t)(0))  
*Parity Definitions.*
- #define **UART\_Parity\_EVEN** ((uint32\_t)(1UL << 10))
- #define **UART\_Parity\_ODD** ((uint32\_t)(1UL << 10) | (1UL << 9))
- #define **UART\_StopBits\_half** ((uint32\_t)(1 << 12))  
*Stop Bits Definitions.*
- #define **UART\_StopBits\_1** ((uint32\_t)(0))
- #define **UART\_StopBits\_1\_half** ((uint32\_t)(3 << 12))
- #define **UART\_StopBits\_2** ((uint32\_t)(2 << 12))
- #define **UART\_HwFlowCtl\_NONE** ((uint32\_t)(0))

- Hardware Flow Control Definitions.*
- #define **UART\_HwFlowCtl\_RTS** ((uint32\_t)(1UL << 8))
  - #define **UART\_HwFlowCtl\_CTS** ((uint32\_t)(1UL << 9))
  - #define **UART\_HwFlowCtl\_RTS\_CTS** ((uint32\_t)(1UL << 8 | 1UL << 9))
  - #define **UART\_IRQ\_Enable\_NONE** ((uint32\_t)(0))
- IRQ Enable Definitions.*
- #define **UART\_IRQ\_Enable\_TXE** ((uint32\_t)(1UL << 7))
  - #define **UART\_IRQ\_Enable\_TC** ((uint32\_t)(1UL << 6))
  - #define **UART\_IRQ\_Enable\_RXNE** ((uint32\_t)(1UL << 5))
  - #define **UART\_IRQ\_Enable\_PE** ((uint32\_t)(1UL << 8))

### 5.150.1 Detailed Description

## 5.151 API Function Prototypes

Collaboration diagram for API Function Prototypes:



## Functions

- void **MCAL\_USART\_Init** (USART\_TypeDef \*USARTx, **USART\_cfg\_t** \*USART\_cfg)
 

*Initializes UART (Asynchronous mode only).*
- void **MCAL\_USART\_DeInit** (USART\_TypeDef \*USARTx)
 

*Deinitializes UART (Asynchronous mode only).*
- void **MCAL\_USART\_GPIO\_Set\_Pins** (USART\_TypeDef \*USARTx)
 

*Initializes GPIO pins for USART.*
- void **MCAL\_USART\_SendData** (USART\_TypeDef \*USARTx, uint16\_t \*pTxBuffer, **Polling\_Mechanism** PollingEn)
 

*Sends buffer via USART.*
- void **MCAL\_USART\_SendString** (USART\_TypeDef \*USARTx, uint8\_t \*str, uint8\_t str\_len)
 

*Sends a string via USART.*
- void **MCAL\_USART\_ReceiveData** (USART\_TypeDef \*USARTx, uint16\_t \*pRxBuffer, **Polling\_Mechanism** PollingEn)
 

*Receives buffer from USART.*
- void **MCAL\_USART\_ReceiveBuffer** (USART\_TypeDef \*USARTx, uint16\_t \*pRxBuffer, uint8\_t length)
 

*Receives buffer from USART with specified length.*
- void **MCAL\_USART\_Wait\_TC** (USART\_TypeDef \*USARTx)
 

*Waits until transmission is completed by polling on TC flag.*

### 5.151.1 Detailed Description

### 5.151.2 Function Documentation

#### 5.151.2.1 MCAL\_USART\_DeInit()

```
void MCAL_USART_DeInit (
    USART_TypeDef * USARTx )
```

Deinitializes UART (Asynchronous mode only).

##### Parameters

|               |                                           |
|---------------|-------------------------------------------|
| <i>USARTx</i> | Pointer to the USART peripheral instance. |
|---------------|-------------------------------------------|

Deinitializes UART (Asynchronous mode only).

This function resets the USART peripheral and disables its associated NVIC interrupt.

##### Parameters

|    |               |                                                                       |
|----|---------------|-----------------------------------------------------------------------|
| in | <i>USARTx</i> | Pointer to the USART peripheral instance (USART1, USART2, or USART6). |
|----|---------------|-----------------------------------------------------------------------|

##### Returns

None

#### 5.151.2.2 MCAL\_USART\_GPIO\_Set\_Pins()

```
void MCAL_USART_GPIO_Set_Pins (
    USART_TypeDef * USARTx )
```

Initializes GPIO pins for UART.

##### Parameters

|               |                                           |
|---------------|-------------------------------------------|
| <i>USARTx</i> | Pointer to the USART peripheral instance. |
|---------------|-------------------------------------------|

Initializes GPIO pins for UART.

This function sets up the GPIO pins used by the USART peripheral, including TX, RX, and optional CTS/RTS pins, depending on the hardware flow control settings.

**Parameters**

|    |               |                                                                       |
|----|---------------|-----------------------------------------------------------------------|
| in | <i>USARTx</i> | Pointer to the USART peripheral instance (USART1, USART2, or USART6). |
|----|---------------|-----------------------------------------------------------------------|

**Returns**

None

**Note**Called automatically at the end of [MCAL\\_USART\\_Init\(\)](#).**5.151.2.3 MCAL\_USART\_Init()**

```
void MCAL_USART_Init (
    USART_TypeDef * USARTx,
    USART_cfg_t * USART_cfg )
```

Initializes UART (Asynchronous mode only).

**Parameters**

|                  |                                           |
|------------------|-------------------------------------------|
| <i>USARTx</i>    | Pointer to the USART peripheral instance. |
| <i>USART_cfg</i> | Pointer to the USART configuration.       |

Initializes UART (Asynchronous mode only).

This function configures the USART peripheral based on the settings provided in the USART configuration structure. It supports asynchronous mode and sets up the necessary GPIO pins.

**Parameters**

|    |                  |                                                                       |
|----|------------------|-----------------------------------------------------------------------|
| in | <i>USARTx</i>    | Pointer to the USART peripheral instance (USART1, USART2, or USART6). |
| in | <i>USART_cfg</i> | Pointer to the USART configuration structure.                         |

**Returns**

None

**Note**

Supports asynchronous mode only with an 8MHz clock.

### 5.151.2.4 MCAL\_USART\_ReceiveBuffer()

```
void MCAL_USART_ReceiveBuffer (
    USART_TypeDef * USARTx,
    uint16_t * pRxBUFFER,
    uint8_t length )
```

Receives buffer from UART with specified length.

#### Parameters

|                  |                                                           |
|------------------|-----------------------------------------------------------|
| <i>USARTx</i>    | Pointer to the USART peripheral instance.                 |
| <i>pRxBUFFER</i> | Buffer to be received.                                    |
| <i>length</i>    | Length of data to be received (0 = until receiving '\r'). |

### 5.151.2.5 MCAL\_USART\_ReceiveData()

```
void MCAL_USART_ReceiveData (
    USART_TypeDef * USARTx,
    uint16_t * pRxBUFFER,
    Polling_Mechanism PollingEn )
```

Receives buffer from UART.

#### Parameters

|                  |                                           |
|------------------|-------------------------------------------|
| <i>USARTx</i>    | Pointer to the USART peripheral instance. |
| <i>pRxBUFFER</i> | Buffer to be received.                    |
| <i>PollingEn</i> | Enable or disable polling mechanism.      |

### 5.151.2.6 MCAL\_USART\_SendData()

```
void MCAL_USART_SendData (
    USART_TypeDef * USARTx,
    uint16_t * pTxBuffer,
    Polling_Mechanism PollingEn )
```

Sends buffer via UART.

#### Parameters

|                  |                                           |
|------------------|-------------------------------------------|
| <i>USARTx</i>    | Pointer to the USART peripheral instance. |
| <i>pTxBuffer</i> | Buffer to be transmitted.                 |
| <i>PollingEn</i> | Enable or disable polling mechanism.      |

### 5.151.2.7 MCAL\_USART\_SendString()

```
void MCAL_USART_SendString (
    USART_TypeDef * USARTx,
    uint8_t * str,
    uint8_t str_len )
```

Sends a string via UART.

#### Parameters

|                |                                                                |
|----------------|----------------------------------------------------------------|
| <i>USARTx</i>  | Pointer to the USART peripheral instance.                      |
| <i>str</i>     | Pointer to the string to be transmitted.                       |
| <i>str_len</i> | Length of string to be transmitted (0 = send until null '\0'). |

### 5.151.2.8 MCAL\_USART\_Wait\_TC()

```
void MCAL_USART_Wait_TC (
    USART_TypeDef * USARTx )
```

Waits until transmission is completed by polling on TC flag.

#### Parameters

|               |                                           |
|---------------|-------------------------------------------|
| <i>USARTx</i> | Pointer to the USART peripheral instance. |
|---------------|-------------------------------------------|

Waits until transmission is completed by polling on TC flag.

#### Parameters

|    |               |                                                                                                      |
|----|---------------|------------------------------------------------------------------------------------------------------|
| in | <i>USARTx</i> | Pointer to the USART peripheral instance. It can be one of the following: USART1, USART2, or USART6. |
|----|---------------|------------------------------------------------------------------------------------------------------|

#### Returns

None

#### Note

This function continuously polls the TC flag in the SR (Status Register) until the flag is set, indicating that the transmission is complete.

## 5.152 Application States

Definitions and APIs for managing application states.

Collaboration diagram for Application States:



## Modules

- **Includes**  
*Required libraries for managing application states.*
- **State Macros**  
*Macros for defining and managing application state handler functions.*
- **Prototypes**  
*Function Prototypes for the Application states APIs.*
- **State Handlers**  
*Function prototypes for handling different application states.*

## Enumerations

- enum STATES {  
    Init\_STATE , Admin\_STATE , Idle\_STATE , Enter\_Gate\_STATE ,  
    Exit\_Gate\_STATE , Full\_STATE }  
*Enum representing various application states.*

## Functions

- **STATE\_API (Init\_STATE)**  
*Initializes the system and sets up the initial state.*
- **STATE\_API (Admin\_STATE)**  
*Admin state to initialize the user IDs and prepare the system.*
- **STATE\_API (Idle\_STATE)**  
*Idle state where the system waits for user input (entry/exit requests).*
- **STATE\_API (Enter\_Gate\_STATE)**  
*Handles the logic for opening the entry gate.*
- **STATE\_API (Exit\_Gate\_STATE)**  
*Handles the logic for opening the exit gate.*
- **STATE\_API (Full\_STATE)**  
*Full state where the parking lot is full, and no entry is allowed.*

## Variables

- volatile uint8 Enter\_Flag  
*Flags and variables used for managing system state.*
- volatile uint8 Exit\_Flag  
*Flags for entry and exit state triggers.*
- uint8 Free\_Slots
- uint8 Print\_Slots\_LCD\_Flag  
*Available parking slots and LCD print flag.*
- void(\* fp\_App\_State\_Handler )() = STATE\_NAME(Init\_STATE)  
*Function pointer to manage current state transitions.*
- STATES APP\_Current\_State  
*Current application state.*

### 5.152.1 Detailed Description

Definitions and APIs for managing application states.

### 5.152.2 Enumeration Type Documentation

#### 5.152.2.1 STATES

```
enum STATES
```

Enum representing various application states.

< Include header for ECU definitions and functions

This enumeration defines the different states that the application can be in.

Enumerator

|                  |                             |
|------------------|-----------------------------|
| Init_STATE       | Initialization state        |
| Admin_STATE      | Administration state        |
| Idle_STATE       | Idle state                  |
| Enter_Gate_STATE | State for entering the gate |
| Exit_Gate_STATE  | State for exiting the gate  |
| Full_STATE       | Full state                  |

### 5.152.3 Function Documentation

**5.152.3.1 STATE\_API() [1/6]**

```
STATE_API (
    Admin_STATE )
```

Admin state to initialize the user IDs and prepare the system.

Handler function for the administration state.

**5.152.3.2 STATE\_API() [2/6]**

```
STATE_API (
    Enter_Gate_STATE )
```

Handles the logic for opening the entry gate.

Handler function for the entering gate state.

**5.152.3.3 STATE\_API() [3/6]**

```
STATE_API (
    Exit_Gate_STATE )
```

Handles the logic for opening the exit gate.

Handler function for the exiting gate state.

**5.152.3.4 STATE\_API() [4/6]**

```
STATE_API (
    Full_STATE )
```

Full state where the parking lot is full, and no entry is allowed.

Handler function for the full state.

**5.152.3.5 STATE\_API() [5/6]**

```
STATE_API (
    Idle_STATE )
```

Idle state where the system waits for user input (entry/exit requests).

Handler function for the idle state.

**5.152.3.6 STATE\_API() [6/6]**

```
STATE_API (
    Init_STATE )
```

Initializes the system and sets up the initial state.

Handler function for the initialization state.

## 5.152.4 Variable Documentation

### 5.152.4.1 fp\_App\_State\_Handler

```
void(* fp_App_State_Handler) () () = STATE_NAME(Init_STATE)
```

Function pointer to manage current state transitions.

Function pointer for the current application state handler.

Pointer to current state handler function.

### 5.152.4.2 Free\_Slots

```
uint8 Free_Slots [extern]
```

Number of free parking slots

## 5.153 Includes

Required libraries for managing application states.

Collaboration diagram for Includes:



Required libraries for managing application states.

Required libraries for ECU module functionalities.

## 5.154 State Macros

Macros for defining and managing application state handler functions.

Collaboration diagram for State Macros:



### Macros

- `#define STATE_API(_NAME) void ST_##_NAME(void)`  
*Macro to define a state handler function.*
- `#define STATE_NAME(_NAME) ST_##_NAME`  
*Macro to create a state handler function name.*

### 5.154.1 Detailed Description

Macros for defining and managing application state handler functions.

### 5.154.2 Macro Definition Documentation

#### 5.154.2.1 STATE\_API

```
#define STATE_API(  
    _NAME ) void ST_##_NAME(void)
```

Macro to define a state handler function.

@macro STATE\_API

Parameters

|                    |                    |
|--------------------|--------------------|
| <code>_NAME</code> | Name of the state. |
|--------------------|--------------------|

This macro defines a function prototype for the state handler function corresponding to the specified state.

### 5.154.2.2 STATE\_NAME

```
#define STATE_NAME(  
    _NAME ) ST_##_NAME
```

Macro to create a state handler function name.

@macro STATE\_NAME

Parameters

|                    |                    |
|--------------------|--------------------|
| <code>_NAME</code> | Name of the state. |
|--------------------|--------------------|

This macro generates the name of the state handler function based on the state name.

## 5.155 Prototypes

Function Prototypes for the Application states APIs.

Collaboration diagram for Prototypes:



## Variables

- `void(* fp_App_State_Handler)()`  
*Function pointer for the current application state handler.*

### 5.155.1 Detailed Description

Function Prototypes for the Application states APIs.

### 5.155.2 Variable Documentation

### 5.155.2.1 fp\_App\_State\_Handler

```
void(* fp_App_State_Handler) () () [extern]
```

Function pointer for the current application state handler.

This pointer is used to reference the handler function corresponding to the current application state. Pointer to the current application state handler function

Function pointer for the current application state handler.

Pointer to current state handler function.

## 5.156 State Handlers

Function prototypes for handling different application states.

Collaboration diagram for State Handlers:



## Functions

- [STATE\\_API \(Init\\_STATE\)](#)  
*Handler function for the initialization state.*
- [STATE\\_API \(Admin\\_STATE\)](#)  
*Handler function for the administration state.*
- [STATE\\_API \(Idle\\_STATE\)](#)  
*Handler function for the idle state.*
- [STATE\\_API \(Enter\\_Gate\\_STATE\)](#)  
*Handler function for the entering gate state.*
- [STATE\\_API \(Exit\\_Gate\\_STATE\)](#)  
*Handler function for the exiting gate state.*
- [STATE\\_API \(Full\\_STATE\)](#)  
*Handler function for the full state.*

### 5.156.1 Detailed Description

Function prototypes for handling different application states.

## 5.156.2 Function Documentation

### 5.156.2.1 STATE\_API() [1/6]

```
STATE_API (
    Admin_STATE )
```

Handler function for the administration state.

Handler function for the administration state.

### 5.156.2.2 STATE\_API() [2/6]

```
STATE_API (
    Enter_Gate_STATE )
```

Handler function for the entering gate state.

Handler function for the entering gate state.

### 5.156.2.3 STATE\_API() [3/6]

```
STATE_API (
    Exit_Gate_STATE )
```

Handler function for the exiting gate state.

Handler function for the exiting gate state.

### 5.156.2.4 STATE\_API() [4/6]

```
STATE_API (
    Full_STATE )
```

Handler function for the full state.

Handler function for the full state.

### 5.156.2.5 STATE\_API() [5/6]

```
STATE_API (
    Idle_STATE )
```

Handler function for the idle state.

Handler function for the idle state.

### 5.156.2.6 STATE\_API() [6/6]

```
STATE_API (
    Init_STATE )
```

Handler function for the initialization state.

Handler function for the initialization state.

## 5.157 ECU Definitions and APIs

Definitions and APIs for the ECU (Electronic Control Unit) system.

Collaboration diagram for ECU Definitions and APIs:



## Modules

- **Includes**  
*Required libraries for managing application states.*
- **Enum representing the result of ID check.**
- **Configuration Macros**  
*Macros for system configuration.*
- **ECU APIs**  
*APIs for managing the ECU functionalities.*
- **Functions\_Declarations**  
*Declaration of callback functions for UART operations.*
- **Global\_Variables\_Definitions**  
*Global variable definitions for LEDs, LCDs, UART, and system states.*
- **API\_Definitions**  
*API definitions for the ECU functionalities.*

### 5.157.1 Detailed Description

Definitions and APIs for the ECU (Electronic Control Unit) system.

## 5.158 Enum representing the result of ID check.

Collaboration diagram for Enum representing the result of ID check.:  


### Enumerations

- enum `ID_Check_Result { ID_NOT_Found , ID_Found }`

### 5.158.1 Detailed Description

This enumeration defines possible outcomes of checking an ID in the system.

### 5.158.2 Enumeration Type Documentation

#### 5.158.2.1 `ID_Check_Result`

enum `ID_Check_Result`

Enumerator

|                           |                  |
|---------------------------|------------------|
| <code>ID_NOT_Found</code> | ID was not found |
| <code>ID_Found</code>     | ID was found     |

## 5.159 Configuration Macros

Macros for system configuration.

Collaboration diagram for Configuration Macros:



## Macros

- `#define NO_OF_SLOTS 3`  
*Number of parking slots.*
- `#define USERS_COUNT 3`  
*Total number of users.*
- `#define USER1 0`  
*User 1 ID.*
- `#define USER2 1`  
*User 2 ID.*
- `#define USER3 2`  
*User 3 ID.*
- `#define ENTER_USART_INSTANT USART1`  
*Enter gate USART instance.*
- `#define EXIT_USART_INSTANT USART2`  
*Exit gate USART instance.*
- `#define ENTER_PIR_PORT GPIOA`  
*Enter gate PIR sensor GPIO port.*
- `#define ENTER_PIR_PIN GPIO_PIN_7`  
*Enter gate PIR sensor GPIO pin.*
- `#define EXIT_PIR_PORT GPIOA`  
*Exit gate PIR sensor GPIO port.*
- `#define EXIT_PIR_PIN GPIO_PIN_1`  
*Exit gate PIR sensor GPIO pin.*

### 5.159.1 Detailed Description

Macros for system configuration.

## 5.160 ECU APIs

APIs for managing the ECU functionalities.

Collaboration diagram for ECU APIs:



## Functions

- void [ECU\\_Init](#) (void)  
*Initializes all hardware components and peripherals.*
- void [Admin\\_Init](#) (void)  
*Initializes the admin settings, including setting up user IDs.*
- void [UserLCD\\_PrintFreeSlots](#) (void)  
*Prints the number of free parking slots on the LCD.*
- [ID\\_Check\\_Result Check\\_ID](#) (uint8 \_ID)  
*Checks if the given ID exists in the system.*
- [uint8 Check\\_Flag](#) (uint8 \_ID)  
*Returns the status flag associated with the given ID.*
- void [Flag\\_SET\\_RESET](#) (uint8 \_ID)  
*Toggles the flag associated with the given ID.*
- [uint8 Check\\_Password](#) (uint8 \_ID)  
*Checks if the entered password matches the stored password for the given ID.*
- void [combineArrays](#) (uint8\_t \*array1, int size1, uint8\_t \*array2, int size2, uint8\_t \*array3, int size3, uint8\_t \*array4, int size4, uint8\_t \*combinedArray)  
*Combines four arrays into a single array.*
- void [Enter\\_Gate\\_Open](#) (void)  
*Opens the entrance gate and displays the status on the LCD.*
- void [Exit\\_Gate\\_Open](#) (void)  
*Opens the exit gate and displays the status on the LCD.*
- void [Wrong\\_RFID](#) (void)  
*Triggers the alarm and prints "UNKNOWN ID!" on the LCD.*
- void [Trigger\\_Alarm](#) (USART\_TypeDef \*\_USART)  
*Echoes the entered ID via USART and flashes the red LED.*

### 5.160.1 Detailed Description

APIs for managing the ECU functionalities.

### 5.160.2 Function Documentation

### 5.160.2.1 Admin\_Init()

```
void Admin_Init (
    void )
```

Initializes the admin settings, including setting up user IDs.

This function is called at system startup to set the user IDs and configure the initial admin settings.

#### Returns

None

Initializes the admin settings, including setting up user IDs.

This function is called at the very start of the system to set the users' IDs. It prompts the admin to enter user IDs via a keypad and displays the entered IDs on the LCD. It also sets the default screen for the rest of the program.

#### Parameters

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

#### Returns

None

### 5.160.2.2 Check\_Flag()

```
uint8 Check_Flag (
    uint8 _ID )
```

Returns the status flag associated with the given ID.

This function checks the flag status for the specified user ID. It compares the input ID with stored user IDs and returns the corresponding flag value if a match is found.

#### Parameters

|    |     |                                        |
|----|-----|----------------------------------------|
| in | _ID | ID whose flag status is to be checked. |
|----|-----|----------------------------------------|

#### Returns

User flag if the ID matches; 0 if no match is found.

### 5.160.2.3 Check\_ID()

```
ID_Check_Result Check_ID (
    uint8 _ID )
```

Checks if the given ID exists in the system.

This function checks if the provided ID exists among the saved user IDs.

#### Parameters

|    |     |                  |
|----|-----|------------------|
| in | _ID | The ID to check. |
|----|-----|------------------|

#### Returns

ID\_Found if the ID is found, ID\_NOT\_Found otherwise.

Checks if the given ID exists in the system.

This function searches for the specified ID in the list of saved IDs and returns the result of the search.

#### Parameters

|    |     |              |
|----|-----|--------------|
| in | _ID | ID to check. |
|----|-----|--------------|

#### Returns

ID\_Found if the ID is found, ID\_NOT\_Found otherwise.

### 5.160.2.4 Check\_Password()

```
uint8 Check_Password (
    uint8 _ID )
```

Checks if the entered password matches the stored password for the given ID.

This function prompts the user to enter a 4-digit password using a keypad. It compares the entered password with the stored password for the corresponding ID. If the passwords match, the function returns 1; otherwise, it returns 0.

#### Parameters

|    |     |                                             |
|----|-----|---------------------------------------------|
| in | _ID | ID for which the password is being checked. |
|----|-----|---------------------------------------------|

#### Returns

1 if the entered password matches the stored password, 0 otherwise.

### 5.160.2.5 combineArrays()

```
void combineArrays (
    uint8_t * array1,
    int size1,
    uint8_t * array2,
    int size2,
    uint8_t * array3,
    int size3,
    uint8_t * array4,
    int size4,
    uint8_t * combinedArray )
```

Combines four arrays into a single array.

This function merges four separate arrays into one single array. It copies the contents of each input array sequentially into the `combinedArray`. The sizes of the arrays and the final combined array should be managed carefully to avoid buffer overflows.

#### Parameters

|     |                            |                                                                                                                                                   |
|-----|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| in  | <code>array1</code>        | Pointer to the first input array.                                                                                                                 |
| in  | <code>size1</code>         | Number of elements in the first array.                                                                                                            |
| in  | <code>array2</code>        | Pointer to the second input array.                                                                                                                |
| in  | <code>size2</code>         | Number of elements in the second array.                                                                                                           |
| in  | <code>array3</code>        | Pointer to the third input array.                                                                                                                 |
| in  | <code>size3</code>         | Number of elements in the third array.                                                                                                            |
| in  | <code>array4</code>        | Pointer to the fourth input array.                                                                                                                |
| in  | <code>size4</code>         | Number of elements in the fourth array.                                                                                                           |
| out | <code>combinedArray</code> | Pointer to the array where the combined data will be stored. The size of this array must be at least <code>size1 + size2 + size3 + size4</code> . |

#### Returns

void

### 5.160.2.6 ECU\_Init()

```
void ECU_Init (
    void  )
```

Initializes all hardware components and peripherals.

This function initializes the necessary peripherals for the application, including USART, servo motors, LCD, LED, and keypad drivers.

#### Returns

None

**Note**

Must be called on system boot.

This function sets up all the essential peripherals, including clock initialization, LED configuration, LCD, UART, and sensor setups. Must be called during system startup.

**Returns**

None

**5.160.2.7 Enter\_Gate\_Open()**

```
void Enter_Gate_Open (
    void )
```

Opens the entrance gate and displays the status on the LCD.

This function opens the entrance gate and prints a message on the LCD indicating that the gate is open.

**Returns**

None

Opens the entrance gate and displays the status on the LCD.

This function activates the servo to open the entry gate, turns on the green LED to indicate the gate is open, and waits until the PIR sensor detects that the gate is closed before closing the gate.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

None

**5.160.2.8 Exit\_Gate\_Open()**

```
void Exit_Gate_Open (
    void )
```

Opens the exit gate and displays the status on the LCD.

This function opens the exit gate and prints a message on the LCD indicating that the gate is open.

**Returns**

None

Opens the exit gate and displays the status on the LCD.

This function activates the servo to open the exit gate, turns on the green LED to indicate the gate is open, and waits until the PIR sensor detects that the gate is closed before closing the gate.

**Parameters**

|    |             |  |
|----|-------------|--|
| in | <i>None</i> |  |
|----|-------------|--|

**Returns**

None

### 5.160.2.9 Flag\_SET\_RESET()

```
void Flag_SET_RESET (
    uint8 _ID )
```

Toggles the flag associated with the given ID.

This function toggles the flag of a user identified by the provided ID. If the flag is currently set (1), it will be reset (0), and vice versa.

**Parameters**

|    |            |                                 |
|----|------------|---------------------------------|
| in | <i>_ID</i> | ID whose flag is to be toggled. |
|----|------------|---------------------------------|

### 5.160.2.10 Trigger\_Alarm()

```
void Trigger_Alarm (
    USART_TypeDef * _USART )
```

Echoes the entered ID via USART and flashes the red LED.

This function echoes the entered ID through the specified USART and flashes the red LED to signal an alarm condition.

**Parameters**

|    |               |                                                     |
|----|---------------|-----------------------------------------------------|
| in | <i>_USART</i> | Pointer to the USART instance that received the ID. |
|----|---------------|-----------------------------------------------------|

**Returns**

None

Echoes the entered ID via USART and flashes the red LED.

This function retrieves the entered ID from the specified USART instance, echoes the ID back on UART, and triggers the red LED to flash multiple times as an alarm indication.

**Parameters**

|    |        |                                                              |
|----|--------|--------------------------------------------------------------|
| in | _USART | Pointer to the USART instance that contains the received ID. |
|----|--------|--------------------------------------------------------------|

**Returns**

None

**Note**

The function uses blocking delays to flash the LED.

### 5.160.2.11 UserLCD\_PrintFreeSlots()

```
void UserLCD_PrintFreeSlots (
    void )
```

Prints the number of free parking slots on the LCD.

This function prints the number of available parking slots on the user LCD when requested by setting the `Print←_Slots_LCD_Flag`.

**Returns**

None

**Note**

`Print_Slots_LCD_Flag` must be set to 1 before calling this function.

Prints the number of free parking slots on the LCD.

This function updates the UserLCD with the number of free slots if the `Print_Slots_LCD_Flag` is set. If there are no free slots, it displays a message indicating that parking is full.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

None

**Note**

Must set Print\_Slots\_LCD\_Flag to 1 before calling this function.

### 5.160.2.12 Wrong\_RFID()

```
void Wrong_RFID (
    void )
```

Triggers the alarm and prints "UNKNOWN ID!" on the LCD.

This function triggers an alarm when an unrecognized RFID tag is presented, and displays a message indicating the unknown ID on the LCD.

**Returns**

None

Triggers the alarm and prints "UNKNOWN ID!" on the LCD.

This function activates the red LED to indicate an error and sets the servos to the down position. It also displays "UNKNOWN ID!" on the LCD to inform the user of the error.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

None

## 5.161 Functions\_Declarations

Declaration of callback functions for UART operations.

Collaboration diagram for Functions\_Declarations:



### 5.161.1 Detailed Description

Declaration of callback functions for UART operations.

## 5.162 Global\_Variables\_Definitions

Global variable definitions for LEDs, LCDs, UART, and system states.

Collaboration diagram for Global\_Variables\_Definitions:



### Macros

- `#define SIZE1 3`  
*Definitions for combining arrays.*
- `#define SIZE2 4`
- `#define SIZE3 4`
- `#define SIZE4 4`
- `#define TOTAL_SIZE (SIZE1 + SIZE2 + SIZE3 + SIZE4)`

### Variables

- `volatile uint8 Enter_Flag`  
*Flags and variables used for managing system state.*
- `volatile uint8 Exit_Flag`
- `uint8 Free_Slots = 3`
- `uint8 Print_Slots_LCD_Flag`

### 5.162.1 Detailed Description

Global variable definitions for LEDs, LCDs, UART, and system states.

### 5.162.2 Macro Definition Documentation

### 5.162.2.1 SIZE1

```
#define SIZE1 3
```

Definitions for combining arrays.

- SIZE1: Size of the first array.
- SIZE2: Size of the second array.
- SIZE3: Size of the third array.
- SIZE4: Size of the fourth array.
- TOTAL\_SIZE: Total size for the combined array.

### 5.162.3 Variable Documentation

#### 5.162.3.1 Exit\_Flag

```
volatile uint8 Exit_Flag
```

Flags to manage entry and exit

#### 5.162.3.2 Free\_Slots

```
uint8 Free_Slots = 3
```

Number of free parking slots

#### 5.162.3.3 Print\_Slots\_LCD\_Flag

```
uint8 Print_Slots_LCD_Flag
```

Flag to trigger printing free slots

## 5.163 API\_Definitions

API definitions for the ECU functionalities.

Collaboration diagram for API\_Definitions:



## Functions

- void [ECU\\_Init](#) (void)  
*Initializes all hardware components and peripherals.*
- void [Admin\\_Init](#) (void)  
*Initializes user IDs and displays them on the LCD.*
- void [UserLCD\\_PrintFreeSlots](#) (void)  
*Prints the number of free slots on the UserLCD.*
- [ID\\_Check\\_Result Check\\_ID](#) (uint8 \_ID)  
*Checks if the given ID is present in the saved IDs.*
- [uint8 Check\\_Flag](#) (uint8 \_ID)  
*Returns the status flag associated with the given ID.*
- void [Flag\\_SET\\_RESET](#) (uint8 \_ID)  
*Toggles the flag associated with the given ID.*
- [uint8 Check\\_Password](#) (uint8 \_ID)  
*Checks if the entered password matches the stored password for the given ID.*
- void [combineArrays](#) (uint8\_t \*array1, int size1, uint8\_t \*array2, int size2, uint8\_t \*array3, int size3, uint8\_t \*array4, int size4, uint8\_t \*combinedArray)  
*Combines four arrays into a single array.*
- void [Enter\\_Gate\\_Open](#) (void)  
*Opens the entry gate and displays a message on the LCD.*
- void [Exit\\_Gate\\_Open](#) (void)  
*Opens the exit gate and displays a message on the LCD.*
- void [Wrong\\_RFID](#) (void)  
*Triggers an alarm and displays an "UNKNOWN ID!" message on the LCD.*
- void [Trigger\\_Alarm](#) (USART\_TypeDef \*\_USART)  
*Triggers an alarm by echoing the received ID on UART and flashing the red LED.*
- void [Enter\\_UART\\_CallBack](#) (void)  
*Callback function for handling entry UART events.*
- void [Exit\\_UART\\_CallBack](#) (void)  
*Callback function for handling exit UART events.*

### 5.163.1 Detailed Description

API definitions for the ECU functionalities.

### 5.163.2 Function Documentation

#### 5.163.2.1 Admin\_Init()

```
void Admin_Init (
    void )
```

Initializes user IDs and displays them on the LCD.

Initializes the admin settings, including setting up user IDs.

This function is called at the very start of the system to set the users' IDs. It prompts the admin to enter user IDs via a keypad and displays the entered IDs on the LCD. It also sets the default screen for the rest of the program.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

None

**5.163.2.2 Check\_Flag()**

```
uint8 Check_Flag (
    uint8 _ID )
```

Returns the status flag associated with the given ID.

This function checks the flag status for the specified user ID. It compares the input ID with stored user IDs and returns the corresponding flag value if a match is found.

**Parameters**

|    |     |                                        |
|----|-----|----------------------------------------|
| in | _ID | ID whose flag status is to be checked. |
|----|-----|----------------------------------------|

**Returns**

User flag if the ID matches; 0 if no match is found.

**5.163.2.3 Check\_ID()**

```
ID_Check_Result Check_ID (
    uint8 _ID )
```

Checks if the given ID is present in the saved IDs.

Checks if the given ID exists in the system.

This function searches for the specified ID in the list of saved IDs and returns the result of the search.

**Parameters**

|    |     |              |
|----|-----|--------------|
| in | _ID | ID to check. |
|----|-----|--------------|

**Returns**

ID\_Found if the ID is found, ID\_NOT\_Found otherwise.

#### 5.163.2.4 Check\_Password()

```
uint8 Check_Password (
    uint8 _ID )
```

Checks if the entered password matches the stored password for the given ID.

This function prompts the user to enter a 4-digit password using a keypad. It compares the entered password with the stored password for the corresponding ID. If the passwords match, the function returns 1; otherwise, it returns 0.

##### Parameters

|    |            |                                             |
|----|------------|---------------------------------------------|
| in | <i>_ID</i> | ID for which the password is being checked. |
|----|------------|---------------------------------------------|

##### Returns

1 if the entered password matches the stored password, 0 otherwise.

#### 5.163.2.5 combineArrays()

```
void combineArrays (
    uint8_t * array1,
    int size1,
    uint8_t * array2,
    int size2,
    uint8_t * array3,
    int size3,
    uint8_t * array4,
    int size4,
    uint8_t * combinedArray )
```

Combines four arrays into a single array.

This function merges four separate arrays into one single array. It copies the contents of each input array sequentially into the `combinedArray`. The sizes of the arrays and the final combined array should be managed carefully to avoid buffer overflows.

##### Parameters

|     |                      |                                                                                                                                                   |
|-----|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| in  | <i>array1</i>        | Pointer to the first input array.                                                                                                                 |
| in  | <i>size1</i>         | Number of elements in the first array.                                                                                                            |
| in  | <i>array2</i>        | Pointer to the second input array.                                                                                                                |
| in  | <i>size2</i>         | Number of elements in the second array.                                                                                                           |
| in  | <i>array3</i>        | Pointer to the third input array.                                                                                                                 |
| in  | <i>size3</i>         | Number of elements in the third array.                                                                                                            |
| in  | <i>array4</i>        | Pointer to the fourth input array.                                                                                                                |
| in  | <i>size4</i>         | Number of elements in the fourth array.                                                                                                           |
| out | <i>combinedArray</i> | Pointer to the array where the combined data will be stored. The size of this array must be at least <code>size1 + size2 + size3 + size4</code> . |

**Returns**

```
void
```

**5.163.2.6 ECU\_Init()**

```
void ECU_Init (
    void )
```

Initializes all hardware components and peripherals.

This function sets up all the essential peripherals, including clock initialization, LED configuration, LCD, UART, and sensor setups. Must be called during system startup.

**Returns**

```
None
```

**5.163.2.7 Enter\_Gate\_Open()**

```
void Enter_Gate_Open (
    void )
```

Opens the entry gate and displays a message on the LCD.

Opens the entrance gate and displays the status on the LCD.

This function activates the servo to open the entry gate, turns on the green LED to indicate the gate is open, and waits until the PIR sensor detects that the gate is closed before closing the gate.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

```
None
```

**5.163.2.8 Enter\_UART\_CallBack()**

```
void Enter_UART_CallBack (
    void )
```

Callback function for handling entry UART events.

This function sets the `Enter_Flag` to 1 when called, indicating that an entry event has occurred via UART.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

None

**5.163.2.9 Exit\_Gate\_Open()**

```
void Exit_Gate_Open (
    void )
```

Opens the exit gate and displays a message on the LCD.

Opens the exit gate and displays the status on the LCD.

This function activates the servo to open the exit gate, turns on the green LED to indicate the gate is open, and waits until the PIR sensor detects that the gate is closed before closing the gate.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

None

**5.163.2.10 Exit\_UART\_CallBack()**

```
void Exit_UART_CallBack (
    void )
```

Callback function for handling exit UART events.

This function sets the `Exit_Flag` to 1 when called, indicating that an exit event has occurred via UART.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

None

### 5.163.2.11 Flag\_SET\_RESET()

```
void Flag_SET_RESET (
    uint8 _ID )
```

Toggles the flag associated with the given ID.

This function toggles the flag of a user identified by the provided ID. If the flag is currently set (1), it will be reset (0), and vice versa.

#### Parameters

|    |     |                                 |
|----|-----|---------------------------------|
| in | _ID | ID whose flag is to be toggled. |
|----|-----|---------------------------------|

### 5.163.2.12 Trigger\_Alarm()

```
void Trigger_Alarm (
    USART_TypeDef * _USART )
```

Triggers an alarm by echoing the received ID on UART and flashing the red LED.

Echoes the entered ID via USART and flashes the red LED.

This function retrieves the entered ID from the specified USART instance, echoes the ID back on UART, and triggers the red LED to flash multiple times as an alarm indication.

#### Parameters

|    |        |                                                              |
|----|--------|--------------------------------------------------------------|
| in | _USART | Pointer to the USART instance that contains the received ID. |
|----|--------|--------------------------------------------------------------|

#### Returns

None

#### Note

The function uses blocking delays to flash the LED.

### 5.163.2.13 UserLCD\_PrintFreeSlots()

```
void UserLCD_PrintFreeSlots (
    void )
```

Prints the number of free slots on the UserLCD.

Prints the number of free parking slots on the LCD.

This function updates the UserLCD with the number of free slots if the Print\_Slots\_LCD\_Flag is set. If there are no free slots, it displays a message indicating that parking is full.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

None

**Note**

Must set Print\_Slots\_LCD\_Flag to 1 before calling this function.

**5.163.2.14 Wrong\_RFID()**

```
void Wrong_RFID (
    void )
```

Triggers an alarm and displays an "UNKNOWN ID!" message on the LCD.

Triggers the alarm and prints "UNKNOWN ID!" on the LCD.

This function activates the red LED to indicate an error and sets the servos to the down position. It also displays "UNKNOWN ID!" on the LCD to inform the user of the error.

**Parameters**

|    |      |  |
|----|------|--|
| in | None |  |
|----|------|--|

**Returns**

None

## 5.164 CMSIS

Collaboration diagram for CMSIS:



### Modules

- CMSIS Global Defines
  - Defines and Type Definitions
- Type definitions and defines for Cortex-M processor based devices.*
- Status and Control Registers
- Core Register type definitions.*
- CMSIS Core Register Access Functions
  - CMSIS Core Instruction Interface
  - CMSIS SIMD Intrinsics
  - Stm32f4xx
  - Stm32f4xx\_system

## Functions

- void **NMI\_Handler** (void)
- void **HardFault\_Handler** (void)
- void **MemManage\_Handler** (void)
- void **BusFault\_Handler** (void)
- void **UsageFault\_Handler** (void)
- void **SVC\_Handler** (void)
- void **DebugMon\_Handler** (void)
- void **PendSV\_Handler** (void)
- void **SysTick\_Handler** (void)

*SysTick interrupt handler.*

## Variables

- `_IO uint32_t ADC_TypeDef::SR`
- `_IO uint32_t ADC_TypeDef::CR1`
- `_IO uint32_t ADC_TypeDef::CR2`
- `_IO uint32_t ADC_TypeDef::SMPR1`
- `_IO uint32_t ADC_TypeDef::SMPR2`
- `_IO uint32_t ADC_TypeDef::JOFR1`
- `_IO uint32_t ADC_TypeDef::JOFR2`
- `_IO uint32_t ADC_TypeDef::JOFR3`
- `_IO uint32_t ADC_TypeDef::JOFR4`
- `_IO uint32_t ADC_TypeDef::HTR`
- `_IO uint32_t ADC_TypeDef::LTR`
- `_IO uint32_t ADC_TypeDef::SQR1`
- `_IO uint32_t ADC_TypeDef::SQR2`
- `_IO uint32_t ADC_TypeDef::SQR3`
- `_IO uint32_t ADC_TypeDef::JSQR`
- `_IO uint32_t ADC_TypeDef::JDR1`
- `_IO uint32_t ADC_TypeDef::JDR2`
- `_IO uint32_t ADC_TypeDef::JDR3`
- `_IO uint32_t ADC_TypeDef::JDR4`
- `_IO uint32_t ADC_TypeDef::DR`
- `_IO uint32_t ADC_Common_TypeDef::CSR`
- `_IO uint32_t ADC_Common_TypeDef::CCR`
- `_IO uint32_t ADC_Common_TypeDef::CDR`
- `_IO uint32_t CAN_TxMailBox_TypeDef::TIR`
- `_IO uint32_t CAN_TxMailBox_TypeDef::TDTR`
- `_IO uint32_t CAN_TxMailBox_TypeDef::TDLR`
- `_IO uint32_t CAN_TxMailBox_TypeDef::TDHR`
- `_IO uint32_t CAN_FIFOMailBox_TypeDef::RIR`
- `_IO uint32_t CAN_FIFOMailBox_TypeDef::RDTR`
- `_IO uint32_t CAN_FIFOMailBox_TypeDef::RDLR`
- `_IO uint32_t CAN_FIFOMailBox_TypeDef::RDHR`
- `_IO uint32_t CAN_FilterRegister_TypeDef::FR1`
- `_IO uint32_t CAN_FilterRegister_TypeDef::FR2`
- `_IO uint32_t CAN_TypeDef::MCR`
- `_IO uint32_t CAN_TypeDef::MSR`
- `_IO uint32_t CAN_TypeDef::TSR`
- `_IO uint32_t CAN_TypeDef::RF0R`
- `_IO uint32_t CAN_TypeDef::RF1R`
- `_IO uint32_t CAN_TypeDef::IER`

- `__IO uint32_t CAN_TypeDef::ESR`
- `__IO uint32_t CAN_TypeDef::BTR`
- `uint32_t CAN_TypeDef::RESERVED0 [88]`
- `CAN_TxMailBox_TypeDef CAN_TypeDef::sTxMailBox [3]`
- `CAN_FIFOMailBox_TypeDef CAN_TypeDef::sFIFOMailBox [2]`
- `uint32_t CAN_TypeDef::RESERVED1 [12]`
- `__IO uint32_t CAN_TypeDef::FMR`
- `__IO uint32_t CAN_TypeDef::FM1R`
- `uint32_t CAN_TypeDef::RESERVED2`
- `__IO uint32_t CAN_TypeDef::FS1R`
- `uint32_t CAN_TypeDef::RESERVED3`
- `__IO uint32_t CAN_TypeDef::FFA1R`
- `uint32_t CAN_TypeDef::RESERVED4`
- `__IO uint32_t CAN_TypeDef::FA1R`
- `uint32_t CAN_TypeDef::RESERVED5 [8]`
- `CAN_FilterRegister_TypeDef CAN_TypeDef::sFilterRegister [28]`
- `__IO uint32_t CRC_TypeDef::DR`
- `__IO uint8_t CRC_TypeDef::IDR`
- `uint8_t CRC_TypeDef::RESERVED0`
- `uint16_t CRC_TypeDef::RESERVED1`
- `__IO uint32_t CRC_TypeDef::CR`
- `__IO uint32_t DAC_TypeDef::CR`
- `__IO uint32_t DAC_TypeDef::SWTRIGR`
- `__IO uint32_t DAC_TypeDef::DHR12R1`
- `__IO uint32_t DAC_TypeDef::DHR12L1`
- `__IO uint32_t DAC_TypeDef::DHR8R1`
- `__IO uint32_t DAC_TypeDef::DHR12R2`
- `__IO uint32_t DAC_TypeDef::DHR12L2`
- `__IO uint32_t DAC_TypeDef::DHR8R2`
- `__IO uint32_t DAC_TypeDef::DHR12RD`
- `__IO uint32_t DAC_TypeDef::DHR12LD`
- `__IO uint32_t DAC_TypeDef::DHR8RD`
- `__IO uint32_t DAC_TypeDef::DOR1`
- `__IO uint32_t DAC_TypeDef::DOR2`
- `__IO uint32_t DAC_TypeDef::SR`
- `__IO uint32_t DBGMCU_TypeDef::IDCODE`
- `__IO uint32_t DBGMCU_TypeDef::CR`
- `__IO uint32_t DBGMCU_TypeDef::APB1FZ`
- `__IO uint32_t DBGMCU_TypeDef::APB2FZ`
- `__IO uint32_t DCMI_TypeDef::CR`
- `__IO uint32_t DCMI_TypeDef::SR`
- `__IO uint32_t DCMI_TypeDef::RISR`
- `__IO uint32_t DCMI_TypeDef::IER`
- `__IO uint32_t DCMI_TypeDef::MISR`
- `__IO uint32_t DCMI_TypeDef::ICR`
- `__IO uint32_t DCMI_TypeDef::ESCR`
- `__IO uint32_t DCMI_TypeDef::ESUR`
- `__IO uint32_t DCMI_TypeDef::CWSTRTR`
- `__IO uint32_t DCMI_TypeDef::CWSIZER`
- `__IO uint32_t DCMI_TypeDef::DR`
- `__IO uint32_t DMA_Stream_TypeDef::CR`
- `__IO uint32_t DMA_Stream_TypeDef::NDTR`
- `__IO uint32_t DMA_Stream_TypeDef::PAR`
- `__IO uint32_t DMA_Stream_TypeDef::M0AR`
- `__IO uint32_t DMA_Stream_TypeDef::M1AR`

- `__IO uint32_t DMA_Stream_TypeDef::FCR`
- `__IO uint32_t DMA_TypeDef::LISR`
- `__IO uint32_t DMA_TypeDef::HISR`
- `__IO uint32_t DMA_TypeDef::LIFCR`
- `__IO uint32_t DMA_TypeDef::HIFCR`
- `__IO uint32_t DMA2D_TypeDef::CR`
- `__IO uint32_t DMA2D_TypeDef::ISR`
- `__IO uint32_t DMA2D_TypeDef::IFCR`
- `__IO uint32_t DMA2D_TypeDef::FGMAR`
- `__IO uint32_t DMA2D_TypeDef::FGOR`
- `__IO uint32_t DMA2D_TypeDef::BGMAR`
- `__IO uint32_t DMA2D_TypeDef::BGOR`
- `__IO uint32_t DMA2D_TypeDef::FGPFCCR`
- `__IO uint32_t DMA2D_TypeDef::FGCOLR`
- `__IO uint32_t DMA2D_TypeDef::BGPFCCR`
- `__IO uint32_t DMA2D_TypeDef::BGCOLR`
- `__IO uint32_t DMA2D_TypeDef::FGCMAR`
- `__IO uint32_t DMA2D_TypeDef::BGCMAR`
- `__IO uint32_t DMA2D_TypeDef::OPFCCR`
- `__IO uint32_t DMA2D_TypeDef::OCOLR`
- `__IO uint32_t DMA2D_TypeDef::OMAR`
- `__IO uint32_t DMA2D_TypeDef::OOR`
- `__IO uint32_t DMA2D_TypeDef::NLR`
- `__IO uint32_t DMA2D_TypeDef::LWR`
- `__IO uint32_t DMA2D_TypeDef::AMTCR`
- `uint32_t DMA2D_TypeDef::RESERVED [236]`
- `__IO uint32_t DMA2D_TypeDef::FGCLUT [256]`
- `__IO uint32_t DMA2D_TypeDef::BGCLUT [256]`
- `__IO uint32_t ETH_TypeDef::MACCR`
- `__IO uint32_t ETH_TypeDef::MACFFR`
- `__IO uint32_t ETH_TypeDef::MACHTHR`
- `__IO uint32_t ETH_TypeDef::MACHTLR`
- `__IO uint32_t ETH_TypeDef::MACMIIAR`
- `__IO uint32_t ETH_TypeDef::MACMIIDR`
- `__IO uint32_t ETH_TypeDef::MACFCR`
- `__IO uint32_t ETH_TypeDef::MACVLANTR`
- `uint32_t ETH_TypeDef::RESERVED0 [2]`
- `__IO uint32_t ETH_TypeDef::MACRWUFFR`
- `__IO uint32_t ETH_TypeDef::MACPMTCSR`
- `uint32_t ETH_TypeDef::RESERVED1 [2]`
- `__IO uint32_t ETH_TypeDef::MACSR`
- `__IO uint32_t ETH_TypeDef::MACIMR`
- `__IO uint32_t ETH_TypeDef::MACA0HR`
- `__IO uint32_t ETH_TypeDef::MACA0LR`
- `__IO uint32_t ETH_TypeDef::MACA1HR`
- `__IO uint32_t ETH_TypeDef::MACA1LR`
- `__IO uint32_t ETH_TypeDef::MACA2HR`
- `__IO uint32_t ETH_TypeDef::MACA2LR`
- `__IO uint32_t ETH_TypeDef::MACA3HR`
- `__IO uint32_t ETH_TypeDef::MACA3LR`
- `uint32_t ETH_TypeDef::RESERVED2 [40]`
- `__IO uint32_t ETH_TypeDef::MMCCR`
- `__IO uint32_t ETH_TypeDef::MMCRIR`
- `__IO uint32_t ETH_TypeDef::MMCTIR`
- `__IO uint32_t ETH_TypeDef::MMCRIMR`

- `__IO uint32_t ETH_TypeDef::MMCTIMR`
- `uint32_t ETH_TypeDef::RESERVED3 [14]`
- `__IO uint32_t ETH_TypeDef::MMCTGFSCCR`
- `__IO uint32_t ETH_TypeDef::MMCTGFMSCCR`
- `uint32_t ETH_TypeDef::RESERVED4 [5]`
- `__IO uint32_t ETH_TypeDef::MMCTGFCR`
- `uint32_t ETH_TypeDef::RESERVED5 [10]`
- `__IO uint32_t ETH_TypeDef::MMCRFCECR`
- `__IO uint32_t ETH_TypeDef::MMCRFAECR`
- `uint32_t ETH_TypeDef::RESERVED6 [10]`
- `__IO uint32_t ETH_TypeDef::MMCRGUFCR`
- `uint32_t ETH_TypeDef::RESERVED7 [334]`
- `__IO uint32_t ETH_TypeDef::PTPTSCR`
- `__IO uint32_t ETH_TypeDef::PTPSSIR`
- `__IO uint32_t ETH_TypeDef::PTPTSHR`
- `__IO uint32_t ETH_TypeDef::PTPTSLR`
- `__IO uint32_t ETH_TypeDef::PTPTSHUR`
- `__IO uint32_t ETH_TypeDef::PTPTSLUR`
- `__IO uint32_t ETH_TypeDef::PTPTSAR`
- `__IO uint32_t ETH_TypeDef::PTPTTHR`
- `__IO uint32_t ETH_TypeDef::PTPTTLR`
- `__IO uint32_t ETH_TypeDef::RESERVED8`
- `__IO uint32_t ETH_TypeDef::PTPTSSR`
- `uint32_t ETH_TypeDef::RESERVED9 [565]`
- `__IO uint32_t ETH_TypeDef::DMABMR`
- `__IO uint32_t ETH_TypeDef::DMATPDR`
- `__IO uint32_t ETH_TypeDef::DMARPDR`
- `__IO uint32_t ETH_TypeDef::DMARDLAR`
- `__IO uint32_t ETH_TypeDef::DMATDLAR`
- `__IO uint32_t ETH_TypeDef::DMASR`
- `__IO uint32_t ETH_TypeDef::DMAOMR`
- `__IO uint32_t ETH_TypeDef::DMAIER`
- `__IO uint32_t ETH_TypeDef::DMAMFBOCR`
- `__IO uint32_t ETH_TypeDef::DMARSWTR`
- `uint32_t ETH_TypeDef::RESERVED10 [8]`
- `__IO uint32_t ETH_TypeDef::DMACHTDR`
- `__IO uint32_t ETH_TypeDef::DMACHRDR`
- `__IO uint32_t ETH_TypeDef::DMACHTBAR`
- `__IO uint32_t ETH_TypeDef::DMACHRBAR`
- `__IO uint32_t EXTI_TypeDef::IMR`
- `__IO uint32_t EXTI_TypeDef::EMR`
- `__IO uint32_t EXTI_TypeDef::RTSR`
- `__IO uint32_t EXTI_TypeDef::FTSR`
- `__IO uint32_t EXTI_TypeDef::SWIER`
- `__IO uint32_t EXTI_TypeDef::PR`
- `__IO uint32_t FLASH_TypeDef::ACR`
- `__IO uint32_t FLASH_TypeDef::KEYR`
- `__IO uint32_t FLASH_TypeDef::OPTKEYR`
- `__IO uint32_t FLASH_TypeDef::SR`
- `__IO uint32_t FLASH_TypeDef::CR`
- `__IO uint32_t FLASH_TypeDef::OPTCR`
- `__IO uint32_t FLASH_TypeDef::OPTCR1`
- `__IO uint32_t GPIO_TypeDef::MODER`
- `__IO uint32_t GPIO_TypeDef::OTYPER`
- `__IO uint32_t GPIO_TypeDef::OSPEEDR`

- `__IO uint32_t GPIO_TypeDef::PUPDR`
- `__IO uint32_t GPIO_TypeDef::IDR`
- `__IO uint32_t GPIO_TypeDef::ODR`
- `__IO uint16_t GPIO_TypeDef::BSRRL`
- `__IO uint16_t GPIO_TypeDef::BSRRH`
- `__IO uint32_t GPIO_TypeDef::LCKR`
- `__IO uint32_t GPIO_TypeDef::AFR [2]`
- `__IO uint32_t SYSCFG_TypeDef::MEMRMP`
- `__IO uint32_t SYSCFG_TypeDef::PMC`
- `__IO uint32_t SYSCFG_TypeDef::EXTICR [4]`
- `uint32_t SYSCFG_TypeDef::RESERVED [2]`
- `__IO uint32_t SYSCFG_TypeDef::CMPCR`
- `__IO uint16_t I2C_TypeDef::CR1`
- `uint16_t I2C_TypeDef::RESERVED0`
- `__IO uint16_t I2C_TypeDef::CR2`
- `uint16_t I2C_TypeDef::RESERVED1`
- `__IO uint16_t I2C_TypeDef::OAR1`
- `uint16_t I2C_TypeDef::RESERVED2`
- `__IO uint16_t I2C_TypeDef::OAR2`
- `uint16_t I2C_TypeDef::RESERVED3`
- `__IO uint16_t I2C_TypeDef::DR`
- `uint16_t I2C_TypeDef::RESERVED4`
- `__IO uint16_t I2C_TypeDef::SR1`
- `uint16_t I2C_TypeDef::RESERVED5`
- `__IO uint16_t I2C_TypeDef::SR2`
- `uint16_t I2C_TypeDef::RESERVED6`
- `__IO uint16_t I2C_TypeDef::CCR`
- `uint16_t I2C_TypeDef::RESERVED7`
- `__IO uint16_t I2C_TypeDef::TRISE`
- `uint16_t I2C_TypeDef::RESERVED8`
- `__IO uint16_t I2C_TypeDef::FLTR`
- `uint16_t I2C_TypeDef::RESERVED9`
- `__IO uint32_t IWDG_TypeDef::KR`
- `__IO uint32_t IWDG_TypeDef::PR`
- `__IO uint32_t IWDG_TypeDef::RLR`
- `__IO uint32_t IWDG_TypeDef::SR`
- `uint32_t LTDC_TypeDef::RESERVED0 [2]`
- `__IO uint32_t LTDC_TypeDef::SSCR`
- `__IO uint32_t LTDC_TypeDef::BPCR`
- `__IO uint32_t LTDC_TypeDef::AWCR`
- `__IO uint32_t LTDC_TypeDef::TWCR`
- `__IO uint32_t LTDC_TypeDef::GCR`
- `uint32_t LTDC_TypeDef::RESERVED1 [2]`
- `__IO uint32_t LTDC_TypeDef::SRCR`
- `uint32_t LTDC_TypeDef::RESERVED2 [1]`
- `__IO uint32_t LTDC_TypeDef::BCCR`
- `uint32_t LTDC_TypeDef::RESERVED3 [1]`
- `__IO uint32_t LTDC_TypeDef::IER`
- `__IO uint32_t LTDC_TypeDef::ISR`
- `__IO uint32_t LTDC_TypeDef::ICR`
- `__IO uint32_t LTDC_TypeDef::LIPCR`
- `__IO uint32_t LTDC_TypeDef::CPSR`
- `__IO uint32_t LTDC_TypeDef::CDSR`
- `__IO uint32_t LTDC_Layer_TypeDef::CR`
- `__IO uint32_t LTDC_Layer_TypeDef::WHPCR`

- `_IO uint32_t LTDC_Layer_TypeDef::WVPCR`
- `_IO uint32_t LTDC_Layer_TypeDef::CKCR`
- `_IO uint32_t LTDC_Layer_TypeDef::PFCR`
- `_IO uint32_t LTDC_Layer_TypeDef::CACR`
- `_IO uint32_t LTDC_Layer_TypeDef::DCCR`
- `_IO uint32_t LTDC_Layer_TypeDef::BFCR`
- `uint32_t LTDC_Layer_TypeDef::RESERVED0 [2]`
- `_IO uint32_t LTDC_Layer_TypeDef::CFBAR`
- `_IO uint32_t LTDC_Layer_TypeDef::CFBLR`
- `_IO uint32_t LTDC_Layer_TypeDef::CFBLNR`
- `uint32_t LTDC_Layer_TypeDef::RESERVED1 [3]`
- `_IO uint32_t LTDC_Layer_TypeDef::CLUTWR`
- `_IO uint32_t PWR_TypeDef::CR`
- `_IO uint32_t PWR_TypeDef::CSR`
- `_IO uint32_t RCC_TypeDef::CR`
- `_IO uint32_t RCC_TypeDef::PLLCFGR`
- `_IO uint32_t RCC_TypeDef::CFGGR`
- `_IO uint32_t RCC_TypeDef::CIR`
- `_IO uint32_t RCC_TypeDef::AHB1RSTR`
- `_IO uint32_t RCC_TypeDef::AHB2RSTR`
- `_IO uint32_t RCC_TypeDef::AHB3RSTR`
- `uint32_t RCC_TypeDef::RESERVED0`
- `_IO uint32_t RCC_TypeDef::APB1RSTR`
- `_IO uint32_t RCC_TypeDef::APB2RSTR`
- `uint32_t RCC_TypeDef::RESERVED1 [2]`
- `_IO uint32_t RCC_TypeDef::AHB1ENR`
- `_IO uint32_t RCC_TypeDef::AHB2ENR`
- `_IO uint32_t RCC_TypeDef::AHB3ENR`
- `uint32_t RCC_TypeDef::RESERVED2`
- `_IO uint32_t RCC_TypeDef::APB1ENR`
- `_IO uint32_t RCC_TypeDef::APB2ENR`
- `uint32_t RCC_TypeDef::RESERVED3 [2]`
- `_IO uint32_t RCC_TypeDef::AHB1LPENR`
- `_IO uint32_t RCC_TypeDef::AHB2LPENR`
- `_IO uint32_t RCC_TypeDef::AHB3LPENR`
- `uint32_t RCC_TypeDef::RESERVED4`
- `_IO uint32_t RCC_TypeDef::APB1LPENR`
- `_IO uint32_t RCC_TypeDef::APB2LPENR`
- `uint32_t RCC_TypeDef::RESERVED5 [2]`
- `_IO uint32_t RCC_TypeDef::BDCR`
- `_IO uint32_t RCC_TypeDef::CSR`
- `uint32_t RCC_TypeDef::RESERVED6 [2]`
- `_IO uint32_t RCC_TypeDef::SSCGR`
- `_IO uint32_t RCC_TypeDef::PLLSAICFGR`
- `_IO uint32_t RCC_TypeDef::DCKCFGR`
- `_IO uint32_t RCC_TypeDef::CKGATENR`
- `_IO uint32_t RCC_TypeDef::DCKCFGR2`
- `_IO uint32_t RTC_TypeDef::TR`
- `_IO uint32_t RTC_TypeDef::DR`
- `_IO uint32_t RTC_TypeDef::CR`
- `_IO uint32_t RTC_TypeDef::ISR`
- `_IO uint32_t RTC_TypeDef::PRER`
- `_IO uint32_t RTC_TypeDef::WUTR`
- `_IO uint32_t RTC_TypeDef::CALIBR`

- `__IO uint32_t RTC_TypeDef::ALRMAR`
- `__IO uint32_t RTC_TypeDef::ALRMBR`
- `__IO uint32_t RTC_TypeDef::WPR`
- `__IO uint32_t RTC_TypeDef::SSR`
- `__IO uint32_t RTC_TypeDef::SHIFTR`
- `__IO uint32_t RTC_TypeDef::TSTR`
- `__IO uint32_t RTC_TypeDef::TSDR`
- `__IO uint32_t RTC_TypeDef::TSSSR`
- `__IO uint32_t RTC_TypeDef::CALR`
- `__IO uint32_t RTC_TypeDef::TAFCR`
- `__IO uint32_t RTC_TypeDef::ALRMASSR`
- `__IO uint32_t RTC_TypeDef::ALRMBSSR`
- `uint32_t RTC_TypeDef::RESERVED7`
- `__IO uint32_t RTC_TypeDef::BKP0R`
- `__IO uint32_t RTC_TypeDef::BKP1R`
- `__IO uint32_t RTC_TypeDef::BKP2R`
- `__IO uint32_t RTC_TypeDef::BKP3R`
- `__IO uint32_t RTC_TypeDef::BKP4R`
- `__IO uint32_t RTC_TypeDef::BKP5R`
- `__IO uint32_t RTC_TypeDef::BKP6R`
- `__IO uint32_t RTC_TypeDef::BKP7R`
- `__IO uint32_t RTC_TypeDef::BKP8R`
- `__IO uint32_t RTC_TypeDef::BKP9R`
- `__IO uint32_t RTC_TypeDef::BKP10R`
- `__IO uint32_t RTC_TypeDef::BKP11R`
- `__IO uint32_t RTC_TypeDef::BKP12R`
- `__IO uint32_t RTC_TypeDef::BKP13R`
- `__IO uint32_t RTC_TypeDef::BKP14R`
- `__IO uint32_t RTC_TypeDef::BKP15R`
- `__IO uint32_t RTC_TypeDef::BKP16R`
- `__IO uint32_t RTC_TypeDef::BKP17R`
- `__IO uint32_t RTC_TypeDef::BKP18R`
- `__IO uint32_t RTC_TypeDef::BKP19R`
- `__IO uint32_t SAI_TypeDef::GCR`
- `__IO uint32_t SAI_Block_TypeDef::CR1`
- `__IO uint32_t SAI_Block_TypeDef::CR2`
- `__IO uint32_t SAI_Block_TypeDef::FRCR`
- `__IO uint32_t SAI_Block_TypeDef::SLOTR`
- `__IO uint32_t SAI_Block_TypeDef::IMR`
- `__IO uint32_t SAI_Block_TypeDef::SR`
- `__IO uint32_t SAI_Block_TypeDef::CLRFR`
- `__IO uint32_t SAI_Block_TypeDef::DR`
- `__IO uint32_t SDIO_TypeDef::POWER`
- `__IO uint32_t SDIO_TypeDef::CLKCR`
- `__IO uint32_t SDIO_TypeDef::ARG`
- `__IO uint32_t SDIO_TypeDef::CMD`
- `__I uint32_t SDIO_TypeDef::RESPCMD`
- `__I uint32_t SDIO_TypeDef::RESP1`
- `__I uint32_t SDIO_TypeDef::RESP2`
- `__I uint32_t SDIO_TypeDef::RESP3`
- `__I uint32_t SDIO_TypeDef::RESP4`
- `__IO uint32_t SDIO_TypeDef::DTIMER`
- `__IO uint32_t SDIO_TypeDef::DLEN`
- `__IO uint32_t SDIO_TypeDef::DCTRL`
- `__I uint32_t SDIO_TypeDef::DCOUNT`

- `__I uint32_t SDIO_TypeDef::STA`
- `__IO uint32_t SDIO_TypeDef::ICR`
- `__IO uint32_t SDIO_TypeDef::MASK`
- `uint32_t SDIO_TypeDef::RESERVED0 [2]`
- `__I uint32_t SDIO_TypeDef::FIFOCNT`
- `uint32_t SDIO_TypeDef::RESERVED1 [13]`
- `__IO uint32_t SPI_TypeDef::FIFO`
- `__IO uint16_t SPI_TypeDef::CR1`
- `uint16_t SPI_TypeDef::RESERVED0`
- `__IO uint16_t SPI_TypeDef::CR2`
- `uint16_t SPI_TypeDef::RESERVED1`
- `__IO uint16_t SPI_TypeDef::SR`
- `uint16_t SPI_TypeDef::RESERVED2`
- `__IO uint16_t SPI_TypeDef::DR`
- `uint16_t SPI_TypeDef::RESERVED3`
- `__IO uint16_t SPI_TypeDef::CRCPR`
- `uint16_t SPI_TypeDef::RESERVED4`
- `__IO uint16_t SPI_TypeDef::RXCCR`
- `uint16_t SPI_TypeDef::RESERVED5`
- `__IO uint16_t SPI_TypeDef::TXCCR`
- `uint16_t SPI_TypeDef::RESERVED6`
- `__IO uint16_t SPI_TypeDef::I2SCFGR`
- `uint16_t SPI_TypeDef::RESERVED7`
- `__IO uint16_t SPI_TypeDef::I2SPR`
- `uint16_t SPI_TypeDef::RESERVED8`
- `__IO uint16_t TIM_TypeDef::CR1`
- `uint16_t TIM_TypeDef::RESERVED0`
- `__IO uint16_t TIM_TypeDef::CR2`
- `uint16_t TIM_TypeDef::RESERVED1`
- `__IO uint16_t TIM_TypeDef::SMCR`
- `uint16_t TIM_TypeDef::RESERVED2`
- `__IO uint16_t TIM_TypeDef::DIER`
- `uint16_t TIM_TypeDef::RESERVED3`
- `__IO uint16_t TIM_TypeDef::SR`
- `uint16_t TIM_TypeDef::RESERVED4`
- `__IO uint16_t TIM_TypeDef::EGR`
- `uint16_t TIM_TypeDef::RESERVED5`
- `__IO uint16_t TIM_TypeDef::CCMR1`
- `uint16_t TIM_TypeDef::RESERVED6`
- `__IO uint16_t TIM_TypeDef::CCMR2`
- `uint16_t TIM_TypeDef::RESERVED7`
- `__IO uint16_t TIM_TypeDef::CCER`
- `uint16_t TIM_TypeDef::RESERVED8`
- `__IO uint32_t TIM_TypeDef::CNT`
- `__IO uint16_t TIM_TypeDef::PSC`
- `uint16_t TIM_TypeDef::RESERVED9`
- `__IO uint32_t TIM_TypeDef::ARR`
- `__IO uint16_t TIM_TypeDef::RCR`
- `uint16_t TIM_TypeDef::RESERVED10`
- `__IO uint32_t TIM_TypeDef::CCR1`
- `__IO uint32_t TIM_TypeDef::CCR2`
- `__IO uint32_t TIM_TypeDef::CCR3`
- `__IO uint32_t TIM_TypeDef::CCR4`
- `__IO uint16_t TIM_TypeDef::BDTR`
- `uint16_t TIM_TypeDef::RESERVED11`

- `__IO uint16_t TIM_TypeDef::DCR`
- `uint16_t TIM_TypeDef::RESERVED12`
- `__IO uint16_t TIM_TypeDef::DMAR`
- `uint16_t TIM_TypeDef::RESERVED13`
- `__IO uint16_t TIM_TypeDef::OR`
- `uint16_t TIM_TypeDef::RESERVED14`
- `__IO uint16_t USART_TypeDef::SR`
- `uint16_t USART_TypeDef::RESERVED0`
- `__IO uint16_t USART_TypeDef::DR`
- `uint16_t USART_TypeDef::RESERVED1`
- `__IO uint16_t USART_TypeDef::BRR`
- `uint16_t USART_TypeDef::RESERVED2`
- `__IO uint16_t USART_TypeDef::CR1`
- `uint16_t USART_TypeDef::RESERVED3`
- `__IO uint16_t USART_TypeDef::CR2`
- `uint16_t USART_TypeDef::RESERVED4`
- `__IO uint16_t USART_TypeDef::CR3`
- `uint16_t USART_TypeDef::RESERVED5`
- `__IO uint16_t USART_TypeDef::GTPR`
- `uint16_t USART_TypeDef::RESERVED6`
- `__IO uint32_t WWDG_TypeDef::CR`
- `__IO uint32_t WWDG_TypeDef::CFR`
- `__IO uint32_t WWDG_TypeDef::SR`
- `__IO uint32_t CRYP_TypeDef::CR`
- `__IO uint32_t CRYP_TypeDef::SR`
- `__IO uint32_t CRYP_TypeDef::DR`
- `__IO uint32_t CRYP_TypeDef::DOUT`
- `__IO uint32_t CRYP_TypeDef::DMACR`
- `__IO uint32_t CRYP_TypeDef::IMSCR`
- `__IO uint32_t CRYP_TypeDef::RISR`
- `__IO uint32_t CRYP_TypeDef::MISR`
- `__IO uint32_t CRYP_TypeDef::K0LR`
- `__IO uint32_t CRYP_TypeDef::K0RR`
- `__IO uint32_t CRYP_TypeDef::K1LR`
- `__IO uint32_t CRYP_TypeDef::K1RR`
- `__IO uint32_t CRYP_TypeDef::K2LR`
- `__IO uint32_t CRYP_TypeDef::K2RR`
- `__IO uint32_t CRYP_TypeDef::K3LR`
- `__IO uint32_t CRYP_TypeDef::K3RR`
- `__IO uint32_t CRYP_TypeDef::IV0LR`
- `__IO uint32_t CRYP_TypeDef::IV0RR`
- `__IO uint32_t CRYP_TypeDef::IV1LR`
- `__IO uint32_t CRYP_TypeDef::IV1RR`
- `__IO uint32_t CRYP_TypeDef::CSGCMCCM0R`
- `__IO uint32_t CRYP_TypeDef::CSGCMCCM1R`
- `__IO uint32_t CRYP_TypeDef::CSGCMCCM2R`
- `__IO uint32_t CRYP_TypeDef::CSGCMCCM3R`
- `__IO uint32_t CRYP_TypeDef::CSGCMCCM4R`
- `__IO uint32_t CRYP_TypeDef::CSGCMCCM5R`
- `__IO uint32_t CRYP_TypeDef::CSGCMCCM6R`
- `__IO uint32_t CRYP_TypeDef::CSGCMCCM7R`
- `__IO uint32_t CRYP_TypeDef::CSGCM0R`
- `__IO uint32_t CRYP_TypeDef::CSGCM1R`
- `__IO uint32_t CRYP_TypeDef::CSGCM2R`
- `__IO uint32_t CRYP_TypeDef::CSGCM3R`

- `__IO uint32_t CRYP_TypeDef::CSGCM4R`
- `__IO uint32_t CRYP_TypeDef::CSGCM5R`
- `__IO uint32_t CRYP_TypeDef::CSGCM6R`
- `__IO uint32_t CRYP_TypeDef::CSGCM7R`
- `__IO uint32_t HASH_TypeDef::CR`
- `__IO uint32_t HASH_TypeDef::DIN`
- `__IO uint32_t HASH_TypeDef::STR`
- `__IO uint32_t HASH_TypeDef::HR [5]`
- `__IO uint32_t HASH_TypeDef::IMR`
- `__IO uint32_t HASH_TypeDef::SR`
- `uint32_t HASH_TypeDef::RESERVED [52]`
- `__IO uint32_t HASH_TypeDef::CSR [54]`
- `__IO uint32_t HASH_DIGEST_TypeDef::HR [8]`
- `__IO uint32_t RNG_TypeDef::CR`
- `__IO uint32_t RNG_TypeDef::SR`
- `__IO uint32_t RNG_TypeDef::DR`
  
- `volatile int32_t ITM_RxBuffer`
- `__STATIC_INLINE void NVIC_SetPriorityGrouping (uint32_t PriorityGroup)`

*Set Priority Grouping.*
- `__STATIC_INLINE uint32_t NVIC_GetPriorityGrouping (void)`

*Get Priority Grouping.*
- `__STATIC_INLINE void NVIC_EnableIRQ (IRQn_Type IRQn)`

*Enable External Interrupt.*
- `__STATIC_INLINE void NVIC_DisableIRQ (IRQn_Type IRQn)`

*Disable External Interrupt.*
- `__STATIC_INLINE uint32_t NVIC_GetPendingIRQ (IRQn_Type IRQn)`

*Get Pending Interrupt.*
- `__STATIC_INLINE void NVIC_SetPendingIRQ (IRQn_Type IRQn)`

*Set Pending Interrupt.*
- `__STATIC_INLINE void NVIC_ClearPendingIRQ (IRQn_Type IRQn)`

*Clear Pending Interrupt.*
- `__STATIC_INLINE uint32_t NVIC_GetActive (IRQn_Type IRQn)`

*Get Active Interrupt.*
- `__STATIC_INLINE void NVIC_SetPriority (IRQn_Type IRQn, uint32_t priority)`

*Set Interrupt Priority.*
- `__STATIC_INLINE uint32_t NVIC_GetPriority (IRQn_Type IRQn)`

*Get Interrupt Priority.*
- `__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority)`

*Encode Priority.*
- `__STATIC_INLINE void NVIC_DecodePriority (uint32_t Priority, uint32_t PriorityGroup, uint32_t *pPreemptPriority, uint32_t *pSubPriority)`

*Decode Priority.*
- `__STATIC_INLINE void NVIC_SystemReset (void)`

*System Reset.*
- `__STATIC_INLINE uint32_t SysTick_Config (uint32_t ticks)`

*System Tick Configuration.*
- `__STATIC_INLINE uint32_t ITM_SendChar (uint32_t ch)`

*ITM Send Character.*
- `__STATIC_INLINE int32_t ITM_ReceiveChar (void)`

*ITM Receive Character.*

- `__STATIC_INLINE int32_t ITM_CheckChar (void)`  
*ITM Check Character.*
- `#define __CM4_CMSIS_VERSION_MAIN (0x04)`
- `#define __CM4_CMSIS_VERSION_SUB (0x00)`
- `#define __CM4_CMSIS_VERSION`
- `#define __CORTEX_M (0x04)`
- `#define __CORE_CM4_H_DEPENDANT`
- `#define __I volatile const`
- `#define __O volatile`
- `#define __IO volatile`
- `#define APSR_N_Pos 31`
- `#define APSR_N_Msk (1UL << APSR_N_Pos)`
- `#define APSR_Z_Pos 30`
- `#define APSR_Z_Msk (1UL << APSR_Z_Pos)`
- `#define APSR_C_Pos 29`
- `#define APSR_C_Msk (1UL << APSR_C_Pos)`
- `#define APSR_V_Pos 28`
- `#define APSR_V_Msk (1UL << APSR_V_Pos)`
- `#define APSR_Q_Pos 27`
- `#define APSR_Q_Msk (1UL << APSR_Q_Pos)`
- `#define APSR_GE_Pos 16`
- `#define APSR_GE_Msk (0xFUL << APSR_GE_Pos)`
- `#define IPSR_ISR_Pos 0`
- `#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/)`
- `#define xPSR_N_Pos 31`
- `#define xPSR_N_Msk (1UL << xPSR_N_Pos)`
- `#define xPSR_Z_Pos 30`
- `#define xPSR_Z_Msk (1UL << xPSR_Z_Pos)`
- `#define xPSR_C_Pos 29`
- `#define xPSR_C_Msk (1UL << xPSR_C_Pos)`
- `#define xPSR_V_Pos 28`
- `#define xPSR_V_Msk (1UL << xPSR_V_Pos)`
- `#define xPSR_Q_Pos 27`
- `#define xPSR_Q_Msk (1UL << xPSR_Q_Pos)`
- `#define xPSR_IT_Pos 25`
- `#define xPSR_IT_Msk (3UL << xPSR_IT_Pos)`
- `#define xPSR_T_Pos 24`
- `#define xPSR_T_Msk (1UL << xPSR_T_Pos)`
- `#define xPSR_GE_Pos 16`
- `#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos)`
- `#define xPSR_ISR_Pos 0`
- `#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/)`
- `#define CONTROL_FPCA_Pos 2`
- `#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos)`
- `#define CONTROL_SPSEL_Pos 1`
- `#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos)`
- `#define CONTROL_nPRIV_Pos 0`
- `#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/)`
- `#define NVIC_STIR_INTID_Pos 0`
- `#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/)`
- `#define SCB_CPUID_IMPLEMENTER_Pos 24`
- `#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos)`
- `#define SCB_CPUID_VARIANT_Pos 20`
- `#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos)`

- #define SCB\_CPUID\_ARCHITECTURE\_Pos 16
- #define SCB\_CPUID\_ARCHITECTURE\_Msk (0xFUL << SCB\_CPUID\_ARCHITECTURE\_Pos)
- #define SCB\_CPUID\_PARTNO\_Pos 4
- #define SCB\_CPUID\_PARTNO\_Msk (0xFFFFUL << SCB\_CPUID\_PARTNO\_Pos)
- #define SCB\_CPUID\_REVISION\_Pos 0
- #define SCB\_CPUID\_REVISION\_Msk (0xFUL /\*<< SCB\_CPUID\_REVISION\_Pos\*/)
- #define SCB\_ICSR\_NMIPENDSET\_Pos 31
- #define SCB\_ICSR\_NMIPENDSET\_Msk (1UL << SCB\_ICSR\_NMIPENDSET\_Pos)
- #define SCB\_ICSR\_PENDSVSET\_Pos 28
- #define SCB\_ICSR\_PENDSVSET\_Msk (1UL << SCB\_ICSR\_PENDSVSET\_Pos)
- #define SCB\_ICSR\_PENDSVCLR\_Pos 27
- #define SCB\_ICSR\_PENDSVCLR\_Msk (1UL << SCB\_ICSR\_PENDSVCLR\_Pos)
- #define SCB\_ICSR\_PENDSTSET\_Pos 26
- #define SCB\_ICSR\_PENDSTSET\_Msk (1UL << SCB\_ICSR\_PENDSTSET\_Pos)
- #define SCB\_ICSR\_PENDSTCLR\_Pos 25
- #define SCB\_ICSR\_PENDSTCLR\_Msk (1UL << SCB\_ICSR\_PENDSTCLR\_Pos)
- #define SCB\_ICSR\_ISRPREEMPT\_Pos 23
- #define SCB\_ICSR\_ISRPREEMPT\_Msk (1UL << SCB\_ICSR\_ISRPREEMPT\_Pos)
- #define SCB\_ICSR\_ISRPENDING\_Pos 22
- #define SCB\_ICSR\_ISRPENDING\_Msk (1UL << SCB\_ICSR\_ISRPENDING\_Pos)
- #define SCB\_ICSR\_VECTPENDING\_Pos 12
- #define SCB\_ICSR\_VECTPENDING\_Msk (0x1FFUL << SCB\_ICSR\_VECTPENDING\_Pos)
- #define SCB\_ICSR\_RETTOBASE\_Pos 11
- #define SCB\_ICSR\_RETTOBASE\_Msk (1UL << SCB\_ICSR\_RETTOBASE\_Pos)
- #define SCB\_ICSR\_VECTACTIVE\_Pos 0
- #define SCB\_ICSR\_VECTACTIVE\_Msk (0x1FFUL /\*<< SCB\_ICSR\_VECTACTIVE\_Pos\*/)
- #define SCB\_VTOR\_TBLOFF\_Pos 7
- #define SCB\_VTOR\_TBLOFF\_Msk (0x1FFFFFFFUL << SCB\_VTOR\_TBLOFF\_Pos)
- #define SCB\_AIRCR\_VECTKEY\_Pos 16
- #define SCB\_AIRCR\_VECTKEY\_Msk (0xFFFFUL << SCB\_AIRCR\_VECTKEY\_Pos)
- #define SCB\_AIRCR\_VECTKEYSTAT\_Pos 16
- #define SCB\_AIRCR\_VECTKEYSTAT\_Msk (0xFFFFUL << SCB\_AIRCR\_VECTKEYSTAT\_Pos)
- #define SCB\_AIRCR\_ENDIANESS\_Pos 15
- #define SCB\_AIRCR\_ENDIANESS\_Msk (1UL << SCB\_AIRCR\_ENDIANESS\_Pos)
- #define SCB\_AIRCR\_PRIGROUP\_Pos 8
- #define SCB\_AIRCR\_PRIGROUP\_Msk (7UL << SCB\_AIRCR\_PRIGROUP\_Pos)
- #define SCB\_AIRCR\_SYSRESETREQ\_Pos 2
- #define SCB\_AIRCR\_SYSRESETREQ\_Msk (1UL << SCB\_AIRCR\_SYSRESETREQ\_Pos)
- #define SCB\_AIRCR\_VECTCLRACTIVE\_Pos 1
- #define SCB\_AIRCR\_VECTCLRACTIVE\_Msk (1UL << SCB\_AIRCR\_VECTCLRACTIVE\_Pos)
- #define SCB\_AIRCR\_VECTRESET\_Pos 0
- #define SCB\_AIRCR\_VECTRESET\_Msk (1UL /\*<< SCB\_AIRCR\_VECTRESET\_Pos\*/)
- #define SCB\_SCR\_SEVONPEND\_Pos 4
- #define SCB\_SCR\_SEVONPEND\_Msk (1UL << SCB\_SCR\_SEVONPEND\_Pos)
- #define SCB\_SCR\_SLEEPDEEP\_Pos 2
- #define SCB\_SCR\_SLEEPDEEP\_Msk (1UL << SCB\_SCR\_SLEEPDEEP\_Pos)
- #define SCB\_SCR\_SLEEPONEXIT\_Pos 1
- #define SCB\_SCR\_SLEEPONEXIT\_Msk (1UL << SCB\_SCR\_SLEEPONEXIT\_Pos)
- #define SCB\_CCR\_STKALIGN\_Pos 9
- #define SCB\_CCR\_STKALIGN\_Msk (1UL << SCB\_CCR\_STKALIGN\_Pos)
- #define SCB\_CCR\_BFHFMIGN\_Pos 8
- #define SCB\_CCR\_BFHFMIGN\_Msk (1UL << SCB\_CCR\_BFHFMIGN\_Pos)
- #define SCB\_CCR\_DIV\_0\_TRP\_Pos 4
- #define SCB\_CCR\_DIV\_0\_TRP\_Msk (1UL << SCB\_CCR\_DIV\_0\_TRP\_Pos)
- #define SCB\_CCR\_UNALIGN\_TRP\_Pos 3

- #define SCB\_CCR\_UNALIGN\_TRP\_Msk (1UL << SCB\_CCR\_UNALIGN\_TRP\_Pos)
- #define SCB\_CCR\_USERSETMPEND\_Pos 1
- #define SCB\_CCR\_USERSETMPEND\_Msk (1UL << SCB\_CCR\_USERSETMPEND\_Pos)
- #define SCB\_CCR\_NONBASETHRDENA\_Pos 0
- #define SCB\_CCR\_NONBASETHRDENA\_Msk (1UL /\*<< SCB\_CCR\_NONBASETHRDENA\_Pos\*/)
- #define SCB\_SHCSR\_USGFAULTENA\_Pos 18
- #define SCB\_SHCSR\_USGFAULTENA\_Msk (1UL << SCB\_SHCSR\_USGFAULTENA\_Pos)
- #define SCB\_SHCSR\_BUSFAULTENA\_Pos 17
- #define SCB\_SHCSR\_BUSFAULTENA\_Msk (1UL << SCB\_SHCSR\_BUSFAULTENA\_Pos)
- #define SCB\_SHCSR\_MEMFAULTENA\_Pos 16
- #define SCB\_SHCSR\_MEMFAULTENA\_Msk (1UL << SCB\_SHCSR\_MEMFAULTENA\_Pos)
- #define SCB\_SHCSR\_SVCALLPENDED\_Pos 15
- #define SCB\_SHCSR\_SVCALLPENDED\_Msk (1UL << SCB\_SHCSR\_SVCALLPENDED\_Pos)
- #define SCB\_SHCSR\_BUSFAULTPENDED\_Pos 14
- #define SCB\_SHCSR\_BUSFAULTPENDED\_Msk (1UL << SCB\_SHCSR\_BUSFAULTPENDED\_Pos)
- #define SCB\_SHCSR\_MEMFAULTPENDED\_Pos 13
- #define SCB\_SHCSR\_MEMFAULTPENDED\_Msk (1UL << SCB\_SHCSR\_MEMFAULTPENDED\_Pos)
- #define SCB\_SHCSR\_USGFAULTPENDED\_Pos 12
- #define SCB\_SHCSR\_USGFAULTPENDED\_Msk (1UL << SCB\_SHCSR\_USGFAULTPENDED\_Pos)
- #define SCB\_SHCSR\_SYSTICKACT\_Pos 11
- #define SCB\_SHCSR\_SYSTICKACT\_Msk (1UL << SCB\_SHCSR\_SYSTICKACT\_Pos)
- #define SCB\_SHCSR\_PENDSVACT\_Pos 10
- #define SCB\_SHCSR\_PENDSVACT\_Msk (1UL << SCB\_SHCSR\_PENDSVACT\_Pos)
- #define SCB\_SHCSR\_MONITORACT\_Pos 8
- #define SCB\_SHCSR\_MONITORACT\_Msk (1UL << SCB\_SHCSR\_MONITORACT\_Pos)
- #define SCB\_SHCSR\_SVCALLACT\_Pos 7
- #define SCB\_SHCSR\_SVCALLACT\_Msk (1UL << SCB\_SHCSR\_SVCALLACT\_Pos)
- #define SCB\_SHCSR\_USGFAULTACT\_Pos 3
- #define SCB\_SHCSR\_USGFAULTACT\_Msk (1UL << SCB\_SHCSR\_USGFAULTACT\_Pos)
- #define SCB\_SHCSR\_BUSFAULTACT\_Pos 1
- #define SCB\_SHCSR\_BUSFAULTACT\_Msk (1UL << SCB\_SHCSR\_BUSFAULTACT\_Pos)
- #define SCB\_SHCSR\_MEMFAULTACT\_Pos 0
- #define SCB\_SHCSR\_MEMFAULTACT\_Msk (1UL /\*<< SCB\_SHCSR\_MEMFAULTACT\_Pos\*/)
- #define SCB\_CFSR\_USGFAULTSR\_Pos 16
- #define SCB\_CFSR\_USGFAULTSR\_Msk (0xFFFFUL << SCB\_CFSR\_USGFAULTSR\_Pos)
- #define SCB\_CFSR\_BUSFAULTSR\_Pos 8
- #define SCB\_CFSR\_BUSFAULTSR\_Msk (0xFFUL << SCB\_CFSR\_BUSFAULTSR\_Pos)
- #define SCB\_CFSR\_MEMFAULTSR\_Pos 0
- #define SCB\_CFSR\_MEMFAULTSR\_Msk (0xFFUL /\*<< SCB\_CFSR\_MEMFAULTSR\_Pos\*/)
- #define SCB\_HFSR\_DEBUGEVT\_Pos 31
- #define SCB\_HFSR\_DEBUGEVT\_Msk (1UL << SCB\_HFSR\_DEBUGEVT\_Pos)
- #define SCB\_HFSR\_FORCED\_Pos 30
- #define SCB\_HFSR\_FORCED\_Msk (1UL << SCB\_HFSR\_FORCED\_Pos)
- #define SCB\_HFSR\_VECTTBL\_Pos 1
- #define SCB\_HFSR\_VECTTBL\_Msk (1UL << SCB\_HFSR\_VECTTBL\_Pos)
- #define SCB\_DFSR\_EXTERNAL\_Pos 4
- #define SCB\_DFSR\_EXTERNAL\_Msk (1UL << SCB\_DFSR\_EXTERNAL\_Pos)
- #define SCB\_DFSR\_VCATCH\_Pos 3
- #define SCB\_DFSR\_VCATCH\_Msk (1UL << SCB\_DFSR\_VCATCH\_Pos)
- #define SCB\_DFSR\_DWTTRAP\_Pos 2
- #define SCB\_DFSR\_DWTTRAP\_Msk (1UL << SCB\_DFSR\_DWTTRAP\_Pos)
- #define SCB\_DFSR\_BKPT\_Pos 1
- #define SCB\_DFSR\_BKPT\_Msk (1UL << SCB\_DFSR\_BKPT\_Pos)
- #define SCB\_DFSR\_HALTED\_Pos 0
- #define SCB\_DFSR\_HALTED\_Msk (1UL /\*<< SCB\_DFSR\_HALTED\_Pos\*/)

- #define SCnSCB\_ICTR\_INTLINESNUM\_Pos 0
- #define SCnSCB\_ICTR\_INTLINESNUM\_Msk (0xFUL /\*<< SCnSCB\_ICTR\_INTLINESNUM\_Pos\*/)
- #define SCnSCB\_ACTLR\_DISOOPF\_Pos 9
- #define SCnSCB\_ACTLR\_DISOOPF\_Msk (1UL << SCnSCB\_ACTLR\_DISOOPF\_Pos)
- #define SCnSCB\_ACTLR\_DISFPCA\_Pos 8
- #define SCnSCB\_ACTLR\_DISFPCA\_Msk (1UL << SCnSCB\_ACTLR\_DISFPCA\_Pos)
- #define SCnSCB\_ACTLR\_DISFOLD\_Pos 2
- #define SCnSCB\_ACTLR\_DISFOLD\_Msk (1UL << SCnSCB\_ACTLR\_DISFOLD\_Pos)
- #define SCnSCB\_ACTLR\_DISDEFWBUFF\_Pos 1
- #define SCnSCB\_ACTLR\_DISDEFWBUFF\_Msk (1UL << SCnSCB\_ACTLR\_DISDEFWBUFF\_Pos)
- #define SCnSCB\_ACTLR\_DISMCYCINT\_Pos 0
- #define SCnSCB\_ACTLR\_DISMCYCINT\_Msk (1UL /\*<< SCnSCB\_ACTLR\_DISMCYCINT\_Pos\*/)
- #define SysTick\_CTRL\_COUNTFLAG\_Pos 16
- #define SysTick\_CTRL\_COUNTFLAG\_Msk (1UL << SysTick\_CTRL\_COUNTFLAG\_Pos)
- #define SysTick\_CTRL\_CLKSOURCE\_Pos 2
- #define SysTick\_CTRL\_CLKSOURCE\_Msk (1UL << SysTick\_CTRL\_CLKSOURCE\_Pos)
- #define SysTick\_CTRL\_TICKINT\_Pos 1
- #define SysTick\_CTRL\_TICKINT\_Msk (1UL << SysTick\_CTRL\_TICKINT\_Pos)
- #define SysTick\_CTRL\_ENABLE\_Pos 0
- #define SysTick\_CTRL\_ENABLE\_Msk (1UL /\*<< SysTick\_CTRL\_ENABLE\_Pos\*/)
- #define SysTick\_LOAD\_RELOAD\_Pos 0
- #define SysTick\_LOAD\_RELOAD\_Msk (0xFFFFFUL /\*<< SysTick\_LOAD\_RELOAD\_Pos\*/)
- #define SysTick\_VAL\_CURRENT\_Pos 0
- #define SysTick\_VAL\_CURRENT\_Msk (0xFFFFFUL /\*<< SysTick\_VAL\_CURRENT\_Pos\*/)
- #define SysTick\_CALIB\_NOREF\_Pos 31
- #define SysTick\_CALIB\_NOREF\_Msk (1UL << SysTick\_CALIB\_NOREF\_Pos)
- #define SysTick\_CALIB\_SKEW\_Pos 30
- #define SysTick\_CALIB\_SKEW\_Msk (1UL << SysTick\_CALIB\_SKEW\_Pos)
- #define SysTick\_CALIB\_TENMS\_Pos 0
- #define SysTick\_CALIB\_TENMS\_Msk (0xFFFFFUL /\*<< SysTick\_CALIB\_TENMS\_Pos\*/)
- #define ITM\_TPR\_PRIVMASK\_Pos 0
- #define ITM\_TPR\_PRIVMASK\_Msk (0xFUL /\*<< ITM\_TPR\_PRIVMASK\_Pos\*/)
- #define ITM\_TCR\_BUSY\_Pos 23
- #define ITM\_TCR\_BUSY\_Msk (1UL << ITM\_TCR\_BUSY\_Pos)
- #define ITM\_TCR\_TraceBusID\_Pos 16
- #define ITM\_TCR\_TraceBusID\_Msk (0x7FUL << ITM\_TCR\_TraceBusID\_Pos)
- #define ITM\_TCR\_GTSFREQ\_Pos 10
- #define ITM\_TCR\_GTSFREQ\_Msk (3UL << ITM\_TCR\_GTSFREQ\_Pos)
- #define ITM\_TCR\_TSPrescale\_Pos 8
- #define ITM\_TCR\_TSPrescale\_Msk (3UL << ITM\_TCR\_TSPrescale\_Pos)
- #define ITM\_TCR\_SWOENA\_Pos 4
- #define ITM\_TCR\_SWOENA\_Msk (1UL << ITM\_TCR\_SWOENA\_Pos)
- #define ITM\_TCR\_DWTENA\_Pos 3
- #define ITM\_TCR\_DWTENA\_Msk (1UL << ITM\_TCR\_DWTENA\_Pos)
- #define ITM\_TCR\_SYNCENA\_Pos 2
- #define ITM\_TCR\_SYNCENA\_Msk (1UL << ITM\_TCR\_SYNCENA\_Pos)
- #define ITM\_TCR\_TSENA\_Pos 1
- #define ITM\_TCR\_TSENA\_Msk (1UL << ITM\_TCR\_TSENA\_Pos)
- #define ITM\_TCR\_ITMENA\_Pos 0
- #define ITM\_TCR\_ITMENA\_Msk (1UL /\*<< ITM\_TCR\_ITMENA\_Pos\*/)
- #define ITM\_IWR\_ATVALIDDM\_Pos 0
- #define ITM\_IWR\_ATVALIDDM\_Msk (1UL /\*<< ITM\_IWR\_ATVALIDDM\_Pos\*/)
- #define ITM\_IRR\_ATREADYM\_Pos 0
- #define ITM\_IRR\_ATREADYM\_Msk (1UL /\*<< ITM\_IRR\_ATREADYM\_Pos\*/)
- #define ITM\_IMCR\_INTEGRATION\_Pos 0

- #define ITM\_IMCR\_INTEGRATION\_Msk (1UL /\*<< ITM\_IMCR\_INTEGRATION\_Pos\*/)
- #define ITM\_LSR\_ByteAcc\_Pos 2
- #define ITM\_LSR\_ByteAcc\_Msk (1UL << ITM\_LSR\_ByteAcc\_Pos)
- #define ITM\_LSR\_Access\_Pos 1
- #define ITM\_LSR\_Access\_Msk (1UL << ITM\_LSR\_Access\_Pos)
- #define ITM\_LSR\_Present\_Pos 0
- #define ITM\_LSR\_Present\_Msk (1UL /\*<< ITM\_LSR\_Present\_Pos\*/)
- #define DWT\_CTRL\_NUMCOMP\_Pos 28
- #define DWT\_CTRL\_NUMCOMP\_Msk (0xFUL << DWT\_CTRL\_NUMCOMP\_Pos)
- #define DWT\_CTRL\_NOTRCPKT\_Pos 27
- #define DWT\_CTRL\_NOTRCPKT\_Msk (0x1UL << DWT\_CTRL\_NOTRCPKT\_Pos)
- #define DWT\_CTRL\_NOEXTTRIG\_Pos 26
- #define DWT\_CTRL\_NOEXTTRIG\_Msk (0x1UL << DWT\_CTRL\_NOEXTTRIG\_Pos)
- #define DWT\_CTRL\_NOCYCCNT\_Pos 25
- #define DWT\_CTRL\_NOCYCCNT\_Msk (0x1UL << DWT\_CTRL\_NOCYCCNT\_Pos)
- #define DWT\_CTRL\_NOPRFCNT\_Pos 24
- #define DWT\_CTRL\_NOPRFCNT\_Msk (0x1UL << DWT\_CTRL\_NOPRFCNT\_Pos)
- #define DWT\_CTRL\_CYCEVTENA\_Pos 22
- #define DWT\_CTRL\_CYCEVTENA\_Msk (0x1UL << DWT\_CTRL\_CYCEVTENA\_Pos)
- #define DWT\_CTRL\_FOLDEVTENA\_Pos 21
- #define DWT\_CTRL\_FOLDEVTENA\_Msk (0x1UL << DWT\_CTRL\_FOLDEVTENA\_Pos)
- #define DWT\_CTRL\_LSUEVTENA\_Pos 20
- #define DWT\_CTRL\_LSUEVTENA\_Msk (0x1UL << DWT\_CTRL\_LSUEVTENA\_Pos)
- #define DWT\_CTRL\_SLEEPEVTENA\_Pos 19
- #define DWT\_CTRL\_SLEEPEVTENA\_Msk (0x1UL << DWT\_CTRL\_SLEEPEVTENA\_Pos)
- #define DWT\_CTRL\_EXCEVTENA\_Pos 18
- #define DWT\_CTRL\_EXCEVTENA\_Msk (0x1UL << DWT\_CTRL\_EXCEVTENA\_Pos)
- #define DWT\_CTRL\_CPIEVTEA\_Pos 17
- #define DWT\_CTRL\_CPIEVTEA\_Msk (0x1UL << DWT\_CTRL\_CPIEVTEA\_Pos)
- #define DWT\_CTRL\_EXCTRCENA\_Pos 16
- #define DWT\_CTRL\_EXCTRCENA\_Msk (0x1UL << DWT\_CTRL\_EXCTRCENA\_Pos)
- #define DWT\_CTRL\_PCSAMPLENA\_Pos 12
- #define DWT\_CTRL\_PCSAMPLENA\_Msk (0x1UL << DWT\_CTRL\_PCSAMPLENA\_Pos)
- #define DWT\_CTRL\_SYNCTAP\_Pos 10
- #define DWT\_CTRL\_SYNCTAP\_Msk (0x3UL << DWT\_CTRL\_SYNCTAP\_Pos)
- #define DWT\_CTRL\_CYCTAP\_Pos 9
- #define DWT\_CTRL\_CYCTAP\_Msk (0x1UL << DWT\_CTRL\_CYCTAP\_Pos)
- #define DWT\_CTRL\_POSTINIT\_Pos 5
- #define DWT\_CTRL\_POSTINIT\_Msk (0xFUL << DWT\_CTRL\_POSTINIT\_Pos)
- #define DWT\_CTRL\_POSTPRESET\_Pos 1
- #define DWT\_CTRL\_POSTPRESET\_Msk (0xFUL << DWT\_CTRL\_POSTPRESET\_Pos)
- #define DWT\_CTRL\_CYCCNTENA\_Pos 0
- #define DWT\_CTRL\_CYCCNTENA\_Msk (0x1UL /\*<< DWT\_CTRL\_CYCCNTENA\_Pos\*/)
- #define DWT\_CPLICNT\_CPLICNT\_Pos 0
- #define DWT\_CPLICNT\_CPLICNT\_Msk (0xFFUL /\*<< DWT\_CPLICNT\_CPLICNT\_Pos\*/)
- #define DWT\_EXCCNT\_EXCCNT\_Pos 0
- #define DWT\_EXCCNT\_EXCCNT\_Msk (0xFFUL /\*<< DWT\_EXCCNT\_EXCCNT\_Pos\*/)
- #define DWT\_SLEEPcnt\_SLEEPcnt\_Pos 0
- #define DWT\_SLEEPcnt\_SLEEPcnt\_Msk (0xFFUL /\*<< DWT\_SLEEPcnt\_SLEEPcnt\_Pos\*/)
- #define DWT\_LSUCNT\_LSUCNT\_Pos 0
- #define DWT\_LSUCNT\_LSUCNT\_Msk (0xFFUL /\*<< DWT\_LSUCNT\_LSUCNT\_Pos\*/)
- #define DWT\_FOLDCNT\_FOLDCNT\_Pos 0
- #define DWT\_FOLDCNT\_FOLDCNT\_Msk (0xFFUL /\*<< DWT\_FOLDCNT\_FOLDCNT\_Pos\*/)
- #define DWT\_MASK\_MASK\_Pos 0
- #define DWT\_MASK\_MASK\_Msk (0x1FUL /\*<< DWT\_MASK\_MASK\_Pos\*/)

- #define DWT\_FUNCTION\_MATCHED\_Pos 24
- #define DWT\_FUNCTION\_MATCHED\_Msk (0x1UL << DWT\_FUNCTION\_MATCHED\_Pos)
- #define DWT\_FUNCTION\_DATAVADDR1\_Pos 16
- #define DWT\_FUNCTION\_DATAVADDR1\_Msk (0xFUL << DWT\_FUNCTION\_DATAVADDR1\_Pos)
- #define DWT\_FUNCTION\_DATAVADDR0\_Pos 12
- #define DWT\_FUNCTION\_DATAVADDR0\_Msk (0xFUL << DWT\_FUNCTION\_DATAVADDR0\_Pos)
- #define DWT\_FUNCTION\_DATAVSIZE\_Pos 10
- #define DWT\_FUNCTION\_DATAVSIZE\_Msk (0x3UL << DWT\_FUNCTION\_DATAVSIZE\_Pos)
- #define DWT\_FUNCTION\_LNK1ENA\_Pos 9
- #define DWT\_FUNCTION\_LNK1ENA\_Msk (0x1UL << DWT\_FUNCTION\_LNK1ENA\_Pos)
- #define DWT\_FUNCTION\_DATAVMATCH\_Pos 8
- #define DWT\_FUNCTION\_DATAVMATCH\_Msk (0x1UL << DWT\_FUNCTION\_DATAVMATCH\_Pos)
- #define DWT\_FUNCTION\_CYCMATCH\_Pos 7
- #define DWT\_FUNCTION\_CYCMATCH\_Msk (0x1UL << DWT\_FUNCTION\_CYCMATCH\_Pos)
- #define DWT\_FUNCTION\_EMITRANGE\_Pos 5
- #define DWT\_FUNCTION\_EMITRANGE\_Msk (0x1UL << DWT\_FUNCTION\_EMITRANGE\_Pos)
- #define DWT\_FUNCTION\_FUNCTION\_Pos 0
- #define DWT\_FUNCTION\_FUNCTION\_Msk (0xFUL /\*<< DWT\_FUNCTION\_FUNCTION\_Pos\*/)
- #define TPI\_ACPR\_PRESCALER\_Pos 0
- #define TPI\_ACPR\_PRESCALER\_Msk (0xFFFFUL /\*<< TPI\_ACPR\_PRESCALER\_Pos\*/)
- #define TPI\_SPPR\_TXMODE\_Pos 0
- #define TPI\_SPPR\_TXMODE\_Msk (0x3UL /\*<< TPI\_SPPR\_TXMODE\_Pos\*/)
- #define TPI\_FFSR\_FtNonStop\_Pos 3
- #define TPI\_FFSR\_FtNonStop\_Msk (0x1UL << TPI\_FFSR\_FtNonStop\_Pos)
- #define TPI\_FFSR\_TCPresent\_Pos 2
- #define TPI\_FFSR\_TCPresent\_Msk (0x1UL << TPI\_FFSR\_TCPresent\_Pos)
- #define TPI\_FFSR\_FtStopped\_Pos 1
- #define TPI\_FFSR\_FtStopped\_Msk (0x1UL << TPI\_FFSR\_FtStopped\_Pos)
- #define TPI\_FFSR\_FInProg\_Pos 0
- #define TPI\_FFSR\_FInProg\_Msk (0x1UL /\*<< TPI\_FFSR\_FInProg\_Pos\*/)
- #define TPI\_FFCR\_TrigIn\_Pos 8
- #define TPI\_FFCR\_TrigIn\_Msk (0x1UL << TPI\_FFCR\_TrigIn\_Pos)
- #define TPI\_FFCR\_EnFCont\_Pos 1
- #define TPI\_FFCR\_EnFCont\_Msk (0x1UL << TPI\_FFCR\_EnFCont\_Pos)
- #define TPI\_TRIGGER\_TRIGGER\_Pos 0
- #define TPI\_TRIGGER\_TRIGGER\_Msk (0x1UL /\*<< TPI\_TRIGGER\_TRIGGER\_Pos\*/)
- #define TPI\_FIFO0\_ITM\_ATVALID\_Pos 29
- #define TPI\_FIFO0\_ITM\_ATVALID\_Msk (0x3UL << TPI\_FIFO0\_ITM\_ATVALID\_Pos)
- #define TPI\_FIFO0\_ITM\_bytectcount\_Pos 27
- #define TPI\_FIFO0\_ITM\_bytectcount\_Msk (0x3UL << TPI\_FIFO0\_ITM\_bytectcount\_Pos)
- #define TPI\_FIFO0\_ETM\_ATVALID\_Pos 26
- #define TPI\_FIFO0\_ETM\_ATVALID\_Msk (0x3UL << TPI\_FIFO0\_ETM\_ATVALID\_Pos)
- #define TPI\_FIFO0\_ETM\_bytectcount\_Pos 24
- #define TPI\_FIFO0\_ETM\_bytectcount\_Msk (0x3UL << TPI\_FIFO0\_ETM\_bytectcount\_Pos)
- #define TPI\_FIFO0\_ETM2\_Pos 16
- #define TPI\_FIFO0\_ETM2\_Msk (0xFFUL << TPI\_FIFO0\_ETM2\_Pos)
- #define TPI\_FIFO0\_ETM1\_Pos 8
- #define TPI\_FIFO0\_ETM1\_Msk (0xFFUL << TPI\_FIFO0\_ETM1\_Pos)
- #define TPI\_FIFO0\_ETM0\_Pos 0
- #define TPI\_FIFO0\_ETM0\_Msk (0xFFUL /\*<< TPI\_FIFO0\_ETM0\_Pos\*/)
- #define TPI\_ITATBCTR2\_ATREADY\_Pos 0
- #define TPI\_ITATBCTR2\_ATREADY\_Msk (0x1UL /\*<< TPI\_ITATBCTR2\_ATREADY\_Pos\*/)
- #define TPI\_FIFO1\_ITM\_ATVALID\_Pos 29
- #define TPI\_FIFO1\_ITM\_ATVALID\_Msk (0x3UL << TPI\_FIFO1\_ITM\_ATVALID\_Pos)
- #define TPI\_FIFO1\_ITM\_bytectcount\_Pos 27

- #define TPI\_FIFO1\_ITM\_bytecount\_Msk (0x3UL << TPI\_FIFO1\_ITM\_bytecount\_Pos)
- #define TPI\_FIFO1\_ETM\_ATVALID\_Pos 26
- #define TPI\_FIFO1\_ETM\_ATVALID\_Msk (0x3UL << TPI\_FIFO1\_ETM\_ATVALID\_Pos)
- #define TPI\_FIFO1\_ETM\_bytecount\_Pos 24
- #define TPI\_FIFO1\_ETM\_bytecount\_Msk (0x3UL << TPI\_FIFO1\_ETM\_bytecount\_Pos)
- #define TPI\_FIFO1\_ITM2\_Pos 16
- #define TPI\_FIFO1\_ITM2\_Msk (0xFFUL << TPI\_FIFO1\_ITM2\_Pos)
- #define TPI\_FIFO1\_ITM1\_Pos 8
- #define TPI\_FIFO1\_ITM1\_Msk (0xFFUL << TPI\_FIFO1\_ITM1\_Pos)
- #define TPI\_FIFO1\_ITM0\_Pos 0
- #define TPI\_FIFO1\_ITM0\_Msk (0xFFUL /\*<< TPI\_FIFO1\_ITM0\_Pos\*/)
- #define TPI\_ITATBCTR0\_ATREADY\_Pos 0
- #define TPI\_ITATBCTR0\_ATREADY\_Msk (0x1UL /\*<< TPI\_ITATBCTR0\_ATREADY\_Pos\*/)
- #define TPI\_ITCTRL\_Mode\_Pos 0
- #define TPI\_ITCTRL\_Mode\_Msk (0x1UL /\*<< TPI\_ITCTRL\_Mode\_Pos\*/)
- #define TPI\_DEVID\_NRZVALID\_Pos 11
- #define TPI\_DEVID\_NRZVALID\_Msk (0x1UL << TPI\_DEVID\_NRZVALID\_Pos)
- #define TPI\_DEVID\_MANCVALID\_Pos 10
- #define TPI\_DEVID\_MANCVALID\_Msk (0x1UL << TPI\_DEVID\_MANCVALID\_Pos)
- #define TPI\_DEVID\_PTINVALID\_Pos 9
- #define TPI\_DEVID\_PTINVALID\_Msk (0x1UL << TPI\_DEVID\_PTINVALID\_Pos)
- #define TPI\_DEVID\_MinBufSz\_Pos 6
- #define TPI\_DEVID\_MinBufSz\_Msk (0x7UL << TPI\_DEVID\_MinBufSz\_Pos)
- #define TPI\_DEVID\_AsynClkIn\_Pos 5
- #define TPI\_DEVID\_AsynClkIn\_Msk (0x1UL << TPI\_DEVID\_AsynClkIn\_Pos)
- #define TPI\_DEVID\_NrTraceInput\_Pos 0
- #define TPI\_DEVID\_NrTraceInput\_Msk (0x1FUL /\*<< TPI\_DEVID\_NrTraceInput\_Pos\*/)
- #define TPI\_DEVTYPE\_MajorType\_Pos 4
- #define TPI\_DEVTYPE\_MajorType\_Msk (0xFUL << TPI\_DEVTYPE\_MajorType\_Pos)
- #define TPI\_DEVTYPE\_SubType\_Pos 0
- #define TPI\_DEVTYPE\_SubType\_Msk (0xFUL /\*<< TPI\_DEVTYPE\_SubType\_Pos\*/)
- #define CoreDebug\_DHCSR\_DBGKEY\_Pos 16
- #define CoreDebug\_DHCSR\_DBGKEY\_Msk (0xFFFFUL << CoreDebug\_DHCSR\_DBGKEY\_Pos)
- #define CoreDebug\_DHCSR\_S\_RESET\_ST\_Pos 25
- #define CoreDebug\_DHCSR\_S\_RESET\_ST\_Msk (1UL << CoreDebug\_DHCSR\_S\_RESET\_ST\_Pos)
- #define CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Pos 24
- #define CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Msk (1UL << CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Pos)
- #define CoreDebug\_DHCSR\_S\_LOCKUP\_Pos 19
- #define CoreDebug\_DHCSR\_S\_LOCKUP\_Msk (1UL << CoreDebug\_DHCSR\_S\_LOCKUP\_Pos)
- #define CoreDebug\_DHCSR\_S\_SLEEP\_Pos 18
- #define CoreDebug\_DHCSR\_S\_SLEEP\_Msk (1UL << CoreDebug\_DHCSR\_S\_SLEEP\_Pos)
- #define CoreDebug\_DHCSR\_S\_HALT\_Pos 17
- #define CoreDebug\_DHCSR\_S\_HALT\_Msk (1UL << CoreDebug\_DHCSR\_S\_HALT\_Pos)
- #define CoreDebug\_DHCSR\_S\_REGRDY\_Pos 16
- #define CoreDebug\_DHCSR\_S\_REGRDY\_Msk (1UL << CoreDebug\_DHCSR\_S\_REGRDY\_Pos)
- #define CoreDebug\_DHCSR\_C\_SNAPSTALL\_Pos 5
- #define CoreDebug\_DHCSR\_C\_SNAPSTALL\_Msk (1UL << CoreDebug\_DHCSR\_C\_SNAPSTALL\_Pos)
- #define CoreDebug\_DHCSR\_C\_MASKINTS\_Pos 3
- #define CoreDebug\_DHCSR\_C\_MASKINTS\_Msk (1UL << CoreDebug\_DHCSR\_C\_MASKINTS\_Pos)
- #define CoreDebug\_DHCSR\_C\_STEP\_Pos 2
- #define CoreDebug\_DHCSR\_C\_STEP\_Msk (1UL << CoreDebug\_DHCSR\_C\_STEP\_Pos)
- #define CoreDebug\_DHCSR\_C\_HALT\_Pos 1
- #define CoreDebug\_DHCSR\_C\_HALT\_Msk (1UL << CoreDebug\_DHCSR\_C\_HALT\_Pos)
- #define CoreDebug\_DHCSR\_C\_DEBUGEN\_Pos 0
- #define CoreDebug\_DHCSR\_C\_DEBUGEN\_Msk (1UL /\*<< CoreDebug\_DHCSR\_C\_DEBUGEN\_Pos\*/)

- #define CoreDebug\_DCRSR\_REGWnR\_Pos 16
- #define CoreDebug\_DCRSR\_REGWnR\_Msk (1UL << CoreDebug\_DCRSR\_REGWnR\_Pos)
- #define CoreDebug\_DCRSR\_REGSEL\_Pos 0
- #define CoreDebug\_DCRSR\_REGSEL\_Msk (0x1FUL /\*<< CoreDebug\_DCRSR\_REGSEL\_Pos\*/)
- #define CoreDebug\_DEMCR\_TRCENA\_Pos 24
- #define CoreDebug\_DEMCR\_TRCENA\_Msk (1UL << CoreDebug\_DEMCR\_TRCENA\_Pos)
- #define CoreDebug\_DEMCR\_MON\_REQ\_Pos 19
- #define CoreDebug\_DEMCR\_MON\_REQ\_Msk (1UL << CoreDebug\_DEMCR\_MON\_REQ\_Pos)
- #define CoreDebug\_DEMCR\_MON\_STEP\_Pos 18
- #define CoreDebug\_DEMCR\_MON\_STEP\_Msk (1UL << CoreDebug\_DEMCR\_MON\_STEP\_Pos)
- #define CoreDebug\_DEMCR\_MON\_PEND\_Pos 17
- #define CoreDebug\_DEMCR\_MON\_PEND\_Msk (1UL << CoreDebug\_DEMCR\_MON\_PEND\_Pos)
- #define CoreDebug\_DEMCR\_MON\_EN\_Pos 16
- #define CoreDebug\_DEMCR\_MON\_EN\_Msk (1UL << CoreDebug\_DEMCR\_MON\_EN\_Pos)
- #define CoreDebug\_DEMCR\_VC\_HARDERR\_Pos 10
- #define CoreDebug\_DEMCR\_VC\_HARDERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_HARDERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_INTERR\_Pos 9
- #define CoreDebug\_DEMCR\_VC\_INTERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_INTERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_BUSERR\_Pos 8
- #define CoreDebug\_DEMCR\_VC\_BUSERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_BUSERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_STATERR\_Pos 7
- #define CoreDebug\_DEMCR\_VC\_STATERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_STATERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_CHKERR\_Pos 6
- #define CoreDebug\_DEMCR\_VC\_CHKERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_CHKERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos 5
- #define CoreDebug\_DEMCR\_VC\_NOCPERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_MMERR\_Pos 4
- #define CoreDebug\_DEMCR\_VC\_MMERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_MMERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_CORERESET\_Pos 0
- #define CoreDebug\_DEMCR\_VC\_CORERESET\_Msk (1UL /\*<< CoreDebug\_DEMCR\_VC\_CORERESET\_Pos\*/)
- #define SCS\_BASE (0xE000E000UL)
- #define ITM\_BASE (0xE0000000UL)
- #define DWT\_BASE (0xE0001000UL)
- #define TPI\_BASE (0xE0040000UL)
- #define CoreDebug\_BASE (0xE000EDF0UL)
- #define SysTick\_BASE (SCS\_BASE + 0x0010UL)
- #define NVIC\_BASE (SCS\_BASE + 0x0100UL)
- #define SCB\_BASE (SCS\_BASE + 0x0D00UL)
- #define SCnSCB ((SCnSCB\_Type \*) SCS\_BASE )
- #define SCB ((SCB\_Type \*) SCB\_BASE )
- #define SysTick ((SysTick\_Type \*) SysTick\_BASE )
- #define NVIC ((NVIC\_Type \*) NVIC\_BASE )
- #define ITM ((ITM\_Type \*) ITM\_BASE )
- #define DWT ((DWT\_Type \*) DWT\_BASE )
- #define TPI ((TPI\_Type \*) TPI\_BASE )
- #define CoreDebug ((CoreDebug\_Type \*) CoreDebug\_BASE)
- #define ITM\_RXBUFFER\_EMPTY 0x5AA55AA5

## 5.164.1 Detailed Description

### 5.164.1.1 MISRA-C:2004 Compliance Exceptions

CMSIS violates the following MISRA-C:2004 rules:

- Required Rule 8.5, object/function definition in header file.  
Function definitions in header files are used to allow 'inlining'.
- Required Rule 18.4, declaration of union type or object of union type: '{...}'.  
Unions are used for effective representation of core registers.
- Advisory Rule 19.7, Function-like macro defined.  
Function-like macros are used to allow more efficient code.

## 5.164.2 Macro Definition Documentation

### 5.164.2.1 \_\_CM4\_CMSIS\_VERSION

```
#define __CM4_CMSIS_VERSION
```

**Value:**

```
((__CM4_CMSIS_VERSION_MAIN << 16) | \
    __CM4_CMSIS_VERSION_SUB)
```

CMSIS HAL version number

### 5.164.2.2 \_\_CM4\_CMSIS\_VERSION\_MAIN

```
#define __CM4_CMSIS_VERSION_MAIN (0x04)
```

[31:16] CMSIS HAL main version

### 5.164.2.3 \_\_CM4\_CMSIS\_VERSION\_SUB

```
#define __CM4_CMSIS_VERSION_SUB (0x00)
```

[15:0] CMSIS HAL sub version

#### 5.164.2.4 \_\_CORE\_CM4\_H\_DEPENDANT

```
#define __CORE_CM4_H_DEPENDANT
```

\_\_FPU\_USED indicates whether an FPU is used or not. For this, \_\_FPU\_PRESENT has to be checked prior to making use of FPU specific registers and functions.

#### 5.164.2.5 \_\_CORTEX\_M

```
#define __CORTEX_M (0x04)
```

Cortex-M Core

#### 5.164.2.6 \_\_I

```
#define __I volatile const
```

Defines 'read only' permissions

#### 5.164.2.7 \_\_IO

```
#define __IO volatile
```

Defines 'read / write' permissions

#### 5.164.2.8 \_\_O

```
#define __O volatile
```

Defines 'write only' permissions

#### 5.164.2.9 APSR\_C\_Msk

```
#define APSR_C_Msk (1UL << APSR_C_Pos)
```

APSR: C Mask

#### 5.164.2.10 APSR\_C\_Pos

```
#define APSR_C_Pos 29
```

APSR: C Position

### 5.164.2.11 APSR\_GE\_Msk

```
#define APSR_GE_Msk (0xFUL << APSR_GE_Pos)
```

APSR: GE Mask

### 5.164.2.12 APSR\_GE\_Pos

```
#define APSR_GE_Pos 16
```

APSR: GE Position

### 5.164.2.13 APSR\_N\_Msk

```
#define APSR_N_Msk (1UL << APSR_N_Pos)
```

APSR: N Mask

### 5.164.2.14 APSR\_N\_Pos

```
#define APSR_N_Pos 31
```

APSR: N Position

### 5.164.2.15 APSR\_Q\_Msk

```
#define APSR_Q_Msk (1UL << APSR_Q_Pos)
```

APSR: Q Mask

### 5.164.2.16 APSR\_Q\_Pos

```
#define APSR_Q_Pos 27
```

APSR: Q Position

### 5.164.2.17 APSR\_V\_Msk

```
#define APSR_V_Msk (1UL << APSR_V_Pos)
```

APSR: V Mask

### 5.164.2.18 APSR\_V\_Pos

```
#define APSR_V_Pos 28
```

APSR: V Position

### 5.164.2.19 APSR\_Z\_Msk

```
#define APSR_Z_Msk (1UL << APSR_Z_Pos)
```

APSR: Z Mask

### 5.164.2.20 APSR\_Z\_Pos

```
#define APSR_Z_Pos 30
```

APSR: Z Position

### 5.164.2.21 CONTROL\_FPCA\_Msk

```
#define CONTROL_FPCA_Msk (1UL << CONTROL_FPCA_Pos)
```

CONTROL: FPCA Mask

### 5.164.2.22 CONTROL\_FPCA\_Pos

```
#define CONTROL_FPCA_Pos 2
```

CONTROL: FPCA Position

### 5.164.2.23 CONTROL\_nPRIV\_Msk

```
#define CONTROL_nPRIV_Msk (1UL /*<< CONTROL_nPRIV_Pos*/)
```

CONTROL: nPRIV Mask

### 5.164.2.24 CONTROL\_nPRIV\_Pos

```
#define CONTROL_nPRIV_Pos 0
```

CONTROL: nPRIV Position

### 5.164.2.25 CONTROL\_SPSEL\_Msk

```
#define CONTROL_SPSEL_Msk (1UL << CONTROL_SPSEL_Pos)
```

CONTROL: SPSEL Mask

### 5.164.2.26 CONTROL\_SPSEL\_Pos

```
#define CONTROL_SPSEL_Pos 1
```

CONTROL: SPSEL Position

### 5.164.2.27 CoreDebug

```
#define CoreDebug ((CoreDebug_Type *) CoreDebug_BASE)
```

Core Debug configuration struct

### 5.164.2.28 CoreDebug\_BASE

```
#define CoreDebug_BASE (0xE000EDF0UL)
```

Core Debug Base Address

### 5.164.2.29 CoreDebug\_DCRSR\_REGSEL\_Msk

```
#define CoreDebug_DCRSR_REGSEL_Msk (0x1FUL /*<< CoreDebug_DCRSR_REGSEL_Pos*/)
```

CoreDebug DCRSR: REGSEL Mask

### 5.164.2.30 CoreDebug\_DCRSR\_REGSEL\_Pos

```
#define CoreDebug_DCRSR_REGSEL_Pos 0
```

CoreDebug DCRSR: REGSEL Position

### 5.164.2.31 CoreDebug\_DCRSR\_REGWnR\_Msk

```
#define CoreDebug_DCRSR_REGWnR_Msk (1UL << CoreDebug_DCRSR_REGWnR_Pos)
```

CoreDebug DCRSR: REGWnR Mask

### 5.164.2.32 CoreDebug\_DCRSR\_REGWnR\_Pos

```
#define CoreDebug_DCRSR_REGWnR_Pos 16
```

CoreDebug DCRSR: REGWnR Position

### 5.164.2.33 CoreDebug\_DEMCR\_MON\_EN\_Msk

```
#define CoreDebug_DEMCR_MON_EN_Msk (1UL << CoreDebug_DEMCR_MON_EN_Pos)
```

CoreDebug DEMCR: MON\_EN Mask

#### 5.164.2.34 CoreDebug\_DEMCR\_MON\_EN\_Pos

```
#define CoreDebug_DEMCR_MON_EN_Pos 16
```

CoreDebug DEMCR: MON\_EN Position

#### 5.164.2.35 CoreDebug\_DEMCR\_MON\_PEND\_Msk

```
#define CoreDebug_DEMCR_MON_PEND_Msk (1UL << CoreDebug_DEMCR_MON_PEND_Pos)
```

CoreDebug DEMCR: MON\_PEND Mask

#### 5.164.2.36 CoreDebug\_DEMCR\_MON\_PEND\_Pos

```
#define CoreDebug_DEMCR_MON_PEND_Pos 17
```

CoreDebug DEMCR: MON\_PEND Position

#### 5.164.2.37 CoreDebug\_DEMCR\_MON\_REQ\_Msk

```
#define CoreDebug_DEMCR_MON_REQ_Msk (1UL << CoreDebug_DEMCR_MON_REQ_Pos)
```

CoreDebug DEMCR: MON\_REQ Mask

#### 5.164.2.38 CoreDebug\_DEMCR\_MON\_REQ\_Pos

```
#define CoreDebug_DEMCR_MON_REQ_Pos 19
```

CoreDebug DEMCR: MON\_REQ Position

#### 5.164.2.39 CoreDebug\_DEMCR\_MON\_STEP\_Msk

```
#define CoreDebug_DEMCR_MON_STEP_Msk (1UL << CoreDebug_DEMCR_MON_STEP_Pos)
```

CoreDebug DEMCR: MON\_STEP Mask

#### 5.164.2.40 CoreDebug\_DEMCR\_MON\_STEP\_Pos

```
#define CoreDebug_DEMCR_MON_STEP_Pos 18
```

CoreDebug DEMCR: MON\_STEP Position

#### 5.164.2.41 CoreDebug\_DEMCR\_TRCENA\_Msk

```
#define CoreDebug_DEMCR_TRCENA_Msk (1UL << CoreDebug_DEMCR_TRCENA_Pos)
```

CoreDebug DEMCR: TRCENA Mask

#### 5.164.2.42 CoreDebug\_DEMCR\_TRCENA\_Pos

```
#define CoreDebug_DEMCR_TRCENA_Pos 24
```

CoreDebug DEMCR: TRCENA Position

#### 5.164.2.43 CoreDebug\_DEMCR\_VC\_BUSERR\_Msk

```
#define CoreDebug_DEMCR_VC_BUSERR_Msk (1UL << CoreDebug_DEMCR_VC_BUSERR_Pos)
```

CoreDebug DEMCR: VC\_BUSERR Mask

#### 5.164.2.44 CoreDebug\_DEMCR\_VC\_BUSERR\_Pos

```
#define CoreDebug_DEMCR_VC_BUSERR_Pos 8
```

CoreDebug DEMCR: VC\_BUSERR Position

#### 5.164.2.45 CoreDebug\_DEMCR\_VC\_CHKERR\_Msk

```
#define CoreDebug_DEMCR_VC_CHKERR_Msk (1UL << CoreDebug_DEMCR_VC_CHKERR_Pos)
```

CoreDebug DEMCR: VC\_CHKERR Mask

#### 5.164.2.46 CoreDebug\_DEMCR\_VC\_CHKERR\_Pos

```
#define CoreDebug_DEMCR_VC_CHKERR_Pos 6
```

CoreDebug DEMCR: VC\_CHKERR Position

#### 5.164.2.47 CoreDebug\_DEMCR\_VC\_CORERESET\_Msk

```
#define CoreDebug_DEMCR_VC_CORERESET_Msk (1UL /*<< CoreDebug_DEMCR_VC_CORERESET_Pos*/)
```

CoreDebug DEMCR: VC\_CORERESET Mask

#### 5.164.2.48 CoreDebug\_DEMCR\_VC\_CORERESET\_Pos

```
#define CoreDebug_DEMCR_VC_CORERESET_Pos 0
```

CoreDebug DEMCR: VC\_CORERESET Position

#### 5.164.2.49 CoreDebug\_DEMCR\_VC\_HARDERR\_Msk

```
#define CoreDebug_DEMCR_VC_HARDERR_Msk (1UL << CoreDebug_DEMCR_VC_HARDERR_Pos)
```

CoreDebug DEMCR: VC\_HARDERR Mask

#### 5.164.2.50 CoreDebug\_DEMCR\_VC\_HARDERR\_Pos

```
#define CoreDebug_DEMCR_VC_HARDERR_Pos 10
```

CoreDebug DEMCR: VC\_HARDERR Position

#### 5.164.2.51 CoreDebug\_DEMCR\_VC\_INTERR\_Msk

```
#define CoreDebug_DEMCR_VC_INTERR_Msk (1UL << CoreDebug_DEMCR_VC_INTERR_Pos)
```

CoreDebug DEMCR: VC\_INTERR Mask

#### 5.164.2.52 CoreDebug\_DEMCR\_VC\_INTERR\_Pos

```
#define CoreDebug_DEMCR_VC_INTERR_Pos 9
```

CoreDebug DEMCR: VC\_INTERR Position

#### 5.164.2.53 CoreDebug\_DEMCR\_VC\_MMERR\_Msk

```
#define CoreDebug_DEMCR_VC_MMERR_Msk (1UL << CoreDebug_DEMCR_VC_MMERR_Pos)
```

CoreDebug DEMCR: VC\_MMERR Mask

#### 5.164.2.54 CoreDebug\_DEMCR\_VC\_MMERR\_Pos

```
#define CoreDebug_DEMCR_VC_MMERR_Pos 4
```

CoreDebug DEMCR: VC\_MMERR Position

#### 5.164.2.55 CoreDebug\_DEMCR\_VC\_NOCPERR\_Msk

```
#define CoreDebug_DEMCR_VC_NOCPERR_Msk (1UL << CoreDebug_DEMCR_VC_NOCPERR_Pos)
```

CoreDebug DEMCR: VC\_NOCPERR Mask

#### 5.164.2.56 CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos

```
#define CoreDebug_DEMCR_VC_NOCPERR_Pos 5
```

CoreDebug DEMCR: VC\_NOCPERR Position

#### 5.164.2.57 CoreDebug\_DEMCR\_VC\_STATERR\_Msk

```
#define CoreDebug_DEMCR_VC_STATERR_Msk (1UL << CoreDebug_DEMCR_VC_STATERR_Pos)
```

CoreDebug DEMCR: VC\_STATERR Mask

### 5.164.2.58 CoreDebug\_DEMCR\_VC\_STATERR\_Pos

```
#define CoreDebug_DEMCR_VC_STATERR_Pos 7
```

CoreDebug DEMCR: VC\_STATERR Position

### 5.164.2.59 CoreDebug\_DHCSR\_C\_DEBUGEN\_Msk

```
#define CoreDebug_DHCSR_C_DEBUGEN_Msk (1UL /*<< CoreDebug_DHCSR_C_DEBUGEN_Pos*/)
```

CoreDebug DHCSR: C\_DEBUGEN Mask

### 5.164.2.60 CoreDebug\_DHCSR\_C\_DEBUGEN\_Pos

```
#define CoreDebug_DHCSR_C_DEBUGEN_Pos 0
```

CoreDebug DHCSR: C\_DEBUGEN Position

### 5.164.2.61 CoreDebug\_DHCSR\_C\_HALT\_Msk

```
#define CoreDebug_DHCSR_C_HALT_Msk (1UL << CoreDebug_DHCSR_C_HALT_Pos)
```

CoreDebug DHCSR: C\_HALT Mask

### 5.164.2.62 CoreDebug\_DHCSR\_C\_HALT\_Pos

```
#define CoreDebug_DHCSR_C_HALT_Pos 1
```

CoreDebug DHCSR: C\_HALT Position

### 5.164.2.63 CoreDebug\_DHCSR\_C\_MASKINTS\_Msk

```
#define CoreDebug_DHCSR_C_MASKINTS_Msk (1UL << CoreDebug_DHCSR_C_MASKINTS_Pos)
```

CoreDebug DHCSR: C\_MASKINTS Mask

### 5.164.2.64 CoreDebug\_DHCSR\_C\_MASKINTS\_Pos

```
#define CoreDebug_DHCSR_C_MASKINTS_Pos 3
```

CoreDebug DHCSR: C\_MASKINTS Position

### 5.164.2.65 CoreDebug\_DHCSR\_C\_SNAPSTALL\_Msk

```
#define CoreDebug_DHCSR_C_SNAPSTALL_Msk (1UL << CoreDebug_DHCSR_C_SNAPSTALL_Pos)
```

CoreDebug DHCSR: C\_SNAPSTALL Mask

**5.164.2.66 CoreDebug\_DHCSR\_C\_SNAPSTALL\_Pos**

```
#define CoreDebug_DHCSR_C_SNAPSTALL_Pos 5
```

CoreDebug DHCSR: C\_SNAPSTALL Position

**5.164.2.67 CoreDebug\_DHCSR\_C\_STEP\_Msk**

```
#define CoreDebug_DHCSR_C_STEP_Msk (1UL << CoreDebug_DHCSR_C_STEP_Pos)
```

CoreDebug DHCSR: C\_STEP Mask

**5.164.2.68 CoreDebug\_DHCSR\_C\_STEP\_Pos**

```
#define CoreDebug_DHCSR_C_STEP_Pos 2
```

CoreDebug DHCSR: C\_STEP Position

**5.164.2.69 CoreDebug\_DHCSR\_DBGKEY\_Msk**

```
#define CoreDebug_DHCSR_DBGKEY_Msk (0xFFFFUL << CoreDebug_DHCSR_DBGKEY_Pos)
```

CoreDebug DHCSR: DBGKEY Mask

**5.164.2.70 CoreDebug\_DHCSR\_DBGKEY\_Pos**

```
#define CoreDebug_DHCSR_DBGKEY_Pos 16
```

CoreDebug DHCSR: DBGKEY Position

**5.164.2.71 CoreDebug\_DHCSR\_S\_HALT\_Msk**

```
#define CoreDebug_DHCSR_S_HALT_Msk (1UL << CoreDebug_DHCSR_S_HALT_Pos)
```

CoreDebug DHCSR: S\_HALT Mask

**5.164.2.72 CoreDebug\_DHCSR\_S\_HALT\_Pos**

```
#define CoreDebug_DHCSR_S_HALT_Pos 17
```

CoreDebug DHCSR: S\_HALT Position

**5.164.2.73 CoreDebug\_DHCSR\_S\_LOCKUP\_Msk**

```
#define CoreDebug_DHCSR_S_LOCKUP_Msk (1UL << CoreDebug_DHCSR_S_LOCKUP_Pos)
```

CoreDebug DHCSR: S\_LOCKUP Mask

#### 5.164.2.74 CoreDebug\_DHCSR\_S\_LOCKUP\_Pos

```
#define CoreDebug_DHCSR_S_LOCKUP_Pos 19
```

CoreDebug DHCSR: S\_LOCKUP Position

#### 5.164.2.75 CoreDebug\_DHCSR\_S\_REGRDY\_Msk

```
#define CoreDebug_DHCSR_S_REGRDY_Msk (1UL << CoreDebug_DHCSR_S_REGRDY_Pos)
```

CoreDebug DHCSR: S\_REGRDY Mask

#### 5.164.2.76 CoreDebug\_DHCSR\_S\_REGRDY\_Pos

```
#define CoreDebug_DHCSR_S_REGRDY_Pos 16
```

CoreDebug DHCSR: S\_REGRDY Position

#### 5.164.2.77 CoreDebug\_DHCSR\_S\_RESET\_ST\_Msk

```
#define CoreDebug_DHCSR_S_RESET_ST_Msk (1UL << CoreDebug_DHCSR_S_RESET_ST_Pos)
```

CoreDebug DHCSR: S\_RESET\_ST Mask

#### 5.164.2.78 CoreDebug\_DHCSR\_S\_RESET\_ST\_Pos

```
#define CoreDebug_DHCSR_S_RESET_ST_Pos 25
```

CoreDebug DHCSR: S\_RESET\_ST Position

#### 5.164.2.79 CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Msk

```
#define CoreDebug_DHCSR_S_RETIRE_ST_Msk (1UL << CoreDebug_DHCSR_S_RETIRE_ST_Pos)
```

CoreDebug DHCSR: S\_RETIRE\_ST Mask

#### 5.164.2.80 CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Pos

```
#define CoreDebug_DHCSR_S_RETIRE_ST_Pos 24
```

CoreDebug DHCSR: S\_RETIRE\_ST Position

#### 5.164.2.81 CoreDebug\_DHCSR\_S\_SLEEP\_Msk

```
#define CoreDebug_DHCSR_S_SLEEP_Msk (1UL << CoreDebug_DHCSR_S_SLEEP_Pos)
```

CoreDebug DHCSR: S\_SLEEP Mask

### 5.164.2.82 CoreDebug\_DHCSR\_S\_SLEEP\_Pos

```
#define CoreDebug_DHCSR_S_SLEEP_Pos 18
```

CoreDebug DHCSR: S\_SLEEP Position

### 5.164.2.83 DWT

```
#define DWT ((DWT_Type *) DWT_BASE)
```

DWT configuration struct

### 5.164.2.84 DWT\_BASE

```
#define DWT_BASE (0xE0001000UL)
```

DWT Base Address

### 5.164.2.85 DWT\_CPICNT\_CPICNT\_Msk

```
#define DWT_CPICNT_CPICNT_Msk (0xFFUL /*<< DWT_CPICNT_CPICNT_Pos*/)
```

DWT CPICNT: CPICNT Mask

### 5.164.2.86 DWT\_CPICNT\_CPICNT\_Pos

```
#define DWT_CPICNT_CPICNT_Pos 0
```

DWT CPICNT: CPICNT Position

### 5.164.2.87 DWT\_CTRL\_CPIEVTENA\_Msk

```
#define DWT_CTRL_CPIEVTENA_Msk (0x1UL << DWT_CTRL_CPIEVTENA_Pos)
```

DWT CTRL: CPIEVTENA Mask

### 5.164.2.88 DWT\_CTRL\_CPIEVTENA\_Pos

```
#define DWT_CTRL_CPIEVTENA_Pos 17
```

DWT CTRL: CPIEVTENA Position

### 5.164.2.89 DWT\_CTRL\_CYCCNTENA\_Msk

```
#define DWT_CTRL_CYCCNTENA_Msk (0x1UL /*<< DWT_CTRL_CYCCNTENA_Pos*/)
```

DWT CTRL: CYCCNTENA Mask

### 5.164.2.90 DWT\_CTRL\_CYCCNTENA\_Pos

```
#define DWT_CTRL_CYCCNTENA_Pos 0
```

DWT CTRL: CYCCNTENA Position

### 5.164.2.91 DWT\_CTRL\_CYCEVTENA\_Msk

```
#define DWT_CTRL_CYCEVTENA_Msk (0x1UL << DWT_CTRL_CYCEVTENA_Pos)
```

DWT CTRL: CYCEVTENA Mask

### 5.164.2.92 DWT\_CTRL\_CYCEVTENA\_Pos

```
#define DWT_CTRL_CYCEVTENA_Pos 22
```

DWT CTRL: CYCEVTENA Position

### 5.164.2.93 DWT\_CTRL\_CYCTAP\_Msk

```
#define DWT_CTRL_CYCTAP_Msk (0x1UL << DWT_CTRL_CYCTAP_Pos)
```

DWT CTRL: CYCTAP Mask

### 5.164.2.94 DWT\_CTRL\_CYCTAP\_Pos

```
#define DWT_CTRL_CYCTAP_Pos 9
```

DWT CTRL: CYCTAP Position

### 5.164.2.95 DWT\_CTRL\_EXCEVTENA\_Msk

```
#define DWT_CTRL_EXCEVTENA_Msk (0x1UL << DWT_CTRL_EXCEVTENA_Pos)
```

DWT CTRL: EXCEVTENA Mask

### 5.164.2.96 DWT\_CTRL\_EXCEVTENA\_Pos

```
#define DWT_CTRL_EXCEVTENA_Pos 18
```

DWT CTRL: EXCEVTENA Position

**5.164.2.97 DWT\_CTRL\_EXCTRCENA\_Msk**

```
#define DWT_CTRL_EXCTRCENA_Msk (0x1UL << DWT_CTRL_EXCTRCENA_Pos)
```

DWT CTRL: EXCTRCENA Mask

**5.164.2.98 DWT\_CTRL\_EXCTRCENA\_Pos**

```
#define DWT_CTRL_EXCTRCENA_Pos 16
```

DWT CTRL: EXCTRCENA Position

**5.164.2.99 DWT\_CTRL\_FOLDEVTENA\_Msk**

```
#define DWT_CTRL_FOLDEVTENA_Msk (0x1UL << DWT_CTRL_FOLDEVTENA_Pos)
```

DWT CTRL: FOLDEVTENA Mask

**5.164.2.100 DWT\_CTRL\_FOLDEVTENA\_Pos**

```
#define DWT_CTRL_FOLDEVTENA_Pos 21
```

DWT CTRL: FOLDEVTENA Position

**5.164.2.101 DWT\_CTRL\_LSUEVTENA\_Msk**

```
#define DWT_CTRL_LSUEVTENA_Msk (0x1UL << DWT_CTRL_LSUEVTENA_Pos)
```

DWT CTRL: LSUEVTENA Mask

**5.164.2.102 DWT\_CTRL\_LSUEVTENA\_Pos**

```
#define DWT_CTRL_LSUEVTENA_Pos 20
```

DWT CTRL: LSUEVTENA Position

**5.164.2.103 DWT\_CTRL\_NOCCNT\_Msk**

```
#define DWT_CTRL_NOCCNT_Msk (0x1UL << DWT_CTRL_NOCCNT_Pos)
```

DWT CTRL: NOCCNT Mask

**5.164.2.104 DWT\_CTRL\_NOCCNT\_Pos**

```
#define DWT_CTRL_NOCCNT_Pos 25
```

DWT CTRL: NOCCNT Position

### 5.164.2.105 DWT\_CTRL\_NOEXTTRIG\_Msk

```
#define DWT_CTRL_NOEXTTRIG_Msk (0x1UL << DWT_CTRL_NOEXTTRIG_Pos)
```

DWT CTRL: NOEXTTRIG Mask

### 5.164.2.106 DWT\_CTRL\_NOEXTTRIG\_Pos

```
#define DWT_CTRL_NOEXTTRIG_Pos 26
```

DWT CTRL: NOEXTTRIG Position

### 5.164.2.107 DWT\_CTRL\_NOPRFCNT\_Msk

```
#define DWT_CTRL_NOPRFCNT_Msk (0x1UL << DWT_CTRL_NOPRFCNT_Pos)
```

DWT CTRL: NOPRFCNT Mask

### 5.164.2.108 DWT\_CTRL\_NOPRFCNT\_Pos

```
#define DWT_CTRL_NOPRFCNT_Pos 24
```

DWT CTRL: NOPRFCNT Position

### 5.164.2.109 DWT\_CTRL\_NOTRCPKT\_Msk

```
#define DWT_CTRL_NOTRCPKT_Msk (0x1UL << DWT_CTRL_NOTRCPKT_Pos)
```

DWT CTRL: NOTRCPKT Mask

### 5.164.2.110 DWT\_CTRL\_NOTRCPKT\_Pos

```
#define DWT_CTRL_NOTRCPKT_Pos 27
```

DWT CTRL: NOTRCPKT Position

### 5.164.2.111 DWT\_CTRL\_NUMCOMP\_Msk

```
#define DWT_CTRL_NUMCOMP_Msk (0xFUL << DWT_CTRL_NUMCOMP_Pos)
```

DWT CTRL: NUMCOMP Mask

### 5.164.2.112 DWT\_CTRL\_NUMCOMP\_Pos

```
#define DWT_CTRL_NUMCOMP_Pos 28
```

DWT CTRL: NUMCOMP Position

**5.164.2.113 DWT\_CTRL\_PCSAMPLENA\_Msk**

```
#define DWT_CTRL_PCSAMPLENA_Msk (0x1UL << DWT_CTRL_PCSAMPLENA_Pos)
```

DWT CTRL: PCSAMPLENA Mask

**5.164.2.114 DWT\_CTRL\_PCSAMPLENA\_Pos**

```
#define DWT_CTRL_PCSAMPLENA_Pos 12
```

DWT CTRL: PCSAMPLENA Position

**5.164.2.115 DWT\_CTRL\_POSTINIT\_Msk**

```
#define DWT_CTRL_POSTINIT_Msk (0xFUL << DWT_CTRL_POSTINIT_Pos)
```

DWT CTRL: POSTINIT Mask

**5.164.2.116 DWT\_CTRL\_POSTINIT\_Pos**

```
#define DWT_CTRL_POSTINIT_Pos 5
```

DWT CTRL: POSTINIT Position

**5.164.2.117 DWT\_CTRL\_POSTPRESET\_Msk**

```
#define DWT_CTRL_POSTPRESET_Msk (0xFUL << DWT_CTRL_POSTPRESET_Pos)
```

DWT CTRL: POSTPRESET Mask

**5.164.2.118 DWT\_CTRL\_POSTPRESET\_Pos**

```
#define DWT_CTRL_POSTPRESET_Pos 1
```

DWT CTRL: POSTPRESET Position

**5.164.2.119 DWT\_CTRL\_SLEEPEVTENA\_Msk**

```
#define DWT_CTRL_SLEEPEVTENA_Msk (0x1UL << DWT_CTRL_SLEEPEVTENA_Pos)
```

DWT CTRL: SLEEPEVTENA Mask

**5.164.2.120 DWT\_CTRL\_SLEEPEVTENA\_Pos**

```
#define DWT_CTRL_SLEEPEVTENA_Pos 19
```

DWT CTRL: SLEEPEVTENA Position

### 5.164.2.121 DWT\_CTRL\_SYNCTAP\_Msk

```
#define DWT_CTRL_SYNCTAP_Msk (0x3UL << DWT_CTRL_SYNCTAP_Pos)
```

DWT CTRL: SYNCTAP Mask

### 5.164.2.122 DWT\_CTRL\_SYNCTAP\_Pos

```
#define DWT_CTRL_SYNCTAP_Pos 10
```

DWT CTRL: SYNCTAP Position

### 5.164.2.123 DWT\_EXCCNT\_EXCCNT\_Msk

```
#define DWT_EXCCNT_EXCCNT_Msk (0xFFUL /*<< DWT_EXCCNT_EXCCNT_Pos*/)
```

DWT EXCCNT: EXCCNT Mask

### 5.164.2.124 DWT\_EXCCNT\_EXCCNT\_Pos

```
#define DWT_EXCCNT_EXCCNT_Pos 0
```

DWT EXCCNT: EXCCNT Position

### 5.164.2.125 DWT\_FOLDCNT\_FOLDCNT\_Msk

```
#define DWT_FOLDCNT_FOLDCNT_Msk (0xFFUL /*<< DWT_FOLDCNT_FOLDCNT_Pos*/)
```

DWT FOLDCNT: FOLDCNT Mask

### 5.164.2.126 DWT\_FOLDCNT\_FOLDCNT\_Pos

```
#define DWT_FOLDCNT_FOLDCNT_Pos 0
```

DWT FOLDCNT: FOLDCNT Position

### 5.164.2.127 DWT\_FUNCTION\_CYCMATCH\_Msk

```
#define DWT_FUNCTION_CYCMATCH_Msk (0x1UL << DWT_FUNCTION_CYCMATCH_Pos)
```

DWT FUNCTION: CYCMATCH Mask

### 5.164.2.128 DWT\_FUNCTION\_CYCMATCH\_Pos

```
#define DWT_FUNCTION_CYCMATCH_Pos 7
```

DWT FUNCTION: CYCMATCH Position

**5.164.2.129 DWT\_FUNCTION\_DATAVADDR0\_Msk**

```
#define DWT_FUNCTION_DATAVADDR0_Msk (0xFUL << DWT_FUNCTION_DATAVADDR0_Pos)
```

DWT FUNCTION: DATAVADDR0 Mask

**5.164.2.130 DWT\_FUNCTION\_DATAVADDR0\_Pos**

```
#define DWT_FUNCTION_DATAVADDR0_Pos 12
```

DWT FUNCTION: DATAVADDR0 Position

**5.164.2.131 DWT\_FUNCTION\_DATAVADDR1\_Msk**

```
#define DWT_FUNCTION_DATAVADDR1_Msk (0xFUL << DWT_FUNCTION_DATAVADDR1_Pos)
```

DWT FUNCTION: DATAVADDR1 Mask

**5.164.2.132 DWT\_FUNCTION\_DATAVADDR1\_Pos**

```
#define DWT_FUNCTION_DATAVADDR1_Pos 16
```

DWT FUNCTION: DATAVADDR1 Position

**5.164.2.133 DWT\_FUNCTION\_DATAVMATCH\_Msk**

```
#define DWT_FUNCTION_DATAVMATCH_Msk (0x1UL << DWT_FUNCTION_DATAVMATCH_Pos)
```

DWT FUNCTION: DATAVMATCH Mask

**5.164.2.134 DWT\_FUNCTION\_DATAVMATCH\_Pos**

```
#define DWT_FUNCTION_DATAVMATCH_Pos 8
```

DWT FUNCTION: DATAVMATCH Position

**5.164.2.135 DWT\_FUNCTION\_DATAVSIZE\_Msk**

```
#define DWT_FUNCTION_DATAVSIZE_Msk (0x3UL << DWT_FUNCTION_DATAVSIZE_Pos)
```

DWT FUNCTION: DATAVSIZE Mask

**5.164.2.136 DWT\_FUNCTION\_DATAVSIZE\_Pos**

```
#define DWT_FUNCTION_DATAVSIZE_Pos 10
```

DWT FUNCTION: DATAVSIZE Position

### 5.164.2.137 DWT\_FUNCTION\_EMITRANGE\_Msk

```
#define DWT_FUNCTION_EMITRANGE_Msk (0x1UL << DWT_FUNCTION_EMITRANGE_Pos)
```

DWT FUNCTION: EMITRANGE Mask

### 5.164.2.138 DWT\_FUNCTION\_EMITRANGE\_Pos

```
#define DWT_FUNCTION_EMITRANGE_Pos 5
```

DWT FUNCTION: EMITRANGE Position

### 5.164.2.139 DWT\_FUNCTION\_FUNCTION\_Msk

```
#define DWT_FUNCTION_FUNCTION_Msk (0xFUL /*<< DWT_FUNCTION_FUNCTION_Pos*/)
```

DWT FUNCTION: FUNCTION Mask

### 5.164.2.140 DWT\_FUNCTION\_FUNCTION\_Pos

```
#define DWT_FUNCTION_FUNCTION_Pos 0
```

DWT FUNCTION: FUNCTION Position

### 5.164.2.141 DWT\_FUNCTION\_LNK1ENA\_Msk

```
#define DWT_FUNCTION_LNK1ENA_Msk (0x1UL << DWT_FUNCTION_LNK1ENA_Pos)
```

DWT FUNCTION: LNK1ENA Mask

### 5.164.2.142 DWT\_FUNCTION\_LNK1ENA\_Pos

```
#define DWT_FUNCTION_LNK1ENA_Pos 9
```

DWT FUNCTION: LNK1ENA Position

### 5.164.2.143 DWT\_FUNCTION\_MATCHED\_Msk

```
#define DWT_FUNCTION_MATCHED_Msk (0x1UL << DWT_FUNCTION_MATCHED_Pos)
```

DWT FUNCTION: MATCHED Mask

### 5.164.2.144 DWT\_FUNCTION\_MATCHED\_Pos

```
#define DWT_FUNCTION_MATCHED_Pos 24
```

DWT FUNCTION: MATCHED Position

**5.164.2.145 DWT\_LSUCNT\_LSUCNT\_Msk**

```
#define DWT_LSUCNT_LSUCNT_Msk (0xFFUL /*<< DWT_LSUCNT_LSUCNT_Pos*/)
```

DWT LSUCNT: LSUCNT Mask

**5.164.2.146 DWT\_LSUCNT\_LSUCNT\_Pos**

```
#define DWT_LSUCNT_LSUCNT_Pos 0
```

DWT LSUCNT: LSUCNT Position

**5.164.2.147 DWT\_MASK\_MASK\_Msk**

```
#define DWT_MASK_MASK_Msk (0x1FUL /*<< DWT_MASK_MASK_Pos*/)
```

DWT MASK: MASK Mask

**5.164.2.148 DWT\_MASK\_MASK\_Pos**

```
#define DWT_MASK_MASK_Pos 0
```

DWT MASK: MASK Position

**5.164.2.149 DWT\_SLEEPcnt\_SLEEPcnt\_Msk**

```
#define DWT_SLEEPcnt_SLEEPcnt_Msk (0xFFUL /*<< DWT_SLEEPcnt_SLEEPcnt_Pos*/)
```

DWT SLEEPcnt: SLEEPcnt Mask

**5.164.2.150 DWT\_SLEEPcnt\_SLEEPcnt\_Pos**

```
#define DWT_SLEEPcnt_SLEEPcnt_Pos 0
```

DWT SLEEPcnt: SLEEPcnt Position

**5.164.2.151 IPSR\_ISR\_Msk**

```
#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/)
```

IPSR: ISR Mask

**5.164.2.152 IPSR\_ISR\_Pos**

```
#define IPSR_ISR_Pos 0
```

IPSR: ISR Position

### 5.164.2.153 ITM

```
#define ITM ((ITM_Type *) ITM_BASE)
```

ITM configuration struct

### 5.164.2.154 ITM\_BASE

```
#define ITM_BASE (0xE0000000UL)
```

ITM Base Address

### 5.164.2.155 ITM\_IMCR\_INTEGRATION\_Msk

```
#define ITM_IMCR_INTEGRATION_Msk (1UL /*<< ITM_IMCR_INTEGRATION_Pos*/)
```

ITM IMCR: INTEGRATION Mask

### 5.164.2.156 ITM\_IMCR\_INTEGRATION\_Pos

```
#define ITM_IMCR_INTEGRATION_Pos 0
```

ITM IMCR: INTEGRATION Position

### 5.164.2.157 ITMIRR\_ATREADYM\_Msk

```
#define ITMIRR_ATREADYM_Msk (1UL /*<< ITMIRR_ATREADYM_Pos*/)
```

ITM IRR: ATREADYM Mask

### 5.164.2.158 ITMIRR\_ATREADYM\_Pos

```
#define ITMIRR_ATREADYM_Pos 0
```

ITM IRR: ATREADYM Position

### 5.164.2.159 ITMIWR\_ATVALIDDM\_Msk

```
#define ITMIWR_ATVALIDDM_Msk (1UL /*<< ITMIWR_ATVALIDDM_Pos*/)
```

ITM IWR: ATVALIDDM Mask

**5.164.2.160 ITM\_IWR\_ATVALIDM\_Pos**

```
#define ITM_IWR_ATVALIDM_Pos 0
```

ITM IWR: ATVALIDM Position

**5.164.2.161 ITM\_LSR\_Access\_Msk**

```
#define ITM_LSR_Access_Msk (1UL << ITM_LSR_Access_Pos)
```

ITM LSR: Access Mask

**5.164.2.162 ITM\_LSR\_Access\_Pos**

```
#define ITM_LSR_Access_Pos 1
```

ITM LSR: Access Position

**5.164.2.163 ITM\_LSR\_ByteAcc\_Msk**

```
#define ITM_LSR_ByteAcc_Msk (1UL << ITM_LSR_ByteAcc_Pos)
```

ITM LSR: ByteAcc Mask

**5.164.2.164 ITM\_LSR\_ByteAcc\_Pos**

```
#define ITM_LSR_ByteAcc_Pos 2
```

ITM LSR: ByteAcc Position

**5.164.2.165 ITM\_LSR\_Present\_Msk**

```
#define ITM_LSR_Present_Msk (1UL /*<< ITM_LSR_Present_Pos*/)
```

ITM LSR: Present Mask

**5.164.2.166 ITM\_LSR\_Present\_Pos**

```
#define ITM_LSR_Present_Pos 0
```

ITM LSR: Present Position

**5.164.2.167 ITM\_RXBUFFER\_EMPTY**

```
#define ITM_RXBUFFER_EMPTY 0x5AA55AA5
```

Value identifying [ITM\\_RxBuffer](#) is ready for next character.

### 5.164.2.168 **ITM\_TCR\_BUSY\_Msk**

```
#define ITM_TCR_BUSY_Msk (1UL << ITM_TCR_BUSY_Pos)
```

ITM TCR: BUSY Mask

### 5.164.2.169 **ITM\_TCR\_BUSY\_Pos**

```
#define ITM_TCR_BUSY_Pos 23
```

ITM TCR: BUSY Position

### 5.164.2.170 **ITM\_TCR\_DWTENA\_Msk**

```
#define ITM_TCR_DWTENA_Msk (1UL << ITM_TCR_DWTENA_Pos)
```

ITM TCR: DWTENA Mask

### 5.164.2.171 **ITM\_TCR\_DWTENA\_Pos**

```
#define ITM_TCR_DWTENA_Pos 3
```

ITM TCR: DWTENA Position

### 5.164.2.172 **ITM\_TCR\_GTSFREQ\_Msk**

```
#define ITM_TCR_GTSFREQ_Msk (3UL << ITM_TCR_GTSFREQ_Pos)
```

ITM TCR: Global timestamp frequency Mask

### 5.164.2.173 **ITM\_TCR\_GTSFREQ\_Pos**

```
#define ITM_TCR_GTSFREQ_Pos 10
```

ITM TCR: Global timestamp frequency Position

### 5.164.2.174 **ITM\_TCR\_ITMENA\_Msk**

```
#define ITM_TCR_ITMENA_Msk (1UL /*<< ITM_TCR_ITMENA_Pos*/)
```

ITM TCR: ITM Enable bit Mask

### 5.164.2.175 **ITM\_TCR\_ITMENA\_Pos**

```
#define ITM_TCR_ITMENA_Pos 0
```

ITM TCR: ITM Enable bit Position

**5.164.2.176 ITM\_TCR\_SWOENA\_Msk**

```
#define ITM_TCR_SWOENA_Msk (1UL << ITM_TCR_SWOENA_Pos)
```

ITM TCR: SWOENA Mask

**5.164.2.177 ITM\_TCR\_SWOENA\_Pos**

```
#define ITM_TCR_SWOENA_Pos 4
```

ITM TCR: SWOENA Position

**5.164.2.178 ITM\_TCR\_SYNCENA\_Msk**

```
#define ITM_TCR_SYNCENA_Msk (1UL << ITM_TCR_SYNCENA_Pos)
```

ITM TCR: SYNCENA Mask

**5.164.2.179 ITM\_TCR\_SYNCENA\_Pos**

```
#define ITM_TCR_SYNCENA_Pos 2
```

ITM TCR: SYNCENA Position

**5.164.2.180 ITM\_TCR\_TraceBusID\_Msk**

```
#define ITM_TCR_TraceBusID_Msk (0x7FUL << ITM_TCR_TraceBusID_Pos)
```

ITM TCR: ATBID Mask

**5.164.2.181 ITM\_TCR\_TraceBusID\_Pos**

```
#define ITM_TCR_TraceBusID_Pos 16
```

ITM TCR: ATBID Position

**5.164.2.182 ITM\_TCR\_TSENA\_Msk**

```
#define ITM_TCR_TSENA_Msk (1UL << ITM_TCR_TSENA_Pos)
```

ITM TCR: TSENA Mask

**5.164.2.183 ITM\_TCR\_TSENA\_Pos**

```
#define ITM_TCR_TSENA_Pos 1
```

ITM TCR: TSENA Position

### 5.164.2.184 ITM\_TCR\_TSPrescale\_Msk

```
#define ITM_TCR_TSPrescale_Msk (3UL << ITM_TCR_TSPrescale_Pos)
```

ITM TCR: TSPrescale Mask

### 5.164.2.185 ITM\_TCR\_TSPrescale\_Pos

```
#define ITM_TCR_TSPrescale_Pos 8
```

ITM TCR: TSPrescale Position

### 5.164.2.186 ITM\_TPR\_PRIVMASK\_Msk

```
#define ITM_TPR_PRIVMASK_Msk (0xFUL /*<< ITM_TPR_PRIVMASK_Pos*/)
```

ITM TPR: PRIVMASK Mask

### 5.164.2.187 ITM\_TPR\_PRIVMASK\_Pos

```
#define ITM_TPR_PRIVMASK_Pos 0
```

ITM TPR: PRIVMASK Position

### 5.164.2.188 NVIC

```
#define NVIC ((NVIC_Type *) NVIC_BASE )
```

NVIC configuration struct

### 5.164.2.189 NVIC\_BASE

```
#define NVIC_BASE (SCS_BASE + 0x0100UL)
```

NVIC Base Address

### 5.164.2.190 NVIC\_STIR\_INTID\_Msk

```
#define NVIC_STIR_INTID_Msk (0x1FFUL /*<< NVIC_STIR_INTID_Pos*/)
```

STIR: INTLINESNUM Mask

**5.164.2.191 NVIC\_STIR\_INTID\_Pos**

```
#define NVIC_STIR_INTID_Pos 0
```

STIR: INTLINESNUM Position

**5.164.2.192 SCB**

```
#define SCB ((SCB_Type *) SCB_BASE)
```

SCB configuration struct

**5.164.2.193 SCB\_AIRCR\_ENDIANESS\_Msk**

```
#define SCB_AIRCR_ENDIANESS_Msk (1UL << SCB_AIRCR_ENDIANESS_Pos)
```

SCB AIRCR: ENDIANESS Mask

**5.164.2.194 SCB\_AIRCR\_ENDIANESS\_Pos**

```
#define SCB_AIRCR_ENDIANESS_Pos 15
```

SCB AIRCR: ENDIANESS Position

**5.164.2.195 SCB\_AIRCR\_PRIGROUP\_Msk**

```
#define SCB_AIRCR_PRIGROUP_Msk (7UL << SCB_AIRCR_PRIGROUP_Pos)
```

SCB AIRCR: PRIGROUP Mask

**5.164.2.196 SCB\_AIRCR\_PRIGROUP\_Pos**

```
#define SCB_AIRCR_PRIGROUP_Pos 8
```

SCB AIRCR: PRIGROUP Position

**5.164.2.197 SCB\_AIRCR\_SYSRESETREQ\_Msk**

```
#define SCB_AIRCR_SYSRESETREQ_Msk (1UL << SCB_AIRCR_SYSRESETREQ_Pos)
```

SCB AIRCR: SYSRESETREQ Mask

### 5.164.2.198 SCB\_AIRCR\_SYSRESETREQ\_Pos

```
#define SCB_AIRCR_SYSRESETREQ_Pos 2
```

SCB AIRCR: SYSRESETREQ Position

### 5.164.2.199 SCB\_AIRCR\_VECTCLRACTIVE\_Msk

```
#define SCB_AIRCR_VECTCLRACTIVE_Msk (1UL << SCB_AIRCR_VECTCLRACTIVE_Pos)
```

SCB AIRCR: VECTCLRACTIVE Mask

### 5.164.2.200 SCB\_AIRCR\_VECTCLRACTIVE\_Pos

```
#define SCB_AIRCR_VECTCLRACTIVE_Pos 1
```

SCB AIRCR: VECTCLRACTIVE Position

### 5.164.2.201 SCB\_AIRCR\_VECTKEY\_Msk

```
#define SCB_AIRCR_VECTKEY_Msk (0xFFFFUL << SCB_AIRCR_VECTKEY_Pos)
```

SCB AIRCR: VECTKEY Mask

### 5.164.2.202 SCB\_AIRCR\_VECTKEY\_Pos

```
#define SCB_AIRCR_VECTKEY_Pos 16
```

SCB AIRCR: VECTKEY Position

### 5.164.2.203 SCB\_AIRCR\_VECTKEYSTAT\_Msk

```
#define SCB_AIRCR_VECTKEYSTAT_Msk (0xFFFFUL << SCB_AIRCR_VECTKEYSTAT_Pos)
```

SCB AIRCR: VECTKEYSTAT Mask

### 5.164.2.204 SCB\_AIRCR\_VECTKEYSTAT\_Pos

```
#define SCB_AIRCR_VECTKEYSTAT_Pos 16
```

SCB AIRCR: VECTKEYSTAT Position

### 5.164.2.205 SCB\_AIRCR\_VECTRESET\_Msk

```
#define SCB_AIRCR_VECTRESET_Msk (1UL /*<< SCB_AIRCR_VECTRESET_Pos*/)
```

SCB AIRCR: VECTRESET Mask

**5.164.2.206 SCB\_AIRCR\_VECTRESET\_Pos**

```
#define SCB_AIRCR_VECTRESET_Pos 0
```

SCB AIRCR: VECTRESET Position

**5.164.2.207 SCB\_BASE**

```
#define SCB_BASE (SCS_BASE + 0x0D00UL)
```

System Control Block Base Address

**5.164.2.208 SCB\_CCR\_BFHFNIGN\_Msk**

```
#define SCB_CCR_BFHFNIGN_Msk (1UL << SCB_CCR_BFHFNIGN_Pos)
```

SCB CCR: BFHFNMIGN Mask

**5.164.2.209 SCB\_CCR\_BFHFNIGN\_Pos**

```
#define SCB_CCR_BFHFNIGN_Pos 8
```

SCB CCR: BFHFNMIGN Position

**5.164.2.210 SCB\_CCR\_DIV\_0\_TRP\_Msk**

```
#define SCB_CCR_DIV_0_TRP_Msk (1UL << SCB_CCR_DIV_0_TRP_Pos)
```

SCB CCR: DIV\_0\_TRP Mask

**5.164.2.211 SCB\_CCR\_DIV\_0\_TRP\_Pos**

```
#define SCB_CCR_DIV_0_TRP_Pos 4
```

SCB CCR: DIV\_0\_TRP Position

**5.164.2.212 SCB\_CCR\_NONBASETHRDENA\_Msk**

```
#define SCB_CCR_NONBASETHRDENA_Msk (1UL /*<< SCB_CCR_NONBASETHRDENA_Pos*/)
```

SCB CCR: NONBASETHRDENA Mask

### 5.164.2.213 SCB\_CCR\_NONBASETHRDENA\_Pos

```
#define SCB_CCR_NONBASETHRDENA_Pos 0
```

SCB CCR: NONBASETHRDENA Position

### 5.164.2.214 SCB\_CCR\_STKALIGN\_Msk

```
#define SCB_CCR_STKALIGN_Msk (1UL << SCB_CCR_STKALIGN_Pos)
```

SCB CCR: STKALIGN Mask

### 5.164.2.215 SCB\_CCR\_STKALIGN\_Pos

```
#define SCB_CCR_STKALIGN_Pos 9
```

SCB CCR: STKALIGN Position

### 5.164.2.216 SCB\_CCR\_UNALIGN\_TRP\_Msk

```
#define SCB_CCR_UNALIGN_TRP_Msk (1UL << SCB_CCR_UNALIGN_TRP_Pos)
```

SCB CCR: UNALIGN\_TRP Mask

### 5.164.2.217 SCB\_CCR\_UNALIGN\_TRP\_Pos

```
#define SCB_CCR_UNALIGN_TRP_Pos 3
```

SCB CCR: UNALIGN\_TRP Position

### 5.164.2.218 SCB\_CCR\_USERSETMPEND\_Msk

```
#define SCB_CCR_USERSETMPEND_Msk (1UL << SCB_CCR_USERSETMPEND_Pos)
```

SCB CCR: USERSETMPEND Mask

### 5.164.2.219 SCB\_CCR\_USERSETMPEND\_Pos

```
#define SCB_CCR_USERSETMPEND_Pos 1
```

SCB CCR: USERSETMPEND Position

### 5.164.2.220 SCB\_CFSR\_BUSFAULTSR\_Msk

```
#define SCB_CFSR_BUSFAULTSR_Msk (0xFFUL << SCB_CFSR_BUSFAULTSR_Pos)
```

SCB CFSR: Bus Fault Status Register Mask

**5.164.2.221 SCB\_CFSR\_BUSFAULTSR\_Pos**

```
#define SCB_CFSR_BUSFAULTSR_Pos 8
```

SCB CFSR: Bus Fault Status Register Position

**5.164.2.222 SCB\_CFSR\_MEMFAULTSR\_Msk**

```
#define SCB_CFSR_MEMFAULTSR_Msk (0xFFUL /*<< SCB_CFSR_MEMFAULTSR_Pos*/)
```

SCB CFSR: Memory Manage Fault Status Register Mask

**5.164.2.223 SCB\_CFSR\_MEMFAULTSR\_Pos**

```
#define SCB_CFSR_MEMFAULTSR_Pos 0
```

SCB CFSR: Memory Manage Fault Status Register Position

**5.164.2.224 SCB\_CFSR\_USGFAULTSR\_Msk**

```
#define SCB_CFSR_USGFAULTSR_Msk (0xFFFFUL << SCB_CFSR_USGFAULTSR_Pos)
```

SCB CFSR: Usage Fault Status Register Mask

**5.164.2.225 SCB\_CFSR\_USGFAULTSR\_Pos**

```
#define SCB_CFSR_USGFAULTSR_Pos 16
```

SCB CFSR: Usage Fault Status Register Position

**5.164.2.226 SCB\_CPUID\_ARCHITECTURE\_Msk**

```
#define SCB_CPUID_ARCHITECTURE_Msk (0xFUL << SCB_CPUID_ARCHITECTURE_Pos)
```

SCB CPUID: ARCHITECTURE Mask

**5.164.2.227 SCB\_CPUID\_ARCHITECTURE\_Pos**

```
#define SCB_CPUID_ARCHITECTURE_Pos 16
```

SCB CPUID: ARCHITECTURE Position

**5.164.2.228 SCB\_CPUID\_IMPLEMENTER\_Msk**

```
#define SCB_CPUID_IMPLEMENTER_Msk (0xFFUL << SCB_CPUID_IMPLEMENTER_Pos)
```

SCB CPUID: IMPLEMENTER Mask

**5.164.2.229 SCB\_CPUID\_IMPLEMENTER\_Pos**

```
#define SCB_CPUID_IMPLEMENTER_Pos 24
```

SCB CPUID: IMPLEMENTER Position

**5.164.2.230 SCB\_CPUID\_PARTNO\_Msk**

```
#define SCB_CPUID_PARTNO_Msk (0xFFFFUL << SCB_CPUID_IMPLEMENTER_Pos)
```

SCB CPUID: PARTNO Mask

**5.164.2.231 SCB\_CPUID\_PARTNO\_Pos**

```
#define SCB_CPUID_PARTNO_Pos 4
```

SCB CPUID: PARTNO Position

**5.164.2.232 SCB\_CPUID\_REVISION\_Msk**

```
#define SCB_CPUID_REVISION_Msk (0xFUL /*<< SCB_CPUID_REVISION_Pos*/)
```

SCB CPUID: REVISION Mask

**5.164.2.233 SCB\_CPUID\_REVISION\_Pos**

```
#define SCB_CPUID_REVISION_Pos 0
```

SCB CPUID: REVISION Position

**5.164.2.234 SCB\_CPUID\_VARIANT\_Msk**

```
#define SCB_CPUID_VARIANT_Msk (0xFUL << SCB_CPUID_VARIANT_Pos)
```

SCB CPUID: VARIANT Mask

**5.164.2.235 SCB\_CPUID\_VARIANT\_Pos**

```
#define SCB_CPUID_VARIANT_Pos 20
```

SCB CPUID: VARIANT Position

**5.164.2.236 SCB\_DFSR\_BKPT\_Msk**

```
#define SCB_DFSR_BKPT_Msk (1UL << SCB_DFSR_BKPT_Pos)
```

SCB DFSR: BKPT Mask

**5.164.2.237 SCB\_DFSR\_BKPT\_Pos**

```
#define SCB_DFSR_BKPT_Pos 1
```

SCB DFSR: BKPT Position

**5.164.2.238 SCB\_DFSR\_DWTTRAP\_Msk**

```
#define SCB_DFSR_DWTTRAP_Msk (1UL << SCB_DFSR_DWTTRAP_Pos)
```

SCB DFSR: DWTTRAP Mask

**5.164.2.239 SCB\_DFSR\_DWTTRAP\_Pos**

```
#define SCB_DFSR_DWTTRAP_Pos 2
```

SCB DFSR: DWTTRAP Position

**5.164.2.240 SCB\_DFSR\_EXTERNAL\_Msk**

```
#define SCB_DFSR_EXTERNAL_Msk (1UL << SCB_DFSR_EXTERNAL_Pos)
```

SCB DFSR: EXTERNAL Mask

**5.164.2.241 SCB\_DFSR\_EXTERNAL\_Pos**

```
#define SCB_DFSR_EXTERNAL_Pos 4
```

SCB DFSR: EXTERNAL Position

**5.164.2.242 SCB\_DFSR\_HALTED\_Msk**

```
#define SCB_DFSR_HALTED_Msk (1UL /*<< SCB_DFSR_HALTED_Pos*/)
```

SCB DFSR: HALTED Mask

**5.164.2.243 SCB\_DFSR\_HALTED\_Pos**

```
#define SCB_DFSR_HALTED_Pos 0
```

SCB DFSR: HALTED Position

**5.164.2.244 SCB\_DFSR\_VCATCH\_Msk**

```
#define SCB_DFSR_VCATCH_Msk (1UL << SCB_DFSR_VCATCH_Pos)
```

SCB DFSR: VCATCH Mask

**5.164.2.245 SCB\_DFSR\_VCATCH\_Pos**

```
#define SCB_DFSR_VCATCH_Pos 3
```

SCB DFSR: VCATCH Position

**5.164.2.246 SCB\_HFSR\_DEBUGEV\_T\_Msk**

```
#define SCB_HFSR_DEBUGEV_T_Msk (1UL << SCB_HFSR_DEBUGEV_T_Pos)
```

SCB HFSR: DEBUGEV\_T Mask

**5.164.2.247 SCB\_HFSR\_DEBUGEV\_T\_Pos**

```
#define SCB_HFSR_DEBUGEV_T_Pos 31
```

SCB HFSR: DEBUGEV\_T Position

**5.164.2.248 SCB\_HFSR\_FORCED\_Msk**

```
#define SCB_HFSR_FORCED_Msk (1UL << SCB_HFSR_FORCED_Pos)
```

SCB HFSR: FORCED Mask

**5.164.2.249 SCB\_HFSR\_FORCED\_Pos**

```
#define SCB_HFSR_FORCED_Pos 30
```

SCB HFSR: FORCED Position

**5.164.2.250 SCB\_HFSR\_VECTTBL\_Msk**

```
#define SCB_HFSR_VECTTBL_Msk (1UL << SCB_HFSR_VECTTBL_Pos)
```

SCB HFSR: VECTTBL Mask

**5.164.2.251 SCB\_HFSR\_VECTTBL\_Pos**

```
#define SCB_HFSR_VECTTBL_Pos 1
```

SCB HFSR: VECTTBL Position

**5.164.2.252 SCB\_ICSR\_ISRPENDING\_Msk**

```
#define SCB_ICSR_ISRPENDING_Msk (1UL << SCB_ICSR_ISRPENDING_Pos)
```

SCB ICSR: ISRPENDING Mask

**5.164.2.253 SCB\_ICSR\_ISRPENDING\_Pos**

```
#define SCB_ICSR_ISRPENDING_Pos 22
```

SCB ICSR: ISRPENDING Position

**5.164.2.254 SCB\_ICSR\_ISRPREEMPT\_Msk**

```
#define SCB_ICSR_ISRPREEMPT_Msk (1UL << SCB_ICSR_ISRPREEMPT_Pos)
```

SCB ICSR: ISRPREEMPT Mask

**5.164.2.255 SCB\_ICSR\_ISRPREEMPT\_Pos**

```
#define SCB_ICSR_ISRPREEMPT_Pos 23
```

SCB ICSR: ISRPREEMPT Position

**5.164.2.256 SCB\_ICSR\_NMIPENDSET\_Msk**

```
#define SCB_ICSR_NMIPENDSET_Msk (1UL << SCB_ICSR_NMIPENDSET_Pos)
```

SCB ICSR: NMIPENDSET Mask

**5.164.2.257 SCB\_ICSR\_NMIPENDSET\_Pos**

```
#define SCB_ICSR_NMIPENDSET_Pos 31
```

SCB ICSR: NMIPENDSET Position

**5.164.2.258 SCB\_ICSR\_PENDSTCLR\_Msk**

```
#define SCB_ICSR_PENDSTCLR_Msk (1UL << SCB_ICSR_PENDSTCLR_Pos)
```

SCB ICSR: PENDSTCLR Mask

**5.164.2.259 SCB\_ICSR\_PENDSTCLR\_Pos**

```
#define SCB_ICSR_PENDSTCLR_Pos 25
```

SCB ICSR: PENDSTCLR Position

**5.164.2.260 SCB\_ICSR\_PENDSTSET\_Msk**

```
#define SCB_ICSR_PENDSTSET_Msk (1UL << SCB_ICSR_PENDSTSET_Pos)
```

SCB ICSR: PENDSTSET Mask

---

**5.164.2.261 SCB\_ICSR\_PENDSTSET\_Pos**

```
#define SCB_ICSR_PENDSTSET_Pos 26
```

SCB ICSR: PENDSTSET Position

**5.164.2.262 SCB\_ICSR\_PENDSVCLR\_Msk**

```
#define SCB_ICSR_PENDSVCLR_Msk (1UL << SCB_ICSR_PENDSVCLR_Pos)
```

SCB ICSR: PENDSVCLR Mask

**5.164.2.263 SCB\_ICSR\_PENDSVCLR\_Pos**

```
#define SCB_ICSR_PENDSVCLR_Pos 27
```

SCB ICSR: PENDSVCLR Position

**5.164.2.264 SCB\_ICSR\_PENDSVSET\_Msk**

```
#define SCB_ICSR_PENDSVSET_Msk (1UL << SCB_ICSR_PENDSVSET_Pos)
```

SCB ICSR: PENDSVSET Mask

**5.164.2.265 SCB\_ICSR\_PENDSVSET\_Pos**

```
#define SCB_ICSR_PENDSVSET_Pos 28
```

SCB ICSR: PENDSVSET Position

**5.164.2.266 SCB\_ICSR\_RETTOBASE\_Msk**

```
#define SCB_ICSR_RETTOBASE_Msk (1UL << SCB_ICSR_RETTOBASE_Pos)
```

SCB ICSR: RETTOBASE Mask

**5.164.2.267 SCB\_ICSR\_RETTOBASE\_Pos**

```
#define SCB_ICSR_RETTOBASE_Pos 11
```

SCB ICSR: RETTOBASE Position

**5.164.2.268 SCB\_ICSR\_VECTACTIVE\_Msk**

```
#define SCB_ICSR_VECTACTIVE_Msk (0x1FFUL /*<< SCB_ICSR_VECTACTIVE_Pos*/)
```

SCB ICSR: VECTACTIVE Mask

**5.164.2.269 SCB\_ICSR\_VECTACTIVE\_Pos**

```
#define SCB_ICSR_VECTACTIVE_Pos 0
```

SCB ICSR: VECTACTIVE Position

**5.164.2.270 SCB\_ICSR\_VECTPENDING\_Msk**

```
#define SCB_ICSR_VECTPENDING_Msk (0x1FFUL << SCB_ICSR_VECTPENDING_Pos)
```

SCB ICSR: VECTPENDING Mask

**5.164.2.271 SCB\_ICSR\_VECTPENDING\_Pos**

```
#define SCB_ICSR_VECTPENDING_Pos 12
```

SCB ICSR: VECTPENDING Position

**5.164.2.272 SCB\_SCR\_SEVONPEND\_Msk**

```
#define SCB_SCR_SEVONPEND_Msk (1UL << SCB_SCR_SEVONPEND_Pos)
```

SCB SCR: SEVONPEND Mask

**5.164.2.273 SCB\_SCR\_SEVONPEND\_Pos**

```
#define SCB_SCR_SEVONPEND_Pos 4
```

SCB SCR: SEVONPEND Position

**5.164.2.274 SCB\_SCR\_SLEEPDEEP\_Msk**

```
#define SCB_SCR_SLEEPDEEP_Msk (1UL << SCB_SCR_SLEEPDEEP_Pos)
```

SCB SCR: SLEEPDEEP Mask

**5.164.2.275 SCB\_SCR\_SLEEPDEEP\_Pos**

```
#define SCB_SCR_SLEEPDEEP_Pos 2
```

SCB SCR: SLEEPDEEP Position

**5.164.2.276 SCB\_SCR\_SLEEPONEXIT\_Msk**

```
#define SCB_SCR_SLEEPONEXIT_Msk (1UL << SCB_SCR_SLEEPONEXIT_Pos)
```

SCB SCR: SLEEPONEXIT Mask

**5.164.2.277 SCB\_SCR\_SLEEPONEXIT\_Pos**

```
#define SCB_SCR_SLEEPONEXIT_Pos 1
```

SCB SCR: SLEEPONEXIT Position

**5.164.2.278 SCB\_SHCSR\_BUSFAULTACT\_Msk**

```
#define SCB_SHCSR_BUSFAULTACT_Msk (1UL << SCB_SHCSR_BUSFAULTACT_Pos)
```

SCB SHCSR: BUSFAULTACT Mask

**5.164.2.279 SCB\_SHCSR\_BUSFAULTACT\_Pos**

```
#define SCB_SHCSR_BUSFAULTACT_Pos 1
```

SCB SHCSR: BUSFAULTACT Position

**5.164.2.280 SCB\_SHCSR\_BUSFAULTENA\_Msk**

```
#define SCB_SHCSR_BUSFAULTENA_Msk (1UL << SCB_SHCSR_BUSFAULTENA_Pos)
```

SCB SHCSR: BUSFAULTENA Mask

**5.164.2.281 SCB\_SHCSR\_BUSFAULTENA\_Pos**

```
#define SCB_SHCSR_BUSFAULTENA_Pos 17
```

SCB SHCSR: BUSFAULTENA Position

**5.164.2.282 SCB\_SHCSR\_BUSFAULTPENDED\_Msk**

```
#define SCB_SHCSR_BUSFAULTPENDED_Msk (1UL << SCB_SHCSR_BUSFAULTPENDED_Pos)
```

SCB SHCSR: BUSFAULTPENDED Mask

**5.164.2.283 SCB\_SHCSR\_BUSFAULTPENDED\_Pos**

```
#define SCB_SHCSR_BUSFAULTPENDED_Pos 14
```

SCB SHCSR: BUSFAULTPENDED Position

**5.164.2.284 SCB\_SHCSR\_MEMFAULTACT\_Msk**

```
#define SCB_SHCSR_MEMFAULTACT_Msk (1UL /*<< SCB_SHCSR_MEMFAULTACT_Pos*/)
```

SCB SHCSR: MEMFAULTACT Mask

**5.164.2.285 SCB\_SHCSR\_MEMFAULTACT\_Pos**

```
#define SCB_SHCSR_MEMFAULTACT_Pos 0
```

SCB SHCSR: MEMFAULTACT Position

**5.164.2.286 SCB\_SHCSR\_MEMFAULTENA\_Msk**

```
#define SCB_SHCSR_MEMFAULTENA_Msk (1UL << SCB_SHCSR_MEMFAULTENA_Pos)
```

SCB SHCSR: MEMFAULTENA Mask

**5.164.2.287 SCB\_SHCSR\_MEMFAULTENA\_Pos**

```
#define SCB_SHCSR_MEMFAULTENA_Pos 16
```

SCB SHCSR: MEMFAULTENA Position

**5.164.2.288 SCB\_SHCSR\_MEMFAULTPENDED\_Msk**

```
#define SCB_SHCSR_MEMFAULTPENDED_Msk (1UL << SCB_SHCSR_MEMFAULTPENDED_Pos)
```

SCB SHCSR: MEMFAULTPENDED Mask

**5.164.2.289 SCB\_SHCSR\_MEMFAULTPENDED\_Pos**

```
#define SCB_SHCSR_MEMFAULTPENDED_Pos 13
```

SCB SHCSR: MEMFAULTPENDED Position

**5.164.2.290 SCB\_SHCSR\_MONITORACT\_Msk**

```
#define SCB_SHCSR_MONITORACT_Msk (1UL << SCB_SHCSR_MONITORACT_Pos)
```

SCB SHCSR: MONITORACT Mask

**5.164.2.291 SCB\_SHCSR\_MONITORACT\_Pos**

```
#define SCB_SHCSR_MONITORACT_Pos 8
```

SCB SHCSR: MONITORACT Position

**5.164.2.292 SCB\_SHCSR\_PENDSVACT\_Msk**

```
#define SCB_SHCSR_PENDSVACT_Msk (1UL << SCB_SHCSR_PENDSVACT_Pos)
```

SCB SHCSR: PENDSVACT Mask

**5.164.2.293 SCB\_SHCSR\_PENDSVACT\_Pos**

```
#define SCB_SHCSR_PENDSVACT_Pos 10
```

SCB SHCSR: PENDSVACT Position

**5.164.2.294 SCB\_SHCSR\_SVCALLACT\_Msk**

```
#define SCB_SHCSR_SVCALLACT_Msk (1UL << SCB_SHCSR_SVCALLACT_Pos)
```

SCB SHCSR: SVCALLACT Mask

**5.164.2.295 SCB\_SHCSR\_SVCALLACT\_Pos**

```
#define SCB_SHCSR_SVCALLACT_Pos 7
```

SCB SHCSR: SVCALLACT Position

**5.164.2.296 SCB\_SHCSR\_SVCALLPENDED\_Msk**

```
#define SCB_SHCSR_SVCALLPENDED_Msk (1UL << SCB_SHCSR_SVCALLPENDED_Pos)
```

SCB SHCSR: SVCALLPENDED Mask

**5.164.2.297 SCB\_SHCSR\_SVCALLPENDED\_Pos**

```
#define SCB_SHCSR_SVCALLPENDED_Pos 15
```

SCB SHCSR: SVCALLPENDED Position

**5.164.2.298 SCB\_SHCSR\_SYSTICKACT\_Msk**

```
#define SCB_SHCSR_SYSTICKACT_Msk (1UL << SCB_SHCSR_SYSTICKACT_Pos)
```

SCB SHCSR: SYSTICKACT Mask

**5.164.2.299 SCB\_SHCSR\_SYSTICKACT\_Pos**

```
#define SCB_SHCSR_SYSTICKACT_Pos 11
```

SCB SHCSR: SYSTICKACT Position

**5.164.2.300 SCB\_SHCSR\_USGFAULTACT\_Msk**

```
#define SCB_SHCSR_USGFAULTACT_Msk (1UL << SCB_SHCSR_USGFAULTACT_Pos)
```

SCB SHCSR: USGFAULTACT Mask

**5.164.2.301 SCB\_SHCSR\_USGFAULTACT\_Pos**

```
#define SCB_SHCSR_USGFAULTACT_Pos 3
```

SCB SHCSR: USGFAULTACT Position

**5.164.2.302 SCB\_SHCSR\_USGFAULTENA\_Msk**

```
#define SCB_SHCSR_USGFAULTENA_Msk (1UL << SCB_SHCSR_USGFAULTENA_Pos)
```

SCB SHCSR: USGFAULTENA Mask

**5.164.2.303 SCB\_SHCSR\_USGFAULTENA\_Pos**

```
#define SCB_SHCSR_USGFAULTENA_Pos 18
```

SCB SHCSR: USGFAULTENA Position

**5.164.2.304 SCB\_SHCSR\_USGFAULTPENDED\_Msk**

```
#define SCB_SHCSR_USGFAULTPENDED_Msk (1UL << SCB_SHCSR_USGFAULTPENDED_Pos)
```

SCB SHCSR: USGFAULTPENDED Mask

**5.164.2.305 SCB\_SHCSR\_USGFAULTPENDED\_Pos**

```
#define SCB_SHCSR_USGFAULTPENDED_Pos 12
```

SCB SHCSR: USGFAULTPENDED Position

**5.164.2.306 SCB\_VTOR\_TBLOFF\_Msk**

```
#define SCB_VTOR_TBLOFF_Msk (0x1FFFFFFUL << SCB_VTOR_TBLOFF_Pos)
```

SCB VTOR: TBLOFF Mask

**5.164.2.307 SCB\_VTOR\_TBLOFF\_Pos**

```
#define SCB_VTOR_TBLOFF_Pos 7
```

SCB VTOR: TBLOFF Position

**5.164.2.308 SCnSCB**

```
#define SCnSCB ((SCnSCB_Type *) SCS_BASE )
```

System control Register not in SCB

**5.164.2.309 SCnSCB\_ACTLR\_DISDEFWBUF\_Msk**

```
#define SCnSCB_ACTLR_DISDEFWBUF_Msk (1UL << SCnSCB_ACTLR_DISDEFWBUF_Pos)
```

ACTLR: DISDEFWBUF Mask

**5.164.2.310 SCnSCB\_ACTLR\_DISDEFWBUF\_Pos**

```
#define SCnSCB_ACTLR_DISDEFWBUF_Pos 1
```

ACTLR: DISDEFWBUF Position

**5.164.2.311 SCnSCB\_ACTLR\_DISFOLD\_Msk**

```
#define SCnSCB_ACTLR_DISFOLD_Msk (1UL << SCnSCB_ACTLR_DISFOLD_Pos)
```

ACTLR: DISFOLD Mask

**5.164.2.312 SCnSCB\_ACTLR\_DISFOLD\_Pos**

```
#define SCnSCB_ACTLR_DISFOLD_Pos 2
```

ACTLR: DISFOLD Position

**5.164.2.313 SCnSCB\_ACTLR\_DISFPCA\_Msk**

```
#define SCnSCB_ACTLR_DISFPCA_Msk (1UL << SCnSCB_ACTLR_DISFPCA_Pos)
```

ACTLR: DISFPCA Mask

**5.164.2.314 SCnSCB\_ACTLR\_DISFPCA\_Pos**

```
#define SCnSCB_ACTLR_DISFPCA_Pos 8
```

ACTLR: DISFPCA Position

**5.164.2.315 SCnSCB\_ACTLR\_DISMCYCINT\_Msk**

```
#define SCnSCB_ACTLR_DISMCYCINT_Msk (1UL /*<< SCnSCB_ACTLR_DISMCYCINT_Pos*/)
```

ACTLR: DISMCYCINT Mask

**5.164.2.316 SCnSCB\_ACTLR\_DISMCYCINT\_Pos**

```
#define SCnSCB_ACTLR_DISMCYCINT_Pos 0
```

ACTLR: DISMCYCINT Position

**5.164.2.317 SCnSCB\_ACTLR\_DISOOFP\_Msk**

```
#define SCnSCB_ACTLR_DISOOFP_Msk (1UL << SCnSCB_ACTLR_DISOOFP_Pos)
```

ACTLR: DISOOFP Mask

**5.164.2.318 SCnSCB\_ACTLR\_DISOOFP\_Pos**

```
#define SCnSCB_ACTLR_DISOOFP_Pos 9
```

ACTLR: DISOOFP Position

**5.164.2.319 SCnSCB\_ICTR\_INTLINESNUM\_Msk**

```
#define SCnSCB_ICTR_INTLINESNUM_Msk (0xFUL /*<< SCnSCB_ICTR_INTLINESNUM_Pos*/)
```

ICTR: INTLINESNUM Mask

**5.164.2.320 SCnSCB\_ICTR\_INTLINESNUM\_Pos**

```
#define SCnSCB_ICTR_INTLINESNUM_Pos 0
```

ICTR: INTLINESNUM Position

**5.164.2.321 SCS\_BASE**

```
#define SCS_BASE (0xE000E000UL)
```

System Control Space Base Address

**5.164.2.322 SysTick**

```
#define SysTick ((SysTick_Type *) SysTick_BASE )
```

SysTick configuration struct

**5.164.2.323 SysTick\_BASE**

```
#define SysTick_BASE (SCS_BASE + 0x0010UL)
```

SysTick Base Address

### 5.164.2.324 SysTick\_CALIB\_NOREF\_Msk

```
#define SysTick_CALIB_NOREF_Msk (1UL << SysTick_CALIB_NOREF_Pos)
```

SysTick CALIB: NOREF Mask

### 5.164.2.325 SysTick\_CALIB\_NOREF\_Pos

```
#define SysTick_CALIB_NOREF_Pos 31
```

SysTick CALIB: NOREF Position

### 5.164.2.326 SysTick\_CALIB\_SKEW\_Msk

```
#define SysTick_CALIB_SKEW_Msk (1UL << SysTick_CALIB_SKEW_Pos)
```

SysTick CALIB: SKEW Mask

### 5.164.2.327 SysTick\_CALIB\_SKEW\_Pos

```
#define SysTick_CALIB_SKEW_Pos 30
```

SysTick CALIB: SKEW Position

### 5.164.2.328 SysTick\_CALIB\_TENMS\_Msk

```
#define SysTick_CALIB_TENMS_Msk (0xFFFFFUL /*<< SysTick_CALIB_TENMS_Pos*/)
```

SysTick CALIB: TENMS Mask

### 5.164.2.329 SysTick\_CALIB\_TENMS\_Pos

```
#define SysTick_CALIB_TENMS_Pos 0
```

SysTick CALIB: TENMS Position

### 5.164.2.330 SysTick\_CTRL\_CLKSOURCE\_Msk

```
#define SysTick_CTRL_CLKSOURCE_Msk (1UL << SysTick_CTRL_CLKSOURCE_Pos)
```

SysTick CTRL: CLKSOURCE Mask

### 5.164.2.331 SysTick\_CTRL\_CLKSOURCE\_Pos

```
#define SysTick_CTRL_CLKSOURCE_Pos 2
```

SysTick CTRL: CLKSOURCE Position

#### 5.164.2.332 SysTick\_CTRL\_COUNTFLAG\_Msk

```
#define SysTick_CTRL_COUNTFLAG_Msk (1UL << SysTick_CTRL_COUNTFLAG_Pos)
```

SysTick CTRL: COUNTFLAG Mask

#### 5.164.2.333 SysTick\_CTRL\_COUNTFLAG\_Pos

```
#define SysTick_CTRL_COUNTFLAG_Pos 16
```

SysTick CTRL: COUNTFLAG Position

#### 5.164.2.334 SysTick\_CTRL\_ENABLE\_Msk

```
#define SysTick_CTRL_ENABLE_Msk (1UL /*<< SysTick_CTRL_ENABLE_Pos*/)
```

SysTick CTRL: ENABLE Mask

#### 5.164.2.335 SysTick\_CTRL\_ENABLE\_Pos

```
#define SysTick_CTRL_ENABLE_Pos 0
```

SysTick CTRL: ENABLE Position

#### 5.164.2.336 SysTick\_CTRL\_TICKINT\_Msk

```
#define SysTick_CTRL_TICKINT_Msk (1UL << SysTick_CTRL_TICKINT_Pos)
```

SysTick CTRL: TICKINT Mask

#### 5.164.2.337 SysTick\_CTRL\_TICKINT\_Pos

```
#define SysTick_CTRL_TICKINT_Pos 1
```

SysTick CTRL: TICKINT Position

#### 5.164.2.338 SysTick\_LOAD\_RELOAD\_Msk

```
#define SysTick_LOAD_RELOAD_Msk (0xFFFFFUL /*<< SysTick_LOAD_RELOAD_Pos*/)
```

SysTick LOAD: RELOAD Mask

#### 5.164.2.339 SysTick\_LOAD\_RELOAD\_Pos

```
#define SysTick_LOAD_RELOAD_Pos 0
```

SysTick LOAD: RELOAD Position

### 5.164.2.340 SysTick\_VAL\_CURRENT\_Msk

```
#define SysTick_VAL_CURRENT_Msk (0xFFFFFFFFUL /*<< SysTick_VAL_CURRENT_Pos*/)
```

SysTick VAL: CURRENT Mask

### 5.164.2.341 SysTick\_VAL\_CURRENT\_Pos

```
#define SysTick_VAL_CURRENT_Pos 0
```

SysTick VAL: CURRENT Position

### 5.164.2.342 TPI

```
#define TPI ((TPI_Type *) TPI_BASE )
```

TPI configuration struct

### 5.164.2.343 TPI\_ACPR\_PRESCALER\_Msk

```
#define TPI_ACPR_PRESCALER_Msk (0x1FFFUL /*<< TPI_ACPR_PRESCALER_Pos*/)
```

TPI ACPR: PRESCALER Mask

### 5.164.2.344 TPI\_ACPR\_PRESCALER\_Pos

```
#define TPI_ACPR_PRESCALER_Pos 0
```

TPI ACPR: PRESCALER Position

### 5.164.2.345 TPI\_BASE

```
#define TPI_BASE (0xE0040000UL)
```

TPI Base Address

### 5.164.2.346 TPI\_DEVID\_AsynClkIn\_Msk

```
#define TPI_DEVID_AsynClkIn_Msk (0x1UL << TPI_DEVID_AsynClkIn_Pos)
```

TPI DEVID: AsynClkIn Mask

**5.164.2.347 TPI\_DEVID\_AsynClkIn\_Pos**

```
#define TPI_DEVID_AsynClkIn_Pos 5
```

TPI DEVID: AsynClkIn Position

**5.164.2.348 TPI\_DEVID\_MANCVALID\_Msk**

```
#define TPI_DEVID_MANCVALID_Msk (0x1UL << TPI_DEVID_MANCVALID_Pos)
```

TPI DEVID: MANCVALID Mask

**5.164.2.349 TPI\_DEVID\_MANCVALID\_Pos**

```
#define TPI_DEVID_MANCVALID_Pos 10
```

TPI DEVID: MANCVALID Position

**5.164.2.350 TPI\_DEVID\_MinBufSz\_Msk**

```
#define TPI_DEVID_MinBufSz_Msk (0x7UL << TPI_DEVID_MinBufSz_Pos)
```

TPI DEVID: MinBufSz Mask

**5.164.2.351 TPI\_DEVID\_MinBufSz\_Pos**

```
#define TPI_DEVID_MinBufSz_Pos 6
```

TPI DEVID: MinBufSz Position

**5.164.2.352 TPI\_DEVID\_NrTraceInput\_Msk**

```
#define TPI_DEVID_NrTraceInput_Msk (0x1FUL /*<< TPI_DEVID_NrTraceInput_Pos*/)
```

TPI DEVID: NrTraceInput Mask

**5.164.2.353 TPI\_DEVID\_NrTraceInput\_Pos**

```
#define TPI_DEVID_NrTraceInput_Pos 0
```

TPI DEVID: NrTraceInput Position

**5.164.2.354 TPI\_DEVID\_NRZVALID\_Msk**

```
#define TPI_DEVID_NRZVALID_Msk (0x1UL << TPI_DEVID_NRZVALID_Pos)
```

TPI DEVID: NRZVALID Mask

### 5.164.2.355 TPI\_DEVID\_NRZVALID\_Pos

```
#define TPI_DEVID_NRZVALID_Pos 11
```

TPI DEVID: NRZVALID Position

### 5.164.2.356 TPI\_DEVID\_PTINVALIDID\_Msk

```
#define TPI_DEVID_PTINVALIDID_Msk (0x1UL << TPI_DEVID_PTINVALIDID_Pos)
```

TPI DEVID: PTINVALIDID Mask

### 5.164.2.357 TPI\_DEVID\_PTINVALIDID\_Pos

```
#define TPI_DEVID_PTINVALIDID_Pos 9
```

TPI DEVID: PTINVALIDID Position

### 5.164.2.358 TPI\_DEVTYPE\_MajorType\_Msk

```
#define TPI_DEVTYPE_MajorType_Msk (0xFUL << TPI_DEVTYPE_MajorType_Pos)
```

TPI DEVTYPE: MajorType Mask

### 5.164.2.359 TPI\_DEVTYPE\_MajorType\_Pos

```
#define TPI_DEVTYPE_MajorType_Pos 4
```

TPI DEVTYPE: MajorType Position

### 5.164.2.360 TPI\_DEVTYPE\_SubType\_Msk

```
#define TPI_DEVTYPE_SubType_Msk (0xFUL /*<< TPI_DEVTYPE_SubType_Pos*/)
```

TPI DEVTYPE: SubType Mask

### 5.164.2.361 TPI\_DEVTYPE\_SubType\_Pos

```
#define TPI_DEVTYPE_SubType_Pos 0
```

TPI DEVTYPE: SubType Position

### 5.164.2.362 TPI\_FFCR\_EnFCont\_Msk

```
#define TPI_FFCR_EnFCont_Msk (0x1UL << TPI_FFCR_EnFCont_Pos)
```

TPI FFCR: EnFCont Mask

**5.164.2.363 TPI\_FFCR\_EnFCont\_Pos**

```
#define TPI_FFCR_EnFCont_Pos 1
```

TPI FFCR: EnFCont Position

**5.164.2.364 TPI\_FFCR\_TrigIn\_Msk**

```
#define TPI_FFCR_TrigIn_Msk (0x1UL << TPI_FFCR_TrigIn_Pos)
```

TPI FFCR: TrigIn Mask

**5.164.2.365 TPI\_FFCR\_TrigIn\_Pos**

```
#define TPI_FFCR_TrigIn_Pos 8
```

TPI FFCR: TrigIn Position

**5.164.2.366 TPI\_FFSR\_FInProg\_Msk**

```
#define TPI_FFSR_FInProg_Msk (0x1UL /*<< TPI_FFSR_FInProg_Pos*/)
```

TPI FFSR: FInProg Mask

**5.164.2.367 TPI\_FFSR\_FInProg\_Pos**

```
#define TPI_FFSR_FInProg_Pos 0
```

TPI FFSR: FInProg Position

**5.164.2.368 TPI\_FFSR\_FtNonStop\_Msk**

```
#define TPI_FFSR_FtNonStop_Msk (0x1UL << TPI_FFSR_FtNonStop_Pos)
```

TPI FFSR: FtNonStop Mask

**5.164.2.369 TPI\_FFSR\_FtNonStop\_Pos**

```
#define TPI_FFSR_FtNonStop_Pos 3
```

TPI FFSR: FtNonStop Position

**5.164.2.370 TPI\_FFSR\_FtStopped\_Msk**

```
#define TPI_FFSR_FtStopped_Msk (0x1UL << TPI_FFSR_FtStopped_Pos)
```

TPI FFSR: FtStopped Mask

### 5.164.2.371 TPI\_FFSR\_FtStopped\_Pos

```
#define TPI_FFSR_FtStopped_Pos 1
```

TPI FFSR: FtStopped Position

### 5.164.2.372 TPI\_FFSR\_TCPresent\_Msk

```
#define TPI_FFSR_TCPresent_Msk (0x1UL << TPI_FFSR_TCPresent_Pos)
```

TPI FFSR: TCPresent Mask

### 5.164.2.373 TPI\_FFSR\_TCPresent\_Pos

```
#define TPI_FFSR_TCPresent_Pos 2
```

TPI FFSR: TCPresent Position

### 5.164.2.374 TPI\_FIFO0\_ETM0\_Msk

```
#define TPI_FIFO0_ETM0_Msk (0xFFUL /*<< TPI_FIFO0_ETM0_Pos*/)
```

TPI FIFO0: ETM0 Mask

### 5.164.2.375 TPI\_FIFO0\_ETM0\_Pos

```
#define TPI_FIFO0_ETM0_Pos 0
```

TPI FIFO0: ETM0 Position

### 5.164.2.376 TPI\_FIFO0\_ETM1\_Msk

```
#define TPI_FIFO0_ETM1_Msk (0xFFUL << TPI_FIFO0_ETM1_Pos)
```

TPI FIFO0: ETM1 Mask

### 5.164.2.377 TPI\_FIFO0\_ETM1\_Pos

```
#define TPI_FIFO0_ETM1_Pos 8
```

TPI FIFO0: ETM1 Position

### 5.164.2.378 TPI\_FIFO0\_ETM2\_Msk

```
#define TPI_FIFO0_ETM2_Msk (0xFFUL << TPI_FIFO0_ETM2_Pos)
```

TPI FIFO0: ETM2 Mask

**5.164.2.379 TPI\_FIFO0\_ETM2\_Pos**

```
#define TPI_FIFO0_ETM2_Pos 16
```

TPI FIFO0: ETM2 Position

**5.164.2.380 TPI\_FIFO0\_ETM\_ATVALID\_Msk**

```
#define TPI_FIFO0_ETM_ATVALID_Msk (0x3UL << TPI_FIFO0_ETM_ATVALID_Pos)
```

TPI FIFO0: ETM\_ATVALID Mask

**5.164.2.381 TPI\_FIFO0\_ETM\_ATVALID\_Pos**

```
#define TPI_FIFO0_ETM_ATVALID_Pos 26
```

TPI FIFO0: ETM\_ATVALID Position

**5.164.2.382 TPI\_FIFO0\_ETM\_bytectcount\_Msk**

```
#define TPI_FIFO0_ETM_bytectcount_Msk (0x3UL << TPI_FIFO0_ETM_bytectcount_Pos)
```

TPI FIFO0: ETM\_bytectcount Mask

**5.164.2.383 TPI\_FIFO0\_ETM\_bytectcount\_Pos**

```
#define TPI_FIFO0_ETM_bytectcount_Pos 24
```

TPI FIFO0: ETM\_bytectcount Position

**5.164.2.384 TPI\_FIFO0\_ITM\_ATVALID\_Msk**

```
#define TPI_FIFO0_ITM_ATVALID_Msk (0x3UL << TPI_FIFO0_ITM_ATVALID_Pos)
```

TPI FIFO0: ITM\_ATVALID Mask

**5.164.2.385 TPI\_FIFO0\_ITM\_ATVALID\_Pos**

```
#define TPI_FIFO0_ITM_ATVALID_Pos 29
```

TPI FIFO0: ITM\_ATVALID Position

**5.164.2.386 TPI\_FIFO0\_ITM\_bytectcount\_Msk**

```
#define TPI_FIFO0_ITM_bytectcount_Msk (0x3UL << TPI_FIFO0_ITM_bytectcount_Pos)
```

TPI FIFO0: ITM\_bytectcount Mask

**5.164.2.387 TPI\_FIFO0\_ITM\_bytectcount\_Pos**

```
#define TPI_FIFO0_ITM_bytectcount_Pos 27
```

TPI FIFO0: ITM\_bytectcount Position

**5.164.2.388 TPI\_FIFO1\_ETM\_ATVALID\_Msk**

```
#define TPI_FIFO1_ETM_ATVALID_Msk (0x3UL << TPI_FIFO1_ETM_ATVALID_Pos)
```

TPI FIFO1: ETM\_ATVALID Mask

**5.164.2.389 TPI\_FIFO1\_ETM\_ATVALID\_Pos**

```
#define TPI_FIFO1_ETM_ATVALID_Pos 26
```

TPI FIFO1: ETM\_ATVALID Position

**5.164.2.390 TPI\_FIFO1\_ETM\_bytectcount\_Msk**

```
#define TPI_FIFO1_ETM_bytectcount_Msk (0x3UL << TPI_FIFO1_ETM_bytectcount_Pos)
```

TPI FIFO1: ETM\_bytectcount Mask

**5.164.2.391 TPI\_FIFO1\_ETM\_bytectcount\_Pos**

```
#define TPI_FIFO1_ETM_bytectcount_Pos 24
```

TPI FIFO1: ETM\_bytectcount Position

**5.164.2.392 TPI\_FIFO1\_ITM0\_Msk**

```
#define TPI_FIFO1_ITM0_Msk (0xFFUL /*<< TPI_FIFO1_ITM0_Pos*/)
```

TPI FIFO1: ITM0 Mask

**5.164.2.393 TPI\_FIFO1\_ITM0\_Pos**

```
#define TPI_FIFO1_ITM0_Pos 0
```

TPI FIFO1: ITM0 Position

**5.164.2.394 TPI\_FIFO1\_ITM1\_Msk**

```
#define TPI_FIFO1_ITM1_Msk (0xFFUL << TPI_FIFO1_ITM1_Pos)
```

TPI FIFO1: ITM1 Mask

**5.164.2.395 TPI\_FIFO1\_ITM1\_Pos**

```
#define TPI_FIFO1_ITM1_Pos 8
```

TPI FIFO1: ITM1 Position

**5.164.2.396 TPI\_FIFO1\_ITM2\_Msk**

```
#define TPI_FIFO1_ITM2_Msk (0xFFUL << TPI_FIFO1_ITM2_Pos)
```

TPI FIFO1: ITM2 Mask

**5.164.2.397 TPI\_FIFO1\_ITM2\_Pos**

```
#define TPI_FIFO1_ITM2_Pos 16
```

TPI FIFO1: ITM2 Position

**5.164.2.398 TPI\_FIFO1\_ITM\_ATVALID\_Msk**

```
#define TPI_FIFO1_ITM_ATVALID_Msk (0x3UL << TPI_FIFO1_ITM_ATVALID_Pos)
```

TPI FIFO1: ITM\_ATVALID Mask

**5.164.2.399 TPI\_FIFO1\_ITM\_ATVALID\_Pos**

```
#define TPI_FIFO1_ITM_ATVALID_Pos 29
```

TPI FIFO1: ITM\_ATVALID Position

**5.164.2.400 TPI\_FIFO1\_ITM\_bytectcount\_Msk**

```
#define TPI_FIFO1_ITM_bytectcount_Msk (0x3UL << TPI_FIFO1_ITM_bytectcount_Pos)
```

TPI FIFO1: ITM\_bytectcount Mask

**5.164.2.401 TPI\_FIFO1\_ITM\_bytectcount\_Pos**

```
#define TPI_FIFO1_ITM_bytectcount_Pos 27
```

TPI FIFO1: ITM\_bytectcount Position

**5.164.2.402 TPI\_ITATBCTR0\_ATREADY\_Msk**

```
#define TPI_ITATBCTR0_ATREADY_Msk (0x1UL /*<< TPI_ITATBCTR0_ATREADY_Pos*/)
```

TPI ITATBCTR0: ATREADY Mask

#### 5.164.2.403 TPI\_ITATBCTR0\_ATREADY\_Pos

```
#define TPI_ITATBCTR0_ATREADY_Pos 0
```

TPI ITATBCTR0: ATREADY Position

#### 5.164.2.404 TPI\_ITATBCTR2\_ATREADY\_Msk

```
#define TPI_ITATBCTR2_ATREADY_Msk (0x1UL /*<< TPI_ITATBCTR2_ATREADY_Pos*/)
```

TPI ITATBCTR2: ATREADY Mask

#### 5.164.2.405 TPI\_ITATBCTR2\_ATREADY\_Pos

```
#define TPI_ITATBCTR2_ATREADY_Pos 0
```

TPI ITATBCTR2: ATREADY Position

#### 5.164.2.406 TPI\_ITCTRL\_Mode\_Msk

```
#define TPI_ITCTRL_Mode_Msk (0x1UL /*<< TPI_ITCTRL_Mode_Pos*/)
```

TPI ITCTRL: Mode Mask

#### 5.164.2.407 TPI\_ITCTRL\_Mode\_Pos

```
#define TPI_ITCTRL_Mode_Pos 0
```

TPI ITCTRL: Mode Position

#### 5.164.2.408 TPI\_SPPR\_TXMODE\_Msk

```
#define TPI_SPPR_TXMODE_Msk (0x3UL /*<< TPI_SPPR_TXMODE_Pos*/)
```

TPI SPPR: TXMODE Mask

#### 5.164.2.409 TPI\_SPPR\_TXMODE\_Pos

```
#define TPI_SPPR_TXMODE_Pos 0
```

TPI SPPR: TXMODE Position

#### 5.164.2.410 TPI\_TRIGGER\_TRIGGER\_Msk

```
#define TPI_TRIGGER_TRIGGER_Msk (0x1UL /*<< TPI_TRIGGER_TRIGGER_Pos*/)
```

TPI TRIGGER: TRIGGER Mask

**5.164.2.411 TPI\_TRIGGER\_TRIGGER\_Pos**

```
#define TPI_TRIGGER_TRIGGER_Pos 0
```

TPI TRIGGER: TRIGGER Position

**5.164.2.412 xPSR\_C\_Msk**

```
#define xPSR_C_Msk (1UL << xPSR_C_Pos)
```

xPSR: C Mask

**5.164.2.413 xPSR\_C\_Pos**

```
#define xPSR_C_Pos 29
```

xPSR: C Position

**5.164.2.414 xPSR\_GE\_Msk**

```
#define xPSR_GE_Msk (0xFUL << xPSR_GE_Pos)
```

xPSR: GE Mask

**5.164.2.415 xPSR\_GE\_Pos**

```
#define xPSR_GE_Pos 16
```

xPSR: GE Position

**5.164.2.416 xPSR\_ISR\_Msk**

```
#define xPSR_ISR_Msk (0x1FFUL /*<< xPSR_ISR_Pos*/)
```

xPSR: ISR Mask

**5.164.2.417 xPSR\_ISR\_Pos**

```
#define xPSR_ISR_Pos 0
```

xPSR: ISR Position

**5.164.2.418 xPSR\_IT\_Msk**

```
#define xPSR_IT_Msk (3UL << xPSR_IT_Pos)
```

xPSR: IT Mask

**5.164.2.419 xPSR\_IT\_Pos**

```
#define xPSR_IT_Pos 25
```

xPSR: IT Position

**5.164.2.420 xPSR\_N\_Msk**

```
#define xPSR_N_Msk (1UL << xPSR_N_Pos)
```

xPSR: N Mask

**5.164.2.421 xPSR\_N\_Pos**

```
#define xPSR_N_Pos 31
```

xPSR: N Position

**5.164.2.422 xPSR\_Q\_Msk**

```
#define xPSR_Q_Msk (1UL << xPSR_Q_Pos)
```

xPSR: Q Mask

**5.164.2.423 xPSR\_Q\_Pos**

```
#define xPSR_Q_Pos 27
```

xPSR: Q Position

**5.164.2.424 xPSR\_T\_Msk**

```
#define xPSR_T_Msk (1UL << xPSR_T_Pos)
```

xPSR: T Mask

**5.164.2.425 xPSR\_T\_Pos**

```
#define xPSR_T_Pos 24
```

xPSR: T Position

**5.164.2.426 xPSR\_V\_Msk**

```
#define xPSR_V_Msk (1UL << xPSR_V_Pos)
```

xPSR: V Mask

#### 5.164.2.427 xPSR\_V\_Pos

```
#define xPSR_V_Pos 28
```

xPSR: V Position

#### 5.164.2.428 xPSR\_Z\_Msk

```
#define xPSR_Z_Msk (1UL << xPSR_Z_Pos)
```

xPSR: Z Mask

#### 5.164.2.429 xPSR\_Z\_Pos

```
#define xPSR_Z_Pos 30
```

xPSR: Z Position

### 5.164.3 Function Documentation

#### 5.164.3.1 ITM\_CheckChar()

```
__STATIC_INLINE int32_t ITM_CheckChar (
    void )
```

ITM Check Character.

The function checks whether a character is pending for reading in the variable [ITM\\_RxBuffer](#).

##### Returns

- 0 No character available.
- 1 Character available.

#### 5.164.3.2 ITM\_ReceiveChar()

```
__STATIC_INLINE int32_t ITM_ReceiveChar (
    void )
```

ITM Receive Character.

The function inputs a character via the external variable [ITM\\_RxBuffer](#).

##### Returns

- Received character.
- 1 No character pending.

### 5.164.3.3 ITM\_SendChar()

```
__STATIC_INLINE uint32_t ITM_SendChar (
    uint32_t ch )
```

ITM Send Character.

The function transmits a character via the ITM channel 0, and

- Just returns when no debugger is connected that has booked the output.
- Is blocking when a debugger is connected, but the previous character sent has not been transmitted.

#### Parameters

|    |           |                        |
|----|-----------|------------------------|
| in | <i>ch</i> | Character to transmit. |
|----|-----------|------------------------|

#### Returns

Character to transmit.

### 5.164.3.4 NVIC\_ClearPendingIRQ()

```
__STATIC_INLINE void NVIC_ClearPendingIRQ (
    IRQn_Type IRQn )
```

Clear Pending Interrupt.

The function clears the pending bit of an external interrupt.

#### Parameters

|    |             |                                                      |
|----|-------------|------------------------------------------------------|
| in | <i>IRQn</i> | External interrupt number. Value cannot be negative. |
|----|-------------|------------------------------------------------------|

### 5.164.3.5 NVIC\_DecodePriority()

```
__STATIC_INLINE void NVIC_DecodePriority (
    uint32_t Priority,
    uint32_t PriorityGroup,
    uint32_t * pPreemptPriority,
    uint32_t * pSubPriority )
```

Decode Priority.

The function decodes an interrupt priority value with a given priority group to preemptive priority value and subpriority value. In case of a conflict between priority grouping and available priority bits (`__NVIC_PRIO_BITS`) the smallest possible priority group is set.

**Parameters**

|     |                         |                                                                                               |
|-----|-------------------------|-----------------------------------------------------------------------------------------------|
| in  | <i>Priority</i>         | Priority value, which can be retrieved with the function <a href="#">NVIC_GetPriority()</a> . |
| in  | <i>PriorityGroup</i>    | Used priority group.                                                                          |
| out | <i>pPreemptPriority</i> | Preemptive priority value (starting from 0).                                                  |
| out | <i>pSubPriority</i>     | Subpriority value (starting from 0).                                                          |

**5.164.3.6 NVIC\_DisableIRQ()**

```
__STATIC_INLINE void NVIC_DisableIRQ (
    IRQn_Type IRQn )
```

Disable External Interrupt.

The function disables a device-specific interrupt in the NVIC interrupt controller.

**Parameters**

|    |             |                                                      |
|----|-------------|------------------------------------------------------|
| in | <i>IRQn</i> | External interrupt number. Value cannot be negative. |
|----|-------------|------------------------------------------------------|

**5.164.3.7 NVIC\_EnableIRQ()**

```
__STATIC_INLINE void NVIC_EnableIRQ (
    IRQn_Type IRQn )
```

Enable External Interrupt.

The function enables a device-specific interrupt in the NVIC interrupt controller.

**Parameters**

|    |             |                                                      |
|----|-------------|------------------------------------------------------|
| in | <i>IRQn</i> | External interrupt number. Value cannot be negative. |
|----|-------------|------------------------------------------------------|

**5.164.3.8 NVIC\_EncodePriority()**

```
__STATIC_INLINE uint32_t NVIC_EncodePriority (
    uint32_t PriorityGroup,
    uint32_t PreemptPriority,
    uint32_t SubPriority )
```

Encode Priority.

The function encodes the priority for an interrupt with the given priority group, preemptive priority value, and sub-priority value. In case of a conflict between priority grouping and available priority bits (`__NVIC_PRIO_BITS`), the smallest possible priority group is set.

**Parameters**

|    |                        |                                              |
|----|------------------------|----------------------------------------------|
| in | <i>PriorityGroup</i>   | Used priority group.                         |
| in | <i>PreemptPriority</i> | Preemptive priority value (starting from 0). |
| in | <i>SubPriority</i>     | Subpriority value (starting from 0).         |

**Returns**

Encoded priority. Value can be used in the function [NVIC\\_SetPriority\(\)](#).

**5.164.3.9 NVIC\_GetActive()**

```
__STATIC_INLINE uint32_t NVIC_GetActive (
    IRQn_Type IRQn )
```

Get Active Interrupt.

The function reads the active register in NVIC and returns the active bit.

**Parameters**

|    |             |                   |
|----|-------------|-------------------|
| in | <i>IRQn</i> | Interrupt number. |
|----|-------------|-------------------|

**Returns**

- 0 Interrupt status is not active.
- 1 Interrupt status is active.

**5.164.3.10 NVIC\_GetPendingIRQ()**

```
__STATIC_INLINE uint32_t NVIC_GetPendingIRQ (
    IRQn_Type IRQn )
```

Get Pending Interrupt.

The function reads the pending register in the NVIC and returns the pending bit for the specified interrupt.

**Parameters**

|    |             |                   |
|----|-------------|-------------------|
| in | <i>IRQn</i> | Interrupt number. |
|----|-------------|-------------------|

**Returns**

- 0 Interrupt status is not pending.
- 1 Interrupt status is pending.

**5.164.3.11 NVIC\_GetPriority()**

```
__STATIC_INLINE uint32_t NVIC_GetPriority (
    IRQn_Type IRQn )
```

Get Interrupt Priority.

The function reads the priority of an interrupt. The interrupt number can be positive to specify an external (device specific) interrupt, or negative to specify an internal (core) interrupt.

**Parameters**

|    |             |                   |
|----|-------------|-------------------|
| in | <i>IRQn</i> | Interrupt number. |
|----|-------------|-------------------|

**Returns**

Interrupt Priority. Value is aligned automatically to the implemented priority bits of the microcontroller.

**5.164.3.12 NVIC\_GetPriorityGrouping()**

```
__STATIC_INLINE uint32_t NVIC_GetPriorityGrouping (
    void )
```

Get Priority Grouping.

The function reads the priority grouping field from the NVIC Interrupt Controller.

**Returns**

Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field).

**5.164.3.13 NVIC\_SetPendingIRQ()**

```
__STATIC_INLINE void NVIC_SetPendingIRQ (
    IRQn_Type IRQn )
```

Set Pending Interrupt.

The function sets the pending bit of an external interrupt.

#### Parameters

|    |             |                                             |
|----|-------------|---------------------------------------------|
| in | <i>IRQn</i> | Interrupt number. Value cannot be negative. |
|----|-------------|---------------------------------------------|

#### 5.164.3.14 NVIC\_SetPriority()

```
__STATIC_INLINE void NVIC_SetPriority (
    IRQn_Type IRQn,
    uint32_t priority )
```

Set Interrupt Priority.

The function sets the priority of an interrupt.

#### Note

The priority cannot be set for every core interrupt.

#### Parameters

|    |                 |                   |
|----|-----------------|-------------------|
| in | <i>IRQn</i>     | Interrupt number. |
| in | <i>priority</i> | Priority to set.  |

#### 5.164.3.15 NVIC\_SetPriorityGrouping()

```
__STATIC_INLINE void NVIC_SetPriorityGrouping (
    uint32_t PriorityGroup )
```

Set Priority Grouping.

The function sets the priority grouping field using the required unlock sequence. The parameter *PriorityGroup* is assigned to the field SCB->AIRCR [10:8] PRIGROUP field. Only values from 0..7 are used. In case of a conflict between priority grouping and available priority bits (*\_\_NVIC\_PRIO\_BITS*), the smallest possible priority group is set.

#### Parameters

|    |                      |                          |
|----|----------------------|--------------------------|
| in | <i>PriorityGroup</i> | Priority grouping field. |
|----|----------------------|--------------------------|

#### 5.164.3.16 NVIC\_SystemReset()

```
__STATIC_INLINE void NVIC_SystemReset (
    void )
```

System Reset.

The function initiates a system reset request to reset the MCU.

#### 5.164.3.17 **SysTick\_Config()**

```
__STATIC_INLINE uint32_t SysTick_Config (
    uint32_t ticks )
```

System Tick Configuration.

The function initializes the System Timer and its interrupt, and starts the System Tick Timer. Counter is in free running mode to generate periodic interrupts.

##### Parameters

|    |              |                                         |
|----|--------------|-----------------------------------------|
| in | <i>ticks</i> | Number of ticks between two interrupts. |
|----|--------------|-----------------------------------------|

##### Returns

0 Function succeeded.

1 Function failed.

##### Note

When the variable `__Vendor_SysTickConfig` is set to 1, then the function **SysTick\_Config** is not included. In this case, the file **device.h** must contain a vendor-specific implementation of this function.

#### 5.164.3.18 **SysTick\_Handler()**

```
void SysTick_Handler (
    void )
```

SysTick interrupt handler.

This function is called when the SysTick timer interrupt occurs. It handles the interrupt by calling the user-defined callback function and, if necessary, stopping the timer based on the running mode.

##### Parameters

|    |             |  |
|----|-------------|--|
| in | <i>None</i> |  |
|----|-------------|--|

**Returns**

None

## 5.164.4 Variable Documentation

### 5.164.4.1 ACR

```
__IO uint32_t FLASH_TypeDef::ACR
```

FLASH access control register, Address offset: 0x00

### 5.164.4.2 AFR

```
__IO uint32_t GPIO_TypeDef::AFR[2]
```

GPIO alternate function registers, Address offset: 0x20-0x24

### 5.164.4.3 AHB1ENR

```
__IO uint32_t RCC_TypeDef::AHB1ENR
```

RCC AHB1 peripheral clock register, Address offset: 0x30

### 5.164.4.4 AHB1LPENR

```
__IO uint32_t RCC_TypeDef::AHB1LPENR
```

RCC AHB1 peripheral clock enable in low power mode register, Address offset: 0x50

### 5.164.4.5 AHB1RSTR

```
__IO uint32_t RCC_TypeDef::AHB1RSTR
```

RCC AHB1 peripheral reset register, Address offset: 0x10

### 5.164.4.6 AHB2ENR

```
__IO uint32_t RCC_TypeDef::AHB2ENR
```

RCC AHB2 peripheral clock register, Address offset: 0x34

#### 5.164.4.7 AHB2LPENR

`__IO uint32_t RCC_TypeDef::AHB2LPENR`

RCC AHB2 peripheral clock enable in low power mode register, Address offset: 0x54

#### 5.164.4.8 AHB2RSTR

`__IO uint32_t RCC_TypeDef::AHB2RSTR`

RCC AHB2 peripheral reset register, Address offset: 0x14

#### 5.164.4.9 AHB3ENR

`__IO uint32_t RCC_TypeDef::AHB3ENR`

RCC AHB3 peripheral clock register, Address offset: 0x38

#### 5.164.4.10 AHB3LPENR

`__IO uint32_t RCC_TypeDef::AHB3LPENR`

RCC AHB3 peripheral clock enable in low power mode register, Address offset: 0x58

#### 5.164.4.11 AHB3RSTR

`__IO uint32_t RCC_TypeDef::AHB3RSTR`

RCC AHB3 peripheral reset register, Address offset: 0x18

#### 5.164.4.12 ALRMAR

`__IO uint32_t RTC_TypeDef::ALRMAR`

RTC alarm A register, Address offset: 0x1C

#### 5.164.4.13 ALRMASSR

`__IO uint32_t RTC_TypeDef::ALRMASSR`

RTC alarm A sub second register, Address offset: 0x44

#### 5.164.4.14 ALRMBR

`__IO uint32_t RTC_TypeDef::ALRMBR`

RTC alarm B register, Address offset: 0x20

#### 5.164.4.15 ALRMBSSR

```
__IO uint32_t RTC_TypeDef::ALRMBSSR
```

RTC alarm B sub second register, Address offset: 0x48

#### 5.164.4.16 AMTCR

```
__IO uint32_t DMA2D_TypeDef::AMTCR
```

DMA2D AHB Master Timer Configuration Register, Address offset: 0x4C

#### 5.164.4.17 APB1ENR

```
__IO uint32_t RCC_TypeDef::APB1ENR
```

RCC APB1 peripheral clock enable register, Address offset: 0x40

#### 5.164.4.18 APB1FZ

```
__IO uint32_t DBGMCU_TypeDef::APB1FZ
```

Debug MCU APB1 freeze register, Address offset: 0x08

#### 5.164.4.19 APB1LPENR

```
__IO uint32_t RCC_TypeDef::APB1LPENR
```

RCC APB1 peripheral clock enable in low power mode register, Address offset: 0x60

#### 5.164.4.20 APB1RSTR

```
__IO uint32_t RCC_TypeDef::APB1RSTR
```

RCC APB1 peripheral reset register, Address offset: 0x20

#### 5.164.4.21 APB2ENR

```
__IO uint32_t RCC_TypeDef::APB2ENR
```

RCC APB2 peripheral clock enable register, Address offset: 0x44

#### 5.164.4.22 APB2FZ

```
__IO uint32_t DBGMCU_TypeDef::APB2FZ
```

Debug MCU APB2 freeze register, Address offset: 0x0C

#### 5.164.4.23 APB2LPENR

`__IO uint32_t RCC_TypeDef::APB2LPENR`

RCC APB2 peripheral clock enable in low power mode register, Address offset: 0x64

#### 5.164.4.24 APB2RSTR

`__IO uint32_t RCC_TypeDef::APB2RSTR`

RCC APB2 peripheral reset register, Address offset: 0x24

#### 5.164.4.25 ARG

`__IO uint32_t SDIO_TypeDef::ARG`

SDIO argument register, Address offset: 0x08

#### 5.164.4.26 ARR

`__IO uint32_t TIM_TypeDef::ARR`

TIM auto-reload register, Address offset: 0x2C

#### 5.164.4.27 AWCR

`__IO uint32_t LTDC_TypeDef::AWCR`

LTDC Active Width Configuration Register, Address offset: 0x10

#### 5.164.4.28 BCCR

`__IO uint32_t LTDC_TypeDef::BCCR`

LTDC Background Color Configuration Register, Address offset: 0x2C

#### 5.164.4.29 BDCR

`__IO uint32_t RCC_TypeDef::BDCR`

RCC Backup domain control register, Address offset: 0x70

#### 5.164.4.30 BDTR

`__IO uint16_t TIM_TypeDef::BDTR`

TIM break and dead-time register, Address offset: 0x44

#### 5.164.4.31 BFCR

```
__IO uint32_t LTDC_Layer_TypeDef::BFCR
```

LTDC Layerx Blending Factors Configuration Register Address offset: 0xA0

#### 5.164.4.32 BGCLUT

```
__IO uint32_t DMA2D_TypeDef::BGCLUT[256]
```

DMA2D Background CLUT, Address offset: 800-BFF

#### 5.164.4.33 BGCMAR

```
__IO uint32_t DMA2D_TypeDef::BGCMAR
```

DMA2D Background CLUT Memory Address Register, Address offset: 0x30

#### 5.164.4.34 BGCOLR

```
__IO uint32_t DMA2D_TypeDef::BGCOLR
```

DMA2D Background Color Register, Address offset: 0x28

#### 5.164.4.35 BGMAR

```
__IO uint32_t DMA2D_TypeDef::BGMAR
```

DMA2D Background Memory Address Register, Address offset: 0x14

#### 5.164.4.36 BGOR

```
__IO uint32_t DMA2D_TypeDef::BGOR
```

DMA2D Background Offset Register, Address offset: 0x18

#### 5.164.4.37 BGPFCCR

```
__IO uint32_t DMA2D_TypeDef::BGPFCCR
```

DMA2D Background PFC Control Register, Address offset: 0x24

#### 5.164.4.38 BKPOR

```
__IO uint32_t RTC_TypeDef::BKPOR
```

RTC backup register 1, Address offset: 0x50

#### 5.164.4.39 BKP10R

```
__IO uint32_t RTC_TypeDef::BKP10R
```

RTC backup register 10, Address offset: 0x78

#### 5.164.4.40 BKP11R

```
__IO uint32_t RTC_TypeDef::BKP11R
```

RTC backup register 11, Address offset: 0x7C

#### 5.164.4.41 BKP12R

```
__IO uint32_t RTC_TypeDef::BKP12R
```

RTC backup register 12, Address offset: 0x80

#### 5.164.4.42 BKP13R

```
__IO uint32_t RTC_TypeDef::BKP13R
```

RTC backup register 13, Address offset: 0x84

#### 5.164.4.43 BKP14R

```
__IO uint32_t RTC_TypeDef::BKP14R
```

RTC backup register 14, Address offset: 0x88

#### 5.164.4.44 BKP15R

```
__IO uint32_t RTC_TypeDef::BKP15R
```

RTC backup register 15, Address offset: 0x8C

#### 5.164.4.45 BKP16R

```
__IO uint32_t RTC_TypeDef::BKP16R
```

RTC backup register 16, Address offset: 0x90

#### 5.164.4.46 BKP17R

```
__IO uint32_t RTC_TypeDef::BKP17R
```

RTC backup register 17, Address offset: 0x94

#### 5.164.4.47 BKP18R

```
__IO uint32_t RTC_TypeDef::BKP18R
```

RTC backup register 18, Address offset: 0x98

#### 5.164.4.48 BKP19R

```
__IO uint32_t RTC_TypeDef::BKP19R
```

RTC backup register 19, Address offset: 0x9C

#### 5.164.4.49 BKP1R

```
__IO uint32_t RTC_TypeDef::BKP1R
```

RTC backup register 1, Address offset: 0x54

#### 5.164.4.50 BKP2R

```
__IO uint32_t RTC_TypeDef::BKP2R
```

RTC backup register 2, Address offset: 0x58

#### 5.164.4.51 BKP3R

```
__IO uint32_t RTC_TypeDef::BKP3R
```

RTC backup register 3, Address offset: 0x5C

#### 5.164.4.52 BKP4R

```
__IO uint32_t RTC_TypeDef::BKP4R
```

RTC backup register 4, Address offset: 0x60

#### 5.164.4.53 BKP5R

```
__IO uint32_t RTC_TypeDef::BKP5R
```

RTC backup register 5, Address offset: 0x64

#### 5.164.4.54 BKP6R

```
__IO uint32_t RTC_TypeDef::BKP6R
```

RTC backup register 6, Address offset: 0x68

#### 5.164.4.55 BKP7R

`__IO uint32_t RTC_TypeDef::BKP7R`

RTC backup register 7, Address offset: 0x6C

#### 5.164.4.56 BKP8R

`__IO uint32_t RTC_TypeDef::BKP8R`

RTC backup register 8, Address offset: 0x70

#### 5.164.4.57 BKP9R

`__IO uint32_t RTC_TypeDef::BKP9R`

RTC backup register 9, Address offset: 0x74

#### 5.164.4.58 BPCR

`__IO uint32_t LTDC_TypeDef::BPCR`

LTDC Back Porch Configuration Register, Address offset: 0x0C

#### 5.164.4.59 BRR

`__IO uint16_t USART_TypeDef::BRR`

USART Baud rate register, Address offset: 0x08

#### 5.164.4.60 BSRRH

`__IO uint16_t GPIO_TypeDef::BSRRH`

GPIO port bit set/reset high register, Address offset: 0x1A

#### 5.164.4.61 BSRRL

`__IO uint16_t GPIO_TypeDef::BSRRL`

GPIO port bit set/reset low register, Address offset: 0x18

#### 5.164.4.62 BTR

```
__IO uint32_t CAN_TypeDef::BTR
```

CAN bit timing register, Address offset: 0x1C

#### 5.164.4.63 CACR

```
__IO uint32_t LTDC_Layer_TypeDef::CACR
```

LTDC Layerx Constant Alpha Configuration Register Address offset: 0x98

#### 5.164.4.64 CALIBR

```
__IO uint32_t RTC_TypeDef::CALIBR
```

RTC calibration register, Address offset: 0x18

#### 5.164.4.65 CALR

```
__IO uint32_t RTC_TypeDef::CALR
```

RTC calibration register, Address offset: 0x3C

#### 5.164.4.66 CCER

```
__IO uint16_t TIM_TypeDef::CCER
```

TIM capture/compare enable register, Address offset: 0x20

#### 5.164.4.67 CCMR1

```
__IO uint16_t TIM_TypeDef::CCMR1
```

TIM capture/compare mode register 1, Address offset: 0x18

#### 5.164.4.68 CCMR2

```
__IO uint16_t TIM_TypeDef::CCMR2
```

TIM capture/compare mode register 2, Address offset: 0x1C

#### 5.164.4.69 CCR [1/2]

`__IO uint32_t ADC_Common_TypeDef::CCR`

ADC common control register, Address offset: ADC1 base address + 0x304

#### 5.164.4.70 CCR [2/2]

`__IO uint16_t I2C_TypeDef::CCR`

I2C Clock control register, Address offset: 0x1C

#### 5.164.4.71 CCR1

`__IO uint32_t TIM_TypeDef::CCR1`

TIM capture/compare register 1, Address offset: 0x34

#### 5.164.4.72 CCR2

`__IO uint32_t TIM_TypeDef::CCR2`

TIM capture/compare register 2, Address offset: 0x38

#### 5.164.4.73 CCR3

`__IO uint32_t TIM_TypeDef::CCR3`

TIM capture/compare register 3, Address offset: 0x3C

#### 5.164.4.74 CCR4

`__IO uint32_t TIM_TypeDef::CCR4`

TIM capture/compare register 4, Address offset: 0x40

#### 5.164.4.75 CDR

`__IO uint32_t ADC_Common_TypeDef::CDR`

ADC common regular data register for dual AND triple modes, Address offset: ADC1 base address + 0x308

#### 5.164.4.76 CDSR

`__IO uint32_t LTDC_TypeDef::CDSR`

LTDC Current Display Status Register, Address offset: 0x48

#### 5.164.4.77 CFBAR

```
__IO uint32_t LTDC_Layer_TypeDef::CFBAR
```

LTDC Layerx Color Frame Buffer Address Register Address offset: 0xAC

#### 5.164.4.78 CFBLNR

```
__IO uint32_t LTDC_Layer_TypeDef::CFBLNR
```

LTDC Layerx ColorFrame Buffer Line Number Register Address offset: 0xB4

#### 5.164.4.79 CFBLR

```
__IO uint32_t LTDC_Layer_TypeDef::CFBLR
```

LTDC Layerx Color Frame Buffer Length Register Address offset: 0xB0

#### 5.164.4.80 CFGR

```
__IO uint32_t RCC_TypeDef::CFGCR
```

RCC clock configuration register, Address offset: 0x08

#### 5.164.4.81 CFR

```
__IO uint32_t WWDG_TypeDef::CFR
```

WWDG Configuration register, Address offset: 0x04

#### 5.164.4.82 CIR

```
__IO uint32_t RCC_TypeDef::CIR
```

RCC clock interrupt register, Address offset: 0x0C

#### 5.164.4.83 CKCR

```
__IO uint32_t LTDC_Layer_TypeDef::CKCR
```

LTDC Layerx Color Keying Configuration Register Address offset: 0x90

#### 5.164.4.84 CKGATENR

```
__IO uint32_t RCC_TypeDef::CKGATENR
```

RCC Clocks Gated Enable Register, Address offset: 0x90

#### 5.164.4.85 CLKCR

`__IO uint32_t SDIO_TypeDef::CLKCR`

SDI clock control register, Address offset: 0x04

#### 5.164.4.86 CLRFR

`__IO uint32_t SAI_Block_TypeDef::CLRFR`

SAI block x clear flag register, Address offset: 0x1C

#### 5.164.4.87 CLUTWR

`__IO uint32_t LTDC_Layer_TypeDef::CLUTWR`

LTDC Layerx CLUT Write Register Address offset: 0x144

#### 5.164.4.88 CMD

`__IO uint32_t SDIO_TypeDef::CMD`

SDIO command register, Address offset: 0x0C

#### 5.164.4.89 CMPCR

`__IO uint32_t SYSCFG_TypeDef::CMPCR`

SYSCFG Compensation cell control register, Address offset: 0x20

#### 5.164.4.90 CNT

`__IO uint32_t TIM_TypeDef::CNT`

TIM counter register, Address offset: 0x24

#### 5.164.4.91 CPSR

`__IO uint32_t LTDC_TypeDef::CPSR`

LTDC Current Position Status Register, Address offset: 0x44

**5.164.4.92 CR [1/15]**

```
__IO uint32_t CRC_TypeDef::CR
```

CRC Control register, Address offset: 0x08

**5.164.4.93 CR [2/15]**

```
__IO uint32_t DAC_TypeDef::CR
```

DAC control register, Address offset: 0x00

**5.164.4.94 CR [3/15]**

```
__IO uint32_t DBGMCU_TypeDef::CR
```

Debug MCU configuration register, Address offset: 0x04

**5.164.4.95 CR [4/15]**

```
__IO uint32_t DCMI_TypeDef::CR
```

DCMI control register 1, Address offset: 0x00

**5.164.4.96 CR [5/15]**

```
__IO uint32_t DMA_Stream_TypeDef::CR
```

DMA stream x configuration register

**5.164.4.97 CR [6/15]**

```
__IO uint32_t DMA2D_TypeDef::CR
```

DMA2D Control Register, Address offset: 0x00

**5.164.4.98 CR [7/15]**

```
__IO uint32_t FLASH_TypeDef::CR
```

FLASH control register, Address offset: 0x10

**5.164.4.99 CR [8/15]**

```
__IO uint32_t LTDC_Layer_TypeDef::CR
```

LTDC Layerx Control Register Address offset: 0x84

**5.164.4.100 CR [9/15]**

```
__IO uint32_t PWR_TypeDef::CR
```

PWR power control register, Address offset: 0x00

**5.164.4.101 CR [10/15]**

```
__IO uint32_t RCC_TypeDef::CR
```

RCC clock control register, Address offset: 0x00

**5.164.4.102 CR [11/15]**

```
__IO uint32_t RTC_TypeDef::CR
```

RTC control register, Address offset: 0x08

**5.164.4.103 CR [12/15]**

```
__IO uint32_t WWDG_TypeDef::CR
```

WWDG Control register, Address offset: 0x00

**5.164.4.104 CR [13/15]**

```
__IO uint32_t CRYP_TypeDef::CR
```

CRYP control register, Address offset: 0x00

**5.164.4.105 CR [14/15]**

```
__IO uint32_t HASH_TypeDef::CR
```

HASH control register, Address offset: 0x00

**5.164.4.106 CR [15/15]**

```
__IO uint32_t RNG_TypeDef::CR
```

RNG control register, Address offset: 0x00

**5.164.4.107 CR1 [1/6]**

```
__IO uint32_t ADC_TypeDef::CR1
```

ADC control register 1, Address offset: 0x04

**5.164.4.108 CR1 [2/6]**

```
__IO uint16_t I2C_TypeDef::CR1
```

I2C Control register 1, Address offset: 0x00

**5.164.4.109 CR1 [3/6]**

```
__IO uint32_t SAI_Block_TypeDef::CR1
```

SAI block x configuration register 1, Address offset: 0x04

**5.164.4.110 CR1 [4/6]**

```
__IO uint16_t SPI_TypeDef::CR1
```

SPI control register 1 (not used in I2S mode), Address offset: 0x00

**5.164.4.111 CR1 [5/6]**

```
__IO uint16_t TIM_TypeDef::CR1
```

TIM control register 1, Address offset: 0x00

**5.164.4.112 CR1 [6/6]**

```
__IO uint16_t USART_TypeDef::CR1
```

USART Control register 1, Address offset: 0x0C

**5.164.4.113 CR2 [1/6]**

```
__IO uint32_t ADC_TypeDef::CR2
```

ADC control register 2, Address offset: 0x08

**5.164.4.114 CR2 [2/6]**

```
__IO uint16_t I2C_TypeDef::CR2
```

I2C Control register 2, Address offset: 0x04

**5.164.4.115 CR2 [3/6]**

```
__IO uint32_t SAI_Block_TypeDef::CR2
```

SAI block x configuration register 2, Address offset: 0x08

**5.164.4.116 CR2 [4/6]**

```
__IO uint16_t SPI_TypeDef::CR2
```

SPI control register 2, Address offset: 0x04

**5.164.4.117 CR2 [5/6]**

```
__IO uint16_t TIM_TypeDef::CR2
```

TIM control register 2, Address offset: 0x04

**5.164.4.118 CR2 [6/6]**

```
__IO uint16_t USART_TypeDef::CR2
```

USART Control register 2, Address offset: 0x10

**5.164.4.119 CR3**

```
__IO uint16_t USART_TypeDef::CR3
```

USART Control register 3, Address offset: 0x14

**5.164.4.120 CRCPR**

```
__IO uint16_t SPI_TypeDef::CRCPR
```

SPI CRC polynomial register (not used in I2S mode), Address offset: 0x10

**5.164.4.121 CSGCM0R**

```
__IO uint32_t CRYP_TypeDef::CSGCM0R
```

CRYP GCM/GMAC context swap register 0, Address offset: 0x70

#### 5.164.4.122 CSGCM1R

```
__IO uint32_t CRYP_TypeDef::CSGCM1R
```

CRYP GCM/GMAC context swap register 1, Address offset: 0x74

#### 5.164.4.123 CSGCM2R

```
__IO uint32_t CRYP_TypeDef::CSGCM2R
```

CRYP GCM/GMAC context swap register 2, Address offset: 0x78

#### 5.164.4.124 CSGCM3R

```
__IO uint32_t CRYP_TypeDef::CSGCM3R
```

CRYP GCM/GMAC context swap register 3, Address offset: 0x7C

#### 5.164.4.125 CSGCM4R

```
__IO uint32_t CRYP_TypeDef::CSGCM4R
```

CRYP GCM/GMAC context swap register 4, Address offset: 0x80

#### 5.164.4.126 CSGCM5R

```
__IO uint32_t CRYP_TypeDef::CSGCM5R
```

CRYP GCM/GMAC context swap register 5, Address offset: 0x84

#### 5.164.4.127 CSGCM6R

```
__IO uint32_t CRYP_TypeDef::CSGCM6R
```

CRYP GCM/GMAC context swap register 6, Address offset: 0x88

#### 5.164.4.128 CSGCM7R

```
__IO uint32_t CRYP_TypeDef::CSGCM7R
```

CRYP GCM/GMAC context swap register 7, Address offset: 0x8C

#### 5.164.4.129 CSGCMCCM0R

```
__IO uint32_t CRYP_TypeDef::CSGCMCCM0R
```

CRYP GCM/GMAC or CCM/CMAC context swap register 0, Address offset: 0x50

#### 5.164.4.130 CSGCMCCM1R

```
__IO uint32_t CRYP_TypeDef::CSGCMCCM1R
```

CRYP GCM/GMAC or CCM/CMAC context swap register 1, Address offset: 0x54

#### 5.164.4.131 CSGCMCCM2R

```
__IO uint32_t CRYP_TypeDef::CSGCMCCM2R
```

CRYP GCM/GMAC or CCM/CMAC context swap register 2, Address offset: 0x58

#### 5.164.4.132 CSGCMCCM3R

```
__IO uint32_t CRYP_TypeDef::CSGCMCCM3R
```

CRYP GCM/GMAC or CCM/CMAC context swap register 3, Address offset: 0x5C

#### 5.164.4.133 CSGCMCCM4R

```
__IO uint32_t CRYP_TypeDef::CSGCMCCM4R
```

CRYP GCM/GMAC or CCM/CMAC context swap register 4, Address offset: 0x60

#### 5.164.4.134 CSGCMCCM5R

```
__IO uint32_t CRYP_TypeDef::CSGCMCCM5R
```

CRYP GCM/GMAC or CCM/CMAC context swap register 5, Address offset: 0x64

#### 5.164.4.135 CSGCMCCM6R

```
__IO uint32_t CRYP_TypeDef::CSGCMCCM6R
```

CRYP GCM/GMAC or CCM/CMAC context swap register 6, Address offset: 0x68

#### 5.164.4.136 CSGCMCCM7R

```
__IO uint32_t CRYP_TypeDef::CSGCMCCM7R
```

CRYP GCM/GMAC or CCM/CMAC context swap register 7, Address offset: 0x6C

#### 5.164.4.137 CSR [1/4]

```
__IO uint32_t ADC_Common_TypeDef::CSR
```

ADC Common status register, Address offset: ADC1 base address + 0x300

**5.164.4.138 CSR [2/4]**

```
__IO uint32_t PWR_TypeDef::CSR
```

PWR power control/status register, Address offset: 0x04

**5.164.4.139 CSR [3/4]**

```
__IO uint32_t RCC_TypeDef::CSR
```

RCC clock control & status register, Address offset: 0x74

**5.164.4.140 CSR [4/4]**

```
__IO uint32_t HASH_TypeDef::CSR[54]
```

HASH context swap registers, Address offset: 0x0F8-0x1CC

**5.164.4.141 CWSIZER**

```
__IO uint32_t DCMI_TypeDef::CWSIZER
```

DCMI crop window size, Address offset: 0x24

**5.164.4.142 CWSTRTR**

```
__IO uint32_t DCMI_TypeDef::CWSTRTR
```

DCMI crop window start, Address offset: 0x20

**5.164.4.143 DCCR**

```
__IO uint32_t LTDC_Layer_TypeDef::DCCR
```

LTDC Layerx Default Color Configuration Register Address offset: 0x9C

**5.164.4.144 DCKCFGR**

```
__IO uint32_t RCC_TypeDef::DCKCFGR
```

RCC Dedicated Clocks configuration register, Address offset: 0x8C

**5.164.4.145 DCKCFGR2**

```
__IO uint32_t RCC_TypeDef::DCKCFGR2
```

RCC Dedicated Clocks configuration register 2, Address offset: 0x94

#### 5.164.4.146 DCOUNT

`__I uint32_t SDIO_TypeDef::DCOUNT`

SDIO data counter register, Address offset: 0x30

#### 5.164.4.147 DCR

`__IO uint16_t TIM_TypeDef::DCR`

TIM DMA control register, Address offset: 0x48

#### 5.164.4.148 DCTRL

`__IO uint32_t SDIO_TypeDef::DCTRL`

SDIO data control register, Address offset: 0x2C

#### 5.164.4.149 DHR12L1

`__IO uint32_t DAC_TypeDef::DHR12L1`

DAC channel1 12-bit left aligned data holding register, Address offset: 0x0C

#### 5.164.4.150 DHR12L2

`__IO uint32_t DAC_TypeDef::DHR12L2`

DAC channel2 12-bit left aligned data holding register, Address offset: 0x18

#### 5.164.4.151 DHR12LD

`__IO uint32_t DAC_TypeDef::DHR12LD`

DUAL DAC 12-bit left aligned data holding register, Address offset: 0x24

#### 5.164.4.152 DHR12R1

`__IO uint32_t DAC_TypeDef::DHR12R1`

DAC channel1 12-bit right-aligned data holding register, Address offset: 0x08

#### 5.164.4.153 DHR12R2

`__IO uint32_t DAC_TypeDef::DHR12R2`

DAC channel2 12-bit right aligned data holding register, Address offset: 0x14

**5.164.4.154 DHR12RD**

```
__IO uint32_t DAC_TypeDef::DHR12RD
```

Dual DAC 12-bit right-aligned data holding register, Address offset: 0x20

**5.164.4.155 DHR8R1**

```
__IO uint32_t DAC_TypeDef::DHR8R1
```

DAC channel1 8-bit right aligned data holding register, Address offset: 0x10

**5.164.4.156 DHR8R2**

```
__IO uint32_t DAC_TypeDef::DHR8R2
```

DAC channel2 8-bit right-aligned data holding register, Address offset: 0x1C

**5.164.4.157 DHR8RD**

```
__IO uint32_t DAC_TypeDef::DHR8RD
```

DUAL DAC 8-bit right aligned data holding register, Address offset: 0x28

**5.164.4.158 DIER**

```
__IO uint16_t TIM_TypeDef::DIER
```

TIM DMA/interrupt enable register, Address offset: 0x0C

**5.164.4.159 DIN**

```
__IO uint32_t HASH_TypeDef::DIN
```

HASH data input register, Address offset: 0x04

**5.164.4.160 DLEN**

```
__IO uint32_t SDIO_TypeDef::DLEN
```

SDIO data length register, Address offset: 0x28

#### 5.164.4.161 DMACR

`__IO uint32_t CRYP_TypeDef::DMACR`

CRYP DMA control register, Address offset: 0x10

#### 5.164.4.162 DMAR

`__IO uint16_t TIM_TypeDef::DMAR`

TIM DMA address for full transfer, Address offset: 0x4C

#### 5.164.4.163 DOR1

`__IO uint32_t DAC_TypeDef::DOR1`

DAC channel1 data output register, Address offset: 0x2C

#### 5.164.4.164 DOR2

`__IO uint32_t DAC_TypeDef::DOR2`

DAC channel2 data output register, Address offset: 0x30

#### 5.164.4.165 DOUT

`__IO uint32_t CRYP_TypeDef::DOUT`

CRYP data output register, Address offset: 0x0C

#### 5.164.4.166 DR [1/10]

`__IO uint32_t ADC_TypeDef::DR`

ADC regular data register, Address offset: 0x4C

#### 5.164.4.167 DR [2/10]

`__IO uint32_t CRC_TypeDef::DR`

CRC Data register, Address offset: 0x00

#### 5.164.4.168 DR [3/10]

`__IO uint32_t DCMI_TypeDef::DR`

DCMI data register, Address offset: 0x28

**5.164.4.169 DR [4/10]**

```
__IO uint16_t I2C_TypeDef::DR
```

I2C Data register, Address offset: 0x10

**5.164.4.170 DR [5/10]**

```
__IO uint32_t RTC_TypeDef::DR
```

RTC date register, Address offset: 0x04

**5.164.4.171 DR [6/10]**

```
__IO uint32_t SAI_Block_TypeDef::DR
```

SAI block x data register, Address offset: 0x20

**5.164.4.172 DR [7/10]**

```
__IO uint16_t SPI_TypeDef::DR
```

SPI data register, Address offset: 0x0C

**5.164.4.173 DR [8/10]**

```
__IO uint16_t USART_TypeDef::DR
```

USART Data register, Address offset: 0x04

**5.164.4.174 DR [9/10]**

```
__IO uint32_t CRYP_TypeDef::DR
```

CRYP data input register, Address offset: 0x08

**5.164.4.175 DR [10/10]**

```
__IO uint32_t RNG_TypeDef::DR
```

RNG data register, Address offset: 0x08

**5.164.4.176 DTIMER**

```
__IO uint32_t SDIO_TypeDef::DTIMER
```

SDIO data timer register, Address offset: 0x24

---

#### 5.164.4.177 EGR

`__IO uint16_t TIM_TypeDef::EGR`

TIM event generation register, Address offset: 0x14

#### 5.164.4.178 EMR

`__IO uint32_t EXTI_TypeDef::EMR`

EXTI Event mask register, Address offset: 0x04

#### 5.164.4.179 ESCR

`__IO uint32_t DCMI_TypeDef::ESCR`

DCMI embedded synchronization code register, Address offset: 0x18

#### 5.164.4.180 ESR

`__IO uint32_t CAN_TypeDef::ESR`

CAN error status register, Address offset: 0x18

#### 5.164.4.181 ESUR

`__IO uint32_t DCMI_TypeDef::ESUR`

DCMI embedded synchronization unmask register, Address offset: 0x1C

#### 5.164.4.182 EXTICR

`__IO uint32_t SYSCFG_TypeDef::EXTICR[4]`

SYSCFG external interrupt configuration registers, Address offset: 0x08-0x14

#### 5.164.4.183 FA1R

`__IO uint32_t CAN_TypeDef::FA1R`

CAN filter activation register, Address offset: 0x21C

**5.164.4.184 FCR**

```
__IO uint32_t DMA_Stream_TypeDef::FCR
```

DMA stream x FIFO control register

**5.164.4.185 FFA1R**

```
__IO uint32_t CAN_TypeDef::FFA1R
```

CAN filter FIFO assignment register, Address offset: 0x214

**5.164.4.186 FGCLUT**

```
__IO uint32_t DMA2D_TypeDef::FGCLUT[256]
```

DMA2D Foreground CLUT, Address offset: 400-7FF

**5.164.4.187 FGCMAR**

```
__IO uint32_t DMA2D_TypeDef::FGCMAR
```

DMA2D Foreground CLUT Memory Address Register, Address offset: 0x2C

**5.164.4.188 FGCOLR**

```
__IO uint32_t DMA2D_TypeDef::FGCOLR
```

DMA2D Foreground Color Register, Address offset: 0x20

**5.164.4.189 FGMAR**

```
__IO uint32_t DMA2D_TypeDef::FGMAR
```

DMA2D Foreground Memory Address Register, Address offset: 0x0C

**5.164.4.190 FGOR**

```
__IO uint32_t DMA2D_TypeDef::FGOR
```

DMA2D Foreground Offset Register, Address offset: 0x10

#### 5.164.4.191 FGPFCCR

```
__IO uint32_t DMA2D_TypeDef::FGPFCCR
```

DMA2D Foreground PFC Control Register, Address offset: 0x1C

#### 5.164.4.192 FIFO

```
__IO uint32_t SDIO_TypeDef::FIFO
```

SDIO data FIFO register, Address offset: 0x80

#### 5.164.4.193 FIFOCNT

```
__I uint32_t SDIO_TypeDef::FIFOCNT
```

SDIO FIFO counter register, Address offset: 0x48

#### 5.164.4.194 FLTR

```
__IO uint16_t I2C_TypeDef::FLTR
```

I2C FLTR register, Address offset: 0x24

#### 5.164.4.195 FM1R

```
__IO uint32_t CAN_TypeDef::FM1R
```

CAN filter mode register, Address offset: 0x204

#### 5.164.4.196 FMR

```
__IO uint32_t CAN_TypeDef::FMR
```

CAN filter master register, Address offset: 0x200

#### 5.164.4.197 FR1

```
__IO uint32_t CAN_FilterRegister_TypeDef::FR1
```

CAN Filter bank register 1

**5.164.4.198 FR2**

```
__IO uint32_t CAN_FilterRegister_TypeDef::FR2
```

CAN Filter bank register 1

**5.164.4.199 FRCR**

```
__IO uint32_t SAI_Block_TypeDef::FRCR
```

SAI block x frame configuration register, Address offset: 0x0C

**5.164.4.200 FS1R**

```
__IO uint32_t CAN_TypeDef::FS1R
```

CAN filter scale register, Address offset: 0x20C

**5.164.4.201 FTSR**

```
__IO uint32_t EXTI_TypeDef::FTSR
```

EXTI Falling trigger selection register, Address offset: 0x0C

**5.164.4.202 GCR [1/2]**

```
__IO uint32_t LTDC_TypeDef::GCR
```

LTDC Global Control Register, Address offset: 0x18

**5.164.4.203 GCR [2/2]**

```
__IO uint32_t SAI_TypeDef::GCR
```

SAI global configuration register, Address offset: 0x00

**5.164.4.204 GTPR**

```
__IO uint16_t USART_TypeDef::GTPR
```

USART Guard time and prescaler register, Address offset: 0x18

#### 5.164.4.205 HIFCR

```
__IO uint32_t DMA_TypeDef::HIFCR
```

DMA high interrupt flag clear register, Address offset: 0x0C

#### 5.164.4.206 HISR

```
__IO uint32_t DMA_TypeDef::HISR
```

DMA high interrupt status register, Address offset: 0x04

#### 5.164.4.207 HR [1/2]

```
__IO uint32_t HASH_TypeDef::HR[5]
```

HASH digest registers, Address offset: 0x0C-0x1C

#### 5.164.4.208 HR [2/2]

```
__IO uint32_t HASH_DIGEST_TypeDef::HR[8]
```

HASH digest registers, Address offset: 0x310-0x32C

#### 5.164.4.209 HTR

```
__IO uint32_t ADC_TypeDef::HTR
```

ADC watchdog higher threshold register, Address offset: 0x24

#### 5.164.4.210 I2SCFGR

```
__IO uint16_t SPI_TypeDef::I2SCFGR
```

SPI\_I2S configuration register, Address offset: 0x1C

#### 5.164.4.211 I2SPR

```
__IO uint16_t SPI_TypeDef::I2SPR
```

SPI\_I2S prescaler register, Address offset: 0x20

**5.164.4.212 ICR [1/3]**

```
__IO uint32_t DCMI_TypeDef::ICR
```

DCMI interrupt clear register, Address offset: 0x14

**5.164.4.213 ICR [2/3]**

```
__IO uint32_t LTDC_TypeDef::ICR
```

LTDC Interrupt Clear Register, Address offset: 0x3C

**5.164.4.214 ICR [3/3]**

```
__IO uint32_t SDIO_TypeDef::ICR
```

SDIO interrupt clear register, Address offset: 0x38

**5.164.4.215 IDCODE**

```
__IO uint32_t DBGMCU_TypeDef::IDCODE
```

MCU device ID code, Address offset: 0x00

**5.164.4.216 IDR [1/2]**

```
__IO uint8_t CRC_TypeDef::IDR
```

CRC Independent data register, Address offset: 0x04

**5.164.4.217 IDR [2/2]**

```
__IO uint32_t GPIO_TypeDef::IDR
```

GPIO port input data register, Address offset: 0x10

**5.164.4.218 IER [1/3]**

```
__IO uint32_t CAN_TypeDef::IER
```

CAN interrupt enable register, Address offset: 0x14

**5.164.4.219 IER [2/3]**

```
__IO uint32_t DCMI_TypeDef::IER
```

DCMI interrupt enable register, Address offset: 0x0C

**5.164.4.220 IER [3/3]**

```
__IO uint32_t LTDC_TypeDef::IER
```

LTDC Interrupt Enable Register, Address offset: 0x34

**5.164.4.221 IFCR**

```
__IO uint32_t DMA2D_TypeDef::IFCR
```

DMA2D Interrupt Flag Clear Register, Address offset: 0x08

**5.164.4.222 IMR [1/3]**

```
__IO uint32_t EXTI_TypeDef::IMR
```

EXTI Interrupt mask register, Address offset: 0x00

**5.164.4.223 IMR [2/3]**

```
__IO uint32_t SAI_Block_TypeDef::IMR
```

SAI block x interrupt mask register, Address offset: 0x14

**5.164.4.224 IMR [3/3]**

```
__IO uint32_t HASH_TypeDef::IMR
```

HASH interrupt enable register, Address offset: 0x20

**5.164.4.225 IMSCR**

```
__IO uint32_t CRYP_TypeDef::IMSCR
```

CRYP interrupt mask set/clear register, Address offset: 0x14

**5.164.4.226 ISR [1/3]**

```
__IO uint32_t DMA2D_TypeDef::ISR
```

DMA2D Interrupt Status Register, Address offset: 0x04

**5.164.4.227 ISR [2/3]**

```
__IO uint32_t LTDC_TypeDef::ISR
```

LTDC Interrupt Status Register, Address offset: 0x38

**5.164.4.228 ISR [3/3]**

```
__IO uint32_t RTC_TypeDef::ISR
```

RTC initialization and status register, Address offset: 0x0C

**5.164.4.229 ITM\_RxBuffer**

```
volatile int32_t ITM_RxBuffer [extern]
```

External variable to receive characters.

**5.164.4.230 IV0LR**

```
__IO uint32_t CRYP_TypeDef::IV0LR
```

CRYP initialization vector left-word register 0, Address offset: 0x40

**5.164.4.231 IV0RR**

```
__IO uint32_t CRYP_TypeDef::IV0RR
```

CRYP initialization vector right-word register 0, Address offset: 0x44

**5.164.4.232 IV1LR**

```
__IO uint32_t CRYP_TypeDef::IV1LR
```

CRYP initialization vector left-word register 1, Address offset: 0x48

#### 5.164.4.233 IV1RR

`__IO uint32_t CRYP_TypeDef::IV1RR`

CRYP initialization vector right-word register 1, Address offset: 0x4C

#### 5.164.4.234 JDR1

`__IO uint32_t ADC_TypeDef::JDR1`

ADC injected data register 1, Address offset: 0x3C

#### 5.164.4.235 JDR2

`__IO uint32_t ADC_TypeDef::JDR2`

ADC injected data register 2, Address offset: 0x40

#### 5.164.4.236 JDR3

`__IO uint32_t ADC_TypeDef::JDR3`

ADC injected data register 3, Address offset: 0x44

#### 5.164.4.237 JDR4

`__IO uint32_t ADC_TypeDef::JDR4`

ADC injected data register 4, Address offset: 0x48

#### 5.164.4.238 JOFR1

`__IO uint32_t ADC_TypeDef::JOFR1`

ADC injected channel data offset register 1, Address offset: 0x14

#### 5.164.4.239 JOFR2

`__IO uint32_t ADC_TypeDef::JOFR2`

ADC injected channel data offset register 2, Address offset: 0x18

#### 5.164.4.240 JOFR3

`__IO uint32_t ADC_TypeDef::JOFR3`

ADC injected channel data offset register 3, Address offset: 0x1C

**5.164.4.241 JOFR4**

```
__IO uint32_t ADC_TypeDef::JOFR4
```

ADC injected channel data offset register 4, Address offset: 0x20

**5.164.4.242 JSQR**

```
__IO uint32_t ADC_TypeDef::JSQR
```

ADC injected sequence register, Address offset: 0x38

**5.164.4.243 K0LR**

```
__IO uint32_t CRYP_TypeDef::K0LR
```

CRYP key left register 0, Address offset: 0x20

**5.164.4.244 K0RR**

```
__IO uint32_t CRYP_TypeDef::K0RR
```

CRYP key right register 0, Address offset: 0x24

**5.164.4.245 K1LR**

```
__IO uint32_t CRYP_TypeDef::K1LR
```

CRYP key left register 1, Address offset: 0x28

**5.164.4.246 K1RR**

```
__IO uint32_t CRYP_TypeDef::K1RR
```

CRYP key right register 1, Address offset: 0x2C

**5.164.4.247 K2LR**

```
__IO uint32_t CRYP_TypeDef::K2LR
```

CRYP key left register 2, Address offset: 0x30

**5.164.4.248 K2RR**

```
__IO uint32_t CRYP_TypeDef::K2RR
```

CRYP key right register 2, Address offset: 0x34

**5.164.4.249 K3LR**

```
__IO uint32_t CRYP_TypeDef::K3LR
```

CRYP key left register 3, Address offset: 0x38

**5.164.4.250 K3RR**

```
__IO uint32_t CRYP_TypeDef::K3RR
```

CRYP key right register 3, Address offset: 0x3C

**5.164.4.251 KEYR**

```
__IO uint32_t FLASH_TypeDef::KEYR
```

FLASH key register, Address offset: 0x04

**5.164.4.252 KR**

```
__IO uint32_t IWDG_TypeDef::KR
```

IWDG Key register, Address offset: 0x00

**5.164.4.253 LCKR**

```
__IO uint32_t GPIO_TypeDef::LCKR
```

GPIO port configuration lock register, Address offset: 0x1C

**5.164.4.254 LIFCR**

```
__IO uint32_t DMA_TypeDef::LIFCR
```

DMA low interrupt flag clear register, Address offset: 0x08

**5.164.4.255 LIPCR**

```
__IO uint32_t LTDC_TypeDef::LIPCR
```

LTDC Line Interrupt Position Configuration Register, Address offset: 0x40

**5.164.4.256 LISR**

```
__IO uint32_t DMA_TypeDef::LISR
```

DMA low interrupt status register, Address offset: 0x00

**5.164.4.257 LTR**

```
__IO uint32_t ADC_TypeDef::LTR
```

ADC watchdog lower threshold register, Address offset: 0x28

**5.164.4.258 LWR**

```
__IO uint32_t DMA2D_TypeDef::LWR
```

DMA2D Line Watermark Register, Address offset: 0x48

**5.164.4.259 M0AR**

```
__IO uint32_t DMA_Stream_TypeDef::M0AR
```

DMA stream x memory 0 address register

**5.164.4.260 M1AR**

```
__IO uint32_t DMA_Stream_TypeDef::M1AR
```

DMA stream x memory 1 address register

**5.164.4.261 MASK**

```
__IO uint32_t SDIO_TypeDef::MASK
```

SDIO mask register, Address offset: 0x3C

**5.164.4.262 MCR**

```
__IO uint32_t CAN_TypeDef::MCR
```

CAN master control register, Address offset: 0x00

#### 5.164.4.263 MEMRMP

`__IO uint32_t SYSCFG_TypeDef::MEMRMP`

SYSCFG memory remap register, Address offset: 0x00

#### 5.164.4.264 MISR [1/2]

`__IO uint32_t DCMI_TypeDef::MISR`

DCMI masked interrupt status register, Address offset: 0x10

#### 5.164.4.265 MISR [2/2]

`__IO uint32_t CRYP_TypeDef::MISR`

CRYP masked interrupt status register, Address offset: 0x1C

#### 5.164.4.266 MODER

`__IO uint32_t GPIO_TypeDef::MODER`

GPIO port mode register, Address offset: 0x00

#### 5.164.4.267 MSR

`__IO uint32_t CAN_TypeDef::MSR`

CAN master status register, Address offset: 0x04

#### 5.164.4.268 NDTR

`__IO uint32_t DMA_Stream_TypeDef::NDTR`

DMA stream x number of data register

#### 5.164.4.269 NLR

`__IO uint32_t DMA2D_TypeDef::NLR`

DMA2D Number of Line Register, Address offset: 0x44

**5.164.4.270 OAR1**

```
__IO uint16_t I2C_TypeDef::OAR1
```

I2C Own address register 1, Address offset: 0x08

**5.164.4.271 OAR2**

```
__IO uint16_t I2C_TypeDef::OAR2
```

I2C Own address register 2, Address offset: 0x0C

**5.164.4.272 OCOLR**

```
__IO uint32_t DMA2D_TypeDef::OCOLR
```

DMA2D Output Color Register, Address offset: 0x38

**5.164.4.273 ODR**

```
__IO uint32_t GPIO_TypeDef::ODR
```

GPIO port output data register, Address offset: 0x14

**5.164.4.274 OMAR**

```
__IO uint32_t DMA2D_TypeDef::OMAR
```

DMA2D Output Memory Address Register, Address offset: 0x3C

**5.164.4.275 OOR**

```
__IO uint32_t DMA2D_TypeDef::OOR
```

DMA2D Output Offset Register, Address offset: 0x40

**5.164.4.276 OPFCCR**

```
__IO uint32_t DMA2D_TypeDef::OPFCCR
```

DMA2D Output PFC Control Register, Address offset: 0x34

**5.164.4.277 OPTCR**

```
__IO uint32_t FLASH_TypeDef::OPTCR
```

FLASH option control register , Address offset: 0x14

**5.164.4.278 OPTCR1**

```
__IO uint32_t FLASH_TypeDef::OPTCR1
```

FLASH option control register 1, Address offset: 0x18

**5.164.4.279 OPTKEYR**

```
__IO uint32_t FLASH_TypeDef::OPTKEYR
```

FLASH option key register, Address offset: 0x08

**5.164.4.280 OR**

```
__IO uint16_t TIM_TypeDef::OR
```

TIM option register, Address offset: 0x50

**5.164.4.281 OSPEEDR**

```
__IO uint32_t GPIO_TypeDef::OSPEEDR
```

GPIO port output speed register, Address offset: 0x08

**5.164.4.282 OTYPER**

```
__IO uint32_t GPIO_TypeDef::OTYPER
```

GPIO port output type register, Address offset: 0x04

**5.164.4.283 PAR**

```
__IO uint32_t DMA_Stream_TypeDef::PAR
```

DMA stream x peripheral address register

**5.164.4.284 PFCR**

```
__IO uint32_t LTDC_Layer_TypeDef::PFCR
```

LTDC Layerx Pixel Format Configuration Register Address offset: 0x94

**5.164.4.285 PLLCFGR**

```
__IO uint32_t RCC_TypeDef::PLLCFGR
```

RCC PLL configuration register, Address offset: 0x04

**5.164.4.286 PLLI2SCFGR**

```
__IO uint32_t RCC_TypeDef::PLLI2SCFGR
```

RCC PLLI2S configuration register, Address offset: 0x84

**5.164.4.287 PLLSAICFGR**

```
__IO uint32_t RCC_TypeDef::PLLSAICFGR
```

RCC PLLSAI configuration register, Address offset: 0x88

**5.164.4.288 PMC**

```
__IO uint32_t SYSCFG_TypeDef::PMC
```

SYSCFG peripheral mode configuration register, Address offset: 0x04

**5.164.4.289 POWER**

```
__IO uint32_t SDIO_TypeDef::POWER
```

SDIO power control register, Address offset: 0x00

**5.164.4.290 PR [1/2]**

```
__IO uint32_t EXTI_TypeDef::PR
```

EXTI Pending register, Address offset: 0x14

**5.164.4.291 PR [2/2]**

```
__IO uint32_t IWDG_TypeDef::PR
```

IWDG Prescaler register, Address offset: 0x04

**5.164.4.292 PRER**

```
__IO uint32_t RTC_TypeDef::PRER
```

RTC prescaler register, Address offset: 0x10

**5.164.4.293 PSC**

```
__IO uint16_t TIM_TypeDef::PSC
```

TIM prescaler, Address offset: 0x28

**5.164.4.294 PUPDR**

```
__IO uint32_t GPIO_TypeDef::PUPDR
```

GPIO port pull-up/pull-down register, Address offset: 0x0C

**5.164.4.295 RCR**

```
__IO uint16_t TIM_TypeDef::RCR
```

TIM repetition counter register, Address offset: 0x30

**5.164.4.296 RDHR**

```
__IO uint32_t CAN_FIFOMailBox_TypeDef::RDHR
```

CAN receive FIFO mailbox data high register

**5.164.4.297 RDLR**

```
__IO uint32_t CAN_FIFOMailBox_TypeDef::RDLR
```

CAN receive FIFO mailbox data low register

**5.164.4.298 RDTR**

```
__IO uint32_t CAN_FIFOMailBox_TypeDef::RDTR
```

CAN receive FIFO mailbox data length control and time stamp register

**5.164.4.299 RESERVED [1/3]**

```
uint32_t DMA2D_TypeDef::RESERVED[236]
```

Reserved, 0x50-0x3FF

**5.164.4.300 RESERVED [2/3]**

```
uint32_t SYSCFG_TypeDef::RESERVED[2]
```

Reserved, 0x18-0x1C

**5.164.4.301 RESERVED [3/3]**

```
uint32_t HASH_TypeDef::RESERVED[52]
```

Reserved, 0x28-0xF4

**5.164.4.302 RESERVED0 [1/10]**

```
uint16_t I2C_TypeDef::RESERVED0
```

Reserved, 0x02

**5.164.4.303 RESERVED0 [2/10]**

```
uint32_t LTDC_TypeDef::RESERVED0[2]
```

Reserved, 0x00-0x04

**5.164.4.304 RESERVED0 [3/10]**

```
uint32_t LTDC_Layer_TypeDef::RESERVED0[2]
```

Reserved

**5.164.4.305 RESERVED0 [4/10]**

```
uint32_t SDIO_TypeDef::RESERVED0[2]
```

Reserved, 0x40-0x44

**5.164.4.306 RESERVED0 [5/10]**

```
uint32_t CAN_TypeDef::RESERVED0[88]
```

Reserved, 0x020 - 0x17F

**5.164.4.307 RESERVED0 [6/10]**

```
uint8_t CRC_TypeDef::RESERVED0
```

Reserved, 0x05

**5.164.4.308 RESERVED0 [7/10]**

```
uint32_t RCC_TypeDef::RESERVED0
```

Reserved, 0x1C

**5.164.4.309 RESERVED0 [8/10]**

```
uint16_t SPI_TypeDef::RESERVED0
```

Reserved, 0x02

**5.164.4.310 RESERVED0 [9/10]**

```
uint16_t TIM_TypeDef::RESERVED0
```

Reserved, 0x02

**5.164.4.311 RESERVED0 [10/10]**

```
uint16_t USART_TypeDef::RESERVED0
```

Reserved, 0x02

**5.164.4.312 RESERVED1 [1/10]**

```
uint32_t CAN_TypeDef::RESERVED1[12]
```

Reserved, 0x1D0 - 0x1FF

**5.164.4.313 RESERVED1 [2/10]**

```
uint16_t CRC_TypeDef::RESERVED1
```

Reserved, 0x06

**5.164.4.314 RESERVED1 [3/10]**

```
uint32_t SDIO_TypeDef::RESERVED1[13]
```

Reserved, 0x4C-0x7C

**5.164.4.315 RESERVED1 [4/10]**

```
uint16_t I2C_TypeDef::RESERVED1
```

Reserved, 0x06

**5.164.4.316 RESERVED1 [5/10]**

```
uint32_t LTDC_TypeDef::RESERVED1[2]
```

Reserved, 0x1C-0x20

**5.164.4.317 RESERVED1 [6/10]**

```
uint32_t RCC_TypeDef::RESERVED1[2]
```

Reserved, 0x28-0x2C

**5.164.4.318 RESERVED1 [7/10]**

```
uint32_t LTDC_Layer_TypeDef::RESERVED1[3]
```

Reserved

**5.164.4.319 RESERVED1 [8/10]**

```
uint16_t SPI_TypeDef::RESERVED1
```

Reserved, 0x06

**5.164.4.320 RESERVED1 [9/10]**

```
uint16_t TIM_TypeDef::RESERVED1
```

Reserved, 0x06

**5.164.4.321 RESERVED1 [10/10]**

```
uint16_t USART_TypeDef::RESERVED1
```

Reserved, 0x06

**5.164.4.322 RESERVED10**

```
uint16_t TIM_TypeDef::RESERVED10
```

Reserved, 0x32

**5.164.4.323 RESERVED11**

```
uint16_t TIM_TypeDef::RESERVED11
```

Reserved, 0x46

**5.164.4.324 RESERVED12**

```
uint16_t TIM_TypeDef::RESERVED12
```

Reserved, 0x4A

**5.164.4.325 RESERVED13**

```
uint16_t TIM_TypeDef::RESERVED13
```

Reserved, 0x4E

**5.164.4.326 RESERVED14**

```
uint16_t TIM_TypeDef::RESERVED14
```

Reserved, 0x52

**5.164.4.327 RESERVED2 [1/7]**

```
uint32_t CAN_TypeDef::RESERVED2
```

Reserved, 0x208

**5.164.4.328 RESERVED2 [2/7]**

```
uint32_t LTDC_TypeDef::RESERVED2[1]
```

Reserved, 0x28

**5.164.4.329 RESERVED2 [3/7]**

```
uint16_t I2C_TypeDef::RESERVED2
```

Reserved, 0x0A

**5.164.4.330 RESERVED2 [4/7]**

```
uint32_t RCC_TypeDef::RESERVED2
```

Reserved, 0x3C

**5.164.4.331 RESERVED2 [5/7]**

```
uint16_t SPI_TypeDef::RESERVED2
```

Reserved, 0x0A

**5.164.4.332 RESERVED2 [6/7]**

```
uint16_t TIM_TypeDef::RESERVED2
```

Reserved, 0x0A

**5.164.4.333 RESERVED2 [7/7]**

```
uint16_t USART_TypeDef::RESERVED2
```

Reserved, 0x0A

**5.164.4.334 RESERVED3 [1/7]**

```
uint32_t CAN_TypeDef::RESERVED3
```

Reserved, 0x210

**5.164.4.335 RESERVED3 [2/7]**

```
uint16_t I2C_TypeDef::RESERVED3
```

Reserved, 0x0E

**5.164.4.336 RESERVED3 [3/7]**

```
uint32_t LTDC_TypeDef::RESERVED3[1]
```

Reserved, 0x30

**5.164.4.337 RESERVED3 [4/7]**

```
uint32_t RCC_TypeDef::RESERVED3[2]
```

Reserved, 0x48-0x4C

**5.164.4.338 RESERVED3 [5/7]**

```
uint16_t SPI_TypeDef::RESERVED3
```

Reserved, 0x0E

**5.164.4.339 RESERVED3 [6/7]**

```
uint16_t TIM_TypeDef::RESERVED3
```

Reserved, 0x0E

**5.164.4.340 RESERVED3 [7/7]**

```
uint16_t USART_TypeDef::RESERVED3
```

Reserved, 0x0E

**5.164.4.341 RESERVED4 [1/6]**

```
uint32_t CAN_TypeDef::RESERVED4
```

Reserved, 0x218

**5.164.4.342 RESERVED4 [2/6]**

```
uint16_t I2C_TypeDef::RESERVED4
```

Reserved, 0x12

**5.164.4.343 RESERVED4 [3/6]**

```
uint32_t RCC_TypeDef::RESERVED4
```

Reserved, 0x5C

**5.164.4.344 RESERVED4 [4/6]**

```
uint16_t SPI_TypeDef::RESERVED4
```

Reserved, 0x12

**5.164.4.345 RESERVED4 [5/6]**

```
uint16_t TIM_TypeDef::RESERVED4
```

Reserved, 0x12

**5.164.4.346 RESERVED4 [6/6]**

```
uint16_t USART_TypeDef::RESERVED4
```

Reserved, 0x12

**5.164.4.347 RESERVED5 [1/6]**

```
uint32_t CAN_TypeDef::RESERVED5[8]
```

Reserved, 0x220-0x23F

**5.164.4.348 RESERVED5 [2/6]**

```
uint16_t I2C_TypeDef::RESERVED5
```

Reserved, 0x16

**5.164.4.349 RESERVED5 [3/6]**

```
uint32_t RCC_TypeDef::RESERVED5[2]
```

Reserved, 0x68-0x6C

**5.164.4.350 RESERVED5 [4/6]**

```
uint16_t SPI_TypeDef::RESERVED5
```

Reserved, 0x16

**5.164.4.351 RESERVED5 [5/6]**

```
uint16_t TIM_TypeDef::RESERVED5
```

Reserved, 0x16

**5.164.4.352 RESERVED5 [6/6]**

```
uint16_t USART_TypeDef::RESERVED5
```

Reserved, 0x16

**5.164.4.353 RESERVED6 [1/5]**

```
uint16_t I2C_TypeDef::RESERVED6
```

Reserved, 0x1A

**5.164.4.354 RESERVED6 [2/5]**

```
uint32_t RCC_TypeDef::RESERVED6[2]
```

Reserved, 0x78-0x7C

**5.164.4.355 RESERVED6 [3/5]**

```
uint16_t SPI_TypeDef::RESERVED6
```

Reserved, 0x1A

**5.164.4.356 RESERVED6 [4/5]**

```
uint16_t TIM_TypeDef::RESERVED6
```

Reserved, 0x1A

**5.164.4.357 RESERVED6 [5/5]**

```
uint16_t USART_TypeDef::RESERVED6
```

Reserved, 0x1A

**5.164.4.358 RESERVED7 [1/4]**

```
uint16_t I2C_TypeDef::RESERVED7
```

Reserved, 0x1E

**5.164.4.359 RESERVED7 [2/4]**

```
uint32_t RTC_TypeDef::RESERVED7
```

Reserved, 0x4C

**5.164.4.360 RESERVED7 [3/4]**

```
uint16_t SPI_TypeDef::RESERVED7
```

Reserved, 0x1E

**5.164.4.361 RESERVED7 [4/4]**

```
uint16_t TIM_TypeDef::RESERVED7
```

Reserved, 0x1E

**5.164.4.362 RESERVED8 [1/3]**

```
uint16_t I2C_TypeDef::RESERVED8
```

Reserved, 0x22

**5.164.4.363 RESERVED8 [2/3]**

```
uint16_t SPI_TypeDef::RESERVED8
```

Reserved, 0x22

**5.164.4.364 RESERVED8 [3/3]**

```
uint16_t TIM_TypeDef::RESERVED8
```

Reserved, 0x22

**5.164.4.365 RESERVED9 [1/2]**

```
uint16_t I2C_TypeDef::RESERVED9
```

Reserved, 0x26

**5.164.4.366 RESERVED9 [2/2]**

```
uint16_t TIM_TypeDef::RESERVED9
```

Reserved, 0x2A

**5.164.4.367 RESP1**

I uint32\_t SDIO\_TypeDef::RESP1

SDIO response 1 register, Address offset: 0x14

**5.164.4.368 RESP2**

```
__I uint32_t SDIO_TypeDef::RESP2
```

SDIO response 2 register, Address offset: 0x18

**5.164.4.369 RESP3**

```
__I uint32_t SDIO_TypeDef::RESP3
```

SDIO response 3 register, Address offset: 0x1C

**5.164.4.370 RESP4**

```
__I uint32_t SDIO_TypeDef::RESP4
```

SDIO response 4 register, Address offset: 0x20

**5.164.4.371 RESPCMD**

```
__I uint32_t SDIO_TypeDef::RESPCMD
```

SDIO command response register, Address offset: 0x10

**5.164.4.372 RF0R**

```
__IO uint32_t CAN_TypeDef::RF0R
```

CAN receive FIFO 0 register, Address offset: 0x0C

**5.164.4.373 RF1R**

```
__IO uint32_t CAN_TypeDef::RF1R
```

CAN receive FIFO 1 register, Address offset: 0x10

**5.164.4.374 RIR**

```
__IO uint32_t CAN_FIFOMailBox_TypeDef::RIR
```

CAN receive FIFO mailbox identifier register

**5.164.4.375 RISR [1/2]**

```
__IO uint32_t DCMI_TypeDef::RISR
```

DCMI raw interrupt status register, Address offset: 0x08

**5.164.4.376 RISR [2/2]**

```
__IO uint32_t CRYP_TypeDef::RISR
```

CRYP raw interrupt status register, Address offset: 0x18

**5.164.4.377 RLR**

```
__IO uint32_t IWDG_TypeDef::RLR
```

IWDG Reload register, Address offset: 0x08

**5.164.4.378 RTSR**

```
__IO uint32_t EXTI_TypeDef::RTSR
```

EXTI Rising trigger selection register, Address offset: 0x08

**5.164.4.379 RXCRCR**

```
__IO uint16_t SPI_TypeDef::RXCRCR
```

SPI RX CRC register (not used in I2S mode), Address offset: 0x14

**5.164.4.380 sFIFOMailBox**

```
CAN_FIFOMailBox_TypeDef CAN_TypeDef::sFIFOMailBox[2]
```

CAN FIFO MailBox, Address offset: 0x1B0 - 0x1CC

**5.164.4.381 sFilterRegister**

```
CAN_FilterRegister_TypeDef CAN_TypeDef::sFilterRegister[28]
```

CAN Filter Register, Address offset: 0x240-0x31C

**5.164.4.382 SHIFTR**

```
__IO uint32_t RTC_TypeDef::SHIFTR
```

RTC shift control register, Address offset: 0x2C

**5.164.4.383 SLOTR**

```
__IO uint32_t SAI_Block_TypeDef::SLOTR
```

SAI block x slot register, Address offset: 0x10

**5.164.4.384 SMCR**

```
__IO uint16_t TIM_TypeDef::SMCR
```

TIM slave mode control register, Address offset: 0x08

**5.164.4.385 SMPR1**

```
__IO uint32_t ADC_TypeDef::SMPR1
```

ADC sample time register 1, Address offset: 0x0C

**5.164.4.386 SMPR2**

```
__IO uint32_t ADC_TypeDef::SMPR2
```

ADC sample time register 2, Address offset: 0x10

**5.164.4.387 SQR1**

```
__IO uint32_t ADC_TypeDef::SQR1
```

ADC regular sequence register 1, Address offset: 0x2C

**5.164.4.388 SQR2**

```
__IO uint32_t ADC_TypeDef::SQR2
```

ADC regular sequence register 2, Address offset: 0x30

**5.164.4.389 SQR3**

```
__IO uint32_t ADC_TypeDef::SQR3
```

ADC regular sequence register 3, Address offset: 0x34

**5.164.4.390 SR [1/13]**

```
__IO uint32_t ADC_TypeDef::SR
```

ADC status register, Address offset: 0x00

**5.164.4.391 SR [2/13]**

```
__IO uint32_t DAC_TypeDef::SR
```

DAC status register, Address offset: 0x34

**5.164.4.392 SR [3/13]**

```
__IO uint32_t DCMI_TypeDef::SR
```

DCMI status register, Address offset: 0x04

**5.164.4.393 SR [4/13]**

```
__IO uint32_t FLASH_TypeDef::SR
```

FLASH status register, Address offset: 0x0C

**5.164.4.394 SR [5/13]**

```
__IO uint32_t IWDG_TypeDef::SR
```

IWDG Status register, Address offset: 0x0C

**5.164.4.395 SR [6/13]**

```
__IO uint32_t SAI_Block_TypeDef::SR
```

SAI block x status register, Address offset: 0x18

**5.164.4.396 SR [7/13]**

```
__IO uint16_t SPI_TypeDef::SR
```

SPI status register, Address offset: 0x08

**5.164.4.397 SR [8/13]**

```
__IO uint16_t TIM_TypeDef::SR
```

TIM status register, Address offset: 0x10

**5.164.4.398 SR [9/13]**

```
__IO uint16_t USART_TypeDef::SR
```

USART Status register, Address offset: 0x00

**5.164.4.399 SR [10/13]**

```
__IO uint32_t WWDG_TypeDef::SR
```

WWDG Status register, Address offset: 0x08

**5.164.4.400 SR [11/13]**

```
__IO uint32_t CRYP_TypeDef::SR
```

CRYP status register, Address offset: 0x04

**5.164.4.401 SR [12/13]**

```
__IO uint32_t HASH_TypeDef::SR
```

HASH status register, Address offset: 0x24

**5.164.4.402 SR [13/13]**

```
__IO uint32_t RNG_TypeDef::SR
```

RNG status register, Address offset: 0x04

**5.164.4.403 SR1**

```
__IO uint16_t I2C_TypeDef::SR1
```

I2C Status register 1, Address offset: 0x14

**5.164.4.404 SR2**

```
__IO uint16_t I2C_TypeDef::SR2
```

I2C Status register 2, Address offset: 0x18

#### 5.164.4.405 SRCR

`__IO uint32_t LTDC_TypeDef::SRCR`

LTDC Shadow Reload Configuration Register, Address offset: 0x24

#### 5.164.4.406 SSCGR

`__IO uint32_t RCC_TypeDef::SSCGR`

RCC spread spectrum clock generation register, Address offset: 0x80

#### 5.164.4.407 SSCR

`__IO uint32_t LTDC_TypeDef::SSCR`

LTDC Synchronization Size Configuration Register, Address offset: 0x08

#### 5.164.4.408 SSR

`__IO uint32_t RTC_TypeDef::SSR`

RTC sub second register, Address offset: 0x28

#### 5.164.4.409 STA

`__I uint32_t SDIO_TypeDef::STA`

SDIO status register, Address offset: 0x34

#### 5.164.4.410 STR

`__IO uint32_t HASH_TypeDef::STR`

HASH start register, Address offset: 0x08

#### 5.164.4.411 sTxMailBox

`CAN_TxMailBox_TypeDef CAN_TypeDef::sTxMailBox[3]`

CAN Tx MailBox, Address offset: 0x180 - 0x1AC

**5.164.4.412 SWIER**

```
__IO uint32_t EXTI_TypeDef::SWIER
```

EXTI Software interrupt event register, Address offset: 0x10

**5.164.4.413 SWTRIGR**

```
__IO uint32_t DAC_TypeDef::SWTRIGR
```

DAC software trigger register, Address offset: 0x04

**5.164.4.414 TAFCR**

```
__IO uint32_t RTC_TypeDef::TAFCR
```

RTC tamper and alternate function configuration register, Address offset: 0x40

**5.164.4.415 TDHR**

```
__IO uint32_t CAN_TxMailBox_TypeDef::TDHR
```

CAN mailbox data high register

**5.164.4.416 TDLR**

```
__IO uint32_t CAN_TxMailBox_TypeDef::TDLR
```

CAN mailbox data low register

**5.164.4.417 TDTR**

```
__IO uint32_t CAN_TxMailBox_TypeDef::TDTR
```

CAN mailbox data length control and time stamp register

**5.164.4.418 TIR**

```
__IO uint32_t CAN_TxMailBox_TypeDef::TIR
```

CAN TX mailbox identifier register

**5.164.4.419 TR**

```
__IO uint32_t RTC_TypeDef::TR
```

RTC time register, Address offset: 0x00

#### 5.164.4.420 TRISE

`__IO uint16_t I2C_TypeDef::TRISE`

I2C TRISE register, Address offset: 0x20

#### 5.164.4.421 TSDR

`__IO uint32_t RTC_TypeDef::TSDR`

RTC time stamp date register, Address offset: 0x34

#### 5.164.4.422 TSR

`__IO uint32_t CAN_TypeDef::TSR`

CAN transmit status register, Address offset: 0x08

#### 5.164.4.423 TSSSR

`__IO uint32_t RTC_TypeDef::TSSSR`

RTC time-stamp sub second register, Address offset: 0x38

#### 5.164.4.424 TSTR

`__IO uint32_t RTC_TypeDef::TSTR`

RTC time stamp time register, Address offset: 0x30

#### 5.164.4.425 TWCR

`__IO uint32_t LTDC_TypeDef::TWCR`

LTDC Total Width Configuration Register, Address offset: 0x14

#### 5.164.4.426 TXCRCR

`__IO uint16_t SPI_TypeDef::TXCRCR`

SPI TX CRC register (not used in I2S mode), Address offset: 0x18

#### 5.164.4.427 WHPCR

```
__IO uint32_t LTDC_Layer_TypeDef::WHPCR
```

LTDC Layerx Window Horizontal Position Configuration Register Address offset: 0x88

#### 5.164.4.428 WPR

```
__IO uint32_t RTC_TypeDef::WPR
```

RTC write protection register, Address offset: 0x24

#### 5.164.4.429 WUTR

```
__IO uint32_t RTC_TypeDef::WUTR
```

RTC wakeup timer register, Address offset: 0x14

#### 5.164.4.430 WVPCR

```
__IO uint32_t LTDC_Layer_TypeDef::WVPCR
```

LTDC Layerx Window Vertical Position Configuration Register Address offset: 0x8C

## 5.165 Stm32f4xx

Collaboration diagram for Stm32f4xx:



## Modules

- [Library\\_configuration\\_section](#)
- [Configuration\\_section\\_for\CMSIS](#)
- [Exported\\_types](#)
- [Peripheral\\_registers\\_structures](#)
- [Peripheral\\_memory\\_map](#)
- [Peripheral\\_declaration](#)
- [Exported\\_constants](#)

### 5.165.1 Detailed Description

## 5.166 Library\_configuration\_section

Collaboration diagram for Library\_configuration\_section:



## Macros

- `#define HSE_VALUE ((uint32_t)25000000)`  
*Comment the line below if you will not use the peripherals drivers. In this case, these drivers will not be included and the application code will be based on direct access to peripherals registers.*
- `#define HSE_STARTUP_TIMEOUT ((uint16_t)0x05000)`  
*In the following line adjust the External High Speed oscillator (HSE) Startup Timeout value.*
- `#define HSI_VALUE ((uint32_t)16000000)`
- `#define __STM32F4XX_STDPERIPH_VERSION_MAIN (0x01)`  
*STM32F4XX Standard Peripherals Library version number V1.8.0.*
- `#define __STM32F4XX_STDPERIPH_VERSION_SUB1 (0x08)`
- `#define __STM32F4XX_STDPERIPH_VERSION_SUB2 (0x00)`
- `#define __STM32F4XX_STDPERIPH_VERSION_RC (0x00)`
- `#define __STM32F4XX_STDPERIPH_VERSION`

### 5.166.1 Detailed Description

### 5.166.2 Macro Definition Documentation

### 5.166.2.1 \_\_STM32F4XX\_STDPERIPH\_VERSION

```
#define __STM32F4XX_STDPERIPH_VERSION
```

**Value:**

```
((__STM32F4XX_STDPERIPH_VERSION_MAIN << 24) \  
| (__STM32F4XX_STDPERIPH_VERSION_SUB1 << 16) \  
| (__STM32F4XX_STDPERIPH_VERSION_SUB2 << 8) \  
| (__STM32F4XX_STDPERIPH_VERSION_RC))
```

### 5.166.2.2 \_\_STM32F4XX\_STDPERIPH\_VERSION\_MAIN

```
#define __STM32F4XX_STDPERIPH_VERSION_MAIN (0x01)
```

STM32F4XX Standard Peripherals Library version number V1.8.0.

[31:24] main version

### 5.166.2.3 \_\_STM32F4XX\_STDPERIPH\_VERSION\_RC

```
#define __STM32F4XX_STDPERIPH_VERSION_RC (0x00)
```

[7:0] release candidate

### 5.166.2.4 \_\_STM32F4XX\_STDPERIPH\_VERSION\_SUB1

```
#define __STM32F4XX_STDPERIPH_VERSION_SUB1 (0x08)
```

[23:16] sub1 version

### 5.166.2.5 \_\_STM32F4XX\_STDPERIPH\_VERSION\_SUB2

```
#define __STM32F4XX_STDPERIPH_VERSION_SUB2 (0x00)
```

[15:8] sub2 version

### 5.166.2.6 HSE\_STARTUP\_TIMEOUT

```
#define HSE_STARTUP_TIMEOUT ((uint16_t)0x05000)
```

In the following line adjust the External High Speed oscillator (HSE) Startup Timeout value.

Time out for HSE start up

### 5.166.2.7 HSE\_VALUE

```
#define HSE_VALUE ((uint32_t)25000000)
```

Comment the line below if you will not use the peripherals drivers. In this case, these drivers will not be included and the application code will be based on direct access to peripherals registers.

In the following line adjust the value of External High Speed oscillator (HSE) used in your application

Tip: To avoid modifying this file each time you need to use different HSE, you can define the HSE value in your toolchain compiler preprocessor. Value of the External oscillator in Hz

### 5.166.2.8 HSI\_VALUE

```
#define HSI_VALUE ((uint32_t)16000000)
```

Value of the Internal oscillator in Hz

## 5.167 Configuration\_section\_for\_CMSIS

Collaboration diagram for Configuration\_section\_for\_CMSIS:



## Macros

- #define \_\_CM4\_REV 0x0001  
*Configuration of the Cortex-M4 Processor and Core Peripherals.*
- #define \_\_MPU\_PRESENT 1
- #define \_\_NVIC\_PRIO\_BITS 4
- #define \_\_Vendor\_SysTickConfig 0
- #define \_\_FPU\_PRESENT 1

## Typedefs

- typedef enum IRQn IRQn\_Type  
*STM32F4XX Interrupt Number Definition, according to the selected device in [Library\\_configuration\\_section](#).*

## Enumerations

- enum IRQn {
 NonMaskableInt\_IRQn = -14 , MemoryManagement\_IRQn = -12 , BusFault\_IRQn = -11 , UsageFault\_IRQn = -10 ,
 SVCall\_IRQn = -5 , DebugMonitor\_IRQn = -4 , PendSV\_IRQn = -2 , SysTick\_IRQn = -1 ,
 WWDG\_IRQn = 0 , PVD\_IRQn = 1 , TAMP\_STAMP\_IRQn = 2 , RTC\_WKUP\_IRQn = 3 ,
 FLASH\_IRQn = 4 , RCC\_IRQn = 5 , EXTI0\_IRQn = 6 , EXTI1\_IRQn = 7 ,
 EXTI2\_IRQn = 8 , EXTI3\_IRQn = 9 , EXTI4\_IRQn = 10 , DMA1\_Stream0\_IRQn = 11 ,
 DMA1\_Stream1\_IRQn = 12 , DMA1\_Stream2\_IRQn = 13 , DMA1\_Stream3\_IRQn = 14 , DMA1\_Stream4\_IRQn = 15 ,
 DMA1\_Stream5\_IRQn = 16 , DMA1\_Stream6\_IRQn = 17 , ADC\_IRQn = 18 , EXTI9\_5\_IRQn = 23 ,
 TIM1\_BRK\_TIM9\_IRQn = 24 , TIM1\_UP\_TIM10\_IRQn = 25 , TIM1\_TRG\_COM\_TIM11\_IRQn = 26 ,
 TIM1\_CC\_IRQn = 27 ,
 TIM2\_IRQn = 28 , TIM3\_IRQn = 29 , TIM4\_IRQn = 30 , I2C1\_EV\_IRQn = 31 ,
 I2C1\_ER\_IRQn = 32 , I2C2\_EV\_IRQn = 33 , I2C2\_ER\_IRQn = 34 , SPI1\_IRQn = 35 ,
 SPI2\_IRQn = 36 , USART1\_IRQn = 37 , USART2\_IRQn = 38 , EXTI15\_10\_IRQn = 40 ,
 RTC\_Alarm\_IRQn = 41 , OTG\_FS\_WKUP\_IRQn = 42 , DMA1\_Stream7\_IRQn = 47 , SDIO\_IRQn = 49 ,
 TIM5\_IRQn = 50 , SPI3\_IRQn = 51 , DMA2\_Stream0\_IRQn = 56 , DMA2\_Stream1\_IRQn = 57 ,
 DMA2\_Stream2\_IRQn = 58 , DMA2\_Stream3\_IRQn = 59 , DMA2\_Stream4\_IRQn = 60 , OTG\_FS\_IRQn = 67 ,
 DMA2\_Stream5\_IRQn = 68 , DMA2\_Stream6\_IRQn = 69 , DMA2\_Stream7\_IRQn = 70 , USART6\_IRQn = 71 ,
 I2C3\_EV\_IRQn = 72 , I2C3\_ER\_IRQn = 73 , FPU\_IRQn = 81 , SPI4\_IRQn = 84 }

*STM32F4XX Interrupt Number Definition, according to the selected device in [Library configuration section](#).*

### 5.167.1 Detailed Description

### 5.167.2 Macro Definition Documentation

#### 5.167.2.1 \_\_CM4\_REV

```
#define __CM4_REV 0x0001
```

Configuration of the Cortex-M4 Processor and Core Peripherals.

Core revision r0p1

#### 5.167.2.2 \_\_FPU\_PRESENT

```
#define __FPU_PRESENT 1
```

FPU present

### 5.167.2.3 \_\_MPU\_PRESENT

```
#define __MPU_PRESENT 1
```

STM32F4XX provides an MPU

### 5.167.2.4 \_\_NVIC\_PRIO\_BITS

```
#define __NVIC_PRIO_BITS 4
```

STM32F4XX uses 4 Bits for the Priority Levels

### 5.167.2.5 \_\_Vendor\_SysTickConfig

```
#define __Vendor_SysTickConfig 0
```

Set to 1 if different SysTick Config is used

## 5.167.3 Enumeration Type Documentation

### 5.167.3.1 IRQn

```
enum IRQn
```

STM32F4XX Interrupt Number Definition, according to the selected device in [Library\\_configuration\\_section](#).

Enumerator

|                       |                                         |
|-----------------------|-----------------------------------------|
| NonMaskableInt_IRQn   | 2 Non Maskable Interrupt                |
| MemoryManagement_IRQn | 4 Cortex-M4 Memory Management Interrupt |
| BusFault_IRQn         | 5 Cortex-M4 Bus Fault Interrupt         |
| UsageFault_IRQn       | 6 Cortex-M4 Usage Fault Interrupt       |
| SVCall_IRQn           | 11 Cortex-M4 SV Call Interrupt          |
| DebugMonitor_IRQn     | 12 Cortex-M4 Debug Monitor Interrupt    |
| PendSV_IRQn           | 14 Cortex-M4 Pend SV Interrupt          |
| SysTick_IRQn          | 15 Cortex-M4 System Tick Interrupt      |
| WWDG_IRQn             | Window WatchDog Interrupt               |

## Enumerator

|                         |                                                                   |
|-------------------------|-------------------------------------------------------------------|
| PVD_IRQn                | PVD through EXTI Line detection Interrupt                         |
| TAMP_STAMP_IRQn         | Tamper andTimeStamp interrupts through the EXTI line              |
| RTC_WKUP_IRQn           | RTC Wakeup interrupt through the EXTI line                        |
| FLASH_IRQn              | FLASH global Interrupt                                            |
| RCC_IRQn                | RCC global Interrupt                                              |
| EXTI0_IRQn              | EXTI Line0 Interrupt                                              |
| EXTI1_IRQn              | EXTI Line1 Interrupt                                              |
| EXTI2_IRQn              | EXTI Line2 Interrupt                                              |
| EXTI3_IRQn              | EXTI Line3 Interrupt                                              |
| EXTI4_IRQn              | EXTI Line4 Interrupt                                              |
| DMA1_Stream0_IRQn       | DMA1 Stream 0 global Interrupt                                    |
| DMA1_Stream1_IRQn       | DMA1 Stream 1 global Interrupt                                    |
| DMA1_Stream2_IRQn       | DMA1 Stream 2 global Interrupt                                    |
| DMA1_Stream3_IRQn       | DMA1 Stream 3 global Interrupt                                    |
| DMA1_Stream4_IRQn       | DMA1 Stream 4 global Interrupt                                    |
| DMA1_Stream5_IRQn       | DMA1 Stream 5 global Interrupt                                    |
| DMA1_Stream6_IRQn       | DMA1 Stream 6 global Interrupt                                    |
| ADC_IRQn                | ADC1, ADC2 and ADC3 global Interrupts                             |
| EXTI9_5_IRQn            | External Line[9:5] Interrupts                                     |
| TIM1_BRK_TIM9_IRQn      | TIM1 Break interrupt and TIM9 global interrupt                    |
| TIM1_UP_TIM10_IRQn      | TIM1 Update Interrupt and TIM10 global interrupt                  |
| TIM1_TRG_COM_TIM11_IRQn | TIM1 Trigger and Commutation Interrupt and TIM11 global interrupt |
| TIM1_CC_IRQn            | TIM1 Capture Compare Interrupt                                    |
| TIM2_IRQn               | TIM2 global Interrupt                                             |
| TIM3_IRQn               | TIM3 global Interrupt                                             |
| TIM4_IRQn               | TIM4 global Interrupt                                             |
| I2C1_EV_IRQn            | I2C1 Event Interrupt                                              |
| I2C1_ER_IRQn            | I2C1 Error Interrupt                                              |

## Enumerator

|                   |                                                 |
|-------------------|-------------------------------------------------|
| I2C2_EV_IRQn      | I2C2 Event Interrupt                            |
| I2C2_ER_IRQn      | I2C2 Error Interrupt                            |
| SPI1_IRQn         | SPI1 global Interrupt                           |
| SPI2_IRQn         | SPI2 global Interrupt                           |
| USART1_IRQn       | USART1 global Interrupt                         |
| USART2_IRQn       | USART2 global Interrupt                         |
| EXTI15_10_IRQn    | External Line[15:10] Interrupts                 |
| RTC_Alarm_IRQn    | RTC Alarm (A and B) through EXTI Line Interrupt |
| OTG_FS_WKUP_IRQn  | USB OTG FS Wakeup through EXTI line interrupt   |
| DMA1_Stream7_IRQn | DMA1 Stream7 Interrupt                          |
| SDIO_IRQn         | SDIO global Interrupt                           |
| TIM5_IRQn         | TIM5 global Interrupt                           |
| SPI3_IRQn         | SPI3 global Interrupt                           |
| DMA2_Stream0_IRQn | DMA2 Stream 0 global Interrupt                  |
| DMA2_Stream1_IRQn | DMA2 Stream 1 global Interrupt                  |
| DMA2_Stream2_IRQn | DMA2 Stream 2 global Interrupt                  |
| DMA2_Stream3_IRQn | DMA2 Stream 3 global Interrupt                  |
| DMA2_Stream4_IRQn | DMA2 Stream 4 global Interrupt                  |
| OTG_FS_IRQn       | USB OTG FS global Interrupt                     |
| DMA2_Stream5_IRQn | DMA2 Stream 5 global interrupt                  |
| DMA2_Stream6_IRQn | DMA2 Stream 6 global interrupt                  |
| DMA2_Stream7_IRQn | DMA2 Stream 7 global interrupt                  |
| USART6_IRQn       | USART6 global interrupt                         |
| I2C3_EV_IRQn      | I2C3 event interrupt                            |
| I2C3_ER_IRQn      | I2C3 error interrupt                            |
| FPU_IRQn          | FPU global interrupt                            |
| SPI4_IRQn         | SPI4 global Interrupt                           |

## 5.168 Exported\_types

Collaboration diagram for Exported\_types:



### Macros

- #define **IS\_FUNCTIONAL\_STATE**(STATE) (((STATE) == **DISABLE**) || ((STATE) == **ENABLE**))

### Typedefs

- typedef int32\_t **s32**
- typedef int16\_t **s16**
- typedef int8\_t **s8**
- typedef const int32\_t **sc32**
- typedef const int16\_t **sc16**
- typedef const int8\_t **sc8**
- typedef **\_IO** int32\_t **vs32**
- typedef **\_IO** int16\_t **vs16**
- typedef **\_IO** int8\_t **vs8**
- typedef **\_I** int32\_t **vsc32**
- typedef **\_I** int16\_t **vsc16**
- typedef **\_I** int8\_t **vsc8**
- typedef uint32\_t **u32**
- typedef uint16\_t **u16**
- typedef uint8\_t **u8**
- typedef const uint32\_t **uc32**
- typedef const uint16\_t **uc16**
- typedef const uint8\_t **uc8**
- typedef **\_IO** uint32\_t **vu32**
- typedef **\_IO** uint16\_t **vu16**
- typedef **\_IO** uint8\_t **vu8**
- typedef **\_I** uint32\_t **vuc32**
- typedef **\_I** uint16\_t **vuc16**
- typedef **\_I** uint8\_t **vuc8**
- typedef enum **FlagStatus** **ITStatus**

### Enumerations

- enum **FlagStatus** { **RESET** = 0 , **SET** = !**RESET** , **Reset** , **Set** }
- enum **FunctionalState** { **DISABLE** = 0 , **ENABLE** = !**DISABLE** }
- enum **ErrorStatus** { **ERROR** = 0 , **SUCCESS** = !**ERROR** }

### 5.168.1 Detailed Description

### 5.168.2 Typedef Documentation

#### 5.168.2.1 `s32`

```
typedef int32_t s32
< STM32F10x Standard Peripheral Library old types (maintained for legacy purpose)
```

#### 5.168.2.2 `sc16`

```
typedef const int16_t sc16
```

Read Only

#### 5.168.2.3 `sc32`

```
typedef const int32_t sc32
Read Only
```

#### 5.168.2.4 `sc8`

```
typedef const int8_t sc8
Read Only
```

#### 5.168.2.5 `uc16`

```
typedef const uint16_t uc16
Read Only
```

#### 5.168.2.6 `uc32`

```
typedef const uint32_t uc32
Read Only
```

**5.168.2.7 uc8**

```
typedef const uint8_t uc8
```

Read Only

**5.168.2.8 vsc16**

```
typedef __I int16_t vsc16
```

Read Only

**5.168.2.9 vsc32**

```
typedef __I int32_t vsc32
```

Read Only

**5.168.2.10 vsc8**

```
typedef __I int8_t vsc8
```

Read Only

**5.168.2.11 vuc16**

```
typedef __I uint16_t vuc16
```

Read Only

**5.168.2.12 vuc32**

```
typedef __I uint32_t vuc32
```

Read Only

**5.168.2.13 vuc8**

```
typedef __I uint8_t vuc8
```

Read Only

**5.168.3 Enumeration Type Documentation****5.168.3.1 FlagStatus**

```
enum FlagStatus
```

## Enumerator

|       |                |
|-------|----------------|
| Reset | Flag is reset. |
| Set   | Flag is set.   |

## 5.169 Peripheral\_registers\_structures

Collaboration diagram for Peripheral\_registers\_structures:



## Classes

- struct [ADC\\_TypeDef](#)  
*Analog to Digital Converter*
- struct [ADC\\_Common\\_TypeDef](#)
- struct [CAN\\_TxMailBox\\_TypeDef](#)  
*Controller Area Network TxMailBox.*
- struct [CAN\\_FIFOMailBox\\_TypeDef](#)  
*Controller Area Network FIFOMailBox.*
- struct [CAN\\_FilterRegister\\_TypeDef](#)  
*Controller Area Network FilterRegister.*
- struct [CAN\\_TypeDef](#)  
*Controller Area Network.*
- struct [CRC\\_TypeDef](#)  
*CRC calculation unit.*
- struct [DAC\\_TypeDef](#)  
*Digital to Analog Converter.*
- struct [DBGMCU\\_TypeDef](#)  
*Debug MCU.*
- struct [DCMI\\_TypeDef](#)

- struct [DMA\\_Stream\\_TypeDef](#)  
*DMA Controller.*
- struct [DMA\\_TypeDef](#)
- struct [DMA2D\\_TypeDef](#)  
*DMA2D Controller.*
- struct [ETH\\_TypeDef](#)  
*Ethernet MAC.*
- struct [EXTI\\_TypeDef](#)  
*External Interrupt/Event Controller.*
- struct [FLASH\\_TypeDef](#)  
*FLASH Registers.*
- struct [GPIO\\_TypeDef](#)  
*General Purpose I/O.*
- struct [SYSCFG\\_TypeDef](#)  
*System configuration controller.*
- struct [I2C\\_TypeDef](#)  
*Inter-integrated Circuit Interface.*
- struct [IWDG\\_TypeDef](#)  
*Independent WATCHDOG.*
- struct [LTDC\\_TypeDef](#)  
*LCD-TFT Display Controller.*
- struct [LTDC\\_Layer\\_TypeDef](#)  
*LCD-TFT Display layer x Controller.*
- struct [PWR\\_TypeDef](#)  
*Power Control.*
- struct [RCC\\_TypeDef](#)  
*Reset and Clock Control.*
- struct [RTC\\_TypeDef](#)  
*Real-Time Clock.*
- struct [SAI\\_TypeDef](#)  
*Serial Audio Interface.*
- struct [SAI\\_Block\\_TypeDef](#)
- struct [SDIO\\_TypeDef](#)  
*SD host Interface.*
- struct [SPI\\_TypeDef](#)  
*Serial Peripheral Interface.*
- struct [TIM\\_TypeDef](#)  
*TIM.*
- struct [USART\\_TypeDef](#)  
*Universal Synchronous Asynchronous Receiver Transmitter.*
- struct [WWDG\\_TypeDef](#)  
*Window WATCHDOG.*
- struct [CRYP\\_TypeDef](#)  
*Crypto Processor.*
- struct [HASH\\_TypeDef](#)  
*HASH.*
- struct [HASH\\_DIGEST\\_TypeDef](#)  
*HASH\_DIGEST.*
- struct [RNG\\_TypeDef](#)  
*RNG.*

### 5.169.1 Detailed Description

## 5.170 Peripheral\_memory\_map

Collaboration diagram for Peripheral\_memory\_map:



### Macros

- #define FLASH\_BASE ((uint32\_t)0x08000000)
- #define CCMDATARAM\_BASE ((uint32\_t)0x10000000)
- #define SRAM1\_BASE ((uint32\_t)0x20000000)
- #define PERIPH\_BASE ((uint32\_t)0x40000000)
- #define BKPSRAM\_BASE ((uint32\_t)0x40024000)
- #define CCMDATARAM\_BB\_BASE ((uint32\_t)0x12000000)
- #define SRAM1\_BB\_BASE ((uint32\_t)0x22000000)
- #define PERIPH\_BB\_BASE ((uint32\_t)0x42000000)
- #define BKPSRAM\_BB\_BASE ((uint32\_t)0x42480000)
- #define SRAM\_BASE SRAM1\_BASE
- #define SRAM\_BB\_BASE SRAM1\_BB\_BASE
- #define APB1PERIPH\_BASE PERIPH\_BASE
- #define APB2PERIPH\_BASE (PERIPH\_BASE + 0x00010000)
- #define AHB1PERIPH\_BASE (PERIPH\_BASE + 0x00020000)
- #define AHB2PERIPH\_BASE (PERIPH\_BASE + 0x10000000)
- #define TIM2\_BASE (APB1PERIPH\_BASE + 0x0000)
- #define TIM3\_BASE (APB1PERIPH\_BASE + 0x0400)
- #define TIM4\_BASE (APB1PERIPH\_BASE + 0x0800)
- #define TIM5\_BASE (APB1PERIPH\_BASE + 0x0C00)
- #define TIM6\_BASE (APB1PERIPH\_BASE + 0x1000)
- #define TIM7\_BASE (APB1PERIPH\_BASE + 0x1400)
- #define TIM12\_BASE (APB1PERIPH\_BASE + 0x1800)
- #define TIM13\_BASE (APB1PERIPH\_BASE + 0x1C00)
- #define TIM14\_BASE (APB1PERIPH\_BASE + 0x2000)
- #define RTC\_BASE (APB1PERIPH\_BASE + 0x2800)
- #define WWDG\_BASE (APB1PERIPH\_BASE + 0x2C00)
- #define IWDG\_BASE (APB1PERIPH\_BASE + 0x3000)
- #define I2S2ext\_BASE (APB1PERIPH\_BASE + 0x3400)
- #define SPI2\_BASE (APB1PERIPH\_BASE + 0x3800)
- #define SPI3\_BASE (APB1PERIPH\_BASE + 0x3C00)
- #define I2S3ext\_BASE (APB1PERIPH\_BASE + 0x4000)
- #define USART2\_BASE (APB1PERIPH\_BASE + 0x4400)
- #define USART3\_BASE (APB1PERIPH\_BASE + 0x4800)
- #define UART4\_BASE (APB1PERIPH\_BASE + 0x4C00)

- #define **UART5\_BASE** (APB1PERIPH\_BASE + 0x5000)
- #define **I2C1\_BASE** (APB1PERIPH\_BASE + 0x5400)
- #define **I2C2\_BASE** (APB1PERIPH\_BASE + 0x5800)
- #define **I2C3\_BASE** (APB1PERIPH\_BASE + 0x5C00)
- #define **CAN1\_BASE** (APB1PERIPH\_BASE + 0x6400)
- #define **CAN2\_BASE** (APB1PERIPH\_BASE + 0x6800)
- #define **PWR\_BASE** (APB1PERIPH\_BASE + 0x7000)
- #define **DAC\_BASE** (APB1PERIPH\_BASE + 0x7400)
- #define **UART7\_BASE** (APB1PERIPH\_BASE + 0x7800)
- #define **UART8\_BASE** (APB1PERIPH\_BASE + 0x7C00)
- #define **TIM1\_BASE** (APB2PERIPH\_BASE + 0x0000)
- #define **TIM8\_BASE** (APB2PERIPH\_BASE + 0x0400)
- #define **USART1\_BASE** (APB2PERIPH\_BASE + 0x1000)
- #define **USART6\_BASE** (APB2PERIPH\_BASE + 0x1400)
- #define **UART9\_BASE** (APB2PERIPH\_BASE + 0x1800U)
- #define **UART10\_BASE** (APB2PERIPH\_BASE + 0x1C00U)
- #define **ADC1\_BASE** (APB2PERIPH\_BASE + 0x2000)
- #define **ADC2\_BASE** (APB2PERIPH\_BASE + 0x2100)
- #define **ADC3\_BASE** (APB2PERIPH\_BASE + 0x2200)
- #define **ADC\_BASE** (APB2PERIPH\_BASE + 0x2300)
- #define **SDIO\_BASE** (APB2PERIPH\_BASE + 0x2C00)
- #define **SPI1\_BASE** (APB2PERIPH\_BASE + 0x3000)
- #define **SPI4\_BASE** (APB2PERIPH\_BASE + 0x3400)
- #define **SYSCFG\_BASE** (APB2PERIPH\_BASE + 0x3800)
- #define **EXTI\_BASE** (APB2PERIPH\_BASE + 0x3C00)
- #define **TIM9\_BASE** (APB2PERIPH\_BASE + 0x4000)
- #define **TIM10\_BASE** (APB2PERIPH\_BASE + 0x4400)
- #define **TIM11\_BASE** (APB2PERIPH\_BASE + 0x4800)
- #define **SPI5\_BASE** (APB2PERIPH\_BASE + 0x5000)
- #define **SPI6\_BASE** (APB2PERIPH\_BASE + 0x5400)
- #define **SAI1\_BASE** (APB2PERIPH\_BASE + 0x5800)
- #define **SAI1\_Block\_A\_BASE** (SAI1\_BASE + 0x004)
- #define **SAI1\_Block\_B\_BASE** (SAI1\_BASE + 0x024)
- #define **LTDC\_BASE** (APB2PERIPH\_BASE + 0x6800)
- #define **LTDC\_Layer1\_BASE** (LTDC\_BASE + 0x84)
- #define **LTDC\_Layer2\_BASE** (LTDC\_BASE + 0x104)
- #define **GPIOA\_BASE** (AHB1PERIPH\_BASE + 0x0000)
- #define **GPIOB\_BASE** (AHB1PERIPH\_BASE + 0x0400)
- #define **GPIOC\_BASE** (AHB1PERIPH\_BASE + 0x0800)
- #define **GPIOD\_BASE** (AHB1PERIPH\_BASE + 0x0C00)
- #define **GPIOE\_BASE** (AHB1PERIPH\_BASE + 0x1000)
- #define **GPIOF\_BASE** (AHB1PERIPH\_BASE + 0x1400)
- #define **GPIOG\_BASE** (AHB1PERIPH\_BASE + 0x1800)
- #define **GPIOH\_BASE** (AHB1PERIPH\_BASE + 0x1C00)
- #define **GPIOI\_BASE** (AHB1PERIPH\_BASE + 0x2000)
- #define **GPIOJ\_BASE** (AHB1PERIPH\_BASE + 0x2400)
- #define **GPIOK\_BASE** (AHB1PERIPH\_BASE + 0x2800)
- #define **CRC\_BASE** (AHB1PERIPH\_BASE + 0x3000)
- #define **RCC\_BASE** (AHB1PERIPH\_BASE + 0x3800)
- #define **FLASH\_R\_BASE** (AHB1PERIPH\_BASE + 0x3C00)
- #define **DMA1\_BASE** (AHB1PERIPH\_BASE + 0x6000)
- #define **DMA1\_Stream0\_BASE** (DMA1\_BASE + 0x010)
- #define **DMA1\_Stream1\_BASE** (DMA1\_BASE + 0x028)
- #define **DMA1\_Stream2\_BASE** (DMA1\_BASE + 0x040)
- #define **DMA1\_Stream3\_BASE** (DMA1\_BASE + 0x058)

- #define **DMA1\_Stream4\_BASE** (DMA1\_BASE + 0x070)
- #define **DMA1\_Stream5\_BASE** (DMA1\_BASE + 0x088)
- #define **DMA1\_Stream6\_BASE** (DMA1\_BASE + 0x0A0)
- #define **DMA1\_Stream7\_BASE** (DMA1\_BASE + 0x0B8)
- #define **DMA2\_BASE** (AHB1PERIPH\_BASE + 0x6400)
- #define **DMA2\_Stream0\_BASE** (DMA2\_BASE + 0x010)
- #define **DMA2\_Stream1\_BASE** (DMA2\_BASE + 0x028)
- #define **DMA2\_Stream2\_BASE** (DMA2\_BASE + 0x040)
- #define **DMA2\_Stream3\_BASE** (DMA2\_BASE + 0x058)
- #define **DMA2\_Stream4\_BASE** (DMA2\_BASE + 0x070)
- #define **DMA2\_Stream5\_BASE** (DMA2\_BASE + 0x088)
- #define **DMA2\_Stream6\_BASE** (DMA2\_BASE + 0x0A0)
- #define **DMA2\_Stream7\_BASE** (DMA2\_BASE + 0x0B8)
- #define **ETH\_BASE** (AHB1PERIPH\_BASE + 0x8000)
- #define **ETH\_MAC\_BASE** (ETH\_BASE)
- #define **ETH MMC\_BASE** (ETH\_BASE + 0x0100)
- #define **ETH\_PTP\_BASE** (ETH\_BASE + 0x0700)
- #define **ETH\_DMA\_BASE** (ETH\_BASE + 0x1000)
- #define **DMA2D\_BASE** (AHB1PERIPH\_BASE + 0xB000)
- #define **DCMI\_BASE** (AHB2PERIPH\_BASE + 0x50000)
- #define **CRYP\_BASE** (AHB2PERIPH\_BASE + 0x60000)
- #define **HASH\_BASE** (AHB2PERIPH\_BASE + 0x60400)
- #define **HASH\_DIGEST\_BASE** (AHB2PERIPH\_BASE + 0x60710)
- #define **RNG\_BASE** (AHB2PERIPH\_BASE + 0x60800)
- #define **DBGMCU\_BASE** ((uint32\_t)0xE0042000)

### 5.170.1 Detailed Description

### 5.170.2 Macro Definition Documentation

#### 5.170.2.1 AHB2PERIPH\_BASE

```
#define AHB2PERIPH_BASE (PERIPH_BASE + 0x10000000)
```

APB1 peripherals

#### 5.170.2.2 BKPSRAM\_BASE

```
#define BKPSRAM_BASE ((uint32_t)0x40024000)
```

Backup SRAM(4 KB) base address in the alias region

#### 5.170.2.3 BKPSRAM\_BB\_BASE

```
#define BKPSRAM_BB_BASE ((uint32_t)0x42480000)
```

Backup SRAM(4 KB) base address in the bit-band region

### 5.170.2.4 CCMDATARAM\_BASE

```
#define CCMDATARAM_BASE ((uint32_t)0x10000000)
```

CCM(core coupled memory) data RAM(64 KB) base address in the alias region

### 5.170.2.5 CCMDATARAM\_BB\_BASE

```
#define CCMDATARAM_BB_BASE ((uint32_t)0x12000000)
```

CCM(core coupled memory) data RAM(64 KB) base address in the bit-band region

### 5.170.2.6 DMA2D\_BASE

```
#define DMA2D_BASE (AHB1PERIPH_BASE + 0xB000)
```

AHB2 peripherals

### 5.170.2.7 FLASH\_BASE

```
#define FLASH_BASE ((uint32_t)0x08000000)
```

FLASH(up to 1 MB) base address in the alias region

### 5.170.2.8 GPIOA\_BASE

```
#define GPIOA_BASE (AHB1PERIPH_BASE + 0x0000)
```

< AHB1 peripherals

### 5.170.2.9 PERIPH\_BASE

```
#define PERIPH_BASE ((uint32_t)0x40000000)
```

Peripheral base address in the alias region

### 5.170.2.10 PERIPH\_BB\_BASE

```
#define PERIPH_BB_BASE ((uint32_t)0x42000000)
```

Peripheral base address in the bit-band region

### 5.170.2.11 SRAM1\_BASE

```
#define SRAM1_BASE ((uint32_t)0x20000000)
```

SRAM1(112 KB) base address in the alias region

### 5.170.2.12 SRAM1\_BB\_BASE

```
#define SRAM1_BB_BASE ((uint32_t)0x22000000)
```

SRAM1(112 KB) base address in the bit-band region

### 5.170.2.13 SRAM\_BB\_BASE

```
#define SRAM_BB_BASE SRAM1_BB_BASE
```

Peripheral memory map

### 5.170.2.14 UART8\_BASE

```
#define UART8_BASE (APB1PERIPH_BASE + 0x7C00)
```

APB2 peripherals

## 5.171 Peripheral\_declaration

Collaboration diagram for Peripheral\_declaration:



## Macros

- #define **TIM2** ((**TIM\_TypeDef** \*) **TIM2\_BASE**)
- #define **TIM3** ((**TIM\_TypeDef** \*) **TIM3\_BASE**)
- #define **TIM4** ((**TIM\_TypeDef** \*) **TIM4\_BASE**)
- #define **TIM5** ((**TIM\_TypeDef** \*) **TIM5\_BASE**)
- #define **TIM6** ((**TIM\_TypeDef** \*) **TIM6\_BASE**)
- #define **TIM7** ((**TIM\_TypeDef** \*) **TIM7\_BASE**)
- #define **TIM12** ((**TIM\_TypeDef** \*) **TIM12\_BASE**)
- #define **TIM13** ((**TIM\_TypeDef** \*) **TIM13\_BASE**)
- #define **TIM14** ((**TIM\_TypeDef** \*) **TIM14\_BASE**)
- #define **RTC** ((**RTC\_TypeDef** \*) **RTC\_BASE**)
- #define **WWDG** ((**WWDG\_TypeDef** \*) **WWDG\_BASE**)
- #define **IWDG** ((**IWDG\_TypeDef** \*) **IWDG\_BASE**)
- #define **I2S2ext** ((**SPI\_TypeDef** \*) **I2S2ext\_BASE**)
- #define **SPI2** ((**SPI\_TypeDef** \*) **SPI2\_BASE**)
- #define **SPI3** ((**SPI\_TypeDef** \*) **SPI3\_BASE**)
- #define **I2S3ext** ((**SPI\_TypeDef** \*) **I2S3ext\_BASE**)
- #define **USART2** ((**USART\_TypeDef** \*) **USART2\_BASE**)
- #define **USART3** ((**USART\_TypeDef** \*) **USART3\_BASE**)
- #define **UART4** ((**USART\_TypeDef** \*) **UART4\_BASE**)
- #define **UART5** ((**USART\_TypeDef** \*) **UART5\_BASE**)
- #define **I2C1** ((**I2C\_TypeDef** \*) **I2C1\_BASE**)
- #define **I2C2** ((**I2C\_TypeDef** \*) **I2C2\_BASE**)
- #define **I2C3** ((**I2C\_TypeDef** \*) **I2C3\_BASE**)
- #define **CAN1** ((**CAN\_TypeDef** \*) **CAN1\_BASE**)
- #define **CAN2** ((**CAN\_TypeDef** \*) **CAN2\_BASE**)
- #define **PWR** ((**PWR\_TypeDef** \*) **PWR\_BASE**)
- #define **DAC** ((**DAC\_TypeDef** \*) **DAC\_BASE**)
- #define **UART7** ((**USART\_TypeDef** \*) **UART7\_BASE**)
- #define **UART8** ((**USART\_TypeDef** \*) **UART8\_BASE**)
- #define **UART9** ((**USART\_TypeDef** \*) **UART9\_BASE**)
- #define **UART10** ((**USART\_TypeDef** \*) **UART10\_BASE**)
- #define **TIM1** ((**TIM\_TypeDef** \*) **TIM1\_BASE**)
- #define **TIM8** ((**TIM\_TypeDef** \*) **TIM8\_BASE**)
- #define **USART1** ((**USART\_TypeDef** \*) **USART1\_BASE**)
- #define **USART6** ((**USART\_TypeDef** \*) **USART6\_BASE**)
- #define **ADC** ((**ADC\_Common\_TypeDef** \*) **ADC\_BASE**)
- #define **ADC1** ((**ADC\_TypeDef** \*) **ADC1\_BASE**)
- #define **ADC2** ((**ADC\_TypeDef** \*) **ADC2\_BASE**)
- #define **ADC3** ((**ADC\_TypeDef** \*) **ADC3\_BASE**)
- #define **SDIO** ((**SDIO\_TypeDef** \*) **SDIO\_BASE**)
- #define **SPI1** ((**SPI\_TypeDef** \*) **SPI1\_BASE**)
- #define **SPI4** ((**SPI\_TypeDef** \*) **SPI4\_BASE**)
- #define **SYSCFG** ((**SYSCFG\_TypeDef** \*) **SYSCFG\_BASE**)
- #define **EXTI** ((**EXTI\_TypeDef** \*) **EXTI\_BASE**)
- #define **TIM9** ((**TIM\_TypeDef** \*) **TIM9\_BASE**)
- #define **TIM10** ((**TIM\_TypeDef** \*) **TIM10\_BASE**)
- #define **TIM11** ((**TIM\_TypeDef** \*) **TIM11\_BASE**)
- #define **SPI5** ((**SPI\_TypeDef** \*) **SPI5\_BASE**)
- #define **SPI6** ((**SPI\_TypeDef** \*) **SPI6\_BASE**)
- #define **SAI1** ((**SAI\_TypeDef** \*) **SAI1\_BASE**)
- #define **SAI1\_Block\_A** ((**SAI\_Block\_TypeDef** \*) **SAI1\_Block\_A\_BASE**)
- #define **SAI1\_Block\_B** ((**SAI\_Block\_TypeDef** \*) **SAI1\_Block\_B\_BASE**)
- #define **LTDC** ((**LTDC\_TypeDef** \*) **LTDC\_BASE**)

- #define **LTDC\_Layer1** ((**LTDC\_Layer\_TypeDef** \*)LTDC\_Layer1\_BASE)
- #define **LTDC\_Layer2** ((**LTDC\_Layer\_TypeDef** \*)LTDC\_Layer2\_BASE)
- #define **GPIOA** ((**GPIO\_TypeDef** \*) GPIOA\_BASE)
- #define **GPIOB** ((**GPIO\_TypeDef** \*) GPIOB\_BASE)
- #define **GPIOC** ((**GPIO\_TypeDef** \*) GPIOC\_BASE)
- #define **GPIOD** ((**GPIO\_TypeDef** \*) GPIOD\_BASE)
- #define **GPIOE** ((**GPIO\_TypeDef** \*) GPIOE\_BASE)
- #define **GPIOF** ((**GPIO\_TypeDef** \*) GPIOF\_BASE)
- #define **GPIOG** ((**GPIO\_TypeDef** \*) GPIOG\_BASE)
- #define **GPIOH** ((**GPIO\_TypeDef** \*) GPIOH\_BASE)
- #define **GPIOI** ((**GPIO\_TypeDef** \*) GPIOI\_BASE)
- #define **GPIOJ** ((**GPIO\_TypeDef** \*) GPIOJ\_BASE)
- #define **GPIOK** ((**GPIO\_TypeDef** \*) GPIOK\_BASE)
- #define **CRC** ((**CRC\_TypeDef** \*) CRC\_BASE)
- #define **RCC** ((**RCC\_TypeDef** \*) RCC\_BASE)
- #define **FLASH** ((**FLASH\_TypeDef** \*) FLASH\_R\_BASE)
- #define **DMA1** ((**DMA\_TypeDef** \*) DMA1\_BASE)
- #define **DMA1\_Stream0** ((**DMA\_Stream\_TypeDef** \*) DMA1\_Stream0\_BASE)
- #define **DMA1\_Stream1** ((**DMA\_Stream\_TypeDef** \*) DMA1\_Stream1\_BASE)
- #define **DMA1\_Stream2** ((**DMA\_Stream\_TypeDef** \*) DMA1\_Stream2\_BASE)
- #define **DMA1\_Stream3** ((**DMA\_Stream\_TypeDef** \*) DMA1\_Stream3\_BASE)
- #define **DMA1\_Stream4** ((**DMA\_Stream\_TypeDef** \*) DMA1\_Stream4\_BASE)
- #define **DMA1\_Stream5** ((**DMA\_Stream\_TypeDef** \*) DMA1\_Stream5\_BASE)
- #define **DMA1\_Stream6** ((**DMA\_Stream\_TypeDef** \*) DMA1\_Stream6\_BASE)
- #define **DMA1\_Stream7** ((**DMA\_Stream\_TypeDef** \*) DMA1\_Stream7\_BASE)
- #define **DMA2** ((**DMA\_TypeDef** \*) DMA2\_BASE)
- #define **DMA2\_Stream0** ((**DMA\_Stream\_TypeDef** \*) DMA2\_Stream0\_BASE)
- #define **DMA2\_Stream1** ((**DMA\_Stream\_TypeDef** \*) DMA2\_Stream1\_BASE)
- #define **DMA2\_Stream2** ((**DMA\_Stream\_TypeDef** \*) DMA2\_Stream2\_BASE)
- #define **DMA2\_Stream3** ((**DMA\_Stream\_TypeDef** \*) DMA2\_Stream3\_BASE)
- #define **DMA2\_Stream4** ((**DMA\_Stream\_TypeDef** \*) DMA2\_Stream4\_BASE)
- #define **DMA2\_Stream5** ((**DMA\_Stream\_TypeDef** \*) DMA2\_Stream5\_BASE)
- #define **DMA2\_Stream6** ((**DMA\_Stream\_TypeDef** \*) DMA2\_Stream6\_BASE)
- #define **DMA2\_Stream7** ((**DMA\_Stream\_TypeDef** \*) DMA2\_Stream7\_BASE)
- #define **ETH** ((**ETH\_TypeDef** \*) ETH\_BASE)
- #define **DMA2D** ((**DMA2D\_TypeDef** \*) DMA2D\_BASE)
- #define **DCMI** ((**DCMI\_TypeDef** \*) DCMI\_BASE)
- #define **CRYP** ((**CRYP\_TypeDef** \*) CRYP\_BASE)
- #define **HASH** ((**HASH\_TypeDef** \*) HASH\_BASE)
- #define **HASH\_DIGEST** ((**HASH\_DIGEST\_TypeDef** \*) HASH\_DIGEST\_BASE)
- #define **RNG** ((**RNG\_TypeDef** \*) RNG\_BASE)
- #define **DBGMCU** ((**DBGMCU\_TypeDef** \*) DBGMCU\_BASE)

### 5.171.1 Detailed Description

## 5.172 Exported\_constants

Collaboration diagram for Exported\_constants:



### Modules

- [Peripheral\\_Registers\\_Bits\\_Definition](#)
- [Exported\\_macro](#)

### 5.172.1 Detailed Description

## 5.173 Peripheral\_Registers\_Bits\_Definition

Collaboration diagram for Peripheral\_Registers\_Bits\_Definition:



### Macros

- [#define ADC\\_SR\\_AWD \(\(uint8\\_t\)0x01\)](#)
- [#define ADC\\_SR\\_EOC \(\(uint8\\_t\)0x02\)](#)
- [#define ADC\\_SR\\_JEOC \(\(uint8\\_t\)0x04\)](#)
- [#define ADC\\_SR\\_JSTRT \(\(uint8\\_t\)0x08\)](#)
- [#define ADC\\_SR\\_STRT \(\(uint8\\_t\)0x10\)](#)
- [#define ADC\\_SR\\_OVR \(\(uint8\\_t\)0x20\)](#)
- [#define ADC\\_CR1\\_AWDCH \(\(uint32\\_t\)0x0000001F\)](#)
- [#define ADC\\_CR1\\_AWDCH\\_0 \(\(uint32\\_t\)0x00000001\)](#)

- #define ADC\_CR1\_AWDCH\_1 ((uint32\_t)0x00000002)
- #define ADC\_CR1\_AWDCH\_2 ((uint32\_t)0x00000004)
- #define ADC\_CR1\_AWDCH\_3 ((uint32\_t)0x00000008)
- #define ADC\_CR1\_AWDCH\_4 ((uint32\_t)0x00000010)
- #define ADC\_CR1\_EOCIE ((uint32\_t)0x00000020)
- #define ADC\_CR1\_AWDIE ((uint32\_t)0x00000040)
- #define ADC\_CR1\_JEOCIE ((uint32\_t)0x00000080)
- #define ADC\_CR1\_SCAN ((uint32\_t)0x00000100)
- #define ADC\_CR1\_AWDSGL ((uint32\_t)0x00000200)
- #define ADC\_CR1\_JAUTO ((uint32\_t)0x00000400)
- #define ADC\_CR1\_DISCEN ((uint32\_t)0x00000800)
- #define ADC\_CR1\_JDISCEN ((uint32\_t)0x00001000)
- #define ADC\_CR1\_DISCNUM ((uint32\_t)0x0000E000)
- #define ADC\_CR1\_DISCNUM\_0 ((uint32\_t)0x00002000)
- #define ADC\_CR1\_DISCNUM\_1 ((uint32\_t)0x00004000)
- #define ADC\_CR1\_DISCNUM\_2 ((uint32\_t)0x00008000)
- #define ADC\_CR1\_JAWDEN ((uint32\_t)0x00400000)
- #define ADC\_CR1\_AWDEN ((uint32\_t)0x00800000)
- #define ADC\_CR1\_RES ((uint32\_t)0x03000000)
- #define ADC\_CR1\_RES\_0 ((uint32\_t)0x01000000)
- #define ADC\_CR1\_RES\_1 ((uint32\_t)0x02000000)
- #define ADC\_CR1\_OVRIE ((uint32\_t)0x04000000)
- #define ADC\_CR2\_ADON ((uint32\_t)0x00000001)
- #define ADC\_CR2\_CONT ((uint32\_t)0x00000002)
- #define ADC\_CR2\_DMA ((uint32\_t)0x00000100)
- #define ADC\_CR2\_DDS ((uint32\_t)0x00000200)
- #define ADC\_CR2\_EOCS ((uint32\_t)0x00000400)
- #define ADC\_CR2\_ALIGN ((uint32\_t)0x00000800)
- #define ADC\_CR2\_JEXTSEL ((uint32\_t)0x000F0000)
- #define ADC\_CR2\_JEXTSEL\_0 ((uint32\_t)0x00010000)
- #define ADC\_CR2\_JEXTSEL\_1 ((uint32\_t)0x00020000)
- #define ADC\_CR2\_JEXTSEL\_2 ((uint32\_t)0x00040000)
- #define ADC\_CR2\_JEXTSEL\_3 ((uint32\_t)0x00080000)
- #define ADC\_CR2\_JEXTEN ((uint32\_t)0x00300000)
- #define ADC\_CR2\_JEXTEN\_0 ((uint32\_t)0x00100000)
- #define ADC\_CR2\_JEXTEN\_1 ((uint32\_t)0x00200000)
- #define ADC\_CR2\_JSWSTART ((uint32\_t)0x00400000)
- #define ADC\_CR2\_EXTSEL ((uint32\_t)0x0F000000)
- #define ADC\_CR2\_EXTSEL\_0 ((uint32\_t)0x01000000)
- #define ADC\_CR2\_EXTSEL\_1 ((uint32\_t)0x02000000)
- #define ADC\_CR2\_EXTSEL\_2 ((uint32\_t)0x04000000)
- #define ADC\_CR2\_EXTSEL\_3 ((uint32\_t)0x08000000)
- #define ADC\_CR2\_EXTN ((uint32\_t)0x30000000)
- #define ADC\_CR2\_EXTN\_0 ((uint32\_t)0x10000000)
- #define ADC\_CR2\_EXTN\_1 ((uint32\_t)0x20000000)
- #define ADC\_CR2\_SWSTART ((uint32\_t)0x40000000)
- #define ADC\_SMPR1\_SMP10 ((uint32\_t)0x00000007)
- #define ADC\_SMPR1\_SMP10\_0 ((uint32\_t)0x00000001)
- #define ADC\_SMPR1\_SMP10\_1 ((uint32\_t)0x00000002)
- #define ADC\_SMPR1\_SMP10\_2 ((uint32\_t)0x00000004)
- #define ADC\_SMPR1\_SMP11 ((uint32\_t)0x00000038)
- #define ADC\_SMPR1\_SMP11\_0 ((uint32\_t)0x00000008)
- #define ADC\_SMPR1\_SMP11\_1 ((uint32\_t)0x00000010)
- #define ADC\_SMPR1\_SMP11\_2 ((uint32\_t)0x00000020)
- #define ADC\_SMPR1\_SMP12 ((uint32\_t)0x000001C0)

- #define ADC\_SMPR1\_SMP12\_0 ((uint32\_t)0x00000040)
- #define ADC\_SMPR1\_SMP12\_1 ((uint32\_t)0x00000080)
- #define ADC\_SMPR1\_SMP12\_2 ((uint32\_t)0x00000100)
- #define ADC\_SMPR1\_SMP13 ((uint32\_t)0x00000E00)
- #define ADC\_SMPR1\_SMP13\_0 ((uint32\_t)0x00000200)
- #define ADC\_SMPR1\_SMP13\_1 ((uint32\_t)0x00000400)
- #define ADC\_SMPR1\_SMP13\_2 ((uint32\_t)0x00000800)
- #define ADC\_SMPR1\_SMP14 ((uint32\_t)0x00007000)
- #define ADC\_SMPR1\_SMP14\_0 ((uint32\_t)0x00001000)
- #define ADC\_SMPR1\_SMP14\_1 ((uint32\_t)0x00002000)
- #define ADC\_SMPR1\_SMP14\_2 ((uint32\_t)0x00004000)
- #define ADC\_SMPR1\_SMP15 ((uint32\_t)0x00038000)
- #define ADC\_SMPR1\_SMP15\_0 ((uint32\_t)0x00008000)
- #define ADC\_SMPR1\_SMP15\_1 ((uint32\_t)0x00010000)
- #define ADC\_SMPR1\_SMP15\_2 ((uint32\_t)0x00020000)
- #define ADC\_SMPR1\_SMP16 ((uint32\_t)0x001C0000)
- #define ADC\_SMPR1\_SMP16\_0 ((uint32\_t)0x00040000)
- #define ADC\_SMPR1\_SMP16\_1 ((uint32\_t)0x00080000)
- #define ADC\_SMPR1\_SMP16\_2 ((uint32\_t)0x00100000)
- #define ADC\_SMPR1\_SMP17 ((uint32\_t)0x00E00000)
- #define ADC\_SMPR1\_SMP17\_0 ((uint32\_t)0x00200000)
- #define ADC\_SMPR1\_SMP17\_1 ((uint32\_t)0x00400000)
- #define ADC\_SMPR1\_SMP17\_2 ((uint32\_t)0x00800000)
- #define ADC\_SMPR1\_SMP18 ((uint32\_t)0x07000000)
- #define ADC\_SMPR1\_SMP18\_0 ((uint32\_t)0x01000000)
- #define ADC\_SMPR1\_SMP18\_1 ((uint32\_t)0x02000000)
- #define ADC\_SMPR1\_SMP18\_2 ((uint32\_t)0x04000000)
- #define ADC\_SMPR2\_SMP0 ((uint32\_t)0x00000007)
- #define ADC\_SMPR2\_SMP0\_0 ((uint32\_t)0x00000001)
- #define ADC\_SMPR2\_SMP0\_1 ((uint32\_t)0x00000002)
- #define ADC\_SMPR2\_SMP0\_2 ((uint32\_t)0x00000004)
- #define ADC\_SMPR2\_SMP1 ((uint32\_t)0x00000038)
- #define ADC\_SMPR2\_SMP1\_0 ((uint32\_t)0x00000008)
- #define ADC\_SMPR2\_SMP1\_1 ((uint32\_t)0x00000010)
- #define ADC\_SMPR2\_SMP1\_2 ((uint32\_t)0x00000020)
- #define ADC\_SMPR2\_SMP2 ((uint32\_t)0x000001C0)
- #define ADC\_SMPR2\_SMP2\_0 ((uint32\_t)0x00000040)
- #define ADC\_SMPR2\_SMP2\_1 ((uint32\_t)0x00000080)
- #define ADC\_SMPR2\_SMP2\_2 ((uint32\_t)0x00000100)
- #define ADC\_SMPR2\_SMP3 ((uint32\_t)0x000000E00)
- #define ADC\_SMPR2\_SMP3\_0 ((uint32\_t)0x00000200)
- #define ADC\_SMPR2\_SMP3\_1 ((uint32\_t)0x00000400)
- #define ADC\_SMPR2\_SMP3\_2 ((uint32\_t)0x00000800)
- #define ADC\_SMPR2\_SMP4 ((uint32\_t)0x00007000)
- #define ADC\_SMPR2\_SMP4\_0 ((uint32\_t)0x00001000)
- #define ADC\_SMPR2\_SMP4\_1 ((uint32\_t)0x00002000)
- #define ADC\_SMPR2\_SMP4\_2 ((uint32\_t)0x00004000)
- #define ADC\_SMPR2\_SMP5 ((uint32\_t)0x00038000)
- #define ADC\_SMPR2\_SMP5\_0 ((uint32\_t)0x00008000)
- #define ADC\_SMPR2\_SMP5\_1 ((uint32\_t)0x00010000)
- #define ADC\_SMPR2\_SMP5\_2 ((uint32\_t)0x00020000)
- #define ADC\_SMPR2\_SMP6 ((uint32\_t)0x001C0000)
- #define ADC\_SMPR2\_SMP6\_0 ((uint32\_t)0x00040000)
- #define ADC\_SMPR2\_SMP6\_1 ((uint32\_t)0x00080000)
- #define ADC\_SMPR2\_SMP6\_2 ((uint32\_t)0x00100000)

```
• #define ADC_SMPR2_SMP7 ((uint32_t)0x00E00000)
• #define ADC_SMPR2_SMP7_0 ((uint32_t)0x00200000)
• #define ADC_SMPR2_SMP7_1 ((uint32_t)0x00400000)
• #define ADC_SMPR2_SMP7_2 ((uint32_t)0x00800000)
• #define ADC_SMPR2_SMP8 ((uint32_t)0x07000000)
• #define ADC_SMPR2_SMP8_0 ((uint32_t)0x01000000)
• #define ADC_SMPR2_SMP8_1 ((uint32_t)0x02000000)
• #define ADC_SMPR2_SMP8_2 ((uint32_t)0x04000000)
• #define ADC_SMPR2_SMP9 ((uint32_t)0x38000000)
• #define ADC_SMPR2_SMP9_0 ((uint32_t)0x08000000)
• #define ADC_SMPR2_SMP9_1 ((uint32_t)0x10000000)
• #define ADC_SMPR2_SMP9_2 ((uint32_t)0x20000000)
• #define ADC_JOFR1_JOFFSET1 ((uint16_t)0xFFFF)
• #define ADC_JOFR2_JOFFSET2 ((uint16_t)0xFFFF)
• #define ADC_JOFR3_JOFFSET3 ((uint16_t)0xFFFF)
• #define ADC_JOFR4_JOFFSET4 ((uint16_t)0xFFFF)
• #define ADC_HTR_HT ((uint16_t)0xFFFF)
• #define ADC_LTR_LT ((uint16_t)0xFFFF)
• #define ADC_SQR1_SQ13 ((uint32_t)0x00000001F)
• #define ADC_SQR1_SQ13_0 ((uint32_t)0x000000001)
• #define ADC_SQR1_SQ13_1 ((uint32_t)0x000000002)
• #define ADC_SQR1_SQ13_2 ((uint32_t)0x000000004)
• #define ADC_SQR1_SQ13_3 ((uint32_t)0x000000008)
• #define ADC_SQR1_SQ13_4 ((uint32_t)0x000000010)
• #define ADC_SQR1_SQ14 ((uint32_t)0x0000003E0)
• #define ADC_SQR1_SQ14_0 ((uint32_t)0x000000020)
• #define ADC_SQR1_SQ14_1 ((uint32_t)0x000000040)
• #define ADC_SQR1_SQ14_2 ((uint32_t)0x000000080)
• #define ADC_SQR1_SQ14_3 ((uint32_t)0x000000100)
• #define ADC_SQR1_SQ14_4 ((uint32_t)0x000000200)
• #define ADC_SQR1_SQ15 ((uint32_t)0x00007C00)
• #define ADC_SQR1_SQ15_0 ((uint32_t)0x00000400)
• #define ADC_SQR1_SQ15_1 ((uint32_t)0x00000800)
• #define ADC_SQR1_SQ15_2 ((uint32_t)0x00001000)
• #define ADC_SQR1_SQ15_3 ((uint32_t)0x00002000)
• #define ADC_SQR1_SQ15_4 ((uint32_t)0x00004000)
• #define ADC_SQR1_SQ16 ((uint32_t)0x000F8000)
• #define ADC_SQR1_SQ16_0 ((uint32_t)0x00008000)
• #define ADC_SQR1_SQ16_1 ((uint32_t)0x00010000)
• #define ADC_SQR1_SQ16_2 ((uint32_t)0x00020000)
• #define ADC_SQR1_SQ16_3 ((uint32_t)0x00040000)
• #define ADC_SQR1_SQ16_4 ((uint32_t)0x00080000)
• #define ADC_SQR1_L ((uint32_t)0x00F00000)
• #define ADC_SQR1_L_0 ((uint32_t)0x00100000)
• #define ADC_SQR1_L_1 ((uint32_t)0x00200000)
• #define ADC_SQR1_L_2 ((uint32_t)0x00400000)
• #define ADC_SQR1_L_3 ((uint32_t)0x00800000)
• #define ADC_SQR2_SQ7 ((uint32_t)0x0000001F)
• #define ADC_SQR2_SQ7_0 ((uint32_t)0x00000001)
• #define ADC_SQR2_SQ7_1 ((uint32_t)0x00000002)
• #define ADC_SQR2_SQ7_2 ((uint32_t)0x00000004)
• #define ADC_SQR2_SQ7_3 ((uint32_t)0x00000008)
• #define ADC_SQR2_SQ7_4 ((uint32_t)0x00000010)
• #define ADC_SQR2_SQ8 ((uint32_t)0x000003E0)
• #define ADC_SQR2_SQ8_0 ((uint32_t)0x00000020)
```

```
• #define ADC_SQR2_SQ8_1 ((uint32_t)0x00000040)
• #define ADC_SQR2_SQ8_2 ((uint32_t)0x00000080)
• #define ADC_SQR2_SQ8_3 ((uint32_t)0x00000100)
• #define ADC_SQR2_SQ8_4 ((uint32_t)0x00000200)
• #define ADC_SQR2_SQ9 ((uint32_t)0x00007C00)
• #define ADC_SQR2_SQ9_0 ((uint32_t)0x00000400)
• #define ADC_SQR2_SQ9_1 ((uint32_t)0x00000800)
• #define ADC_SQR2_SQ9_2 ((uint32_t)0x00001000)
• #define ADC_SQR2_SQ9_3 ((uint32_t)0x00002000)
• #define ADC_SQR2_SQ9_4 ((uint32_t)0x00004000)
• #define ADC_SQR2_SQ10 ((uint32_t)0x000F8000)
• #define ADC_SQR2_SQ10_0 ((uint32_t)0x00008000)
• #define ADC_SQR2_SQ10_1 ((uint32_t)0x00010000)
• #define ADC_SQR2_SQ10_2 ((uint32_t)0x00020000)
• #define ADC_SQR2_SQ10_3 ((uint32_t)0x00040000)
• #define ADC_SQR2_SQ10_4 ((uint32_t)0x00080000)
• #define ADC_SQR2_SQ11 ((uint32_t)0x01F00000)
• #define ADC_SQR2_SQ11_0 ((uint32_t)0x00100000)
• #define ADC_SQR2_SQ11_1 ((uint32_t)0x00200000)
• #define ADC_SQR2_SQ11_2 ((uint32_t)0x00400000)
• #define ADC_SQR2_SQ11_3 ((uint32_t)0x00800000)
• #define ADC_SQR2_SQ11_4 ((uint32_t)0x01000000)
• #define ADC_SQR2_SQ12 ((uint32_t)0x3E000000)
• #define ADC_SQR2_SQ12_0 ((uint32_t)0x02000000)
• #define ADC_SQR2_SQ12_1 ((uint32_t)0x04000000)
• #define ADC_SQR2_SQ12_2 ((uint32_t)0x08000000)
• #define ADC_SQR2_SQ12_3 ((uint32_t)0x10000000)
• #define ADC_SQR2_SQ12_4 ((uint32_t)0x20000000)
• #define ADC_SQR3_SQ1 ((uint32_t)0x0000001F)
• #define ADC_SQR3_SQ1_0 ((uint32_t)0x00000001)
• #define ADC_SQR3_SQ1_1 ((uint32_t)0x00000002)
• #define ADC_SQR3_SQ1_2 ((uint32_t)0x00000004)
• #define ADC_SQR3_SQ1_3 ((uint32_t)0x00000008)
• #define ADC_SQR3_SQ1_4 ((uint32_t)0x00000010)
• #define ADC_SQR3_SQ2 ((uint32_t)0x000003E0)
• #define ADC_SQR3_SQ2_0 ((uint32_t)0x00000020)
• #define ADC_SQR3_SQ2_1 ((uint32_t)0x00000040)
• #define ADC_SQR3_SQ2_2 ((uint32_t)0x00000080)
• #define ADC_SQR3_SQ2_3 ((uint32_t)0x00000100)
• #define ADC_SQR3_SQ2_4 ((uint32_t)0x00000200)
• #define ADC_SQR3_SQ3 ((uint32_t)0x00007C00)
• #define ADC_SQR3_SQ3_0 ((uint32_t)0x00000400)
• #define ADC_SQR3_SQ3_1 ((uint32_t)0x00000800)
• #define ADC_SQR3_SQ3_2 ((uint32_t)0x00001000)
• #define ADC_SQR3_SQ3_3 ((uint32_t)0x00002000)
• #define ADC_SQR3_SQ3_4 ((uint32_t)0x00004000)
• #define ADC_SQR3_SQ4 ((uint32_t)0x000F8000)
• #define ADC_SQR3_SQ4_0 ((uint32_t)0x00008000)
• #define ADC_SQR3_SQ4_1 ((uint32_t)0x00010000)
• #define ADC_SQR3_SQ4_2 ((uint32_t)0x00020000)
• #define ADC_SQR3_SQ4_3 ((uint32_t)0x00040000)
• #define ADC_SQR3_SQ4_4 ((uint32_t)0x00080000)
• #define ADC_SQR3_SQ5 ((uint32_t)0x01F00000)
• #define ADC_SQR3_SQ5_0 ((uint32_t)0x00100000)
• #define ADC_SQR3_SQ5_1 ((uint32_t)0x00200000)
```

- #define ADC\_SQR3\_SQ5\_2 ((uint32\_t)0x00400000)
- #define ADC\_SQR3\_SQ5\_3 ((uint32\_t)0x00800000)
- #define ADC\_SQR3\_SQ5\_4 ((uint32\_t)0x01000000)
- #define ADC\_SQR3\_SQ6 ((uint32\_t)0x3E000000)
- #define ADC\_SQR3\_SQ6\_0 ((uint32\_t)0x02000000)
- #define ADC\_SQR3\_SQ6\_1 ((uint32\_t)0x04000000)
- #define ADC\_SQR3\_SQ6\_2 ((uint32\_t)0x08000000)
- #define ADC\_SQR3\_SQ6\_3 ((uint32\_t)0x10000000)
- #define ADC\_SQR3\_SQ6\_4 ((uint32\_t)0x20000000)
- #define ADC\_JSQR\_JSQ1 ((uint32\_t)0x00000001F)
- #define ADC\_JSQR\_JSQ1\_0 ((uint32\_t)0x00000001)
- #define ADC\_JSQR\_JSQ1\_1 ((uint32\_t)0x00000002)
- #define ADC\_JSQR\_JSQ1\_2 ((uint32\_t)0x00000004)
- #define ADC\_JSQR\_JSQ1\_3 ((uint32\_t)0x00000008)
- #define ADC\_JSQR\_JSQ1\_4 ((uint32\_t)0x00000010)
- #define ADC\_JSQR\_JSQ2 ((uint32\_t)0x0000003E0)
- #define ADC\_JSQR\_JSQ2\_0 ((uint32\_t)0x00000020)
- #define ADC\_JSQR\_JSQ2\_1 ((uint32\_t)0x00000040)
- #define ADC\_JSQR\_JSQ2\_2 ((uint32\_t)0x00000080)
- #define ADC\_JSQR\_JSQ2\_3 ((uint32\_t)0x00000100)
- #define ADC\_JSQR\_JSQ2\_4 ((uint32\_t)0x00000200)
- #define ADC\_JSQR\_JSQ3 ((uint32\_t)0x00007C00)
- #define ADC\_JSQR\_JSQ3\_0 ((uint32\_t)0x00000400)
- #define ADC\_JSQR\_JSQ3\_1 ((uint32\_t)0x00000800)
- #define ADC\_JSQR\_JSQ3\_2 ((uint32\_t)0x00001000)
- #define ADC\_JSQR\_JSQ3\_3 ((uint32\_t)0x00002000)
- #define ADC\_JSQR\_JSQ3\_4 ((uint32\_t)0x00004000)
- #define ADC\_JSQR\_JSQ4 ((uint32\_t)0x000F8000)
- #define ADC\_JSQR\_JSQ4\_0 ((uint32\_t)0x00008000)
- #define ADC\_JSQR\_JSQ4\_1 ((uint32\_t)0x00010000)
- #define ADC\_JSQR\_JSQ4\_2 ((uint32\_t)0x00020000)
- #define ADC\_JSQR\_JSQ4\_3 ((uint32\_t)0x00040000)
- #define ADC\_JSQR\_JSQ4\_4 ((uint32\_t)0x00080000)
- #define ADC\_JSQR\_JL ((uint32\_t)0x00300000)
- #define ADC\_JSQR\_JL\_0 ((uint32\_t)0x00100000)
- #define ADC\_JSQR\_JL\_1 ((uint32\_t)0x00200000)
- #define ADC\_JDR1\_JDATA ((uint16\_t)0xFFFF)
- #define ADC\_JDR2\_JDATA ((uint16\_t)0xFFFF)
- #define ADC\_JDR3\_JDATA ((uint16\_t)0xFFFF)
- #define ADC\_JDR4\_JDATA ((uint16\_t)0xFFFF)
- #define ADC\_DR\_DATA ((uint32\_t)0x0000FFFF)
- #define ADC\_DR\_ADC2DATA ((uint32\_t)0xFFFF0000)
- #define ADC\_CSR\_AWD1 ((uint32\_t)0x00000001)
- #define ADC\_CSR\_EOC1 ((uint32\_t)0x00000002)
- #define ADC\_CSR\_JEOC1 ((uint32\_t)0x00000004)
- #define ADC\_CSR\_JSTRT1 ((uint32\_t)0x00000008)
- #define ADC\_CSR\_STRT1 ((uint32\_t)0x00000010)
- #define ADC\_CSR\_OVR1 ((uint32\_t)0x00000020)
- #define ADC\_CSR\_AWD2 ((uint32\_t)0x00000100)
- #define ADC\_CSR\_EOC2 ((uint32\_t)0x00000200)
- #define ADC\_CSR\_JEOC2 ((uint32\_t)0x00000400)
- #define ADC\_CSR\_JSTRT2 ((uint32\_t)0x00000800)
- #define ADC\_CSR\_STRT2 ((uint32\_t)0x00001000)
- #define ADC\_CSR\_OVR2 ((uint32\_t)0x00002000)
- #define ADC\_CSR\_AWD3 ((uint32\_t)0x00010000)

- #define ADC\_CSR\_EOC3 ((uint32\_t)0x00020000)
- #define ADC\_CSR\_JEOC3 ((uint32\_t)0x00040000)
- #define ADC\_CSR\_JSTRT3 ((uint32\_t)0x00080000)
- #define ADC\_CSR\_STRT3 ((uint32\_t)0x00100000)
- #define ADC\_CSR\_OVR3 ((uint32\_t)0x02000000)
- #define ADC\_CSR\_DOVRI ADC\_CSR\_OVR1
- #define ADC\_CSR\_DOVRS ADC\_CSR\_OVR2
- #define ADC\_CSR\_DOVRC ADC\_CSR\_OVR3
- #define ADC\_CCR\_MULTI ((uint32\_t)0x0000001F)
- #define ADC\_CCR\_MULTI\_0 ((uint32\_t)0x00000001)
- #define ADC\_CCR\_MULTI\_1 ((uint32\_t)0x00000002)
- #define ADC\_CCR\_MULTI\_2 ((uint32\_t)0x00000004)
- #define ADC\_CCR\_MULTI\_3 ((uint32\_t)0x00000008)
- #define ADC\_CCR\_MULTI\_4 ((uint32\_t)0x00000010)
- #define ADC\_CCR\_DELAY ((uint32\_t)0x00000F00)
- #define ADC\_CCR\_DELAY\_0 ((uint32\_t)0x00000100)
- #define ADC\_CCR\_DELAY\_1 ((uint32\_t)0x00000200)
- #define ADC\_CCR\_DELAY\_2 ((uint32\_t)0x00000400)
- #define ADC\_CCR\_DELAY\_3 ((uint32\_t)0x00000800)
- #define ADC\_CCR\_DDS ((uint32\_t)0x00002000)
- #define ADC\_CCR\_DMA ((uint32\_t)0x0000C000)
- #define ADC\_CCR\_DMA\_0 ((uint32\_t)0x00004000)
- #define ADC\_CCR\_DMA\_1 ((uint32\_t)0x00008000)
- #define ADC\_CCR\_ADCPRE ((uint32\_t)0x00030000)
- #define ADC\_CCR\_ADCPRE\_0 ((uint32\_t)0x00010000)
- #define ADC\_CCR\_ADCPRE\_1 ((uint32\_t)0x00020000)
- #define ADC\_CCR\_VBATE ((uint32\_t)0x00400000)
- #define ADC\_CCR\_TSVREFE ((uint32\_t)0x00800000)
- #define ADC\_CDR\_DATA1 ((uint32\_t)0x0000FFFF)
- #define ADC\_CDR\_DATA2 ((uint32\_t)0xFFFF0000)
- #define CAN\_MCR\_INRQ ((uint16\_t)0x0001)
- #define CAN\_MCR\_SLEEP ((uint16\_t)0x0002)
- #define CAN\_MCR\_TXFP ((uint16\_t)0x0004)
- #define CAN\_MCR\_RFLM ((uint16\_t)0x0008)
- #define CAN\_MCR\_NART ((uint16\_t)0x0010)
- #define CAN\_MCR\_AWUM ((uint16\_t)0x0020)
- #define CAN\_MCR\_ABOM ((uint16\_t)0x0040)
- #define CAN\_MCR\_TTCM ((uint16\_t)0x0080)
- #define CAN\_MCR\_RESET ((uint16\_t)0x8000)
- #define CAN\_MSR\_INAK ((uint16\_t)0x0001)
- #define CAN\_MSR\_SLAK ((uint16\_t)0x0002)
- #define CAN\_MSR\_ERRI ((uint16\_t)0x0004)
- #define CAN\_MSR\_WKUI ((uint16\_t)0x0008)
- #define CAN\_MSR\_SLAKI ((uint16\_t)0x0010)
- #define CAN\_MSR\_TXM ((uint16\_t)0x0100)
- #define CAN\_MSR\_RXM ((uint16\_t)0x0200)
- #define CAN\_MSR\_SAMP ((uint16\_t)0x0400)
- #define CAN\_MSR\_RX ((uint16\_t)0x0800)
- #define CAN\_TSR\_RQCP0 ((uint32\_t)0x00000001)
- #define CAN\_TSR\_TXOK0 ((uint32\_t)0x00000002)
- #define CAN\_TSR\_ALST0 ((uint32\_t)0x00000004)
- #define CAN\_TSR\_TERR0 ((uint32\_t)0x00000008)
- #define CAN\_TSR\_ABRQ0 ((uint32\_t)0x00000080)
- #define CAN\_TSR\_RQCP1 ((uint32\_t)0x00000100)
- #define CAN\_TSR\_TXOK1 ((uint32\_t)0x00000200)

- #define CAN\_TSR\_ALST1 ((uint32\_t)0x00000400)
- #define CAN\_TSR\_TERR1 ((uint32\_t)0x00000800)
- #define CAN\_TSR\_ABRQ1 ((uint32\_t)0x00008000)
- #define CAN\_TSR\_RQCP2 ((uint32\_t)0x00010000)
- #define CAN\_TSR\_TXOK2 ((uint32\_t)0x00020000)
- #define CAN\_TSR\_ALST2 ((uint32\_t)0x00040000)
- #define CAN\_TSR\_TERR2 ((uint32\_t)0x00080000)
- #define CAN\_TSR\_ABRQ2 ((uint32\_t)0x00800000)
- #define CAN\_TSR\_CODE ((uint32\_t)0x03000000)
- #define CAN\_TSR\_TME ((uint32\_t)0x1C000000)
- #define CAN\_TSR\_TME0 ((uint32\_t)0x04000000)
- #define CAN\_TSR\_TME1 ((uint32\_t)0x08000000)
- #define CAN\_TSR\_TME2 ((uint32\_t)0x10000000)
- #define CAN\_TSR\_LOW ((uint32\_t)0xE0000000)
- #define CAN\_TSR\_LOW0 ((uint32\_t)0x20000000)
- #define CAN\_TSR\_LOW1 ((uint32\_t)0x40000000)
- #define CAN\_TSR\_LOW2 ((uint32\_t)0x80000000)
- #define CAN\_RF0R\_FMP0 ((uint8\_t)0x03)
- #define CAN\_RF0R\_FULL0 ((uint8\_t)0x08)
- #define CAN\_RF0R\_FOVR0 ((uint8\_t)0x10)
- #define CAN\_RF0R\_RFOM0 ((uint8\_t)0x20)
- #define CAN\_RF1R\_FMP1 ((uint8\_t)0x03)
- #define CAN\_RF1R\_FULL1 ((uint8\_t)0x08)
- #define CAN\_RF1R\_FOVR1 ((uint8\_t)0x10)
- #define CAN\_RF1R\_RFOM1 ((uint8\_t)0x20)
- #define CAN\_IER\_TMEIE ((uint32\_t)0x00000001)
- #define CAN\_IER\_FMPIE0 ((uint32\_t)0x00000002)
- #define CAN\_IER\_FFIE0 ((uint32\_t)0x00000004)
- #define CAN\_IER\_FOVIE0 ((uint32\_t)0x00000008)
- #define CAN\_IER\_FMPIE1 ((uint32\_t)0x00000010)
- #define CAN\_IER\_FFIE1 ((uint32\_t)0x00000020)
- #define CAN\_IER\_FOVIE1 ((uint32\_t)0x00000040)
- #define CAN\_IER\_EWGIE ((uint32\_t)0x00000100)
- #define CAN\_IER\_EPVIE ((uint32\_t)0x00000200)
- #define CAN\_IER\_BOFIE ((uint32\_t)0x00000400)
- #define CAN\_IER\_LECIE ((uint32\_t)0x00000800)
- #define CAN\_IER\_ERRIE ((uint32\_t)0x00008000)
- #define CAN\_IER\_WKUIE ((uint32\_t)0x00010000)
- #define CAN\_IER\_SLKIE ((uint32\_t)0x00020000)
- #define CAN\_ESR\_EWGF ((uint32\_t)0x00000001)
- #define CAN\_ESR\_EPVF ((uint32\_t)0x00000002)
- #define CAN\_ESR\_BOFF ((uint32\_t)0x00000004)
- #define CAN\_ESR\_LEC ((uint32\_t)0x00000070)
- #define CAN\_ESR\_LEC\_0 ((uint32\_t)0x00000010)
- #define CAN\_ESR\_LEC\_1 ((uint32\_t)0x00000020)
- #define CAN\_ESR\_LEC\_2 ((uint32\_t)0x00000040)
- #define CAN\_ESR\_TEC ((uint32\_t)0x00FF0000)
- #define CAN\_ESR\_REC ((uint32\_t)0xFF000000)
- #define CAN\_BTR\_BRP ((uint32\_t)0x000003FF)
- #define CAN\_BTR\_TS1 ((uint32\_t)0x000F0000)
- #define CAN\_BTR\_TS2 ((uint32\_t)0x00700000)
- #define CAN\_BTR\_SJW ((uint32\_t)0x03000000)
- #define CAN\_BTR\_LBKM ((uint32\_t)0x40000000)
- #define CAN\_BTR\_SILM ((uint32\_t)0x80000000)
- #define CAN\_TI0R\_TXRQ ((uint32\_t)0x00000001)

```
• #define CAN_TI0R_RTR ((uint32_t)0x00000002)
• #define CAN_TI0R_IDE ((uint32_t)0x00000004)
• #define CAN_TI0R_EXID ((uint32_t)0x001FFFF8)
• #define CAN_TI0R_STID ((uint32_t)0xFFE00000)
• #define CAN_TDT0R_DLC ((uint32_t)0x0000000F)
• #define CAN_TDT0R_TGT ((uint32_t)0x00000100)
• #define CAN_TDT0R_TIME ((uint32_t)0xFFFF0000)
• #define CAN_TDL0R_DATA0 ((uint32_t)0x000000FF)
• #define CAN_TDL0R_DATA1 ((uint32_t)0x0000FF00)
• #define CAN_TDL0R_DATA2 ((uint32_t)0x00FF0000)
• #define CAN_TDL0R_DATA3 ((uint32_t)0xFF000000)
• #define CAN_TDH0R_DATA4 ((uint32_t)0x000000FF)
• #define CAN_TDH0R_DATA5 ((uint32_t)0x0000FF00)
• #define CAN_TDH0R_DATA6 ((uint32_t)0x00FF0000)
• #define CAN_TDH0R_DATA7 ((uint32_t)0xFF000000)
• #define CAN_TI1R_TXRQ ((uint32_t)0x00000001)
• #define CAN_TI1R_RTR ((uint32_t)0x00000002)
• #define CAN_TI1R_IDE ((uint32_t)0x00000004)
• #define CAN_TI1R_EXID ((uint32_t)0x001FFFF8)
• #define CAN_TI1R_STID ((uint32_t)0xFFE00000)
• #define CAN_TDT1R_DLC ((uint32_t)0x0000000F)
• #define CAN_TDT1R_TGT ((uint32_t)0x00000100)
• #define CAN_TDT1R_TIME ((uint32_t)0xFFFF0000)
• #define CAN_TDL1R_DATA0 ((uint32_t)0x000000FF)
• #define CAN_TDL1R_DATA1 ((uint32_t)0x0000FF00)
• #define CAN_TDL1R_DATA2 ((uint32_t)0x00FF0000)
• #define CAN_TDL1R_DATA3 ((uint32_t)0xFF000000)
• #define CAN_TDH1R_DATA4 ((uint32_t)0x000000FF)
• #define CAN_TDH1R_DATA5 ((uint32_t)0x0000FF00)
• #define CAN_TDH1R_DATA6 ((uint32_t)0x00FF0000)
• #define CAN_TDH1R_DATA7 ((uint32_t)0xFF000000)
• #define CAN_TI2R_TXRQ ((uint32_t)0x00000001)
• #define CAN_TI2R_RTR ((uint32_t)0x00000002)
• #define CAN_TI2R_IDE ((uint32_t)0x00000004)
• #define CAN_TI2R_EXID ((uint32_t)0x001FFFF8)
• #define CAN_TI2R_STID ((uint32_t)0xFFE00000)
• #define CAN_TDT2R_DLC ((uint32_t)0x0000000F)
• #define CAN_TDT2R_TGT ((uint32_t)0x00000100)
• #define CAN_TDT2R_TIME ((uint32_t)0xFFFF0000)
• #define CAN_TDL2R_DATA0 ((uint32_t)0x000000FF)
• #define CAN_TDL2R_DATA1 ((uint32_t)0x0000FF00)
• #define CAN_TDL2R_DATA2 ((uint32_t)0x00FF0000)
• #define CAN_TDL2R_DATA3 ((uint32_t)0xFF000000)
• #define CAN_TDH2R_DATA4 ((uint32_t)0x000000FF)
• #define CAN_TDH2R_DATA5 ((uint32_t)0x0000FF00)
• #define CAN_TDH2R_DATA6 ((uint32_t)0x00FF0000)
• #define CAN_TDH2R_DATA7 ((uint32_t)0xFF000000)
• #define CAN_RI0R_RTR ((uint32_t)0x00000002)
• #define CAN_RI0R_IDE ((uint32_t)0x00000004)
• #define CAN_RI0R_EXID ((uint32_t)0x001FFFF8)
• #define CAN_RI0R_STID ((uint32_t)0xFFE00000)
• #define CAN_RDT0R_DLC ((uint32_t)0x0000000F)
• #define CAN_RDT0R_FMI ((uint32_t)0x0000FF00)
• #define CAN_RDT0R_TIME ((uint32_t)0xFFFF0000)
• #define CAN_RDL0R_DATA0 ((uint32_t)0x000000FF)
```

- #define CAN\_RDL0R\_DATA1 ((uint32\_t)0x0000FF00)
- #define CAN\_RDL0R\_DATA2 ((uint32\_t)0x00FF0000)
- #define CAN\_RDL0R\_DATA3 ((uint32\_t)0xFF000000)
- #define CAN\_RDH0R\_DATA4 ((uint32\_t)0x000000FF)
- #define CAN\_RDH0R\_DATA5 ((uint32\_t)0x0000FF00)
- #define CAN\_RDH0R\_DATA6 ((uint32\_t)0x00FF0000)
- #define CAN\_RDH0R\_DATA7 ((uint32\_t)0xFF000000)
- #define CAN\_RI1R\_RTR ((uint32\_t)0x00000002)
- #define CAN\_RI1R\_IDE ((uint32\_t)0x00000004)
- #define CAN\_RI1R\_EXID ((uint32\_t)0x001FFFF8)
- #define CAN\_RI1R\_STID ((uint32\_t)0xFFE00000)
- #define CAN\_RDT1R\_DLC ((uint32\_t)0x0000000F)
- #define CAN\_RDT1R\_FMI ((uint32\_t)0x0000FF00)
- #define CAN\_RDT1R\_TIME ((uint32\_t)0xFFFF0000)
- #define CAN\_RDL1R\_DATA0 ((uint32\_t)0x000000FF)
- #define CAN\_RDL1R\_DATA1 ((uint32\_t)0x0000FF00)
- #define CAN\_RDL1R\_DATA2 ((uint32\_t)0x00FF0000)
- #define CAN\_RDL1R\_DATA3 ((uint32\_t)0xFF000000)
- #define CAN\_RDH1R\_DATA4 ((uint32\_t)0x000000FF)
- #define CAN\_RDH1R\_DATA5 ((uint32\_t)0x0000FF00)
- #define CAN\_RDH1R\_DATA6 ((uint32\_t)0x00FF0000)
- #define CAN\_RDH1R\_DATA7 ((uint32\_t)0xFF000000)
- #define CAN\_FMR\_INIT ((uint8\_t)0x01)
- #define CAN\_FM1R\_FBM ((uint16\_t)0x3FFF)
- #define CAN\_FM1R\_FBM0 ((uint16\_t)0x0001)
- #define CAN\_FM1R\_FBM1 ((uint16\_t)0x0002)
- #define CAN\_FM1R\_FBM2 ((uint16\_t)0x0004)
- #define CAN\_FM1R\_FBM3 ((uint16\_t)0x0008)
- #define CAN\_FM1R\_FBM4 ((uint16\_t)0x0010)
- #define CAN\_FM1R\_FBM5 ((uint16\_t)0x0020)
- #define CAN\_FM1R\_FBM6 ((uint16\_t)0x0040)
- #define CAN\_FM1R\_FBM7 ((uint16\_t)0x0080)
- #define CAN\_FM1R\_FBM8 ((uint16\_t)0x0100)
- #define CAN\_FM1R\_FBM9 ((uint16\_t)0x0200)
- #define CAN\_FM1R\_FBM10 ((uint16\_t)0x0400)
- #define CAN\_FM1R\_FBM11 ((uint16\_t)0x0800)
- #define CAN\_FM1R\_FBM12 ((uint16\_t)0x1000)
- #define CAN\_FM1R\_FBM13 ((uint16\_t)0x2000)
- #define CAN\_FS1R\_FSC ((uint16\_t)0x3FFF)
- #define CAN\_FS1R\_FSC0 ((uint16\_t)0x0001)
- #define CAN\_FS1R\_FSC1 ((uint16\_t)0x0002)
- #define CAN\_FS1R\_FSC2 ((uint16\_t)0x0004)
- #define CAN\_FS1R\_FSC3 ((uint16\_t)0x0008)
- #define CAN\_FS1R\_FSC4 ((uint16\_t)0x0010)
- #define CAN\_FS1R\_FSC5 ((uint16\_t)0x0020)
- #define CAN\_FS1R\_FSC6 ((uint16\_t)0x0040)
- #define CAN\_FS1R\_FSC7 ((uint16\_t)0x0080)
- #define CAN\_FS1R\_FSC8 ((uint16\_t)0x0100)
- #define CAN\_FS1R\_FSC9 ((uint16\_t)0x0200)
- #define CAN\_FS1R\_FSC10 ((uint16\_t)0x0400)
- #define CAN\_FS1R\_FSC11 ((uint16\_t)0x0800)
- #define CAN\_FS1R\_FSC12 ((uint16\_t)0x1000)
- #define CAN\_FS1R\_FSC13 ((uint16\_t)0x2000)
- #define CAN\_FFA1R\_FFA ((uint16\_t)0x3FFF)
- #define CAN\_FFA1R\_FFA0 ((uint16\_t)0x0001)

- #define CAN\_FFA1R\_FFA1 ((uint16\_t)0x0002)
- #define CAN\_FFA1R\_FFA2 ((uint16\_t)0x0004)
- #define CAN\_FFA1R\_FFA3 ((uint16\_t)0x0008)
- #define CAN\_FFA1R\_FFA4 ((uint16\_t)0x0010)
- #define CAN\_FFA1R\_FFA5 ((uint16\_t)0x0020)
- #define CAN\_FFA1R\_FFA6 ((uint16\_t)0x0040)
- #define CAN\_FFA1R\_FFA7 ((uint16\_t)0x0080)
- #define CAN\_FFA1R\_FFA8 ((uint16\_t)0x0100)
- #define CAN\_FFA1R\_FFA9 ((uint16\_t)0x0200)
- #define CAN\_FFA1R\_FFA10 ((uint16\_t)0x0400)
- #define CAN\_FFA1R\_FFA11 ((uint16\_t)0x0800)
- #define CAN\_FFA1R\_FFA12 ((uint16\_t)0x1000)
- #define CAN\_FFA1R\_FFA13 ((uint16\_t)0x2000)
- #define CAN\_FA1R\_FACT ((uint16\_t)0x3FFF)
- #define CAN\_FA1R\_FACT0 ((uint16\_t)0x0001)
- #define CAN\_FA1R\_FACT1 ((uint16\_t)0x0002)
- #define CAN\_FA1R\_FACT2 ((uint16\_t)0x0004)
- #define CAN\_FA1R\_FACT3 ((uint16\_t)0x0008)
- #define CAN\_FA1R\_FACT4 ((uint16\_t)0x0010)
- #define CAN\_FA1R\_FACT5 ((uint16\_t)0x0020)
- #define CAN\_FA1R\_FACT6 ((uint16\_t)0x0040)
- #define CAN\_FA1R\_FACT7 ((uint16\_t)0x0080)
- #define CAN\_FA1R\_FACT8 ((uint16\_t)0x0100)
- #define CAN\_FA1R\_FACT9 ((uint16\_t)0x0200)
- #define CAN\_FA1R\_FACT10 ((uint16\_t)0x0400)
- #define CAN\_FA1R\_FACT11 ((uint16\_t)0x0800)
- #define CAN\_FA1R\_FACT12 ((uint16\_t)0x1000)
- #define CAN\_FA1R\_FACT13 ((uint16\_t)0x2000)
- #define CAN\_F0R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F0R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F0R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F0R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F0R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F0R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F0R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F0R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F0R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F0R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F0R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F0R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F0R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F0R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F0R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F0R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F0R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F0R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F0R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F0R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F0R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F0R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F0R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F0R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F0R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F0R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F0R1\_FB26 ((uint32\_t)0x04000000)

- #define CAN\_F0R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F0R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F0R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F0R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F0R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F1R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F1R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F1R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F1R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F1R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F1R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F1R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F1R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F1R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F1R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F1R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F1R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F1R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F1R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F1R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F1R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F1R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F1R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F1R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F1R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F1R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F1R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F1R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F1R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F1R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F1R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F1R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F1R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F1R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F1R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F1R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F1R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F2R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F2R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F2R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F2R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F2R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F2R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F2R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F2R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F2R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F2R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F2R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F2R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F2R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F2R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F2R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F2R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F2R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F2R1\_FB17 ((uint32\_t)0x00020000)

- #define CAN\_F2R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F2R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F2R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F2R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F2R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F2R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F2R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F2R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F2R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F2R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F2R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F2R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F2R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F2R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F3R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F3R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F3R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F3R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F3R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F3R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F3R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F3R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F3R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F3R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F3R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F3R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F3R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F3R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F3R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F3R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F3R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F3R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F3R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F3R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F3R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F3R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F3R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F3R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F3R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F3R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F3R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F3R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F3R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F3R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F3R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F3R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F4R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F4R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F4R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F4R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F4R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F4R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F4R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F4R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F4R1\_FB8 ((uint32\_t)0x00000100)

- #define CAN\_F4R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F4R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F4R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F4R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F4R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F4R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F4R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F4R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F4R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F4R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F4R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F4R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F4R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F4R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F4R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F4R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F4R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F4R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F4R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F4R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F4R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F4R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F4R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F5R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F5R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F5R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F5R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F5R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F5R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F5R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F5R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F5R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F5R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F5R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F5R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F5R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F5R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F5R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F5R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F5R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F5R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F5R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F5R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F5R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F5R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F5R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F5R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F5R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F5R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F5R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F5R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F5R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F5R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F5R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F5R1\_FB31 ((uint32\_t)0x80000000)

- #define CAN\_F6R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F6R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F6R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F6R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F6R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F6R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F6R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F6R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F6R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F6R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F6R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F6R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F6R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F6R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F6R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F6R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F6R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F6R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F6R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F6R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F6R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F6R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F6R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F6R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F6R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F6R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F6R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F6R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F6R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F6R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F6R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F6R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F7R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F7R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F7R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F7R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F7R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F7R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F7R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F7R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F7R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F7R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F7R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F7R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F7R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F7R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F7R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F7R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F7R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F7R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F7R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F7R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F7R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F7R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F7R1\_FB22 ((uint32\_t)0x00400000)

- #define CAN\_F7R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F7R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F7R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F7R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F7R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F7R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F7R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F7R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F7R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F8R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F8R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F8R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F8R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F8R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F8R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F8R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F8R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F8R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F8R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F8R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F8R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F8R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F8R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F8R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F8R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F8R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F8R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F8R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F8R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F8R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F8R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F8R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F8R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F8R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F8R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F8R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F8R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F8R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F8R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F8R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F8R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F9R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F9R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F9R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F9R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F9R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F9R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F9R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F9R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F9R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F9R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F9R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F9R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F9R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F9R1\_FB13 ((uint32\_t)0x00002000)

- #define CAN\_F9R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F9R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F9R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F9R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F9R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F9R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F9R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F9R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F9R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F9R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F9R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F9R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F9R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F9R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F9R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F9R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F9R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F9R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F10R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F10R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F10R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F10R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F10R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F10R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F10R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F10R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F10R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F10R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F10R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F10R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F10R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F10R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F10R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F10R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F10R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F10R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F10R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F10R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F10R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F10R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F10R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F10R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F10R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F10R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F10R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F10R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F10R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F10R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F10R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F10R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F11R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F11R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F11R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F11R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F11R1\_FB4 ((uint32\_t)0x00000010)

- #define CAN\_F11R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F11R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F11R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F11R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F11R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F11R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F11R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F11R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F11R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F11R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F11R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F11R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F11R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F11R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F11R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F11R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F11R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F11R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F11R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F11R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F11R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F11R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F11R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F11R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F11R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F11R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F11R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F12R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F12R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F12R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F12R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F12R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F12R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F12R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F12R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F12R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F12R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F12R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F12R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F12R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F12R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F12R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F12R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F12R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F12R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F12R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F12R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F12R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F12R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F12R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F12R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F12R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F12R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F12R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F12R1\_FB27 ((uint32\_t)0x08000000)

- #define CAN\_F12R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F12R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F12R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F12R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F13R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F13R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F13R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F13R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F13R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F13R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F13R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F13R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F13R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F13R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F13R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F13R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F13R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F13R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F13R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F13R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F13R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F13R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F13R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F13R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F13R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F13R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F13R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F13R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F13R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F13R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F13R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F13R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F13R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F13R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F13R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F13R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F0R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F0R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F0R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F0R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F0R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F0R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F0R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F0R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F0R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F0R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F0R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F0R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F0R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F0R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F0R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F0R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F0R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F0R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F0R2\_FB18 ((uint32\_t)0x00040000)

- #define CAN\_F0R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F0R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F0R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F0R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F0R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F0R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F0R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F0R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F0R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F0R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F0R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F0R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F0R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F1R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F1R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F1R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F1R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F1R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F1R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F1R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F1R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F1R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F1R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F1R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F1R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F1R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F1R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F1R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F1R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F1R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F1R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F1R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F1R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F1R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F1R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F1R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F1R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F1R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F1R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F1R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F1R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F1R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F1R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F1R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F1R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F2R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F2R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F2R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F2R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F2R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F2R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F2R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F2R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F2R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F2R2\_FB9 ((uint32\_t)0x00000200)

```
• #define CAN_F2R2_FB10 ((uint32_t)0x00000400)
• #define CAN_F2R2_FB11 ((uint32_t)0x00000800)
• #define CAN_F2R2_FB12 ((uint32_t)0x00001000)
• #define CAN_F2R2_FB13 ((uint32_t)0x00002000)
• #define CAN_F2R2_FB14 ((uint32_t)0x00004000)
• #define CAN_F2R2_FB15 ((uint32_t)0x00008000)
• #define CAN_F2R2_FB16 ((uint32_t)0x00010000)
• #define CAN_F2R2_FB17 ((uint32_t)0x00020000)
• #define CAN_F2R2_FB18 ((uint32_t)0x00040000)
• #define CAN_F2R2_FB19 ((uint32_t)0x00080000)
• #define CAN_F2R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F2R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F2R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F2R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F2R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F2R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F2R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F2R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F2R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F2R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F2R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F2R2_FB31 ((uint32_t)0x80000000)
• #define CAN_F3R2_FB0 ((uint32_t)0x00000001)
• #define CAN_F3R2_FB1 ((uint32_t)0x00000002)
• #define CAN_F3R2_FB2 ((uint32_t)0x00000004)
• #define CAN_F3R2_FB3 ((uint32_t)0x00000008)
• #define CAN_F3R2_FB4 ((uint32_t)0x00000010)
• #define CAN_F3R2_FB5 ((uint32_t)0x00000020)
• #define CAN_F3R2_FB6 ((uint32_t)0x00000040)
• #define CAN_F3R2_FB7 ((uint32_t)0x00000080)
• #define CAN_F3R2_FB8 ((uint32_t)0x00000100)
• #define CAN_F3R2_FB9 ((uint32_t)0x00000200)
• #define CAN_F3R2_FB10 ((uint32_t)0x00000400)
• #define CAN_F3R2_FB11 ((uint32_t)0x00000800)
• #define CAN_F3R2_FB12 ((uint32_t)0x00001000)
• #define CAN_F3R2_FB13 ((uint32_t)0x00002000)
• #define CAN_F3R2_FB14 ((uint32_t)0x00004000)
• #define CAN_F3R2_FB15 ((uint32_t)0x00008000)
• #define CAN_F3R2_FB16 ((uint32_t)0x00010000)
• #define CAN_F3R2_FB17 ((uint32_t)0x00020000)
• #define CAN_F3R2_FB18 ((uint32_t)0x00040000)
• #define CAN_F3R2_FB19 ((uint32_t)0x00080000)
• #define CAN_F3R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F3R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F3R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F3R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F3R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F3R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F3R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F3R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F3R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F3R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F3R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F3R2_FB31 ((uint32_t)0x80000000)
• #define CAN_F4R2_FB0 ((uint32_t)0x00000001)
```

- #define CAN\_F4R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F4R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F4R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F4R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F4R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F4R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F4R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F4R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F4R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F4R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F4R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F4R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F4R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F4R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F4R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F4R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F4R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F4R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F4R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F4R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F4R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F4R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F4R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F4R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F4R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F4R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F4R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F4R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F4R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F4R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F4R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F5R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F5R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F5R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F5R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F5R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F5R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F5R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F5R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F5R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F5R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F5R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F5R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F5R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F5R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F5R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F5R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F5R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F5R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F5R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F5R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F5R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F5R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F5R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F5R2\_FB23 ((uint32\_t)0x00800000)

- #define CAN\_F5R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F5R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F5R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F5R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F5R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F5R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F5R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F5R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F6R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F6R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F6R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F6R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F6R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F6R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F6R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F6R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F6R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F6R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F6R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F6R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F6R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F6R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F6R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F6R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F6R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F6R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F6R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F6R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F6R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F6R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F6R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F6R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F6R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F6R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F6R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F6R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F6R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F6R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F6R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F6R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F7R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F7R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F7R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F7R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F7R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F7R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F7R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F7R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F7R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F7R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F7R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F7R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F7R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F7R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F7R2\_FB14 ((uint32\_t)0x00004000)

- #define CAN\_F7R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F7R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F7R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F7R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F7R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F7R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F7R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F7R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F7R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F7R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F7R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F7R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F7R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F7R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F7R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F7R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F7R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F8R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F8R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F8R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F8R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F8R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F8R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F8R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F8R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F8R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F8R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F8R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F8R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F8R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F8R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F8R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F8R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F8R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F8R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F8R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F8R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F8R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F8R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F8R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F8R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F8R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F8R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F8R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F8R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F8R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F8R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F8R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F8R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F9R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F9R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F9R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F9R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F9R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F9R2\_FB5 ((uint32\_t)0x00000020)

- #define CAN\_F9R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F9R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F9R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F9R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F9R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F9R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F9R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F9R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F9R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F9R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F9R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F9R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F9R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F9R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F9R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F9R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F9R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F9R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F9R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F9R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F9R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F9R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F9R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F9R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F9R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F9R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F10R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F10R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F10R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F10R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F10R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F10R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F10R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F10R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F10R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F10R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F10R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F10R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F10R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F10R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F10R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F10R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F10R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F10R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F10R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F10R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F10R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F10R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F10R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F10R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F10R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F10R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F10R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F10R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F10R2\_FB28 ((uint32\_t)0x10000000)

- #define CAN\_F10R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F10R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F10R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F11R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F11R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F11R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F11R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F11R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F11R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F11R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F11R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F11R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F11R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F11R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F11R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F11R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F11R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F11R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F11R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F11R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F11R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F11R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F11R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F11R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F11R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F11R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F11R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F11R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F11R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F11R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F11R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F11R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F11R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F11R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F11R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F12R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F12R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F12R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F12R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F12R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F12R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F12R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F12R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F12R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F12R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F12R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F12R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F12R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F12R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F12R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F12R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F12R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F12R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F12R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F12R2\_FB19 ((uint32\_t)0x00080000)

```
• #define CAN_F12R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F12R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F12R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F12R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F12R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F12R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F12R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F12R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F12R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F12R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F12R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F12R2_FB31 ((uint32_t)0x80000000)
• #define CAN_F13R2_FB0 ((uint32_t)0x00000001)
• #define CAN_F13R2_FB1 ((uint32_t)0x00000002)
• #define CAN_F13R2_FB2 ((uint32_t)0x00000004)
• #define CAN_F13R2_FB3 ((uint32_t)0x00000008)
• #define CAN_F13R2_FB4 ((uint32_t)0x00000010)
• #define CAN_F13R2_FB5 ((uint32_t)0x00000020)
• #define CAN_F13R2_FB6 ((uint32_t)0x00000040)
• #define CAN_F13R2_FB7 ((uint32_t)0x00000080)
• #define CAN_F13R2_FB8 ((uint32_t)0x00000100)
• #define CAN_F13R2_FB9 ((uint32_t)0x00000200)
• #define CAN_F13R2_FB10 ((uint32_t)0x00000400)
• #define CAN_F13R2_FB11 ((uint32_t)0x00000800)
• #define CAN_F13R2_FB12 ((uint32_t)0x00001000)
• #define CAN_F13R2_FB13 ((uint32_t)0x00002000)
• #define CAN_F13R2_FB14 ((uint32_t)0x00004000)
• #define CAN_F13R2_FB15 ((uint32_t)0x00008000)
• #define CAN_F13R2_FB16 ((uint32_t)0x00010000)
• #define CAN_F13R2_FB17 ((uint32_t)0x00020000)
• #define CAN_F13R2_FB18 ((uint32_t)0x00040000)
• #define CAN_F13R2_FB19 ((uint32_t)0x00080000)
• #define CAN_F13R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F13R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F13R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F13R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F13R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F13R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F13R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F13R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F13R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F13R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F13R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F13R2_FB31 ((uint32_t)0x80000000)
• #define CRC_DR_DR ((uint32_t)0xFFFFFFFF)
• #define CRC_IDR_IDR ((uint8_t)0xFF)
• #define CRC_CR_RESET ((uint8_t)0x01)
• #define CRYP_CR_ALGODIR ((uint32_t)0x00000004)
• #define CRYP_CR_ALGOMODE ((uint32_t)0x00080038)
• #define CRYP_CR_ALGOMODE_0 ((uint32_t)0x00000008)
• #define CRYP_CR_ALGOMODE_1 ((uint32_t)0x00000010)
• #define CRYP_CR_ALGOMODE_2 ((uint32_t)0x00000020)
• #define CRYP_CR_ALGOMODE_TDES_ECB ((uint32_t)0x00000000)
• #define CRYP_CR_ALGOMODE_TDES_CBC ((uint32_t)0x00000008)
• #define CRYP_CR_ALGOMODE_DES_ECB ((uint32_t)0x00000010)
```

- #define **CRYP\_CR\_ALGOMODE\_DES\_CBC** ((uint32\_t)0x00000018)
- #define **CRYP\_CR\_ALGOMODE\_AES\_ECB** ((uint32\_t)0x00000020)
- #define **CRYP\_CR\_ALGOMODE\_AES\_CBC** ((uint32\_t)0x00000028)
- #define **CRYP\_CR\_ALGOMODE\_AES\_CTR** ((uint32\_t)0x00000030)
- #define **CRYP\_CR\_ALGOMODE\_AES\_KEY** ((uint32\_t)0x00000038)
- #define **CRYP\_CR\_DATATYPE** ((uint32\_t)0x000000C0)
- #define **CRYP\_CR\_DATATYPE\_0** ((uint32\_t)0x00000040)
- #define **CRYP\_CR\_DATATYPE\_1** ((uint32\_t)0x00000080)
- #define **CRYP\_CR\_KEYSIZE** ((uint32\_t)0x00000300)
- #define **CRYP\_CR\_KEYSIZE\_0** ((uint32\_t)0x00000100)
- #define **CRYP\_CR\_KEYSIZE\_1** ((uint32\_t)0x00000200)
- #define **CRYP\_CR\_FFLUSH** ((uint32\_t)0x00004000)
- #define **CRYP\_CR\_CRYPTEN** ((uint32\_t)0x00008000)
- #define **CRYP\_CR\_GCM\_CCMPH** ((uint32\_t)0x00030000)
- #define **CRYP\_CR\_GCM\_CCMPH\_0** ((uint32\_t)0x00010000)
- #define **CRYP\_CR\_GCM\_CCMPH\_1** ((uint32\_t)0x00020000)
- #define **CRYP\_CR\_ALGOMODE\_3** ((uint32\_t)0x00080000)
- #define **CRYP\_SR\_IFEM** ((uint32\_t)0x00000001)
- #define **CRYP\_SR\_IFNF** ((uint32\_t)0x00000002)
- #define **CRYP\_SR\_OFNE** ((uint32\_t)0x00000004)
- #define **CRYP\_SR\_OFFU** ((uint32\_t)0x00000008)
- #define **CRYP\_SR\_BUSY** ((uint32\_t)0x00000010)
- #define **CRYP\_DMACR\_DIEN** ((uint32\_t)0x00000001)
- #define **CRYP\_DMACR\_DOEN** ((uint32\_t)0x00000002)
- #define **CRYP\_IMSCR\_INIM** ((uint32\_t)0x00000001)
- #define **CRYP\_IMSCR\_OUTIM** ((uint32\_t)0x00000002)
- #define **CRYP\_RISR\_OUTRIS** ((uint32\_t)0x00000001)
- #define **CRYP\_RISR\_INRIS** ((uint32\_t)0x00000002)
- #define **CRYP\_MISR\_INMIS** ((uint32\_t)0x00000001)
- #define **CRYP\_MISR\_OUTMIS** ((uint32\_t)0x00000002)
- #define **DAC\_CR\_EN1** ((uint32\_t)0x00000001)
- #define **DAC\_CR\_BOFF1** ((uint32\_t)0x00000002)
- #define **DAC\_CR\_TEN1** ((uint32\_t)0x00000004)
- #define **DAC\_CR\_TSEL1** ((uint32\_t)0x00000038)
- #define **DAC\_CR\_TSEL1\_0** ((uint32\_t)0x00000008)
- #define **DAC\_CR\_TSEL1\_1** ((uint32\_t)0x00000010)
- #define **DAC\_CR\_TSEL1\_2** ((uint32\_t)0x00000020)
- #define **DAC\_CR\_WAVE1** ((uint32\_t)0x000000C0)
- #define **DAC\_CR\_WAVE1\_0** ((uint32\_t)0x00000040)
- #define **DAC\_CR\_WAVE1\_1** ((uint32\_t)0x00000080)
- #define **DAC\_CR\_MAMP1** ((uint32\_t)0x00000F00)
- #define **DAC\_CR\_MAMP1\_0** ((uint32\_t)0x00000100)
- #define **DAC\_CR\_MAMP1\_1** ((uint32\_t)0x00000200)
- #define **DAC\_CR\_MAMP1\_2** ((uint32\_t)0x00000400)
- #define **DAC\_CR\_MAMP1\_3** ((uint32\_t)0x00000800)
- #define **DAC\_CR\_DMAEN1** ((uint32\_t)0x00001000)
- #define **DAC\_CR\_DMAUDRIE1** ((uint32\_t)0x00002000)
- #define **DAC\_CR\_EN2** ((uint32\_t)0x00010000)
- #define **DAC\_CR\_BOFF2** ((uint32\_t)0x00020000)
- #define **DAC\_CR\_TEN2** ((uint32\_t)0x00040000)
- #define **DAC\_CR\_TSEL2** ((uint32\_t)0x00380000)
- #define **DAC\_CR\_TSEL2\_0** ((uint32\_t)0x00080000)
- #define **DAC\_CR\_TSEL2\_1** ((uint32\_t)0x00100000)
- #define **DAC\_CR\_TSEL2\_2** ((uint32\_t)0x00200000)
- #define **DAC\_CR\_WAVE2** ((uint32\_t)0x00C00000)

- #define **DAC\_CR\_WAVE2\_0** ((uint32\_t)0x00400000)
- #define **DAC\_CR\_WAVE2\_1** ((uint32\_t)0x00800000)
- #define **DAC\_CR\_MAMP2** ((uint32\_t)0xF0000000)
- #define **DAC\_CR\_MAMP2\_0** ((uint32\_t)0x01000000)
- #define **DAC\_CR\_MAMP2\_1** ((uint32\_t)0x02000000)
- #define **DAC\_CR\_MAMP2\_2** ((uint32\_t)0x04000000)
- #define **DAC\_CR\_MAMP2\_3** ((uint32\_t)0x08000000)
- #define **DAC\_CR\_DMAEN2** ((uint32\_t)0x10000000)
- #define **DAC\_CR\_DMAUDRIE2** ((uint32\_t)0x20000000U)
- #define **DAC\_SWTRIGR\_SWTRIG1** ((uint8\_t)0x01)
- #define **DAC\_SWTRIGR\_SWTRIG2** ((uint8\_t)0x02)
- #define **DAC\_DHR12R1\_DACC1DHR** ((uint16\_t)0xFFFF)
- #define **DAC\_DHR12L1\_DACC1DHR** ((uint16\_t)0xFFFF0)
- #define **DAC\_DHR8R1\_DACC1DHR** ((uint8\_t)0xFF)
- #define **DAC\_DHR12R2\_DACC2DHR** ((uint16\_t)0xFFFF)
- #define **DAC\_DHR12L2\_DACC2DHR** ((uint16\_t)0xFFFF0)
- #define **DAC\_DHR8R2\_DACC2DHR** ((uint8\_t)0xFF)
- #define **DAC\_DHR12RD\_DACC1DHR** ((uint32\_t)0x00000FFF)
- #define **DAC\_DHR12RD\_DACC2DHR** ((uint32\_t)0x0FFF0000)
- #define **DAC\_DHR12LD\_DACC1DHR** ((uint32\_t)0x0000FFF0)
- #define **DAC\_DHR12LD\_DACC2DHR** ((uint32\_t)0xFFFF0000)
- #define **DAC\_DHR8RD\_DACC1DHR** ((uint16\_t)0x00FF)
- #define **DAC\_DHR8RD\_DACC2DHR** ((uint16\_t)0xFF00)
- #define **DAC\_DOR1\_DACC1DOR** ((uint16\_t)0x0FFF)
- #define **DAC\_DOR2\_DACC2DOR** ((uint16\_t)0xFFFF)
- #define **DAC\_SR\_DMAUDR1** ((uint32\_t)0x00002000)
- #define **DAC\_SR\_DMAUDR2** ((uint32\_t)0x20000000)
- #define **DCMI\_CR\_CAPTURE** ((uint32\_t)0x00000001)
- #define **DCMI\_CR\_CM** ((uint32\_t)0x00000002)
- #define **DCMI\_CR\_CROP** ((uint32\_t)0x00000004)
- #define **DCMI\_CR\_JPEG** ((uint32\_t)0x00000008)
- #define **DCMI\_CR\_ESS** ((uint32\_t)0x00000010)
- #define **DCMI\_CR\_PCKPOL** ((uint32\_t)0x00000020)
- #define **DCMI\_CR\_HSPOL** ((uint32\_t)0x00000040)
- #define **DCMI\_CR\_VSPOL** ((uint32\_t)0x00000080)
- #define **DCMI\_CR\_FCRC\_0** ((uint32\_t)0x00000100)
- #define **DCMI\_CR\_FCRC\_1** ((uint32\_t)0x00000200)
- #define **DCMI\_CR\_EDM\_0** ((uint32\_t)0x00000400)
- #define **DCMI\_CR\_EDM\_1** ((uint32\_t)0x00000800)
- #define **DCMI\_CR\_CRE** ((uint32\_t)0x00001000)
- #define **DCMI\_CR\_ENABLE** ((uint32\_t)0x00004000)
- #define **DCMI\_SR\_HSYNC** ((uint32\_t)0x00000001)
- #define **DCMI\_SR\_VSYNC** ((uint32\_t)0x00000002)
- #define **DCMI\_SR\_FNE** ((uint32\_t)0x00000004)
- #define **DCMI\_RIS\_FRAME\_RIS** ((uint32\_t)0x00000001)
- #define **DCMI\_RIS\_OVR\_RIS** ((uint32\_t)0x00000002)
- #define **DCMI\_RIS\_ERR\_RIS** ((uint32\_t)0x00000004)
- #define **DCMI\_RIS\_VSYNC\_RIS** ((uint32\_t)0x00000008)
- #define **DCMI\_RIS\_LINE\_RIS** ((uint32\_t)0x00000010)
- #define **DCMI\_RISR\_FRAME\_RIS** DCMI\_RIS\_FRAME\_RIS
- #define **DCMI\_RISR\_OVR\_RIS** DCMI\_RIS\_OVR\_RIS
- #define **DCMI\_RISR\_ERR\_RIS** DCMI\_RIS\_ERR\_RIS
- #define **DCMI\_RISR\_VSYNC\_RIS** DCMI\_RIS\_VSYNC\_RIS
- #define **DCMI\_RISR\_LINE\_RIS** DCMI\_RIS\_LINE\_RIS
- #define **DCMI\_RISR\_OVF\_RIS** DCMI\_RIS\_OVR\_RIS

- #define **DCMI\_IER\_FRAME\_IE** ((uint32\_t)0x00000001)
- #define **DCMI\_IER\_OVR\_IE** ((uint32\_t)0x00000002)
- #define **DCMI\_IER\_ERR\_IE** ((uint32\_t)0x00000004)
- #define **DCMI\_IER\_VSYNC\_IE** ((uint32\_t)0x00000008)
- #define **DCMI\_IER\_LINE\_IE** ((uint32\_t)0x00000010)
- #define **DCMI\_IER\_OVF\_IE** DCMI\_IER\_OVR\_IE
- #define **DCMI\_MIS\_FRAME\_MIS** ((uint32\_t)0x00000001)
- #define **DCMI\_MIS\_OVR\_MIS** ((uint32\_t)0x00000002)
- #define **DCMI\_MIS\_ERR\_MIS** ((uint32\_t)0x00000004)
- #define **DCMI\_MIS\_VSYNC\_MIS** ((uint32\_t)0x00000008)
- #define **DCMI\_MIS\_LINE\_MIS** ((uint32\_t)0x00000010)
- #define **DCMI\_MISR\_FRAME\_MIS** DCMI\_MIS\_FRAME\_MIS
- #define **DCMI\_MISR\_OVF\_MIS** DCMI\_MIS\_OVR\_MIS
- #define **DCMI\_MISR\_ERR\_MIS** DCMI\_MIS\_ERR\_MIS
- #define **DCMI\_MISR\_VSYNC\_MIS** DCMI\_MIS\_VSYNC\_MIS
- #define **DCMI\_MISR\_LINE\_MIS** DCMI\_MIS\_LINE\_MIS
- #define **DCMI\_ICR\_FRAME\_ISC** ((uint32\_t)0x00000001)
- #define **DCMI\_ICR\_OVR\_ISC** ((uint32\_t)0x00000002)
- #define **DCMI\_ICR\_ERR\_ISC** ((uint32\_t)0x00000004)
- #define **DCMI\_ICR\_VSYNC\_ISC** ((uint32\_t)0x00000008)
- #define **DCMI\_ICR\_LINE\_ISC** ((uint32\_t)0x00000010)
- #define **DCMI\_ICR\_OVF\_ISC** DCMI\_ICR\_OVR\_ISC
- #define **DCMI\_ESCR\_FSC** ((uint32\_t)0x000000FF)
- #define **DCMI\_ESCR\_LSC** ((uint32\_t)0x0000FF00)
- #define **DCMI\_ESCR\_LEC** ((uint32\_t)0x00FF0000)
- #define **DCMI\_ESCR\_FEC** ((uint32\_t)0xFF000000)
- #define **DCMI\_ESUR\_FSU** ((uint32\_t)0x000000FF)
- #define **DCMI\_ESUR\_LSU** ((uint32\_t)0x0000FF00)
- #define **DCMI\_ESUR\_LEU** ((uint32\_t)0x00FF0000)
- #define **DCMI\_ESUR\_FEU** ((uint32\_t)0xFF000000)
- #define **DCMI\_CWSTRT\_HOFFCNT** ((uint32\_t)0x00003FFF)
- #define **DCMI\_CWSTRT\_VST** ((uint32\_t)0x1FFF0000)
- #define **DCMI\_CWSIZE\_CAPCNT** ((uint32\_t)0x00003FFF)
- #define **DCMI\_CWSIZE\_VLINE** ((uint32\_t)0x3FFF0000)
- #define **DCMI\_DR\_BYTE0** ((uint32\_t)0x000000FF)
- #define **DCMI\_DR\_BYTE1** ((uint32\_t)0x0000FF00)
- #define **DCMI\_DR\_BYTE2** ((uint32\_t)0x00FF0000)
- #define **DCMI\_DR\_BYTE3** ((uint32\_t)0xFF000000)
- #define **DFSDM\_CHCFGR1\_DFSDMEN** ((uint32\_t)0x80000000)
- #define **DFSDM\_CHCFGR1\_CKOUTSRC** ((uint32\_t)0x40000000)
- #define **DFSDM\_CHCFGR1\_CKOUTDIV** ((uint32\_t)0x00FF0000)
- #define **DFSDM\_CHCFGR1\_DATPACK** ((uint32\_t)0x0000C000)
- #define **DFSDM\_CHCFGR1\_DATPACK\_1** ((uint32\_t)0x00008000)
- #define **DFSDM\_CHCFGR1\_DATPACK\_0** ((uint32\_t)0x00004000)
- #define **DFSDM\_CHCFGR1\_DATMPX** ((uint32\_t)0x00003000)
- #define **DFSDM\_CHCFGR1\_DATMPX\_1** ((uint32\_t)0x00002000)
- #define **DFSDM\_CHCFGR1\_DATMPX\_0** ((uint32\_t)0x00001000)
- #define **DFSDM\_CHCFGR1\_CHINSEL** ((uint32\_t)0x00000100)
- #define **DFSDM\_CHCFGR1\_CHEN** ((uint32\_t)0x00000080)
- #define **DFSDM\_CHCFGR1\_CKABEN** ((uint32\_t)0x00000040)
- #define **DFSDM\_CHCFGR1\_SCDEN** ((uint32\_t)0x00000020)
- #define **DFSDM\_CHCFGR1\_SPICKSEL** ((uint32\_t)0x0000000C)
- #define **DFSDM\_CHCFGR1\_SPICKSEL\_1** ((uint32\_t)0x00000008)
- #define **DFSDM\_CHCFGR1\_SPICKSEL\_0** ((uint32\_t)0x00000004)
- #define **DFSDM\_CHCFGR1\_SITP** ((uint32\_t)0x00000003)

- #define DFSDM\_CHCFGR1\_SITP\_1 ((uint32\_t)0x00000002)
- #define DFSDM\_CHCFGR1\_SITP\_0 ((uint32\_t)0x00000001)
- #define DFSDM\_CHCFGR2\_OFFSET ((uint32\_t)0xFFFFFFF00)
- #define DFSDM\_CHCFGR2\_DTRBS ((uint32\_t)0x000000F8)
- #define DFSDM\_CHAWSCDR\_AWFORD ((uint32\_t)0x00C00000)
- #define DFSDM\_CHAWSCDR\_AWFORD\_1 ((uint32\_t)0x00800000)
- #define DFSDM\_CHAWSCDR\_AWFORD\_0 ((uint32\_t)0x00400000)
- #define DFSDM\_CHAWSCDR\_AWFOSR ((uint32\_t)0x001F0000)
- #define DFSDM\_CHAWSCDR\_BKSCD ((uint32\_t)0x0000F000)
- #define DFSDM\_CHAWSCDR\_SCDT ((uint32\_t)0x000000FF)
- #define DFSDM\_CHWDATR\_WDATA ((uint32\_t)0x0000FFFF)
- #define DFSDM\_CHDATINR\_INDAT0 ((uint32\_t)0x0000FFFF)
- #define DFSDM\_CHDATINR\_INDAT1 ((uint32\_t)0xFFFF0000)
- #define DFSDM\_FLTCR1\_AWFSEL ((uint32\_t)0x40000000)
- #define DFSDM\_FLTCR1\_FAST ((uint32\_t)0x20000000)
- #define DFSDM\_FLTCR1\_RCH ((uint32\_t)0x07000000)
- #define DFSDM\_FLTCR1\_RDMAEN ((uint32\_t)0x00200000)
- #define DFSDM\_FLTCR1\_RSYNC ((uint32\_t)0x00080000)
- #define DFSDM\_FLTCR1\_RCONT ((uint32\_t)0x00040000)
- #define DFSDM\_FLTCR1\_RSWSTART ((uint32\_t)0x00020000)
- #define DFSDM\_FLTCR1\_JEXTEN ((uint32\_t)0x00006000)
- #define DFSDM\_FLTCR1\_JEXTEN\_1 ((uint32\_t)0x00004000)
- #define DFSDM\_FLTCR1\_JEXTEN\_0 ((uint32\_t)0x00002000)
- #define DFSDM\_FLTCR1\_JEXTSEL ((uint32\_t)0x00000700)
- #define DFSDM\_FLTCR1\_JEXTSEL\_2 ((uint32\_t)0x00000400)
- #define DFSDM\_FLTCR1\_JEXTSEL\_1 ((uint32\_t)0x00000200)
- #define DFSDM\_FLTCR1\_JEXTSEL\_0 ((uint32\_t)0x00000100)
- #define DFSDM\_FLTCR1\_JDMAEN ((uint32\_t)0x00000020)
- #define DFSDM\_FLTCR1\_JSCAN ((uint32\_t)0x00000010)
- #define DFSDM\_FLTCR1\_JSYNC ((uint32\_t)0x00000008)
- #define DFSDM\_FLTCR1\_JSWSTART ((uint32\_t)0x00000002)
- #define DFSDM\_FLTCR1\_DFEN ((uint32\_t)0x00000001)
- #define DFSDM\_FLTCR2\_AWDCH ((uint32\_t)0x000F0000)
- #define DFSDM\_FLTCR2\_EXCH ((uint32\_t)0x00000F00)
- #define DFSDM\_FLTCR2\_CKABIE ((uint32\_t)0x00000040)
- #define DFSDM\_FLTCR2\_SCDIE ((uint32\_t)0x00000020)
- #define DFSDM\_FLTCR2\_AWDIE ((uint32\_t)0x00000010)
- #define DFSDM\_FLTCR2\_ROVRIE ((uint32\_t)0x00000008)
- #define DFSDM\_FLTCR2\_JOVRIE ((uint32\_t)0x00000004)
- #define DFSDM\_FLTCR2\_REOCIE ((uint32\_t)0x00000002)
- #define DFSDM\_FLTCR2\_JEOCIE ((uint32\_t)0x00000001)
- #define DFSDM\_FLTISR\_SCDF ((uint32\_t)0x0F000000)
- #define DFSDM\_FLTISR\_CKABF ((uint32\_t)0x000F0000)
- #define DFSDM\_FLTISR\_RCIP ((uint32\_t)0x00004000)
- #define DFSDM\_FLTISR\_JCIP ((uint32\_t)0x00002000)
- #define DFSDM\_FLTISR\_AWDF ((uint32\_t)0x00000010)
- #define DFSDM\_FLTISR\_ROVRF ((uint32\_t)0x00000008)
- #define DFSDM\_FLTISR\_JOVRF ((uint32\_t)0x00000004)
- #define DFSDM\_FLTISR\_REOFC ((uint32\_t)0x00000002)
- #define DFSDM\_FLTISR\_JEOCF ((uint32\_t)0x00000001)
- #define DFSDM\_FLTICR\_CLRSCSDF ((uint32\_t)0x0F000000)
- #define DFSDM\_FLTICR\_CLRKABF ((uint32\_t)0x000F0000)
- #define DFSDM\_FLTICR\_CLRRORVRF ((uint32\_t)0x00000008)
- #define DFSDM\_FLTICR\_CLRJOVRF ((uint32\_t)0x00000004)
- #define DFSDM\_FLTJCHGR\_JCHG ((uint32\_t)0x000000FF)

- #define DFSDM\_FLTFCR\_FORD ((uint32\_t)0xE0000000)
- #define DFSDM\_FLTFCR\_FORD\_2 ((uint32\_t)0x80000000)
- #define DFSDM\_FLTFCR\_FORD\_1 ((uint32\_t)0x40000000)
- #define DFSDM\_FLTFCR\_FORD\_0 ((uint32\_t)0x20000000)
- #define DFSDM\_FLTFCR\_FOSR ((uint32\_t)0x03FF0000)
- #define DFSDM\_FLTFCR\_IOSR ((uint32\_t)0x000000FF)
- #define DFSDM\_FLTJDATAR\_JDATA ((uint32\_t)0xFFFFFFF0)
- #define DFSDM\_FLTJDATAR\_JDATACH ((uint32\_t)0x00000007)
- #define DFSDM\_FLTRDATAR\_RDATA ((uint32\_t)0xFFFFFFF0)
- #define DFSDM\_FLTRDATAR\_RPEND ((uint32\_t)0x00000010)
- #define DFSDM\_FLTRDATAR\_RDATAACH ((uint32\_t)0x00000007)
- #define DFSDM\_FLTAWHTR\_AWHT ((uint32\_t)0xFFFFFFF0)
- #define DFSDM\_FLTAWHTR\_BKAWH ((uint32\_t)0x0000000F)
- #define DFSDM\_FLTAWLTR\_AWLT ((uint32\_t)0xFFFFFFF0)
- #define DFSDM\_FLTAWLTR\_BKAWL ((uint32\_t)0x0000000F)
- #define DFSDM\_FLTAWSR\_AWHTF ((uint32\_t)0x00000F00)
- #define DFSDM\_FLTAWSR\_AWLTF ((uint32\_t)0x0000000F)
- #define DFSDM\_FLTAWCRR\_CLRAWHTF ((uint32\_t)0x00000F00)
- #define DFSDM\_FLTAWCRR\_CLRAWLTF ((uint32\_t)0x0000000F)
- #define DFSDM\_FLTEXMAX\_EXMAX ((uint32\_t)0xFFFFFFF0)
- #define DFSDM\_FLTEXMAX\_EXMAXCH ((uint32\_t)0x00000007)
- #define DFSDM\_FLTEXMIN\_EXMIN ((uint32\_t)0xFFFFFFF0)
- #define DFSDM\_FLTEXMIN\_EXMINCH ((uint32\_t)0x00000007)
- #define DFSDM\_FLTCNVTIMR\_CNVCT ((uint32\_t)0xFFFFFFF0)
- #define DMA\_SxCR\_CHSEL ((uint32\_t)0x0E000000)
- #define DMA\_SxCR\_CHSEL\_0 ((uint32\_t)0x02000000)
- #define DMA\_SxCR\_CHSEL\_1 ((uint32\_t)0x04000000)
- #define DMA\_SxCR\_CHSEL\_2 ((uint32\_t)0x08000000)
- #define DMA\_SxCR\_MBURST ((uint32\_t)0x01800000)
- #define DMA\_SxCR\_MBURST\_0 ((uint32\_t)0x00800000)
- #define DMA\_SxCR\_MBURST\_1 ((uint32\_t)0x01000000)
- #define DMA\_SxCR\_PBURST ((uint32\_t)0x00600000)
- #define DMA\_SxCR\_PBURST\_0 ((uint32\_t)0x00200000)
- #define DMA\_SxCR\_PBURST\_1 ((uint32\_t)0x00400000)
- #define DMA\_SxCR\_ACK ((uint32\_t)0x00100000)
- #define DMA\_SxCR\_CT ((uint32\_t)0x00080000)
- #define DMA\_SxCR\_DBM ((uint32\_t)0x00040000)
- #define DMA\_SxCR\_PL ((uint32\_t)0x00030000)
- #define DMA\_SxCR\_PL\_0 ((uint32\_t)0x00010000)
- #define DMA\_SxCR\_PL\_1 ((uint32\_t)0x00020000)
- #define DMA\_SxCR\_PINCOS ((uint32\_t)0x000008000)
- #define DMA\_SxCR\_MSIZE ((uint32\_t)0x00006000)
- #define DMA\_SxCR\_MSIZE\_0 ((uint32\_t)0x00002000)
- #define DMA\_SxCR\_MSIZE\_1 ((uint32\_t)0x00004000)
- #define DMA\_SxCR\_PSIZE ((uint32\_t)0x00001800)
- #define DMA\_SxCR\_PSIZE\_0 ((uint32\_t)0x00000800)
- #define DMA\_SxCR\_PSIZE\_1 ((uint32\_t)0x00001000)
- #define DMA\_SxCR\_MINC ((uint32\_t)0x00000400)
- #define DMA\_SxCR\_PINC ((uint32\_t)0x00000200)
- #define DMA\_SxCR\_CIRC ((uint32\_t)0x00000100)
- #define DMA\_SxCR\_DIR ((uint32\_t)0x000000C0)
- #define DMA\_SxCR\_DIR\_0 ((uint32\_t)0x00000040)
- #define DMA\_SxCR\_DIR\_1 ((uint32\_t)0x00000080)
- #define DMA\_SxCR\_PFCTRL ((uint32\_t)0x00000020)
- #define DMA\_SxCR\_TCIE ((uint32\_t)0x00000010)

- #define **DMA\_SxCR\_HTIE** ((uint32\_t)0x00000008)
- #define **DMA\_SxCR\_TEIE** ((uint32\_t)0x00000004)
- #define **DMA\_SxCR\_DMEIE** ((uint32\_t)0x00000002)
- #define **DMA\_SxCR\_EN** ((uint32\_t)0x00000001)
- #define **DMA\_SxNDT** ((uint32\_t)0x0000FFFF)
- #define **DMA\_SxNDT\_0** ((uint32\_t)0x00000001)
- #define **DMA\_SxNDT\_1** ((uint32\_t)0x00000002)
- #define **DMA\_SxNDT\_2** ((uint32\_t)0x00000004)
- #define **DMA\_SxNDT\_3** ((uint32\_t)0x00000008)
- #define **DMA\_SxNDT\_4** ((uint32\_t)0x00000010)
- #define **DMA\_SxNDT\_5** ((uint32\_t)0x00000020)
- #define **DMA\_SxNDT\_6** ((uint32\_t)0x00000040)
- #define **DMA\_SxNDT\_7** ((uint32\_t)0x00000080)
- #define **DMA\_SxNDT\_8** ((uint32\_t)0x00000100)
- #define **DMA\_SxNDT\_9** ((uint32\_t)0x00000200)
- #define **DMA\_SxNDT\_10** ((uint32\_t)0x00000400)
- #define **DMA\_SxNDT\_11** ((uint32\_t)0x00000800)
- #define **DMA\_SxNDT\_12** ((uint32\_t)0x00001000)
- #define **DMA\_SxNDT\_13** ((uint32\_t)0x00002000)
- #define **DMA\_SxNDT\_14** ((uint32\_t)0x00004000)
- #define **DMA\_SxNDT\_15** ((uint32\_t)0x00008000)
- #define **DMA\_SxFCR\_FEIE** ((uint32\_t)0x00000080)
- #define **DMA\_SxFCR\_FS** ((uint32\_t)0x00000038)
- #define **DMA\_SxFCR\_FS\_0** ((uint32\_t)0x00000008)
- #define **DMA\_SxFCR\_FS\_1** ((uint32\_t)0x00000010)
- #define **DMA\_SxFCR\_FS\_2** ((uint32\_t)0x00000020)
- #define **DMA\_SxFCR\_DMDIS** ((uint32\_t)0x00000004)
- #define **DMA\_SxFCR\_FTH** ((uint32\_t)0x00000003)
- #define **DMA\_SxFCR\_FTH\_0** ((uint32\_t)0x00000001)
- #define **DMA\_SxFCR\_FTH\_1** ((uint32\_t)0x00000002)
- #define **DMA\_LISR\_TCIF3** ((uint32\_t)0x08000000)
- #define **DMA\_LISR\_HTIF3** ((uint32\_t)0x04000000)
- #define **DMA\_LISR\_TEIF3** ((uint32\_t)0x02000000)
- #define **DMA\_LISR\_DMEIF3** ((uint32\_t)0x01000000)
- #define **DMA\_LISR\_FEIF3** ((uint32\_t)0x00400000)
- #define **DMA\_LISR\_TCIF2** ((uint32\_t)0x00200000)
- #define **DMA\_LISR\_HTIF2** ((uint32\_t)0x00100000)
- #define **DMA\_LISR\_TEIF2** ((uint32\_t)0x00080000)
- #define **DMA\_LISR\_DMEIF2** ((uint32\_t)0x00040000)
- #define **DMA\_LISR\_FEIF2** ((uint32\_t)0x00010000)
- #define **DMA\_LISR\_TCIF1** ((uint32\_t)0x00000800)
- #define **DMA\_LISR\_HTIF1** ((uint32\_t)0x00000400)
- #define **DMA\_LISR\_TEIF1** ((uint32\_t)0x00000200)
- #define **DMA\_LISR\_DMEIF1** ((uint32\_t)0x00000100)
- #define **DMA\_LISR\_FEIF1** ((uint32\_t)0x00000040)
- #define **DMA\_LISR\_TCIF0** ((uint32\_t)0x00000020)
- #define **DMA\_LISR\_HTIF0** ((uint32\_t)0x00000010)
- #define **DMA\_LISR\_TEIF0** ((uint32\_t)0x00000008)
- #define **DMA\_LISR\_DMEIFO** ((uint32\_t)0x00000004)
- #define **DMA\_LISR\_FEIFO** ((uint32\_t)0x00000001)
- #define **DMA\_HISR\_TCIF7** ((uint32\_t)0x08000000)
- #define **DMA\_HISR\_HTIF7** ((uint32\_t)0x04000000)
- #define **DMA\_HISR\_TEIF7** ((uint32\_t)0x02000000)
- #define **DMA\_HISR\_DMEIF7** ((uint32\_t)0x01000000)
- #define **DMA\_HISR\_FEIF7** ((uint32\_t)0x00400000)

- #define **DMA\_HISR\_TCIF6** ((uint32\_t)0x00200000)
- #define **DMA\_HISR\_HTIF6** ((uint32\_t)0x00100000)
- #define **DMA\_HISR\_TEIF6** ((uint32\_t)0x00080000)
- #define **DMA\_HISR\_DMEIF6** ((uint32\_t)0x00040000)
- #define **DMA\_HISR\_FEIF6** ((uint32\_t)0x00010000)
- #define **DMA\_HISR\_TCIF5** ((uint32\_t)0x00000800)
- #define **DMA\_HISR\_HTIF5** ((uint32\_t)0x00000400)
- #define **DMA\_HISR\_TEIF5** ((uint32\_t)0x00000200)
- #define **DMA\_HISR\_DMEIF5** ((uint32\_t)0x00000100)
- #define **DMA\_HISR\_FEIF5** ((uint32\_t)0x00000040)
- #define **DMA\_HISR\_TCIF4** ((uint32\_t)0x00000020)
- #define **DMA\_HISR\_HTIF4** ((uint32\_t)0x00000010)
- #define **DMA\_HISR\_TEIF4** ((uint32\_t)0x00000008)
- #define **DMA\_HISR\_DMEIF4** ((uint32\_t)0x00000004)
- #define **DMA\_HISR\_FEIF4** ((uint32\_t)0x00000001)
- #define **DMA\_LIFCR\_CTCIF3** ((uint32\_t)0x08000000)
- #define **DMA\_LIFCR\_CHTIF3** ((uint32\_t)0x04000000)
- #define **DMA\_LIFCR\_CTEIF3** ((uint32\_t)0x02000000)
- #define **DMA\_LIFCR\_CDMEIF3** ((uint32\_t)0x01000000)
- #define **DMA\_LIFCR\_CFEIF3** ((uint32\_t)0x00400000)
- #define **DMA\_LIFCR\_CTCIF2** ((uint32\_t)0x00200000)
- #define **DMA\_LIFCR\_CHTIF2** ((uint32\_t)0x00100000)
- #define **DMA\_LIFCR\_CTEIF2** ((uint32\_t)0x00080000)
- #define **DMA\_LIFCR\_CDMEIF2** ((uint32\_t)0x00040000)
- #define **DMA\_LIFCR\_CFEIF2** ((uint32\_t)0x00010000)
- #define **DMA\_LIFCR\_CTCIF1** ((uint32\_t)0x00000800)
- #define **DMA\_LIFCR\_CHTIF1** ((uint32\_t)0x00000400)
- #define **DMA\_LIFCR\_CTEIF1** ((uint32\_t)0x00000200)
- #define **DMA\_LIFCR\_CDMEIF1** ((uint32\_t)0x00000100)
- #define **DMA\_LIFCR\_CFEIF1** ((uint32\_t)0x00000040)
- #define **DMA\_LIFCR\_CTCIF0** ((uint32\_t)0x00000020)
- #define **DMA\_LIFCR\_CHTIFO** ((uint32\_t)0x00000010)
- #define **DMA\_LIFCR\_CTEIFO** ((uint32\_t)0x00000008)
- #define **DMA\_LIFCR\_CDMEIFO** ((uint32\_t)0x00000004)
- #define **DMA\_LIFCR\_CFEIFO** ((uint32\_t)0x00000001)
- #define **DMA\_HIFCR\_CTCIF7** ((uint32\_t)0x08000000)
- #define **DMA\_HIFCR\_CHTIF7** ((uint32\_t)0x04000000)
- #define **DMA\_HIFCR\_CTEIF7** ((uint32\_t)0x02000000)
- #define **DMA\_HIFCR\_CDMEIF7** ((uint32\_t)0x01000000)
- #define **DMA\_HIFCR\_CFEIF7** ((uint32\_t)0x00400000)
- #define **DMA\_HIFCR\_CTCIF6** ((uint32\_t)0x00200000)
- #define **DMA\_HIFCR\_CHTIF6** ((uint32\_t)0x00100000)
- #define **DMA\_HIFCR\_CTEIF6** ((uint32\_t)0x00080000)
- #define **DMA\_HIFCR\_CDMEIF6** ((uint32\_t)0x00040000)
- #define **DMA\_HIFCR\_CFEIF6** ((uint32\_t)0x00010000)
- #define **DMA\_HIFCR\_CTCIF5** ((uint32\_t)0x00000800)
- #define **DMA\_HIFCR\_CHTIF5** ((uint32\_t)0x00000400)
- #define **DMA\_HIFCR\_CTEIF5** ((uint32\_t)0x00000200)
- #define **DMA\_HIFCR\_CDMEIF5** ((uint32\_t)0x00000100)
- #define **DMA\_HIFCR\_CFEIF5** ((uint32\_t)0x00000040)
- #define **DMA\_HIFCR\_CTCIF4** ((uint32\_t)0x00000020)
- #define **DMA\_HIFCR\_CHTIF4** ((uint32\_t)0x00000010)
- #define **DMA\_HIFCR\_CTEIF4** ((uint32\_t)0x00000008)
- #define **DMA\_HIFCR\_CDMEIF4** ((uint32\_t)0x00000004)
- #define **DMA\_HIFCR\_CFEIF4** ((uint32\_t)0x00000001)

- #define DMA2D\_CR\_START ((uint32\_t)0x00000001)
- #define DMA2D\_CR\_SUSP ((uint32\_t)0x00000002)
- #define DMA2D\_CR\_ABORT ((uint32\_t)0x00000004)
- #define DMA2D\_CR\_TEIE ((uint32\_t)0x00000100)
- #define DMA2D\_CR\_TCIE ((uint32\_t)0x00000200)
- #define DMA2D\_CR\_TWIE ((uint32\_t)0x00000400)
- #define DMA2D\_CR\_CAEIE ((uint32\_t)0x00000800)
- #define DMA2D\_CR\_CTCIE ((uint32\_t)0x00001000)
- #define DMA2D\_CR\_CEIE ((uint32\_t)0x00002000)
- #define DMA2D\_CR\_MODE ((uint32\_t)0x00030000)
- #define DMA2D\_ISR\_TEIF ((uint32\_t)0x00000001)
- #define DMA2D\_ISR\_TCIF ((uint32\_t)0x00000002)
- #define DMA2D\_ISR\_TWIF ((uint32\_t)0x00000004)
- #define DMA2D\_ISR\_CAEIF ((uint32\_t)0x00000008)
- #define DMA2D\_ISR\_CTCIF ((uint32\_t)0x00000010)
- #define DMA2D\_ISR\_CEIF ((uint32\_t)0x00000020)
- #define DMA2D\_IFCR\_CTEIF ((uint32\_t)0x00000001)
- #define DMA2D\_IFCR\_CTCIF ((uint32\_t)0x00000002)
- #define DMA2D\_IFCR\_CTWIF ((uint32\_t)0x00000004)
- #define DMA2D\_IFCR\_CAECIF ((uint32\_t)0x00000008)
- #define DMA2D\_IFCR\_CCTCIF ((uint32\_t)0x00000010)
- #define DMA2D\_IFCR\_CCEIF ((uint32\_t)0x00000020)
- #define DMA2D\_IFSR\_CTEIF DMA2D\_IFCR\_CTEIF
- #define DMA2D\_IFSR\_CTCIF DMA2D\_IFCR\_CTCIF
- #define DMA2D\_IFSR\_CTWIF DMA2D\_IFCR\_CTWIF
- #define DMA2D\_IFSR\_CCAEIF DMA2D\_IFCR\_CAECIF
- #define DMA2D\_IFSR\_CCTCIF DMA2D\_IFCR\_CCTCIF
- #define DMA2D\_IFSR\_CCEIF DMA2D\_IFCR\_CCEIF
- #define DMA2D\_FGMAR\_MA ((uint32\_t)0xFFFFFFFF)
- #define DMA2D\_FGOR\_LO ((uint32\_t)0x00003FFF)
- #define DMA2D\_BGMAR\_MA ((uint32\_t)0xFFFFFFFF)
- #define DMA2D\_BGOR\_LO ((uint32\_t)0x00003FFF)
- #define DMA2D\_FGPFCCR\_CM ((uint32\_t)0x0000000F)
- #define DMA2D\_FGPFCCR\_CM\_0 ((uint32\_t)0x00000001)
- #define DMA2D\_FGPFCCR\_CM\_1 ((uint32\_t)0x00000002)
- #define DMA2D\_FGPFCCR\_CM\_2 ((uint32\_t)0x00000004)
- #define DMA2D\_FGPFCCR\_CM\_3 ((uint32\_t)0x00000008)
- #define DMA2D\_FGPFCCR\_CM\_3 ((uint32\_t)0x00000008)
- #define DMA2D\_FGPFCCR\_CCM ((uint32\_t)0x00000010)
- #define DMA2D\_FGPFCCR\_START ((uint32\_t)0x00000020)
- #define DMA2D\_FGPFCCR\_CS ((uint32\_t)0x0000FF00)
- #define DMA2D\_FGPFCCR\_AM ((uint32\_t)0x00030000)
- #define DMA2D\_FGPFCCR\_AM\_0 ((uint32\_t)0x00100000)
- #define DMA2D\_FGPFCCR\_AM\_1 ((uint32\_t)0x00200000)
- #define DMA2D\_FGPFCCR\_ALPHA ((uint32\_t)0xFF000000)
- #define DMA2D\_FGCOLR\_BLUE ((uint32\_t)0x000000FF)
- #define DMA2D\_FGCOLR\_GREEN ((uint32\_t)0x0000FF00)
- #define DMA2D\_FGCOLR\_RED ((uint32\_t)0x00FF0000)
- #define DMA2D\_BGPFCCR\_CM ((uint32\_t)0x0000000F)
- #define DMA2D\_BGPFCCR\_CM\_0 ((uint32\_t)0x00000001)
- #define DMA2D\_BGPFCCR\_CM\_1 ((uint32\_t)0x00000002)
- #define DMA2D\_BGPFCCR\_CM\_2 ((uint32\_t)0x00000004)
- #define DMA2D\_BGPFCCR\_CCM ((uint32\_t)0x00000010)
- #define DMA2D\_BGPFCCR\_START ((uint32\_t)0x00000020)
- #define DMA2D\_BGPFCCR\_CS ((uint32\_t)0x0000FF00)

- #define DMA2D\_BGPFCCR\_AM ((uint32\_t)0x00030000)
- #define DMA2D\_BGPFCCR\_AM\_0 ((uint32\_t)0x00010000)
- #define DMA2D\_BGPFCCR\_AM\_1 ((uint32\_t)0x00020000)
- #define DMA2D\_BGPFCCR\_ALPHA ((uint32\_t)0xFF000000)
- #define DMA2D\_BGCOLR\_BLUE ((uint32\_t)0x000000FF)
- #define DMA2D\_BGCOLR\_GREEN ((uint32\_t)0x0000FF00)
- #define DMA2D\_BGCOLR\_RED ((uint32\_t)0x00FF0000)
- #define DMA2D\_FGCMAR\_MA ((uint32\_t)0xFFFFFFFF)
- #define DMA2D\_BGCMAR\_MA ((uint32\_t)0xFFFFFFFF)
- #define DMA2D\_OPFCCR\_CM ((uint32\_t)0x00000007)
- #define DMA2D\_OPFCCR\_CM\_0 ((uint32\_t)0x00000001)
- #define DMA2D\_OPFCCR\_CM\_1 ((uint32\_t)0x00000002)
- #define DMA2D\_OPFCCR\_CM\_2 ((uint32\_t)0x00000004)
- #define DMA2D\_OCOLR\_BLUE\_1 ((uint32\_t)0x000000FF)
- #define DMA2D\_OCOLR\_GREEN\_1 ((uint32\_t)0x0000FF00)
- #define DMA2D\_OCOLR\_RED\_1 ((uint32\_t)0x00FF0000)
- #define DMA2D\_OCOLR\_ALPHA\_1 ((uint32\_t)0xFF000000)
- #define DMA2D\_OCOLR\_BLUE\_2 ((uint32\_t)0x0000001F)
- #define DMA2D\_OCOLR\_GREEN\_2 ((uint32\_t)0x000007E0)
- #define DMA2D\_OCOLR\_RED\_2 ((uint32\_t)0x0000F800)
- #define DMA2D\_OCOLR\_BLUE\_3 ((uint32\_t)0x0000001F)
- #define DMA2D\_OCOLR\_GREEN\_3 ((uint32\_t)0x000003E0)
- #define DMA2D\_OCOLR\_RED\_3 ((uint32\_t)0x00007C00)
- #define DMA2D\_OCOLR\_ALPHA\_3 ((uint32\_t)0x00008000)
- #define DMA2D\_OCOLR\_BLUE\_4 ((uint32\_t)0x0000000F)
- #define DMA2D\_OCOLR\_GREEN\_4 ((uint32\_t)0x000000F0)
- #define DMA2D\_OCOLR\_RED\_4 ((uint32\_t)0x00000F00)
- #define DMA2D\_OCOLR\_ALPHA\_4 ((uint32\_t)0x0000F000)
- #define DMA2D\_OMAR\_MA ((uint32\_t)0xFFFFFFFF)
- #define DMA2D\_OOR\_LO ((uint32\_t)0x00003FFF)
- #define DMA2D\_NLR\_NL ((uint32\_t)0x0000FFFF)
- #define DMA2D\_NLR\_PL ((uint32\_t)0x3FFF0000)
- #define DMA2D\_LWR\_LW ((uint32\_t)0x0000FFFF)
- #define DMA2D\_AMTCR\_EN ((uint32\_t)0x00000001)
- #define DMA2D\_AMTCR\_DT ((uint32\_t)0x0000FF00)
- #define EXTI\_IMR\_MR0 ((uint32\_t)0x00000001)
- #define EXTI\_IMR\_MR1 ((uint32\_t)0x00000002)
- #define EXTI\_IMR\_MR2 ((uint32\_t)0x00000004)
- #define EXTI\_IMR\_MR3 ((uint32\_t)0x00000008)
- #define EXTI\_IMR\_MR4 ((uint32\_t)0x00000010)
- #define EXTI\_IMR\_MR5 ((uint32\_t)0x00000020)
- #define EXTI\_IMR\_MR6 ((uint32\_t)0x00000040)
- #define EXTI\_IMR\_MR7 ((uint32\_t)0x00000080)
- #define EXTI\_IMR\_MR8 ((uint32\_t)0x00000100)
- #define EXTI\_IMR\_MR9 ((uint32\_t)0x00000200)
- #define EXTI\_IMR\_MR10 ((uint32\_t)0x00000400)
- #define EXTI\_IMR\_MR11 ((uint32\_t)0x00000800)
- #define EXTI\_IMR\_MR12 ((uint32\_t)0x00001000)
- #define EXTI\_IMR\_MR13 ((uint32\_t)0x00002000)
- #define EXTI\_IMR\_MR14 ((uint32\_t)0x00004000)
- #define EXTI\_IMR\_MR15 ((uint32\_t)0x00008000)
- #define EXTI\_IMR\_MR16 ((uint32\_t)0x00010000)
- #define EXTI\_IMR\_MR17 ((uint32\_t)0x00020000)
- #define EXTI\_IMR\_MR18 ((uint32\_t)0x00040000)
- #define EXTI\_IMR\_MR19 ((uint32\_t)0x00080000)

- #define `EXTI_IMR_MR23` ((`uint32_t`)0x00800000)
- #define `EXTI_EMR_MR0` ((`uint32_t`)0x00000001)
- #define `EXTI_EMR_MR1` ((`uint32_t`)0x00000002)
- #define `EXTI_EMR_MR2` ((`uint32_t`)0x00000004)
- #define `EXTI_EMR_MR3` ((`uint32_t`)0x00000008)
- #define `EXTI_EMR_MR4` ((`uint32_t`)0x00000010)
- #define `EXTI_EMR_MR5` ((`uint32_t`)0x00000020)
- #define `EXTI_EMR_MR6` ((`uint32_t`)0x00000040)
- #define `EXTI_EMR_MR7` ((`uint32_t`)0x00000080)
- #define `EXTI_EMR_MR8` ((`uint32_t`)0x00000100)
- #define `EXTI_EMR_MR9` ((`uint32_t`)0x00000200)
- #define `EXTI_EMR_MR10` ((`uint32_t`)0x00000400)
- #define `EXTI_EMR_MR11` ((`uint32_t`)0x00000800)
- #define `EXTI_EMR_MR12` ((`uint32_t`)0x00001000)
- #define `EXTI_EMR_MR13` ((`uint32_t`)0x00002000)
- #define `EXTI_EMR_MR14` ((`uint32_t`)0x00004000)
- #define `EXTI_EMR_MR15` ((`uint32_t`)0x00008000)
- #define `EXTI_EMR_MR16` ((`uint32_t`)0x00010000)
- #define `EXTI_EMR_MR17` ((`uint32_t`)0x00020000)
- #define `EXTI_EMR_MR18` ((`uint32_t`)0x00040000)
- #define `EXTI_EMR_MR19` ((`uint32_t`)0x00080000)
- #define `EXTI_EMR_MR23` ((`uint32_t`)0x00800000)
- #define `EXTI_RTSR_TR0` ((`uint32_t`)0x00000001)
- #define `EXTI_RTSR_TR1` ((`uint32_t`)0x00000002)
- #define `EXTI_RTSR_TR2` ((`uint32_t`)0x00000004)
- #define `EXTI_RTSR_TR3` ((`uint32_t`)0x00000008)
- #define `EXTI_RTSR_TR4` ((`uint32_t`)0x00000010)
- #define `EXTI_RTSR_TR5` ((`uint32_t`)0x00000020)
- #define `EXTI_RTSR_TR6` ((`uint32_t`)0x00000040)
- #define `EXTI_RTSR_TR7` ((`uint32_t`)0x00000080)
- #define `EXTI_RTSR_TR8` ((`uint32_t`)0x00000100)
- #define `EXTI_RTSR_TR9` ((`uint32_t`)0x00000200)
- #define `EXTI_RTSR_TR10` ((`uint32_t`)0x00000400)
- #define `EXTI_RTSR_TR11` ((`uint32_t`)0x00000800)
- #define `EXTI_RTSR_TR12` ((`uint32_t`)0x00001000)
- #define `EXTI_RTSR_TR13` ((`uint32_t`)0x00002000)
- #define `EXTI_RTSR_TR14` ((`uint32_t`)0x00004000)
- #define `EXTI_RTSR_TR15` ((`uint32_t`)0x00008000)
- #define `EXTI_RTSR_TR16` ((`uint32_t`)0x00010000)
- #define `EXTI_RTSR_TR17` ((`uint32_t`)0x00020000)
- #define `EXTI_RTSR_TR18` ((`uint32_t`)0x00040000)
- #define `EXTI_RTSR_TR19` ((`uint32_t`)0x00080000)
- #define `EXTI_RTSR_TR23` ((`uint32_t`)0x00800000)
- #define `EXTI_FTSR_TR0` ((`uint32_t`)0x00000001)
- #define `EXTI_FTSR_TR1` ((`uint32_t`)0x00000002)
- #define `EXTI_FTSR_TR2` ((`uint32_t`)0x00000004)
- #define `EXTI_FTSR_TR3` ((`uint32_t`)0x00000008)
- #define `EXTI_FTSR_TR4` ((`uint32_t`)0x00000010)
- #define `EXTI_FTSR_TR5` ((`uint32_t`)0x00000020)
- #define `EXTI_FTSR_TR6` ((`uint32_t`)0x00000040)
- #define `EXTI_FTSR_TR7` ((`uint32_t`)0x00000080)
- #define `EXTI_FTSR_TR8` ((`uint32_t`)0x00000100)
- #define `EXTI_FTSR_TR9` ((`uint32_t`)0x00000200)
- #define `EXTI_FTSR_TR10` ((`uint32_t`)0x00000400)
- #define `EXTI_FTSR_TR11` ((`uint32_t`)0x00000800)

- #define **EXTI\_FTSR\_TR12** ((uint32\_t)0x00001000)
- #define **EXTI\_FTSR\_TR13** ((uint32\_t)0x00002000)
- #define **EXTI\_FTSR\_TR14** ((uint32\_t)0x00004000)
- #define **EXTI\_FTSR\_TR15** ((uint32\_t)0x00008000)
- #define **EXTI\_FTSR\_TR16** ((uint32\_t)0x00010000)
- #define **EXTI\_FTSR\_TR17** ((uint32\_t)0x00020000)
- #define **EXTI\_FTSR\_TR18** ((uint32\_t)0x00040000)
- #define **EXTI\_FTSR\_TR19** ((uint32\_t)0x00080000)
- #define **EXTI\_FTSR\_TR23** ((uint32\_t)0x00800000)
- #define **EXTI\_SWIER\_SWIER0** ((uint32\_t)0x00000001)
- #define **EXTI\_SWIER\_SWIER1** ((uint32\_t)0x00000002)
- #define **EXTI\_SWIER\_SWIER2** ((uint32\_t)0x00000004)
- #define **EXTI\_SWIER\_SWIER3** ((uint32\_t)0x00000008)
- #define **EXTI\_SWIER\_SWIER4** ((uint32\_t)0x00000010)
- #define **EXTI\_SWIER\_SWIER5** ((uint32\_t)0x00000020)
- #define **EXTI\_SWIER\_SWIER6** ((uint32\_t)0x00000040)
- #define **EXTI\_SWIER\_SWIER7** ((uint32\_t)0x00000080)
- #define **EXTI\_SWIER\_SWIER8** ((uint32\_t)0x00000100)
- #define **EXTI\_SWIER\_SWIER9** ((uint32\_t)0x00000200)
- #define **EXTI\_SWIER\_SWIER10** ((uint32\_t)0x00000400)
- #define **EXTI\_SWIER\_SWIER11** ((uint32\_t)0x00000800)
- #define **EXTI\_SWIER\_SWIER12** ((uint32\_t)0x00001000)
- #define **EXTI\_SWIER\_SWIER13** ((uint32\_t)0x00002000)
- #define **EXTI\_SWIER\_SWIER14** ((uint32\_t)0x00004000)
- #define **EXTI\_SWIER\_SWIER15** ((uint32\_t)0x00008000)
- #define **EXTI\_SWIER\_SWIER16** ((uint32\_t)0x00010000)
- #define **EXTI\_SWIER\_SWIER17** ((uint32\_t)0x00020000)
- #define **EXTI\_SWIER\_SWIER18** ((uint32\_t)0x00040000)
- #define **EXTI\_SWIER\_SWIER19** ((uint32\_t)0x00080000)
- #define **EXTI\_SWIER\_SWIER23** ((uint32\_t)0x00800000)
- #define **EXTI\_PR\_PR0** ((uint32\_t)0x00000001)
- #define **EXTI\_PR\_PR1** ((uint32\_t)0x00000002)
- #define **EXTI\_PR\_PR2** ((uint32\_t)0x00000004)
- #define **EXTI\_PR\_PR3** ((uint32\_t)0x00000008)
- #define **EXTI\_PR\_PR4** ((uint32\_t)0x00000010)
- #define **EXTI\_PR\_PR5** ((uint32\_t)0x00000020)
- #define **EXTI\_PR\_PR6** ((uint32\_t)0x00000040)
- #define **EXTI\_PR\_PR7** ((uint32\_t)0x00000080)
- #define **EXTI\_PR\_PR8** ((uint32\_t)0x00000100)
- #define **EXTI\_PR\_PR9** ((uint32\_t)0x00000200)
- #define **EXTI\_PR\_PR10** ((uint32\_t)0x00000400)
- #define **EXTI\_PR\_PR11** ((uint32\_t)0x00000800)
- #define **EXTI\_PR\_PR12** ((uint32\_t)0x00001000)
- #define **EXTI\_PR\_PR13** ((uint32\_t)0x00002000)
- #define **EXTI\_PR\_PR14** ((uint32\_t)0x00004000)
- #define **EXTI\_PR\_PR15** ((uint32\_t)0x00008000)
- #define **EXTI\_PR\_PR16** ((uint32\_t)0x00010000)
- #define **EXTI\_PR\_PR17** ((uint32\_t)0x00020000)
- #define **EXTI\_PR\_PR18** ((uint32\_t)0x00040000)
- #define **EXTI\_PR\_PR19** ((uint32\_t)0x00080000)
- #define **EXTI\_PR\_PR23** ((uint32\_t)0x00800000)
- #define **FLASH\_ACR\_LATENCY** ((uint32\_t)0x0000000F)
- #define **FLASH\_ACR\_LATENCY\_0WS** ((uint32\_t)0x00000000)
- #define **FLASH\_ACR\_LATENCY\_1WS** ((uint32\_t)0x00000001)
- #define **FLASH\_ACR\_LATENCY\_2WS** ((uint32\_t)0x00000002)

- #define **FLASH\_ACR\_LATENCY\_3WS** ((uint32\_t)0x00000003)
- #define **FLASH\_ACR\_LATENCY\_4WS** ((uint32\_t)0x00000004)
- #define **FLASH\_ACR\_LATENCY\_5WS** ((uint32\_t)0x00000005)
- #define **FLASH\_ACR\_LATENCY\_6WS** ((uint32\_t)0x00000006)
- #define **FLASH\_ACR\_LATENCY\_7WS** ((uint32\_t)0x00000007)
- #define **FLASH\_ACR\_LATENCY\_8WS** ((uint32\_t)0x00000008)
- #define **FLASH\_ACR\_LATENCY\_9WS** ((uint32\_t)0x00000009)
- #define **FLASH\_ACR\_LATENCY\_10WS** ((uint32\_t)0x0000000A)
- #define **FLASH\_ACR\_LATENCY\_11WS** ((uint32\_t)0x0000000B)
- #define **FLASH\_ACR\_LATENCY\_12WS** ((uint32\_t)0x0000000C)
- #define **FLASH\_ACR\_LATENCY\_13WS** ((uint32\_t)0x0000000D)
- #define **FLASH\_ACR\_LATENCY\_14WS** ((uint32\_t)0x0000000E)
- #define **FLASH\_ACR\_LATENCY\_15WS** ((uint32\_t)0x0000000F)
- #define **FLASH\_ACR\_PRFTEN** ((uint32\_t)0x00000100)
- #define **FLASH\_ACR\_ICEN** ((uint32\_t)0x00000200)
- #define **FLASH\_ACR\_DCEN** ((uint32\_t)0x00000400)
- #define **FLASH\_ACR\_ICRST** ((uint32\_t)0x00000800)
- #define **FLASH\_ACR\_DCRST** ((uint32\_t)0x00001000)
- #define **FLASH\_ACR\_BYTE0\_ADDRESS** ((uint32\_t)0x40023C00)
- #define **FLASH\_ACR\_BYTE2\_ADDRESS** ((uint32\_t)0x40023C03)
- #define **FLASH\_SR\_EOP** ((uint32\_t)0x00000001)
- #define **FLASH\_SR\_SOP** ((uint32\_t)0x00000002)
- #define **FLASH\_SR\_WRPERR** ((uint32\_t)0x00000010)
- #define **FLASH\_SR\_PGAERR** ((uint32\_t)0x00000020)
- #define **FLASH\_SR\_PGPERR** ((uint32\_t)0x00000040)
- #define **FLASH\_SR\_PGSERR** ((uint32\_t)0x00000080)
- #define **FLASH\_SR\_BSY** ((uint32\_t)0x00010000)
- #define **FLASH\_CR\_PG** ((uint32\_t)0x00000001)
- #define **FLASH\_CR\_SER** ((uint32\_t)0x00000002)
- #define **FLASH\_CR\_MER** ((uint32\_t)0x00000004)
- #define **FLASH\_CR\_MER1** **FLASH\_CR\_MER**
- #define **FLASH\_CR\_SNBB** ((uint32\_t)0x000000F8)
- #define **FLASH\_CR\_SNBB\_0** ((uint32\_t)0x00000008)
- #define **FLASH\_CR\_SNBB\_1** ((uint32\_t)0x00000010)
- #define **FLASH\_CR\_SNBB\_2** ((uint32\_t)0x00000020)
- #define **FLASH\_CR\_SNBB\_3** ((uint32\_t)0x00000040)
- #define **FLASH\_CR\_SNBB\_4** ((uint32\_t)0x00000040)
- #define **FLASH\_CR\_PSIZE** ((uint32\_t)0x00000300)
- #define **FLASH\_CR\_PSIZE\_0** ((uint32\_t)0x00000100)
- #define **FLASH\_CR\_PSIZE\_1** ((uint32\_t)0x00000200)
- #define **FLASH\_CR\_MER2** ((uint32\_t)0x00008000)
- #define **FLASH\_CR\_STRT** ((uint32\_t)0x00010000)
- #define **FLASH\_CR\_EOPIE** ((uint32\_t)0x01000000)
- #define **FLASH\_CR\_LOCK** ((uint32\_t)0x80000000)
- #define **FLASH\_OPTCR\_OPTLOCK** ((uint32\_t)0x00000001)
- #define **FLASH\_OPTCR\_OPTSTRT** ((uint32\_t)0x00000002)
- #define **FLASH\_OPTCR\_BORLEV\_0** ((uint32\_t)0x00000004)
- #define **FLASH\_OPTCR\_BORLEV\_1** ((uint32\_t)0x00000008)
- #define **FLASH\_OPTCR\_BORLEV** ((uint32\_t)0x0000000C)
- #define **FLASH\_OPTCR\_BFB2** ((uint32\_t)0x00000010)
- #define **FLASH\_OPTCR\_WDG\_SW** ((uint32\_t)0x00000020)
- #define **FLASH\_OPTCR\_nRST\_STOP** ((uint32\_t)0x00000040)
- #define **FLASH\_OPTCR\_nRST\_STDBY** ((uint32\_t)0x00000080)
- #define **FLASH\_OPTCR\_RDP** ((uint32\_t)0x0000FF00)
- #define **FLASH\_OPTCR\_RDP\_0** ((uint32\_t)0x00000100)

- #define **FLASH\_OPTCR\_RDP\_1** ((uint32\_t)0x00000200)
- #define **FLASH\_OPTCR\_RDP\_2** ((uint32\_t)0x00000400)
- #define **FLASH\_OPTCR\_RDP\_3** ((uint32\_t)0x00000800)
- #define **FLASH\_OPTCR\_RDP\_4** ((uint32\_t)0x00001000)
- #define **FLASH\_OPTCR\_RDP\_5** ((uint32\_t)0x00002000)
- #define **FLASH\_OPTCR\_RDP\_6** ((uint32\_t)0x00004000)
- #define **FLASH\_OPTCR\_RDP\_7** ((uint32\_t)0x00008000)
- #define **FLASH\_OPTCR\_nWRP** ((uint32\_t)0xFFFF0000)
- #define **FLASH\_OPTCR\_nWRP\_0** ((uint32\_t)0x00010000)
- #define **FLASH\_OPTCR\_nWRP\_1** ((uint32\_t)0x00020000)
- #define **FLASH\_OPTCR\_nWRP\_2** ((uint32\_t)0x00040000)
- #define **FLASH\_OPTCR\_nWRP\_3** ((uint32\_t)0x00080000)
- #define **FLASH\_OPTCR\_nWRP\_4** ((uint32\_t)0x00100000)
- #define **FLASH\_OPTCR\_nWRP\_5** ((uint32\_t)0x00200000)
- #define **FLASH\_OPTCR\_nWRP\_6** ((uint32\_t)0x00400000)
- #define **FLASH\_OPTCR\_nWRP\_7** ((uint32\_t)0x00800000)
- #define **FLASH\_OPTCR\_nWRP\_8** ((uint32\_t)0x01000000)
- #define **FLASH\_OPTCR\_nWRP\_9** ((uint32\_t)0x02000000)
- #define **FLASH\_OPTCR\_nWRP\_10** ((uint32\_t)0x04000000)
- #define **FLASH\_OPTCR\_nWRP\_11** ((uint32\_t)0x08000000)
- #define **FLASH\_OPTCR\_DB1M** ((uint32\_t)0x40000000)
- #define **FLASH\_OPTCR\_SPRMOD** ((uint32\_t)0x80000000)
- #define **FLASH\_OPTCR1\_nWRP** ((uint32\_t)0xFFFF0000)
- #define **FLASH\_OPTCR1\_nWRP\_0** ((uint32\_t)0x00010000)
- #define **FLASH\_OPTCR1\_nWRP\_1** ((uint32\_t)0x00020000)
- #define **FLASH\_OPTCR1\_nWRP\_2** ((uint32\_t)0x00040000)
- #define **FLASH\_OPTCR1\_nWRP\_3** ((uint32\_t)0x00080000)
- #define **FLASH\_OPTCR1\_nWRP\_4** ((uint32\_t)0x00100000)
- #define **FLASH\_OPTCR1\_nWRP\_5** ((uint32\_t)0x00200000)
- #define **FLASH\_OPTCR1\_nWRP\_6** ((uint32\_t)0x00400000)
- #define **FLASH\_OPTCR1\_nWRP\_7** ((uint32\_t)0x00800000)
- #define **FLASH\_OPTCR1\_nWRP\_8** ((uint32\_t)0x01000000)
- #define **FLASH\_OPTCR1\_nWRP\_9** ((uint32\_t)0x02000000)
- #define **FLASH\_OPTCR1\_nWRP\_10** ((uint32\_t)0x04000000)
- #define **FLASH\_OPTCR1\_nWRP\_11** ((uint32\_t)0x08000000)
- #define **GPIO\_MODER\_MODERO** ((uint32\_t)0x00000003)
- #define **GPIO\_MODER\_MODERO\_0** ((uint32\_t)0x00000001)
- #define **GPIO\_MODER\_MODERO\_1** ((uint32\_t)0x00000002)
- #define **GPIO\_MODER\_MODERO1** ((uint32\_t)0x0000000C)
- #define **GPIO\_MODER\_MODER1\_0** ((uint32\_t)0x00000004)
- #define **GPIO\_MODER\_MODER1\_1** ((uint32\_t)0x00000008)
- #define **GPIO\_MODER\_MODER2** ((uint32\_t)0x00000030)
- #define **GPIO\_MODER\_MODER2\_0** ((uint32\_t)0x00000010)
- #define **GPIO\_MODER\_MODER2\_1** ((uint32\_t)0x00000020)
- #define **GPIO\_MODER\_MODER3** ((uint32\_t)0x000000C0)
- #define **GPIO\_MODER\_MODER3\_0** ((uint32\_t)0x00000040)
- #define **GPIO\_MODER\_MODER3\_1** ((uint32\_t)0x00000080)
- #define **GPIO\_MODER\_MODER4** ((uint32\_t)0x00000300)
- #define **GPIO\_MODER\_MODER4\_0** ((uint32\_t)0x00000100)
- #define **GPIO\_MODER\_MODER4\_1** ((uint32\_t)0x00000200)
- #define **GPIO\_MODER\_MODER5** ((uint32\_t)0x00000C00)
- #define **GPIO\_MODER\_MODER5\_0** ((uint32\_t)0x00000400)
- #define **GPIO\_MODER\_MODER5\_1** ((uint32\_t)0x00000800)
- #define **GPIO\_MODER\_MODER6** ((uint32\_t)0x00003000)
- #define **GPIO\_MODER\_MODER6\_0** ((uint32\_t)0x00001000)

- #define **GPIO\_MODER\_MODER6\_1** ((uint32\_t)0x00002000)
- #define **GPIO\_MODER\_MODER7** ((uint32\_t)0x0000C000)
- #define **GPIO\_MODER\_MODER7\_0** ((uint32\_t)0x00004000)
- #define **GPIO\_MODER\_MODER7\_1** ((uint32\_t)0x00008000)
- #define **GPIO\_MODER\_MODER8** ((uint32\_t)0x00030000)
- #define **GPIO\_MODER\_MODER8\_0** ((uint32\_t)0x00010000)
- #define **GPIO\_MODER\_MODER8\_1** ((uint32\_t)0x00020000)
- #define **GPIO\_MODER\_MODER9** ((uint32\_t)0x000C0000)
- #define **GPIO\_MODER\_MODER9\_0** ((uint32\_t)0x00040000)
- #define **GPIO\_MODER\_MODER9\_1** ((uint32\_t)0x00080000)
- #define **GPIO\_MODER\_MODER10** ((uint32\_t)0x00300000)
- #define **GPIO\_MODER\_MODER10\_0** ((uint32\_t)0x00100000)
- #define **GPIO\_MODER\_MODER10\_1** ((uint32\_t)0x00200000)
- #define **GPIO\_MODER\_MODER11** ((uint32\_t)0x00C00000)
- #define **GPIO\_MODER\_MODER11\_0** ((uint32\_t)0x00400000)
- #define **GPIO\_MODER\_MODER11\_1** ((uint32\_t)0x00800000)
- #define **GPIO\_MODER\_MODER12** ((uint32\_t)0x03000000)
- #define **GPIO\_MODER\_MODER12\_0** ((uint32\_t)0x01000000)
- #define **GPIO\_MODER\_MODER12\_1** ((uint32\_t)0x02000000)
- #define **GPIO\_MODER\_MODER13** ((uint32\_t)0x0C000000)
- #define **GPIO\_MODER\_MODER13\_0** ((uint32\_t)0x04000000)
- #define **GPIO\_MODER\_MODER13\_1** ((uint32\_t)0x08000000)
- #define **GPIO\_MODER\_MODER14** ((uint32\_t)0x30000000)
- #define **GPIO\_MODER\_MODER14\_0** ((uint32\_t)0x10000000)
- #define **GPIO\_MODER\_MODER14\_1** ((uint32\_t)0x20000000)
- #define **GPIO\_MODER\_MODER15** ((uint32\_t)0xC0000000)
- #define **GPIO\_MODER\_MODER15\_0** ((uint32\_t)0x40000000)
- #define **GPIO\_MODER\_MODER15\_1** ((uint32\_t)0x80000000)
- #define **GPIO\_OTYPER\_OT\_0** ((uint32\_t)0x00000001)
- #define **GPIO\_OTYPER\_OT\_1** ((uint32\_t)0x00000002)
- #define **GPIO\_OTYPER\_OT\_2** ((uint32\_t)0x00000004)
- #define **GPIO\_OTYPER\_OT\_3** ((uint32\_t)0x00000008)
- #define **GPIO\_OTYPER\_OT\_4** ((uint32\_t)0x00000010)
- #define **GPIO\_OTYPER\_OT\_5** ((uint32\_t)0x00000020)
- #define **GPIO\_OTYPER\_OT\_6** ((uint32\_t)0x00000040)
- #define **GPIO\_OTYPER\_OT\_7** ((uint32\_t)0x00000080)
- #define **GPIO\_OTYPER\_OT\_8** ((uint32\_t)0x00000100)
- #define **GPIO\_OTYPER\_OT\_9** ((uint32\_t)0x00000200)
- #define **GPIO\_OTYPER\_OT\_10** ((uint32\_t)0x00000400)
- #define **GPIO\_OTYPER\_OT\_11** ((uint32\_t)0x00000800)
- #define **GPIO\_OTYPER\_OT\_12** ((uint32\_t)0x00001000)
- #define **GPIO\_OTYPER\_OT\_13** ((uint32\_t)0x00002000)
- #define **GPIO\_OTYPER\_OT\_14** ((uint32\_t)0x00004000)
- #define **GPIO\_OTYPER\_OT\_15** ((uint32\_t)0x00008000)
- #define **GPIO\_OSPEEDER\_OSPEEDR0** ((uint32\_t)0x00000003)
- #define **GPIO\_OSPEEDER\_OSPEEDR0\_0** ((uint32\_t)0x00000001)
- #define **GPIO\_OSPEEDER\_OSPEEDR0\_1** ((uint32\_t)0x00000002)
- #define **GPIO\_OSPEEDER\_OSPEEDR1** ((uint32\_t)0x0000000C)
- #define **GPIO\_OSPEEDER\_OSPEEDR1\_0** ((uint32\_t)0x00000004)
- #define **GPIO\_OSPEEDER\_OSPEEDR1\_1** ((uint32\_t)0x00000008)
- #define **GPIO\_OSPEEDER\_OSPEEDR2** ((uint32\_t)0x00000030)
- #define **GPIO\_OSPEEDER\_OSPEEDR2\_0** ((uint32\_t)0x00000010)
- #define **GPIO\_OSPEEDER\_OSPEEDR2\_1** ((uint32\_t)0x00000020)
- #define **GPIO\_OSPEEDER\_OSPEEDR3** ((uint32\_t)0x000000C0)
- #define **GPIO\_OSPEEDER\_OSPEEDR3\_0** ((uint32\_t)0x00000040)

- #define **GPIO\_OSPEEDER\_OSPEEDR3\_1** ((uint32\_t)0x00000080)
- #define **GPIO\_OSPEEDER\_OSPEEDR4** ((uint32\_t)0x000000300)
- #define **GPIO\_OSPEEDER\_OSPEEDR4\_0** ((uint32\_t)0x000000100)
- #define **GPIO\_OSPEEDER\_OSPEEDR4\_1** ((uint32\_t)0x000000200)
- #define **GPIO\_OSPEEDER\_OSPEEDR5** ((uint32\_t)0x00000C00)
- #define **GPIO\_OSPEEDER\_OSPEEDR5\_0** ((uint32\_t)0x000000400)
- #define **GPIO\_OSPEEDER\_OSPEEDR5\_1** ((uint32\_t)0x000000800)
- #define **GPIO\_OSPEEDER\_OSPEEDR6** ((uint32\_t)0x000003000)
- #define **GPIO\_OSPEEDER\_OSPEEDR6\_0** ((uint32\_t)0x000001000)
- #define **GPIO\_OSPEEDER\_OSPEEDR6\_1** ((uint32\_t)0x000002000)
- #define **GPIO\_OSPEEDER\_OSPEEDR7** ((uint32\_t)0x00000C000)
- #define **GPIO\_OSPEEDER\_OSPEEDR7\_0** ((uint32\_t)0x000004000)
- #define **GPIO\_OSPEEDER\_OSPEEDR7\_1** ((uint32\_t)0x000008000)
- #define **GPIO\_OSPEEDER\_OSPEEDR8** ((uint32\_t)0x000300000)
- #define **GPIO\_OSPEEDER\_OSPEEDR8\_0** ((uint32\_t)0x000100000)
- #define **GPIO\_OSPEEDER\_OSPEEDR8\_1** ((uint32\_t)0x000200000)
- #define **GPIO\_OSPEEDER\_OSPEEDR9** ((uint32\_t)0x000C00000)
- #define **GPIO\_OSPEEDER\_OSPEEDR9\_0** ((uint32\_t)0x000400000)
- #define **GPIO\_OSPEEDER\_OSPEEDR9\_1** ((uint32\_t)0x000800000)
- #define **GPIO\_OSPEEDER\_OSPEEDR10** ((uint32\_t)0x003000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR10\_0** ((uint32\_t)0x001000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR10\_1** ((uint32\_t)0x002000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR11** ((uint32\_t)0x00C000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR11\_0** ((uint32\_t)0x004000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR11\_1** ((uint32\_t)0x008000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR12** ((uint32\_t)0x030000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR12\_0** ((uint32\_t)0x010000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR12\_1** ((uint32\_t)0x020000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR13** ((uint32\_t)0x0C0000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR13\_0** ((uint32\_t)0x040000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR13\_1** ((uint32\_t)0x080000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR14** ((uint32\_t)0x300000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR14\_0** ((uint32\_t)0x100000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR14\_1** ((uint32\_t)0x200000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR15** ((uint32\_t)0xC00000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR15\_0** ((uint32\_t)0x400000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR15\_1** ((uint32\_t)0x800000000)
- #define **GPIO\_PUPDR\_PUPDR0** ((uint32\_t)0x00000003)
- #define **GPIO\_PUPDR\_PUPDR0\_0** ((uint32\_t)0x000000001)
- #define **GPIO\_PUPDR\_PUPDR0\_1** ((uint32\_t)0x000000002)
- #define **GPIO\_PUPDR\_PUPDR1** ((uint32\_t)0x00000000C)
- #define **GPIO\_PUPDR\_PUPDR1\_0** ((uint32\_t)0x000000004)
- #define **GPIO\_PUPDR\_PUPDR1\_1** ((uint32\_t)0x000000008)
- #define **GPIO\_PUPDR\_PUPDR2** ((uint32\_t)0x000000030)
- #define **GPIO\_PUPDR\_PUPDR2\_0** ((uint32\_t)0x000000010)
- #define **GPIO\_PUPDR\_PUPDR2\_1** ((uint32\_t)0x000000020)
- #define **GPIO\_PUPDR\_PUPDR3** ((uint32\_t)0x0000000C0)
- #define **GPIO\_PUPDR\_PUPDR3\_0** ((uint32\_t)0x000000040)
- #define **GPIO\_PUPDR\_PUPDR3\_1** ((uint32\_t)0x000000080)
- #define **GPIO\_PUPDR\_PUPDR4** ((uint32\_t)0x000000300)
- #define **GPIO\_PUPDR\_PUPDR4\_0** ((uint32\_t)0x000000100)
- #define **GPIO\_PUPDR\_PUPDR4\_1** ((uint32\_t)0x000000200)
- #define **GPIO\_PUPDR\_PUPDR5** ((uint32\_t)0x00000C00)
- #define **GPIO\_PUPDR\_PUPDR5\_0** ((uint32\_t)0x00000400)
- #define **GPIO\_PUPDR\_PUPDR5\_1** ((uint32\_t)0x00000800)

- #define **GPIO\_PUPDR\_PUPDR6** ((uint32\_t)0x00003000)
- #define **GPIO\_PUPDR\_PUPDR6\_0** ((uint32\_t)0x00001000)
- #define **GPIO\_PUPDR\_PUPDR6\_1** ((uint32\_t)0x00002000)
- #define **GPIO\_PUPDR\_PUPDR7** ((uint32\_t)0x0000C000)
- #define **GPIO\_PUPDR\_PUPDR7\_0** ((uint32\_t)0x00004000)
- #define **GPIO\_PUPDR\_PUPDR7\_1** ((uint32\_t)0x00008000)
- #define **GPIO\_PUPDR\_PUPDR8** ((uint32\_t)0x00030000)
- #define **GPIO\_PUPDR\_PUPDR8\_0** ((uint32\_t)0x00010000)
- #define **GPIO\_PUPDR\_PUPDR8\_1** ((uint32\_t)0x00020000)
- #define **GPIO\_PUPDR\_PUPDR9** ((uint32\_t)0x000C0000)
- #define **GPIO\_PUPDR\_PUPDR9\_0** ((uint32\_t)0x00040000)
- #define **GPIO\_PUPDR\_PUPDR9\_1** ((uint32\_t)0x00080000)
- #define **GPIO\_PUPDR\_PUPDR10** ((uint32\_t)0x00300000)
- #define **GPIO\_PUPDR\_PUPDR10\_0** ((uint32\_t)0x00100000)
- #define **GPIO\_PUPDR\_PUPDR10\_1** ((uint32\_t)0x00200000)
- #define **GPIO\_PUPDR\_PUPDR11** ((uint32\_t)0x00C00000)
- #define **GPIO\_PUPDR\_PUPDR11\_0** ((uint32\_t)0x00400000)
- #define **GPIO\_PUPDR\_PUPDR11\_1** ((uint32\_t)0x00800000)
- #define **GPIO\_PUPDR\_PUPDR12** ((uint32\_t)0x03000000)
- #define **GPIO\_PUPDR\_PUPDR12\_0** ((uint32\_t)0x01000000)
- #define **GPIO\_PUPDR\_PUPDR12\_1** ((uint32\_t)0x02000000)
- #define **GPIO\_PUPDR\_PUPDR13** ((uint32\_t)0x0C000000)
- #define **GPIO\_PUPDR\_PUPDR13\_0** ((uint32\_t)0x04000000)
- #define **GPIO\_PUPDR\_PUPDR13\_1** ((uint32\_t)0x08000000)
- #define **GPIO\_PUPDR\_PUPDR14** ((uint32\_t)0x30000000)
- #define **GPIO\_PUPDR\_PUPDR14\_0** ((uint32\_t)0x10000000)
- #define **GPIO\_PUPDR\_PUPDR14\_1** ((uint32\_t)0x20000000)
- #define **GPIO\_PUPDR\_PUPDR15** ((uint32\_t)0xC0000000)
- #define **GPIO\_PUPDR\_PUPDR15\_0** ((uint32\_t)0x40000000)
- #define **GPIO\_PUPDR\_PUPDR15\_1** ((uint32\_t)0x80000000)
- #define **GPIO\_IDR\_IDR\_0** ((uint32\_t)0x00000001)
- #define **GPIO\_IDR\_IDR\_1** ((uint32\_t)0x00000002)
- #define **GPIO\_IDR\_IDR\_2** ((uint32\_t)0x00000004)
- #define **GPIO\_IDR\_IDR\_3** ((uint32\_t)0x00000008)
- #define **GPIO\_IDR\_IDR\_4** ((uint32\_t)0x00000010)
- #define **GPIO\_IDR\_IDR\_5** ((uint32\_t)0x00000020)
- #define **GPIO\_IDR\_IDR\_6** ((uint32\_t)0x00000040)
- #define **GPIO\_IDR\_IDR\_7** ((uint32\_t)0x00000080)
- #define **GPIO\_IDR\_IDR\_8** ((uint32\_t)0x00000100)
- #define **GPIO\_IDR\_IDR\_9** ((uint32\_t)0x00000200)
- #define **GPIO\_IDR\_IDR\_10** ((uint32\_t)0x00000400)
- #define **GPIO\_IDR\_IDR\_11** ((uint32\_t)0x00000800)
- #define **GPIO\_IDR\_IDR\_12** ((uint32\_t)0x00001000)
- #define **GPIO\_IDR\_IDR\_13** ((uint32\_t)0x00002000)
- #define **GPIO\_IDR\_IDR\_14** ((uint32\_t)0x00004000)
- #define **GPIO\_IDR\_IDR\_15** ((uint32\_t)0x00008000)
- #define **GPIO\_OTYPER\_IDR\_0** GPIO\_IDR\_IDR\_0
- #define **GPIO\_OTYPER\_IDR\_1** GPIO\_IDR\_IDR\_1
- #define **GPIO\_OTYPER\_IDR\_2** GPIO\_IDR\_IDR\_2
- #define **GPIO\_OTYPER\_IDR\_3** GPIO\_IDR\_IDR\_3
- #define **GPIO\_OTYPER\_IDR\_4** GPIO\_IDR\_IDR\_4
- #define **GPIO\_OTYPER\_IDR\_5** GPIO\_IDR\_IDR\_5
- #define **GPIO\_OTYPER\_IDR\_6** GPIO\_IDR\_IDR\_6
- #define **GPIO\_OTYPER\_IDR\_7** GPIO\_IDR\_IDR\_7
- #define **GPIO\_OTYPER\_IDR\_8** GPIO\_IDR\_IDR\_8

- #define **GPIO\_OTYPER\_IDR\_9** GPIO\_IDR\_IDR\_9
- #define **GPIO\_OTYPER\_IDR\_10** GPIO\_IDR\_IDR\_10
- #define **GPIO\_OTYPER\_IDR\_11** GPIO\_IDR\_IDR\_11
- #define **GPIO\_OTYPER\_IDR\_12** GPIO\_IDR\_IDR\_12
- #define **GPIO\_OTYPER\_IDR\_13** GPIO\_IDR\_IDR\_13
- #define **GPIO\_OTYPER\_IDR\_14** GPIO\_IDR\_IDR\_14
- #define **GPIO\_OTYPER\_IDR\_15** GPIO\_IDR\_IDR\_15
- #define **GPIO\_ODR\_ODR\_0** ((uint32\_t)0x00000001)
- #define **GPIO\_ODR\_ODR\_1** ((uint32\_t)0x00000002)
- #define **GPIO\_ODR\_ODR\_2** ((uint32\_t)0x00000004)
- #define **GPIO\_ODR\_ODR\_3** ((uint32\_t)0x00000008)
- #define **GPIO\_ODR\_ODR\_4** ((uint32\_t)0x00000010)
- #define **GPIO\_ODR\_ODR\_5** ((uint32\_t)0x00000020)
- #define **GPIO\_ODR\_ODR\_6** ((uint32\_t)0x00000040)
- #define **GPIO\_ODR\_ODR\_7** ((uint32\_t)0x00000080)
- #define **GPIO\_ODR\_ODR\_8** ((uint32\_t)0x00000100)
- #define **GPIO\_ODR\_ODR\_9** ((uint32\_t)0x00000200)
- #define **GPIO\_ODR\_ODR\_10** ((uint32\_t)0x00000400)
- #define **GPIO\_ODR\_ODR\_11** ((uint32\_t)0x00000800)
- #define **GPIO\_ODR\_ODR\_12** ((uint32\_t)0x00001000)
- #define **GPIO\_ODR\_ODR\_13** ((uint32\_t)0x00002000)
- #define **GPIO\_ODR\_ODR\_14** ((uint32\_t)0x00004000)
- #define **GPIO\_ODR\_ODR\_15** ((uint32\_t)0x00008000)
- #define **GPIO\_OTYPER\_ODR\_0** GPIO\_ODR\_ODR\_0
- #define **GPIO\_OTYPER\_ODR\_1** GPIO\_ODR\_ODR\_1
- #define **GPIO\_OTYPER\_ODR\_2** GPIO\_ODR\_ODR\_2
- #define **GPIO\_OTYPER\_ODR\_3** GPIO\_ODR\_ODR\_3
- #define **GPIO\_OTYPER\_ODR\_4** GPIO\_ODR\_ODR\_4
- #define **GPIO\_OTYPER\_ODR\_5** GPIO\_ODR\_ODR\_5
- #define **GPIO\_OTYPER\_ODR\_6** GPIO\_ODR\_ODR\_6
- #define **GPIO\_OTYPER\_ODR\_7** GPIO\_ODR\_ODR\_7
- #define **GPIO\_OTYPER\_ODR\_8** GPIO\_ODR\_ODR\_8
- #define **GPIO\_OTYPER\_ODR\_9** GPIO\_ODR\_ODR\_9
- #define **GPIO\_OTYPER\_ODR\_10** GPIO\_ODR\_ODR\_10
- #define **GPIO\_OTYPER\_ODR\_11** GPIO\_ODR\_ODR\_11
- #define **GPIO\_OTYPER\_ODR\_12** GPIO\_ODR\_ODR\_12
- #define **GPIO\_OTYPER\_ODR\_13** GPIO\_ODR\_ODR\_13
- #define **GPIO\_OTYPER\_ODR\_14** GPIO\_ODR\_ODR\_14
- #define **GPIO\_OTYPER\_ODR\_15** GPIO\_ODR\_ODR\_15
- #define **GPIO\_BSRR\_BS\_0** ((uint32\_t)0x00000001)
- #define **GPIO\_BSRR\_BS\_1** ((uint32\_t)0x00000002)
- #define **GPIO\_BSRR\_BS\_2** ((uint32\_t)0x00000004)
- #define **GPIO\_BSRR\_BS\_3** ((uint32\_t)0x00000008)
- #define **GPIO\_BSRR\_BS\_4** ((uint32\_t)0x00000010)
- #define **GPIO\_BSRR\_BS\_5** ((uint32\_t)0x00000020)
- #define **GPIO\_BSRR\_BS\_6** ((uint32\_t)0x00000040)
- #define **GPIO\_BSRR\_BS\_7** ((uint32\_t)0x00000080)
- #define **GPIO\_BSRR\_BS\_8** ((uint32\_t)0x00000100)
- #define **GPIO\_BSRR\_BS\_9** ((uint32\_t)0x00000200)
- #define **GPIO\_BSRR\_BS\_10** ((uint32\_t)0x00000400)
- #define **GPIO\_BSRR\_BS\_11** ((uint32\_t)0x00000800)
- #define **GPIO\_BSRR\_BS\_12** ((uint32\_t)0x00001000)
- #define **GPIO\_BSRR\_BS\_13** ((uint32\_t)0x00002000)
- #define **GPIO\_BSRR\_BS\_14** ((uint32\_t)0x00004000)
- #define **GPIO\_BSRR\_BS\_15** ((uint32\_t)0x00008000)

- #define **GPIO\_BSRR\_BR\_0** ((uint32\_t)0x00010000)
- #define **GPIO\_BSRR\_BR\_1** ((uint32\_t)0x00020000)
- #define **GPIO\_BSRR\_BR\_2** ((uint32\_t)0x00040000)
- #define **GPIO\_BSRR\_BR\_3** ((uint32\_t)0x00080000)
- #define **GPIO\_BSRR\_BR\_4** ((uint32\_t)0x00100000)
- #define **GPIO\_BSRR\_BR\_5** ((uint32\_t)0x00200000)
- #define **GPIO\_BSRR\_BR\_6** ((uint32\_t)0x00400000)
- #define **GPIO\_BSRR\_BR\_7** ((uint32\_t)0x00800000)
- #define **GPIO\_BSRR\_BR\_8** ((uint32\_t)0x01000000)
- #define **GPIO\_BSRR\_BR\_9** ((uint32\_t)0x02000000)
- #define **GPIO\_BSRR\_BR\_10** ((uint32\_t)0x04000000)
- #define **GPIO\_BSRR\_BR\_11** ((uint32\_t)0x08000000)
- #define **GPIO\_BSRR\_BR\_12** ((uint32\_t)0x10000000)
- #define **GPIO\_BSRR\_BR\_13** ((uint32\_t)0x20000000)
- #define **GPIO\_BSRR\_BR\_14** ((uint32\_t)0x40000000)
- #define **GPIO\_BSRR\_BR\_15** ((uint32\_t)0x80000000)
- #define **HASH\_CR\_INIT** ((uint32\_t)0x00000004)
- #define **HASH\_CR\_DMAE** ((uint32\_t)0x00000008)
- #define **HASH\_CR\_DATATYPE** ((uint32\_t)0x00000030)
- #define **HASH\_CR\_DATATYPE\_0** ((uint32\_t)0x00000010)
- #define **HASH\_CR\_DATATYPE\_1** ((uint32\_t)0x00000020)
- #define **HASH\_CR\_MODE** ((uint32\_t)0x00000040)
- #define **HASH\_CR\_ALGO** ((uint32\_t)0x00040080)
- #define **HASH\_CR\_ALGO\_0** ((uint32\_t)0x00000080)
- #define **HASH\_CR\_ALGO\_1** ((uint32\_t)0x00040000)
- #define **HASH\_CR\_NBW** ((uint32\_t)0x00000F00)
- #define **HASH\_CR\_NBW\_0** ((uint32\_t)0x00000100)
- #define **HASH\_CR\_NBW\_1** ((uint32\_t)0x00000200)
- #define **HASH\_CR\_NBW\_2** ((uint32\_t)0x00000400)
- #define **HASH\_CR\_NBW\_3** ((uint32\_t)0x00000800)
- #define **HASH\_CR\_DINNE** ((uint32\_t)0x00001000)
- #define **HASH\_CR\_MDMAT** ((uint32\_t)0x00002000)
- #define **HASH\_CR\_LKEY** ((uint32\_t)0x00010000)
- #define **HASH\_STR\_NBW** ((uint32\_t)0x0000001F)
- #define **HASH\_STR\_NBW\_0** ((uint32\_t)0x00000001)
- #define **HASH\_STR\_NBW\_1** ((uint32\_t)0x00000002)
- #define **HASH\_STR\_NBW\_2** ((uint32\_t)0x00000004)
- #define **HASH\_STR\_NBW\_3** ((uint32\_t)0x00000008)
- #define **HASH\_STR\_NBW\_4** ((uint32\_t)0x00000010)
- #define **HASH\_STR\_DCAL** ((uint32\_t)0x00000100)
- #define **HASH\_IMR\_DINIM** ((uint32\_t)0x00000001)
- #define **HASH\_IMR\_DCIM** ((uint32\_t)0x00000002)
- #define **HASH\_SR\_DINIS** ((uint32\_t)0x00000001)
- #define **HASH\_SR\_DCIS** ((uint32\_t)0x00000002)
- #define **HASH\_SR\_DMAS** ((uint32\_t)0x00000004)
- #define **HASH\_SR\_BUSY** ((uint32\_t)0x00000008)
- #define **I2C\_CR1\_PE** ((uint16\_t)0x0001)
- #define **I2C\_CR1\_SMBUS** ((uint16\_t)0x0002)
- #define **I2C\_CR1\_SMBTYPE** ((uint16\_t)0x0008)
- #define **I2C\_CR1\_ENARP** ((uint16\_t)0x0010)
- #define **I2C\_CR1\_ENPEC** ((uint16\_t)0x0020)
- #define **I2C\_CR1\_ENGC** ((uint16\_t)0x0040)
- #define **I2C\_CR1\_NOSTRETCH** ((uint16\_t)0x0080)
- #define **I2C\_CR1\_START** ((uint16\_t)0x0100)
- #define **I2C\_CR1\_STOP** ((uint16\_t)0x0200)

- #define I2C\_CR1\_ACK ((uint16\_t)0x0400)
- #define I2C\_CR1\_POS ((uint16\_t)0x0800)
- #define I2C\_CR1\_PEC ((uint16\_t)0x1000)
- #define I2C\_CR1\_ALERT ((uint16\_t)0x2000)
- #define I2C\_CR1\_SWRST ((uint16\_t)0x8000)
- #define I2C\_CR2\_FREQ ((uint16\_t)0x003F)
- #define I2C\_CR2\_FREQ\_0 ((uint16\_t)0x0001)
- #define I2C\_CR2\_FREQ\_1 ((uint16\_t)0x0002)
- #define I2C\_CR2\_FREQ\_2 ((uint16\_t)0x0004)
- #define I2C\_CR2\_FREQ\_3 ((uint16\_t)0x0008)
- #define I2C\_CR2\_FREQ\_4 ((uint16\_t)0x0010)
- #define I2C\_CR2\_FREQ\_5 ((uint16\_t)0x0020)
- #define I2C\_CR2\_ITERREN ((uint16\_t)0x0100)
- #define I2C\_CR2\_IYTEVTEN ((uint16\_t)0x0200)
- #define I2C\_CR2\_ITBUFEN ((uint16\_t)0x0400)
- #define I2C\_CR2\_DMAEN ((uint16\_t)0x0800)
- #define I2C\_CR2\_LAST ((uint16\_t)0x1000)
- #define I2C\_OAR1\_ADD1\_7 ((uint16\_t)0x00FE)
- #define I2C\_OAR1\_ADD8\_9 ((uint16\_t)0x0300)
- #define I2C\_OAR1\_ADD0 ((uint16\_t)0x0001)
- #define I2C\_OAR1\_ADD1 ((uint16\_t)0x0002)
- #define I2C\_OAR1\_ADD2 ((uint16\_t)0x0004)
- #define I2C\_OAR1\_ADD3 ((uint16\_t)0x0008)
- #define I2C\_OAR1\_ADD4 ((uint16\_t)0x0010)
- #define I2C\_OAR1\_ADD5 ((uint16\_t)0x0020)
- #define I2C\_OAR1\_ADD6 ((uint16\_t)0x0040)
- #define I2C\_OAR1\_ADD7 ((uint16\_t)0x0080)
- #define I2C\_OAR1\_ADD8 ((uint16\_t)0x0100)
- #define I2C\_OAR1\_ADD9 ((uint16\_t)0x0200)
- #define I2C\_OAR1\_ADDMODE ((uint16\_t)0x8000)
- #define I2C\_OAR2\_ENDUAL ((uint8\_t)0x01)
- #define I2C\_OAR2\_ADD2 ((uint8\_t)0xFE)
- #define I2C\_DR\_DR ((uint8\_t)0xFF)
- #define I2C\_SR1\_SB ((uint16\_t)0x0001)
- #define I2C\_SR1\_ADDR ((uint16\_t)0x0002)
- #define I2C\_SR1\_BTF ((uint16\_t)0x0004)
- #define I2C\_SR1\_ADD10 ((uint16\_t)0x0008)
- #define I2C\_SR1\_STOPF ((uint16\_t)0x0010)
- #define I2C\_SR1\_RXNE ((uint16\_t)0x0040)
- #define I2C\_SR1\_TXE ((uint16\_t)0x0080)
- #define I2C\_SR1\_BERR ((uint16\_t)0x0100)
- #define I2C\_SR1\_ARLO ((uint16\_t)0x0200)
- #define I2C\_SR1\_AF ((uint16\_t)0x0400)
- #define I2C\_SR1\_OVR ((uint16\_t)0x0800)
- #define I2C\_SR1\_PECERR ((uint16\_t)0x1000)
- #define I2C\_SR1\_TIMEOUT ((uint16\_t)0x4000)
- #define I2C\_SR1\_SMBALERT ((uint16\_t)0x8000)
- #define I2C\_SR2\_MSL ((uint16\_t)0x0001)
- #define I2C\_SR2\_BUSY ((uint16\_t)0x0002)
- #define I2C\_SR2\_TRA ((uint16\_t)0x0004)
- #define I2C\_SR2\_GENCALL ((uint16\_t)0x0010)
- #define I2C\_SR2\_SMBDEFAULT ((uint16\_t)0x0020)
- #define I2C\_SR2\_SMBHOST ((uint16\_t)0x0040)
- #define I2C\_SR2\_DUALF ((uint16\_t)0x0080)
- #define I2C\_SR2\_PEC ((uint16\_t)0xFF00)

- #define I2C\_CCR\_CCR ((uint16\_t)0x0FFF)
- #define I2C\_CCR\_DUTY ((uint16\_t)0x4000)
- #define I2C\_CCR\_FS ((uint16\_t)0x8000)
- #define I2C\_TRISE\_TRISE ((uint8\_t)0x3F)
- #define I2C\_FLTR\_DNF ((uint8\_t)0x0F)
- #define I2C\_FLTR\_ANOFF ((uint8\_t)0x10)
- #define IWDG\_KR\_KEY ((uint16\_t)0xFFFF)
- #define IWDG\_PR\_PR ((uint8\_t)0x07)
- #define IWDG\_PR\_PR\_0 ((uint8\_t)0x01)
- #define IWDG\_PR\_PR\_1 ((uint8\_t)0x02)
- #define IWDG\_PR\_PR\_2 ((uint8\_t)0x04)
- #define IWDG\_RLR\_RL ((uint16\_t)0x0FFF)
- #define IWDG\_SR\_PVU ((uint8\_t)0x01)
- #define IWDG\_SR\_RVU ((uint8\_t)0x02)
- #define LTDC\_SSCR\_VSH ((uint32\_t)0x0000007FF)
- #define LTDC\_SSCR\_HSW ((uint32\_t)0x0FFF0000)
- #define LTDC\_BPCR\_AVBP ((uint32\_t)0x0000007FF)
- #define LTDC\_BPCR\_AHBP ((uint32\_t)0x0FFF0000)
- #define LTDC\_AWCR\_AAH ((uint32\_t)0x0000007FF)
- #define LTDC\_AWCR\_AAW ((uint32\_t)0x0FFF0000)
- #define LTDC\_TWCR\_TOTALH ((uint32\_t)0x0000007FF)
- #define LTDC\_TWCR\_TOTALW ((uint32\_t)0x0FFF0000)
- #define LTDC\_GCR\_LTDCEN ((uint32\_t)0x000000001)
- #define LTDC\_GCR\_DBW ((uint32\_t)0x00000070)
- #define LTDC\_GCR\_DGW ((uint32\_t)0x00000700)
- #define LTDC\_GCR\_DRW ((uint32\_t)0x00007000)
- #define LTDC\_GCR\_DEN ((uint32\_t)0x00010000)
- #define LTDC\_GCR\_PCPOL ((uint32\_t)0x10000000)
- #define LTDC\_GCR\_DEPOL ((uint32\_t)0x20000000)
- #define LTDC\_GCR\_VSPOL ((uint32\_t)0x40000000)
- #define LTDC\_GCR\_HSPOL ((uint32\_t)0x80000000)
- #define LTDC\_GCR\_DTEN LTDC\_GCR\_DEN
- #define LTDC\_SRCR\_IMR ((uint32\_t)0x00000001)
- #define LTDC\_SRCR\_VBR ((uint32\_t)0x00000002)
- #define LTDC\_BCCR\_BCBLUE ((uint32\_t)0x000000FF)
- #define LTDC\_BCCR\_BCGREEN ((uint32\_t)0x0000FF00)
- #define LTDC\_BCCR\_BCRED ((uint32\_t)0x00FF0000)
- #define LTDC\_IER\_LIE ((uint32\_t)0x00000001)
- #define LTDC\_IER\_FUIE ((uint32\_t)0x00000002)
- #define LTDC\_IER\_TERRIE ((uint32\_t)0x00000004)
- #define LTDC\_IER\_RRIE ((uint32\_t)0x00000008)
- #define LTDC\_ISR\_LIF ((uint32\_t)0x00000001)
- #define LTDC\_ISR\_FUIF ((uint32\_t)0x00000002)
- #define LTDC\_ISR\_TERRIF ((uint32\_t)0x00000004)
- #define LTDC\_ISR\_RRIF ((uint32\_t)0x00000008)
- #define LTDC\_ICR\_CLIF ((uint32\_t)0x00000001)
- #define LTDC\_ICR\_CFUIF ((uint32\_t)0x00000002)
- #define LTDC\_ICR\_CTERRIF ((uint32\_t)0x00000004)
- #define LTDC\_ICR\_CRRIF ((uint32\_t)0x00000008)
- #define LTDC\_LIPCR\_LIPOS ((uint32\_t)0x000007FF)
- #define LTDC\_CPSR\_CYPOS ((uint32\_t)0x0000FFFF)
- #define LTDC\_CPSR\_CXPOS ((uint32\_t)0xFFFF0000)
- #define LTDC\_CDSR\_VDES ((uint32\_t)0x00000001)
- #define LTDC\_CDSR\_HDES ((uint32\_t)0x00000002)
- #define LTDC\_CDSR\_VSYNCS ((uint32\_t)0x00000004)

- #define LTDC\_CDSR\_HSYNCS ((uint32\_t)0x00000008)
- #define LTDC\_LxCR\_LEN ((uint32\_t)0x00000001)
- #define LTDC\_LxCR\_COLKEN ((uint32\_t)0x00000002)
- #define LTDC\_LxCR\_CLUTEN ((uint32\_t)0x00000010)
- #define LTDC\_LxWHPCR\_WHSTPOS ((uint32\_t)0x00000FFF)
- #define LTDC\_LxWHPCR\_WHSPPOS ((uint32\_t)0xFFFF0000)
- #define LTDC\_LxWVPCR\_WVSTPOS ((uint32\_t)0x00000FFF)
- #define LTDC\_LxWVPCR\_WVSPPOS ((uint32\_t)0xFFFF0000)
- #define LTDC\_LxCKCR\_CKBLUE ((uint32\_t)0x000000FF)
- #define LTDC\_LxCKCR\_CKGREEN ((uint32\_t)0x0000FF00)
- #define LTDC\_LxCKCR\_CKRED ((uint32\_t)0x00FF0000)
- #define LTDC\_LxPFCR\_PF ((uint32\_t)0x00000007)
- #define LTDC\_LxCACR\_CONSTA ((uint32\_t)0x000000FF)
- #define LTDC\_LxDCCR\_DCBLUE ((uint32\_t)0x000000FF)
- #define LTDC\_LxDCCR\_DCGREEN ((uint32\_t)0x0000FF00)
- #define LTDC\_LxDCCR\_DCRED ((uint32\_t)0x00FF0000)
- #define LTDC\_LxDCCR\_DCALPHA ((uint32\_t)0xFF000000)
- #define LTDC\_LxBFCR\_BF2 ((uint32\_t)0x00000007)
- #define LTDC\_LxBFCR\_BF1 ((uint32\_t)0x00000700)
- #define LTDC\_LxCFBAR\_CFBADD ((uint32\_t)0xFFFFFFFF)
- #define LTDC\_LxCFBLR\_CFBLL ((uint32\_t)0x00001FFF)
- #define LTDC\_LxCFBLNR\_CFBLNBR ((uint32\_t)0x000007FF)
- #define LTDC\_LxCLUTWR\_BLUE ((uint32\_t)0x000000FF)
- #define LTDC\_LxCLUTWR\_GREEN ((uint32\_t)0x0000FF00)
- #define LTDC\_LxCLUTWR\_RED ((uint32\_t)0x00FF0000)
- #define LTDC\_LxCLUTWR\_CLUTADD ((uint32\_t)0xFF000000)
- #define PWR\_CR\_LPDS ((uint32\_t)0x00000001)
- #define PWR\_CR\_PDDS ((uint32\_t)0x00000002)
- #define PWR\_CR\_CWUF ((uint32\_t)0x00000004)
- #define PWR\_CR\_CSBF ((uint32\_t)0x00000008)
- #define PWR\_CR\_PVDE ((uint32\_t)0x00000010)
- #define PWR\_CR\_PLS ((uint32\_t)0x000000E0)
- #define PWR\_CR\_PLS\_0 ((uint32\_t)0x00000020)
- #define PWR\_CR\_PLS\_1 ((uint32\_t)0x00000040)
- #define PWR\_CR\_PLS\_2 ((uint32\_t)0x00000080)
- #define PWR\_CR\_PLS\_LEVO ((uint32\_t)0x00000000)
- #define PWR\_CR\_PLSLEV1 ((uint32\_t)0x00000020)
- #define PWR\_CR\_PLSLEV2 ((uint32\_t)0x00000040)
- #define PWR\_CR\_PLSLEV3 ((uint32\_t)0x00000060)
- #define PWR\_CR\_PLSLEV4 ((uint32\_t)0x00000080)
- #define PWR\_CR\_PLSLEV5 ((uint32\_t)0x000000A0)
- #define PWR\_CR\_PLSLEV6 ((uint32\_t)0x000000C0)
- #define PWR\_CR\_PLSLEV7 ((uint32\_t)0x000000E0)
- #define PWR\_CR\_DBP ((uint32\_t)0x00000100)
- #define PWR\_CR\_FPDS ((uint32\_t)0x00000200)
- #define PWR\_CR\_LPUDS ((uint32\_t)0x00000400)
- #define PWR\_CR\_MRUDS ((uint32\_t)0x00000800)
- #define PWR\_CR\_LPLVDS ((uint32\_t)0x00000400)
- #define PWR\_CR\_MRLVDS ((uint32\_t)0x00000800)
- #define PWR\_CR\_ADCDC1 ((uint32\_t)0x00002000)
- #define PWR\_CR\_VOS ((uint32\_t)0x0000C000)
- #define PWR\_CR\_VOS\_0 ((uint32\_t)0x00004000)
- #define PWR\_CR\_VOS\_1 ((uint32\_t)0x00008000)
- #define PWR\_CR\_ODEN ((uint32\_t)0x00010000)

- #define PWR\_CR\_ODSWEN ((uint32\_t)0x00020000)
- #define PWR\_CR\_UDEN ((uint32\_t)0x000C0000)
- #define PWR\_CR\_UDEN\_0 ((uint32\_t)0x00040000)
- #define PWR\_CR\_UDEN\_1 ((uint32\_t)0x00080000)
- #define PWR\_CR\_FMSSR ((uint32\_t)0x00100000)
- #define PWR\_CR\_FISSR ((uint32\_t)0x00200000)
- #define PWR\_CR\_PMODE PWR\_CR\_VOS
- #define PWR\_CSR\_WUF ((uint32\_t)0x00000001)
- #define PWR\_CSR\_SBF ((uint32\_t)0x00000002)
- #define PWR\_CSR\_PVDO ((uint32\_t)0x00000004)
- #define PWR\_CSR\_BRR ((uint32\_t)0x00000008)
- #define PWR\_CSR\_WUPP ((uint32\_t)0x00000080)
- #define PWR\_CSR\_EWUP ((uint32\_t)0x00000100)
- #define PWR\_CSR\_BRE ((uint32\_t)0x00000200)
- #define PWR\_CSR\_VOSRDY ((uint32\_t)0x00004000)
- #define PWR\_CSR\_ODRDY ((uint32\_t)0x00010000)
- #define PWR\_CSR\_ODSWRDY ((uint32\_t)0x00020000)
- #define PWR\_CSR\_UDSWRDY ((uint32\_t)0x000C0000)
- #define PWR\_CSR\_REGRDY PWR\_CSR\_VOSRDY
- #define RCC\_CR\_HSION ((uint32\_t)0x00000001)
- #define RCC\_CR\_HSIRDY ((uint32\_t)0x00000002)
- #define RCC\_CR\_HSITRIM ((uint32\_t)0x000000F8)
- #define RCC\_CR\_HSITRIM\_0 ((uint32\_t)0x00000008)
- #define RCC\_CR\_HSITRIM\_1 ((uint32\_t)0x00000010)
- #define RCC\_CR\_HSITRIM\_2 ((uint32\_t)0x00000020)
- #define RCC\_CR\_HSITRIM\_3 ((uint32\_t)0x00000040)
- #define RCC\_CR\_HSITRIM\_4 ((uint32\_t)0x00000080)
- #define RCC\_CR\_HSICAL ((uint32\_t)0x0000FF00)
- #define RCC\_CR\_HSICAL\_0 ((uint32\_t)0x00000100)
- #define RCC\_CR\_HSICAL\_1 ((uint32\_t)0x00000200)
- #define RCC\_CR\_HSICAL\_2 ((uint32\_t)0x00000400)
- #define RCC\_CR\_HSICAL\_3 ((uint32\_t)0x00000800)
- #define RCC\_CR\_HSICAL\_4 ((uint32\_t)0x00001000)
- #define RCC\_CR\_HSICAL\_5 ((uint32\_t)0x00002000)
- #define RCC\_CR\_HSICAL\_6 ((uint32\_t)0x00004000)
- #define RCC\_CR\_HSICAL\_7 ((uint32\_t)0x00008000)
- #define RCC\_CR\_HSEON ((uint32\_t)0x00010000)
- #define RCC\_CR\_HSERDY ((uint32\_t)0x00020000)
- #define RCC\_CR\_HSEBYP ((uint32\_t)0x00040000)
- #define RCC\_CR\_CSSON ((uint32\_t)0x00080000)
- #define RCC\_CR\_PLLON ((uint32\_t)0x01000000)
- #define RCC\_CR\_PLLRDY ((uint32\_t)0x02000000)
- #define RCC\_CR\_PLLI2SON ((uint32\_t)0x04000000)
- #define RCC\_CR\_PLLI2SRDY ((uint32\_t)0x08000000)
- #define RCC\_CR\_PLLSAION ((uint32\_t)0x10000000)
- #define RCC\_CR\_PLLSAIRDY ((uint32\_t)0x20000000)
- #define RCC\_PLLCFG\_R\_PLLM ((uint32\_t)0x0000003F)
- #define RCC\_PLLCFG\_R\_PLLM\_0 ((uint32\_t)0x00000001)
- #define RCC\_PLLCFG\_R\_PLLM\_1 ((uint32\_t)0x00000002)
- #define RCC\_PLLCFG\_R\_PLLM\_2 ((uint32\_t)0x00000004)
- #define RCC\_PLLCFG\_R\_PLLM\_3 ((uint32\_t)0x00000008)
- #define RCC\_PLLCFG\_R\_PLLM\_4 ((uint32\_t)0x00000010)
- #define RCC\_PLLCFG\_R\_PLLM\_5 ((uint32\_t)0x00000020)
- #define RCC\_PLLCFG\_R\_PLLN ((uint32\_t)0x00007FC0)
- #define RCC\_PLLCFG\_R\_PLLN\_0 ((uint32\_t)0x00000040)

- #define **RCC\_PLLCFGR\_PLLN\_1** ((uint32\_t)0x00000080)
- #define **RCC\_PLLCFGR\_PLLN\_2** ((uint32\_t)0x00000100)
- #define **RCC\_PLLCFGR\_PLLN\_3** ((uint32\_t)0x00000200)
- #define **RCC\_PLLCFGR\_PLLN\_4** ((uint32\_t)0x00000400)
- #define **RCC\_PLLCFGR\_PLLN\_5** ((uint32\_t)0x00000800)
- #define **RCC\_PLLCFGR\_PLLN\_6** ((uint32\_t)0x00001000)
- #define **RCC\_PLLCFGR\_PLLN\_7** ((uint32\_t)0x00002000)
- #define **RCC\_PLLCFGR\_PLLN\_8** ((uint32\_t)0x00004000)
- #define **RCC\_PLLCFGR\_PLLP** ((uint32\_t)0x00030000)
- #define **RCC\_PLLCFGR\_PLLP\_0** ((uint32\_t)0x00010000)
- #define **RCC\_PLLCFGR\_PLLP\_1** ((uint32\_t)0x00020000)
- #define **RCC\_PLLCFGR\_PLLSRC** ((uint32\_t)0x00400000)
- #define **RCC\_PLLCFGR\_PLLSRC\_HSE** ((uint32\_t)0x0040000000)
- #define **RCC\_PLLCFGR\_PLLSRC\_HSI** ((uint32\_t)0x00000000)
- #define **RCC\_PLLCFGR\_PLLQ** ((uint32\_t)0xF0000000)
- #define **RCC\_PLLCFGR\_PLLQ\_0** ((uint32\_t)0x01000000)
- #define **RCC\_PLLCFGR\_PLLQ\_1** ((uint32\_t)0x02000000)
- #define **RCC\_PLLCFGR\_PLLQ\_2** ((uint32\_t)0x04000000)
- #define **RCC\_PLLCFGR\_PLLQ\_3** ((uint32\_t)0x08000000)
- #define **RCC\_CFGR\_SW** ((uint32\_t)0x00000003)
- #define **RCC\_CFGR\_SW\_0** ((uint32\_t)0x00000001)
- #define **RCC\_CFGR\_SW\_1** ((uint32\_t)0x00000002)
- #define **RCC\_CFGR\_SW\_HSI** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_SW\_HSE** ((uint32\_t)0x00000001)
- #define **RCC\_CFGR\_SW\_PLL** ((uint32\_t)0x00000002)
- #define **RCC\_CFGR\_SWS** ((uint32\_t)0x0000000C)
- #define **RCC\_CFGR\_SWS\_0** ((uint32\_t)0x00000004)
- #define **RCC\_CFGR\_SWS\_1** ((uint32\_t)0x00000008)
- #define **RCC\_CFGR\_SWS\_HSI** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_SWS\_HSE** ((uint32\_t)0x00000004)
- #define **RCC\_CFGR\_SWS\_PLL** ((uint32\_t)0x00000008)
- #define **RCC\_CFGR\_HPRE** ((uint32\_t)0x000000F0)
- #define **RCC\_CFGR\_HPRE\_0** ((uint32\_t)0x00000010)
- #define **RCC\_CFGR\_HPRE\_1** ((uint32\_t)0x00000020)
- #define **RCC\_CFGR\_HPRE\_2** ((uint32\_t)0x00000040)
- #define **RCC\_CFGR\_HPRE\_3** ((uint32\_t)0x00000080)
- #define **RCC\_CFGR\_HPRE\_DIV1** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_HPRE\_DIV2** ((uint32\_t)0x00000080)
- #define **RCC\_CFGR\_HPRE\_DIV4** ((uint32\_t)0x00000090)
- #define **RCC\_CFGR\_HPRE\_DIV8** ((uint32\_t)0x000000A0)
- #define **RCC\_CFGR\_HPRE\_DIV16** ((uint32\_t)0x000000B0)
- #define **RCC\_CFGR\_HPRE\_DIV64** ((uint32\_t)0x000000C0)
- #define **RCC\_CFGR\_HPRE\_DIV128** ((uint32\_t)0x000000D0)
- #define **RCC\_CFGR\_HPRE\_DIV256** ((uint32\_t)0x000000E0)
- #define **RCC\_CFGR\_HPRE\_DIV512** ((uint32\_t)0x000000F0)
- #define **RCC\_CFGR\_PPREG1** ((uint32\_t)0x00001C00)
- #define **RCC\_CFGR\_PPREG1\_0** ((uint32\_t)0x00000400)
- #define **RCC\_CFGR\_PPREG1\_1** ((uint32\_t)0x00000800)
- #define **RCC\_CFGR\_PPREG1\_2** ((uint32\_t)0x00001000)
- #define **RCC\_CFGR\_PPREG1\_DIV1** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_PPREG1\_DIV2** ((uint32\_t)0x00001000)
- #define **RCC\_CFGR\_PPREG1\_DIV4** ((uint32\_t)0x00001400)
- #define **RCC\_CFGR\_PPREG1\_DIV8** ((uint32\_t)0x00001800)
- #define **RCC\_CFGR\_PPREG1\_DIV16** ((uint32\_t)0x00001C00)
- #define **RCC\_CFGR\_PPREG2** ((uint32\_t)0x0000E000)

- #define **RCC\_CFGR\_PPREG\_0** ((uint32\_t)0x00002000)
- #define **RCC\_CFGR\_PPREG\_1** ((uint32\_t)0x00004000)
- #define **RCC\_CFGR\_PPREG\_2** ((uint32\_t)0x00008000)
- #define **RCC\_CFGR\_PPREG\_DIV1** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_PPREG\_DIV2** ((uint32\_t)0x00008000)
- #define **RCC\_CFGR\_PPREG\_DIV4** ((uint32\_t)0x0000A000)
- #define **RCC\_CFGR\_PPREG\_DIV8** ((uint32\_t)0x0000C000)
- #define **RCC\_CFGR\_PPREG\_DIV16** ((uint32\_t)0x0000E000)
- #define **RCC\_CFGR\_RTCPRE** ((uint32\_t)0x001F0000)
- #define **RCC\_CFGR\_RTCPRE\_0** ((uint32\_t)0x00010000)
- #define **RCC\_CFGR\_RTCPRE\_1** ((uint32\_t)0x00020000)
- #define **RCC\_CFGR\_RTCPRE\_2** ((uint32\_t)0x00040000)
- #define **RCC\_CFGR\_RTCPRE\_3** ((uint32\_t)0x00080000)
- #define **RCC\_CFGR\_RTCPRE\_4** ((uint32\_t)0x00100000)
- #define **RCC\_CFGR\_MCO1** ((uint32\_t)0x00600000)
- #define **RCC\_CFGR\_MCO1\_0** ((uint32\_t)0x00200000)
- #define **RCC\_CFGR\_MCO1\_1** ((uint32\_t)0x00400000)
- #define **RCC\_CFGR\_I2SSRC** ((uint32\_t)0x00800000)
- #define **RCC\_CFGR\_MCO1PRE** ((uint32\_t)0x07000000)
- #define **RCC\_CFGR\_MCO1PRE\_0** ((uint32\_t)0x01000000)
- #define **RCC\_CFGR\_MCO1PRE\_1** ((uint32\_t)0x02000000)
- #define **RCC\_CFGR\_MCO1PRE\_2** ((uint32\_t)0x04000000)
- #define **RCC\_CFGR\_MCO2PRE** ((uint32\_t)0x38000000)
- #define **RCC\_CFGR\_MCO2PRE\_0** ((uint32\_t)0x08000000)
- #define **RCC\_CFGR\_MCO2PRE\_1** ((uint32\_t)0x10000000)
- #define **RCC\_CFGR\_MCO2PRE\_2** ((uint32\_t)0x20000000)
- #define **RCC\_CFGR\_MCO2** ((uint32\_t)0xC0000000)
- #define **RCC\_CFGR\_MCO2\_0** ((uint32\_t)0x40000000)
- #define **RCC\_CFGR\_MCO2\_1** ((uint32\_t)0x80000000)
- #define **RCC\_CIR\_LSIRDYF** ((uint32\_t)0x00000001)
- #define **RCC\_CIR\_LSERDYF** ((uint32\_t)0x00000002)
- #define **RCC\_CIR\_HSIRDYF** ((uint32\_t)0x00000004)
- #define **RCC\_CIR\_HSERDYF** ((uint32\_t)0x00000008)
- #define **RCC\_CIR\_PLLRDYF** ((uint32\_t)0x00000010)
- #define **RCC\_CIR\_PLLI2SRDYF** ((uint32\_t)0x00000020)
- #define **RCC\_CIR\_PLLSAIRDYF** ((uint32\_t)0x00000040)
- #define **RCC\_CIR\_CSSF** ((uint32\_t)0x00000080)
- #define **RCC\_CIR\_LSIRDYIE** ((uint32\_t)0x00000100)
- #define **RCC\_CIR\_LSERDYIE** ((uint32\_t)0x00000200)
- #define **RCC\_CIR\_HSIRDYIE** ((uint32\_t)0x00000400)
- #define **RCC\_CIR\_HSERDYIE** ((uint32\_t)0x00000800)
- #define **RCC\_CIR\_PLLRDYIE** ((uint32\_t)0x00001000)
- #define **RCC\_CIR\_PLLI2SRDYIE** ((uint32\_t)0x00002000)
- #define **RCC\_CIR\_PLLSAIRDYIE** ((uint32\_t)0x00004000)
- #define **RCC\_CIR\_LSIRDYC** ((uint32\_t)0x00010000)
- #define **RCC\_CIR\_LSERDYC** ((uint32\_t)0x00020000)
- #define **RCC\_CIR\_HSIRDYC** ((uint32\_t)0x00040000)
- #define **RCC\_CIR\_HSERDYC** ((uint32\_t)0x00080000)
- #define **RCC\_CIR\_PLLRDYC** ((uint32\_t)0x00100000)
- #define **RCC\_CIR\_PLLI2SRDYC** ((uint32\_t)0x00200000)
- #define **RCC\_CIR\_PLLSAIRDYC** ((uint32\_t)0x00400000)
- #define **RCC\_CIR\_CSSC** ((uint32\_t)0x00800000)
- #define **RCC\_AHB1RSTR\_GPIOARST** ((uint32\_t)0x00000001)
- #define **RCC\_AHB1RSTR\_GPIOBRST** ((uint32\_t)0x00000002)
- #define **RCC\_AHB1RSTR\_GPIOCRST** ((uint32\_t)0x00000004)

- #define **RCC\_AHB1RSTR\_GPIODRST** ((uint32\_t)0x00000008)
- #define **RCC\_AHB1RSTR\_GPIOERST** ((uint32\_t)0x00000010)
- #define **RCC\_AHB1RSTR\_GPIOFRST** ((uint32\_t)0x00000020)
- #define **RCC\_AHB1RSTR\_GPIOGRST** ((uint32\_t)0x00000040)
- #define **RCC\_AHB1RSTR\_GPIOHRST** ((uint32\_t)0x00000080)
- #define **RCC\_AHB1RSTR\_GPIOIRST** ((uint32\_t)0x00000100)
- #define **RCC\_AHB1RSTR\_GPIOJRST** ((uint32\_t)0x00000200)
- #define **RCC\_AHB1RSTR\_GPIOKRST** ((uint32\_t)0x00000400)
- #define **RCC\_AHB1RSTR\_CRCRST** ((uint32\_t)0x00001000)
- #define **RCC\_AHB1RSTR\_DMA1RST** ((uint32\_t)0x00200000)
- #define **RCC\_AHB1RSTR\_DMA2RST** ((uint32\_t)0x00400000)
- #define **RCC\_AHB1RSTR\_DMA2DRST** ((uint32\_t)0x00800000)
- #define **RCC\_AHB1RSTR\_ETHMACRST** ((uint32\_t)0x02000000)
- #define **RCC\_AHB1RSTR\_OTGHRST** ((uint32\_t)0x10000000)
- #define **RCC\_AHB2RSTR\_DCMIRST** ((uint32\_t)0x00000001)
- #define **RCC\_AHB2RSTR\_CRYPRST** ((uint32\_t)0x00000010)
- #define **RCC\_AHB2RSTR\_HASHRST** ((uint32\_t)0x00000020)
- #define **RCC\_AHB2RSTR\_HSAHRST** RCC\_AHB2RSTR\_HASHRST
- #define **RCC\_AHB2RSTR\_RNGRST** ((uint32\_t)0x00000040)
- #define **RCC\_AHB2RSTR\_OTGFSRST** ((uint32\_t)0x00000080)
- #define **RCC\_APB1RSTR\_TIM2RST** ((uint32\_t)0x00000001)
- #define **RCC\_APB1RSTR\_TIM3RST** ((uint32\_t)0x00000002)
- #define **RCC\_APB1RSTR\_TIM4RST** ((uint32\_t)0x00000004)
- #define **RCC\_APB1RSTR\_TIM5RST** ((uint32\_t)0x00000008)
- #define **RCC\_APB1RSTR\_TIM6RST** ((uint32\_t)0x00000010)
- #define **RCC\_APB1RSTR\_TIM7RST** ((uint32\_t)0x00000020)
- #define **RCC\_APB1RSTR\_TIM12RST** ((uint32\_t)0x00000040)
- #define **RCC\_APB1RSTR\_TIM13RST** ((uint32\_t)0x00000080)
- #define **RCC\_APB1RSTR\_TIM14RST** ((uint32\_t)0x00000100)
- #define **RCC\_APB1RSTR\_WWDGRST** ((uint32\_t)0x00000800)
- #define **RCC\_APB1RSTR\_SPI2RST** ((uint32\_t)0x00004000)
- #define **RCC\_APB1RSTR\_SPI3RST** ((uint32\_t)0x00008000)
- #define **RCC\_APB1RSTR\_USART2RST** ((uint32\_t)0x00020000)
- #define **RCC\_APB1RSTR\_USART3RST** ((uint32\_t)0x00040000)
- #define **RCC\_APB1RSTR\_UART4RST** ((uint32\_t)0x00080000)
- #define **RCC\_APB1RSTR\_UART5RST** ((uint32\_t)0x00100000)
- #define **RCC\_APB1RSTR\_I2C1RST** ((uint32\_t)0x00200000)
- #define **RCC\_APB1RSTR\_I2C2RST** ((uint32\_t)0x00400000)
- #define **RCC\_APB1RSTR\_I2C3RST** ((uint32\_t)0x00800000)
- #define **RCC\_APB1RSTR\_CAN1RST** ((uint32\_t)0x02000000)
- #define **RCC\_APB1RSTR\_CAN2RST** ((uint32\_t)0x04000000)
- #define **RCC\_APB1RSTR\_PWRRST** ((uint32\_t)0x10000000)
- #define **RCC\_APB1RSTR\_DACRST** ((uint32\_t)0x20000000)
- #define **RCC\_APB1RSTR\_UART7RST** ((uint32\_t)0x40000000)
- #define **RCC\_APB1RSTR\_UART8RST** ((uint32\_t)0x80000000)
- #define **RCC\_APB2RSTR\_TIM1RST** ((uint32\_t)0x00000001)
- #define **RCC\_APB2RSTR\_TIM8RST** ((uint32\_t)0x00000002)
- #define **RCC\_APB2RSTR\_USART1RST** ((uint32\_t)0x00000010)
- #define **RCC\_APB2RSTR\_USART6RST** ((uint32\_t)0x00000020)
- #define **RCC\_APB2RSTR\_USART9RST** ((uint32\_t)0x00000040)
- #define **RCC\_APB2RSTR\_USART10RST** ((uint32\_t)0x00000080)
- #define **RCC\_APB2RSTR\_ADCRST** ((uint32\_t)0x00000100)
- #define **RCC\_APB2RSTR\_SDIORST** ((uint32\_t)0x00000800)
- #define **RCC\_APB2RSTR\_SPI1RST** ((uint32\_t)0x00001000)
- #define **RCC\_APB2RSTR\_SPI4RST** ((uint32\_t)0x00002000)

- #define **RCC\_APB2RSTR\_SYSCFGRST** ((uint32\_t)0x00004000)
- #define **RCC\_APB2RSTR\_TIM9RST** ((uint32\_t)0x00010000)
- #define **RCC\_APB2RSTR\_TIM10RST** ((uint32\_t)0x00020000)
- #define **RCC\_APB2RSTR\_TIM11RST** ((uint32\_t)0x00040000)
- #define **RCC\_APB2RSTR\_SPI5RST** ((uint32\_t)0x00100000)
- #define **RCC\_APB2RSTR\_SPI6RST** ((uint32\_t)0x00200000)
- #define **RCC\_APB2RSTR\_SAI1RST** ((uint32\_t)0x00400000)
- #define **RCC\_APB2RSTR\_LTDCRST** ((uint32\_t)0x04000000)
- #define **RCC\_APB2RSTR\_SPI1** RCC\_APB2RSTR\_SPI1RST
- #define **RCC\_APB2RSTR\_DFSDMRST** RCC\_APB2RSTR\_DFSDM1RST
- #define **RCC\_AHB1ENR\_GPIOAEN** ((uint32\_t)0x00000001)
- #define **RCC\_AHB1ENR\_GPIOBEN** ((uint32\_t)0x00000002)
- #define **RCC\_AHB1ENR\_GPIOCEN** ((uint32\_t)0x00000004)
- #define **RCC\_AHB1ENR\_GPIODEN** ((uint32\_t)0x00000008)
- #define **RCC\_AHB1ENR\_GPIOEEN** ((uint32\_t)0x00000010)
- #define **RCC\_AHB1ENR\_GPIOFEN** ((uint32\_t)0x00000020)
- #define **RCC\_AHB1ENR\_GPIOGEN** ((uint32\_t)0x00000040)
- #define **RCC\_AHB1ENR\_GPIOHEN** ((uint32\_t)0x00000080)
- #define **RCC\_AHB1ENR\_GPIOIEN** ((uint32\_t)0x00000100)
- #define **RCC\_AHB1ENR\_GPIOJEN** ((uint32\_t)0x00000200)
- #define **RCC\_AHB1ENR\_GPIOKEN** ((uint32\_t)0x00000400)
- #define **RCC\_AHB1ENR\_CRCEN** ((uint32\_t)0x00001000)
- #define **RCC\_AHB1ENR\_BKPSRAMEN** ((uint32\_t)0x00040000)
- #define **RCC\_AHB1ENR\_CCMDATARAMEN** ((uint32\_t)0x00100000)
- #define **RCC\_AHB1ENR\_DMA1EN** ((uint32\_t)0x00200000)
- #define **RCC\_AHB1ENR\_DMA2EN** ((uint32\_t)0x00400000)
- #define **RCC\_AHB1ENR\_DMA2DEN** ((uint32\_t)0x00800000)
- #define **RCC\_AHB1ENR\_ETHMACEN** ((uint32\_t)0x02000000)
- #define **RCC\_AHB1ENR\_ETHMACTXEN** ((uint32\_t)0x04000000)
- #define **RCC\_AHB1ENR\_ETHMACRXEN** ((uint32\_t)0x08000000)
- #define **RCC\_AHB1ENR\_ETHMACPTPEN** ((uint32\_t)0x10000000)
- #define **RCC\_AHB1ENR\_OTGHSEN** ((uint32\_t)0x20000000)
- #define **RCC\_AHB1ENR\_OTGHSULPIEN** ((uint32\_t)0x40000000)
- #define **RCC\_AHB2ENR\_DCMIEN** ((uint32\_t)0x00000001)
- #define **RCC\_AHB2ENR\_CRYPEN** ((uint32\_t)0x00000010)
- #define **RCC\_AHB2ENR\_HASHEN** ((uint32\_t)0x00000020)
- #define **RCC\_AHB2ENR\_RNGEN** ((uint32\_t)0x00000040)
- #define **RCC\_AHB2ENR\_OTGFSEN** ((uint32\_t)0x00000080)
- #define **RCC\_APB1ENR\_TIM2EN** ((uint32\_t)0x00000001)
- #define **RCC\_APB1ENR\_TIM3EN** ((uint32\_t)0x00000002)
- #define **RCC\_APB1ENR\_TIM4EN** ((uint32\_t)0x00000004)
- #define **RCC\_APB1ENR\_TIM5EN** ((uint32\_t)0x00000008)
- #define **RCC\_APB1ENR\_TIM6EN** ((uint32\_t)0x00000010)
- #define **RCC\_APB1ENR\_TIM7EN** ((uint32\_t)0x00000020)
- #define **RCC\_APB1ENR\_TIM12EN** ((uint32\_t)0x00000040)
- #define **RCC\_APB1ENR\_TIM13EN** ((uint32\_t)0x00000080)
- #define **RCC\_APB1ENR\_TIM14EN** ((uint32\_t)0x00000100)
- #define **RCC\_APB1ENR\_WWDGEN** ((uint32\_t)0x00000800)
- #define **RCC\_APB1ENR\_SPI2EN** ((uint32\_t)0x00004000)
- #define **RCC\_APB1ENR\_SPI3EN** ((uint32\_t)0x00008000)
- #define **RCC\_APB1ENR\_USART2EN** ((uint32\_t)0x00020000)
- #define **RCC\_APB1ENR\_USART3EN** ((uint32\_t)0x00040000)
- #define **RCC\_APB1ENR\_UART4EN** ((uint32\_t)0x00080000)
- #define **RCC\_APB1ENR\_UART5EN** ((uint32\_t)0x00100000)
- #define **RCC\_APB1ENR\_I2C1EN** ((uint32\_t)0x00200000)

- #define **RCC\_APB1ENR\_I2C2EN** ((uint32\_t)0x00400000)
- #define **RCC\_APB1ENR\_I2C3EN** ((uint32\_t)0x00800000)
- #define **RCC\_APB1ENR\_CAN1EN** ((uint32\_t)0x02000000)
- #define **RCC\_APB1ENR\_CAN2EN** ((uint32\_t)0x04000000)
- #define **RCC\_APB1ENR\_PWREN** ((uint32\_t)0x10000000)
- #define **RCC\_APB1ENR\_DACEN** ((uint32\_t)0x20000000)
- #define **RCC\_APB1ENR\_UART7EN** ((uint32\_t)0x40000000)
- #define **RCC\_APB1ENR\_UART8EN** ((uint32\_t)0x80000000)
- #define **RCC\_APB2ENR\_TIM1EN** ((uint32\_t)0x00000001)
- #define **RCC\_APB2ENR\_TIM8EN** ((uint32\_t)0x00000002)
- #define **RCC\_APB2ENR\_USART1EN** ((uint32\_t)0x00000010)
- #define **RCC\_APB2ENR\_USART6EN** ((uint32\_t)0x00000020)
- #define **RCC\_APB2ENR\_UART9EN** ((uint32\_t)0x00000040)
- #define **RCC\_APB2ENR\_UART10EN** ((uint32\_t)0x00000080)
- #define **RCC\_APB2ENR\_ADC1EN** ((uint32\_t)0x00000100)
- #define **RCC\_APB2ENR\_ADC2EN** ((uint32\_t)0x00000200)
- #define **RCC\_APB2ENR\_ADC3EN** ((uint32\_t)0x00000400)
- #define **RCC\_APB2ENR\_SDIOEN** ((uint32\_t)0x00000800)
- #define **RCC\_APB2ENR\_SPI1EN** ((uint32\_t)0x00001000)
- #define **RCC\_APB2ENR\_SPI4EN** ((uint32\_t)0x00002000)
- #define **RCC\_APB2ENR\_SYSCFGEN** ((uint32\_t)0x00004000)
- #define **RCC\_APB2ENR\_EXTIEN** ((uint32\_t)0x00008000)
- #define **RCC\_APB2ENR\_TIM9EN** ((uint32\_t)0x00010000)
- #define **RCC\_APB2ENR\_TIM10EN** ((uint32\_t)0x00020000)
- #define **RCC\_APB2ENR\_TIM11EN** ((uint32\_t)0x00040000)
- #define **RCC\_APB2ENR\_SPI5EN** ((uint32\_t)0x00100000)
- #define **RCC\_APB2ENR\_SPI6EN** ((uint32\_t)0x00200000)
- #define **RCC\_APB2ENR\_SAI1EN** ((uint32\_t)0x00400000)
- #define **RCC\_APB2ENR\_LTDCEN** ((uint32\_t)0x04000000)
- #define **RCC\_AHB1LPENR\_GPIOALPEN** ((uint32\_t)0x00000001)
- #define **RCC\_AHB1LPENR\_GPIOBLPEN** ((uint32\_t)0x00000002)
- #define **RCC\_AHB1LPENR\_GPIOCLPEN** ((uint32\_t)0x00000004)
- #define **RCC\_AHB1LPENR\_GPIOODLPEN** ((uint32\_t)0x00000008)
- #define **RCC\_AHB1LPENR\_GPIOELPEN** ((uint32\_t)0x00000010)
- #define **RCC\_AHB1LPENR\_GPIOFLPEN** ((uint32\_t)0x00000020)
- #define **RCC\_AHB1LPENR\_GPIOGLPEN** ((uint32\_t)0x00000040)
- #define **RCC\_AHB1LPENR\_GPIOHLPEN** ((uint32\_t)0x00000080)
- #define **RCC\_AHB1LPENR\_GPIOILPEN** ((uint32\_t)0x00000100)
- #define **RCC\_AHB1LPENR\_GPIOJLPEN** ((uint32\_t)0x00000200)
- #define **RCC\_AHB1LPENR\_GPIOOKLPEN** ((uint32\_t)0x00000400)
- #define **RCC\_AHB1LPENR\_CRCLPEN** ((uint32\_t)0x00001000)
- #define **RCC\_AHB1LPENR\_FLITFLPEN** ((uint32\_t)0x00008000)
- #define **RCC\_AHB1LPENR\_SRAM1LPEN** ((uint32\_t)0x00010000)
- #define **RCC\_AHB1LPENR\_SRAM2LPEN** ((uint32\_t)0x00020000)
- #define **RCC\_AHB1LPENR\_BKPSRAMLPEN** ((uint32\_t)0x00040000)
- #define **RCC\_AHB1LPENR\_SRAM3LPEN** ((uint32\_t)0x00080000)
- #define **RCC\_AHB1LPENR\_DMA1LPEN** ((uint32\_t)0x00200000)
- #define **RCC\_AHB1LPENR\_DMA2LPEN** ((uint32\_t)0x00400000)
- #define **RCC\_AHB1LPENR\_DMA2DLPEN** ((uint32\_t)0x00800000)
- #define **RCC\_AHB1LPENR\_ETHMACLPEN** ((uint32\_t)0x02000000)
- #define **RCC\_AHB1LPENR\_ETHMACTXLPEN** ((uint32\_t)0x04000000)
- #define **RCC\_AHB1LPENR\_ETHMACRXLPEN** ((uint32\_t)0x08000000)
- #define **RCC\_AHB1LPENR\_ETHMACPTPLPEN** ((uint32\_t)0x10000000)
- #define **RCC\_AHB1LPENR\_OTGHSLPEN** ((uint32\_t)0x20000000)
- #define **RCC\_AHB1LPENR\_OTGHSULPILPEN** ((uint32\_t)0x40000000)

- #define **RCC\_AHB2LPENR\_DCMILPEN** ((uint32\_t)0x00000001)
- #define **RCC\_AHB2LPENR\_CRYPLPEN** ((uint32\_t)0x00000010)
- #define **RCC\_AHB2LPENR\_HASHLPEN** ((uint32\_t)0x00000020)
- #define **RCC\_AHB2LPENR\_RNGLPEN** ((uint32\_t)0x00000040)
- #define **RCC\_AHB2LPENR\_OTGFSLPEN** ((uint32\_t)0x00000080)
- #define **RCC\_APB1LPENR\_TIM2LPEN** ((uint32\_t)0x00000001)
- #define **RCC\_APB1LPENR\_TIM3LPEN** ((uint32\_t)0x00000002)
- #define **RCC\_APB1LPENR\_TIM4LPEN** ((uint32\_t)0x00000004)
- #define **RCC\_APB1LPENR\_TIM5LPEN** ((uint32\_t)0x00000008)
- #define **RCC\_APB1LPENR\_TIM6LPEN** ((uint32\_t)0x00000010)
- #define **RCC\_APB1LPENR\_TIM7LPEN** ((uint32\_t)0x00000020)
- #define **RCC\_APB1LPENR\_TIM12LPEN** ((uint32\_t)0x00000040)
- #define **RCC\_APB1LPENR\_TIM13LPEN** ((uint32\_t)0x00000080)
- #define **RCC\_APB1LPENR\_TIM14LPEN** ((uint32\_t)0x00000100)
- #define **RCC\_APB1LPENR\_WWDGLPEN** ((uint32\_t)0x00000800)
- #define **RCC\_APB1LPENR\_SPI2LPEN** ((uint32\_t)0x00004000)
- #define **RCC\_APB1LPENR\_SPI3LPEN** ((uint32\_t)0x00008000)
- #define **RCC\_APB1LPENR\_USART2LPEN** ((uint32\_t)0x00020000)
- #define **RCC\_APB1LPENR\_USART3LPEN** ((uint32\_t)0x00040000)
- #define **RCC\_APB1LPENR\_UART4LPEN** ((uint32\_t)0x00080000)
- #define **RCC\_APB1LPENR\_UART5LPEN** ((uint32\_t)0x00100000)
- #define **RCC\_APB1LPENR\_I2C1LPEN** ((uint32\_t)0x00200000)
- #define **RCC\_APB1LPENR\_I2C2LPEN** ((uint32\_t)0x00400000)
- #define **RCC\_APB1LPENR\_I2C3LPEN** ((uint32\_t)0x00800000)
- #define **RCC\_APB1LPENR\_CAN1LPEN** ((uint32\_t)0x02000000)
- #define **RCC\_APB1LPENR\_CAN2LPEN** ((uint32\_t)0x04000000)
- #define **RCC\_APB1LPENR\_PWRLPEN** ((uint32\_t)0x10000000)
- #define **RCC\_APB1LPENR\_DACLPEN** ((uint32\_t)0x20000000)
- #define **RCC\_APB1LPENR\_UART7LPEN** ((uint32\_t)0x40000000)
- #define **RCC\_APB1LPENR\_UART8LPEN** ((uint32\_t)0x80000000)
- #define **RCC\_APB2LPENR\_TIM1LPEN** ((uint32\_t)0x00000001)
- #define **RCC\_APB2LPENR\_TIM8LPEN** ((uint32\_t)0x00000002)
- #define **RCC\_APB2LPENR\_USART1LPEN** ((uint32\_t)0x00000010)
- #define **RCC\_APB2LPENR\_USART6LPEN** ((uint32\_t)0x00000020)
- #define **RCC\_APB2LPENR\_UART9LPEN** ((uint32\_t)0x00000040)
- #define **RCC\_APB2LPENR\_UART10LPEN** ((uint32\_t)0x00000080)
- #define **RCC\_APB2LPENR\_ADC1LPEN** ((uint32\_t)0x00000100)
- #define **RCC\_APB2LPENR\_ADC2PEN** ((uint32\_t)0x00000200)
- #define **RCC\_APB2LPENR\_ADC3LPEN** ((uint32\_t)0x00000400)
- #define **RCC\_APB2LPENR\_SDIOLPEN** ((uint32\_t)0x00000800)
- #define **RCC\_APB2LPENR\_SPI1LPEN** ((uint32\_t)0x00001000)
- #define **RCC\_APB2LPENR\_SPI4LPEN** ((uint32\_t)0x00002000)
- #define **RCC\_APB2LPENR\_SYSCFGLPEN** ((uint32\_t)0x00004000)
- #define **RCC\_APB2LPENR\_TIM9LPEN** ((uint32\_t)0x00010000)
- #define **RCC\_APB2LPENR\_TIM10LPEN** ((uint32\_t)0x00020000)
- #define **RCC\_APB2LPENR\_TIM11LPEN** ((uint32\_t)0x00040000)
- #define **RCC\_APB2LPENR\_SPI5LPEN** ((uint32\_t)0x00100000)
- #define **RCC\_APB2LPENR\_SPI6LPEN** ((uint32\_t)0x00200000)
- #define **RCC\_APB2LPENR\_SAI1LPEN** ((uint32\_t)0x00400000)
- #define **RCC\_APB2LPENR\_LTDCLPEN** ((uint32\_t)0x04000000)
- #define **RCC\_BDCR\_LSEON** ((uint32\_t)0x00000001)
- #define **RCC\_BDCR\_LSERDY** ((uint32\_t)0x00000002)
- #define **RCC\_BDCR\_LSEBYP** ((uint32\_t)0x00000004)
- #define **RCC\_BDCR\_LSEMOP** ((uint32\_t)0x00000008)
- #define **RCC\_BDCR\_RTCSEL** ((uint32\_t)0x00000300)

- #define **RCC\_BDCR\_RTCSEL\_0** ((uint32\_t)0x00000100)
- #define **RCC\_BDCR\_RTCSEL\_1** ((uint32\_t)0x00000200)
- #define **RCC\_BDCR\_RTCEN** ((uint32\_t)0x00008000)
- #define **RCC\_BDCR\_BDRST** ((uint32\_t)0x00010000)
- #define **RCC\_CSR\_LSION** ((uint32\_t)0x00000001)
- #define **RCC\_CSR\_LSIRDY** ((uint32\_t)0x00000002)
- #define **RCC\_CSR\_RMVF** ((uint32\_t)0x01000000)
- #define **RCC\_CSR\_BORRSTF** ((uint32\_t)0x02000000)
- #define **RCC\_CSR\_PADRSTF** ((uint32\_t)0x04000000)
- #define **RCC\_CSR\_PORRSTF** ((uint32\_t)0x08000000)
- #define **RCC\_CSR\_SFTRSTF** ((uint32\_t)0x10000000)
- #define **RCC\_CSR\_WDGRSTF** ((uint32\_t)0x20000000)
- #define **RCC\_CSR\_WWDGRSTF** ((uint32\_t)0x40000000)
- #define **RCC\_CSR\_LPWRRSTF** ((uint32\_t)0x80000000)
- #define **RCC\_SSCGR\_MODPER** ((uint32\_t)0x00001FFF)
- #define **RCC\_SSCGR\_INCSTEP** ((uint32\_t)0x0FFE000)
- #define **RCC\_SSCGR\_SPREADSEL** ((uint32\_t)0x40000000)
- #define **RCC\_SSCGR\_SSCGEN** ((uint32\_t)0x80000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM** ((uint32\_t)0x0000003F)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM\_0** ((uint32\_t)0x00000001)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM\_1** ((uint32\_t)0x00000002)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM\_2** ((uint32\_t)0x00000004)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM\_3** ((uint32\_t)0x00000008)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM\_4** ((uint32\_t)0x00000010)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM\_5** ((uint32\_t)0x00000020)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN** ((uint32\_t)0x00007FC0)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN\_0** ((uint32\_t)0x00000040)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN\_1** ((uint32\_t)0x00000080)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN\_2** ((uint32\_t)0x00000100)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN\_3** ((uint32\_t)0x00000200)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN\_4** ((uint32\_t)0x00000400)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN\_5** ((uint32\_t)0x00000800)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN\_6** ((uint32\_t)0x00001000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN\_7** ((uint32\_t)0x00002000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SN\_8** ((uint32\_t)0x00004000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SQ** ((uint32\_t)0x0F000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SQ\_0** ((uint32\_t)0x01000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SQ\_1** ((uint32\_t)0x02000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SQ\_2** ((uint32\_t)0x04000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SQ\_3** ((uint32\_t)0x08000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SR** ((uint32\_t)0x70000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SR\_0** ((uint32\_t)0x10000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SR\_1** ((uint32\_t)0x20000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SR\_2** ((uint32\_t)0x40000000)
- #define **RCC\_PLLSAICFGR\_PLLSAIN** ((uint32\_t)0x00007FC0)
- #define **RCC\_PLLSAICFGR\_PLLSAIN\_0** ((uint32\_t)0x00000040)
- #define **RCC\_PLLSAICFGR\_PLLSAIN\_1** ((uint32\_t)0x00000080)
- #define **RCC\_PLLSAICFGR\_PLLSAIN\_2** ((uint32\_t)0x00000100)
- #define **RCC\_PLLSAICFGR\_PLLSAIN\_3** ((uint32\_t)0x00000200)
- #define **RCC\_PLLSAICFGR\_PLLSAIN\_4** ((uint32\_t)0x00000400)
- #define **RCC\_PLLSAICFGR\_PLLSAIN\_5** ((uint32\_t)0x00000800)
- #define **RCC\_PLLSAICFGR\_PLLSAIN\_6** ((uint32\_t)0x00001000)
- #define **RCC\_PLLSAICFGR\_PLLSAIN\_7** ((uint32\_t)0x00002000)
- #define **RCC\_PLLSAICFGR\_PLLSAIN\_8** ((uint32\_t)0x00004000)
- #define **RCC\_PLLSAICFGR\_PLLSAIQ** ((uint32\_t)0x0F000000)

- #define **RCC\_PLLSAICFGR\_PLLSAIQ\_0** ((uint32\_t)0x01000000)
- #define **RCC\_PLLSAICFGR\_PLLSAIQ\_1** ((uint32\_t)0x02000000)
- #define **RCC\_PLLSAICFGR\_PLLSAIQ\_2** ((uint32\_t)0x04000000)
- #define **RCC\_PLLSAICFGR\_PLLSAIQ\_3** ((uint32\_t)0x08000000)
- #define **RCC\_PLLSAICFGR\_PLLSAIR** ((uint32\_t)0x70000000)
- #define **RCC\_PLLSAICFGR\_PLLSAIR\_0** ((uint32\_t)0x10000000)
- #define **RCC\_PLLSAICFGR\_PLLSAIR\_1** ((uint32\_t)0x20000000)
- #define **RCC\_PLLSAICFGR\_PLLSAIR\_2** ((uint32\_t)0x40000000)
- #define **RCC\_DCKCFGR\_PLLI2SDIVQ** ((uint32\_t)0x00000001F)
- #define **RCC\_DCKCFGR\_PLLSAIDIVQ** ((uint32\_t)0x00001F00)
- #define **RCC\_DCKCFGR\_PLLSAIDIVR** ((uint32\_t)0x00030000)
- #define **RCC\_DCKCFGR\_SAI1ASRC** ((uint32\_t)0x00300000)
- #define **RCC\_DCKCFGR\_SAI1ASRC\_0** ((uint32\_t)0x00100000)
- #define **RCC\_DCKCFGR\_SAI1ASRC\_1** ((uint32\_t)0x00200000)
- #define **RCC\_DCKCFGR\_SAI1BSRC** ((uint32\_t)0x00C00000)
- #define **RCC\_DCKCFGR\_SAI1BSRC\_0** ((uint32\_t)0x00400000)
- #define **RCC\_DCKCFGR\_SAI1BSRC\_1** ((uint32\_t)0x00800000)
- #define **RCC\_DCKCFGR\_TIMPRE** ((uint32\_t)0x01000000)
- #define **RNG\_CR\_RNGEN** ((uint32\_t)0x00000004)
- #define **RNG\_CR\_IE** ((uint32\_t)0x00000008)
- #define **RNG\_SR\_DRDY** ((uint32\_t)0x00000001)
- #define **RNG\_SR\_CECS** ((uint32\_t)0x00000002)
- #define **RNG\_SR\_SECS** ((uint32\_t)0x00000004)
- #define **RNG\_SR\_CEIS** ((uint32\_t)0x00000020)
- #define **RNG\_SR\_SEIS** ((uint32\_t)0x00000040)
- #define **RTC\_TR\_PM** ((uint32\_t)0x00400000)
- #define **RTC\_TR\_HT** ((uint32\_t)0x00300000)
- #define **RTC\_TR\_HT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_TR\_HT\_1** ((uint32\_t)0x00200000)
- #define **RTC\_TR\_HU** ((uint32\_t)0x000F0000)
- #define **RTC\_TR\_HU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_TR\_HU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_TR\_HU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_TR\_HU\_3** ((uint32\_t)0x00080000)
- #define **RTC\_TR\_MNT** ((uint32\_t)0x00007000)
- #define **RTC\_TR\_MNT\_0** ((uint32\_t)0x00001000)
- #define **RTC\_TR\_MNT\_1** ((uint32\_t)0x00002000)
- #define **RTC\_TR\_MNT\_2** ((uint32\_t)0x00004000)
- #define **RTC\_TR\_MNU** ((uint32\_t)0x00000F00)
- #define **RTC\_TR\_MNU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_TR\_MNU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_TR\_MNU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_TR\_MNU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_TR\_ST** ((uint32\_t)0x00000070)
- #define **RTC\_TR\_ST\_0** ((uint32\_t)0x00000010)
- #define **RTC\_TR\_ST\_1** ((uint32\_t)0x00000020)
- #define **RTC\_TR\_ST\_2** ((uint32\_t)0x00000040)
- #define **RTC\_TR\_SU** ((uint32\_t)0x0000000F)
- #define **RTC\_TR\_SU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_TR\_SU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_TR\_SU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_TR\_SU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_DR\_YT** ((uint32\_t)0x00F00000)
- #define **RTC\_DR\_YT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_DR\_YT\_1** ((uint32\_t)0x00200000)

- #define **RTC\_DR\_YT\_2** ((uint32\_t)0x00400000)
- #define **RTC\_DR\_YT\_3** ((uint32\_t)0x00800000)
- #define **RTC\_DR\_YU** ((uint32\_t)0x000F0000)
- #define **RTC\_DR\_YU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_DR\_YU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_DR\_YU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_DR\_YU\_3** ((uint32\_t)0x00080000)
- #define **RTC\_DR\_WDU** ((uint32\_t)0x0000E000)
- #define **RTC\_DR\_WDU\_0** ((uint32\_t)0x00002000)
- #define **RTC\_DR\_WDU\_1** ((uint32\_t)0x00004000)
- #define **RTC\_DR\_WDU\_2** ((uint32\_t)0x00008000)
- #define **RTC\_DR\_MT** ((uint32\_t)0x00001000)
- #define **RTC\_DR\_MU** ((uint32\_t)0x00000F00)
- #define **RTC\_DR\_MU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_DR\_MU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_DR\_MU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_DR\_MU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_DR\_DT** ((uint32\_t)0x00000030)
- #define **RTC\_DR\_DT\_0** ((uint32\_t)0x00000010)
- #define **RTC\_DR\_DT\_1** ((uint32\_t)0x00000020)
- #define **RTC\_DR\_DU** ((uint32\_t)0x0000000F)
- #define **RTC\_DR\_DU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_DR\_DU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_DR\_DU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_DR\_DU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_CR\_COE** ((uint32\_t)0x00800000)
- #define **RTC\_CR\_OSEL** ((uint32\_t)0x00600000)
- #define **RTC\_CR\_OSEL\_0** ((uint32\_t)0x00200000)
- #define **RTC\_CR\_OSEL\_1** ((uint32\_t)0x00400000)
- #define **RTC\_CR\_POL** ((uint32\_t)0x00100000)
- #define **RTC\_CR\_COSEL** ((uint32\_t)0x00080000)
- #define **RTC\_CR\_BCK** ((uint32\_t)0x00040000)
- #define **RTC\_CR\_SUB1H** ((uint32\_t)0x00020000)
- #define **RTC\_CR\_ADD1H** ((uint32\_t)0x00010000)
- #define **RTC\_CR\_TSIE** ((uint32\_t)0x00008000)
- #define **RTC\_CR\_WUTIE** ((uint32\_t)0x00004000)
- #define **RTC\_CR\_ALRBIE** ((uint32\_t)0x00002000)
- #define **RTC\_CR\_ALRAIE** ((uint32\_t)0x00001000)
- #define **RTC\_CR\_TSE** ((uint32\_t)0x00000800)
- #define **RTC\_CR\_WUTE** ((uint32\_t)0x00000400)
- #define **RTC\_CR\_ALRBE** ((uint32\_t)0x00000200)
- #define **RTC\_CR\_ALRAE** ((uint32\_t)0x00000100)
- #define **RTC\_CR\_DCE** ((uint32\_t)0x00000080)
- #define **RTC\_CR\_FMT** ((uint32\_t)0x00000040)
- #define **RTC\_CR\_BYPSHAD** ((uint32\_t)0x00000020)
- #define **RTC\_CR\_REFCKON** ((uint32\_t)0x00000010)
- #define **RTC\_CR\_TSEDGE** ((uint32\_t)0x00000008)
- #define **RTC\_CR\_WUCKSEL** ((uint32\_t)0x00000007)
- #define **RTC\_CR\_WUCKSEL\_0** ((uint32\_t)0x00000001)
- #define **RTC\_CR\_WUCKSEL\_1** ((uint32\_t)0x00000002)
- #define **RTC\_CR\_WUCKSEL\_2** ((uint32\_t)0x00000004)
- #define **RTC\_ISR\_RECALPF** ((uint32\_t)0x00010000)
- #define **RTC\_ISR\_TAMP1F** ((uint32\_t)0x00002000)
- #define **RTC\_ISR\_TAMP2F** ((uint32\_t)0x00004000)
- #define **RTC\_ISR\_TSOVF** ((uint32\_t)0x00001000)

- #define **RTC\_ISR\_TSF** ((uint32\_t)0x00000800)
- #define **RTC\_ISR\_WUTF** ((uint32\_t)0x00000400)
- #define **RTC\_ISR\_ALRBF** ((uint32\_t)0x00000200)
- #define **RTC\_ISR\_ALRAF** ((uint32\_t)0x00000100)
- #define **RTC\_ISR\_INIT** ((uint32\_t)0x00000080)
- #define **RTC\_ISR\_INITF** ((uint32\_t)0x00000040)
- #define **RTC\_ISR\_RSF** ((uint32\_t)0x00000020)
- #define **RTC\_ISR\_INITS** ((uint32\_t)0x00000010)
- #define **RTC\_ISR\_SHPF** ((uint32\_t)0x00000008)
- #define **RTC\_ISR\_WUTWF** ((uint32\_t)0x00000004)
- #define **RTC\_ISR\_ALRBWF** ((uint32\_t)0x00000002)
- #define **RTC\_ISR\_ALRAWF** ((uint32\_t)0x00000001)
- #define **RTC\_PRER\_PREDIV\_A** ((uint32\_t)0x007F0000)
- #define **RTC\_PRER\_PREDIV\_S** ((uint32\_t)0x00001FFF)
- #define **RTC\_WUTR\_WUT** ((uint32\_t)0x0000FFFF)
- #define **RTC\_CALIBR\_DCS** ((uint32\_t)0x00000080)
- #define **RTC\_CALIBR\_DC** ((uint32\_t)0x0000001F)
- #define **RTC\_ALRMAR\_MSK4** ((uint32\_t)0x80000000)
- #define **RTC\_ALRMAR\_WDSEL** ((uint32\_t)0x40000000)
- #define **RTC\_ALRMAR\_DT** ((uint32\_t)0x30000000)
- #define **RTC\_ALRMAR\_DT\_0** ((uint32\_t)0x10000000)
- #define **RTC\_ALRMAR\_DT\_1** ((uint32\_t)0x20000000)
- #define **RTC\_ALRMAR\_DU** ((uint32\_t)0x0F000000)
- #define **RTC\_ALRMAR\_DU\_0** ((uint32\_t)0x01000000)
- #define **RTC\_ALRMAR\_DU\_1** ((uint32\_t)0x02000000)
- #define **RTC\_ALRMAR\_DU\_2** ((uint32\_t)0x04000000)
- #define **RTC\_ALRMAR\_DU\_3** ((uint32\_t)0x08000000)
- #define **RTC\_ALRMAR\_MSK3** ((uint32\_t)0x00800000)
- #define **RTC\_ALRMAR\_PM** ((uint32\_t)0x00400000)
- #define **RTC\_ALRMAR\_HT** ((uint32\_t)0x00300000)
- #define **RTC\_ALRMAR\_HT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_ALRMAR\_HT\_1** ((uint32\_t)0x00200000)
- #define **RTC\_ALRMAR\_HU** ((uint32\_t)0x000F0000)
- #define **RTC\_ALRMAR\_HU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_ALRMAR\_HU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_ALRMAR\_HU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_ALRMAR\_HU\_3** ((uint32\_t)0x00080000)
- #define **RTC\_ALRMAR\_MSK2** ((uint32\_t)0x00008000)
- #define **RTC\_ALRMAR\_MNT** ((uint32\_t)0x00007000)
- #define **RTC\_ALRMAR\_MNT\_0** ((uint32\_t)0x00001000)
- #define **RTC\_ALRMAR\_MNT\_1** ((uint32\_t)0x00002000)
- #define **RTC\_ALRMAR\_MNT\_2** ((uint32\_t)0x00004000)
- #define **RTC\_ALRMAR\_MNU** ((uint32\_t)0x0000F00)
- #define **RTC\_ALRMAR\_MNU\_0** ((uint32\_t)0x0000100)
- #define **RTC\_ALRMAR\_MNU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_ALRMAR\_MNU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_ALRMAR\_MNU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_ALRMAR\_MSK1** ((uint32\_t)0x00000080)
- #define **RTC\_ALRMAR\_ST** ((uint32\_t)0x00000070)
- #define **RTC\_ALRMAR\_ST\_0** ((uint32\_t)0x00000010)
- #define **RTC\_ALRMAR\_ST\_1** ((uint32\_t)0x00000020)
- #define **RTC\_ALRMAR\_ST\_2** ((uint32\_t)0x00000040)
- #define **RTC\_ALRMAR\_SU** ((uint32\_t)0x0000000F)
- #define **RTC\_ALRMAR\_SU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_ALRMAR\_SU\_1** ((uint32\_t)0x00000002)

- #define **RTC\_ALRMAR\_SU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_ALRMAR\_SU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_ALRMBR\_MSK4** ((uint32\_t)0x80000000)
- #define **RTC\_ALRMBR\_WDSEL** ((uint32\_t)0x40000000)
- #define **RTC\_ALRMBR\_DT** ((uint32\_t)0x30000000)
- #define **RTC\_ALRMBR\_DT\_0** ((uint32\_t)0x10000000)
- #define **RTC\_ALRMBR\_DT\_1** ((uint32\_t)0x20000000)
- #define **RTC\_ALRMBR\_DU** ((uint32\_t)0x0F000000)
- #define **RTC\_ALRMBR\_DU\_0** ((uint32\_t)0x01000000)
- #define **RTC\_ALRMBR\_DU\_1** ((uint32\_t)0x02000000)
- #define **RTC\_ALRMBR\_DU\_2** ((uint32\_t)0x04000000)
- #define **RTC\_ALRMBR\_DU\_3** ((uint32\_t)0x08000000)
- #define **RTC\_ALRMBR\_MSK3** ((uint32\_t)0x00800000)
- #define **RTC\_ALRMBR\_PM** ((uint32\_t)0x00400000)
- #define **RTC\_ALRMBR\_HT** ((uint32\_t)0x00300000)
- #define **RTC\_ALRMBR\_HT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_ALRMBR\_HT\_1** ((uint32\_t)0x00200000)
- #define **RTC\_ALRMBR\_HU** ((uint32\_t)0x000F0000)
- #define **RTC\_ALRMBR\_HU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_ALRMBR\_HU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_ALRMBR\_HU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_ALRMBR\_HU\_3** ((uint32\_t)0x00080000)
- #define **RTC\_ALRMBR\_MSK2** ((uint32\_t)0x00008000)
- #define **RTC\_ALRMBR\_MNT** ((uint32\_t)0x00007000)
- #define **RTC\_ALRMBR\_MNT\_0** ((uint32\_t)0x00001000)
- #define **RTC\_ALRMBR\_MNT\_1** ((uint32\_t)0x00002000)
- #define **RTC\_ALRMBR\_MNT\_2** ((uint32\_t)0x00004000)
- #define **RTC\_ALRMBR\_MNU** ((uint32\_t)0x00000F00)
- #define **RTC\_ALRMBR\_MNU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_ALRMBR\_MNU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_ALRMBR\_MNU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_ALRMBR\_MNU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_ALRMBR\_MSK1** ((uint32\_t)0x00000080)
- #define **RTC\_ALRMBR\_ST** ((uint32\_t)0x00000070)
- #define **RTC\_ALRMBR\_ST\_0** ((uint32\_t)0x00000010)
- #define **RTC\_ALRMBR\_ST\_1** ((uint32\_t)0x00000020)
- #define **RTC\_ALRMBR\_ST\_2** ((uint32\_t)0x00000040)
- #define **RTC\_ALRMBR\_SU** ((uint32\_t)0x0000000F)
- #define **RTC\_ALRMBR\_SU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_ALRMBR\_SU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_ALRMBR\_SU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_ALRMBR\_SU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_WPR\_KEY** ((uint32\_t)0x000000FF)
- #define **RTC\_SSR\_SS** ((uint32\_t)0x0000FFFF)
- #define **RTC\_SHIFTR\_SUBFS** ((uint32\_t)0x00007FFF)
- #define **RTC\_SHIFTR\_ADD1S** ((uint32\_t)0x80000000)
- #define **RTC\_TSTR\_PM** ((uint32\_t)0x00400000)
- #define **RTC\_TSTR\_HT** ((uint32\_t)0x00300000)
- #define **RTC\_TSTR\_HT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_TSTR\_HT\_1** ((uint32\_t)0x00200000)
- #define **RTC\_TSTR\_HU** ((uint32\_t)0x000F0000)
- #define **RTC\_TSTR\_HU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_TSTR\_HU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_TSTR\_HU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_TSTR\_HU\_3** ((uint32\_t)0x00080000)

- #define **RTC\_TSTR\_MNT** ((uint32\_t)0x00007000)
- #define **RTC\_TSTR\_MNT\_0** ((uint32\_t)0x00001000)
- #define **RTC\_TSTR\_MNT\_1** ((uint32\_t)0x00002000)
- #define **RTC\_TSTR\_MNT\_2** ((uint32\_t)0x00004000)
- #define **RTC\_TSTR\_MNU** ((uint32\_t)0x00000F00)
- #define **RTC\_TSTR\_MNU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_TSTR\_MNU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_TSTR\_MNU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_TSTR\_MNU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_TSTR\_ST** ((uint32\_t)0x00000070)
- #define **RTC\_TSTR\_ST\_0** ((uint32\_t)0x00000010)
- #define **RTC\_TSTR\_ST\_1** ((uint32\_t)0x00000020)
- #define **RTC\_TSTR\_ST\_2** ((uint32\_t)0x00000040)
- #define **RTC\_TSTR\_SU** ((uint32\_t)0x0000000F)
- #define **RTC\_TSTR\_SU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_TSTR\_SU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_TSTR\_SU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_TSTR\_SU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_TSDR\_WDU** ((uint32\_t)0x0000E000)
- #define **RTC\_TSDR\_WDU\_0** ((uint32\_t)0x00002000)
- #define **RTC\_TSDR\_WDU\_1** ((uint32\_t)0x00004000)
- #define **RTC\_TSDR\_WDU\_2** ((uint32\_t)0x00008000)
- #define **RTC\_TSDR\_MT** ((uint32\_t)0x00001000)
- #define **RTC\_TSDR\_MU** ((uint32\_t)0x00000F00)
- #define **RTC\_TSDR\_MU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_TSDR\_MU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_TSDR\_MU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_TSDR\_MU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_TSDR\_DT** ((uint32\_t)0x00000030)
- #define **RTC\_TSDR\_DT\_0** ((uint32\_t)0x00000010)
- #define **RTC\_TSDR\_DT\_1** ((uint32\_t)0x00000020)
- #define **RTC\_TSDR\_DU** ((uint32\_t)0x0000000F)
- #define **RTC\_TSDR\_DU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_TSDR\_DU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_TSDR\_DU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_TSDR\_DU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_TSSSR\_SS** ((uint32\_t)0x0000FFFF)
- #define **RTC\_CALR\_CALP** ((uint32\_t)0x00008000)
- #define **RTC\_CALR\_CALW8** ((uint32\_t)0x00004000)
- #define **RTC\_CALR\_CALW16** ((uint32\_t)0x00002000)
- #define **RTC\_CALR\_CALM** ((uint32\_t)0x000001FF)
- #define **RTC\_CALR\_CALM\_0** ((uint32\_t)0x00000001)
- #define **RTC\_CALR\_CALM\_1** ((uint32\_t)0x00000002)
- #define **RTC\_CALR\_CALM\_2** ((uint32\_t)0x00000004)
- #define **RTC\_CALR\_CALM\_3** ((uint32\_t)0x00000008)
- #define **RTC\_CALR\_CALM\_4** ((uint32\_t)0x00000010)
- #define **RTC\_CALR\_CALM\_5** ((uint32\_t)0x00000020)
- #define **RTC\_CALR\_CALM\_6** ((uint32\_t)0x00000040)
- #define **RTC\_CALR\_CALM\_7** ((uint32\_t)0x00000080)
- #define **RTC\_CALR\_CALM\_8** ((uint32\_t)0x00000100)
- #define **RTC\_TAFCR\_ALARMOUTTYPE** ((uint32\_t)0x00040000)
- #define **RTC\_TAFCR\_TSINSEL** ((uint32\_t)0x00020000)
- #define **RTC\_TAFCR\_TAMPINSEL** ((uint32\_t)0x00010000)
- #define **RTC\_TAFCR\_TAMPPUDIS** ((uint32\_t)0x00008000)
- #define **RTC\_TAFCR\_TAMPPRCH** ((uint32\_t)0x00006000)

- #define **RTC\_TAFCR\_TAMPPRCH\_0** ((uint32\_t)0x00002000)
- #define **RTC\_TAFCR\_TAMPPRCH\_1** ((uint32\_t)0x00004000)
- #define **RTC\_TAFCR\_TAMPFLT** ((uint32\_t)0x00001800)
- #define **RTC\_TAFCR\_TAMPFLT\_0** ((uint32\_t)0x00000800)
- #define **RTC\_TAFCR\_TAMPFLT\_1** ((uint32\_t)0x00001000)
- #define **RTC\_TAFCR\_TAMPFREQ** ((uint32\_t)0x00000700)
- #define **RTC\_TAFCR\_TAMPFREQ\_0** ((uint32\_t)0x00000100)
- #define **RTC\_TAFCR\_TAMPFREQ\_1** ((uint32\_t)0x00000200)
- #define **RTC\_TAFCR\_TAMPFREQ\_2** ((uint32\_t)0x00000400)
- #define **RTC\_TAFCR\_TAMPTS** ((uint32\_t)0x00000080)
- #define **RTC\_TAFCR\_TAMP2TRG** ((uint32\_t)0x00000010)
- #define **RTC\_TAFCR\_TAMP2E** ((uint32\_t)0x00000008)
- #define **RTC\_TAFCR\_TAMPIE** ((uint32\_t)0x00000004)
- #define **RTC\_TAFCR\_TAMP1TRG** ((uint32\_t)0x00000002)
- #define **RTC\_TAFCR\_TAMP1E** ((uint32\_t)0x00000001)
- #define **RTC\_ALRMASSR\_MASKSS** ((uint32\_t)0x0F000000)
- #define **RTC\_ALRMASSR\_MASKSS\_0** ((uint32\_t)0x01000000)
- #define **RTC\_ALRMASSR\_MASKSS\_1** ((uint32\_t)0x02000000)
- #define **RTC\_ALRMASSR\_MASKSS\_2** ((uint32\_t)0x04000000)
- #define **RTC\_ALRMASSR\_MASKSS\_3** ((uint32\_t)0x08000000)
- #define **RTC\_ALRMASSR\_SS** ((uint32\_t)0x00007FFF)
- #define **RTC\_ALRMBSSR\_MASKSS** ((uint32\_t)0x0F000000)
- #define **RTC\_ALRMBSSR\_MASKSS\_0** ((uint32\_t)0x01000000)
- #define **RTC\_ALRMBSSR\_MASKSS\_1** ((uint32\_t)0x02000000)
- #define **RTC\_ALRMBSSR\_MASKSS\_2** ((uint32\_t)0x04000000)
- #define **RTC\_ALRMBSSR\_MASKSS\_3** ((uint32\_t)0x08000000)
- #define **RTC\_ALRMBSSR\_SS** ((uint32\_t)0x00007FFF)
- #define **RTC\_BKP0R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP1R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP2R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP3R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP4R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP5R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP6R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP7R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP8R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP9R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP10R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP11R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP12R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP13R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP14R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP15R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP16R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP17R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP18R** ((uint32\_t)0xFFFFFFFF)
- #define **RTC\_BKP19R** ((uint32\_t)0xFFFFFFFF)
- #define **SAI\_GCR\_SYNCIN** ((uint32\_t)0x00000003)
- #define **SAI\_GCR\_SYNCIN\_0** ((uint32\_t)0x00000001)
- #define **SAI\_GCR\_SYNCIN\_1** ((uint32\_t)0x00000002)
- #define **SAI\_GCR\_SYNCOUT** ((uint32\_t)0x00000030)
- #define **SAI\_GCR\_SYNCOUT\_0** ((uint32\_t)0x00000010)
- #define **SAI\_GCR\_SYNCOUT\_1** ((uint32\_t)0x00000020)
- #define **SAI\_xCR1\_MODE** ((uint32\_t)0x00000003)
- #define **SAI\_xCR1\_MODE\_0** ((uint32\_t)0x00000001)

```
• #define SAI_xCR1_MODE_1 ((uint32_t)0x00000002)
• #define SAI_xCR1_PRTCFG ((uint32_t)0x0000000C)
• #define SAI_xCR1_PRTCFG_0 ((uint32_t)0x00000004)
• #define SAI_xCR1_PRTCFG_1 ((uint32_t)0x00000008)
• #define SAI_xCR1_DS ((uint32_t)0x000000E0)
• #define SAI_xCR1_DS_0 ((uint32_t)0x00000020)
• #define SAI_xCR1_DS_1 ((uint32_t)0x00000040)
• #define SAI_xCR1_DS_2 ((uint32_t)0x00000080)
• #define SAI_xCR1_LSBFIRST ((uint32_t)0x00000100)
• #define SAI_xCR1_CKSTR ((uint32_t)0x00000200)
• #define SAI_xCR1_SYNCEN ((uint32_t)0x00000C00)
• #define SAI_xCR1_SYNCEN_0 ((uint32_t)0x00000400)
• #define SAI_xCR1_SYNCEN_1 ((uint32_t)0x00000800)
• #define SAI_xCR1_MONO ((uint32_t)0x00001000)
• #define SAI_xCR1_OUTDRIV ((uint32_t)0x00002000)
• #define SAI_xCR1_SAIEN ((uint32_t)0x00010000)
• #define SAI_xCR1_DMAEN ((uint32_t)0x00020000)
• #define SAI_xCR1_NODIV ((uint32_t)0x00080000)
• #define SAI_xCR1_MCKDIV ((uint32_t)0x00780000)
• #define SAI_xCR1_MCKDIV_0 ((uint32_t)0x00080000)
• #define SAI_xCR1_MCKDIV_1 ((uint32_t)0x00100000)
• #define SAI_xCR1_MCKDIV_2 ((uint32_t)0x00200000)
• #define SAI_xCR1_MCKDIV_3 ((uint32_t)0x00400000)
• #define SAI_xCR2_FTH ((uint32_t)0x00000003)
• #define SAI_xCR2_FTH_0 ((uint32_t)0x00000001)
• #define SAI_xCR2_FTH_1 ((uint32_t)0x00000002)
• #define SAI_xCR2_FFLUSH ((uint32_t)0x00000008)
• #define SAI_xCR2_TRIS ((uint32_t)0x00000010)
• #define SAI_xCR2_MUTE ((uint32_t)0x00000020)
• #define SAI_xCR2_MUTEVAL ((uint32_t)0x00000040)
• #define SAI_xCR2_MUTECNT ((uint32_t)0x00001F80)
• #define SAI_xCR2_MUTECNT_0 ((uint32_t)0x00000080)
• #define SAI_xCR2_MUTECNT_1 ((uint32_t)0x00000100)
• #define SAI_xCR2_MUTECNT_2 ((uint32_t)0x00000200)
• #define SAI_xCR2_MUTECNT_3 ((uint32_t)0x00000400)
• #define SAI_xCR2_MUTECNT_4 ((uint32_t)0x00000800)
• #define SAI_xCR2_MUTECNT_5 ((uint32_t)0x00001000)
• #define SAI_xCR2_CPL ((uint32_t)0x00002000)
• #define SAI_xCR2_COMP ((uint32_t)0x0000C000)
• #define SAI_xCR2_COMP_0 ((uint32_t)0x00004000)
• #define SAI_xCR2_COMP_1 ((uint32_t)0x00008000)
• #define SAI_xFRCR_FRL ((uint32_t)0x000000FF)
• #define SAI_xFRCR_FRL_0 ((uint32_t)0x00000001)
• #define SAI_xFRCR_FRL_1 ((uint32_t)0x00000002)
• #define SAI_xFRCR_FRL_2 ((uint32_t)0x00000004)
• #define SAI_xFRCR_FRL_3 ((uint32_t)0x00000008)
• #define SAI_xFRCR_FRL_4 ((uint32_t)0x00000010)
• #define SAI_xFRCR_FRL_5 ((uint32_t)0x00000020)
• #define SAI_xFRCR_FRL_6 ((uint32_t)0x00000040)
• #define SAI_xFRCR_FRL_7 ((uint32_t)0x00000080)
• #define SAI_xFRCR_FSALL ((uint32_t)0x00007F00)
• #define SAI_xFRCR_FSALL_0 ((uint32_t)0x00000100)
• #define SAI_xFRCR_FSALL_1 ((uint32_t)0x00000200)
• #define SAI_xFRCR_FSALL_2 ((uint32_t)0x00000400)
• #define SAI_xFRCR_FSALL_3 ((uint32_t)0x00000800)
```

- #define SAI\_xFRCR\_FSALL\_4 ((uint32\_t)0x00001000)
- #define SAI\_xFRCR\_FSALL\_5 ((uint32\_t)0x00002000)
- #define SAI\_xFRCR\_FSALL\_6 ((uint32\_t)0x00004000)
- #define SAI\_xFRCR\_FSDEF ((uint32\_t)0x00010000)
- #define SAI\_xFRCR\_FSPOL ((uint32\_t)0x00020000)
- #define SAI\_xFRCR\_FSOFF ((uint32\_t)0x00040000)
- #define SAI\_xFRCR\_FSPO SAI\_xFRCR\_FSPOL
- #define SAI\_xSLOTR\_FBOFF ((uint32\_t)0x00000001F)
- #define SAI\_xSLOTR\_FBOFF\_0 ((uint32\_t)0x000000001)
- #define SAI\_xSLOTR\_FBOFF\_1 ((uint32\_t)0x000000002)
- #define SAI\_xSLOTR\_FBOFF\_2 ((uint32\_t)0x000000004)
- #define SAI\_xSLOTR\_FBOFF\_3 ((uint32\_t)0x000000008)
- #define SAI\_xSLOTR\_FBOFF\_4 ((uint32\_t)0x000000010)
- #define SAI\_xSLOTR\_SLOTsz ((uint32\_t)0x000000C0)
- #define SAI\_xSLOTR\_SLOTsz\_0 ((uint32\_t)0x00000040)
- #define SAI\_xSLOTR\_SLOTsz\_1 ((uint32\_t)0x00000080)
- #define SAI\_xSLOTR\_NBSLOT ((uint32\_t)0x000000F00)
- #define SAI\_xSLOTR\_NBSLOT\_0 ((uint32\_t)0x00000100)
- #define SAI\_xSLOTR\_NBSLOT\_1 ((uint32\_t)0x00000200)
- #define SAI\_xSLOTR\_NBSLOT\_2 ((uint32\_t)0x00000400)
- #define SAI\_xSLOTR\_NBSLOT\_3 ((uint32\_t)0x00000800)
- #define SAI\_xSLOTR\_SLOTEN ((uint32\_t)0xFFFF0000)
- #define SAI\_xIMR\_OVRUDRIE ((uint32\_t)0x00000001)
- #define SAI\_xIMR\_MUTEDETIE ((uint32\_t)0x00000002)
- #define SAI\_xIMR\_WCKCFGIE ((uint32\_t)0x00000004)
- #define SAI\_xIMR\_FREQIE ((uint32\_t)0x00000008)
- #define SAI\_xIMR\_CNRDYIE ((uint32\_t)0x00000010)
- #define SAI\_xIMR\_AFSDETIE ((uint32\_t)0x00000020)
- #define SAI\_xIMR\_LFSDETIE ((uint32\_t)0x00000040)
- #define SAI\_xSR\_OVRUDR ((uint32\_t)0x00000001)
- #define SAI\_xSR\_MUTEDET ((uint32\_t)0x00000002)
- #define SAI\_xSR\_WCKCFG ((uint32\_t)0x00000004)
- #define SAI\_xSR\_FREQ ((uint32\_t)0x00000008)
- #define SAI\_xSR\_CNRDY ((uint32\_t)0x00000010)
- #define SAI\_xSR\_AFSDET ((uint32\_t)0x00000020)
- #define SAI\_xSR\_LFSDET ((uint32\_t)0x00000040)
- #define SAI\_xSR\_FLVL ((uint32\_t)0x00070000)
- #define SAI\_xSR\_FLVL\_0 ((uint32\_t)0x00010000)
- #define SAI\_xSR\_FLVL\_1 ((uint32\_t)0x00020000)
- #define SAI\_xSR\_FLVL\_2 ((uint32\_t)0x00030000)
- #define SAI\_xCLRFR\_COVRUDR ((uint32\_t)0x00000001)
- #define SAI\_xCLRFR\_CMUTEDET ((uint32\_t)0x00000002)
- #define SAI\_xCLRFR\_CWCKCFG ((uint32\_t)0x00000004)
- #define SAI\_xCLRFR\_CFREQ ((uint32\_t)0x00000008)
- #define SAI\_xCLRFR\_CCNRDY ((uint32\_t)0x00000010)
- #define SAI\_xCLRFR\_CAFSDET ((uint32\_t)0x00000020)
- #define SAI\_xCLRFR\_CLFSDET ((uint32\_t)0x00000040)
- #define SAI\_xDR\_DATA ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_POWER\_PWRCTRL ((uint8\_t)0x03)
- #define SDIO\_POWER\_PWRCTRL\_0 ((uint8\_t)0x01)
- #define SDIO\_POWER\_PWRCTRL\_1 ((uint8\_t)0x02)
- #define SDIO\_CLKCR\_CLKDIV ((uint16\_t)0x00FF)
- #define SDIO\_CLKCR\_CLKEN ((uint16\_t)0x0100)
- #define SDIO\_CLKCR\_PWRSAV ((uint16\_t)0x0200)
- #define SDIO\_CLKCR\_BYPASS ((uint16\_t)0x0400)

- #define SDIO\_CLKCR\_WIDBUS ((uint16\_t)0x1800)
- #define SDIO\_CLKCR\_WIDBUS\_0 ((uint16\_t)0x0800)
- #define SDIO\_CLKCR\_WIDBUS\_1 ((uint16\_t)0x1000)
- #define SDIO\_CLKCR\_NEGEDGE ((uint16\_t)0x2000)
- #define SDIO\_CLKCR\_HWFC\_EN ((uint16\_t)0x4000)
- #define SDIO\_ARG\_CMDARG ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_CMD\_CMDINDEX ((uint16\_t)0x003F)
- #define SDIO\_CMD\_WAITRESP ((uint16\_t)0x00C0)
- #define SDIO\_CMD\_WAITRESP\_0 ((uint16\_t)0x0040)
- #define SDIO\_CMD\_WAITRESP\_1 ((uint16\_t)0x0080)
- #define SDIO\_CMD\_WAITINT ((uint16\_t)0x0100)
- #define SDIO\_CMD\_WAITPEND ((uint16\_t)0x0200)
- #define SDIO\_CMD\_CPSMEN ((uint16\_t)0x0400)
- #define SDIO\_CMD\_SDIOSUSPEND ((uint16\_t)0x0800)
- #define SDIO\_CMD\_ENCMDCOMPL ((uint16\_t)0x1000)
- #define SDIO\_CMD\_NIEN ((uint16\_t)0x2000)
- #define SDIO\_CMD\_CEATACMD ((uint16\_t)0x4000)
- #define SDIO\_RESPCMD\_RESPCMD ((uint8\_t)0x3F)
- #define SDIO\_RESP0\_CARDSTATUS0 ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_RESP1\_CARDSTATUS1 ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_RESP2\_CARDSTATUS2 ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_RESP3\_CARDSTATUS3 ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_RESP4\_CARDSTATUS4 ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_DTIMER\_DATETIME ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_DLEN\_DATALENGTH ((uint32\_t)0x01FFFFFF)
- #define SDIO\_DCTRL\_DTEN ((uint16\_t)0x0001)
- #define SDIO\_DCTRL\_DDIR ((uint16\_t)0x0002)
- #define SDIO\_DCTRL\_DTMODE ((uint16\_t)0x0004)
- #define SDIO\_DCTRL\_DMAEN ((uint16\_t)0x0008)
- #define SDIO\_DCTRL\_DBLOCKSIZE ((uint16\_t)0x00F0)
- #define SDIO\_DCTRL\_DBLOCKSIZE\_0 ((uint16\_t)0x0010)
- #define SDIO\_DCTRL\_DBLOCKSIZE\_1 ((uint16\_t)0x0020)
- #define SDIO\_DCTRL\_DBLOCKSIZE\_2 ((uint16\_t)0x0040)
- #define SDIO\_DCTRL\_DBLOCKSIZE\_3 ((uint16\_t)0x0080)
- #define SDIO\_DCTRL\_RWSTART ((uint16\_t)0x0100)
- #define SDIO\_DCTRL\_RWSTOP ((uint16\_t)0x0200)
- #define SDIO\_DCTRL\_RWMOD ((uint16\_t)0x0400)
- #define SDIO\_DCTRL\_SDIOEN ((uint16\_t)0x0800)
- #define SDIO\_DCOUNT\_DATACOUNT ((uint32\_t)0x01FFFFFF)
- #define SDIO\_STA\_CCRCFAIL ((uint32\_t)0x00000001)
- #define SDIO\_STA\_DCRCFAIL ((uint32\_t)0x00000002)
- #define SDIO\_STA\_CTIMEOUT ((uint32\_t)0x00000004)
- #define SDIO\_STA\_DTIMEOUT ((uint32\_t)0x00000008)
- #define SDIO\_STA\_TXUNDERR ((uint32\_t)0x00000010)
- #define SDIO\_STA\_RXOVERR ((uint32\_t)0x00000020)
- #define SDIO\_STA\_CMDREND ((uint32\_t)0x00000040)
- #define SDIO\_STA\_CMDSENT ((uint32\_t)0x00000080)
- #define SDIO\_STA\_DATAEND ((uint32\_t)0x00000100)
- #define SDIO\_STA\_STBITERR ((uint32\_t)0x00000200)
- #define SDIO\_STA\_DBCKEND ((uint32\_t)0x00000400)
- #define SDIO\_STA\_CMDACT ((uint32\_t)0x00000800)
- #define SDIO\_STA\_TXACT ((uint32\_t)0x00001000)
- #define SDIO\_STA\_RXACT ((uint32\_t)0x00002000)
- #define SDIO\_STA\_TXFIFOHE ((uint32\_t)0x00004000)
- #define SDIO\_STA\_RXFIFOHF ((uint32\_t)0x00008000)

- #define SDIO\_STA\_TXFIFOF ((uint32\_t)0x00010000)
- #define SDIO\_STA\_RXFIFOF ((uint32\_t)0x00020000)
- #define SDIO\_STA\_TXFIFOE ((uint32\_t)0x00040000)
- #define SDIO\_STA\_RXFIFOE ((uint32\_t)0x00080000)
- #define SDIO\_STA\_TXDAVL ((uint32\_t)0x00100000)
- #define SDIO\_STA\_RXDAVL ((uint32\_t)0x00200000)
- #define SDIO\_STA\_SDIOIT ((uint32\_t)0x00400000)
- #define SDIO\_STA\_CEATAEND ((uint32\_t)0x00800000)
- #define SDIO\_ICR\_CCRCFAILC ((uint32\_t)0x00000001)
- #define SDIO\_ICR\_DCRCFAILC ((uint32\_t)0x00000002)
- #define SDIO\_ICR\_CTIMEOUTC ((uint32\_t)0x00000004)
- #define SDIO\_ICR\_DTIMEOUTC ((uint32\_t)0x00000008)
- #define SDIO\_ICR\_TXUNDERRC ((uint32\_t)0x00000010)
- #define SDIO\_ICR\_RXOVERRC ((uint32\_t)0x00000020)
- #define SDIO\_ICR\_CMDRENDC ((uint32\_t)0x00000040)
- #define SDIO\_ICR\_CMDSENTC ((uint32\_t)0x00000080)
- #define SDIO\_ICR\_DATAENDC ((uint32\_t)0x00000100)
- #define SDIO\_ICR\_STBITERRC ((uint32\_t)0x00000200)
- #define SDIO\_ICR\_DBCKENDC ((uint32\_t)0x00000400)
- #define SDIO\_ICR\_SDIOITC ((uint32\_t)0x00400000)
- #define SDIO\_ICR\_CEATAENDC ((uint32\_t)0x00800000)
- #define SDIO\_MASK\_CCRCFAILIE ((uint32\_t)0x00000001)
- #define SDIO\_MASK\_DCRCFAILIE ((uint32\_t)0x00000002)
- #define SDIO\_MASK\_CTIMEOUTIE ((uint32\_t)0x00000004)
- #define SDIO\_MASK\_DTIMEOUTIE ((uint32\_t)0x00000008)
- #define SDIO\_MASK\_TXUNDERRIE ((uint32\_t)0x00000010)
- #define SDIO\_MASK\_RXOVERRIE ((uint32\_t)0x00000020)
- #define SDIO\_MASK\_CMDRENDE ((uint32\_t)0x00000040)
- #define SDIO\_MASK\_CMDSENTIE ((uint32\_t)0x00000080)
- #define SDIO\_MASK\_DATAENDIE ((uint32\_t)0x00000100)
- #define SDIO\_MASK\_STBITERRIE ((uint32\_t)0x00000200)
- #define SDIO\_MASK\_DBCKENDIE ((uint32\_t)0x00000400)
- #define SDIO\_MASK\_CMDACTIE ((uint32\_t)0x00000800)
- #define SDIO\_MASK\_TXACTIE ((uint32\_t)0x00001000)
- #define SDIO\_MASK\_RXACTIE ((uint32\_t)0x00002000)
- #define SDIO\_MASK\_TXFIFOHEIE ((uint32\_t)0x00004000)
- #define SDIO\_MASK\_RXFIFOHFIE ((uint32\_t)0x00008000)
- #define SDIO\_MASK\_TXFIFOFIE ((uint32\_t)0x00010000)
- #define SDIO\_MASK\_RXFIFOFIE ((uint32\_t)0x00020000)
- #define SDIO\_MASK\_TXFIFOEIE ((uint32\_t)0x00040000)
- #define SDIO\_MASK\_RXFIFOEIE ((uint32\_t)0x00080000)
- #define SDIO\_MASK\_TXDAVLIE ((uint32\_t)0x00100000)
- #define SDIO\_MASK\_RXDAVLIE ((uint32\_t)0x00200000)
- #define SDIO\_MASK\_SDIOITIE ((uint32\_t)0x00400000)
- #define SDIO\_MASK\_CEATAENDIE ((uint32\_t)0x00800000)
- #define SDIO\_FIFO\_CNT\_FIFOCOUNT ((uint32\_t)0x00FFFFFF)
- #define SDIO\_FIFO\_FIFODATA ((uint32\_t)0xFFFFFFFF)
- #define SPI\_CR1\_CPHA ((uint16\_t)0x0001)
- #define SPI\_CR1\_CPOL ((uint16\_t)0x0002)
- #define SPI\_CR1\_MSTR ((uint16\_t)0x0004)
- #define SPI\_CR1\_BR ((uint16\_t)0x0038)
- #define SPI\_CR1\_BR\_0 ((uint16\_t)0x0008)
- #define SPI\_CR1\_BR\_1 ((uint16\_t)0x0010)
- #define SPI\_CR1\_BR\_2 ((uint16\_t)0x0020)
- #define SPI\_CR1\_SPE ((uint16\_t)0x0040)

- #define SPI\_CR1\_LSBFIRST ((uint16\_t)0x0080)
- #define SPI\_CR1\_SSI ((uint16\_t)0x0100)
- #define SPI\_CR1\_SSM ((uint16\_t)0x0200)
- #define SPI\_CR1\_RXONLY ((uint16\_t)0x0400)
- #define SPI\_CR1\_DFF ((uint16\_t)0x0800)
- #define SPI\_CR1\_CRCNEXT ((uint16\_t)0x1000)
- #define SPI\_CR1\_CRCEN ((uint16\_t)0x2000)
- #define SPI\_CR1\_BIDIOE ((uint16\_t)0x4000)
- #define SPI\_CR1\_BIDIMODE ((uint16\_t)0x8000)
- #define SPI\_CR2\_RXDMAEN ((uint8\_t)0x01)
- #define SPI\_CR2\_TXDMAEN ((uint8\_t)0x02)
- #define SPI\_CR2\_SSOE ((uint8\_t)0x04)
- #define SPI\_CR2\_ERRIE ((uint8\_t)0x20)
- #define SPI\_CR2\_RXNEIE ((uint8\_t)0x40)
- #define SPI\_CR2\_TXEIE ((uint8\_t)0x80)
- #define SPI\_SR\_RXNE ((uint8\_t)0x01)
- #define SPI\_SR\_TXE ((uint8\_t)0x02)
- #define SPI\_SR\_CHSIDE ((uint8\_t)0x04)
- #define SPI\_SR\_UDR ((uint8\_t)0x08)
- #define SPI\_SR\_CRCERR ((uint8\_t)0x10)
- #define SPI\_SR\_MODF ((uint8\_t)0x20)
- #define SPI\_SR\_OVR ((uint8\_t)0x40)
- #define SPI\_SR\_BSY ((uint8\_t)0x80)
- #define SPI\_DR\_DR ((uint16\_t)0xFFFF)
- #define SPI\_CRCPR\_CRCPOLY ((uint16\_t)0xFFFF)
- #define SPI\_RXCRCR\_RXCRC ((uint16\_t)0xFFFF)
- #define SPI\_TXCRCR\_TXCRC ((uint16\_t)0xFFFF)
- #define SPI\_I2SCFGR\_CHLEN ((uint16\_t)0x0001)
- #define SPI\_I2SCFGR\_DATLEN ((uint16\_t)0x0006)
- #define SPI\_I2SCFGR\_DATLEN\_0 ((uint16\_t)0x0002)
- #define SPI\_I2SCFGR\_DATLEN\_1 ((uint16\_t)0x0004)
- #define SPI\_I2SCFGR\_CKPOL ((uint16\_t)0x0008)
- #define SPI\_I2SCFGR\_I2SSTD ((uint16\_t)0x0030)
- #define SPI\_I2SCFGR\_I2SSTD\_0 ((uint16\_t)0x0010)
- #define SPI\_I2SCFGR\_I2SSTD\_1 ((uint16\_t)0x0020)
- #define SPI\_I2SCFGR\_PCMSYNC ((uint16\_t)0x0080)
- #define SPI\_I2SCFGR\_I2SCFG ((uint16\_t)0x0300)
- #define SPI\_I2SCFGR\_I2SCFG\_0 ((uint16\_t)0x0100)
- #define SPI\_I2SCFGR\_I2SCFG\_1 ((uint16\_t)0x0200)
- #define SPI\_I2SCFGR\_I2SE ((uint16\_t)0x0400)
- #define SPI\_I2SCFGR\_I2SMOD ((uint16\_t)0x0800)
- #define SPI\_I2SPR\_I2SDIV ((uint16\_t)0x00FF)
- #define SPI\_I2SPR\_ODD ((uint16\_t)0x0100)
- #define SPI\_I2SPR\_MCKOE ((uint16\_t)0x0200)
- #define SYSCFG\_MEMRMP\_MEM\_MODE ((uint32\_t)0x00000007)
- #define SYSCFG\_MEMRMP\_MEM\_MODE\_0 ((uint32\_t)0x00000001)
- #define SYSCFG\_MEMRMP\_MEM\_MODE\_1 ((uint32\_t)0x00000002)
- #define SYSCFG\_MEMRMP\_MEM\_MODE\_2 ((uint32\_t)0x00000004)
- #define SYSCFG\_MEMRMP\_FB\_MODE ((uint32\_t)0x00000100)
- #define SYSCFG\_MEMRMP\_SWP\_FMC ((uint32\_t)0x00000C00)
- #define SYSCFG\_MEMRMP\_SWP\_FMC\_0 ((uint32\_t)0x00000400)
- #define SYSCFG\_MEMRMP\_SWP\_FMC\_1 ((uint32\_t)0x00000800)
- #define SYSCFG\_PMC\_ADCxDC2 ((uint32\_t)0x00070000)
- #define SYSCFG\_PMC\_ADC1DC2 ((uint32\_t)0x00010000)
- #define SYSCFG\_PMC\_ADC2DC2 ((uint32\_t)0x00020000)

- #define SYSCFG\_PMC\_ADC3DC2 ((uint32\_t)0x00040000)
- #define SYSCFG\_PMC\_MII\_RMII\_SEL ((uint32\_t)0x00800000)
- #define **SYSCFG\_PMC\_MII\_RMII** SYSCFG\_PMC\_MII\_RMII\_SEL
- #define SYSCFG\_EXTICR1\_EXTI0 ((uint16\_t)0x000F)
- #define SYSCFG\_EXTICR1\_EXTI1 ((uint16\_t)0x00F0)
- #define SYSCFG\_EXTICR1\_EXTI2 ((uint16\_t)0x0F00)
- #define SYSCFG\_EXTICR1\_EXTI3 ((uint16\_t)0xF000)
- #define SYSCFG\_EXTICR1\_EXTI0\_PA ((uint16\_t)0x0000)

*EXTI0 configuration*

- #define SYSCFG\_EXTICR1\_EXTI0\_PB ((uint16\_t)0x0001)
- #define SYSCFG\_EXTICR1\_EXTI0\_PC ((uint16\_t)0x0002)
- #define SYSCFG\_EXTICR1\_EXTI0\_PD ((uint16\_t)0x0003)
- #define SYSCFG\_EXTICR1\_EXTI0\_PE ((uint16\_t)0x0004)
- #define SYSCFG\_EXTICR1\_EXTI0\_PF ((uint16\_t)0x0005)
- #define SYSCFG\_EXTICR1\_EXTI0\_PG ((uint16\_t)0x0006)
- #define SYSCFG\_EXTICR1\_EXTI0\_PH ((uint16\_t)0x0007)
- #define SYSCFG\_EXTICR1\_EXTI0\_PI ((uint16\_t)0x0008)
- #define SYSCFG\_EXTICR1\_EXTI0\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR1\_EXTI0\_PK ((uint16\_t)0x000A)
- #define SYSCFG\_EXTICR1\_EXTI1\_PA ((uint16\_t)0x0000)

*EXTI1 configuration*

- #define SYSCFG\_EXTICR1\_EXTI1\_PB ((uint16\_t)0x0010)
- #define SYSCFG\_EXTICR1\_EXTI1\_PC ((uint16\_t)0x0020)
- #define SYSCFG\_EXTICR1\_EXTI1\_PD ((uint16\_t)0x0030)
- #define SYSCFG\_EXTICR1\_EXTI1\_PE ((uint16\_t)0x0040)
- #define SYSCFG\_EXTICR1\_EXTI1\_PF ((uint16\_t)0x0050)
- #define SYSCFG\_EXTICR1\_EXTI1\_PG ((uint16\_t)0x0060)
- #define SYSCFG\_EXTICR1\_EXTI1\_PH ((uint16\_t)0x0070)
- #define SYSCFG\_EXTICR1\_EXTI1\_PI ((uint16\_t)0x0080)
- #define SYSCFG\_EXTICR1\_EXTI1\_PJ ((uint16\_t)0x0090)
- #define SYSCFG\_EXTICR1\_EXTI1\_PK ((uint16\_t)0x00A0)
- #define SYSCFG\_EXTICR1\_EXTI2\_PA ((uint16\_t)0x0000)

*EXTI2 configuration*

- #define SYSCFG\_EXTICR1\_EXTI2\_PB ((uint16\_t)0x0100)
- #define SYSCFG\_EXTICR1\_EXTI2\_PC ((uint16\_t)0x0200)
- #define SYSCFG\_EXTICR1\_EXTI2\_PD ((uint16\_t)0x0300)
- #define SYSCFG\_EXTICR1\_EXTI2\_PE ((uint16\_t)0x0400)
- #define SYSCFG\_EXTICR1\_EXTI2\_PF ((uint16\_t)0x0500)
- #define SYSCFG\_EXTICR1\_EXTI2\_PG ((uint16\_t)0x0600)
- #define SYSCFG\_EXTICR1\_EXTI2\_PH ((uint16\_t)0x0700)
- #define SYSCFG\_EXTICR1\_EXTI2\_PI ((uint16\_t)0x0800)
- #define SYSCFG\_EXTICR1\_EXTI2\_PJ ((uint16\_t)0x0900)
- #define SYSCFG\_EXTICR1\_EXTI2\_PK ((uint16\_t)0x0A00)
- #define SYSCFG\_EXTICR1\_EXTI3\_PA ((uint16\_t)0x0000)

*EXTI3 configuration*

- #define SYSCFG\_EXTICR1\_EXTI3\_PB ((uint16\_t)0x1000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PC ((uint16\_t)0x2000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PD ((uint16\_t)0x3000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PE ((uint16\_t)0x4000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PF ((uint16\_t)0x5000)

- #define SYSCFG\_EXTICR1\_EXTI3\_PG ((uint16\_t)0x6000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PH ((uint16\_t)0x7000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PI ((uint16\_t)0x8000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PJ ((uint16\_t)0x9000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PK ((uint16\_t)0xA000)
- #define SYSCFG\_EXTICR2\_EXTI4 ((uint16\_t)0x000F)
- #define SYSCFG\_EXTICR2\_EXTI5 ((uint16\_t)0x00F0)
- #define SYSCFG\_EXTICR2\_EXTI6 ((uint16\_t)0x0F00)
- #define SYSCFG\_EXTICR2\_EXTI7 ((uint16\_t)0xF000)
- #define SYSCFG\_EXTICR2\_EXTI4\_PA ((uint16\_t)0x0000)

*EXTI4 configuration*

- #define SYSCFG\_EXTICR2\_EXTI4\_PB ((uint16\_t)0x0001)
- #define SYSCFG\_EXTICR2\_EXTI4\_PC ((uint16\_t)0x0002)
- #define SYSCFG\_EXTICR2\_EXTI4\_PD ((uint16\_t)0x0003)
- #define SYSCFG\_EXTICR2\_EXTI4\_PE ((uint16\_t)0x0004)
- #define SYSCFG\_EXTICR2\_EXTI4\_PF ((uint16\_t)0x0005)
- #define SYSCFG\_EXTICR2\_EXTI4\_PG ((uint16\_t)0x0006)
- #define SYSCFG\_EXTICR2\_EXTI4\_PH ((uint16\_t)0x0007)
- #define SYSCFG\_EXTICR2\_EXTI4\_PI ((uint16\_t)0x0008)
- #define SYSCFG\_EXTICR2\_EXTI4\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR2\_EXTI4\_PK ((uint16\_t)0x000A)
- #define SYSCFG\_EXTICR2\_EXTI5\_PA ((uint16\_t)0x0000)

*EXTI5 configuration*

- #define SYSCFG\_EXTICR2\_EXTI5\_PB ((uint16\_t)0x0010)
- #define SYSCFG\_EXTICR2\_EXTI5\_PC ((uint16\_t)0x0020)
- #define SYSCFG\_EXTICR2\_EXTI5\_PD ((uint16\_t)0x0030)
- #define SYSCFG\_EXTICR2\_EXTI5\_PE ((uint16\_t)0x0040)
- #define SYSCFG\_EXTICR2\_EXTI5\_PF ((uint16\_t)0x0050)
- #define SYSCFG\_EXTICR2\_EXTI5\_PG ((uint16\_t)0x0060)
- #define SYSCFG\_EXTICR2\_EXTI5\_PH ((uint16\_t)0x0070)
- #define SYSCFG\_EXTICR2\_EXTI5\_PI ((uint16\_t)0x0080)
- #define SYSCFG\_EXTICR2\_EXTI5\_PJ ((uint16\_t)0x0090)
- #define SYSCFG\_EXTICR2\_EXTI5\_PK ((uint16\_t)0x00A0)
- #define SYSCFG\_EXTICR2\_EXTI6\_PA ((uint16\_t)0x0000)

*EXTI6 configuration*

- #define SYSCFG\_EXTICR2\_EXTI6\_PB ((uint16\_t)0x0100)
- #define SYSCFG\_EXTICR2\_EXTI6\_PC ((uint16\_t)0x0200)
- #define SYSCFG\_EXTICR2\_EXTI6\_PD ((uint16\_t)0x0300)
- #define SYSCFG\_EXTICR2\_EXTI6\_PE ((uint16\_t)0x0400)
- #define SYSCFG\_EXTICR2\_EXTI6\_PF ((uint16\_t)0x0500)
- #define SYSCFG\_EXTICR2\_EXTI6\_PG ((uint16\_t)0x0600)
- #define SYSCFG\_EXTICR2\_EXTI6\_PH ((uint16\_t)0x0700)
- #define SYSCFG\_EXTICR2\_EXTI6\_PI ((uint16\_t)0x0800)
- #define SYSCFG\_EXTICR2\_EXTI6\_PJ ((uint16\_t)0x0900)
- #define SYSCFG\_EXTICR2\_EXTI6\_PK ((uint16\_t)0x0A00)
- #define SYSCFG\_EXTICR2\_EXTI7\_PA ((uint16\_t)0x0000)

*EXTI7 configuration*

- #define SYSCFG\_EXTICR2\_EXTI7\_PB ((uint16\_t)0x1000)
- #define SYSCFG\_EXTICR2\_EXTI7\_PC ((uint16\_t)0x2000)
- #define SYSCFG\_EXTICR2\_EXTI7\_PD ((uint16\_t)0x3000)

- #define SYSCFG\_EXTICR2\_EXTI7\_PE ((uint16\_t)0x4000)
- #define SYSCFG\_EXTICR2\_EXTI7\_PF ((uint16\_t)0x5000)
- #define SYSCFG\_EXTICR2\_EXTI7\_PG ((uint16\_t)0x6000)
- #define SYSCFG\_EXTICR2\_EXTI7\_PH ((uint16\_t)0x7000)
- #define SYSCFG\_EXTICR2\_EXTI7\_PI ((uint16\_t)0x8000)
- #define SYSCFG\_EXTICR2\_EXTI7\_PJ ((uint16\_t)0x9000)
- #define SYSCFG\_EXTICR2\_EXTI7\_PK ((uint16\_t)0xA000)
- #define SYSCFG\_EXTICR3\_EXTI8 ((uint16\_t)0x000F)
- #define SYSCFG\_EXTICR3\_EXTI9 ((uint16\_t)0x00F0)
- #define SYSCFG\_EXTICR3\_EXTI10 ((uint16\_t)0x0F00)
- #define SYSCFG\_EXTICR3\_EXTI11 ((uint16\_t)0xF000)
- #define SYSCFG\_EXTICR3\_EXTI8\_PA ((uint16\_t)0x0000)

*EXTI8 configuration*

- #define SYSCFG\_EXTICR3\_EXTI8\_PB ((uint16\_t)0x0001)
- #define SYSCFG\_EXTICR3\_EXTI8\_PC ((uint16\_t)0x0002)
- #define SYSCFG\_EXTICR3\_EXTI8\_PD ((uint16\_t)0x0003)
- #define SYSCFG\_EXTICR3\_EXTI8\_PE ((uint16\_t)0x0004)
- #define SYSCFG\_EXTICR3\_EXTI8\_PF ((uint16\_t)0x0005)
- #define SYSCFG\_EXTICR3\_EXTI8\_PG ((uint16\_t)0x0006)
- #define SYSCFG\_EXTICR3\_EXTI8\_PH ((uint16\_t)0x0007)
- #define SYSCFG\_EXTICR3\_EXTI8\_PI ((uint16\_t)0x0008)
- #define SYSCFG\_EXTICR3\_EXTI8\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR3\_EXTI9\_PA ((uint16\_t)0x0000)

*EXTI9 configuration*

- #define SYSCFG\_EXTICR3\_EXTI9\_PB ((uint16\_t)0x0010)
- #define SYSCFG\_EXTICR3\_EXTI9\_PC ((uint16\_t)0x0020)
- #define SYSCFG\_EXTICR3\_EXTI9\_PD ((uint16\_t)0x0030)
- #define SYSCFG\_EXTICR3\_EXTI9\_PE ((uint16\_t)0x0040)
- #define SYSCFG\_EXTICR3\_EXTI9\_PF ((uint16\_t)0x0050)
- #define SYSCFG\_EXTICR3\_EXTI9\_PG ((uint16\_t)0x0060)
- #define SYSCFG\_EXTICR3\_EXTI9\_PH ((uint16\_t)0x0070)
- #define SYSCFG\_EXTICR3\_EXTI9\_PI ((uint16\_t)0x0080)
- #define SYSCFG\_EXTICR3\_EXTI9\_PJ ((uint16\_t)0x0090)
- #define SYSCFG\_EXTICR3\_EXTI10\_PA ((uint16\_t)0x0000)

*EXTI10 configuration*

- #define SYSCFG\_EXTICR3\_EXTI10\_PB ((uint16\_t)0x0100)
- #define SYSCFG\_EXTICR3\_EXTI10\_PC ((uint16\_t)0x0200)
- #define SYSCFG\_EXTICR3\_EXTI10\_PD ((uint16\_t)0x0300)
- #define SYSCFG\_EXTICR3\_EXTI10\_PE ((uint16\_t)0x0400)
- #define SYSCFG\_EXTICR3\_EXTI10\_PF ((uint16\_t)0x0500)
- #define SYSCFG\_EXTICR3\_EXTI10\_PG ((uint16\_t)0x0600)
- #define SYSCFG\_EXTICR3\_EXTI10\_PH ((uint16\_t)0x0700)
- #define SYSCFG\_EXTICR3\_EXTI10\_PI ((uint16\_t)0x0800)
- #define SYSCFG\_EXTICR3\_EXTI10\_PJ ((uint16\_t)0x0900)
- #define SYSCFG\_EXTICR3\_EXTI11\_PA ((uint16\_t)0x0000)

*EXTI11 configuration*

- #define SYSCFG\_EXTICR3\_EXTI11\_PB ((uint16\_t)0x1000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PC ((uint16\_t)0x2000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PD ((uint16\_t)0x3000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PE ((uint16\_t)0x4000)

- #define SYSCFG\_EXTICR3\_EXTI11\_PF ((uint16\_t)0x5000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PG ((uint16\_t)0x6000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PH ((uint16\_t)0x7000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PI ((uint16\_t)0x8000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PJ ((uint16\_t)0x9000)
- #define SYSCFG\_EXTICR4\_EXTI12 ((uint16\_t)0x000F)
- #define SYSCFG\_EXTICR4\_EXTI13 ((uint16\_t)0x00F0)
- #define SYSCFG\_EXTICR4\_EXTI14 ((uint16\_t)0x0F00)
- #define SYSCFG\_EXTICR4\_EXTI15 ((uint16\_t)0xF000)
- #define SYSCFG\_EXTICR4\_EXTI12\_PA ((uint16\_t)0x0000)

*EXTI12 configuration*

- #define SYSCFG\_EXTICR4\_EXTI12\_PB ((uint16\_t)0x0001)
- #define SYSCFG\_EXTICR4\_EXTI12\_PC ((uint16\_t)0x0002)
- #define SYSCFG\_EXTICR4\_EXTI12\_PD ((uint16\_t)0x0003)
- #define SYSCFG\_EXTICR4\_EXTI12\_PE ((uint16\_t)0x0004)
- #define SYSCFG\_EXTICR4\_EXTI12\_PF ((uint16\_t)0x0005)
- #define SYSCFG\_EXTICR4\_EXTI12\_PG ((uint16\_t)0x0006)
- #define SYSCFG\_EXTICR4\_EXTI12\_PH ((uint16\_t)0x0007)
- #define SYSCFG\_EXTICR4\_EXTI12\_PI ((uint16\_t)0x0008)
- #define SYSCFG\_EXTICR4\_EXTI12\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR4\_EXTI13\_PA ((uint16\_t)0x0000)

*EXTI13 configuration*

- #define SYSCFG\_EXTICR4\_EXTI13\_PB ((uint16\_t)0x0010)
- #define SYSCFG\_EXTICR4\_EXTI13\_PC ((uint16\_t)0x0020)
- #define SYSCFG\_EXTICR4\_EXTI13\_PD ((uint16\_t)0x0030)
- #define SYSCFG\_EXTICR4\_EXTI13\_PE ((uint16\_t)0x0040)
- #define SYSCFG\_EXTICR4\_EXTI13\_PF ((uint16\_t)0x0050)
- #define SYSCFG\_EXTICR4\_EXTI13\_PG ((uint16\_t)0x0060)
- #define SYSCFG\_EXTICR4\_EXTI13\_PH ((uint16\_t)0x0070)
- #define SYSCFG\_EXTICR4\_EXTI13\_PI ((uint16\_t)0x0008)
- #define SYSCFG\_EXTICR4\_EXTI13\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR4\_EXTI14\_PA ((uint16\_t)0x0000)

*EXTI14 configuration*

- #define SYSCFG\_EXTICR4\_EXTI14\_PB ((uint16\_t)0x0100)
- #define SYSCFG\_EXTICR4\_EXTI14\_PC ((uint16\_t)0x0200)
- #define SYSCFG\_EXTICR4\_EXTI14\_PD ((uint16\_t)0x0300)
- #define SYSCFG\_EXTICR4\_EXTI14\_PE ((uint16\_t)0x0400)
- #define SYSCFG\_EXTICR4\_EXTI14\_PF ((uint16\_t)0x0500)
- #define SYSCFG\_EXTICR4\_EXTI14\_PG ((uint16\_t)0x0600)
- #define SYSCFG\_EXTICR4\_EXTI14\_PH ((uint16\_t)0x0700)
- #define SYSCFG\_EXTICR4\_EXTI14\_PI ((uint16\_t)0x0800)
- #define SYSCFG\_EXTICR4\_EXTI14\_PJ ((uint16\_t)0x0900)
- #define SYSCFG\_EXTICR4\_EXTI15\_PA ((uint16\_t)0x0000)

*EXTI15 configuration*

- #define SYSCFG\_EXTICR4\_EXTI15\_PB ((uint16\_t)0x1000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PC ((uint16\_t)0x2000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PD ((uint16\_t)0x3000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PE ((uint16\_t)0x4000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PF ((uint16\_t)0x5000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PG ((uint16\_t)0x6000)

- #define SYSCFG\_EXTICR4\_EXTI15\_PH ((uint16\_t)0x7000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PI ((uint16\_t)0x8000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PJ ((uint16\_t)0x9000)
- #define SYSCFG\_CMPCR\_CMP\_PD ((uint32\_t)0x00000001)
- #define SYSCFG\_CMPCR\_READY ((uint32\_t)0x00000100)
- #define TIM\_CR1\_CEN ((uint16\_t)0x0001)
- #define TIM\_CR1\_UDIS ((uint16\_t)0x0002)
- #define TIM\_CR1\_URS ((uint16\_t)0x0004)
- #define TIM\_CR1\_OPM ((uint16\_t)0x0008)
- #define TIM\_CR1\_DIR ((uint16\_t)0x0010)
- #define TIM\_CR1\_CMS ((uint16\_t)0x0060)
- #define TIM\_CR1\_CMS\_0 ((uint16\_t)0x0020)
- #define TIM\_CR1\_CMS\_1 ((uint16\_t)0x0040)
- #define TIM\_CR1\_ARPE ((uint16\_t)0x0080)
- #define TIM\_CR1\_CKD ((uint16\_t)0x0300)
- #define TIM\_CR1\_CKD\_0 ((uint16\_t)0x0100)
- #define TIM\_CR1\_CKD\_1 ((uint16\_t)0x0200)
- #define TIM\_CR2\_CCPC ((uint16\_t)0x0001)
- #define TIM\_CR2\_CCUS ((uint16\_t)0x0004)
- #define TIM\_CR2\_CCDS ((uint16\_t)0x0008)
- #define TIM\_CR2\_MMS ((uint16\_t)0x0070)
- #define TIM\_CR2\_MMS\_0 ((uint16\_t)0x0010)
- #define TIM\_CR2\_MMS\_1 ((uint16\_t)0x0020)
- #define TIM\_CR2\_MMS\_2 ((uint16\_t)0x0040)
- #define TIM\_CR2\_TI1S ((uint16\_t)0x0080)
- #define TIM\_CR2\_OIS1 ((uint16\_t)0x0100)
- #define TIM\_CR2\_OIS1N ((uint16\_t)0x0200)
- #define TIM\_CR2\_OIS2 ((uint16\_t)0x0400)
- #define TIM\_CR2\_OIS2N ((uint16\_t)0x0800)
- #define TIM\_CR2\_OIS3 ((uint16\_t)0x1000)
- #define TIM\_CR2\_OIS3N ((uint16\_t)0x2000)
- #define TIM\_CR2\_OIS4 ((uint16\_t)0x4000)
- #define TIM\_SMCR\_SMS ((uint16\_t)0x0007)
- #define TIM\_SMCR\_SMS\_0 ((uint16\_t)0x0001)
- #define TIM\_SMCR\_SMS\_1 ((uint16\_t)0x0002)
- #define TIM\_SMCR\_SMS\_2 ((uint16\_t)0x0004)
- #define TIM\_SMCR\_TS ((uint16\_t)0x0070)
- #define TIM\_SMCR\_TS\_0 ((uint16\_t)0x0010)
- #define TIM\_SMCR\_TS\_1 ((uint16\_t)0x0020)
- #define TIM\_SMCR\_TS\_2 ((uint16\_t)0x0040)
- #define TIM\_SMCR\_MSM ((uint16\_t)0x0080)
- #define TIM\_SMCR\_ETF ((uint16\_t)0x0F00)
- #define TIM\_SMCR\_ETF\_0 ((uint16\_t)0x0100)
- #define TIM\_SMCR\_ETF\_1 ((uint16\_t)0x0200)
- #define TIM\_SMCR\_ETF\_2 ((uint16\_t)0x0400)
- #define TIM\_SMCR\_ETF\_3 ((uint16\_t)0x0800)
- #define TIM\_SMCR\_ETPS ((uint16\_t)0x3000)
- #define TIM\_SMCR\_ETPS\_0 ((uint16\_t)0x1000)
- #define TIM\_SMCR\_ETPS\_1 ((uint16\_t)0x2000)
- #define TIM\_SMCR\_ECE ((uint16\_t)0x4000)
- #define TIM\_SMCR\_ETP ((uint16\_t)0x8000)
- #define TIM\_DIER\_UIE ((uint16\_t)0x0001)
- #define TIM\_DIER\_CC1IE ((uint16\_t)0x0002)
- #define TIM\_DIER\_CC2IE ((uint16\_t)0x0004)
- #define TIM\_DIER\_CC3IE ((uint16\_t)0x0008)

- #define **TIM\_DIER\_CC4IE** ((uint16\_t)0x0010)
- #define **TIM\_DIER\_COMIE** ((uint16\_t)0x0020)
- #define **TIM\_DIER\_TIE** ((uint16\_t)0x0040)
- #define **TIM\_DIER\_BIE** ((uint16\_t)0x0080)
- #define **TIM\_DIER\_UDE** ((uint16\_t)0x0100)
- #define **TIM\_DIER\_CC1DE** ((uint16\_t)0x0200)
- #define **TIM\_DIER\_CC2DE** ((uint16\_t)0x0400)
- #define **TIM\_DIER\_CC3DE** ((uint16\_t)0x0800)
- #define **TIM\_DIER\_CC4DE** ((uint16\_t)0x1000)
- #define **TIM\_DIER\_COMDE** ((uint16\_t)0x2000)
- #define **TIM\_DIER\_TDE** ((uint16\_t)0x4000)
- #define **TIM\_SR UIF** ((uint16\_t)0x0001)
- #define **TIM\_SR\_CC1IF** ((uint16\_t)0x0002)
- #define **TIM\_SR\_CC2IF** ((uint16\_t)0x0004)
- #define **TIM\_SR\_CC3IF** ((uint16\_t)0x0008)
- #define **TIM\_SR\_CC4IF** ((uint16\_t)0x0010)
- #define **TIM\_SR\_COMIF** ((uint16\_t)0x0020)
- #define **TIM\_SR\_TIF** ((uint16\_t)0x0040)
- #define **TIM\_SR\_BIF** ((uint16\_t)0x0080)
- #define **TIM\_SR\_CC1OF** ((uint16\_t)0x0200)
- #define **TIM\_SR\_CC2OF** ((uint16\_t)0x0400)
- #define **TIM\_SR\_CC3OF** ((uint16\_t)0x0800)
- #define **TIM\_SR\_CC4OF** ((uint16\_t)0x1000)
- #define **TIM\_EGR\_UG** ((uint8\_t)0x01)
- #define **TIM\_EGR\_CC1G** ((uint8\_t)0x02)
- #define **TIM\_EGR\_CC2G** ((uint8\_t)0x04)
- #define **TIM\_EGR\_CC3G** ((uint8\_t)0x08)
- #define **TIM\_EGR\_CC4G** ((uint8\_t)0x10)
- #define **TIM\_EGR\_COMG** ((uint8\_t)0x20)
- #define **TIM\_EGR\_TG** ((uint8\_t)0x40)
- #define **TIM\_EGR\_BG** ((uint8\_t)0x80)
- #define **TIM\_CCMR1\_CC1S** ((uint16\_t)0x0003)
- #define **TIM\_CCMR1\_CC1S\_0** ((uint16\_t)0x0001)
- #define **TIM\_CCMR1\_CC1S\_1** ((uint16\_t)0x0002)
- #define **TIM\_CCMR1\_OC1FE** ((uint16\_t)0x0004)
- #define **TIM\_CCMR1\_OC1PE** ((uint16\_t)0x0008)
- #define **TIM\_CCMR1\_OC1M** ((uint16\_t)0x0070)
- #define **TIM\_CCMR1\_OC1M\_0** ((uint16\_t)0x0010)
- #define **TIM\_CCMR1\_OC1M\_1** ((uint16\_t)0x0020)
- #define **TIM\_CCMR1\_OC1M\_2** ((uint16\_t)0x0040)
- #define **TIM\_CCMR1\_OC1CE** ((uint16\_t)0x0080)
- #define **TIM\_CCMR1\_CC2S** ((uint16\_t)0x0300)
- #define **TIM\_CCMR1\_CC2S\_0** ((uint16\_t)0x0100)
- #define **TIM\_CCMR1\_CC2S\_1** ((uint16\_t)0x0200)
- #define **TIM\_CCMR1\_OC2FE** ((uint16\_t)0x0400)
- #define **TIM\_CCMR1\_OC2PE** ((uint16\_t)0x0800)
- #define **TIM\_CCMR1\_OC2M** ((uint16\_t)0x7000)
- #define **TIM\_CCMR1\_OC2M\_0** ((uint16\_t)0x1000)
- #define **TIM\_CCMR1\_OC2M\_1** ((uint16\_t)0x2000)
- #define **TIM\_CCMR1\_OC2M\_2** ((uint16\_t)0x4000)
- #define **TIM\_CCMR1\_OC2CE** ((uint16\_t)0x8000)
- #define **TIM\_CCMR1\_IC1PSC** ((uint16\_t)0x000C)
- #define **TIM\_CCMR1\_IC1PSC\_0** ((uint16\_t)0x0004)
- #define **TIM\_CCMR1\_IC1PSC\_1** ((uint16\_t)0x0008)
- #define **TIM\_CCMR1\_IC1F** ((uint16\_t)0x00F0)

- #define TIM\_CCMR1\_IC1F\_0 ((uint16\_t)0x0010)
- #define TIM\_CCMR1\_IC1F\_1 ((uint16\_t)0x0020)
- #define TIM\_CCMR1\_IC1F\_2 ((uint16\_t)0x0040)
- #define TIM\_CCMR1\_IC1F\_3 ((uint16\_t)0x0080)
- #define TIM\_CCMR1\_IC2PSC ((uint16\_t)0xC000)
- #define TIM\_CCMR1\_IC2PSC\_0 ((uint16\_t)0x0400)
- #define TIM\_CCMR1\_IC2PSC\_1 ((uint16\_t)0x0800)
- #define TIM\_CCMR1\_IC2F ((uint16\_t)0xF000)
- #define TIM\_CCMR1\_IC2F\_0 ((uint16\_t)0x1000)
- #define TIM\_CCMR1\_IC2F\_1 ((uint16\_t)0x2000)
- #define TIM\_CCMR1\_IC2F\_2 ((uint16\_t)0x4000)
- #define TIM\_CCMR1\_IC2F\_3 ((uint16\_t)0x8000)
- #define TIM\_CCMR2\_CC3S ((uint16\_t)0x0003)
- #define TIM\_CCMR2\_CC3S\_0 ((uint16\_t)0x0001)
- #define TIM\_CCMR2\_CC3S\_1 ((uint16\_t)0x0002)
- #define TIM\_CCMR2\_OC3FE ((uint16\_t)0x0004)
- #define TIM\_CCMR2\_OC3PE ((uint16\_t)0x0008)
- #define TIM\_CCMR2\_OC3M ((uint16\_t)0x0070)
- #define TIM\_CCMR2\_OC3M\_0 ((uint16\_t)0x0010)
- #define TIM\_CCMR2\_OC3M\_1 ((uint16\_t)0x0020)
- #define TIM\_CCMR2\_OC3M\_2 ((uint16\_t)0x0040)
- #define TIM\_CCMR2\_OC3CE ((uint16\_t)0x0080)
- #define TIM\_CCMR2\_CC4S ((uint16\_t)0x0300)
- #define TIM\_CCMR2\_CC4S\_0 ((uint16\_t)0x0100)
- #define TIM\_CCMR2\_CC4S\_1 ((uint16\_t)0x0200)
- #define TIM\_CCMR2\_OC4FE ((uint16\_t)0x0400)
- #define TIM\_CCMR2\_OC4PE ((uint16\_t)0x0800)
- #define TIM\_CCMR2\_OC4M ((uint16\_t)0x7000)
- #define TIM\_CCMR2\_OC4M\_0 ((uint16\_t)0x1000)
- #define TIM\_CCMR2\_OC4M\_1 ((uint16\_t)0x2000)
- #define TIM\_CCMR2\_OC4M\_2 ((uint16\_t)0x4000)
- #define TIM\_CCMR2\_OC4CE ((uint16\_t)0x8000)
- #define TIM\_CCMR2\_IC3PSC ((uint16\_t)0x000C)
- #define TIM\_CCMR2\_IC3PSC\_0 ((uint16\_t)0x0004)
- #define TIM\_CCMR2\_IC3PSC\_1 ((uint16\_t)0x0008)
- #define TIM\_CCMR2\_IC3F ((uint16\_t)0x00F0)
- #define TIM\_CCMR2\_IC3F\_0 ((uint16\_t)0x0010)
- #define TIM\_CCMR2\_IC3F\_1 ((uint16\_t)0x0020)
- #define TIM\_CCMR2\_IC3F\_2 ((uint16\_t)0x0040)
- #define TIM\_CCMR2\_IC3F\_3 ((uint16\_t)0x0080)
- #define TIM\_CCMR2\_IC4PSC ((uint16\_t)0xC000)
- #define TIM\_CCMR2\_IC4PSC\_0 ((uint16\_t)0x0400)
- #define TIM\_CCMR2\_IC4PSC\_1 ((uint16\_t)0x0800)
- #define TIM\_CCMR2\_IC4F ((uint16\_t)0xF000)
- #define TIM\_CCMR2\_IC4F\_0 ((uint16\_t)0x1000)
- #define TIM\_CCMR2\_IC4F\_1 ((uint16\_t)0x2000)
- #define TIM\_CCMR2\_IC4F\_2 ((uint16\_t)0x4000)
- #define TIM\_CCMR2\_IC4F\_3 ((uint16\_t)0x8000)
- #define TIM\_CCER\_CC1E ((uint16\_t)0x0001)
- #define TIM\_CCER\_CC1P ((uint16\_t)0x0002)
- #define TIM\_CCER\_CC1NE ((uint16\_t)0x0004)
- #define TIM\_CCER\_CC1NP ((uint16\_t)0x0008)
- #define TIM\_CCER\_CC2E ((uint16\_t)0x0010)
- #define TIM\_CCER\_CC2P ((uint16\_t)0x0020)
- #define TIM\_CCER\_CC2NE ((uint16\_t)0x0040)

- #define TIM\_CCER\_CC2NP ((uint16\_t)0x0080)
- #define TIM\_CCER\_CC3E ((uint16\_t)0x0100)
- #define TIM\_CCER\_CC3P ((uint16\_t)0x0200)
- #define TIM\_CCER\_CC3NE ((uint16\_t)0x0400)
- #define TIM\_CCER\_CC3NP ((uint16\_t)0x0800)
- #define TIM\_CCER\_CC4E ((uint16\_t)0x1000)
- #define TIM\_CCER\_CC4P ((uint16\_t)0x2000)
- #define TIM\_CCER\_CC4NP ((uint16\_t)0x8000)
- #define TIM\_CNT\_CNT ((uint16\_t)0xFFFF)
- #define TIM\_PSC\_PSC ((uint16\_t)0xFFFF)
- #define TIM\_ARR\_ARR ((uint16\_t)0xFFFF)
- #define TIM\_RCR REP ((uint8\_t)0xFF)
- #define TIM\_CCR1\_CCR1 ((uint16\_t)0xFFFF)
- #define TIM\_CCR2\_CCR2 ((uint16\_t)0xFFFF)
- #define TIM\_CCR3\_CCR3 ((uint16\_t)0xFFFF)
- #define TIM\_CCR4\_CCR4 ((uint16\_t)0xFFFF)
- #define TIM\_BDTR\_DTG ((uint16\_t)0x00FF)
- #define TIM\_BDTR\_DTG\_0 ((uint16\_t)0x0001)
- #define TIM\_BDTR\_DTG\_1 ((uint16\_t)0x0002)
- #define TIM\_BDTR\_DTG\_2 ((uint16\_t)0x0004)
- #define TIM\_BDTR\_DTG\_3 ((uint16\_t)0x0008)
- #define TIM\_BDTR\_DTG\_4 ((uint16\_t)0x0010)
- #define TIM\_BDTR\_DTG\_5 ((uint16\_t)0x0020)
- #define TIM\_BDTR\_DTG\_6 ((uint16\_t)0x0040)
- #define TIM\_BDTR\_DTG\_7 ((uint16\_t)0x0080)
- #define TIM\_BDTR\_LOCK ((uint16\_t)0x0300)
- #define TIM\_BDTR\_LOCK\_0 ((uint16\_t)0x0100)
- #define TIM\_BDTR\_LOCK\_1 ((uint16\_t)0x0200)
- #define TIM\_BDTR\_OSSI ((uint16\_t)0x0400)
- #define TIM\_BDTR\_OSSR ((uint16\_t)0x0800)
- #define TIM\_BDTR\_BKE ((uint16\_t)0x1000)
- #define TIM\_BDTR\_BKP ((uint16\_t)0x2000)
- #define TIM\_BDTR\_AOE ((uint16\_t)0x4000)
- #define TIM\_BDTR\_MOE ((uint16\_t)0x8000)
- #define TIM\_DCR\_DBA ((uint16\_t)0x001F)
- #define TIM\_DCR\_DBA\_0 ((uint16\_t)0x0001)
- #define TIM\_DCR\_DBA\_1 ((uint16\_t)0x0002)
- #define TIM\_DCR\_DBA\_2 ((uint16\_t)0x0004)
- #define TIM\_DCR\_DBA\_3 ((uint16\_t)0x0008)
- #define TIM\_DCR\_DBA\_4 ((uint16\_t)0x0010)
- #define TIM\_DCR\_DBL ((uint16\_t)0x1F00)
- #define TIM\_DCR\_DBL\_0 ((uint16\_t)0x0100)
- #define TIM\_DCR\_DBL\_1 ((uint16\_t)0x0200)
- #define TIM\_DCR\_DBL\_2 ((uint16\_t)0x0400)
- #define TIM\_DCR\_DBL\_3 ((uint16\_t)0x0800)
- #define TIM\_DCR\_DBL\_4 ((uint16\_t)0x1000)
- #define TIM\_DMAR\_DMAB ((uint16\_t)0xFFFF)
- #define TIM\_OR\_TI4\_RMP ((uint16\_t)0x00C0)
- #define TIM\_OR\_TI4\_RMP\_0 ((uint16\_t)0x0040)
- #define TIM\_OR\_TI4\_RMP\_1 ((uint16\_t)0x0080)
- #define TIM\_OR\_ITR1\_RMP ((uint16\_t)0x0C00)
- #define TIM\_OR\_ITR1\_RMP\_0 ((uint16\_t)0x0400)
- #define TIM\_OR\_ITR1\_RMP\_1 ((uint16\_t)0x0800)
- #define USART\_SR\_PE ((uint16\_t)0x0001)
- #define USART\_SR\_FE ((uint16\_t)0x0002)

- #define USART\_SR\_NE ((uint16\_t)0x0004)
- #define USART\_SR\_ORE ((uint16\_t)0x0008)
- #define USART\_SR\_IDLE ((uint16\_t)0x0010)
- #define USART\_SR\_RXNE ((uint16\_t)0x0020)
- #define USART\_SR\_TC ((uint16\_t)0x0040)
- #define USART\_SR\_TXE ((uint16\_t)0x0080)
- #define USART\_SR\_LBD ((uint16\_t)0x0100)
- #define USART\_SR\_CTS ((uint16\_t)0x0200)
- #define USART\_DR\_DR ((uint16\_t)0x01FF)
- #define USART\_BRR\_DIV\_Fraction ((uint16\_t)0x000F)
- #define USART\_BRR\_DIV\_Mantissa ((uint16\_t)0xFFFF0)
- #define USART\_CR1\_SBK ((uint16\_t)0x0001)
- #define USART\_CR1\_RWU ((uint16\_t)0x0002)
- #define USART\_CR1\_RE ((uint16\_t)0x0004)
- #define USART\_CR1\_TE ((uint16\_t)0x0008)
- #define USART\_CR1\_IDLEIE ((uint16\_t)0x0010)
- #define USART\_CR1\_RXNEIE ((uint16\_t)0x0020)
- #define USART\_CR1\_TCIE ((uint16\_t)0x0040)
- #define USART\_CR1\_TXEIE ((uint16\_t)0x0080)
- #define USART\_CR1\_PEIE ((uint16\_t)0x0100)
- #define USART\_CR1\_PS ((uint16\_t)0x0200)
- #define USART\_CR1\_PCE ((uint16\_t)0x0400)
- #define USART\_CR1\_WAKE ((uint16\_t)0x0800)
- #define USART\_CR1\_M ((uint16\_t)0x1000)
- #define USART\_CR1\_UE ((uint16\_t)0x2000)
- #define USART\_CR1\_OVER8 ((uint16\_t)0x8000)
- #define USART\_CR2\_ADD ((uint16\_t)0x000F)
- #define USART\_CR2\_LBDL ((uint16\_t)0x0020)
- #define USART\_CR2\_LBDIE ((uint16\_t)0x0040)
- #define USART\_CR2\_LBCL ((uint16\_t)0x0100)
- #define USART\_CR2\_CPHA ((uint16\_t)0x0200)
- #define USART\_CR2\_CPOL ((uint16\_t)0x0400)
- #define USART\_CR2\_CLKEN ((uint16\_t)0x0800)
- #define USART\_CR2\_STOP ((uint16\_t)0x3000)
- #define USART\_CR2\_STOP\_0 ((uint16\_t)0x1000)
- #define USART\_CR2\_STOP\_1 ((uint16\_t)0x2000)
- #define USART\_CR2 LINEN ((uint16\_t)0x4000)
- #define USART\_CR3\_EIE ((uint16\_t)0x0001)
- #define USART\_CR3\_IREN ((uint16\_t)0x0002)
- #define USART\_CR3\_IRLP ((uint16\_t)0x0004)
- #define USART\_CR3\_HDSEL ((uint16\_t)0x0008)
- #define USART\_CR3\_NACK ((uint16\_t)0x0010)
- #define USART\_CR3\_SCEN ((uint16\_t)0x0020)
- #define USART\_CR3\_DMAR ((uint16\_t)0x0040)
- #define USART\_CR3\_DMAT ((uint16\_t)0x0080)
- #define USART\_CR3\_RTSE ((uint16\_t)0x0100)
- #define USART\_CR3\_CTSE ((uint16\_t)0x0200)
- #define USART\_CR3\_CTSIE ((uint16\_t)0x0400)
- #define USART\_CR3\_ONEBIT ((uint16\_t)0x0800)
- #define USART\_GTPR\_PSC ((uint16\_t)0x00FF)
- #define USART\_GTPR\_PSC\_0 ((uint16\_t)0x0001)
- #define USART\_GTPR\_PSC\_1 ((uint16\_t)0x0002)
- #define USART\_GTPR\_PSC\_2 ((uint16\_t)0x0004)
- #define USART\_GTPR\_PSC\_3 ((uint16\_t)0x0008)
- #define USART\_GTPR\_PSC\_4 ((uint16\_t)0x0010)

- #define USART\_GTPR\_PSC\_5 ((uint16\_t)0x0020)
- #define USART\_GTPR\_PSC\_6 ((uint16\_t)0x0040)
- #define USART\_GTPR\_PSC\_7 ((uint16\_t)0x0080)
- #define USART\_GTPR\_GT ((uint16\_t)0xFF00)
- #define WWDG\_CR\_T ((uint8\_t)0x7F)
- #define WWDG\_CR\_T\_0 ((uint8\_t)0x01)
- #define WWDG\_CR\_T\_1 ((uint8\_t)0x02)
- #define WWDG\_CR\_T\_2 ((uint8\_t)0x04)
- #define WWDG\_CR\_T\_3 ((uint8\_t)0x08)
- #define WWDG\_CR\_T\_4 ((uint8\_t)0x10)
- #define WWDG\_CR\_T\_5 ((uint8\_t)0x20)
- #define WWDG\_CR\_T\_6 ((uint8\_t)0x40)
- #define WWDG\_CR\_T0 WWDG\_CR\_T\_0
- #define WWDG\_CR\_T1 WWDG\_CR\_T\_1
- #define WWDG\_CR\_T2 WWDG\_CR\_T\_2
- #define WWDG\_CR\_T3 WWDG\_CR\_T\_3
- #define WWDG\_CR\_T4 WWDG\_CR\_T\_4
- #define WWDG\_CR\_T5 WWDG\_CR\_T\_5
- #define WWDG\_CR\_T6 WWDG\_CR\_T\_6
- #define WWDG\_CFR\_WDGA ((uint8\_t)0x80)
- #define WWDG\_CFR\_W ((uint16\_t)0x007F)
- #define WWDG\_CFR\_W\_0 ((uint16\_t)0x0001)
- #define WWDG\_CFR\_W\_1 ((uint16\_t)0x0002)
- #define WWDG\_CFR\_W\_2 ((uint16\_t)0x0004)
- #define WWDG\_CFR\_W\_3 ((uint16\_t)0x0008)
- #define WWDG\_CFR\_W\_4 ((uint16\_t)0x0010)
- #define WWDG\_CFR\_W\_5 ((uint16\_t)0x0020)
- #define WWDG\_CFR\_W\_6 ((uint16\_t)0x0040)
- #define WWDG\_CFR\_W0 WWDG\_CFR\_W\_0
- #define WWDG\_CFR\_W1 WWDG\_CFR\_W\_1
- #define WWDG\_CFR\_W2 WWDG\_CFR\_W\_2
- #define WWDG\_CFR\_W3 WWDG\_CFR\_W\_3
- #define WWDG\_CFR\_W4 WWDG\_CFR\_W\_4
- #define WWDG\_CFR\_W5 WWDG\_CFR\_W\_5
- #define WWDG\_CFR\_W6 WWDG\_CFR\_W\_6
- #define WWDG\_CFR\_WDGTB ((uint16\_t)0x0180)
- #define WWDG\_CFR\_WDGTB\_0 ((uint16\_t)0x0080)
- #define WWDG\_CFR\_WDGTB\_1 ((uint16\_t)0x0100)
- #define WWDG\_CFR\_WDGTB0 WWDG\_CFR\_WDGTB\_0
- #define WWDG\_CFR\_WDGTB1 WWDG\_CFR\_WDGTB\_1
- #define WWDG\_CFR\_EWI ((uint16\_t)0x0200)
- #define WWDG\_SR\_EWIF ((uint8\_t)0x01)
- #define DBGMCU\_IDCODE\_DEV\_ID ((uint32\_t)0x00000FFF)
- #define DBGMCU\_IDCODE\_REV\_ID ((uint32\_t)0xFFFF0000)
- #define DBGMCU\_CR\_DBG\_SLEEP ((uint32\_t)0x00000001)
- #define DBGMCU\_CR\_DBG\_STOP ((uint32\_t)0x00000002)
- #define DBGMCU\_CR\_DBG\_STANDBY ((uint32\_t)0x00000004)
- #define DBGMCU\_CR\_TRACE\_IOEN ((uint32\_t)0x00000020)
- #define DBGMCU\_CR\_TRACE\_MODE ((uint32\_t)0x000000C0)
- #define DBGMCU\_CR\_TRACE\_MODE\_0 ((uint32\_t)0x00000040)
- #define DBGMCU\_CR\_TRACE\_MODE\_1 ((uint32\_t)0x00000080)
- #define DBGMCU\_APB1\_FZ\_DBG\_TIM2\_STOP ((uint32\_t)0x00000001)
- #define DBGMCU\_APB1\_FZ\_DBG\_TIM3\_STOP ((uint32\_t)0x00000002)
- #define DBGMCU\_APB1\_FZ\_DBG\_TIM4\_STOP ((uint32\_t)0x00000004)
- #define DBGMCU\_APB1\_FZ\_DBG\_TIM5\_STOP ((uint32\_t)0x00000008)

- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM6\_STOP** ((uint32\_t)0x00000010)
- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM7\_STOP** ((uint32\_t)0x00000020)
- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM12\_STOP** ((uint32\_t)0x00000040)
- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM13\_STOP** ((uint32\_t)0x00000080)
- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM14\_STOP** ((uint32\_t)0x00000100)
- #define **DBGMCU\_APB1\_FZ\_DBG\_RTC\_STOP** ((uint32\_t)0x00000400)
- #define **DBGMCU\_APB1\_FZ\_DBG\_WWDG\_STOP** ((uint32\_t)0x00000800)
- #define **DBGMCU\_APB1\_FZ\_DBG\_IWDG\_STOP** ((uint32\_t)0x00001000)
- #define **DBGMCU\_APB1\_FZ\_DBG\_I2C1\_SMBUS\_TIMEOUT** ((uint32\_t)0x00200000)
- #define **DBGMCU\_APB1\_FZ\_DBG\_I2C2\_SMBUS\_TIMEOUT** ((uint32\_t)0x00400000)
- #define **DBGMCU\_APB1\_FZ\_DBG\_I2C3\_SMBUS\_TIMEOUT** ((uint32\_t)0x00800000)
- #define **DBGMCU\_APB1\_FZ\_DBG\_CAN1\_STOP** ((uint32\_t)0x02000000)
- #define **DBGMCU\_APB1\_FZ\_DBG\_CAN2\_STOP** ((uint32\_t)0x04000000)
- #define **DBGMCU\_APB1\_FZ\_DBG\_IWDEG\_STOP** **DBGMCU\_APB1\_FZ\_DBG\_IWDG\_STOP**
- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM1\_STOP** ((uint32\_t)0x00000001)
- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM8\_STOP** ((uint32\_t)0x00000002)
- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM9\_STOP** ((uint32\_t)0x00010000)
- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM10\_STOP** ((uint32\_t)0x00020000)
- #define **DBGMCU\_APB1\_FZ\_DBG\_TIM11\_STOP** ((uint32\_t)0x00040000)
- #define **ETH\_MACCR\_WD** ((uint32\_t)0x00800000) /\* Watchdog disable \*/
- #define **ETH\_MACCR\_JD** ((uint32\_t)0x00400000) /\* Jabber disable \*/
- #define **ETH\_MACCR\_IFG** ((uint32\_t)0x000E0000) /\* Inter-frame gap \*/
- #define **ETH\_MACCR\_IFG\_96Bit** ((uint32\_t)0x00000000) /\* Minimum IFG between frames during transmission is 96Bit \*/
- #define **ETH\_MACCR\_IFG\_88Bit** ((uint32\_t)0x00020000) /\* Minimum IFG between frames during transmission is 88Bit \*/
- #define **ETH\_MACCR\_IFG\_80Bit** ((uint32\_t)0x00040000) /\* Minimum IFG between frames during transmission is 80Bit \*/
- #define **ETH\_MACCR\_IFG\_72Bit** ((uint32\_t)0x00060000) /\* Minimum IFG between frames during transmission is 72Bit \*/
- #define **ETH\_MACCR\_IFG\_64Bit** ((uint32\_t)0x00080000) /\* Minimum IFG between frames during transmission is 64Bit \*/
- #define **ETH\_MACCR\_IFG\_56Bit** ((uint32\_t)0x000A0000) /\* Minimum IFG between frames during transmission is 56Bit \*/
- #define **ETH\_MACCR\_IFG\_48Bit** ((uint32\_t)0x000C0000) /\* Minimum IFG between frames during transmission is 48Bit \*/
- #define **ETH\_MACCR\_IFG\_40Bit** ((uint32\_t)0x000E0000) /\* Minimum IFG between frames during transmission is 40Bit \*/
- #define **ETH\_MACCR\_CSD** ((uint32\_t)0x00010000) /\* Carrier sense disable (during transmission) \*/
- #define **ETH\_MACCR\_FES** ((uint32\_t)0x00004000) /\* Fast ethernet speed \*/
- #define **ETH\_MACCR\_ROD** ((uint32\_t)0x00002000) /\* Receive own disable \*/
- #define **ETH\_MACCR\_LM** ((uint32\_t)0x00001000) /\* loopback mode \*/
- #define **ETH\_MACCR\_DM** ((uint32\_t)0x00000800) /\* Duplex mode \*/
- #define **ETH\_MACCR\_IPCO** ((uint32\_t)0x00000400) /\* IP Checksum offload \*/
- #define **ETH\_MACCR\_RD** ((uint32\_t)0x00000200) /\* Retry disable \*/
- #define **ETH\_MACCR\_APCS** ((uint32\_t)0x00000080) /\* Automatic Pad/**CRC** stripping \*/
- #define **ETH\_MACCR\_BL**
- #define **ETH\_MACCR\_BL\_10** ((uint32\_t)0x00000000) /\* k = min (n, 10) \*/
- #define **ETH\_MACCR\_BL\_8** ((uint32\_t)0x00000020) /\* k = min (n, 8) \*/
- #define **ETH\_MACCR\_BL\_4** ((uint32\_t)0x00000040) /\* k = min (n, 4) \*/
- #define **ETH\_MACCR\_BL\_1** ((uint32\_t)0x00000060) /\* k = min (n, 1) \*/
- #define **ETH\_MACCR\_DC** ((uint32\_t)0x00000010) /\* Defferal check \*/
- #define **ETH\_MACCR\_TE** ((uint32\_t)0x00000008) /\* Transmitter enable \*/
- #define **ETH\_MACCR\_RE** ((uint32\_t)0x00000004) /\* Receiver enable \*/
- #define **ETH\_MACFFR\_RA** ((uint32\_t)0x80000000) /\* Receive all \*/

- #define **ETH\_MACFFR\_HPF** ((uint32\_t)0x000000400) /\* Hash or perfect filter \*/
- #define **ETH\_MACFFR\_SAF** ((uint32\_t)0x000000200) /\* Source address filter enable \*/
- #define **ETH\_MACFFR\_SAIF** ((uint32\_t)0x000000100) /\* SA inverse filtering \*/
- #define **ETH\_MACFFR\_PCF** ((uint32\_t)0x000000C0) /\* Pass control frames: 3 cases \*/
- #define **ETH\_MACFFR\_PCF\_BlockAll** ((uint32\_t)0x00000040) /\* MAC filters all control frames from reaching the application \*/
- #define **ETH\_MACFFR\_PCF\_ForwardAll** ((uint32\_t)0x00000080) /\* MAC forwards all control frames to application even if they fail the Address Filter \*/
- #define **ETH\_MACFFR\_PCF\_ForwardPassedAddrFilter** ((uint32\_t)0x000000C0) /\* MAC forwards control frames that pass the Address Filter. \*/
- #define **ETH\_MACFFR\_BFD** ((uint32\_t)0x00000020) /\* Broadcast frame disable \*/
- #define **ETH\_MACFFR\_PAM** ((uint32\_t)0x00000010) /\* Pass all multicast \*/
- #define **ETH\_MACFFR\_DAIF** ((uint32\_t)0x00000008) /\* DA Inverse filtering \*/
- #define **ETH\_MACFFR\_HM** ((uint32\_t)0x00000004) /\* Hash multicast \*/
- #define **ETH\_MACFFR\_HU** ((uint32\_t)0x00000002) /\* Hash unicast \*/
- #define **ETH\_MACFFR\_PM** ((uint32\_t)0x00000001) /\* Promiscuous mode \*/
- #define **ETH\_MACHTHR\_HTH** ((uint32\_t)0xFFFFFFFF) /\* Hash table high \*/
- #define **ETH\_MACHTLR\_HTL** ((uint32\_t)0xFFFFFFFF) /\* Hash table low \*/
- #define **ETH\_MACMIIAR\_PA** ((uint32\_t)0x0000F800) /\* Physical layer address \*/
- #define **ETH\_MACMIIAR\_MR** ((uint32\_t)0x000007C0) /\* MII register in the selected PHY \*/
- #define **ETH\_MACMIIAR\_CR** ((uint32\_t)0x0000001C) /\* CR clock range: 6 cases \*/
- #define **ETH\_MACMIIAR\_CR\_Div42** ((uint32\_t)0x00000000) /\* HCLK:60-100 MHz; MDC clock= HCLK/42 \*/
- #define **ETH\_MACMIIAR\_CR\_Div62** ((uint32\_t)0x00000004) /\* HCLK:100-150 MHz; MDC clock= HCLK/62 \*/
- #define **ETH\_MACMIIAR\_CR\_Div16** ((uint32\_t)0x00000008) /\* HCLK:20-35 MHz; MDC clock= HCLK/16 \*/
- #define **ETH\_MACMIIAR\_CR\_Div26** ((uint32\_t)0x0000000C) /\* HCLK:35-60 MHz; MDC clock= HCLK/26 \*/
- #define **ETH\_MACMIIAR\_CR\_Div102** ((uint32\_t)0x00000010) /\* HCLK:150-168 MHz; MDC clock= HCLK/102 \*/
- #define **ETH\_MACMIIAR\_MW** ((uint32\_t)0x00000002) /\* MII write \*/
- #define **ETH\_MACMIIAR\_MB** ((uint32\_t)0x00000001) /\* MII busy \*/
- #define **ETH\_MACMIIDR\_MD** ((uint32\_t)0x0000FFFF) /\* MII data: read/write data from/to PHY \*/
- #define **ETH\_MACFCR\_PT** ((uint32\_t)0xFFFF0000) /\* Pause time \*/
- #define **ETH\_MACFCR\_ZQPD** ((uint32\_t)0x00000080) /\* Zero-quanta pause disable \*/
- #define **ETH\_MACFCR\_PLT** ((uint32\_t)0x00000030) /\* Pause low threshold: 4 cases \*/
- #define **ETH\_MACFCR\_PLT\_Minus4** ((uint32\_t)0x00000000) /\* Pause time minus 4 slot times \*/
- #define **ETH\_MACFCR\_PLT\_Minus28** ((uint32\_t)0x00000010) /\* Pause time minus 28 slot times \*/
- #define **ETH\_MACFCR\_PLT\_Minus144** ((uint32\_t)0x00000020) /\* Pause time minus 144 slot times \*/
- #define **ETH\_MACFCR\_PLT\_Minus256** ((uint32\_t)0x00000030) /\* Pause time minus 256 slot times \*/
- #define **ETH\_MACFCR\_UPFD** ((uint32\_t)0x00000008) /\* Unicast pause frame detect \*/
- #define **ETH\_MACFCR\_RFCE** ((uint32\_t)0x00000004) /\* Receive flow control enable \*/
- #define **ETH\_MACFCR\_TFCE** ((uint32\_t)0x00000002) /\* Transmit flow control enable \*/
- #define **ETH\_MACFCR\_FCBBPA** ((uint32\_t)0x00000001) /\* Flow control busy/backpressure activate \*/
- #define **ETH\_MACVLANTR\_VLANTC** ((uint32\_t)0x00010000) /\* 12-bit VLAN tag comparison \*/
- #define **ETH\_MACVLANTR\_VLANTI** ((uint32\_t)0x0000FFFF) /\* VLAN tag identifier (for receive frames) \*/
- #define **ETH\_MACRWUFFR\_D** ((uint32\_t)0xFFFFFFFF) /\* Wake-up frame filter register data \*/
- #define **ETH\_MACPMTCSR\_WFFRPPR** ((uint32\_t)0x80000000) /\* Wake-Up Frame Filter Register Pointer Reset \*/
- #define **ETH\_MACPMTCSR\_GU** ((uint32\_t)0x00000200) /\* Global Unicast \*/
- #define **ETH\_MACPMTCSR\_WFR** ((uint32\_t)0x00000040) /\* Wake-Up Frame Received \*/
- #define **ETH\_MACPMTCSR\_MPR** ((uint32\_t)0x00000020) /\* Magic Packet Received \*/
- #define **ETH\_MACPMTCSR\_WFE** ((uint32\_t)0x00000004) /\* Wake-Up Frame Enable \*/
- #define **ETH\_MACPMTCSR\_MPE** ((uint32\_t)0x00000002) /\* Magic Packet Enable \*/
- #define **ETH\_MACPMTCSR\_PD** ((uint32\_t)0x00000001) /\* Power Down \*/

- #define **ETH\_MACSR\_TSTS** ((uint32\_t)0x000000200) /\* Time stamp trigger status \*/
- #define **ETH\_MACSR\_MMCTS** ((uint32\_t)0x000000040) /\* MMC transmit status \*/
- #define **ETH\_MACSR\_MMMCRS** ((uint32\_t)0x000000020) /\* MMC receive status \*/
- #define **ETH\_MACSR\_MMCS** ((uint32\_t)0x000000010) /\* MMC status \*/
- #define **ETH\_MACSR\_PMTS** ((uint32\_t)0x000000008) /\* PMT status \*/
- #define **ETH\_MACIMR\_TSTIM** ((uint32\_t)0x000000200) /\* Time stamp trigger interrupt mask \*/
- #define **ETH\_MACIMR\_PMTIM** ((uint32\_t)0x000000008) /\* PMT interrupt mask \*/
- #define **ETH\_MACA0HR\_MACA0H** ((uint32\_t)0x0000FFFF) /\* MAC address0 high \*/
- #define **ETH\_MACA0LR\_MACA0L** ((uint32\_t)0xFFFFFFFF) /\* MAC address0 low \*/
- #define **ETH\_MACA1HR\_AE** ((uint32\_t)0x80000000) /\* Address enable \*/
- #define **ETH\_MACA1HR\_SA** ((uint32\_t)0x40000000) /\* Source address \*/
- #define **ETH\_MACA1HR\_MBC** ((uint32\_t)0x3F000000) /\* Mask byte control: bits to mask for comparison of the MAC Address bytes \*/
- #define **ETH\_MACA1HR\_MBC\_HBits15\_8** ((uint32\_t)0x20000000) /\* Mask MAC Address high reg bits [15:8] \*/
- #define **ETH\_MACA1HR\_MBC\_HBits7\_0** ((uint32\_t)0x10000000) /\* Mask MAC Address high reg bits [7:0] \*/
- #define **ETH\_MACA1HR\_MBC\_LBits31\_24** ((uint32\_t)0x08000000) /\* Mask MAC Address low reg bits [31:24] \*/
- #define **ETH\_MACA1HR\_MBC\_LBits23\_16** ((uint32\_t)0x04000000) /\* Mask MAC Address low reg bits [23:16] \*/
- #define **ETH\_MACA1HR\_MBC\_LBits15\_8** ((uint32\_t)0x02000000) /\* Mask MAC Address low reg bits [15:8] \*/
- #define **ETH\_MACA1HR\_MBC\_LBits7\_0** ((uint32\_t)0x01000000) /\* Mask MAC Address low reg bits [7:0] \*/
- #define **ETH\_MACA1HR\_MACA1H** ((uint32\_t)0x0000FFFF) /\* MAC address1 high \*/
- #define **ETH\_MACA1LR\_MACA1L** ((uint32\_t)0xFFFFFFFF) /\* MAC address1 low \*/
- #define **ETH\_MACA2HR\_AE** ((uint32\_t)0x80000000) /\* Address enable \*/
- #define **ETH\_MACA2HR\_SA** ((uint32\_t)0x40000000) /\* Source address \*/
- #define **ETH\_MACA2HR\_MBC** ((uint32\_t)0x3F000000) /\* Mask byte control \*/
- #define **ETH\_MACA2HR\_MBC\_HBits15\_8** ((uint32\_t)0x20000000) /\* Mask MAC Address high reg bits [15:8] \*/
- #define **ETH\_MACA2HR\_MBC\_HBits7\_0** ((uint32\_t)0x10000000) /\* Mask MAC Address high reg bits [7:0] \*/
- #define **ETH\_MACA2HR\_MBC\_LBits31\_24** ((uint32\_t)0x08000000) /\* Mask MAC Address low reg bits [31:24] \*/
- #define **ETH\_MACA2HR\_MBC\_LBits23\_16** ((uint32\_t)0x04000000) /\* Mask MAC Address low reg bits [23:16] \*/
- #define **ETH\_MACA2HR\_MBC\_LBits15\_8** ((uint32\_t)0x02000000) /\* Mask MAC Address low reg bits [15:8] \*/
- #define **ETH\_MACA2HR\_MBC\_LBits7\_0** ((uint32\_t)0x01000000) /\* Mask MAC Address low reg bits [7:0] \*/
- #define **ETH\_MACA2HR\_MACA2H** ((uint32\_t)0x0000FFFF) /\* MAC address1 high \*/
- #define **ETH\_MACA2LR\_MACA2L** ((uint32\_t)0xFFFFFFFF) /\* MAC address2 low \*/
- #define **ETH\_MACA3HR\_AE** ((uint32\_t)0x80000000) /\* Address enable \*/
- #define **ETH\_MACA3HR\_SA** ((uint32\_t)0x40000000) /\* Source address \*/
- #define **ETH\_MACA3HR\_MBC** ((uint32\_t)0x3F000000) /\* Mask byte control \*/
- #define **ETH\_MACA3HR\_MBC\_HBits15\_8** ((uint32\_t)0x20000000) /\* Mask MAC Address high reg bits [15:8] \*/
- #define **ETH\_MACA3HR\_MBC\_HBits7\_0** ((uint32\_t)0x10000000) /\* Mask MAC Address high reg bits [7:0] \*/
- #define **ETH\_MACA3HR\_MBC\_LBits31\_24** ((uint32\_t)0x08000000) /\* Mask MAC Address low reg bits [31:24] \*/
- #define **ETH\_MACA3HR\_MBC\_LBits23\_16** ((uint32\_t)0x04000000) /\* Mask MAC Address low reg bits [23:16] \*/
- #define **ETH\_MACA3HR\_MBC\_LBits15\_8** ((uint32\_t)0x02000000) /\* Mask MAC Address low reg bits [15:8] \*/

- #define **ETH\_MACA3HR\_MBC\_LBits7\_0** ((uint32\_t)0x01000000) /\* Mask MAC Address low reg bits [70] \*/
- #define **ETH\_MACA3HR\_MACA3H** ((uint32\_t)0x0000FFFF) /\* MAC address3 high \*/
- #define **ETH\_MACA3LR\_MACA3L** ((uint32\_t)0xFFFFFFF) /\* MAC address3 low \*/
- #define **ETH\_MMCCR\_MCFHP** ((uint32\_t)0x00000020) /\* MMC counter Full-Half preset \*/
- #define **ETH\_MMCCR\_MCP** ((uint32\_t)0x00000010) /\* MMC counter preset \*/
- #define **ETH\_MMCCR\_MCF** ((uint32\_t)0x00000008) /\* MMC Counter Freeze \*/
- #define **ETH\_MMCCR\_ROR** ((uint32\_t)0x00000004) /\* **Reset** on Read \*/
- #define **ETH\_MMCCR\_CSR** ((uint32\_t)0x00000002) /\* Counter Stop Rollover \*/
- #define **ETH\_MMCCR\_CR** ((uint32\_t)0x00000001) /\* Counters **Reset** \*/
- #define **ETH\_MMCRIR\_RGUFS** ((uint32\_t)0x00020000) /\* **Set** when Rx good unicast frames counter reaches half the maximum value \*/
- #define **ETH\_MMCRIR\_RFAES** ((uint32\_t)0x00000040) /\* **Set** when Rx alignment error counter reaches half the maximum value \*/
- #define **ETH\_MMCRIR\_RFCES** ((uint32\_t)0x00000020) /\* **Set** when Rx crc error counter reaches half the maximum value \*/
- #define **ETH\_MMCTIR\_TGFS** ((uint32\_t)0x00200000) /\* **Set** when Tx good frame count counter reaches half the maximum value \*/
- #define **ETH\_MMCTIR\_TGFMSCS** ((uint32\_t)0x00008000) /\* **Set** when Tx good multi col counter reaches half the maximum value \*/
- #define **ETH\_MMCTIR\_TGFSCS** ((uint32\_t)0x00004000) /\* **Set** when Tx good single col counter reaches half the maximum value \*/
- #define **ETH\_MMCRIMR\_RGUFM** ((uint32\_t)0x00020000) /\* Mask the interrupt when Rx good unicast frames counter reaches half the maximum value \*/
- #define **ETH\_MMCRIMR\_RFAEM** ((uint32\_t)0x00000040) /\* Mask the interrupt when Rx alignment error counter reaches half the maximum value \*/
- #define **ETH\_MMCRIMR\_RFCEM** ((uint32\_t)0x00000020) /\* Mask the interrupt when Rx crc error counter reaches half the maximum value \*/
- #define **ETH\_MMCTIMR\_TGFM** ((uint32\_t)0x00200000) /\* Mask the interrupt when Tx good frame count counter reaches half the maximum value \*/
- #define **ETH\_MMCTIMR\_TGFMSCM** ((uint32\_t)0x00008000) /\* Mask the interrupt when Tx good multi col counter reaches half the maximum value \*/
- #define **ETH\_MMCTIMR\_TGFSCM** ((uint32\_t)0x00004000) /\* Mask the interrupt when Tx good single col counter reaches half the maximum value \*/
- #define **ETH\_MMCTGFSCCR\_TGFSCC** ((uint32\_t)0xFFFFFFFF) /\* Number of successfully transmitted frames after a single collision in Half-duplex mode. \*/
- #define **ETH\_MMCTGFMSCCR\_TGFMSCC** ((uint32\_t)0xFFFFFFFF) /\* Number of successfully transmitted frames after more than a single collision in Half-duplex mode. \*/
- #define **ETH\_MMCTGFCCR\_TGFC** ((uint32\_t)0xFFFFFFFF) /\* Number of good frames transmitted. \*/
- #define **ETH\_MMCRFCECR\_RFCEC** ((uint32\_t)0xFFFFFFFF) /\* Number of frames received with **CRC** error. \*/
- #define **ETH\_MMCRFAECR\_RFAEC** ((uint32\_t)0xFFFFFFFF) /\* Number of frames received with alignment (dribble) error \*/
- #define **ETH\_MMCRGUFCR\_RGUFC** ((uint32\_t)0xFFFFFFFF) /\* Number of good unicast frames received. \*/
- #define **ETH\_PTPTSCR\_TSCNT** ((uint32\_t)0x00030000) /\* Time stamp clock node type \*/
- #define **ETH\_PTPTSSR\_TSSMRME** ((uint32\_t)0x00008000) /\* Time stamp snapshot for message relevant to master enable \*/
- #define **ETH\_PTPTSSR\_TSSEME** ((uint32\_t)0x00004000) /\* Time stamp snapshot for event message enable \*/
- #define **ETH\_PTPTSSR\_TSSIPV4FE** ((uint32\_t)0x00002000) /\* Time stamp snapshot for IPv4 frames enable \*/
- #define **ETH\_PTPTSSR\_TSSIPV6FE** ((uint32\_t)0x00001000) /\* Time stamp snapshot for IPv6 frames enable \*/
- #define **ETH\_PTPTSSR\_TSSPTPOEFE** ((uint32\_t)0x00000800) /\* Time stamp snapshot for PTP over ethernet frames enable \*/

- #define **ETH\_PTPTSSR\_TSPTPPSV2E** ((uint32\_t)0x000000400) /\* Time stamp PTP packet snooping for version2 format enable \*/
- #define **ETH\_PTPTSSR\_TSSSR** ((uint32\_t)0x000000200) /\* Time stamp Sub-seconds rollover \*/
- #define **ETH\_PTPTSSR\_TSSARFE** ((uint32\_t)0x000000100) /\* Time stamp snapshot for all received frames enable \*/
- #define **ETH\_PTPTSCR\_TSARU** ((uint32\_t)0x000000020) /\* Addend register update \*/
- #define **ETH\_PTPTSCR\_TSITE** ((uint32\_t)0x000000010) /\* Time stamp interrupt trigger enable \*/
- #define **ETH\_PTPTSCR\_TSSTU** ((uint32\_t)0x000000008) /\* Time stamp update \*/
- #define **ETH\_PTPTSCR\_TSSTI** ((uint32\_t)0x000000004) /\* Time stamp initialize \*/
- #define **ETH\_PTPTSCR\_TSFCU** ((uint32\_t)0x000000002) /\* Time stamp fine or coarse update \*/
- #define **ETH\_PTPTSCR\_TSE** ((uint32\_t)0x000000001) /\* Time stamp enable \*/
- #define **ETH\_PTPSSIR\_STSSI** ((uint32\_t)0x000000FF) /\* System time Sub-second increment value \*/
- #define **ETH\_PTPTSHR\_STS** ((uint32\_t)0xFFFFFFFF) /\* System Time second \*/
- #define **ETH\_PTPTSLR\_STPNS** ((uint32\_t)0x800000000) /\* System Time Positive or negative time \*/
- #define **ETH\_PTPTSLR\_STSS** ((uint32\_t)0x7FFFFFFF) /\* System Time sub-seconds \*/
- #define **ETH\_PTPTSHUR\_TSUS** ((uint32\_t)0xFFFFFFFF) /\* Time stamp update seconds \*/
- #define **ETH\_PTPTSLUR\_TSUPNS** ((uint32\_t)0x800000000) /\* Time stamp update Positive or negative time \*/
- #define **ETH\_PTPTSLUR\_TSUSS** ((uint32\_t)0x7FFFFFFF) /\* Time stamp update sub-seconds \*/
- #define **ETH\_PTPTSAR\_TSA** ((uint32\_t)0xFFFFFFFF) /\* Time stamp addend \*/
- #define **ETH\_PTPTTHR\_TTSH** ((uint32\_t)0xFFFFFFFF) /\* Target time stamp high \*/
- #define **ETH\_PTPTTLR\_TTSL** ((uint32\_t)0xFFFFFFFF) /\* Target time stamp low \*/
- #define **ETH\_PTPTSSR\_TSTTR** ((uint32\_t)0x000000020) /\* Time stamp target time reached \*/
- #define **ETH\_PTPTSSR\_TSSO** ((uint32\_t)0x000000010) /\* Time stamp seconds overflow \*/
- #define **ETH\_DMABMR\_AAB** ((uint32\_t)0x02000000) /\* Address-Aligned beats \*/
- #define **ETH\_DMABMR\_FPM** ((uint32\_t)0x01000000) /\* 4xPBL mode \*/
- #define **ETH\_DMABMR\_USP** ((uint32\_t)0x00800000) /\* Use separate PBL \*/
- #define **ETH\_DMABMR\_RDP** ((uint32\_t)0x007E0000) /\* RxDMA PBL \*/
- #define **ETH\_DMABMR\_RDP\_1Beat** ((uint32\_t)0x000200000) /\* maximum number of beats to be transferred in one RxDMA transaction is 1 \*/
- #define **ETH\_DMABMR\_RDP\_2Beat** ((uint32\_t)0x000400000) /\* maximum number of beats to be transferred in one RxDMA transaction is 2 \*/
- #define **ETH\_DMABMR\_RDP\_4Beat** ((uint32\_t)0x000800000) /\* maximum number of beats to be transferred in one RxDMA transaction is 4 \*/
- #define **ETH\_DMABMR\_RDP\_8Beat** ((uint32\_t)0x001000000) /\* maximum number of beats to be transferred in one RxDMA transaction is 8 \*/
- #define **ETH\_DMABMR\_RDP\_16Beat** ((uint32\_t)0x002000000) /\* maximum number of beats to be transferred in one RxDMA transaction is 16 \*/
- #define **ETH\_DMABMR\_RDP\_32Beat** ((uint32\_t)0x004000000) /\* maximum number of beats to be transferred in one RxDMA transaction is 32 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_4Beat** ((uint32\_t)0x010200000) /\* maximum number of beats to be transferred in one RxDMA transaction is 4 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_8Beat** ((uint32\_t)0x010400000) /\* maximum number of beats to be transferred in one RxDMA transaction is 8 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_16Beat** ((uint32\_t)0x010800000) /\* maximum number of beats to be transferred in one RxDMA transaction is 16 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_32Beat** ((uint32\_t)0x011000000) /\* maximum number of beats to be transferred in one RxDMA transaction is 32 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_64Beat** ((uint32\_t)0x012000000) /\* maximum number of beats to be transferred in one RxDMA transaction is 64 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_128Beat** ((uint32\_t)0x014000000) /\* maximum number of beats to be transferred in one RxDMA transaction is 128 \*/
- #define **ETH\_DMABMR\_FB** ((uint32\_t)0x00010000) /\* Fixed Burst \*/
- #define **ETH\_DMABMR RTPR** ((uint32\_t)0x0000C000) /\* Rx Tx priority ratio \*/
- #define **ETH\_DMABMR RTPR\_1\_1** ((uint32\_t)0x00000000) /\* Rx Tx priority ratio \*/

- #define **ETH\_DMABMR\_RTPR\_2\_1** ((uint32\_t)0x00004000) /\* Rx Tx priority ratio \*/
- #define **ETH\_DMABMR\_RTPR\_3\_1** ((uint32\_t)0x00008000) /\* Rx Tx priority ratio \*/
- #define **ETH\_DMABMR\_RTPR\_4\_1** ((uint32\_t)0x0000C000) /\* Rx Tx priority ratio \*/
- #define **ETH\_DMABMR\_PBL** ((uint32\_t)0x00003F00) /\* Programmable burst length \*/
- #define **ETH\_DMABMR\_PBL\_1Beat** ((uint32\_t)0x00000100) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 1 \*/
- #define **ETH\_DMABMR\_PBL\_2Beat** ((uint32\_t)0x00000200) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 2 \*/
- #define **ETH\_DMABMR\_PBL\_4Beat** ((uint32\_t)0x00000400) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 4 \*/
- #define **ETH\_DMABMR\_PBL\_8Beat** ((uint32\_t)0x00000800) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 8 \*/
- #define **ETH\_DMABMR\_PBL\_16Beat** ((uint32\_t)0x00001000) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 16 \*/
- #define **ETH\_DMABMR\_PBL\_32Beat** ((uint32\_t)0x00002000) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 32 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_4Beat** ((uint32\_t)0x01000100) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 4 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_8Beat** ((uint32\_t)0x01000200) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 8 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_16Beat** ((uint32\_t)0x01000400) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 16 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_32Beat** ((uint32\_t)0x01000800) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 32 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_64Beat** ((uint32\_t)0x01001000) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 64 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_128Beat** ((uint32\_t)0x01002000) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 128 \*/
- #define **ETH\_DMABMR\_EDE** ((uint32\_t)0x00000080) /\* Enhanced Descriptor Enable \*/
- #define **ETH\_DMABMR\_DSL** ((uint32\_t)0x0000007C) /\* Descriptor Skip Length \*/
- #define **ETH\_DMABMR\_DA** ((uint32\_t)0x00000002) /\* DMA arbitration scheme \*/
- #define **ETH\_DMABMR\_SR** ((uint32\_t)0x00000001) /\* Software reset \*/
- #define **ETH\_DMATPDR\_TPD** ((uint32\_t)0xFFFFFFFF) /\* Transmit poll demand \*/
- #define **ETH\_DMARPDR\_RPD** ((uint32\_t)0xFFFFFFFF) /\* Receive poll demand \*/
- #define **ETH\_DMARDLAR\_SRL** ((uint32\_t)0xFFFFFFFF) /\* Start of receive list \*/
- #define **ETH\_DMATDLAR\_STL** ((uint32\_t)0xFFFFFFFF) /\* Start of transmit list \*/
- #define **ETH\_DMASR\_TSTS** ((uint32\_t)0x20000000) /\* Time-stamp trigger status \*/
- #define **ETH\_DMASR\_PMTS** ((uint32\_t)0x10000000) /\* PMT status \*/
- #define **ETH\_DMASR\_MMCS** ((uint32\_t)0x08000000) /\* MMC status \*/
- #define **ETH\_DMASR\_EBS** ((uint32\_t)0x03800000) /\* Error bits status \*/
- #define **ETH\_DMASR\_EBS\_DescAccess** ((uint32\_t)0x02000000) /\* Error bits 0-data buffer, 1-desc. access \*/
- #define **ETH\_DMASR\_EBS\_ReadTransf** ((uint32\_t)0x01000000) /\* Error bits 0-write trnsf, 1-read transfr \*/
- #define **ETH\_DMASR\_EBS\_DataTransfTx** ((uint32\_t)0x00800000) /\* Error bits 0-Rx DMA, 1-Tx DMA \*/
- #define **ETH\_DMASR\_TPS** ((uint32\_t)0x00700000) /\* Transmit process state \*/
- #define **ETH\_DMASR\_TPS\_Stopped** ((uint32\_t)0x00000000) /\* Stopped - Reset or Stop Tx Command issued \*/
- #define **ETH\_DMASR\_TPS\_Fetching** ((uint32\_t)0x00100000) /\* Running - fetching the Tx descriptor \*/
- #define **ETH\_DMASR\_TPS\_Waiting** ((uint32\_t)0x00200000) /\* Running - waiting for status \*/
- #define **ETH\_DMASR\_TPS\_Reading** ((uint32\_t)0x00300000) /\* Running - reading the data from host memory \*/
- #define **ETH\_DMASR\_TPS\_Suspended** ((uint32\_t)0x00600000) /\* Suspended - Tx Descriptor unavailable \*/
- #define **ETH\_DMASR\_TPS\_Closing** ((uint32\_t)0x00700000) /\* Running - closing Rx descriptor \*/
- #define **ETH\_DMASR\_RPS** ((uint32\_t)0x000E0000) /\* Receive process state \*/

- #define **ETH\_DMASR\_RPS\_Stopped** ((uint32\_t)0x00000000) /\* Stopped - **Reset** or Stop Rx Command issued \*/
- #define **ETH\_DMASR\_RPS\_Fetching** ((uint32\_t)0x00020000) /\* Running - fetching the Rx descriptor \*/
- #define **ETH\_DMASR\_RPS\_Waiting** ((uint32\_t)0x00060000) /\* Running - waiting for packet \*/
- #define **ETH\_DMASR\_RPS\_Suspended** ((uint32\_t)0x00080000) /\* Suspended - Rx Descriptor unavailable \*/
- #define **ETH\_DMASR\_RPS\_Closing** ((uint32\_t)0x000A0000) /\* Running - closing descriptor \*/
- #define **ETH\_DMASR\_RPS\_Queueing** ((uint32\_t)0x000E0000) /\* Running - queuing the receive frame into host memory \*/
- #define **ETH\_DMASR\_NIS** ((uint32\_t)0x00010000) /\* Normal interrupt summary \*/
- #define **ETH\_DMASR\_AIS** ((uint32\_t)0x00008000) /\* Abnormal interrupt summary \*/
- #define **ETH\_DMASR\_ERS** ((uint32\_t)0x00004000) /\* Early receive status \*/
- #define **ETH\_DMASR\_FBES** ((uint32\_t)0x00002000) /\* Fatal bus error status \*/
- #define **ETH\_DMASR\_ETS** ((uint32\_t)0x00000400) /\* Early transmit status \*/
- #define **ETH\_DMASR\_RWTS** ((uint32\_t)0x00000200) /\* Receive watchdog timeout status \*/
- #define **ETH\_DMASR\_RPSS** ((uint32\_t)0x00000100) /\* Receive process stopped status \*/
- #define **ETH\_DMASR\_RBUS** ((uint32\_t)0x00000080) /\* Receive **buffer** unavailable status \*/
- #define **ETH\_DMASR\_RS** ((uint32\_t)0x00000040) /\* Receive status \*/
- #define **ETH\_DMASR\_TUS** ((uint32\_t)0x00000020) /\* Transmit underflow status \*/
- #define **ETH\_DMASR\_ROS** ((uint32\_t)0x00000010) /\* Receive overflow status \*/
- #define **ETH\_DMASR\_TJTS** ((uint32\_t)0x00000008) /\* Transmit jabber timeout status \*/
- #define **ETH\_DMASR\_TBUS** ((uint32\_t)0x00000004) /\* Transmit **buffer** unavailable status \*/
- #define **ETH\_DMASR\_TPSS** ((uint32\_t)0x00000002) /\* Transmit process stopped status \*/
- #define **ETH\_DMASR\_TS** ((uint32\_t)0x00000001) /\* Transmit status \*/
- #define **ETH\_DMAOMR\_DTCEFD** ((uint32\_t)0x04000000) /\* Disable Dropping of TCP/IP checksum error frames \*/
- #define **ETH\_DMAOMR\_RSF** ((uint32\_t)0x02000000) /\* Receive store and forward \*/
- #define **ETH\_DMAOMR\_DFRF** ((uint32\_t)0x01000000) /\* Disable flushing of received frames \*/
- #define **ETH\_DMAOMR\_TSF** ((uint32\_t)0x00200000) /\* Transmit store and forward \*/
- #define **ETH\_DMAOMR\_FTF** ((uint32\_t)0x00100000) /\* Flush transmit FIFO \*/
- #define **ETH\_DMAOMR\_TTC** ((uint32\_t)0x0001C000) /\* Transmit threshold control \*/
- #define **ETH\_DMAOMR\_TTC\_64Bytes** ((uint32\_t)0x00000000) /\* threshold level of the MTL Transmit FIFO is 64 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_128Bytes** ((uint32\_t)0x00004000) /\* threshold level of the MTL Transmit FIFO is 128 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_192Bytes** ((uint32\_t)0x00008000) /\* threshold level of the MTL Transmit FIFO is 192 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_256Bytes** ((uint32\_t)0x0000C000) /\* threshold level of the MTL Transmit FIFO is 256 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_40Bytes** ((uint32\_t)0x00010000) /\* threshold level of the MTL Transmit FIFO is 40 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_32Bytes** ((uint32\_t)0x00014000) /\* threshold level of the MTL Transmit FIFO is 32 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_24Bytes** ((uint32\_t)0x00018000) /\* threshold level of the MTL Transmit FIFO is 24 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_16Bytes** ((uint32\_t)0x0001C000) /\* threshold level of the MTL Transmit FIFO is 16 Bytes \*/
- #define **ETH\_DMAOMR\_ST** ((uint32\_t)0x00002000) /\* **Start**/stop transmission command \*/
- #define **ETH\_DMAOMR\_FEF** ((uint32\_t)0x00000080) /\* Forward error frames \*/
- #define **ETH\_DMAOMR\_FUGF** ((uint32\_t)0x00000040) /\* Forward undersized good frames \*/
- #define **ETH\_DMAOMR\_RTC** ((uint32\_t)0x00000018) /\* receive threshold control \*/
- #define **ETH\_DMAOMR\_RTC\_64Bytes** ((uint32\_t)0x00000000) /\* threshold level of the MTL Receive FIFO is 64 Bytes \*/
- #define **ETH\_DMAOMR\_RTC\_32Bytes** ((uint32\_t)0x00000008) /\* threshold level of the MTL Receive FIFO is 32 Bytes \*/

- #define **ETH\_DMAOMR\_RTC\_96Bytes** ((uint32\_t)0x00000010) /\* threshold level of the MTL Receive FIFO is 96 Bytes \*/
- #define **ETH\_DMAOMR\_RTC\_128Bytes** ((uint32\_t)0x00000018) /\* threshold level of the MTL Receive FIFO is 128 Bytes \*/
- #define **ETH\_DMAOMR\_OSF** ((uint32\_t)0x00000004) /\* operate on second frame \*/
- #define **ETH\_DMAOMR\_SR** ((uint32\_t)0x00000002) /\* Start/stop receive \*/
- #define **ETH\_DMAIER\_NISE** ((uint32\_t)0x00010000) /\* Normal interrupt summary enable \*/
- #define **ETH\_DMAIER\_AISE** ((uint32\_t)0x00008000) /\* Abnormal interrupt summary enable \*/
- #define **ETH\_DMAIER\_ERIE** ((uint32\_t)0x00004000) /\* Early receive interrupt enable \*/
- #define **ETH\_DMAIER\_FBEIE** ((uint32\_t)0x00002000) /\* Fatal bus error interrupt enable \*/
- #define **ETH\_DMAIER\_ETIE** ((uint32\_t)0x00000400) /\* Early transmit interrupt enable \*/
- #define **ETH\_DMAIER\_RWTIE** ((uint32\_t)0x00000200) /\* Receive watchdog timeout interrupt enable \*/
- #define **ETH\_DMAIER\_RPSIE** ((uint32\_t)0x00000100) /\* Receive process stopped interrupt enable \*/
- #define **ETH\_DMAIER\_RBUIE** ((uint32\_t)0x00000080) /\* Receive buffer unavailable interrupt enable \*/
- #define **ETH\_DMAIER\_RIE** ((uint32\_t)0x00000040) /\* Receive interrupt enable \*/
- #define **ETH\_DMAIER\_TUIE** ((uint32\_t)0x00000020) /\* Transmit Underflow interrupt enable \*/
- #define **ETH\_DMAIER\_ROIE** ((uint32\_t)0x00000010) /\* Receive Overflow interrupt enable \*/
- #define **ETH\_DMAIER\_TJTIE** ((uint32\_t)0x00000008) /\* Transmit jabber timeout interrupt enable \*/
- #define **ETH\_DMAIER\_TBUIE** ((uint32\_t)0x00000004) /\* Transmit buffer unavailable interrupt enable \*/
- #define **ETH\_DMAIER\_TPSIE** ((uint32\_t)0x00000002) /\* Transmit process stopped interrupt enable \*/
- #define **ETH\_DMAIER\_TIE** ((uint32\_t)0x00000001) /\* Transmit interrupt enable \*/
- #define **ETH\_DMAMFBOCR\_OFOC** ((uint32\_t)0x10000000) /\* Overflow bit for FIFO overflow counter \*/
- #define **ETH\_DMAMFBOCR\_MFA** ((uint32\_t)0x0FFE0000) /\* Number of frames missed by the application \*/
- #define **ETH\_DMAMFBOCR\_OMFC** ((uint32\_t)0x00010000) /\* Overflow bit for missed frame counter \*/
- #define **ETH\_DMAMFBOCR\_MFC** ((uint32\_t)0x0000FFFF) /\* Number of frames missed by the controller \*/
- #define **ETH\_DMACHTDR\_HTDAP** ((uint32\_t)0xFFFFFFFF) /\* Host transmit descriptor address pointer \*/
- #define **ETH\_DMACHRDR\_HRDAP** ((uint32\_t)0xFFFFFFFF) /\* Host receive descriptor address pointer \*/
- #define **ETH\_DMACHTBAR\_HTBAP** ((uint32\_t)0xFFFFFFFF) /\* Host transmit buffer address pointer \*/
- #define **ETH\_DMACHRBAR\_HRBAP** ((uint32\_t)0xFFFFFFFF) /\* Host receive buffer address pointer \*/

### 5.173.1 Detailed Description

### 5.173.2 Macro Definition Documentation

#### 5.173.2.1 ADC\_CCR\_ADCPRE

```
#define ADC_CCR_ADCPRE ((uint32_t)0x00030000)
```

ADCPRE[1:0] bits (ADC prescaler)

#### 5.173.2.2 ADC\_CCR\_ADCPRE\_0

```
#define ADC_CCR_ADCPRE_0 ((uint32_t)0x00010000)
```

Bit 0

### 5.173.2.3 ADC\_CCR\_ADCPRE\_1

```
#define ADC_CCR_ADCPRE_1 ((uint32_t)0x00020000)
```

Bit 1

### 5.173.2.4 ADC\_CCR\_DDS

```
#define ADC_CCR_DDS ((uint32_t)0x00002000)
```

DMA disable selection (Multi-ADC mode)

### 5.173.2.5 ADC\_CCR\_DELAY

```
#define ADC_CCR_DELAY ((uint32_t)0x00000F00)
```

DELAY[3:0] bits (Delay between 2 sampling phases)

### 5.173.2.6 ADC\_CCR\_DELAY\_0

```
#define ADC_CCR_DELAY_0 ((uint32_t)0x00000100)
```

Bit 0

### 5.173.2.7 ADC\_CCR\_DELAY\_1

```
#define ADC_CCR_DELAY_1 ((uint32_t)0x00000200)
```

Bit 1

### 5.173.2.8 ADC\_CCR\_DELAY\_2

```
#define ADC_CCR_DELAY_2 ((uint32_t)0x00000400)
```

Bit 2

### 5.173.2.9 ADC\_CCR\_DELAY\_3

```
#define ADC_CCR_DELAY_3 ((uint32_t)0x00000800)
```

Bit 3

### 5.173.2.10 ADC\_CCR\_DMA

```
#define ADC_CCR_DMA ((uint32_t)0x0000C000)
```

DMA[1:0] bits (Direct Memory Access mode for multimode)

**5.173.2.11 ADC\_CCR\_DMA\_0**

```
#define ADC_CCR_DMA_0 ((uint32_t)0x00004000)
```

Bit 0

**5.173.2.12 ADC\_CCR\_DMA\_1**

```
#define ADC_CCR_DMA_1 ((uint32_t)0x00008000)
```

Bit 1

**5.173.2.13 ADC\_CCR\_MULTI**

```
#define ADC_CCR_MULTI ((uint32_t)0x0000001F)
```

MULTI[4:0] bits (Multi-ADC mode selection)

**5.173.2.14 ADC\_CCR\_MULTI\_0**

```
#define ADC_CCR_MULTI_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.15 ADC\_CCR\_MULTI\_1**

```
#define ADC_CCR_MULTI_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.16 ADC\_CCR\_MULTI\_2**

```
#define ADC_CCR_MULTI_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.17 ADC\_CCR\_MULTI\_3**

```
#define ADC_CCR_MULTI_3 ((uint32_t)0x00000008)
```

Bit 3

**5.173.2.18 ADC\_CCR\_MULTI\_4**

```
#define ADC_CCR_MULTI_4 ((uint32_t)0x00000010)
```

Bit 4

### 5.173.2.19 ADC\_CCR\_TSVREFE

```
#define ADC_CCR_TSVREFE ((uint32_t)0x00800000)
```

Temperature Sensor and VREFINT Enable

### 5.173.2.20 ADC\_CCR\_VBATE

```
#define ADC_CCR_VBATE ((uint32_t)0x00400000)
```

VBAT Enable

### 5.173.2.21 ADC\_CDR\_DATA1

```
#define ADC_CDR_DATA1 ((uint32_t)0x0000FFFF)
```

1st data of a pair of regular conversions

### 5.173.2.22 ADC\_CDR\_DATA2

```
#define ADC_CDR_DATA2 ((uint32_t)0xFFFF0000)
```

2nd data of a pair of regular conversions

### 5.173.2.23 ADC\_CR1\_AWDCH

```
#define ADC_CR1_AWDCH ((uint32_t)0x0000001F)
```

AWDCH[4:0] bits (Analog watchdog channel select bits)

### 5.173.2.24 ADC\_CR1\_AWDCH\_0

```
#define ADC_CR1_AWDCH_0 ((uint32_t)0x00000001)
```

Bit 0

### 5.173.2.25 ADC\_CR1\_AWDCH\_1

```
#define ADC_CR1_AWDCH_1 ((uint32_t)0x00000002)
```

Bit 1

### 5.173.2.26 ADC\_CR1\_AWDCH\_2

```
#define ADC_CR1_AWDCH_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.27 ADC\_CR1\_AWDCH\_3**

```
#define ADC_CR1_AWDCH_3 ((uint32_t)0x00000008)
```

Bit 3

**5.173.2.28 ADC\_CR1\_AWDCH\_4**

```
#define ADC_CR1_AWDCH_4 ((uint32_t)0x00000010)
```

Bit 4

**5.173.2.29 ADC\_CR1\_AWDEN**

```
#define ADC_CR1_AWDEN ((uint32_t)0x00800000)
```

Analog watchdog enable on regular channels

**5.173.2.30 ADC\_CR1\_AWDIE**

```
#define ADC_CR1_AWDIE ((uint32_t)0x00000040)
```

Analog Watchdog interrupt enable

**5.173.2.31 ADC\_CR1\_AWDSGL**

```
#define ADC_CR1_AWDSGL ((uint32_t)0x00000200)
```

Enable the watchdog on a single channel in scan mode

**5.173.2.32 ADC\_CR1\_DISCEN**

```
#define ADC_CR1_DISCEN ((uint32_t)0x00000800)
```

Discontinuous mode on regular channels

**5.173.2.33 ADC\_CR1\_DISCNUM**

```
#define ADC_CR1_DISCNUM ((uint32_t)0x0000E000)
```

DISCNUM[2:0] bits (Discontinuous mode channel count)

**5.173.2.34 ADC\_CR1\_DISCNUM\_0**

```
#define ADC_CR1_DISCNUM_0 ((uint32_t)0x00002000)
```

Bit 0

**5.173.2.35 ADC\_CR1\_DISCNUM\_1**

```
#define ADC_CR1_DISCNUM_1 ((uint32_t)0x00004000)
```

Bit 1

**5.173.2.36 ADC\_CR1\_DISCNUM\_2**

```
#define ADC_CR1_DISCNUM_2 ((uint32_t)0x00008000)
```

Bit 2

**5.173.2.37 ADC\_CR1\_EOCIE**

```
#define ADC_CR1_EOCIE ((uint32_t)0x00000020)
```

Interrupt enable for EOC

**5.173.2.38 ADC\_CR1\_JAUTO**

```
#define ADC_CR1_JAUTO ((uint32_t)0x00000400)
```

Automatic injected group conversion

**5.173.2.39 ADC\_CR1\_JAWDEN**

```
#define ADC_CR1_JAWDEN ((uint32_t)0x00400000)
```

Analog watchdog enable on injected channels

**5.173.2.40 ADC\_CR1\_JDISCEN**

```
#define ADC_CR1_JDISCEN ((uint32_t)0x00001000)
```

Discontinuous mode on injected channels

### 5.173.2.41 ADC\_CR1\_JEOCIE

```
#define ADC_CR1_JEOCIE ((uint32_t)0x00000080)
```

Interrupt enable for injected channels

### 5.173.2.42 ADC\_CR1\_OVRIE

```
#define ADC_CR1_OVRIE ((uint32_t)0x04000000)
```

overrun interrupt enable

### 5.173.2.43 ADC\_CR1\_RES

```
#define ADC_CR1_RES ((uint32_t)0x03000000)
```

RES[2:0] bits (Resolution)

### 5.173.2.44 ADC\_CR1\_RES\_0

```
#define ADC_CR1_RES_0 ((uint32_t)0x01000000)
```

Bit 0

### 5.173.2.45 ADC\_CR1\_RES\_1

```
#define ADC_CR1_RES_1 ((uint32_t)0x02000000)
```

Bit 1

### 5.173.2.46 ADC\_CR1\_SCAN

```
#define ADC_CR1_SCAN ((uint32_t)0x00000100)
```

Scan mode

### 5.173.2.47 ADC\_CR2\_ADON

```
#define ADC_CR2_ADON ((uint32_t)0x00000001)
```

A/D Converter ON / OFF

### 5.173.2.48 ADC\_CR2\_ALIGN

```
#define ADC_CR2_ALIGN ((uint32_t)0x00000800)
```

Data Alignment

### 5.173.2.49 ADC\_CR2\_CONT

```
#define ADC_CR2_CONT ((uint32_t)0x00000002)
```

Continuous Conversion

### 5.173.2.50 ADC\_CR2\_DDS

```
#define ADC_CR2_DDS ((uint32_t)0x00000200)
```

DMA disable selection (Single ADC)

### 5.173.2.51 ADC\_CR2\_DMA

```
#define ADC_CR2_DMA ((uint32_t)0x00000100)
```

Direct Memory access mode

### 5.173.2.52 ADC\_CR2\_EOCS

```
#define ADC_CR2_EOCS ((uint32_t)0x00000400)
```

End of conversion selection

### 5.173.2.53 ADC\_CR2\_EXTEN

```
#define ADC_CR2_EXTEN ((uint32_t)0x30000000)
```

EXTEN[1:0] bits (External Trigger Conversion mode for regular channelsp)

### 5.173.2.54 ADC\_CR2\_EXTEN\_0

```
#define ADC_CR2_EXTEN_0 ((uint32_t)0x10000000)
```

Bit 0

**5.173.2.55 ADC\_CR2\_EXTEN\_1**

```
#define ADC_CR2_EXTEN_1 ((uint32_t)0x20000000)
```

Bit 1

**5.173.2.56 ADC\_CR2\_EXTSEL**

```
#define ADC_CR2_EXTSEL ((uint32_t)0x0F000000)
```

EXTSEL[3:0] bits (External Event Select for regular group)

**5.173.2.57 ADC\_CR2\_EXTSEL\_0**

```
#define ADC_CR2_EXTSEL_0 ((uint32_t)0x01000000)
```

Bit 0

**5.173.2.58 ADC\_CR2\_EXTSEL\_1**

```
#define ADC_CR2_EXTSEL_1 ((uint32_t)0x02000000)
```

Bit 1

**5.173.2.59 ADC\_CR2\_EXTSEL\_2**

```
#define ADC_CR2_EXTSEL_2 ((uint32_t)0x04000000)
```

Bit 2

**5.173.2.60 ADC\_CR2\_EXTSEL\_3**

```
#define ADC_CR2_EXTSEL_3 ((uint32_t)0x08000000)
```

Bit 3

**5.173.2.61 ADC\_CR2\_JEXTEN**

```
#define ADC_CR2_JEXTEN ((uint32_t)0x00300000)
```

JEXTEN[1:0] bits (External Trigger Conversion mode for injected channelsp)

**5.173.2.62 ADC\_CR2\_JEXTEN\_0**

```
#define ADC_CR2_JEXTEN_0 ((uint32_t)0x00100000)
```

Bit 0

### 5.173.2.63 ADC\_CR2\_JEXTEN\_1

```
#define ADC_CR2_JEXTEN_1 ((uint32_t)0x00200000)
```

Bit 1

### 5.173.2.64 ADC\_CR2\_JEXTSEL

```
#define ADC_CR2_JEXTSEL ((uint32_t)0x000F0000)
```

JEXTSEL[3:0] bits (External event select for injected group)

### 5.173.2.65 ADC\_CR2\_JEXTSEL\_0

```
#define ADC_CR2_JEXTSEL_0 ((uint32_t)0x00010000)
```

Bit 0

### 5.173.2.66 ADC\_CR2\_JEXTSEL\_1

```
#define ADC_CR2_JEXTSEL_1 ((uint32_t)0x00020000)
```

Bit 1

### 5.173.2.67 ADC\_CR2\_JEXTSEL\_2

```
#define ADC_CR2_JEXTSEL_2 ((uint32_t)0x00040000)
```

Bit 2

### 5.173.2.68 ADC\_CR2\_JEXTSEL\_3

```
#define ADC_CR2_JEXTSEL_3 ((uint32_t)0x00080000)
```

Bit 3

### 5.173.2.69 ADC\_CR2\_JSWSTART

```
#define ADC_CR2_JSWSTART ((uint32_t)0x00400000)
```

Start Conversion of injected channels

### 5.173.2.70 ADC\_CR2\_SWSTART

```
#define ADC_CR2_SWSTART ((uint32_t)0x40000000)
```

Start Conversion of regular channels

**5.173.2.71 ADC\_CSR\_AWD1**

```
#define ADC_CSR_AWD1 ((uint32_t)0x00000001)
```

ADC1 Analog watchdog flag

**5.173.2.72 ADC\_CSR\_AWD2**

```
#define ADC_CSR_AWD2 ((uint32_t)0x00000100)
```

ADC2 Analog watchdog flag

**5.173.2.73 ADC\_CSR\_AWD3**

```
#define ADC_CSR_AWD3 ((uint32_t)0x00010000)
```

ADC3 Analog watchdog flag

**5.173.2.74 ADC\_CSR\_EOC1**

```
#define ADC_CSR_EOC1 ((uint32_t)0x00000002)
```

ADC1 End of conversion

**5.173.2.75 ADC\_CSR\_EOC2**

```
#define ADC_CSR_EOC2 ((uint32_t)0x00000200)
```

ADC2 End of conversion

**5.173.2.76 ADC\_CSR\_EOC3**

```
#define ADC_CSR_EOC3 ((uint32_t)0x00020000)
```

ADC3 End of conversion

**5.173.2.77 ADC\_CSR\_JEOC1**

```
#define ADC_CSR_JEOC1 ((uint32_t)0x00000004)
```

ADC1 Injected channel end of conversion

**5.173.2.78 ADC\_CSR\_JEOC2**

```
#define ADC_CSR_JEOC2 ((uint32_t)0x00000400)
```

ADC2 Injected channel end of conversion

### 5.173.2.79 ADC\_CSR\_JEOC3

```
#define ADC_CSR_JEOC3 ((uint32_t)0x00040000)
```

ADC3 Injected channel end of conversion

### 5.173.2.80 ADC\_CSR\_JSTRT1

```
#define ADC_CSR_JSTRT1 ((uint32_t)0x00000008)
```

ADC1 Injected channel Start flag

### 5.173.2.81 ADC\_CSR\_JSTRT2

```
#define ADC_CSR_JSTRT2 ((uint32_t)0x00000800)
```

ADC2 Injected channel Start flag

### 5.173.2.82 ADC\_CSR\_JSTRT3

```
#define ADC_CSR_JSTRT3 ((uint32_t)0x00080000)
```

ADC3 Injected channel Start flag

### 5.173.2.83 ADC\_CSR\_OVR1

```
#define ADC_CSR_OVR1 ((uint32_t)0x00000020)
```

ADC1 DMA overrun flag

### 5.173.2.84 ADC\_CSR\_OVR2

```
#define ADC_CSR_OVR2 ((uint32_t)0x00002000)
```

ADC2 DMA overrun flag

### 5.173.2.85 ADC\_CSR\_OVR3

```
#define ADC_CSR_OVR3 ((uint32_t)0x00200000)
```

ADC3 DMA overrun flag

### 5.173.2.86 ADC\_CSR\_STRT1

```
#define ADC_CSR_STRT1 ((uint32_t)0x00000010)
```

ADC1 Regular channel Start flag

**5.173.2.87 ADC\_CSR\_STRT2**

```
#define ADC_CSR_STRT2 ((uint32_t)0x00001000)
```

ADC2 Regular channel Start flag

**5.173.2.88 ADC\_CSR\_STRT3**

```
#define ADC_CSR_STRT3 ((uint32_t)0x00100000)
```

ADC3 Regular channel Start flag

**5.173.2.89 ADC\_DR\_ADC2DATA**

```
#define ADC_DR_ADC2DATA ((uint32_t)0xFFFF0000)
```

ADC2 data

**5.173.2.90 ADC\_DR\_DATA**

```
#define ADC_DR_DATA ((uint32_t)0x0000FFFF)
```

Regular data

**5.173.2.91 ADC\_HTR\_HT**

```
#define ADC_HTR_HT ((uint16_t)0x0FFF)
```

Analog watchdog high threshold

**5.173.2.92 ADC\_JDR1\_JDATA**

```
#define ADC_JDR1_JDATA ((uint16_t)0xFFFF)
```

Injected data

**5.173.2.93 ADC\_JDR2\_JDATA**

```
#define ADC_JDR2_JDATA ((uint16_t)0xFFFF)
```

Injected data

**5.173.2.94 ADC\_JDR3\_JDATA**

```
#define ADC_JDR3_JDATA ((uint16_t)0xFFFF)
```

Injected data

### 5.173.2.95 ADC\_JDR4\_JDATA

```
#define ADC_JDR4_JDATA ((uint16_t)0xFFFF)
```

Injected data

### 5.173.2.96 ADC\_JOFR1\_JOFFSET1

```
#define ADC_JOFR1_JOFFSET1 ((uint16_t)0x0FFF)
```

Data offset for injected channel 1

### 5.173.2.97 ADC\_JOFR2\_JOFFSET2

```
#define ADC_JOFR2_JOFFSET2 ((uint16_t)0x0FFF)
```

Data offset for injected channel 2

### 5.173.2.98 ADC\_JOFR3\_JOFFSET3

```
#define ADC_JOFR3_JOFFSET3 ((uint16_t)0x0FFF)
```

Data offset for injected channel 3

### 5.173.2.99 ADC\_JOFR4\_JOFFSET4

```
#define ADC_JOFR4_JOFFSET4 ((uint16_t)0x0FFF)
```

Data offset for injected channel 4

### 5.173.2.100 ADC\_JSQR\_JL

```
#define ADC_JSQR_JL ((uint32_t)0x00300000)
```

JL[1:0] bits (Injected Sequence length)

### 5.173.2.101 ADC\_JSQR\_JL\_0

```
#define ADC_JSQR_JL_0 ((uint32_t)0x00100000)
```

Bit 0

### 5.173.2.102 ADC\_JSQR\_JL\_1

```
#define ADC_JSQR_JL_1 ((uint32_t)0x00200000)
```

Bit 1

**5.173.2.103 ADC\_JSQR\_JSQ1**

```
#define ADC_JSQR_JSQ1 ((uint32_t)0x0000001F)
```

JSQ1[4:0] bits (1st conversion in injected sequence)

**5.173.2.104 ADC\_JSQR\_JSQ1\_0**

```
#define ADC_JSQR_JSQ1_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.105 ADC\_JSQR\_JSQ1\_1**

```
#define ADC_JSQR_JSQ1_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.106 ADC\_JSQR\_JSQ1\_2**

```
#define ADC_JSQR_JSQ1_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.107 ADC\_JSQR\_JSQ1\_3**

```
#define ADC_JSQR_JSQ1_3 ((uint32_t)0x00000008)
```

Bit 3

**5.173.2.108 ADC\_JSQR\_JSQ1\_4**

```
#define ADC_JSQR_JSQ1_4 ((uint32_t)0x00000010)
```

Bit 4

**5.173.2.109 ADC\_JSQR\_JSQ2**

```
#define ADC_JSQR_JSQ2 ((uint32_t)0x000003E0)
```

JSQ2[4:0] bits (2nd conversion in injected sequence)

**5.173.2.110 ADC\_JSQR\_JSQ2\_0**

```
#define ADC_JSQR_JSQ2_0 ((uint32_t)0x00000020)
```

Bit 0

**5.173.2.111 ADC\_JSQR\_JSQ2\_1**

```
#define ADC_JSQR_JSQ2_1 ((uint32_t)0x00000040)
```

Bit 1

**5.173.2.112 ADC\_JSQR\_JSQ2\_2**

```
#define ADC_JSQR_JSQ2_2 ((uint32_t)0x00000080)
```

Bit 2

**5.173.2.113 ADC\_JSQR\_JSQ2\_3**

```
#define ADC_JSQR_JSQ2_3 ((uint32_t)0x00000100)
```

Bit 3

**5.173.2.114 ADC\_JSQR\_JSQ2\_4**

```
#define ADC_JSQR_JSQ2_4 ((uint32_t)0x00000200)
```

Bit 4

**5.173.2.115 ADC\_JSQR\_JSQ3**

```
#define ADC_JSQR_JSQ3 ((uint32_t)0x00007C00)
```

JSQ3[4:0] bits (3rd conversion in injected sequence)

**5.173.2.116 ADC\_JSQR\_JSQ3\_0**

```
#define ADC_JSQR_JSQ3_0 ((uint32_t)0x00000400)
```

Bit 0

**5.173.2.117 ADC\_JSQR\_JSQ3\_1**

```
#define ADC_JSQR_JSQ3_1 ((uint32_t)0x00000800)
```

Bit 1

**5.173.2.118 ADC\_JSQR\_JSQ3\_2**

```
#define ADC_JSQR_JSQ3_2 ((uint32_t)0x00001000)
```

Bit 2

**5.173.2.119 ADC\_JSQR\_JSQ3\_3**

```
#define ADC_JSQR_JSQ3_3 ((uint32_t)0x00002000)
```

Bit 3

**5.173.2.120 ADC\_JSQR\_JSQ3\_4**

```
#define ADC_JSQR_JSQ3_4 ((uint32_t)0x00004000)
```

Bit 4

**5.173.2.121 ADC\_JSQR\_JSQ4**

```
#define ADC_JSQR_JSQ4 ((uint32_t)0x000F8000)
```

JSQ4[4:0] bits (4th conversion in injected sequence)

**5.173.2.122 ADC\_JSQR\_JSQ4\_0**

```
#define ADC_JSQR_JSQ4_0 ((uint32_t)0x00008000)
```

Bit 0

**5.173.2.123 ADC\_JSQR\_JSQ4\_1**

```
#define ADC_JSQR_JSQ4_1 ((uint32_t)0x00010000)
```

Bit 1

**5.173.2.124 ADC\_JSQR\_JSQ4\_2**

```
#define ADC_JSQR_JSQ4_2 ((uint32_t)0x00020000)
```

Bit 2

**5.173.2.125 ADC\_JSQR\_JSQ4\_3**

```
#define ADC_JSQR_JSQ4_3 ((uint32_t)0x00040000)
```

Bit 3

**5.173.2.126 ADC\_JSQR\_JSQ4\_4**

```
#define ADC_JSQR_JSQ4_4 ((uint32_t)0x00080000)
```

Bit 4

**5.173.2.127 ADC\_LTR\_LT**

```
#define ADC_LTR_LT ((uint16_t)0xFFFF)
```

Analog watchdog low threshold

**5.173.2.128 ADC\_SMPR1\_SMP10**

```
#define ADC_SMPR1_SMP10 ((uint32_t)0x00000007)
```

SMP10[2:0] bits (Channel 10 Sample time selection)

**5.173.2.129 ADC\_SMPR1\_SMP10\_0**

```
#define ADC_SMPR1_SMP10_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.130 ADC\_SMPR1\_SMP10\_1**

```
#define ADC_SMPR1_SMP10_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.131 ADC\_SMPR1\_SMP10\_2**

```
#define ADC_SMPR1_SMP10_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.132 ADC\_SMPR1\_SMP11**

```
#define ADC_SMPR1_SMP11 ((uint32_t)0x00000038)
```

SMP11[2:0] bits (Channel 11 Sample time selection)

**5.173.2.133 ADC\_SMPR1\_SMP11\_0**

```
#define ADC_SMPR1_SMP11_0 ((uint32_t)0x00000008)
```

Bit 0

**5.173.2.134 ADC\_SMPR1\_SMP11\_1**

```
#define ADC_SMPR1_SMP11_1 ((uint32_t)0x00000010)
```

Bit 1

**5.173.2.135 ADC\_SMPR1\_SMP11\_2**

```
#define ADC_SMPR1_SMP11_2 ((uint32_t)0x00000020)
```

Bit 2

**5.173.2.136 ADC\_SMPR1\_SMP12**

```
#define ADC_SMPR1_SMP12 ((uint32_t)0x000001C0)
```

SMP12[2:0] bits (Channel 12 Sample time selection)

**5.173.2.137 ADC\_SMPR1\_SMP12\_0**

```
#define ADC_SMPR1_SMP12_0 ((uint32_t)0x00000040)
```

Bit 0

**5.173.2.138 ADC\_SMPR1\_SMP12\_1**

```
#define ADC_SMPR1_SMP12_1 ((uint32_t)0x00000080)
```

Bit 1

**5.173.2.139 ADC\_SMPR1\_SMP12\_2**

```
#define ADC_SMPR1_SMP12_2 ((uint32_t)0x00000100)
```

Bit 2

**5.173.2.140 ADC\_SMPR1\_SMP13**

```
#define ADC_SMPR1_SMP13 ((uint32_t)0x00000E00)
```

SMP13[2:0] bits (Channel 13 Sample time selection)

**5.173.2.141 ADC\_SMPR1\_SMP13\_0**

```
#define ADC_SMPR1_SMP13_0 ((uint32_t)0x00000200)
```

Bit 0

**5.173.2.142 ADC\_SMPR1\_SMP13\_1**

```
#define ADC_SMPR1_SMP13_1 ((uint32_t)0x00000400)
```

Bit 1

**5.173.2.143 ADC\_SMPR1\_SMP13\_2**

```
#define ADC_SMPR1_SMP13_2 ((uint32_t)0x00000800)
```

Bit 2

**5.173.2.144 ADC\_SMPR1\_SMP14**

```
#define ADC_SMPR1_SMP14 ((uint32_t)0x00007000)
```

SMP14[2:0] bits (Channel 14 Sample time selection)

**5.173.2.145 ADC\_SMPR1\_SMP14\_0**

```
#define ADC_SMPR1_SMP14_0 ((uint32_t)0x00001000)
```

Bit 0

**5.173.2.146 ADC\_SMPR1\_SMP14\_1**

```
#define ADC_SMPR1_SMP14_1 ((uint32_t)0x00002000)
```

Bit 1

**5.173.2.147 ADC\_SMPR1\_SMP14\_2**

```
#define ADC_SMPR1_SMP14_2 ((uint32_t)0x00004000)
```

Bit 2

**5.173.2.148 ADC\_SMPR1\_SMP15**

```
#define ADC_SMPR1_SMP15 ((uint32_t)0x00038000)
```

SMP15[2:0] bits (Channel 15 Sample time selection)

**5.173.2.149 ADC\_SMPR1\_SMP15\_0**

```
#define ADC_SMPR1_SMP15_0 ((uint32_t)0x00008000)
```

Bit 0

**5.173.2.150 ADC\_SMPR1\_SMP15\_1**

```
#define ADC_SMPR1_SMP15_1 ((uint32_t)0x00010000)
```

Bit 1

**5.173.2.151 ADC\_SMPR1\_SMP15\_2**

```
#define ADC_SMPR1_SMP15_2 ((uint32_t)0x00020000)
```

Bit 2

**5.173.2.152 ADC\_SMPR1\_SMP16**

```
#define ADC_SMPR1_SMP16 ((uint32_t)0x001C0000)
```

SMP16[2:0] bits (Channel 16 Sample time selection)

**5.173.2.153 ADC\_SMPR1\_SMP16\_0**

```
#define ADC_SMPR1_SMP16_0 ((uint32_t)0x00040000)
```

Bit 0

**5.173.2.154 ADC\_SMPR1\_SMP16\_1**

```
#define ADC_SMPR1_SMP16_1 ((uint32_t)0x00080000)
```

Bit 1

**5.173.2.155 ADC\_SMPR1\_SMP16\_2**

```
#define ADC_SMPR1_SMP16_2 ((uint32_t)0x00100000)
```

Bit 2

**5.173.2.156 ADC\_SMPR1\_SMP17**

```
#define ADC_SMPR1_SMP17 ((uint32_t)0x00E00000)
```

SMP17[2:0] bits (Channel 17 Sample time selection)

**5.173.2.157 ADC\_SMPR1\_SMP17\_0**

```
#define ADC_SMPR1_SMP17_0 ((uint32_t)0x00200000)
```

Bit 0

**5.173.2.158 ADC\_SMPR1\_SMP17\_1**

```
#define ADC_SMPR1_SMP17_1 ((uint32_t)0x00400000)
```

Bit 1

**5.173.2.159 ADC\_SMPR1\_SMP17\_2**

```
#define ADC_SMPR1_SMP17_2 ((uint32_t)0x00800000)
```

Bit 2

**5.173.2.160 ADC\_SMPR1\_SMP18**

```
#define ADC_SMPR1_SMP18 ((uint32_t)0x07000000)
```

SMP18[2:0] bits (Channel 18 Sample time selection)

**5.173.2.161 ADC\_SMPR1\_SMP18\_0**

```
#define ADC_SMPR1_SMP18_0 ((uint32_t)0x01000000)
```

Bit 0

**5.173.2.162 ADC\_SMPR1\_SMP18\_1**

```
#define ADC_SMPR1_SMP18_1 ((uint32_t)0x02000000)
```

Bit 1

**5.173.2.163 ADC\_SMPR1\_SMP18\_2**

```
#define ADC_SMPR1_SMP18_2 ((uint32_t)0x04000000)
```

Bit 2

**5.173.2.164 ADC\_SMPR2\_SMP0**

```
#define ADC_SMPR2_SMP0 ((uint32_t)0x00000007)
```

SMP0[2:0] bits (Channel 0 Sample time selection)

**5.173.2.165 ADC\_SMPR2\_SMP0\_0**

```
#define ADC_SMPR2_SMP0_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.166 ADC\_SMPR2\_SMP0\_1**

```
#define ADC_SMPR2_SMP0_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.167 ADC\_SMPR2\_SMP0\_2**

```
#define ADC_SMPR2_SMP0_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.168 ADC\_SMPR2\_SMP1**

```
#define ADC_SMPR2_SMP1 ((uint32_t)0x00000038)
```

SMP1[2:0] bits (Channel 1 Sample time selection)

**5.173.2.169 ADC\_SMPR2\_SMP1\_0**

```
#define ADC_SMPR2_SMP1_0 ((uint32_t)0x00000008)
```

Bit 0

**5.173.2.170 ADC\_SMPR2\_SMP1\_1**

```
#define ADC_SMPR2_SMP1_1 ((uint32_t)0x00000010)
```

Bit 1

**5.173.2.171 ADC\_SMPR2\_SMP1\_2**

```
#define ADC_SMPR2_SMP1_2 ((uint32_t)0x00000020)
```

Bit 2

**5.173.2.172 ADC\_SMPR2\_SMP2**

```
#define ADC_SMPR2_SMP2 ((uint32_t)0x000001C0)
```

SMP2[2:0] bits (Channel 2 Sample time selection)

**5.173.2.173 ADC\_SMPR2\_SMP2\_0**

```
#define ADC_SMPR2_SMP2_0 ((uint32_t)0x00000040)
```

Bit 0

**5.173.2.174 ADC\_SMPR2\_SMP2\_1**

```
#define ADC_SMPR2_SMP2_1 ((uint32_t)0x00000080)
```

Bit 1

**5.173.2.175 ADC\_SMPR2\_SMP2\_2**

```
#define ADC_SMPR2_SMP2_2 ((uint32_t)0x00000100)
```

Bit 2

**5.173.2.176 ADC\_SMPR2\_SMP3**

```
#define ADC_SMPR2_SMP3 ((uint32_t)0x00000E00)
```

SMP3[2:0] bits (Channel 3 Sample time selection)

**5.173.2.177 ADC\_SMPR2\_SMP3\_0**

```
#define ADC_SMPR2_SMP3_0 ((uint32_t)0x00000200)
```

Bit 0

**5.173.2.178 ADC\_SMPR2\_SMP3\_1**

```
#define ADC_SMPR2_SMP3_1 ((uint32_t)0x00000400)
```

Bit 1

**5.173.2.179 ADC\_SMPR2\_SMP3\_2**

```
#define ADC_SMPR2_SMP3_2 ((uint32_t)0x00000800)
```

Bit 2

**5.173.2.180 ADC\_SMPR2\_SMP4**

```
#define ADC_SMPR2_SMP4 ((uint32_t)0x00007000)
```

SMP4[2:0] bits (Channel 4 Sample time selection)

**5.173.2.181 ADC\_SMPR2\_SMP4\_0**

```
#define ADC_SMPR2_SMP4_0 ((uint32_t)0x00001000)
```

Bit 0

**5.173.2.182 ADC\_SMPR2\_SMP4\_1**

```
#define ADC_SMPR2_SMP4_1 ((uint32_t)0x00002000)
```

Bit 1

**5.173.2.183 ADC\_SMPR2\_SMP4\_2**

```
#define ADC_SMPR2_SMP4_2 ((uint32_t)0x00004000)
```

Bit 2

**5.173.2.184 ADC\_SMPR2\_SMP5**

```
#define ADC_SMPR2_SMP5 ((uint32_t)0x00038000)
```

SMP5[2:0] bits (Channel 5 Sample time selection)

**5.173.2.185 ADC\_SMPR2\_SMP5\_0**

```
#define ADC_SMPR2_SMP5_0 ((uint32_t)0x00008000)
```

Bit 0

**5.173.2.186 ADC\_SMPR2\_SMP5\_1**

```
#define ADC_SMPR2_SMP5_1 ((uint32_t)0x00010000)
```

Bit 1

**5.173.2.187 ADC\_SMPR2\_SMP5\_2**

```
#define ADC_SMPR2_SMP5_2 ((uint32_t)0x00020000)
```

Bit 2

**5.173.2.188 ADC\_SMPR2\_SMP6**

```
#define ADC_SMPR2_SMP6 ((uint32_t)0x001C0000)
```

SMP6[2:0] bits (Channel 6 Sample time selection)

**5.173.2.189 ADC\_SMPR2\_SMP6\_0**

```
#define ADC_SMPR2_SMP6_0 ((uint32_t)0x00040000)
```

Bit 0

**5.173.2.190 ADC\_SMPR2\_SMP6\_1**

```
#define ADC_SMPR2_SMP6_1 ((uint32_t)0x00080000)
```

Bit 1

**5.173.2.191 ADC\_SMPR2\_SMP6\_2**

```
#define ADC_SMPR2_SMP6_2 ((uint32_t)0x00100000)
```

Bit 2

**5.173.2.192 ADC\_SMPR2\_SMP7**

```
#define ADC_SMPR2_SMP7 ((uint32_t)0x00E00000)
```

SMP7[2:0] bits (Channel 7 Sample time selection)

**5.173.2.193 ADC\_SMPR2\_SMP7\_0**

```
#define ADC_SMPR2_SMP7_0 ((uint32_t)0x00200000)
```

Bit 0

**5.173.2.194 ADC\_SMPR2\_SMP7\_1**

```
#define ADC_SMPR2_SMP7_1 ((uint32_t)0x00400000)
```

Bit 1

**5.173.2.195 ADC\_SMPR2\_SMP7\_2**

```
#define ADC_SMPR2_SMP7_2 ((uint32_t)0x00800000)
```

Bit 2

**5.173.2.196 ADC\_SMPR2\_SMP8**

```
#define ADC_SMPR2_SMP8 ((uint32_t)0x07000000)
```

SMP8[2:0] bits (Channel 8 Sample time selection)

**5.173.2.197 ADC\_SMPR2\_SMP8\_0**

```
#define ADC_SMPR2_SMP8_0 ((uint32_t)0x01000000)
```

Bit 0

**5.173.2.198 ADC\_SMPR2\_SMP8\_1**

```
#define ADC_SMPR2_SMP8_1 ((uint32_t)0x02000000)
```

Bit 1

**5.173.2.199 ADC\_SMPR2\_SMP8\_2**

```
#define ADC_SMPR2_SMP8_2 ((uint32_t)0x04000000)
```

Bit 2

**5.173.2.200 ADC\_SMPR2\_SMP9**

```
#define ADC_SMPR2_SMP9 ((uint32_t)0x38000000)
```

SMP9[2:0] bits (Channel 9 Sample time selection)

**5.173.2.201 ADC\_SMPR2\_SMP9\_0**

```
#define ADC_SMPR2_SMP9_0 ((uint32_t)0x08000000)
```

Bit 0

**5.173.2.202 ADC\_SMPR2\_SMP9\_1**

```
#define ADC_SMPR2_SMP9_1 ((uint32_t)0x10000000)
```

Bit 1

**5.173.2.203 ADC\_SMPR2\_SMP9\_2**

```
#define ADC_SMPR2_SMP9_2 ((uint32_t)0x20000000)
```

Bit 2

**5.173.2.204 ADC\_SQR1\_L**

```
#define ADC_SQR1_L ((uint32_t)0x00F00000)
```

L[3:0] bits (Regular channel sequence length)

**5.173.2.205 ADC\_SQR1\_L\_0**

```
#define ADC_SQR1_L_0 ((uint32_t)0x00100000)
```

Bit 0

**5.173.2.206 ADC\_SQR1\_L\_1**

```
#define ADC_SQR1_L_1 ((uint32_t)0x00200000)
```

Bit 1

**5.173.2.207 ADC\_SQR1\_L\_2**

```
#define ADC_SQR1_L_2 ((uint32_t)0x00400000)
```

Bit 2

**5.173.2.208 ADC\_SQR1\_L\_3**

```
#define ADC_SQR1_L_3 ((uint32_t)0x00800000)
```

Bit 3

**5.173.2.209 ADC\_SQR1\_SQ13**

```
#define ADC_SQR1_SQ13 ((uint32_t)0x0000001F)
```

SQ13[4:0] bits (13th conversion in regular sequence)

**5.173.2.210 ADC\_SQR1\_SQ13\_0**

```
#define ADC_SQR1_SQ13_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.211 ADC\_SQR1\_SQ13\_1**

```
#define ADC_SQR1_SQ13_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.212 ADC\_SQR1\_SQ13\_2**

```
#define ADC_SQR1_SQ13_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.213 ADC\_SQR1\_SQ13\_3**

```
#define ADC_SQR1_SQ13_3 ((uint32_t)0x00000008)
```

Bit 3

**5.173.2.214 ADC\_SQR1\_SQ13\_4**

```
#define ADC_SQR1_SQ13_4 ((uint32_t)0x00000010)
```

Bit 4

**5.173.2.215 ADC\_SQR1\_SQ14**

```
#define ADC_SQR1_SQ14 ((uint32_t)0x000003E0)
```

SQ14[4:0] bits (14th conversion in regular sequence)

**5.173.2.216 ADC\_SQR1\_SQ14\_0**

```
#define ADC_SQR1_SQ14_0 ((uint32_t)0x00000020)
```

Bit 0

**5.173.2.217 ADC\_SQR1\_SQ14\_1**

```
#define ADC_SQR1_SQ14_1 ((uint32_t)0x00000040)
```

Bit 1

**5.173.2.218 ADC\_SQR1\_SQ14\_2**

```
#define ADC_SQR1_SQ14_2 ((uint32_t)0x00000080)
```

Bit 2

**5.173.2.219 ADC\_SQR1\_SQ14\_3**

```
#define ADC_SQR1_SQ14_3 ((uint32_t)0x00000100)
```

Bit 3

**5.173.2.220 ADC\_SQR1\_SQ14\_4**

```
#define ADC_SQR1_SQ14_4 ((uint32_t)0x00000200)
```

Bit 4

**5.173.2.221 ADC\_SQR1\_SQ15**

```
#define ADC_SQR1_SQ15 ((uint32_t)0x00007C00)
```

SQ15[4:0] bits (15th conversion in regular sequence)

**5.173.2.222 ADC\_SQR1\_SQ15\_0**

```
#define ADC_SQR1_SQ15_0 ((uint32_t)0x00000400)
```

Bit 0

**5.173.2.223 ADC\_SQR1\_SQ15\_1**

```
#define ADC_SQR1_SQ15_1 ((uint32_t)0x00000800)
```

Bit 1

**5.173.2.224 ADC\_SQR1\_SQ15\_2**

```
#define ADC_SQR1_SQ15_2 ((uint32_t)0x00001000)
```

Bit 2

**5.173.2.225 ADC\_SQR1\_SQ15\_3**

```
#define ADC_SQR1_SQ15_3 ((uint32_t)0x00002000)
```

Bit 3

**5.173.2.226 ADC\_SQR1\_SQ15\_4**

```
#define ADC_SQR1_SQ15_4 ((uint32_t)0x00004000)
```

Bit 4

**5.173.2.227 ADC\_SQR1\_SQ16**

```
#define ADC_SQR1_SQ16 ((uint32_t)0x000F8000)
```

SQ16[4:0] bits (16th conversion in regular sequence)

**5.173.2.228 ADC\_SQR1\_SQ16\_0**

```
#define ADC_SQR1_SQ16_0 ((uint32_t)0x00008000)
```

Bit 0

**5.173.2.229 ADC\_SQR1\_SQ16\_1**

```
#define ADC_SQR1_SQ16_1 ((uint32_t)0x00010000)
```

Bit 1

**5.173.2.230 ADC\_SQR1\_SQ16\_2**

```
#define ADC_SQR1_SQ16_2 ((uint32_t)0x00020000)
```

Bit 2

**5.173.2.231 ADC\_SQR1\_SQ16\_3**

```
#define ADC_SQR1_SQ16_3 ((uint32_t)0x00040000)
```

Bit 3

**5.173.2.232 ADC\_SQR1\_SQ16\_4**

```
#define ADC_SQR1_SQ16_4 ((uint32_t)0x00080000)
```

Bit 4

**5.173.2.233 ADC\_SQR2\_SQ10**

```
#define ADC_SQR2_SQ10 ((uint32_t)0x000F8000)
```

SQ10[4:0] bits (10th conversion in regular sequence)

**5.173.2.234 ADC\_SQR2\_SQ10\_0**

```
#define ADC_SQR2_SQ10_0 ((uint32_t)0x00008000)
```

Bit 0

**5.173.2.235 ADC\_SQR2\_SQ10\_1**

```
#define ADC_SQR2_SQ10_1 ((uint32_t)0x00010000)
```

Bit 1

**5.173.2.236 ADC\_SQR2\_SQ10\_2**

```
#define ADC_SQR2_SQ10_2 ((uint32_t)0x00020000)
```

Bit 2

**5.173.2.237 ADC\_SQR2\_SQ10\_3**

```
#define ADC_SQR2_SQ10_3 ((uint32_t)0x00040000)
```

Bit 3

**5.173.2.238 ADC\_SQR2\_SQ10\_4**

```
#define ADC_SQR2_SQ10_4 ((uint32_t)0x00080000)
```

Bit 4

**5.173.2.239 ADC\_SQR2\_SQ11**

```
#define ADC_SQR2_SQ11 ((uint32_t)0x01F00000)
```

SQ11[4:0] bits (11th conversion in regular sequence)

**5.173.2.240 ADC\_SQR2\_SQ11\_0**

```
#define ADC_SQR2_SQ11_0 ((uint32_t)0x00100000)
```

Bit 0

**5.173.2.241 ADC\_SQR2\_SQ11\_1**

```
#define ADC_SQR2_SQ11_1 ((uint32_t)0x00200000)
```

Bit 1

**5.173.2.242 ADC\_SQR2\_SQ11\_2**

```
#define ADC_SQR2_SQ11_2 ((uint32_t)0x00400000)
```

Bit 2

**5.173.2.243 ADC\_SQR2\_SQ11\_3**

```
#define ADC_SQR2_SQ11_3 ((uint32_t)0x00800000)
```

Bit 3

**5.173.2.244 ADC\_SQR2\_SQ11\_4**

```
#define ADC_SQR2_SQ11_4 ((uint32_t)0x01000000)
```

Bit 4

**5.173.2.245 ADC\_SQR2\_SQ12**

```
#define ADC_SQR2_SQ12 ((uint32_t)0x3E000000)
```

SQ12[4:0] bits (12th conversion in regular sequence)

**5.173.2.246 ADC\_SQR2\_SQ12\_0**

```
#define ADC_SQR2_SQ12_0 ((uint32_t)0x02000000)
```

Bit 0

**5.173.2.247 ADC\_SQR2\_SQ12\_1**

```
#define ADC_SQR2_SQ12_1 ((uint32_t)0x04000000)
```

Bit 1

**5.173.2.248 ADC\_SQR2\_SQ12\_2**

```
#define ADC_SQR2_SQ12_2 ((uint32_t)0x08000000)
```

Bit 2

**5.173.2.249 ADC\_SQR2\_SQ12\_3**

```
#define ADC_SQR2_SQ12_3 ((uint32_t)0x10000000)
```

Bit 3

**5.173.2.250 ADC\_SQR2\_SQ12\_4**

```
#define ADC_SQR2_SQ12_4 ((uint32_t)0x20000000)
```

Bit 4

**5.173.2.251 ADC\_SQR2\_SQ7**

```
#define ADC_SQR2_SQ7 ((uint32_t)0x0000001F)
```

SQ7[4:0] bits (7th conversion in regular sequence)

**5.173.2.252 ADC\_SQR2\_SQ7\_0**

```
#define ADC_SQR2_SQ7_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.253 ADC\_SQR2\_SQ7\_1**

```
#define ADC_SQR2_SQ7_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.254 ADC\_SQR2\_SQ7\_2**

```
#define ADC_SQR2_SQ7_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.255 ADC\_SQR2\_SQ7\_3**

```
#define ADC_SQR2_SQ7_3 ((uint32_t)0x00000008)
```

Bit 3

**5.173.2.256 ADC\_SQR2\_SQ7\_4**

```
#define ADC_SQR2_SQ7_4 ((uint32_t)0x00000010)
```

Bit 4

**5.173.2.257 ADC\_SQR2\_SQ8**

```
#define ADC_SQR2_SQ8 ((uint32_t)0x000003E0)
```

SQ8[4:0] bits (8th conversion in regular sequence)

**5.173.2.258 ADC\_SQR2\_SQ8\_0**

```
#define ADC_SQR2_SQ8_0 ((uint32_t)0x00000020)
```

Bit 0

**5.173.2.259 ADC\_SQR2\_SQ8\_1**

```
#define ADC_SQR2_SQ8_1 ((uint32_t)0x00000040)
```

Bit 1

**5.173.2.260 ADC\_SQR2\_SQ8\_2**

```
#define ADC_SQR2_SQ8_2 ((uint32_t)0x00000080)
```

Bit 2

**5.173.2.261 ADC\_SQR2\_SQ8\_3**

```
#define ADC_SQR2_SQ8_3 ((uint32_t)0x00000100)
```

Bit 3

**5.173.2.262 ADC\_SQR2\_SQ8\_4**

```
#define ADC_SQR2_SQ8_4 ((uint32_t)0x00000200)
```

Bit 4

**5.173.2.263 ADC\_SQR2\_SQ9**

```
#define ADC_SQR2_SQ9 ((uint32_t)0x00007C00)
```

SQ9[4:0] bits (9th conversion in regular sequence)

**5.173.2.264 ADC\_SQR2\_SQ9\_0**

```
#define ADC_SQR2_SQ9_0 ((uint32_t)0x00000400)
```

Bit 0

**5.173.2.265 ADC\_SQR2\_SQ9\_1**

```
#define ADC_SQR2_SQ9_1 ((uint32_t)0x00000800)
```

Bit 1

**5.173.2.266 ADC\_SQR2\_SQ9\_2**

```
#define ADC_SQR2_SQ9_2 ((uint32_t)0x00001000)
```

Bit 2

**5.173.2.267 ADC\_SQR2\_SQ9\_3**

```
#define ADC_SQR2_SQ9_3 ((uint32_t)0x00002000)
```

Bit 3

**5.173.2.268 ADC\_SQR2\_SQ9\_4**

```
#define ADC_SQR2_SQ9_4 ((uint32_t)0x00004000)
```

Bit 4

**5.173.2.269 ADC\_SQR3\_SQ1**

```
#define ADC_SQR3_SQ1 ((uint32_t)0x0000001F)
```

SQ1[4:0] bits (1st conversion in regular sequence)

**5.173.2.270 ADC\_SQR3\_SQ1\_0**

```
#define ADC_SQR3_SQ1_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.271 ADC\_SQR3\_SQ1\_1**

```
#define ADC_SQR3_SQ1_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.272 ADC\_SQR3\_SQ1\_2**

```
#define ADC_SQR3_SQ1_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.273 ADC\_SQR3\_SQ1\_3**

```
#define ADC_SQR3_SQ1_3 ((uint32_t)0x00000008)
```

Bit 3

**5.173.2.274 ADC\_SQR3\_SQ1\_4**

```
#define ADC_SQR3_SQ1_4 ((uint32_t)0x00000010)
```

Bit 4

**5.173.2.275 ADC\_SQR3\_SQ2**

```
#define ADC_SQR3_SQ2 ((uint32_t)0x000003E0)
```

SQ2[4:0] bits (2nd conversion in regular sequence)

**5.173.2.276 ADC\_SQR3\_SQ2\_0**

```
#define ADC_SQR3_SQ2_0 ((uint32_t)0x00000020)
```

Bit 0

**5.173.2.277 ADC\_SQR3\_SQ2\_1**

```
#define ADC_SQR3_SQ2_1 ((uint32_t)0x00000040)
```

Bit 1

**5.173.2.278 ADC\_SQR3\_SQ2\_2**

```
#define ADC_SQR3_SQ2_2 ((uint32_t)0x00000080)
```

Bit 2

**5.173.2.279 ADC\_SQR3\_SQ2\_3**

```
#define ADC_SQR3_SQ2_3 ((uint32_t)0x00000100)
```

Bit 3

**5.173.2.280 ADC\_SQR3\_SQ2\_4**

```
#define ADC_SQR3_SQ2_4 ((uint32_t)0x00000200)
```

Bit 4

**5.173.2.281 ADC\_SQR3\_SQ3**

```
#define ADC_SQR3_SQ3 ((uint32_t)0x00007C00)
```

SQ3[4:0] bits (3rd conversion in regular sequence)

**5.173.2.282 ADC\_SQR3\_SQ3\_0**

```
#define ADC_SQR3_SQ3_0 ((uint32_t)0x00000400)
```

Bit 0

**5.173.2.283 ADC\_SQR3\_SQ3\_1**

```
#define ADC_SQR3_SQ3_1 ((uint32_t)0x00000800)
```

Bit 1

**5.173.2.284 ADC\_SQR3\_SQ3\_2**

```
#define ADC_SQR3_SQ3_2 ((uint32_t)0x00001000)
```

Bit 2

**5.173.2.285 ADC\_SQR3\_SQ3\_3**

```
#define ADC_SQR3_SQ3_3 ((uint32_t)0x00002000)
```

Bit 3

**5.173.2.286 ADC\_SQR3\_SQ3\_4**

```
#define ADC_SQR3_SQ3_4 ((uint32_t)0x00004000)
```

Bit 4

**5.173.2.287 ADC\_SQR3\_SQ4**

```
#define ADC_SQR3_SQ4 ((uint32_t)0x000F8000)
```

SQ4[4:0] bits (4th conversion in regular sequence)

**5.173.2.288 ADC\_SQR3\_SQ4\_0**

```
#define ADC_SQR3_SQ4_0 ((uint32_t)0x00008000)
```

Bit 0

**5.173.2.289 ADC\_SQR3\_SQ4\_1**

```
#define ADC_SQR3_SQ4_1 ((uint32_t)0x00010000)
```

Bit 1

**5.173.2.290 ADC\_SQR3\_SQ4\_2**

```
#define ADC_SQR3_SQ4_2 ((uint32_t)0x00020000)
```

Bit 2

**5.173.2.291 ADC\_SQR3\_SQ4\_3**

```
#define ADC_SQR3_SQ4_3 ((uint32_t)0x00040000)
```

Bit 3

**5.173.2.292 ADC\_SQR3\_SQ4\_4**

```
#define ADC_SQR3_SQ4_4 ((uint32_t)0x00080000)
```

Bit 4

**5.173.2.293 ADC\_SQR3\_SQ5**

```
#define ADC_SQR3_SQ5 ((uint32_t)0x01F00000)
```

SQ5[4:0] bits (5th conversion in regular sequence)

**5.173.2.294 ADC\_SQR3\_SQ5\_0**

```
#define ADC_SQR3_SQ5_0 ((uint32_t)0x00100000)
```

Bit 0

**5.173.2.295 ADC\_SQR3\_SQ5\_1**

```
#define ADC_SQR3_SQ5_1 ((uint32_t)0x00200000)
```

Bit 1

**5.173.2.296 ADC\_SQR3\_SQ5\_2**

```
#define ADC_SQR3_SQ5_2 ((uint32_t)0x00400000)
```

Bit 2

**5.173.2.297 ADC\_SQR3\_SQ5\_3**

```
#define ADC_SQR3_SQ5_3 ((uint32_t)0x00800000)
```

Bit 3

**5.173.2.298 ADC\_SQR3\_SQ5\_4**

```
#define ADC_SQR3_SQ5_4 ((uint32_t)0x01000000)
```

Bit 4

**5.173.2.299 ADC\_SQR3\_SQ6**

```
#define ADC_SQR3_SQ6 ((uint32_t)0x3E000000)
```

SQ6[4:0] bits (6th conversion in regular sequence)

**5.173.2.300 ADC\_SQR3\_SQ6\_0**

```
#define ADC_SQR3_SQ6_0 ((uint32_t)0x02000000)
```

Bit 0

**5.173.2.301 ADC\_SQR3\_SQ6\_1**

```
#define ADC_SQR3_SQ6_1 ((uint32_t)0x04000000)
```

Bit 1

**5.173.2.302 ADC\_SQR3\_SQ6\_2**

```
#define ADC_SQR3_SQ6_2 ((uint32_t)0x08000000)
```

Bit 2

**5.173.2.303 ADC\_SQR3\_SQ6\_3**

```
#define ADC_SQR3_SQ6_3 ((uint32_t)0x10000000)
```

Bit 3

**5.173.2.304 ADC\_SQR3\_SQ6\_4**

```
#define ADC_SQR3_SQ6_4 ((uint32_t)0x20000000)
```

Bit 4

**5.173.2.305 ADC\_SR\_AWD**

```
#define ADC_SR_AWD ((uint8_t)0x01)
```

Analog watchdog flag

**5.173.2.306 ADC\_SR\_EOC**

```
#define ADC_SR_EOC ((uint8_t)0x02)
```

End of conversion

**5.173.2.307 ADC\_SR\_JEOC**

```
#define ADC_SR_JEOC ((uint8_t)0x04)
```

Injected channel end of conversion

**5.173.2.308 ADC\_SR\_JSTRT**

```
#define ADC_SR_JSTRT ((uint8_t)0x08)
```

Injected channel Start flag

**5.173.2.309 ADC\_SR\_OVR**

```
#define ADC_SR_OVR ((uint8_t)0x20)
```

Overrun flag

**5.173.2.310 ADC\_SR\_STRT**

```
#define ADC_SR_STRT ((uint8_t)0x10)
```

Regular channel Start flag

**5.173.2.311 CAN\_BTR\_BRP**

```
#define CAN_BTR_BRP ((uint32_t)0x000003FF)
```

Baud Rate Prescaler

**5.173.2.312 CAN\_BTR\_LBKM**

```
#define CAN_BTR_LBKM ((uint32_t)0x40000000)
```

Loop Back Mode (Debug)

**5.173.2.313 CAN\_BTR\_SILM**

```
#define CAN_BTR_SILM ((uint32_t)0x80000000)
```

Silent Mode Mailbox registers

**5.173.2.314 CAN\_BTR\_SJW**

```
#define CAN_BTR_SJW ((uint32_t)0x03000000)
```

Resynchronization Jump Width

**5.173.2.315 CAN\_BTR\_TS1**

```
#define CAN_BTR_TS1 ((uint32_t)0x000F0000)
```

Time Segment 1

**5.173.2.316 CAN\_BTR\_TS2**

```
#define CAN_BTR_TS2 ((uint32_t)0x00700000)
```

Time Segment 2

**5.173.2.317 CAN\_ESR\_BOFF**

```
#define CAN_ESR_BOFF ((uint32_t)0x00000004)
```

Bus-Off Flag

**5.173.2.318 CAN\_ESR\_EPVF**

```
#define CAN_ESR_EPVF ((uint32_t)0x00000002)
```

Error Passive Flag

**5.173.2.319 CAN\_ESR\_EWGF**

```
#define CAN_ESR_EWGF ((uint32_t)0x00000001)
```

Error Warning Flag

**5.173.2.320 CAN\_ESR\_LEC**

```
#define CAN_ESR_LEC ((uint32_t)0x00000070)
```

LEC[2:0] bits (Last Error Code)

**5.173.2.321 CAN\_ESR\_LEC\_0**

```
#define CAN_ESR_LEC_0 ((uint32_t)0x00000010)
```

Bit 0

**5.173.2.322 CAN\_ESR\_LEC\_1**

```
#define CAN_ESR_LEC_1 ((uint32_t)0x00000020)
```

Bit 1

**5.173.2.323 CAN\_ESR\_LEC\_2**

```
#define CAN_ESR_LEC_2 ((uint32_t)0x00000040)
```

Bit 2

**5.173.2.324 CAN\_ESR\_REC**

```
#define CAN_ESR_REC ((uint32_t)0xFF000000)
```

Receive Error Counter

**5.173.2.325 CAN\_ESR\_TEC**

```
#define CAN_ESR_TEC ((uint32_t)0x00FF0000)
```

Least significant byte of the 9-bit Transmit Error Counter

**5.173.2.326 CAN\_F0R1\_FB0**

```
#define CAN_F0R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.327 CAN\_F0R1\_FB1**

```
#define CAN_F0R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.328 CAN\_F0R1\_FB10**

```
#define CAN_F0R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.329 CAN\_F0R1\_FB11**

```
#define CAN_F0R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.330 CAN\_F0R1\_FB12**

```
#define CAN_F0R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.331 CAN\_F0R1\_FB13**

```
#define CAN_F0R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.332 CAN\_F0R1\_FB14**

```
#define CAN_F0R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.333 CAN\_F0R1\_FB15**

```
#define CAN_F0R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.334 CAN\_F0R1\_FB16**

```
#define CAN_F0R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.335 CAN\_F0R1\_FB17**

```
#define CAN_F0R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.336 CAN\_F0R1\_FB18**

```
#define CAN_F0R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.337 CAN\_F0R1\_FB19**

```
#define CAN_F0R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.338 CAN\_F0R1\_FB2**

```
#define CAN_F0R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.339 CAN\_F0R1\_FB20**

```
#define CAN_F0R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.340 CAN\_F0R1\_FB21**

```
#define CAN_F0R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.341 CAN\_F0R1\_FB22**

```
#define CAN_F0R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.342 CAN\_F0R1\_FB23**

```
#define CAN_F0R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.343 CAN\_F0R1\_FB24**

```
#define CAN_F0R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.344 CAN\_F0R1\_FB25**

```
#define CAN_F0R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.345 CAN\_F0R1\_FB26**

```
#define CAN_F0R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.346 CAN\_F0R1\_FB27**

```
#define CAN_F0R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.347 CAN\_F0R1\_FB28**

```
#define CAN_F0R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.348 CAN\_F0R1\_FB29**

```
#define CAN_F0R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.349 CAN\_F0R1\_FB3**

```
#define CAN_F0R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.350 CAN\_F0R1\_FB30**

```
#define CAN_F0R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.351 CAN\_F0R1\_FB31**

```
#define CAN_F0R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.352 CAN\_F0R1\_FB4**

```
#define CAN_F0R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.353 CAN\_F0R1\_FB5**

```
#define CAN_F0R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.354 CAN\_F0R1\_FB6**

```
#define CAN_F0R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.355 CAN\_F0R1\_FB7**

```
#define CAN_F0R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.356 CAN\_F0R1\_FB8**

```
#define CAN_F0R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.357 CAN\_F0R1\_FB9**

```
#define CAN_F0R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.358 CAN\_F0R2\_FB0**

```
#define CAN_F0R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.359 CAN\_F0R2\_FB1**

```
#define CAN_F0R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.360 CAN\_F0R2\_FB10**

```
#define CAN_F0R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.361 CAN\_F0R2\_FB11**

```
#define CAN_F0R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.362 CAN\_F0R2\_FB12**

```
#define CAN_F0R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.363 CAN\_F0R2\_FB13**

```
#define CAN_F0R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.364 CAN\_F0R2\_FB14**

```
#define CAN_F0R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.365 CAN\_F0R2\_FB15**

```
#define CAN_F0R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.366 CAN\_F0R2\_FB16**

```
#define CAN_F0R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.367 CAN\_F0R2\_FB17**

```
#define CAN_F0R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.368 CAN\_F0R2\_FB18**

```
#define CAN_F0R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.369 CAN\_F0R2\_FB19**

```
#define CAN_F0R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.370 CAN\_F0R2\_FB2**

```
#define CAN_F0R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.371 CAN\_F0R2\_FB20**

```
#define CAN_F0R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.372 CAN\_F0R2\_FB21**

```
#define CAN_F0R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.373 CAN\_F0R2\_FB22**

```
#define CAN_F0R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.374 CAN\_F0R2\_FB23**

```
#define CAN_F0R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.375 CAN\_F0R2\_FB24**

```
#define CAN_F0R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.376 CAN\_F0R2\_FB25**

```
#define CAN_F0R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.377 CAN\_F0R2\_FB26**

```
#define CAN_F0R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.378 CAN\_F0R2\_FB27**

```
#define CAN_F0R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.379 CAN\_F0R2\_FB28**

```
#define CAN_F0R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.380 CAN\_F0R2\_FB29**

```
#define CAN_F0R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.381 CAN\_F0R2\_FB3**

```
#define CAN_F0R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.382 CAN\_F0R2\_FB30**

```
#define CAN_F0R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.383 CAN\_F0R2\_FB31**

```
#define CAN_F0R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.384 CAN\_F0R2\_FB4**

```
#define CAN_F0R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.385 CAN\_F0R2\_FB5**

```
#define CAN_F0R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.386 CAN\_F0R2\_FB6**

```
#define CAN_F0R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.387 CAN\_F0R2\_FB7**

```
#define CAN_F0R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.388 CAN\_F0R2\_FB8**

```
#define CAN_F0R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.389 CAN\_F0R2\_FB9**

```
#define CAN_F0R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.390 CAN\_F10R1\_FB0**

```
#define CAN_F10R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.391 CAN\_F10R1\_FB1**

```
#define CAN_F10R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.392 CAN\_F10R1\_FB10**

```
#define CAN_F10R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.393 CAN\_F10R1\_FB11**

```
#define CAN_F10R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.394 CAN\_F10R1\_FB12**

```
#define CAN_F10R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.395 CAN\_F10R1\_FB13**

```
#define CAN_F10R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.396 CAN\_F10R1\_FB14**

```
#define CAN_F10R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.397 CAN\_F10R1\_FB15**

```
#define CAN_F10R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.398 CAN\_F10R1\_FB16**

```
#define CAN_F10R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.399 CAN\_F10R1\_FB17**

```
#define CAN_F10R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.400 CAN\_F10R1\_FB18**

```
#define CAN_F10R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.401 CAN\_F10R1\_FB19**

```
#define CAN_F10R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.402 CAN\_F10R1\_FB2**

```
#define CAN_F10R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.403 CAN\_F10R1\_FB20**

```
#define CAN_F10R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.404 CAN\_F10R1\_FB21**

```
#define CAN_F10R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.405 CAN\_F10R1\_FB22**

```
#define CAN_F10R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.406 CAN\_F10R1\_FB23**

```
#define CAN_F10R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.407 CAN\_F10R1\_FB24**

```
#define CAN_F10R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.408 CAN\_F10R1\_FB25**

```
#define CAN_F10R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.409 CAN\_F10R1\_FB26**

```
#define CAN_F10R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.410 CAN\_F10R1\_FB27**

```
#define CAN_F10R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.411 CAN\_F10R1\_FB28**

```
#define CAN_F10R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.412 CAN\_F10R1\_FB29**

```
#define CAN_F10R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.413 CAN\_F10R1\_FB3**

```
#define CAN_F10R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.414 CAN\_F10R1\_FB30**

```
#define CAN_F10R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.415 CAN\_F10R1\_FB31**

```
#define CAN_F10R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.416 CAN\_F10R1\_FB4**

```
#define CAN_F10R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.417 CAN\_F10R1\_FB5**

```
#define CAN_F10R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.418 CAN\_F10R1\_FB6**

```
#define CAN_F10R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.419 CAN\_F10R1\_FB7**

```
#define CAN_F10R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.420 CAN\_F10R1\_FB8**

```
#define CAN_F10R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.421 CAN\_F10R1\_FB9**

```
#define CAN_F10R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.422 CAN\_F10R2\_FB0**

```
#define CAN_F10R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.423 CAN\_F10R2\_FB1**

```
#define CAN_F10R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.424 CAN\_F10R2\_FB10**

```
#define CAN_F10R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.425 CAN\_F10R2\_FB11**

```
#define CAN_F10R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.426 CAN\_F10R2\_FB12**

```
#define CAN_F10R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.427 CAN\_F10R2\_FB13**

```
#define CAN_F10R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.428 CAN\_F10R2\_FB14**

```
#define CAN_F10R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.429 CAN\_F10R2\_FB15**

```
#define CAN_F10R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.430 CAN\_F10R2\_FB16**

```
#define CAN_F10R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.431 CAN\_F10R2\_FB17**

```
#define CAN_F10R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.432 CAN\_F10R2\_FB18**

```
#define CAN_F10R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.433 CAN\_F10R2\_FB19**

```
#define CAN_F10R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.434 CAN\_F10R2\_FB2**

```
#define CAN_F10R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.435 CAN\_F10R2\_FB20**

```
#define CAN_F10R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.436 CAN\_F10R2\_FB21**

```
#define CAN_F10R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.437 CAN\_F10R2\_FB22**

```
#define CAN_F10R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.438 CAN\_F10R2\_FB23**

```
#define CAN_F10R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.439 CAN\_F10R2\_FB24**

```
#define CAN_F10R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.440 CAN\_F10R2\_FB25**

```
#define CAN_F10R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.441 CAN\_F10R2\_FB26**

```
#define CAN_F10R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.442 CAN\_F10R2\_FB27**

```
#define CAN_F10R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.443 CAN\_F10R2\_FB28**

```
#define CAN_F10R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.444 CAN\_F10R2\_FB29**

```
#define CAN_F10R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.445 CAN\_F10R2\_FB3**

```
#define CAN_F10R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.446 CAN\_F10R2\_FB30**

```
#define CAN_F10R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.447 CAN\_F10R2\_FB31**

```
#define CAN_F10R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.448 CAN\_F10R2\_FB4**

```
#define CAN_F10R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.449 CAN\_F10R2\_FB5**

```
#define CAN_F10R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.450 CAN\_F10R2\_FB6**

```
#define CAN_F10R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.451 CAN\_F10R2\_FB7**

```
#define CAN_F10R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.452 CAN\_F10R2\_FB8**

```
#define CAN_F10R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.453 CAN\_F10R2\_FB9**

```
#define CAN_F10R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.454 CAN\_F11R1\_FB0**

```
#define CAN_F11R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.455 CAN\_F11R1\_FB1**

```
#define CAN_F11R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.456 CAN\_F11R1\_FB10**

```
#define CAN_F11R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.457 CAN\_F11R1\_FB11**

```
#define CAN_F11R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.458 CAN\_F11R1\_FB12**

```
#define CAN_F11R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.459 CAN\_F11R1\_FB13**

```
#define CAN_F11R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.460 CAN\_F11R1\_FB14**

```
#define CAN_F11R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.461 CAN\_F11R1\_FB15**

```
#define CAN_F11R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.462 CAN\_F11R1\_FB16**

```
#define CAN_F11R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.463 CAN\_F11R1\_FB17**

```
#define CAN_F11R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.464 CAN\_F11R1\_FB18**

```
#define CAN_F11R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.465 CAN\_F11R1\_FB19**

```
#define CAN_F11R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.466 CAN\_F11R1\_FB2**

```
#define CAN_F11R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.467 CAN\_F11R1\_FB20**

```
#define CAN_F11R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.468 CAN\_F11R1\_FB21**

```
#define CAN_F11R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.469 CAN\_F11R1\_FB22**

```
#define CAN_F11R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.470 CAN\_F11R1\_FB23**

```
#define CAN_F11R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.471 CAN\_F11R1\_FB24**

```
#define CAN_F11R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.472 CAN\_F11R1\_FB25**

```
#define CAN_F11R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.473 CAN\_F11R1\_FB26**

```
#define CAN_F11R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.474 CAN\_F11R1\_FB27**

```
#define CAN_F11R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.475 CAN\_F11R1\_FB28**

```
#define CAN_F11R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.476 CAN\_F11R1\_FB29**

```
#define CAN_F11R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.477 CAN\_F11R1\_FB3**

```
#define CAN_F11R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.478 CAN\_F11R1\_FB30**

```
#define CAN_F11R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.479 CAN\_F11R1\_FB31**

```
#define CAN_F11R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.480 CAN\_F11R1\_FB4**

```
#define CAN_F11R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.481 CAN\_F11R1\_FB5**

```
#define CAN_F11R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.482 CAN\_F11R1\_FB6**

```
#define CAN_F11R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.483 CAN\_F11R1\_FB7**

```
#define CAN_F11R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.484 CAN\_F11R1\_FB8**

```
#define CAN_F11R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.485 CAN\_F11R1\_FB9**

```
#define CAN_F11R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.486 CAN\_F11R2\_FB0**

```
#define CAN_F11R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.487 CAN\_F11R2\_FB1**

```
#define CAN_F11R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.488 CAN\_F11R2\_FB10**

```
#define CAN_F11R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.489 CAN\_F11R2\_FB11**

```
#define CAN_F11R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.490 CAN\_F11R2\_FB12**

```
#define CAN_F11R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.491 CAN\_F11R2\_FB13**

```
#define CAN_F11R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.492 CAN\_F11R2\_FB14**

```
#define CAN_F11R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.493 CAN\_F11R2\_FB15**

```
#define CAN_F11R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.494 CAN\_F11R2\_FB16**

```
#define CAN_F11R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.495 CAN\_F11R2\_FB17**

```
#define CAN_F11R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.496 CAN\_F11R2\_FB18**

```
#define CAN_F11R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.497 CAN\_F11R2\_FB19**

```
#define CAN_F11R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.498 CAN\_F11R2\_FB2**

```
#define CAN_F11R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.499 CAN\_F11R2\_FB20**

```
#define CAN_F11R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.500 CAN\_F11R2\_FB21**

```
#define CAN_F11R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.501 CAN\_F11R2\_FB22**

```
#define CAN_F11R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.502 CAN\_F11R2\_FB23**

```
#define CAN_F11R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.503 CAN\_F11R2\_FB24**

```
#define CAN_F11R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.504 CAN\_F11R2\_FB25**

```
#define CAN_F11R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.505 CAN\_F11R2\_FB26**

```
#define CAN_F11R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.506 CAN\_F11R2\_FB27**

```
#define CAN_F11R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.507 CAN\_F11R2\_FB28**

```
#define CAN_F11R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.508 CAN\_F11R2\_FB29**

```
#define CAN_F11R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.509 CAN\_F11R2\_FB3**

```
#define CAN_F11R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.510 CAN\_F11R2\_FB30**

```
#define CAN_F11R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.511 CAN\_F11R2\_FB31**

```
#define CAN_F11R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.512 CAN\_F11R2\_FB4**

```
#define CAN_F11R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.513 CAN\_F11R2\_FB5**

```
#define CAN_F11R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.514 CAN\_F11R2\_FB6**

```
#define CAN_F11R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.515 CAN\_F11R2\_FB7**

```
#define CAN_F11R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.516 CAN\_F11R2\_FB8**

```
#define CAN_F11R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.517 CAN\_F11R2\_FB9**

```
#define CAN_F11R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.518 CAN\_F12R1\_FB0**

```
#define CAN_F12R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.519 CAN\_F12R1\_FB1**

```
#define CAN_F12R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.520 CAN\_F12R1\_FB10**

```
#define CAN_F12R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.521 CAN\_F12R1\_FB11**

```
#define CAN_F12R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.522 CAN\_F12R1\_FB12**

```
#define CAN_F12R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.523 CAN\_F12R1\_FB13**

```
#define CAN_F12R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.524 CAN\_F12R1\_FB14**

```
#define CAN_F12R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.525 CAN\_F12R1\_FB15**

```
#define CAN_F12R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.526 CAN\_F12R1\_FB16**

```
#define CAN_F12R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.527 CAN\_F12R1\_FB17**

```
#define CAN_F12R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.528 CAN\_F12R1\_FB18**

```
#define CAN_F12R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.529 CAN\_F12R1\_FB19**

```
#define CAN_F12R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.530 CAN\_F12R1\_FB2**

```
#define CAN_F12R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.531 CAN\_F12R1\_FB20**

```
#define CAN_F12R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.532 CAN\_F12R1\_FB21**

```
#define CAN_F12R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.533 CAN\_F12R1\_FB22**

```
#define CAN_F12R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.534 CAN\_F12R1\_FB23**

```
#define CAN_F12R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.535 CAN\_F12R1\_FB24**

```
#define CAN_F12R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.536 CAN\_F12R1\_FB25**

```
#define CAN_F12R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.537 CAN\_F12R1\_FB26**

```
#define CAN_F12R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.538 CAN\_F12R1\_FB27**

```
#define CAN_F12R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.539 CAN\_F12R1\_FB28**

```
#define CAN_F12R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.540 CAN\_F12R1\_FB29**

```
#define CAN_F12R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.541 CAN\_F12R1\_FB3**

```
#define CAN_F12R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.542 CAN\_F12R1\_FB30**

```
#define CAN_F12R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.543 CAN\_F12R1\_FB31**

```
#define CAN_F12R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.544 CAN\_F12R1\_FB4**

```
#define CAN_F12R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.545 CAN\_F12R1\_FB5**

```
#define CAN_F12R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.546 CAN\_F12R1\_FB6**

```
#define CAN_F12R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.547 CAN\_F12R1\_FB7**

```
#define CAN_F12R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.548 CAN\_F12R1\_FB8**

```
#define CAN_F12R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.549 CAN\_F12R1\_FB9**

```
#define CAN_F12R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.550 CAN\_F12R2\_FB0**

```
#define CAN_F12R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.551 CAN\_F12R2\_FB1**

```
#define CAN_F12R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.552 CAN\_F12R2\_FB10**

```
#define CAN_F12R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.553 CAN\_F12R2\_FB11**

```
#define CAN_F12R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.554 CAN\_F12R2\_FB12**

```
#define CAN_F12R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.555 CAN\_F12R2\_FB13**

```
#define CAN_F12R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.556 CAN\_F12R2\_FB14**

```
#define CAN_F12R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.557 CAN\_F12R2\_FB15**

```
#define CAN_F12R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.558 CAN\_F12R2\_FB16**

```
#define CAN_F12R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.559 CAN\_F12R2\_FB17**

```
#define CAN_F12R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.560 CAN\_F12R2\_FB18**

```
#define CAN_F12R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.561 CAN\_F12R2\_FB19**

```
#define CAN_F12R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.562 CAN\_F12R2\_FB2**

```
#define CAN_F12R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.563 CAN\_F12R2\_FB20**

```
#define CAN_F12R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.564 CAN\_F12R2\_FB21**

```
#define CAN_F12R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.565 CAN\_F12R2\_FB22**

```
#define CAN_F12R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.566 CAN\_F12R2\_FB23**

```
#define CAN_F12R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.567 CAN\_F12R2\_FB24**

```
#define CAN_F12R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.568 CAN\_F12R2\_FB25**

```
#define CAN_F12R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.569 CAN\_F12R2\_FB26**

```
#define CAN_F12R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.570 CAN\_F12R2\_FB27**

```
#define CAN_F12R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.571 CAN\_F12R2\_FB28**

```
#define CAN_F12R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.572 CAN\_F12R2\_FB29**

```
#define CAN_F12R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.573 CAN\_F12R2\_FB3**

```
#define CAN_F12R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.574 CAN\_F12R2\_FB30**

```
#define CAN_F12R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.575 CAN\_F12R2\_FB31**

```
#define CAN_F12R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.576 CAN\_F12R2\_FB4**

```
#define CAN_F12R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.577 CAN\_F12R2\_FB5**

```
#define CAN_F12R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.578 CAN\_F12R2\_FB6**

```
#define CAN_F12R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.579 CAN\_F12R2\_FB7**

```
#define CAN_F12R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.580 CAN\_F12R2\_FB8**

```
#define CAN_F12R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.581 CAN\_F12R2\_FB9**

```
#define CAN_F12R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.582 CAN\_F13R1\_FB0**

```
#define CAN_F13R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.583 CAN\_F13R1\_FB1**

```
#define CAN_F13R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.584 CAN\_F13R1\_FB10**

```
#define CAN_F13R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.585 CAN\_F13R1\_FB11**

```
#define CAN_F13R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.586 CAN\_F13R1\_FB12**

```
#define CAN_F13R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.587 CAN\_F13R1\_FB13**

```
#define CAN_F13R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.588 CAN\_F13R1\_FB14**

```
#define CAN_F13R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.589 CAN\_F13R1\_FB15**

```
#define CAN_F13R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.590 CAN\_F13R1\_FB16**

```
#define CAN_F13R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.591 CAN\_F13R1\_FB17**

```
#define CAN_F13R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.592 CAN\_F13R1\_FB18**

```
#define CAN_F13R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.593 CAN\_F13R1\_FB19**

```
#define CAN_F13R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.594 CAN\_F13R1\_FB2**

```
#define CAN_F13R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.595 CAN\_F13R1\_FB20**

```
#define CAN_F13R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.596 CAN\_F13R1\_FB21**

```
#define CAN_F13R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.597 CAN\_F13R1\_FB22**

```
#define CAN_F13R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.598 CAN\_F13R1\_FB23**

```
#define CAN_F13R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.599 CAN\_F13R1\_FB24**

```
#define CAN_F13R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.600 CAN\_F13R1\_FB25**

```
#define CAN_F13R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.601 CAN\_F13R1\_FB26**

```
#define CAN_F13R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.602 CAN\_F13R1\_FB27**

```
#define CAN_F13R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.603 CAN\_F13R1\_FB28**

```
#define CAN_F13R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.604 CAN\_F13R1\_FB29**

```
#define CAN_F13R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.605 CAN\_F13R1\_FB3**

```
#define CAN_F13R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.606 CAN\_F13R1\_FB30**

```
#define CAN_F13R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.607 CAN\_F13R1\_FB31**

```
#define CAN_F13R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.608 CAN\_F13R1\_FB4**

```
#define CAN_F13R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.609 CAN\_F13R1\_FB5**

```
#define CAN_F13R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.610 CAN\_F13R1\_FB6**

```
#define CAN_F13R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.611 CAN\_F13R1\_FB7**

```
#define CAN_F13R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.612 CAN\_F13R1\_FB8**

```
#define CAN_F13R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.613 CAN\_F13R1\_FB9**

```
#define CAN_F13R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.614 CAN\_F13R2\_FB0**

```
#define CAN_F13R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.615 CAN\_F13R2\_FB1**

```
#define CAN_F13R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.616 CAN\_F13R2\_FB10**

```
#define CAN_F13R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.617 CAN\_F13R2\_FB11**

```
#define CAN_F13R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.618 CAN\_F13R2\_FB12**

```
#define CAN_F13R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.619 CAN\_F13R2\_FB13**

```
#define CAN_F13R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.620 CAN\_F13R2\_FB14**

```
#define CAN_F13R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.621 CAN\_F13R2\_FB15**

```
#define CAN_F13R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.622 CAN\_F13R2\_FB16**

```
#define CAN_F13R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.623 CAN\_F13R2\_FB17**

```
#define CAN_F13R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.624 CAN\_F13R2\_FB18**

```
#define CAN_F13R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.625 CAN\_F13R2\_FB19**

```
#define CAN_F13R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.626 CAN\_F13R2\_FB2**

```
#define CAN_F13R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.627 CAN\_F13R2\_FB20**

```
#define CAN_F13R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.628 CAN\_F13R2\_FB21**

```
#define CAN_F13R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.629 CAN\_F13R2\_FB22**

```
#define CAN_F13R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.630 CAN\_F13R2\_FB23**

```
#define CAN_F13R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.631 CAN\_F13R2\_FB24**

```
#define CAN_F13R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.632 CAN\_F13R2\_FB25**

```
#define CAN_F13R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.633 CAN\_F13R2\_FB26**

```
#define CAN_F13R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.634 CAN\_F13R2\_FB27**

```
#define CAN_F13R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.635 CAN\_F13R2\_FB28**

```
#define CAN_F13R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.636 CAN\_F13R2\_FB29**

```
#define CAN_F13R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.637 CAN\_F13R2\_FB3**

```
#define CAN_F13R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.638 CAN\_F13R2\_FB30**

```
#define CAN_F13R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.639 CAN\_F13R2\_FB31**

```
#define CAN_F13R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.640 CAN\_F13R2\_FB4**

```
#define CAN_F13R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.641 CAN\_F13R2\_FB5**

```
#define CAN_F13R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.642 CAN\_F13R2\_FB6**

```
#define CAN_F13R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.643 CAN\_F13R2\_FB7**

```
#define CAN_F13R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.644 CAN\_F13R2\_FB8**

```
#define CAN_F13R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.645 CAN\_F13R2\_FB9**

```
#define CAN_F13R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.646 CAN\_F1R1\_FB0**

```
#define CAN_F1R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.647 CAN\_F1R1\_FB1**

```
#define CAN_F1R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.648 CAN\_F1R1\_FB10**

```
#define CAN_F1R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.649 CAN\_F1R1\_FB11**

```
#define CAN_F1R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.650 CAN\_F1R1\_FB12**

```
#define CAN_F1R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.651 CAN\_F1R1\_FB13**

```
#define CAN_F1R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.652 CAN\_F1R1\_FB14**

```
#define CAN_F1R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.653 CAN\_F1R1\_FB15**

```
#define CAN_F1R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.654 CAN\_F1R1\_FB16**

```
#define CAN_F1R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.655 CAN\_F1R1\_FB17**

```
#define CAN_F1R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.656 CAN\_F1R1\_FB18**

```
#define CAN_F1R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.657 CAN\_F1R1\_FB19**

```
#define CAN_F1R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.658 CAN\_F1R1\_FB2**

```
#define CAN_F1R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.659 CAN\_F1R1\_FB20**

```
#define CAN_F1R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.660 CAN\_F1R1\_FB21**

```
#define CAN_F1R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.661 CAN\_F1R1\_FB22**

```
#define CAN_F1R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.662 CAN\_F1R1\_FB23**

```
#define CAN_F1R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.663 CAN\_F1R1\_FB24**

```
#define CAN_F1R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.664 CAN\_F1R1\_FB25**

```
#define CAN_F1R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.665 CAN\_F1R1\_FB26**

```
#define CAN_F1R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.666 CAN\_F1R1\_FB27**

```
#define CAN_F1R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.667 CAN\_F1R1\_FB28**

```
#define CAN_F1R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.668 CAN\_F1R1\_FB29**

```
#define CAN_F1R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.669 CAN\_F1R1\_FB3**

```
#define CAN_F1R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.670 CAN\_F1R1\_FB30**

```
#define CAN_F1R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.671 CAN\_F1R1\_FB31**

```
#define CAN_F1R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.672 CAN\_F1R1\_FB4**

```
#define CAN_F1R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.673 CAN\_F1R1\_FB5**

```
#define CAN_F1R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.674 CAN\_F1R1\_FB6**

```
#define CAN_F1R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.675 CAN\_F1R1\_FB7**

```
#define CAN_F1R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.676 CAN\_F1R1\_FB8**

```
#define CAN_F1R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.677 CAN\_F1R1\_FB9**

```
#define CAN_F1R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.678 CAN\_F1R2\_FB0**

```
#define CAN_F1R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.679 CAN\_F1R2\_FB1**

```
#define CAN_F1R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.680 CAN\_F1R2\_FB10**

```
#define CAN_F1R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.681 CAN\_F1R2\_FB11**

```
#define CAN_F1R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.682 CAN\_F1R2\_FB12**

```
#define CAN_F1R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.683 CAN\_F1R2\_FB13**

```
#define CAN_F1R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.684 CAN\_F1R2\_FB14**

```
#define CAN_F1R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.685 CAN\_F1R2\_FB15**

```
#define CAN_F1R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.686 CAN\_F1R2\_FB16**

```
#define CAN_F1R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.687 CAN\_F1R2\_FB17**

```
#define CAN_F1R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.688 CAN\_F1R2\_FB18**

```
#define CAN_F1R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.689 CAN\_F1R2\_FB19**

```
#define CAN_F1R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.690 CAN\_F1R2\_FB2**

```
#define CAN_F1R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.691 CAN\_F1R2\_FB20**

```
#define CAN_F1R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.692 CAN\_F1R2\_FB21**

```
#define CAN_F1R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.693 CAN\_F1R2\_FB22**

```
#define CAN_F1R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.694 CAN\_F1R2\_FB23**

```
#define CAN_F1R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.695 CAN\_F1R2\_FB24**

```
#define CAN_F1R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.696 CAN\_F1R2\_FB25**

```
#define CAN_F1R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.697 CAN\_F1R2\_FB26**

```
#define CAN_F1R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.698 CAN\_F1R2\_FB27**

```
#define CAN_F1R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.699 CAN\_F1R2\_FB28**

```
#define CAN_F1R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.700 CAN\_F1R2\_FB29**

```
#define CAN_F1R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.701 CAN\_F1R2\_FB3**

```
#define CAN_F1R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.702 CAN\_F1R2\_FB30**

```
#define CAN_F1R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.703 CAN\_F1R2\_FB31**

```
#define CAN_F1R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.704 CAN\_F1R2\_FB4**

```
#define CAN_F1R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.705 CAN\_F1R2\_FB5**

```
#define CAN_F1R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.706 CAN\_F1R2\_FB6**

```
#define CAN_F1R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.707 CAN\_F1R2\_FB7**

```
#define CAN_F1R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.708 CAN\_F1R2\_FB8**

```
#define CAN_F1R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.709 CAN\_F1R2\_FB9**

```
#define CAN_F1R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.710 CAN\_F2R1\_FB0**

```
#define CAN_F2R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.711 CAN\_F2R1\_FB1**

```
#define CAN_F2R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.712 CAN\_F2R1\_FB10**

```
#define CAN_F2R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.713 CAN\_F2R1\_FB11**

```
#define CAN_F2R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.714 CAN\_F2R1\_FB12**

```
#define CAN_F2R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.715 CAN\_F2R1\_FB13**

```
#define CAN_F2R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.716 CAN\_F2R1\_FB14**

```
#define CAN_F2R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.717 CAN\_F2R1\_FB15**

```
#define CAN_F2R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.718 CAN\_F2R1\_FB16**

```
#define CAN_F2R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.719 CAN\_F2R1\_FB17**

```
#define CAN_F2R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.720 CAN\_F2R1\_FB18**

```
#define CAN_F2R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.721 CAN\_F2R1\_FB19**

```
#define CAN_F2R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.722 CAN\_F2R1\_FB2**

```
#define CAN_F2R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.723 CAN\_F2R1\_FB20**

```
#define CAN_F2R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.724 CAN\_F2R1\_FB21**

```
#define CAN_F2R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.725 CAN\_F2R1\_FB22**

```
#define CAN_F2R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.726 CAN\_F2R1\_FB23**

```
#define CAN_F2R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.727 CAN\_F2R1\_FB24**

```
#define CAN_F2R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.728 CAN\_F2R1\_FB25**

```
#define CAN_F2R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.729 CAN\_F2R1\_FB26**

```
#define CAN_F2R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.730 CAN\_F2R1\_FB27**

```
#define CAN_F2R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.731 CAN\_F2R1\_FB28**

```
#define CAN_F2R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.732 CAN\_F2R1\_FB29**

```
#define CAN_F2R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.733 CAN\_F2R1\_FB3**

```
#define CAN_F2R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.734 CAN\_F2R1\_FB30**

```
#define CAN_F2R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.735 CAN\_F2R1\_FB31**

```
#define CAN_F2R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.736 CAN\_F2R1\_FB4**

```
#define CAN_F2R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.737 CAN\_F2R1\_FB5**

```
#define CAN_F2R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.738 CAN\_F2R1\_FB6**

```
#define CAN_F2R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.739 CAN\_F2R1\_FB7**

```
#define CAN_F2R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.740 CAN\_F2R1\_FB8**

```
#define CAN_F2R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.741 CAN\_F2R1\_FB9**

```
#define CAN_F2R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.742 CAN\_F2R2\_FB0**

```
#define CAN_F2R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.743 CAN\_F2R2\_FB1**

```
#define CAN_F2R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.744 CAN\_F2R2\_FB10**

```
#define CAN_F2R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.745 CAN\_F2R2\_FB11**

```
#define CAN_F2R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.746 CAN\_F2R2\_FB12**

```
#define CAN_F2R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.747 CAN\_F2R2\_FB13**

```
#define CAN_F2R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.748 CAN\_F2R2\_FB14**

```
#define CAN_F2R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.749 CAN\_F2R2\_FB15**

```
#define CAN_F2R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.750 CAN\_F2R2\_FB16**

```
#define CAN_F2R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.751 CAN\_F2R2\_FB17**

```
#define CAN_F2R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.752 CAN\_F2R2\_FB18**

```
#define CAN_F2R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.753 CAN\_F2R2\_FB19**

```
#define CAN_F2R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.754 CAN\_F2R2\_FB2**

```
#define CAN_F2R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.755 CAN\_F2R2\_FB20**

```
#define CAN_F2R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.756 CAN\_F2R2\_FB21**

```
#define CAN_F2R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.757 CAN\_F2R2\_FB22**

```
#define CAN_F2R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.758 CAN\_F2R2\_FB23**

```
#define CAN_F2R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.759 CAN\_F2R2\_FB24**

```
#define CAN_F2R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.760 CAN\_F2R2\_FB25**

```
#define CAN_F2R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.761 CAN\_F2R2\_FB26**

```
#define CAN_F2R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.762 CAN\_F2R2\_FB27**

```
#define CAN_F2R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.763 CAN\_F2R2\_FB28**

```
#define CAN_F2R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.764 CAN\_F2R2\_FB29**

```
#define CAN_F2R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.765 CAN\_F2R2\_FB3**

```
#define CAN_F2R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.766 CAN\_F2R2\_FB30**

```
#define CAN_F2R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.767 CAN\_F2R2\_FB31**

```
#define CAN_F2R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.768 CAN\_F2R2\_FB4**

```
#define CAN_F2R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.769 CAN\_F2R2\_FB5**

```
#define CAN_F2R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.770 CAN\_F2R2\_FB6**

```
#define CAN_F2R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.771 CAN\_F2R2\_FB7**

```
#define CAN_F2R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.772 CAN\_F2R2\_FB8**

```
#define CAN_F2R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.773 CAN\_F2R2\_FB9**

```
#define CAN_F2R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.774 CAN\_F3R1\_FB0**

```
#define CAN_F3R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.775 CAN\_F3R1\_FB1**

```
#define CAN_F3R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.776 CAN\_F3R1\_FB10**

```
#define CAN_F3R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.777 CAN\_F3R1\_FB11**

```
#define CAN_F3R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.778 CAN\_F3R1\_FB12**

```
#define CAN_F3R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.779 CAN\_F3R1\_FB13**

```
#define CAN_F3R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.780 CAN\_F3R1\_FB14**

```
#define CAN_F3R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.781 CAN\_F3R1\_FB15**

```
#define CAN_F3R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.782 CAN\_F3R1\_FB16**

```
#define CAN_F3R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.783 CAN\_F3R1\_FB17**

```
#define CAN_F3R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.784 CAN\_F3R1\_FB18**

```
#define CAN_F3R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.785 CAN\_F3R1\_FB19**

```
#define CAN_F3R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.786 CAN\_F3R1\_FB2**

```
#define CAN_F3R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.787 CAN\_F3R1\_FB20**

```
#define CAN_F3R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.788 CAN\_F3R1\_FB21**

```
#define CAN_F3R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.789 CAN\_F3R1\_FB22**

```
#define CAN_F3R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.790 CAN\_F3R1\_FB23**

```
#define CAN_F3R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.791 CAN\_F3R1\_FB24**

```
#define CAN_F3R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.792 CAN\_F3R1\_FB25**

```
#define CAN_F3R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.793 CAN\_F3R1\_FB26**

```
#define CAN_F3R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.794 CAN\_F3R1\_FB27**

```
#define CAN_F3R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.795 CAN\_F3R1\_FB28**

```
#define CAN_F3R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.796 CAN\_F3R1\_FB29**

```
#define CAN_F3R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.797 CAN\_F3R1\_FB3**

```
#define CAN_F3R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.798 CAN\_F3R1\_FB30**

```
#define CAN_F3R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.799 CAN\_F3R1\_FB31**

```
#define CAN_F3R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.800 CAN\_F3R1\_FB4**

```
#define CAN_F3R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.801 CAN\_F3R1\_FB5**

```
#define CAN_F3R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.802 CAN\_F3R1\_FB6**

```
#define CAN_F3R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.803 CAN\_F3R1\_FB7**

```
#define CAN_F3R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.804 CAN\_F3R1\_FB8**

```
#define CAN_F3R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.805 CAN\_F3R1\_FB9**

```
#define CAN_F3R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.806 CAN\_F3R2\_FB0**

```
#define CAN_F3R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.807 CAN\_F3R2\_FB1**

```
#define CAN_F3R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.808 CAN\_F3R2\_FB10**

```
#define CAN_F3R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.809 CAN\_F3R2\_FB11**

```
#define CAN_F3R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.810 CAN\_F3R2\_FB12**

```
#define CAN_F3R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.811 CAN\_F3R2\_FB13**

```
#define CAN_F3R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.812 CAN\_F3R2\_FB14**

```
#define CAN_F3R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

### 5.173.2.813 CAN\_F3R2\_FB15

```
#define CAN_F3R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

### 5.173.2.814 CAN\_F3R2\_FB16

```
#define CAN_F3R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

### 5.173.2.815 CAN\_F3R2\_FB17

```
#define CAN_F3R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

### 5.173.2.816 CAN\_F3R2\_FB18

```
#define CAN_F3R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

### 5.173.2.817 CAN\_F3R2\_FB19

```
#define CAN_F3R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

### 5.173.2.818 CAN\_F3R2\_FB2

```
#define CAN_F3R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

### 5.173.2.819 CAN\_F3R2\_FB20

```
#define CAN_F3R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

### 5.173.2.820 CAN\_F3R2\_FB21

```
#define CAN_F3R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.821 CAN\_F3R2\_FB22**

```
#define CAN_F3R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.822 CAN\_F3R2\_FB23**

```
#define CAN_F3R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.823 CAN\_F3R2\_FB24**

```
#define CAN_F3R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.824 CAN\_F3R2\_FB25**

```
#define CAN_F3R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.825 CAN\_F3R2\_FB26**

```
#define CAN_F3R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.826 CAN\_F3R2\_FB27**

```
#define CAN_F3R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.827 CAN\_F3R2\_FB28**

```
#define CAN_F3R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.828 CAN\_F3R2\_FB29**

```
#define CAN_F3R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.829 CAN\_F3R2\_FB3**

```
#define CAN_F3R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.830 CAN\_F3R2\_FB30**

```
#define CAN_F3R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.831 CAN\_F3R2\_FB31**

```
#define CAN_F3R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.832 CAN\_F3R2\_FB4**

```
#define CAN_F3R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.833 CAN\_F3R2\_FB5**

```
#define CAN_F3R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.834 CAN\_F3R2\_FB6**

```
#define CAN_F3R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.835 CAN\_F3R2\_FB7**

```
#define CAN_F3R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.836 CAN\_F3R2\_FB8**

```
#define CAN_F3R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.837 CAN\_F3R2\_FB9**

```
#define CAN_F3R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.838 CAN\_F4R1\_FB0**

```
#define CAN_F4R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.839 CAN\_F4R1\_FB1**

```
#define CAN_F4R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.840 CAN\_F4R1\_FB10**

```
#define CAN_F4R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.841 CAN\_F4R1\_FB11**

```
#define CAN_F4R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.842 CAN\_F4R1\_FB12**

```
#define CAN_F4R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.843 CAN\_F4R1\_FB13**

```
#define CAN_F4R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.844 CAN\_F4R1\_FB14**

```
#define CAN_F4R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.845 CAN\_F4R1\_FB15**

```
#define CAN_F4R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.846 CAN\_F4R1\_FB16**

```
#define CAN_F4R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.847 CAN\_F4R1\_FB17**

```
#define CAN_F4R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.848 CAN\_F4R1\_FB18**

```
#define CAN_F4R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.849 CAN\_F4R1\_FB19**

```
#define CAN_F4R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.850 CAN\_F4R1\_FB2**

```
#define CAN_F4R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.851 CAN\_F4R1\_FB20**

```
#define CAN_F4R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.852 CAN\_F4R1\_FB21**

```
#define CAN_F4R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.853 CAN\_F4R1\_FB22**

```
#define CAN_F4R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.854 CAN\_F4R1\_FB23**

```
#define CAN_F4R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.855 CAN\_F4R1\_FB24**

```
#define CAN_F4R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.856 CAN\_F4R1\_FB25**

```
#define CAN_F4R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.857 CAN\_F4R1\_FB26**

```
#define CAN_F4R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.858 CAN\_F4R1\_FB27**

```
#define CAN_F4R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.859 CAN\_F4R1\_FB28**

```
#define CAN_F4R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.860 CAN\_F4R1\_FB29**

```
#define CAN_F4R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.861 CAN\_F4R1\_FB3**

```
#define CAN_F4R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.862 CAN\_F4R1\_FB30**

```
#define CAN_F4R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.863 CAN\_F4R1\_FB31**

```
#define CAN_F4R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.864 CAN\_F4R1\_FB4**

```
#define CAN_F4R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.865 CAN\_F4R1\_FB5**

```
#define CAN_F4R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.866 CAN\_F4R1\_FB6**

```
#define CAN_F4R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.867 CAN\_F4R1\_FB7**

```
#define CAN_F4R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.868 CAN\_F4R1\_FB8**

```
#define CAN_F4R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.869 CAN\_F4R1\_FB9**

```
#define CAN_F4R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.870 CAN\_F4R2\_FB0**

```
#define CAN_F4R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.871 CAN\_F4R2\_FB1**

```
#define CAN_F4R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.872 CAN\_F4R2\_FB10**

```
#define CAN_F4R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.873 CAN\_F4R2\_FB11**

```
#define CAN_F4R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.874 CAN\_F4R2\_FB12**

```
#define CAN_F4R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.875 CAN\_F4R2\_FB13**

```
#define CAN_F4R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.876 CAN\_F4R2\_FB14**

```
#define CAN_F4R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.877 CAN\_F4R2\_FB15**

```
#define CAN_F4R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.878 CAN\_F4R2\_FB16**

```
#define CAN_F4R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.879 CAN\_F4R2\_FB17**

```
#define CAN_F4R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.880 CAN\_F4R2\_FB18**

```
#define CAN_F4R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.881 CAN\_F4R2\_FB19**

```
#define CAN_F4R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.882 CAN\_F4R2\_FB2**

```
#define CAN_F4R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.883 CAN\_F4R2\_FB20**

```
#define CAN_F4R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.884 CAN\_F4R2\_FB21**

```
#define CAN_F4R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.885 CAN\_F4R2\_FB22**

```
#define CAN_F4R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.886 CAN\_F4R2\_FB23**

```
#define CAN_F4R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.887 CAN\_F4R2\_FB24**

```
#define CAN_F4R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.888 CAN\_F4R2\_FB25**

```
#define CAN_F4R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.889 CAN\_F4R2\_FB26**

```
#define CAN_F4R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.890 CAN\_F4R2\_FB27**

```
#define CAN_F4R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.891 CAN\_F4R2\_FB28**

```
#define CAN_F4R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.892 CAN\_F4R2\_FB29**

```
#define CAN_F4R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.893 CAN\_F4R2\_FB3**

```
#define CAN_F4R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.894 CAN\_F4R2\_FB30**

```
#define CAN_F4R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.895 CAN\_F4R2\_FB31**

```
#define CAN_F4R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.896 CAN\_F4R2\_FB4**

```
#define CAN_F4R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.897 CAN\_F4R2\_FB5**

```
#define CAN_F4R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.898 CAN\_F4R2\_FB6**

```
#define CAN_F4R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.899 CAN\_F4R2\_FB7**

```
#define CAN_F4R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.900 CAN\_F4R2\_FB8**

```
#define CAN_F4R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.901 CAN\_F4R2\_FB9**

```
#define CAN_F4R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.902 CAN\_F5R1\_FB0**

```
#define CAN_F5R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.903 CAN\_F5R1\_FB1**

```
#define CAN_F5R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.904 CAN\_F5R1\_FB10**

```
#define CAN_F5R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.905 CAN\_F5R1\_FB11**

```
#define CAN_F5R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.906 CAN\_F5R1\_FB12**

```
#define CAN_F5R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.907 CAN\_F5R1\_FB13**

```
#define CAN_F5R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.908 CAN\_F5R1\_FB14**

```
#define CAN_F5R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.909 CAN\_F5R1\_FB15**

```
#define CAN_F5R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.910 CAN\_F5R1\_FB16**

```
#define CAN_F5R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.911 CAN\_F5R1\_FB17**

```
#define CAN_F5R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.912 CAN\_F5R1\_FB18**

```
#define CAN_F5R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.913 CAN\_F5R1\_FB19**

```
#define CAN_F5R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.914 CAN\_F5R1\_FB2**

```
#define CAN_F5R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.915 CAN\_F5R1\_FB20**

```
#define CAN_F5R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.916 CAN\_F5R1\_FB21**

```
#define CAN_F5R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.917 CAN\_F5R1\_FB22**

```
#define CAN_F5R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.918 CAN\_F5R1\_FB23**

```
#define CAN_F5R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.919 CAN\_F5R1\_FB24**

```
#define CAN_F5R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.920 CAN\_F5R1\_FB25**

```
#define CAN_F5R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.921 CAN\_F5R1\_FB26**

```
#define CAN_F5R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.922 CAN\_F5R1\_FB27**

```
#define CAN_F5R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.923 CAN\_F5R1\_FB28**

```
#define CAN_F5R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.924 CAN\_F5R1\_FB29**

```
#define CAN_F5R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.925 CAN\_F5R1\_FB3**

```
#define CAN_F5R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.926 CAN\_F5R1\_FB30**

```
#define CAN_F5R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.927 CAN\_F5R1\_FB31**

```
#define CAN_F5R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.928 CAN\_F5R1\_FB4**

```
#define CAN_F5R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.929 CAN\_F5R1\_FB5**

```
#define CAN_F5R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.930 CAN\_F5R1\_FB6**

```
#define CAN_F5R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.931 CAN\_F5R1\_FB7**

```
#define CAN_F5R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.932 CAN\_F5R1\_FB8**

```
#define CAN_F5R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.933 CAN\_F5R1\_FB9**

```
#define CAN_F5R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.934 CAN\_F5R2\_FB0**

```
#define CAN_F5R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.935 CAN\_F5R2\_FB1**

```
#define CAN_F5R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.936 CAN\_F5R2\_FB10**

```
#define CAN_F5R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.937 CAN\_F5R2\_FB11**

```
#define CAN_F5R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.938 CAN\_F5R2\_FB12**

```
#define CAN_F5R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.939 CAN\_F5R2\_FB13**

```
#define CAN_F5R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.940 CAN\_F5R2\_FB14**

```
#define CAN_F5R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.941 CAN\_F5R2\_FB15**

```
#define CAN_F5R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.942 CAN\_F5R2\_FB16**

```
#define CAN_F5R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.943 CAN\_F5R2\_FB17**

```
#define CAN_F5R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.944 CAN\_F5R2\_FB18**

```
#define CAN_F5R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.945 CAN\_F5R2\_FB19**

```
#define CAN_F5R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.946 CAN\_F5R2\_FB2**

```
#define CAN_F5R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.947 CAN\_F5R2\_FB20**

```
#define CAN_F5R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.948 CAN\_F5R2\_FB21**

```
#define CAN_F5R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.949 CAN\_F5R2\_FB22**

```
#define CAN_F5R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.950 CAN\_F5R2\_FB23**

```
#define CAN_F5R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.951 CAN\_F5R2\_FB24**

```
#define CAN_F5R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.952 CAN\_F5R2\_FB25**

```
#define CAN_F5R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.953 CAN\_F5R2\_FB26**

```
#define CAN_F5R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.954 CAN\_F5R2\_FB27**

```
#define CAN_F5R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.955 CAN\_F5R2\_FB28**

```
#define CAN_F5R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.956 CAN\_F5R2\_FB29**

```
#define CAN_F5R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.957 CAN\_F5R2\_FB3**

```
#define CAN_F5R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.958 CAN\_F5R2\_FB30**

```
#define CAN_F5R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.959 CAN\_F5R2\_FB31**

```
#define CAN_F5R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.960 CAN\_F5R2\_FB4**

```
#define CAN_F5R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.961 CAN\_F5R2\_FB5**

```
#define CAN_F5R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.962 CAN\_F5R2\_FB6**

```
#define CAN_F5R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.963 CAN\_F5R2\_FB7**

```
#define CAN_F5R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.964 CAN\_F5R2\_FB8**

```
#define CAN_F5R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.965 CAN\_F5R2\_FB9**

```
#define CAN_F5R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.966 CAN\_F6R1\_FB0**

```
#define CAN_F6R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.967 CAN\_F6R1\_FB1**

```
#define CAN_F6R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.968 CAN\_F6R1\_FB10**

```
#define CAN_F6R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.969 CAN\_F6R1\_FB11**

```
#define CAN_F6R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.970 CAN\_F6R1\_FB12**

```
#define CAN_F6R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.971 CAN\_F6R1\_FB13**

```
#define CAN_F6R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.972 CAN\_F6R1\_FB14**

```
#define CAN_F6R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.973 CAN\_F6R1\_FB15**

```
#define CAN_F6R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.974 CAN\_F6R1\_FB16**

```
#define CAN_F6R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.975 CAN\_F6R1\_FB17**

```
#define CAN_F6R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.976 CAN\_F6R1\_FB18**

```
#define CAN_F6R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.977 CAN\_F6R1\_FB19**

```
#define CAN_F6R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.978 CAN\_F6R1\_FB2**

```
#define CAN_F6R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.979 CAN\_F6R1\_FB20**

```
#define CAN_F6R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.980 CAN\_F6R1\_FB21**

```
#define CAN_F6R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.981 CAN\_F6R1\_FB22**

```
#define CAN_F6R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.982 CAN\_F6R1\_FB23**

```
#define CAN_F6R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.983 CAN\_F6R1\_FB24**

```
#define CAN_F6R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.984 CAN\_F6R1\_FB25**

```
#define CAN_F6R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.985 CAN\_F6R1\_FB26**

```
#define CAN_F6R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.986 CAN\_F6R1\_FB27**

```
#define CAN_F6R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.987 CAN\_F6R1\_FB28**

```
#define CAN_F6R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.988 CAN\_F6R1\_FB29**

```
#define CAN_F6R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.989 CAN\_F6R1\_FB3**

```
#define CAN_F6R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.990 CAN\_F6R1\_FB30**

```
#define CAN_F6R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.991 CAN\_F6R1\_FB31**

```
#define CAN_F6R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.992 CAN\_F6R1\_FB4**

```
#define CAN_F6R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.993 CAN\_F6R1\_FB5**

```
#define CAN_F6R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.994 CAN\_F6R1\_FB6**

```
#define CAN_F6R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.995 CAN\_F6R1\_FB7**

```
#define CAN_F6R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.996 CAN\_F6R1\_FB8**

```
#define CAN_F6R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.997 CAN\_F6R1\_FB9**

```
#define CAN_F6R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.998 CAN\_F6R2\_FB0**

```
#define CAN_F6R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.999 CAN\_F6R2\_FB1**

```
#define CAN_F6R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.1000 CAN\_F6R2\_FB10**

```
#define CAN_F6R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.1001 CAN\_F6R2\_FB11**

```
#define CAN_F6R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.1002 CAN\_F6R2\_FB12**

```
#define CAN_F6R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.1003 CAN\_F6R2\_FB13**

```
#define CAN_F6R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.1004 CAN\_F6R2\_FB14**

```
#define CAN_F6R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.1005 CAN\_F6R2\_FB15**

```
#define CAN_F6R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.1006 CAN\_F6R2\_FB16**

```
#define CAN_F6R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.1007 CAN\_F6R2\_FB17**

```
#define CAN_F6R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.1008 CAN\_F6R2\_FB18**

```
#define CAN_F6R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.1009 CAN\_F6R2\_FB19**

```
#define CAN_F6R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.1010 CAN\_F6R2\_FB2**

```
#define CAN_F6R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.1011 CAN\_F6R2\_FB20**

```
#define CAN_F6R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.1012 CAN\_F6R2\_FB21**

```
#define CAN_F6R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.1013 CAN\_F6R2\_FB22**

```
#define CAN_F6R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.1014 CAN\_F6R2\_FB23**

```
#define CAN_F6R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.1015 CAN\_F6R2\_FB24**

```
#define CAN_F6R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.1016 CAN\_F6R2\_FB25**

```
#define CAN_F6R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.1017 CAN\_F6R2\_FB26**

```
#define CAN_F6R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.1018 CAN\_F6R2\_FB27**

```
#define CAN_F6R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.1019 CAN\_F6R2\_FB28**

```
#define CAN_F6R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.1020 CAN\_F6R2\_FB29**

```
#define CAN_F6R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.1021 CAN\_F6R2\_FB3**

```
#define CAN_F6R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.1022 CAN\_F6R2\_FB30**

```
#define CAN_F6R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.1023 CAN\_F6R2\_FB31**

```
#define CAN_F6R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.1024 CAN\_F6R2\_FB4**

```
#define CAN_F6R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.1025 CAN\_F6R2\_FB5**

```
#define CAN_F6R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.1026 CAN\_F6R2\_FB6**

```
#define CAN_F6R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.1027 CAN\_F6R2\_FB7**

```
#define CAN_F6R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.1028 CAN\_F6R2\_FB8**

```
#define CAN_F6R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.1029 CAN\_F6R2\_FB9**

```
#define CAN_F6R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.1030 CAN\_F7R1\_FB0**

```
#define CAN_F7R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.1031 CAN\_F7R1\_FB1**

```
#define CAN_F7R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.1032 CAN\_F7R1\_FB10**

```
#define CAN_F7R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.1033 CAN\_F7R1\_FB11**

```
#define CAN_F7R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.1034 CAN\_F7R1\_FB12**

```
#define CAN_F7R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.1035 CAN\_F7R1\_FB13**

```
#define CAN_F7R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.1036 CAN\_F7R1\_FB14**

```
#define CAN_F7R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.1037 CAN\_F7R1\_FB15**

```
#define CAN_F7R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.1038 CAN\_F7R1\_FB16**

```
#define CAN_F7R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.1039 CAN\_F7R1\_FB17**

```
#define CAN_F7R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.1040 CAN\_F7R1\_FB18**

```
#define CAN_F7R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.1041 CAN\_F7R1\_FB19**

```
#define CAN_F7R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.1042 CAN\_F7R1\_FB2**

```
#define CAN_F7R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.1043 CAN\_F7R1\_FB20**

```
#define CAN_F7R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.1044 CAN\_F7R1\_FB21**

```
#define CAN_F7R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.1045 CAN\_F7R1\_FB22**

```
#define CAN_F7R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.1046 CAN\_F7R1\_FB23**

```
#define CAN_F7R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.1047 CAN\_F7R1\_FB24**

```
#define CAN_F7R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.1048 CAN\_F7R1\_FB25**

```
#define CAN_F7R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.1049 CAN\_F7R1\_FB26**

```
#define CAN_F7R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.1050 CAN\_F7R1\_FB27**

```
#define CAN_F7R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.1051 CAN\_F7R1\_FB28**

```
#define CAN_F7R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.1052 CAN\_F7R1\_FB29**

```
#define CAN_F7R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.1053 CAN\_F7R1\_FB3**

```
#define CAN_F7R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.1054 CAN\_F7R1\_FB30**

```
#define CAN_F7R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.1055 CAN\_F7R1\_FB31**

```
#define CAN_F7R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.1056 CAN\_F7R1\_FB4**

```
#define CAN_F7R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.1057 CAN\_F7R1\_FB5**

```
#define CAN_F7R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.1058 CAN\_F7R1\_FB6**

```
#define CAN_F7R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.1059 CAN\_F7R1\_FB7**

```
#define CAN_F7R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.1060 CAN\_F7R1\_FB8**

```
#define CAN_F7R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.1061 CAN\_F7R1\_FB9**

```
#define CAN_F7R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.1062 CAN\_F7R2\_FB0**

```
#define CAN_F7R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.1063 CAN\_F7R2\_FB1**

```
#define CAN_F7R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.1064 CAN\_F7R2\_FB10**

```
#define CAN_F7R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.1065 CAN\_F7R2\_FB11**

```
#define CAN_F7R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.1066 CAN\_F7R2\_FB12**

```
#define CAN_F7R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.1067 CAN\_F7R2\_FB13**

```
#define CAN_F7R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.1068 CAN\_F7R2\_FB14**

```
#define CAN_F7R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.1069 CAN\_F7R2\_FB15**

```
#define CAN_F7R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.1070 CAN\_F7R2\_FB16**

```
#define CAN_F7R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.1071 CAN\_F7R2\_FB17**

```
#define CAN_F7R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.1072 CAN\_F7R2\_FB18**

```
#define CAN_F7R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.1073 CAN\_F7R2\_FB19**

```
#define CAN_F7R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.1074 CAN\_F7R2\_FB2**

```
#define CAN_F7R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.1075 CAN\_F7R2\_FB20**

```
#define CAN_F7R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.1076 CAN\_F7R2\_FB21**

```
#define CAN_F7R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.1077 CAN\_F7R2\_FB22**

```
#define CAN_F7R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.1078 CAN\_F7R2\_FB23**

```
#define CAN_F7R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.1079 CAN\_F7R2\_FB24**

```
#define CAN_F7R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.1080 CAN\_F7R2\_FB25**

```
#define CAN_F7R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.1081 CAN\_F7R2\_FB26**

```
#define CAN_F7R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.1082 CAN\_F7R2\_FB27**

```
#define CAN_F7R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.1083 CAN\_F7R2\_FB28**

```
#define CAN_F7R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.1084 CAN\_F7R2\_FB29**

```
#define CAN_F7R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.1085 CAN\_F7R2\_FB3**

```
#define CAN_F7R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.1086 CAN\_F7R2\_FB30**

```
#define CAN_F7R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.1087 CAN\_F7R2\_FB31**

```
#define CAN_F7R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.1088 CAN\_F7R2\_FB4**

```
#define CAN_F7R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.1089 CAN\_F7R2\_FB5**

```
#define CAN_F7R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.1090 CAN\_F7R2\_FB6**

```
#define CAN_F7R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.1091 CAN\_F7R2\_FB7**

```
#define CAN_F7R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.1092 CAN\_F7R2\_FB8**

```
#define CAN_F7R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.1093 CAN\_F7R2\_FB9**

```
#define CAN_F7R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.1094 CAN\_F8R1\_FB0**

```
#define CAN_F8R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.1095 CAN\_F8R1\_FB1**

```
#define CAN_F8R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.1096 CAN\_F8R1\_FB10**

```
#define CAN_F8R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.1097 CAN\_F8R1\_FB11**

```
#define CAN_F8R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.1098 CAN\_F8R1\_FB12**

```
#define CAN_F8R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.1099 CAN\_F8R1\_FB13**

```
#define CAN_F8R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.1100 CAN\_F8R1\_FB14**

```
#define CAN_F8R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.1101 CAN\_F8R1\_FB15**

```
#define CAN_F8R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.1102 CAN\_F8R1\_FB16**

```
#define CAN_F8R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.1103 CAN\_F8R1\_FB17**

```
#define CAN_F8R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.1104 CAN\_F8R1\_FB18**

```
#define CAN_F8R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.1105 CAN\_F8R1\_FB19**

```
#define CAN_F8R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.1106 CAN\_F8R1\_FB2**

```
#define CAN_F8R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.1107 CAN\_F8R1\_FB20**

```
#define CAN_F8R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.1108 CAN\_F8R1\_FB21**

```
#define CAN_F8R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.1109 CAN\_F8R1\_FB22**

```
#define CAN_F8R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.1110 CAN\_F8R1\_FB23**

```
#define CAN_F8R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.1111 CAN\_F8R1\_FB24**

```
#define CAN_F8R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.1112 CAN\_F8R1\_FB25**

```
#define CAN_F8R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.1113 CAN\_F8R1\_FB26**

```
#define CAN_F8R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.1114 CAN\_F8R1\_FB27**

```
#define CAN_F8R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.1115 CAN\_F8R1\_FB28**

```
#define CAN_F8R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.1116 CAN\_F8R1\_FB29**

```
#define CAN_F8R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.1117 CAN\_F8R1\_FB3**

```
#define CAN_F8R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.1118 CAN\_F8R1\_FB30**

```
#define CAN_F8R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.1119 CAN\_F8R1\_FB31**

```
#define CAN_F8R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.1120 CAN\_F8R1\_FB4**

```
#define CAN_F8R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.1121 CAN\_F8R1\_FB5**

```
#define CAN_F8R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.1122 CAN\_F8R1\_FB6**

```
#define CAN_F8R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.1123 CAN\_F8R1\_FB7**

```
#define CAN_F8R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.1124 CAN\_F8R1\_FB8**

```
#define CAN_F8R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.1125 CAN\_F8R1\_FB9**

```
#define CAN_F8R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.1126 CAN\_F8R2\_FB0**

```
#define CAN_F8R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.1127 CAN\_F8R2\_FB1**

```
#define CAN_F8R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.1128 CAN\_F8R2\_FB10**

```
#define CAN_F8R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.1129 CAN\_F8R2\_FB11**

```
#define CAN_F8R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.1130 CAN\_F8R2\_FB12**

```
#define CAN_F8R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.1131 CAN\_F8R2\_FB13**

```
#define CAN_F8R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.1132 CAN\_F8R2\_FB14**

```
#define CAN_F8R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.1133 CAN\_F8R2\_FB15**

```
#define CAN_F8R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.1134 CAN\_F8R2\_FB16**

```
#define CAN_F8R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.1135 CAN\_F8R2\_FB17**

```
#define CAN_F8R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.1136 CAN\_F8R2\_FB18**

```
#define CAN_F8R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.1137 CAN\_F8R2\_FB19**

```
#define CAN_F8R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.1138 CAN\_F8R2\_FB2**

```
#define CAN_F8R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.1139 CAN\_F8R2\_FB20**

```
#define CAN_F8R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.1140 CAN\_F8R2\_FB21**

```
#define CAN_F8R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.1141 CAN\_F8R2\_FB22**

```
#define CAN_F8R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.1142 CAN\_F8R2\_FB23**

```
#define CAN_F8R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.1143 CAN\_F8R2\_FB24**

```
#define CAN_F8R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.1144 CAN\_F8R2\_FB25**

```
#define CAN_F8R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.1145 CAN\_F8R2\_FB26**

```
#define CAN_F8R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.1146 CAN\_F8R2\_FB27**

```
#define CAN_F8R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.1147 CAN\_F8R2\_FB28**

```
#define CAN_F8R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.1148 CAN\_F8R2\_FB29**

```
#define CAN_F8R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.1149 CAN\_F8R2\_FB3**

```
#define CAN_F8R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.1150 CAN\_F8R2\_FB30**

```
#define CAN_F8R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.1151 CAN\_F8R2\_FB31**

```
#define CAN_F8R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.1152 CAN\_F8R2\_FB4**

```
#define CAN_F8R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.1153 CAN\_F8R2\_FB5**

```
#define CAN_F8R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.1154 CAN\_F8R2\_FB6**

```
#define CAN_F8R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.1155 CAN\_F8R2\_FB7**

```
#define CAN_F8R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.1156 CAN\_F8R2\_FB8**

```
#define CAN_F8R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.1157 CAN\_F8R2\_FB9**

```
#define CAN_F8R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.1158 CAN\_F9R1\_FB0**

```
#define CAN_F9R1_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.1159 CAN\_F9R1\_FB1**

```
#define CAN_F9R1_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.1160 CAN\_F9R1\_FB10**

```
#define CAN_F9R1_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.1161 CAN\_F9R1\_FB11**

```
#define CAN_F9R1_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.1162 CAN\_F9R1\_FB12**

```
#define CAN_F9R1_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.1163 CAN\_F9R1\_FB13**

```
#define CAN_F9R1_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.1164 CAN\_F9R1\_FB14**

```
#define CAN_F9R1_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.1165 CAN\_F9R1\_FB15**

```
#define CAN_F9R1_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.1166 CAN\_F9R1\_FB16**

```
#define CAN_F9R1_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.1167 CAN\_F9R1\_FB17**

```
#define CAN_F9R1_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.1168 CAN\_F9R1\_FB18**

```
#define CAN_F9R1_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.1169 CAN\_F9R1\_FB19**

```
#define CAN_F9R1_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.1170 CAN\_F9R1\_FB2**

```
#define CAN_F9R1_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.1171 CAN\_F9R1\_FB20**

```
#define CAN_F9R1_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.1172 CAN\_F9R1\_FB21**

```
#define CAN_F9R1_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.1173 CAN\_F9R1\_FB22**

```
#define CAN_F9R1_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.1174 CAN\_F9R1\_FB23**

```
#define CAN_F9R1_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.1175 CAN\_F9R1\_FB24**

```
#define CAN_F9R1_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.1176 CAN\_F9R1\_FB25**

```
#define CAN_F9R1_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.1177 CAN\_F9R1\_FB26**

```
#define CAN_F9R1_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.1178 CAN\_F9R1\_FB27**

```
#define CAN_F9R1_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.1179 CAN\_F9R1\_FB28**

```
#define CAN_F9R1_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.1180 CAN\_F9R1\_FB29**

```
#define CAN_F9R1_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.1181 CAN\_F9R1\_FB3**

```
#define CAN_F9R1_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.1182 CAN\_F9R1\_FB30**

```
#define CAN_F9R1_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.1183 CAN\_F9R1\_FB31**

```
#define CAN_F9R1_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.1184 CAN\_F9R1\_FB4**

```
#define CAN_F9R1_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.1185 CAN\_F9R1\_FB5**

```
#define CAN_F9R1_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.1186 CAN\_F9R1\_FB6**

```
#define CAN_F9R1_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.1187 CAN\_F9R1\_FB7**

```
#define CAN_F9R1_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.1188 CAN\_F9R1\_FB8**

```
#define CAN_F9R1_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.1189 CAN\_F9R1\_FB9**

```
#define CAN_F9R1_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.1190 CAN\_F9R2\_FB0**

```
#define CAN_F9R2_FB0 ((uint32_t)0x00000001)
```

Filter bit 0

**5.173.2.1191 CAN\_F9R2\_FB1**

```
#define CAN_F9R2_FB1 ((uint32_t)0x00000002)
```

Filter bit 1

**5.173.2.1192 CAN\_F9R2\_FB10**

```
#define CAN_F9R2_FB10 ((uint32_t)0x00000400)
```

Filter bit 10

**5.173.2.1193 CAN\_F9R2\_FB11**

```
#define CAN_F9R2_FB11 ((uint32_t)0x00000800)
```

Filter bit 11

**5.173.2.1194 CAN\_F9R2\_FB12**

```
#define CAN_F9R2_FB12 ((uint32_t)0x00001000)
```

Filter bit 12

**5.173.2.1195 CAN\_F9R2\_FB13**

```
#define CAN_F9R2_FB13 ((uint32_t)0x00002000)
```

Filter bit 13

**5.173.2.1196 CAN\_F9R2\_FB14**

```
#define CAN_F9R2_FB14 ((uint32_t)0x00004000)
```

Filter bit 14

**5.173.2.1197 CAN\_F9R2\_FB15**

```
#define CAN_F9R2_FB15 ((uint32_t)0x00008000)
```

Filter bit 15

**5.173.2.1198 CAN\_F9R2\_FB16**

```
#define CAN_F9R2_FB16 ((uint32_t)0x00010000)
```

Filter bit 16

**5.173.2.1199 CAN\_F9R2\_FB17**

```
#define CAN_F9R2_FB17 ((uint32_t)0x00020000)
```

Filter bit 17

**5.173.2.1200 CAN\_F9R2\_FB18**

```
#define CAN_F9R2_FB18 ((uint32_t)0x00040000)
```

Filter bit 18

**5.173.2.1201 CAN\_F9R2\_FB19**

```
#define CAN_F9R2_FB19 ((uint32_t)0x00080000)
```

Filter bit 19

**5.173.2.1202 CAN\_F9R2\_FB2**

```
#define CAN_F9R2_FB2 ((uint32_t)0x00000004)
```

Filter bit 2

**5.173.2.1203 CAN\_F9R2\_FB20**

```
#define CAN_F9R2_FB20 ((uint32_t)0x00100000)
```

Filter bit 20

**5.173.2.1204 CAN\_F9R2\_FB21**

```
#define CAN_F9R2_FB21 ((uint32_t)0x00200000)
```

Filter bit 21

**5.173.2.1205 CAN\_F9R2\_FB22**

```
#define CAN_F9R2_FB22 ((uint32_t)0x00400000)
```

Filter bit 22

**5.173.2.1206 CAN\_F9R2\_FB23**

```
#define CAN_F9R2_FB23 ((uint32_t)0x00800000)
```

Filter bit 23

**5.173.2.1207 CAN\_F9R2\_FB24**

```
#define CAN_F9R2_FB24 ((uint32_t)0x01000000)
```

Filter bit 24

**5.173.2.1208 CAN\_F9R2\_FB25**

```
#define CAN_F9R2_FB25 ((uint32_t)0x02000000)
```

Filter bit 25

**5.173.2.1209 CAN\_F9R2\_FB26**

```
#define CAN_F9R2_FB26 ((uint32_t)0x04000000)
```

Filter bit 26

**5.173.2.1210 CAN\_F9R2\_FB27**

```
#define CAN_F9R2_FB27 ((uint32_t)0x08000000)
```

Filter bit 27

**5.173.2.1211 CAN\_F9R2\_FB28**

```
#define CAN_F9R2_FB28 ((uint32_t)0x10000000)
```

Filter bit 28

**5.173.2.1212 CAN\_F9R2\_FB29**

```
#define CAN_F9R2_FB29 ((uint32_t)0x20000000)
```

Filter bit 29

**5.173.2.1213 CAN\_F9R2\_FB3**

```
#define CAN_F9R2_FB3 ((uint32_t)0x00000008)
```

Filter bit 3

**5.173.2.1214 CAN\_F9R2\_FB30**

```
#define CAN_F9R2_FB30 ((uint32_t)0x40000000)
```

Filter bit 30

**5.173.2.1215 CAN\_F9R2\_FB31**

```
#define CAN_F9R2_FB31 ((uint32_t)0x80000000)
```

Filter bit 31

**5.173.2.1216 CAN\_F9R2\_FB4**

```
#define CAN_F9R2_FB4 ((uint32_t)0x00000010)
```

Filter bit 4

**5.173.2.1217 CAN\_F9R2\_FB5**

```
#define CAN_F9R2_FB5 ((uint32_t)0x00000020)
```

Filter bit 5

**5.173.2.1218 CAN\_F9R2\_FB6**

```
#define CAN_F9R2_FB6 ((uint32_t)0x00000040)
```

Filter bit 6

**5.173.2.1219 CAN\_F9R2\_FB7**

```
#define CAN_F9R2_FB7 ((uint32_t)0x00000080)
```

Filter bit 7

**5.173.2.1220 CAN\_F9R2\_FB8**

```
#define CAN_F9R2_FB8 ((uint32_t)0x00000100)
```

Filter bit 8

**5.173.2.1221 CAN\_F9R2\_FB9**

```
#define CAN_F9R2_FB9 ((uint32_t)0x00000200)
```

Filter bit 9

**5.173.2.1222 CAN\_FA1R\_FACT**

```
#define CAN_FA1R_FACT ((uint16_t)0x3FFF)
```

Filter Active

**5.173.2.1223 CAN\_FA1R\_FACT0**

```
#define CAN_FA1R_FACT0 ((uint16_t)0x0001)
```

Filter 0 Active

**5.173.2.1224 CAN\_FA1R\_FACT1**

```
#define CAN_FA1R_FACT1 ((uint16_t)0x0002)
```

Filter 1 Active

**5.173.2.1225 CAN\_FA1R\_FACT10**

```
#define CAN_FA1R_FACT10 ((uint16_t)0x0400)
```

Filter 10 Active

**5.173.2.1226 CAN\_FA1R\_FACT11**

```
#define CAN_FA1R_FACT11 ((uint16_t)0x0800)
```

Filter 11 Active

**5.173.2.1227 CAN\_FA1R\_FACT12**

```
#define CAN_FA1R_FACT12 ((uint16_t)0x1000)
```

Filter 12 Active

**5.173.2.1228 CAN\_FA1R\_FACT13**

```
#define CAN_FA1R_FACT13 ((uint16_t)0x2000)
```

Filter 13 Active

**5.173.2.1229 CAN\_FA1R\_FACT2**

```
#define CAN_FA1R_FACT2 ((uint16_t)0x0004)
```

Filter 2 Active

**5.173.2.1230 CAN\_FA1R\_FACT3**

```
#define CAN_FA1R_FACT3 ((uint16_t)0x0008)
```

Filter 3 Active

**5.173.2.1231 CAN\_FA1R\_FACT4**

```
#define CAN_FA1R_FACT4 ((uint16_t)0x0010)
```

Filter 4 Active

**5.173.2.1232 CAN\_FA1R\_FACT5**

```
#define CAN_FA1R_FACT5 ((uint16_t)0x0020)
```

Filter 5 Active

**5.173.2.1233 CAN\_FA1R\_FACT6**

```
#define CAN_FA1R_FACT6 ((uint16_t)0x0040)
```

Filter 6 Active

**5.173.2.1234 CAN\_FA1R\_FACT7**

```
#define CAN_FA1R_FACT7 ((uint16_t)0x0080)
```

Filter 7 Active

**5.173.2.1235 CAN\_FA1R\_FACT8**

```
#define CAN_FA1R_FACT8 ((uint16_t)0x0100)
```

Filter 8 Active

**5.173.2.1236 CAN\_FA1R\_FACT9**

```
#define CAN_FA1R_FACT9 ((uint16_t)0x0200)
```

Filter 9 Active

**5.173.2.1237 CAN\_FFA1R\_FFA**

```
#define CAN_FFA1R_FFA ((uint16_t)0x3FFF)
```

Filter FIFO Assignment

**5.173.2.1238 CAN\_FFA1R\_FFA0**

```
#define CAN_FFA1R_FFA0 ((uint16_t)0x0001)
```

Filter FIFO Assignment for Filter 0

**5.173.2.1239 CAN\_FFA1R\_FFA1**

```
#define CAN_FFA1R_FFA1 ((uint16_t)0x0002)
```

Filter FIFO Assignment for Filter 1

**5.173.2.1240 CAN\_FFA1R\_FFA10**

```
#define CAN_FFA1R_FFA10 ((uint16_t)0x0400)
```

Filter FIFO Assignment for Filter 10

**5.173.2.1241 CAN\_FFA1R\_FFA11**

```
#define CAN_FFA1R_FFA11 ((uint16_t)0x0800)
```

Filter FIFO Assignment for Filter 11

**5.173.2.1242 CAN\_FFA1R\_FFA12**

```
#define CAN_FFA1R_FFA12 ((uint16_t)0x1000)
```

Filter FIFO Assignment for Filter 12

**5.173.2.1243 CAN\_FFA1R\_FFA13**

```
#define CAN_FFA1R_FFA13 ((uint16_t)0x2000)
```

Filter FIFO Assignment for Filter 13

**5.173.2.1244 CAN\_FFA1R\_FFA2**

```
#define CAN_FFA1R_FFA2 ((uint16_t)0x0004)
```

Filter FIFO Assignment for Filter 2

**5.173.2.1245 CAN\_FFA1R\_FFA3**

```
#define CAN_FFA1R_FFA3 ((uint16_t)0x0008)
```

Filter FIFO Assignment for Filter 3

**5.173.2.1246 CAN\_FFA1R\_FFA4**

```
#define CAN_FFA1R_FFA4 ((uint16_t)0x0010)
```

Filter FIFO Assignment for Filter 4

**5.173.2.1247 CAN\_FFA1R\_FFA5**

```
#define CAN_FFA1R_FFA5 ((uint16_t)0x0020)
```

Filter FIFO Assignment for Filter 5

**5.173.2.1248 CAN\_FFA1R\_FFA6**

```
#define CAN_FFA1R_FFA6 ((uint16_t)0x0040)
```

Filter FIFO Assignment for Filter 6

**5.173.2.1249 CAN\_FFA1R\_FFA7**

```
#define CAN_FFA1R_FFA7 ((uint16_t)0x0080)
```

Filter FIFO Assignment for Filter 7

**5.173.2.1250 CAN\_FFA1R\_FFA8**

```
#define CAN_FFA1R_FFA8 ((uint16_t)0x0100)
```

Filter FIFO Assignment for Filter 8

**5.173.2.1251 CAN\_FFA1R\_FFA9**

```
#define CAN_FFA1R_FFA9 ((uint16_t)0x0200)
```

Filter FIFO Assignment for Filter 9

**5.173.2.1252 CAN\_FM1R\_FBM**

```
#define CAN_FM1R_FBM ((uint16_t)0x3FFF)
```

Filter Mode

**5.173.2.1253 CAN\_FM1R\_FBM0**

```
#define CAN_FM1R_FBM0 ((uint16_t)0x0001)
```

Filter Init Mode bit 0

**5.173.2.1254 CAN\_FM1R\_FBM1**

```
#define CAN_FM1R_FBM1 ((uint16_t)0x0002)
```

Filter Init Mode bit 1

**5.173.2.1255 CAN\_FM1R\_FBM10**

```
#define CAN_FM1R_FBM10 ((uint16_t)0x0400)
```

Filter Init Mode bit 10

**5.173.2.1256 CAN\_FM1R\_FBM11**

```
#define CAN_FM1R_FBM11 ((uint16_t)0x0800)
```

Filter Init Mode bit 11

**5.173.2.1257 CAN\_FM1R\_FBM12**

```
#define CAN_FM1R_FBM12 ((uint16_t)0x1000)
```

Filter Init Mode bit 12

**5.173.2.1258 CAN\_FM1R\_FBM13**

```
#define CAN_FM1R_FBM13 ((uint16_t)0x2000)
```

Filter Init Mode bit 13

**5.173.2.1259 CAN\_FM1R\_FBM2**

```
#define CAN_FM1R_FBM2 ((uint16_t)0x0004)
```

Filter Init Mode bit 2

**5.173.2.1260 CAN\_FM1R\_FBM3**

```
#define CAN_FM1R_FBM3 ((uint16_t)0x0008)
```

Filter Init Mode bit 3

**5.173.2.1261 CAN\_FM1R\_FBM4**

```
#define CAN_FM1R_FBM4 ((uint16_t)0x0010)
```

Filter Init Mode bit 4

**5.173.2.1262 CAN\_FM1R\_FBM5**

```
#define CAN_FM1R_FBM5 ((uint16_t)0x0020)
```

Filter Init Mode bit 5

**5.173.2.1263 CAN\_FM1R\_FBM6**

```
#define CAN_FM1R_FBM6 ((uint16_t)0x0040)
```

Filter Init Mode bit 6

**5.173.2.1264 CAN\_FM1R\_FBM7**

```
#define CAN_FM1R_FBM7 ((uint16_t)0x0080)
```

Filter Init Mode bit 7

**5.173.2.1265 CAN\_FM1R\_FBM8**

```
#define CAN_FM1R_FBM8 ((uint16_t)0x0100)
```

Filter Init Mode bit 8

**5.173.2.1266 CAN\_FM1R\_FBM9**

```
#define CAN_FM1R_FBM9 ((uint16_t)0x0200)
```

Filter Init Mode bit 9

**5.173.2.1267 CAN\_FMR\_INIT**

```
#define CAN_FMR_INIT ((uint8_t)0x01)
```

Filter Init Mode

**5.173.2.1268 CAN\_FS1R\_FSC**

```
#define CAN_FS1R_FSC ((uint16_t)0x3FFF)
```

Filter Scale Configuration

**5.173.2.1269 CAN\_FS1R\_FSC0**

```
#define CAN_FS1R_FSC0 ((uint16_t)0x0001)
```

Filter Scale Configuration bit 0

**5.173.2.1270 CAN\_FS1R\_FSC1**

```
#define CAN_FS1R_FSC1 ((uint16_t)0x0002)
```

Filter Scale Configuration bit 1

**5.173.2.1271 CAN\_FS1R\_FSC10**

```
#define CAN_FS1R_FSC10 ((uint16_t)0x0400)
```

Filter Scale Configuration bit 10

**5.173.2.1272 CAN\_FS1R\_FSC11**

```
#define CAN_FS1R_FSC11 ((uint16_t)0x0800)
```

Filter Scale Configuration bit 11

**5.173.2.1273 CAN\_FS1R\_FSC12**

```
#define CAN_FS1R_FSC12 ((uint16_t)0x1000)
```

Filter Scale Configuration bit 12

**5.173.2.1274 CAN\_FS1R\_FSC13**

```
#define CAN_FS1R_FSC13 ((uint16_t)0x2000)
```

Filter Scale Configuration bit 13

**5.173.2.1275 CAN\_FS1R\_FSC2**

```
#define CAN_FS1R_FSC2 ((uint16_t)0x0004)
```

Filter Scale Configuration bit 2

**5.173.2.1276 CAN\_FS1R\_FSC3**

```
#define CAN_FS1R_FSC3 ((uint16_t)0x0008)
```

Filter Scale Configuration bit 3

### 5.173.2.1277 CAN\_FS1R\_FSC4

```
#define CAN_FS1R_FSC4 ((uint16_t)0x0010)
```

Filter Scale Configuration bit 4

### 5.173.2.1278 CAN\_FS1R\_FSC5

```
#define CAN_FS1R_FSC5 ((uint16_t)0x0020)
```

Filter Scale Configuration bit 5

### 5.173.2.1279 CAN\_FS1R\_FSC6

```
#define CAN_FS1R_FSC6 ((uint16_t)0x0040)
```

Filter Scale Configuration bit 6

### 5.173.2.1280 CAN\_FS1R\_FSC7

```
#define CAN_FS1R_FSC7 ((uint16_t)0x0080)
```

Filter Scale Configuration bit 7

### 5.173.2.1281 CAN\_FS1R\_FSC8

```
#define CAN_FS1R_FSC8 ((uint16_t)0x0100)
```

Filter Scale Configuration bit 8

### 5.173.2.1282 CAN\_FS1R\_FSC9

```
#define CAN_FS1R_FSC9 ((uint16_t)0x0200)
```

Filter Scale Configuration bit 9

### 5.173.2.1283 CAN\_IER\_BOFIE

```
#define CAN_IER_BOFIE ((uint32_t)0x00000400)
```

Bus-Off Interrupt Enable

### 5.173.2.1284 CAN\_IER\_EPVIE

```
#define CAN_IER_EPVIE ((uint32_t)0x00000200)
```

Error Passive Interrupt Enable

**5.173.2.1285 CAN\_IER\_ERRIE**

```
#define CAN_IER_ERRIE ((uint32_t)0x00008000)
```

Error Interrupt Enable

**5.173.2.1286 CAN\_IER\_EWGIE**

```
#define CAN_IER_EWGIE ((uint32_t)0x00000100)
```

Error Warning Interrupt Enable

**5.173.2.1287 CAN\_IER\_FFIE0**

```
#define CAN_IER_FFIE0 ((uint32_t)0x00000004)
```

FIFO Full Interrupt Enable

**5.173.2.1288 CAN\_IER\_FFIE1**

```
#define CAN_IER_FFIE1 ((uint32_t)0x00000020)
```

FIFO Full Interrupt Enable

**5.173.2.1289 CAN\_IER\_FMPIE0**

```
#define CAN_IER_FMPIE0 ((uint32_t)0x00000002)
```

FIFO Message Pending Interrupt Enable

**5.173.2.1290 CAN\_IER\_FMPIE1**

```
#define CAN_IER_FMPIE1 ((uint32_t)0x00000010)
```

FIFO Message Pending Interrupt Enable

**5.173.2.1291 CAN\_IER\_FOVIE0**

```
#define CAN_IER_FOVIE0 ((uint32_t)0x00000008)
```

FIFO Overrun Interrupt Enable

**5.173.2.1292 CAN\_IER\_FOVIE1**

```
#define CAN_IER_FOVIE1 ((uint32_t)0x00000040)
```

FIFO Overrun Interrupt Enable

**5.173.2.1293 CAN\_IER\_LCIE**

```
#define CAN_IER_LCIE ((uint32_t)0x00000800)
```

Last Error Code Interrupt Enable

**5.173.2.1294 CAN\_IER\_SLKIE**

```
#define CAN_IER_SLKIE ((uint32_t)0x00020000)
```

Sleep Interrupt Enable

**5.173.2.1295 CAN\_IER\_TMEIE**

```
#define CAN_IER_TMEIE ((uint32_t)0x00000001)
```

Transmit Mailbox Empty Interrupt Enable

**5.173.2.1296 CAN\_IER\_WKUIE**

```
#define CAN_IER_WKUIE ((uint32_t)0x00010000)
```

Wakeup Interrupt Enable

**5.173.2.1297 CAN\_MCR\_ABOM**

```
#define CAN_MCR_ABOM ((uint16_t)0x0040)
```

Automatic Bus-Off Management

**5.173.2.1298 CAN\_MCR\_AWUM**

```
#define CAN_MCR_AWUM ((uint16_t)0x0020)
```

Automatic Wakeup Mode

**5.173.2.1299 CAN\_MCR\_INRQ**

```
#define CAN_MCR_INRQ ((uint16_t)0x0001)
```

<CAN control and status registers Initialization Request

**5.173.2.1300 CAN\_MCR\_NART**

```
#define CAN_MCR_NART ((uint16_t)0x0010)
```

No Automatic Retransmission

**5.173.2.1301 CAN\_MCR\_RESET**

```
#define CAN_MCR_RESET ((uint16_t)0x8000)
```

bxCAN software master reset

**5.173.2.1302 CAN\_MCR\_RFLM**

```
#define CAN_MCR_RFLM ((uint16_t)0x0008)
```

Receive FIFO Locked Mode

**5.173.2.1303 CAN\_MCR\_SLEEP**

```
#define CAN_MCR_SLEEP ((uint16_t)0x0002)
```

Sleep Mode Request

**5.173.2.1304 CAN\_MCR\_TTCM**

```
#define CAN_MCR_TTCM ((uint16_t)0x0080)
```

Time Triggered Communication Mode

**5.173.2.1305 CAN\_MCR\_TXFP**

```
#define CAN_MCR_TXFP ((uint16_t)0x0004)
```

Transmit FIFO Priority

**5.173.2.1306 CAN\_MSR\_ERRI**

```
#define CAN_MSR_ERRI ((uint16_t)0x0004)
```

Error Interrupt

**5.173.2.1307 CAN\_MSR\_INAK**

```
#define CAN_MSR_INAK ((uint16_t)0x0001)
```

Initialization Acknowledge

**5.173.2.1308 CAN\_MSR\_RX**

```
#define CAN_MSR_RX ((uint16_t)0x0800)
```

CAN Rx Signal

**5.173.2.1309 CAN\_MSR\_RXM**

```
#define CAN_MSR_RXM ((uint16_t)0x0200)
```

Receive Mode

**5.173.2.1310 CAN\_MSR\_SAMP**

```
#define CAN_MSR_SAMP ((uint16_t)0x0400)
```

Last Sample Point

**5.173.2.1311 CAN\_MSR\_SLAK**

```
#define CAN_MSR_SLAK ((uint16_t)0x0002)
```

Sleep Acknowledge

**5.173.2.1312 CAN\_MSR\_SLAKI**

```
#define CAN_MSR_SLAKI ((uint16_t)0x0010)
```

Sleep Acknowledge Interrupt

**5.173.2.1313 CAN\_MSR\_TXM**

```
#define CAN_MSR_TXM ((uint16_t)0x0100)
```

Transmit Mode

**5.173.2.1314 CAN\_MSR\_WKUI**

```
#define CAN_MSR_WKUI ((uint16_t)0x0008)
```

Wakeup Interrupt

**5.173.2.1315 CAN\_RDH0R\_DATA4**

```
#define CAN_RDH0R_DATA4 ((uint32_t)0x000000FF)
```

Data byte 4

**5.173.2.1316 CAN\_RDH0R\_DATA5**

```
#define CAN_RDH0R_DATA5 ((uint32_t)0x0000FF00)
```

Data byte 5

**5.173.2.1317 CAN\_RDH0R\_DATA6**

```
#define CAN_RDH0R_DATA6 ((uint32_t)0x00FF0000)
```

Data byte 6

**5.173.2.1318 CAN\_RDH0R\_DATA7**

```
#define CAN_RDH0R_DATA7 ((uint32_t)0xFF000000)
```

Data byte 7

**5.173.2.1319 CAN\_RDH1R\_DATA4**

```
#define CAN_RDH1R_DATA4 ((uint32_t)0x000000FF)
```

Data byte 4

**5.173.2.1320 CAN\_RDH1R\_DATA5**

```
#define CAN_RDH1R_DATA5 ((uint32_t)0x0000FF00)
```

Data byte 5

**5.173.2.1321 CAN\_RDH1R\_DATA6**

```
#define CAN_RDH1R_DATA6 ((uint32_t)0x00FF0000)
```

Data byte 6

**5.173.2.1322 CAN\_RDH1R\_DATA7**

```
#define CAN_RDH1R_DATA7 ((uint32_t)0xFF000000)
```

Data byte 7 CAN filter registers

**5.173.2.1323 CAN\_RDL0R\_DATA0**

```
#define CAN_RDL0R_DATA0 ((uint32_t)0x000000FF)
```

Data byte 0

**5.173.2.1324 CAN\_RDL0R\_DATA1**

```
#define CAN_RDL0R_DATA1 ((uint32_t)0x0000FF00)
```

Data byte 1

**5.173.2.1325 CAN\_RDL0R\_DATA2**

```
#define CAN_RDL0R_DATA2 ((uint32_t)0x00FF0000)
```

Data byte 2

**5.173.2.1326 CAN\_RDL0R\_DATA3**

```
#define CAN_RDL0R_DATA3 ((uint32_t)0xFF000000)
```

Data byte 3

**5.173.2.1327 CAN\_RDL1R\_DATA0**

```
#define CAN_RDL1R_DATA0 ((uint32_t)0x000000FF)
```

Data byte 0

**5.173.2.1328 CAN\_RDL1R\_DATA1**

```
#define CAN_RDL1R_DATA1 ((uint32_t)0x0000FF00)
```

Data byte 1

**5.173.2.1329 CAN\_RDL1R\_DATA2**

```
#define CAN_RDL1R_DATA2 ((uint32_t)0x00FF0000)
```

Data byte 2

**5.173.2.1330 CAN\_RDL1R\_DATA3**

```
#define CAN_RDL1R_DATA3 ((uint32_t)0xFF000000)
```

Data byte 3

**5.173.2.1331 CAN\_RDT0R\_DLC**

```
#define CAN_RDT0R_DLC ((uint32_t)0x0000000F)
```

Data Length Code

**5.173.2.1332 CAN\_RDT0R\_FMI**

```
#define CAN_RDT0R_FMI ((uint32_t)0x0000FF00)
```

Filter Match Index

**5.173.2.1333 CAN\_RDT0R\_TIME**

```
#define CAN_RDT0R_TIME ((uint32_t)0xFFFF0000)
```

Message Time Stamp

**5.173.2.1334 CAN\_RDT1R\_DLC**

```
#define CAN_RDT1R_DLC ((uint32_t)0x0000000F)
```

Data Length Code

**5.173.2.1335 CAN\_RDT1R\_FMI**

```
#define CAN_RDT1R_FMI ((uint32_t)0x0000FF00)
```

Filter Match Index

**5.173.2.1336 CAN\_RDT1R\_TIME**

```
#define CAN_RDT1R_TIME ((uint32_t)0xFFFF0000)
```

Message Time Stamp

**5.173.2.1337 CAN\_RF0R\_FMP0**

```
#define CAN_RF0R_FMP0 ((uint8_t)0x03)
```

FIFO 0 Message Pending

**5.173.2.1338 CAN\_RF0R\_FOVRO**

```
#define CAN_RF0R_FOVRO ((uint8_t)0x10)
```

FIFO 0 Overrun

**5.173.2.1339 CAN\_RF0R\_FULL0**

```
#define CAN_RF0R_FULL0 ((uint8_t)0x08)
```

FIFO 0 Full

**5.173.2.1340 CAN\_RF0R\_RFOM0**

```
#define CAN_RF0R_RFOM0 ((uint8_t)0x20)
```

Release FIFO 0 Output Mailbox

**5.173.2.1341 CAN\_RF1R\_FMP1**

```
#define CAN_RF1R_FMP1 ((uint8_t)0x03)
```

FIFO 1 Message Pending

**5.173.2.1342 CAN\_RF1R\_FOVR1**

```
#define CAN_RF1R_FOVR1 ((uint8_t)0x10)
```

FIFO 1 Overrun

**5.173.2.1343 CAN\_RF1R\_FULL1**

```
#define CAN_RF1R_FULL1 ((uint8_t)0x08)
```

FIFO 1 Full

**5.173.2.1344 CAN\_RF1R\_RFOM1**

```
#define CAN_RF1R_RFOM1 ((uint8_t)0x20)
```

Release FIFO 1 Output Mailbox

**5.173.2.1345 CAN\_RI0R\_EXID**

```
#define CAN_RI0R_EXID ((uint32_t)0x001FFFF8)
```

Extended Identifier

**5.173.2.1346 CAN\_RI0R\_IDE**

```
#define CAN_RI0R_IDE ((uint32_t)0x00000004)
```

Identifier Extension

**5.173.2.1347 CAN\_RI0R\_RTR**

```
#define CAN_RI0R_RTR ((uint32_t)0x00000002)
```

Remote Transmission Request

**5.173.2.1348 CAN\_RI0R\_STID**

```
#define CAN_RI0R_STID ((uint32_t)0xFFE00000)
```

Standard Identifier or Extended Identifier

**5.173.2.1349 CAN\_RI1R\_EXID**

```
#define CAN_RI1R_EXID ((uint32_t)0x001FFFF8)
```

Extended identifier

**5.173.2.1350 CAN\_RI1R\_IDE**

```
#define CAN_RI1R_IDE ((uint32_t)0x00000004)
```

Identifier Extension

**5.173.2.1351 CAN\_RI1R\_RTR**

```
#define CAN_RI1R_RTR ((uint32_t)0x00000002)
```

Remote Transmission Request

**5.173.2.1352 CAN\_RI1R\_STID**

```
#define CAN_RI1R_STID ((uint32_t)0xFFE00000)
```

Standard Identifier or Extended Identifier

**5.173.2.1353 CAN\_TDH0R\_DATA4**

```
#define CAN_TDH0R_DATA4 ((uint32_t)0x000000FF)
```

Data byte 4

**5.173.2.1354 CAN\_TDH0R\_DATA5**

```
#define CAN_TDH0R_DATA5 ((uint32_t)0x0000FF00)
```

Data byte 5

**5.173.2.1355 CAN\_TDH0R\_DATA6**

```
#define CAN_TDH0R_DATA6 ((uint32_t)0x00FF0000)
```

Data byte 6

**5.173.2.1356 CAN\_TDH0R\_DATA7**

```
#define CAN_TDH0R_DATA7 ((uint32_t)0xFF000000)
```

Data byte 7

**5.173.2.1357 CAN\_TD1R\_DATA4**

```
#define CAN_TD1R_DATA4 ((uint32_t)0x000000FF)
```

Data byte 4

**5.173.2.1358 CAN\_TD1R\_DATA5**

```
#define CAN_TD1R_DATA5 ((uint32_t)0x0000FF00)
```

Data byte 5

**5.173.2.1359 CAN\_TD1R\_DATA6**

```
#define CAN_TD1R_DATA6 ((uint32_t)0x00FF0000)
```

Data byte 6

**5.173.2.1360 CAN\_TD1R\_DATA7**

```
#define CAN_TD1R_DATA7 ((uint32_t)0xFF000000)
```

Data byte 7

**5.173.2.1361 CAN\_TD2R\_DATA4**

```
#define CAN_TD2R_DATA4 ((uint32_t)0x000000FF)
```

Data byte 4

**5.173.2.1362 CAN\_TD2R\_DATA5**

```
#define CAN_TD2R_DATA5 ((uint32_t)0x0000FF00)
```

Data byte 5

**5.173.2.1363 CAN\_TD2R\_DATA6**

```
#define CAN_TD2R_DATA6 ((uint32_t)0x00FF0000)
```

Data byte 6

**5.173.2.1364 CAN\_TD2R\_DATA7**

```
#define CAN_TD2R_DATA7 ((uint32_t)0xFF000000)
```

Data byte 7

**5.173.2.1365 CAN\_TDL0R\_DATA0**

```
#define CAN_TDL0R_DATA0 ((uint32_t)0x000000FF)
```

Data byte 0

**5.173.2.1366 CAN\_TDL0R\_DATA1**

```
#define CAN_TDL0R_DATA1 ((uint32_t)0x0000FF00)
```

Data byte 1

**5.173.2.1367 CAN\_TDL0R\_DATA2**

```
#define CAN_TDL0R_DATA2 ((uint32_t)0x00FF0000)
```

Data byte 2

**5.173.2.1368 CAN\_TDL0R\_DATA3**

```
#define CAN_TDL0R_DATA3 ((uint32_t)0xFF000000)
```

Data byte 3

**5.173.2.1369 CAN\_TDL1R\_DATA0**

```
#define CAN_TDL1R_DATA0 ((uint32_t)0x000000FF)
```

Data byte 0

**5.173.2.1370 CAN\_TDL1R\_DATA1**

```
#define CAN_TDL1R_DATA1 ((uint32_t)0x0000FF00)
```

Data byte 1

**5.173.2.1371 CAN\_TDL1R\_DATA2**

```
#define CAN_TDL1R_DATA2 ((uint32_t)0x00FF0000)
```

Data byte 2

**5.173.2.1372 CAN\_TDL1R\_DATA3**

```
#define CAN_TDL1R_DATA3 ((uint32_t)0xFF000000)
```

Data byte 3

**5.173.2.1373 CAN\_TDL2R\_DATA0**

```
#define CAN_TDL2R_DATA0 ((uint32_t)0x000000FF)
```

Data byte 0

**5.173.2.1374 CAN\_TDL2R\_DATA1**

```
#define CAN_TDL2R_DATA1 ((uint32_t)0x0000FF00)
```

Data byte 1

**5.173.2.1375 CAN\_TDL2R\_DATA2**

```
#define CAN_TDL2R_DATA2 ((uint32_t)0x00FF0000)
```

Data byte 2

**5.173.2.1376 CAN\_TDL2R\_DATA3**

```
#define CAN_TDL2R_DATA3 ((uint32_t)0xFF000000)
```

Data byte 3

**5.173.2.1377 CAN\_TDT0R\_DLC**

```
#define CAN_TDT0R_DLC ((uint32_t)0x0000000F)
```

Data Length Code

**5.173.2.1378 CAN\_TDT0R\_TGT**

```
#define CAN_TDT0R_TGT ((uint32_t)0x000000100)
```

Transmit Global Time

**5.173.2.1379 CAN\_TDT0R\_TIME**

```
#define CAN_TDT0R_TIME ((uint32_t)0xFFFF0000)
```

Message Time Stamp

**5.173.2.1380 CAN\_TDT1R\_DLC**

```
#define CAN_TDT1R_DLC ((uint32_t)0x0000000F)
```

Data Length Code

**5.173.2.1381 CAN\_TDT1R\_TGT**

```
#define CAN_TDT1R_TGT ((uint32_t)0x00000100)
```

Transmit Global Time

**5.173.2.1382 CAN\_TDT1R\_TIME**

```
#define CAN_TDT1R_TIME ((uint32_t)0xFFFF0000)
```

Message Time Stamp

**5.173.2.1383 CAN\_TDT2R\_DLC**

```
#define CAN_TDT2R_DLC ((uint32_t)0x0000000F)
```

Data Length Code

**5.173.2.1384 CAN\_TDT2R\_TGT**

```
#define CAN_TDT2R_TGT ((uint32_t)0x00000100)
```

Transmit Global Time

**5.173.2.1385 CAN\_TDT2R\_TIME**

```
#define CAN_TDT2R_TIME ((uint32_t)0xFFFF0000)
```

Message Time Stamp

**5.173.2.1386 CAN\_TI0R\_EXID**

```
#define CAN_TI0R_EXID ((uint32_t)0x001FFFF8)
```

Extended Identifier

**5.173.2.1387 CAN\_TI0R\_IDE**

```
#define CAN_TI0R_IDE ((uint32_t)0x00000004)
```

Identifier Extension

**5.173.2.1388 CAN\_TI0R\_RTR**

```
#define CAN_TI0R_RTR ((uint32_t)0x00000002)
```

Remote Transmission Request

**5.173.2.1389 CAN\_TI0R\_STID**

```
#define CAN_TI0R_STID ((uint32_t)0xFFE00000)
```

Standard Identifier or Extended Identifier

**5.173.2.1390 CAN\_TI0R\_TXRQ**

```
#define CAN_TI0R_TXRQ ((uint32_t)0x00000001)
```

Transmit Mailbox Request

**5.173.2.1391 CAN\_TI1R\_EXID**

```
#define CAN_TI1R_EXID ((uint32_t)0x001FFFF8)
```

Extended Identifier

**5.173.2.1392 CAN\_TI1R\_IDE**

```
#define CAN_TI1R_IDE ((uint32_t)0x00000004)
```

Identifier Extension

**5.173.2.1393 CAN\_TI1R\_RTR**

```
#define CAN_TI1R_RTR ((uint32_t)0x00000002)
```

Remote Transmission Request

**5.173.2.1394 CAN\_TI1R\_STID**

```
#define CAN_TI1R_STID ((uint32_t)0xFFE00000)
```

Standard Identifier or Extended Identifier

**5.173.2.1395 CAN\_TI1R\_TXRQ**

```
#define CAN_TI1R_TXRQ ((uint32_t)0x00000001)
```

Transmit Mailbox Request

**5.173.2.1396 CAN\_TI2R\_EXID**

```
#define CAN_TI2R_EXID ((uint32_t)0x001FFFF8)
```

Extended identifier

**5.173.2.1397 CAN\_TI2R\_IDE**

```
#define CAN_TI2R_IDE ((uint32_t)0x00000004)
```

Identifier Extension

**5.173.2.1398 CAN\_TI2R\_RTR**

```
#define CAN_TI2R_RTR ((uint32_t)0x00000002)
```

Remote Transmission Request

**5.173.2.1399 CAN\_TI2R\_STID**

```
#define CAN_TI2R_STID ((uint32_t)0xFFE00000)
```

Standard Identifier or Extended Identifier

**5.173.2.1400 CAN\_TI2R\_TXRQ**

```
#define CAN_TI2R_TXRQ ((uint32_t)0x00000001)
```

Transmit Mailbox Request

**5.173.2.1401 CAN\_TSR\_ABRQ0**

```
#define CAN_TSR_ABRQ0 ((uint32_t)0x00000080)
```

Abort Request for Mailbox0

**5.173.2.1402 CAN\_TSR\_ABRQ1**

```
#define CAN_TSR_ABRQ1 ((uint32_t)0x00008000)
```

Abort Request for Mailbox 1

**5.173.2.1403 CAN\_TSR\_ABRQ2**

```
#define CAN_TSR_ABRQ2 ((uint32_t)0x00800000)
```

Abort Request for Mailbox 2

**5.173.2.1404 CAN\_TSR\_ALST0**

```
#define CAN_TSR_ALST0 ((uint32_t)0x00000004)
```

Arbitration Lost for Mailbox0

**5.173.2.1405 CAN\_TSR\_ALST1**

```
#define CAN_TSR_ALST1 ((uint32_t)0x00000400)
```

Arbitration Lost for Mailbox1

**5.173.2.1406 CAN\_TSR\_ALST2**

```
#define CAN_TSR_ALST2 ((uint32_t)0x00040000)
```

Arbitration Lost for mailbox 2

**5.173.2.1407 CAN\_TSR\_CODE**

```
#define CAN_TSR_CODE ((uint32_t)0x03000000)
```

Mailbox Code

**5.173.2.1408 CAN\_TSR\_LOW**

```
#define CAN_TSR_LOW ((uint32_t)0xE0000000)
```

LOW[2:0] bits

**5.173.2.1409 CAN\_TSR\_LOW0**

```
#define CAN_TSR_LOW0 ((uint32_t)0x20000000)
```

Lowest Priority Flag for Mailbox 0

**5.173.2.1410 CAN\_TSR\_LOW1**

```
#define CAN_TSR_LOW1 ((uint32_t)0x40000000)
```

Lowest Priority Flag for Mailbox 1

**5.173.2.1411 CAN\_TSR\_LOW2**

```
#define CAN_TSR_LOW2 ((uint32_t)0x80000000)
```

Lowest Priority Flag for Mailbox 2

**5.173.2.1412 CAN\_TSR\_RQCP0**

```
#define CAN_TSR_RQCP0 ((uint32_t)0x00000001)
```

Request Completed Mailbox0

**5.173.2.1413 CAN\_TSR\_RQCP1**

```
#define CAN_TSR_RQCP1 ((uint32_t)0x00000100)
```

Request Completed Mailbox1

**5.173.2.1414 CAN\_TSR\_RQCP2**

```
#define CAN_TSR_RQCP2 ((uint32_t)0x00010000)
```

Request Completed Mailbox2

**5.173.2.1415 CAN\_TSR\_TERR0**

```
#define CAN_TSR_TERR0 ((uint32_t)0x00000008)
```

Transmission Error of Mailbox0

**5.173.2.1416 CAN\_TSR\_TERR1**

```
#define CAN_TSR_TERR1 ((uint32_t)0x00000800)
```

Transmission Error of Mailbox1

**5.173.2.1417 CAN\_TSR\_TERR2**

```
#define CAN_TSR_TERR2 ((uint32_t)0x00080000)
```

Transmission Error of Mailbox 2

**5.173.2.1418 CAN\_TSR\_TME**

```
#define CAN_TSR_TME ((uint32_t)0x1C000000)
```

TME[2:0] bits

**5.173.2.1419 CAN\_TSR\_TME0**

```
#define CAN_TSR_TME0 ((uint32_t)0x04000000)
```

Transmit Mailbox 0 Empty

**5.173.2.1420 CAN\_TSR\_TME1**

```
#define CAN_TSR_TME1 ((uint32_t)0x08000000)
```

Transmit Mailbox 1 Empty

**5.173.2.1421 CAN\_TSR\_TME2**

```
#define CAN_TSR_TME2 ((uint32_t)0x10000000)
```

Transmit Mailbox 2 Empty

**5.173.2.1422 CAN\_TSR\_TXOK0**

```
#define CAN_TSR_TXOK0 ((uint32_t)0x00000002)
```

Transmission OK of Mailbox0

**5.173.2.1423 CAN\_TSR\_TXOK1**

```
#define CAN_TSR_TXOK1 ((uint32_t)0x00000200)
```

Transmission OK of Mailbox1

**5.173.2.1424 CAN\_TSR\_TXOK2**

```
#define CAN_TSR_TXOK2 ((uint32_t)0x00020000)
```

Transmission OK of Mailbox 2

**5.173.2.1425 CRC\_CR\_RESET**

```
#define CRC_CR_RESET ((uint8_t)0x01)
```

RESET bit

**5.173.2.1426 CRC\_DR\_DR**

```
#define CRC_DR_DR ((uint32_t)0xFFFFFFFF)
```

Data register bits

**5.173.2.1427 CRC\_IDR\_IDR**

```
#define CRC_IDR_IDR ((uint8_t)0xFF)
```

General-purpose 8-bit data register bits

**5.173.2.1428 DAC\_CR\_BOFF1**

```
#define DAC_CR_BOFF1 ((uint32_t)0x00000002)
```

DAC channel1 output buffer disable

**5.173.2.1429 DAC\_CR\_BOFF2**

```
#define DAC_CR_BOFF2 ((uint32_t)0x00020000)
```

DAC channel2 output buffer disable

**5.173.2.1430 DAC\_CR\_DMAEN1**

```
#define DAC_CR_DMAEN1 ((uint32_t)0x00001000)
```

DAC channel1 DMA enable

**5.173.2.1431 DAC\_CR\_DMAEN2**

```
#define DAC_CR_DMAEN2 ((uint32_t)0x10000000)
```

DAC channel2 DMA enabled

**5.173.2.1432 DAC\_CR\_DMAUDRIE1**

```
#define DAC_CR_DMAUDRIE1 ((uint32_t)0x00002000)
```

DAC channel1 DMA underrun interrupt enable

**5.173.2.1433 DAC\_CR\_DMAUDRIE2**

```
#define DAC_CR_DMAUDRIE2 ((uint32_t)0x20000000U)
```

DAC channel2 DMA underrun interrupt enable

**5.173.2.1434 DAC\_CR\_EN1**

```
#define DAC_CR_EN1 ((uint32_t)0x00000001)
```

DAC channel1 enable

**5.173.2.1435 DAC\_CR\_EN2**

```
#define DAC_CR_EN2 ((uint32_t)0x00010000)
```

DAC channel2 enable

**5.173.2.1436 DAC\_CR\_MAMP1**

```
#define DAC_CR_MAMP1 ((uint32_t)0x00000F00)
```

MAMP1 3:0

**5.173.2.1437 DAC\_CR\_MAMP1\_0**

```
#define DAC_CR_MAMP1_0 ((uint32_t)0x00000100)
```

Bit 0

**5.173.2.1438 DAC\_CR\_MAMP1\_1**

```
#define DAC_CR_MAMP1_1 ((uint32_t)0x00000200)
```

Bit 1

**5.173.2.1439 DAC\_CR\_MAMP1\_2**

```
#define DAC_CR_MAMP1_2 ((uint32_t)0x00000400)
```

Bit 2

**5.173.2.1440 DAC\_CR\_MAMP1\_3**

```
#define DAC_CR_MAMP1_3 ((uint32_t)0x00000800)
```

Bit 3

**5.173.2.1441 DAC\_CR\_MAMP2**

```
#define DAC_CR_MAMP2 ((uint32_t)0x0F000000)
```

MAMP2 3:0

**5.173.2.1442 DAC\_CR\_MAMP2\_0**

```
#define DAC_CR_MAMP2_0 ((uint32_t)0x01000000)
```

Bit 0

**5.173.2.1443 DAC\_CR\_MAMP2\_1**

```
#define DAC_CR_MAMP2_1 ((uint32_t)0x02000000)
```

Bit 1

**5.173.2.1444 DAC\_CR\_MAMP2\_2**

```
#define DAC_CR_MAMP2_2 ((uint32_t)0x04000000)
```

Bit 2

**5.173.2.1445 DAC\_CR\_MAMP2\_3**

```
#define DAC_CR_MAMP2_3 ((uint32_t)0x08000000)
```

Bit 3

**5.173.2.1446 DAC\_CR\_TEN1**

```
#define DAC_CR_TEN1 ((uint32_t)0x00000004)
```

DAC channel1 Trigger enable

**5.173.2.1447 DAC\_CR\_TEN2**

```
#define DAC_CR_TEN2 ((uint32_t)0x00040000)
```

DAC channel2 Trigger enable

**5.173.2.1448 DAC\_CR\_TSEL1**

```
#define DAC_CR_TSEL1 ((uint32_t)0x00000038)
```

TSEL1[2:0] (DAC channel1 Trigger selection)

**5.173.2.1449 DAC\_CR\_TSEL1\_0**

```
#define DAC_CR_TSEL1_0 ((uint32_t)0x00000008)
```

Bit 0

**5.173.2.1450 DAC\_CR\_TSEL1\_1**

```
#define DAC_CR_TSEL1_1 ((uint32_t)0x00000010)
```

Bit 1

**5.173.2.1451 DAC\_CR\_TSEL1\_2**

```
#define DAC_CR_TSEL1_2 ((uint32_t)0x00000020)
```

Bit 2

**5.173.2.1452 DAC\_CR\_TSEL2**

```
#define DAC_CR_TSEL2 ((uint32_t)0x00380000)
```

TSEL2[2:0] (DAC channel2 Trigger selection)

**5.173.2.1453 DAC\_CR\_TSEL2\_0**

```
#define DAC_CR_TSEL2_0 ((uint32_t)0x00080000)
```

Bit 0

**5.173.2.1454 DAC\_CR\_TSEL2\_1**

```
#define DAC_CR_TSEL2_1 ((uint32_t)0x00100000)
```

Bit 1

**5.173.2.1455 DAC\_CR\_TSEL2\_2**

```
#define DAC_CR_TSEL2_2 ((uint32_t)0x00200000)
```

Bit 2

**5.173.2.1456 DAC\_CR\_WAVE1**

```
#define DAC_CR_WAVE1 ((uint32_t)0x000000C0)
```

WAVE1 1:0

**5.173.2.1457 DAC\_CR\_WAVE1\_0**

```
#define DAC_CR_WAVE1_0 ((uint32_t)0x00000040)
```

Bit 0

**5.173.2.1458 DAC\_CR\_WAVE1\_1**

```
#define DAC_CR_WAVE1_1 ((uint32_t)0x00000080)
```

Bit 1

**5.173.2.1459 DAC\_CR\_WAVE2**

```
#define DAC_CR_WAVE2 ((uint32_t)0x00C00000)
```

WAVE2 1:0

**5.173.2.1460 DAC\_CR\_WAVE2\_0**

```
#define DAC_CR_WAVE2_0 ((uint32_t)0x00400000)
```

Bit 0

**5.173.2.1461 DAC\_CR\_WAVE2\_1**

```
#define DAC_CR_WAVE2_1 ((uint32_t)0x00800000)
```

Bit 1

**5.173.2.1462 DAC\_DHR12L1\_DACC1DHR**

```
#define DAC_DHR12L1_DACC1DHR ((uint16_t)0xFFFF0)
```

DAC channel1 12-bit Left aligned data

**5.173.2.1463 DAC\_DHR12L2\_DACC2DHR**

```
#define DAC_DHR12L2_DACC2DHR ((uint16_t)0xFFFF0)
```

DAC channel2 12-bit Left aligned data

**5.173.2.1464 DAC\_DHR12LD\_DACC1DHR**

```
#define DAC_DHR12LD_DACC1DHR ((uint32_t)0x0000FFFF0)
```

DAC channel1 12-bit Left aligned data

**5.173.2.1465 DAC\_DHR12LD\_DACC2DHR**

```
#define DAC_DHR12LD_DACC2DHR ((uint32_t)0xFFFF00000)
```

DAC channel2 12-bit Left aligned data

**5.173.2.1466 DAC\_DHR12R1\_DACC1DHR**

```
#define DAC_DHR12R1_DACC1DHR ((uint16_t)0x0FFF)
```

DAC channel1 12-bit Right aligned data

**5.173.2.1467 DAC\_DHR12R2\_DACC2DHR**

```
#define DAC_DHR12R2_DACC2DHR ((uint16_t)0x0FFF)
```

DAC channel2 12-bit Right aligned data

**5.173.2.1468 DAC\_DHR12RD\_DACC1DHR**

```
#define DAC_DHR12RD_DACC1DHR ((uint32_t)0x00000FFF)
```

DAC channel1 12-bit Right aligned data

**5.173.2.1469 DAC\_DHR12RD\_DACC2DHR**

```
#define DAC_DHR12RD_DACC2DHR ((uint32_t)0xFFFF0000)
```

DAC channel2 12-bit Right aligned data

**5.173.2.1470 DAC\_DHR8R1\_DACC1DHR**

```
#define DAC_DHR8R1_DACC1DHR ((uint8_t)0xFF)
```

DAC channel1 8-bit Right aligned data

**5.173.2.1471 DAC\_DHR8R2\_DACC2DHR**

```
#define DAC_DHR8R2_DACC2DHR ((uint8_t)0xFF)
```

DAC channel2 8-bit Right aligned data

**5.173.2.1472 DAC\_DHR8RD\_DACC1DHR**

```
#define DAC_DHR8RD_DACC1DHR ((uint16_t)0x00FF)
```

DAC channel1 8-bit Right aligned data

**5.173.2.1473 DAC\_DHR8RD\_DACC2DHR**

```
#define DAC_DHR8RD_DACC2DHR ((uint16_t)0xFF00)
```

DAC channel2 8-bit Right aligned data

**5.173.2.1474 DAC\_DOR1\_DACC1DOR**

```
#define DAC_DOR1_DACC1DOR ((uint16_t)0xFFFF)
```

DAC channel1 data output

**5.173.2.1475 DAC\_DOR2\_DACC2DOR**

```
#define DAC_DOR2_DACC2DOR ((uint16_t)0xFFFF)
```

DAC channel2 data output

**5.173.2.1476 DAC\_SR\_DMAUDR1**

```
#define DAC_SR_DMAUDR1 ((uint32_t)0x00002000)
```

DAC channel1 DMA underrun flag

**5.173.2.1477 DAC\_SR\_DMAUDR2**

```
#define DAC_SR_DMAUDR2 ((uint32_t)0x20000000)
```

DAC channel2 DMA underrun flag

**5.173.2.1478 DAC\_SWTRIGR\_SWTRIG1**

```
#define DAC_SWTRIGR_SWTRIG1 ((uint8_t)0x01)
```

DAC channel1 software trigger

**5.173.2.1479 DAC\_SWTRIGR\_SWTRIG2**

```
#define DAC_SWTRIGR_SWTRIG2 ((uint8_t)0x02)
```

DAC channel2 software trigger

**5.173.2.1480 DBGMCU\_CR\_TRACE\_MODE\_0**

```
#define DBGMCU_CR_TRACE_MODE_0 ((uint32_t)0x00000040)
```

Bit 0

**5.173.2.1481 DBGMCU\_CR\_TRACE\_MODE\_1**

```
#define DBGMCU_CR_TRACE_MODE_1 ((uint32_t)0x00000080)
```

Bit 1

**5.173.2.1482 DFSDM\_CHAWSCDR\_AWFORD**

```
#define DFSDM_CHAWSCDR_AWFORD ((uint32_t)0x00C00000)
```

AWFORD[1:0] Analog watchdog Sinc filter order on channel y

**5.173.2.1483 DFSDM\_CHAWSCDR\_AWFORD\_0**

```
#define DFSDM_CHAWSCDR_AWFORD_0 ((uint32_t)0x00400000)
```

Analog watchdog Sinc filter order on channel y, Bit 0

**5.173.2.1484 DFSDM\_CHAWSCDR\_AWFORD\_1**

```
#define DFSDM_CHAWSCDR_AWFORD_1 ((uint32_t)0x00800000)
```

Analog watchdog Sinc filter order on channel y, Bit 1

**5.173.2.1485 DFSDM\_CHAWSCDR\_AWFOSR**

```
#define DFSDM_CHAWSCDR_AWFOSR ((uint32_t)0x001F0000)
```

AWFOSR[4:0] Analog watchdog filter oversampling ratio on channel y

**5.173.2.1486 DFSDM\_CHAWSCDR\_BKSCD**

```
#define DFSDM_CHAWSCDR_BKSCD ((uint32_t)0x0000F000)
```

BKSCD[3:0] Break signal assignment for short circuit detector on channel y

**5.173.2.1487 DFSDM\_CHAWSCDR\_SCDT**

```
#define DFSDM_CHAWSCDR_SCDT ((uint32_t)0x000000FF)
```

SCDT[7:0] Short circuit detector threshold for channel y

**5.173.2.1488 DFSDM\_CHCGR1\_CHEN**

```
#define DFSDM_CHCGR1_CHEN ((uint32_t)0x00000080)
```

Channel y enable

**5.173.2.1489 DFSDM\_CHCGR1\_CHINSEL**

```
#define DFSDM_CHCGR1_CHINSEL ((uint32_t)0x00000100)
```

Serial inputs selection for channel y

**5.173.2.1490 DFSDM\_CHCGR1\_CKABEN**

```
#define DFSDM_CHCGR1_CKABEN ((uint32_t)0x00000040)
```

Clock absence detector enable on channel y

**5.173.2.1491 DFSDM\_CHCGR1\_CKOUTDIV**

```
#define DFSDM_CHCGR1_CKOUTDIV ((uint32_t)0x00FF0000)
```

CKOUTDIV[7:0] output serial clock divider

**5.173.2.1492 DFSDM\_CHCGR1\_CKOUTSRC**

```
#define DFSDM_CHCGR1_CKOUTSRC ((uint32_t)0x40000000)
```

Output serial clock source selection

**5.173.2.1493 DFSDM\_CHCFGR1\_DATMPX**

```
#define DFSDM_CHCFGR1_DATMPX ((uint32_t)0x00003000)
```

DATMPX[1:0] Input data multiplexer for channel y

**5.173.2.1494 DFSDM\_CHCFGR1\_DATMPX\_0**

```
#define DFSDM_CHCFGR1_DATMPX_0 ((uint32_t)0x00001000)
```

Input data multiplexer for channel y, Bit 0

**5.173.2.1495 DFSDM\_CHCFGR1\_DATMPX\_1**

```
#define DFSDM_CHCFGR1_DATMPX_1 ((uint32_t)0x00002000)
```

Input data multiplexer for channel y, Bit 1

**5.173.2.1496 DFSDM\_CHCFGR1\_DATPACK**

```
#define DFSDM_CHCFGR1_DATPACK ((uint32_t)0x0000C000)
```

DATPACK[1:0] Data packing mode

**5.173.2.1497 DFSDM\_CHCFGR1\_DATPACK\_0**

```
#define DFSDM_CHCFGR1_DATPACK_0 ((uint32_t)0x00004000)
```

Data packing mode, Bit 0

**5.173.2.1498 DFSDM\_CHCFGR1\_DATPACK\_1**

```
#define DFSDM_CHCFGR1_DATPACK_1 ((uint32_t)0x00008000)
```

Data packing mode, Bit 1

**5.173.2.1499 DFSDM\_CHCFGR1\_DFSDMEN**

```
#define DFSDM_CHCFGR1_DFSDMEN ((uint32_t)0x80000000)
```

Global enable for DFSDM interface

**5.173.2.1500 DFSDM\_CHCFGR1\_SCDEN**

```
#define DFSDM_CHCFGR1_SCDEN ((uint32_t)0x00000020)
```

Short circuit detector enable on channel y

**5.173.2.1501 DFSDM\_CHCFGR1\_SITP**

```
#define DFSDM_CHCFGR1_SITP ((uint32_t)0x00000003)
```

SITP[1:0] Serial interface type for channel y

**5.173.2.1502 DFSDM\_CHCFGR1\_SITP\_0**

```
#define DFSDM_CHCFGR1_SITP_0 ((uint32_t)0x00000001)
```

Serial interface type for channel y, Bit 0

**5.173.2.1503 DFSDM\_CHCFGR1\_SITP\_1**

```
#define DFSDM_CHCFGR1_SITP_1 ((uint32_t)0x00000002)
```

Serial interface type for channel y, Bit 1

**5.173.2.1504 DFSDM\_CHCFGR1\_SPICKSEL**

```
#define DFSDM_CHCFGR1_SPICKSEL ((uint32_t)0x0000000C)
```

SPICKSEL[1:0] SPI clock select for channel y

**5.173.2.1505 DFSDM\_CHCFGR1\_SPICKSEL\_0**

```
#define DFSDM_CHCFGR1_SPICKSEL_0 ((uint32_t)0x00000004)
```

SPI clock select for channel y, Bit 0

**5.173.2.1506 DFSDM\_CHCFGR1\_SPICKSEL\_1**

```
#define DFSDM_CHCFGR1_SPICKSEL_1 ((uint32_t)0x00000008)
```

SPI clock select for channel y, Bit 1

**5.173.2.1507 DFSDM\_CHCFGR2\_DTRBS**

```
#define DFSDM_CHCFGR2_DTRBS ((uint32_t)0x000000F8)
```

DTRBS[4:0] Data right bit-shift for channel y

**5.173.2.1508 DFSDM\_CHCFGR2\_OFFSET**

```
#define DFSDM_CHCFGR2_OFFSET ((uint32_t)0xFFFFFFF00)
```

OFFSET[23:0] 24-bit calibration offset for channel y

**5.173.2.1509 DFSDM\_CHDATINR\_INDAT0**

```
#define DFSDM_CHDATINR_INDAT0 ((uint32_t)0x0000FFFF)
```

INDAT0[31:16] Input data for channel y or channel (y+1)

**5.173.2.1510 DFSDM\_CHDATINR\_INDAT1**

```
#define DFSDM_CHDATINR_INDAT1 ((uint32_t)0xFFFF0000)
```

INDAT0[15:0] Input data for channel y

**5.173.2.1511 DFSDM\_CHWDATR\_WDATA**

```
#define DFSDM_CHWDATR_WDATA ((uint32_t)0x0000FFFF)
```

WDATA[15:0] Input channel y watchdog data

**5.173.2.1512 DFSDM\_FLTAWCFR\_CLRAWHTF**

```
#define DFSDM_FLTAWCFR_CLRAWHTF ((uint32_t)0x00000F00)
```

CLRAWHTF[15:8] Clear the Analog watchdog high threshold flag

**5.173.2.1513 DFSDM\_FLTAWCFR\_CLRAWLTF**

```
#define DFSDM_FLTAWCFR_CLRAWLTF ((uint32_t)0x0000000F)
```

CLRAWLTF[7:0] Clear the Analog watchdog low threshold flag

**5.173.2.1514 DFSDM\_FLTAWHTR\_AWHT**

```
#define DFSDM_FLTAWHTR_AWHT ((uint32_t)0xFFFFFFF0)
```

AWHT[23:0] Analog watchdog high threshold

**5.173.2.1515 DFSDM\_FLTAWHTR\_BKAWH**

```
#define DFSDM_FLTAWHTR_BKAWH ((uint32_t)0x0000000F)
```

BKAWH[3:0] Break signal assignment to analog watchdog high threshold event

**5.173.2.1516 DFSDM\_FLTAWLTR\_AWL**

```
#define DFSDM_FLTAWLTR_AWL ((uint32_t)0xFFFFFFF0)
```

AWLT[23:0] Analog watchdog low threshold

### 5.173.2.1517 DFSDM\_FLTAWLTR\_BKAWL

```
#define DFSDM_FLTAWLTR_BKAWL ((uint32_t)0x0000000F)
```

BKAWL[3:0] Break signal assignment to analog watchdog low threshold event

### 5.173.2.1518 DFSDM\_FLTAWSR\_AWHTF

```
#define DFSDM_FLTAWSR_AWHTF ((uint32_t)0x00000F00)
```

AWHTF[15:8] Analog watchdog high threshold error on given channels

### 5.173.2.1519 DFSDM\_FLTAWSR\_AWLTF

```
#define DFSDM_FLTAWSR_AWLTF ((uint32_t)0x0000000F)
```

AWLTF[7:0] Analog watchdog low threshold error on given channels

### 5.173.2.1520 DFSDM\_FLTCNVTIMR\_CNVCNT

```
#define DFSDM_FLTCNVTIMR_CNVCNT ((uint32_t)0xFFFFFFFF0)
```

CNVCNT[27:0]: 28-bit timer counting conversion time

### 5.173.2.1521 DFSDM\_FLTCR1\_AWFSEL

```
#define DFSDM_FLTCR1_AWFSEL ((uint32_t)0x40000000)
```

Analog watchdog fast mode select

### 5.173.2.1522 DFSDM\_FLTCR1\_DFEN

```
#define DFSDM_FLTCR1_DFEN ((uint32_t)0x00000001)
```

DFSDM enable

### 5.173.2.1523 DFSDM\_FLTCR1\_FAST

```
#define DFSDM_FLTCR1_FAST ((uint32_t)0x20000000)
```

Fast conversion mode selection

### 5.173.2.1524 DFSDM\_FLTCR1\_JDMAEN

```
#define DFSDM_FLTCR1_JDMAEN ((uint32_t)0x00000020)
```

DMA channel enabled to read data for the injected channel group

### 5.173.2.1525 DFSDM\_FLTCR1\_JEXTEN

```
#define DFSDM_FLTCR1_JEXTEN ((uint32_t)0x00006000)
```

JEXTEN[1:0] Trigger enable and trigger edge selection for injected conversions

### 5.173.2.1526 DFSDM\_FLTCR1\_JEXTEN\_0

```
#define DFSDM_FLTCR1_JEXTEN_0 ((uint32_t)0x00002000)
```

Trigger enable and trigger edge selection for injected conversions, Bit 0

### 5.173.2.1527 DFSDM\_FLTCR1\_JEXTEN\_1

```
#define DFSDM_FLTCR1_JEXTEN_1 ((uint32_t)0x00004000)
```

Trigger enable and trigger edge selection for injected conversions, Bit 1

### 5.173.2.1528 DFSDM\_FLTCR1\_JEXTSEL

```
#define DFSDM_FLTCR1_JEXTSEL ((uint32_t)0x00000700)
```

JEXTSEL[2:0]Trigger signal selection for launching injected conversions

### 5.173.2.1529 DFSDM\_FLTCR1\_JEXTSEL\_0

```
#define DFSDM_FLTCR1_JEXTSEL_0 ((uint32_t)0x00000100)
```

Trigger signal selection for launching injected conversions, Bit 0

### 5.173.2.1530 DFSDM\_FLTCR1\_JEXTSEL\_1

```
#define DFSDM_FLTCR1_JEXTSEL_1 ((uint32_t)0x00000200)
```

Trigger signal selection for launching injected conversions, Bit 1

### 5.173.2.1531 DFSDM\_FLTCR1\_JEXTSEL\_2

```
#define DFSDM_FLTCR1_JEXTSEL_2 ((uint32_t)0x00000400)
```

Trigger signal selection for launching injected conversions, Bit 2

### 5.173.2.1532 DFSDM\_FLTCR1\_JSCAN

```
#define DFSDM_FLTCR1_JSCAN ((uint32_t)0x00000010)
```

Scanning conversion in continuous mode selection for injected conversions

**5.173.2.1533 DFSDM\_FLTCR1\_JSWSTART**

```
#define DFSDM_FLTCR1_JSWSTART ((uint32_t)0x00000002)
```

Start the conversion of the injected group of channels

**5.173.2.1534 DFSDM\_FLTCR1\_JSYNC**

```
#define DFSDM_FLTCR1_JSYNC ((uint32_t)0x00000008)
```

Launch an injected conversion synchronously with DFSDMx JSWSTART trigger

**5.173.2.1535 DFSDM\_FLTCR1\_RCH**

```
#define DFSDM_FLTCR1_RCH ((uint32_t)0x07000000)
```

RCH[2:0] Regular channel selection

**5.173.2.1536 DFSDM\_FLTCR1\_RCONT**

```
#define DFSDM_FLTCR1_RCONT ((uint32_t)0x00040000)
```

Continuous mode selection for regular conversions

**5.173.2.1537 DFSDM\_FLTCR1\_RDMAEN**

```
#define DFSDM_FLTCR1_RDMAEN ((uint32_t)0x00200000)
```

DMA channel enabled to read data for the regular conversion

**5.173.2.1538 DFSDM\_FLTCR1\_RSWSTART**

```
#define DFSDM_FLTCR1_RSWSTART ((uint32_t)0x00020000)
```

Software start of a conversion on the regular channel

**5.173.2.1539 DFSDM\_FLTCR1\_RSYNC**

```
#define DFSDM_FLTCR1_RSYNC ((uint32_t)0x00080000)
```

Launch regular conversion synchronously with DFSDMx

**5.173.2.1540 DFSDM\_FLTCR2\_AWDCH**

```
#define DFSDM_FLTCR2_AWDCH ((uint32_t)0x000F0000)
```

AWDCH[7:0] Analog watchdog channel selection

**5.173.2.1541 DFSDM\_FLTCR2\_AWDIE**

```
#define DFSDM_FLTCR2_AWDIE ((uint32_t)0x00000010)
```

Analog watchdog interrupt enable

**5.173.2.1542 DFSDM\_FLTCR2\_CKABIE**

```
#define DFSDM_FLTCR2_CKABIE ((uint32_t)0x00000040)
```

Clock absence interrupt enable

**5.173.2.1543 DFSDM\_FLTCR2\_EXCH**

```
#define DFSDM_FLTCR2_EXCH ((uint32_t)0x00000F00)
```

EXCH[7:0] Extreme detector channel selection

**5.173.2.1544 DFSDM\_FLTCR2\_JEOCIE**

```
#define DFSDM_FLTCR2_JEOCIE ((uint32_t)0x00000001)
```

Injected end of conversion interrupt enable

**5.173.2.1545 DFSDM\_FLTCR2\_JOVRIE**

```
#define DFSDM_FLTCR2_JOVRIE ((uint32_t)0x00000004)
```

Injected data overrun interrupt enable

**5.173.2.1546 DFSDM\_FLTCR2\_REOCIE**

```
#define DFSDM_FLTCR2_REOCIE ((uint32_t)0x00000002)
```

Regular end of conversion interrupt enable

**5.173.2.1547 DFSDM\_FLTCR2\_ROVRIE**

```
#define DFSDM_FLTCR2_ROVRIE ((uint32_t)0x00000008)
```

Regular data overrun interrupt enable

**5.173.2.1548 DFSDM\_FLTCR2\_SCDIE**

```
#define DFSDM_FLTCR2_SCDIE ((uint32_t)0x00000020)
```

Short circuit detector interrupt enable

**5.173.2.1549 DFSDM\_FLTEXMAX\_EXMAX**

```
#define DFSDM_FLTEXMAX_EXMAX ((uint32_t)0xFFFFFFF00)
```

EXMAX[23:0] Extreme detector maximum value

**5.173.2.1550 DFSDM\_FLTEXMAX\_EXMAXCH**

```
#define DFSDM_FLTEXMAX_EXMAXCH ((uint32_t)0x00000007)
```

EXMAXCH[2:0] Extreme detector maximum data channel

**5.173.2.1551 DFSDM\_FLTEXMIN\_EXMIN**

```
#define DFSDM_FLTEXMIN_EXMIN ((uint32_t)0xFFFFFFF00)
```

EXMIN[23:0] Extreme detector minimum value

**5.173.2.1552 DFSDM\_FLTEXMIN\_EXMINCH**

```
#define DFSDM_FLTEXMIN_EXMINCH ((uint32_t)0x00000007)
```

EXMINCH[2:0] Extreme detector minimum data channel

**5.173.2.1553 DFSDM\_FLTFCR\_FORD**

```
#define DFSDM_FLTFCR_FORD ((uint32_t)0xE0000000)
```

FORD[2:0] Sinc filter order

**5.173.2.1554 DFSDM\_FLTFCR\_FORD\_0**

```
#define DFSDM_FLTFCR_FORD_0 ((uint32_t)0x20000000)
```

Sinc filter order, Bit 0

**5.173.2.1555 DFSDM\_FLTFCR\_FORD\_1**

```
#define DFSDM_FLTFCR_FORD_1 ((uint32_t)0x40000000)
```

Sinc filter order, Bit 1

**5.173.2.1556 DFSDM\_FLTFCR\_FORD\_2**

```
#define DFSDM_FLTFCR_FORD_2 ((uint32_t)0x80000000)
```

Sinc filter order, Bit 2

**5.173.2.1557 DFSDM\_FLTFCR\_FOSR**

```
#define DFSDM_FLTFCR_FOSR ((uint32_t)0x03FF0000)
```

FOSR[9:0] Sinc filter oversampling ratio (decimation rate)

**5.173.2.1558 DFSDM\_FLTFCR\_IOSR**

```
#define DFSDM_FLTFCR_IOSR ((uint32_t)0x000000FF)
```

IOSR[7:0] Integrator oversampling ratio (averaging length)

**5.173.2.1559 DFSDM\_FLTICR\_CLRCKABF**

```
#define DFSDM_FLTICR_CLRCKABF ((uint32_t)0x000F0000)
```

CLRCKABF[7:0] Clear the clock absence flag

**5.173.2.1560 DFSDM\_FLTICR\_CLRJOVRF**

```
#define DFSDM_FLTICR_CLRJOVRF ((uint32_t)0x00000004)
```

Clear the injected conversion overrun flag

**5.173.2.1561 DFSDM\_FLTICR\_CLRROVRF**

```
#define DFSDM_FLTICR_CLRROVRF ((uint32_t)0x00000008)
```

Clear the regular conversion overrun flag

**5.173.2.1562 DFSDM\_FLTICR\_CLRSCTSDF**

```
#define DFSDM_FLTICR_CLRSCTSDF ((uint32_t)0x0F000000)
```

CLRSCTSDF[7:0] Clear the short circuit detector flag

**5.173.2.1563 DFSDM\_FLTISR\_AWDF**

```
#define DFSDM_FLTISR_AWDF ((uint32_t)0x00000010)
```

Analog watchdog

**5.173.2.1564 DFSDM\_FLTISR\_CKABF**

```
#define DFSDM_FLTISR_CKABF ((uint32_t)0x000F0000)
```

CKABF[7:0] Clock absence flag

**5.173.2.1565 DFSDM\_FLTISR\_JCIP**

```
#define DFSDM_FLTISR_JCIP ((uint32_t)0x00002000)
```

Injected conversion in progress status

**5.173.2.1566 DFSDM\_FLTISR\_JEOCF**

```
#define DFSDM_FLTISR_JEOCF ((uint32_t)0x00000001)
```

End of injected conversion flag

**5.173.2.1567 DFSDM\_FLTISR\_JOVRF**

```
#define DFSDM_FLTISR_JOVRF ((uint32_t)0x00000004)
```

Injected conversion overrun flag

**5.173.2.1568 DFSDM\_FLTISR\_RCIP**

```
#define DFSDM_FLTISR_RCIP ((uint32_t)0x00004000)
```

Regular conversion in progress status

**5.173.2.1569 DFSDM\_FLTISR\_REOCF**

```
#define DFSDM_FLTISR_REOCF ((uint32_t)0x00000002)
```

End of regular conversion flag

**5.173.2.1570 DFSDM\_FLTISR\_ROVRF**

```
#define DFSDM_FLTISR_ROVRF ((uint32_t)0x00000008)
```

Regular conversion overrun flag

**5.173.2.1571 DFSDM\_FLTISR\_SCDF**

```
#define DFSDM_FLTISR_SCDF ((uint32_t)0x0F000000)
```

SCDF[7:0] Short circuit detector flag

**5.173.2.1572 DFSDM\_FLTJCHGR\_JCHG**

```
#define DFSDM_FLTJCHGR_JCHG ((uint32_t)0x000000FF)
```

JCHG[7:0] Injected channel group selection

**5.173.2.1573 DFSDM\_FLTJDATAR\_JDATA**

```
#define DFSDM_FLTJDATAR_JDATA ((uint32_t)0xFFFFFFF00)
```

JDATA[23:0] Injected group conversion data

**5.173.2.1574 DFSDM\_FLTJDATAR\_JDATACH**

```
#define DFSDM_FLTJDATAR_JDATACH ((uint32_t)0x00000007)
```

JDATACH[2:0] Injected channel most recently converted

**5.173.2.1575 DFSDM\_FLTRDATAR\_RDATA**

```
#define DFSDM_FLTRDATAR_RDATA ((uint32_t)0xFFFFFFF00)
```

RDATA[23:0] Regular channel conversion data

**5.173.2.1576 DFSDM\_FLTRDATAR\_RDATACH**

```
#define DFSDM_FLTRDATAR_RDATACH ((uint32_t)0x00000007)
```

RDATACH[2:0] Regular channel most recently converted

**5.173.2.1577 DFSDM\_FLTRDATAR\_RPEND**

```
#define DFSDM_FLTRDATAR_RPEND ((uint32_t)0x00000010)
```

RPEND Regular channel pending data

**5.173.2.1578 DMA2D\_AMTCR\_DT**

```
#define DMA2D_AMTCR_DT ((uint32_t)0x0000FF00)
```

Dead Time

**5.173.2.1579 DMA2D\_AMTCR\_EN**

```
#define DMA2D_AMTCR_EN ((uint32_t)0x00000001)
```

Enable

**5.173.2.1580 DMA2D\_BGCMAR\_MA**

```
#define DMA2D_BGCMAR_MA ((uint32_t)0xFFFFFFFF)
```

Memory Address

**5.173.2.1581 DMA2D\_BGCOLR\_BLUE**

```
#define DMA2D_BGCOLR_BLUE ((uint32_t)0x000000FF)
```

Blue Value

**5.173.2.1582 DMA2D\_BGCOLR\_GREEN**

```
#define DMA2D_BGCOLR_GREEN ((uint32_t)0x0000FF00)
```

Green Value

**5.173.2.1583 DMA2D\_BGCOLR\_RED**

```
#define DMA2D_BGCOLR_RED ((uint32_t)0x00FF0000)
```

Red Value

**5.173.2.1584 DMA2D\_BGMAR\_MA**

```
#define DMA2D_BGMAR_MA ((uint32_t)0xFFFFFFFF)
```

Memory Address

**5.173.2.1585 DMA2D\_BGOR\_LO**

```
#define DMA2D_BGOR_LO ((uint32_t)0x00003FFF)
```

Line Offset

**5.173.2.1586 DMA2D\_BGPFCCR\_ALPHA**

```
#define DMA2D_BGPFCCR_ALPHA ((uint32_t)0xFF000000)
```

Alpha value

**5.173.2.1587 DMA2D\_BGPFCCR\_AM**

```
#define DMA2D_BGPFCCR_AM ((uint32_t)0x00030000)
```

Alpha mode AM[1:0]

**5.173.2.1588 DMA2D\_BGPFCCR\_AM\_0**

```
#define DMA2D_BGPFCCR_AM_0 ((uint32_t)0x00010000)
```

Alpha mode AM bit 0

**5.173.2.1589 DMA2D\_BGPFCCR\_AM\_1**

```
#define DMA2D_BGPFCCR_AM_1 ((uint32_t)0x00020000)
```

Alpha mode AM bit 1

**5.173.2.1590 DMA2D\_BGPFCCR\_CCM**

```
#define DMA2D_BGPFCCR_CCM ((uint32_t)0x00000010)
```

CLUT Color mode

**5.173.2.1591 DMA2D\_BGPFCCR\_CM**

```
#define DMA2D_BGPFCCR_CM ((uint32_t)0x0000000F)
```

Input color mode CM[3:0]

**5.173.2.1592 DMA2D\_BGPFCCR\_CM\_0**

```
#define DMA2D_BGPFCCR_CM_0 ((uint32_t)0x00000001)
```

Input color mode CM bit 0

**5.173.2.1593 DMA2D\_BGPFCCR\_CM\_1**

```
#define DMA2D_BGPFCCR_CM_1 ((uint32_t)0x00000002)
```

Input color mode CM bit 1

**5.173.2.1594 DMA2D\_BGPFCCR\_CM\_2**

```
#define DMA2D_BGPFCCR_CM_2 ((uint32_t)0x00000004)
```

Input color mode CM bit 2

**5.173.2.1595 DMA2D\_BGPFCCR\_CS**

```
#define DMA2D_BGPFCCR_CS ((uint32_t)0x0000FF00)
```

CLUT size

**5.173.2.1596 DMA2D\_BGPFCCR\_START**

```
#define DMA2D_BGPFCCR_START ((uint32_t)0x00000020)
```

Start

**5.173.2.1597 DMA2D\_CR\_ABORT**

```
#define DMA2D_CR_ABORT ((uint32_t)0x00000004)
```

Abort transfer

**5.173.2.1598 DMA2D\_CR\_CAEIE**

```
#define DMA2D_CR_CAEIE ((uint32_t)0x00000800)
```

CLUT Access Error Interrupt Enable

**5.173.2.1599 DMA2D\_CR\_CEIE**

```
#define DMA2D_CR_CEIE ((uint32_t)0x00002000)
```

Configuration Error Interrupt Enable

**5.173.2.1600 DMA2D\_CR\_CTCIE**

```
#define DMA2D_CR_CTCIE ((uint32_t)0x00001000)
```

CLUT Transfer Complete Interrupt Enable

**5.173.2.1601 DMA2D\_CR\_MODE**

```
#define DMA2D_CR_MODE ((uint32_t)0x00030000)
```

DMA2D Mode

**5.173.2.1602 DMA2D\_CR\_START**

```
#define DMA2D_CR_START ((uint32_t)0x00000001)
```

Start transfer

**5.173.2.1603 DMA2D\_CR\_SUSP**

```
#define DMA2D_CR_SUSP ((uint32_t)0x00000002)
```

Suspend transfer

**5.173.2.1604 DMA2D\_CR\_TCIE**

```
#define DMA2D_CR_TCIE ((uint32_t)0x00000200)
```

Transfer Complete Interrupt Enable

**5.173.2.1605 DMA2D\_CR\_TEIE**

```
#define DMA2D_CR_TEIE ((uint32_t)0x00000100)
```

Transfer Error Interrupt Enable

**5.173.2.1606 DMA2D\_CR\_TWIE**

```
#define DMA2D_CR_TWIE ((uint32_t)0x00000400)
```

Transfer Watermark Interrupt Enable

**5.173.2.1607 DMA2D\_FGCMAR\_MA**

```
#define DMA2D_FGCMAR_MA ((uint32_t)0xFFFFFFFF)
```

Memory Address

**5.173.2.1608 DMA2D\_FGCOLR\_BLUE**

```
#define DMA2D_FGCOLR_BLUE ((uint32_t)0x000000FF)
```

Blue Value

**5.173.2.1609 DMA2D\_FGCOLR\_GREEN**

```
#define DMA2D_FGCOLR_GREEN ((uint32_t)0x0000FF00)
```

Green Value

**5.173.2.1610 DMA2D\_FGCOLR\_RED**

```
#define DMA2D_FGCOLR_RED ((uint32_t)0x00FF0000)
```

Red Value

**5.173.2.1611 DMA2D\_FGMAR\_MA**

```
#define DMA2D_FGMAR_MA ((uint32_t)0xFFFFFFFF)
```

Memory Address

### 5.173.2.1612 DMA2D\_FGOR\_LO

```
#define DMA2D_FGOR_LO ((uint32_t)0x00003FFF)
```

Line Offset

### 5.173.2.1613 DMA2D\_FGPFCCR\_ALPHA

```
#define DMA2D_FGPFCCR_ALPHA ((uint32_t)0xFF000000)
```

Alpha value

### 5.173.2.1614 DMA2D\_FGPFCCR\_AM

```
#define DMA2D_FGPFCCR_AM ((uint32_t)0x00030000)
```

Alpha mode AM[1:0]

### 5.173.2.1615 DMA2D\_FGPFCCR\_AM\_0

```
#define DMA2D_FGPFCCR_AM_0 ((uint32_t)0x00010000)
```

Alpha mode AM bit 0

### 5.173.2.1616 DMA2D\_FGPFCCR\_AM\_1

```
#define DMA2D_FGPFCCR_AM_1 ((uint32_t)0x00020000)
```

Alpha mode AM bit 1

### 5.173.2.1617 DMA2D\_FGPFCCR\_CCM

```
#define DMA2D_FGPFCCR_CCM ((uint32_t)0x00000010)
```

CLUT Color mode

### 5.173.2.1618 DMA2D\_FGPFCCR\_CM

```
#define DMA2D_FGPFCCR_CM ((uint32_t)0x0000000F)
```

Input color mode CM[3:0]

### 5.173.2.1619 DMA2D\_FGPFCCR\_CM\_0

```
#define DMA2D_FGPFCCR_CM_0 ((uint32_t)0x00000001)
```

Input color mode CM bit 0

**5.173.2.1620 DMA2D\_FGPFCCR\_CM\_1**

```
#define DMA2D_FGPFCCR_CM_1 ((uint32_t)0x00000002)
```

Input color mode CM bit 1

**5.173.2.1621 DMA2D\_FGPFCCR\_CM\_2**

```
#define DMA2D_FGPFCCR_CM_2 ((uint32_t)0x00000004)
```

Input color mode CM bit 2

**5.173.2.1622 DMA2D\_FGPFCCR\_CM\_3 [1/2]**

```
#define DMA2D_FGPFCCR_CM_3 ((uint32_t)0x00000008)
```

Input color mode CM bit 3

**5.173.2.1623 DMA2D\_FGPFCCR\_CM\_3 [2/2]**

```
#define DMA2D_FGPFCCR_CM_3 ((uint32_t)0x00000008)
```

Input color mode CM bit 3

**5.173.2.1624 DMA2D\_FGPFCCR\_CS**

```
#define DMA2D_FGPFCCR_CS ((uint32_t)0x0000FF00)
```

CLUT size

**5.173.2.1625 DMA2D\_FGPFCCR\_START**

```
#define DMA2D_FGPFCCR_START ((uint32_t)0x00000020)
```

Start

**5.173.2.1626 DMA2D\_IFCR\_CAECAF**

```
#define DMA2D_IFCR_CAECAF ((uint32_t)0x00000008)
```

Clears CLUT Access Error Interrupt Flag

**5.173.2.1627 DMA2D\_IFCR\_CCEIF**

```
#define DMA2D_IFCR_CCEIF ((uint32_t)0x00000020)
```

Clears Configuration Error Interrupt Flag

**5.173.2.1628 DMA2D\_IFCR\_CCTCIF**

```
#define DMA2D_IFCR_CCTCIF ((uint32_t)0x00000010)
```

Clears CLUT Transfer Complete Interrupt Flag

**5.173.2.1629 DMA2D\_IFCR\_CTCIF**

```
#define DMA2D_IFCR_CTCIF ((uint32_t)0x00000002)
```

Clears Transfer Complete Interrupt Flag

**5.173.2.1630 DMA2D\_IFCR\_CTEIF**

```
#define DMA2D_IFCR_CTEIF ((uint32_t)0x00000001)
```

Clears Transfer Error Interrupt Flag

**5.173.2.1631 DMA2D\_IFCR\_CTWIF**

```
#define DMA2D_IFCR_CTWIF ((uint32_t)0x00000004)
```

Clears Transfer Watermark Interrupt Flag

**5.173.2.1632 DMA2D\_IFSR\_CCAEIF**

```
#define DMA2D_IFSR_CCAEIF DMA2D_IFCR_CAECIF
```

Clears CLUT Access Error Interrupt Flag

**5.173.2.1633 DMA2D\_IFSR\_CCEIF**

```
#define DMA2D_IFSR_CCEIF DMA2D_IFCR_CCEIF
```

Clears Configuration Error Interrupt Flag

**5.173.2.1634 DMA2D\_IFSR\_CCTCIF**

```
#define DMA2D_IFSR_CCTCIF DMA2D_IFCR_CCTCIF
```

Clears CLUT Transfer Complete Interrupt Flag

**5.173.2.1635 DMA2D\_IFSR\_CTCIF**

```
#define DMA2D_IFSR_CTCIF DMA2D_IFCR_CTCIF
```

Clears Transfer Complete Interrupt Flag

**5.173.2.1636 DMA2D\_IFSR\_CTEIF**

```
#define DMA2D_IFSR_CTEIF DMA2D_IFCR_CTEIF
```

Clears Transfer Error Interrupt Flag

**5.173.2.1637 DMA2D\_IFSR\_CTWIF**

```
#define DMA2D_IFSR_CTWIF DMA2D_IFCR_CTWIF
```

Clears Transfer Watermark Interrupt Flag

**5.173.2.1638 DMA2D\_ISR\_CAEIF**

```
#define DMA2D_ISR_CAEIF ((uint32_t)0x00000008)
```

CLUT Access Error Interrupt Flag

**5.173.2.1639 DMA2D\_ISR\_CEIF**

```
#define DMA2D_ISR_CEIF ((uint32_t)0x00000020)
```

Configuration Error Interrupt Flag

**5.173.2.1640 DMA2D\_ISR\_CTCIF**

```
#define DMA2D_ISR_CTCIF ((uint32_t)0x00000010)
```

CLUT Transfer Complete Interrupt Flag

**5.173.2.1641 DMA2D\_ISR\_TCIF**

```
#define DMA2D_ISR_TCIF ((uint32_t)0x00000002)
```

Transfer Complete Interrupt Flag

**5.173.2.1642 DMA2D\_ISR\_TEIF**

```
#define DMA2D_ISR_TEIF ((uint32_t)0x00000001)
```

Transfer Error Interrupt Flag

**5.173.2.1643 DMA2D\_ISR\_TWIF**

```
#define DMA2D_ISR_TWIF ((uint32_t)0x00000004)
```

Transfer Watermark Interrupt Flag

**5.173.2.1644 DMA2D\_LWR\_LW**

```
#define DMA2D_LWR_LW ((uint32_t)0x0000FFFF)
```

Line Watermark

**5.173.2.1645 DMA2D\_NLR\_NL**

```
#define DMA2D_NLR_NL ((uint32_t)0x0000FFFF)
```

Number of Lines

**5.173.2.1646 DMA2D\_NLR\_PL**

```
#define DMA2D_NLR_PL ((uint32_t)0x3FFF0000)
```

Pixel per Lines

**5.173.2.1647 DMA2D\_OCOLR\_ALPHA\_1**

```
#define DMA2D_OCOLR_ALPHA_1 ((uint32_t)0xFF000000)
```

Alpha Channel Value Mode\_RGB565

**5.173.2.1648 DMA2D\_OCOLR\_ALPHA\_3**

```
#define DMA2D_OCOLR_ALPHA_3 ((uint32_t)0x00008000)
```

Alpha Channel Value Mode\_ARGB4444

**5.173.2.1649 DMA2D\_OCOLR\_ALPHA\_4**

```
#define DMA2D_OCOLR_ALPHA_4 ((uint32_t)0x0000F000)
```

Alpha Channel Value

**5.173.2.1650 DMA2D\_OCOLR\_BLUE\_1**

```
#define DMA2D_OCOLR_BLUE_1 ((uint32_t)0x000000FF)
```

<Mode\_ARGB8888/RGB888 BLUE Value

**5.173.2.1651 DMA2D\_OCOLR\_BLUE\_2**

```
#define DMA2D_OCOLR_BLUE_2 ((uint32_t)0x0000001F)
```

BLUE Value

**5.173.2.1652 DMA2D\_OCOLR\_BLUE\_3**

```
#define DMA2D_OCOLR_BLUE_3 ((uint32_t)0x00000001F)
```

BLUE Value

**5.173.2.1653 DMA2D\_OCOLR\_BLUE\_4**

```
#define DMA2D_OCOLR_BLUE_4 ((uint32_t)0x00000000F)
```

BLUE Value

**5.173.2.1654 DMA2D\_OCOLR\_GREEN\_1**

```
#define DMA2D_OCOLR_GREEN_1 ((uint32_t)0x0000FF00)
```

GREEN Value

**5.173.2.1655 DMA2D\_OCOLR\_GREEN\_2**

```
#define DMA2D_OCOLR_GREEN_2 ((uint32_t)0x000007E0)
```

GREEN Value

**5.173.2.1656 DMA2D\_OCOLR\_GREEN\_3**

```
#define DMA2D_OCOLR_GREEN_3 ((uint32_t)0x000003E0)
```

GREEN Value

**5.173.2.1657 DMA2D\_OCOLR\_GREEN\_4**

```
#define DMA2D_OCOLR_GREEN_4 ((uint32_t)0x000000F0)
```

GREEN Value

**5.173.2.1658 DMA2D\_OCOLR\_RED\_1**

```
#define DMA2D_OCOLR_RED_1 ((uint32_t)0x00FF0000)
```

Red Value

**5.173.2.1659 DMA2D\_OCOLR\_RED\_2**

```
#define DMA2D_OCOLR_RED_2 ((uint32_t)0x0000F800)
```

Red Value Mode\_ARGB1555

**5.173.2.1660 DMA2D\_OCOLR\_RED\_3**

```
#define DMA2D_OCOLR_RED_3 ((uint32_t)0x00007C00)
```

Red Value

**5.173.2.1661 DMA2D\_OCOLR\_RED\_4**

```
#define DMA2D_OCOLR_RED_4 ((uint32_t)0x00000F00)
```

Red Value

**5.173.2.1662 DMA2D\_OMAR\_MA**

```
#define DMA2D_OMAR_MA ((uint32_t)0xFFFFFFFF)
```

Memory Address

### 5.173.2.1663 DMA2D\_OOR\_LO

```
#define DMA2D_OOR_LO ((uint32_t)0x00003FFF)
```

Line Offset

### 5.173.2.1664 DMA2D\_OPFCCR\_CM

```
#define DMA2D_OPFCCR_CM ((uint32_t)0x00000007)
```

Color mode CM[2:0]

### 5.173.2.1665 DMA2D\_OPFCCR\_CM\_0

```
#define DMA2D_OPFCCR_CM_0 ((uint32_t)0x00000001)
```

Color mode CM bit 0

### 5.173.2.1666 DMA2D\_OPFCCR\_CM\_1

```
#define DMA2D_OPFCCR_CM_1 ((uint32_t)0x00000002)
```

Color mode CM bit 1

### 5.173.2.1667 DMA2D\_OPFCCR\_CM\_2

```
#define DMA2D_OPFCCR_CM_2 ((uint32_t)0x00000004)
```

Color mode CM bit 2

### 5.173.2.1668 ETH\_MACCR\_BL

```
#define ETH_MACCR_BL
```

#### Value:

```
          ((uint32_t)0x00000060) /* Back-off limit: random
integer number (r) of slot time delays before rescheduling
a transmission attempt during retries after a
collision: 0 =< r <2^k */
```

### 5.173.2.1669 EXTI\_EMR\_MR0

```
#define EXTI_EMR_MR0 ((uint32_t)0x00000001)
```

Event Mask on line 0

**5.173.2.1670 EXTI\_EMR\_MR1**

```
#define EXTI_EMR_MR1 ((uint32_t)0x00000002)
```

Event Mask on line 1

**5.173.2.1671 EXTI\_EMR\_MR10**

```
#define EXTI_EMR_MR10 ((uint32_t)0x00000400)
```

Event Mask on line 10

**5.173.2.1672 EXTI\_EMR\_MR11**

```
#define EXTI_EMR_MR11 ((uint32_t)0x00000800)
```

Event Mask on line 11

**5.173.2.1673 EXTI\_EMR\_MR12**

```
#define EXTI_EMR_MR12 ((uint32_t)0x00001000)
```

Event Mask on line 12

**5.173.2.1674 EXTI\_EMR\_MR13**

```
#define EXTI_EMR_MR13 ((uint32_t)0x00002000)
```

Event Mask on line 13

**5.173.2.1675 EXTI\_EMR\_MR14**

```
#define EXTI_EMR_MR14 ((uint32_t)0x00004000)
```

Event Mask on line 14

**5.173.2.1676 EXTI\_EMR\_MR15**

```
#define EXTI_EMR_MR15 ((uint32_t)0x00008000)
```

Event Mask on line 15

**5.173.2.1677 EXTI\_EMR\_MR16**

```
#define EXTI_EMR_MR16 ((uint32_t)0x00010000)
```

Event Mask on line 16

**5.173.2.1678 EXTI\_EMR\_MR17**

```
#define EXTI_EMR_MR17 ((uint32_t)0x00020000)
```

Event Mask on line 17

**5.173.2.1679 EXTI\_EMR\_MR18**

```
#define EXTI_EMR_MR18 ((uint32_t)0x00040000)
```

Event Mask on line 18

**5.173.2.1680 EXTI\_EMR\_MR19**

```
#define EXTI_EMR_MR19 ((uint32_t)0x00080000)
```

Event Mask on line 19

**5.173.2.1681 EXTI\_EMR\_MR2**

```
#define EXTI_EMR_MR2 ((uint32_t)0x00000004)
```

Event Mask on line 2

**5.173.2.1682 EXTI\_EMR\_MR23**

```
#define EXTI_EMR_MR23 ((uint32_t)0x00800000)
```

Event Mask on line 19

**5.173.2.1683 EXTI\_EMR\_MR3**

```
#define EXTI_EMR_MR3 ((uint32_t)0x00000008)
```

Event Mask on line 3

**5.173.2.1684 EXTI\_EMR\_MR4**

```
#define EXTI_EMR_MR4 ((uint32_t)0x00000010)
```

Event Mask on line 4

**5.173.2.1685 EXTI\_EMR\_MR5**

```
#define EXTI_EMR_MR5 ((uint32_t)0x00000020)
```

Event Mask on line 5

**5.173.2.1686 EXTI\_EMR\_MR6**

```
#define EXTI_EMR_MR6 ((uint32_t)0x00000040)
```

Event Mask on line 6

**5.173.2.1687 EXTI\_EMR\_MR7**

```
#define EXTI_EMR_MR7 ((uint32_t)0x00000080)
```

Event Mask on line 7

**5.173.2.1688 EXTI\_EMR\_MR8**

```
#define EXTI_EMR_MR8 ((uint32_t)0x00000100)
```

Event Mask on line 8

**5.173.2.1689 EXTI\_EMR\_MR9**

```
#define EXTI_EMR_MR9 ((uint32_t)0x00000200)
```

Event Mask on line 9

**5.173.2.1690 EXTI\_FTSR\_TR0**

```
#define EXTI_FTSR_TR0 ((uint32_t)0x00000001)
```

Falling trigger event configuration bit of line 0

**5.173.2.1691 EXTI\_FTSR\_TR1**

```
#define EXTI_FTSR_TR1 ((uint32_t)0x00000002)
```

Falling trigger event configuration bit of line 1

**5.173.2.1692 EXTI\_FTSR\_TR10**

```
#define EXTI_FTSR_TR10 ((uint32_t)0x00000400)
```

Falling trigger event configuration bit of line 10

**5.173.2.1693 EXTI\_FTSR\_TR11**

```
#define EXTI_FTSR_TR11 ((uint32_t)0x00000800)
```

Falling trigger event configuration bit of line 11

**5.173.2.1694 EXTI\_FTSR\_TR12**

```
#define EXTI_FTSR_TR12 ((uint32_t)0x00001000)
```

Falling trigger event configuration bit of line 12

**5.173.2.1695 EXTI\_FTSR\_TR13**

```
#define EXTI_FTSR_TR13 ((uint32_t)0x00002000)
```

Falling trigger event configuration bit of line 13

**5.173.2.1696 EXTI\_FTSR\_TR14**

```
#define EXTI_FTSR_TR14 ((uint32_t)0x00004000)
```

Falling trigger event configuration bit of line 14

**5.173.2.1697 EXTI\_FTSR\_TR15**

```
#define EXTI_FTSR_TR15 ((uint32_t)0x00008000)
```

Falling trigger event configuration bit of line 15

**5.173.2.1698 EXTI\_FTSR\_TR16**

```
#define EXTI_FTSR_TR16 ((uint32_t)0x00010000)
```

Falling trigger event configuration bit of line 16

**5.173.2.1699 EXTI\_FTSR\_TR17**

```
#define EXTI_FTSR_TR17 ((uint32_t)0x00020000)
```

Falling trigger event configuration bit of line 17

**5.173.2.1700 EXTI\_FTSR\_TR18**

```
#define EXTI_FTSR_TR18 ((uint32_t)0x00040000)
```

Falling trigger event configuration bit of line 18

**5.173.2.1701 EXTI\_FTSR\_TR19**

```
#define EXTI_FTSR_TR19 ((uint32_t)0x00080000)
```

Falling trigger event configuration bit of line 19

**5.173.2.1702 EXTI\_FTSR\_TR2**

```
#define EXTI_FTSR_TR2 ((uint32_t)0x00000004)
```

Falling trigger event configuration bit of line 2

**5.173.2.1703 EXTI\_FTSR\_TR23**

```
#define EXTI_FTSR_TR23 ((uint32_t)0x00800000)
```

Falling trigger event configuration bit of line 23

**5.173.2.1704 EXTI\_FTSR\_TR3**

```
#define EXTI_FTSR_TR3 ((uint32_t)0x00000008)
```

Falling trigger event configuration bit of line 3

**5.173.2.1705 EXTI\_FTSR\_TR4**

```
#define EXTI_FTSR_TR4 ((uint32_t)0x00000010)
```

Falling trigger event configuration bit of line 4

**5.173.2.1706 EXTI\_FTSR\_TR5**

```
#define EXTI_FTSR_TR5 ((uint32_t)0x00000020)
```

Falling trigger event configuration bit of line 5

**5.173.2.1707 EXTI\_FTSR\_TR6**

```
#define EXTI_FTSR_TR6 ((uint32_t)0x00000040)
```

Falling trigger event configuration bit of line 6

**5.173.2.1708 EXTI\_FTSR\_TR7**

```
#define EXTI_FTSR_TR7 ((uint32_t)0x00000080)
```

Falling trigger event configuration bit of line 7

**5.173.2.1709 EXTI\_FTSR\_TR8**

```
#define EXTI_FTSR_TR8 ((uint32_t)0x00000100)
```

Falling trigger event configuration bit of line 8

**5.173.2.1710 EXTI\_FTSR\_TR9**

```
#define EXTI_FTSR_TR9 ((uint32_t)0x00000200)
```

Falling trigger event configuration bit of line 9

**5.173.2.1711 EXTI\_IMR\_MR0**

```
#define EXTI_IMR_MR0 ((uint32_t)0x00000001)
```

Interrupt Mask on line 0

**5.173.2.1712 EXTI\_IMR\_MR1**

```
#define EXTI_IMR_MR1 ((uint32_t)0x00000002)
```

Interrupt Mask on line 1

**5.173.2.1713 EXTI\_IMR\_MR10**

```
#define EXTI_IMR_MR10 ((uint32_t)0x00000400)
```

Interrupt Mask on line 10

**5.173.2.1714 EXTI\_IMR\_MR11**

```
#define EXTI_IMR_MR11 ((uint32_t)0x00000800)
```

Interrupt Mask on line 11

**5.173.2.1715 EXTI\_IMR\_MR12**

```
#define EXTI_IMR_MR12 ((uint32_t)0x00001000)
```

Interrupt Mask on line 12

**5.173.2.1716 EXTI\_IMR\_MR13**

```
#define EXTI_IMR_MR13 ((uint32_t)0x00002000)
```

Interrupt Mask on line 13

**5.173.2.1717 EXTI\_IMR\_MR14**

```
#define EXTI_IMR_MR14 ((uint32_t)0x00004000)
```

Interrupt Mask on line 14

**5.173.2.1718 EXTI\_IMR\_MR15**

```
#define EXTI_IMR_MR15 ((uint32_t)0x00008000)
```

Interrupt Mask on line 15

**5.173.2.1719 EXTI\_IMR\_MR16**

```
#define EXTI_IMR_MR16 ((uint32_t)0x00010000)
```

Interrupt Mask on line 16

**5.173.2.1720 EXTI\_IMR\_MR17**

```
#define EXTI_IMR_MR17 ((uint32_t)0x00020000)
```

Interrupt Mask on line 17

**5.173.2.1721 EXTI\_IMR\_MR18**

```
#define EXTI_IMR_MR18 ((uint32_t)0x00040000)
```

Interrupt Mask on line 18

**5.173.2.1722 EXTI\_IMR\_MR19**

```
#define EXTI_IMR_MR19 ((uint32_t)0x00080000)
```

Interrupt Mask on line 19

**5.173.2.1723 EXTI\_IMR\_MR2**

```
#define EXTI_IMR_MR2 ((uint32_t)0x00000004)
```

Interrupt Mask on line 2

**5.173.2.1724 EXTI\_IMR\_MR23**

```
#define EXTI_IMR_MR23 ((uint32_t)0x00800000)
```

Interrupt Mask on line 23

**5.173.2.1725 EXTI\_IMR\_MR3**

```
#define EXTI_IMR_MR3 ((uint32_t)0x00000008)
```

Interrupt Mask on line 3

**5.173.2.1726 EXTI\_IMR\_MR4**

```
#define EXTI_IMR_MR4 ((uint32_t)0x00000010)
```

Interrupt Mask on line 4

**5.173.2.1727 EXTI\_IMR\_MR5**

```
#define EXTI_IMR_MR5 ((uint32_t)0x00000020)
```

Interrupt Mask on line 5

**5.173.2.1728 EXTI\_IMR\_MR6**

```
#define EXTI_IMR_MR6 ((uint32_t)0x00000040)
```

Interrupt Mask on line 6

**5.173.2.1729 EXTI\_IMR\_MR7**

```
#define EXTI_IMR_MR7 ((uint32_t)0x00000080)
```

Interrupt Mask on line 7

**5.173.2.1730 EXTI\_IMR\_MR8**

```
#define EXTI_IMR_MR8 ((uint32_t)0x00000100)
```

Interrupt Mask on line 8

**5.173.2.1731 EXTI\_IMR\_MR9**

```
#define EXTI_IMR_MR9 ((uint32_t)0x00000200)
```

Interrupt Mask on line 9

**5.173.2.1732 EXTI\_PR\_PR0**

```
#define EXTI_PR_PR0 ((uint32_t)0x00000001)
```

Pending bit for line 0

**5.173.2.1733 EXTI\_PR\_PR1**

```
#define EXTI_PR_PR1 ((uint32_t)0x00000002)
```

Pending bit for line 1

**5.173.2.1734 EXTI\_PR\_PR10**

```
#define EXTI_PR_PR10 ((uint32_t)0x00000400)
```

Pending bit for line 10

**5.173.2.1735 EXTI\_PR\_PR11**

```
#define EXTI_PR_PR11 ((uint32_t)0x00000800)
```

Pending bit for line 11

**5.173.2.1736 EXTI\_PR\_PR12**

```
#define EXTI_PR_PR12 ((uint32_t)0x00001000)
```

Pending bit for line 12

**5.173.2.1737 EXTI\_PR\_PR13**

```
#define EXTI_PR_PR13 ((uint32_t)0x00002000)
```

Pending bit for line 13

**5.173.2.1738 EXTI\_PR\_PR14**

```
#define EXTI_PR_PR14 ((uint32_t)0x00004000)
```

Pending bit for line 14

**5.173.2.1739 EXTI\_PR\_PR15**

```
#define EXTI_PR_PR15 ((uint32_t)0x00008000)
```

Pending bit for line 15

**5.173.2.1740 EXTI\_PR\_PR16**

```
#define EXTI_PR_PR16 ((uint32_t)0x00010000)
```

Pending bit for line 16

**5.173.2.1741 EXTI\_PR\_PR17**

```
#define EXTI_PR_PR17 ((uint32_t)0x00020000)
```

Pending bit for line 17

**5.173.2.1742 EXTI\_PR\_PR18**

```
#define EXTI_PR_PR18 ((uint32_t)0x00040000)
```

Pending bit for line 18

**5.173.2.1743 EXTI\_PR\_PR19**

```
#define EXTI_PR_PR19 ((uint32_t)0x00080000)
```

Pending bit for line 19

**5.173.2.1744 EXTI\_PR\_PR2**

```
#define EXTI_PR_PR2 ((uint32_t)0x00000004)
```

Pending bit for line 2

**5.173.2.1745 EXTI\_PR\_PR23**

```
#define EXTI_PR_PR23 ((uint32_t)0x00800000)
```

Pending bit for line 23

**5.173.2.1746 EXTI\_PR\_PR3**

```
#define EXTI_PR_PR3 ((uint32_t)0x00000008)
```

Pending bit for line 3

**5.173.2.1747 EXTI\_PR\_PR4**

```
#define EXTI_PR_PR4 ((uint32_t)0x00000010)
```

Pending bit for line 4

**5.173.2.1748 EXTI\_PR\_PR5**

```
#define EXTI_PR_PR5 ((uint32_t)0x00000020)
```

Pending bit for line 5

**5.173.2.1749 EXTI\_PR\_PR6**

```
#define EXTI_PR_PR6 ((uint32_t)0x00000040)
```

Pending bit for line 6

**5.173.2.1750 EXTI\_PR\_PR7**

```
#define EXTI_PR_PR7 ((uint32_t)0x00000080)
```

Pending bit for line 7

**5.173.2.1751 EXTI\_PR\_PR8**

```
#define EXTI_PR_PR8 ((uint32_t)0x00000100)
```

Pending bit for line 8

**5.173.2.1752 EXTI\_PR\_PR9**

```
#define EXTI_PR_PR9 ((uint32_t)0x00000200)
```

Pending bit for line 9

**5.173.2.1753 EXTI\_RTSR\_TR0**

```
#define EXTI_RTSR_TR0 ((uint32_t)0x00000001)
```

Rising trigger event configuration bit of line 0

**5.173.2.1754 EXTI\_RTSR\_TR1**

```
#define EXTI_RTSR_TR1 ((uint32_t)0x00000002)
```

Rising trigger event configuration bit of line 1

**5.173.2.1755 EXTI\_RTSR\_TR10**

```
#define EXTI_RTSR_TR10 ((uint32_t)0x00000400)
```

Rising trigger event configuration bit of line 10

**5.173.2.1756 EXTI\_RTSR\_TR11**

```
#define EXTI_RTSR_TR11 ((uint32_t)0x00000800)
```

Rising trigger event configuration bit of line 11

**5.173.2.1757 EXTI\_RTSR\_TR12**

```
#define EXTI_RTSR_TR12 ((uint32_t)0x00001000)
```

Rising trigger event configuration bit of line 12

**5.173.2.1758 EXTI\_RTSR\_TR13**

```
#define EXTI_RTSR_TR13 ((uint32_t)0x00002000)
```

Rising trigger event configuration bit of line 13

**5.173.2.1759 EXTI\_RTSR\_TR14**

```
#define EXTI_RTSR_TR14 ((uint32_t)0x00004000)
```

Rising trigger event configuration bit of line 14

**5.173.2.1760 EXTI\_RTSR\_TR15**

```
#define EXTI_RTSR_TR15 ((uint32_t)0x00008000)
```

Rising trigger event configuration bit of line 15

**5.173.2.1761 EXTI\_RTSR\_TR16**

```
#define EXTI_RTSR_TR16 ((uint32_t)0x00010000)
```

Rising trigger event configuration bit of line 16

**5.173.2.1762 EXTI\_RTSR\_TR17**

```
#define EXTI_RTSR_TR17 ((uint32_t)0x00020000)
```

Rising trigger event configuration bit of line 17

**5.173.2.1763 EXTI\_RTSR\_TR18**

```
#define EXTI_RTSR_TR18 ((uint32_t)0x00040000)
```

Rising trigger event configuration bit of line 18

**5.173.2.1764 EXTI\_RTSR\_TR19**

```
#define EXTI_RTSR_TR19 ((uint32_t)0x00080000)
```

Rising trigger event configuration bit of line 19

**5.173.2.1765 EXTI\_RTSR\_TR2**

```
#define EXTI_RTSR_TR2 ((uint32_t)0x00000004)
```

Rising trigger event configuration bit of line 2

**5.173.2.1766 EXTI\_RTSR\_TR23**

```
#define EXTI_RTSR_TR23 ((uint32_t)0x00800000)
```

Rising trigger event configuration bit of line 23

**5.173.2.1767 EXTI\_RTSR\_TR3**

```
#define EXTI_RTSR_TR3 ((uint32_t)0x00000008)
```

Rising trigger event configuration bit of line 3

**5.173.2.1768 EXTI\_RTSR\_TR4**

```
#define EXTI_RTSR_TR4 ((uint32_t)0x00000010)
```

Rising trigger event configuration bit of line 4

**5.173.2.1769 EXTI\_RTSR\_TR5**

```
#define EXTI_RTSR_TR5 ((uint32_t)0x00000020)
```

Rising trigger event configuration bit of line 5

**5.173.2.1770 EXTI\_RTSR\_TR6**

```
#define EXTI_RTSR_TR6 ((uint32_t)0x00000040)
```

Rising trigger event configuration bit of line 6

**5.173.2.1771 EXTI\_RTSR\_TR7**

```
#define EXTI_RTSR_TR7 ((uint32_t)0x00000080)
```

Rising trigger event configuration bit of line 7

**5.173.2.1772 EXTI\_RTSR\_TR8**

```
#define EXTI_RTSR_TR8 ((uint32_t)0x00000100)
```

Rising trigger event configuration bit of line 8

**5.173.2.1773 EXTI\_RTSR\_TR9**

```
#define EXTI_RTSR_TR9 ((uint32_t)0x00000200)
```

Rising trigger event configuration bit of line 9

**5.173.2.1774 EXTI\_SWIER\_SWIER0**

```
#define EXTI_SWIER_SWIER0 ((uint32_t)0x00000001)
```

Software Interrupt on line 0

**5.173.2.1775 EXTI\_SWIER\_SWIER1**

```
#define EXTI_SWIER_SWIER1 ((uint32_t)0x00000002)
```

Software Interrupt on line 1

**5.173.2.1776 EXTI\_SWIER\_SWIER10**

```
#define EXTI_SWIER_SWIER10 ((uint32_t)0x00000400)
```

Software Interrupt on line 10

**5.173.2.1777 EXTI\_SWIER\_SWIER11**

```
#define EXTI_SWIER_SWIER11 ((uint32_t)0x00000800)
```

Software Interrupt on line 11

**5.173.2.1778 EXTI\_SWIER\_SWIER12**

```
#define EXTI_SWIER_SWIER12 ((uint32_t)0x00001000)
```

Software Interrupt on line 12

**5.173.2.1779 EXTI\_SWIER\_SWIER13**

```
#define EXTI_SWIER_SWIER13 ((uint32_t)0x00002000)
```

Software Interrupt on line 13

**5.173.2.1780 EXTI\_SWIER\_SWIER14**

```
#define EXTI_SWIER_SWIER14 ((uint32_t)0x00004000)
```

Software Interrupt on line 14

**5.173.2.1781 EXTI\_SWIER\_SWIER15**

```
#define EXTI_SWIER_SWIER15 ((uint32_t)0x00008000)
```

Software Interrupt on line 15

**5.173.2.1782 EXTI\_SWIER\_SWIER16**

```
#define EXTI_SWIER_SWIER16 ((uint32_t)0x00010000)
```

Software Interrupt on line 16

**5.173.2.1783 EXTI\_SWIER\_SWIER17**

```
#define EXTI_SWIER_SWIER17 ((uint32_t)0x00020000)
```

Software Interrupt on line 17

**5.173.2.1784 EXTI\_SWIER\_SWIER18**

```
#define EXTI_SWIER_SWIER18 ((uint32_t)0x00040000)
```

Software Interrupt on line 18

**5.173.2.1785 EXTI\_SWIER\_SWIER19**

```
#define EXTI_SWIER_SWIER19 ((uint32_t)0x00080000)
```

Software Interrupt on line 19

**5.173.2.1786 EXTI\_SWIER\_SWIER2**

```
#define EXTI_SWIER_SWIER2 ((uint32_t)0x00000004)
```

Software Interrupt on line 2

**5.173.2.1787 EXTI\_SWIER\_SWIER23**

```
#define EXTI_SWIER_SWIER23 ((uint32_t)0x00800000)
```

Software Interrupt on line 23

**5.173.2.1788 EXTI\_SWIER\_SWIER3**

```
#define EXTI_SWIER_SWIER3 ((uint32_t)0x00000008)
```

Software Interrupt on line 3

**5.173.2.1789 EXTI\_SWIER\_SWIER4**

```
#define EXTI_SWIER_SWIER4 ((uint32_t)0x00000010)
```

Software Interrupt on line 4

**5.173.2.1790 EXTI\_SWIER\_SWIER5**

```
#define EXTI_SWIER_SWIER5 ((uint32_t)0x00000020)
```

Software Interrupt on line 5

**5.173.2.1791 EXTI\_SWIER\_SWIER6**

```
#define EXTI_SWIER_SWIER6 ((uint32_t)0x00000040)
```

Software Interrupt on line 6

**5.173.2.1792 EXTI\_SWIER\_SWIER7**

```
#define EXTI_SWIER_SWIER7 ((uint32_t)0x00000080)
```

Software Interrupt on line 7

**5.173.2.1793 EXTI\_SWIER\_SWIER8**

```
#define EXTI_SWIER_SWIER8 ((uint32_t)0x00000100)
```

Software Interrupt on line 8

**5.173.2.1794 EXTI\_SWIER\_SWIER9**

```
#define EXTI_SWIER_SWIER9 ((uint32_t)0x00000200)
```

Software Interrupt on line 9

**5.173.2.1795 I2C\_CCR\_CCR**

```
#define I2C_CCR_CCR ((uint16_t)0xFFFF)
```

Clock Control Register in Fast/Standard mode (Master mode)

**5.173.2.1796 I2C\_CCR\_DUTY**

```
#define I2C_CCR_DUTY ((uint16_t)0x4000)
```

Fast Mode Duty Cycle

**5.173.2.1797 I2C\_CCR\_FS**

```
#define I2C_CCR_FS ((uint16_t)0x8000)
```

I2C Master Mode Selection

**5.173.2.1798 I2C\_CR1\_ACK**

```
#define I2C_CR1_ACK ((uint16_t)0x0400)
```

Acknowledge Enable

**5.173.2.1799 I2C\_CR1\_ALERT**

```
#define I2C_CR1_ALERT ((uint16_t)0x2000)
```

SMBus Alert

**5.173.2.1800 I2C\_CR1\_ENARP**

```
#define I2C_CR1_ENARP ((uint16_t)0x0010)
```

ARP Enable

**5.173.2.1801 I2C\_CR1\_ENGC**

```
#define I2C_CR1_ENGC ((uint16_t)0x0040)
```

General Call Enable

**5.173.2.1802 I2C\_CR1\_ENPEC**

```
#define I2C_CR1_ENPEC ((uint16_t)0x0020)
```

PEC Enable

**5.173.2.1803 I2C\_CR1\_NOSTRETCH**

```
#define I2C_CR1_NOSTRETCH ((uint16_t)0x0080)
```

Clock Stretching Disable (Slave mode)

**5.173.2.1804 I2C\_CR1\_PE**

```
#define I2C_CR1_PE ((uint16_t)0x0001)
```

Peripheral Enable

**5.173.2.1805 I2C\_CR1\_PEC**

```
#define I2C_CR1_PEC ((uint16_t)0x1000)
```

Packet Error Checking

**5.173.2.1806 I2C\_CR1\_POS**

```
#define I2C_CR1_POS ((uint16_t)0x0800)
```

Acknowledge/PEC Position (for data reception)

**5.173.2.1807 I2C\_CR1\_SMBTYPE**

```
#define I2C_CR1_SMBTYPE ((uint16_t)0x0008)
```

SMBus Type

**5.173.2.1808 I2C\_CR1\_SMBUS**

```
#define I2C_CR1_SMBUS ((uint16_t)0x0002)
```

SMBus Mode

**5.173.2.1809 I2C\_CR1\_START**

```
#define I2C_CR1_START ((uint16_t)0x0100)
```

Start Generation

**5.173.2.1810 I2C\_CR1\_STOP**

```
#define I2C_CR1_STOP ((uint16_t)0x0200)
```

Stop Generation

### 5.173.2.1811 I2C\_CR1\_SWRST

```
#define I2C_CR1_SWRST ((uint16_t)0x8000)
```

Software Reset

### 5.173.2.1812 I2C\_CR2\_DMAEN

```
#define I2C_CR2_DMAEN ((uint16_t)0x0800)
```

DMA Requests Enable

### 5.173.2.1813 I2C\_CR2\_FREQ

```
#define I2C_CR2_FREQ ((uint16_t)0x003F)
```

FREQ[5:0] bits (Peripheral Clock Frequency)

### 5.173.2.1814 I2C\_CR2\_FREQ\_0

```
#define I2C_CR2_FREQ_0 ((uint16_t)0x0001)
```

Bit 0

### 5.173.2.1815 I2C\_CR2\_FREQ\_1

```
#define I2C_CR2_FREQ_1 ((uint16_t)0x0002)
```

Bit 1

### 5.173.2.1816 I2C\_CR2\_FREQ\_2

```
#define I2C_CR2_FREQ_2 ((uint16_t)0x0004)
```

Bit 2

### 5.173.2.1817 I2C\_CR2\_FREQ\_3

```
#define I2C_CR2_FREQ_3 ((uint16_t)0x0008)
```

Bit 3

**5.173.2.1818 I2C\_CR2\_FREQ\_4**

```
#define I2C_CR2_FREQ_4 ((uint16_t)0x0010)
```

Bit 4

**5.173.2.1819 I2C\_CR2\_FREQ\_5**

```
#define I2C_CR2_FREQ_5 ((uint16_t)0x0020)
```

Bit 5

**5.173.2.1820 I2C\_CR2\_ITBUFEN**

```
#define I2C_CR2_ITBUFEN ((uint16_t)0x0400)
```

Buffer Interrupt Enable

**5.173.2.1821 I2C\_CR2\_ITERREN**

```
#define I2C_CR2_ITERREN ((uint16_t)0x0100)
```

Error Interrupt Enable

**5.173.2.1822 I2C\_CR2 ITEVTEN**

```
#define I2C_CR2_ITEVVTEN ((uint16_t)0x0200)
```

Event Interrupt Enable

**5.173.2.1823 I2C\_CR2\_LAST**

```
#define I2C_CR2_LAST ((uint16_t)0x1000)
```

DMA Last Transfer

**5.173.2.1824 I2C\_DR\_DR**

```
#define I2C_DR_DR ((uint8_t)0xFF)
```

8-bit Data Register

**5.173.2.1825 I2C\_FLTR\_ANOFF**

```
#define I2C_FLTR_ANOFF ((uint8_t)0x10)
```

Analog Noise Filter OFF

**5.173.2.1826 I2C\_FLTR\_DNF**

```
#define I2C_FLTR_DNF ((uint8_t)0x0F)
```

Digital Noise Filter

**5.173.2.1827 I2C\_OAR1\_ADD0**

```
#define I2C_OAR1_ADD0 ((uint16_t)0x0001)
```

Bit 0

**5.173.2.1828 I2C\_OAR1\_ADD1**

```
#define I2C_OAR1_ADD1 ((uint16_t)0x0002)
```

Bit 1

**5.173.2.1829 I2C\_OAR1\_ADD1\_7**

```
#define I2C_OAR1_ADD1_7 ((uint16_t)0x00FE)
```

Interface Address

**5.173.2.1830 I2C\_OAR1\_ADD2**

```
#define I2C_OAR1_ADD2 ((uint16_t)0x0004)
```

Bit 2

**5.173.2.1831 I2C\_OAR1\_ADD3**

```
#define I2C_OAR1_ADD3 ((uint16_t)0x0008)
```

Bit 3

**5.173.2.1832 I2C\_OAR1\_ADD4**

```
#define I2C_OAR1_ADD4 ((uint16_t)0x0010)
```

Bit 4

**5.173.2.1833 I2C\_OAR1\_ADD5**

```
#define I2C_OAR1_ADD5 ((uint16_t)0x0020)
```

Bit 5

**5.173.2.1834 I2C\_OAR1\_ADD6**

```
#define I2C_OAR1_ADD6 ((uint16_t)0x0040)
```

Bit 6

**5.173.2.1835 I2C\_OAR1\_ADD7**

```
#define I2C_OAR1_ADD7 ((uint16_t)0x0080)
```

Bit 7

**5.173.2.1836 I2C\_OAR1\_ADD8**

```
#define I2C_OAR1_ADD8 ((uint16_t)0x0100)
```

Bit 8

**5.173.2.1837 I2C\_OAR1\_ADD8\_9**

```
#define I2C_OAR1_ADD8_9 ((uint16_t)0x0300)
```

Interface Address

**5.173.2.1838 I2C\_OAR1\_ADD9**

```
#define I2C_OAR1_ADD9 ((uint16_t)0x0200)
```

Bit 9

**5.173.2.1839 I2C\_OAR1\_ADDMODE**

```
#define I2C_OAR1_ADDMODE ((uint16_t)0x8000)
```

Addressing Mode (Slave mode)

**5.173.2.1840 I2C\_OAR2\_ADD2**

```
#define I2C_OAR2_ADD2 ((uint8_t)0xFE)
```

Interface address

**5.173.2.1841 I2C\_OAR2\_ENDUAL**

```
#define I2C_OAR2_ENDUAL ((uint8_t)0x01)
```

Dual addressing mode enable

**5.173.2.1842 I2C\_SR1\_ADD10**

```
#define I2C_SR1_ADD10 ((uint16_t)0x0008)
```

10-bit header sent (Master mode)

**5.173.2.1843 I2C\_SR1\_ADDR**

```
#define I2C_SR1_ADDR ((uint16_t)0x0002)
```

Address sent (master mode)/matched (slave mode)

**5.173.2.1844 I2C\_SR1\_AF**

```
#define I2C_SR1_AF ((uint16_t)0x0400)
```

Acknowledge Failure

**5.173.2.1845 I2C\_SR1\_ARLO**

```
#define I2C_SR1_ARLO ((uint16_t)0x0200)
```

Arbitration Lost (master mode)

**5.173.2.1846 I2C\_SR1\_BERR**

```
#define I2C_SR1_BERR ((uint16_t)0x0100)
```

Bus Error

**5.173.2.1847 I2C\_SR1\_BTF**

```
#define I2C_SR1_BTF ((uint16_t)0x0004)
```

Byte Transfer Finished

**5.173.2.1848 I2C\_SR1\_OVR**

```
#define I2C_SR1_OVR ((uint16_t)0x0800)
```

Overrun/Underrun

**5.173.2.1849 I2C\_SR1\_PECERR**

```
#define I2C_SR1_PECERR ((uint16_t)0x1000)
```

PEC Error in reception

**5.173.2.1850 I2C\_SR1\_RXNE**

```
#define I2C_SR1_RXNE ((uint16_t)0x0040)
```

Data Register not Empty (receivers)

**5.173.2.1851 I2C\_SR1\_SB**

```
#define I2C_SR1_SB ((uint16_t)0x0001)
```

Start Bit (Master mode)

**5.173.2.1852 I2C\_SR1\_SMBALERT**

```
#define I2C_SR1_SMBALERT ((uint16_t)0x8000)
```

SMBus Alert

**5.173.2.1853 I2C\_SR1\_STOPF**

```
#define I2C_SR1_STOPF ((uint16_t)0x0010)
```

Stop detection (Slave mode)

**5.173.2.1854 I2C\_SR1\_TIMEOUT**

```
#define I2C_SR1_TIMEOUT ((uint16_t)0x4000)
```

Timeout or Tlow Error

**5.173.2.1855 I2C\_SR1\_TXE**

```
#define I2C_SR1_TXE ((uint16_t)0x0080)
```

Data Register Empty (transmitters)

**5.173.2.1856 I2C\_SR2\_BUSY**

```
#define I2C_SR2_BUSY ((uint16_t)0x0002)
```

Bus Busy

**5.173.2.1857 I2C\_SR2\_DUALF**

```
#define I2C_SR2_DUALF ((uint16_t)0x0080)
```

Dual Flag (Slave mode)

**5.173.2.1858 I2C\_SR2\_GENCALL**

```
#define I2C_SR2_GENCALL ((uint16_t)0x0010)
```

General Call Address (Slave mode)

**5.173.2.1859 I2C\_SR2\_MSL**

```
#define I2C_SR2_MSL ((uint16_t)0x0001)
```

Master/Slave

**5.173.2.1860 I2C\_SR2\_PEC**

```
#define I2C_SR2_PEC ((uint16_t)0xFF00)
```

Packet Error Checking Register

**5.173.2.1861 I2C\_SR2\_SMBDEFAULT**

```
#define I2C_SR2_SMBDEFAULT ((uint16_t)0x0020)
```

SMBus Device Default Address (Slave mode)

### 5.173.2.1862 I2C\_SR2\_SMBHOST

```
#define I2C_SR2_SMBHOST ((uint16_t)0x0040)
```

SMBus Host Header (Slave mode)

### 5.173.2.1863 I2C\_SR2\_TRA

```
#define I2C_SR2_TRA ((uint16_t)0x0004)
```

Transmitter/Receiver

### 5.173.2.1864 I2C\_TRISE\_TRISE

```
#define I2C_TRISE_TRISE ((uint8_t)0x3F)
```

Maximum Rise Time in Fast/Standard mode (Master mode)

### 5.173.2.1865 IWDG\_KR\_KEY

```
#define IWDG_KR_KEY ((uint16_t)0xFFFF)
```

Key value (write only, read 0000h)

### 5.173.2.1866 IWDG\_PR\_PR

```
#define IWDG_PR_PR ((uint8_t)0x07)
```

PR[2:0] (Prescaler divider)

### 5.173.2.1867 IWDG\_PR\_PR\_0

```
#define IWDG_PR_PR_0 ((uint8_t)0x01)
```

Bit 0

### 5.173.2.1868 IWDG\_PR\_PR\_1

```
#define IWDG_PR_PR_1 ((uint8_t)0x02)
```

Bit 1

**5.173.2.1869 IWDG\_PR\_PR\_2**

```
#define IWDG_PR_PR_2 ((uint8_t)0x04)
```

Bit 2

**5.173.2.1870 IWDG\_RLR\_RL**

```
#define IWDG_RLR_RL ((uint16_t)0xFFFF)
```

Watchdog counter reload value

**5.173.2.1871 IWDG\_SR\_PVU**

```
#define IWDG_SR_PVU ((uint8_t)0x01)
```

Watchdog prescaler value update

**5.173.2.1872 IWDG\_SR\_RVU**

```
#define IWDG_SR_RVU ((uint8_t)0x02)
```

Watchdog counter reload value update

**5.173.2.1873 LTDC\_AWCR\_AAH**

```
#define LTDC_AWCR_AAH ((uint32_t)0x0000007FF)
```

Accumulated Active heigh

**5.173.2.1874 LTDC\_AWCR\_AAW**

```
#define LTDC_AWCR_AAW ((uint32_t)0x0FFF0000)
```

Accumulated Active Width

**5.173.2.1875 LTDC\_BCCR\_BCBLUE**

```
#define LTDC_BCCR_BCBLUE ((uint32_t)0x000000FF)
```

Background Blue value

**5.173.2.1876 LTDC\_BCCR\_BCGREEN**

```
#define LTDC_BCCR_BCGREEN ((uint32_t)0x0000FF00)
```

Background Green value

**5.173.2.1877 LTDC\_BCCR\_BCRED**

```
#define LTDC_BCCR_BCRED ((uint32_t)0x00FF0000)
```

Background Red value

**5.173.2.1878 LTDC\_BPCR\_AHBP**

```
#define LTDC_BPCR_AHBP ((uint32_t)0xFFFF0000)
```

Accumulated Horizontal Back Porch

**5.173.2.1879 LTDC\_BPCR\_AVBP**

```
#define LTDC_BPCR_AVBP ((uint32_t)0x000007FF)
```

Accumulated Vertical Back Porch

**5.173.2.1880 LTDC\_CDSR\_HDES**

```
#define LTDC_CDSR_HDES ((uint32_t)0x00000002)
```

Horizontal Data Enable Status

**5.173.2.1881 LTDC\_CDSR\_HSYNCS**

```
#define LTDC_CDSR_HSYNCS ((uint32_t)0x00000008)
```

Horizontal Synchronization Status

**5.173.2.1882 LTDC\_CDSR\_VDES**

```
#define LTDC_CDSR_VDES ((uint32_t)0x00000001)
```

Vertical Data Enable Status

**5.173.2.1883 LTDC\_CDSR\_VSYNCS**

```
#define LTDC_CDSR_VSYNCS ((uint32_t)0x00000004)
```

Vertical Synchronization Status

**5.173.2.1884 LTDC\_CPSR\_CXPOS**

```
#define LTDC_CPSR_CXPOS ((uint32_t)0xFFFF0000)
```

Current X Position

**5.173.2.1885 LTDC\_CPSR\_CYPOS**

```
#define LTDC_CPSR_CYPOS ((uint32_t)0x0000FFFF)
```

Current Y Position

**5.173.2.1886 LTDC\_GCR\_DBW**

```
#define LTDC_GCR_DBW ((uint32_t)0x00000070)
```

Dither Blue Width

**5.173.2.1887 LTDC\_GCR\_DEN**

```
#define LTDC_GCR_DEN ((uint32_t)0x00010000)
```

Dither Enable

**5.173.2.1888 LTDC\_GCR\_DEPOL**

```
#define LTDC_GCR_DEPOL ((uint32_t)0x20000000)
```

Data Enable Polarity

**5.173.2.1889 LTDC\_GCR\_DGW**

```
#define LTDC_GCR_DGW ((uint32_t)0x00000700)
```

Dither Green Width

**5.173.2.1890 LTDC\_GCR\_DRW**

```
#define LTDC_GCR_DRW ((uint32_t)0x00007000)
```

Dither Red Width

**5.173.2.1891 LTDC\_GCR\_HSPOL**

```
#define LTDC_GCR_HSPOL ((uint32_t)0x80000000)
```

Horizontal Synchronization Polarity

**5.173.2.1892 LTDC\_GCR\_LTDCEN**

```
#define LTDC_GCR_LTDCEN ((uint32_t)0x00000001)
```

LCD-TFT controller enable bit

**5.173.2.1893 LTDC\_GCR\_PCPOL**

```
#define LTDC_GCR_PCPOL ((uint32_t)0x10000000)
```

Pixel Clock Polarity

**5.173.2.1894 LTDC\_GCR\_VSPOL**

```
#define LTDC_GCR_VSPOL ((uint32_t)0x40000000)
```

Vertical Synchronization Polarity

**5.173.2.1895 LTDC\_ICR\_CFUIF**

```
#define LTDC_ICR_CFUIF ((uint32_t)0x00000002)
```

Clears the FIFO Underrun Interrupt Flag

**5.173.2.1896 LTDC\_ICR\_CLIF**

```
#define LTDC_ICR_CLIF ((uint32_t)0x00000001)
```

Clears the Line Interrupt Flag

**5.173.2.1897 LTDC\_ICR\_CRRIF**

```
#define LTDC_ICR_CRRIF ((uint32_t)0x00000008)
```

Clears Register Reload interrupt Flag

**5.173.2.1898 LTDC\_ICR\_CTERRIF**

```
#define LTDC_ICR_CTERRIF ((uint32_t)0x00000004)
```

Clears the Transfer Error Interrupt Flag

**5.173.2.1899 LTDC\_IER\_FUIE**

```
#define LTDC_IER_FUIE ((uint32_t)0x00000002)
```

FIFO Underrun Interrupt Enable

**5.173.2.1900 LTDC\_IER\_LIE**

```
#define LTDC_IER_LIE ((uint32_t)0x00000001)
```

Line Interrupt Enable

**5.173.2.1901 LTDC\_IER\_RRIE**

```
#define LTDC_IER_RRIE ((uint32_t)0x00000008)
```

Register Reload interrupt enable

**5.173.2.1902 LTDC\_IER\_TERRIE**

```
#define LTDC_IER_TERRIE ((uint32_t)0x00000004)
```

Transfer Error Interrupt Enable

**5.173.2.1903 LTDC\_ISR\_FUIF**

```
#define LTDC_ISR_FUIF ((uint32_t)0x00000002)
```

FIFO Underrun Interrupt Flag

**5.173.2.1904 LTDC\_ISR\_LIF**

```
#define LTDC_ISR_LIF ((uint32_t)0x00000001)
```

Line Interrupt Flag

**5.173.2.1905 LTDC\_ISR\_RRIF**

```
#define LTDC_ISR_RRIF ((uint32_t)0x00000008)
```

Register Reload interrupt Flag

**5.173.2.1906 LTDC\_ISR\_TERRIF**

```
#define LTDC_ISR_TERRIF ((uint32_t)0x00000004)
```

Transfer Error Interrupt Flag

**5.173.2.1907 LTDC\_LIPCR\_LIPOS**

```
#define LTDC_LIPCR_LIPOS ((uint32_t)0x000007FF)
```

Line Interrupt Position

**5.173.2.1908 LTDC\_LxBFCR\_BF1**

```
#define LTDC_LxBFCR_BF1 ((uint32_t)0x00000700)
```

Blending Factor 1

**5.173.2.1909 LTDC\_LxBFCR\_BF2**

```
#define LTDC_LxBFCR_BF2 ((uint32_t)0x00000007)
```

Blending Factor 2

**5.173.2.1910 LTDC\_LxCACR\_CONSTA**

```
#define LTDC_LxCACR_CONSTA ((uint32_t)0x000000FF)
```

Constant Alpha

**5.173.2.1911 LTDC\_LxCFBAR\_CFBADD**

```
#define LTDC_LxCFBAR_CFBADD ((uint32_t)0xFFFFFFFF)
```

Color Frame Buffer Start Address

**5.173.2.1912 LTDC\_LxCFBLNR\_CFBLNBR**

```
#define LTDC_LxCFBLNR_CFBLNBR ((uint32_t)0x000007FF)
```

Frame Buffer Line Number

**5.173.2.1913 LTDC\_LxCFBLR\_CFBLL**

```
#define LTDC_LxCFBLR_CFBLL ((uint32_t)0x00001FFF)
```

Color Frame Buffer Line Length

**5.173.2.1914 LTDC\_LxCFBLR\_CFBP**

```
#define LTDC_LxCFBLR_CFBP ((uint32_t)0x1FFF0000)
```

Color Frame Buffer Pitch in bytes

**5.173.2.1915 LTDC\_LxCKCR\_CKBLUE**

```
#define LTDC_LxCKCR_CKBLUE ((uint32_t)0x000000FF)
```

Color Key Blue value

**5.173.2.1916 LTDC\_LxCKCR\_CKGREEN**

```
#define LTDC_LxCKCR_CKGREEN ((uint32_t)0x0000FF00)
```

Color Key Green value

**5.173.2.1917 LTDC\_LxCKCR\_CKRED**

```
#define LTDC_LxCKCR_CKRED ((uint32_t)0x00FF0000)
```

Color Key Red value

**5.173.2.1918 LTDC\_LxCLUTWR\_BLUE**

```
#define LTDC_LxCLUTWR_BLUE ((uint32_t)0x000000FF)
```

Blue value

**5.173.2.1919 LTDC\_LxCLUTWR\_CLUTADD**

```
#define LTDC_LxCLUTWR_CLUTADD ((uint32_t)0xFF000000)
```

CLUT address

**5.173.2.1920 LTDC\_LxCLUTWR\_GREEN**

```
#define LTDC_LxCLUTWR_GREEN ((uint32_t)0x0000FF00)
```

Green value

**5.173.2.1921 LTDC\_LxCLUTWR\_RED**

```
#define LTDC_LxCLUTWR_RED ((uint32_t)0x00FF0000)
```

Red value

**5.173.2.1922 LTDC\_LxCR\_CLUTEN**

```
#define LTDC_LxCR_CLUTEN ((uint32_t)0x00000010)
```

Color Lockup Table Enable

**5.173.2.1923 LTDC\_LxCR\_COLKEN**

```
#define LTDC_LxCR_COLKEN ((uint32_t)0x00000002)
```

Color Keying Enable

**5.173.2.1924 LTDC\_LxCR\_LEN**

```
#define LTDC_LxCR_LEN ((uint32_t)0x00000001)
```

Layer Enable

**5.173.2.1925 LTDC\_LxDCCR\_DCALPHA**

```
#define LTDC_LxDCCR_DCALPHA ((uint32_t)0xFF000000)
```

Default Color Alpha

**5.173.2.1926 LTDC\_LxDCCR\_DCBLUE**

```
#define LTDC_LxDCCR_DCBLUE ((uint32_t)0x000000FF)
```

Default Color Blue

**5.173.2.1927 LTDC\_LxDCCR\_DCGREEN**

```
#define LTDC_LxDCCR_DCGREEN ((uint32_t)0x0000FF00)
```

Default Color Green

**5.173.2.1928 LTDC\_LxDCCR\_DCRED**

```
#define LTDC_LxDCCR_DCRED ((uint32_t)0x00FF0000)
```

Default Color Red

**5.173.2.1929 LTDC\_LxPFCR\_PF**

```
#define LTDC_LxPFCR_PF ((uint32_t)0x00000007)
```

Pixel Format

**5.173.2.1930 LTDC\_LxWHPCR\_WHSPPOS**

```
#define LTDC_LxWHPCR_WHSPPOS ((uint32_t)0xFFFFF000)
```

Window Horizontal Stop Position

**5.173.2.1931 LTDC\_LxWHPCR\_WHSTPOS**

```
#define LTDC_LxWHPCR_WHSTPOS ((uint32_t)0x00000FFF)
```

Window Horizontal Start Position

**5.173.2.1932 LTDC\_LxWVPCR\_WVSPPOS**

```
#define LTDC_LxWVPCR_WVSPPOS ((uint32_t)0xFFFF0000)
```

Window Vertical Stop Position

**5.173.2.1933 LTDC\_LxWVPCR\_WVSTPOS**

```
#define LTDC_LxWVPCR_WVSTPOS ((uint32_t)0x00000FFF)
```

Window Vertical Start Position

**5.173.2.1934 LTDC\_SRCR\_IMR**

```
#define LTDC_SRCR_IMR ((uint32_t)0x00000001)
```

Immediate Reload

**5.173.2.1935 LTDC\_SRCR\_VBR**

```
#define LTDC_SRCR_VBR ((uint32_t)0x00000002)
```

Vertical Blanking Reload

**5.173.2.1936 LTDC\_SSCR\_HSW**

```
#define LTDC_SSCR_HSW ((uint32_t)0x0FFF0000)
```

Horizontal Synchronization Width

**5.173.2.1937 LTDC\_SSCR\_VSH**

```
#define LTDC_SSCR_VSH ((uint32_t)0x000007FF)
```

Vertical Synchronization Height

**5.173.2.1938 LTDC\_TWCR\_TOTALH**

```
#define LTDC_TWCR_TOTALH ((uint32_t)0x000007FF)
```

Total Heigh

**5.173.2.1939 LTDC\_TWCR\_TOTALW**

```
#define LTDC_TWCR_TOTALW ((uint32_t)0x0FFF0000)
```

Total Width

**5.173.2.1940 PWR\_CR\_ADCDC1**

```
#define PWR_CR_ADCDC1 ((uint32_t)0x000002000)
```

Refer to AN4073 on how to use this bit

**5.173.2.1941 PWR\_CR\_CSBF**

```
#define PWR_CR_CSBF ((uint32_t)0x00000008)
```

Clear Standby Flag

**5.173.2.1942 PWR\_CR\_CWUF**

```
#define PWR_CR_CWUF ((uint32_t)0x00000004)
```

Clear Wakeup Flag

**5.173.2.1943 PWR\_CR\_DBP**

```
#define PWR_CR_DBP ((uint32_t)0x000000100)
```

Disable Backup Domain write protection

**5.173.2.1944 PWR\_CR\_FISSR**

```
#define PWR_CR_FISSR ((uint32_t)0x002000000)
```

Flash Interface Stop while System Run

**5.173.2.1945 PWR\_CR\_FMSSR**

```
#define PWR_CR_FMSSR ((uint32_t)0x001000000)
```

Flash Memory Sleep System Run

**5.173.2.1946 PWR\_CR\_FPDS**

```
#define PWR_CR_FPDS ((uint32_t)0x00000200)
```

Flash power down in Stop mode

**5.173.2.1947 PWR\_CR\_LPDS**

```
#define PWR_CR_LPDS ((uint32_t)0x00000001)
```

Low-Power Deepsleep

**5.173.2.1948 PWR\_CR\_LPLVDS**

```
#define PWR_CR_LPLVDS ((uint32_t)0x00000400)
```

Low-power regulator Low Voltage in Deep Sleep mode

**5.173.2.1949 PWR\_CR\_LPUDS**

```
#define PWR_CR_LPUDS ((uint32_t)0x00000400)
```

Low-Power Regulator in Stop under-drive mode

**5.173.2.1950 PWR\_CR\_MRLVDS**

```
#define PWR_CR_MRLVDS ((uint32_t)0x00000800)
```

Main regulator Low Voltage in Deep Sleep mode

**5.173.2.1951 PWR\_CR\_MRUDS**

```
#define PWR_CR_MRUDS ((uint32_t)0x00000800)
```

Main regulator in Stop under-drive mode

**5.173.2.1952 PWR\_CR\_ODEN**

```
#define PWR_CR_ODEN ((uint32_t)0x00010000)
```

Over Drive enable

**5.173.2.1953 PWR\_CR\_ODSWEN**

```
#define PWR_CR_ODSWEN ((uint32_t)0x00020000)
```

Over Drive switch enabled

**5.173.2.1954 PWR\_CR\_PDDS**

```
#define PWR_CR_PDDS ((uint32_t)0x00000002)
```

Power Down Deepsleep

**5.173.2.1955 PWR\_CR\_PLS**

```
#define PWR_CR_PLS ((uint32_t)0x000000E0)
```

PLS[2:0] bits (PVD Level Selection)

**5.173.2.1956 PWR\_CR\_PLS\_0**

```
#define PWR_CR_PLS_0 ((uint32_t)0x00000020)
```

Bit 0

**5.173.2.1957 PWR\_CR\_PLS\_1**

```
#define PWR_CR_PLS_1 ((uint32_t)0x00000040)
```

Bit 1

**5.173.2.1958 PWR\_CR\_PLS\_2**

```
#define PWR_CR_PLS_2 ((uint32_t)0x00000080)
```

Bit 2 PVD level configuration

**5.173.2.1959 PWR\_CR\_PLS\_LEV0**

```
#define PWR_CR_PLS_LEV0 ((uint32_t)0x00000000)
```

PVD level 0

**5.173.2.1960 PWR\_CR\_PLS\_LEV1**

```
#define PWR_CR_PLS_LEV1 ((uint32_t)0x00000020)
```

PVD level 1

**5.173.2.1961 PWR\_CR\_PLS\_LEV2**

```
#define PWR_CR_PLSLEV2 ((uint32_t)0x00000040)
```

PVD level 2

**5.173.2.1962 PWR\_CR\_PLS\_LEV3**

```
#define PWR_CR_PLSLEV3 ((uint32_t)0x00000060)
```

PVD level 3

**5.173.2.1963 PWR\_CR\_PLS\_LEV4**

```
#define PWR_CR_PLSLEV4 ((uint32_t)0x00000080)
```

PVD level 4

**5.173.2.1964 PWR\_CR\_PLS\_LEV5**

```
#define PWR_CR_PLSLEV5 ((uint32_t)0x000000A0)
```

PVD level 5

**5.173.2.1965 PWR\_CR\_PLS\_LEV6**

```
#define PWR_CR_PLSLEV6 ((uint32_t)0x000000C0)
```

PVD level 6

**5.173.2.1966 PWR\_CR\_PLS\_LEV7**

```
#define PWR_CR_PLSLEV7 ((uint32_t)0x000000E0)
```

PVD level 7

**5.173.2.1967 PWR\_CR\_PVDE**

```
#define PWR_CR_PVDE ((uint32_t)0x00000010)
```

Power Voltage Detector Enable

### 5.173.2.1968 PWR\_CR\_UDEN

```
#define PWR_CR_UDEN ((uint32_t)0x000C0000)
```

Under Drive enable in stop mode

### 5.173.2.1969 PWR\_CR\_UDEN\_0

```
#define PWR_CR_UDEN_0 ((uint32_t)0x00040000)
```

Bit 0

### 5.173.2.1970 PWR\_CR\_UDEN\_1

```
#define PWR_CR_UDEN_1 ((uint32_t)0x00080000)
```

Bit 1

### 5.173.2.1971 PWR\_CR\_VOS

```
#define PWR_CR_VOS ((uint32_t)0x0000C000)
```

VOS[1:0] bits (Regulator voltage scaling output selection)

### 5.173.2.1972 PWR\_CR\_VOS\_0

```
#define PWR_CR_VOS_0 ((uint32_t)0x00004000)
```

Bit 0

### 5.173.2.1973 PWR\_CR\_VOS\_1

```
#define PWR_CR_VOS_1 ((uint32_t)0x00008000)
```

Bit 1

### 5.173.2.1974 PWR\_CSR\_BRE

```
#define PWR_CSR_BRE ((uint32_t)0x00000200)
```

Backup regulator enable

**5.173.2.1975 PWR\_CSR\_BRR**

```
#define PWR_CSR_BRR ((uint32_t)0x00000008)
```

Backup regulator ready

**5.173.2.1976 PWR\_CSR\_EWUP**

```
#define PWR_CSR_EWUP ((uint32_t)0x000000100)
```

Enable WKUP pin

**5.173.2.1977 PWR\_CSR\_ODRDY**

```
#define PWR_CSR_ODRDY ((uint32_t)0x00010000)
```

Over Drive generator ready

**5.173.2.1978 PWR\_CSR\_ODSWRDY**

```
#define PWR_CSR_ODSWRDY ((uint32_t)0x00020000)
```

Over Drive Switch ready

**5.173.2.1979 PWR\_CSR\_PVDO**

```
#define PWR_CSR_PVDO ((uint32_t)0x00000004)
```

PVD Output

**5.173.2.1980 PWR\_CSR\_SBF**

```
#define PWR_CSR_SBF ((uint32_t)0x00000002)
```

Standby Flag

**5.173.2.1981 PWR\_CSR\_UDSWRDY**

```
#define PWR_CSR_UDSWRDY ((uint32_t)0x000C0000)
```

Under Drive ready

**5.173.2.1982 PWR\_CSR\_VOSRDY**

```
#define PWR_CSR_VOSRDY ((uint32_t)0x00004000)
```

Regulator voltage scaling output selection ready

**5.173.2.1983 PWR\_CSR\_WUF**

```
#define PWR_CSR_WUF ((uint32_t)0x00000001)
```

Wakeup Flag

**5.173.2.1984 PWR\_CSR\_WUPP**

```
#define PWR_CSR_WUPP ((uint32_t)0x00000080)
```

WKUP pin Polarity

**5.173.2.1985 RCC\_CFGR\_HPRE**

```
#define RCC_CFGR_HPRE ((uint32_t)0x000000F0)
```

< HPRE configuration HPRE[3:0] bits (AHB prescaler)

**5.173.2.1986 RCC\_CFGR\_HPRE\_0**

```
#define RCC_CFGR_HPRE_0 ((uint32_t)0x00000010)
```

Bit 0

**5.173.2.1987 RCC\_CFGR\_HPRE\_1**

```
#define RCC_CFGR_HPRE_1 ((uint32_t)0x00000020)
```

Bit 1

**5.173.2.1988 RCC\_CFGR\_HPRE\_2**

```
#define RCC_CFGR_HPRE_2 ((uint32_t)0x00000040)
```

Bit 2

**5.173.2.1989 RCC\_CFGR\_HPREF\_3**

```
#define RCC_CFGR_HPREF_3 ((uint32_t)0x00000080)
```

Bit 3

**5.173.2.1990 RCC\_CFGR\_HPREF\_DIV1**

```
#define RCC_CFGR_HPREF_DIV1 ((uint32_t)0x00000000)
```

SYSCLK not divided

**5.173.2.1991 RCC\_CFGR\_HPREF\_DIV128**

```
#define RCC_CFGR_HPREF_DIV128 ((uint32_t)0x000000D0)
```

SYSCLK divided by 128

**5.173.2.1992 RCC\_CFGR\_HPREF\_DIV16**

```
#define RCC_CFGR_HPREF_DIV16 ((uint32_t)0x000000B0)
```

SYSCLK divided by 16

**5.173.2.1993 RCC\_CFGR\_HPREF\_DIV2**

```
#define RCC_CFGR_HPREF_DIV2 ((uint32_t)0x00000080)
```

SYSCLK divided by 2

**5.173.2.1994 RCC\_CFGR\_HPREF\_DIV256**

```
#define RCC_CFGR_HPREF_DIV256 ((uint32_t)0x000000E0)
```

SYSCLK divided by 256

**5.173.2.1995 RCC\_CFGR\_HPREF\_DIV4**

```
#define RCC_CFGR_HPREF_DIV4 ((uint32_t)0x00000090)
```

SYSCLK divided by 4

**5.173.2.1996 RCC\_CFGR\_HPREF\_DIV512**

```
#define RCC_CFGR_HPREF_DIV512 ((uint32_t)0x000000F0)
```

SYSCLK divided by 512

**5.173.2.1997 RCC\_CFGR\_HPRE\_DIV64**

```
#define RCC_CFGR_HPRE_DIV64 ((uint32_t)0x000000C0)
```

SYSCLK divided by 64

**5.173.2.1998 RCC\_CFGR\_HPRE\_DIV8**

```
#define RCC_CFGR_HPRE_DIV8 ((uint32_t)0x000000A0)
```

SYSCLK divided by 8

**5.173.2.1999 RCC\_CFGR\_PPREG1**

```
#define RCC_CFGR_PPREG1 ((uint32_t)0x00001C00)
```

< PPREG1 configuration PRE1[2:0] bits (APB1 prescaler)

**5.173.2.2000 RCC\_CFGR\_PPREG1\_0**

```
#define RCC_CFGR_PPREG1_0 ((uint32_t)0x00000400)
```

Bit 0

**5.173.2.2001 RCC\_CFGR\_PPREG1\_1**

```
#define RCC_CFGR_PPREG1_1 ((uint32_t)0x00000800)
```

Bit 1

**5.173.2.2002 RCC\_CFGR\_PPREG1\_2**

```
#define RCC_CFGR_PPREG1_2 ((uint32_t)0x00001000)
```

Bit 2

**5.173.2.2003 RCC\_CFGR\_PPREG1\_DIV1**

```
#define RCC_CFGR_PPREG1_DIV1 ((uint32_t)0x00000000)
```

HCLK not divided

**5.173.2.2004 RCC\_CFGR\_PPREG1\_DIV16**

```
#define RCC_CFGR_PPREG1_DIV16 ((uint32_t)0x00001C00)
```

HCLK divided by 16 PPREG2 configuration

**5.173.2.2005 RCC\_CFGR\_PPREG1\_DIV2**

```
#define RCC_CFGR_PPREG1_DIV2 ((uint32_t)0x00001000)
```

HCLK divided by 2

**5.173.2.2006 RCC\_CFGR\_PPREG1\_DIV4**

```
#define RCC_CFGR_PPREG1_DIV4 ((uint32_t)0x00001400)
```

HCLK divided by 4

**5.173.2.2007 RCC\_CFGR\_PPREG1\_DIV8**

```
#define RCC_CFGR_PPREG1_DIV8 ((uint32_t)0x00001800)
```

HCLK divided by 8

**5.173.2.2008 RCC\_CFGR\_PPREG2**

```
#define RCC_CFGR_PPREG2 ((uint32_t)0x0000E000)
```

PRE2[2:0] bits (APB2 prescaler)

**5.173.2.2009 RCC\_CFGR\_PPREG2\_0**

```
#define RCC_CFGR_PPREG2_0 ((uint32_t)0x00002000)
```

Bit 0

**5.173.2.2010 RCC\_CFGR\_PPREG2\_1**

```
#define RCC_CFGR_PPREG2_1 ((uint32_t)0x00004000)
```

Bit 1

**5.173.2.2011 RCC\_CFGR\_PPREG2\_2**

```
#define RCC_CFGR_PPREG2_2 ((uint32_t)0x00008000)
```

Bit 2

**5.173.2.2012 RCC\_CFGR\_PPREG2\_DIV1**

```
#define RCC_CFGR_PPREG2_DIV1 ((uint32_t)0x00000000)
```

HCLK not divided

**5.173.2.2013 RCC\_CFGR\_PPREG\_DIV16**

```
#define RCC_CFGR_PPREG_DIV16 ((uint32_t)0x0000E000)
```

HCLK divided by 16 RTCPRE configuration

**5.173.2.2014 RCC\_CFGR\_PPREG\_DIV2**

```
#define RCC_CFGR_PPREG_DIV2 ((uint32_t)0x00008000)
```

HCLK divided by 2

**5.173.2.2015 RCC\_CFGR\_PPREG\_DIV4**

```
#define RCC_CFGR_PPREG_DIV4 ((uint32_t)0x0000A000)
```

HCLK divided by 4

**5.173.2.2016 RCC\_CFGR\_PPREG\_DIV8**

```
#define RCC_CFGR_PPREG_DIV8 ((uint32_t)0x0000C000)
```

HCLK divided by 8

**5.173.2.2017 RCC\_CFGR\_RTCPRE\_4**

```
#define RCC_CFGR_RTCPRE_4 ((uint32_t)0x00100000)
```

MCO1 configuration

**5.173.2.2018 RCC\_CFGR\_SW**

```
#define RCC_CFGR_SW ((uint32_t)0x00000003)
```

< SW configuration SW[1:0] bits (System clock Switch)

**5.173.2.2019 RCC\_CFGR\_SW\_0**

```
#define RCC_CFGR_SW_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.2020 RCC\_CFGR\_SW\_1**

```
#define RCC_CFGR_SW_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.2021 RCC\_CFGR\_SW\_HSE**

```
#define RCC_CFGR_SW_HSE ((uint32_t)0x00000001)
```

HSE selected as system clock

**5.173.2.2022 RCC\_CFGR\_SW\_HSI**

```
#define RCC_CFGR_SW_HSI ((uint32_t)0x00000000)
```

HSI selected as system clock

**5.173.2.2023 RCC\_CFGR\_SW\_PLL**

```
#define RCC_CFGR_SW_PLL ((uint32_t)0x00000002)
```

PLL/PLLP selected as system clock

**5.173.2.2024 RCC\_CFGR\_SWS**

```
#define RCC_CFGR_SWS ((uint32_t)0x0000000C)
```

< SWS configuration SWS[1:0] bits (System Clock Switch Status)

**5.173.2.2025 RCC\_CFGR\_SWS\_0**

```
#define RCC_CFGR_SWS_0 ((uint32_t)0x00000004)
```

Bit 0

**5.173.2.2026 RCC\_CFGR\_SWS\_1**

```
#define RCC_CFGR_SWS_1 ((uint32_t)0x00000008)
```

Bit 1

**5.173.2.2027 RCC\_CFGR\_SWS\_HSE**

```
#define RCC_CFGR_SWS_HSE ((uint32_t)0x00000004)
```

HSE oscillator used as system clock

**5.173.2.2028 RCC\_CFGR\_SWS\_HSI**

```
#define RCC_CFGR_SWS_HSI ((uint32_t)0x00000000)
```

HSI oscillator used as system clock

**5.173.2.2029 RCC\_CFGR\_SWS\_PLL**

```
#define RCC_CFGR_SWS_PLL ((uint32_t)0x00000008)
```

PLL/PLLP used as system clock

**5.173.2.2030 RCC\_CR\_HSICAL\_0**

```
#define RCC_CR_HSICAL_0 ((uint32_t)0x00000100)
```

Bit 0

**5.173.2.2031 RCC\_CR\_HSICAL\_1**

```
#define RCC_CR_HSICAL_1 ((uint32_t)0x00000200)
```

Bit 1

**5.173.2.2032 RCC\_CR\_HSICAL\_2**

```
#define RCC_CR_HSICAL_2 ((uint32_t)0x00000400)
```

Bit 2

**5.173.2.2033 RCC\_CR\_HSICAL\_3**

```
#define RCC_CR_HSICAL_3 ((uint32_t)0x00000800)
```

Bit 3

**5.173.2.2034 RCC\_CR\_HSICAL\_4**

```
#define RCC_CR_HSICAL_4 ((uint32_t)0x00001000)
```

Bit 4

**5.173.2.2035 RCC\_CR\_HSICAL\_5**

```
#define RCC_CR_HSICAL_5 ((uint32_t)0x00002000)
```

Bit 5

**5.173.2.2036 RCC\_CR\_HSICAL\_6**

```
#define RCC_CR_HSICAL_6 ((uint32_t)0x00004000)
```

Bit 6

**5.173.2.2037 RCC\_CR\_HSICAL\_7**

```
#define RCC_CR_HSICAL_7 ((uint32_t)0x00008000)
```

Bit 7

**5.173.2.2038 RCC\_CR\_HSITRIM\_0**

```
#define RCC_CR_HSITRIM_0 ((uint32_t)0x00000008)
```

Bit 0

**5.173.2.2039 RCC\_CR\_HSITRIM\_1**

```
#define RCC_CR_HSITRIM_1 ((uint32_t)0x00000010)
```

Bit 1

**5.173.2.2040 RCC\_CR\_HSITRIM\_2**

```
#define RCC_CR_HSITRIM_2 ((uint32_t)0x00000020)
```

Bit 2

**5.173.2.2041 RCC\_CR\_HSITRIM\_3**

```
#define RCC_CR_HSITRIM_3 ((uint32_t)0x00000040)
```

Bit 3

**5.173.2.2042 RCC\_CR\_HSITRIM\_4**

```
#define RCC_CR_HSITRIM_4 ((uint32_t)0x00000080)
```

Bit 4

**5.173.2.2043 SAI\_GCR\_SYNCIN**

```
#define SAI_GCR_SYNCIN ((uint32_t)0x00000003)
```

SYNCIN[1:0] bits (Synchronization Inputs)

**5.173.2.2044 SAI\_GCR\_SYNCIN\_0**

```
#define SAI_GCR_SYNCIN_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.2045 SAI\_GCR\_SYNCIN\_1**

```
#define SAI_GCR_SYNCIN_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.2046 SAI\_GCR\_SYNCOUT**

```
#define SAI_GCR_SYNCOUT ((uint32_t)0x00000030)
```

SYNCOUT[1:0] bits (Synchronization Outputs)

**5.173.2.2047 SAI\_GCR\_SYNCOUT\_0**

```
#define SAI_GCR_SYNCOUT_0 ((uint32_t)0x00000010)
```

Bit 0

**5.173.2.2048 SAI\_GCR\_SYNCOUT\_1**

```
#define SAI_GCR_SYNCOUT_1 ((uint32_t)0x00000020)
```

Bit 1

**5.173.2.2049 SAI\_xCLRFR\_CAFSDET**

```
#define SAI_xCLRFR_CAFSDET ((uint32_t)0x00000020)
```

Clear Anticipated frame synchronization detection

**5.173.2.2050 SAI\_xCLRFR\_CCNRDY**

```
#define SAI_xCLRFR_CCNRDY ((uint32_t)0x00000010)
```

Clear Codec not ready

**5.173.2.2051 SAI\_xCLRFR\_CFREQ**

```
#define SAI_xCLRFR_CFREQ ((uint32_t)0x00000008)
```

Clear FIFO request

**5.173.2.2052 SAI\_xCLRFR\_CLFSDET**

```
#define SAI_xCLRFR_CLFSDET ((uint32_t)0x00000040)
```

Clear Late frame synchronization detection

**5.173.2.2053 SAI\_xCLRFR\_CMUTEDET**

```
#define SAI_xCLRFR_CMUTEDET ((uint32_t)0x00000002)
```

Clear Mute detection

**5.173.2.2054 SAI\_xCLRFR\_COVRUDR**

```
#define SAI_xCLRFR_COVRUDR ((uint32_t)0x00000001)
```

Clear Overrun underrun

**5.173.2.2055 SAI\_xCLRFR\_CWCKCFG**

```
#define SAI_xCLRFR_CWCKCFG ((uint32_t)0x00000004)
```

Clear Wrong Clock Configuration

**5.173.2.2056 SAI\_xCR1\_CKSTR**

```
#define SAI_xCR1_CKSTR ((uint32_t)0x00000200)
```

ClocK STRobing edge

**5.173.2.2057 SAI\_xCR1\_DMAEN**

```
#define SAI_xCR1_DMAEN ((uint32_t)0x00020000)
```

DMA enable

**5.173.2.2058 SAI\_xCR1\_DS**

```
#define SAI_xCR1_DS ((uint32_t)0x000000E0)
```

DS[1:0] bits (Data Size)

**5.173.2.2059 SAI\_xCR1\_DS\_0**

```
#define SAI_xCR1_DS_0 ((uint32_t)0x00000020)
```

Bit 0

**5.173.2.2060 SAI\_xCR1\_DS\_1**

```
#define SAI_xCR1_DS_1 ((uint32_t)0x00000040)
```

Bit 1

**5.173.2.2061 SAI\_xCR1\_DS\_2**

```
#define SAI_xCR1_DS_2 ((uint32_t)0x00000080)
```

Bit 2

**5.173.2.2062 SAI\_xCR1\_LSBFIRST**

```
#define SAI_xCR1_LSBFIRST ((uint32_t)0x00000100)
```

LSB First Configuration

**5.173.2.2063 SAI\_xCR1\_MCKDIV**

```
#define SAI_xCR1_MCKDIV ((uint32_t)0x00780000)
```

MCKDIV[3:0] (Master ClocK Divider)

**5.173.2.2064 SAI\_xCR1\_MCKDIV\_0**

```
#define SAI_xCR1_MCKDIV_0 ((uint32_t)0x00080000)
```

Bit 0

**5.173.2.2065 SAI\_xCR1\_MCKDIV\_1**

```
#define SAI_xCR1_MCKDIV_1 ((uint32_t)0x00100000)
```

Bit 1

**5.173.2.2066 SAI\_xCR1\_MCKDIV\_2**

```
#define SAI_xCR1_MCKDIV_2 ((uint32_t)0x00200000)
```

Bit 2

**5.173.2.2067 SAI\_xCR1\_MCKDIV\_3**

```
#define SAI_xCR1_MCKDIV_3 ((uint32_t)0x00400000)
```

Bit 3

**5.173.2.2068 SAI\_xCR1\_MODE**

```
#define SAI_xCR1_MODE ((uint32_t)0x00000003)
```

MODE[1:0] bits (Audio Block Mode)

**5.173.2.2069 SAI\_xCR1\_MODE\_0**

```
#define SAI_xCR1_MODE_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.2070 SAI\_xCR1\_MODE\_1**

```
#define SAI_xCR1_MODE_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.2071 SAI\_xCR1\_MONO**

```
#define SAI_xCR1_MONO ((uint32_t)0x00001000)
```

Mono mode

**5.173.2.2072 SAI\_xCR1\_NODIV**

```
#define SAI_xCR1_NODIV ((uint32_t)0x00080000)
```

No Divider Configuration

**5.173.2.2073 SAI\_xCR1\_OUTDRIV**

```
#define SAI_xCR1_OUTDRIV ((uint32_t)0x00002000)
```

Output Drive

**5.173.2.2074 SAI\_xCR1\_PRTCFG**

```
#define SAI_xCR1_PRTCFG ((uint32_t)0x0000000C)
```

PRTCFG[1:0] bits (Protocol Configuration)

**5.173.2.2075 SAI\_xCR1\_PRTCFG\_0**

```
#define SAI_xCR1_PRTCFG_0 ((uint32_t)0x00000004)
```

Bit 0

**5.173.2.2076 SAI\_xCR1\_PRTCFG\_1**

```
#define SAI_xCR1_PRTCFG_1 ((uint32_t)0x00000008)
```

Bit 1

**5.173.2.2077 SAI\_xCR1\_SAIEN**

```
#define SAI_xCR1_SAIEN ((uint32_t)0x00010000)
```

Audio Block enable

**5.173.2.2078 SAI\_xCR1\_SYNCEN**

```
#define SAI_xCR1_SYNCEN ((uint32_t)0x00000C00)
```

SYNCEN[1:0](SYNChronization ENable)

**5.173.2.2079 SAI\_xCR1\_SYNCEN\_0**

```
#define SAI_xCR1_SYNCEN_0 ((uint32_t)0x00000400)
```

Bit 0

**5.173.2.2080 SAI\_xCR1\_SYNCEN\_1**

```
#define SAI_xCR1_SYNCEN_1 ((uint32_t)0x00000800)
```

Bit 1

**5.173.2.2081 SAI\_xCR2\_COMP**

```
#define SAI_xCR2_COMP ((uint32_t)0x0000C000)
```

COMP[1:0] (Companding mode)

**5.173.2.2082 SAI\_xCR2\_COMP\_0**

```
#define SAI_xCR2_COMP_0 ((uint32_t)0x00004000)
```

Bit 0

**5.173.2.2083 SAI\_xCR2\_COMP\_1**

```
#define SAI_xCR2_COMP_1 ((uint32_t)0x00008000)
```

Bit 1

**5.173.2.2084 SAI\_xCR2\_CPL**

```
#define SAI_xCR2_CPL ((uint32_t)0x00002000)
```

Complement Bit

**5.173.2.2085 SAI\_xCR2\_FFLUSH**

```
#define SAI_xCR2_FFLUSH ((uint32_t)0x00000008)
```

Fifo FLUSH

**5.173.2.2086 SAI\_xCR2\_FTH**

```
#define SAI_xCR2_FTH ((uint32_t)0x00000003)

FTH[1:0](Fifo THreshold)
```

**5.173.2.2087 SAI\_xCR2\_FTH\_0**

```
#define SAI_xCR2_FTH_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.2088 SAI\_xCR2\_FTH\_1**

```
#define SAI_xCR2_FTH_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.2089 SAI\_xCR2\_MUTE**

```
#define SAI_xCR2_MUTE ((uint32_t)0x00000020)
```

Mute mode

**5.173.2.2090 SAI\_xCR2\_MUTECNT**

```
#define SAI_xCR2_MUTECNT ((uint32_t)0x00001F80)
```

MUTECNT[5:0] (MUTE counter)

**5.173.2.2091 SAI\_xCR2\_MUTECNT\_0**

```
#define SAI_xCR2_MUTECNT_0 ((uint32_t)0x00000080)
```

Bit 0

**5.173.2.2092 SAI\_xCR2\_MUTECNT\_1**

```
#define SAI_xCR2_MUTECNT_1 ((uint32_t)0x00000100)
```

Bit 1

**5.173.2.2093 SAI\_xCR2\_MUTECNT\_2**

```
#define SAI_xCR2_MUTECNT_2 ((uint32_t)0x00000200)
```

Bit 2

**5.173.2.2094 SAI\_xCR2\_MUTECNT\_3**

```
#define SAI_xCR2_MUTECNT_3 ((uint32_t)0x00000400)
```

Bit 3

**5.173.2.2095 SAI\_xCR2\_MUTECNT\_4**

```
#define SAI_xCR2_MUTECNT_4 ((uint32_t)0x00000800)
```

Bit 4

**5.173.2.2096 SAI\_xCR2\_MUTECNT\_5**

```
#define SAI_xCR2_MUTECNT_5 ((uint32_t)0x00001000)
```

Bit 5

**5.173.2.2097 SAI\_xCR2\_MUTEVAL**

```
#define SAI_xCR2_MUTEVAL ((uint32_t)0x00000040)
```

Muate value

**5.173.2.2098 SAI\_xCR2\_TRIS**

```
#define SAI_xCR2_TRIS ((uint32_t)0x00000010)
```

TRISState Management on data line

**5.173.2.2099 SAI\_xFRCR\_FRL**

```
#define SAI_xFRCR_FRL ((uint32_t)0x000000FF)
```

FRL[1:0](Frame length)

**5.173.2.2100 SAI\_xFRCR\_FRL\_0**

```
#define SAI_xFRCR_FRL_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.2101 SAI\_xFRCR\_FRL\_1**

```
#define SAI_xFRCR_FRL_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.2102 SAI\_xFRCR\_FRL\_2**

```
#define SAI_xFRCR_FRL_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.2103 SAI\_xFRCR\_FRL\_3**

```
#define SAI_xFRCR_FRL_3 ((uint32_t)0x00000008)
```

Bit 3

**5.173.2.2104 SAI\_xFRCR\_FRL\_4**

```
#define SAI_xFRCR_FRL_4 ((uint32_t)0x00000010)
```

Bit 4

**5.173.2.2105 SAI\_xFRCR\_FRL\_5**

```
#define SAI_xFRCR_FRL_5 ((uint32_t)0x00000020)
```

Bit 5

**5.173.2.2106 SAI\_xFRCR\_FRL\_6**

```
#define SAI_xFRCR_FRL_6 ((uint32_t)0x00000040)
```

Bit 6

**5.173.2.2107 SAI\_xFRCR\_FRL\_7**

```
#define SAI_xFRCR_FRL_7 ((uint32_t)0x00000080)
```

Bit 7

**5.173.2.2108 SAI\_xFRCR\_FSALL**

```
#define SAI_xFRCR_FSALL ((uint32_t)0x00007F00)
```

FRL[1:0] (Frame synchronization active level length)

**5.173.2.2109 SAI\_xFRCR\_FSALL\_0**

```
#define SAI_xFRCR_FSALL_0 ((uint32_t)0x00000100)
```

Bit 0

**5.173.2.2110 SAI\_xFRCR\_FSALL\_1**

```
#define SAI_xFRCR_FSALL_1 ((uint32_t)0x00000200)
```

Bit 1

**5.173.2.2111 SAI\_xFRCR\_FSALL\_2**

```
#define SAI_xFRCR_FSALL_2 ((uint32_t)0x00000400)
```

Bit 2

**5.173.2.2112 SAI\_xFRCR\_FSALL\_3**

```
#define SAI_xFRCR_FSALL_3 ((uint32_t)0x00000800)
```

Bit 3

**5.173.2.2113 SAI\_xFRCR\_FSALL\_4**

```
#define SAI_xFRCR_FSALL_4 ((uint32_t)0x00001000)
```

Bit 4

**5.173.2.2114 SAI\_xFRCR\_FSALL\_5**

```
#define SAI_xFRCR_FSALL_5 ((uint32_t)0x00002000)
```

Bit 5

**5.173.2.2115 SAI\_xFRCR\_FSALL\_6**

```
#define SAI_xFRCR_FSALL_6 ((uint32_t)0x00004000)
```

Bit 6

**5.173.2.2116 SAI\_xFRCR\_FSDEF**

```
#define SAI_xFRCR_FSDEF ((uint32_t)0x00010000)
```

Frame Synchronization Definition

**5.173.2.2117 SAI\_xFRCR\_FSOFF**

```
#define SAI_xFRCR_FSOFF ((uint32_t)0x00040000)
```

Frame Synchronization OFFset

**5.173.2.2118 SAI\_xFRCR\_FSPOL**

```
#define SAI_xFRCR_FSPOL ((uint32_t)0x00020000)
```

Frame Synchronization POLarity

**5.173.2.2119 SAI\_xIMR\_AFSDETIE**

```
#define SAI_xIMR_AFSDETIE ((uint32_t)0x00000020)
```

Anticipated frame synchronization detection interrupt enable

**5.173.2.2120 SAI\_xIMR\_CNRDYIE**

```
#define SAI_xIMR_CNRDYIE ((uint32_t)0x00000010)
```

Codec not ready interrupt enable

**5.173.2.2121 SAI\_xIMR\_FREQIE**

```
#define SAI_xIMR_FREQIE ((uint32_t)0x00000008)
```

FIFO request interrupt enable

**5.173.2.2122 SAI\_xIMR\_LFSDETIE**

```
#define SAI_xIMR_LFSDETIE ((uint32_t)0x00000040)
```

Late frame synchronization detection interrupt enable

**5.173.2.2123 SAI\_xIMR\_MUTEDETIE**

```
#define SAI_xIMR_MUTEDETIE ((uint32_t)0x00000002)
```

Mute detection interrupt enable

**5.173.2.2124 SAI\_xIMR\_OVRUDRIE**

```
#define SAI_xIMR_OVRUDRIE ((uint32_t)0x00000001)
```

Overrun underrun interrupt enable

**5.173.2.2125 SAI\_xIMR\_WCKCFGIE**

```
#define SAI_xIMR_WCKCFGIE ((uint32_t)0x00000004)
```

Wrong Clock Configuration interrupt enable

**5.173.2.2126 SAI\_xSLOTR\_FBOFF**

```
#define SAI_xSLOTR_FBOFF ((uint32_t)0x0000001F)
```

FRL[4:0](First Bit Offset)

**5.173.2.2127 SAI\_xSLOTR\_FBOFF\_0**

```
#define SAI_xSLOTR_FBOFF_0 ((uint32_t)0x00000001)
```

Bit 0

**5.173.2.2128 SAI\_xSLOTR\_FBOFF\_1**

```
#define SAI_xSLOTR_FBOFF_1 ((uint32_t)0x00000002)
```

Bit 1

**5.173.2.2129 SAI\_xSLOTR\_FBOFF\_2**

```
#define SAI_xSLOTR_FBOFF_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.2130 SAI\_xSLOTR\_FBOFF\_3**

```
#define SAI_xSLOTR_FBOFF_3 ((uint32_t)0x00000008)
```

Bit 3

**5.173.2.2131 SAI\_xSLOTR\_FBOFF\_4**

```
#define SAI_xSLOTR_FBOFF_4 ((uint32_t)0x00000010)
```

Bit 4

**5.173.2.2132 SAI\_xSLOTR\_NBSLOT**

```
#define SAI_xSLOTR_NBSLOT ((uint32_t)0x00000F00)
```

NBSLOT[3:0] (Number of Slot in audio Frame)

**5.173.2.2133 SAI\_xSLOTR\_NBSLOT\_0**

```
#define SAI_xSLOTR_NBSLOT_0 ((uint32_t)0x00000100)
```

Bit 0

**5.173.2.2134 SAI\_xSLOTR\_NBSLOT\_1**

```
#define SAI_xSLOTR_NBSLOT_1 ((uint32_t)0x00000200)
```

Bit 1

**5.173.2.2135 SAI\_xSLOTR\_NBSLOT\_2**

```
#define SAI_xSLOTR_NBSLOT_2 ((uint32_t)0x00000400)
```

Bit 2

**5.173.2.2136 SAI\_xSLOTR\_NBSLOT\_3**

```
#define SAI_xSLOTR_NBSLOT_3 ((uint32_t)0x00000800)
```

Bit 3

**5.173.2.2137 SAI\_xSLOTR\_SLOTEN**

```
#define SAI_xSLOTR_SLOTEN ((uint32_t)0xFFFF0000)
```

SLOTEN[15:0] (Slot Enable)

**5.173.2.2138 SAI\_xSLOTR\_SLOTSZ**

```
#define SAI_xSLOTR_SLOTSZ ((uint32_t)0x000000C0)
```

SLOTSZ[1:0] (Slot size)

**5.173.2.2139 SAI\_xSLOTR\_SLOTSZ\_0**

```
#define SAI_xSLOTR_SLOTSZ_0 ((uint32_t)0x00000040)
```

Bit 0

**5.173.2.2140 SAI\_xSLOTR\_SLOTSZ\_1**

```
#define SAI_xSLOTR_SLOTSZ_1 ((uint32_t)0x00000080)
```

Bit 1

**5.173.2.2141 SAI\_xSR\_AFSDET**

```
#define SAI_xSR_AFSDET ((uint32_t)0x00000020)
```

Anticipated frame synchronization detection

**5.173.2.2142 SAI\_xSR\_CNRDY**

```
#define SAI_xSR_CNRDY ((uint32_t)0x00000010)
```

Codec not ready

**5.173.2.2143 SAI\_xSR\_FLVL**

```
#define SAI_xSR_FLVL ((uint32_t)0x00070000)
```

FLVL[2:0] (FIFO Level Threshold)

**5.173.2.2144 SAI\_xSR\_FLVL\_0**

```
#define SAI_xSR_FLVL_0 ((uint32_t)0x00010000)
```

Bit 0

**5.173.2.2145 SAI\_xSR\_FLVL\_1**

```
#define SAI_xSR_FLVL_1 ((uint32_t)0x00020000)
```

Bit 1

**5.173.2.2146 SAI\_xSR\_FLVL\_2**

```
#define SAI_xSR_FLVL_2 ((uint32_t)0x00030000)
```

Bit 2

**5.173.2.2147 SAI\_xSR\_FREQ**

```
#define SAI_xSR_FREQ ((uint32_t)0x00000008)
```

FIFO request

**5.173.2.2148 SAI\_xSR\_LFSDET**

```
#define SAI_xSR_LFSDET ((uint32_t)0x00000040)
```

Late frame synchronization detection

**5.173.2.2149 SAI\_xSR\_MUTEDET**

```
#define SAI_xSR_MUTEDET ((uint32_t)0x00000002)
```

Mute detection

**5.173.2.2150 SAI\_xSR\_OVRUDR**

```
#define SAI_xSR_OVRUDR ((uint32_t)0x00000001)
```

Overrun underrun

**5.173.2.2151 SAI\_xSR\_WCKCFG**

```
#define SAI_xSR_WCKCFG ((uint32_t)0x00000004)
```

Wrong Clock Configuration

**5.173.2.2152 SDIO\_ARG\_CMDARG**

```
#define SDIO_ARG_CMDARG ((uint32_t)0xFFFFFFFF)
```

Command argument

**5.173.2.2153 SDIO\_CLKCR\_BYPASS**

```
#define SDIO_CLKCR_BYPASS ((uint16_t)0x0400)
```

Clock divider bypass enable bit

**5.173.2.2154 SDIO\_CLKCR\_CLKDIV**

```
#define SDIO_CLKCR_CLKDIV ((uint16_t)0x00FF)
```

Clock divide factor

**5.173.2.2155 SDIO\_CLKCR\_CLKEN**

```
#define SDIO_CLKCR_CLKEN ((uint16_t)0x0100)
```

Clock enable bit

**5.173.2.2156 SDIO\_CLKCR\_HWFC\_EN**

```
#define SDIO_CLKCR_HWFC_EN ((uint16_t)0x4000)
```

HW Flow Control enable

**5.173.2.2157 SDIO\_CLKCR\_NEGEDGE**

```
#define SDIO_CLKCR_NEGEDGE ((uint16_t)0x2000)
```

SDIO\_CK dephasing selection bit

**5.173.2.2158 SDIO\_CLKCR\_PWRSAV**

```
#define SDIO_CLKCR_PWRSAV ((uint16_t)0x0200)
```

Power saving configuration bit

**5.173.2.2159 SDIO\_CLKCR\_WIDBUS**

```
#define SDIO_CLKCR_WIDBUS ((uint16_t)0x1800)
```

WIDBUS[1:0] bits (Wide bus mode enable bit)

**5.173.2.2160 SDIO\_CLKCR\_WIDBUS\_0**

```
#define SDIO_CLKCR_WIDBUS_0 ((uint16_t)0x0800)
```

Bit 0

**5.173.2.2161 SDIO\_CLKCR\_WIDBUS\_1**

```
#define SDIO_CLKCR_WIDBUS_1 ((uint16_t)0x1000)
```

Bit 1

**5.173.2.2162 SDIO\_CMD\_CEATACMD**

```
#define SDIO_CMD_CEATACMD ((uint16_t)0x4000)
```

CE-ATA command

**5.173.2.2163 SDIO\_CMD\_CMDINDEX**

```
#define SDIO_CMD_CMDINDEX ((uint16_t)0x003F)
```

Command Index

**5.173.2.2164 SDIO\_CMD\_CPSMEN**

```
#define SDIO_CMD_CPSMEN ((uint16_t)0x0400)
```

Command path state machine (CPSM) Enable bit

**5.173.2.2165 SDIO\_CMD\_ENCMDCOMPL**

```
#define SDIO_CMD_ENCMDCOMPL ((uint16_t)0x1000)
```

Enable CMD completion

**5.173.2.2166 SDIO\_CMD\_NIEN**

```
#define SDIO_CMD_NIEN ((uint16_t)0x2000)
```

Not Interrupt Enable

**5.173.2.2167 SDIO\_CMD\_SDIOSUSPEND**

```
#define SDIO_CMD_SDIOSUSPEND ((uint16_t)0x0800)
```

SD I/O suspend command

**5.173.2.2168 SDIO\_CMD\_WAITINT**

```
#define SDIO_CMD_WAITINT ((uint16_t)0x0100)
```

CPSM Waits for Interrupt Request

**5.173.2.2169 SDIO\_CMD\_WAITPEND**

```
#define SDIO_CMD_WAITPEND ((uint16_t)0x0200)
```

CPSM Waits for ends of data transfer (CmdPend internal signal)

**5.173.2.2170 SDIO\_CMD\_WAITRESP**

```
#define SDIO_CMD_WAITRESP ((uint16_t)0x00C0)
```

WAITRESP[1:0] bits (Wait for response bits)

**5.173.2.2171 SDIO\_CMD\_WAITRESP\_0**

```
#define SDIO_CMD_WAITRESP_0 ((uint16_t)0x0040)
```

Bit 0

**5.173.2.2172 SDIO\_CMD\_WAITRESP\_1**

```
#define SDIO_CMD_WAITRESP_1 ((uint16_t)0x0080)
```

Bit 1

**5.173.2.2173 SDIO\_DCOUNT\_DATACOUNT**

```
#define SDIO_DCOUNT_DATACOUNT ((uint32_t)0x01FFFFFF)
```

Data count value

**5.173.2.2174 SDIO\_DCTRL\_DBLOCKSIZE**

```
#define SDIO_DCTRL_DBLOCKSIZE ((uint16_t)0x00F0)
```

DBLOCKSIZE[3:0] bits (Data block size)

**5.173.2.2175 SDIO\_DCTRL\_DBLOCKSIZE\_0**

```
#define SDIO_DCTRL_DBLOCKSIZE_0 ((uint16_t)0x0010)
```

Bit 0

**5.173.2.2176 SDIO\_DCTRL\_DBLOCKSIZE\_1**

```
#define SDIO_DCTRL_DBLOCKSIZE_1 ((uint16_t)0x0020)
```

Bit 1

**5.173.2.2177 SDIO\_DCTRL\_DBLOCKSIZE\_2**

```
#define SDIO_DCTRL_DBLOCKSIZE_2 ((uint16_t)0x0040)
```

Bit 2

**5.173.2.2178 SDIO\_DCTRL\_DBLOCKSIZE\_3**

```
#define SDIO_DCTRL_DBLOCKSIZE_3 ((uint16_t)0x0080)
```

Bit 3

**5.173.2.2179 SDIO\_DCTRL\_DMAEN**

```
#define SDIO_DCTRL_DMAEN ((uint16_t)0x0008)
```

DMA enabled bit

**5.173.2.2180 SDIO\_DCTRL\_DTDIR**

```
#define SDIO_DCTRL_DTDIR ((uint16_t)0x0002)
```

Data transfer direction selection

**5.173.2.2181 SDIO\_DCTRL\_DTEN**

```
#define SDIO_DCTRL_DTEN ((uint16_t)0x0001)
```

Data transfer enabled bit

**5.173.2.2182 SDIO\_DCTRL\_DTMODE**

```
#define SDIO_DCTRL_DTMODE ((uint16_t)0x0004)
```

Data transfer mode selection

**5.173.2.2183 SDIO\_DCTRL\_RWMOD**

```
#define SDIO_DCTRL_RWMOD ((uint16_t)0x0400)
```

Read wait mode

**5.173.2.2184 SDIO\_DCTRL\_RWSTART**

```
#define SDIO_DCTRL_RWSTART ((uint16_t)0x0100)
```

Read wait start

**5.173.2.2185 SDIO\_DCTRL\_RWSTOP**

```
#define SDIO_DCTRL_RWSTOP ((uint16_t)0x0200)
```

Read wait stop

**5.173.2.2186 SDIO\_DCTRL\_SDIOEN**

```
#define SDIO_DCTRL_SDIOEN ((uint16_t)0x0800)
```

SD I/O enable functions

**5.173.2.2187 SDIO\_DLEN\_DATALENGTH**

```
#define SDIO_DLEN_DATALENGTH ((uint32_t)0x01FFFFFF)
```

Data length value

**5.173.2.2188 SDIO\_DTIMER\_DATATIME**

```
#define SDIO_DTIMER_DATATIME ((uint32_t)0xFFFFFFFF)
```

Data timeout period.

**5.173.2.2189 SDIO\_FIFO\_FIFODATA**

```
#define SDIO_FIFO_FIFODATA ((uint32_t)0xFFFFFFFF)
```

Receive and transmit FIFO data

**5.173.2.2190 SDIO\_FIFOCNT\_FIFOCOUNT**

```
#define SDIO_FIFOCNT_FIFOCOUNT ((uint32_t)0x00FFFFFF)
```

Remaining number of words to be written to or read from the FIFO

**5.173.2.2191 SDIO\_ICR\_CCRCFAILC**

```
#define SDIO_ICR_CCRCFAILC ((uint32_t)0x00000001)
```

CCRCFAIL flag clear bit

**5.173.2.2192 SDIO\_ICR\_CEATAENDC**

```
#define SDIO_ICR_CEATAENDC ((uint32_t)0x00800000)
```

CEATAEND flag clear bit

**5.173.2.2193 SDIO\_ICR\_CMDRENDC**

```
#define SDIO_ICR_CMDRENDC ((uint32_t)0x00000040)
```

CMDREN flag clear bit

**5.173.2.2194 SDIO\_ICR\_CMDSENTC**

```
#define SDIO_ICR_CMDSENTC ((uint32_t)0x00000080)
```

CMDSENT flag clear bit

**5.173.2.2195 SDIO\_ICR\_CTIMEOUTC**

```
#define SDIO_ICR_CTIMEOUTC ((uint32_t)0x00000004)
```

CTIMEOUT flag clear bit

**5.173.2.2196 SDIO\_ICR\_DATAENDC**

```
#define SDIO_ICR_DATAENDC ((uint32_t)0x00000100)
```

DATAEND flag clear bit

**5.173.2.2197 SDIO\_ICR\_DBCKENDC**

```
#define SDIO_ICR_DBCKENDC ((uint32_t)0x00000400)
```

DBCKEND flag clear bit

**5.173.2.2198 SDIO\_ICR\_DCRCFAILC**

```
#define SDIO_ICR_DCRCFAILC ((uint32_t)0x00000002)
```

DCRCFAIL flag clear bit

**5.173.2.2199 SDIO\_ICR\_DTIMEOUTC**

```
#define SDIO_ICR_DTIMEOUTC ((uint32_t)0x00000008)
```

DTIMEOUT flag clear bit

**5.173.2.2200 SDIO\_ICR\_RXOVERRC**

```
#define SDIO_ICR_RXOVERRC ((uint32_t)0x00000020)
```

RXOVERR flag clear bit

**5.173.2.2201 SDIO\_ICR\_SDIOITC**

```
#define SDIO_ICR_SDIOITC ((uint32_t)0x00400000)
```

SDIOIT flag clear bit

**5.173.2.2202 SDIO\_ICR\_STBITERRC**

```
#define SDIO_ICR_STBITERRC ((uint32_t)0x000000200)
```

STBITERR flag clear bit

**5.173.2.2203 SDIO\_ICR\_TXUNDERRC**

```
#define SDIO_ICR_TXUNDERRC ((uint32_t)0x000000010)
```

TXUNDERR flag clear bit

**5.173.2.2204 SDIO\_MASK\_CCRCFAILIE**

```
#define SDIO_MASK_CCRCFAILIE ((uint32_t)0x00000001)
```

Command CRC Fail Interrupt Enable

**5.173.2.2205 SDIO\_MASK\_CEATAENDIE**

```
#define SDIO_MASK_CEATAENDIE ((uint32_t)0x00800000)
```

CE-ATA command completion signal received Interrupt Enable

**5.173.2.2206 SDIO\_MASK\_CMDACTIE**

```
#define SDIO_MASK_CMDACTIE ((uint32_t)0x000000800)
```

CCommand Acting Interrupt Enable

**5.173.2.2207 SDIO\_MASK\_CMDRENDIE**

```
#define SDIO_MASK_CMDRENDIE ((uint32_t)0x00000040)
```

Command Response Received Interrupt Enable

**5.173.2.2208 SDIO\_MASK\_CMDSENTIE**

```
#define SDIO_MASK_CMDSENTIE ((uint32_t)0x00000080)
```

Command Sent Interrupt Enable

**5.173.2.2209 SDIO\_MASK\_CTIMEOUTIE**

```
#define SDIO_MASK_CTIMEOUTIE ((uint32_t)0x00000004)
```

Command TimeOut Interrupt Enable

**5.173.2.2210 SDIO\_MASK\_DATAENDIE**

```
#define SDIO_MASK_DATAENDIE ((uint32_t)0x00000100)
```

Data End Interrupt Enable

**5.173.2.2211 SDIO\_MASK\_DBCKENDIE**

```
#define SDIO_MASK_DBCKENDIE ((uint32_t)0x00000400)
```

Data Block End Interrupt Enable

**5.173.2.2212 SDIO\_MASK\_DCRCFAILIE**

```
#define SDIO_MASK_DCRCFAILIE ((uint32_t)0x00000002)
```

Data CRC Fail Interrupt Enable

**5.173.2.2213 SDIO\_MASK\_DTIMEOUTIE**

```
#define SDIO_MASK_DTIMEOUTIE ((uint32_t)0x00000008)
```

Data TimeOut Interrupt Enable

**5.173.2.2214 SDIO\_MASK\_RXACTIE**

```
#define SDIO_MASK_RXACTIE ((uint32_t)0x00002000)
```

Data receive acting interrupt enabled

**5.173.2.2215 SDIO\_MASK\_RXDAVLIE**

```
#define SDIO_MASK_RXDAVLIE ((uint32_t)0x00200000)
```

Data available in Rx FIFO interrupt Enable

**5.173.2.2216 SDIO\_MASK\_RXFIFOEIE**

```
#define SDIO_MASK_RXFIFOEIE ((uint32_t)0x00080000)
```

Rx FIFO Empty interrupt Enable

**5.173.2.2217 SDIO\_MASK\_RXFIFOFIE**

```
#define SDIO_MASK_RXFIFOFIE ((uint32_t)0x00020000)
```

Rx FIFO Full interrupt Enable

**5.173.2.2218 SDIO\_MASK\_RXFIFOHFIE**

```
#define SDIO_MASK_RXFIFOHFIE ((uint32_t)0x00008000)
```

Rx FIFO Half Full interrupt Enable

**5.173.2.2219 SDIO\_MASK\_RXOVERRIE**

```
#define SDIO_MASK_RXOVERRIE ((uint32_t)0x00000020)
```

Rx FIFO OverRun Error Interrupt Enable

**5.173.2.2220 SDIO\_MASK\_SDIOITIE**

```
#define SDIO_MASK_SDIOITIE ((uint32_t)0x00400000)
```

SDIO Mode Interrupt Received interrupt Enable

**5.173.2.2221 SDIO\_MASK\_STBITERRIE**

```
#define SDIO_MASK_STBITERRIE ((uint32_t)0x00000200)
```

Start Bit Error Interrupt Enable

**5.173.2.2222 SDIO\_MASK\_TXACTIE**

```
#define SDIO_MASK_TXACTIE ((uint32_t)0x00001000)
```

Data Transmit Acting Interrupt Enable

**5.173.2.2223 SDIO\_MASK\_TXDAVLIE**

```
#define SDIO_MASK_TXDAVLIE ((uint32_t)0x00100000)
```

Data available in Tx FIFO interrupt Enable

**5.173.2.2224 SDIO\_MASK\_TXFIFOEIE**

```
#define SDIO_MASK_TXFIFOEIE ((uint32_t)0x00040000)
```

Tx FIFO Empty interrupt Enable

**5.173.2.2225 SDIO\_MASK\_TXFIFOFIE**

```
#define SDIO_MASK_TXFIFOFIE ((uint32_t)0x00010000)
```

Tx FIFO Full interrupt Enable

**5.173.2.2226 SDIO\_MASK\_TXFIFOHEIE**

```
#define SDIO_MASK_TXFIFOHEIE ((uint32_t)0x00004000)
```

Tx FIFO Half Empty interrupt Enable

**5.173.2.2227 SDIO\_MASK\_TXUNDERRIE**

```
#define SDIO_MASK_TXUNDERRIE ((uint32_t)0x00000010)
```

Tx FIFO UnderRun Error Interrupt Enable

**5.173.2.2228 SDIO\_POWER\_PWRCTRL**

```
#define SDIO_POWER_PWRCTRL ((uint8_t)0x03)
```

PWRCTRL[1:0] bits (Power supply control bits)

**5.173.2.2229 SDIO\_POWER\_PWRCTRL\_0**

```
#define SDIO_POWER_PWRCTRL_0 ((uint8_t)0x01)
```

Bit 0

**5.173.2.2230 SDIO\_POWER\_PWRCTRL\_1**

```
#define SDIO_POWER_PWRCTRL_1 ((uint8_t)0x02)
```

Bit 1

**5.173.2.2231 SDIO\_RESP0\_CARDSTATUS0**

```
#define SDIO_RESP0_CARDSTATUS0 ((uint32_t)0xFFFFFFFF)
```

Card Status

**5.173.2.2232 SDIO\_RESP1\_CARDSTATUS1**

```
#define SDIO_RESP1_CARDSTATUS1 ((uint32_t)0xFFFFFFFF)
```

Card Status

**5.173.2.2233 SDIO\_RESP2\_CARDSTATUS2**

```
#define SDIO_RESP2_CARDSTATUS2 ((uint32_t)0xFFFFFFFF)
```

Card Status

**5.173.2.2234 SDIO\_RESP3\_CARDSTATUS3**

```
#define SDIO_RESP3_CARDSTATUS3 ((uint32_t)0xFFFFFFFF)
```

Card Status

**5.173.2.2235 SDIO\_RESP4\_CARDSTATUS4**

```
#define SDIO_RESP4_CARDSTATUS4 ((uint32_t)0xFFFFFFFF)
```

Card Status

**5.173.2.2236 SDIO\_RESPCMD\_RESPCMD**

```
#define SDIO_RESPCMD_RESPCMD ((uint8_t)0x3F)
```

Response command index

**5.173.2.2237 SDIO\_STA\_CCRCFAIL**

```
#define SDIO_STA_CCRCFAIL ((uint32_t)0x00000001)
```

Command response received (CRC check failed)

**5.173.2.2238 SDIO\_STA\_CEATAEND**

```
#define SDIO_STA_CEATAEND ((uint32_t)0x00800000)
```

CE-ATA command completion signal received for CMD61

**5.173.2.2239 SDIO\_STA\_CMDACT**

```
#define SDIO_STA_CMDACT ((uint32_t)0x00000800)
```

Command transfer in progress

**5.173.2.2240 SDIO\_STA\_CMDREND**

```
#define SDIO_STA_CMDREND ((uint32_t)0x00000040)
```

Command response received (CRC check passed)

**5.173.2.2241 SDIO\_STA\_CMDSENT**

```
#define SDIO_STA_CMDSENT ((uint32_t)0x00000080)
```

Command sent (no response required)

**5.173.2.2242 SDIO\_STA\_CTIMEOUT**

```
#define SDIO_STA_CTIMEOUT ((uint32_t)0x00000004)
```

Command response timeout

**5.173.2.2243 SDIO\_STA\_DATAEND**

```
#define SDIO_STA_DATAEND ((uint32_t)0x000000100)
```

Data end (data counter, SDIDCOUNT, is zero)

**5.173.2.2244 SDIO\_STA\_DBCKEND**

```
#define SDIO_STA_DBCKEND ((uint32_t)0x000000400)
```

Data block sent/received (CRC check passed)

**5.173.2.2245 SDIO\_STA\_DCRCFAIL**

```
#define SDIO_STA_DCRCFAIL ((uint32_t)0x000000002)
```

Data block sent/received (CRC check failed)

**5.173.2.2246 SDIO\_STA\_DTIMEOUT**

```
#define SDIO_STA_DTIMEOUT ((uint32_t)0x000000008)
```

Data timeout

**5.173.2.2247 SDIO\_STA\_RXACT**

```
#define SDIO_STA_RXACT ((uint32_t)0x00002000)
```

Data receive in progress

**5.173.2.2248 SDIO\_STA\_RXDAVL**

```
#define SDIO_STA_RXDAVL ((uint32_t)0x00200000)
```

Data available in receive FIFO

**5.173.2.2249 SDIO\_STA\_RXFIFOE**

```
#define SDIO_STA_RXFIFOE ((uint32_t)0x00080000)
```

Receive FIFO empty

**5.173.2.2250 SDIO\_STA\_RXFIFOF**

```
#define SDIO_STA_RXFIFOF ((uint32_t)0x00020000)
```

Receive FIFO full

**5.173.2.2251 SDIO\_STA\_RXFIFOHF**

```
#define SDIO_STA_RXFIFOHF ((uint32_t)0x00008000)
```

Receive FIFO Half Full: there are at least 8 words in the FIFO

**5.173.2.2252 SDIO\_STA\_RXOVERR**

```
#define SDIO_STA_RXOVERR ((uint32_t)0x00000020)
```

Received FIFO overrun error

**5.173.2.2253 SDIO\_STA\_SDIOIT**

```
#define SDIO_STA_SDIOIT ((uint32_t)0x00400000)
```

SDIO interrupt received

**5.173.2.2254 SDIO\_STA\_STBITERR**

```
#define SDIO_STA_STBITERR ((uint32_t)0x00000200)
```

Start bit not detected on all data signals in wide bus mode

**5.173.2.2255 SDIO\_STA\_TXACT**

```
#define SDIO_STA_TXACT ((uint32_t)0x00001000)
```

Data transmit in progress

**5.173.2.2256 SDIO\_STA\_TXDAVL**

```
#define SDIO_STA_TXDAVL ((uint32_t)0x00100000)
```

Data available in transmit FIFO

**5.173.2.2257 SDIO\_STA\_TXFIFOE**

```
#define SDIO_STA_TXFIFOE ((uint32_t)0x00040000)
```

Transmit FIFO empty

**5.173.2.2258 SDIO\_STA\_TXFIFOF**

```
#define SDIO_STA_TXFIFOF ((uint32_t)0x00010000)
```

Transmit FIFO full

**5.173.2.2259 SDIO\_STA\_TXFIFOHE**

```
#define SDIO_STA_TXFIFOHE ((uint32_t)0x00004000)
```

Transmit FIFO Half Empty: at least 8 words can be written into the FIFO

**5.173.2.2260 SDIO\_STA\_TXUNDERR**

```
#define SDIO_STA_TXUNDERR ((uint32_t)0x00000010)
```

Transmit FIFO underrun error

**5.173.2.2261 SPI\_CR1\_BIDIMODE**

```
#define SPI_CR1_BIDIMODE ((uint16_t)0x8000)
```

Bidirectional data mode enable

**5.173.2.2262 SPI\_CR1\_BIDIOE**

```
#define SPI_CR1_BIDIOE ((uint16_t)0x4000)
```

Output enable in bidirectional mode

**5.173.2.2263 SPI\_CR1\_BR**

```
#define SPI_CR1_BR ((uint16_t)0x0038)
```

BR[2:0] bits (Baud Rate Control)

**5.173.2.2264 SPI\_CR1\_BR\_0**

```
#define SPI_CR1_BR_0 ((uint16_t)0x0008)
```

Bit 0

**5.173.2.2265 SPI\_CR1\_BR\_1**

```
#define SPI_CR1_BR_1 ((uint16_t)0x0010)
```

Bit 1

**5.173.2.2266 SPI\_CR1\_BR\_2**

```
#define SPI_CR1_BR_2 ((uint16_t)0x0020)
```

Bit 2

**5.173.2.2267 SPI\_CR1\_CPHA**

```
#define SPI_CR1_CPHA ((uint16_t)0x0001)
```

Clock Phase

**5.173.2.2268 SPI\_CR1\_CPOL**

```
#define SPI_CR1_CPOL ((uint16_t)0x0002)
```

Clock Polarity

**5.173.2.2269 SPI\_CR1\_CRCEN**

```
#define SPI_CR1_CRCEN ((uint16_t)0x2000)
```

Hardware CRC calculation enable

**5.173.2.2270 SPI\_CR1\_CRCNEXT**

```
#define SPI_CR1_CRCNEXT ((uint16_t)0x1000)
```

Transmit CRC next

**5.173.2.2271 SPI\_CR1\_DFF**

```
#define SPI_CR1_DFF ((uint16_t)0x0800)
```

Data Frame Format

**5.173.2.2272 SPI\_CR1\_LSBFIRST**

```
#define SPI_CR1_LSBFIRST ((uint16_t)0x0080)
```

Frame Format

**5.173.2.2273 SPI\_CR1\_MSTR**

```
#define SPI_CR1_MSTR ((uint16_t)0x0004)
```

Master Selection

**5.173.2.2274 SPI\_CR1\_RXONLY**

```
#define SPI_CR1_RXONLY ((uint16_t)0x0400)
```

Receive only

**5.173.2.2275 SPI\_CR1\_SPE**

```
#define SPI_CR1_SPE ((uint16_t)0x0040)
```

SPI Enable

**5.173.2.2276 SPI\_CR1\_SSI**

```
#define SPI_CR1_SSI ((uint16_t)0x0100)
```

Internal slave select

**5.173.2.2277 SPI\_CR1\_SSM**

```
#define SPI_CR1_SSM ((uint16_t)0x0200)
```

Software slave management

**5.173.2.2278 SPI\_CR2\_ERRIE**

```
#define SPI_CR2_ERRIE ((uint8_t)0x20)
```

Error Interrupt Enable

**5.173.2.2279 SPI\_CR2\_RXDMAEN**

```
#define SPI_CR2_RXDMAEN ((uint8_t)0x01)
```

Rx Buffer DMA Enable

**5.173.2.2280 SPI\_CR2\_RXNEIE**

```
#define SPI_CR2_RXNEIE ((uint8_t)0x40)
```

RX buffer Not Empty Interrupt Enable

**5.173.2.2281 SPI\_CR2\_SSOE**

```
#define SPI_CR2_SSOE ((uint8_t)0x04)
```

SS Output Enable

**5.173.2.2282 SPI\_CR2\_TXDMAEN**

```
#define SPI_CR2_TXDMAEN ((uint8_t)0x02)
```

Tx Buffer DMA Enable

**5.173.2.2283 SPI\_CR2\_TXEIE**

```
#define SPI_CR2_TXEIE ((uint8_t)0x80)
```

Tx buffer Empty Interrupt Enable

**5.173.2.2284 SPI\_CRCPR\_CRCPOLY**

```
#define SPI_CRCPR_CRCPOLY ((uint16_t)0xFFFF)
```

CRC polynomial register

**5.173.2.2285 SPI\_DR\_DR**

```
#define SPI_DR_DR ((uint16_t)0xFFFF)
```

Data Register

**5.173.2.2286 SPI\_I2SCFGR\_CHLEN**

```
#define SPI_I2SCFGR_CHLEN ((uint16_t)0x0001)
```

Channel length (number of bits per audio channel)

**5.173.2.2287 SPI\_I2SCFGR\_CKPOL**

```
#define SPI_I2SCFGR_CKPOL ((uint16_t)0x0008)
```

steady state clock polarity

**5.173.2.2288 SPI\_I2SCFGR\_DATLEN**

```
#define SPI_I2SCFGR_DATLEN ((uint16_t)0x0006)
```

DATLEN[1:0] bits (Data length to be transferred)

**5.173.2.2289 SPI\_I2SCFGR\_DATLEN\_0**

```
#define SPI_I2SCFGR_DATLEN_0 ((uint16_t)0x0002)
```

Bit 0

**5.173.2.2290 SPI\_I2SCFGR\_DATLEN\_1**

```
#define SPI_I2SCFGR_DATLEN_1 ((uint16_t)0x0004)
```

Bit 1

**5.173.2.2291 SPI\_I2SCFGR\_I2SCFG**

```
#define SPI_I2SCFGR_I2SCFG ((uint16_t)0x0300)
```

I2SCFG[1:0] bits (I2S configuration mode)

**5.173.2.2292 SPI\_I2SCFGR\_I2SCFG\_0**

```
#define SPI_I2SCFGR_I2SCFG_0 ((uint16_t)0x0100)
```

Bit 0

**5.173.2.2293 SPI\_I2SCFGR\_I2SCFG\_1**

```
#define SPI_I2SCFGR_I2SCFG_1 ((uint16_t)0x0200)
```

Bit 1

**5.173.2.2294 SPI\_I2SCFGR\_I2SE**

```
#define SPI_I2SCFGR_I2SE ((uint16_t)0x0400)
```

I2S Enable

**5.173.2.2295 SPI\_I2SCFGR\_I2SMOD**

```
#define SPI_I2SCFGR_I2SMOD ((uint16_t)0x0800)
```

I2S mode selection

**5.173.2.2296 SPI\_I2SCFGR\_I2SSSTD**

```
#define SPI_I2SCFGR_I2SSSTD ((uint16_t)0x0030)
```

I2SSSTD[1:0] bits (I2S standard selection)

**5.173.2.2297 SPI\_I2SCFGR\_I2SSSTD\_0**

```
#define SPI_I2SCFGR_I2SSSTD_0 ((uint16_t)0x0010)
```

Bit 0

**5.173.2.2298 SPI\_I2SCFGR\_I2SSSTD\_1**

```
#define SPI_I2SCFGR_I2SSSTD_1 ((uint16_t)0x0020)
```

Bit 1

**5.173.2.2299 SPI\_I2SCFGR\_PCMSYNC**

```
#define SPI_I2SCFGR_PCMSYNC ((uint16_t)0x0080)
```

PCM frame synchronization

**5.173.2.2300 SPI\_I2SPR\_I2SDIV**

```
#define SPI_I2SPR_I2SDIV ((uint16_t)0x00FF)
```

I2S Linear prescaler

**5.173.2.2301 SPI\_I2SPR\_MCKOE**

```
#define SPI_I2SPR_MCKOE ((uint16_t)0x0200)
```

Master Clock Output Enable

**5.173.2.2302 SPI\_I2SPR\_ODD**

```
#define SPI_I2SPR_ODD ((uint16_t)0x0100)
```

Odd factor for the prescaler

**5.173.2.2303 SPI\_RXCRCR\_RXCRC**

```
#define SPI_RXCRCR_RXCRC ((uint16_t)0xFFFF)
```

Rx CRC Register

**5.173.2.2304 SPI\_SR\_BSY**

```
#define SPI_SR_BSY ((uint8_t)0x80)
```

Busy flag

**5.173.2.2305 SPI\_SR\_CHSIDE**

```
#define SPI_SR_CHSIDE ((uint8_t)0x04)
```

Channel side

**5.173.2.2306 SPI\_SR\_CRCERR**

```
#define SPI_SR_CRCERR ((uint8_t)0x10)
```

CRC Error flag

**5.173.2.2307 SPI\_SR\_MODF**

```
#define SPI_SR_MODF ((uint8_t)0x20)
```

Mode fault

**5.173.2.2308 SPI\_SR\_OVR**

```
#define SPI_SR_OVR ((uint8_t)0x40)
```

Overrun flag

**5.173.2.2309 SPI\_SR\_RXNE**

```
#define SPI_SR_RXNE ((uint8_t)0x01)
```

Receive buffer Not Empty

**5.173.2.2310 SPI\_SR\_TXE**

```
#define SPI_SR_TXE ((uint8_t)0x02)
```

Transmit buffer Empty

**5.173.2.2311 SPI\_SR\_UDR**

```
#define SPI_SR_UDR ((uint8_t)0x08)
```

Underrun flag

**5.173.2.2312 SPI\_TXCRCR\_TXCRC**

```
#define SPI_TXCRCR_TXCRC ((uint16_t)0xFFFF)
```

Tx CRC Register

**5.173.2.2313 SYSCFG\_CMPCR\_CMP\_PD**

```
#define SYSCFG_CMPCR_CMP_PD ((uint32_t)0x00000001)
```

Compensation cell ready flag

**5.173.2.2314 SYSCFG\_CMPCR\_READY**

```
#define SYSCFG_CMPCR_READY ((uint32_t)0x00000100)
```

Compensation cell power-down

**5.173.2.2315 SYSCFG\_EXTICR1\_EXTI0**

```
#define SYSCFG_EXTICR1_EXTI0 ((uint16_t)0x000F)
```

EXTI 0 configuration

**5.173.2.2316 SYSCFG\_EXTICR1\_EXTI0\_PA**

```
#define SYSCFG_EXTICR1_EXTI0_PA ((uint16_t)0x0000)
```

EXTI0 configuration

PA[0] pin

**5.173.2.2317 SYSCFG\_EXTICR1\_EXTI0\_PB**

```
#define SYSCFG_EXTICR1_EXTI0_PB ((uint16_t)0x0001)
```

PB[0] pin

**5.173.2.2318 SYSCFG\_EXTICR1\_EXTI0\_PC**

```
#define SYSCFG_EXTICR1_EXTI0_PC ((uint16_t)0x0002)
```

PC[0] pin

**5.173.2.2319 SYSCFG\_EXTICR1\_EXTI0\_PD**

```
#define SYSCFG_EXTICR1_EXTI0_PD ((uint16_t)0x0003)
```

PD[0] pin

**5.173.2.2320 SYSCFG\_EXTICR1\_EXTI0\_PE**

```
#define SYSCFG_EXTICR1_EXTI0_PE ((uint16_t)0x0004)

PE[0] pin
```

**5.173.2.2321 SYSCFG\_EXTICR1\_EXTI0\_PF**

```
#define SYSCFG_EXTICR1_EXTI0_PF ((uint16_t)0x0005)

PF[0] pin
```

**5.173.2.2322 SYSCFG\_EXTICR1\_EXTI0\_PG**

```
#define SYSCFG_EXTICR1_EXTI0_PG ((uint16_t)0x0006)

PG[0] pin
```

**5.173.2.2323 SYSCFG\_EXTICR1\_EXTI0\_PH**

```
#define SYSCFG_EXTICR1_EXTI0_PH ((uint16_t)0x0007)

PH[0] pin
```

**5.173.2.2324 SYSCFG\_EXTICR1\_EXTI0\_PI**

```
#define SYSCFG_EXTICR1_EXTI0_PI ((uint16_t)0x0008)

PI[0] pin
```

**5.173.2.2325 SYSCFG\_EXTICR1\_EXTI0\_PJ**

```
#define SYSCFG_EXTICR1_EXTI0_PJ ((uint16_t)0x0009)

PJ[0] pin
```

**5.173.2.2326 SYSCFG\_EXTICR1\_EXTI0\_PK**

```
#define SYSCFG_EXTICR1_EXTI0_PK ((uint16_t)0x000A)

PK[0] pin
```

**5.173.2.2327 SYSCFG\_EXTICR1\_EXTI1**

```
#define SYSCFG_EXTICR1_EXTI1 ((uint16_t)0x00F0)

EXTI 1 configuration
```

**5.173.2.2328 SYSCFG\_EXTICR1\_EXTI1\_PA**

```
#define SYSCFG_EXTICR1_EXTI1_PA ((uint16_t)0x0000)
```

EXTI1 configuration

PA[1] pin

**5.173.2.2329 SYSCFG\_EXTICR1\_EXTI1\_PB**

```
#define SYSCFG_EXTICR1_EXTI1_PB ((uint16_t)0x0010)
```

PB[1] pin

**5.173.2.2330 SYSCFG\_EXTICR1\_EXTI1\_PC**

```
#define SYSCFG_EXTICR1_EXTI1_PC ((uint16_t)0x0020)
```

PC[1] pin

**5.173.2.2331 SYSCFG\_EXTICR1\_EXTI1\_PD**

```
#define SYSCFG_EXTICR1_EXTI1_PD ((uint16_t)0x0030)
```

PD[1] pin

**5.173.2.2332 SYSCFG\_EXTICR1\_EXTI1\_PE**

```
#define SYSCFG_EXTICR1_EXTI1_PE ((uint16_t)0x0040)
```

PE[1] pin

**5.173.2.2333 SYSCFG\_EXTICR1\_EXTI1\_PF**

```
#define SYSCFG_EXTICR1_EXTI1_PF ((uint16_t)0x0050)
```

PF[1] pin

**5.173.2.2334 SYSCFG\_EXTICR1\_EXTI1\_PG**

```
#define SYSCFG_EXTICR1_EXTI1_PG ((uint16_t)0x0060)
```

PG[1] pin

**5.173.2.2335 SYSCFG\_EXTICR1\_EXTI1\_PH**

```
#define SYSCFG_EXTICR1_EXTI1_PH ((uint16_t)0x0070)
```

PH[1] pin

**5.173.2.2336 SYSCFG\_EXTICR1\_EXTI1\_PI**

```
#define SYSCFG_EXTICR1_EXTI1_PI ((uint16_t)0x0080)
```

PI[1] pin

**5.173.2.2337 SYSCFG\_EXTICR1\_EXTI1\_PJ**

```
#define SYSCFG_EXTICR1_EXTI1_PJ ((uint16_t)0x0090)
```

PJ[1] pin

**5.173.2.2338 SYSCFG\_EXTICR1\_EXTI1\_PK**

```
#define SYSCFG_EXTICR1_EXTI1_PK ((uint16_t)0x00A0)
```

PK[1] pin

**5.173.2.2339 SYSCFG\_EXTICR1\_EXTI2**

```
#define SYSCFG_EXTICR1_EXTI2 ((uint16_t)0x0F00)
```

EXTI 2 configuration

**5.173.2.2340 SYSCFG\_EXTICR1\_EXTI2\_PA**

```
#define SYSCFG_EXTICR1_EXTI2_PA ((uint16_t)0x0000)
```

EXTI2 configuration

PA[2] pin

**5.173.2.2341 SYSCFG\_EXTICR1\_EXTI2\_PB**

```
#define SYSCFG_EXTICR1_EXTI2_PB ((uint16_t)0x0100)
```

PB[2] pin

**5.173.2.2342 SYSCFG\_EXTICR1\_EXTI2\_PC**

```
#define SYSCFG_EXTICR1_EXTI2_PC ((uint16_t)0x0200)
```

PC[2] pin

**5.173.2.2343 SYSCFG\_EXTICR1\_EXTI2\_PD**

```
#define SYSCFG_EXTICR1_EXTI2_PD ((uint16_t)0x0300)
```

PD[2] pin

**5.173.2.2344 SYSCFG\_EXTICR1\_EXTI2\_PE**

```
#define SYSCFG_EXTICR1_EXTI2_PE ((uint16_t)0x0400)
```

PE[2] pin

**5.173.2.2345 SYSCFG\_EXTICR1\_EXTI2\_PF**

```
#define SYSCFG_EXTICR1_EXTI2_PF ((uint16_t)0x0500)
```

PF[2] pin

**5.173.2.2346 SYSCFG\_EXTICR1\_EXTI2\_PG**

```
#define SYSCFG_EXTICR1_EXTI2_PG ((uint16_t)0x0600)
```

PG[2] pin

**5.173.2.2347 SYSCFG\_EXTICR1\_EXTI2\_PH**

```
#define SYSCFG_EXTICR1_EXTI2_PH ((uint16_t)0x0700)
```

PH[2] pin

**5.173.2.2348 SYSCFG\_EXTICR1\_EXTI2\_PI**

```
#define SYSCFG_EXTICR1_EXTI2_PI ((uint16_t)0x0800)
```

PI[2] pin

**5.173.2.2349 SYSCFG\_EXTICR1\_EXTI2\_PJ**

```
#define SYSCFG_EXTICR1_EXTI2_PJ ((uint16_t)0x0900)
```

PJ[2] pin

**5.173.2.2350 SYSCFG\_EXTICR1\_EXTI2\_PK**

```
#define SYSCFG_EXTICR1_EXTI2_PK ((uint16_t)0x0A00)
```

PK[2] pin

**5.173.2.2351 SYSCFG\_EXTICR1\_EXTI3**

```
#define SYSCFG_EXTICR1_EXTI3 ((uint16_t)0xF000)
```

EXTI 3 configuration

**5.173.2.2352 SYSCFG\_EXTICR1\_EXTI3\_PA**

```
#define SYSCFG_EXTICR1_EXTI3_PA ((uint16_t)0x0000)
```

EXTI3 configuration

PA[3] pin

**5.173.2.2353 SYSCFG\_EXTICR1\_EXTI3\_PB**

```
#define SYSCFG_EXTICR1_EXTI3_PB ((uint16_t)0x1000)
```

PB[3] pin

**5.173.2.2354 SYSCFG\_EXTICR1\_EXTI3\_PC**

```
#define SYSCFG_EXTICR1_EXTI3_PC ((uint16_t)0x2000)
```

PC[3] pin

**5.173.2.2355 SYSCFG\_EXTICR1\_EXTI3\_PD**

```
#define SYSCFG_EXTICR1_EXTI3_PD ((uint16_t)0x3000)
```

PD[3] pin

**5.173.2.2356 SYSCFG\_EXTICR1\_EXTI3\_PE**

```
#define SYSCFG_EXTICR1_EXTI3_PE ((uint16_t)0x4000)
```

PE[3] pin

**5.173.2.2357 SYSCFG\_EXTICR1\_EXTI3\_PF**

```
#define SYSCFG_EXTICR1_EXTI3_PF ((uint16_t)0x5000)
```

PF[3] pin

**5.173.2.2358 SYSCFG\_EXTICR1\_EXTI3\_PG**

```
#define SYSCFG_EXTICR1_EXTI3_PG ((uint16_t)0x6000)
```

PG[3] pin

**5.173.2.2359 SYSCFG\_EXTICR1\_EXTI3\_PH**

```
#define SYSCFG_EXTICR1_EXTI3_PH ((uint16_t)0x7000)
```

PH[3] pin

**5.173.2.2360 SYSCFG\_EXTICR1\_EXTI3\_PI**

```
#define SYSCFG_EXTICR1_EXTI3_PI ((uint16_t)0x8000)
```

PI[3] pin

**5.173.2.2361 SYSCFG\_EXTICR1\_EXTI3\_PJ**

```
#define SYSCFG_EXTICR1_EXTI3_PJ ((uint16_t)0x9000)
```

PJ[3] pin

**5.173.2.2362 SYSCFG\_EXTICR1\_EXTI3\_PK**

```
#define SYSCFG_EXTICR1_EXTI3_PK ((uint16_t)0xA000)
```

PK[3] pin

**5.173.2.2363 SYSCFG\_EXTICR2\_EXTI4**

```
#define SYSCFG_EXTICR2_EXTI4 ((uint16_t)0x000F)
```

EXTI 4 configuration

**5.173.2.2364 SYSCFG\_EXTICR2\_EXTI4\_PA**

```
#define SYSCFG_EXTICR2_EXTI4_PA ((uint16_t)0x0000)
```

EXTI4 configuration

PA[4] pin

**5.173.2.2365 SYSCFG\_EXTICR2\_EXTI4\_PB**

```
#define SYSCFG_EXTICR2_EXTI4_PB ((uint16_t)0x0001)
```

PB[4] pin

**5.173.2.2366 SYSCFG\_EXTICR2\_EXTI4\_PC**

```
#define SYSCFG_EXTICR2_EXTI4_PC ((uint16_t)0x0002)
```

PC[4] pin

**5.173.2.2367 SYSCFG\_EXTICR2\_EXTI4\_PD**

```
#define SYSCFG_EXTICR2_EXTI4_PD ((uint16_t)0x0003)
```

PD[4] pin

**5.173.2.2368 SYSCFG\_EXTICR2\_EXTI4\_PE**

```
#define SYSCFG_EXTICR2_EXTI4_PE ((uint16_t)0x0004)
```

PE[4] pin

**5.173.2.2369 SYSCFG\_EXTICR2\_EXTI4\_PF**

```
#define SYSCFG_EXTICR2_EXTI4_PF ((uint16_t)0x0005)
```

PF[4] pin

**5.173.2.2370 SYSCFG\_EXTICR2\_EXTI4\_PG**

```
#define SYSCFG_EXTICR2_EXTI4_PG ((uint16_t)0x0006)
```

PG[4] pin

**5.173.2.2371 SYSCFG\_EXTICR2\_EXTI4\_PH**

```
#define SYSCFG_EXTICR2_EXTI4_PH ((uint16_t)0x0007)
```

PH[4] pin

**5.173.2.2372 SYSCFG\_EXTICR2\_EXTI4\_PI**

```
#define SYSCFG_EXTICR2_EXTI4_PI ((uint16_t)0x0008)
```

PI[4] pin

**5.173.2.2373 SYSCFG\_EXTICR2\_EXTI4\_PJ**

```
#define SYSCFG_EXTICR2_EXTI4_PJ ((uint16_t)0x0009)
```

PJ[4] pin

**5.173.2.2374 SYSCFG\_EXTICR2\_EXTI4\_PK**

```
#define SYSCFG_EXTICR2_EXTI4_PK ((uint16_t)0x000A)
```

PK[4] pin

**5.173.2.2375 SYSCFG\_EXTICR2\_EXTI5**

```
#define SYSCFG_EXTICR2_EXTI5 ((uint16_t)0x00F0)
```

EXTI 5 configuration

**5.173.2.2376 SYSCFG\_EXTICR2\_EXTI5\_PA**

```
#define SYSCFG_EXTICR2_EXTI5_PA ((uint16_t)0x0000)
```

EXTI5 configuration

PA[5] pin

**5.173.2.2377 SYSCFG\_EXTICR2\_EXTI5\_PB**

```
#define SYSCFG_EXTICR2_EXTI5_PB ((uint16_t)0x0010)
```

PB[5] pin

**5.173.2.2378 SYSCFG\_EXTICR2\_EXTI5\_PC**

```
#define SYSCFG_EXTICR2_EXTI5_PC ((uint16_t)0x0020)

PC[5] pin
```

**5.173.2.2379 SYSCFG\_EXTICR2\_EXTI5\_PD**

```
#define SYSCFG_EXTICR2_EXTI5_PD ((uint16_t)0x0030)

PD[5] pin
```

**5.173.2.2380 SYSCFG\_EXTICR2\_EXTI5\_PE**

```
#define SYSCFG_EXTICR2_EXTI5_PE ((uint16_t)0x0040)

PE[5] pin
```

**5.173.2.2381 SYSCFG\_EXTICR2\_EXTI5\_PF**

```
#define SYSCFG_EXTICR2_EXTI5_PF ((uint16_t)0x0050)

PF[5] pin
```

**5.173.2.2382 SYSCFG\_EXTICR2\_EXTI5\_PG**

```
#define SYSCFG_EXTICR2_EXTI5_PG ((uint16_t)0x0060)

PG[5] pin
```

**5.173.2.2383 SYSCFG\_EXTICR2\_EXTI5\_PH**

```
#define SYSCFG_EXTICR2_EXTI5_PH ((uint16_t)0x0070)

PH[5] pin
```

**5.173.2.2384 SYSCFG\_EXTICR2\_EXTI5\_PI**

```
#define SYSCFG_EXTICR2_EXTI5_PI ((uint16_t)0x0080)

PI[5] pin
```

**5.173.2.2385 SYSCFG\_EXTICR2\_EXTI5\_PJ**

```
#define SYSCFG_EXTICR2_EXTI5_PJ ((uint16_t)0x0090)

PJ[5] pin
```

**5.173.2.2386 SYSCFG\_EXTICR2\_EXTI5\_PK**

```
#define SYSCFG_EXTICR2_EXTI5_PK ((uint16_t)0x00A0)
```

PK[5] pin

**5.173.2.2387 SYSCFG\_EXTICR2\_EXTI6**

```
#define SYSCFG_EXTICR2_EXTI6 ((uint16_t)0x0F00)
```

EXTI 6 configuration

**5.173.2.2388 SYSCFG\_EXTICR2\_EXTI6\_PA**

```
#define SYSCFG_EXTICR2_EXTI6_PA ((uint16_t)0x0000)
```

EXTI6 configuration

PA[6] pin

**5.173.2.2389 SYSCFG\_EXTICR2\_EXTI6\_PB**

```
#define SYSCFG_EXTICR2_EXTI6_PB ((uint16_t)0x0100)
```

PB[6] pin

**5.173.2.2390 SYSCFG\_EXTICR2\_EXTI6\_PC**

```
#define SYSCFG_EXTICR2_EXTI6_PC ((uint16_t)0x0200)
```

PC[6] pin

**5.173.2.2391 SYSCFG\_EXTICR2\_EXTI6\_PD**

```
#define SYSCFG_EXTICR2_EXTI6_PD ((uint16_t)0x0300)
```

PD[6] pin

**5.173.2.2392 SYSCFG\_EXTICR2\_EXTI6\_PE**

```
#define SYSCFG_EXTICR2_EXTI6_PE ((uint16_t)0x0400)
```

PE[6] pin

**5.173.2.2393 SYSCFG\_EXTICR2\_EXTI6\_PF**

```
#define SYSCFG_EXTICR2_EXTI6_PF ((uint16_t)0x0500)
```

PF[6] pin

**5.173.2.2394 SYSCFG\_EXTICR2\_EXTI6\_PG**

```
#define SYSCFG_EXTICR2_EXTI6_PG ((uint16_t)0x0600)
```

PG[6] pin

**5.173.2.2395 SYSCFG\_EXTICR2\_EXTI6\_PH**

```
#define SYSCFG_EXTICR2_EXTI6_PH ((uint16_t)0x0700)
```

PH[6] pin

**5.173.2.2396 SYSCFG\_EXTICR2\_EXTI6\_PI**

```
#define SYSCFG_EXTICR2_EXTI6_PI ((uint16_t)0x0800)
```

PI[6] pin

**5.173.2.2397 SYSCFG\_EXTICR2\_EXTI6\_PJ**

```
#define SYSCFG_EXTICR2_EXTI6_PJ ((uint16_t)0x0900)
```

PJ[6] pin

**5.173.2.2398 SYSCFG\_EXTICR2\_EXTI6\_PK**

```
#define SYSCFG_EXTICR2_EXTI6_PK ((uint16_t)0x0A00)
```

PK[6] pin

**5.173.2.2399 SYSCFG\_EXTICR2\_EXTI7**

```
#define SYSCFG_EXTICR2_EXTI7 ((uint16_t)0xF000)
```

EXTI 7 configuration

**5.173.2.2400 SYSCFG\_EXTICR2\_EXTI7\_PA**

```
#define SYSCFG_EXTICR2_EXTI7_PA ((uint16_t)0x0000)
```

EXTI7 configuration

PA[7] pin

**5.173.2.2401 SYSCFG\_EXTICR2\_EXTI7\_PB**

```
#define SYSCFG_EXTICR2_EXTI7_PB ((uint16_t)0x1000)
```

PB[7] pin

**5.173.2.2402 SYSCFG\_EXTICR2\_EXTI7\_PC**

```
#define SYSCFG_EXTICR2_EXTI7_PC ((uint16_t)0x2000)
```

PC[7] pin

**5.173.2.2403 SYSCFG\_EXTICR2\_EXTI7\_PD**

```
#define SYSCFG_EXTICR2_EXTI7_PD ((uint16_t)0x3000)
```

PD[7] pin

**5.173.2.2404 SYSCFG\_EXTICR2\_EXTI7\_PE**

```
#define SYSCFG_EXTICR2_EXTI7_PE ((uint16_t)0x4000)
```

PE[7] pin

**5.173.2.2405 SYSCFG\_EXTICR2\_EXTI7\_PF**

```
#define SYSCFG_EXTICR2_EXTI7_PF ((uint16_t)0x5000)
```

PF[7] pin

**5.173.2.2406 SYSCFG\_EXTICR2\_EXTI7\_PG**

```
#define SYSCFG_EXTICR2_EXTI7_PG ((uint16_t)0x6000)
```

PG[7] pin

**5.173.2.2407 SYSCFG\_EXTICR2\_EXTI7\_PH**

```
#define SYSCFG_EXTICR2_EXTI7_PH ((uint16_t)0x7000)
```

PH[7] pin

**5.173.2.2408 SYSCFG\_EXTICR2\_EXTI7\_PI**

```
#define SYSCFG_EXTICR2_EXTI7_PI ((uint16_t)0x8000)
```

PI[7] pin

**5.173.2.2409 SYSCFG\_EXTICR2\_EXTI7\_PJ**

```
#define SYSCFG_EXTICR2_EXTI7_PJ ((uint16_t)0x9000)
```

PJ[7] pin

**5.173.2.2410 SYSCFG\_EXTICR2\_EXTI7\_PK**

```
#define SYSCFG_EXTICR2_EXTI7_PK ((uint16_t)0xA000)
```

PK[7] pin

**5.173.2.2411 SYSCFG\_EXTICR3\_EXTI10**

```
#define SYSCFG_EXTICR3_EXTI10 ((uint16_t)0x0F00)
```

EXTI 10 configuration

**5.173.2.2412 SYSCFG\_EXTICR3\_EXTI10\_PA**

```
#define SYSCFG_EXTICR3_EXTI10_PA ((uint16_t)0x0000)
```

EXTI10 configuration

PA[10] pin

**5.173.2.2413 SYSCFG\_EXTICR3\_EXTI10\_PB**

```
#define SYSCFG_EXTICR3_EXTI10_PB ((uint16_t)0x0100)
```

PB[10] pin

**5.173.2.2414 SYSCFG\_EXTICR3\_EXTI10\_PC**

```
#define SYSCFG_EXTICR3_EXTI10_PC ((uint16_t)0x0200)  
PC[10] pin
```

**5.173.2.2415 SYSCFG\_EXTICR3\_EXTI10\_PD**

```
#define SYSCFG_EXTICR3_EXTI10_PD ((uint16_t)0x0300)  
PD[10] pin
```

**5.173.2.2416 SYSCFG\_EXTICR3\_EXTI10\_PE**

```
#define SYSCFG_EXTICR3_EXTI10_PE ((uint16_t)0x0400)  
PE[10] pin
```

**5.173.2.2417 SYSCFG\_EXTICR3\_EXTI10\_PF**

```
#define SYSCFG_EXTICR3_EXTI10_PF ((uint16_t)0x0500)  
PF[10] pin
```

**5.173.2.2418 SYSCFG\_EXTICR3\_EXTI10\_PG**

```
#define SYSCFG_EXTICR3_EXTI10_PG ((uint16_t)0x0600)  
PG[10] pin
```

**5.173.2.2419 SYSCFG\_EXTICR3\_EXTI10\_PH**

```
#define SYSCFG_EXTICR3_EXTI10_PH ((uint16_t)0x0700)  
PH[10] pin
```

**5.173.2.2420 SYSCFG\_EXTICR3\_EXTI10\_PI**

```
#define SYSCFG_EXTICR3_EXTI10_PI ((uint16_t)0x0800)  
PI[10] pin
```

**5.173.2.2421 SYSCFG\_EXTICR3\_EXTI10\_PJ**

```
#define SYSCFG_EXTICR3_EXTI10_PJ ((uint16_t)0x0900)  
PJ[10] pin
```

**5.173.2.2422 SYSCFG\_EXTICR3\_EXTI11**

```
#define SYSCFG_EXTICR3_EXTI11 ((uint16_t)0xF000)
```

EXTI 11 configuration

**5.173.2.2423 SYSCFG\_EXTICR3\_EXTI11\_PA**

```
#define SYSCFG_EXTICR3_EXTI11_PA ((uint16_t)0x0000)
```

EXTI11 configuration

PA[11] pin

**5.173.2.2424 SYSCFG\_EXTICR3\_EXTI11\_PB**

```
#define SYSCFG_EXTICR3_EXTI11_PB ((uint16_t)0x1000)
```

PB[11] pin

**5.173.2.2425 SYSCFG\_EXTICR3\_EXTI11\_PC**

```
#define SYSCFG_EXTICR3_EXTI11_PC ((uint16_t)0x2000)
```

PC[11] pin

**5.173.2.2426 SYSCFG\_EXTICR3\_EXTI11\_PD**

```
#define SYSCFG_EXTICR3_EXTI11_PD ((uint16_t)0x3000)
```

PD[11] pin

**5.173.2.2427 SYSCFG\_EXTICR3\_EXTI11\_PE**

```
#define SYSCFG_EXTICR3_EXTI11_PE ((uint16_t)0x4000)
```

PE[11] pin

**5.173.2.2428 SYSCFG\_EXTICR3\_EXTI11\_PF**

```
#define SYSCFG_EXTICR3_EXTI11_PF ((uint16_t)0x5000)
```

PF[11] pin

**5.173.2.2429 SYSCFG\_EXTICR3\_EXTI11\_PG**

```
#define SYSCFG_EXTICR3_EXTI11_PG ((uint16_t)0x6000)
```

PG[11] pin

**5.173.2.2430 SYSCFG\_EXTICR3\_EXTI11\_PH**

```
#define SYSCFG_EXTICR3_EXTI11_PH ((uint16_t)0x7000)
```

PH[11] pin

**5.173.2.2431 SYSCFG\_EXTICR3\_EXTI11\_PI**

```
#define SYSCFG_EXTICR3_EXTI11_PI ((uint16_t)0x8000)
```

PI[11] pin

**5.173.2.2432 SYSCFG\_EXTICR3\_EXTI11\_PJ**

```
#define SYSCFG_EXTICR3_EXTI11_PJ ((uint16_t)0x9000)
```

PJ[11] pin

**5.173.2.2433 SYSCFG\_EXTICR3\_EXTI8**

```
#define SYSCFG_EXTICR3_EXTI8 ((uint16_t)0x000F)
```

EXTI 8 configuration

**5.173.2.2434 SYSCFG\_EXTICR3\_EXTI8\_PA**

```
#define SYSCFG_EXTICR3_EXTI8_PA ((uint16_t)0x0000)
```

EXTI8 configuration

PA[8] pin

**5.173.2.2435 SYSCFG\_EXTICR3\_EXTI8\_PB**

```
#define SYSCFG_EXTICR3_EXTI8_PB ((uint16_t)0x0001)
```

PB[8] pin

**5.173.2.2436 SYSCFG\_EXTICR3\_EXTI8\_PC**

```
#define SYSCFG_EXTICR3_EXTI8_PC ((uint16_t)0x0002)

PC[8] pin
```

**5.173.2.2437 SYSCFG\_EXTICR3\_EXTI8\_PD**

```
#define SYSCFG_EXTICR3_EXTI8_PD ((uint16_t)0x0003)

PD[8] pin
```

**5.173.2.2438 SYSCFG\_EXTICR3\_EXTI8\_PE**

```
#define SYSCFG_EXTICR3_EXTI8_PE ((uint16_t)0x0004)

PE[8] pin
```

**5.173.2.2439 SYSCFG\_EXTICR3\_EXTI8\_PF**

```
#define SYSCFG_EXTICR3_EXTI8_PF ((uint16_t)0x0005)

PF[8] pin
```

**5.173.2.2440 SYSCFG\_EXTICR3\_EXTI8\_PG**

```
#define SYSCFG_EXTICR3_EXTI8_PG ((uint16_t)0x0006)

PG[8] pin
```

**5.173.2.2441 SYSCFG\_EXTICR3\_EXTI8\_PH**

```
#define SYSCFG_EXTICR3_EXTI8_PH ((uint16_t)0x0007)

PH[8] pin
```

**5.173.2.2442 SYSCFG\_EXTICR3\_EXTI8\_PI**

```
#define SYSCFG_EXTICR3_EXTI8_PI ((uint16_t)0x0008)

PI[8] pin
```

**5.173.2.2443 SYSCFG\_EXTICR3\_EXTI8\_PJ**

```
#define SYSCFG_EXTICR3_EXTI8_PJ ((uint16_t)0x0009)

PJ[8] pin
```

**5.173.2.2444 SYSCFG\_EXTICR3\_EXTI9**

```
#define SYSCFG_EXTICR3_EXTI9 ((uint16_t)0x00F0)
```

EXTI 9 configuration

**5.173.2.2445 SYSCFG\_EXTICR3\_EXTI9\_PA**

```
#define SYSCFG_EXTICR3_EXTI9_PA ((uint16_t)0x0000)
```

EXTI9 configuration

PA[9] pin

**5.173.2.2446 SYSCFG\_EXTICR3\_EXTI9\_PB**

```
#define SYSCFG_EXTICR3_EXTI9_PB ((uint16_t)0x0010)
```

PB[9] pin

**5.173.2.2447 SYSCFG\_EXTICR3\_EXTI9\_PC**

```
#define SYSCFG_EXTICR3_EXTI9_PC ((uint16_t)0x0020)
```

PC[9] pin

**5.173.2.2448 SYSCFG\_EXTICR3\_EXTI9\_PD**

```
#define SYSCFG_EXTICR3_EXTI9_PD ((uint16_t)0x0030)
```

PD[9] pin

**5.173.2.2449 SYSCFG\_EXTICR3\_EXTI9\_PE**

```
#define SYSCFG_EXTICR3_EXTI9_PE ((uint16_t)0x0040)
```

PE[9] pin

**5.173.2.2450 SYSCFG\_EXTICR3\_EXTI9\_PF**

```
#define SYSCFG_EXTICR3_EXTI9_PF ((uint16_t)0x0050)
```

PF[9] pin

**5.173.2.2451 SYSCFG\_EXTICR3\_EXTI9\_PG**

```
#define SYSCFG_EXTICR3_EXTI9_PG ((uint16_t)0x0060)
```

PG[9] pin

**5.173.2.2452 SYSCFG\_EXTICR3\_EXTI9\_PH**

```
#define SYSCFG_EXTICR3_EXTI9_PH ((uint16_t)0x0070)
```

PH[9] pin

**5.173.2.2453 SYSCFG\_EXTICR3\_EXTI9\_PI**

```
#define SYSCFG_EXTICR3_EXTI9_PI ((uint16_t)0x0080)
```

PI[9] pin

**5.173.2.2454 SYSCFG\_EXTICR3\_EXTI9\_PJ**

```
#define SYSCFG_EXTICR3_EXTI9_PJ ((uint16_t)0x0090)
```

PJ[9] pin

**5.173.2.2455 SYSCFG\_EXTICR4\_EXTI12**

```
#define SYSCFG_EXTICR4_EXTI12 ((uint16_t)0x000F)
```

EXTI 12 configuration

**5.173.2.2456 SYSCFG\_EXTICR4\_EXTI12\_PA**

```
#define SYSCFG_EXTICR4_EXTI12_PA ((uint16_t)0x0000)
```

EXTI12 configuration

PA[12] pin

**5.173.2.2457 SYSCFG\_EXTICR4\_EXTI12\_PB**

```
#define SYSCFG_EXTICR4_EXTI12_PB ((uint16_t)0x0001)
```

PB[12] pin

**5.173.2.2458 SYSCFG\_EXTICR4 EXTI12\_PC**

```
#define SYSCFG_EXTICR4_EXTI12_PC ((uint16_t)0x0002)  
PC[12] pin
```

**5.173.2.2459 SYSCFG\_EXTICR4 EXTI12\_PD**

```
#define SYSCFG_EXTICR4_EXTI12_PD ((uint16_t)0x0003)  
PD[12] pin
```

**5.173.2.2460 SYSCFG\_EXTICR4 EXTI12\_PE**

```
#define SYSCFG_EXTICR4_EXTI12_PE ((uint16_t)0x0004)  
PE[12] pin
```

**5.173.2.2461 SYSCFG\_EXTICR4 EXTI12\_PF**

```
#define SYSCFG_EXTICR4_EXTI12_PF ((uint16_t)0x0005)  
PF[12] pin
```

**5.173.2.2462 SYSCFG\_EXTICR4 EXTI12\_PG**

```
#define SYSCFG_EXTICR4_EXTI12_PG ((uint16_t)0x0006)  
PG[12] pin
```

**5.173.2.2463 SYSCFG\_EXTICR4 EXTI12\_PH**

```
#define SYSCFG_EXTICR4_EXTI12_PH ((uint16_t)0x0007)  
PH[12] pin
```

**5.173.2.2464 SYSCFG\_EXTICR4 EXTI12\_PI**

```
#define SYSCFG_EXTICR4_EXTI12_PI ((uint16_t)0x0008)  
PI[12] pin
```

**5.173.2.2465 SYSCFG\_EXTICR4 EXTI12\_PJ**

```
#define SYSCFG_EXTICR4_EXTI12_PJ ((uint16_t)0x0009)  
PJ[12] pin
```

**5.173.2.2466 SYSCFG\_EXTICR4\_EXTI13**

```
#define SYSCFG_EXTICR4_EXTI13 ((uint16_t)0x00F0)
```

EXTI 13 configuration

**5.173.2.2467 SYSCFG\_EXTICR4\_EXTI13\_PA**

```
#define SYSCFG_EXTICR4_EXTI13_PA ((uint16_t)0x0000)
```

EXTI13 configuration

PA[13] pin

**5.173.2.2468 SYSCFG\_EXTICR4\_EXTI13\_PB**

```
#define SYSCFG_EXTICR4_EXTI13_PB ((uint16_t)0x0010)
```

PB[13] pin

**5.173.2.2469 SYSCFG\_EXTICR4\_EXTI13\_PC**

```
#define SYSCFG_EXTICR4_EXTI13_PC ((uint16_t)0x0020)
```

PC[13] pin

**5.173.2.2470 SYSCFG\_EXTICR4\_EXTI13\_PD**

```
#define SYSCFG_EXTICR4_EXTI13_PD ((uint16_t)0x0030)
```

PD[13] pin

**5.173.2.2471 SYSCFG\_EXTICR4\_EXTI13\_PE**

```
#define SYSCFG_EXTICR4_EXTI13_PE ((uint16_t)0x0040)
```

PE[13] pin

**5.173.2.2472 SYSCFG\_EXTICR4\_EXTI13\_PF**

```
#define SYSCFG_EXTICR4_EXTI13_PF ((uint16_t)0x0050)
```

PF[13] pin

**5.173.2.2473 SYSCFG\_EXTICR4 EXTI13 PG**

```
#define SYSCFG_EXTICR4_EXTI13_PG ((uint16_t)0x0060)
```

PG[13] pin

**5.173.2.2474 SYSCFG\_EXTICR4 EXTI13 PH**

```
#define SYSCFG_EXTICR4_EXTI13_PH ((uint16_t)0x0070)
```

PH[13] pin

**5.173.2.2475 SYSCFG\_EXTICR4 EXTI13 PI**

```
#define SYSCFG_EXTICR4_EXTI13_PI ((uint16_t)0x0008)
```

PI[13] pin

**5.173.2.2476 SYSCFG\_EXTICR4 EXTI13 PJ**

```
#define SYSCFG_EXTICR4_EXTI13_PJ ((uint16_t)0x0009)
```

PJ[13] pin

**5.173.2.2477 SYSCFG\_EXTICR4 EXTI14**

```
#define SYSCFG_EXTICR4_EXTI14 ((uint16_t)0x0F00)
```

EXTI 14 configuration

**5.173.2.2478 SYSCFG\_EXTICR4 EXTI14 PA**

```
#define SYSCFG_EXTICR4_EXTI14_PA ((uint16_t)0x0000)
```

EXTI14 configuration

PA[14] pin

**5.173.2.2479 SYSCFG\_EXTICR4 EXTI14 PB**

```
#define SYSCFG_EXTICR4_EXTI14_PB ((uint16_t)0x0100)
```

PB[14] pin

**5.173.2.2480 SYSCFG\_EXTICR4 EXTI14\_PC**

```
#define SYSCFG_EXTICR4_EXTI14_PC ((uint16_t)0x0200)  
PC[14] pin
```

**5.173.2.2481 SYSCFG\_EXTICR4 EXTI14\_PD**

```
#define SYSCFG_EXTICR4_EXTI14_PD ((uint16_t)0x0300)  
PD[14] pin
```

**5.173.2.2482 SYSCFG\_EXTICR4 EXTI14\_PE**

```
#define SYSCFG_EXTICR4_EXTI14_PE ((uint16_t)0x0400)  
PE[14] pin
```

**5.173.2.2483 SYSCFG\_EXTICR4 EXTI14\_PF**

```
#define SYSCFG_EXTICR4_EXTI14_PF ((uint16_t)0x0500)  
PF[14] pin
```

**5.173.2.2484 SYSCFG\_EXTICR4 EXTI14\_PG**

```
#define SYSCFG_EXTICR4_EXTI14_PG ((uint16_t)0x0600)  
PG[14] pin
```

**5.173.2.2485 SYSCFG\_EXTICR4 EXTI14\_PH**

```
#define SYSCFG_EXTICR4_EXTI14_PH ((uint16_t)0x0700)  
PH[14] pin
```

**5.173.2.2486 SYSCFG\_EXTICR4 EXTI14\_PI**

```
#define SYSCFG_EXTICR4_EXTI14_PI ((uint16_t)0x0800)  
PI[14] pin
```

**5.173.2.2487 SYSCFG\_EXTICR4 EXTI14\_PJ**

```
#define SYSCFG_EXTICR4_EXTI14_PJ ((uint16_t)0x0900)  
PJ[14] pin
```

**5.173.2.2488 SYSCFG\_EXTICR4\_EXTI15**

```
#define SYSCFG_EXTICR4_EXTI15 ((uint16_t)0xF000)
```

EXTI 15 configuration

**5.173.2.2489 SYSCFG\_EXTICR4\_EXTI15\_PA**

```
#define SYSCFG_EXTICR4_EXTI15_PA ((uint16_t)0x0000)
```

EXTI15 configuration

PA[15] pin

**5.173.2.2490 SYSCFG\_EXTICR4\_EXTI15\_PB**

```
#define SYSCFG_EXTICR4_EXTI15_PB ((uint16_t)0x1000)
```

PB[15] pin

**5.173.2.2491 SYSCFG\_EXTICR4\_EXTI15\_PC**

```
#define SYSCFG_EXTICR4_EXTI15_PC ((uint16_t)0x2000)
```

PC[15] pin

**5.173.2.2492 SYSCFG\_EXTICR4\_EXTI15\_PD**

```
#define SYSCFG_EXTICR4_EXTI15_PD ((uint16_t)0x3000)
```

PD[15] pin

**5.173.2.2493 SYSCFG\_EXTICR4\_EXTI15\_PE**

```
#define SYSCFG_EXTICR4_EXTI15_PE ((uint16_t)0x4000)
```

PE[15] pin

**5.173.2.2494 SYSCFG\_EXTICR4\_EXTI15\_PF**

```
#define SYSCFG_EXTICR4_EXTI15_PF ((uint16_t)0x5000)
```

PF[15] pin

**5.173.2.2495 SYSCFG\_EXTICR4 EXTI15 PG**

```
#define SYSCFG_EXTICR4_EXTI15_PG ((uint16_t)0x6000)  
PG[15] pin
```

**5.173.2.2496 SYSCFG\_EXTICR4 EXTI15 PH**

```
#define SYSCFG_EXTICR4_EXTI15_PH ((uint16_t)0x7000)  
PH[15] pin
```

**5.173.2.2497 SYSCFG\_EXTICR4 EXTI15 PI**

```
#define SYSCFG_EXTICR4_EXTI15_PI ((uint16_t)0x8000)  
PI[15] pin
```

**5.173.2.2498 SYSCFG\_EXTICR4 EXTI15 PJ**

```
#define SYSCFG_EXTICR4_EXTI15_PJ ((uint16_t)0x9000)  
PJ[15] pin
```

**5.173.2.2499 SYSCFG\_MEMRMP\_FB\_MODE**

```
#define SYSCFG_MEMRMP_FB_MODE ((uint32_t)0x00000100)  
User Flash Bank mode
```

**5.173.2.2500 SYSCFG\_MEMRMP\_MEM\_MODE**

```
#define SYSCFG_MEMRMP_MEM_MODE ((uint32_t)0x00000007)  
SYSCFG_Memory Remap Config
```

**5.173.2.2501 SYSCFG\_MEMRMP\_MEM\_MODE\_0**

```
#define SYSCFG_MEMRMP_MEM_MODE_0 ((uint32_t)0x00000001)  
Bit 0
```

**5.173.2.2502 SYSCFG\_MEMRMP\_MEM\_MODE\_1**

```
#define SYSCFG_MEMRMP_MEM_MODE_1 ((uint32_t)0x00000002)  
Bit 1
```

**5.173.2.2503 SYSCFG\_MEMRMP\_MEM\_MODE\_2**

```
#define SYSCFG_MEMRMP_MEM_MODE_2 ((uint32_t)0x00000004)
```

Bit 2

**5.173.2.2504 SYSCFG\_MEMRMP\_SWP\_FMC**

```
#define SYSCFG_MEMRMP_SWP_FMC ((uint32_t)0x00000C00)
```

FMC memory mapping swap

**5.173.2.2505 SYSCFG\_MEMRMP\_SWP\_FMC\_0**

```
#define SYSCFG_MEMRMP_SWP_FMC_0 ((uint32_t)0x00000400)
```

Bit 0

**5.173.2.2506 SYSCFG\_MEMRMP\_SWP\_FMC\_1**

```
#define SYSCFG_MEMRMP_SWP_FMC_1 ((uint32_t)0x00000800)
```

Bit 1

**5.173.2.2507 SYSCFG\_PMC\_ADC1DC2**

```
#define SYSCFG_PMC_ADC1DC2 ((uint32_t)0x00010000)
```

Refer to AN4073 on how to use this bit

**5.173.2.2508 SYSCFG\_PMC\_ADC2DC2**

```
#define SYSCFG_PMC_ADC2DC2 ((uint32_t)0x00020000)
```

Refer to AN4073 on how to use this bit

**5.173.2.2509 SYSCFG\_PMC\_ADC3DC2**

```
#define SYSCFG_PMC_ADC3DC2 ((uint32_t)0x00040000)
```

Refer to AN4073 on how to use this bit

### 5.173.2.2510 SYSCFG\_PMC\_ADCxDC2

```
#define SYSCFG_PMC_ADCxDC2 ((uint32_t)0x00070000)
```

Refer to AN4073 on how to use this bit

### 5.173.2.2511 SYSCFG\_PMC\_MII\_RMII\_SEL

```
#define SYSCFG_PMC_MII_RMII_SEL ((uint32_t)0x00800000)
```

Ethernet PHY interface selection

### 5.173.2.2512 TIM\_ARR\_ARR

```
#define TIM_ARR_ARR ((uint16_t)0xFFFF)
```

actual auto-reload Value

### 5.173.2.2513 TIM\_BDTR\_AOE

```
#define TIM_BDTR_AOE ((uint16_t)0x4000)
```

Automatic Output enable

### 5.173.2.2514 TIM\_BDTR\_BKE

```
#define TIM_BDTR_BKE ((uint16_t)0x1000)
```

Break enable

### 5.173.2.2515 TIM\_BDTR\_BKP

```
#define TIM_BDTR_BKP ((uint16_t)0x2000)
```

Break Polarity

### 5.173.2.2516 TIM\_BDTR\_DTG

```
#define TIM_BDTR_DTG ((uint16_t)0x00FF)
```

DTG[0:7] bits (Dead-Time Generator set-up)

**5.173.2.2517 TIM\_BDTR\_DTG\_0**

```
#define TIM_BDTR_DTG_0 ((uint16_t)0x0001)
```

Bit 0

**5.173.2.2518 TIM\_BDTR\_DTG\_1**

```
#define TIM_BDTR_DTG_1 ((uint16_t)0x0002)
```

Bit 1

**5.173.2.2519 TIM\_BDTR\_DTG\_2**

```
#define TIM_BDTR_DTG_2 ((uint16_t)0x0004)
```

Bit 2

**5.173.2.2520 TIM\_BDTR\_DTG\_3**

```
#define TIM_BDTR_DTG_3 ((uint16_t)0x0008)
```

Bit 3

**5.173.2.2521 TIM\_BDTR\_DTG\_4**

```
#define TIM_BDTR_DTG_4 ((uint16_t)0x0010)
```

Bit 4

**5.173.2.2522 TIM\_BDTR\_DTG\_5**

```
#define TIM_BDTR_DTG_5 ((uint16_t)0x0020)
```

Bit 5

**5.173.2.2523 TIM\_BDTR\_DTG\_6**

```
#define TIM_BDTR_DTG_6 ((uint16_t)0x0040)
```

Bit 6

**5.173.2.2524 TIM\_BDTR\_DTG\_7**

```
#define TIM_BDTR_DTG_7 ((uint16_t)0x0080)
```

Bit 7

**5.173.2.2525 TIM\_BDTR\_LOCK**

```
#define TIM_BDTR_LOCK ((uint16_t)0x0300)
```

LOCK[1:0] bits (Lock Configuration)

**5.173.2.2526 TIM\_BDTR\_LOCK\_0**

```
#define TIM_BDTR_LOCK_0 ((uint16_t)0x0100)
```

Bit 0

**5.173.2.2527 TIM\_BDTR\_LOCK\_1**

```
#define TIM_BDTR_LOCK_1 ((uint16_t)0x0200)
```

Bit 1

**5.173.2.2528 TIM\_BDTR\_MOE**

```
#define TIM_BDTR_MOE ((uint16_t)0x8000)
```

Main Output enable

**5.173.2.2529 TIM\_BDTR\_OSSI**

```
#define TIM_BDTR_OSSI ((uint16_t)0x0400)
```

Off-State Selection for Idle mode

**5.173.2.2530 TIM\_BDTR\_OSSR**

```
#define TIM_BDTR_OSSR ((uint16_t)0x0800)
```

Off-State Selection for Run mode

**5.173.2.2531 TIM\_CCER\_CC1E**

```
#define TIM_CCER_CC1E ((uint16_t)0x0001)
```

Capture/Compare 1 output enable

**5.173.2.2532 TIM\_CCER\_CC1NE**

```
#define TIM_CCER_CC1NE ((uint16_t)0x0004)
```

Capture/Compare 1 Complementary output enable

**5.173.2.2533 TIM\_CCER\_CC1NP**

```
#define TIM_CCER_CC1NP ((uint16_t)0x0008)
```

Capture/Compare 1 Complementary output Polarity

**5.173.2.2534 TIM\_CCER\_CC1P**

```
#define TIM_CCER_CC1P ((uint16_t)0x0002)
```

Capture/Compare 1 output Polarity

**5.173.2.2535 TIM\_CCER\_CC2E**

```
#define TIM_CCER_CC2E ((uint16_t)0x0010)
```

Capture/Compare 2 output enable

**5.173.2.2536 TIM\_CCER\_CC2NE**

```
#define TIM_CCER_CC2NE ((uint16_t)0x0040)
```

Capture/Compare 2 Complementary output enable

**5.173.2.2537 TIM\_CCER\_CC2NP**

```
#define TIM_CCER_CC2NP ((uint16_t)0x0080)
```

Capture/Compare 2 Complementary output Polarity

**5.173.2.2538 TIM\_CCER\_CC2P**

```
#define TIM_CCER_CC2P ((uint16_t)0x0020)
```

Capture/Compare 2 output Polarity

**5.173.2.2539 TIM\_CCER\_CC3E**

```
#define TIM_CCER_CC3E ((uint16_t)0x0100)
```

Capture/Compare 3 output enable

**5.173.2.2540 TIM\_CCER\_CC3NE**

```
#define TIM_CCER_CC3NE ((uint16_t)0x0400)
```

Capture/Compare 3 Complementary output enable

**5.173.2.2541 TIM\_CCER\_CC3NP**

```
#define TIM_CCER_CC3NP ((uint16_t)0x0800)
```

Capture/Compare 3 Complementary output Polarity

**5.173.2.2542 TIM\_CCER\_CC3P**

```
#define TIM_CCER_CC3P ((uint16_t)0x0200)
```

Capture/Compare 3 output Polarity

**5.173.2.2543 TIM\_CCER\_CC4E**

```
#define TIM_CCER_CC4E ((uint16_t)0x1000)
```

Capture/Compare 4 output enable

**5.173.2.2544 TIM\_CCER\_CC4NP**

```
#define TIM_CCER_CC4NP ((uint16_t)0x8000)
```

Capture/Compare 4 Complementary output Polarity

**5.173.2.2545 TIM\_CCER\_CC4P**

```
#define TIM_CCER_CC4P ((uint16_t)0x2000)
```

Capture/Compare 4 output Polarity

**5.173.2.2546 TIM\_CCMR1\_CC1S**

```
#define TIM_CCMR1_CC1S ((uint16_t)0x0003)
```

CC1S[1:0] bits (Capture/Compare 1 Selection)

**5.173.2.2547 TIM\_CCMR1\_CC1S\_0**

```
#define TIM_CCMR1_CC1S_0 ((uint16_t)0x0001)
```

Bit 0

**5.173.2.2548 TIM\_CCMR1\_CC1S\_1**

```
#define TIM_CCMR1_CC1S_1 ((uint16_t)0x0002)
```

Bit 1

**5.173.2.2549 TIM\_CCMR1\_CC2S**

```
#define TIM_CCMR1_CC2S ((uint16_t)0x0300)
```

CC2S[1:0] bits (Capture/Compare 2 Selection)

**5.173.2.2550 TIM\_CCMR1\_CC2S\_0**

```
#define TIM_CCMR1_CC2S_0 ((uint16_t)0x0100)
```

Bit 0

**5.173.2.2551 TIM\_CCMR1\_CC2S\_1**

```
#define TIM_CCMR1_CC2S_1 ((uint16_t)0x0200)
```

Bit 1

**5.173.2.2552 TIM\_CCMR1\_IC1F**

```
#define TIM_CCMR1_IC1F ((uint16_t)0x00F0)
```

IC1F[3:0] bits (Input Capture 1 Filter)

**5.173.2.2553 TIM\_CCMR1\_IC1F\_0**

```
#define TIM_CCMR1_IC1F_0 ((uint16_t)0x0010)
```

Bit 0

**5.173.2.2554 TIM\_CCMR1\_IC1F\_1**

```
#define TIM_CCMR1_IC1F_1 ((uint16_t)0x0020)
```

Bit 1

**5.173.2.2555 TIM\_CCMR1\_IC1F\_2**

```
#define TIM_CCMR1_IC1F_2 ((uint16_t)0x0040)
```

Bit 2

**5.173.2.2556 TIM\_CCMR1\_IC1F\_3**

```
#define TIM_CCMR1_IC1F_3 ((uint16_t)0x0080)
```

Bit 3

**5.173.2.2557 TIM\_CCMR1\_IC1PSC**

```
#define TIM_CCMR1_IC1PSC ((uint16_t)0x000C)
```

IC1PSC[1:0] bits (Input Capture 1 Prescaler)

**5.173.2.2558 TIM\_CCMR1\_IC1PSC\_0**

```
#define TIM_CCMR1_IC1PSC_0 ((uint16_t)0x0004)
```

Bit 0

**5.173.2.2559 TIM\_CCMR1\_IC1PSC\_1**

```
#define TIM_CCMR1_IC1PSC_1 ((uint16_t)0x0008)
```

Bit 1

**5.173.2.2560 TIM\_CCMR1\_IC2F**

```
#define TIM_CCMR1_IC2F ((uint16_t)0xF000)
```

IC2F[3:0] bits (Input Capture 2 Filter)

**5.173.2.2561 TIM\_CCMR1\_IC2F\_0**

```
#define TIM_CCMR1_IC2F_0 ((uint16_t)0x1000)
```

Bit 0

**5.173.2.2562 TIM\_CCMR1\_IC2F\_1**

```
#define TIM_CCMR1_IC2F_1 ((uint16_t)0x2000)
```

Bit 1

**5.173.2.2563 TIM\_CCMR1\_IC2F\_2**

```
#define TIM_CCMR1_IC2F_2 ((uint16_t)0x4000)
```

Bit 2

**5.173.2.2564 TIM\_CCMR1\_IC2F\_3**

```
#define TIM_CCMR1_IC2F_3 ((uint16_t)0x8000)
```

Bit 3

**5.173.2.2565 TIM\_CCMR1\_IC2PSC**

```
#define TIM_CCMR1_IC2PSC ((uint16_t)0x0C00)
```

IC2PSC[1:0] bits (Input Capture 2 Prescaler)

**5.173.2.2566 TIM\_CCMR1\_IC2PSC\_0**

```
#define TIM_CCMR1_IC2PSC_0 ((uint16_t)0x0400)
```

Bit 0

**5.173.2.2567 TIM\_CCMR1\_IC2PSC\_1**

```
#define TIM_CCMR1_IC2PSC_1 ((uint16_t)0x0800)
```

Bit 1

**5.173.2.2568 TIM\_CCMR1\_OC1CE**

```
#define TIM_CCMR1_OC1CE ((uint16_t)0x0080)
```

Output Compare 1Clear Enable

**5.173.2.2569 TIM\_CCMR1\_OC1FE**

```
#define TIM_CCMR1_OC1FE ((uint16_t)0x0004)
```

Output Compare 1 Fast enable

**5.173.2.2570 TIM\_CCMR1\_OC1M**

```
#define TIM_CCMR1_OC1M ((uint16_t)0x0070)
```

OC1M[2:0] bits (Output Compare 1 Mode)

**5.173.2.2571 TIM\_CCMR1\_OC1M\_0**

```
#define TIM_CCMR1_OC1M_0 ((uint16_t)0x0010)
```

Bit 0

**5.173.2.2572 TIM\_CCMR1\_OC1M\_1**

```
#define TIM_CCMR1_OC1M_1 ((uint16_t)0x0020)
```

Bit 1

**5.173.2.2573 TIM\_CCMR1\_OC1M\_2**

```
#define TIM_CCMR1_OC1M_2 ((uint16_t)0x0040)
```

Bit 2

**5.173.2.2574 TIM\_CCMR1\_OC1PE**

```
#define TIM_CCMR1_OC1PE ((uint16_t)0x0008)
```

Output Compare 1 Preload enable

**5.173.2.2575 TIM\_CCMR1\_OC2CE**

```
#define TIM_CCMR1_OC2CE ((uint16_t)0x8000)
```

Output Compare 2 Clear Enable

**5.173.2.2576 TIM\_CCMR1\_OC2FE**

```
#define TIM_CCMR1_OC2FE ((uint16_t)0x0400)
```

Output Compare 2 Fast enable

**5.173.2.2577 TIM\_CCMR1\_OC2M**

```
#define TIM_CCMR1_OC2M ((uint16_t)0x7000)
```

OC2M[2:0] bits (Output Compare 2 Mode)

**5.173.2.2578 TIM\_CCMR1\_OC2M\_0**

```
#define TIM_CCMR1_OC2M_0 ((uint16_t)0x1000)
```

Bit 0

**5.173.2.2579 TIM\_CCMR1\_OC2M\_1**

```
#define TIM_CCMR1_OC2M_1 ((uint16_t)0x2000)
```

Bit 1

**5.173.2.2580 TIM\_CCMR1\_OC2M\_2**

```
#define TIM_CCMR1_OC2M_2 ((uint16_t)0x4000)
```

Bit 2

**5.173.2.2581 TIM\_CCMR1\_OC2PE**

```
#define TIM_CCMR1_OC2PE ((uint16_t)0x0800)
```

Output Compare 2 Preload enable

**5.173.2.2582 TIM\_CCMR2\_CC3S**

```
#define TIM_CCMR2_CC3S ((uint16_t)0x0003)
```

CC3S[1:0] bits (Capture/Compare 3 Selection)

**5.173.2.2583 TIM\_CCMR2\_CC3S\_0**

```
#define TIM_CCMR2_CC3S_0 ((uint16_t)0x0001)
```

Bit 0

**5.173.2.2584 TIM\_CCMR2\_CC3S\_1**

```
#define TIM_CCMR2_CC3S_1 ((uint16_t)0x0002)
```

Bit 1

**5.173.2.2585 TIM\_CCMR2\_CC4S**

```
#define TIM_CCMR2_CC4S ((uint16_t)0x0300)
```

CC4S[1:0] bits (Capture/Compare 4 Selection)

**5.173.2.2586 TIM\_CCMR2\_CC4S\_0**

```
#define TIM_CCMR2_CC4S_0 ((uint16_t)0x0100)
```

Bit 0

**5.173.2.2587 TIM\_CCMR2\_CC4S\_1**

```
#define TIM_CCMR2_CC4S_1 ((uint16_t)0x0200)
```

Bit 1

**5.173.2.2588 TIM\_CCMR2\_IC3F**

```
#define TIM_CCMR2_IC3F ((uint16_t)0x00F0)
```

IC3F[3:0] bits (Input Capture 3 Filter)

**5.173.2.2589 TIM\_CCMR2\_IC3F\_0**

```
#define TIM_CCMR2_IC3F_0 ((uint16_t)0x0010)
```

Bit 0

**5.173.2.2590 TIM\_CCMR2\_IC3F\_1**

```
#define TIM_CCMR2_IC3F_1 ((uint16_t)0x0020)
```

Bit 1

**5.173.2.2591 TIM\_CCMR2\_IC3F\_2**

```
#define TIM_CCMR2_IC3F_2 ((uint16_t)0x0040)
```

Bit 2

**5.173.2.2592 TIM\_CCMR2\_IC3F\_3**

```
#define TIM_CCMR2_IC3F_3 ((uint16_t)0x0080)
```

Bit 3

**5.173.2.2593 TIM\_CCMR2\_IC3PSC**

```
#define TIM_CCMR2_IC3PSC ((uint16_t)0x000C)
```

IC3PSC[1:0] bits (Input Capture 3 Prescaler)

**5.173.2.2594 TIM\_CCMR2\_IC3PSC\_0**

```
#define TIM_CCMR2_IC3PSC_0 ((uint16_t)0x0004)
```

Bit 0

**5.173.2.2595 TIM\_CCMR2\_IC3PSC\_1**

```
#define TIM_CCMR2_IC3PSC_1 ((uint16_t)0x0008)
```

Bit 1

**5.173.2.2596 TIM\_CCMR2\_IC4F**

```
#define TIM_CCMR2_IC4F ((uint16_t)0xF000)
```

IC4F[3:0] bits (Input Capture 4 Filter)

**5.173.2.2597 TIM\_CCMR2\_IC4F\_0**

```
#define TIM_CCMR2_IC4F_0 ((uint16_t)0x1000)
```

Bit 0

**5.173.2.2598 TIM\_CCMR2\_IC4F\_1**

```
#define TIM_CCMR2_IC4F_1 ((uint16_t)0x2000)
```

Bit 1

**5.173.2.2599 TIM\_CCMR2\_IC4F\_2**

```
#define TIM_CCMR2_IC4F_2 ((uint16_t)0x4000)
```

Bit 2

**5.173.2.2600 TIM\_CCMR2\_IC4F\_3**

```
#define TIM_CCMR2_IC4F_3 ((uint16_t)0x8000)
```

Bit 3

**5.173.2.2601 TIM\_CCMR2\_IC4PSC**

```
#define TIM_CCMR2_IC4PSC ((uint16_t)0x0C00)
```

IC4PSC[1:0] bits (Input Capture 4 Prescaler)

**5.173.2.2602 TIM\_CCMR2\_IC4PSC\_0**

```
#define TIM_CCMR2_IC4PSC_0 ((uint16_t)0x0400)
```

Bit 0

**5.173.2.2603 TIM\_CCMR2\_IC4PSC\_1**

```
#define TIM_CCMR2_IC4PSC_1 ((uint16_t)0x0800)
```

Bit 1

**5.173.2.2604 TIM\_CCMR2\_OC3CE**

```
#define TIM_CCMR2_OC3CE ((uint16_t)0x0080)
```

Output Compare 3 Clear Enable

**5.173.2.2605 TIM\_CCMR2\_OC3FE**

```
#define TIM_CCMR2_OC3FE ((uint16_t)0x0004)
```

Output Compare 3 Fast enable

**5.173.2.2606 TIM\_CCMR2\_OC3M**

```
#define TIM_CCMR2_OC3M ((uint16_t)0x0070)
```

OC3M[2:0] bits (Output Compare 3 Mode)

**5.173.2.2607 TIM\_CCMR2\_OC3M\_0**

```
#define TIM_CCMR2_OC3M_0 ((uint16_t)0x0010)
```

Bit 0

**5.173.2.2608 TIM\_CCMR2\_OC3M\_1**

```
#define TIM_CCMR2_OC3M_1 ((uint16_t)0x0020)
```

Bit 1

**5.173.2.2609 TIM\_CCMR2\_OC3M\_2**

```
#define TIM_CCMR2_OC3M_2 ((uint16_t)0x0040)
```

Bit 2

**5.173.2.2610 TIM\_CCMR2\_OC3PE**

```
#define TIM_CCMR2_OC3PE ((uint16_t)0x0008)
```

Output Compare 3 Preload enable

**5.173.2.2611 TIM\_CCMR2\_OC4CE**

```
#define TIM_CCMR2_OC4CE ((uint16_t)0x8000)
```

Output Compare 4 Clear Enable

**5.173.2.2612 TIM\_CCMR2\_OC4FE**

```
#define TIM_CCMR2_OC4FE ((uint16_t)0x0400)
```

Output Compare 4 Fast enable

**5.173.2.2613 TIM\_CCMR2\_OC4M**

```
#define TIM_CCMR2_OC4M ((uint16_t)0x7000)
```

OC4M[2:0] bits (Output Compare 4 Mode)

**5.173.2.2614 TIM\_CCMR2\_OC4M\_0**

```
#define TIM_CCMR2_OC4M_0 ((uint16_t)0x1000)
```

Bit 0

**5.173.2.2615 TIM\_CCMR2\_OC4M\_1**

```
#define TIM_CCMR2_OC4M_1 ((uint16_t)0x2000)
```

Bit 1

**5.173.2.2616 TIM\_CCMR2\_OC4M\_2**

```
#define TIM_CCMR2_OC4M_2 ((uint16_t)0x4000)
```

Bit 2

**5.173.2.2617 TIM\_CCMR2\_OC4PE**

```
#define TIM_CCMR2_OC4PE ((uint16_t)0x0800)
```

Output Compare 4 Preload enable

**5.173.2.2618 TIM\_CCR1\_CCR1**

```
#define TIM_CCR1_CCR1 ((uint16_t)0xFFFF)
```

Capture/Compare 1 Value

**5.173.2.2619 TIM\_CCR2\_CCR2**

```
#define TIM_CCR2_CCR2 ((uint16_t)0xFFFF)
```

Capture/Compare 2 Value

**5.173.2.2620 TIM\_CCR3\_CCR3**

```
#define TIM_CCR3_CCR3 ((uint16_t)0xFFFF)
```

Capture/Compare 3 Value

**5.173.2.2621 TIM\_CCR4\_CCR4**

```
#define TIM_CCR4_CCR4 ((uint16_t)0xFFFF)
```

Capture/Compare 4 Value

**5.173.2.2622 TIM\_CNT\_CNT**

```
#define TIM_CNT_CNT ((uint16_t)0xFFFF)
```

Counter Value

**5.173.2.2623 TIM\_CR1\_ARPE**

```
#define TIM_CR1_ARPE ((uint16_t)0x0080)
```

Auto-reload preload enable

**5.173.2.2624 TIM\_CR1\_CEN**

```
#define TIM_CR1_CEN ((uint16_t)0x0001)
```

Counter enable

**5.173.2.2625 TIM\_CR1\_CKD**

```
#define TIM_CR1_CKD ((uint16_t)0x0300)
```

CKD[1:0] bits (clock division)

**5.173.2.2626 TIM\_CR1\_CKD\_0**

```
#define TIM_CR1_CKD_0 ((uint16_t)0x0100)
```

Bit 0

**5.173.2.2627 TIM\_CR1\_CKD\_1**

```
#define TIM_CR1_CKD_1 ((uint16_t)0x0200)
```

Bit 1

**5.173.2.2628 TIM\_CR1\_CMS**

```
#define TIM_CR1_CMS ((uint16_t)0x0060)
```

CMS[1:0] bits (Center-aligned mode selection)

**5.173.2.2629 TIM\_CR1\_CMS\_0**

```
#define TIM_CR1_CMS_0 ((uint16_t)0x0020)
```

Bit 0

**5.173.2.2630 TIM\_CR1\_CMS\_1**

```
#define TIM_CR1_CMS_1 ((uint16_t)0x0040)
```

Bit 1

**5.173.2.2631 TIM\_CR1\_DIR**

```
#define TIM_CR1_DIR ((uint16_t)0x0010)
```

Direction

**5.173.2.2632 TIM\_CR1\_OPM**

```
#define TIM_CR1_OPM ((uint16_t)0x0008)
```

One pulse mode

**5.173.2.2633 TIM\_CR1\_UDIS**

```
#define TIM_CR1_UDIS ((uint16_t)0x0002)
```

Update disable

**5.173.2.2634 TIM\_CR1\_URS**

```
#define TIM_CR1_URS ((uint16_t)0x0004)
```

Update request source

**5.173.2.2635 TIM\_CR2\_CCDS**

```
#define TIM_CR2_CCDS ((uint16_t)0x0008)
```

Capture/Compare DMA Selection

**5.173.2.2636 TIM\_CR2\_CCPC**

```
#define TIM_CR2_CCPC ((uint16_t)0x0001)
```

Capture/Compare Preloaded Control

**5.173.2.2637 TIM\_CR2\_CCUS**

```
#define TIM_CR2_CCUS ((uint16_t)0x0004)
```

Capture/Compare Control Update Selection

**5.173.2.2638 TIM\_CR2\_MMS**

```
#define TIM_CR2_MMS ((uint16_t)0x0070)
```

MMS[2:0] bits (Master Mode Selection)

**5.173.2.2639 TIM\_CR2\_MMS\_0**

```
#define TIM_CR2_MMS_0 ((uint16_t)0x0010)
```

Bit 0

**5.173.2.2640 TIM\_CR2\_MMS\_1**

```
#define TIM_CR2_MMS_1 ((uint16_t)0x0020)
```

Bit 1

**5.173.2.2641 TIM\_CR2\_MMS\_2**

```
#define TIM_CR2_MMS_2 ((uint16_t)0x0040)
```

Bit 2

**5.173.2.2642 TIM\_CR2\_OIS1**

```
#define TIM_CR2_OIS1 ((uint16_t)0x0100)
```

Output Idle state 1 (OC1 output)

**5.173.2.2643 TIM\_CR2\_OIS1N**

```
#define TIM_CR2_OIS1N ((uint16_t)0x0200)
```

Output Idle state 1 (OC1N output)

**5.173.2.2644 TIM\_CR2\_OIS2**

```
#define TIM_CR2_OIS2 ((uint16_t)0x0400)
```

Output Idle state 2 (OC2 output)

**5.173.2.2645 TIM\_CR2\_OIS2N**

```
#define TIM_CR2_OIS2N ((uint16_t)0x0800)
```

Output Idle state 2 (OC2N output)

**5.173.2.2646 TIM\_CR2\_OIS3**

```
#define TIM_CR2_OIS3 ((uint16_t)0x1000)
```

Output Idle state 3 (OC3 output)

**5.173.2.2647 TIM\_CR2\_OIS3N**

```
#define TIM_CR2_OIS3N ((uint16_t)0x2000)
```

Output Idle state 3 (OC3N output)

**5.173.2.2648 TIM\_CR2\_OIS4**

```
#define TIM_CR2_OIS4 ((uint16_t)0x4000)
```

Output Idle state 4 (OC4 output)

**5.173.2.2649 TIM\_CR2\_TI1S**

```
#define TIM_CR2_TI1S ((uint16_t)0x0080)
```

TI1 Selection

**5.173.2.2650 TIM\_DCR\_DBA**

```
#define TIM_DCR_DBA ((uint16_t)0x001F)
```

DBA[4:0] bits (DMA Base Address)

**5.173.2.2651 TIM\_DCR\_DBA\_0**

```
#define TIM_DCR_DBA_0 ((uint16_t)0x0001)
```

Bit 0

**5.173.2.2652 TIM\_DCR\_DBA\_1**

```
#define TIM_DCR_DBA_1 ((uint16_t)0x0002)
```

Bit 1

**5.173.2.2653 TIM\_DCR\_DBA\_2**

```
#define TIM_DCR_DBA_2 ((uint16_t)0x0004)
```

Bit 2

**5.173.2.2654 TIM\_DCR\_DBAA\_3**

```
#define TIM_DCR_DBAA_3 ((uint16_t)0x0008)
```

Bit 3

**5.173.2.2655 TIM\_DCR\_DBAA\_4**

```
#define TIM_DCR_DBAA_4 ((uint16_t)0x0010)
```

Bit 4

**5.173.2.2656 TIM\_DCR\_DBBL**

```
#define TIM_DCR_DBBL ((uint16_t)0x1F00)
```

DBL[4:0] bits (DMA Burst Length)

**5.173.2.2657 TIM\_DCR\_DBBL\_0**

```
#define TIM_DCR_DBBL_0 ((uint16_t)0x0100)
```

Bit 0

**5.173.2.2658 TIM\_DCR\_DBBL\_1**

```
#define TIM_DCR_DBBL_1 ((uint16_t)0x0200)
```

Bit 1

**5.173.2.2659 TIM\_DCR\_DBBL\_2**

```
#define TIM_DCR_DBBL_2 ((uint16_t)0x0400)
```

Bit 2

**5.173.2.2660 TIM\_DCR\_DBBL\_3**

```
#define TIM_DCR_DBBL_3 ((uint16_t)0x0800)
```

Bit 3

**5.173.2.2661 TIM\_DCR\_DBBL\_4**

```
#define TIM_DCR_DBBL_4 ((uint16_t)0x1000)
```

Bit 4

**5.173.2.2662 TIM\_DIER\_BIE**

```
#define TIM_DIER_BIE ((uint16_t)0x0080)
```

Break interrupt enable

**5.173.2.2663 TIM\_DIER\_CC1DE**

```
#define TIM_DIER_CC1DE ((uint16_t)0x0200)
```

Capture/Compare 1 DMA request enable

**5.173.2.2664 TIM\_DIER\_CC1IE**

```
#define TIM_DIER_CC1IE ((uint16_t)0x0002)
```

Capture/Compare 1 interrupt enable

**5.173.2.2665 TIM\_DIER\_CC2DE**

```
#define TIM_DIER_CC2DE ((uint16_t)0x0400)
```

Capture/Compare 2 DMA request enable

**5.173.2.2666 TIM\_DIER\_CC2IE**

```
#define TIM_DIER_CC2IE ((uint16_t)0x0004)
```

Capture/Compare 2 interrupt enable

**5.173.2.2667 TIM\_DIER\_CC3DE**

```
#define TIM_DIER_CC3DE ((uint16_t)0x0800)
```

Capture/Compare 3 DMA request enable

**5.173.2.2668 TIM\_DIER\_CC3IE**

```
#define TIM_DIER_CC3IE ((uint16_t)0x0008)
```

Capture/Compare 3 interrupt enable

**5.173.2.2669 TIM\_DIER\_CC4DE**

```
#define TIM_DIER_CC4DE ((uint16_t)0x1000)
```

Capture/Compare 4 DMA request enable

**5.173.2.2670 TIM\_DIER\_CC4IE**

```
#define TIM_DIER_CC4IE ((uint16_t)0x0010)
```

Capture/Compare 4 interrupt enable

**5.173.2.2671 TIM\_DIER\_COMDE**

```
#define TIM_DIER_COMDE ((uint16_t)0x2000)
```

COM DMA request enable

**5.173.2.2672 TIM\_DIER\_COMIE**

```
#define TIM_DIER_COMIE ((uint16_t)0x0020)
```

COM interrupt enable

**5.173.2.2673 TIM\_DIER\_TDE**

```
#define TIM_DIER_TDE ((uint16_t)0x4000)
```

Trigger DMA request enable

**5.173.2.2674 TIM\_DIER\_TIE**

```
#define TIM_DIER_TIE ((uint16_t)0x0040)
```

Trigger interrupt enable

**5.173.2.2675 TIM\_DIER\_UDE**

```
#define TIM_DIER_UDE ((uint16_t)0x0100)
```

Update DMA request enable

**5.173.2.2676 TIM\_DIER\_UIE**

```
#define TIM_DIER_UIE ((uint16_t)0x0001)
```

Update interrupt enable

**5.173.2.2677 TIM\_DMAR\_DMAB**

```
#define TIM_DMAR_DMAB ((uint16_t)0xFFFF)
```

DMA register for burst accesses

**5.173.2.2678 TIM\_EGR\_BG**

```
#define TIM_EGR_BG ((uint8_t)0x80)
```

Break Generation

**5.173.2.2679 TIM\_EGR\_CC1G**

```
#define TIM_EGR_CC1G ((uint8_t)0x02)
```

Capture/Compare 1 Generation

**5.173.2.2680 TIM\_EGR\_CC2G**

```
#define TIM_EGR_CC2G ((uint8_t)0x04)
```

Capture/Compare 2 Generation

**5.173.2.2681 TIM\_EGR\_CC3G**

```
#define TIM_EGR_CC3G ((uint8_t)0x08)
```

Capture/Compare 3 Generation

**5.173.2.2682 TIM\_EGR\_CC4G**

```
#define TIM_EGR_CC4G ((uint8_t)0x10)
```

Capture/Compare 4 Generation

**5.173.2.2683 TIM\_EGR\_COMG**

```
#define TIM_EGR_COMG ((uint8_t)0x20)
```

Capture/Compare Control Update Generation

**5.173.2.2684 TIM\_EGR\_TG**

```
#define TIM_EGR_TG ((uint8_t)0x40)
```

Trigger Generation

**5.173.2.2685 TIM\_EGR\_UG**

```
#define TIM_EGR_UG ((uint8_t)0x01)
```

Update Generation

**5.173.2.2686 TIM\_OR\_ITR1\_RMP**

```
#define TIM_OR_ITR1_RMP ((uint16_t)0x0C00)
```

ITR1\_RMP[1:0] bits (TIM2 Internal trigger 1 remap)

**5.173.2.2687 TIM\_OR\_ITR1\_RMP\_0**

```
#define TIM_OR_ITR1_RMP_0 ((uint16_t)0x0400)
```

Bit 0

**5.173.2.2688 TIM\_OR\_ITR1\_RMP\_1**

```
#define TIM_OR_ITR1_RMP_1 ((uint16_t)0x0800)
```

Bit 1

**5.173.2.2689 TIM\_OR\_TI4\_RMP**

```
#define TIM_OR_TI4_RMP ((uint16_t)0x00C0)
```

TI4\_RMP[1:0] bits (TIM5 Input 4 remap)

**5.173.2.2690 TIM\_OR\_TI4\_RMP\_0**

```
#define TIM_OR_TI4_RMP_0 ((uint16_t)0x0040)
```

Bit 0

**5.173.2.2691 TIM\_OR\_TI4\_RMP\_1**

```
#define TIM_OR_TI4_RMP_1 ((uint16_t)0x0080)
```

Bit 1

**5.173.2.2692 TIM\_PSC\_PSC**

```
#define TIM_PSC_PSC ((uint16_t)0xFFFF)
```

Prescaler Value

**5.173.2.2693 TIM\_RCR REP**

```
#define TIM_RCR REP ((uint8_t)0xFF)
```

Repetition Counter Value

**5.173.2.2694 TIM\_SMCR\_ECE**

```
#define TIM_SMCR_ECE ((uint16_t)0x4000)
```

External clock enable

**5.173.2.2695 TIM\_SMCR ETF**

```
#define TIM_SMCR ETF ((uint16_t)0x0F00)
```

ETF[3:0] bits (External trigger filter)

**5.173.2.2696 TIM\_SMCR ETF\_0**

```
#define TIM_SMCR ETF_0 ((uint16_t)0x0100)
```

Bit 0

**5.173.2.2697 TIM\_SMCR\_ETF\_1**

```
#define TIM_SMCR_ETF_1 ((uint16_t)0x0200)
```

Bit 1

**5.173.2.2698 TIM\_SMCR\_ETF\_2**

```
#define TIM_SMCR_ETF_2 ((uint16_t)0x0400)
```

Bit 2

**5.173.2.2699 TIM\_SMCR\_ETF\_3**

```
#define TIM_SMCR_ETF_3 ((uint16_t)0x0800)
```

Bit 3

**5.173.2.2700 TIM\_SMCR\_ETP**

```
#define TIM_SMCR_ETP ((uint16_t)0x8000)
```

External trigger polarity

**5.173.2.2701 TIM\_SMCR\_ETPS**

```
#define TIM_SMCR_ETPS ((uint16_t)0x3000)
```

ETPS[1:0] bits (External trigger prescaler)

**5.173.2.2702 TIM\_SMCR\_ETPS\_0**

```
#define TIM_SMCR_ETPS_0 ((uint16_t)0x1000)
```

Bit 0

**5.173.2.2703 TIM\_SMCR\_ETPS\_1**

```
#define TIM_SMCR_ETPS_1 ((uint16_t)0x2000)
```

Bit 1

**5.173.2.2704 TIM\_SMCR\_MSM**

```
#define TIM_SMCR_MSM ((uint16_t)0x0080)
```

Master/slave mode

**5.173.2.2705 TIM\_SMCR\_SMS**

```
#define TIM_SMCR_SMS ((uint16_t)0x0007)
```

SMS[2:0] bits (Slave mode selection)

**5.173.2.2706 TIM\_SMCR\_SMS\_0**

```
#define TIM_SMCR_SMS_0 ((uint16_t)0x0001)
```

Bit 0

**5.173.2.2707 TIM\_SMCR\_SMS\_1**

```
#define TIM_SMCR_SMS_1 ((uint16_t)0x0002)
```

Bit 1

**5.173.2.2708 TIM\_SMCR\_SMS\_2**

```
#define TIM_SMCR_SMS_2 ((uint16_t)0x0004)
```

Bit 2

**5.173.2.2709 TIM\_SMCR\_TS**

```
#define TIM_SMCR_TS ((uint16_t)0x0070)
```

TS[2:0] bits (Trigger selection)

**5.173.2.2710 TIM\_SMCR\_TS\_0**

```
#define TIM_SMCR_TS_0 ((uint16_t)0x0010)
```

Bit 0

**5.173.2.2711 TIM\_SMCR\_TS\_1**

```
#define TIM_SMCR_TS_1 ((uint16_t)0x0020)
```

Bit 1

**5.173.2.2712 TIM\_SMCR\_TS\_2**

```
#define TIM_SMCR_TS_2 ((uint16_t)0x0040)
```

Bit 2

**5.173.2.2713 TIM\_SR\_BIF**

```
#define TIM_SR_BIF ((uint16_t)0x0080)
```

Break interrupt Flag

**5.173.2.2714 TIM\_SR\_CC1IF**

```
#define TIM_SR_CC1IF ((uint16_t)0x0002)
```

Capture/Compare 1 interrupt Flag

**5.173.2.2715 TIM\_SR\_CC1OF**

```
#define TIM_SR_CC1OF ((uint16_t)0x0200)
```

Capture/Compare 1 Overcapture Flag

**5.173.2.2716 TIM\_SR\_CC2IF**

```
#define TIM_SR_CC2IF ((uint16_t)0x0004)
```

Capture/Compare 2 interrupt Flag

**5.173.2.2717 TIM\_SR\_CC2OF**

```
#define TIM_SR_CC2OF ((uint16_t)0x0400)
```

Capture/Compare 2 Overcapture Flag

**5.173.2.2718 TIM\_SR\_CC3IF**

```
#define TIM_SR_CC3IF ((uint16_t)0x0008)
```

Capture/Compare 3 interrupt Flag

**5.173.2.2719 TIM\_SR\_CC3OF**

```
#define TIM_SR_CC3OF ((uint16_t)0x0800)
```

Capture/Compare 3 Overcapture Flag

**5.173.2.2720 TIM\_SR\_CC4IF**

```
#define TIM_SR_CC4IF ((uint16_t)0x0010)
```

Capture/Compare 4 interrupt Flag

**5.173.2.2721 TIM\_SR\_CC4OF**

```
#define TIM_SR_CC4OF ((uint16_t)0x1000)
```

Capture/Compare 4 Overcapture Flag

**5.173.2.2722 TIM\_SR\_COMIF**

```
#define TIM_SR_COMIF ((uint16_t)0x0020)
```

COM interrupt Flag

**5.173.2.2723 TIM\_SR\_TIF**

```
#define TIM_SR_TIF ((uint16_t)0x0040)
```

Trigger interrupt Flag

**5.173.2.2724 TIM\_SR\_UIF**

```
#define TIM_SR_UIF ((uint16_t)0x0001)
```

Update interrupt Flag

**5.173.2.2725 USART\_BRR\_DIV\_Fraction**

```
#define USART_BRR_DIV_Fraction ((uint16_t)0x000F)
```

Fraction of USARTDIV

**5.173.2.2726 USART\_BRR\_DIV\_Mantissa**

```
#define USART_BRR_DIV_Mantissa ((uint16_t)0xFFFF)
```

Mantissa of USARTDIV

**5.173.2.2727 USART\_CR1\_IDLEIE**

```
#define USART_CR1_IDLEIE ((uint16_t)0x0010)
```

IDLE Interrupt Enable

**5.173.2.2728 USART\_CR1\_M**

```
#define USART_CR1_M ((uint16_t)0x1000)
```

Word length

**5.173.2.2729 USART\_CR1\_OVER8**

```
#define USART_CR1_OVER8 ((uint16_t)0x8000)
```

USART Oversampling by 8 enable

**5.173.2.2730 USART\_CR1\_PCE**

```
#define USART_CR1_PCE ((uint16_t)0x0400)
```

Parity Control Enable

**5.173.2.2731 USART\_CR1\_PEIE**

```
#define USART_CR1_PEIE ((uint16_t)0x0100)
```

PE Interrupt Enable

**5.173.2.2732 USART\_CR1\_PS**

```
#define USART_CR1_PS ((uint16_t)0x0200)
```

Parity Selection

**5.173.2.2733 USART\_CR1\_RE**

```
#define USART_CR1_RE ((uint16_t)0x0004)
```

Receiver Enable

**5.173.2.2734 USART\_CR1\_RWU**

```
#define USART_CR1_RWU ((uint16_t)0x0002)
```

Receiver wakeup

**5.173.2.2735 USART\_CR1\_RXNEIE**

```
#define USART_CR1_RXNEIE ((uint16_t)0x0020)
```

RXNE Interrupt Enable

**5.173.2.2736 USART\_CR1\_SBK**

```
#define USART_CR1_SBK ((uint16_t)0x0001)
```

Send Break

**5.173.2.2737 USART\_CR1\_TCIE**

```
#define USART_CR1_TCIE ((uint16_t)0x0040)
```

Transmission Complete Interrupt Enable

**5.173.2.2738 USART\_CR1\_TE**

```
#define USART_CR1_TE ((uint16_t)0x0008)
```

Transmitter Enable

**5.173.2.2739 USART\_CR1\_TXEIE**

```
#define USART_CR1_TXEIE ((uint16_t)0x0080)
```

PE Interrupt Enable

**5.173.2.2740 USART\_CR1\_UE**

```
#define USART_CR1_UE ((uint16_t)0x2000)
```

USART Enable

**5.173.2.2741 USART\_CR1\_WAKE**

```
#define USART_CR1_WAKE ((uint16_t)0x0800)
```

Wakeup method

**5.173.2.2742 USART\_CR2\_ADD**

```
#define USART_CR2_ADD ((uint16_t)0x000F)
```

Address of the USART node

**5.173.2.2743 USART\_CR2\_CLKEN**

```
#define USART_CR2_CLKEN ((uint16_t)0x0800)
```

Clock Enable

**5.173.2.2744 USART\_CR2\_CPHA**

```
#define USART_CR2_CPHA ((uint16_t)0x0200)
```

Clock Phase

**5.173.2.2745 USART\_CR2\_CPOL**

```
#define USART_CR2_CPOL ((uint16_t)0x0400)
```

Clock Polarity

**5.173.2.2746 USART\_CR2\_LBCL**

```
#define USART_CR2_LBCL ((uint16_t)0x0100)
```

Last Bit Clock pulse

**5.173.2.2747 USART\_CR2\_LBDIE**

```
#define USART_CR2_LBDIE ((uint16_t)0x0040)
```

LIN Break Detection Interrupt Enable

**5.173.2.2748 USART\_CR2\_LBDL**

```
#define USART_CR2_LBDL ((uint16_t)0x0020)
```

LIN Break Detection Length

**5.173.2.2749 USART\_CR2\_LINEN**

```
#define USART_CR2_LINEN ((uint16_t)0x4000)
```

LIN mode enable

**5.173.2.2750 USART\_CR2\_STOP**

```
#define USART_CR2_STOP ((uint16_t)0x3000)
```

STOP[1:0] bits (STOP bits)

**5.173.2.2751 USART\_CR2\_STOP\_0**

```
#define USART_CR2_STOP_0 ((uint16_t)0x1000)
```

Bit 0

**5.173.2.2752 USART\_CR2\_STOP\_1**

```
#define USART_CR2_STOP_1 ((uint16_t)0x2000)
```

Bit 1

**5.173.2.2753 USART\_CR3\_CTSE**

```
#define USART_CR3_CTSE ((uint16_t)0x0200)
```

CTS Enable

**5.173.2.2754 USART\_CR3\_CTSIE**

```
#define USART_CR3_CTSIE ((uint16_t)0x0400)
```

CTS Interrupt Enable

**5.173.2.2755 USART\_CR3\_DMAR**

```
#define USART_CR3_DMAR ((uint16_t)0x0040)
```

DMA Enable Receiver

**5.173.2.2756 USART\_CR3\_DMAT**

```
#define USART_CR3_DMAT ((uint16_t)0x0080)
```

DMA Enable Transmitter

**5.173.2.2757 USART\_CR3\_EIE**

```
#define USART_CR3_EIE ((uint16_t)0x0001)
```

Error Interrupt Enable

**5.173.2.2758 USART\_CR3\_HDSEL**

```
#define USART_CR3_HDSEL ((uint16_t)0x0008)
```

Half-Duplex Selection

**5.173.2.2759 USART\_CR3\_IREN**

```
#define USART_CR3_IREN ((uint16_t)0x0002)
```

IrDA mode Enable

**5.173.2.2760 USART\_CR3\_IRLP**

```
#define USART_CR3_IRLP ((uint16_t)0x0004)
```

IrDA Low-Power

**5.173.2.2761 USART\_CR3\_NACK**

```
#define USART_CR3_NACK ((uint16_t)0x0010)
```

Smartcard NACK enable

**5.173.2.2762 USART\_CR3\_ONEBIT**

```
#define USART_CR3_ONEBIT ((uint16_t)0x0800)
```

USART One bit method enable

**5.173.2.2763 USART\_CR3\_RTSE**

```
#define USART_CR3_RTSE ((uint16_t)0x0100)
```

RTS Enable

**5.173.2.2764 USART\_CR3\_SCEN**

```
#define USART_CR3_SCEN ((uint16_t)0x0020)
```

Smartcard mode enable

**5.173.2.2765 USART\_DR\_DR**

```
#define USART_DR_DR ((uint16_t)0x01FF)
```

Data value

**5.173.2.2766 USART\_GTPR\_GT**

```
#define USART_GTPR_GT ((uint16_t)0xFF00)
```

Guard time value

**5.173.2.2767 USART\_GTPR\_PSC**

```
#define USART_GTPR_PSC ((uint16_t)0x00FF)
```

PSC[7:0] bits (Prescaler value)

**5.173.2.2768 USART\_GTPR\_PSC\_0**

```
#define USART_GTPR_PSC_0 ((uint16_t)0x0001)
```

Bit 0

**5.173.2.2769 USART\_GTPR\_PSC\_1**

```
#define USART_GTPR_PSC_1 ((uint16_t)0x0002)
```

Bit 1

**5.173.2.2770 USART\_GTPR\_PSC\_2**

```
#define USART_GTPR_PSC_2 ((uint16_t)0x0004)
```

Bit 2

**5.173.2.2771 USART\_GTPR\_PSC\_3**

```
#define USART_GTPR_PSC_3 ((uint16_t)0x0008)
```

Bit 3

**5.173.2.2772 USART\_GTPR\_PSC\_4**

```
#define USART_GTPR_PSC_4 ((uint16_t)0x0010)
```

Bit 4

**5.173.2.2773 USART\_GTPR\_PSC\_5**

```
#define USART_GTPR_PSC_5 ((uint16_t)0x0020)
```

Bit 5

**5.173.2.2774 USART\_GTPR\_PSC\_6**

```
#define USART_GTPR_PSC_6 ((uint16_t)0x0040)
```

Bit 6

**5.173.2.2775 USART\_GTPR\_PSC\_7**

```
#define USART_GTPR_PSC_7 ((uint16_t)0x0080)
```

Bit 7

**5.173.2.2776 USART\_SR\_CTS**

```
#define USART_SR_CTS ((uint16_t)0x0200)
```

CTS Flag

**5.173.2.2777 USART\_SR\_FE**

```
#define USART_SR_FE ((uint16_t)0x0002)
```

Framing Error

**5.173.2.2778 USART\_SR\_IDLE**

```
#define USART_SR_IDLE ((uint16_t)0x0010)
```

IDLE line detected

**5.173.2.2779 USART\_SR\_LBD**

```
#define USART_SR_LBD ((uint16_t)0x0100)
```

LIN Break Detection Flag

**5.173.2.2780 USART\_SR\_NE**

```
#define USART_SR_NE ((uint16_t)0x0004)
```

Noise Error Flag

**5.173.2.2781 USART\_SR\_ORE**

```
#define USART_SR_ORE ((uint16_t)0x0008)
```

OverRun Error

**5.173.2.2782 USART\_SR\_PE**

```
#define USART_SR_PE ((uint16_t)0x0001)
```

Parity Error

**5.173.2.2783 USART\_SR\_RXNE**

```
#define USART_SR_RXNE ((uint16_t)0x0020)
```

Read Data Register Not Empty

**5.173.2.2784 USART\_SR\_TC**

```
#define USART_SR_TC ((uint16_t)0x0040)
```

Transmission Complete

**5.173.2.2785 USART\_SR\_TXE**

```
#define USART_SR_TXE ((uint16_t)0x0080)
```

Transmit Data Register Empty

**5.173.2.2786 WWDG\_CFR\_EWI**

```
#define WWDG_CFR_EWI ((uint16_t)0x0200)
```

Early Wakeup Interrupt

**5.173.2.2787 WWDG\_CFR\_W**

```
#define WWDG_CFR_W ((uint16_t)0x007F)
```

W[6:0] bits (7-bit window value)

**5.173.2.2788 WWDG\_CFR\_W\_0**

```
#define WWDG_CFR_W_0 ((uint16_t)0x0001)
```

Bit 0

**5.173.2.2789 WWDG\_CFR\_W\_1**

```
#define WWDG_CFR_W_1 ((uint16_t)0x0002)
```

Bit 1

**5.173.2.2790 WWDG\_CFR\_W\_2**

```
#define WWDG_CFR_W_2 ((uint16_t)0x0004)
```

Bit 2

**5.173.2.2791 WWDG\_CFR\_W\_3**

```
#define WWDG_CFR_W_3 ((uint16_t)0x0008)
```

Bit 3

**5.173.2.2792 WWDG\_CFR\_W\_4**

```
#define WWDG_CFR_W_4 ((uint16_t)0x0010)
```

Bit 4

**5.173.2.2793 WWDG\_CFR\_W\_5**

```
#define WWDG_CFR_W_5 ((uint16_t)0x0020)
```

Bit 5

**5.173.2.2794 WWDG\_CFR\_W\_6**

```
#define WWDG_CFR_W_6 ((uint16_t)0x0040)
```

Bit 6

**5.173.2.2795 WWDG\_CFR\_WDGTB**

```
#define WWDG_CFR_WDGTB ((uint16_t)0x0180)
```

WDGTB[1:0] bits (Timer Base)

**5.173.2.2796 WWDG\_CFR\_WDGTB\_0**

```
#define WWDG_CFR_WDGTB_0 ((uint16_t)0x0080)
```

Bit 0

**5.173.2.2797 WWDG\_CFR\_WDGTB\_1**

```
#define WWDG_CFR_WDGTB_1 ((uint16_t)0x0100)
```

Bit 1

**5.173.2.2798 WWDG\_CR\_T**

```
#define WWDG_CR_T ((uint8_t)0x7F)
```

T[6:0] bits (7-Bit counter (MSB to LSB))

**5.173.2.2799 WWDG\_CR\_T\_0**

```
#define WWDG_CR_T_0 ((uint8_t)0x01)
```

Bit 0

**5.173.2.2800 WWDG\_CR\_T\_1**

```
#define WWDG_CR_T_1 ((uint8_t)0x02)
```

Bit 1

**5.173.2.2801 WWDG\_CR\_T\_2**

```
#define WWDG_CR_T_2 ((uint8_t)0x04)
```

Bit 2

**5.173.2.2802 WWDG\_CR\_T\_3**

```
#define WWDG_CR_T_3 ((uint8_t)0x08)
```

Bit 3

**5.173.2.2803 WWDG\_CR\_T\_4**

```
#define WWDG_CR_T_4 ((uint8_t)0x10)
```

Bit 4

**5.173.2.2804 WWDG\_CR\_T\_5**

```
#define WWDG_CR_T_5 ((uint8_t)0x20)
```

Bit 5

**5.173.2.2805 WWDG\_CR\_T\_6**

```
#define WWDG_CR_T_6 ((uint8_t)0x40)
```

Bit 6

### 5.173.2.2806 WWDG\_CR\_WDGA

```
#define WWDG_CR_WDGA ((uint8_t)0x80)
```

Activation bit

### 5.173.2.2807 WWDG\_SR\_EWIF

```
#define WWDG_SR_EWIF ((uint8_t)0x01)
```

Early Wakeup Interrupt Flag

## 5.174 Exported\_macro

Collaboration diagram for Exported\_macro:



## Macros

- #define **SET\_BIT**(REG, BIT) ((REG) |= (BIT))
- #define **CLEAR\_BIT**(REG, BIT) ((REG) &= ~(BIT))
- #define **READ\_BIT**(REG, BIT) ((REG) & (BIT))
- #define **CLEAR\_REG**(REG) ((REG) = (0x0))
- #define **WRITE\_REG**(REG, VAL) ((REG) = (VAL))
- #define **READ\_REG**(REG) ((REG))
- #define **MODIFY\_REG**(REG, CLEARMASK, SETMASK) WRITE\_REG((REG), (((READ\_REG(REG)) & (~(CLEARMASK))) | (SETMASK)))

### 5.174.1 Detailed Description

## 5.175 Stm32f4xx\_system

Collaboration diagram for Stm32f4xx\_system:



## Modules

- [STM32F4xx\\_System\\_Includes](#)  
*Define to prevent recursive inclusion.*
- [STM32F4xx\\_System\\_Exported\\_types](#)
- [STM32F4xx\\_System\\_Exported\\_Constants](#)
- [STM32F4xx\\_System\\_Exported\\_MACROS](#)
- [STM32F4xx\\_System\\_Exported\\_Functions](#)

- [STM32F4xx\\_System\\_Private\\_Includes](#)
- [STM32F4xx\\_System\\_Private\\_TypesDefinitions](#)
- [STM32F4xx\\_System\\_Private\\_Defines](#)
- [STM32F4xx\\_System\\_Private\\_Macros](#)
- [STM32F4xx\\_System\\_Private\\_Variables](#)
- [STM32F4xx\\_System\\_Private\\_FunctionPrototypes](#)
- [STM32F4xx\\_System\\_Private\\_Functions](#)

### 5.175.1 Detailed Description

## 5.176 STM32F4xx\_System\_Includes

Define to prevent recursive inclusion.

Collaboration diagram for STM32F4xx\_System\_Includes:



Define to prevent recursive inclusion.

## 5.177 STM32F4xx\_System\_Exported\_types

Collaboration diagram for STM32F4xx\_System\_Exported\_types:



## Variables

- `uint32_t SystemCoreClock`

### 5.177.1 Detailed Description

### 5.177.2 Variable Documentation

#### 5.177.2.1 SystemCoreClock

```
uint32_t SystemCoreClock [extern]
```

System Clock Frequency (Core Clock)

## 5.178 STM32F4xx\_System\_Exported\_Constants

Collaboration diagram for STM32F4xx\_System\_Exported\_Constants:



## 5.179 STM32F4xx\_System\_Exported\_Macros

Collaboration diagram for STM32F4xx\_System\_Exported\_Macros:



## 5.180 STM32F4xx\_System\_Exported\_Functions

Collaboration diagram for STM32F4xx\_System\_Exported\_Functions:



## Functions

- void [SystemInit](#) (void)  
*Setup the microcontroller system Initialize the Embedded Flash Interface, the PLL and update the SystemFrequency variable.*
- void [SystemCoreClockUpdate](#) (void)  
*Update SystemCoreClock variable according to Clock Register Values. The SystemCoreClock variable contains the core clock (HCLK), it can be used by the user application to setup the SysTick timer or configure other parameters.*

### 5.180.1 Detailed Description

### 5.180.2 Function Documentation

#### 5.180.2.1 [SystemCoreClockUpdate\(\)](#)

```
void SystemCoreClockUpdate (
    void )
```

Update SystemCoreClock variable according to Clock Register Values. The SystemCoreClock variable contains the core clock (HCLK), it can be used by the user application to setup the SysTick timer or configure other parameters.

#### Note

Each time the core clock (HCLK) changes, this function must be called to update SystemCoreClock variable value. Otherwise, any configuration based on this variable will be incorrect.

- The system frequency computed by this function is not the real frequency in the chip. It is calculated based on the predefined constant and the selected clock source:

- If SYSCLK source is HSI, SystemCoreClock will contain the [HSI\\_VALUE\(\\*\)](#)
- If SYSCLK source is HSE, SystemCoreClock will contain the [HSE\\_VALUE\(\\*\\*\)](#)
- If SYSCLK source is PLL, SystemCoreClock will contain the [HSE\\_VALUE\(\\*\\*\)](#) or [HSI\\_VALUE\(\\*\)](#) multiplied/divided by the PLL factors.

(\*) HSI\_VALUE is a constant defined in [stm32f4xx.h](#) file (default value 16 MHz) but the real value may vary depending on the variations in voltage and temperature.

(\*\*) HSE\_VALUE is a constant defined in [stm32f4xx.h](#) file (default value 25 MHz), user has to ensure that HSE\_VALUE is same as the real frequency of the crystal used. Otherwise, this function may have wrong result.

- The result of this function could be not correct when using fractional value for HSE crystal.

#### Parameters

|      |                                 |
|------|---------------------------------|
| None | <input type="button" value=""/> |
|------|---------------------------------|

Return values

|      |  |
|------|--|
| None |  |
|------|--|

### 5.180.2.2 SystemInit()

```
void SystemInit (
    void )
```

Setup the microcontroller system Initialize the Embedded Flash Interface, the PLL and update the SystemFrequency variable.

Parameters

|      |  |
|------|--|
| None |  |
|------|--|

Return values

|      |  |
|------|--|
| None |  |
|------|--|

## 5.181 STM32F4xx\_System\_Private\_Includes

Collaboration diagram for STM32F4xx\_System\_Private\_Includes:



## 5.182 STM32F4xx\_System\_Private\_TypesDefinitions

Collaboration diagram for STM32F4xx\_System\_Private\_TypesDefinitions:



## 5.183 STM32F4xx\_System\_Private\_Defines

Collaboration diagram for STM32F4xx\_System\_Private\_Defines:



### Macros

- `#define VECT_TAB_OFFSET 0x00`
- `#define PLL_Q 7`

#### 5.183.1 Detailed Description

#### 5.183.2 Macro Definition Documentation

##### 5.183.2.1 VECT\_TAB\_OFFSET

```
#define VECT_TAB_OFFSET 0x00
```

< Uncomment the following line if you need to use external SRAM or SDRAM mounted on STM324xG\_EVAL/STM324x7I\_EVAL/STM324x9I\_EVAL boards as data memory

< Uncomment the following line if you need to relocate your vector Table in Internal SRAM. Vector Table base offset field. This value must be a multiple of 0x200.

## 5.184 STM32F4xx\_System\_Private\_Macros

Collaboration diagram for STM32F4xx\_System\_Private\_Macros:



## 5.185 STM32F4xx\_System\_Private\_Variables

Collaboration diagram for STM32F4xx\_System\_Private\_Variables:



### Variables

- `__I uint8_t AHBPrescTable [16] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9}`

#### 5.185.1 Detailed Description

## 5.186 STM32F4xx\_System\_Private\_FunctionPrototypes

Collaboration diagram for STM32F4xx\_System\_Private\_FunctionPrototypes:



#### 5.186.1 Detailed Description

## 5.187 STM32F4xx\_System\_Private\_Functions

Collaboration diagram for STM32F4xx\_System\_Private\_Functions:



## Functions

- void **SystemInit** (void)  
*Setup the microcontroller system Initialize the Embedded Flash Interface, the PLL and update the SystemFrequency variable.*
- void **SystemInit\_Old** (void)
- void **SystemCoreClockUpdate** (void)  
*Update SystemCoreClock variable according to Clock Register Values. The SystemCoreClock variable contains the core clock (HCLK), it can be used by the user application to setup the SysTick timer or configure other parameters.*

### 5.187.1 Detailed Description

### 5.187.2 Function Documentation

#### 5.187.2.1 SystemCoreClockUpdate()

```
void SystemCoreClockUpdate (
    void )
```

Update SystemCoreClock variable according to Clock Register Values. The SystemCoreClock variable contains the core clock (HCLK), it can be used by the user application to setup the SysTick timer or configure other parameters.

#### Note

Each time the core clock (HCLK) changes, this function must be called to update SystemCoreClock variable value. Otherwise, any configuration based on this variable will be incorrect.

- The system frequency computed by this function is not the real frequency in the chip. It is calculated based on the predefined constant and the selected clock source:

- If SYSCLK source is HSI, SystemCoreClock will contain the **HSI\_VALUE(\*)**
- If SYSCLK source is HSE, SystemCoreClock will contain the **HSE\_VALUE(\*\*)**
- If SYSCLK source is PLL, SystemCoreClock will contain the **HSE\_VALUE(\*\*)** or **HSI\_VALUE(\*)** multiplied/divided by the PLL factors.

(\*) HSI\_VALUE is a constant defined in [stm32f4xx.h](#) file (default value 16 MHz) but the real value may vary depending on the variations in voltage and temperature.

(\*\*) HSE\_VALUE is a constant defined in [stm32f4xx.h](#) file (default value 25 MHz), user has to ensure that HSE\_← VALUE is same as the real frequency of the crystal used. Otherwise, this function may have wrong result.

- The result of this function could be not correct when using fractional value for HSE crystal.

**Parameters**

|      |                                 |
|------|---------------------------------|
| None | <input type="button" value=""/> |
|------|---------------------------------|

**Return values**

|      |                                 |
|------|---------------------------------|
| None | <input type="button" value=""/> |
|------|---------------------------------|

**5.187.2.2 SystemInit()**

```
void SystemInit (
    void )
```

Setup the microcontroller system Initialize the Embedded Flash Interface, the PLL and update the SystemFrequency variable.

**Parameters**

|      |                                 |
|------|---------------------------------|
| None | <input type="button" value=""/> |
|------|---------------------------------|

**Return values**

|      |                                 |
|------|---------------------------------|
| None | <input type="button" value=""/> |
|------|---------------------------------|

# Chapter 6

## Class Documentation

### 6.1 ADC\_Common\_TypeDef Struct Reference

#### Public Attributes

- `__IO uint32_t CSR`
- `__IO uint32_t CCR`
- `__IO uint32_t CDR`

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

### 6.2 ADC\_TypeDef Struct Reference

Analog to Digital Converter

```
#include <stm32f4xx.h>
```

#### Public Attributes

- `__IO uint32_t SR`
- `__IO uint32_t CR1`
- `__IO uint32_t CR2`
- `__IO uint32_t SMPR1`
- `__IO uint32_t SMPR2`
- `__IO uint32_t JOFR1`
- `__IO uint32_t JOFR2`
- `__IO uint32_t JOFR3`
- `__IO uint32_t JOFR4`
- `__IO uint32_t HTR`
- `__IO uint32_t LTR`
- `__IO uint32_t SQR1`
- `__IO uint32_t SQR2`
- `__IO uint32_t SQR3`
- `__IO uint32_t JSQR`
- `__IO uint32_t JDR1`
- `__IO uint32_t JDR2`
- `__IO uint32_t JDR3`
- `__IO uint32_t JDR4`
- `__IO uint32_t DR`

### 6.2.1 Detailed Description

Analog to Digital Converter

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.3 APSR\_Type Union Reference

Union type to access the Application Program Status Register (APSR).

```
#include <core_cm4.h>
```

### Public Attributes

- struct {  
    uint32\_t APSR\_Type::\_reserved0:16  
    uint32\_t APSR\_Type::GE:4  
    uint32\_t APSR\_Type::\_reserved1:7  
    uint32\_t APSR\_Type::Q:1  
    uint32\_t APSR\_Type::V:1  
    uint32\_t APSR\_Type::C:1  
    uint32\_t APSR\_Type::Z:1  
    uint32\_t APSR\_Type::N:1  
} b
- uint32\_t w

### 6.3.1 Detailed Description

Union type to access the Application Program Status Register (APSR).

The documentation for this union was generated from the following file:

- CMSIS/Inc/core\_cm4.h

## 6.4 CAN\_FIFOMailBox\_TypeDef Struct Reference

Controller Area Network FIFOMailBox.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t RIR`
- `__IO uint32_t RDTR`
- `__IO uint32_t RDLR`
- `__IO uint32_t RDHR`

### 6.4.1 Detailed Description

Controller Area Network FIFOMailBox.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.5 CAN\_FilterRegister\_TypeDef Struct Reference

Controller Area Network FilterRegister.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t FR1`
- `__IO uint32_t FR2`

### 6.5.1 Detailed Description

Controller Area Network FilterRegister.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.6 CAN\_TxMailBox\_TypeDef Struct Reference

Controller Area Network TxMailBox.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t TIR`
- `__IO uint32_t TDTR`
- `__IO uint32_t TDLR`
- `__IO uint32_t TDHR`

### 6.6.1 Detailed Description

Controller Area Network TxMailBox.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.7 CAN\_TypeDef Struct Reference

Controller Area Network.

```
#include <stm32f4xx.h>
```

Collaboration diagram for CAN\_TypeDef:



### Public Attributes

- `__IO uint32_t MCR`
- `__IO uint32_t MSR`
- `__IO uint32_t TSR`
- `__IO uint32_t RFOR`
- `__IO uint32_t RF1R`
- `__IO uint32_t IER`
- `__IO uint32_t ESR`
- `__IO uint32_t BTR`
- `uint32_t RESERVED0 [88]`
- `CAN_TxMailBox_TypeDef sTxMailBox [3]`
- `CAN_FIFOMailBox_TypeDef sFIFOMailBox [2]`
- `uint32_t RESERVED1 [12]`
- `__IO uint32_t FMR`
- `__IO uint32_t FM1R`
- `uint32_t RESERVED2`
- `__IO uint32_t FS1R`
- `uint32_t RESERVED3`
- `__IO uint32_t FFA1R`
- `uint32_t RESERVED4`
- `__IO uint32_t FA1R`
- `uint32_t RESERVED5 [8]`
- `CAN_FilterRegister_TypeDef sFilterRegister [28]`

### 6.7.1 Detailed Description

Controller Area Network.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.8 CONTROL\_Type Union Reference

Union type to access the Control Registers (CONTROL).

```
#include <core_cm4.h>
```

### Public Attributes

- struct {  
    uint32\_t CONTROL\_Type::nPRIV:1  
    uint32\_t CONTROL\_Type::SPSEL:1  
    uint32\_t CONTROL\_Type::FPCA:1  
    uint32\_t CONTROL\_Type::\_reserved0:29  
} **b**
- uint32\_t **w**

### 6.8.1 Detailed Description

Union type to access the Control Registers (CONTROL).

The documentation for this union was generated from the following file:

- CMSIS/Inc/core\_cm4.h

## 6.9 CoreDebug\_Type Struct Reference

Structure type to access the Core Debug Register (CoreDebug).

```
#include <core_cm4.h>
```

### Public Attributes

- **\_IO** uint32\_t **DHCSR**
- **\_IO** uint32\_t **DCRSR**
- **\_IO** uint32\_t **DCRDR**
- **\_IO** uint32\_t **DEMCR**

### 6.9.1 Detailed Description

Structure type to access the Core Debug Register (CoreDebug).

The documentation for this struct was generated from the following file:

- CMSIS/Inc/core\_cm4.h

## 6.10 CRC\_TypeDef Struct Reference

CRC calculation unit.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t DR`
- `__IO uint8_t IDR`
- `uint8_t RESERVED0`
- `uint16_t RESERVED1`
- `__IO uint32_t CR`
- `uint32 CR`
- `uint32 SR`
- `uint32 DR`
- `uint32 IDR`
- `uint32 POL`
- `uint32 RESERVED`
- `uint32 INIT`

### 6.10.1 Detailed Description

CRC calculation unit.

### 6.10.2 Member Data Documentation

#### 6.10.2.1 CR

```
uint32 CRC_TypeDef::CR
```

CRC Control Register

### 6.10.2.2 DR

`uint32_t CRC_TypeDef::DR`

CRC Data Register

### 6.10.2.3 IDR

`uint32_t CRC_TypeDef::IDR`

CRC Independent Data Register

### 6.10.2.4 INIT

`uint32_t CRC_TypeDef::INIT`

CRC Initial Value Register

### 6.10.2.5 POL

`uint32_t CRC_TypeDef::POL`

CRC Polynomial Register

### 6.10.2.6 RESERVED

`uint32_t CRC_TypeDef::RESERVED`

Reserved

### 6.10.2.7 SR

`uint32_t CRC_TypeDef::SR`

CRC Status Register

The documentation for this struct was generated from the following files:

- CMSIS/Inc/[stm32f4xx.h](#)
- drivers/Inc/[stm32f401xx.h](#)

## 6.11 CRYP\_TypeDef Struct Reference

Crypto Processor.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t SR`
- `__IO uint32_t DR`
- `__IO uint32_t DOUT`
- `__IO uint32_t DMACR`
- `__IO uint32_t IMSCR`
- `__IO uint32_t RISR`
- `__IO uint32_t MISR`
- `__IO uint32_t K0LR`
- `__IO uint32_t K0RR`
- `__IO uint32_t K1LR`
- `__IO uint32_t K1RR`
- `__IO uint32_t K2LR`
- `__IO uint32_t K2RR`
- `__IO uint32_t K3LR`
- `__IO uint32_t K3RR`
- `__IO uint32_t IV0LR`
- `__IO uint32_t IV0RR`
- `__IO uint32_t IV1LR`
- `__IO uint32_t IV1RR`
- `__IO uint32_t CSGCMCCM0R`
- `__IO uint32_t CSGCMCCM1R`
- `__IO uint32_t CSGCMCCM2R`
- `__IO uint32_t CSGCMCCM3R`
- `__IO uint32_t CSGCMCCM4R`
- `__IO uint32_t CSGCMCCM5R`
- `__IO uint32_t CSGCMCCM6R`
- `__IO uint32_t CSGCMCCM7R`
- `__IO uint32_t CSGCM0R`
- `__IO uint32_t CSGCM1R`
- `__IO uint32_t CSGCM2R`
- `__IO uint32_t CSGCM3R`
- `__IO uint32_t CSGCM4R`
- `__IO uint32_t CSGCM5R`
- `__IO uint32_t CSGCM6R`
- `__IO uint32_t CSGCM7R`

### 6.11.1 Detailed Description

Crypto Processor.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.12 DAC\_TypeDef Struct Reference

Digital to Analog Converter.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t SWTRIGR`
- `__IO uint32_t DHR12R1`
- `__IO uint32_t DHR12L1`
- `__IO uint32_t DHR8R1`
- `__IO uint32_t DHR12R2`
- `__IO uint32_t DHR12L2`
- `__IO uint32_t DHR8R2`
- `__IO uint32_t DHR12RD`
- `__IO uint32_t DHR12LD`
- `__IO uint32_t DHR8RD`
- `__IO uint32_t DOR1`
- `__IO uint32_t DOR2`
- `__IO uint32_t SR`

### 6.12.1 Detailed Description

Digital to Analog Converter.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.13 DBGMCU\_TypeDef Struct Reference

Debug MCU.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t IDCODE`
- `__IO uint32_t CR`
- `__IO uint32_t APB1FZ`
- `__IO uint32_t APB2FZ`

### 6.13.1 Detailed Description

Debug MCU.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.14 DCMI\_TypeDef Struct Reference

DCMI.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t SR`
- `__IO uint32_t RISR`
- `__IO uint32_t IER`
- `__IO uint32_t MISR`
- `__IO uint32_t ICR`
- `__IO uint32_t ESCR`
- `__IO uint32_t ESUR`
- `__IO uint32_t CWSTRTR`
- `__IO uint32_t CWSIZER`
- `__IO uint32_t DR`

### 6.14.1 Detailed Description

DCMI.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.15 DMA2D\_TypeDef Struct Reference

DMA2D Controller.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t ISR`
- `__IO uint32_t IFCR`
- `__IO uint32_t FGMAR`
- `__IO uint32_t FGOR`
- `__IO uint32_t BGMAR`
- `__IO uint32_t BGOR`
- `__IO uint32_t FGPCCR`
- `__IO uint32_t FGCOLR`
- `__IO uint32_t BGPFCCR`
- `__IO uint32_t BGCOLR`
- `__IO uint32_t FGCMAR`

- `__IO uint32_t BGCMAR`
- `__IO uint32_t OPFCCR`
- `__IO uint32_t OCOLR`
- `__IO uint32_t OMAR`
- `__IO uint32_t OOR`
- `__IO uint32_t NLR`
- `__IO uint32_t LWR`
- `__IO uint32_t AMTCR`
- `uint32_t RESERVED [236]`
- `__IO uint32_t FGCLUT [256]`
- `__IO uint32_t BGCLUT [256]`

### 6.15.1 Detailed Description

DMA2D Controller.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.16 DMA\_Stream\_TypeDef Struct Reference

DMA Controller.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t NDTR`
- `__IO uint32_t PAR`
- `__IO uint32_t M0AR`
- `__IO uint32_t M1AR`
- `__IO uint32_t FCR`

### 6.16.1 Detailed Description

DMA Controller.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.17 DMA\_TypeDef Struct Reference

### Public Attributes

- `__IO uint32_t LISR`
- `__IO uint32_t HISR`
- `__IO uint32_t LIFCR`
- `__IO uint32_t HIFCR`

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.18 DWT\_TypeDef Struct Reference

Structure type to access the Data Watchpoint and Trace Register (DWT).

```
#include <core_cm4.h>
```

### Public Attributes

- `__IO uint32_t CTRL`
- `__IO uint32_t CYCCNT`
- `__IO uint32_t CPICNT`
- `__IO uint32_t EXCCNT`
- `__IO uint32_t SLEEPCNT`
- `__IO uint32_t LSUCNT`
- `__IO uint32_t FOLDCNT`
- `__I uint32_t PCSR`
- `__IO uint32_t COMP0`
- `__IO uint32_t MASK0`
- `__IO uint32_t FUNCTION0`
- `uint32_t RESERVED0 [1]`
- `__IO uint32_t COMP1`
- `__IO uint32_t MASK1`
- `__IO uint32_t FUNCTION1`
- `uint32_t RESERVED1 [1]`
- `__IO uint32_t COMP2`
- `__IO uint32_t MASK2`
- `__IO uint32_t FUNCTION2`
- `uint32_t RESERVED2 [1]`
- `__IO uint32_t COMP3`
- `__IO uint32_t MASK3`
- `__IO uint32_t FUNCTION3`

### 6.18.1 Detailed Description

Structure type to access the Data Watchpoint and Trace Register (DWT).

The documentation for this struct was generated from the following file:

- CMSIS/Inc/core\_cm4.h

## 6.19 ETH\_TypeDef Struct Reference

Ethernet MAC.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t MACCR`
- `__IO uint32_t MACFFR`
- `__IO uint32_t MACHTHR`
- `__IO uint32_t MACHTLR`
- `__IO uint32_t MACMIIAR`
- `__IO uint32_t MACMIIDR`
- `__IO uint32_t MACFCR`
- `__IO uint32_t MACVLANTR`
- `uint32_t RESERVED0 [2]`
- `__IO uint32_t MACRWUFFR`
- `__IO uint32_t MACPMTCSR`
- `uint32_t RESERVED1 [2]`
- `__IO uint32_t MACSR`
- `__IO uint32_t MACIMR`
- `__IO uint32_t MACA0HR`
- `__IO uint32_t MACA0LR`
- `__IO uint32_t MACA1HR`
- `__IO uint32_t MACA1LR`
- `__IO uint32_t MACA2HR`
- `__IO uint32_t MACA2LR`
- `__IO uint32_t MACA3HR`
- `__IO uint32_t MACA3LR`
- `uint32_t RESERVED2 [40]`
- `__IO uint32_t MMCCR`
- `__IO uint32_t MMCRIR`
- `__IO uint32_t MMCTIR`
- `__IO uint32_t MMCRIMR`
- `__IO uint32_t MMCTIMR`
- `uint32_t RESERVED3 [14]`
- `__IO uint32_t MMCTGFSCCR`
- `__IO uint32_t MMCTGFMSCCR`
- `uint32_t RESERVED4 [5]`
- `__IO uint32_t MMCTGFCSR`
- `uint32_t RESERVED5 [10]`
- `__IO uint32_t MMCRFCECR`

- `__IO uint32_t MMCRAECSR`
- `uint32_t RESERVED6 [10]`
- `__IO uint32_t MMCRGUFCR`
- `uint32_t RESERVED7 [334]`
- `__IO uint32_t PTPTSCR`
- `__IO uint32_t PTSSIR`
- `__IO uint32_t PTPTSHR`
- `__IO uint32_t PTPTSLR`
- `__IO uint32_t PTPTSHUR`
- `__IO uint32_t PTPTSLUR`
- `__IO uint32_t PTPTSAR`
- `__IO uint32_t PTPTTHR`
- `__IO uint32_t PTPTTLR`
- `__IO uint32_t RESERVED8`
- `__IO uint32_t PTPTSSR`
- `uint32_t RESERVED9 [565]`
- `__IO uint32_t DMABMR`
- `__IO uint32_t DMATPDR`
- `__IO uint32_t DMARPDR`
- `__IO uint32_t DMARDLAR`
- `__IO uint32_t DMATDLAR`
- `__IO uint32_t DMASTR`
- `__IO uint32_t DMAOMR`
- `__IO uint32_t DMAIER`
- `__IO uint32_t DMAMFBOCR`
- `__IO uint32_t DMARSWTR`
- `uint32_t RESERVED10 [8]`
- `__IO uint32_t DMACHTDR`
- `__IO uint32_t DMACHRDR`
- `__IO uint32_t DMACHTBAR`
- `__IO uint32_t DMACHRBAR`

### 6.19.1 Detailed Description

Ethernet MAC.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.20 EXTI\_TypeDef Struct Reference

External Interrupt/Event Controller.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t IMR`
- `__IO uint32_t EMR`
- `__IO uint32_t RTSR`
- `__IO uint32_t FTSR`
- `__IO uint32_t SWIER`
- `__IO uint32_t PR`
- `vuint32_t IMR`
- `vuint32_t EMR`
- `vuint32_t RTSR`
- `vuint32_t FTSR`
- `vuint32_t SWIER`
- `vuint32_t PR`

### 6.20.1 Detailed Description

External Interrupt/Event Controller.

### 6.20.2 Member Data Documentation

#### 6.20.2.1 EMR

`vuint32_t EXTI_TypeDef::EMR`

Event Mask Register

#### 6.20.2.2 FTSR

`vuint32_t EXTI_TypeDef::FTSR`

Falling Trigger Selection Register

#### 6.20.2.3 IMR

`vuint32_t EXTI_TypeDef::IMR`

Interrupt Mask Register

#### 6.20.2.4 PR

`vuint32_t EXTI_TypeDef::PR`

Pending Register

### 6.20.2.5 RTSR

```
vuint32_t EXTI_TypeDef::RTSR
```

Rising Trigger Selection Register

### 6.20.2.6 SWIER

```
vuint32_t EXTI_TypeDef::SWIER
```

Software Interrupt Event Register

The documentation for this struct was generated from the following files:

- CMSIS/Inc/[stm32f4xx.h](#)
- drivers/Inc/[stm32f401xx.h](#)

## 6.21 FLASH\_TypeDef Struct Reference

FLASH Registers.

```
#include <stm32f4xx.h>
```

### Public Attributes

- [\\_\\_IO uint32\\_t ACR](#)
- [\\_\\_IO uint32\\_t KEYR](#)
- [\\_\\_IO uint32\\_t OPTKEYR](#)
- [\\_\\_IO uint32\\_t SR](#)
- [\\_\\_IO uint32\\_t CR](#)
- [\\_\\_IO uint32\\_t OPTCR](#)
- [\\_\\_IO uint32\\_t OPTCR1](#)

### 6.21.1 Detailed Description

FLASH Registers.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[stm32f4xx.h](#)

## 6.22 GPIO\_PinConfig\_t Struct Reference

Configuration structure for GPIO pins.

```
#include <stm32f401xx_gpio_driver.h>
```

## Public Attributes

- `uint8 GPIO_MODE`
- `uint8 GPIO_PinSpeed`
- `uint16 GPIO_PinNumber`
- `uint32 GPIO_PinPuPdControl`
- `uint32 GPIO_PinOPType`
- `uint32 GPIO_PinAltFunMode`

### 6.22.1 Detailed Description

Configuration structure for GPIO pins.

This structure defines the configuration parameters for a GPIO pin, including mode, speed, pull-up/pull-down configuration, output type, and alternate function mode.

### 6.22.2 Member Data Documentation

#### 6.22.2.1 GPIO\_MODE

`uint8 GPIO_PinConfig_t::GPIO_MODE`

Specifies the operating mode for the selected pins. This parameter can be a value of [GPIO Pin Modes](#)

#### 6.22.2.2 GPIO\_PinAltFunMode

`uint32 GPIO_PinConfig_t::GPIO_PinAltFunMode`

Specifies the alternate function mode of the GPIO pin.

#### 6.22.2.3 GPIO\_PinNumber

`uint16 GPIO_PinConfig_t::GPIO_PinNumber`

Specifies the GPIO pins to be configured. This parameter can be a value of [GPIO Pin Numbers](#)

#### 6.22.2.4 GPIO\_PinOPType

`uint32 GPIO_PinConfig_t::GPIO_PinOPType`

Specifies the output type of the GPIO pin.

### 6.22.2.5 GPIO\_PinPuPdControl

```
uint32_t GPIO_PinConfig_t::GPIO_PinPuPdControl
```

Specifies the pull-up/pull-down configuration for the GPIO pin.

### 6.22.2.6 GPIO\_PinSpeed

```
uint8_t GPIO_PinConfig_t::GPIO_PinSpeed
```

Specifies the speed for the selected pins. This parameter can be a value of [GPIO Pin Speeds](#)

The documentation for this struct was generated from the following file:

- drivers/Inc/stm32f401xx\_gpio\_driver.h

## 6.23 GPIO\_TypeDef Struct Reference

General Purpose I/O.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t MODER`
- `__IO uint32_t OTYPER`
- `__IO uint32_t OSPEEDR`
- `__IO uint32_t PUPDR`
- `__IO uint32_t IDR`
- `__IO uint32_t ODR`
- `__IO uint16_t BSRRRL`
- `__IO uint16_t BSRRRH`
- `__IO uint32_t LCKR`
- `__IO uint32_t AFR [2]`
- `vuint32_t MODER`
- `vuint32_t OTYPER`
- `vuint32_t OSPEEDR`
- `vuint32_t PUPDR`
- `vuint32_t IDR`
- `vuint32_t ODR`
- `vuint32_t BSRR`
- `vuint32_t LCKR`
- `vuint32_t AFR [2]`

### 6.23.1 Detailed Description

General Purpose I/O.

## 6.23.2 Member Data Documentation

### 6.23.2.1 AFR

```
vuint32_t GPIO_TypeDef::AFR[2]
```

Alternate Function Registers

### 6.23.2.2 BSRR

```
vuint32_t GPIO_TypeDef::BSRR
```

Bit Set/Reset Register

### 6.23.2.3 IDR

```
vuint32_t GPIO_TypeDef::IDR
```

Input Data Register

### 6.23.2.4 LCKR

```
vuint32_t GPIO_TypeDef::LCKR
```

Configuration Lock Register

### 6.23.2.5 MODER

```
vuint32_t GPIO_TypeDef::MODER
```

Mode Register

### 6.23.2.6 ODR

```
vuint32_t GPIO_TypeDef::ODR
```

Output Data Register

### 6.23.2.7 OSPEEDR

```
vuint32_t GPIO_TypeDef::OSPEEDR
```

Output Speed Register

### 6.23.2.8 OTYPER

```
vuint32_t GPIO_TypeDef::OTYPER
```

Output Type Register

### 6.23.2.9 PUPDR

```
vuint32_t GPIO_TypeDef::PUPDR
```

Pull-up/Pull-down Register

The documentation for this struct was generated from the following files:

- CMSIS/Inc/[stm32f4xx.h](#)
- drivers/Inc/[stm32f401xx.h](#)

## 6.24 HASH\_DIGEST\_TypeDef Struct Reference

HASH\_DIGEST.

```
#include <stm32f4xx.h>
```

### Public Attributes

- [\\_\\_IO](#) uint32\_t [HR](#) [8]

### 6.24.1 Detailed Description

HASH\_DIGEST.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[stm32f4xx.h](#)

## 6.25 HASH\_TypeDef Struct Reference

HASH.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t DIN`
- `__IO uint32_t STR`
- `__IO uint32_t HR [5]`
- `__IO uint32_t IMR`
- `__IO uint32_t SR`
- `uint32_t RESERVED [52]`
- `__IO uint32_t CSR [54]`

### 6.25.1 Detailed Description

HASH.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.26 I2C\_TypeDef Struct Reference

Inter-integrated Circuit Interface.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint16_t CR1`
- `uint16_t RESERVED0`
- `__IO uint16_t CR2`
- `uint16_t RESERVED1`
- `__IO uint16_t OAR1`
- `uint16_t RESERVED2`
- `__IO uint16_t OAR2`
- `uint16_t RESERVED3`
- `__IO uint16_t DR`
- `uint16_t RESERVED4`
- `__IO uint16_t SR1`
- `uint16_t RESERVED5`
- `__IO uint16_t SR2`
- `uint16_t RESERVED6`
- `__IO uint16_t CCR`
- `uint16_t RESERVED7`
- `__IO uint16_t TRISE`
- `uint16_t RESERVED8`
- `__IO uint16_t FLTR`
- `uint16_t RESERVED9`
- `uint32 CR1`
- `uint32 CR2`
- `uint32 OAR1`
- `uint32 OAR2`
- `uint32 DR`
- `uint32 SR1`
- `uint32 SR2`
- `uint32 CCR`
- `uint32 TRISE`

### 6.26.1 Detailed Description

Inter-integrated Circuit Interface.

### 6.26.2 Member Data Documentation

#### 6.26.2.1 CCR

```
uint32 I2C_TypeDef::CCR
```

I2C Clock Control Register

#### 6.26.2.2 CR1

```
uint32 I2C_TypeDef::CR1
```

I2C Control Register 1

#### 6.26.2.3 CR2

```
uint32 I2C_TypeDef::CR2
```

I2C Control Register 2

#### 6.26.2.4 DR

```
uint32 I2C_TypeDef::DR
```

I2C Data Register

#### 6.26.2.5 OAR1

```
uint32 I2C_TypeDef::OAR1
```

I2C Own Address Register 1

#### 6.26.2.6 OAR2

```
uint32 I2C_TypeDef::OAR2
```

I2C Own Address Register 2

### 6.26.2.7 SR1

```
uint32_t I2C_TypeDef::SR1
```

I2C Status Register 1

### 6.26.2.8 SR2

```
uint32_t I2C_TypeDef::SR2
```

I2C Status Register 2

### 6.26.2.9 TRISE

```
uint32_t I2C_TypeDef::TRISE
```

I2C TRISE Register

The documentation for this struct was generated from the following files:

- CMSIS/Inc/[stm32f4xx.h](#)
- drivers/Inc/[stm32f401xx.h](#)

## 6.27 IPSR\_Type Union Reference

Union type to access the Interrupt Program Status Register (IPSR).

```
#include <core_cm4.h>
```

### Public Attributes

- struct {  
    uint32\_t IPSR\_Type::ISR:9  
    uint32\_t IPSR\_Type::\_reserved0:23  
} **b**
- uint32\_t **w**

### 6.27.1 Detailed Description

Union type to access the Interrupt Program Status Register (IPSR).

The documentation for this union was generated from the following file:

- CMSIS/Inc/[core\\_cm4.h](#)

## 6.28 ITM\_Type Struct Reference

Structure type to access the Instrumentation Trace Macrocell Register (ITM).

```
#include <core_cm4.h>
```

### Public Attributes

- union {
  - \_\_O uint8\_t ITM\_Type::u8
  - \_\_O uint16\_t ITM\_Type::u16
  - \_\_O uint32\_t ITM\_Type::u32}
- PORT [32]
- uint32\_t RESERVED0 [864]
- \_\_IO uint32\_t TER
- uint32\_t RESERVED1 [15]
- \_\_IO uint32\_t TPR
- uint32\_t RESERVED2 [15]
- \_\_IO uint32\_t TCR
- uint32\_t RESERVED3 [29]
- \_\_O uint32\_t IWR
- \_\_I uint32\_t IRR
- \_\_IO uint32\_t IMCR
- uint32\_t RESERVED4 [43]
- \_\_O uint32\_t LAR
- \_\_I uint32\_t LSR
- uint32\_t RESERVED5 [6]
- \_\_I uint32\_t PID4
- \_\_I uint32\_t PID5
- \_\_I uint32\_t PID6
- \_\_I uint32\_t PID7
- \_\_I uint32\_t PID0
- \_\_I uint32\_t PID1
- \_\_I uint32\_t PID2
- \_\_I uint32\_t PID3
- \_\_I uint32\_t CID0
- \_\_I uint32\_t CID1
- \_\_I uint32\_t CID2
- \_\_I uint32\_t CID3

### 6.28.1 Detailed Description

Structure type to access the Instrumentation Trace Macrocell Register (ITM).

The documentation for this struct was generated from the following file:

- CMSIS/Inc/core\_cm4.h

## 6.29 IWDG\_TypeDef Struct Reference

Independent WATCHDOG.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t KR`
- `__IO uint32_t PR`
- `__IO uint32_t RLR`
- `__IO uint32_t SR`

#### 6.29.1 Detailed Description

Independent WATCHDOG.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[stm32f4xx.h](#)

## 6.30 LCD\_t Struct Reference

Structure for configuring the LCD.

```
#include <lcd_driver.h>
```

Collaboration diagram for LCD\_t:



## Public Attributes

- LCD\_MODE\_t Mode
- LCD\_ROWS\_t Rows
- uint8 Display\_Mode
- uint8 Entry\_Mode
- GPIO\_TypeDef \* GPIO\_PORT
- uint16 RS\_PIN
- uint16 EN\_PIN
- uint16 D0\_PIN
- uint16 D1\_PIN
- uint16 D2\_PIN
- uint16 D3\_PIN
- uint16 D4\_PIN
- uint16 D5\_PIN
- uint16 D6\_PIN
- uint16 D7\_PIN

### 6.30.1 Detailed Description

Structure for configuring the LCD.

### 6.30.2 Member Data Documentation

#### 6.30.2.1 D0\_PIN

`uint16 LCD_t::D0_PIN`

GPIO pin for Data pin 0. (see [GPIO Pin Numbers](#))

#### 6.30.2.2 D1\_PIN

`uint16 LCD_t::D1_PIN`

GPIO pin for Data pin 1. (see [GPIO Pin Numbers](#))

#### 6.30.2.3 D2\_PIN

`uint16 LCD_t::D2_PIN`

GPIO pin for Data pin 2. (see [GPIO Pin Numbers](#))

### 6.30.2.4 D3\_PIN

```
uint16 LCD_t::D3_PIN
```

GPIO pin for Data pin 3. (see [GPIO Pin Numbers](#))

### 6.30.2.5 D4\_PIN

```
uint16 LCD_t::D4_PIN
```

GPIO pin for Data pin 4. (see [GPIO Pin Numbers](#))

### 6.30.2.6 D5\_PIN

```
uint16 LCD_t::D5_PIN
```

GPIO pin for Data pin 5. (see [GPIO Pin Numbers](#))

### 6.30.2.7 D6\_PIN

```
uint16 LCD_t::D6_PIN
```

GPIO pin for Data pin 6. (see [GPIO Pin Numbers](#))

### 6.30.2.8 D7\_PIN

```
uint16 LCD_t::D7_PIN
```

GPIO pin for Data pin 7. (see [GPIO Pin Numbers](#))

### 6.30.2.9 Display\_Mode

```
uint8 LCD_t::Display_Mode
```

Display mode configuration (see [LCD Commands](#)).

### 6.30.2.10 EN\_PIN

```
uint16 LCD_t::EN_PIN
```

GPIO pin for Enable (EN). (see [GPIO Pin Numbers](#))

### 6.30.2.11 Entry\_Mode

```
uint8 LCD_t::Entry_Mode
```

Entry mode configuration (see [LCD Commands](#)).

### 6.30.2.12 GPIO\_PORT

```
GPIO_TypeDef* LCD_t::GPIO_PORT
```

GPIO port used for LCD control.

### 6.30.2.13 Mode

```
LCD_MODE_t LCD_t::Mode
```

LCD mode (8-bit or 4-bit).

### 6.30.2.14 Rows

```
LCD_ROWS_t LCD_t::Rows
```

Number of rows on the LCD.

### 6.30.2.15 RS\_PIN

```
uint16 LCD_t::RS_PIN
```

GPIO pin for Register Select (RS). (see [GPIO Pin Numbers](#))

The documentation for this struct was generated from the following file:

- [bsp/Inc/lcd\\_driver.h](#)

## 6.31 LED\_cfg\_t Struct Reference

Collaboration diagram for LED\_cfg\_t:



## Public Attributes

- `GPIO_TypeDef * LED_Port`
- `GPIO_PinConfig_t LED_Pin`
- `LED_Mode_t LED_Mode`

### 6.31.1 Member Data Documentation

#### 6.31.1.1 LED\_Mode

`LED_Mode_t LED_cfg_t::LED_Mode`

LED mode configuration.

#### 6.31.1.2 LED\_Pin

`GPIO_PinConfig_t LED_cfg_t::LED_Pin`

GPIO pin configuration for the LED.

#### 6.31.1.3 LED\_Port

`GPIO_TypeDef* LED_cfg_t::LED_Port`

GPIO port for the LED.

The documentation for this struct was generated from the following file:

- `bsp/Inc/led_driver.h`

## 6.32 LTDC\_Layer\_TypeDef Struct Reference

LCD-TFT Display layer x Controller.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t WHPCR`
- `__IO uint32_t WVPCR`
- `__IO uint32_t CKCR`
- `__IO uint32_t PFCR`
- `__IO uint32_t CACR`
- `__IO uint32_t DCCR`
- `__IO uint32_t BFCR`
- `uint32_t RESERVED0 [2]`
- `__IO uint32_t CFBAR`
- `__IO uint32_t CFBLR`
- `__IO uint32_t CFBLNR`
- `uint32_t RESERVED1 [3]`
- `__IO uint32_t CLUTWR`

### 6.32.1 Detailed Description

LCD-TFT Display layer x Controller.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.33 LTDC\_TypeDef Struct Reference

LCD-TFT Display Controller.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `uint32_t RESERVED0 [2]`
- `__IO uint32_t SSCR`
- `__IO uint32_t BPCR`
- `__IO uint32_t AWCR`
- `__IO uint32_t TWCR`
- `__IO uint32_t GCR`
- `uint32_t RESERVED1 [2]`
- `__IO uint32_t SRCR`
- `uint32_t RESERVED2 [1]`
- `__IO uint32_t BCCR`
- `uint32_t RESERVED3 [1]`
- `__IO uint32_t IER`
- `__IO uint32_t ISR`
- `__IO uint32_t ICR`
- `__IO uint32_t LIPCR`
- `__IO uint32_t CPSR`
- `__IO uint32_t CDSR`

### 6.33.1 Detailed Description

LCD-TFT Display Controller.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.34 NVIC\_Type Struct Reference

Structure type to access the Nested Vectored Interrupt Controller (NVIC).

```
#include <core_cm4.h>
```

### Public Attributes

- `__IO uint32_t ISER [8]`
- `uint32_t RESERVED0 [24]`
- `__IO uint32_t ICER [8]`
- `uint32_t RSERVED1 [24]`
- `__IO uint32_t ISPR [8]`
- `uint32_t RESERVED2 [24]`
- `__IO uint32_t ICPR [8]`
- `uint32_t RESERVED3 [24]`
- `__IO uint32_t IABR [8]`
- `uint32_t RESERVED4 [56]`
- `__IO uint8_t IP [240]`
- `uint32_t RESERVED5 [644]`
- `__O uint32_t STIR`

### 6.34.1 Detailed Description

Structure type to access the Nested Vectored Interrupt Controller (NVIC).

The documentation for this struct was generated from the following file:

- CMSIS/Inc/core\_cm4.h

## 6.35 NVIC\_TypeDef Struct Reference

### Public Attributes

- `vuint32_t ISER [3]`
- `uint32 RESERVED0 [29]`
- `vuint32_t ICER [3]`
- `uint32 RESERVED1 [29]`
- `vuint32_t ISPR [3]`
- `uint32 RESERVED2 [29]`
- `vuint32_t ICPR [3]`
- `uint32 RESERVED3 [29]`
- `vuint32_t IABR [3]`
- `uint32 RESERVED4 [61]`
- `vuint8_t IP [80]`
- `uint32 RESERVED5 [684]`
- `vuint32_t STIR`

### 6.35.1 Member Data Documentation

#### 6.35.1.1 IABR

```
vuint32_t NVIC_TypeDef::IABR[3]
```

Interrupt Active Bit Registers

#### 6.35.1.2 ICER

```
vuint32_t NVIC_TypeDef::ICER[3]
```

Interrupt Clear-Enable Registers

#### 6.35.1.3 ICPR

```
vuint32_t NVIC_TypeDef::ICPR[3]
```

Interrupt Clear-Pending Registers

#### 6.35.1.4 IP

```
vuint8_t NVIC_TypeDef::IP[80]
```

Interrupt Priority Registers

#### 6.35.1.5 ISER

```
vuint32_t NVIC_TypeDef::ISER[3]
```

Interrupt Set-Enable Registers

#### 6.35.1.6 ISPR

```
vuint32_t NVIC_TypeDef::ISPR[3]
```

Interrupt Set-Pending Registers

#### 6.35.1.7 RESERVED0

```
uint32_t NVIC_TypeDef::RESERVED0[29]
```

Reserved

### 6.35.1.8 RESERVED1

```
uint32_t NVIC_TypeDef::RESERVED1[29]
```

Reserved

### 6.35.1.9 RESERVED2

```
uint32_t NVIC_TypeDef::RESERVED2[29]
```

Reserved

### 6.35.1.10 RESERVED3

```
uint32_t NVIC_TypeDef::RESERVED3[29]
```

Reserved

### 6.35.1.11 RESERVED4

```
uint32_t NVIC_TypeDef::RESERVED4[61]
```

Reserved

### 6.35.1.12 RESERVED5

```
vuint32_t NVIC_TypeDef::RESERVED5[684]
```

Reserved

### 6.35.1.13 STIR

```
vuint32_t NVIC_TypeDef::STIR
```

Software Trigger Interrupt Register

The documentation for this struct was generated from the following file:

- drivers/Inc/stm32f401xx.h

## 6.36 PWR\_TypeDef Struct Reference

Power Control.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t CSR`

### 6.36.1 Detailed Description

Power Control.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.37 RCC\_TypeDef Struct Reference

Reset and Clock Control.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t PLLCFGR`
- `__IO uint32_t CFGR`
- `__IO uint32_t CIR`
- `__IO uint32_t AHB1RSTR`
- `__IO uint32_t AHB2RSTR`
- `__IO uint32_t AHB3RSTR`
- `uint32_t RESERVED0`
- `__IO uint32_t APB1RSTR`
- `__IO uint32_t APB2RSTR`
- `uint32_t RESERVED1 [2]`
- `__IO uint32_t AHB1ENR`
- `__IO uint32_t AHB2ENR`
- `__IO uint32_t AHB3ENR`
- `uint32_t RESERVED2`
- `__IO uint32_t APB1ENR`
- `__IO uint32_t APB2ENR`
- `uint32_t RESERVED3 [2]`
- `__IO uint32_t AHB1LPENR`
- `__IO uint32_t AHB2LPENR`
- `__IO uint32_t AHB3LPENR`
- `uint32_t RESERVED4`
- `__IO uint32_t APB1LPENR`
- `__IO uint32_t APB2LPENR`
- `uint32_t RESERVED5 [2]`
- `__IO uint32_t BDCR`
- `__IO uint32_t CSR`
- `uint32_t RESERVED6 [2]`
- `__IO uint32_t SSCGR`

- `__IO uint32_t PLLI2SCFGR`
- `__IO uint32_t PLLSAICFGR`
- `__IO uint32_t DCKCFGR`
- `__IO uint32_t CKGATENR`
- `__IO uint32_t DCKCFGR2`
- `vuint32_t CR`
- `vuint32_t PLLCFG`
- `vuint32_t CFG`
- `vuint32_t CIR`
- `vuint32_t AHB1RSTR`
- `vuint32_t AHB2RSTR`
- `uint32 RESERVED0 [2]`
- `vuint32_t APB1RSTR`
- `vuint32_t APB2RSTR`
- `uint32 RESERVED1 [2]`
- `vuint32_t AHB1ENR`
- `vuint32_t AHB2ENR`
- `uint32 RESERVED2 [2]`
- `vuint32_t APB1ENR`
- `vuint32_t APB2ENR`
- `uint32 RESERVED3 [2]`
- `vuint32_t AHB1LPENR`
- `vuint32_t AHB2LPENR`
- `uint32 RESERVED4 [2]`
- `vuint32_t APB1LPENR`
- `vuint32_t APB2LPENR`
- `uint32 RESERVED5 [2]`
- `vuint32_t BDCR`
- `vuint32_t CSR`
- `uint32 RESERVED6 [2]`
- `vuint32_t SSCGR`
- `vuint32_t PLLI2SCFGR`
- `uint32 RESERVED7`
- `vuint32_t DCKCFGR`

### 6.37.1 Detailed Description

Reset and Clock Control.

### 6.37.2 Member Data Documentation

#### 6.37.2.1 AHB1ENR

`vuint32_t RCC_TypeDef::AHB1ENR`

AHB1 Peripheral Clock Enable Register

### 6.37.2.2 AHB1LPENR

```
vuint32_t RCC_TypeDef::AHB1LPENR
```

AHB1 Peripheral Low Power Enable Register

### 6.37.2.3 AHB1RSTR

```
vuint32_t RCC_TypeDef::AHB1RSTR
```

AHB1 Peripheral Reset Register

### 6.37.2.4 AHB2ENR

```
vuint32_t RCC_TypeDef::AHB2ENR
```

AHB2 Peripheral Clock Enable Register

### 6.37.2.5 AHB2LPENR

```
vuint32_t RCC_TypeDef::AHB2LPENR
```

AHB2 Peripheral Low Power Enable Register

### 6.37.2.6 AHB2RSTR

```
vuint32_t RCC_TypeDef::AHB2RSTR
```

AHB2 Peripheral Reset Register

### 6.37.2.7 APB1ENR

```
vuint32_t RCC_TypeDef::APB1ENR
```

APB1 Peripheral Clock Enable Register

### 6.37.2.8 APB1LPENR

```
vuint32_t RCC_TypeDef::APB1LPENR
```

APB1 Peripheral Low Power Enable Register

### 6.37.2.9 APB1RSTR

```
vuint32_t RCC_TypeDef::APB1RSTR
```

APB1 Peripheral Reset Register

### 6.37.2.10 APB2ENR

```
vuint32_t RCC_TypeDef::APB2ENR
```

APB2 Peripheral Clock Enable Register

### 6.37.2.11 APB2LPENR

```
vuint32_t RCC_TypeDef::APB2LPENR
```

APB2 Peripheral Low Power Enable Register

### 6.37.2.12 APB2RSTR

```
vuint32_t RCC_TypeDef::APB2RSTR
```

APB2 Peripheral Reset Register

### 6.37.2.13 BDCR

```
vuint32_t RCC_TypeDef::BDCR
```

Backup Domain Control Register

### 6.37.2.14 CFGR

```
vuint32_t RCC_TypeDef::CFGR
```

Clock Configuration Register

### 6.37.2.15 CIR

```
vuint32_t RCC_TypeDef::CIR
```

Clock Interrupt Register

### 6.37.2.16 CR

```
vuint32_t RCC_TypeDef::CR
```

Clock Control Register

### 6.37.2.17 CSR

```
vuint32_t RCC_TypeDef::CSR
```

Clock Control and Status Register

### 6.37.2.18 DCKCFGR

```
vuint32_t RCC_TypeDef::DCKCFGR
```

Dedicated Clocks Configuration Register

### 6.37.2.19 PLLCFGGR

```
vuint32_t RCC_TypeDef::PLLCFGR
```

PLL Configuration Register

### 6.37.2.20 PLLI2SCFGR

```
vuint32_t RCC_TypeDef::PLLI2SCFGR
```

PLLI2S Configuration Register

### 6.37.2.21 RESERVED0

```
uint32_t RCC_TypeDef::RESERVED0[2]
```

Reserved

### 6.37.2.22 RESERVED1

```
uint32_t RCC_TypeDef::RESERVED1[2]
```

Reserved

### 6.37.2.23 RESERVED2

```
uint32_t RCC_TypeDef::RESERVED2[2]
```

Reserved

### 6.37.2.24 RESERVED3

```
uint32_t RCC_TypeDef::RESERVED3[2]
```

Reserved

### 6.37.2.25 RESERVED4

```
uint32_t RCC_TypeDef::RESERVED4[2]
```

Reserved

### 6.37.2.26 RESERVED5

```
uint32_t RCC_TypeDef::RESERVED5[2]
```

Reserved

### 6.37.2.27 RESERVED6

```
uint32_t RCC_TypeDef::RESERVED6[2]
```

Reserved

### 6.37.2.28 RESERVED7

```
uint32_t RCC_TypeDef::RESERVED7
```

Reserved

### 6.37.2.29 SSCGR

```
vuint32_t RCC_TypeDef::SSCGR
```

Spread Spectrum Clock Generation Register

The documentation for this struct was generated from the following files:

- CMSIS/Inc/[stm32f4xx.h](#)
- drivers/Inc/[stm32f401xx.h](#)

## 6.38 RNG\_TypeDef Struct Reference

RNG.

```
#include <stm32f4xx.h>
```

### Public Attributes

- [\\_\\_IO uint32\\_t CR](#)
- [\\_\\_IO uint32\\_t SR](#)
- [\\_\\_IO uint32\\_t DR](#)

### 6.38.1 Detailed Description

RNG.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[stm32f4xx.h](#)

## 6.39 RTC\_TypeDef Struct Reference

Real-Time Clock.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t TR`
- `__IO uint32_t DR`
- `__IO uint32_t CR`
- `__IO uint32_t ISR`
- `__IO uint32_t PRER`
- `__IO uint32_t WUTR`
- `__IO uint32_t CALIBR`
- `__IO uint32_t ALRMAR`
- `__IO uint32_t ALRMBR`
- `__IO uint32_t WPR`
- `__IO uint32_t SSR`
- `__IO uint32_t SHIFTR`
- `__IO uint32_t TSTR`
- `__IO uint32_t TSDR`
- `__IO uint32_t TSSSR`
- `__IO uint32_t CALR`
- `__IO uint32_t TAFCR`
- `__IO uint32_t ALRMASSR`
- `__IO uint32_t ALRMBSSR`
- `uint32_t RESERVED7`
- `__IO uint32_t BKP0R`
- `__IO uint32_t BKP1R`
- `__IO uint32_t BKP2R`
- `__IO uint32_t BKP3R`
- `__IO uint32_t BKP4R`
- `__IO uint32_t BKP5R`
- `__IO uint32_t BKP6R`
- `__IO uint32_t BKP7R`
- `__IO uint32_t BKP8R`
- `__IO uint32_t BKP9R`
- `__IO uint32_t BKP10R`
- `__IO uint32_t BKP11R`
- `__IO uint32_t BKP12R`
- `__IO uint32_t BKP13R`
- `__IO uint32_t BKP14R`
- `__IO uint32_t BKP15R`
- `__IO uint32_t BKP16R`
- `__IO uint32_t BKP17R`
- `__IO uint32_t BKP18R`
- `__IO uint32_t BKP19R`

### 6.39.1 Detailed Description

Real-Time Clock.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.40 S\_I2C\_Config\_t Struct Reference

Structure for I2C configuration.

```
#include <stm32f401xx_i2c_driver.h>
```

Collaboration diagram for S\_I2C\_Config\_t:



### Public Attributes

- uint32\_t I2C\_Speed
- uint32\_t I2C\_stretchmode
- uint32\_t I2C\_Mode
- struct S\_I2C\_Slave\_address I2C\_Slave\_address
- uint32\_t I2C\_Ack\_Conrtol
- uint32\_t General\_Call\_Address\_Detection
- void(\* P\_Slave\_Event\_CallBack )(Slave\_State state)

### 6.40.1 Detailed Description

Structure for I2C configuration.

### 6.40.2 Member Data Documentation

#### 6.40.2.1 General\_Call\_Address\_Detection

```
uint32_t S_I2C_Config_t::General_Call_Address_Detection
```

General call address detection.

#### 6.40.2.2 I2C\_Ack\_Conrrol

```
uint32_t S_I2C_Config_t::I2C_Ack_Conrrol
```

Acknowledge control.

#### 6.40.2.3 I2C\_Mode

```
uint32_t S_I2C_Config_t::I2C_Mode
```

I2C or SMBus mode.

#### 6.40.2.4 I2C\_Slave\_address

```
struct S_I2C_Slave_address S_I2C_Config_t::I2C_Slave_address
```

Slave address configuration.

#### 6.40.2.5 I2C\_Speed

```
uint32_t S_I2C_Config_t::I2C_Speed
```

I2C clock speed.

#### 6.40.2.6 I2C\_stretchmode

```
uint32_t S_I2C_Config_t::I2C_stretchmode
```

Clock stretching mode.

#### 6.40.2.7 P\_Slave\_Event\_CallBack

```
void(* S_I2C_Config_t::P_Slave_Event_CallBack) (Slave_State state)
```

Callback function for slave events.

The documentation for this struct was generated from the following file:

- drivers/Inc/stm32f401xx\_i2c\_driver.h

## 6.41 S\_I2C\_Slave\_address Struct Reference

Structure for I2C slave address configuration.

```
#include <stm32f401xx_i2c_driver.h>
```

### Public Attributes

- uint16\_t [Enable\\_Dual\\_Address](#)
- uint16\_t [PrimaryAddress](#)
- uint16\_t [SecondaryAddress](#)
- uint16\_t [I2C\\_Addressing\\_Mode](#)

### 6.41.1 Detailed Description

Structure for I2C slave address configuration.

### 6.41.2 Member Data Documentation

#### 6.41.2.1 Enable\_Dual\_Address

```
uint16_t S_I2C_Slave_address::Enable_Dual_Address
```

Enable or disable dual addressing mode.

#### 6.41.2.2 I2C\_Addressing\_Mode

```
uint16_t S_I2C_Slave_address::I2C_Addressing_Mode
```

Addressing mode (7-bit or 10-bit).

#### 6.41.2.3 PrimaryAddress

```
uint16_t S_I2C_Slave_address::PrimaryAddress
```

Primary 7-bit or 10-bit address of the I2C slave.

#### 6.41.2.4 SecondaryAddress

```
uint16_t S_I2C_Slave_address::SecondaryAddress
```

Secondary 7-bit or 10-bit address of the I2C slave.

The documentation for this struct was generated from the following file:

- drivers/Inc/[stm32f401xx\\_i2c\\_driver.h](#)

## 6.42 S\_IRQ\_SRC Struct Reference

Structure to identify the source of SPI interrupts.

```
#include <stm32f401xx_spi_driver.h>
```

### Public Attributes

- uint8\_t **TXE**:1
- uint8\_t **RXE**:1
- uint8\_t **ERRI**:1
- uint8\_t **Reserved**:5

#### 6.42.1 Detailed Description

Structure to identify the source of SPI interrupts.

This structure is used to indicate which interrupt event has occurred in the SPI peripheral.

#### 6.42.2 Member Data Documentation

##### 6.42.2.1 ERRI

```
uint8_t S_IRQ_SRC::ERRI
```

Error interrupt

##### 6.42.2.2 Reserved

```
uint8_t S_IRQ_SRC::Reserved
```

Reserved bits

##### 6.42.2.3 RXE

```
uint8_t S_IRQ_SRC::RXE
```

RX buffer is empty

#### 6.42.2.4 TXE

```
uint8_t S_IRQ_SRC::TXE
```

TX buffer is empty

The documentation for this struct was generated from the following file:

- drivers/Inc/stm32f401xx\_spi\_driver.h

## 6.43 S\_SPI\_Config\_t Struct Reference

Configuration structure for SPI.

```
#include <stm32f401xx_spi_driver.h>
```

### Public Attributes

- uint16\_t [Device\\_Mode](#)
- uint16\_t [Communication\\_Mode](#)
- uint16\_t [Payload\\_Length](#)
- uint16\_t [Frame\\_Format](#)
- uint16\_t [Clock\\_Polarity](#)
- uint16\_t [Clock\\_Phase](#)
- uint16\_t [NSS](#)
- uint16\_t [SPI\\_Prescaler](#)
- uint16\_t [IRQ\\_Enable](#)
- void(\* [P IRQ\\_CallBack](#) )(struct [S\\_IRQ\\_SRC](#) IRQ)

### 6.43.1 Detailed Description

Configuration structure for SPI.

This structure is used to configure the SPI peripheral. It contains settings for device mode, communication mode, payload length, frame format, clock polarity, clock phase, NSS configuration, SPI prescaler, and interrupt enable.

### 6.43.2 Member Data Documentation

#### 6.43.2.1 Clock\_Phase

```
uint16_t S_SPI_Config_t::Clock_Phase
```

Specifies clock phase (sampling on leading or trailing edge). [SPI Clock Phase Definitions](#)

### 6.43.2.2 Clock\_Polarity

```
uint16_t S_SPI_Config_t::Clock_Polarity
```

Specifies clock polarity (idle low or high). [SPI Clock Polarity Definitions](#)

### 6.43.2.3 Communication\_Mode

```
uint16_t S_SPI_Config_t::Communication_Mode
```

Specifies communication mode (bidirectional or unidirectional). [Communication\\_Mode\\_Define](#)

### 6.43.2.4 Device\_Mode

```
uint16_t S_SPI_Config_t::Device_Mode
```

Specifies if SPI operates in master mode or slave mode. [Device\\_Mode\\_Define](#)

### 6.43.2.5 Frame\_Format

```
uint16_t S_SPI_Config_t::Frame_Format
```

Specifies frame format (MSB or LSB first). [SPI Frame Format Definitions](#)

### 6.43.2.6 IRQ\_Enable

```
uint16_t S_SPI_Config_t::IRQ_Enable
```

Enables or disables SPI interrupts. [SPI IRQ Enable Definitions](#)

### 6.43.2.7 NSS

```
uint16_t S_SPI_Config_t::NSS
```

Specifies NSS management (hardware or software). [SPI NSS Definitions](#)

### 6.43.2.8 P\_IRQ\_CallBack

```
void(* S_SPI_Config_t::P_IRQ_CallBack) (struct S_IRQ_SRC IRQ)
```

Callback function for interrupt handling

### 6.43.2.9 Payload\_Length

```
uint16_t S_SPI_Config_t::Payload_Length
```

Specifies payload length (8 or 16 bits). [SPI Payload Length Definitions](#)

### 6.43.2.10 SPI\_Prescaler

```
uint16_t S_SPI_Config_t::SPI_Prescaler
```

Specifies SPI frequency. [SPI Prescaler Definitions](#)

The documentation for this struct was generated from the following file:

- drivers/Inc/[stm32f401xx\\_spi\\_driver.h](#)

## 6.44 SAI\_Block\_TypeDef Struct Reference

### Public Attributes

- [\\_\\_IO uint32\\_t CR1](#)
- [\\_\\_IO uint32\\_t CR2](#)
- [\\_\\_IO uint32\\_t FRCR](#)
- [\\_\\_IO uint32\\_t SLOTR](#)
- [\\_\\_IO uint32\\_t IMR](#)
- [\\_\\_IO uint32\\_t SR](#)
- [\\_\\_IO uint32\\_t CLRFR](#)
- [\\_\\_IO uint32\\_t DR](#)

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[stm32f4xx.h](#)

## 6.45 SAI\_TypeDef Struct Reference

Serial Audio Interface.

```
#include <stm32f4xx.h>
```

### Public Attributes

- [\\_\\_IO uint32\\_t GCR](#)

### 6.45.1 Detailed Description

Serial Audio Interface.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[stm32f4xx.h](#)

## 6.46 SCB\_Type Struct Reference

Structure type to access the System Control Block (SCB).

```
#include <core_cm4.h>
```

### Public Attributes

- `__I uint32_t CPUID`
- `__IO uint32_t ICSR`
- `__IO uint32_t VTOR`
- `__IO uint32_t AIRCR`
- `__IO uint32_t SCR`
- `__IO uint32_t CCR`
- `__IO uint8_t SHP [12]`
- `__IO uint32_t SHCSR`
- `__IO uint32_t CFSR`
- `__IO uint32_t HFSR`
- `__IO uint32_t DFSR`
- `__IO uint32_t MMFAR`
- `__IO uint32_t BFAR`
- `__IO uint32_t AFSR`
- `__I uint32_t PFR [2]`
- `__I uint32_t DFR`
- `__I uint32_t ADR`
- `__I uint32_t MMFR [4]`
- `__I uint32_t ISAR [5]`
- `uint32_t RESERVED0 [5]`
- `__IO uint32_t CPACR`

### 6.46.1 Detailed Description

Structure type to access the System Control Block (SCB).

The documentation for this struct was generated from the following file:

- CMSIS/Inc/core\_cm4.h

## 6.47 SCB\_TypeDef Struct Reference

### Public Attributes

- `vuint32_t CPUID`
- `vuint32_t ICSR`
- `vuint32_t VTOR`
- `vuint32_t AIRCR`
- `vuint32_t SCR`
- `vuint32_t CCR`
- `vuint8_t SHP [12]`
- `vuint32_t SHCSR`
- `vuint32_t CFSR`
- `vuint32_t HFSR`
- `uint32 RESERVED`
- `vuint32_t MMAR`
- `vuint32_t BFAR`

### 6.47.1 Member Data Documentation

#### 6.47.1.1 AIRCR

```
vuint32_t SCB_TypeDef::AIRCR
```

Application Interrupt and Reset Control Register

#### 6.47.1.2 BFAR

```
vuint32_t SCB_TypeDef::BFAR
```

Bus Fault Address Register

#### 6.47.1.3 CCR

```
vuint32_t SCB_TypeDef::CCR
```

Configuration and Control Register

#### 6.47.1.4 CFSR

```
vuint32_t SCB_TypeDef::CFSR
```

Configurable Fault Status Register

#### 6.47.1.5 CPUID

```
vuint32_t SCB_TypeDef::CPUID
```

CPU ID Base Register

#### 6.47.1.6 HFSR

```
vuint32_t SCB_TypeDef::HFSR
```

Hard Fault Status Register

#### 6.47.1.7 ICSR

```
vuint32_t SCB_TypeDef::ICSR
```

Interrupt Control and State Register

### 6.47.1.8 MMAR

`vuint32_t` SCB\_TypeDef::MMAR

Memory Management Fault Address Register

### 6.47.1.9 RESERVED

`uint32` SCB\_TypeDef::RESERVED

Reserved

### 6.47.1.10 SCR

`vuint32_t` SCB\_TypeDef::SCR

System Control Register

### 6.47.1.11 SHCSR

`vuint32_t` SCB\_TypeDef::SHCSR

System Handler Control and State Register

### 6.47.1.12 SHP

`vuint8_t` SCB\_TypeDef::SHP[12]

System Handler Priority Registers

### 6.47.1.13 VTOR

`vuint32_t` SCB\_TypeDef::VTOR

Vector Table Offset Register

The documentation for this struct was generated from the following file:

- drivers/Inc/[stm32f401xx.h](#)

## 6.48 SCnSCB\_Type Struct Reference

Structure type to access the System Control and ID Register not in the SCB.

```
#include <core_cm4.h>
```

## Public Attributes

- `uint32_t RESERVED0 [1]`
- `__I uint32_t ICTR`
- `__IO uint32_t ACTLR`

### 6.48.1 Detailed Description

Structure type to access the System Control and ID Register not in the SCB.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[core\\_cm4.h](#)

## 6.49 SDIO\_TypeDef Struct Reference

SD host Interface.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint32_t POWER`
- `__IO uint32_t CLKCR`
- `__IO uint32_t ARG`
- `__IO uint32_t CMD`
- `__I uint32_t RESPCMD`
- `__I uint32_t RESP1`
- `__I uint32_t RESP2`
- `__I uint32_t RESP3`
- `__I uint32_t RESP4`
- `__IO uint32_t DTIMER`
- `__IO uint32_t DLEN`
- `__IO uint32_t DCTRL`
- `__I uint32_t DCOUNT`
- `__I uint32_t STA`
- `__IO uint32_t ICR`
- `__IO uint32_t MASK`
- `uint32_t RESERVED0 [2]`
- `__I uint32_t FIFO_CNT`
- `uint32_t RESERVED1 [13]`
- `__IO uint32_t FIFO`

### 6.49.1 Detailed Description

SD host Interface.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[stm32f4xx.h](#)

## 6.50 SPI\_TypeDef Struct Reference

Serial Peripheral Interface.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint16_t CR1`
- `uint16_t RESERVED0`
- `__IO uint16_t CR2`
- `uint16_t RESERVED1`
- `__IO uint16_t SR`
- `uint16_t RESERVED2`
- `__IO uint16_t DR`
- `uint16_t RESERVED3`
- `__IO uint16_t CRCPR`
- `uint16_t RESERVED4`
- `__IO uint16_t RXCRR`
- `uint16_t RESERVED5`
- `__IO uint16_t TXCRR`
- `uint16_t RESERVED6`
- `__IO uint16_t I2SCFGR`
- `uint16_t RESERVED7`
- `__IO uint16_t I2SPR`
- `uint16_t RESERVED8`
- `uint32 CR1`
- `uint32 CR2`
- `uint32 SR`
- `uint32 DR`
- `uint32 CRCPR`
- `uint32 RXCRR`
- `uint32 TXCRR`
- `uint32 I2SCFGR`
- `uint32 I2SPR`

### 6.50.1 Detailed Description

Serial Peripheral Interface.

### 6.50.2 Member Data Documentation

#### 6.50.2.1 CR1

```
uint32 SPI_TypeDef::CR1
```

SPI Control Register 1

### 6.50.2.2 CR2

```
uint32 SPI_TypeDef::CR2
```

SPI Control Register 1

### 6.50.2.3 CRCPR

```
uint32 SPI_TypeDef::CRCPR
```

SPI CRC Polynomial Register

### 6.50.2.4 DR

```
uint32 SPI_TypeDef::DR
```

SPI Data Register

### 6.50.2.5 I2SCFGR

```
uint32 SPI_TypeDef::I2SCFGR
```

SPI I2S Configuration Register

### 6.50.2.6 I2SPR

```
uint32 SPI_TypeDef::I2SPR
```

SPI I2S Prescaler Register

### 6.50.2.7 RXCRCR

```
uint32 SPI_TypeDef::RXCRCR
```

SPI RX CRC Register

### 6.50.2.8 SR

```
uint32 SPI_TypeDef::SR
```

SPI Status Register

### 6.50.2.9 TXCRCR

```
uint32 SPI_TypeDef::TXCRCR
```

SPI TX CRC Register

The documentation for this struct was generated from the following files:

- CMSIS/Inc/[stm32f4xx.h](#)
- drivers/Inc/[stm32f401xx.h](#)

## 6.51 STK\_config\_t Struct Reference

SysTick Configuration Structure Definition.

```
#include <stm32f401xx_systick_driver.h>
```

### Public Attributes

- `uint8 running_mode`
- `uint8 clock_config`
- `uint8 interrupt_config`
- `uint32 reload_value`
- `void(* Callback_Function )(void)`

### 6.51.1 Detailed Description

SysTick Configuration Structure Definition.

This structure contains the configuration options for the SysTick timer, including the running mode, clock source, interrupt configuration, and reload value. A callback function can also be specified to handle the SysTick interrupt.

### 6.51.2 Member Data Documentation

#### 6.51.2.1 Callback\_Function

```
void(* STK_config_t::Callback_Function) (void)
```

Pointer to the callback function for SysTick interrupt

#### 6.51.2.2 clock\_config

```
uint8 STK_config_t::clock_config
```

[SysTick Clock Configuration](#) - Clock source for the SysTick timer

### 6.51.2.3 interrupt\_config

```
uint8 STK_config_t::interrupt_config
```

SysTick Interrupt Configuration - Interrupt enable/disable configuration

### 6.51.2.4 reload\_value

```
uint32 STK_config_t::reload_value
```

Reload value to define the SysTick timer's duration

### 6.51.2.5 running\_mode

```
uint8 STK_config_t::running_mode
```

SysTick Running Mode Configuration - Running mode of the SysTick timer

The documentation for this struct was generated from the following file:

- drivers/Inc/stm32f401xx\_systick\_driver.h

## 6.52 STK\_TypeDef Struct Reference

### Public Attributes

- `vuint32_t CTRL`
- `vuint32_t LOAD`
- `vuint32_t VAL`
- `vuint32_t CALIB`

### 6.52.1 Member Data Documentation

#### 6.52.1.1 CALIB

```
vuint32_t STK_TypeDef::CALIB
```

Calibration Value Register

#### 6.52.1.2 CTRL

```
vuint32_t STK_TypeDef::CTRL
```

Control and Status Register

### 6.52.1.3 LOAD

`vuint32_t` `STK_TypeDef::LOAD`

Reload Value Register

### 6.52.1.4 VAL

`vuint32_t` `STK_TypeDef::VAL`

Current Value Register

The documentation for this struct was generated from the following file:

- `drivers/Inc/stm32f401xx.h`

## 6.53 SYSCFG\_RegDef\_t Struct Reference

### Public Attributes

- `vuint32_t MEMRMP`
- `vuint32_t PMC`
- `vuint32_t EXTICR [4]`
- `uint32 RESERVED1 [2]`
- `vuint32_t CMPCR`
- `uint32 RESERVED2 [2]`
- `vuint32_t CFGR`

### 6.53.1 Member Data Documentation

#### 6.53.1.1 CFGR

`vuint32_t` `SYSCFG_RegDef_t::CFGR`

SYSCFG Configuration Register

#### 6.53.1.2 CMPCR

`vuint32_t` `SYSCFG_RegDef_t::CMPCR`

SYSCFG Compensation Cell Control Register

### 6.53.1.3 EXTICR

```
vuint32_t SYSCFG_RegDef_t::EXTICR[4]
```

SYSCFG External Interrupt Configuration Registers

### 6.53.1.4 MEMRMP

```
vuint32_t SYSCFG_RegDef_t::MEMRMP
```

SYSCFG Memory Remap Register

### 6.53.1.5 PMC

```
vuint32_t SYSCFG_RegDef_t::PMC
```

SYSCFG Peripheral Mode Configuration Register

### 6.53.1.6 RESERVED1

```
uint32_t SYSCFG_RegDef_t::RESERVED1[2]
```

Reserved

### 6.53.1.7 RESERVED2

```
uint32_t SYSCFG_RegDef_t::RESERVED2[2]
```

Reserved

The documentation for this struct was generated from the following file:

- drivers/Inc/stm32f401xx.h

## 6.54 SYSCFG\_TypeDef Struct Reference

System configuration controller.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t MEMRMP`
- `__IO uint32_t PMC`
- `__IO uint32_t EXTICR [4]`
- `uint32_t RESERVED [2]`
- `__IO uint32_t CMPCR`

### 6.54.1 Detailed Description

System configuration controller.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[stm32f4xx.h](#)

## 6.55 SysTick\_Type Struct Reference

Structure type to access the System Timer (SysTick).

```
#include <core_cm4.h>
```

### Public Attributes

- [\\_\\_IO uint32\\_t CTRL](#)
- [\\_\\_IO uint32\\_t LOAD](#)
- [\\_\\_IO uint32\\_t VAL](#)
- [\\_\\_I uint32\\_t CALIB](#)

### 6.55.1 Detailed Description

Structure type to access the System Timer (SysTick).

The documentation for this struct was generated from the following file:

- CMSIS/Inc/[core\\_cm4.h](#)

## 6.56 TIM1\_TypeDef Struct Reference

### Public Attributes

- [uint32 CR1](#)
- [uint32 CR2](#)
- [uint32 SMCR](#)
- [uint32 DIER](#)
- [uint32 SR](#)
- [uint32 EGR](#)
- [uint32 CCMR1](#)
- [uint32 CCMR2](#)
- [uint32 CCER](#)
- [uint32 CNT](#)
- [uint32 PSC](#)
- [uint32 ARR](#)
- [uint32 RCR](#)
- [uint32 CCR1](#)
- [uint32 CCR2](#)
- [uint32 CCR3](#)
- [uint32 CCR4](#)
- [uint32 BDTR](#)
- [uint32 DCR](#)
- [uint32 DMAR](#)
- [uint32 OR](#)

## 6.56.1 Member Data Documentation

### 6.56.1.1 ARR

```
uint32 TIM1_TypeDef::ARR
```

TIM1 Auto-Reload Register

### 6.56.1.2 BDTR

```
uint32 TIM1_TypeDef::BDTR
```

TIM1 Break and Dead-Time Register

### 6.56.1.3 CCER

```
uint32 TIM1_TypeDef::CCER
```

TIM1 Capture/Compare Enable Register

### 6.56.1.4 CCMR1

```
uint32 TIM1_TypeDef::CCMR1
```

TIM1 Capture/Compare Mode Register 1

### 6.56.1.5 CCMR2

```
uint32 TIM1_TypeDef::CCMR2
```

TIM1 Capture/Compare Mode Register 2

### 6.56.1.6 CCR1

```
uint32 TIM1_TypeDef::CCR1
```

TIM1 Capture/Compare Register 1

### 6.56.1.7 CCR2

```
uint32 TIM1_TypeDef::CCR2
```

TIM1 Capture/Compare Register 2

### 6.56.1.8 CCR3

```
uint32 TIM1_TypeDef::CCR3
```

TIM1 Capture/Compare Register 3

### 6.56.1.9 CCR4

```
uint32 TIM1_TypeDef::CCR4
```

TIM1 Capture/Compare Register 4

### 6.56.1.10 CNT

```
uint32 TIM1_TypeDef::CNT
```

TIM1 Counter Register

### 6.56.1.11 CR1

```
uint32 TIM1_TypeDef::CR1
```

TIM1 Control Register 1

### 6.56.1.12 CR2

```
uint32 TIM1_TypeDef::CR2
```

TIM1 Control Register 2

### 6.56.1.13 DCR

```
uint32 TIM1_TypeDef::DCR
```

TIM1 DMA Control Register

### 6.56.1.14 DIER

```
uint32 TIM1_TypeDef::DIER
```

TIM1 DMA/Interrupt Enable Register

### 6.56.1.15 DMAR

```
uint32 TIM1_TypeDef::DMAR
```

TIM1 DMA Address Register

### 6.56.1.16 EGR

```
uint32 TIM1_TypeDef::EGR
```

TIM1 Event Generation Register

### 6.56.1.17 OR

```
uint32 TIM1_TypeDef::OR
```

TIM1 Option Register

### 6.56.1.18 PSC

```
uint32 TIM1_TypeDef::PSC
```

TIM1 Prescaler Register

### 6.56.1.19 RCR

```
uint32 TIM1_TypeDef::RCR
```

TIM1 Repetition Counter Register

### 6.56.1.20 SMCR

```
uint32 TIM1_TypeDef::SMCR
```

TIM1 Slave Mode Control Register

### 6.56.1.21 SR

```
uint32 TIM1_TypeDef::SR
```

TIM1 Status Register

The documentation for this struct was generated from the following file:

- drivers/Inc/stm32f401xx.h

## 6.57 TIM\_TypeDef Struct Reference

TIM.

```
#include <stm32f4xx.h>
```

## Public Attributes

- `__IO uint16_t CR1`
- `uint16_t RESERVED0`
- `__IO uint16_t CR2`
- `uint16_t RESERVED1`
- `__IO uint16_t SMCR`
- `uint16_t RESERVED2`
- `__IO uint16_t DIER`
- `uint16_t RESERVED3`
- `__IO uint16_t SR`
- `uint16_t RESERVED4`
- `__IO uint16_t EGR`
- `uint16_t RESERVED5`
- `__IO uint16_t CCMR1`
- `uint16_t RESERVED6`
- `__IO uint16_t CCMR2`
- `uint16_t RESERVED7`
- `__IO uint16_t CCER`
- `uint16_t RESERVED8`
- `__IO uint32_t CNT`
- `__IO uint16_t PSC`
- `uint16_t RESERVED9`
- `__IO uint32_t ARR`
- `__IO uint16_t RCR`
- `uint16_t RESERVED10`
- `__IO uint32_t CCR1`
- `__IO uint32_t CCR2`
- `__IO uint32_t CCR3`
- `__IO uint32_t CCR4`
- `__IO uint16_t BDTR`
- `uint16_t RESERVED11`
- `__IO uint16_t DCR`
- `uint16_t RESERVED12`
- `__IO uint16_t DMAR`
- `uint16_t RESERVED13`
- `__IO uint16_t OR`
- `uint16_t RESERVED14`

### 6.57.1 Detailed Description

TIM.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.58 TPI\_Type Struct Reference

Structure type to access the Trace Port Interface Register (TPI).

```
#include <core_cm4.h>
```

## Public Attributes

- `__IO uint32_t SSPSR`
- `__IO uint32_t CSPSR`
- `uint32_t RESERVED0 [2]`
- `__IO uint32_t ACPR`
- `uint32_t RESERVED1 [55]`
- `__IO uint32_t SPPR`
- `uint32_t RESERVED2 [131]`
- `__I uint32_t FFSR`
- `__IO uint32_t FFCR`
- `__I uint32_t FSCR`
- `uint32_t RESERVED3 [759]`
- `__I uint32_t TRIGGER`
- `__I uint32_t FIFO0`
- `__I uint32_t ITATBCTR2`
- `uint32_t RESERVED4 [1]`
- `__I uint32_t ITATBCTR0`
- `__I uint32_t FIFO1`
- `__IO uint32_t ITCTRL`
- `uint32_t RESERVED5 [39]`
- `__IO uint32_t CLAIMSET`
- `__IO uint32_t CLAIMCLR`
- `uint32_t RESERVED7 [8]`
- `__I uint32_t DEVID`
- `__I uint32_t DEVTYPE`

### 6.58.1 Detailed Description

Structure type to access the Trace Port Interface Register (TPI).

The documentation for this struct was generated from the following file:

- CMSIS/Inc/core\_cm4.h

## 6.59 USART\_cfg\_t Struct Reference

Configuration structure for USART (Universal Synchronous Asynchronous Receiver Transmitter) peripheral.

```
#include <stm32f401xx_usart_driver.h>
```

## Public Attributes

- `uint8 USART_Mode`
- `uint32 BaudRate`
- `uint8 Payload_Length`
- `uint32 Parity`
- `uint32 StopBits`
- `uint8 HwFlowCtl`
- `uint8 IRQ_Enable`
- `void(* P_IRQ_Callback )(void)`

### 6.59.1 Detailed Description

Configuration structure for USART (Universal Synchronous Asynchronous Receiver Transmitter) peripheral.

The documentation for this struct was generated from the following file:

- drivers/Inc/stm32f401xx\_usart\_driver.h

## 6.60 USART\_TypeDef Struct Reference

Universal Synchronous Asynchronous Receiver Transmitter.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint16_t SR`
- `uint16_t RESERVED0`
- `__IO uint16_t DR`
- `uint16_t RESERVED1`
- `__IO uint16_t BRR`
- `uint16_t RESERVED2`
- `__IO uint16_t CR1`
- `uint16_t RESERVED3`
- `__IO uint16_t CR2`
- `uint16_t RESERVED4`
- `__IO uint16_t CR3`
- `uint16_t RESERVED5`
- `__IO uint16_t GTPR`
- `uint16_t RESERVED6`
- `uint32 SR`
- `uint32 DR`
- `uint32 BRR`
- `uint32 CR1`
- `uint32 CR2`
- `uint32 CR3`
- `uint32 GTPR`

### 6.60.1 Detailed Description

Universal Synchronous Asynchronous Receiver Transmitter.

### 6.60.2 Member Data Documentation

### 6.60.2.1 BRR

```
uint32 USART_TypeDef::BRR
```

USART Baud Rate Register

### 6.60.2.2 CR1

```
uint32 USART_TypeDef::CR1
```

USART Control Register 1

### 6.60.2.3 CR2

```
uint32 USART_TypeDef::CR2
```

USART Control Register 2

### 6.60.2.4 CR3

```
uint32 USART_TypeDef::CR3
```

USART Control Register 3

### 6.60.2.5 DR

```
uint32 USART_TypeDef::DR
```

USART Data Register

### 6.60.2.6 GTPR

```
uint32 USART_TypeDef::GTPR
```

USART Guard Time and Prescaler Register

### 6.60.2.7 SR

```
uint32 USART_TypeDef::SR
```

USART Status Register

The documentation for this struct was generated from the following files:

- CMSIS/Inc/[stm32f4xx.h](#)
- drivers/Inc/[stm32f401xx.h](#)

## 6.61 WWDG\_TypeDef Struct Reference

Window WATCHDOG.

```
#include <stm32f4xx.h>
```

### Public Attributes

- `__IO uint32_t CR`
- `__IO uint32_t CFR`
- `__IO uint32_t SR`

#### 6.61.1 Detailed Description

Window WATCHDOG.

The documentation for this struct was generated from the following file:

- CMSIS/Inc/stm32f4xx.h

## 6.62 xPSR\_Type Union Reference

Union type to access the Special-Purpose Program Status Registers (xPSR).

```
#include <core_cm4.h>
```

### Public Attributes

- struct {  
    `uint32_t xPSR_Type::ISR:9`  
    `uint32_t xPSR_Type::_reserved0:7`  
    `uint32_t xPSR_Type::GE:4`  
    `uint32_t xPSR_Type::_reserved1:4`  
    `uint32_t xPSR_Type::T:1`  
    `uint32_t xPSR_Type::IT:2`  
    `uint32_t xPSR_Type::Q:1`  
    `uint32_t xPSR_Type::V:1`  
    `uint32_t xPSR_Type::C:1`  
    `uint32_t xPSR_Type::Z:1`  
    `uint32_t xPSR_Type::N:1`  
} **b**
- `uint32_t w`

#### 6.62.1 Detailed Description

Union type to access the Special-Purpose Program Status Registers (xPSR).

The documentation for this union was generated from the following file:

- CMSIS/Inc/core\_cm4.h

# Chapter 7

## File Documentation

### 7.1 bsp/Inc/eeprom\_flash.h File Reference

Header file for EEPROM flash memory operations.

```
#include "stm32f401xx_i2c_driver.h"  
Include dependency graph for eeprom_flash.h:
```



This graph shows which files directly or indirectly include this file:



## Macros

- `#define EEPROM_Slave_address 0x50`  
*AT24C1024B EEPROM slave address for I2C communication.*

## Functions

- `void EEPROM_Init (void)`  
*Initializes the EEPROM for communication.*
- `unsigned char EEPROM_Write_NBytes (unsigned int Memory_address, unsigned char *bytes, uint8_t Data_Length)`  
*Writes multiple bytes to the EEPROM.*
- `unsigned char EEPROM_Read_byte (unsigned int Memory_address, uint8_t *dataout, uint8_t datalen)`  
*Reads a byte from the EEPROM.*

### 7.1.1 Detailed Description

Header file for EEPROM flash memory operations.

#### Author

Mohamed Ali Haoufa

Version

0.1

Date

2024-09-21

This file provides the function prototypes and constants for initializing and managing EEPROM flash memory using the STM32F401xx MCU. It includes functions for writing and reading data from the EEPROM and defines the EEPROM slave address used in I2C communication.

Copyright

Copyright (c) 2024 Mohamed Ali Haoufa. All rights reserved.

The EEPROM is configured as an I2C slave device with the address 0x50. The provided functions allow for initialization, writing, and reading data from the AT24C1024B EEPROM. Ensure the correct I2C driver is included and configured for communication with the EEPROM.

## 7.2 bsp/Inc/keypad\_driver.h File Reference

Header file for the STM32F401xx microcontroller keypad driver.

```
#include "stm32f401xx_gpio_driver.h"  
Include dependency graph for keypad_driver.h:
```



This graph shows which files directly or indirectly include this file:



## Macros

- `#define KEYPAD_PORT GPIOE`  
*Defines the GPIO port and pins for the keypad.*
- `#define KEYPAD_ROWS 4`
- `#define ROW0 GPIO_PIN_0`
- `#define ROW1 GPIO_PIN_1`
- `#define ROW2 GPIO_PIN_3`
- `#define ROW3 GPIO_PIN_4`
- `#define KEYPAD_COLS 3`
- `#define COL0 GPIO_PIN_5`
- `#define COL1 GPIO_PIN_6`
- `#define COL2 GPIO_PIN_7`

## Functions

- `void keypad_init (void)`  
*Initializes the keypad.*
- `uint8 keypad_Get_Pressed_Key (void)`  
*Checks for a pressed key and returns its value.*

### 7.2.1 Detailed Description

Header file for the STM32F401xx microcontroller keypad driver.

**Author**

Mohamed Ali Haoufa

**Version**

0.1

**Date**

2024-09-21

This header file provides the necessary definitions, macros, and function prototypes for interfacing with a keypad connected to the STM32F401xx microcontroller. It includes definitions for keypad rows and columns, as well as APIs for initializing the keypad and reading the pressed key.

**Copyright**

Copyright (c) 2024 Mohamed Ali Haoufa. All rights reserved.

## 7.3 bsp/Inc/lcd\_driver.h File Reference

Header file for the STM32F401xx microcontroller LCD driver.

```
#include "stm32f401xx_gpio_driver.h"
#include "stm32f401xx_systick_driver.h"
Include dependency graph for lcd_driver.h:
```



This graph shows which files directly or indirectly include this file:



## Classes

- struct [LCD\\_t](#)

*Structure for configuring the LCD.*

## Macros

- #define [LCD\\_CLEAR\\_DISPLAY](#) (0x01)  
*Command to clear the LCD display.*
- #define [LCD\\_RETURN\\_HOME](#) (0x02)  
*Command to return the cursor to the home position.*
- #define [LCD\\_ENTRY\\_MODE\\_DEC\\_SHIFT\\_OFF](#) (0x04)  
*Command to set the entry mode to decrement and shift off.*
- #define [LCD\\_ENTRY\\_MODE\\_DEC\\_SHIFT\\_ON](#) (0x05)  
*Command to set the entry mode to decrement and shift on.*
- #define [LCD\\_ENTRY\\_MODE\\_INC\\_SHIFT\\_OFF](#) (0x06)  
*Command to set the entry mode to increment and shift off.*
- #define [LCD\\_ENTRY\\_MODE\\_INC\\_SHIFT\\_ON](#) (0x07)  
*Command to set the entry mode to increment and shift on.*
- #define [LCD\\_CURSOR\\_MOVE\\_SHIFT\\_LEFT](#) (0x10)  
*Command to move the cursor left.*
- #define [LCD\\_CURSOR\\_MOVE\\_SHIFT\\_RIGHT](#) (0x14)  
*Command to move the cursor right.*
- #define [LCD\\_DISPLAY\\_SHIFT\\_LEFT](#) (0x18)  
*Command to shift the display left.*
- #define [LCD\\_DISPLAY\\_SHIFT\\_RIGHT](#) (0x1C)

- `#define LCD_DISPLAY_ON_UNDERLINE_OFF_CURSOR_OFF (0x0C)`

*Command to shift the display right.*
- `#define LCD_DISPLAY_ON_UNDERLINE_OFF_CURSOR_ON (0x0D)`

*Command to turn on the display with underline off and cursor off.*
- `#define LCD_DISPLAY_ON_UNDERLINE_ON_CURSOR_OFF (0x0E)`

*Command to turn on the display with underline off and cursor on.*
- `#define LCD_DISPLAY_ON_UNDERLINE_ON_CURSOR_ON (0x0F)`

*Command to turn on the display with underline on and cursor off.*
- `#define LCD_DISPLAY_OFF_CURSOR_OFF (0x08)`

*Command to turn off the display with cursor off.*
- `#define LCD_8BIT_MODE_2_LINE (0x38)`

*Command to set the display in 8-bit mode with 2 lines.*
- `#define LCD_4BIT_MODE_2_LINE (0x28)`

*Command to set the display in 4-bit mode with 2 lines.*
- `#define LCD_FIRST_ROW (0x80)`

*Command to set the cursor position to the first row.*
- `#define LCD_SECOND_ROW (0xC0)`

*Command to set the cursor position to the second row.*
- `#define LCD_THIRD_ROW (0x94)`

*Command to set the cursor position to the third row.*
- `#define LCD_FOURTH_ROW (0xD4)`

*Command to set the cursor position to the fourth row.*

## Enumerations

- enum `LCD_MODE_t { LCD_8BIT , LCD_4BIT }`

*Enum for specifying the LCD mode.*
- enum `LCD_ROWS_t { LCD_2ROWS , LCD_4ROWS }`

*Enum for specifying the number of rows on the LCD.*

## Functions

- void `LCD_Init (LCD_t *LCD_cfg)`

*Initializes the LCD with user-defined configurations.*
- void `LCD_Send_Command (LCD_t *LCD_cfg, uint8 command)`

*Sends a command to the LCD to be executed.*
- void `LCD_Send_Char (LCD_t *LCD_cfg, uint8 Char)`

*Sends a character to the LCD to be displayed.*
- void `LCD_Send_Char_Pos (LCD_t *LCD_cfg, uint8 Char, uint8 row, uint8 column)`

*Sends a character to the LCD to be displayed at a specific location.*
- void `LCD_Send_String (LCD_t *LCD_cfg, uint8 *string)`

*Sends a string to the LCD to be displayed.*
- void `LCD_Send_String_Pos (LCD_t *LCD_cfg, uint8 *string, uint8 row, uint8 column)`

*Sends a string to the LCD to be displayed at a specific location.*
- void `LCD_Send_Enable_Signal (LCD_t *LCD_cfg)`

*Sends an enable signal to the LCD.*
- void `LCD_Set_Cursor (LCD_t *LCD_cfg, uint8 row, uint8 column)`

*Sets the location of the cursor on the LCD.*

### 7.3.1 Detailed Description

Header file for the STM32F401xx microcontroller LCD driver.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This header file provides the necessary definitions, macros, and function prototypes for interfacing with an LCD connected to the STM32F401xx microcontroller. It includes configurations for LCD modes, rows, and various LCD commands and functions.

#### Copyright

Copyright (c) 2024 Mohamed Ali Haoufa. All rights reserved.

## 7.4 bsp/Inc/led\_driver.h File Reference

Header file for the STM32F401xx microcontroller LED driver.

```
#include "stm32f401xx_gpio_driver.h"
```

Include dependency graph for led\_driver.h:



This graph shows which files directly or indirectly include this file:



## Classes

- struct `LED_cfg_t`

## Enumerations

- enum `LED_Mode_t` { `LED_Active_High` , `LED_Active_Low` , `LED_Mode_max` }

## Functions

- void `LED_Init` (const `LED_cfg_t` \*led\_cfg)  
*Initializes the LED with the specified configuration.*
- void `LED_TurnOn` (const `LED_cfg_t` \*led\_cfg)  
*Turns on the LED.*
- void `LED_TurnOff` (const `LED_cfg_t` \*led\_cfg)  
*Turns off the LED.*
- void `LED_Toggle` (const `LED_cfg_t` \*led\_cfg)  
*Toggles the state of the LED.*

### 7.4.1 Detailed Description

Header file for the STM32F401xx microcontroller LED driver.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file provides the necessary definitions, macros, and function prototypes for controlling LEDs connected to the STM32F401xx microcontroller. It includes configurations for LED modes and APIs for initializing and manipulating LEDs.

#### Copyright

Copyright (c) 2024 Mohamed Ali Haoufa. All rights reserved.

## 7.5 bsp/Src/eeprom\_flash.c File Reference

Implementation of EEPROM flash memory operations for STM32F401xx MCU.

```
#include "eeprom_flash.h"
```

Include dependency graph for eeprom\_flash.c:



## Functions

- void [EEPROM\\_Init](#) (void)
 

*Initializes the EEPROM for I2C communication.*
- unsigned char [EEPROM\\_Write\\_NBytes](#) (unsigned int Memory\_address, unsigned char \*bytes, uint8\_t Data\_Length)
 

*Writes a block of data to the EEPROM.*
- unsigned char [EEPROM\\_Read\\_byte](#) (unsigned int Memory\_address, uint8\_t \*dataout, uint8\_t datalen)
 

*Reads a byte from the EEPROM.*

## Variables

- `uint8_t buffer [256]`  
*Buffer used for I2C communication with AT24C1024B EEPROM.*

### 7.5.1 Detailed Description

Implementation of EEPROM flash memory operations for STM32F401xx MCU.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file contains the implementation of functions to initialize and manage EEPROM flash memory using I2C communication with the STM32F401xx MCU. It includes functions for writing and reading data from the EEPROM.

#### Copyright

Copyright (c) 2024 Mohamed Ali Haoufa. All rights reserved.

## 7.6 bsp/Src/keypad\_driver.c File Reference

Source file for the keypad driver, implementing functionality to initialize and read input from a keypad connected to the STM32F401xx MCU.

```
#include "keypad_driver.h"
Include dependency graph for keypad_driver.c:
```



## Functions

- `void keypad_init (void)`  
*Initializes the keypad by configuring the GPIO pins.*
- `uint8 keypad_Get_Pressed_Key (void)`  
*Reads the pressed key from the keypad.*

### 7.6.1 Detailed Description

Source file for the keypad driver, implementing functionality to initialize and read input from a keypad connected to the STM32F401xx MCU.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file contains the implementation of functions for initializing the keypad and reading the pressed key values. It includes definitions and configurations for keypad rows and columns, as well as utility functions to interface with the hardware.

#### Copyright

Copyright (c) 2024 Mohamed Ali Haoufa. All rights reserved.

## 7.7 bsp/Src/lcd\_driver.c File Reference

Contains functions for controlling an LCD using an STM32F401xx MCU.

```
#include "lcd_driver.h"
```

Include dependency graph for lcd\_driver.c:



## Functions

- void `LCD_Init (LCD_t *LCD_cfg)`  
*Initializes the LCD based on user-defined configurations.*
- void `LCD_Send_Command (LCD_t *LCD_cfg, uint8 command)`  
*Sends a command to the LCD.*
- void `LCD_Send_Char (LCD_t *LCD_cfg, uint8 Char)`  
*Sends a character to the LCD to be displayed.*
- void `LCD_Send_Char_Pos (LCD_t *LCD_cfg, uint8 Char, uint8 row, uint8 column)`  
*Sends a character to the LCD to be displayed at a specific location.*
- void `LCD_Send_String (LCD_t *LCD_cfg, uint8 *string)`  
*Sends a string to the LCD to be displayed.*
- void `LCD_Send_String_Pos (LCD_t *LCD_cfg, uint8 *string, uint8 row, uint8 column)`  
*Sends a string to the LCD to be displayed at a specific location.*
- void `LCD_Send_Enable_Signal (LCD_t *LCD_cfg)`  
*Sends an enable signal to the LCD.*
- void `LCD_Set_Cursor (LCD_t *LCD_cfg, uint8 row, uint8 column)`  
*Sets the location of the cursor on the LCD.*

### 7.7.1 Detailed Description

Contains functions for controlling an LCD using an STM32F401xx MCU.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file implements the LCD driver functions including initialization, sending commands, characters, and strings to the LCD, and controlling the cursor position. It uses GPIOs of the STM32F401xx microcontroller for communication with the LCD.

#### Copyright

Copyright (c) 2024

## 7.8 bsp/Src/led\_driver.c File Reference

LED Driver Functions for STM32F401xx MCU.

```
#include "led_driver.h"
Include dependency graph for led_driver.c:
```



## Functions

- void `LED_Init` (const `LED_cfg_t` \*led\_cfg)  
*Initializes the LED according to the provided configuration.*
- void `LED_TurnOn` (const `LED_cfg_t` \*led\_cfg)  
*Turns on the LED.*
- void `LED_TurnOff` (const `LED_cfg_t` \*led\_cfg)  
*Turns off the LED.*
- void `LED_Toggle` (const `LED_cfg_t` \*led\_cfg)  
*Toggles the status of the LED.*

### 7.8.1 Detailed Description

LED Driver Functions for STM32F401xx MCU.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file provides functions to initialize and control LEDs connected to the STM32F401xx microcontroller. It includes functions to initialize the LED, turn it on or off, and toggle its state.

#### Copyright

Copyright (c) 2024

## 7.9 CMSIS/Inc/core\_cm4.h File Reference

CMSIS Cortex-M4 Core Peripheral Access Layer Header File.

```
#include <stdint.h>
#include <core_cmInstr.h>
#include <core_cmFunc.h>
#include <core_cmSimd.h>
```

Include dependency graph for core\_cm4.h:



This graph shows which files directly or indirectly include this file:



### Classes

- union [APSR\\_Type](#)  
*Union type to access the Application Program Status Register (APSR).*
- union [IPSR\\_Type](#)  
*Union type to access the Interrupt Program Status Register (IPSR).*
- union [xPSR\\_Type](#)  
*Union type to access the Special-Purpose Program Status Registers (xPSR).*
- union [CONTROL\\_Type](#)  
*Union type to access the Control Registers (CONTROL).*
- struct [NVIC\\_Type](#)

- **SCB\_Type**  
*Structure type to access the Nested Vectored Interrupt Controller (NVIC).*
  - **SCnSCB\_Type**  
*Structure type to access the System Control Block (SCB).*
  - **SysTick\_Type**  
*Structure type to access the System Timer (SysTick).*
  - **ITM\_Type**  
*Structure type to access the Instrumentation Trace Macrocell Register (ITM).*
  - **DWT\_Type**  
*Structure type to access the Data Watchpoint and Trace Register (DWT).*
  - **TPI\_Type**  
*Structure type to access the Trace Port Interface Register (TPI).*
  - **CoreDebug\_Type**  
*Structure type to access the Core Debug Register (CoreDebug).*
- 
- `#define __CM4_CMSIS_VERSION_MAIN (0x04)`
  - `#define __CM4_CMSIS_VERSION_SUB (0x00)`
  - `#define __CM4_CMSIS_VERSION`
  - `#define __CORTEX_M (0x04)`
  - `#define __CORE_CM4_H_DEPENDANT`
  - `#define __I volatile const`
  - `#define __O volatile`
  - `#define __IO volatile`
  - `#define APSR_N_Pos 31`
  - `#define APSR_N_Msk (1UL << APSR_N_Pos)`
  - `#define APSR_Z_Pos 30`
  - `#define APSR_Z_Msk (1UL << APSR_Z_Pos)`
  - `#define APSR_C_Pos 29`
  - `#define APSR_C_Msk (1UL << APSR_C_Pos)`
  - `#define APSR_V_Pos 28`
  - `#define APSR_V_Msk (1UL << APSR_V_Pos)`
  - `#define APSR_Q_Pos 27`
  - `#define APSR_Q_Msk (1UL << APSR_Q_Pos)`
  - `#define APSR_GE_Pos 16`
  - `#define APSR_GE_Msk (0xFUL << APSR_GE_Pos)`
  - `#define IPSR_ISR_Pos 0`
  - `#define IPSR_ISR_Msk (0x1FFUL /*<< IPSR_ISR_Pos*/)`
  - `#define xPSR_N_Pos 31`
  - `#define xPSR_N_Msk (1UL << xPSR_N_Pos)`
  - `#define xPSR_Z_Pos 30`
  - `#define xPSR_Z_Msk (1UL << xPSR_Z_Pos)`
  - `#define xPSR_C_Pos 29`
  - `#define xPSR_C_Msk (1UL << xPSR_C_Pos)`
  - `#define xPSR_V_Pos 28`
  - `#define xPSR_V_Msk (1UL << xPSR_V_Pos)`
  - `#define xPSR_Q_Pos 27`
  - `#define xPSR_Q_Msk (1UL << xPSR_Q_Pos)`
  - `#define xPSR_IT_Pos 25`
  - `#define xPSR_IT_Msk (3UL << xPSR_IT_Pos)`
  - `#define xPSR_T_Pos 24`
  - `#define xPSR_T_Msk (1UL << xPSR_T_Pos)`
  - `#define xPSR_GE_Pos 16`

- #define xPSR\_GE\_Msk (0xFUL << xPSR\_GE\_Pos)
- #define xPSR\_ISR\_Pos 0
- #define xPSR\_ISR\_Msk (0x1FFUL /\*<< xPSR\_ISR\_Pos\*/)
- #define CONTROL\_FPCA\_Pos 2
- #define CONTROL\_FPCA\_Msk (1UL << CONTROL\_FPCA\_Pos)
- #define CONTROL\_SPSEL\_Pos 1
- #define CONTROL\_SPSEL\_Msk (1UL << CONTROL\_SPSEL\_Pos)
- #define CONTROL\_nPRIV\_Pos 0
- #define CONTROL\_nPRIV\_Msk (1UL /\*<< CONTROL\_nPRIV\_Pos\*/)
- #define NVIC\_STIR\_INTID\_Pos 0
- #define NVIC\_STIR\_INTID\_Msk (0x1FFUL /\*<< NVIC\_STIR\_INTID\_Pos\*/)
- #define SCB\_CPUID\_IMPLEMENTER\_Pos 24
- #define SCB\_CPUID\_IMPLEMENTER\_Msk (0xFFUL << SCB\_CPUID\_IMPLEMENTER\_Pos)
- #define SCB\_CPUID\_VARIANT\_Pos 20
- #define SCB\_CPUID\_VARIANT\_Msk (0xFUL << SCB\_CPUID\_VARIANT\_Pos)
- #define SCB\_CPUID\_ARCHITECTURE\_Pos 16
- #define SCB\_CPUID\_ARCHITECTURE\_Msk (0xFUL << SCB\_CPUID\_ARCHITECTURE\_Pos)
- #define SCB\_CPUID\_PARTNO\_Pos 4
- #define SCB\_CPUID\_PARTNO\_Msk (0xFFFFUL << SCB\_CPUID\_PARTNO\_Pos)
- #define SCB\_CPUID\_REVISION\_Pos 0
- #define SCB\_CPUID\_REVISION\_Msk (0xFUL /\*<< SCB\_CPUID\_REVISION\_Pos\*/)
- #define SCB\_ICSR\_NMIPENDSET\_Pos 31
- #define SCB\_ICSR\_NMIPENDSET\_Msk (1UL << SCB\_ICSR\_NMIPENDSET\_Pos)
- #define SCB\_ICSR\_PENDSVSET\_Pos 28
- #define SCB\_ICSR\_PENDSVSET\_Msk (1UL << SCB\_ICSR\_PENDSVSET\_Pos)
- #define SCB\_ICSR\_PENDSVCLR\_Pos 27
- #define SCB\_ICSR\_PENDSVCLR\_Msk (1UL << SCB\_ICSR\_PENDSVCLR\_Pos)
- #define SCB\_ICSR\_PENDSTSET\_Pos 26
- #define SCB\_ICSR\_PENDSTSET\_Msk (1UL << SCB\_ICSR\_PENDSTSET\_Pos)
- #define SCB\_ICSR\_PENDSTCLR\_Pos 25
- #define SCB\_ICSR\_PENDSTCLR\_Msk (1UL << SCB\_ICSR\_PENDSTCLR\_Pos)
- #define SCB\_ICSR\_ISRPREEMPT\_Pos 23
- #define SCB\_ICSR\_ISRPREEMPT\_Msk (1UL << SCB\_ICSR\_ISRPREEMPT\_Pos)
- #define SCB\_ICSR\_ISRPENDING\_Pos 22
- #define SCB\_ICSR\_ISRPENDING\_Msk (1UL << SCB\_ICSR\_ISRPENDING\_Pos)
- #define SCB\_ICSR\_VECTPENDING\_Pos 12
- #define SCB\_ICSR\_VECTPENDING\_Msk (0x1FFUL << SCB\_ICSR\_VECTPENDING\_Pos)
- #define SCB\_ICSR\_RETTOBASE\_Pos 11
- #define SCB\_ICSR\_RETTOBASE\_Msk (1UL << SCB\_ICSR\_RETTOBASE\_Pos)
- #define SCB\_ICSR\_VECTACTIVE\_Pos 0
- #define SCB\_ICSR\_VECTACTIVE\_Msk (0x1FFUL /\*<< SCB\_ICSR\_VECTACTIVE\_Pos\*/)
- #define SCB\_VTOR\_TBLOFF\_Pos 7
- #define SCB\_VTOR\_TBLOFF\_Msk (0x1FFFFFFUL << SCB\_VTOR\_TBLOFF\_Pos)
- #define SCB\_AIRCR\_VECTKEY\_Pos 16
- #define SCB\_AIRCR\_VECTKEY\_Msk (0xFFFFUL << SCB\_AIRCR\_VECTKEY\_Pos)
- #define SCB\_AIRCR\_VECTKEYSTAT\_Pos 16
- #define SCB\_AIRCR\_VECTKEYSTAT\_Msk (0xFFFFUL << SCB\_AIRCR\_VECTKEYSTAT\_Pos)
- #define SCB\_AIRCR\_ENDIANESS\_Pos 15
- #define SCB\_AIRCR\_ENDIANESS\_Msk (1UL << SCB\_AIRCR\_ENDIANESS\_Pos)
- #define SCB\_AIRCR\_PRIGROUP\_Pos 8
- #define SCB\_AIRCR\_PRIGROUP\_Msk (7UL << SCB\_AIRCR\_PRIGROUP\_Pos)
- #define SCB\_AIRCR\_SYSRESETREQ\_Pos 2
- #define SCB\_AIRCR\_SYSRESETREQ\_Msk (1UL << SCB\_AIRCR\_SYSRESETREQ\_Pos)
- #define SCB\_AIRCR\_VECTCLRACTIVE\_Pos 1
- #define SCB\_AIRCR\_VECTCLRACTIVE\_Msk (1UL << SCB\_AIRCR\_VECTCLRACTIVE\_Pos)

- #define SCB\_AIRCR\_VECTRESET\_Pos 0
- #define SCB\_AIRCR\_VECTRESET\_Msk (1UL /\*<< SCB\_AIRCR\_VECTRESET\_Pos\*/)
- #define SCB\_SCR\_SEVONPEND\_Pos 4
- #define SCB\_SCR\_SEVONPEND\_Msk (1UL << SCB\_SCR\_SEVONPEND\_Pos)
- #define SCB\_SCR\_SLEEPDEEP\_Pos 2
- #define SCB\_SCR\_SLEEPDEEP\_Msk (1UL << SCB\_SCR\_SLEEPDEEP\_Pos)
- #define SCB\_SCR\_SLEEPONEXIT\_Pos 1
- #define SCB\_SCR\_SLEEPONEXIT\_Msk (1UL << SCB\_SCR\_SLEEPONEXIT\_Pos)
- #define SCB\_CCR\_STKALIGN\_Pos 9
- #define SCB\_CCR\_STKALIGN\_Msk (1UL << SCB\_CCR\_STKALIGN\_Pos)
- #define SCB\_CCR\_BFHFNIGN\_Pos 8
- #define SCB\_CCR\_BFHFNIGN\_Msk (1UL << SCB\_CCR\_BFHFNIGN\_Pos)
- #define SCB\_CCR\_DIV\_0\_TRP\_Pos 4
- #define SCB\_CCR\_DIV\_0\_TRP\_Msk (1UL << SCB\_CCR\_DIV\_0\_TRP\_Pos)
- #define SCB\_CCR\_UNALIGN\_TRP\_Pos 3
- #define SCB\_CCR\_UNALIGN\_TRP\_Msk (1UL << SCB\_CCR\_UNALIGN\_TRP\_Pos)
- #define SCB\_CCR\_USERSETMPEND\_Pos 1
- #define SCB\_CCR\_USERSETMPEND\_Msk (1UL << SCB\_CCR\_USERSETMPEND\_Pos)
- #define SCB\_CCR\_NONBASETHRDENA\_Pos 0
- #define SCB\_CCR\_NONBASETHRDENA\_Msk (1UL /\*<< SCB\_CCR\_NONBASETHRDENA\_Pos\*/)
- #define SCB\_SHCSR\_USGFAULTENA\_Pos 18
- #define SCB\_SHCSR\_USGFAULTENA\_Msk (1UL << SCB\_SHCSR\_USGFAULTENA\_Pos)
- #define SCB\_SHCSR\_BUSFAULTENA\_Pos 17
- #define SCB\_SHCSR\_BUSFAULTENA\_Msk (1UL << SCB\_SHCSR\_BUSFAULTENA\_Pos)
- #define SCB\_SHCSR\_MEMFAULTENA\_Pos 16
- #define SCB\_SHCSR\_MEMFAULTENA\_Msk (1UL << SCB\_SHCSR\_MEMFAULTENA\_Pos)
- #define SCB\_SHCSR\_SVCALLPENDED\_Pos 15
- #define SCB\_SHCSR\_SVCALLPENDED\_Msk (1UL << SCB\_SHCSR\_SVCALLPENDED\_Pos)
- #define SCB\_SHCSR\_BUSFAULTPENDED\_Pos 14
- #define SCB\_SHCSR\_BUSFAULTPENDED\_Msk (1UL << SCB\_SHCSR\_BUSFAULTPENDED\_Pos)
- #define SCB\_SHCSR\_MEMFAULTPENDED\_Pos 13
- #define SCB\_SHCSR\_MEMFAULTPENDED\_Msk (1UL << SCB\_SHCSR\_MEMFAULTPENDED\_Pos)
- #define SCB\_SHCSR\_USGFAULTPENDED\_Pos 12
- #define SCB\_SHCSR\_USGFAULTPENDED\_Msk (1UL << SCB\_SHCSR\_USGFAULTPENDED\_Pos)
- #define SCB\_SHCSR\_SYSTICKACT\_Pos 11
- #define SCB\_SHCSR\_SYSTICKACT\_Msk (1UL << SCB\_SHCSR\_SYSTICKACT\_Pos)
- #define SCB\_SHCSR\_PENDSVACT\_Pos 10
- #define SCB\_SHCSR\_PENDSVACT\_Msk (1UL << SCB\_SHCSR\_PENDSVACT\_Pos)
- #define SCB\_SHCSR\_MONITORACT\_Pos 8
- #define SCB\_SHCSR\_MONITORACT\_Msk (1UL << SCB\_SHCSR\_MONITORACT\_Pos)
- #define SCB\_SHCSR\_SVCALLACT\_Pos 7
- #define SCB\_SHCSR\_SVCALLACT\_Msk (1UL << SCB\_SHCSR\_SVCALLACT\_Pos)
- #define SCB\_SHCSR\_USGFAULTACT\_Pos 3
- #define SCB\_SHCSR\_USGFAULTACT\_Msk (1UL << SCB\_SHCSR\_USGFAULTACT\_Pos)
- #define SCB\_SHCSR\_BUSFAULTACT\_Pos 1
- #define SCB\_SHCSR\_BUSFAULTACT\_Msk (1UL << SCB\_SHCSR\_BUSFAULTACT\_Pos)
- #define SCB\_SHCSR\_MEMFAULTACT\_Pos 0
- #define SCB\_SHCSR\_MEMFAULTACT\_Msk (1UL /\*<< SCB\_SHCSR\_MEMFAULTACT\_Pos\*/)
- #define SCB\_CFSR\_USGFAULTSR\_Pos 16
- #define SCB\_CFSR\_USGFAULTSR\_Msk (0xFFFFUL << SCB\_CFSR\_USGFAULTSR\_Pos)
- #define SCB\_CFSR\_BUSFAULTSR\_Pos 8
- #define SCB\_CFSR\_BUSFAULTSR\_Msk (0xFFUL << SCB\_CFSR\_BUSFAULTSR\_Pos)
- #define SCB\_CFSR\_MEMFAULTSR\_Pos 0
- #define SCB\_CFSR\_MEMFAULTSR\_Msk (0xFFUL /\*<< SCB\_CFSR\_MEMFAULTSR\_Pos\*/)
- #define SCB\_HFSR\_DEBUGEVT\_Pos 31

- #define SCB\_HFSR\_DEBUGEV<sub>T</sub>\_Msk (1UL << SCB\_HFSR\_DEBUGEV<sub>T</sub>\_Pos)
- #define SCB\_HFSR\_FORCED\_Pos 30
- #define SCB\_HFSR\_FORCED\_Msk (1UL << SCB\_HFSR\_FORCED\_Pos)
- #define SCB\_HFSR\_VECTTBL\_Pos 1
- #define SCB\_HFSR\_VECTTBL\_Msk (1UL << SCB\_HFSR\_VECTTBL\_Pos)
- #define SCB\_DFSR\_EXTERNAL\_Pos 4
- #define SCB\_DFSR\_EXTERNAL\_Msk (1UL << SCB\_DFSR\_EXTERNAL\_Pos)
- #define SCB\_DFSR\_VCATCH\_Pos 3
- #define SCB\_DFSR\_VCATCH\_Msk (1UL << SCB\_DFSR\_VCATCH\_Pos)
- #define SCB\_DFSR\_DWTTRAP\_Pos 2
- #define SCB\_DFSR\_DWTTRAP\_Msk (1UL << SCB\_DFSR\_DWTTRAP\_Pos)
- #define SCB\_DFSR\_BKPT\_Pos 1
- #define SCB\_DFSR\_BKPT\_Msk (1UL << SCB\_DFSR\_BKPT\_Pos)
- #define SCB\_DFSR\_HALTED\_Pos 0
- #define SCB\_DFSR\_HALTED\_Msk (1UL /\*<< SCB\_DFSR\_HALTED\_Pos\*/)
- #define SCnSCB\_ICTR\_INTLINESNUM\_Pos 0
- #define SCnSCB\_ICTR\_INTLINESNUM\_Msk (0xFUL /\*<< SCnSCB\_ICTR\_INTLINESNUM\_Pos\*/)
- #define SCnSCB\_ACTLR\_DISOOP<sub>F</sub>\_Pos 9
- #define SCnSCB\_ACTLR\_DISOOP<sub>F</sub>\_Msk (1UL << SCnSCB\_ACTLR\_DISOOP<sub>F</sub>\_Pos)
- #define SCnSCB\_ACTLR\_DISFPCA\_Pos 8
- #define SCnSCB\_ACTLR\_DISFPCA\_Msk (1UL << SCnSCB\_ACTLR\_DISFPCA\_Pos)
- #define SCnSCB\_ACTLR\_DISFOLD\_Pos 2
- #define SCnSCB\_ACTLR\_DISFOLD\_Msk (1UL << SCnSCB\_ACTLR\_DISFOLD\_Pos)
- #define SCnSCB\_ACTLR\_DISDEFWB<sub>U</sub>Buf\_Pos 1
- #define SCnSCB\_ACTLR\_DISDEFWB<sub>U</sub>Buf\_Msk (1UL << SCnSCB\_ACTLR\_DISDEFWB<sub>U</sub>Buf\_Pos)
- #define SCnSCB\_ACTLR\_DISMCYCINT\_Pos 0
- #define SCnSCB\_ACTLR\_DISMCYCINT\_Msk (1UL /\*<< SCnSCB\_ACTLR\_DISMCYCINT\_Pos\*/)
- #define SysTick\_CTRL\_COUNTFLAG\_Pos 16
- #define SysTick\_CTRL\_COUNTFLAG\_Msk (1UL << SysTick\_CTRL\_COUNTFLAG\_Pos)
- #define SysTick\_CTRL\_CLKSOURCE\_Pos 2
- #define SysTick\_CTRL\_CLKSOURCE\_Msk (1UL << SysTick\_CTRL\_CLKSOURCE\_Pos)
- #define SysTick\_CTRL\_TICKINT\_Pos 1
- #define SysTick\_CTRL\_TICKINT\_Msk (1UL << SysTick\_CTRL\_TICKINT\_Pos)
- #define SysTick\_CTRL\_ENABLE\_Pos 0
- #define SysTick\_CTRL\_ENABLE\_Msk (1UL /\*<< SysTick\_CTRL\_ENABLE\_Pos\*/)
- #define SysTick\_LOAD\_RELOAD\_Pos 0
- #define SysTick\_LOAD\_RELOAD\_Msk (0xFFFFFUL /\*<< SysTick\_LOAD\_RELOAD\_Pos\*/)
- #define SysTick\_VAL\_CURRENT\_Pos 0
- #define SysTick\_VAL\_CURRENT\_Msk (0xFFFFFUL /\*<< SysTick\_VAL\_CURRENT\_Pos\*/)
- #define SysTick\_CALIB\_NOREF\_Pos 31
- #define SysTick\_CALIB\_NOREF\_Msk (1UL << SysTick\_CALIB\_NOREF\_Pos)
- #define SysTick\_CALIB\_SKEW\_Pos 30
- #define SysTick\_CALIB\_SKEW\_Msk (1UL << SysTick\_CALIB\_SKEW\_Pos)
- #define SysTick\_CALIB\_TENMS\_Pos 0
- #define SysTick\_CALIB\_TENMS\_Msk (0xFFFFFUL /\*<< SysTick\_CALIB\_TENMS\_Pos\*/)
- #define ITM\_TPR\_PRIVMASK\_Pos 0
- #define ITM\_TPR\_PRIVMASK\_Msk (0xFUL /\*<< ITM\_TPR\_PRIVMASK\_Pos\*/)
- #define ITM\_TCR\_BUSY\_Pos 23
- #define ITM\_TCR\_BUSY\_Msk (1UL << ITM\_TCR\_BUSY\_Pos)
- #define ITM\_TCR\_TraceBusID\_Pos 16
- #define ITM\_TCR\_TraceBusID\_Msk (0x7FUL << ITM\_TCR\_TraceBusID\_Pos)
- #define ITM\_TCR\_GTSFREQ\_Pos 10
- #define ITM\_TCR\_GTSFREQ\_Msk (3UL << ITM\_TCR\_GTSFREQ\_Pos)
- #define ITM\_TCR\_TSPrescale\_Pos 8
- #define ITM\_TCR\_TSPrescale\_Msk (3UL << ITM\_TCR\_TSPrescale\_Pos)

- #define ITM\_TCR\_SWOENA\_Pos 4
- #define ITM\_TCR\_SWOENA\_Msk (1UL << ITM\_TCR\_SWOENA\_Pos)
- #define ITM\_TCR\_DWTENA\_Pos 3
- #define ITM\_TCR\_DWTENA\_Msk (1UL << ITM\_TCR\_DWTENA\_Pos)
- #define ITM\_TCR\_SYNCENA\_Pos 2
- #define ITM\_TCR\_SYNCENA\_Msk (1UL << ITM\_TCR\_SYNCENA\_Pos)
- #define ITM\_TCR\_TSENA\_Pos 1
- #define ITM\_TCR\_TSENA\_Msk (1UL << ITM\_TCR\_TSENA\_Pos)
- #define ITM\_TCR\_ITMENA\_Pos 0
- #define ITM\_TCR\_ITMENA\_Msk (1UL /\*<< ITM\_TCR\_ITMENA\_Pos\*/)
- #define ITM\_IWR\_ATVALIDM\_Pos 0
- #define ITM\_IWR\_ATVALIDM\_Msk (1UL /\*<< ITM\_IWR\_ATVALIDM\_Pos\*/)
- #define ITM\_IRR\_ATREADYM\_Pos 0
- #define ITM\_IRR\_ATREADYM\_Msk (1UL /\*<< ITM\_IRR\_ATREADYM\_Pos\*/)
- #define ITM\_IMCR\_INTEGRATION\_Pos 0
- #define ITM\_IMCR\_INTEGRATION\_Msk (1UL /\*<< ITM\_IMCR\_INTEGRATION\_Pos\*/)
- #define ITM\_LSR\_ByteAcc\_Pos 2
- #define ITM\_LSR\_ByteAcc\_Msk (1UL << ITM\_LSR\_ByteAcc\_Pos)
- #define ITM\_LSR\_Access\_Pos 1
- #define ITM\_LSR\_Access\_Msk (1UL << ITM\_LSR\_Access\_Pos)
- #define ITM\_LSR\_Present\_Pos 0
- #define ITM\_LSR\_Present\_Msk (1UL /\*<< ITM\_LSR\_Present\_Pos\*/)
- #define DWT\_CTRL\_NUMCOMP\_Pos 28
- #define DWT\_CTRL\_NUMCOMP\_Msk (0xFUL << DWT\_CTRL\_NUMCOMP\_Pos)
- #define DWT\_CTRL\_NOTRCPKT\_Pos 27
- #define DWT\_CTRL\_NOTRCPKT\_Msk (0x1UL << DWT\_CTRL\_NOTRCPKT\_Pos)
- #define DWT\_CTRL\_NOEXTTRIG\_Pos 26
- #define DWT\_CTRL\_NOEXTTRIG\_Msk (0x1UL << DWT\_CTRL\_NOEXTTRIG\_Pos)
- #define DWT\_CTRL\_NOCYCCNT\_Pos 25
- #define DWT\_CTRL\_NOCYCCNT\_Msk (0x1UL << DWT\_CTRL\_NOCYCCNT\_Pos)
- #define DWT\_CTRL\_NOPRFCNT\_Pos 24
- #define DWT\_CTRL\_NOPRFCNT\_Msk (0x1UL << DWT\_CTRL\_NOPRFCNT\_Pos)
- #define DWT\_CTRL\_CYCEVTENA\_Pos 22
- #define DWT\_CTRL\_CYCEVTENA\_Msk (0x1UL << DWT\_CTRL\_CYCEVTENA\_Pos)
- #define DWT\_CTRL\_FOLDEVTENA\_Pos 21
- #define DWT\_CTRL\_FOLDEVTENA\_Msk (0x1UL << DWT\_CTRL\_FOLDEVTENA\_Pos)
- #define DWT\_CTRL\_LSUEVTENA\_Pos 20
- #define DWT\_CTRL\_LSUEVTENA\_Msk (0x1UL << DWT\_CTRL\_LSUEVTENA\_Pos)
- #define DWT\_CTRL\_SLEEPEVTENA\_Pos 19
- #define DWT\_CTRL\_SLEEPEVTENA\_Msk (0x1UL << DWT\_CTRL\_SLEEPEVTENA\_Pos)
- #define DWT\_CTRL\_EXCEVTENA\_Pos 18
- #define DWT\_CTRL\_EXCEVTENA\_Msk (0x1UL << DWT\_CTRL\_EXCEVTENA\_Pos)
- #define DWT\_CTRL\_CPIEVTEA\_Pos 17
- #define DWT\_CTRL\_CPIEVTEA\_Msk (0x1UL << DWT\_CTRL\_CPIEVTEA\_Pos)
- #define DWT\_CTRL\_EXCTRCENA\_Pos 16
- #define DWT\_CTRL\_EXCTRCENA\_Msk (0x1UL << DWT\_CTRL\_EXCTRCENA\_Pos)
- #define DWT\_CTRL\_PCSAMPLENA\_Pos 12
- #define DWT\_CTRL\_PCSAMPLENA\_Msk (0x1UL << DWT\_CTRL\_PCSAMPLENA\_Pos)
- #define DWT\_CTRL\_SYNCTAP\_Pos 10
- #define DWT\_CTRL\_SYNCTAP\_Msk (0x3UL << DWT\_CTRL\_SYNCTAP\_Pos)
- #define DWT\_CTRL\_CYCTAP\_Pos 9
- #define DWT\_CTRL\_CYCTAP\_Msk (0x1UL << DWT\_CTRL\_CYCTAP\_Pos)
- #define DWT\_CTRL\_POSTINIT\_Pos 5
- #define DWT\_CTRL\_POSTINIT\_Msk (0xFUL << DWT\_CTRL\_POSTINIT\_Pos)
- #define DWT\_CTRL\_POSTPRESET\_Pos 1

- #define DWT\_CTRL\_POSTPRESET\_Msk (0xFUL << DWT\_CTRL\_POSTPRESET\_Pos)
- #define DWT\_CTRL\_CYCCNTENA\_Pos 0
- #define DWT\_CTRL\_CYCCNTENA\_Msk (0x1UL /\*<< DWT\_CTRL\_CYCCNTENA\_Pos\*/)
- #define DWT\_CPLICNT\_CPLICNT\_Pos 0
- #define DWT\_CPLICNT\_CPLICNT\_Msk (0xFFUL /\*<< DWT\_CPLICNT\_CPLICNT\_Pos\*/)
- #define DWT\_EXCCNT\_EXCCNT\_Pos 0
- #define DWT\_EXCCNT\_EXCCNT\_Msk (0xFFUL /\*<< DWT\_EXCCNT\_EXCCNT\_Pos\*/)
- #define DWT\_SLEEP\_CNT\_SLEEP\_CNT\_Pos 0
- #define DWT\_SLEEP\_CNT\_SLEEP\_CNT\_Msk (0xFFUL /\*<< DWT\_SLEEP\_CNT\_SLEEP\_CNT\_Pos\*/)
- #define DWT\_LSUCNT\_LSUCNT\_Pos 0
- #define DWT\_LSUCNT\_LSUCNT\_Msk (0xFFUL /\*<< DWT\_LSUCNT\_LSUCNT\_Pos\*/)
- #define DWT\_FOLDCNT\_FOLDCNT\_Pos 0
- #define DWT\_FOLDCNT\_FOLDCNT\_Msk (0xFFUL /\*<< DWT\_FOLDCNT\_FOLDCNT\_Pos\*/)
- #define DWT\_MASK\_MASK\_Pos 0
- #define DWT\_MASK\_MASK\_Msk (0x1FUL /\*<< DWT\_MASK\_MASK\_Pos\*/)
- #define DWT\_FUNCTION\_MATCHED\_Pos 24
- #define DWT\_FUNCTION\_MATCHED\_Msk (0x1UL << DWT\_FUNCTION\_MATCHED\_Pos)
- #define DWT\_FUNCTION\_DATAVADDR1\_Pos 16
- #define DWT\_FUNCTION\_DATAVADDR1\_Msk (0xFUL << DWT\_FUNCTION\_DATAVADDR1\_Pos)
- #define DWT\_FUNCTION\_DATAVADDR0\_Pos 12
- #define DWT\_FUNCTION\_DATAVADDR0\_Msk (0xFUL << DWT\_FUNCTION\_DATAVADDR0\_Pos)
- #define DWT\_FUNCTION\_DATAVSIZE\_Pos 10
- #define DWT\_FUNCTION\_DATAVSIZE\_Msk (0x3UL << DWT\_FUNCTION\_DATAVSIZE\_Pos)
- #define DWT\_FUNCTION\_LNK1ENA\_Pos 9
- #define DWT\_FUNCTION\_LNK1ENA\_Msk (0x1UL << DWT\_FUNCTION\_LNK1ENA\_Pos)
- #define DWT\_FUNCTION\_DATAVMATCH\_Pos 8
- #define DWT\_FUNCTION\_DATAVMATCH\_Msk (0x1UL << DWT\_FUNCTION\_DATAVMATCH\_Pos)
- #define DWT\_FUNCTION\_CYCMATCH\_Pos 7
- #define DWT\_FUNCTION\_CYCMATCH\_Msk (0x1UL << DWT\_FUNCTION\_CYCMATCH\_Pos)
- #define DWT\_FUNCTION\_EMITRANGE\_Pos 5
- #define DWT\_FUNCTION\_EMITRANGE\_Msk (0x1UL << DWT\_FUNCTION\_EMITRANGE\_Pos)
- #define DWT\_FUNCTION\_FUNCTION\_Pos 0
- #define DWT\_FUNCTION\_FUNCTION\_Msk (0xFUL /\*<< DWT\_FUNCTION\_FUNCTION\_Pos\*/)
- #define TPI\_ACPR\_PRESCALER\_Pos 0
- #define TPI\_ACPR\_PRESCALER\_Msk (0xFFFFUL /\*<< TPI\_ACPR\_PRESCALER\_Pos\*/)
- #define TPI\_SPPR\_TXMODE\_Pos 0
- #define TPI\_SPPR\_TXMODE\_Msk (0x3UL /\*<< TPI\_SPPR\_TXMODE\_Pos\*/)
- #define TPI\_FFSR\_FtNonStop\_Pos 3
- #define TPI\_FFSR\_FtNonStop\_Msk (0x1UL << TPI\_FFSR\_FtNonStop\_Pos)
- #define TPI\_FFSR\_TCPresent\_Pos 2
- #define TPI\_FFSR\_TCPresent\_Msk (0x1UL << TPI\_FFSR\_TCPresent\_Pos)
- #define TPI\_FFSR\_FtStopped\_Pos 1
- #define TPI\_FFSR\_FtStopped\_Msk (0x1UL << TPI\_FFSR\_FtStopped\_Pos)
- #define TPI\_FFSR\_FInProg\_Pos 0
- #define TPI\_FFSR\_FInProg\_Msk (0x1UL /\*<< TPI\_FFSR\_FInProg\_Pos\*/)
- #define TPI\_FFCR\_TrigIn\_Pos 8
- #define TPI\_FFCR\_TrigIn\_Msk (0x1UL << TPI\_FFCR\_TrigIn\_Pos)
- #define TPI\_FFCR\_EnFCont\_Pos 1
- #define TPI\_FFCR\_EnFCont\_Msk (0x1UL << TPI\_FFCR\_EnFCont\_Pos)
- #define TPI\_TRIGGER\_TRIGGER\_Pos 0
- #define TPI\_TRIGGER\_TRIGGER\_Msk (0x1UL /\*<< TPI\_TRIGGER\_TRIGGER\_Pos\*/)
- #define TPI\_FIFO0\_ITM\_ATVALID\_Pos 29
- #define TPI\_FIFO0\_ITM\_ATVALID\_Msk (0x3UL << TPI\_FIFO0\_ITM\_ATVALID\_Pos)
- #define TPI\_FIFO0\_ITM\_bytectcount\_Pos 27
- #define TPI\_FIFO0\_ITM\_bytectcount\_Msk (0x3UL << TPI\_FIFO0\_ITM\_bytectcount\_Pos)

- #define TPI\_FIFO0\_ETM\_ATVALID\_Pos 26
- #define TPI\_FIFO0\_ETM\_ATVALID\_Msk (0x3UL << TPI\_FIFO0\_ETM\_ATVALID\_Pos)
- #define TPI\_FIFO0\_ETM\_bytecount\_Pos 24
- #define TPI\_FIFO0\_ETM\_bytecount\_Msk (0x3UL << TPI\_FIFO0\_ETM\_bytecount\_Pos)
- #define TPI\_FIFO0\_ETM2\_Pos 16
- #define TPI\_FIFO0\_ETM2\_Msk (0xFFUL << TPI\_FIFO0\_ETM2\_Pos)
- #define TPI\_FIFO0\_ETM1\_Pos 8
- #define TPI\_FIFO0\_ETM1\_Msk (0xFFUL << TPI\_FIFO0\_ETM1\_Pos)
- #define TPI\_FIFO0\_ETM0\_Pos 0
- #define TPI\_FIFO0\_ETM0\_Msk (0xFFUL /\*<< TPI\_FIFO0\_ETM0\_Pos\*/)
- #define TPI\_ITATBCTR2\_ATREADY\_Pos 0
- #define TPI\_ITATBCTR2\_ATREADY\_Msk (0x1UL /\*<< TPI\_ITATBCTR2\_ATREADY\_Pos\*/)
- #define TPI\_FIFO1\_ITM\_ATVALID\_Pos 29
- #define TPI\_FIFO1\_ITM\_ATVALID\_Msk (0x3UL << TPI\_FIFO1\_ITM\_ATVALID\_Pos)
- #define TPI\_FIFO1\_ITM\_bytecount\_Pos 27
- #define TPI\_FIFO1\_ITM\_bytecount\_Msk (0x3UL << TPI\_FIFO1\_ITM\_bytecount\_Pos)
- #define TPI\_FIFO1\_ETM\_ATVALID\_Pos 26
- #define TPI\_FIFO1\_ETM\_ATVALID\_Msk (0x3UL << TPI\_FIFO1\_ETM\_ATVALID\_Pos)
- #define TPI\_FIFO1\_ETM\_bytecount\_Pos 24
- #define TPI\_FIFO1\_ETM\_bytecount\_Msk (0x3UL << TPI\_FIFO1\_ETM\_bytecount\_Pos)
- #define TPI\_FIFO1\_ITM2\_Pos 16
- #define TPI\_FIFO1\_ITM2\_Msk (0xFFUL << TPI\_FIFO1\_ITM2\_Pos)
- #define TPI\_FIFO1\_ITM1\_Pos 8
- #define TPI\_FIFO1\_ITM1\_Msk (0xFFUL << TPI\_FIFO1\_ITM1\_Pos)
- #define TPI\_FIFO1\_ITM0\_Pos 0
- #define TPI\_FIFO1\_ITM0\_Msk (0xFFUL /\*<< TPI\_FIFO1\_ITM0\_Pos\*/)
- #define TPI\_ITATBCTR0\_ATREADY\_Pos 0
- #define TPI\_ITATBCTR0\_ATREADY\_Msk (0x1UL /\*<< TPI\_ITATBCTR0\_ATREADY\_Pos\*/)
- #define TPI\_ITCTRL\_Mode\_Pos 0
- #define TPI\_ITCTRL\_Mode\_Msk (0x1UL /\*<< TPI\_ITCTRL\_Mode\_Pos\*/)
- #define TPI\_DEVID\_NRZVALID\_Pos 11
- #define TPI\_DEVID\_NRZVALID\_Msk (0x1UL << TPI\_DEVID\_NRZVALID\_Pos)
- #define TPI\_DEVID\_MANCVALID\_Pos 10
- #define TPI\_DEVID\_MANCVALID\_Msk (0x1UL << TPI\_DEVID\_MANCVALID\_Pos)
- #define TPI\_DEVID\_PTINVALID\_Pos 9
- #define TPI\_DEVID\_PTINVALID\_Msk (0x1UL << TPI\_DEVID\_PTINVALID\_Pos)
- #define TPI\_DEVID\_MinBufSz\_Pos 6
- #define TPI\_DEVID\_MinBufSz\_Msk (0x7UL << TPI\_DEVID\_MinBufSz\_Pos)
- #define TPI\_DEVID\_AsynClkIn\_Pos 5
- #define TPI\_DEVID\_AsynClkIn\_Msk (0x1UL << TPI\_DEVID\_AsynClkIn\_Pos)
- #define TPI\_DEVID\_NrTraceInput\_Pos 0
- #define TPI\_DEVID\_NrTraceInput\_Msk (0xFUL /\*<< TPI\_DEVID\_NrTraceInput\_Pos\*/)
- #define TPI\_DEVTYPE\_MajorType\_Pos 4
- #define TPI\_DEVTYPE\_MajorType\_Msk (0xFUL << TPI\_DEVTYPE\_MajorType\_Pos)
- #define TPI\_DEVTYPE\_SubType\_Pos 0
- #define TPI\_DEVTYPE\_SubType\_Msk (0xFUL /\*<< TPI\_DEVTYPE\_SubType\_Pos\*/)
- #define CoreDebug\_DHCSR\_DBGKEY\_Pos 16
- #define CoreDebug\_DHCSR\_DBGKEY\_Msk (0xFFFFFUL << CoreDebug\_DHCSR\_DBGKEY\_Pos)
- #define CoreDebug\_DHCSR\_S\_RESET\_ST\_Pos 25
- #define CoreDebug\_DHCSR\_S\_RESET\_ST\_Msk (1UL << CoreDebug\_DHCSR\_S\_RESET\_ST\_Pos)
- #define CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Pos 24
- #define CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Msk (1UL << CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Pos)
- #define CoreDebug\_DHCSR\_S\_LOCKUP\_Pos 19
- #define CoreDebug\_DHCSR\_S\_LOCKUP\_Msk (1UL << CoreDebug\_DHCSR\_S\_LOCKUP\_Pos)
- #define CoreDebug\_DHCSR\_S\_SLEEP\_Pos 18

- #define CoreDebug\_DHCSR\_S\_SLEEP\_Msk (1UL << CoreDebug\_DHCSR\_S\_SLEEP\_Pos)
- #define CoreDebug\_DHCSR\_S\_HALT\_Pos 17
- #define CoreDebug\_DHCSR\_S\_HALT\_Msk (1UL << CoreDebug\_DHCSR\_S\_HALT\_Pos)
- #define CoreDebug\_DHCSR\_S\_REGRDY\_Pos 16
- #define CoreDebug\_DHCSR\_S\_REGRDY\_Msk (1UL << CoreDebug\_DHCSR\_S\_REGRDY\_Pos)
- #define CoreDebug\_DHCSR\_C\_SNAPSTALL\_Pos 5
- #define CoreDebug\_DHCSR\_C\_SNAPSTALL\_Msk (1UL << CoreDebug\_DHCSR\_C\_SNAPSTALL\_Pos)
- #define CoreDebug\_DHCSR\_C\_MASKINTS\_Pos 3
- #define CoreDebug\_DHCSR\_C\_MASKINTS\_Msk (1UL << CoreDebug\_DHCSR\_C\_MASKINTS\_Pos)
- #define CoreDebug\_DHCSR\_C\_STEP\_Pos 2
- #define CoreDebug\_DHCSR\_C\_STEP\_Msk (1UL << CoreDebug\_DHCSR\_C\_STEP\_Pos)
- #define CoreDebug\_DHCSR\_C\_HALT\_Pos 1
- #define CoreDebug\_DHCSR\_C\_HALT\_Msk (1UL << CoreDebug\_DHCSR\_C\_HALT\_Pos)
- #define CoreDebug\_DHCSR\_C\_DEBUGEN\_Pos 0
- #define CoreDebug\_DHCSR\_C\_DEBUGEN\_Msk (1UL /\*<< CoreDebug\_DHCSR\_C\_DEBUGEN\_Pos\*/)
- #define CoreDebug\_DCRSR\_REGWnR\_Pos 16
- #define CoreDebug\_DCRSR\_REGWnR\_Msk (1UL << CoreDebug\_DCRSR\_REGWnR\_Pos)
- #define CoreDebug\_DCRSR\_REGSEL\_Pos 0
- #define CoreDebug\_DCRSR\_REGSEL\_Msk (0x1FUL /\*<< CoreDebug\_DCRSR\_REGSEL\_Pos\*/)
- #define CoreDebug\_DEMCR\_TRCENA\_Pos 24
- #define CoreDebug\_DEMCR\_TRCENA\_Msk (1UL << CoreDebug\_DEMCR\_TRCENA\_Pos)
- #define CoreDebug\_DEMCR\_MON\_REQ\_Pos 19
- #define CoreDebug\_DEMCR\_MON\_REQ\_Msk (1UL << CoreDebug\_DEMCR\_MON\_REQ\_Pos)
- #define CoreDebug\_DEMCR\_MON\_STEP\_Pos 18
- #define CoreDebug\_DEMCR\_MON\_STEP\_Msk (1UL << CoreDebug\_DEMCR\_MON\_STEP\_Pos)
- #define CoreDebug\_DEMCR\_MON\_PEND\_Pos 17
- #define CoreDebug\_DEMCR\_MON\_PEND\_Msk (1UL << CoreDebug\_DEMCR\_MON\_PEND\_Pos)
- #define CoreDebug\_DEMCR\_MON\_EN\_Pos 16
- #define CoreDebug\_DEMCR\_MON\_EN\_Msk (1UL << CoreDebug\_DEMCR\_MON\_EN\_Pos)
- #define CoreDebug\_DEMCR\_VC\_HARDERR\_Pos 10
- #define CoreDebug\_DEMCR\_VC\_HARDERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_HARDERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_INTERR\_Pos 9
- #define CoreDebug\_DEMCR\_VC\_INTERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_INTERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_BUSERR\_Pos 8
- #define CoreDebug\_DEMCR\_VC\_BUSERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_BUSERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_STATERR\_Pos 7
- #define CoreDebug\_DEMCR\_VC\_STATERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_STATERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_CHKERR\_Pos 6
- #define CoreDebug\_DEMCR\_VC\_CHKERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_CHKERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos 5
- #define CoreDebug\_DEMCR\_VC\_NOCPERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_MMERR\_Pos 4
- #define CoreDebug\_DEMCR\_VC\_MMERR\_Msk (1UL << CoreDebug\_DEMCR\_VC\_MMERR\_Pos)
- #define CoreDebug\_DEMCR\_VC\_CORERESET\_Pos 0
- #define CoreDebug\_DEMCR\_VC\_CORERESET\_Msk (1UL /\*<< CoreDebug\_DEMCR\_VC\_CORERESET\_Pos\*/)
- #define SCS\_BASE (0xE000E000UL)
- #define ITM\_BASE (0xE0000000UL)
- #define DWT\_BASE (0xE0001000UL)
- #define TPI\_BASE (0xE0040000UL)
- #define CoreDebug\_BASE (0xE000EDF0UL)
- #define SysTick\_BASE (SCS\_BASE + 0x0010UL)
- #define NVIC\_BASE (SCS\_BASE + 0x0100UL)
- #define SCB\_BASE (SCS\_BASE + 0x0D00UL)
- #define SCnSCB ((SCnSCB\_Type \*) SCS\_BASE )
- #define SCB ((SCB\_Type \*) SCB\_BASE )

- #define SysTick ((SysTick\_Type \*) SysTick\_BASE )
- #define NVIC ((NVIC\_Type \*) NVIC\_BASE )
- #define ITM ((ITM\_Type \*) ITM\_BASE )
- #define DWT ((DWT\_Type \*) DWT\_BASE )
- #define TPI ((TPI\_Type \*) TPI\_BASE )
- #define CoreDebug ((CoreDebug\_Type \*) CoreDebug\_BASE)
- #define ITM\_RXBUFFER\_EMPTY 0x5AA55AA5
- volatile int32\_t ITM\_RxBuffer
- \_\_STATIC\_INLINE void NVIC\_SetPriorityGrouping (uint32\_t PriorityGroup)  
*Set Priority Grouping.*
- \_\_STATIC\_INLINE uint32\_t NVIC\_GetPriorityGrouping (void)  
*Get Priority Grouping.*
- \_\_STATIC\_INLINE void NVIC\_EnableIRQ (IRQn\_Type IRQn)  
*Enable External Interrupt.*
- \_\_STATIC\_INLINE void NVIC\_DisableIRQ (IRQn\_Type IRQn)  
*Disable External Interrupt.*
- \_\_STATIC\_INLINE uint32\_t NVIC\_GetPendingIRQ (IRQn\_Type IRQn)  
*Get Pending Interrupt.*
- \_\_STATIC\_INLINE void NVIC\_SetPendingIRQ (IRQn\_Type IRQn)  
*Set Pending Interrupt.*
- \_\_STATIC\_INLINE void NVIC\_ClearPendingIRQ (IRQn\_Type IRQn)  
*Clear Pending Interrupt.*
- \_\_STATIC\_INLINE uint32\_t NVIC\_GetActive (IRQn\_Type IRQn)  
*Get Active Interrupt.*
- \_\_STATIC\_INLINE void NVIC\_SetPriority (IRQn\_Type IRQn, uint32\_t priority)  
*Set Interrupt Priority.*
- \_\_STATIC\_INLINE uint32\_t NVIC\_GetPriority (IRQn\_Type IRQn)  
*Get Interrupt Priority.*
- \_\_STATIC\_INLINE uint32\_t NVIC\_EncodePriority (uint32\_t PriorityGroup, uint32\_t PreemptPriority, uint32\_t SubPriority)  
*Encode Priority.*
- \_\_STATIC\_INLINE void NVIC\_DecodePriority (uint32\_t Priority, uint32\_t PriorityGroup, uint32\_t \*pPreempt←Priority, uint32\_t \*pSubPriority)  
*Decode Priority.*
- \_\_STATIC\_INLINE void NVIC\_SystemReset (void)  
*System Reset.*
- \_\_STATIC\_INLINE uint32\_t SysTick\_Config (uint32\_t ticks)  
*System Tick Configuration.*
- \_\_STATIC\_INLINE uint32\_t ITM\_SendChar (uint32\_t ch)  
*ITM Send Character.*
- \_\_STATIC\_INLINE int32\_t ITM\_ReceiveChar (void)  
*ITM Receive Character.*
- \_\_STATIC\_INLINE int32\_t ITM\_CheckChar (void)  
*ITM Check Character.*

### 7.9.1 Detailed Description

CMSIS Cortex-M4 Core Peripheral Access Layer Header File.

Version

V4.10

Date

18. March 2015

Note

## 7.10 CMSIS/Inc/core\_cmFunc.h File Reference

CMSIS Cortex-M Core Function Access Header File.

This graph shows which files directly or indirectly include this file:



### 7.10.1 Detailed Description

CMSIS Cortex-M Core Function Access Header File.

Version

V4.10

Date

18. March 2015

Note

## 7.11 CMSIS/Inc/core\_cmlInstr.h File Reference

CMSIS Cortex-M Core Instruction Access Header File.

This graph shows which files directly or indirectly include this file:



### 7.11.1 Detailed Description

CMSIS Cortex-M Core Instruction Access Header File.

#### Version

V4.10

#### Date

18. March 2015

#### Note

## 7.12 CMSIS/Inc/core\_cmSimd.h File Reference

CMSIS Cortex-M SIMD Header File.

This graph shows which files directly or indirectly include this file:



### 7.12.1 Detailed Description

CMSIS Cortex-M SIMD Header File.

Version

V4.10

Date

18. March 2015

Note

## 7.13 CMSIS/Inc/stm32f4xx.h File Reference

CMSIS Cortex-M4 Device Peripheral Access Layer Header File. This file contains all the peripheral register's definitions, bits definitions and memory mapping for STM32F4xx devices.

```
#include "core_cm4.h"
#include "system_stm32f4xx.h"
#include <stdint.h>
Include dependency graph for stm32f4xx.h:
```



This graph shows which files directly or indirectly include this file:



### Classes

- struct [ADC\\_TypeDef](#)  
*Analog to Digital Converter*
- struct [ADC\\_Common\\_TypeDef](#)
- struct [CAN\\_TxMailBox\\_TypeDef](#)  
*Controller Area Network TxMailBox.*
- struct [CAN\\_FIFOMailBox\\_TypeDef](#)  
*Controller Area Network FIFO MailBox.*
- struct [CAN\\_FilterRegister\\_TypeDef](#)

- struct [CAN\\_TypeDef](#)  
*Controller Area Network FilterRegister.*
- struct [CRC\\_TypeDef](#)  
*CRC calculation unit.*
- struct [DAC\\_TypeDef](#)  
*Digital to Analog Converter.*
- struct [DBGMCU\\_TypeDef](#)  
*Debug MCU.*
- struct [DCMI\\_TypeDef](#)  
*DCMI.*
- struct [DMA\\_Stream\\_TypeDef](#)  
*DMA Controller.*
- struct [DMA\\_TypeDef](#)
- struct [DMA2D\\_TypeDef](#)  
*DMA2D Controller.*
- struct [ETH\\_TypeDef](#)  
*Ethernet MAC.*
- struct [EXTI\\_TypeDef](#)  
*External Interrupt/Event Controller.*
- struct [FLASH\\_TypeDef](#)  
*FLASH Registers.*
- struct [GPIO\\_TypeDef](#)  
*General Purpose I/O.*
- struct [SYSCFG\\_TypeDef](#)  
*System configuration controller.*
- struct [I2C\\_TypeDef](#)  
*Inter-integrated Circuit Interface.*
- struct [IWDG\\_TypeDef](#)  
*Independent WATCHDOG.*
- struct [LTDC\\_TypeDef](#)  
*LCD-TFT Display Controller.*
- struct [LTDC\\_Layer\\_TypeDef](#)  
*LCD-TFT Display layer x Controller.*
- struct [PWR\\_TypeDef](#)  
*Power Control.*
- struct [RCC\\_TypeDef](#)  
*Reset and Clock Control.*
- struct [RTC\\_TypeDef](#)  
*Real-Time Clock.*
- struct [SAI\\_TypeDef](#)  
*Serial Audio Interface.*
- struct [SAI\\_Block\\_TypeDef](#)
- struct [SDIO\\_TypeDef](#)  
*SD host Interface.*
- struct [SPI\\_TypeDef](#)  
*Serial Peripheral Interface.*
- struct [TIM\\_TypeDef](#)  
*TIM.*
- struct [USART\\_TypeDef](#)  
*Universal Synchronous Asynchronous Receiver Transmitter.*

- struct [WWDG\\_TypeDef](#)  
*Window WATCHDOG.*
- struct [CRYP\\_TypeDef](#)  
*Crypto Processor.*
- struct [HASH\\_TypeDef](#)  
*HASH.*
- struct [HASH\\_DIGEST\\_TypeDef](#)  
*HASH\_DIGEST.*
- struct [RNG\\_TypeDef](#)  
*RNG.*

## Macros

- #define **STM32F401xx**
- #define **HSE\_VALUE** ((uint32\_t)25000000)  
*Comment the line below if you will not use the peripherals drivers. In this case, these drivers will not be included and the application code will be based on direct access to peripherals registers.*
- #define **HSE\_STARTUP\_TIMEOUT** ((uint16\_t)0x05000)  
*In the following line adjust the External High Speed oscillator (HSE) Startup Timeout value.*
- #define **HSI\_VALUE** ((uint32\_t)16000000)
- #define **\_STM32F4XX\_STDPERIPH\_VERSION\_MAIN** (0x01)  
*STM32F4XX Standard Peripherals Library version number V1.8.0.*
- #define **\_STM32F4XX\_STDPERIPH\_VERSION\_SUB1** (0x08)
- #define **\_STM32F4XX\_STDPERIPH\_VERSION\_SUB2** (0x00)
- #define **\_STM32F4XX\_STDPERIPH\_VERSION\_RC** (0x00)
- #define **\_STM32F4XX\_STDPERIPH\_VERSION**
- #define **\_CM4\_REV** 0x0001  
*Configuration of the Cortex-M4 Processor and Core Peripherals.*
- #define **\_MPU\_PRESENT** 1
- #define **\_NVIC\_PRIO\_BITS** 4
- #define **\_Vendor\_SysTickConfig** 0
- #define **\_FPU\_PRESENT** 1
- #define **IS\_FUNCTIONAL\_STATE**(STATE) (((STATE) == **DISABLE**) || ((STATE) == **ENABLE**))
- #define **FLASH\_BASE** ((uint32\_t)0x08000000)
- #define **CCMDATARAM\_BASE** ((uint32\_t)0x10000000)
- #define **SRAM1\_BASE** ((uint32\_t)0x20000000)
- #define **PERIPH\_BASE** ((uint32\_t)0x40000000)
- #define **BKPSRAM\_BASE** ((uint32\_t)0x40024000)
- #define **CCMDATARAM\_BB\_BASE** ((uint32\_t)0x12000000)
- #define **SRAM1\_BB\_BASE** ((uint32\_t)0x22000000)
- #define **PERIPH\_BB\_BASE** ((uint32\_t)0x42000000)
- #define **BKPSRAM\_BB\_BASE** ((uint32\_t)0x42480000)
- #define **SRAM\_BASE** **SRAM1\_BASE**
- #define **SRAM\_BB\_BASE** **SRAM1\_BB\_BASE**
- #define **APB1PERIPH\_BASE** **PERIPH\_BASE**
- #define **APB2PERIPH\_BASE** (**PERIPH\_BASE** + 0x00010000)
- #define **AHB1PERIPH\_BASE** (**PERIPH\_BASE** + 0x00020000)
- #define **AHB2PERIPH\_BASE** (**PERIPH\_BASE** + 0x10000000)
- #define **TIM2\_BASE** (**APB1PERIPH\_BASE** + 0x0000)
- #define **TIM3\_BASE** (**APB1PERIPH\_BASE** + 0x0400)
- #define **TIM4\_BASE** (**APB1PERIPH\_BASE** + 0x0800)
- #define **TIM5\_BASE** (**APB1PERIPH\_BASE** + 0x0C00)

- #define **TIM6\_BASE** (APB1PERIPH\_BASE + 0x1000)
- #define **TIM7\_BASE** (APB1PERIPH\_BASE + 0x1400)
- #define **TIM12\_BASE** (APB1PERIPH\_BASE + 0x1800)
- #define **TIM13\_BASE** (APB1PERIPH\_BASE + 0x1C00)
- #define **TIM14\_BASE** (APB1PERIPH\_BASE + 0x2000)
- #define **RTC\_BASE** (APB1PERIPH\_BASE + 0x2800)
- #define **WWDG\_BASE** (APB1PERIPH\_BASE + 0x2C00)
- #define **IWDG\_BASE** (APB1PERIPH\_BASE + 0x3000)
- #define **I2S2ext\_BASE** (APB1PERIPH\_BASE + 0x3400)
- #define **SPI2\_BASE** (APB1PERIPH\_BASE + 0x3800)
- #define **SPI3\_BASE** (APB1PERIPH\_BASE + 0x3C00)
- #define **I2S3ext\_BASE** (APB1PERIPH\_BASE + 0x4000)
- #define **USART2\_BASE** (APB1PERIPH\_BASE + 0x4400)
- #define **USART3\_BASE** (APB1PERIPH\_BASE + 0x4800)
- #define **UART4\_BASE** (APB1PERIPH\_BASE + 0x4C00)
- #define **UART5\_BASE** (APB1PERIPH\_BASE + 0x5000)
- #define **I2C1\_BASE** (APB1PERIPH\_BASE + 0x5400)
- #define **I2C2\_BASE** (APB1PERIPH\_BASE + 0x5800)
- #define **I2C3\_BASE** (APB1PERIPH\_BASE + 0x5C00)
- #define **CAN1\_BASE** (APB1PERIPH\_BASE + 0x6400)
- #define **CAN2\_BASE** (APB1PERIPH\_BASE + 0x6800)
- #define **PWR\_BASE** (APB1PERIPH\_BASE + 0x7000)
- #define **DAC\_BASE** (APB1PERIPH\_BASE + 0x7400)
- #define **UART7\_BASE** (APB1PERIPH\_BASE + 0x7800)
- #define **UART8\_BASE** (APB1PERIPH\_BASE + 0x7C00)
- #define **TIM1\_BASE** (APB2PERIPH\_BASE + 0x0000)
- #define **TIM8\_BASE** (APB2PERIPH\_BASE + 0x0400)
- #define **USART1\_BASE** (APB2PERIPH\_BASE + 0x1000)
- #define **USART6\_BASE** (APB2PERIPH\_BASE + 0x1400)
- #define **UART9\_BASE** (APB2PERIPH\_BASE + 0x1800U)
- #define **UART10\_BASE** (APB2PERIPH\_BASE + 0x1C00U)
- #define **ADC1\_BASE** (APB2PERIPH\_BASE + 0x2000)
- #define **ADC2\_BASE** (APB2PERIPH\_BASE + 0x2100)
- #define **ADC3\_BASE** (APB2PERIPH\_BASE + 0x2200)
- #define **ADC\_BASE** (APB2PERIPH\_BASE + 0x2300)
- #define **SDIO\_BASE** (APB2PERIPH\_BASE + 0x2C00)
- #define **SPI1\_BASE** (APB2PERIPH\_BASE + 0x3000)
- #define **SPI4\_BASE** (APB2PERIPH\_BASE + 0x3400)
- #define **SYSCFG\_BASE** (APB2PERIPH\_BASE + 0x3800)
- #define **EXTI\_BASE** (APB2PERIPH\_BASE + 0x3C00)
- #define **TIM9\_BASE** (APB2PERIPH\_BASE + 0x4000)
- #define **TIM10\_BASE** (APB2PERIPH\_BASE + 0x4400)
- #define **TIM11\_BASE** (APB2PERIPH\_BASE + 0x4800)
- #define **SPI5\_BASE** (APB2PERIPH\_BASE + 0x5000)
- #define **SPI6\_BASE** (APB2PERIPH\_BASE + 0x5400)
- #define **SAI1\_BASE** (APB2PERIPH\_BASE + 0x5800)
- #define **SAI1\_Block\_A\_BASE** (SAI1\_BASE + 0x004)
- #define **SAI1\_Block\_B\_BASE** (SAI1\_BASE + 0x024)
- #define **LTDC\_BASE** (APB2PERIPH\_BASE + 0x6800)
- #define **LTDC\_Layer1\_BASE** (LTDC\_BASE + 0x84)
- #define **LTDC\_Layer2\_BASE** (LTDC\_BASE + 0x104)
- #define **GPIOA\_BASE** (AHB1PERIPH\_BASE + 0x0000)
- #define **GPIOB\_BASE** (AHB1PERIPH\_BASE + 0x0400)
- #define **GPIOC\_BASE** (AHB1PERIPH\_BASE + 0x0800)
- #define **GPIOD\_BASE** (AHB1PERIPH\_BASE + 0x0C00)

- #define **GPIOE\_BASE** (AHB1PERIPH\_BASE + 0x1000)
- #define **GPIOF\_BASE** (AHB1PERIPH\_BASE + 0x1400)
- #define **GPIOG\_BASE** (AHB1PERIPH\_BASE + 0x1800)
- #define **GPIOH\_BASE** (AHB1PERIPH\_BASE + 0x1C00)
- #define **GPIOI\_BASE** (AHB1PERIPH\_BASE + 0x2000)
- #define **GPIOJ\_BASE** (AHB1PERIPH\_BASE + 0x2400)
- #define **GPIOK\_BASE** (AHB1PERIPH\_BASE + 0x2800)
- #define **CRC\_BASE** (AHB1PERIPH\_BASE + 0x3000)
- #define **RCC\_BASE** (AHB1PERIPH\_BASE + 0x3800)
- #define **FLASH\_R\_BASE** (AHB1PERIPH\_BASE + 0x3C00)
- #define **DMA1\_BASE** (AHB1PERIPH\_BASE + 0x6000)
- #define **DMA1\_Stream0\_BASE** (DMA1\_BASE + 0x010)
- #define **DMA1\_Stream1\_BASE** (DMA1\_BASE + 0x028)
- #define **DMA1\_Stream2\_BASE** (DMA1\_BASE + 0x040)
- #define **DMA1\_Stream3\_BASE** (DMA1\_BASE + 0x058)
- #define **DMA1\_Stream4\_BASE** (DMA1\_BASE + 0x070)
- #define **DMA1\_Stream5\_BASE** (DMA1\_BASE + 0x088)
- #define **DMA1\_Stream6\_BASE** (DMA1\_BASE + 0x0A0)
- #define **DMA1\_Stream7\_BASE** (DMA1\_BASE + 0x0B8)
- #define **DMA2\_BASE** (AHB1PERIPH\_BASE + 0x6400)
- #define **DMA2\_Stream0\_BASE** (DMA2\_BASE + 0x010)
- #define **DMA2\_Stream1\_BASE** (DMA2\_BASE + 0x028)
- #define **DMA2\_Stream2\_BASE** (DMA2\_BASE + 0x040)
- #define **DMA2\_Stream3\_BASE** (DMA2\_BASE + 0x058)
- #define **DMA2\_Stream4\_BASE** (DMA2\_BASE + 0x070)
- #define **DMA2\_Stream5\_BASE** (DMA2\_BASE + 0x088)
- #define **DMA2\_Stream6\_BASE** (DMA2\_BASE + 0x0A0)
- #define **DMA2\_Stream7\_BASE** (DMA2\_BASE + 0x0B8)
- #define **ETH\_BASE** (AHB1PERIPH\_BASE + 0x8000)
- #define **ETH\_MAC\_BASE** (ETH\_BASE)
- #define **ETH\_MMC\_BASE** (ETH\_BASE + 0x0100)
- #define **ETH\_PTP\_BASE** (ETH\_BASE + 0x0700)
- #define **ETH\_DMA\_BASE** (ETH\_BASE + 0x1000)
- #define **DMA2D\_BASE** (AHB1PERIPH\_BASE + 0xB000)
- #define **DCMI\_BASE** (AHB2PERIPH\_BASE + 0x50000)
- #define **CRYP\_BASE** (AHB2PERIPH\_BASE + 0x60000)
- #define **HASH\_BASE** (AHB2PERIPH\_BASE + 0x60400)
- #define **HASH\_DIGEST\_BASE** (AHB2PERIPH\_BASE + 0x60710)
- #define **RNG\_BASE** (AHB2PERIPH\_BASE + 0x60800)
- #define **DBGMCU\_BASE** ((uint32\_t )0xE0042000)
- #define **TIM2** ((TIM\_TypeDef \*) **TIM2\_BASE**)
- #define **TIM3** ((TIM\_TypeDef \*) TIM3\_BASE)
- #define **TIM4** ((TIM\_TypeDef \*) TIM4\_BASE)
- #define **TIM5** ((TIM\_TypeDef \*) TIM5\_BASE)
- #define **TIM6** ((TIM\_TypeDef \*) TIM6\_BASE)
- #define **TIM7** ((TIM\_TypeDef \*) TIM7\_BASE)
- #define **TIM12** ((TIM\_TypeDef \*) TIM12\_BASE)
- #define **TIM13** ((TIM\_TypeDef \*) TIM13\_BASE)
- #define **TIM14** ((TIM\_TypeDef \*) TIM14\_BASE)
- #define **RTC** ((RTC\_TypeDef \*) RTC\_BASE)
- #define **WWDG** ((WWDG\_TypeDef \*) WWDG\_BASE)
- #define **IWDG** ((IWDG\_TypeDef \*) IWDG\_BASE)
- #define **I2S2ext** ((SPI\_TypeDef \*) I2S2ext\_BASE)
- #define **SPI2** ((SPI\_TypeDef \*) **SPI2\_BASE**)
- #define **SPI3** ((SPI\_TypeDef \*) SPI3\_BASE)

```
• #define I2S3ext ((SPI_TypeDef *) I2S3ext_BASE)
• #define USART2 ((USART_TypeDef *) USART2_BASE)
• #define USART3 ((USART_TypeDef *) USART3_BASE)
• #define UART4 ((USART_TypeDef *) UART4_BASE)
• #define UART5 ((USART_TypeDef *) UART5_BASE)
• #define I2C1 ((I2C_TypeDef *) I2C1_BASE)
• #define I2C2 ((I2C_TypeDef *) I2C2_BASE)
• #define I2C3 ((I2C_TypeDef *) I2C3_BASE)
• #define CAN1 ((CAN_TypeDef *) CAN1_BASE)
• #define CAN2 ((CAN_TypeDef *) CAN2_BASE)
• #define PWR ((PWR_TypeDef *) PWR_BASE)
• #define DAC ((DAC_TypeDef *) DAC_BASE)
• #define UART7 ((USART_TypeDef *) UART7_BASE)
• #define UART8 ((USART_TypeDef *) UART8_BASE)
• #define UART9 ((USART_TypeDef *) UART9_BASE)
• #define UART10 ((USART_TypeDef *) UART10_BASE)
• #define TIM1 ((TIM_TypeDef *) TIM1_BASE)
• #define TIM8 ((TIM_TypeDef *) TIM8_BASE)
• #define USART1 ((USART_TypeDef *) USART1_BASE)
• #define USART6 ((USART_TypeDef *) USART6_BASE)
• #define ADC ((ADC_Common_TypeDef *) ADC_BASE)
• #define ADC1 ((ADC_TypeDef *) ADC1_BASE)
• #define ADC2 ((ADC_TypeDef *) ADC2_BASE)
• #define ADC3 ((ADC_TypeDef *) ADC3_BASE)
• #define SDIO ((SDIO_TypeDef *) SDIO_BASE)
• #define SPI1 ((SPI_TypeDef *) SPI1_BASE)
• #define SPI4 ((SPI_TypeDef *) SPI4_BASE)
• #define SYSCFG ((SYSCFG_TypeDef *) SYSCFG_BASE)
• #define EXTI ((EXTI_TypeDef *) EXTI_BASE)
• #define TIM9 ((TIM_TypeDef *) TIM9_BASE)
• #define TIM10 ((TIM_TypeDef *) TIM10_BASE)
• #define TIM11 ((TIM_TypeDef *) TIM11_BASE)
• #define SPI5 ((SPI_TypeDef *) SPI5_BASE)
• #define SPI6 ((SPI_TypeDef *) SPI6_BASE)
• #define SAI1 ((SAI_TypeDef *) SAI1_BASE)
• #define SAI1_Block_A ((SAI_Block_TypeDef *) SAI1_Block_A_BASE)
• #define SAI1_Block_B ((SAI_Block_TypeDef *) SAI1_Block_B_BASE)
• #define LTDC ((LTDC_TypeDef *) LTDC_BASE)
• #define LTDC_Layer1 ((LTDC_Layer_TypeDef *) LTDC_Layer1_BASE)
• #define LTDC_Layer2 ((LTDC_Layer_TypeDef *) LTDC_Layer2_BASE)
• #define GPIOA ((GPIO_TypeDef *) GPIOA_BASE)
• #define GPIOB ((GPIO_TypeDef *) GPIOB_BASE)
• #define GPIOC ((GPIO_TypeDef *) GPIOC_BASE)
• #define GPIOD ((GPIO_TypeDef *) GPIOD_BASE)
• #define GPIOE ((GPIO_TypeDef *) GPIOE_BASE)
• #define GPIOF ((GPIO_TypeDef *) GPIOF_BASE)
• #define GPIOG ((GPIO_TypeDef *) GPIOG_BASE)
• #define GPIOH ((GPIO_TypeDef *) GPIOH_BASE)
• #define GPIOI ((GPIO_TypeDef *) GPIOI_BASE)
• #define GPIOJ ((GPIO_TypeDef *) GPIOJ_BASE)
• #define GPIOK ((GPIO_TypeDef *) GPIOK_BASE)
• #define CRC ((CRC_TypeDef *) CRC_BASE)
• #define RCC ((RCC_TypeDef *) RCC_BASE)
• #define FLASH ((FLASH_TypeDef *) FLASH_R_BASE)
• #define DMA1 ((DMA_TypeDef *) DMA1_BASE)
```

- #define **DMA1\_Stream0** ((DMA\_Stream\_TypeDef \*) DMA1\_Stream0\_BASE)
- #define **DMA1\_Stream1** ((DMA\_Stream\_TypeDef \*) DMA1\_Stream1\_BASE)
- #define **DMA1\_Stream2** ((DMA\_Stream\_TypeDef \*) DMA1\_Stream2\_BASE)
- #define **DMA1\_Stream3** ((DMA\_Stream\_TypeDef \*) DMA1\_Stream3\_BASE)
- #define **DMA1\_Stream4** ((DMA\_Stream\_TypeDef \*) DMA1\_Stream4\_BASE)
- #define **DMA1\_Stream5** ((DMA\_Stream\_TypeDef \*) DMA1\_Stream5\_BASE)
- #define **DMA1\_Stream6** ((DMA\_Stream\_TypeDef \*) DMA1\_Stream6\_BASE)
- #define **DMA1\_Stream7** ((DMA\_Stream\_TypeDef \*) DMA1\_Stream7\_BASE)
- #define **DMA2** ((DMA\_TypeDef \*) DMA2\_BASE)
- #define **DMA2\_Stream0** ((DMA\_Stream\_TypeDef \*) DMA2\_Stream0\_BASE)
- #define **DMA2\_Stream1** ((DMA\_Stream\_TypeDef \*) DMA2\_Stream1\_BASE)
- #define **DMA2\_Stream2** ((DMA\_Stream\_TypeDef \*) DMA2\_Stream2\_BASE)
- #define **DMA2\_Stream3** ((DMA\_Stream\_TypeDef \*) DMA2\_Stream3\_BASE)
- #define **DMA2\_Stream4** ((DMA\_Stream\_TypeDef \*) DMA2\_Stream4\_BASE)
- #define **DMA2\_Stream5** ((DMA\_Stream\_TypeDef \*) DMA2\_Stream5\_BASE)
- #define **DMA2\_Stream6** ((DMA\_Stream\_TypeDef \*) DMA2\_Stream6\_BASE)
- #define **DMA2\_Stream7** ((DMA\_Stream\_TypeDef \*) DMA2\_Stream7\_BASE)
- #define **ETH** ((ETH\_TypeDef \*) ETH\_BASE)
- #define **DMA2D** ((DMA2D\_TypeDef \*) DMA2D\_BASE)
- #define **DCMI** ((DCMI\_TypeDef \*) DCMI\_BASE)
- #define **CRYP** ((CRYP\_TypeDef \*) CRYP\_BASE)
- #define **HASH** ((HASH\_TypeDef \*) HASH\_BASE)
- #define **HASH\_DIGEST** ((HASH\_DIGEST\_TypeDef \*) HASH\_DIGEST\_BASE)
- #define **RNG** ((RNG\_TypeDef \*) RNG\_BASE)
- #define **DBGMCU** ((DBGMCU\_TypeDef \*) DBGMCU\_BASE)
- #define **ADC\_SR\_AWD** ((uint8\_t)0x01)
- #define **ADC\_SR\_EOC** ((uint8\_t)0x02)
- #define **ADC\_SR\_JEOC** ((uint8\_t)0x04)
- #define **ADC\_SR\_JSTRT** ((uint8\_t)0x08)
- #define **ADC\_SR\_STRT** ((uint8\_t)0x10)
- #define **ADC\_SR\_OVR** ((uint8\_t)0x20)
- #define **ADC\_CR1\_AWDCH** ((uint32\_t)0x00000001F)
- #define **ADC\_CR1\_AWDCH\_0** ((uint32\_t)0x000000001)
- #define **ADC\_CR1\_AWDCH\_1** ((uint32\_t)0x000000002)
- #define **ADC\_CR1\_AWDCH\_2** ((uint32\_t)0x000000004)
- #define **ADC\_CR1\_AWDCH\_3** ((uint32\_t)0x000000008)
- #define **ADC\_CR1\_AWDCH\_4** ((uint32\_t)0x000000010)
- #define **ADC\_CR1\_EOCIE** ((uint32\_t)0x000000020)
- #define **ADC\_CR1\_AWDIE** ((uint32\_t)0x000000040)
- #define **ADC\_CR1\_JEOCIE** ((uint32\_t)0x000000080)
- #define **ADC\_CR1\_SCAN** ((uint32\_t)0x000000100)
- #define **ADC\_CR1\_AWDSGL** ((uint32\_t)0x000000200)
- #define **ADC\_CR1\_JAUTO** ((uint32\_t)0x000000400)
- #define **ADC\_CR1\_DISCEN** ((uint32\_t)0x000000800)
- #define **ADC\_CR1\_JDISCEN** ((uint32\_t)0x00001000)
- #define **ADC\_CR1\_DISCNUM** ((uint32\_t)0x0000E000)
- #define **ADC\_CR1\_DISCNUM\_0** ((uint32\_t)0x00002000)
- #define **ADC\_CR1\_DISCNUM\_1** ((uint32\_t)0x00004000)
- #define **ADC\_CR1\_DISCNUM\_2** ((uint32\_t)0x00008000)
- #define **ADC\_CR1\_JAWDEN** ((uint32\_t)0x00400000)
- #define **ADC\_CR1\_AWDEN** ((uint32\_t)0x00800000)
- #define **ADC\_CR1\_RES** ((uint32\_t)0x03000000)
- #define **ADC\_CR1\_RES\_0** ((uint32\_t)0x01000000)
- #define **ADC\_CR1\_RES\_1** ((uint32\_t)0x02000000)
- #define **ADC\_CR1\_OVRIE** ((uint32\_t)0x04000000)

- #define ADC\_CR2\_ADON ((uint32\_t)0x00000001)
- #define ADC\_CR2\_CONT ((uint32\_t)0x00000002)
- #define ADC\_CR2\_DMA ((uint32\_t)0x00000100)
- #define ADC\_CR2\_DDS ((uint32\_t)0x00000200)
- #define ADC\_CR2\_EOCS ((uint32\_t)0x00000400)
- #define ADC\_CR2\_ALIGN ((uint32\_t)0x00000800)
- #define ADC\_CR2\_JEXTSEL ((uint32\_t)0x000F0000)
- #define ADC\_CR2\_JEXTSEL\_0 ((uint32\_t)0x00010000)
- #define ADC\_CR2\_JEXTSEL\_1 ((uint32\_t)0x00020000)
- #define ADC\_CR2\_JEXTSEL\_2 ((uint32\_t)0x00040000)
- #define ADC\_CR2\_JEXTSEL\_3 ((uint32\_t)0x00080000)
- #define ADC\_CR2\_JEXTEN ((uint32\_t)0x00300000)
- #define ADC\_CR2\_JEXTEN\_0 ((uint32\_t)0x00100000)
- #define ADC\_CR2\_JEXTEN\_1 ((uint32\_t)0x00200000)
- #define ADC\_CR2\_JSWSTART ((uint32\_t)0x00400000)
- #define ADC\_CR2\_EXTSEL ((uint32\_t)0x0F000000)
- #define ADC\_CR2\_EXTSEL\_0 ((uint32\_t)0x01000000)
- #define ADC\_CR2\_EXTSEL\_1 ((uint32\_t)0x02000000)
- #define ADC\_CR2\_EXTSEL\_2 ((uint32\_t)0x04000000)
- #define ADC\_CR2\_EXTSEL\_3 ((uint32\_t)0x08000000)
- #define ADC\_CR2\_EXTEN ((uint32\_t)0x30000000)
- #define ADC\_CR2\_EXTEN\_0 ((uint32\_t)0x10000000)
- #define ADC\_CR2\_EXTEN\_1 ((uint32\_t)0x20000000)
- #define ADC\_CR2\_SWSTART ((uint32\_t)0x40000000)
- #define ADC\_SMPR1\_SMP10 ((uint32\_t)0x00000007)
- #define ADC\_SMPR1\_SMP10\_0 ((uint32\_t)0x00000001)
- #define ADC\_SMPR1\_SMP10\_1 ((uint32\_t)0x00000002)
- #define ADC\_SMPR1\_SMP10\_2 ((uint32\_t)0x00000004)
- #define ADC\_SMPR1\_SMP11 ((uint32\_t)0x00000038)
- #define ADC\_SMPR1\_SMP11\_0 ((uint32\_t)0x00000008)
- #define ADC\_SMPR1\_SMP11\_1 ((uint32\_t)0x00000010)
- #define ADC\_SMPR1\_SMP11\_2 ((uint32\_t)0x00000020)
- #define ADC\_SMPR1\_SMP12 ((uint32\_t)0x000001C0)
- #define ADC\_SMPR1\_SMP12\_0 ((uint32\_t)0x00000040)
- #define ADC\_SMPR1\_SMP12\_1 ((uint32\_t)0x00000080)
- #define ADC\_SMPR1\_SMP12\_2 ((uint32\_t)0x00000100)
- #define ADC\_SMPR1\_SMP13 ((uint32\_t)0x00000E00)
- #define ADC\_SMPR1\_SMP13\_0 ((uint32\_t)0x00000200)
- #define ADC\_SMPR1\_SMP13\_1 ((uint32\_t)0x00000400)
- #define ADC\_SMPR1\_SMP13\_2 ((uint32\_t)0x00000800)
- #define ADC\_SMPR1\_SMP14 ((uint32\_t)0x00007000)
- #define ADC\_SMPR1\_SMP14\_0 ((uint32\_t)0x00001000)
- #define ADC\_SMPR1\_SMP14\_1 ((uint32\_t)0x00002000)
- #define ADC\_SMPR1\_SMP14\_2 ((uint32\_t)0x00004000)
- #define ADC\_SMPR1\_SMP15 ((uint32\_t)0x00038000)
- #define ADC\_SMPR1\_SMP15\_0 ((uint32\_t)0x00008000)
- #define ADC\_SMPR1\_SMP15\_1 ((uint32\_t)0x00010000)
- #define ADC\_SMPR1\_SMP15\_2 ((uint32\_t)0x00020000)
- #define ADC\_SMPR1\_SMP16 ((uint32\_t)0x001C0000)
- #define ADC\_SMPR1\_SMP16\_0 ((uint32\_t)0x00040000)
- #define ADC\_SMPR1\_SMP16\_1 ((uint32\_t)0x00080000)
- #define ADC\_SMPR1\_SMP16\_2 ((uint32\_t)0x00100000)
- #define ADC\_SMPR1\_SMP17 ((uint32\_t)0x00E00000)
- #define ADC\_SMPR1\_SMP17\_0 ((uint32\_t)0x00200000)
- #define ADC\_SMPR1\_SMP17\_1 ((uint32\_t)0x00400000)

- #define ADC\_SMPR1\_SMP17\_2 ((uint32\_t)0x00800000)
- #define ADC\_SMPR1\_SMP18 ((uint32\_t)0x07000000)
- #define ADC\_SMPR1\_SMP18\_0 ((uint32\_t)0x01000000)
- #define ADC\_SMPR1\_SMP18\_1 ((uint32\_t)0x02000000)
- #define ADC\_SMPR1\_SMP18\_2 ((uint32\_t)0x04000000)
- #define ADC\_SMPR2\_SMP0 ((uint32\_t)0x00000007)
- #define ADC\_SMPR2\_SMP0\_0 ((uint32\_t)0x00000001)
- #define ADC\_SMPR2\_SMP0\_1 ((uint32\_t)0x00000002)
- #define ADC\_SMPR2\_SMP0\_2 ((uint32\_t)0x00000004)
- #define ADC\_SMPR2\_SMP1 ((uint32\_t)0x00000038)
- #define ADC\_SMPR2\_SMP1\_0 ((uint32\_t)0x00000008)
- #define ADC\_SMPR2\_SMP1\_1 ((uint32\_t)0x00000010)
- #define ADC\_SMPR2\_SMP1\_2 ((uint32\_t)0x00000020)
- #define ADC\_SMPR2\_SMP2 ((uint32\_t)0x000001C0)
- #define ADC\_SMPR2\_SMP2\_0 ((uint32\_t)0x00000040)
- #define ADC\_SMPR2\_SMP2\_1 ((uint32\_t)0x00000080)
- #define ADC\_SMPR2\_SMP2\_2 ((uint32\_t)0x00000100)
- #define ADC\_SMPR2\_SMP3 ((uint32\_t)0x00000E00)
- #define ADC\_SMPR2\_SMP3\_0 ((uint32\_t)0x00000200)
- #define ADC\_SMPR2\_SMP3\_1 ((uint32\_t)0x00000400)
- #define ADC\_SMPR2\_SMP3\_2 ((uint32\_t)0x00000800)
- #define ADC\_SMPR2\_SMP4 ((uint32\_t)0x00007000)
- #define ADC\_SMPR2\_SMP4\_0 ((uint32\_t)0x00001000)
- #define ADC\_SMPR2\_SMP4\_1 ((uint32\_t)0x00002000)
- #define ADC\_SMPR2\_SMP4\_2 ((uint32\_t)0x00004000)
- #define ADC\_SMPR2\_SMP5 ((uint32\_t)0x00038000)
- #define ADC\_SMPR2\_SMP5\_0 ((uint32\_t)0x00008000)
- #define ADC\_SMPR2\_SMP5\_1 ((uint32\_t)0x00010000)
- #define ADC\_SMPR2\_SMP5\_2 ((uint32\_t)0x00020000)
- #define ADC\_SMPR2\_SMP6 ((uint32\_t)0x001C0000)
- #define ADC\_SMPR2\_SMP6\_0 ((uint32\_t)0x00040000)
- #define ADC\_SMPR2\_SMP6\_1 ((uint32\_t)0x00080000)
- #define ADC\_SMPR2\_SMP6\_2 ((uint32\_t)0x00100000)
- #define ADC\_SMPR2\_SMP7 ((uint32\_t)0x00E00000)
- #define ADC\_SMPR2\_SMP7\_0 ((uint32\_t)0x00200000)
- #define ADC\_SMPR2\_SMP7\_1 ((uint32\_t)0x00400000)
- #define ADC\_SMPR2\_SMP7\_2 ((uint32\_t)0x00800000)
- #define ADC\_SMPR2\_SMP8 ((uint32\_t)0x07000000)
- #define ADC\_SMPR2\_SMP8\_0 ((uint32\_t)0x01000000)
- #define ADC\_SMPR2\_SMP8\_1 ((uint32\_t)0x02000000)
- #define ADC\_SMPR2\_SMP8\_2 ((uint32\_t)0x04000000)
- #define ADC\_SMPR2\_SMP9 ((uint32\_t)0x38000000)
- #define ADC\_SMPR2\_SMP9\_0 ((uint32\_t)0x08000000)
- #define ADC\_SMPR2\_SMP9\_1 ((uint32\_t)0x10000000)
- #define ADC\_SMPR2\_SMP9\_2 ((uint32\_t)0x20000000)
- #define ADC\_JOFR1\_JOFFSET1 ((uint16\_t)0xFFFF)
- #define ADC\_JOFR2\_JOFFSET2 ((uint16\_t)0xFFFF)
- #define ADC\_JOFR3\_JOFFSET3 ((uint16\_t)0xFFFF)
- #define ADC\_JOFR4\_JOFFSET4 ((uint16\_t)0xFFFF)
- #define ADC\_HTR\_LT ((uint16\_t)0xFFFF)
- #define ADC\_LTR\_LT ((uint16\_t)0xFFFF)
- #define ADC\_SQR1\_SQ13 ((uint32\_t)0x00000001F)
- #define ADC\_SQR1\_SQ13\_0 ((uint32\_t)0x00000001)
- #define ADC\_SQR1\_SQ13\_1 ((uint32\_t)0x00000002)
- #define ADC\_SQR1\_SQ13\_2 ((uint32\_t)0x00000004)

```
• #define ADC_SQR1_SQ13_3 ((uint32_t)0x00000008)
• #define ADC_SQR1_SQ13_4 ((uint32_t)0x00000010)
• #define ADC_SQR1_SQ14 ((uint32_t)0x000003E0)
• #define ADC_SQR1_SQ14_0 ((uint32_t)0x00000020)
• #define ADC_SQR1_SQ14_1 ((uint32_t)0x00000040)
• #define ADC_SQR1_SQ14_2 ((uint32_t)0x00000080)
• #define ADC_SQR1_SQ14_3 ((uint32_t)0x00000100)
• #define ADC_SQR1_SQ14_4 ((uint32_t)0x00000200)
• #define ADC_SQR1_SQ15 ((uint32_t)0x00007C00)
• #define ADC_SQR1_SQ15_0 ((uint32_t)0x00000400)
• #define ADC_SQR1_SQ15_1 ((uint32_t)0x00000800)
• #define ADC_SQR1_SQ15_2 ((uint32_t)0x00001000)
• #define ADC_SQR1_SQ15_3 ((uint32_t)0x00002000)
• #define ADC_SQR1_SQ15_4 ((uint32_t)0x00004000)
• #define ADC_SQR1_SQ16 ((uint32_t)0x000F8000)
• #define ADC_SQR1_SQ16_0 ((uint32_t)0x00008000)
• #define ADC_SQR1_SQ16_1 ((uint32_t)0x00010000)
• #define ADC_SQR1_SQ16_2 ((uint32_t)0x00020000)
• #define ADC_SQR1_SQ16_3 ((uint32_t)0x00040000)
• #define ADC_SQR1_SQ16_4 ((uint32_t)0x00080000)
• #define ADC_SQR1_L ((uint32_t)0x00F00000)
• #define ADC_SQR1_L_0 ((uint32_t)0x00100000)
• #define ADC_SQR1_L_1 ((uint32_t)0x00200000)
• #define ADC_SQR1_L_2 ((uint32_t)0x00400000)
• #define ADC_SQR1_L_3 ((uint32_t)0x00800000)
• #define ADC_SQR2_SQ7 ((uint32_t)0x0000001F)
• #define ADC_SQR2_SQ7_0 ((uint32_t)0x00000001)
• #define ADC_SQR2_SQ7_1 ((uint32_t)0x00000002)
• #define ADC_SQR2_SQ7_2 ((uint32_t)0x00000004)
• #define ADC_SQR2_SQ7_3 ((uint32_t)0x00000008)
• #define ADC_SQR2_SQ7_4 ((uint32_t)0x00000010)
• #define ADC_SQR2_SQ8 ((uint32_t)0x000003E0)
• #define ADC_SQR2_SQ8_0 ((uint32_t)0x00000020)
• #define ADC_SQR2_SQ8_1 ((uint32_t)0x00000040)
• #define ADC_SQR2_SQ8_2 ((uint32_t)0x00000080)
• #define ADC_SQR2_SQ8_3 ((uint32_t)0x00000100)
• #define ADC_SQR2_SQ8_4 ((uint32_t)0x00000200)
• #define ADC_SQR2_SQ9 ((uint32_t)0x00007C00)
• #define ADC_SQR2_SQ9_0 ((uint32_t)0x00000400)
• #define ADC_SQR2_SQ9_1 ((uint32_t)0x00000800)
• #define ADC_SQR2_SQ9_2 ((uint32_t)0x00001000)
• #define ADC_SQR2_SQ9_3 ((uint32_t)0x00002000)
• #define ADC_SQR2_SQ9_4 ((uint32_t)0x00004000)
• #define ADC_SQR2_SQ10 ((uint32_t)0x000F8000)
• #define ADC_SQR2_SQ10_0 ((uint32_t)0x00008000)
• #define ADC_SQR2_SQ10_1 ((uint32_t)0x00010000)
• #define ADC_SQR2_SQ10_2 ((uint32_t)0x00020000)
• #define ADC_SQR2_SQ10_3 ((uint32_t)0x00040000)
• #define ADC_SQR2_SQ10_4 ((uint32_t)0x00080000)
• #define ADC_SQR2_SQ11 ((uint32_t)0x01F00000)
• #define ADC_SQR2_SQ11_0 ((uint32_t)0x00100000)
• #define ADC_SQR2_SQ11_1 ((uint32_t)0x00200000)
• #define ADC_SQR2_SQ11_2 ((uint32_t)0x00400000)
• #define ADC_SQR2_SQ11_3 ((uint32_t)0x00800000)
• #define ADC_SQR2_SQ11_4 ((uint32_t)0x01000000)
```

```
• #define ADC_SQR2_SQ12 ((uint32_t)0x3E000000)
• #define ADC_SQR2_SQ12_0 ((uint32_t)0x02000000)
• #define ADC_SQR2_SQ12_1 ((uint32_t)0x04000000)
• #define ADC_SQR2_SQ12_2 ((uint32_t)0x08000000)
• #define ADC_SQR2_SQ12_3 ((uint32_t)0x10000000)
• #define ADC_SQR2_SQ12_4 ((uint32_t)0x20000000)
• #define ADC_SQR3_SQ1 ((uint32_t)0x00000001F)
• #define ADC_SQR3_SQ1_0 ((uint32_t)0x000000001)
• #define ADC_SQR3_SQ1_1 ((uint32_t)0x000000002)
• #define ADC_SQR3_SQ1_2 ((uint32_t)0x000000004)
• #define ADC_SQR3_SQ1_3 ((uint32_t)0x000000008)
• #define ADC_SQR3_SQ1_4 ((uint32_t)0x000000010)
• #define ADC_SQR3_SQ2 ((uint32_t)0x0000003E0)
• #define ADC_SQR3_SQ2_0 ((uint32_t)0x000000020)
• #define ADC_SQR3_SQ2_1 ((uint32_t)0x000000040)
• #define ADC_SQR3_SQ2_2 ((uint32_t)0x000000080)
• #define ADC_SQR3_SQ2_3 ((uint32_t)0x000000100)
• #define ADC_SQR3_SQ2_4 ((uint32_t)0x000000200)
• #define ADC_SQR3_SQ3 ((uint32_t)0x00007C00)
• #define ADC_SQR3_SQ3_0 ((uint32_t)0x000000400)
• #define ADC_SQR3_SQ3_1 ((uint32_t)0x00000800)
• #define ADC_SQR3_SQ3_2 ((uint32_t)0x00001000)
• #define ADC_SQR3_SQ3_3 ((uint32_t)0x00002000)
• #define ADC_SQR3_SQ3_4 ((uint32_t)0x00004000)
• #define ADC_SQR3_SQ4 ((uint32_t)0x000F8000)
• #define ADC_SQR3_SQ4_0 ((uint32_t)0x00008000)
• #define ADC_SQR3_SQ4_1 ((uint32_t)0x00010000)
• #define ADC_SQR3_SQ4_2 ((uint32_t)0x00020000)
• #define ADC_SQR3_SQ4_3 ((uint32_t)0x00040000)
• #define ADC_SQR3_SQ4_4 ((uint32_t)0x00080000)
• #define ADC_SQR3_SQ5 ((uint32_t)0x01F00000)
• #define ADC_SQR3_SQ5_0 ((uint32_t)0x00100000)
• #define ADC_SQR3_SQ5_1 ((uint32_t)0x00200000)
• #define ADC_SQR3_SQ5_2 ((uint32_t)0x00400000)
• #define ADC_SQR3_SQ5_3 ((uint32_t)0x00800000)
• #define ADC_SQR3_SQ5_4 ((uint32_t)0x01000000)
• #define ADC_SQR3_SQ6 ((uint32_t)0x3E000000)
• #define ADC_SQR3_SQ6_0 ((uint32_t)0x02000000)
• #define ADC_SQR3_SQ6_1 ((uint32_t)0x04000000)
• #define ADC_SQR3_SQ6_2 ((uint32_t)0x08000000)
• #define ADC_SQR3_SQ6_3 ((uint32_t)0x10000000)
• #define ADC_SQR3_SQ6_4 ((uint32_t)0x20000000)
• #define ADC_JSQR_JSQ1 ((uint32_t)0x00000001F)
• #define ADC_JSQR_JSQ1_0 ((uint32_t)0x000000001)
• #define ADC_JSQR_JSQ1_1 ((uint32_t)0x000000002)
• #define ADC_JSQR_JSQ1_2 ((uint32_t)0x000000004)
• #define ADC_JSQR_JSQ1_3 ((uint32_t)0x000000008)
• #define ADC_JSQR_JSQ1_4 ((uint32_t)0x000000010)
• #define ADC_JSQR_JSQ2 ((uint32_t)0x0000003E0)
• #define ADC_JSQR_JSQ2_0 ((uint32_t)0x000000020)
• #define ADC_JSQR_JSQ2_1 ((uint32_t)0x000000040)
• #define ADC_JSQR_JSQ2_2 ((uint32_t)0x000000080)
• #define ADC_JSQR_JSQ2_3 ((uint32_t)0x000000100)
• #define ADC_JSQR_JSQ2_4 ((uint32_t)0x000000200)
• #define ADC_JSQR_JSQ3 ((uint32_t)0x00007C00)
```

```
• #define ADC_JSQR_JSQ3_0 ((uint32_t)0x00000400)
• #define ADC_JSQR_JSQ3_1 ((uint32_t)0x00000800)
• #define ADC_JSQR_JSQ3_2 ((uint32_t)0x00001000)
• #define ADC_JSQR_JSQ3_3 ((uint32_t)0x00002000)
• #define ADC_JSQR_JSQ3_4 ((uint32_t)0x00004000)
• #define ADC_JSQR_JSQ4 ((uint32_t)0x000F8000)
• #define ADC_JSQR_JSQ4_0 ((uint32_t)0x00008000)
• #define ADC_JSQR_JSQ4_1 ((uint32_t)0x00010000)
• #define ADC_JSQR_JSQ4_2 ((uint32_t)0x00020000)
• #define ADC_JSQR_JSQ4_3 ((uint32_t)0x00040000)
• #define ADC_JSQR_JSQ4_4 ((uint32_t)0x00080000)
• #define ADC_JSQR_JL ((uint32_t)0x00300000)
• #define ADC_JSQR_JL_0 ((uint32_t)0x00100000)
• #define ADC_JSQR_JL_1 ((uint32_t)0x00200000)
• #define ADC_JDR1_JDATA ((uint16_t)0xFFFF)
• #define ADC_JDR2_JDATA ((uint16_t)0xFFFF)
• #define ADC_JDR3_JDATA ((uint16_t)0xFFFF)
• #define ADC_JDR4_JDATA ((uint16_t)0xFFFF)
• #define ADC_DR_DATA ((uint32_t)0x0000FFFF)
• #define ADC_DR_ADC2DATA ((uint32_t)0xFFFF0000)
• #define ADC_CSR_AWD1 ((uint32_t)0x00000001)
• #define ADC_CSR_EOC1 ((uint32_t)0x00000002)
• #define ADC_CSR_JEOC1 ((uint32_t)0x00000004)
• #define ADC_CSR_JSTRT1 ((uint32_t)0x00000008)
• #define ADC_CSR_STRT1 ((uint32_t)0x00000010)
• #define ADC_CSR_OVR1 ((uint32_t)0x00000020)
• #define ADC_CSR_AWD2 ((uint32_t)0x00000100)
• #define ADC_CSR_EOC2 ((uint32_t)0x00000200)
• #define ADC_CSR_JEOC2 ((uint32_t)0x00000400)
• #define ADC_CSR_JSTRT2 ((uint32_t)0x00000800)
• #define ADC_CSR_STRT2 ((uint32_t)0x00001000)
• #define ADC_CSR_OVR2 ((uint32_t)0x00002000)
• #define ADC_CSR_AWD3 ((uint32_t)0x00010000)
• #define ADC_CSR_EOC3 ((uint32_t)0x00020000)
• #define ADC_CSR_JEOC3 ((uint32_t)0x00040000)
• #define ADC_CSR_JSTRT3 ((uint32_t)0x00080000)
• #define ADC_CSR_STRT3 ((uint32_t)0x00100000)
• #define ADC_CSR_OVR3 ((uint32_t)0x00200000)
• #define ADC_CSR_DOVRR1 ADC_CSR_OVR1
• #define ADC_CSR_DOVRR2 ADC_CSR_OVR2
• #define ADC_CSR_DOVRR3 ADC_CSR_OVR3
• #define ADC_CCR_MULTI ((uint32_t)0x0000001F)
• #define ADC_CCR_MULTI_0 ((uint32_t)0x00000001)
• #define ADC_CCR_MULTI_1 ((uint32_t)0x00000002)
• #define ADC_CCR_MULTI_2 ((uint32_t)0x00000004)
• #define ADC_CCR_MULTI_3 ((uint32_t)0x00000008)
• #define ADC_CCR_MULTI_4 ((uint32_t)0x00000010)
• #define ADC_CCR_DELAY ((uint32_t)0x00000F00)
• #define ADC_CCR_DELAY_0 ((uint32_t)0x00000100)
• #define ADC_CCR_DELAY_1 ((uint32_t)0x00000200)
• #define ADC_CCR_DELAY_2 ((uint32_t)0x00000400)
• #define ADC_CCR_DELAY_3 ((uint32_t)0x00000800)
• #define ADC_CCR_DDS ((uint32_t)0x00002000)
• #define ADC_CCR_DMA ((uint32_t)0x0000C000)
• #define ADC_CCR_DMA_0 ((uint32_t)0x00004000)
```

- #define ADC\_CCR\_DMA\_1 ((uint32\_t)0x00008000)
- #define ADC\_CCR\_ADCPRE ((uint32\_t)0x00030000)
- #define ADC\_CCR\_ADCPRE\_0 ((uint32\_t)0x00010000)
- #define ADC\_CCR\_ADCPRE\_1 ((uint32\_t)0x00020000)
- #define ADC\_CCR\_VBATE ((uint32\_t)0x00400000)
- #define ADC\_CCR\_TSVREFE ((uint32\_t)0x00800000)
- #define ADC\_CDR\_DATA1 ((uint32\_t)0x0000FFFF)
- #define ADC\_CDR\_DATA2 ((uint32\_t)0xFFFFF000)
- #define CAN\_MCR\_INRQ ((uint16\_t)0x0001)
- #define CAN\_MCR\_SLEEP ((uint16\_t)0x0002)
- #define CAN\_MCR\_TXFP ((uint16\_t)0x0004)
- #define CAN\_MCR\_RFLM ((uint16\_t)0x0008)
- #define CAN\_MCR\_NART ((uint16\_t)0x0010)
- #define CAN\_MCR\_AWUM ((uint16\_t)0x0020)
- #define CAN\_MCR\_ABOM ((uint16\_t)0x0040)
- #define CAN\_MCR\_TTCM ((uint16\_t)0x0080)
- #define CAN\_MCR\_RESET ((uint16\_t)0x8000)
- #define CAN\_MSR\_INAK ((uint16\_t)0x0001)
- #define CAN\_MSR\_SLAK ((uint16\_t)0x0002)
- #define CAN\_MSR\_ERRI ((uint16\_t)0x0004)
- #define CAN\_MSR\_WKUI ((uint16\_t)0x0008)
- #define CAN\_MSR\_SLAKI ((uint16\_t)0x0010)
- #define CAN\_MSR\_TXM ((uint16\_t)0x0100)
- #define CAN\_MSR\_RXM ((uint16\_t)0x0200)
- #define CAN\_MSR\_SAMP ((uint16\_t)0x0400)
- #define CAN\_MSR\_RX ((uint16\_t)0x0800)
- #define CAN\_TSR\_RQCP0 ((uint32\_t)0x00000001)
- #define CAN\_TSR\_TXOK0 ((uint32\_t)0x00000002)
- #define CAN\_TSR\_ALST0 ((uint32\_t)0x00000004)
- #define CAN\_TSR\_TERR0 ((uint32\_t)0x00000008)
- #define CAN\_TSR\_ABRQ0 ((uint32\_t)0x00000080)
- #define CAN\_TSR\_RQCP1 ((uint32\_t)0x00000100)
- #define CAN\_TSR\_TXOK1 ((uint32\_t)0x00000200)
- #define CAN\_TSR\_ALST1 ((uint32\_t)0x00000400)
- #define CAN\_TSR\_TERR1 ((uint32\_t)0x00000800)
- #define CAN\_TSR\_ABRQ1 ((uint32\_t)0x00008000)
- #define CAN\_TSR\_RQCP2 ((uint32\_t)0x00010000)
- #define CAN\_TSR\_TXOK2 ((uint32\_t)0x00020000)
- #define CAN\_TSR\_ALST2 ((uint32\_t)0x00040000)
- #define CAN\_TSR\_TERR2 ((uint32\_t)0x00080000)
- #define CAN\_TSR\_ABRQ2 ((uint32\_t)0x00800000)
- #define CAN\_TSR\_CODE ((uint32\_t)0x03000000)
- #define CAN\_TSR\_TME ((uint32\_t)0x1C000000)
- #define CAN\_TSR\_TME0 ((uint32\_t)0x04000000)
- #define CAN\_TSR\_TME1 ((uint32\_t)0x08000000)
- #define CAN\_TSR\_TME2 ((uint32\_t)0x10000000)
- #define CAN\_TSR\_LOW ((uint32\_t)0xE0000000)
- #define CAN\_TSR\_LOW0 ((uint32\_t)0x20000000)
- #define CAN\_TSR\_LOW1 ((uint32\_t)0x40000000)
- #define CAN\_TSR\_LOW2 ((uint32\_t)0x80000000)
- #define CAN\_RF0R\_FMP0 ((uint8\_t)0x03)
- #define CAN\_RF0R\_FULL0 ((uint8\_t)0x08)
- #define CAN\_RF0R\_FOVR0 ((uint8\_t)0x10)
- #define CAN\_RF0R\_RFOM0 ((uint8\_t)0x20)
- #define CAN\_RF1R\_FMP1 ((uint8\_t)0x03)

```
• #define CAN_RF1R_FULL1 ((uint8_t)0x08)
• #define CAN_RF1R_FOVR1 ((uint8_t)0x10)
• #define CAN_RF1R_RFOM1 ((uint8_t)0x20)
• #define CAN_IER_TMEIE ((uint32_t)0x00000001)
• #define CAN_IER_FMPIE0 ((uint32_t)0x00000002)
• #define CAN_IER_FFIE0 ((uint32_t)0x00000004)
• #define CAN_IER_FOVIE0 ((uint32_t)0x00000008)
• #define CAN_IER_FMPIE1 ((uint32_t)0x00000010)
• #define CAN_IER_FFIE1 ((uint32_t)0x00000020)
• #define CAN_IER_FOVIE1 ((uint32_t)0x00000040)
• #define CAN_IER_EWGIE ((uint32_t)0x00000100)
• #define CAN_IER_EPVIE ((uint32_t)0x00000200)
• #define CAN_IER_BOFIE ((uint32_t)0x00000400)
• #define CAN_IER_LCIE ((uint32_t)0x00000800)
• #define CAN_IER_ERRIE ((uint32_t)0x00008000)
• #define CAN_IER_WKUIE ((uint32_t)0x00010000)
• #define CAN_IER_SLKIE ((uint32_t)0x00020000)
• #define CAN_ESR_EWGF ((uint32_t)0x00000001)
• #define CAN_ESR_EPVF ((uint32_t)0x00000002)
• #define CAN_ESR_BOFF ((uint32_t)0x00000004)
• #define CAN_ESR_LEC ((uint32_t)0x00000070)
• #define CAN_ESR_LEC_0 ((uint32_t)0x00000010)
• #define CAN_ESR_LEC_1 ((uint32_t)0x00000020)
• #define CAN_ESR_LEC_2 ((uint32_t)0x00000040)
• #define CAN_ESR_TEC ((uint32_t)0x00FF0000)
• #define CAN_ESR_REC ((uint32_t)0xFF000000)
• #define CAN_BTR_BRP ((uint32_t)0x000003FF)
• #define CAN_BTR_TS1 ((uint32_t)0x000F0000)
• #define CAN_BTR_TS2 ((uint32_t)0x00700000)
• #define CAN_BTR_SJW ((uint32_t)0x03000000)
• #define CAN_BTR_LBKM ((uint32_t)0x40000000)
• #define CAN_BTR_SIIM ((uint32_t)0x80000000)
• #define CAN_TI0R_TXRQ ((uint32_t)0x00000001)
• #define CAN_TI0R_RTR ((uint32_t)0x00000002)
• #define CAN_TI0R_IDE ((uint32_t)0x00000004)
• #define CAN_TI0R_EXID ((uint32_t)0x001FFFF8)
• #define CAN_TI0R_STID ((uint32_t)0xFFE00000)
• #define CAN_TDT0R_DLc ((uint32_t)0x0000000F)
• #define CAN_TDT0R_TGT ((uint32_t)0x00000100)
• #define CAN_TDT0R_TIME ((uint32_t)0xFFFF0000)
• #define CAN_TDL0R_DATA0 ((uint32_t)0x000000FF)
• #define CAN_TDL0R_DATA1 ((uint32_t)0x0000FF00)
• #define CAN_TDL0R_DATA2 ((uint32_t)0x00FF0000)
• #define CAN_TDL0R_DATA3 ((uint32_t)0xFF000000)
• #define CAN_TDHO0R_DATA4 ((uint32_t)0x000000FF)
• #define CAN_TDHO0R_DATA5 ((uint32_t)0x0000FF00)
• #define CAN_TDHO0R_DATA6 ((uint32_t)0x00FF0000)
• #define CAN_TDHO0R_DATA7 ((uint32_t)0xFF000000)
• #define CAN_TI1R_TXRQ ((uint32_t)0x00000001)
• #define CAN_TI1R_RTR ((uint32_t)0x00000002)
• #define CAN_TI1R_IDE ((uint32_t)0x00000004)
• #define CAN_TI1R_EXID ((uint32_t)0x001FFFF8)
• #define CAN_TI1R_STID ((uint32_t)0xFFE00000)
• #define CAN_TDT1R_DLc ((uint32_t)0x0000000F)
• #define CAN_TDT1R_TGT ((uint32_t)0x00000100)
```

- #define CAN\_TDT1R\_TIME ((uint32\_t)0xFFFF0000)
- #define CAN\_TDL1R\_DATA0 ((uint32\_t)0x000000FF)
- #define CAN\_TDL1R\_DATA1 ((uint32\_t)0x0000FF00)
- #define CAN\_TDL1R\_DATA2 ((uint32\_t)0x00FF0000)
- #define CAN\_TDL1R\_DATA3 ((uint32\_t)0xFF000000)
- #define CAN\_TDH1R\_DATA4 ((uint32\_t)0x000000FF)
- #define CAN\_TDH1R\_DATA5 ((uint32\_t)0x0000FF00)
- #define CAN\_TDH1R\_DATA6 ((uint32\_t)0x00FF0000)
- #define CAN\_TDH1R\_DATA7 ((uint32\_t)0xFF000000)
- #define CAN\_TI2R\_TXRQ ((uint32\_t)0x00000001)
- #define CAN\_TI2R\_RTR ((uint32\_t)0x00000002)
- #define CAN\_TI2R\_IDE ((uint32\_t)0x00000004)
- #define CAN\_TI2R\_EXID ((uint32\_t)0x001FFFFF8)
- #define CAN\_TI2R\_STID ((uint32\_t)0xFFE00000)
- #define CAN\_TDT2R\_DLC ((uint32\_t)0x0000000F)
- #define CAN\_TDT2R\_TGT ((uint32\_t)0x00000100)
- #define CAN\_TDT2R\_TIME ((uint32\_t)0xFFFF0000)
- #define CAN\_TDL2R\_DATA0 ((uint32\_t)0x000000FF)
- #define CAN\_TDL2R\_DATA1 ((uint32\_t)0x0000FF00)
- #define CAN\_TDL2R\_DATA2 ((uint32\_t)0x00FF0000)
- #define CAN\_TDL2R\_DATA3 ((uint32\_t)0xFF000000)
- #define CAN\_TDH2R\_DATA4 ((uint32\_t)0x000000FF)
- #define CAN\_TDH2R\_DATA5 ((uint32\_t)0x0000FF00)
- #define CAN\_TDH2R\_DATA6 ((uint32\_t)0x00FF0000)
- #define CAN\_TDH2R\_DATA7 ((uint32\_t)0xFF000000)
- #define CAN\_RI0R\_RTR ((uint32\_t)0x00000002)
- #define CAN\_RI0R\_IDE ((uint32\_t)0x00000004)
- #define CAN\_RI0R\_EXID ((uint32\_t)0x001FFFFF8)
- #define CAN\_RI0R\_STID ((uint32\_t)0xFFE00000)
- #define CAN\_RDT0R\_DLC ((uint32\_t)0x0000000F)
- #define CAN\_RDT0R\_FMI ((uint32\_t)0x0000FF00)
- #define CAN\_RDT0R\_TIME ((uint32\_t)0xFFFF0000)
- #define CAN\_RDL0R\_DATA0 ((uint32\_t)0x000000FF)
- #define CAN\_RDL0R\_DATA1 ((uint32\_t)0x0000FF00)
- #define CAN\_RDL0R\_DATA2 ((uint32\_t)0x00FF0000)
- #define CAN\_RDL0R\_DATA3 ((uint32\_t)0xFF000000)
- #define CAN\_RDH0R\_DATA4 ((uint32\_t)0x000000FF)
- #define CAN\_RDH0R\_DATA5 ((uint32\_t)0x0000FF00)
- #define CAN\_RDH0R\_DATA6 ((uint32\_t)0x00FF0000)
- #define CAN\_RDH0R\_DATA7 ((uint32\_t)0xFF000000)
- #define CAN\_RI1R\_RTR ((uint32\_t)0x00000002)
- #define CAN\_RI1R\_IDE ((uint32\_t)0x00000004)
- #define CAN\_RI1R\_EXID ((uint32\_t)0x001FFFFF8)
- #define CAN\_RI1R\_STID ((uint32\_t)0xFFE00000)
- #define CAN\_RDT1R\_DLC ((uint32\_t)0x0000000F)
- #define CAN\_RDT1R\_FMI ((uint32\_t)0x0000FF00)
- #define CAN\_RDT1R\_TIME ((uint32\_t)0xFFFF0000)
- #define CAN\_RDL1R\_DATA0 ((uint32\_t)0x000000FF)
- #define CAN\_RDL1R\_DATA1 ((uint32\_t)0x0000FF00)
- #define CAN\_RDL1R\_DATA2 ((uint32\_t)0x00FF0000)
- #define CAN\_RDL1R\_DATA3 ((uint32\_t)0xFF000000)
- #define CAN\_RDH1R\_DATA4 ((uint32\_t)0x000000FF)
- #define CAN\_RDH1R\_DATA5 ((uint32\_t)0x0000FF00)
- #define CAN\_RDH1R\_DATA6 ((uint32\_t)0x00FF0000)
- #define CAN\_RDH1R\_DATA7 ((uint32\_t)0xFF000000)

- #define CAN\_FMR\_INIT ((uint8\_t)0x01)
- #define CAN\_FM1R\_FBM ((uint16\_t)0x3FFF)
- #define CAN\_FM1R\_FBM0 ((uint16\_t)0x0001)
- #define CAN\_FM1R\_FBM1 ((uint16\_t)0x0002)
- #define CAN\_FM1R\_FBM2 ((uint16\_t)0x0004)
- #define CAN\_FM1R\_FBM3 ((uint16\_t)0x0008)
- #define CAN\_FM1R\_FBM4 ((uint16\_t)0x0010)
- #define CAN\_FM1R\_FBM5 ((uint16\_t)0x0020)
- #define CAN\_FM1R\_FBM6 ((uint16\_t)0x0040)
- #define CAN\_FM1R\_FBM7 ((uint16\_t)0x0080)
- #define CAN\_FM1R\_FBM8 ((uint16\_t)0x0100)
- #define CAN\_FM1R\_FBM9 ((uint16\_t)0x0200)
- #define CAN\_FM1R\_FBM10 ((uint16\_t)0x0400)
- #define CAN\_FM1R\_FBM11 ((uint16\_t)0x0800)
- #define CAN\_FM1R\_FBM12 ((uint16\_t)0x1000)
- #define CAN\_FM1R\_FBM13 ((uint16\_t)0x2000)
- #define CAN\_FS1R\_FSC ((uint16\_t)0x3FFF)
- #define CAN\_FS1R\_FSC0 ((uint16\_t)0x0001)
- #define CAN\_FS1R\_FSC1 ((uint16\_t)0x0002)
- #define CAN\_FS1R\_FSC2 ((uint16\_t)0x0004)
- #define CAN\_FS1R\_FSC3 ((uint16\_t)0x0008)
- #define CAN\_FS1R\_FSC4 ((uint16\_t)0x0010)
- #define CAN\_FS1R\_FSC5 ((uint16\_t)0x0020)
- #define CAN\_FS1R\_FSC6 ((uint16\_t)0x0040)
- #define CAN\_FS1R\_FSC7 ((uint16\_t)0x0080)
- #define CAN\_FS1R\_FSC8 ((uint16\_t)0x0100)
- #define CAN\_FS1R\_FSC9 ((uint16\_t)0x0200)
- #define CAN\_FS1R\_FSC10 ((uint16\_t)0x0400)
- #define CAN\_FS1R\_FSC11 ((uint16\_t)0x0800)
- #define CAN\_FS1R\_FSC12 ((uint16\_t)0x1000)
- #define CAN\_FS1R\_FSC13 ((uint16\_t)0x2000)
- #define CAN\_FFA1R\_FFA ((uint16\_t)0x3FFF)
- #define CAN\_FFA1R\_FFA0 ((uint16\_t)0x0001)
- #define CAN\_FFA1R\_FFA1 ((uint16\_t)0x0002)
- #define CAN\_FFA1R\_FFA2 ((uint16\_t)0x0004)
- #define CAN\_FFA1R\_FFA3 ((uint16\_t)0x0008)
- #define CAN\_FFA1R\_FFA4 ((uint16\_t)0x0010)
- #define CAN\_FFA1R\_FFA5 ((uint16\_t)0x0020)
- #define CAN\_FFA1R\_FFA6 ((uint16\_t)0x0040)
- #define CAN\_FFA1R\_FFA7 ((uint16\_t)0x0080)
- #define CAN\_FFA1R\_FFA8 ((uint16\_t)0x0100)
- #define CAN\_FFA1R\_FFA9 ((uint16\_t)0x0200)
- #define CAN\_FFA1R\_FFA10 ((uint16\_t)0x0400)
- #define CAN\_FFA1R\_FFA11 ((uint16\_t)0x0800)
- #define CAN\_FFA1R\_FFA12 ((uint16\_t)0x1000)
- #define CAN\_FFA1R\_FFA13 ((uint16\_t)0x2000)
- #define CAN\_FA1R\_FACT ((uint16\_t)0x3FFF)
- #define CAN\_FA1R\_FACT0 ((uint16\_t)0x0001)
- #define CAN\_FA1R\_FACT1 ((uint16\_t)0x0002)
- #define CAN\_FA1R\_FACT2 ((uint16\_t)0x0004)
- #define CAN\_FA1R\_FACT3 ((uint16\_t)0x0008)
- #define CAN\_FA1R\_FACT4 ((uint16\_t)0x0010)
- #define CAN\_FA1R\_FACT5 ((uint16\_t)0x0020)
- #define CAN\_FA1R\_FACT6 ((uint16\_t)0x0040)
- #define CAN\_FA1R\_FACT7 ((uint16\_t)0x0080)

- #define CAN\_FA1R\_FACT8 ((uint16\_t)0x0100)
- #define CAN\_FA1R\_FACT9 ((uint16\_t)0x0200)
- #define CAN\_FA1R\_FACT10 ((uint16\_t)0x0400)
- #define CAN\_FA1R\_FACT11 ((uint16\_t)0x0800)
- #define CAN\_FA1R\_FACT12 ((uint16\_t)0x1000)
- #define CAN\_FA1R\_FACT13 ((uint16\_t)0x2000)
- #define CAN\_F0R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F0R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F0R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F0R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F0R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F0R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F0R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F0R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F0R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F0R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F0R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F0R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F0R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F0R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F0R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F0R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F0R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F0R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F0R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F0R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F0R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F0R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F0R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F0R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F0R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F0R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F0R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F0R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F0R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F0R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F0R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F0R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F1R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F1R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F1R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F1R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F1R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F1R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F1R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F1R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F1R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F1R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F1R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F1R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F1R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F1R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F1R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F1R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F1R1\_FB16 ((uint32\_t)0x00010000)

```
• #define CAN_F1R1_FB17 ((uint32_t)0x00020000)
• #define CAN_F1R1_FB18 ((uint32_t)0x00040000)
• #define CAN_F1R1_FB19 ((uint32_t)0x00080000)
• #define CAN_F1R1_FB20 ((uint32_t)0x00100000)
• #define CAN_F1R1_FB21 ((uint32_t)0x00200000)
• #define CAN_F1R1_FB22 ((uint32_t)0x00400000)
• #define CAN_F1R1_FB23 ((uint32_t)0x00800000)
• #define CAN_F1R1_FB24 ((uint32_t)0x01000000)
• #define CAN_F1R1_FB25 ((uint32_t)0x02000000)
• #define CAN_F1R1_FB26 ((uint32_t)0x04000000)
• #define CAN_F1R1_FB27 ((uint32_t)0x08000000)
• #define CAN_F1R1_FB28 ((uint32_t)0x10000000)
• #define CAN_F1R1_FB29 ((uint32_t)0x20000000)
• #define CAN_F1R1_FB30 ((uint32_t)0x40000000)
• #define CAN_F1R1_FB31 ((uint32_t)0x80000000)
• #define CAN_F2R1_FB0 ((uint32_t)0x00000001)
• #define CAN_F2R1_FB1 ((uint32_t)0x00000002)
• #define CAN_F2R1_FB2 ((uint32_t)0x00000004)
• #define CAN_F2R1_FB3 ((uint32_t)0x00000008)
• #define CAN_F2R1_FB4 ((uint32_t)0x00000010)
• #define CAN_F2R1_FB5 ((uint32_t)0x00000020)
• #define CAN_F2R1_FB6 ((uint32_t)0x00000040)
• #define CAN_F2R1_FB7 ((uint32_t)0x00000080)
• #define CAN_F2R1_FB8 ((uint32_t)0x00000100)
• #define CAN_F2R1_FB9 ((uint32_t)0x00000200)
• #define CAN_F2R1_FB10 ((uint32_t)0x00000400)
• #define CAN_F2R1_FB11 ((uint32_t)0x00000800)
• #define CAN_F2R1_FB12 ((uint32_t)0x00001000)
• #define CAN_F2R1_FB13 ((uint32_t)0x00002000)
• #define CAN_F2R1_FB14 ((uint32_t)0x00004000)
• #define CAN_F2R1_FB15 ((uint32_t)0x00008000)
• #define CAN_F2R1_FB16 ((uint32_t)0x00010000)
• #define CAN_F2R1_FB17 ((uint32_t)0x00020000)
• #define CAN_F2R1_FB18 ((uint32_t)0x00040000)
• #define CAN_F2R1_FB19 ((uint32_t)0x00080000)
• #define CAN_F2R1_FB20 ((uint32_t)0x00100000)
• #define CAN_F2R1_FB21 ((uint32_t)0x00200000)
• #define CAN_F2R1_FB22 ((uint32_t)0x00400000)
• #define CAN_F2R1_FB23 ((uint32_t)0x00800000)
• #define CAN_F2R1_FB24 ((uint32_t)0x01000000)
• #define CAN_F2R1_FB25 ((uint32_t)0x02000000)
• #define CAN_F2R1_FB26 ((uint32_t)0x04000000)
• #define CAN_F2R1_FB27 ((uint32_t)0x08000000)
• #define CAN_F2R1_FB28 ((uint32_t)0x10000000)
• #define CAN_F2R1_FB29 ((uint32_t)0x20000000)
• #define CAN_F2R1_FB30 ((uint32_t)0x40000000)
• #define CAN_F2R1_FB31 ((uint32_t)0x80000000)
• #define CAN_F3R1_FB0 ((uint32_t)0x00000001)
• #define CAN_F3R1_FB1 ((uint32_t)0x00000002)
• #define CAN_F3R1_FB2 ((uint32_t)0x00000004)
• #define CAN_F3R1_FB3 ((uint32_t)0x00000008)
• #define CAN_F3R1_FB4 ((uint32_t)0x00000010)
• #define CAN_F3R1_FB5 ((uint32_t)0x00000020)
• #define CAN_F3R1_FB6 ((uint32_t)0x00000040)
• #define CAN_F3R1_FB7 ((uint32_t)0x00000080)
```

- #define CAN\_F3R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F3R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F3R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F3R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F3R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F3R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F3R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F3R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F3R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F3R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F3R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F3R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F3R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F3R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F3R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F3R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F3R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F3R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F3R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F3R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F3R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F3R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F3R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F3R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F4R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F4R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F4R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F4R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F4R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F4R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F4R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F4R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F4R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F4R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F4R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F4R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F4R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F4R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F4R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F4R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F4R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F4R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F4R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F4R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F4R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F4R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F4R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F4R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F4R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F4R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F4R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F4R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F4R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F4R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F4R1\_FB30 ((uint32\_t)0x40000000)

```
• #define CAN_F4R1_FB31 ((uint32_t)0x80000000)
• #define CAN_F5R1_FB0 ((uint32_t)0x00000001)
• #define CAN_F5R1_FB1 ((uint32_t)0x00000002)
• #define CAN_F5R1_FB2 ((uint32_t)0x00000004)
• #define CAN_F5R1_FB3 ((uint32_t)0x00000008)
• #define CAN_F5R1_FB4 ((uint32_t)0x00000010)
• #define CAN_F5R1_FB5 ((uint32_t)0x00000020)
• #define CAN_F5R1_FB6 ((uint32_t)0x00000040)
• #define CAN_F5R1_FB7 ((uint32_t)0x00000080)
• #define CAN_F5R1_FB8 ((uint32_t)0x00000100)
• #define CAN_F5R1_FB9 ((uint32_t)0x00000200)
• #define CAN_F5R1_FB10 ((uint32_t)0x00000400)
• #define CAN_F5R1_FB11 ((uint32_t)0x00000800)
• #define CAN_F5R1_FB12 ((uint32_t)0x00001000)
• #define CAN_F5R1_FB13 ((uint32_t)0x00002000)
• #define CAN_F5R1_FB14 ((uint32_t)0x00004000)
• #define CAN_F5R1_FB15 ((uint32_t)0x00008000)
• #define CAN_F5R1_FB16 ((uint32_t)0x00010000)
• #define CAN_F5R1_FB17 ((uint32_t)0x00020000)
• #define CAN_F5R1_FB18 ((uint32_t)0x00040000)
• #define CAN_F5R1_FB19 ((uint32_t)0x00080000)
• #define CAN_F5R1_FB20 ((uint32_t)0x00100000)
• #define CAN_F5R1_FB21 ((uint32_t)0x00200000)
• #define CAN_F5R1_FB22 ((uint32_t)0x00400000)
• #define CAN_F5R1_FB23 ((uint32_t)0x00800000)
• #define CAN_F5R1_FB24 ((uint32_t)0x01000000)
• #define CAN_F5R1_FB25 ((uint32_t)0x02000000)
• #define CAN_F5R1_FB26 ((uint32_t)0x04000000)
• #define CAN_F5R1_FB27 ((uint32_t)0x08000000)
• #define CAN_F5R1_FB28 ((uint32_t)0x10000000)
• #define CAN_F5R1_FB29 ((uint32_t)0x20000000)
• #define CAN_F5R1_FB30 ((uint32_t)0x40000000)
• #define CAN_F5R1_FB31 ((uint32_t)0x80000000)
• #define CAN_F6R1_FB0 ((uint32_t)0x00000001)
• #define CAN_F6R1_FB1 ((uint32_t)0x00000002)
• #define CAN_F6R1_FB2 ((uint32_t)0x00000004)
• #define CAN_F6R1_FB3 ((uint32_t)0x00000008)
• #define CAN_F6R1_FB4 ((uint32_t)0x00000010)
• #define CAN_F6R1_FB5 ((uint32_t)0x00000020)
• #define CAN_F6R1_FB6 ((uint32_t)0x00000040)
• #define CAN_F6R1_FB7 ((uint32_t)0x00000080)
• #define CAN_F6R1_FB8 ((uint32_t)0x00000100)
• #define CAN_F6R1_FB9 ((uint32_t)0x00000200)
• #define CAN_F6R1_FB10 ((uint32_t)0x00000400)
• #define CAN_F6R1_FB11 ((uint32_t)0x00000800)
• #define CAN_F6R1_FB12 ((uint32_t)0x00001000)
• #define CAN_F6R1_FB13 ((uint32_t)0x00002000)
• #define CAN_F6R1_FB14 ((uint32_t)0x00004000)
• #define CAN_F6R1_FB15 ((uint32_t)0x00008000)
• #define CAN_F6R1_FB16 ((uint32_t)0x00010000)
• #define CAN_F6R1_FB17 ((uint32_t)0x00020000)
• #define CAN_F6R1_FB18 ((uint32_t)0x00040000)
• #define CAN_F6R1_FB19 ((uint32_t)0x00080000)
• #define CAN_F6R1_FB20 ((uint32_t)0x00100000)
• #define CAN_F6R1_FB21 ((uint32_t)0x00200000)
```

```
• #define CAN_F6R1_FB22 ((uint32_t)0x00400000)
• #define CAN_F6R1_FB23 ((uint32_t)0x00800000)
• #define CAN_F6R1_FB24 ((uint32_t)0x01000000)
• #define CAN_F6R1_FB25 ((uint32_t)0x02000000)
• #define CAN_F6R1_FB26 ((uint32_t)0x04000000)
• #define CAN_F6R1_FB27 ((uint32_t)0x08000000)
• #define CAN_F6R1_FB28 ((uint32_t)0x10000000)
• #define CAN_F6R1_FB29 ((uint32_t)0x20000000)
• #define CAN_F6R1_FB30 ((uint32_t)0x40000000)
• #define CAN_F6R1_FB31 ((uint32_t)0x80000000)
• #define CAN_F7R1_FB0 ((uint32_t)0x00000001)
• #define CAN_F7R1_FB1 ((uint32_t)0x00000002)
• #define CAN_F7R1_FB2 ((uint32_t)0x00000004)
• #define CAN_F7R1_FB3 ((uint32_t)0x00000008)
• #define CAN_F7R1_FB4 ((uint32_t)0x00000010)
• #define CAN_F7R1_FB5 ((uint32_t)0x00000020)
• #define CAN_F7R1_FB6 ((uint32_t)0x00000040)
• #define CAN_F7R1_FB7 ((uint32_t)0x00000080)
• #define CAN_F7R1_FB8 ((uint32_t)0x00000100)
• #define CAN_F7R1_FB9 ((uint32_t)0x00000200)
• #define CAN_F7R1_FB10 ((uint32_t)0x00000400)
• #define CAN_F7R1_FB11 ((uint32_t)0x00000800)
• #define CAN_F7R1_FB12 ((uint32_t)0x00001000)
• #define CAN_F7R1_FB13 ((uint32_t)0x00002000)
• #define CAN_F7R1_FB14 ((uint32_t)0x00004000)
• #define CAN_F7R1_FB15 ((uint32_t)0x00008000)
• #define CAN_F7R1_FB16 ((uint32_t)0x00010000)
• #define CAN_F7R1_FB17 ((uint32_t)0x00020000)
• #define CAN_F7R1_FB18 ((uint32_t)0x00040000)
• #define CAN_F7R1_FB19 ((uint32_t)0x00080000)
• #define CAN_F7R1_FB20 ((uint32_t)0x00100000)
• #define CAN_F7R1_FB21 ((uint32_t)0x00200000)
• #define CAN_F7R1_FB22 ((uint32_t)0x00400000)
• #define CAN_F7R1_FB23 ((uint32_t)0x00800000)
• #define CAN_F7R1_FB24 ((uint32_t)0x01000000)
• #define CAN_F7R1_FB25 ((uint32_t)0x02000000)
• #define CAN_F7R1_FB26 ((uint32_t)0x04000000)
• #define CAN_F7R1_FB27 ((uint32_t)0x08000000)
• #define CAN_F7R1_FB28 ((uint32_t)0x10000000)
• #define CAN_F7R1_FB29 ((uint32_t)0x20000000)
• #define CAN_F7R1_FB30 ((uint32_t)0x40000000)
• #define CAN_F7R1_FB31 ((uint32_t)0x80000000)
• #define CAN_F8R1_FB0 ((uint32_t)0x00000001)
• #define CAN_F8R1_FB1 ((uint32_t)0x00000002)
• #define CAN_F8R1_FB2 ((uint32_t)0x00000004)
• #define CAN_F8R1_FB3 ((uint32_t)0x00000008)
• #define CAN_F8R1_FB4 ((uint32_t)0x00000010)
• #define CAN_F8R1_FB5 ((uint32_t)0x00000020)
• #define CAN_F8R1_FB6 ((uint32_t)0x00000040)
• #define CAN_F8R1_FB7 ((uint32_t)0x00000080)
• #define CAN_F8R1_FB8 ((uint32_t)0x00000100)
• #define CAN_F8R1_FB9 ((uint32_t)0x00000200)
• #define CAN_F8R1_FB10 ((uint32_t)0x00000400)
• #define CAN_F8R1_FB11 ((uint32_t)0x00000800)
• #define CAN_F8R1_FB12 ((uint32_t)0x00001000)
```

- #define CAN\_F8R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F8R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F8R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F8R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F8R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F8R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F8R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F8R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F8R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F8R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F8R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F8R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F8R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F8R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F8R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F8R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F8R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F8R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F8R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F9R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F9R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F9R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F9R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F9R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F9R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F9R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F9R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F9R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F9R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F9R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F9R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F9R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F9R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F9R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F9R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F9R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F9R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F9R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F9R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F9R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F9R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F9R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F9R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F9R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F9R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F9R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F9R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F9R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F9R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F9R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F9R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F10R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F10R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F10R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F10R1\_FB3 ((uint32\_t)0x00000008)

- #define CAN\_F10R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F10R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F10R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F10R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F10R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F10R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F10R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F10R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F10R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F10R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F10R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F10R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F10R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F10R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F10R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F10R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F10R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F10R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F10R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F10R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F10R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F10R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F10R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F10R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F10R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F10R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F10R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F10R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F11R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F11R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F11R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F11R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F11R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F11R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F11R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F11R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F11R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F11R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F11R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F11R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F11R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F11R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F11R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F11R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F11R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F11R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F11R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F11R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F11R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F11R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F11R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F11R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F11R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F11R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F11R1\_FB26 ((uint32\_t)0x04000000)

- #define CAN\_F11R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F11R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F11R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F11R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F11R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F12R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F12R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F12R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F12R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F12R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F12R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F12R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F12R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F12R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F12R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F12R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F12R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F12R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F12R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F12R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F12R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F12R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F12R1\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F12R1\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F12R1\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F12R1\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F12R1\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F12R1\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F12R1\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F12R1\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F12R1\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F12R1\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F12R1\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F12R1\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F12R1\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F12R1\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F12R1\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F13R1\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F13R1\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F13R1\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F13R1\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F13R1\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F13R1\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F13R1\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F13R1\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F13R1\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F13R1\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F13R1\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F13R1\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F13R1\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F13R1\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F13R1\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F13R1\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F13R1\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F13R1\_FB17 ((uint32\_t)0x00020000)

```
• #define CAN_F13R1_FB18 ((uint32_t)0x00040000)
• #define CAN_F13R1_FB19 ((uint32_t)0x00080000)
• #define CAN_F13R1_FB20 ((uint32_t)0x00100000)
• #define CAN_F13R1_FB21 ((uint32_t)0x00200000)
• #define CAN_F13R1_FB22 ((uint32_t)0x00400000)
• #define CAN_F13R1_FB23 ((uint32_t)0x00800000)
• #define CAN_F13R1_FB24 ((uint32_t)0x01000000)
• #define CAN_F13R1_FB25 ((uint32_t)0x02000000)
• #define CAN_F13R1_FB26 ((uint32_t)0x04000000)
• #define CAN_F13R1_FB27 ((uint32_t)0x08000000)
• #define CAN_F13R1_FB28 ((uint32_t)0x10000000)
• #define CAN_F13R1_FB29 ((uint32_t)0x20000000)
• #define CAN_F13R1_FB30 ((uint32_t)0x40000000)
• #define CAN_F13R1_FB31 ((uint32_t)0x80000000)
• #define CAN_F0R2_FB0 ((uint32_t)0x00000001)
• #define CAN_F0R2_FB1 ((uint32_t)0x00000002)
• #define CAN_F0R2_FB2 ((uint32_t)0x00000004)
• #define CAN_F0R2_FB3 ((uint32_t)0x00000008)
• #define CAN_F0R2_FB4 ((uint32_t)0x00000010)
• #define CAN_F0R2_FB5 ((uint32_t)0x00000020)
• #define CAN_F0R2_FB6 ((uint32_t)0x00000040)
• #define CAN_F0R2_FB7 ((uint32_t)0x00000080)
• #define CAN_F0R2_FB8 ((uint32_t)0x00000100)
• #define CAN_F0R2_FB9 ((uint32_t)0x00000200)
• #define CAN_F0R2_FB10 ((uint32_t)0x00000400)
• #define CAN_F0R2_FB11 ((uint32_t)0x00000800)
• #define CAN_F0R2_FB12 ((uint32_t)0x00001000)
• #define CAN_F0R2_FB13 ((uint32_t)0x00002000)
• #define CAN_F0R2_FB14 ((uint32_t)0x00004000)
• #define CAN_F0R2_FB15 ((uint32_t)0x00008000)
• #define CAN_F0R2_FB16 ((uint32_t)0x00010000)
• #define CAN_F0R2_FB17 ((uint32_t)0x00020000)
• #define CAN_F0R2_FB18 ((uint32_t)0x00040000)
• #define CAN_F0R2_FB19 ((uint32_t)0x00080000)
• #define CAN_F0R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F0R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F0R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F0R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F0R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F0R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F0R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F0R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F0R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F0R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F0R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F0R2_FB31 ((uint32_t)0x80000000)
• #define CAN_F1R2_FB0 ((uint32_t)0x00000001)
• #define CAN_F1R2_FB1 ((uint32_t)0x00000002)
• #define CAN_F1R2_FB2 ((uint32_t)0x00000004)
• #define CAN_F1R2_FB3 ((uint32_t)0x00000008)
• #define CAN_F1R2_FB4 ((uint32_t)0x00000010)
• #define CAN_F1R2_FB5 ((uint32_t)0x00000020)
• #define CAN_F1R2_FB6 ((uint32_t)0x00000040)
• #define CAN_F1R2_FB7 ((uint32_t)0x00000080)
• #define CAN_F1R2_FB8 ((uint32_t)0x00000100)
```

```
• #define CAN_F1R2_FB9 ((uint32_t)0x00000200)
• #define CAN_F1R2_FB10 ((uint32_t)0x00000400)
• #define CAN_F1R2_FB11 ((uint32_t)0x00000800)
• #define CAN_F1R2_FB12 ((uint32_t)0x00001000)
• #define CAN_F1R2_FB13 ((uint32_t)0x00002000)
• #define CAN_F1R2_FB14 ((uint32_t)0x00004000)
• #define CAN_F1R2_FB15 ((uint32_t)0x00008000)
• #define CAN_F1R2_FB16 ((uint32_t)0x00010000)
• #define CAN_F1R2_FB17 ((uint32_t)0x00020000)
• #define CAN_F1R2_FB18 ((uint32_t)0x00040000)
• #define CAN_F1R2_FB19 ((uint32_t)0x00080000)
• #define CAN_F1R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F1R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F1R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F1R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F1R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F1R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F1R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F1R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F1R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F1R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F1R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F1R2_FB31 ((uint32_t)0x80000000)
• #define CAN_F2R2_FB0 ((uint32_t)0x00000001)
• #define CAN_F2R2_FB1 ((uint32_t)0x00000002)
• #define CAN_F2R2_FB2 ((uint32_t)0x00000004)
• #define CAN_F2R2_FB3 ((uint32_t)0x00000008)
• #define CAN_F2R2_FB4 ((uint32_t)0x00000010)
• #define CAN_F2R2_FB5 ((uint32_t)0x00000020)
• #define CAN_F2R2_FB6 ((uint32_t)0x00000040)
• #define CAN_F2R2_FB7 ((uint32_t)0x00000080)
• #define CAN_F2R2_FB8 ((uint32_t)0x00000100)
• #define CAN_F2R2_FB9 ((uint32_t)0x00000200)
• #define CAN_F2R2_FB10 ((uint32_t)0x00000400)
• #define CAN_F2R2_FB11 ((uint32_t)0x00000800)
• #define CAN_F2R2_FB12 ((uint32_t)0x00001000)
• #define CAN_F2R2_FB13 ((uint32_t)0x00002000)
• #define CAN_F2R2_FB14 ((uint32_t)0x00004000)
• #define CAN_F2R2_FB15 ((uint32_t)0x00008000)
• #define CAN_F2R2_FB16 ((uint32_t)0x00010000)
• #define CAN_F2R2_FB17 ((uint32_t)0x00020000)
• #define CAN_F2R2_FB18 ((uint32_t)0x00040000)
• #define CAN_F2R2_FB19 ((uint32_t)0x00080000)
• #define CAN_F2R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F2R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F2R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F2R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F2R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F2R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F2R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F2R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F2R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F2R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F2R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F2R2_FB31 ((uint32_t)0x80000000)
```

- #define CAN\_F3R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F3R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F3R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F3R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F3R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F3R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F3R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F3R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F3R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F3R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F3R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F3R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F3R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F3R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F3R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F3R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F3R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F3R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F3R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F3R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F3R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F3R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F3R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F3R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F3R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F3R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F3R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F3R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F3R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F3R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F3R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F3R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F4R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F4R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F4R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F4R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F4R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F4R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F4R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F4R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F4R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F4R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F4R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F4R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F4R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F4R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F4R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F4R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F4R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F4R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F4R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F4R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F4R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F4R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F4R2\_FB22 ((uint32\_t)0x00400000)

```
• #define CAN_F4R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F4R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F4R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F4R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F4R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F4R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F4R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F4R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F4R2_FB31 ((uint32_t)0x80000000)
• #define CAN_F5R2_FB0 ((uint32_t)0x00000001)
• #define CAN_F5R2_FB1 ((uint32_t)0x00000002)
• #define CAN_F5R2_FB2 ((uint32_t)0x00000004)
• #define CAN_F5R2_FB3 ((uint32_t)0x00000008)
• #define CAN_F5R2_FB4 ((uint32_t)0x00000010)
• #define CAN_F5R2_FB5 ((uint32_t)0x00000020)
• #define CAN_F5R2_FB6 ((uint32_t)0x00000040)
• #define CAN_F5R2_FB7 ((uint32_t)0x00000080)
• #define CAN_F5R2_FB8 ((uint32_t)0x00000100)
• #define CAN_F5R2_FB9 ((uint32_t)0x00000200)
• #define CAN_F5R2_FB10 ((uint32_t)0x00000400)
• #define CAN_F5R2_FB11 ((uint32_t)0x00000800)
• #define CAN_F5R2_FB12 ((uint32_t)0x00001000)
• #define CAN_F5R2_FB13 ((uint32_t)0x00002000)
• #define CAN_F5R2_FB14 ((uint32_t)0x00004000)
• #define CAN_F5R2_FB15 ((uint32_t)0x00008000)
• #define CAN_F5R2_FB16 ((uint32_t)0x00010000)
• #define CAN_F5R2_FB17 ((uint32_t)0x00020000)
• #define CAN_F5R2_FB18 ((uint32_t)0x00040000)
• #define CAN_F5R2_FB19 ((uint32_t)0x00080000)
• #define CAN_F5R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F5R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F5R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F5R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F5R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F5R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F5R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F5R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F5R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F5R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F5R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F5R2_FB31 ((uint32_t)0x80000000)
• #define CAN_F6R2_FB0 ((uint32_t)0x00000001)
• #define CAN_F6R2_FB1 ((uint32_t)0x00000002)
• #define CAN_F6R2_FB2 ((uint32_t)0x00000004)
• #define CAN_F6R2_FB3 ((uint32_t)0x00000008)
• #define CAN_F6R2_FB4 ((uint32_t)0x00000010)
• #define CAN_F6R2_FB5 ((uint32_t)0x00000020)
• #define CAN_F6R2_FB6 ((uint32_t)0x00000040)
• #define CAN_F6R2_FB7 ((uint32_t)0x00000080)
• #define CAN_F6R2_FB8 ((uint32_t)0x00000100)
• #define CAN_F6R2_FB9 ((uint32_t)0x00000200)
• #define CAN_F6R2_FB10 ((uint32_t)0x00000400)
• #define CAN_F6R2_FB11 ((uint32_t)0x00000800)
• #define CAN_F6R2_FB12 ((uint32_t)0x00001000)
• #define CAN_F6R2_FB13 ((uint32_t)0x00002000)
```

```
• #define CAN_F6R2_FB14 ((uint32_t)0x00004000)
• #define CAN_F6R2_FB15 ((uint32_t)0x00008000)
• #define CAN_F6R2_FB16 ((uint32_t)0x00010000)
• #define CAN_F6R2_FB17 ((uint32_t)0x00020000)
• #define CAN_F6R2_FB18 ((uint32_t)0x00040000)
• #define CAN_F6R2_FB19 ((uint32_t)0x00080000)
• #define CAN_F6R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F6R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F6R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F6R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F6R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F6R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F6R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F6R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F6R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F6R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F6R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F6R2_FB31 ((uint32_t)0x80000000)
• #define CAN_F7R2_FB0 ((uint32_t)0x00000001)
• #define CAN_F7R2_FB1 ((uint32_t)0x00000002)
• #define CAN_F7R2_FB2 ((uint32_t)0x00000004)
• #define CAN_F7R2_FB3 ((uint32_t)0x00000008)
• #define CAN_F7R2_FB4 ((uint32_t)0x00000010)
• #define CAN_F7R2_FB5 ((uint32_t)0x00000020)
• #define CAN_F7R2_FB6 ((uint32_t)0x00000040)
• #define CAN_F7R2_FB7 ((uint32_t)0x00000080)
• #define CAN_F7R2_FB8 ((uint32_t)0x00000100)
• #define CAN_F7R2_FB9 ((uint32_t)0x00000200)
• #define CAN_F7R2_FB10 ((uint32_t)0x00000400)
• #define CAN_F7R2_FB11 ((uint32_t)0x00000800)
• #define CAN_F7R2_FB12 ((uint32_t)0x00001000)
• #define CAN_F7R2_FB13 ((uint32_t)0x00002000)
• #define CAN_F7R2_FB14 ((uint32_t)0x00004000)
• #define CAN_F7R2_FB15 ((uint32_t)0x00008000)
• #define CAN_F7R2_FB16 ((uint32_t)0x00010000)
• #define CAN_F7R2_FB17 ((uint32_t)0x00020000)
• #define CAN_F7R2_FB18 ((uint32_t)0x00040000)
• #define CAN_F7R2_FB19 ((uint32_t)0x00080000)
• #define CAN_F7R2_FB20 ((uint32_t)0x00100000)
• #define CAN_F7R2_FB21 ((uint32_t)0x00200000)
• #define CAN_F7R2_FB22 ((uint32_t)0x00400000)
• #define CAN_F7R2_FB23 ((uint32_t)0x00800000)
• #define CAN_F7R2_FB24 ((uint32_t)0x01000000)
• #define CAN_F7R2_FB25 ((uint32_t)0x02000000)
• #define CAN_F7R2_FB26 ((uint32_t)0x04000000)
• #define CAN_F7R2_FB27 ((uint32_t)0x08000000)
• #define CAN_F7R2_FB28 ((uint32_t)0x10000000)
• #define CAN_F7R2_FB29 ((uint32_t)0x20000000)
• #define CAN_F7R2_FB30 ((uint32_t)0x40000000)
• #define CAN_F7R2_FB31 ((uint32_t)0x80000000)
• #define CAN_F8R2_FB0 ((uint32_t)0x00000001)
• #define CAN_F8R2_FB1 ((uint32_t)0x00000002)
• #define CAN_F8R2_FB2 ((uint32_t)0x00000004)
• #define CAN_F8R2_FB3 ((uint32_t)0x00000008)
• #define CAN_F8R2_FB4 ((uint32_t)0x00000010)
```

- #define CAN\_F8R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F8R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F8R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F8R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F8R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F8R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F8R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F8R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F8R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F8R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F8R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F8R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F8R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F8R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F8R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F8R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F8R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F8R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F8R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F8R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F8R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F8R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F8R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F8R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F8R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F8R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F8R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F9R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F9R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F9R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F9R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F9R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F9R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F9R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F9R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F9R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F9R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F9R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F9R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F9R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F9R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F9R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F9R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F9R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F9R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F9R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F9R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F9R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F9R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F9R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F9R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F9R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F9R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F9R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F9R2\_FB27 ((uint32\_t)0x08000000)

- #define CAN\_F9R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F9R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F9R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F9R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F10R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F10R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F10R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F10R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F10R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F10R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F10R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F10R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F10R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F10R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F10R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F10R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F10R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F10R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F10R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F10R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F10R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F10R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F10R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F10R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F10R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F10R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F10R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F10R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F10R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F10R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F10R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F10R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F10R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F10R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F10R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F10R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F11R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F11R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F11R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F11R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F11R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F11R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F11R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F11R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F11R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F11R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F11R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F11R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F11R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F11R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F11R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F11R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F11R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F11R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F11R2\_FB18 ((uint32\_t)0x00040000)

- #define CAN\_F11R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F11R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F11R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F11R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F11R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F11R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F11R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F11R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F11R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F11R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F11R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F11R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F11R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F12R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F12R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F12R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F12R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F12R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F12R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F12R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F12R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F12R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F12R2\_FB9 ((uint32\_t)0x00000200)
- #define CAN\_F12R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F12R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F12R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F12R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F12R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F12R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F12R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F12R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F12R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F12R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F12R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F12R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F12R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F12R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F12R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F12R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F12R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F12R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F12R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F12R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F12R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F12R2\_FB31 ((uint32\_t)0x80000000)
- #define CAN\_F13R2\_FB0 ((uint32\_t)0x00000001)
- #define CAN\_F13R2\_FB1 ((uint32\_t)0x00000002)
- #define CAN\_F13R2\_FB2 ((uint32\_t)0x00000004)
- #define CAN\_F13R2\_FB3 ((uint32\_t)0x00000008)
- #define CAN\_F13R2\_FB4 ((uint32\_t)0x00000010)
- #define CAN\_F13R2\_FB5 ((uint32\_t)0x00000020)
- #define CAN\_F13R2\_FB6 ((uint32\_t)0x00000040)
- #define CAN\_F13R2\_FB7 ((uint32\_t)0x00000080)
- #define CAN\_F13R2\_FB8 ((uint32\_t)0x00000100)
- #define CAN\_F13R2\_FB9 ((uint32\_t)0x00000200)

- #define CAN\_F13R2\_FB10 ((uint32\_t)0x00000400)
- #define CAN\_F13R2\_FB11 ((uint32\_t)0x00000800)
- #define CAN\_F13R2\_FB12 ((uint32\_t)0x00001000)
- #define CAN\_F13R2\_FB13 ((uint32\_t)0x00002000)
- #define CAN\_F13R2\_FB14 ((uint32\_t)0x00004000)
- #define CAN\_F13R2\_FB15 ((uint32\_t)0x00008000)
- #define CAN\_F13R2\_FB16 ((uint32\_t)0x00010000)
- #define CAN\_F13R2\_FB17 ((uint32\_t)0x00020000)
- #define CAN\_F13R2\_FB18 ((uint32\_t)0x00040000)
- #define CAN\_F13R2\_FB19 ((uint32\_t)0x00080000)
- #define CAN\_F13R2\_FB20 ((uint32\_t)0x00100000)
- #define CAN\_F13R2\_FB21 ((uint32\_t)0x00200000)
- #define CAN\_F13R2\_FB22 ((uint32\_t)0x00400000)
- #define CAN\_F13R2\_FB23 ((uint32\_t)0x00800000)
- #define CAN\_F13R2\_FB24 ((uint32\_t)0x01000000)
- #define CAN\_F13R2\_FB25 ((uint32\_t)0x02000000)
- #define CAN\_F13R2\_FB26 ((uint32\_t)0x04000000)
- #define CAN\_F13R2\_FB27 ((uint32\_t)0x08000000)
- #define CAN\_F13R2\_FB28 ((uint32\_t)0x10000000)
- #define CAN\_F13R2\_FB29 ((uint32\_t)0x20000000)
- #define CAN\_F13R2\_FB30 ((uint32\_t)0x40000000)
- #define CAN\_F13R2\_FB31 ((uint32\_t)0x80000000)
- #define CRC\_DR\_DR ((uint32\_t)0xFFFFFFFF)
- #define CRC\_IDR\_IDR ((uint8\_t)0xFF)
- #define CRYP\_CR\_RESET ((uint8\_t)0x01)
- #define CRYP\_CR\_ALGODIR ((uint32\_t)0x00000004)
- #define CRYP\_CR\_ALGOMODE ((uint32\_t)0x00080038)
- #define CRYP\_CR\_ALGOMODE\_0 ((uint32\_t)0x00000008)
- #define CRYP\_CR\_ALGOMODE\_1 ((uint32\_t)0x00000010)
- #define CRYP\_CR\_ALGOMODE\_2 ((uint32\_t)0x00000020)
- #define CRYP\_CR\_ALGOMODE\_TDES\_ECB ((uint32\_t)0x00000000)
- #define CRYP\_CR\_ALGOMODE\_TDES\_CBC ((uint32\_t)0x00000008)
- #define CRYP\_CR\_ALGOMODE\_DES\_ECB ((uint32\_t)0x00000010)
- #define CRYP\_CR\_ALGOMODE\_DES\_CBC ((uint32\_t)0x00000018)
- #define CRYP\_CR\_ALGOMODE\_AES\_ECB ((uint32\_t)0x00000020)
- #define CRYP\_CR\_ALGOMODE\_AES\_CBC ((uint32\_t)0x00000028)
- #define CRYP\_CR\_ALGOMODE\_AES\_CTR ((uint32\_t)0x00000030)
- #define CRYP\_CR\_ALGOMODE\_AES\_KEY ((uint32\_t)0x00000038)
- #define CRYP\_CR\_DATATYPE ((uint32\_t)0x000000C0)
- #define CRYP\_CR\_DATATYPE\_0 ((uint32\_t)0x00000040)
- #define CRYP\_CR\_DATATYPE\_1 ((uint32\_t)0x00000080)
- #define CRYP\_CR\_KEYSIZE ((uint32\_t)0x00000300)
- #define CRYP\_CR\_KEYSIZE\_0 ((uint32\_t)0x00000100)
- #define CRYP\_CR\_KEYSIZE\_1 ((uint32\_t)0x00000200)
- #define CRYP\_CR\_FFLUSH ((uint32\_t)0x00004000)
- #define CRYP\_CR\_CRYPTEN ((uint32\_t)0x00008000)
- #define CRYP\_CR\_GCM\_CCMPH ((uint32\_t)0x00030000)
- #define CRYP\_CR\_GCM\_CCMPH\_0 ((uint32\_t)0x00010000)
- #define CRYP\_CR\_GCM\_CCMPH\_1 ((uint32\_t)0x00020000)
- #define CRYP\_CR\_ALGOMODE\_3 ((uint32\_t)0x00080000)
- #define CRYP\_SR\_IFEM ((uint32\_t)0x00000001)
- #define CRYP\_SR\_IFNF ((uint32\_t)0x00000002)
- #define CRYP\_SR\_OFNE ((uint32\_t)0x00000004)
- #define CRYP\_SR\_OFFU ((uint32\_t)0x00000008)
- #define CRYP\_SR\_BUSY ((uint32\_t)0x00000010)

- #define **CRYP\_DMACR\_DIEN** ((uint32\_t)0x00000001)
- #define **CRYP\_DMACR\_DOEN** ((uint32\_t)0x00000002)
- #define **CRYP\_IMSCR\_INIM** ((uint32\_t)0x00000001)
- #define **CRYP\_IMSCR\_OUTIM** ((uint32\_t)0x00000002)
- #define **CRYP\_RISR\_OUTRIS** ((uint32\_t)0x00000001)
- #define **CRYP\_RISR\_INRIS** ((uint32\_t)0x00000002)
- #define **CRYP\_MISR\_INMIS** ((uint32\_t)0x00000001)
- #define **CRYP\_MISR\_OUTMIS** ((uint32\_t)0x00000002)
- #define **DAC\_CR\_EN1** ((uint32\_t)0x00000001)
- #define **DAC\_CR\_BOFF1** ((uint32\_t)0x00000002)
- #define **DAC\_CR\_TEN1** ((uint32\_t)0x00000004)
- #define **DAC\_CR\_TSEL1** ((uint32\_t)0x00000038)
- #define **DAC\_CR\_TSEL1\_0** ((uint32\_t)0x00000008)
- #define **DAC\_CR\_TSEL1\_1** ((uint32\_t)0x00000010)
- #define **DAC\_CR\_TSEL1\_2** ((uint32\_t)0x00000020)
- #define **DAC\_CR\_WAVE1** ((uint32\_t)0x000000C0)
- #define **DAC\_CR\_WAVE1\_0** ((uint32\_t)0x00000040)
- #define **DAC\_CR\_WAVE1\_1** ((uint32\_t)0x00000080)
- #define **DAC\_CR\_MAMP1** ((uint32\_t)0x00000F00)
- #define **DAC\_CR\_MAMP1\_0** ((uint32\_t)0x00000100)
- #define **DAC\_CR\_MAMP1\_1** ((uint32\_t)0x00000200)
- #define **DAC\_CR\_MAMP1\_2** ((uint32\_t)0x00000400)
- #define **DAC\_CR\_MAMP1\_3** ((uint32\_t)0x00000800)
- #define **DAC\_CR\_DMAEN1** ((uint32\_t)0x00001000)
- #define **DAC\_CR\_DMAUDRIE1** ((uint32\_t)0x00002000)
- #define **DAC\_CR\_EN2** ((uint32\_t)0x00010000)
- #define **DAC\_CR\_BOFF2** ((uint32\_t)0x00020000)
- #define **DAC\_CR\_TEN2** ((uint32\_t)0x00040000)
- #define **DAC\_CR\_TSEL2** ((uint32\_t)0x00380000)
- #define **DAC\_CR\_TSEL2\_0** ((uint32\_t)0x00080000)
- #define **DAC\_CR\_TSEL2\_1** ((uint32\_t)0x00100000)
- #define **DAC\_CR\_TSEL2\_2** ((uint32\_t)0x00200000)
- #define **DAC\_CR\_WAVE2** ((uint32\_t)0x00C00000)
- #define **DAC\_CR\_WAVE2\_0** ((uint32\_t)0x00400000)
- #define **DAC\_CR\_WAVE2\_1** ((uint32\_t)0x00800000)
- #define **DAC\_CR\_MAMP2** ((uint32\_t)0x0F000000)
- #define **DAC\_CR\_MAMP2\_0** ((uint32\_t)0x01000000)
- #define **DAC\_CR\_MAMP2\_1** ((uint32\_t)0x02000000)
- #define **DAC\_CR\_MAMP2\_2** ((uint32\_t)0x04000000)
- #define **DAC\_CR\_MAMP2\_3** ((uint32\_t)0x08000000)
- #define **DAC\_CR\_DMAEN2** ((uint32\_t)0x10000000)
- #define **DAC\_CR\_DMAUDRIE2** ((uint32\_t)0x20000000U)
- #define **DAC\_SWTRIGR\_SWTRIG1** ((uint8\_t)0x01)
- #define **DAC\_SWTRIGR\_SWTRIG2** ((uint8\_t)0x02)
- #define **DAC\_DHR12R1\_DACC1DHR** ((uint16\_t)0xFFFF)
- #define **DAC\_DHR12L1\_DACC1DHR** ((uint16\_t)0xFFFF0)
- #define **DAC\_DHR8R1\_DACC1DHR** ((uint8\_t)0xFF)
- #define **DAC\_DHR12R2\_DACC2DHR** ((uint16\_t)0xFFFF)
- #define **DAC\_DHR12L2\_DACC2DHR** ((uint16\_t)0xFFFF0)
- #define **DAC\_DHR8R2\_DACC2DHR** ((uint8\_t)0xFF)
- #define **DAC\_DHR12RD\_DACC1DHR** ((uint32\_t)0x00000FFF)
- #define **DAC\_DHR12RD\_DACC2DHR** ((uint32\_t)0x0FFF0000)
- #define **DAC\_DHR12LD\_DACC1DHR** ((uint32\_t)0x0000FFF0)
- #define **DAC\_DHR12LD\_DACC2DHR** ((uint32\_t)0xFFFF0000)
- #define **DAC\_DHR8RD\_DACC1DHR** ((uint16\_t)0x00FF)

- #define **DAC\_DHR8RD\_DACC2DHR** ((uint16\_t)0xFF00)
- #define **DAC\_DOR1\_DACC1DOR** ((uint16\_t)0xFFFF)
- #define **DAC\_DOR2\_DACC2DOR** ((uint16\_t)0xFFFF)
- #define **DAC\_SR\_DMAUDR1** ((uint32\_t)0x00002000)
- #define **DAC\_SR\_DMAUDR2** ((uint32\_t)0x20000000)
- #define **DCMI\_CR\_CAPTURE** ((uint32\_t)0x00000001)
- #define **DCMI\_CR\_CM** ((uint32\_t)0x00000002)
- #define **DCMI\_CR\_CROP** ((uint32\_t)0x00000004)
- #define **DCMI\_CR\_JPEG** ((uint32\_t)0x00000008)
- #define **DCMI\_CR\_ESS** ((uint32\_t)0x00000010)
- #define **DCMI\_CR\_PCKPOL** ((uint32\_t)0x00000020)
- #define **DCMI\_CR\_HSPOL** ((uint32\_t)0x00000040)
- #define **DCMI\_CR\_VSPOL** ((uint32\_t)0x00000080)
- #define **DCMI\_CR\_FCRC\_0** ((uint32\_t)0x00000100)
- #define **DCMI\_CR\_FCRC\_1** ((uint32\_t)0x00000200)
- #define **DCMI\_CR\_EDM\_0** ((uint32\_t)0x00000400)
- #define **DCMI\_CR\_EDM\_1** ((uint32\_t)0x00000800)
- #define **DCMI\_CR\_CRE** ((uint32\_t)0x00001000)
- #define **DCMI\_CR\_ENABLE** ((uint32\_t)0x00004000)
- #define **DCMI\_SR\_HSYNC** ((uint32\_t)0x00000001)
- #define **DCMI\_SR\_VSYNC** ((uint32\_t)0x00000002)
- #define **DCMI\_SR\_FNE** ((uint32\_t)0x00000004)
- #define **DCMI\_RIS\_FRAME\_RIS** ((uint32\_t)0x00000001)
- #define **DCMI\_RIS\_OVR\_RIS** ((uint32\_t)0x00000002)
- #define **DCMI\_RIS\_ERR\_RIS** ((uint32\_t)0x00000004)
- #define **DCMI\_RIS\_VSYNC\_RIS** ((uint32\_t)0x00000008)
- #define **DCMI\_RIS\_LINE\_RIS** ((uint32\_t)0x00000010)
- #define **DCMI\_RISR\_FRAME\_RIS** DCMI\_RIS\_FRAME\_RIS
- #define **DCMI\_RISR\_OVR\_RIS** DCMI\_RIS\_OVR\_RIS
- #define **DCMI\_RISR\_ERR\_RIS** DCMI\_RIS\_ERR\_RIS
- #define **DCMI\_RISR\_VSYNC\_RIS** DCMI\_RIS\_VSYNC\_RIS
- #define **DCMI\_RISR\_LINE\_RIS** DCMI\_RIS\_LINE\_RIS
- #define **DCMI\_RISR\_OVF\_RIS** DCMI\_RIS\_OVR\_RIS
- #define **DCMI\_IER\_FRAME\_IE** ((uint32\_t)0x00000001)
- #define **DCMI\_IER\_OVR\_IE** ((uint32\_t)0x00000002)
- #define **DCMI\_IER\_ERR\_IE** ((uint32\_t)0x00000004)
- #define **DCMI\_IER\_VSYNC\_IE** ((uint32\_t)0x00000008)
- #define **DCMI\_IER\_LINE\_IE** ((uint32\_t)0x00000010)
- #define **DCMI\_IER\_OVF\_IE** DCMI\_IER\_OVR\_IE
- #define **DCMI\_MIS\_FRAME\_MIS** ((uint32\_t)0x00000001)
- #define **DCMI\_MIS\_OVR\_MIS** ((uint32\_t)0x00000002)
- #define **DCMI\_MIS\_ERR\_MIS** ((uint32\_t)0x00000004)
- #define **DCMI\_MIS\_VSYNC\_MIS** ((uint32\_t)0x00000008)
- #define **DCMI\_MIS\_LINE\_MIS** ((uint32\_t)0x00000010)
- #define **DCMI\_MISR\_FRAME\_MIS** DCMI\_MIS\_FRAME\_MIS
- #define **DCMI\_MISR\_OVF\_MIS** DCMI\_MIS\_OVR\_MIS
- #define **DCMI\_MISR\_ERR\_MIS** DCMI\_MIS\_ERR\_MIS
- #define **DCMI\_MISR\_VSYNC\_MIS** DCMI\_MIS\_VSYNC\_MIS
- #define **DCMI\_MISR\_LINE\_MIS** DCMI\_MIS\_LINE\_MIS
- #define **DCMI\_ICR\_FRAME\_ISC** ((uint32\_t)0x00000001)
- #define **DCMI\_ICR\_OVR\_ISC** ((uint32\_t)0x00000002)
- #define **DCMI\_ICR\_ERR\_ISC** ((uint32\_t)0x00000004)
- #define **DCMI\_ICR\_VSYNC\_ISC** ((uint32\_t)0x00000008)
- #define **DCMI\_ICR\_LINE\_ISC** ((uint32\_t)0x00000010)
- #define **DCMI\_ICR\_OVF\_ISC** DCMI\_ICR\_OVR\_ISC

```
• #define DCMI_ESCR_FSC ((uint32_t)0x000000FF)
• #define DCMI_ESCR_LSC ((uint32_t)0x0000FF00)
• #define DCMI_ESCR_LEC ((uint32_t)0x00FF0000)
• #define DCMI_ESCR_FEC ((uint32_t)0xFF000000)
• #define DCMI_ESUR_FSU ((uint32_t)0x000000FF)
• #define DCMI_ESUR_LSU ((uint32_t)0x0000FF00)
• #define DCMI_ESUR_LEU ((uint32_t)0x00FF0000)
• #define DCMI_ESUR_FEU ((uint32_t)0xFF000000)
• #define DCMI_CWSTRT_HOFFCNT ((uint32_t)0x00003FFF)
• #define DCMI_CWSTRT_VST ((uint32_t)0x1FFF0000)
• #define DCMI_CWSIZE_CAPCNT ((uint32_t)0x00003FFF)
• #define DCMI_CWSIZE_VLINE ((uint32_t)0x3FFF0000)
• #define DCMI_DR_BYTE0 ((uint32_t)0x000000FF)
• #define DCMI_DR_BYTE1 ((uint32_t)0x0000FF00)
• #define DCMI_DR_BYTE2 ((uint32_t)0x00FF0000)
• #define DCMI_DR_BYTE3 ((uint32_t)0xFF000000)
• #define DFSDM_CHCFG1_DFSDMEN ((uint32_t)0x80000000)
• #define DFSDM_CHCFG1_CKOUTSRC ((uint32_t)0x40000000)
• #define DFSDM_CHCFG1_CKOUTDIV ((uint32_t)0x00FF0000)
• #define DFSDM_CHCFG1_DATPACK ((uint32_t)0x0000C000)
• #define DFSDM_CHCFG1_DATPACK_1 ((uint32_t)0x00008000)
• #define DFSDM_CHCFG1_DATPACK_0 ((uint32_t)0x00004000)
• #define DFSDM_CHCFG1_DATMPX ((uint32_t)0x00003000)
• #define DFSDM_CHCFG1_DATMPX_1 ((uint32_t)0x00002000)
• #define DFSDM_CHCFG1_DATMPX_0 ((uint32_t)0x00001000)
• #define DFSDM_CHCFG1_CHINSEL ((uint32_t)0x00000100)
• #define DFSDM_CHCFG1_CHEN ((uint32_t)0x00000080)
• #define DFSDM_CHCFG1_CKABEN ((uint32_t)0x00000040)
• #define DFSDM_CHCFG1_SCDEN ((uint32_t)0x00000020)
• #define DFSDM_CHCFG1_SPICKSEL ((uint32_t)0x0000000C)
• #define DFSDM_CHCFG1_SPICKSEL_1 ((uint32_t)0x00000008)
• #define DFSDM_CHCFG1_SPICKSEL_0 ((uint32_t)0x00000004)
• #define DFSDM_CHCFG1_SITP ((uint32_t)0x00000003)
• #define DFSDM_CHCFG1_SITP_1 ((uint32_t)0x00000002)
• #define DFSDM_CHCFG1_SITP_0 ((uint32_t)0x00000001)
• #define DFSDM_CHCFG2_OFFSET ((uint32_t)0xFFFFFFF0)
• #define DFSDM_CHCFG2_DTRBS ((uint32_t)0x000000F8)
• #define DFSDM_CHAWSCDR_AWFORD ((uint32_t)0x00C00000)
• #define DFSDM_CHAWSCDR_AWFORD_1 ((uint32_t)0x00800000)
• #define DFSDM_CHAWSCDR_AWFORD_0 ((uint32_t)0x00400000)
• #define DFSDM_CHAWSCDR_AWFOSR ((uint32_t)0x001F0000)
• #define DFSDM_CHAWSCDR_BKSCD ((uint32_t)0x0000F000)
• #define DFSDM_CHAWSCDR_SCDT ((uint32_t)0x000000FF)
• #define DFSDM_CHWDATR_WDATA ((uint32_t)0x0000FFFF)
• #define DFSDM_CHDATINR_INDATA0 ((uint32_t)0x0000FFFF)
• #define DFSDM_CHDATINR_INDATA1 ((uint32_t)0xFFFF0000)
• #define DFSDM_FLTCR1_AWFSEL ((uint32_t)0x40000000)
• #define DFSDM_FLTCR1_FAST ((uint32_t)0x20000000)
• #define DFSDM_FLTCR1_RCH ((uint32_t)0x07000000)
• #define DFSDM_FLTCR1_RDMAEN ((uint32_t)0x00200000)
• #define DFSDM_FLTCR1_RSYNC ((uint32_t)0x00080000)
• #define DFSDM_FLTCR1_RCONT ((uint32_t)0x00040000)
• #define DFSDM_FLTCR1_RSWSTART ((uint32_t)0x00020000)
• #define DFSDM_FLTCR1_JEXTEN ((uint32_t)0x00006000)
• #define DFSDM_FLTCR1_JEXTEN_1 ((uint32_t)0x00004000)
```

```
• #define DFSDM_FLTCR1_JEXTEN_0 ((uint32_t)0x00002000)
• #define DFSDM_FLTCR1_JEXTSEL ((uint32_t)0x00000700)
• #define DFSDM_FLTCR1_JEXTSEL_2 ((uint32_t)0x00000400)
• #define DFSDM_FLTCR1_JEXTSEL_1 ((uint32_t)0x00000200)
• #define DFSDM_FLTCR1_JEXTSEL_0 ((uint32_t)0x00000100)
• #define DFSDM_FLTCR1_JDMAEN ((uint32_t)0x00000020)
• #define DFSDM_FLTCR1_JSCAN ((uint32_t)0x00000010)
• #define DFSDM_FLTCR1_JSYNC ((uint32_t)0x00000008)
• #define DFSDM_FLTCR1_JSWSTART ((uint32_t)0x00000002)
• #define DFSDM_FLTCR1_DFEN ((uint32_t)0x00000001)
• #define DFSDM_FLTCR2_AWDCH ((uint32_t)0x000F0000)
• #define DFSDM_FLTCR2_EXCH ((uint32_t)0x00000F00)
• #define DFSDM_FLTCR2_CKABIE ((uint32_t)0x00000040)
• #define DFSDM_FLTCR2_SCDIE ((uint32_t)0x00000020)
• #define DFSDM_FLTCR2_AWDIE ((uint32_t)0x00000010)
• #define DFSDM_FLTCR2_ROVRIE ((uint32_t)0x00000008)
• #define DFSDM_FLTCR2_JOVRIE ((uint32_t)0x00000004)
• #define DFSDM_FLTCR2_REOCIE ((uint32_t)0x00000002)
• #define DFSDM_FLTCR2_JEOCIE ((uint32_t)0x00000001)
• #define DFSDM_FLTISR_SCDF ((uint32_t)0x0F000000)
• #define DFSDM_FLTISR_CKABF ((uint32_t)0x000F0000)
• #define DFSDM_FLTISR_RCIP ((uint32_t)0x00004000)
• #define DFSDM_FLTISR_JCIP ((uint32_t)0x00002000)
• #define DFSDM_FLTISR_AWDF ((uint32_t)0x00000010)
• #define DFSDM_FLTISR_ROVRF ((uint32_t)0x00000008)
• #define DFSDM_FLTISR_JOVRF ((uint32_t)0x00000004)
• #define DFSDM_FLTISR_REOCF ((uint32_t)0x00000002)
• #define DFSDM_FLTISR_JEOCF ((uint32_t)0x00000001)
• #define DFSDM_FLTICR_CLRSCSDF ((uint32_t)0x0F000000)
• #define DFSDM_FLTICR_CLRCKABF ((uint32_t)0x000F0000)
• #define DFSDM_FLTICR_CLRROVRF ((uint32_t)0x00000008)
• #define DFSDM_FLTICR_CLRJOVRF ((uint32_t)0x00000004)
• #define DFSDM_FLTJCHGR_JCHG ((uint32_t)0x000000FF)
• #define DFSDM_FLTFCR_FORD ((uint32_t)0xE0000000)
• #define DFSDM_FLTFCR_FORD_2 ((uint32_t)0x80000000)
• #define DFSDM_FLTFCR_FORD_1 ((uint32_t)0x40000000)
• #define DFSDM_FLTFCR_FORD_0 ((uint32_t)0x20000000)
• #define DFSDM_FLTFCR_FOSR ((uint32_t)0x03FF0000)
• #define DFSDM_FLTFCR_IOSR ((uint32_t)0x0000000FF)
• #define DFSDM_FLTJDATAR_JDATA ((uint32_t)0xFFFFFFF00)
• #define DFSDM_FLTJDATAR_JDATACH ((uint32_t)0x000000007)
• #define DFSDM_FLTRDATAR_RDATA ((uint32_t)0xFFFFFFF00)
• #define DFSDM_FLTRDATAR_RPEND ((uint32_t)0x000000010)
• #define DFSDM_FLTRDATAR_RDATAANCH ((uint32_t)0x000000007)
• #define DFSDM_FLTAWHTR_AWHT ((uint32_t)0xFFFFFFF00)
• #define DFSDM_FLTAWHTR_BKAWH ((uint32_t)0x0000000F)
• #define DFSDM_FLTAWLTR_AWLTL ((uint32_t)0xFFFFFFF00)
• #define DFSDM_FLTAWLTR_BKAWL ((uint32_t)0x0000000F)
• #define DFSDM_FLTAWSR_AWHTF ((uint32_t)0x00000F00)
• #define DFSDM_FLTAWSR_AWLTF ((uint32_t)0x0000000F)
• #define DFSDM_FLTAWCFR_CLRAWHTF ((uint32_t)0x000000F00)
• #define DFSDM_FLTAWCFR_CLRAWLTF ((uint32_t)0x0000000F)
• #define DFSDM_FLTEXMAX_EXMAX ((uint32_t)0xFFFFFFF00)
• #define DFSDM_FLTEXMAX_EXMAXCH ((uint32_t)0x00000007)
• #define DFSDM_FLTEXMIN_EXMIN ((uint32_t)0xFFFFFFF00)
```

- #define **DFSDM\_FLTEXMIN\_EXMINCH** ((uint32\_t)0x00000007)
- #define **DFSDM\_FLTCNVTIMR\_CNVCNT** ((uint32\_t)0xFFFFFFF0)
- #define **DMA\_SxCR\_CHSEL** ((uint32\_t)0xE0000000)
- #define **DMA\_SxCR\_CHSEL\_0** ((uint32\_t)0x02000000)
- #define **DMA\_SxCR\_CHSEL\_1** ((uint32\_t)0x04000000)
- #define **DMA\_SxCR\_CHSEL\_2** ((uint32\_t)0x08000000)
- #define **DMA\_SxCR\_MBURST** ((uint32\_t)0x01800000)
- #define **DMA\_SxCR\_MBURST\_0** ((uint32\_t)0x00800000)
- #define **DMA\_SxCR\_MBURST\_1** ((uint32\_t)0x01000000)
- #define **DMA\_SxCR\_PBURST** ((uint32\_t)0x00600000)
- #define **DMA\_SxCR\_PBURST\_0** ((uint32\_t)0x00200000)
- #define **DMA\_SxCR\_PBURST\_1** ((uint32\_t)0x00400000)
- #define **DMA\_SxCR\_ACK** ((uint32\_t)0x00100000)
- #define **DMA\_SxCR\_CT** ((uint32\_t)0x00080000)
- #define **DMA\_SxCR\_DBM** ((uint32\_t)0x00040000)
- #define **DMA\_SxCR\_PL** ((uint32\_t)0x00030000)
- #define **DMA\_SxCR\_PL\_0** ((uint32\_t)0x00010000)
- #define **DMA\_SxCR\_PL\_1** ((uint32\_t)0x00020000)
- #define **DMA\_SxCR\_PINCOS** ((uint32\_t)0x00008000)
- #define **DMA\_SxCR\_MSIZE** ((uint32\_t)0x00006000)
- #define **DMA\_SxCR\_MSIZE\_0** ((uint32\_t)0x00002000)
- #define **DMA\_SxCR\_MSIZE\_1** ((uint32\_t)0x00004000)
- #define **DMA\_SxCR\_PSIZE** ((uint32\_t)0x00001800)
- #define **DMA\_SxCR\_PSIZE\_0** ((uint32\_t)0x00000800)
- #define **DMA\_SxCR\_PSIZE\_1** ((uint32\_t)0x00001000)
- #define **DMA\_SxCR\_MINC** ((uint32\_t)0x0000400)
- #define **DMA\_SxCR\_PINC** ((uint32\_t)0x00000200)
- #define **DMA\_SxCR\_CIRC** ((uint32\_t)0x00000100)
- #define **DMA\_SxCR\_DIR** ((uint32\_t)0x000000C0)
- #define **DMA\_SxCR\_DIR\_0** ((uint32\_t)0x00000040)
- #define **DMA\_SxCR\_DIR\_1** ((uint32\_t)0x00000080)
- #define **DMA\_SxCR\_PFCTRL** ((uint32\_t)0x00000020)
- #define **DMA\_SxCR\_TCIE** ((uint32\_t)0x00000010)
- #define **DMA\_SxCR\_HTIE** ((uint32\_t)0x00000008)
- #define **DMA\_SxCR\_TEIE** ((uint32\_t)0x00000004)
- #define **DMA\_SxCR\_DMEIE** ((uint32\_t)0x00000002)
- #define **DMA\_SxCR\_EN** ((uint32\_t)0x00000001)
- #define **DMA\_SxNDT** ((uint32\_t)0x0000FFFF)
- #define **DMA\_SxNDT\_0** ((uint32\_t)0x00000001)
- #define **DMA\_SxNDT\_1** ((uint32\_t)0x00000002)
- #define **DMA\_SxNDT\_2** ((uint32\_t)0x00000004)
- #define **DMA\_SxNDT\_3** ((uint32\_t)0x00000008)
- #define **DMA\_SxNDT\_4** ((uint32\_t)0x00000010)
- #define **DMA\_SxNDT\_5** ((uint32\_t)0x00000020)
- #define **DMA\_SxNDT\_6** ((uint32\_t)0x00000040)
- #define **DMA\_SxNDT\_7** ((uint32\_t)0x00000080)
- #define **DMA\_SxNDT\_8** ((uint32\_t)0x00000100)
- #define **DMA\_SxNDT\_9** ((uint32\_t)0x00000200)
- #define **DMA\_SxNDT\_10** ((uint32\_t)0x00000400)
- #define **DMA\_SxNDT\_11** ((uint32\_t)0x00000800)
- #define **DMA\_SxNDT\_12** ((uint32\_t)0x00001000)
- #define **DMA\_SxNDT\_13** ((uint32\_t)0x00002000)
- #define **DMA\_SxNDT\_14** ((uint32\_t)0x00004000)
- #define **DMA\_SxNDT\_15** ((uint32\_t)0x00008000)
- #define **DMA\_SxFCR\_FEIE** ((uint32\_t)0x00000080)

- #define **DMA\_SxFCR\_FS** ((uint32\_t)0x00000038)
- #define **DMA\_SxFCR\_FS\_0** ((uint32\_t)0x00000008)
- #define **DMA\_SxFCR\_FS\_1** ((uint32\_t)0x00000010)
- #define **DMA\_SxFCR\_FS\_2** ((uint32\_t)0x00000020)
- #define **DMA\_SxFCR\_DMDIS** ((uint32\_t)0x00000004)
- #define **DMA\_SxFCR\_FTH** ((uint32\_t)0x00000003)
- #define **DMA\_SxFCR\_FTH\_0** ((uint32\_t)0x00000001)
- #define **DMA\_SxFCR\_FTH\_1** ((uint32\_t)0x00000002)
- #define **DMA\_LISR\_TCIF3** ((uint32\_t)0x08000000)
- #define **DMA\_LISR\_HTIF3** ((uint32\_t)0x04000000)
- #define **DMA\_LISR\_TEIF3** ((uint32\_t)0x02000000)
- #define **DMA\_LISR\_DMEIF3** ((uint32\_t)0x01000000)
- #define **DMA\_LISR\_FEIF3** ((uint32\_t)0x00400000)
- #define **DMA\_LISR\_TCIF2** ((uint32\_t)0x00200000)
- #define **DMA\_LISR\_HTIF2** ((uint32\_t)0x00100000)
- #define **DMA\_LISR\_TEIF2** ((uint32\_t)0x00080000)
- #define **DMA\_LISR\_DMEIF2** ((uint32\_t)0x00040000)
- #define **DMA\_LISR\_FEIF2** ((uint32\_t)0x00010000)
- #define **DMA\_LISR\_TCIF1** ((uint32\_t)0x00000800)
- #define **DMA\_LISR\_HTIF1** ((uint32\_t)0x00000400)
- #define **DMA\_LISR\_TEIF1** ((uint32\_t)0x00000200)
- #define **DMA\_LISR\_DMEIF1** ((uint32\_t)0x00000100)
- #define **DMA\_LISR\_FEIF1** ((uint32\_t)0x00000040)
- #define **DMA\_LISR\_TCIF0** ((uint32\_t)0x00000020)
- #define **DMA\_LISR\_Htif0** ((uint32\_t)0x00000010)
- #define **DMA\_LISR\_TEIF0** ((uint32\_t)0x00000008)
- #define **DMA\_LISR\_DMEIF0** ((uint32\_t)0x00000004)
- #define **DMA\_LISR\_FEIF0** ((uint32\_t)0x00000001)
- #define **DMA\_HISR\_TCIF7** ((uint32\_t)0x08000000)
- #define **DMA\_HISR\_HTIF7** ((uint32\_t)0x04000000)
- #define **DMA\_HISR\_TEIF7** ((uint32\_t)0x02000000)
- #define **DMA\_HISR\_DMEIF7** ((uint32\_t)0x01000000)
- #define **DMA\_HISR\_FEIF7** ((uint32\_t)0x00400000)
- #define **DMA\_HISR\_TCIF6** ((uint32\_t)0x00200000)
- #define **DMA\_HISR\_Htif6** ((uint32\_t)0x00100000)
- #define **DMA\_HISR\_TEIF6** ((uint32\_t)0x00080000)
- #define **DMA\_HISR\_DMEIF6** ((uint32\_t)0x00040000)
- #define **DMA\_HISR\_FEIF6** ((uint32\_t)0x00010000)
- #define **DMA\_HISR\_TCIF5** ((uint32\_t)0x00000800)
- #define **DMA\_HISR\_Htif5** ((uint32\_t)0x00000400)
- #define **DMA\_HISR\_TEIF5** ((uint32\_t)0x00000200)
- #define **DMA\_HISR\_DMEIF5** ((uint32\_t)0x00000100)
- #define **DMA\_HISR\_FEIF5** ((uint32\_t)0x00000040)
- #define **DMA\_HISR\_TCIF4** ((uint32\_t)0x00000020)
- #define **DMA\_HISR\_Htif4** ((uint32\_t)0x00000010)
- #define **DMA\_HISR\_TEIF4** ((uint32\_t)0x00000008)
- #define **DMA\_HISR\_DMEIF4** ((uint32\_t)0x00000004)
- #define **DMA\_HISR\_FEIF4** ((uint32\_t)0x00000001)
- #define **DMA\_LIFCR\_CTCIF3** ((uint32\_t)0x08000000)
- #define **DMA\_LIFCR\_CHTIF3** ((uint32\_t)0x04000000)
- #define **DMA\_LIFCR\_CTEIF3** ((uint32\_t)0x02000000)
- #define **DMA\_LIFCR\_CDMEIF3** ((uint32\_t)0x01000000)
- #define **DMA\_LIFCR\_CFEIF3** ((uint32\_t)0x00400000)
- #define **DMA\_LIFCR\_CTCIF2** ((uint32\_t)0x00200000)
- #define **DMA\_LIFCR\_CHTIF2** ((uint32\_t)0x00100000)

```
• #define DMA_LIFCR_CTEIF2 ((uint32_t)0x00080000)
• #define DMA_LIFCR_CDMEIF2 ((uint32_t)0x00040000)
• #define DMA_LIFCR_CFEIF2 ((uint32_t)0x00010000)
• #define DMA_LIFCR_CTCIF1 ((uint32_t)0x00000800)
• #define DMA_LIFCR_CHTIF1 ((uint32_t)0x00000400)
• #define DMA_LIFCR_CTEIF1 ((uint32_t)0x00000200)
• #define DMA_LIFCR_CDMEIF1 ((uint32_t)0x000000100)
• #define DMA_LIFCR_CFEIF1 ((uint32_t)0x00000040)
• #define DMA_LIFCR_CTCIFO ((uint32_t)0x00000020)
• #define DMA_LIFCR_CHTIFO ((uint32_t)0x00000010)
• #define DMA_LIFCR_CTEIFO ((uint32_t)0x00000008)
• #define DMA_LIFCR_CDMEIFO ((uint32_t)0x00000004)
• #define DMA_LIFCR_CFEIFO ((uint32_t)0x00000001)
• #define DMA_HIFCR_CTCIF7 ((uint32_t)0x08000000)
• #define DMA_HIFCR_CHTIF7 ((uint32_t)0x04000000)
• #define DMA_HIFCR_CTEIF7 ((uint32_t)0x02000000)
• #define DMA_HIFCR_CDMEIF7 ((uint32_t)0x01000000)
• #define DMA_HIFCR_CFEIF7 ((uint32_t)0x00400000)
• #define DMA_HIFCR_CTCIF6 ((uint32_t)0x00200000)
• #define DMA_HIFCR_CHTIF6 ((uint32_t)0x00100000)
• #define DMA_HIFCR_CTEIF6 ((uint32_t)0x00080000)
• #define DMA_HIFCR_CDMEIF6 ((uint32_t)0x00040000)
• #define DMA_HIFCR_CFEIF6 ((uint32_t)0x00010000)
• #define DMA_HIFCR_CTCIF5 ((uint32_t)0x00000800)
• #define DMA_HIFCR_CHTIF5 ((uint32_t)0x00000400)
• #define DMA_HIFCR_CTEIF5 ((uint32_t)0x00000200)
• #define DMA_HIFCR_CDMEIF5 ((uint32_t)0x00000100)
• #define DMA_HIFCR_CFEIF5 ((uint32_t)0x00000040)
• #define DMA_HIFCR_CTCIF4 ((uint32_t)0x00000020)
• #define DMA_HIFCR_CHTIF4 ((uint32_t)0x00000010)
• #define DMA_HIFCR_CTEIF4 ((uint32_t)0x00000008)
• #define DMA_HIFCR_CDMEIF4 ((uint32_t)0x00000004)
• #define DMA_HIFCR_CFEIF4 ((uint32_t)0x00000001)
• #define DMA2D_CR_START ((uint32_t)0x00000001)
• #define DMA2D_CR_SUSP ((uint32_t)0x00000002)
• #define DMA2D_CR_ABORT ((uint32_t)0x00000004)
• #define DMA2D_CR_TEIE ((uint32_t)0x00000100)
• #define DMA2D_CR_TCIE ((uint32_t)0x00000200)
• #define DMA2D_CR_TWIE ((uint32_t)0x00000400)
• #define DMA2D_CR_CAEIE ((uint32_t)0x00000800)
• #define DMA2D_CR_CTCIE ((uint32_t)0x00001000)
• #define DMA2D_CR_CEIE ((uint32_t)0x00002000)
• #define DMA2D_CR_MODE ((uint32_t)0x00030000)
• #define DMA2D_ISR_TEIF ((uint32_t)0x00000001)
• #define DMA2D_ISR_TCIF ((uint32_t)0x00000002)
• #define DMA2D_ISR_TWIF ((uint32_t)0x00000004)
• #define DMA2D_ISR_CAEIF ((uint32_t)0x00000008)
• #define DMA2D_ISR_CTCIF ((uint32_t)0x00000010)
• #define DMA2D_ISR_CEIF ((uint32_t)0x00000020)
• #define DMA2D_IFCR_CTEIF ((uint32_t)0x00000001)
• #define DMA2D_IFCR_CTCIF ((uint32_t)0x00000002)
• #define DMA2D_IFCR_CTWIF ((uint32_t)0x00000004)
• #define DMA2D_IFCR_CAE CIF ((uint32_t)0x00000008)
• #define DMA2D_IFCR_CCTCIF ((uint32_t)0x00000010)
• #define DMA2D_IFCR_CCEIF ((uint32_t)0x00000020)
```

```
• #define DMA2D_IFSR_CTEIF DMA2D_IFCR_CTEIF
• #define DMA2D_IFSR_CTCIF DMA2D_IFCR_CTCIF
• #define DMA2D_IFSR_CTWIF DMA2D_IFCR_CTWIF
• #define DMA2D_IFSR_CCAEIF DMA2D_IFCR_CAECIF
• #define DMA2D_IFSR_CCTCIF DMA2D_IFCR_CCTCIF
• #define DMA2D_IFSR_CCEIF DMA2D_IFCR_CCEIF
• #define DMA2D_FGMAR_MA ((uint32_t)0xFFFFFFFF)
• #define DMA2D_FGOR_LO ((uint32_t)0x00003FFF)
• #define DMA2D_BGMAR_MA ((uint32_t)0xFFFFFFFF)
• #define DMA2D_BGOR_LO ((uint32_t)0x00003FFF)
• #define DMA2D_FGPFCCR_CM ((uint32_t)0x0000000F)
• #define DMA2D_FGPFCCR_CM_0 ((uint32_t)0x00000001)
• #define DMA2D_FGPFCCR_CM_1 ((uint32_t)0x00000002)
• #define DMA2D_FGPFCCR_CM_2 ((uint32_t)0x00000004)
• #define DMA2D_FGPFCCR_CM_3 ((uint32_t)0x00000008)
• #define DMA2D_FGPFCCR_CCM ((uint32_t)0x00000010)
• #define DMA2D_FGPFCCR_START ((uint32_t)0x00000020)
• #define DMA2D_FGPFCCR_CS ((uint32_t)0x0000FF00)
• #define DMA2D_FGPFCCR_AM ((uint32_t)0x00030000)
• #define DMA2D_FGPFCCR_AM_0 ((uint32_t)0x00010000)
• #define DMA2D_FGPFCCR_AM_1 ((uint32_t)0x00020000)
• #define DMA2D_FGPFCCR_ALPHA ((uint32_t)0xFF000000)
• #define DMA2D_FGCOLR_BLUE ((uint32_t)0x000000FF)
• #define DMA2D_FGCOLR_GREEN ((uint32_t)0x0000FF00)
• #define DMA2D_FGCOLR_RED ((uint32_t)0x00FF0000)
• #define DMA2D_BGPFCCR_CM ((uint32_t)0x0000000F)
• #define DMA2D_BGPFCCR_CM_0 ((uint32_t)0x00000001)
• #define DMA2D_BGPFCCR_CM_1 ((uint32_t)0x00000002)
• #define DMA2D_BGPFCCR_CM_2 ((uint32_t)0x00000004)
• #define DMA2D_BGPFCCR_CM_3 ((uint32_t)0x00000008)
• #define DMA2D_BGPFCCR_CCM ((uint32_t)0x00000010)
• #define DMA2D_BGPFCCR_START ((uint32_t)0x00000020)
• #define DMA2D_BGPFCCR_CS ((uint32_t)0x0000FF00)
• #define DMA2D_BGPFCCR_AM ((uint32_t)0x00030000)
• #define DMA2D_BGPFCCR_AM_0 ((uint32_t)0x00010000)
• #define DMA2D_BGPFCCR_AM_1 ((uint32_t)0x00020000)
• #define DMA2D_BGPFCCR_ALPHA ((uint32_t)0xFF000000)
• #define DMA2D_BGCOLR_BLUE ((uint32_t)0x000000FF)
• #define DMA2D_BGCOLR_GREEN ((uint32_t)0x0000FF00)
• #define DMA2D_BGCOLR_RED ((uint32_t)0x00FF0000)
• #define DMA2D_FGCMAR_MA ((uint32_t)0xFFFFFFFF)
• #define DMA2D_BGCMAR_MA ((uint32_t)0xFFFFFFFF)
• #define DMA2D_OPFCCR_CM ((uint32_t)0x00000007)
• #define DMA2D_OPFCCR_CM_0 ((uint32_t)0x00000001)
• #define DMA2D_OPFCCR_CM_1 ((uint32_t)0x00000002)
• #define DMA2D_OPFCCR_CM_2 ((uint32_t)0x00000004)
• #define DMA2D_OCOLR_BLUE_1 ((uint32_t)0x000000FF)
• #define DMA2D_OCOLR_GREEN_1 ((uint32_t)0x0000FF00)
• #define DMA2D_OCOLR_RED_1 ((uint32_t)0x00FF0000)
• #define DMA2D_OCOLR_ALPHA_1 ((uint32_t)0xFF000000)
• #define DMA2D_OCOLR_BLUE_2 ((uint32_t)0x0000001F)
• #define DMA2D_OCOLR_GREEN_2 ((uint32_t)0x000007E0)
• #define DMA2D_OCOLR_RED_2 ((uint32_t)0x0000F800)
• #define DMA2D_OCOLR_BLUE_3 ((uint32_t)0x0000001F)
• #define DMA2D_OCOLR_GREEN_3 ((uint32_t)0x000003E0)
```

- #define DMA2D\_OCOLR\_RED\_3 ((uint32\_t)0x000007C00)
- #define DMA2D\_OCOLR\_ALPHA\_3 ((uint32\_t)0x00008000)
- #define DMA2D\_OCOLR\_BLUE\_4 ((uint32\_t)0x0000000F)
- #define DMA2D\_OCOLR\_GREEN\_4 ((uint32\_t)0x000000F0)
- #define DMA2D\_OCOLR\_RED\_4 ((uint32\_t)0x00000F00)
- #define DMA2D\_OCOLR\_ALPHA\_4 ((uint32\_t)0x0000F000)
- #define DMA2D\_OMAR\_MA ((uint32\_t)0xFFFFFFFF)
- #define DMA2D\_OOR\_LO ((uint32\_t)0x00003FFF)
- #define DMA2D\_NLR\_NL ((uint32\_t)0x0000FFFF)
- #define DMA2D\_NLR\_PL ((uint32\_t)0x3FFF0000)
- #define DMA2D\_LWR\_LW ((uint32\_t)0x0000FFFF)
- #define DMA2D\_AMTCR\_EN ((uint32\_t)0x00000001)
- #define DMA2D\_AMTCR\_DT ((uint32\_t)0x0000FF00)
- #define EXTI\_IMR\_MR0 ((uint32\_t)0x00000001)
- #define EXTI\_IMR\_MR1 ((uint32\_t)0x00000002)
- #define EXTI\_IMR\_MR2 ((uint32\_t)0x00000004)
- #define EXTI\_IMR\_MR3 ((uint32\_t)0x00000008)
- #define EXTI\_IMR\_MR4 ((uint32\_t)0x00000010)
- #define EXTI\_IMR\_MR5 ((uint32\_t)0x00000020)
- #define EXTI\_IMR\_MR6 ((uint32\_t)0x00000040)
- #define EXTI\_IMR\_MR7 ((uint32\_t)0x00000080)
- #define EXTI\_IMR\_MR8 ((uint32\_t)0x00000100)
- #define EXTI\_IMR\_MR9 ((uint32\_t)0x00000200)
- #define EXTI\_IMR\_MR10 ((uint32\_t)0x00000400)
- #define EXTI\_IMR\_MR11 ((uint32\_t)0x00000800)
- #define EXTI\_IMR\_MR12 ((uint32\_t)0x00001000)
- #define EXTI\_IMR\_MR13 ((uint32\_t)0x00002000)
- #define EXTI\_IMR\_MR14 ((uint32\_t)0x00004000)
- #define EXTI\_IMR\_MR15 ((uint32\_t)0x00008000)
- #define EXTI\_IMR\_MR16 ((uint32\_t)0x00010000)
- #define EXTI\_IMR\_MR17 ((uint32\_t)0x00020000)
- #define EXTI\_IMR\_MR18 ((uint32\_t)0x00040000)
- #define EXTI\_IMR\_MR19 ((uint32\_t)0x00080000)
- #define EXTI\_IMR\_MR23 ((uint32\_t)0x00800000)
- #define EXTI\_EMR\_MR0 ((uint32\_t)0x00000001)
- #define EXTI\_EMR\_MR1 ((uint32\_t)0x00000002)
- #define EXTI\_EMR\_MR2 ((uint32\_t)0x00000004)
- #define EXTI\_EMR\_MR3 ((uint32\_t)0x00000008)
- #define EXTI\_EMR\_MR4 ((uint32\_t)0x00000010)
- #define EXTI\_EMR\_MR5 ((uint32\_t)0x00000020)
- #define EXTI\_EMR\_MR6 ((uint32\_t)0x00000040)
- #define EXTI\_EMR\_MR7 ((uint32\_t)0x00000080)
- #define EXTI\_EMR\_MR8 ((uint32\_t)0x00000100)
- #define EXTI\_EMR\_MR9 ((uint32\_t)0x00000200)
- #define EXTI\_EMR\_MR10 ((uint32\_t)0x00000400)
- #define EXTI\_EMR\_MR11 ((uint32\_t)0x00000800)
- #define EXTI\_EMR\_MR12 ((uint32\_t)0x00001000)
- #define EXTI\_EMR\_MR13 ((uint32\_t)0x00002000)
- #define EXTI\_EMR\_MR14 ((uint32\_t)0x00004000)
- #define EXTI\_EMR\_MR15 ((uint32\_t)0x00008000)
- #define EXTI\_EMR\_MR16 ((uint32\_t)0x00010000)
- #define EXTI\_EMR\_MR17 ((uint32\_t)0x00020000)
- #define EXTI\_EMR\_MR18 ((uint32\_t)0x00040000)
- #define EXTI\_EMR\_MR19 ((uint32\_t)0x00080000)
- #define EXTI\_EMR\_MR23 ((uint32\_t)0x00800000)

```
• #define EXTI_RTSR_TR0 ((uint32_t)0x00000001)
• #define EXTI_RTSR_TR1 ((uint32_t)0x00000002)
• #define EXTI_RTSR_TR2 ((uint32_t)0x00000004)
• #define EXTI_RTSR_TR3 ((uint32_t)0x00000008)
• #define EXTI_RTSR_TR4 ((uint32_t)0x00000010)
• #define EXTI_RTSR_TR5 ((uint32_t)0x00000020)
• #define EXTI_RTSR_TR6 ((uint32_t)0x00000040)
• #define EXTI_RTSR_TR7 ((uint32_t)0x00000080)
• #define EXTI_RTSR_TR8 ((uint32_t)0x00000100)
• #define EXTI_RTSR_TR9 ((uint32_t)0x00000200)
• #define EXTI_RTSR_TR10 ((uint32_t)0x00000400)
• #define EXTI_RTSR_TR11 ((uint32_t)0x00000800)
• #define EXTI_RTSR_TR12 ((uint32_t)0x00001000)
• #define EXTI_RTSR_TR13 ((uint32_t)0x00002000)
• #define EXTI_RTSR_TR14 ((uint32_t)0x00004000)
• #define EXTI_RTSR_TR15 ((uint32_t)0x00008000)
• #define EXTI_RTSR_TR16 ((uint32_t)0x00010000)
• #define EXTI_RTSR_TR17 ((uint32_t)0x00020000)
• #define EXTI_RTSR_TR18 ((uint32_t)0x00040000)
• #define EXTI_RTSR_TR19 ((uint32_t)0x00080000)
• #define EXTI_RTSR_TR23 ((uint32_t)0x00800000)
• #define EXTI_FTSR_TR0 ((uint32_t)0x00000001)
• #define EXTI_FTSR_TR1 ((uint32_t)0x00000002)
• #define EXTI_FTSR_TR2 ((uint32_t)0x00000004)
• #define EXTI_FTSR_TR3 ((uint32_t)0x00000008)
• #define EXTI_FTSR_TR4 ((uint32_t)0x00000010)
• #define EXTI_FTSR_TR5 ((uint32_t)0x00000020)
• #define EXTI_FTSR_TR6 ((uint32_t)0x00000040)
• #define EXTI_FTSR_TR7 ((uint32_t)0x00000080)
• #define EXTI_FTSR_TR8 ((uint32_t)0x00000100)
• #define EXTI_FTSR_TR9 ((uint32_t)0x00000200)
• #define EXTI_FTSR_TR10 ((uint32_t)0x00000400)
• #define EXTI_FTSR_TR11 ((uint32_t)0x00000800)
• #define EXTI_FTSR_TR12 ((uint32_t)0x00001000)
• #define EXTI_FTSR_TR13 ((uint32_t)0x00002000)
• #define EXTI_FTSR_TR14 ((uint32_t)0x00004000)
• #define EXTI_FTSR_TR15 ((uint32_t)0x00008000)
• #define EXTI_FTSR_TR16 ((uint32_t)0x00010000)
• #define EXTI_FTSR_TR17 ((uint32_t)0x00020000)
• #define EXTI_FTSR_TR18 ((uint32_t)0x00040000)
• #define EXTI_FTSR_TR19 ((uint32_t)0x00080000)
• #define EXTI_FTSR_TR23 ((uint32_t)0x00800000)
• #define EXTI_SWIER_SWIER0 ((uint32_t)0x00000001)
• #define EXTI_SWIER_SWIER1 ((uint32_t)0x00000002)
• #define EXTI_SWIER_SWIER2 ((uint32_t)0x00000004)
• #define EXTI_SWIER_SWIER3 ((uint32_t)0x00000008)
• #define EXTI_SWIER_SWIER4 ((uint32_t)0x00000010)
• #define EXTI_SWIER_SWIER5 ((uint32_t)0x00000020)
• #define EXTI_SWIER_SWIER6 ((uint32_t)0x00000040)
• #define EXTI_SWIER_SWIER7 ((uint32_t)0x00000080)
• #define EXTI_SWIER_SWIER8 ((uint32_t)0x00000100)
• #define EXTI_SWIER_SWIER9 ((uint32_t)0x00000200)
• #define EXTI_SWIER_SWIER10 ((uint32_t)0x00000400)
• #define EXTI_SWIER_SWIER11 ((uint32_t)0x00000800)
• #define EXTI_SWIER_SWIER12 ((uint32_t)0x00001000)
```

- #define **EXTI\_SWIER\_SWIER13** ((uint32\_t)0x00002000)
- #define **EXTI\_SWIER\_SWIER14** ((uint32\_t)0x00004000)
- #define **EXTI\_SWIER\_SWIER15** ((uint32\_t)0x00008000)
- #define **EXTI\_SWIER\_SWIER16** ((uint32\_t)0x00010000)
- #define **EXTI\_SWIER\_SWIER17** ((uint32\_t)0x00020000)
- #define **EXTI\_SWIER\_SWIER18** ((uint32\_t)0x00040000)
- #define **EXTI\_SWIER\_SWIER19** ((uint32\_t)0x00080000)
- #define **EXTI\_SWIER\_SWIER23** ((uint32\_t)0x00800000)
- #define **EXTI\_PR\_PR0** ((uint32\_t)0x00000001)
- #define **EXTI\_PR\_PR1** ((uint32\_t)0x00000002)
- #define **EXTI\_PR\_PR2** ((uint32\_t)0x00000004)
- #define **EXTI\_PR\_PR3** ((uint32\_t)0x00000008)
- #define **EXTI\_PR\_PR4** ((uint32\_t)0x00000010)
- #define **EXTI\_PR\_PR5** ((uint32\_t)0x00000020)
- #define **EXTI\_PR\_PR6** ((uint32\_t)0x00000040)
- #define **EXTI\_PR\_PR7** ((uint32\_t)0x00000080)
- #define **EXTI\_PR\_PR8** ((uint32\_t)0x00000100)
- #define **EXTI\_PR\_PR9** ((uint32\_t)0x00000200)
- #define **EXTI\_PR\_PR10** ((uint32\_t)0x00000400)
- #define **EXTI\_PR\_PR11** ((uint32\_t)0x00000800)
- #define **EXTI\_PR\_PR12** ((uint32\_t)0x00001000)
- #define **EXTI\_PR\_PR13** ((uint32\_t)0x00002000)
- #define **EXTI\_PR\_PR14** ((uint32\_t)0x00004000)
- #define **EXTI\_PR\_PR15** ((uint32\_t)0x00008000)
- #define **EXTI\_PR\_PR16** ((uint32\_t)0x00010000)
- #define **EXTI\_PR\_PR17** ((uint32\_t)0x00020000)
- #define **EXTI\_PR\_PR18** ((uint32\_t)0x00040000)
- #define **EXTI\_PR\_PR19** ((uint32\_t)0x00080000)
- #define **EXTI\_PR\_PR23** ((uint32\_t)0x00800000)
- #define **FLASH\_ACR\_LATENCY** ((uint32\_t)0x0000000F)
- #define **FLASH\_ACR\_LATENCY\_0WS** ((uint32\_t)0x00000000)
- #define **FLASH\_ACR\_LATENCY\_1WS** ((uint32\_t)0x00000001)
- #define **FLASH\_ACR\_LATENCY\_2WS** ((uint32\_t)0x00000002)
- #define **FLASH\_ACR\_LATENCY\_3WS** ((uint32\_t)0x00000003)
- #define **FLASH\_ACR\_LATENCY\_4WS** ((uint32\_t)0x00000004)
- #define **FLASH\_ACR\_LATENCY\_5WS** ((uint32\_t)0x00000005)
- #define **FLASH\_ACR\_LATENCY\_6WS** ((uint32\_t)0x00000006)
- #define **FLASH\_ACR\_LATENCY\_7WS** ((uint32\_t)0x00000007)
- #define **FLASH\_ACR\_LATENCY\_8WS** ((uint32\_t)0x00000008)
- #define **FLASH\_ACR\_LATENCY\_9WS** ((uint32\_t)0x00000009)
- #define **FLASH\_ACR\_LATENCY\_10WS** ((uint32\_t)0x0000000A)
- #define **FLASH\_ACR\_LATENCY\_11WS** ((uint32\_t)0x0000000B)
- #define **FLASH\_ACR\_LATENCY\_12WS** ((uint32\_t)0x0000000C)
- #define **FLASH\_ACR\_LATENCY\_13WS** ((uint32\_t)0x0000000D)
- #define **FLASH\_ACR\_LATENCY\_14WS** ((uint32\_t)0x0000000E)
- #define **FLASH\_ACR\_LATENCY\_15WS** ((uint32\_t)0x0000000F)
- #define **FLASH\_ACR\_PRFTEN** ((uint32\_t)0x00000100)
- #define **FLASH\_ACR\_ICEN** ((uint32\_t)0x00000200)
- #define **FLASH\_ACR\_DCEN** ((uint32\_t)0x00000400)
- #define **FLASH\_ACR\_ICRST** ((uint32\_t)0x00000800)
- #define **FLASH\_ACR\_DCRST** ((uint32\_t)0x00001000)
- #define **FLASH\_ACR\_BYTE0\_ADDRESS** ((uint32\_t)0x40023C00)
- #define **FLASH\_ACR\_BYTE2\_ADDRESS** ((uint32\_t)0x40023C03)
- #define **FLASH\_SR\_EOP** ((uint32\_t)0x00000001)
- #define **FLASH\_SR\_SOP** ((uint32\_t)0x00000002)

- #define **FLASH\_SR\_WRPERR** ((uint32\_t)0x00000010)
- #define **FLASH\_SR\_PGAERR** ((uint32\_t)0x00000020)
- #define **FLASH\_SR\_PGPERR** ((uint32\_t)0x00000040)
- #define **FLASH\_SR\_PGSERR** ((uint32\_t)0x00000080)
- #define **FLASH\_SR\_BSY** ((uint32\_t)0x00010000)
- #define **FLASH\_CR\_PG** ((uint32\_t)0x00000001)
- #define **FLASH\_CR\_SER** ((uint32\_t)0x00000002)
- #define **FLASH\_CR\_MER** ((uint32\_t)0x00000004)
- #define **FLASH\_CR\_MER1** FLASH\_CR\_MER
- #define **FLASH\_CR\_SNBB** ((uint32\_t)0x000000F8)
- #define **FLASH\_CR\_SNBB\_0** ((uint32\_t)0x00000008)
- #define **FLASH\_CR\_SNBB\_1** ((uint32\_t)0x00000010)
- #define **FLASH\_CR\_SNBB\_2** ((uint32\_t)0x00000020)
- #define **FLASH\_CR\_SNBB\_3** ((uint32\_t)0x00000040)
- #define **FLASH\_CR\_SNBB\_4** ((uint32\_t)0x00000040)
- #define **FLASH\_CR\_PSIZE** ((uint32\_t)0x00000300)
- #define **FLASH\_CR\_PSIZE\_0** ((uint32\_t)0x00000100)
- #define **FLASH\_CR\_PSIZE\_1** ((uint32\_t)0x00000200)
- #define **FLASH\_CR\_MER2** ((uint32\_t)0x00008000)
- #define **FLASH\_CR\_STRT** ((uint32\_t)0x00010000)
- #define **FLASH\_CR\_EOPIE** ((uint32\_t)0x01000000)
- #define **FLASH\_CR\_LOCK** ((uint32\_t)0x80000000)
- #define **FLASH\_OPTCR\_OPTLOCK** ((uint32\_t)0x00000001)
- #define **FLASH\_OPTCR\_OPTSTRT** ((uint32\_t)0x00000002)
- #define **FLASH\_OPTCR\_BORLEV\_0** ((uint32\_t)0x00000004)
- #define **FLASH\_OPTCR\_BORLEV\_1** ((uint32\_t)0x00000008)
- #define **FLASH\_OPTCR\_BORLEV** ((uint32\_t)0x0000000C)
- #define **FLASH\_OPTCR\_BFB2** ((uint32\_t)0x00000010)
- #define **FLASH\_OPTCR\_WDG\_SW** ((uint32\_t)0x00000020)
- #define **FLASH\_OPTCR\_nRST\_STOP** ((uint32\_t)0x00000040)
- #define **FLASH\_OPTCR\_nRST\_STDBY** ((uint32\_t)0x00000080)
- #define **FLASH\_OPTCR\_RDP** ((uint32\_t)0x0000FF00)
- #define **FLASH\_OPTCR\_RDP\_0** ((uint32\_t)0x00000100)
- #define **FLASH\_OPTCR\_RDP\_1** ((uint32\_t)0x00000200)
- #define **FLASH\_OPTCR\_RDP\_2** ((uint32\_t)0x00000400)
- #define **FLASH\_OPTCR\_RDP\_3** ((uint32\_t)0x00000800)
- #define **FLASH\_OPTCR\_RDP\_4** ((uint32\_t)0x00001000)
- #define **FLASH\_OPTCR\_RDP\_5** ((uint32\_t)0x00002000)
- #define **FLASH\_OPTCR\_RDP\_6** ((uint32\_t)0x00004000)
- #define **FLASH\_OPTCR\_RDP\_7** ((uint32\_t)0x00008000)
- #define **FLASH\_OPTCR\_nWRP** ((uint32\_t)0xFFFF0000)
- #define **FLASH\_OPTCR\_nWRP\_0** ((uint32\_t)0x00010000)
- #define **FLASH\_OPTCR\_nWRP\_1** ((uint32\_t)0x00020000)
- #define **FLASH\_OPTCR\_nWRP\_2** ((uint32\_t)0x00040000)
- #define **FLASH\_OPTCR\_nWRP\_3** ((uint32\_t)0x00080000)
- #define **FLASH\_OPTCR\_nWRP\_4** ((uint32\_t)0x00100000)
- #define **FLASH\_OPTCR\_nWRP\_5** ((uint32\_t)0x00200000)
- #define **FLASH\_OPTCR\_nWRP\_6** ((uint32\_t)0x00400000)
- #define **FLASH\_OPTCR\_nWRP\_7** ((uint32\_t)0x00800000)
- #define **FLASH\_OPTCR\_nWRP\_8** ((uint32\_t)0x01000000)
- #define **FLASH\_OPTCR\_nWRP\_9** ((uint32\_t)0x02000000)
- #define **FLASH\_OPTCR\_nWRP\_10** ((uint32\_t)0x04000000)
- #define **FLASH\_OPTCR\_nWRP\_11** ((uint32\_t)0x08000000)
- #define **FLASH\_OPTCR\_DB1M** ((uint32\_t)0x40000000)
- #define **FLASH\_OPTCR\_SPRMOD** ((uint32\_t)0x80000000)

```
• #define FLASH_OPTCR1_nWRP ((uint32_t)0xFFFF0000)
• #define FLASH_OPTCR1_nWRP_0 ((uint32_t)0x00010000)
• #define FLASH_OPTCR1_nWRP_1 ((uint32_t)0x00020000)
• #define FLASH_OPTCR1_nWRP_2 ((uint32_t)0x00040000)
• #define FLASH_OPTCR1_nWRP_3 ((uint32_t)0x00080000)
• #define FLASH_OPTCR1_nWRP_4 ((uint32_t)0x00100000)
• #define FLASH_OPTCR1_nWRP_5 ((uint32_t)0x00200000)
• #define FLASH_OPTCR1_nWRP_6 ((uint32_t)0x00400000)
• #define FLASH_OPTCR1_nWRP_7 ((uint32_t)0x00800000)
• #define FLASH_OPTCR1_nWRP_8 ((uint32_t)0x01000000)
• #define FLASH_OPTCR1_nWRP_9 ((uint32_t)0x02000000)
• #define FLASH_OPTCR1_nWRP_10 ((uint32_t)0x04000000)
• #define FLASH_OPTCR1_nWRP_11 ((uint32_t)0x08000000)
• #define GPIO_MODER_MODER0 ((uint32_t)0x00000003)
• #define GPIO_MODER_MODER0_0 ((uint32_t)0x00000001)
• #define GPIO_MODER_MODER0_1 ((uint32_t)0x00000002)
• #define GPIO_MODER_MODER1 ((uint32_t)0x0000000C)
• #define GPIO_MODER_MODER1_0 ((uint32_t)0x00000004)
• #define GPIO_MODER_MODER1_1 ((uint32_t)0x00000008)
• #define GPIO_MODER_MODER2 ((uint32_t)0x00000030)
• #define GPIO_MODER_MODER2_0 ((uint32_t)0x00000010)
• #define GPIO_MODER_MODER2_1 ((uint32_t)0x00000020)
• #define GPIO_MODER_MODER3 ((uint32_t)0x000000C0)
• #define GPIO_MODER_MODER3_0 ((uint32_t)0x00000040)
• #define GPIO_MODER_MODER3_1 ((uint32_t)0x00000080)
• #define GPIO_MODER_MODER4 ((uint32_t)0x00000300)
• #define GPIO_MODER_MODER4_0 ((uint32_t)0x00000100)
• #define GPIO_MODER_MODER4_1 ((uint32_t)0x00000200)
• #define GPIO_MODER_MODER5 ((uint32_t)0x00000C00)
• #define GPIO_MODER_MODER5_0 ((uint32_t)0x00000400)
• #define GPIO_MODER_MODER5_1 ((uint32_t)0x00000800)
• #define GPIO_MODER_MODER6 ((uint32_t)0x00003000)
• #define GPIO_MODER_MODER6_0 ((uint32_t)0x00001000)
• #define GPIO_MODER_MODER6_1 ((uint32_t)0x00002000)
• #define GPIO_MODER_MODER7 ((uint32_t)0x0000C000)
• #define GPIO_MODER_MODER7_0 ((uint32_t)0x00004000)
• #define GPIO_MODER_MODER7_1 ((uint32_t)0x00008000)
• #define GPIO_MODER_MODER8 ((uint32_t)0x00030000)
• #define GPIO_MODER_MODER8_0 ((uint32_t)0x00010000)
• #define GPIO_MODER_MODER8_1 ((uint32_t)0x00020000)
• #define GPIO_MODER_MODER9 ((uint32_t)0x000C0000)
• #define GPIO_MODER_MODER9_0 ((uint32_t)0x00040000)
• #define GPIO_MODER_MODER9_1 ((uint32_t)0x00080000)
• #define GPIO_MODER_MODER10 ((uint32_t)0x00300000)
• #define GPIO_MODER_MODER10_0 ((uint32_t)0x00100000)
• #define GPIO_MODER_MODER10_1 ((uint32_t)0x00200000)
• #define GPIO_MODER_MODER11 ((uint32_t)0x00C00000)
• #define GPIO_MODER_MODER11_0 ((uint32_t)0x00400000)
• #define GPIO_MODER_MODER11_1 ((uint32_t)0x00800000)
• #define GPIO_MODER_MODER12 ((uint32_t)0x03000000)
• #define GPIO_MODER_MODER12_0 ((uint32_t)0x01000000)
• #define GPIO_MODER_MODER12_1 ((uint32_t)0x02000000)
• #define GPIO_MODER_MODER13 ((uint32_t)0x0C000000)
• #define GPIO_MODER_MODER13_0 ((uint32_t)0x04000000)
• #define GPIO_MODER_MODER13_1 ((uint32_t)0x08000000)
```

- #define **GPIO\_MODER\_MODER14** ((uint32\_t)0x30000000)
- #define **GPIO\_MODER\_MODER14\_0** ((uint32\_t)0x10000000)
- #define **GPIO\_MODER\_MODER14\_1** ((uint32\_t)0x20000000)
- #define **GPIO\_MODER\_MODER15** ((uint32\_t)0xC0000000)
- #define **GPIO\_MODER\_MODER15\_0** ((uint32\_t)0x40000000)
- #define **GPIO\_MODER\_MODER15\_1** ((uint32\_t)0x80000000)
- #define **GPIO\_OTYPER\_OT\_0** ((uint32\_t)0x00000001)
- #define **GPIO\_OTYPER\_OT\_1** ((uint32\_t)0x00000002)
- #define **GPIO\_OTYPER\_OT\_2** ((uint32\_t)0x00000004)
- #define **GPIO\_OTYPER\_OT\_3** ((uint32\_t)0x00000008)
- #define **GPIO\_OTYPER\_OT\_4** ((uint32\_t)0x00000010)
- #define **GPIO\_OTYPER\_OT\_5** ((uint32\_t)0x00000020)
- #define **GPIO\_OTYPER\_OT\_6** ((uint32\_t)0x00000040)
- #define **GPIO\_OTYPER\_OT\_7** ((uint32\_t)0x00000080)
- #define **GPIO\_OTYPER\_OT\_8** ((uint32\_t)0x00000100)
- #define **GPIO\_OTYPER\_OT\_9** ((uint32\_t)0x00000200)
- #define **GPIO\_OTYPER\_OT\_10** ((uint32\_t)0x00000400)
- #define **GPIO\_OTYPER\_OT\_11** ((uint32\_t)0x00000800)
- #define **GPIO\_OTYPER\_OT\_12** ((uint32\_t)0x00001000)
- #define **GPIO\_OTYPER\_OT\_13** ((uint32\_t)0x00002000)
- #define **GPIO\_OTYPER\_OT\_14** ((uint32\_t)0x00004000)
- #define **GPIO\_OTYPER\_OT\_15** ((uint32\_t)0x00008000)
- #define **GPIO\_OSPEEDER\_OSPEEDR0** ((uint32\_t)0x00000003)
- #define **GPIO\_OSPEEDER\_OSPEEDR0\_0** ((uint32\_t)0x00000001)
- #define **GPIO\_OSPEEDER\_OSPEEDR0\_1** ((uint32\_t)0x00000002)
- #define **GPIO\_OSPEEDER\_OSPEEDR1** ((uint32\_t)0x0000000C)
- #define **GPIO\_OSPEEDER\_OSPEEDR1\_0** ((uint32\_t)0x00000004)
- #define **GPIO\_OSPEEDER\_OSPEEDR1\_1** ((uint32\_t)0x00000008)
- #define **GPIO\_OSPEEDER\_OSPEEDR2** ((uint32\_t)0x00000030)
- #define **GPIO\_OSPEEDER\_OSPEEDR2\_0** ((uint32\_t)0x00000010)
- #define **GPIO\_OSPEEDER\_OSPEEDR2\_1** ((uint32\_t)0x00000020)
- #define **GPIO\_OSPEEDER\_OSPEEDR3** ((uint32\_t)0x000000C0)
- #define **GPIO\_OSPEEDER\_OSPEEDR3\_0** ((uint32\_t)0x00000040)
- #define **GPIO\_OSPEEDER\_OSPEEDR3\_1** ((uint32\_t)0x00000080)
- #define **GPIO\_OSPEEDER\_OSPEEDR4** ((uint32\_t)0x00000300)
- #define **GPIO\_OSPEEDER\_OSPEEDR4\_0** ((uint32\_t)0x00000100)
- #define **GPIO\_OSPEEDER\_OSPEEDR4\_1** ((uint32\_t)0x00000200)
- #define **GPIO\_OSPEEDER\_OSPEEDR5** ((uint32\_t)0x00000C00)
- #define **GPIO\_OSPEEDER\_OSPEEDR5\_0** ((uint32\_t)0x00000400)
- #define **GPIO\_OSPEEDER\_OSPEEDR5\_1** ((uint32\_t)0x00000800)
- #define **GPIO\_OSPEEDER\_OSPEEDR6** ((uint32\_t)0x00003000)
- #define **GPIO\_OSPEEDER\_OSPEEDR6\_0** ((uint32\_t)0x00001000)
- #define **GPIO\_OSPEEDER\_OSPEEDR6\_1** ((uint32\_t)0x00002000)
- #define **GPIO\_OSPEEDER\_OSPEEDR7** ((uint32\_t)0x0000C000)
- #define **GPIO\_OSPEEDER\_OSPEEDR7\_0** ((uint32\_t)0x00004000)
- #define **GPIO\_OSPEEDER\_OSPEEDR7\_1** ((uint32\_t)0x00008000)
- #define **GPIO\_OSPEEDER\_OSPEEDR8** ((uint32\_t)0x00030000)
- #define **GPIO\_OSPEEDER\_OSPEEDR8\_0** ((uint32\_t)0x00010000)
- #define **GPIO\_OSPEEDER\_OSPEEDR8\_1** ((uint32\_t)0x00020000)
- #define **GPIO\_OSPEEDER\_OSPEEDR9** ((uint32\_t)0x000C0000)
- #define **GPIO\_OSPEEDER\_OSPEEDR9\_0** ((uint32\_t)0x00040000)
- #define **GPIO\_OSPEEDER\_OSPEEDR9\_1** ((uint32\_t)0x00080000)
- #define **GPIO\_OSPEEDER\_OSPEEDR10** ((uint32\_t)0x00300000)
- #define **GPIO\_OSPEEDER\_OSPEEDR10\_0** ((uint32\_t)0x00100000)
- #define **GPIO\_OSPEEDER\_OSPEEDR10\_1** ((uint32\_t)0x00200000)

- #define **GPIO\_OSPEEDER\_OSPEEDR11** ((uint32\_t)0x00C00000)
- #define **GPIO\_OSPEEDER\_OSPEEDR11\_0** ((uint32\_t)0x00400000)
- #define **GPIO\_OSPEEDER\_OSPEEDR11\_1** ((uint32\_t)0x00800000)
- #define **GPIO\_OSPEEDER\_OSPEEDR12** ((uint32\_t)0x03000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR12\_0** ((uint32\_t)0x01000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR12\_1** ((uint32\_t)0x02000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR13** ((uint32\_t)0x0C000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR13\_0** ((uint32\_t)0x04000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR13\_1** ((uint32\_t)0x08000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR14** ((uint32\_t)0x30000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR14\_0** ((uint32\_t)0x10000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR14\_1** ((uint32\_t)0x20000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR15** ((uint32\_t)0xC0000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR15\_0** ((uint32\_t)0x40000000)
- #define **GPIO\_OSPEEDER\_OSPEEDR15\_1** ((uint32\_t)0x80000000)
- #define **GPIO\_PUPDR\_PUPDR0** ((uint32\_t)0x00000003)
- #define **GPIO\_PUPDR\_PUPDR0\_0** ((uint32\_t)0x00000001)
- #define **GPIO\_PUPDR\_PUPDR0\_1** ((uint32\_t)0x00000002)
- #define **GPIO\_PUPDR\_PUPDR1** ((uint32\_t)0x0000000C)
- #define **GPIO\_PUPDR\_PUPDR1\_0** ((uint32\_t)0x00000004)
- #define **GPIO\_PUPDR\_PUPDR1\_1** ((uint32\_t)0x00000008)
- #define **GPIO\_PUPDR\_PUPDR2** ((uint32\_t)0x00000030)
- #define **GPIO\_PUPDR\_PUPDR2\_0** ((uint32\_t)0x00000010)
- #define **GPIO\_PUPDR\_PUPDR2\_1** ((uint32\_t)0x00000020)
- #define **GPIO\_PUPDR\_PUPDR3** ((uint32\_t)0x000000C0)
- #define **GPIO\_PUPDR\_PUPDR3\_0** ((uint32\_t)0x00000040)
- #define **GPIO\_PUPDR\_PUPDR3\_1** ((uint32\_t)0x00000080)
- #define **GPIO\_PUPDR\_PUPDR4** ((uint32\_t)0x00000300)
- #define **GPIO\_PUPDR\_PUPDR4\_0** ((uint32\_t)0x00000100)
- #define **GPIO\_PUPDR\_PUPDR4\_1** ((uint32\_t)0x00000200)
- #define **GPIO\_PUPDR\_PUPDR5** ((uint32\_t)0x00000C00)
- #define **GPIO\_PUPDR\_PUPDR5\_0** ((uint32\_t)0x00000400)
- #define **GPIO\_PUPDR\_PUPDR5\_1** ((uint32\_t)0x00000800)
- #define **GPIO\_PUPDR\_PUPDR6** ((uint32\_t)0x00003000)
- #define **GPIO\_PUPDR\_PUPDR6\_0** ((uint32\_t)0x00001000)
- #define **GPIO\_PUPDR\_PUPDR6\_1** ((uint32\_t)0x00002000)
- #define **GPIO\_PUPDR\_PUPDR7** ((uint32\_t)0x0000C000)
- #define **GPIO\_PUPDR\_PUPDR7\_0** ((uint32\_t)0x00004000)
- #define **GPIO\_PUPDR\_PUPDR7\_1** ((uint32\_t)0x00008000)
- #define **GPIO\_PUPDR\_PUPDR8** ((uint32\_t)0x00030000)
- #define **GPIO\_PUPDR\_PUPDR8\_0** ((uint32\_t)0x00010000)
- #define **GPIO\_PUPDR\_PUPDR8\_1** ((uint32\_t)0x00020000)
- #define **GPIO\_PUPDR\_PUPDR9** ((uint32\_t)0x000C0000)
- #define **GPIO\_PUPDR\_PUPDR9\_0** ((uint32\_t)0x00040000)
- #define **GPIO\_PUPDR\_PUPDR9\_1** ((uint32\_t)0x00080000)
- #define **GPIO\_PUPDR\_PUPDR10** ((uint32\_t)0x00300000)
- #define **GPIO\_PUPDR\_PUPDR10\_0** ((uint32\_t)0x00100000)
- #define **GPIO\_PUPDR\_PUPDR10\_1** ((uint32\_t)0x00200000)
- #define **GPIO\_PUPDR\_PUPDR11** ((uint32\_t)0x00C00000)
- #define **GPIO\_PUPDR\_PUPDR11\_0** ((uint32\_t)0x00400000)
- #define **GPIO\_PUPDR\_PUPDR11\_1** ((uint32\_t)0x00800000)
- #define **GPIO\_PUPDR\_PUPDR12** ((uint32\_t)0x03000000)
- #define **GPIO\_PUPDR\_PUPDR12\_0** ((uint32\_t)0x01000000)
- #define **GPIO\_PUPDR\_PUPDR12\_1** ((uint32\_t)0x02000000)
- #define **GPIO\_PUPDR\_PUPDR13** ((uint32\_t)0x0C000000)

```
• #define GPIO_PUPDR_PUPDR13_0 ((uint32_t)0x04000000)
• #define GPIO_PUPDR_PUPDR13_1 ((uint32_t)0x08000000)
• #define GPIO_PUPDR_PUPDR14 ((uint32_t)0x30000000)
• #define GPIO_PUPDR_PUPDR14_0 ((uint32_t)0x10000000)
• #define GPIO_PUPDR_PUPDR14_1 ((uint32_t)0x20000000)
• #define GPIO_PUPDR_PUPDR15 ((uint32_t)0xC0000000)
• #define GPIO_PUPDR_PUPDR15_0 ((uint32_t)0x40000000)
• #define GPIO_PUPDR_PUPDR15_1 ((uint32_t)0x80000000)
• #define GPIO_IDR_IDR_0 ((uint32_t)0x00000001)
• #define GPIO_IDR_IDR_1 ((uint32_t)0x00000002)
• #define GPIO_IDR_IDR_2 ((uint32_t)0x00000004)
• #define GPIO_IDR_IDR_3 ((uint32_t)0x00000008)
• #define GPIO_IDR_IDR_4 ((uint32_t)0x00000010)
• #define GPIO_IDR_IDR_5 ((uint32_t)0x00000020)
• #define GPIO_IDR_IDR_6 ((uint32_t)0x00000040)
• #define GPIO_IDR_IDR_7 ((uint32_t)0x00000080)
• #define GPIO_IDR_IDR_8 ((uint32_t)0x00000100)
• #define GPIO_IDR_IDR_9 ((uint32_t)0x00000200)
• #define GPIO_IDR_IDR_10 ((uint32_t)0x00000400)
• #define GPIO_IDR_IDR_11 ((uint32_t)0x00000800)
• #define GPIO_IDR_IDR_12 ((uint32_t)0x00001000)
• #define GPIO_IDR_IDR_13 ((uint32_t)0x00002000)
• #define GPIO_IDR_IDR_14 ((uint32_t)0x00004000)
• #define GPIO_IDR_IDR_15 ((uint32_t)0x00008000)
• #define GPIO_OTYPER_IDR_0 GPIO_IDR_IDR_0
• #define GPIO_OTYPER_IDR_1 GPIO_IDR_IDR_1
• #define GPIO_OTYPER_IDR_2 GPIO_IDR_IDR_2
• #define GPIO_OTYPER_IDR_3 GPIO_IDR_IDR_3
• #define GPIO_OTYPER_IDR_4 GPIO_IDR_IDR_4
• #define GPIO_OTYPER_IDR_5 GPIO_IDR_IDR_5
• #define GPIO_OTYPER_IDR_6 GPIO_IDR_IDR_6
• #define GPIO_OTYPER_IDR_7 GPIO_IDR_IDR_7
• #define GPIO_OTYPER_IDR_8 GPIO_IDR_IDR_8
• #define GPIO_OTYPER_IDR_9 GPIO_IDR_IDR_9
• #define GPIO_OTYPER_IDR_10 GPIO_IDR_IDR_10
• #define GPIO_OTYPER_IDR_11 GPIO_IDR_IDR_11
• #define GPIO_OTYPER_IDR_12 GPIO_IDR_IDR_12
• #define GPIO_OTYPER_IDR_13 GPIO_IDR_IDR_13
• #define GPIO_OTYPER_IDR_14 GPIO_IDR_IDR_14
• #define GPIO_OTYPER_IDR_15 GPIO_IDR_IDR_15
• #define GPIO_ODR_ODR_0 ((uint32_t)0x00000001)
• #define GPIO_ODR_ODR_1 ((uint32_t)0x00000002)
• #define GPIO_ODR_ODR_2 ((uint32_t)0x00000004)
• #define GPIO_ODR_ODR_3 ((uint32_t)0x00000008)
• #define GPIO_ODR_ODR_4 ((uint32_t)0x00000010)
• #define GPIO_ODR_ODR_5 ((uint32_t)0x00000020)
• #define GPIO_ODR_ODR_6 ((uint32_t)0x00000040)
• #define GPIO_ODR_ODR_7 ((uint32_t)0x00000080)
• #define GPIO_ODR_ODR_8 ((uint32_t)0x00000100)
• #define GPIO_ODR_ODR_9 ((uint32_t)0x00000200)
• #define GPIO_ODR_ODR_10 ((uint32_t)0x00000400)
• #define GPIO_ODR_ODR_11 ((uint32_t)0x00000800)
• #define GPIO_ODR_ODR_12 ((uint32_t)0x00001000)
• #define GPIO_ODR_ODR_13 ((uint32_t)0x00002000)
• #define GPIO_ODR_ODR_14 ((uint32_t)0x00004000)
```

```
• #define GPIO_ODR_ODR_15 ((uint32_t)0x00008000)
• #define GPIO_OTYPER_ODR_0 GPIO_ODR_ODR_0
• #define GPIO_OTYPER_ODR_1 GPIO_ODR_ODR_1
• #define GPIO_OTYPER_ODR_2 GPIO_ODR_ODR_2
• #define GPIO_OTYPER_ODR_3 GPIO_ODR_ODR_3
• #define GPIO_OTYPER_ODR_4 GPIO_ODR_ODR_4
• #define GPIO_OTYPER_ODR_5 GPIO_ODR_ODR_5
• #define GPIO_OTYPER_ODR_6 GPIO_ODR_ODR_6
• #define GPIO_OTYPER_ODR_7 GPIO_ODR_ODR_7
• #define GPIO_OTYPER_ODR_8 GPIO_ODR_ODR_8
• #define GPIO_OTYPER_ODR_9 GPIO_ODR_ODR_9
• #define GPIO_OTYPER_ODR_10 GPIO_ODR_ODR_10
• #define GPIO_OTYPER_ODR_11 GPIO_ODR_ODR_11
• #define GPIO_OTYPER_ODR_12 GPIO_ODR_ODR_12
• #define GPIO_OTYPER_ODR_13 GPIO_ODR_ODR_13
• #define GPIO_OTYPER_ODR_14 GPIO_ODR_ODR_14
• #define GPIO_OTYPER_ODR_15 GPIO_ODR_ODR_15
• #define GPIO_BSRR_BS_0 ((uint32_t)0x00000001)
• #define GPIO_BSRR_BS_1 ((uint32_t)0x00000002)
• #define GPIO_BSRR_BS_2 ((uint32_t)0x00000004)
• #define GPIO_BSRR_BS_3 ((uint32_t)0x00000008)
• #define GPIO_BSRR_BS_4 ((uint32_t)0x00000010)
• #define GPIO_BSRR_BS_5 ((uint32_t)0x00000020)
• #define GPIO_BSRR_BS_6 ((uint32_t)0x00000040)
• #define GPIO_BSRR_BS_7 ((uint32_t)0x00000080)
• #define GPIO_BSRR_BS_8 ((uint32_t)0x00000100)
• #define GPIO_BSRR_BS_9 ((uint32_t)0x00000200)
• #define GPIO_BSRR_BS_10 ((uint32_t)0x00000400)
• #define GPIO_BSRR_BS_11 ((uint32_t)0x00000800)
• #define GPIO_BSRR_BS_12 ((uint32_t)0x00001000)
• #define GPIO_BSRR_BS_13 ((uint32_t)0x00002000)
• #define GPIO_BSRR_BS_14 ((uint32_t)0x00004000)
• #define GPIO_BSRR_BS_15 ((uint32_t)0x00008000)
• #define GPIO_BSRR_BR_0 ((uint32_t)0x00010000)
• #define GPIO_BSRR_BR_1 ((uint32_t)0x00020000)
• #define GPIO_BSRR_BR_2 ((uint32_t)0x00040000)
• #define GPIO_BSRR_BR_3 ((uint32_t)0x00080000)
• #define GPIO_BSRR_BR_4 ((uint32_t)0x00100000)
• #define GPIO_BSRR_BR_5 ((uint32_t)0x00200000)
• #define GPIO_BSRR_BR_6 ((uint32_t)0x00400000)
• #define GPIO_BSRR_BR_7 ((uint32_t)0x00800000)
• #define GPIO_BSRR_BR_8 ((uint32_t)0x01000000)
• #define GPIO_BSRR_BR_9 ((uint32_t)0x02000000)
• #define GPIO_BSRR_BR_10 ((uint32_t)0x04000000)
• #define GPIO_BSRR_BR_11 ((uint32_t)0x08000000)
• #define GPIO_BSRR_BR_12 ((uint32_t)0x10000000)
• #define GPIO_BSRR_BR_13 ((uint32_t)0x20000000)
• #define GPIO_BSRR_BR_14 ((uint32_t)0x40000000)
• #define GPIO_BSRR_BR_15 ((uint32_t)0x80000000)
• #define HASH_CR_INIT ((uint32_t)0x00000004)
• #define HASH_CR_DMAE ((uint32_t)0x00000008)
• #define HASH_CR_DATATYPE ((uint32_t)0x00000030)
• #define HASH_CR_DATATYPE_0 ((uint32_t)0x00000010)
• #define HASH_CR_DATATYPE_1 ((uint32_t)0x00000020)
• #define HASH_CR_MODE ((uint32_t)0x00000040)
```

```
• #define HASH_CR_ALGO ((uint32_t)0x00040080)
• #define HASH_CR_ALGO_0 ((uint32_t)0x00000080)
• #define HASH_CR_ALGO_1 ((uint32_t)0x00040000)
• #define HASH_CR_NBW ((uint32_t)0x00000F00)
• #define HASH_CR_NBW_0 ((uint32_t)0x00000100)
• #define HASH_CR_NBW_1 ((uint32_t)0x00000200)
• #define HASH_CR_NBW_2 ((uint32_t)0x00000400)
• #define HASH_CR_NBW_3 ((uint32_t)0x00000800)
• #define HASH_CR_DINNE ((uint32_t)0x00001000)
• #define HASH_CR_MDMAT ((uint32_t)0x00002000)
• #define HASH_CR_LKEY ((uint32_t)0x00010000)
• #define HASH_STR_NBW ((uint32_t)0x0000001F)
• #define HASH_STR_NBW_0 ((uint32_t)0x00000001)
• #define HASH_STR_NBW_1 ((uint32_t)0x00000002)
• #define HASH_STR_NBW_2 ((uint32_t)0x00000004)
• #define HASH_STR_NBW_3 ((uint32_t)0x00000008)
• #define HASH_STR_NBW_4 ((uint32_t)0x00000010)
• #define HASH_STR_DCAL ((uint32_t)0x00000100)
• #define HASH_IMR_DINIM ((uint32_t)0x00000001)
• #define HASH_IMR_DCIM ((uint32_t)0x00000002)
• #define HASH_SR_DINIS ((uint32_t)0x00000001)
• #define HASH_SR_DCIS ((uint32_t)0x00000002)
• #define HASH_SR_DMAS ((uint32_t)0x00000004)
• #define HASH_SR_BUSY ((uint32_t)0x00000008)
• #define I2C_CR1_PE ((uint16_t)0x0001)
• #define I2C_CR1_SMBUS ((uint16_t)0x0002)
• #define I2C_CR1_SMBTYPE ((uint16_t)0x0008)
• #define I2C_CR1_ENARP ((uint16_t)0x0010)
• #define I2C_CR1_ENPEC ((uint16_t)0x0020)
• #define I2C_CR1_ENGC ((uint16_t)0x0040)
• #define I2C_CR1_NOSTRETCH ((uint16_t)0x0080)
• #define I2C_CR1_START ((uint16_t)0x0100)
• #define I2C_CR1_STOP ((uint16_t)0x0200)
• #define I2C_CR1_ACK ((uint16_t)0x0400)
• #define I2C_CR1_POS ((uint16_t)0x0800)
• #define I2C_CR1_PEC ((uint16_t)0x1000)
• #define I2C_CR1_ALERT ((uint16_t)0x2000)
• #define I2C_CR1_SWRST ((uint16_t)0x8000)
• #define I2C_CR2_FREQ ((uint16_t)0x003F)
• #define I2C_CR2_FREQ_0 ((uint16_t)0x0001)
• #define I2C_CR2_FREQ_1 ((uint16_t)0x0002)
• #define I2C_CR2_FREQ_2 ((uint16_t)0x0004)
• #define I2C_CR2_FREQ_3 ((uint16_t)0x0008)
• #define I2C_CR2_FREQ_4 ((uint16_t)0x0010)
• #define I2C_CR2_FREQ_5 ((uint16_t)0x0020)
• #define I2C_CR2_IERREN ((uint16_t)0x0100)
• #define I2C_CR2_IETVTEN ((uint16_t)0x0200)
• #define I2C_CR2_ITBUFEN ((uint16_t)0x0400)
• #define I2C_CR2_DMAEN ((uint16_t)0x0800)
• #define I2C_CR2_LAST ((uint16_t)0x1000)
• #define I2C_OAR1_ADD1_7 ((uint16_t)0x00FE)
• #define I2C_OAR1_ADD8_9 ((uint16_t)0x0300)
• #define I2C_OAR1_ADD0 ((uint16_t)0x0001)
• #define I2C_OAR1_ADD1 ((uint16_t)0x0002)
• #define I2C_OAR1_ADD2 ((uint16_t)0x0004)
```

- #define I2C\_OAR1\_ADD3 ((uint16\_t)0x0008)
- #define I2C\_OAR1\_ADD4 ((uint16\_t)0x0010)
- #define I2C\_OAR1\_ADD5 ((uint16\_t)0x0020)
- #define I2C\_OAR1\_ADD6 ((uint16\_t)0x0040)
- #define I2C\_OAR1\_ADD7 ((uint16\_t)0x0080)
- #define I2C\_OAR1\_ADD8 ((uint16\_t)0x0100)
- #define I2C\_OAR1\_ADD9 ((uint16\_t)0x0200)
- #define I2C\_OAR1\_ADDMODE ((uint16\_t)0x8000)
- #define I2C\_OAR2\_ENDUAL ((uint8\_t)0x01)
- #define I2C\_OAR2\_ADD2 ((uint8\_t)0xFE)
- #define I2C\_DR\_DR ((uint8\_t)0xFF)
- #define I2C\_SR1\_SB ((uint16\_t)0x0001)
- #define I2C\_SR1\_ADDR ((uint16\_t)0x0002)
- #define I2C\_SR1\_BTF ((uint16\_t)0x0004)
- #define I2C\_SR1\_ADD10 ((uint16\_t)0x0008)
- #define I2C\_SR1\_STOPF ((uint16\_t)0x0010)
- #define I2C\_SR1\_RXNE ((uint16\_t)0x0040)
- #define I2C\_SR1\_TXE ((uint16\_t)0x0080)
- #define I2C\_SR1\_BERR ((uint16\_t)0x0100)
- #define I2C\_SR1\_ARLO ((uint16\_t)0x0200)
- #define I2C\_SR1\_AF ((uint16\_t)0x0400)
- #define I2C\_SR1\_OVR ((uint16\_t)0x0800)
- #define I2C\_SR1\_PECERR ((uint16\_t)0x1000)
- #define I2C\_SR1\_TIMEOUT ((uint16\_t)0x4000)
- #define I2C\_SR1\_SMBALERT ((uint16\_t)0x8000)
- #define I2C\_SR2\_MSL ((uint16\_t)0x0001)
- #define I2C\_SR2\_BUSY ((uint16\_t)0x0002)
- #define I2C\_SR2\_TRA ((uint16\_t)0x0004)
- #define I2C\_SR2\_GENCALL ((uint16\_t)0x0010)
- #define I2C\_SR2\_SMBDEFAULT ((uint16\_t)0x0020)
- #define I2C\_SR2\_SMBHOST ((uint16\_t)0x0040)
- #define I2C\_SR2\_DUALF ((uint16\_t)0x0080)
- #define I2C\_SR2\_PEC ((uint16\_t)0xFF00)
- #define I2C\_CCR\_CCR ((uint16\_t)0xFFFF)
- #define I2C\_CCR\_DUTY ((uint16\_t)0x4000)
- #define I2C\_CCR\_FS ((uint16\_t)0x8000)
- #define I2C\_TRISE\_TRISE ((uint8\_t)0x3F)
- #define I2C\_FLTR\_DNF ((uint8\_t)0x0F)
- #define I2C\_FLTR\_ANOFF ((uint8\_t)0x10)
- #define IWDG\_KR\_KEY ((uint16\_t)0xFFFF)
- #define IWDG\_PR\_PR ((uint8\_t)0x07)
- #define IWDG\_PR\_PR\_0 ((uint8\_t)0x01)
- #define IWDG\_PR\_PR\_1 ((uint8\_t)0x02)
- #define IWDG\_PR\_PR\_2 ((uint8\_t)0x04)
- #define IWDG\_RLR\_RL ((uint16\_t)0xFFFF)
- #define IWDG\_SR\_PVU ((uint8\_t)0x01)
- #define IWDG\_SR\_RVU ((uint8\_t)0x02)
- #define LTDC\_SSCR\_VSH ((uint32\_t)0x0000007FF)
- #define LTDC\_SSCR\_HSW ((uint32\_t)0x0FFF0000)
- #define LTDC\_BPCR\_AVBP ((uint32\_t)0x0000007FF)
- #define LTDC\_BPCR\_AHBP ((uint32\_t)0x0FFF0000)
- #define LTDC\_AWCR\_AAH ((uint32\_t)0x0000007FF)
- #define LTDC\_AWCR\_AAW ((uint32\_t)0x0FFF0000)
- #define LTDC\_TWCR\_TOTALH ((uint32\_t)0x0000007FF)
- #define LTDC\_TWCR\_TOTALW ((uint32\_t)0x0FFF0000)

```
• #define LTDC_GCR_LTDCEN ((uint32_t)0x00000001)
• #define LTDC_GCR_DBW ((uint32_t)0x00000070)
• #define LTDC_GCR_DGW ((uint32_t)0x00000700)
• #define LTDC_GCR_DRW ((uint32_t)0x00007000)
• #define LTDC_GCR_DEN ((uint32_t)0x00010000)
• #define LTDC_GCR_PCPOL ((uint32_t)0x10000000)
• #define LTDC_GCR_DEPOL ((uint32_t)0x20000000)
• #define LTDC_GCR_VSPOL ((uint32_t)0x40000000)
• #define LTDC_GCR_HSPOL ((uint32_t)0x80000000)
• #define LTDC_GCR_DTEN LTDC_GCR_DEN
• #define LTDC_SRCR_IMR ((uint32_t)0x00000001)
• #define LTDC_SRCR_VBR ((uint32_t)0x00000002)
• #define LTDC_BCCR_BCBLUE ((uint32_t)0x000000FF)
• #define LTDC_BCCR_BCGREEN ((uint32_t)0x0000FF00)
• #define LTDC_BCCR_BCRED ((uint32_t)0x00FF0000)
• #define LTDC_IER_LIE ((uint32_t)0x00000001)
• #define LTDC_IER_FUIE ((uint32_t)0x00000002)
• #define LTDC_IER_TERRIE ((uint32_t)0x00000004)
• #define LTDC_IER_RRIE ((uint32_t)0x00000008)
• #define LTDC_ISR_LIF ((uint32_t)0x00000001)
• #define LTDC_ISR_FUIF ((uint32_t)0x00000002)
• #define LTDC_ISR_TERRIF ((uint32_t)0x00000004)
• #define LTDC_ISR_RRIIF ((uint32_t)0x00000008)
• #define LTDC_ICR_CLIF ((uint32_t)0x00000001)
• #define LTDC_ICR_CFUIF ((uint32_t)0x00000002)
• #define LTDC_ICR_CTERRIF ((uint32_t)0x00000004)
• #define LTDC_ICR_CRRIF ((uint32_t)0x00000008)
• #define LTDC_LPCR_LPOS ((uint32_t)0x000007FF)
• #define LTDC_CPSR_CYPOS ((uint32_t)0x0000FFFF)
• #define LTDC_CPSR_CXPOS ((uint32_t)0xFFFF0000)
• #define LTDC_CDSR_VDES ((uint32_t)0x00000001)
• #define LTDC_CDSR_HDES ((uint32_t)0x00000002)
• #define LTDC_CDSR_VSYNCs ((uint32_t)0x00000004)
• #define LTDC_CDSR_HSYNCs ((uint32_t)0x00000008)
• #define LTDC_LxCR_LEN ((uint32_t)0x00000001)
• #define LTDC_LxCR_COLKEN ((uint32_t)0x00000002)
• #define LTDC_LxCR_CLUTEN ((uint32_t)0x00000010)
• #define LTDC_LxWHPCR_WHSTPOS ((uint32_t)0x00000FFF)
• #define LTDC_LxWHPCR_WHSPPOS ((uint32_t)0xFFFF0000)
• #define LTDC_LxWVPCR_WVSTPOS ((uint32_t)0x00000FFF)
• #define LTDC_LxWVPCR_WVSPPOS ((uint32_t)0xFFFF0000)
• #define LTDC_LxCKCR_CKBLUE ((uint32_t)0x000000FF)
• #define LTDC_LxCKCR_CKGREEN ((uint32_t)0x0000FF00)
• #define LTDC_LxCKCR_CKRED ((uint32_t)0x00FF0000)
• #define LTDC_LxPFCR_PF ((uint32_t)0x00000007)
• #define LTDC_LxCACR_CONSTA ((uint32_t)0x000000FF)
• #define LTDC_LxDCCR_DCBLUE ((uint32_t)0x000000FF)
• #define LTDC_LxDCCR_DCGREEN ((uint32_t)0x0000FF00)
• #define LTDC_LxDCCR_DCRED ((uint32_t)0x00FF0000)
• #define LTDC_LxDCCR_DCALPHA ((uint32_t)0xFF000000)
• #define LTDC_LxBFCR_BF2 ((uint32_t)0x00000007)
• #define LTDC_LxBFCR_BF1 ((uint32_t)0x00000700)
• #define LTDC_LxCFBAR_CFBADD ((uint32_t)0xFFFFFFFF)
• #define LTDC_LxCFBLR_CFBLL ((uint32_t)0x00001FFF)
• #define LTDC_LxCFBLR_CFBP ((uint32_t)0x1FFF0000)
```

- #define LTDC\_LxCFBLNR\_CFBLNBR ((uint32\_t)0x000007FF)
- #define LTDC\_LxCLUTWR\_BLUE ((uint32\_t)0x000000FF)
- #define LTDC\_LxCLUTWR\_GREEN ((uint32\_t)0x0000FF00)
- #define LTDC\_LxCLUTWR\_RED ((uint32\_t)0x00FF0000)
- #define LTDC\_LxCLUTWR\_CLUTADD ((uint32\_t)0xFF000000)
- #define PWR\_CR\_LPDS ((uint32\_t)0x00000001)
- #define PWR\_CR\_PDDS ((uint32\_t)0x00000002)
- #define PWR\_CR\_CWUF ((uint32\_t)0x00000004)
- #define PWR\_CR\_CSBF ((uint32\_t)0x00000008)
- #define PWR\_CR\_PVDE ((uint32\_t)0x00000010)
- #define PWR\_CR\_PLS ((uint32\_t)0x000000E0)
- #define PWR\_CR\_PLS\_0 ((uint32\_t)0x00000020)
- #define PWR\_CR\_PLS\_1 ((uint32\_t)0x00000040)
- #define PWR\_CR\_PLS\_2 ((uint32\_t)0x00000080)
- #define PWR\_CR\_PLS\_LEV0 ((uint32\_t)0x00000000)
- #define PWR\_CR\_PLS\_LEV1 ((uint32\_t)0x00000020)
- #define PWR\_CR\_PLS\_LEV2 ((uint32\_t)0x00000040)
- #define PWR\_CR\_PLS\_LEV3 ((uint32\_t)0x00000060)
- #define PWR\_CR\_PLS\_LEV4 ((uint32\_t)0x00000080)
- #define PWR\_CR\_PLS\_LEV5 ((uint32\_t)0x000000A0)
- #define PWR\_CR\_PLS\_LEV6 ((uint32\_t)0x000000C0)
- #define PWR\_CR\_PLS\_LEV7 ((uint32\_t)0x000000E0)
- #define PWR\_CR\_DBP ((uint32\_t)0x00000100)
- #define PWR\_CR\_FPDS ((uint32\_t)0x00000200)
- #define PWR\_CR\_LPUDS ((uint32\_t)0x00000400)
- #define PWR\_CR\_MRUDS ((uint32\_t)0x00000800)
- #define PWR\_CR\_LPLVDS ((uint32\_t)0x00000400)
- #define PWR\_CR\_MRLVDS ((uint32\_t)0x00000800)
- #define PWR\_CR\_ADCDC1 ((uint32\_t)0x00002000)
- #define PWR\_CR\_VOS ((uint32\_t)0x0000C000)
- #define PWR\_CR\_VOS\_0 ((uint32\_t)0x00004000)
- #define PWR\_CR\_VOS\_1 ((uint32\_t)0x00008000)
- #define PWR\_CR\_ODEN ((uint32\_t)0x00010000)
- #define PWR\_CR\_ODSWEN ((uint32\_t)0x00020000)
- #define PWR\_CR\_UDEN ((uint32\_t)0x000C0000)
- #define PWR\_CR\_UDEN\_0 ((uint32\_t)0x00040000)
- #define PWR\_CR\_UDEN\_1 ((uint32\_t)0x00080000)
- #define PWR\_CR\_FMSSR ((uint32\_t)0x00100000)
- #define PWR\_CR\_FISSR ((uint32\_t)0x00200000)
- #define PWR\_CR\_PMODE PWR\_CR\_VOS
- #define PWR\_CSR\_WUF ((uint32\_t)0x00000001)
- #define PWR\_CSR\_SBF ((uint32\_t)0x00000002)
- #define PWR\_CSR\_PVDO ((uint32\_t)0x00000004)
- #define PWR\_CSR\_BRR ((uint32\_t)0x00000008)
- #define PWR\_CSR\_WUPP ((uint32\_t)0x00000080)
- #define PWR\_CSR\_EWUP ((uint32\_t)0x00000100)
- #define PWR\_CSR\_BRE ((uint32\_t)0x00000200)
- #define PWR\_CSR\_VOSRDY ((uint32\_t)0x00004000)
- #define PWR\_CSR\_ODRDY ((uint32\_t)0x00010000)
- #define PWR\_CSR\_ODSWRDY ((uint32\_t)0x00020000)
- #define PWR\_CSR\_UDSWRDY ((uint32\_t)0x000C0000)
- #define PWR\_CSR\_REGRDY PWR\_CSR\_VOSRDY
- #define RCC\_CR\_HSION ((uint32\_t)0x00000001)
- #define RCC\_CR\_HSIRDY ((uint32\_t)0x00000002)
- #define RCC\_CR\_HSITRIM ((uint32\_t)0x000000F8)

- #define **RCC\_CR\_HSITRIM\_0** ((uint32\_t)0x00000008)
- #define **RCC\_CR\_HSITRIM\_1** ((uint32\_t)0x00000010)
- #define **RCC\_CR\_HSITRIM\_2** ((uint32\_t)0x00000020)
- #define **RCC\_CR\_HSITRIM\_3** ((uint32\_t)0x00000040)
- #define **RCC\_CR\_HSITRIM\_4** ((uint32\_t)0x00000080)
- #define **RCC\_CR\_HSICAL** ((uint32\_t)0x0000FF00)
- #define **RCC\_CR\_HSICAL\_0** ((uint32\_t)0x00000100)
- #define **RCC\_CR\_HSICAL\_1** ((uint32\_t)0x00000200)
- #define **RCC\_CR\_HSICAL\_2** ((uint32\_t)0x00000400)
- #define **RCC\_CR\_HSICAL\_3** ((uint32\_t)0x00000800)
- #define **RCC\_CR\_HSICAL\_4** ((uint32\_t)0x00001000)
- #define **RCC\_CR\_HSICAL\_5** ((uint32\_t)0x00002000)
- #define **RCC\_CR\_HSICAL\_6** ((uint32\_t)0x00004000)
- #define **RCC\_CR\_HSICAL\_7** ((uint32\_t)0x00008000)
- #define **RCC\_CR\_HSEON** ((uint32\_t)0x00010000)
- #define **RCC\_CR\_HSERDY** ((uint32\_t)0x00020000)
- #define **RCC\_CR\_HSEBYP** ((uint32\_t)0x00040000)
- #define **RCC\_CR\_CSSON** ((uint32\_t)0x00080000)
- #define **RCC\_CR\_PLLON** ((uint32\_t)0x01000000)
- #define **RCC\_CR\_PLLRDY** ((uint32\_t)0x02000000)
- #define **RCC\_CR\_PLLI2SON** ((uint32\_t)0x04000000)
- #define **RCC\_CR\_PLLI2SRDY** ((uint32\_t)0x08000000)
- #define **RCC\_CR\_PLLSAION** ((uint32\_t)0x10000000)
- #define **RCC\_CR\_PLLSAIRDY** ((uint32\_t)0x20000000)
- #define **RCC\_PLLCFG\_R\_PLLM** ((uint32\_t)0x0000003F)
- #define **RCC\_PLLCFG\_R\_PLLM\_0** ((uint32\_t)0x00000001)
- #define **RCC\_PLLCFG\_R\_PLLM\_1** ((uint32\_t)0x00000002)
- #define **RCC\_PLLCFG\_R\_PLLM\_2** ((uint32\_t)0x00000004)
- #define **RCC\_PLLCFG\_R\_PLLM\_3** ((uint32\_t)0x00000008)
- #define **RCC\_PLLCFG\_R\_PLLM\_4** ((uint32\_t)0x00000010)
- #define **RCC\_PLLCFG\_R\_PLLM\_5** ((uint32\_t)0x00000020)
- #define **RCC\_PLLCFG\_R\_PLLN** ((uint32\_t)0x00007FC0)
- #define **RCC\_PLLCFG\_R\_PLLN\_0** ((uint32\_t)0x00000040)
- #define **RCC\_PLLCFG\_R\_PLLN\_1** ((uint32\_t)0x00000080)
- #define **RCC\_PLLCFG\_R\_PLLN\_2** ((uint32\_t)0x00000100)
- #define **RCC\_PLLCFG\_R\_PLLN\_3** ((uint32\_t)0x00000200)
- #define **RCC\_PLLCFG\_R\_PLLN\_4** ((uint32\_t)0x00000400)
- #define **RCC\_PLLCFG\_R\_PLLN\_5** ((uint32\_t)0x00000800)
- #define **RCC\_PLLCFG\_R\_PLLN\_6** ((uint32\_t)0x00001000)
- #define **RCC\_PLLCFG\_R\_PLLN\_7** ((uint32\_t)0x00002000)
- #define **RCC\_PLLCFG\_R\_PLLN\_8** ((uint32\_t)0x00004000)
- #define **RCC\_PLLCFG\_R\_PLLP** ((uint32\_t)0x00030000)
- #define **RCC\_PLLCFG\_R\_PLLP\_0** ((uint32\_t)0x00010000)
- #define **RCC\_PLLCFG\_R\_PLLP\_1** ((uint32\_t)0x00020000)
- #define **RCC\_PLLCFG\_R\_PLLSRC** ((uint32\_t)0x00400000)
- #define **RCC\_PLLCFG\_R\_PLLSRC\_HSE** ((uint32\_t)0x00400000)
- #define **RCC\_PLLCFG\_R\_PLLSRC\_HSI** ((uint32\_t)0x00000000)
- #define **RCC\_PLLCFG\_R\_PLLQ** ((uint32\_t)0x0F000000)
- #define **RCC\_PLLCFG\_R\_PLLQ\_0** ((uint32\_t)0x01000000)
- #define **RCC\_PLLCFG\_R\_PLLQ\_1** ((uint32\_t)0x02000000)
- #define **RCC\_PLLCFG\_R\_PLLQ\_2** ((uint32\_t)0x04000000)
- #define **RCC\_PLLCFG\_R\_PLLQ\_3** ((uint32\_t)0x08000000)
- #define **RCC\_CFGR\_SW** ((uint32\_t)0x00000003)
- #define **RCC\_CFGR\_SW\_0** ((uint32\_t)0x00000001)
- #define **RCC\_CFGR\_SW\_1** ((uint32\_t)0x00000002)

- #define **RCC\_CFGR\_SW\_HSI** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_SW\_HSE** ((uint32\_t)0x00000001)
- #define **RCC\_CFGR\_SW\_PLL** ((uint32\_t)0x00000002)
- #define **RCC\_CFGR\_SWS** ((uint32\_t)0x0000000C)
- #define **RCC\_CFGR\_SWS\_0** ((uint32\_t)0x00000004)
- #define **RCC\_CFGR\_SWS\_1** ((uint32\_t)0x00000008)
- #define **RCC\_CFGR\_SWS\_HSI** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_SWS\_HSE** ((uint32\_t)0x00000004)
- #define **RCC\_CFGR\_SWS\_PLL** ((uint32\_t)0x00000008)
- #define **RCC\_CFGR\_HPRE** ((uint32\_t)0x000000F0)
- #define **RCC\_CFGR\_HPRE\_0** ((uint32\_t)0x00000010)
- #define **RCC\_CFGR\_HPRE\_1** ((uint32\_t)0x00000020)
- #define **RCC\_CFGR\_HPRE\_2** ((uint32\_t)0x00000040)
- #define **RCC\_CFGR\_HPRE\_3** ((uint32\_t)0x00000080)
- #define **RCC\_CFGR\_HPRE\_DIV1** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_HPRE\_DIV2** ((uint32\_t)0x00000080)
- #define **RCC\_CFGR\_HPRE\_DIV4** ((uint32\_t)0x00000090)
- #define **RCC\_CFGR\_HPRE\_DIV8** ((uint32\_t)0x000000A0)
- #define **RCC\_CFGR\_HPRE\_DIV16** ((uint32\_t)0x000000B0)
- #define **RCC\_CFGR\_HPRE\_DIV64** ((uint32\_t)0x000000C0)
- #define **RCC\_CFGR\_HPRE\_DIV128** ((uint32\_t)0x000000D0)
- #define **RCC\_CFGR\_HPRE\_DIV256** ((uint32\_t)0x000000E0)
- #define **RCC\_CFGR\_HPRE\_DIV512** ((uint32\_t)0x000000F0)
- #define **RCC\_CFGR\_PPREG1** ((uint32\_t)0x00001C00)
- #define **RCC\_CFGR\_PPREG1\_0** ((uint32\_t)0x00000400)
- #define **RCC\_CFGR\_PPREG1\_1** ((uint32\_t)0x00000800)
- #define **RCC\_CFGR\_PPREG1\_2** ((uint32\_t)0x00001000)
- #define **RCC\_CFGR\_PPREG1\_DIV1** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_PPREG1\_DIV2** ((uint32\_t)0x00001000)
- #define **RCC\_CFGR\_PPREG1\_DIV4** ((uint32\_t)0x00001400)
- #define **RCC\_CFGR\_PPREG1\_DIV8** ((uint32\_t)0x00001800)
- #define **RCC\_CFGR\_PPREG1\_DIV16** ((uint32\_t)0x00001C00)
- #define **RCC\_CFGR\_PPREG2** ((uint32\_t)0x0000E000)
- #define **RCC\_CFGR\_PPREG2\_0** ((uint32\_t)0x00002000)
- #define **RCC\_CFGR\_PPREG2\_1** ((uint32\_t)0x00004000)
- #define **RCC\_CFGR\_PPREG2\_2** ((uint32\_t)0x00008000)
- #define **RCC\_CFGR\_PPREG2\_DIV1** ((uint32\_t)0x00000000)
- #define **RCC\_CFGR\_PPREG2\_DIV2** ((uint32\_t)0x00008000)
- #define **RCC\_CFGR\_PPREG2\_DIV4** ((uint32\_t)0x0000A000)
- #define **RCC\_CFGR\_PPREG2\_DIV8** ((uint32\_t)0x0000C000)
- #define **RCC\_CFGR\_PPREG2\_DIV16** ((uint32\_t)0x0000E000)
- #define **RCC\_CFGR\_RTCPPRE** ((uint32\_t)0x001F0000)
- #define **RCC\_CFGR\_RTCPPRE\_0** ((uint32\_t)0x00010000)
- #define **RCC\_CFGR\_RTCPPRE\_1** ((uint32\_t)0x00020000)
- #define **RCC\_CFGR\_RTCPPRE\_2** ((uint32\_t)0x00040000)
- #define **RCC\_CFGR\_RTCPPRE\_3** ((uint32\_t)0x00080000)
- #define **RCC\_CFGR\_RTCPPRE\_4** ((uint32\_t)0x00100000)
- #define **RCC\_CFGR\_MCO1** ((uint32\_t)0x00600000)
- #define **RCC\_CFGR\_MCO1\_0** ((uint32\_t)0x00200000)
- #define **RCC\_CFGR\_MCO1\_1** ((uint32\_t)0x00400000)
- #define **RCC\_CFGR\_I2SSRC** ((uint32\_t)0x00800000)
- #define **RCC\_CFGR\_MCO1PRE** ((uint32\_t)0x07000000)
- #define **RCC\_CFGR\_MCO1PRE\_0** ((uint32\_t)0x01000000)
- #define **RCC\_CFGR\_MCO1PRE\_1** ((uint32\_t)0x02000000)
- #define **RCC\_CFGR\_MCO1PRE\_2** ((uint32\_t)0x04000000)

```
• #define RCC_CFGR_MCO2PRE ((uint32_t)0x38000000)
• #define RCC_CFGR_MCO2PRE_0 ((uint32_t)0x08000000)
• #define RCC_CFGR_MCO2PRE_1 ((uint32_t)0x10000000)
• #define RCC_CFGR_MCO2PRE_2 ((uint32_t)0x20000000)
• #define RCC_CFGR_MCO2 ((uint32_t)0xC0000000)
• #define RCC_CFGR_MCO2_0 ((uint32_t)0x40000000)
• #define RCC_CFGR_MCO2_1 ((uint32_t)0x80000000)
• #define RCC_CIR_LSIRDYF ((uint32_t)0x00000001)
• #define RCC_CIR_LSERDYF ((uint32_t)0x00000002)
• #define RCC_CIR_HSIRDYF ((uint32_t)0x00000004)
• #define RCC_CIR_HSERDYF ((uint32_t)0x00000008)
• #define RCC_CIR_PLLRDYF ((uint32_t)0x00000010)
• #define RCC_CIR_PLLI2SRDYF ((uint32_t)0x00000020)
• #define RCC_CIR_PLLSAIRDYF ((uint32_t)0x00000040)
• #define RCC_CIR_CSSF ((uint32_t)0x00000080)
• #define RCC_CIR_LSIRDYIE ((uint32_t)0x00000100)
• #define RCC_CIR_LSERDYIE ((uint32_t)0x00000200)
• #define RCC_CIR_HSIRDYIE ((uint32_t)0x00000400)
• #define RCC_CIR_HSERDYIE ((uint32_t)0x00000800)
• #define RCC_CIR_PLLRDYIE ((uint32_t)0x00001000)
• #define RCC_CIR_PLLI2SRDYIE ((uint32_t)0x00002000)
• #define RCC_CIR_PLLSAIRDYIE ((uint32_t)0x00004000)
• #define RCC_CIR_LSIRDYC ((uint32_t)0x00010000)
• #define RCC_CIR_LSERDYC ((uint32_t)0x00020000)
• #define RCC_CIR_HSIRDYC ((uint32_t)0x00040000)
• #define RCC_CIR_HSERDYC ((uint32_t)0x00080000)
• #define RCC_CIR_PLLRDYC ((uint32_t)0x00100000)
• #define RCC_CIR_PLLI2SRDYC ((uint32_t)0x00200000)
• #define RCC_CIR_PLLSAIRDYC ((uint32_t)0x00400000)
• #define RCC_CIR_CSSC ((uint32_t)0x00800000)
• #define RCC_AHB1RSTR_GPIOARST ((uint32_t)0x00000001)
• #define RCC_AHB1RSTR_GPIOBRST ((uint32_t)0x00000002)
• #define RCC_AHB1RSTR_GPIOCRST ((uint32_t)0x00000004)
• #define RCC_AHB1RSTR_GPIODRST ((uint32_t)0x00000008)
• #define RCC_AHB1RSTR_GPIOERST ((uint32_t)0x00000010)
• #define RCC_AHB1RSTR_GPIOFRST ((uint32_t)0x00000020)
• #define RCC_AHB1RSTR_GPIORST ((uint32_t)0x00000040)
• #define RCC_AHB1RSTR_GPIOHRST ((uint32_t)0x00000080)
• #define RCC_AHB1RSTR_GPIOIRST ((uint32_t)0x00000100)
• #define RCC_AHB1RSTR_GPIOJRST ((uint32_t)0x00000200)
• #define RCC_AHB1RSTR_GPIOKRST ((uint32_t)0x00000400)
• #define RCC_AHB1RSTR_CRCRST ((uint32_t)0x00001000)
• #define RCC_AHB1RSTR_DMA1RST ((uint32_t)0x00200000)
• #define RCC_AHB1RSTR_DMA2RST ((uint32_t)0x00400000)
• #define RCC_AHB1RSTR_DMA2DRST ((uint32_t)0x00800000)
• #define RCC_AHB1RSTR_ETHMACRST ((uint32_t)0x02000000)
• #define RCC_AHB1RSTR_OTGHRST ((uint32_t)0x10000000)
• #define RCC_AHB2RSTR_DCMIRST ((uint32_t)0x00000001)
• #define RCC_AHB2RSTR_CRYPRST ((uint32_t)0x00000010)
• #define RCC_AHB2RSTR_HASHRST ((uint32_t)0x00000020)
• #define RCC_AHB2RSTR_HSAHRST RCC_AHB2RSTR_HASHRST
• #define RCC_AHB2RSTR_RNGRST ((uint32_t)0x00000040)
• #define RCC_AHB2RSTR_OTGFSRST ((uint32_t)0x00000080)
• #define RCC_APB1RSTR_TIM2RST ((uint32_t)0x00000001)
• #define RCC_APB1RSTR_TIM3RST ((uint32_t)0x00000002)
```

- #define **RCC\_APB1RSTR\_TIM4RST** ((uint32\_t)0x00000004)
- #define **RCC\_APB1RSTR\_TIM5RST** ((uint32\_t)0x00000008)
- #define **RCC\_APB1RSTR\_TIM6RST** ((uint32\_t)0x00000010)
- #define **RCC\_APB1RSTR\_TIM7RST** ((uint32\_t)0x00000020)
- #define **RCC\_APB1RSTR\_TIM12RST** ((uint32\_t)0x00000040)
- #define **RCC\_APB1RSTR\_TIM13RST** ((uint32\_t)0x00000080)
- #define **RCC\_APB1RSTR\_TIM14RST** ((uint32\_t)0x00000100)
- #define **RCC\_APB1RSTR\_WWDGRST** ((uint32\_t)0x00000800)
- #define **RCC\_APB1RSTR\_SPI2RST** ((uint32\_t)0x00004000)
- #define **RCC\_APB1RSTR\_SPI3RST** ((uint32\_t)0x00008000)
- #define **RCC\_APB1RSTR\_USART2RST** ((uint32\_t)0x00020000)
- #define **RCC\_APB1RSTR\_USART3RST** ((uint32\_t)0x00040000)
- #define **RCC\_APB1RSTR\_UART4RST** ((uint32\_t)0x00080000)
- #define **RCC\_APB1RSTR\_UART5RST** ((uint32\_t)0x00100000)
- #define **RCC\_APB1RSTR\_I2C1RST** ((uint32\_t)0x00200000)
- #define **RCC\_APB1RSTR\_I2C2RST** ((uint32\_t)0x00400000)
- #define **RCC\_APB1RSTR\_I2C3RST** ((uint32\_t)0x00800000)
- #define **RCC\_APB1RSTR\_CAN1RST** ((uint32\_t)0x02000000)
- #define **RCC\_APB1RSTR\_CAN2RST** ((uint32\_t)0x04000000)
- #define **RCC\_APB1RSTR\_PWRRST** ((uint32\_t)0x10000000)
- #define **RCC\_APB1RSTR\_DACRST** ((uint32\_t)0x20000000)
- #define **RCC\_APB1RSTR\_UART7RST** ((uint32\_t)0x40000000)
- #define **RCC\_APB1RSTR\_UART8RST** ((uint32\_t)0x80000000)
- #define **RCC\_APB2RSTR\_TIM1RST** ((uint32\_t)0x00000001)
- #define **RCC\_APB2RSTR\_TIM8RST** ((uint32\_t)0x00000002)
- #define **RCC\_APB2RSTR\_USART1RST** ((uint32\_t)0x00000010)
- #define **RCC\_APB2RSTR\_USART6RST** ((uint32\_t)0x00000020)
- #define **RCC\_APB2RSTR\_UART9RST** ((uint32\_t)0x00000040)
- #define **RCC\_APB2RSTR\_UART10RST** ((uint32\_t)0x00000080)
- #define **RCC\_APB2RSTR\_ADCRST** ((uint32\_t)0x00000100)
- #define **RCC\_APB2RSTR\_SDIORST** ((uint32\_t)0x00000800)
- #define **RCC\_APB2RSTR\_SPI1RST** ((uint32\_t)0x00001000)
- #define **RCC\_APB2RSTR\_SPI4RST** ((uint32\_t)0x00002000)
- #define **RCC\_APB2RSTR\_SYSCFGRST** ((uint32\_t)0x00004000)
- #define **RCC\_APB2RSTR\_TIM9RST** ((uint32\_t)0x00010000)
- #define **RCC\_APB2RSTR\_TIM10RST** ((uint32\_t)0x00020000)
- #define **RCC\_APB2RSTR\_TIM11RST** ((uint32\_t)0x00040000)
- #define **RCC\_APB2RSTR\_SPI5RST** ((uint32\_t)0x00100000)
- #define **RCC\_APB2RSTR\_SPI6RST** ((uint32\_t)0x00200000)
- #define **RCC\_APB2RSTR\_SAI1RST** ((uint32\_t)0x00400000)
- #define **RCC\_APB2RSTR\_LTDCRST** ((uint32\_t)0x04000000)
- #define **RCC\_APB2RSTR\_SPI1** RCC\_APB2RSTR\_SPI1RST
- #define **RCC\_APB2RSTR\_DFSDMRST** RCC\_APB2RSTR\_DFSDM1RST
- #define **RCC\_AHB1ENR\_GPIOAEN** ((uint32\_t)0x00000001)
- #define **RCC\_AHB1ENR\_GPIOBEN** ((uint32\_t)0x00000002)
- #define **RCC\_AHB1ENR\_GPIOCEN** ((uint32\_t)0x00000004)
- #define **RCC\_AHB1ENR\_GPIODEN** ((uint32\_t)0x00000008)
- #define **RCC\_AHB1ENR\_GPIOEEN** ((uint32\_t)0x00000010)
- #define **RCC\_AHB1ENR\_GPIOFEN** ((uint32\_t)0x00000020)
- #define **RCC\_AHB1ENR\_GPIOGEN** ((uint32\_t)0x00000040)
- #define **RCC\_AHB1ENR\_GPIOHEN** ((uint32\_t)0x00000080)
- #define **RCC\_AHB1ENR\_GPIOIEN** ((uint32\_t)0x00000100)
- #define **RCC\_AHB1ENR\_GPIOJEN** ((uint32\_t)0x00000200)
- #define **RCC\_AHB1ENR\_GPIOKEN** ((uint32\_t)0x00000400)
- #define **RCC\_AHB1ENR\_CRCEN** ((uint32\_t)0x00001000)

- #define **RCC\_AHB1ENR\_BKPSRAMEN** ((uint32\_t)0x00040000)
- #define **RCC\_AHB1ENR\_CCMMDATARAMEN** ((uint32\_t)0x00100000)
- #define **RCC\_AHB1ENR\_DMA1EN** ((uint32\_t)0x00200000)
- #define **RCC\_AHB1ENR\_DMA2EN** ((uint32\_t)0x00400000)
- #define **RCC\_AHB1ENR\_DMA2DEN** ((uint32\_t)0x00800000)
- #define **RCC\_AHB1ENR\_ETHMACEN** ((uint32\_t)0x02000000)
- #define **RCC\_AHB1ENR\_ETHMACTXEN** ((uint32\_t)0x04000000)
- #define **RCC\_AHB1ENR\_ETHMACRXEN** ((uint32\_t)0x08000000)
- #define **RCC\_AHB1ENR\_ETHMACPTPEN** ((uint32\_t)0x10000000)
- #define **RCC\_AHB1ENR\_OTGHSEN** ((uint32\_t)0x20000000)
- #define **RCC\_AHB1ENR\_OTGHSULPIEN** ((uint32\_t)0x40000000)
- #define **RCC\_AHB2ENR\_DCMIEN** ((uint32\_t)0x00000001)
- #define **RCC\_AHB2ENR\_CRYPTEN** ((uint32\_t)0x00000010)
- #define **RCC\_AHB2ENR\_HASHEN** ((uint32\_t)0x00000020)
- #define **RCC\_AHB2ENR RNGEN** ((uint32\_t)0x00000040)
- #define **RCC\_AHB2ENR\_OTGFSEN** ((uint32\_t)0x00000080)
- #define **RCC\_APB1ENR\_TIM2EN** ((uint32\_t)0x00000001)
- #define **RCC\_APB1ENR\_TIM3EN** ((uint32\_t)0x00000002)
- #define **RCC\_APB1ENR\_TIM4EN** ((uint32\_t)0x00000004)
- #define **RCC\_APB1ENR\_TIM5EN** ((uint32\_t)0x00000008)
- #define **RCC\_APB1ENR\_TIM6EN** ((uint32\_t)0x00000010)
- #define **RCC\_APB1ENR\_TIM7EN** ((uint32\_t)0x00000020)
- #define **RCC\_APB1ENR\_TIM12EN** ((uint32\_t)0x00000040)
- #define **RCC\_APB1ENR\_TIM13EN** ((uint32\_t)0x00000080)
- #define **RCC\_APB1ENR\_TIM14EN** ((uint32\_t)0x00000100)
- #define **RCC\_APB1ENR\_WWDGEN** ((uint32\_t)0x00000800)
- #define **RCC\_APB1ENR\_SPI2EN** ((uint32\_t)0x00004000)
- #define **RCC\_APB1ENR\_SPI3EN** ((uint32\_t)0x00008000)
- #define **RCC\_APB1ENR\_USART2EN** ((uint32\_t)0x00020000)
- #define **RCC\_APB1ENR\_USART3EN** ((uint32\_t)0x00040000)
- #define **RCC\_APB1ENR\_UART4EN** ((uint32\_t)0x00080000)
- #define **RCC\_APB1ENR\_UART5EN** ((uint32\_t)0x00100000)
- #define **RCC\_APB1ENR\_I2C1EN** ((uint32\_t)0x00200000)
- #define **RCC\_APB1ENR\_I2C2EN** ((uint32\_t)0x00400000)
- #define **RCC\_APB1ENR\_I2C3EN** ((uint32\_t)0x00800000)
- #define **RCC\_APB1ENR\_CAN1EN** ((uint32\_t)0x02000000)
- #define **RCC\_APB1ENR\_CAN2EN** ((uint32\_t)0x04000000)
- #define **RCC\_APB1ENR\_PWREN** ((uint32\_t)0x10000000)
- #define **RCC\_APB1ENR\_DACEN** ((uint32\_t)0x20000000)
- #define **RCC\_APB1ENR\_UART7EN** ((uint32\_t)0x40000000)
- #define **RCC\_APB1ENR\_UART8EN** ((uint32\_t)0x80000000)
- #define **RCC\_APB2ENR\_TIM1EN** ((uint32\_t)0x00000001)
- #define **RCC\_APB2ENR\_TIM8EN** ((uint32\_t)0x00000002)
- #define **RCC\_APB2ENR\_USART1EN** ((uint32\_t)0x00000010)
- #define **RCC\_APB2ENR\_USART6EN** ((uint32\_t)0x00000020)
- #define **RCC\_APB2ENR\_UART9EN** ((uint32\_t)0x00000040)
- #define **RCC\_APB2ENR\_UART10EN** ((uint32\_t)0x00000080)
- #define **RCC\_APB2ENR\_ADC1EN** ((uint32\_t)0x00000100)
- #define **RCC\_APB2ENR\_ADC2EN** ((uint32\_t)0x00000200)
- #define **RCC\_APB2ENR\_ADC3EN** ((uint32\_t)0x00000400)
- #define **RCC\_APB2ENR\_SDIOEN** ((uint32\_t)0x00000800)
- #define **RCC\_APB2ENR\_SPI1EN** ((uint32\_t)0x00001000)
- #define **RCC\_APB2ENR\_SPI4EN** ((uint32\_t)0x00002000)
- #define **RCC\_APB2ENR\_SYSCFGEN** ((uint32\_t)0x00004000)
- #define **RCC\_APB2ENR\_EXTIEN** ((uint32\_t)0x00008000)

- #define **RCC\_APB2ENR\_TIM9EN** ((uint32\_t)0x00010000)
- #define **RCC\_APB2ENR\_TIM10EN** ((uint32\_t)0x00020000)
- #define **RCC\_APB2ENR\_TIM11EN** ((uint32\_t)0x00040000)
- #define **RCC\_APB2ENR\_SPI5EN** ((uint32\_t)0x00100000)
- #define **RCC\_APB2ENR\_SPI6EN** ((uint32\_t)0x00200000)
- #define **RCC\_APB2ENR\_SAI1EN** ((uint32\_t)0x00400000)
- #define **RCC\_APB2ENR\_LTDCEN** ((uint32\_t)0x04000000)
- #define **RCC\_AHB1LPENR\_GPIOALPEN** ((uint32\_t)0x00000001)
- #define **RCC\_AHB1LPENR\_GPIOBLPEN** ((uint32\_t)0x00000002)
- #define **RCC\_AHB1LPENR\_GPIOCLPEN** ((uint32\_t)0x00000004)
- #define **RCC\_AHB1LPENR\_GPIODLPEN** ((uint32\_t)0x00000008)
- #define **RCC\_AHB1LPENR\_GPIOELPEN** ((uint32\_t)0x00000010)
- #define **RCC\_AHB1LPENR\_GPIOFLPEN** ((uint32\_t)0x00000020)
- #define **RCC\_AHB1LPENR\_GPIOGLPEN** ((uint32\_t)0x00000040)
- #define **RCC\_AHB1LPENR\_GPIOHLPEN** ((uint32\_t)0x00000080)
- #define **RCC\_AHB1LPENR\_GPIOILPEN** ((uint32\_t)0x00000100)
- #define **RCC\_AHB1LPENR\_GPIOJLPEN** ((uint32\_t)0x00000200)
- #define **RCC\_AHB1LPENR\_GPIOKLPEN** ((uint32\_t)0x00000400)
- #define **RCC\_AHB1LPENR\_CRCLPEN** ((uint32\_t)0x00001000)
- #define **RCC\_AHB1LPENR\_FLITFLPEN** ((uint32\_t)0x00008000)
- #define **RCC\_AHB1LPENR\_SRAM1LPEN** ((uint32\_t)0x00010000)
- #define **RCC\_AHB1LPENR\_SRAM2LPEN** ((uint32\_t)0x00020000)
- #define **RCC\_AHB1LPENR\_BKPSRAMLPEN** ((uint32\_t)0x00040000)
- #define **RCC\_AHB1LPENR\_SRAM3LPEN** ((uint32\_t)0x00080000)
- #define **RCC\_AHB1LPENR\_DMA1LPEN** ((uint32\_t)0x00200000)
- #define **RCC\_AHB1LPENR\_DMA2LPEN** ((uint32\_t)0x00400000)
- #define **RCC\_AHB1LPENR\_DMA2DLPEN** ((uint32\_t)0x00800000)
- #define **RCC\_AHB1LPENR\_ETHMACLPEN** ((uint32\_t)0x02000000)
- #define **RCC\_AHB1LPENR\_ETHMACTXLPEN** ((uint32\_t)0x04000000)
- #define **RCC\_AHB1LPENR\_ETHMACRXLPEN** ((uint32\_t)0x08000000)
- #define **RCC\_AHB1LPENR\_ETHMACPTPLPEN** ((uint32\_t)0x10000000)
- #define **RCC\_AHB1LPENR\_OTGHSLPEN** ((uint32\_t)0x20000000)
- #define **RCC\_AHB1LPENR\_OTGHSULPILPEN** ((uint32\_t)0x40000000)
- #define **RCC\_AHB2LPENR\_DCMILPEN** ((uint32\_t)0x00000001)
- #define **RCC\_AHB2LPENR\_CRYPLPEN** ((uint32\_t)0x00000010)
- #define **RCC\_AHB2LPENR\_HASHLPEN** ((uint32\_t)0x00000020)
- #define **RCC\_AHB2LPENR\_RNGLPEN** ((uint32\_t)0x00000040)
- #define **RCC\_AHB2LPENR\_OTGFSLPEN** ((uint32\_t)0x00000080)
- #define **RCC\_APB1LPENR\_TIM2LPEN** ((uint32\_t)0x00000001)
- #define **RCC\_APB1LPENR\_TIM3LPEN** ((uint32\_t)0x00000002)
- #define **RCC\_APB1LPENR\_TIM4LPEN** ((uint32\_t)0x00000004)
- #define **RCC\_APB1LPENR\_TIM5LPEN** ((uint32\_t)0x00000008)
- #define **RCC\_APB1LPENR\_TIM6LPEN** ((uint32\_t)0x00000010)
- #define **RCC\_APB1LPENR\_TIM7LPEN** ((uint32\_t)0x00000020)
- #define **RCC\_APB1LPENR\_TIM12LPEN** ((uint32\_t)0x00000040)
- #define **RCC\_APB1LPENR\_TIM13LPEN** ((uint32\_t)0x00000080)
- #define **RCC\_APB1LPENR\_TIM14LPEN** ((uint32\_t)0x00000100)
- #define **RCC\_APB1LPENR\_WWDGLPEN** ((uint32\_t)0x00000800)
- #define **RCC\_APB1LPENR\_SPI2LPEN** ((uint32\_t)0x00004000)
- #define **RCC\_APB1LPENR\_SPI3LPEN** ((uint32\_t)0x00008000)
- #define **RCC\_APB1LPENR\_USART2LPEN** ((uint32\_t)0x00020000)
- #define **RCC\_APB1LPENR\_USART3LPEN** ((uint32\_t)0x00040000)
- #define **RCC\_APB1LPENR\_UART4LPEN** ((uint32\_t)0x00080000)
- #define **RCC\_APB1LPENR\_UART5LPEN** ((uint32\_t)0x00100000)
- #define **RCC\_APB1LPENR\_I2C1LPEN** ((uint32\_t)0x00200000)

- #define **RCC\_APB1LPENR\_I2C2LPEN** ((uint32\_t)0x00400000)
- #define **RCC\_APB1LPENR\_I2C3LPEN** ((uint32\_t)0x00800000)
- #define **RCC\_APB1LPENR\_CAN1LPEN** ((uint32\_t)0x02000000)
- #define **RCC\_APB1LPENR\_CAN2LPEN** ((uint32\_t)0x04000000)
- #define **RCC\_APB1LPENR\_PWRLPEN** ((uint32\_t)0x10000000)
- #define **RCC\_APB1LPENR\_DACLPEN** ((uint32\_t)0x20000000)
- #define **RCC\_APB1LPENR\_UART7LPEN** ((uint32\_t)0x40000000)
- #define **RCC\_APB1LPENR\_UART8LPEN** ((uint32\_t)0x80000000)
- #define **RCC\_APB2LPENR\_TIM1LPEN** ((uint32\_t)0x00000001)
- #define **RCC\_APB2LPENR\_TIM8LPEN** ((uint32\_t)0x00000002)
- #define **RCC\_APB2LPENR\_USART1LPEN** ((uint32\_t)0x00000010)
- #define **RCC\_APB2LPENR\_USART6LPEN** ((uint32\_t)0x00000020)
- #define **RCC\_APB2LPENR\_UART9LPEN** ((uint32\_t)0x00000040)
- #define **RCC\_APB2LPENR\_UART10LPEN** ((uint32\_t)0x00000080)
- #define **RCC\_APB2LPENR\_ADC1LPEN** ((uint32\_t)0x00000100)
- #define **RCC\_APB2LPENR\_ADC2PEN** ((uint32\_t)0x00000200)
- #define **RCC\_APB2LPENR\_ADC3LPEN** ((uint32\_t)0x00000400)
- #define **RCC\_APB2LPENR\_SDIOLPEN** ((uint32\_t)0x00000800)
- #define **RCC\_APB2LPENR\_SPI1LPEN** ((uint32\_t)0x00001000)
- #define **RCC\_APB2LPENR\_SPI4LPEN** ((uint32\_t)0x00002000)
- #define **RCC\_APB2LPENR\_SYSCFGLPEN** ((uint32\_t)0x00004000)
- #define **RCC\_APB2LPENR\_TIM9LPEN** ((uint32\_t)0x00010000)
- #define **RCC\_APB2LPENR\_TIM10LPEN** ((uint32\_t)0x00020000)
- #define **RCC\_APB2LPENR\_TIM11LPEN** ((uint32\_t)0x00040000)
- #define **RCC\_APB2LPENR\_SPI5LPEN** ((uint32\_t)0x00100000)
- #define **RCC\_APB2LPENR\_SPI6LPEN** ((uint32\_t)0x00200000)
- #define **RCC\_APB2LPENR\_SAI1LPEN** ((uint32\_t)0x00400000)
- #define **RCC\_APB2LPENR\_LTDCLPEN** ((uint32\_t)0x04000000)
- #define **RCC\_BDCR\_LSEON** ((uint32\_t)0x00000001)
- #define **RCC\_BDCR\_LSERDY** ((uint32\_t)0x00000002)
- #define **RCC\_BDCR\_LSEBYP** ((uint32\_t)0x00000004)
- #define **RCC\_BDCR\_LSEMOD** ((uint32\_t)0x00000008)
- #define **RCC\_BDCR\_RTCSEL** ((uint32\_t)0x00000300)
- #define **RCC\_BDCR\_RTCSEL\_0** ((uint32\_t)0x00000100)
- #define **RCC\_BDCR\_RTCSEL\_1** ((uint32\_t)0x00000200)
- #define **RCC\_BDCR\_RTCEN** ((uint32\_t)0x00008000)
- #define **RCC\_BDCR\_BDRST** ((uint32\_t)0x00010000)
- #define **RCC\_CSR\_LSION** ((uint32\_t)0x00000001)
- #define **RCC\_CSR\_LSIRDY** ((uint32\_t)0x00000002)
- #define **RCC\_CSR\_RMVF** ((uint32\_t)0x01000000)
- #define **RCC\_CSR\_BORRSTF** ((uint32\_t)0x02000000)
- #define **RCC\_CSR\_PADRSTF** ((uint32\_t)0x04000000)
- #define **RCC\_CSR\_PORRSTF** ((uint32\_t)0x08000000)
- #define **RCC\_CSR\_SFTRSTF** ((uint32\_t)0x10000000)
- #define **RCC\_CSR\_WDGRSTF** ((uint32\_t)0x20000000)
- #define **RCC\_CSR\_WWDGRSTF** ((uint32\_t)0x40000000)
- #define **RCC\_CSR\_LPWRRSTF** ((uint32\_t)0x80000000)
- #define **RCC\_SSCGR\_MODPER** ((uint32\_t)0x00001FFF)
- #define **RCC\_SSCGR\_INCSTEP** ((uint32\_t)0x0FFE000)
- #define **RCC\_SSCGR\_SPREADSEL** ((uint32\_t)0x40000000)
- #define **RCC\_SSCGR\_SSCGEN** ((uint32\_t)0x80000000)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM** ((uint32\_t)0x0000003F)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM\_0** ((uint32\_t)0x00000001)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM\_1** ((uint32\_t)0x00000002)
- #define **RCC\_PLLI2SCFGR\_PLLI2SM\_2** ((uint32\_t)0x00000004)

```
• #define RCC_PLLI2SCFGR_PLLI2SM_3 ((uint32_t)0x00000008)
• #define RCC_PLLI2SCFGR_PLLI2SM_4 ((uint32_t)0x00000010)
• #define RCC_PLLI2SCFGR_PLLI2SM_5 ((uint32_t)0x00000020)
• #define RCC_PLLI2SCFGR_PLLI2SN ((uint32_t)0x00007FC0)
• #define RCC_PLLI2SCFGR_PLLI2SN_0 ((uint32_t)0x00000040)
• #define RCC_PLLI2SCFGR_PLLI2SN_1 ((uint32_t)0x00000080)
• #define RCC_PLLI2SCFGR_PLLI2SN_2 ((uint32_t)0x00000100)
• #define RCC_PLLI2SCFGR_PLLI2SN_3 ((uint32_t)0x00000200)
• #define RCC_PLLI2SCFGR_PLLI2SN_4 ((uint32_t)0x00000400)
• #define RCC_PLLI2SCFGR_PLLI2SN_5 ((uint32_t)0x00000800)
• #define RCC_PLLI2SCFGR_PLLI2SN_6 ((uint32_t)0x00001000)
• #define RCC_PLLI2SCFGR_PLLI2SN_7 ((uint32_t)0x00002000)
• #define RCC_PLLI2SCFGR_PLLI2SN_8 ((uint32_t)0x00004000)
• #define RCC_PLLI2SCFGR_PLLI2SQ ((uint32_t)0x0F000000)
• #define RCC_PLLI2SCFGR_PLLI2SQ_0 ((uint32_t)0x01000000)
• #define RCC_PLLI2SCFGR_PLLI2SQ_1 ((uint32_t)0x02000000)
• #define RCC_PLLI2SCFGR_PLLI2SQ_2 ((uint32_t)0x04000000)
• #define RCC_PLLI2SCFGR_PLLI2SQ_3 ((uint32_t)0x08000000)
• #define RCC_PLLI2SCFGR_PLLI2SR ((uint32_t)0x70000000)
• #define RCC_PLLI2SCFGR_PLLI2SR_0 ((uint32_t)0x10000000)
• #define RCC_PLLI2SCFGR_PLLI2SR_1 ((uint32_t)0x20000000)
• #define RCC_PLLI2SCFGR_PLLI2SR_2 ((uint32_t)0x40000000)
• #define RCC_PLLSAICFGR_PLLSAIN ((uint32_t)0x00007FC0)
• #define RCC_PLLSAICFGR_PLLSAIN_0 ((uint32_t)0x00000040)
• #define RCC_PLLSAICFGR_PLLSAIN_1 ((uint32_t)0x00000080)
• #define RCC_PLLSAICFGR_PLLSAIN_2 ((uint32_t)0x00000100)
• #define RCC_PLLSAICFGR_PLLSAIN_3 ((uint32_t)0x00000200)
• #define RCC_PLLSAICFGR_PLLSAIN_4 ((uint32_t)0x00000400)
• #define RCC_PLLSAICFGR_PLLSAIN_5 ((uint32_t)0x00000800)
• #define RCC_PLLSAICFGR_PLLSAIN_6 ((uint32_t)0x00001000)
• #define RCC_PLLSAICFGR_PLLSAIN_7 ((uint32_t)0x00002000)
• #define RCC_PLLSAICFGR_PLLSAIN_8 ((uint32_t)0x00004000)
• #define RCC_PLLSAICFGR_PLLSAIQ ((uint32_t)0x0F000000)
• #define RCC_PLLSAICFGR_PLLSAIQ_0 ((uint32_t)0x01000000)
• #define RCC_PLLSAICFGR_PLLSAIQ_1 ((uint32_t)0x02000000)
• #define RCC_PLLSAICFGR_PLLSAIQ_2 ((uint32_t)0x04000000)
• #define RCC_PLLSAICFGR_PLLSAIQ_3 ((uint32_t)0x08000000)
• #define RCC_PLLSAICFGR_PLLSAIR ((uint32_t)0x70000000)
• #define RCC_PLLSAICFGR_PLLSAIR_0 ((uint32_t)0x10000000)
• #define RCC_PLLSAICFGR_PLLSAIR_1 ((uint32_t)0x20000000)
• #define RCC_PLLSAICFGR_PLLSAIR_2 ((uint32_t)0x40000000)
• #define RCC_DCKCFGGR_PLLI2SDIVQ ((uint32_t)0x0000001F)
• #define RCC_DCKCFGGR_PLLSAIDIVQ ((uint32_t)0x00001F00)
• #define RCC_DCKCFGGR_PLLSAIDIVR ((uint32_t)0x00030000)
• #define RCC_DCKCFGGR_SAI1ASRC ((uint32_t)0x00300000)
• #define RCC_DCKCFGGR_SAI1ASRC_0 ((uint32_t)0x00100000)
• #define RCC_DCKCFGGR_SAI1ASRC_1 ((uint32_t)0x00200000)
• #define RCC_DCKCFGGR_SAI1BSRC ((uint32_t)0x00C00000)
• #define RCC_DCKCFGGR_SAI1BSRC_0 ((uint32_t)0x00400000)
• #define RCC_DCKCFGGR_SAI1BSRC_1 ((uint32_t)0x00800000)
• #define RCC_DCKCFGGR_TIMPRE ((uint32_t)0x01000000)
• #define RNG_CR_RNGEN ((uint32_t)0x00000004)
• #define RNG_CR_IE ((uint32_t)0x00000008)
• #define RNG_SR_DRDY ((uint32_t)0x00000001)
• #define RNG_SR_CECS ((uint32_t)0x00000002)
```

- #define **RNG\_SR\_SECS** ((uint32\_t)0x00000004)
- #define **RNG\_SR\_CEIS** ((uint32\_t)0x00000020)
- #define **RNG\_SR\_SEIS** ((uint32\_t)0x00000040)
- #define **RTC\_TR\_PM** ((uint32\_t)0x00400000)
- #define **RTC\_TR\_HT** ((uint32\_t)0x00300000)
- #define **RTC\_TR\_HT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_TR\_HT\_1** ((uint32\_t)0x00200000)
- #define **RTC\_TR\_HU** ((uint32\_t)0x000F0000)
- #define **RTC\_TR\_HU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_TR\_HU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_TR\_HU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_TR\_HU\_3** ((uint32\_t)0x00080000)
- #define **RTC\_TR\_MNT** ((uint32\_t)0x00007000)
- #define **RTC\_TR\_MNT\_0** ((uint32\_t)0x00001000)
- #define **RTC\_TR\_MNT\_1** ((uint32\_t)0x00002000)
- #define **RTC\_TR\_MNT\_2** ((uint32\_t)0x00004000)
- #define **RTC\_TR\_MNU** ((uint32\_t)0x00000F00)
- #define **RTC\_TR\_MNU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_TR\_MNU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_TR\_MNU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_TR\_MNU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_TR\_ST** ((uint32\_t)0x00000070)
- #define **RTC\_TR\_ST\_0** ((uint32\_t)0x00000010)
- #define **RTC\_TR\_ST\_1** ((uint32\_t)0x00000020)
- #define **RTC\_TR\_ST\_2** ((uint32\_t)0x00000040)
- #define **RTC\_TR\_SU** ((uint32\_t)0x0000000F)
- #define **RTC\_TR\_SU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_TR\_SU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_TR\_SU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_TR\_SU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_DR\_YT** ((uint32\_t)0x00F00000)
- #define **RTC\_DR\_YT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_DR\_YT\_1** ((uint32\_t)0x00200000)
- #define **RTC\_DR\_YT\_2** ((uint32\_t)0x00400000)
- #define **RTC\_DR\_YT\_3** ((uint32\_t)0x00800000)
- #define **RTC\_DR\_YU** ((uint32\_t)0x000F0000)
- #define **RTC\_DR\_YU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_DR\_YU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_DR\_YU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_DR\_YU\_3** ((uint32\_t)0x00080000)
- #define **RTC\_DR\_WDU** ((uint32\_t)0x0000E000)
- #define **RTC\_DR\_WDU\_0** ((uint32\_t)0x00002000)
- #define **RTC\_DR\_WDU\_1** ((uint32\_t)0x00004000)
- #define **RTC\_DR\_WDU\_2** ((uint32\_t)0x00008000)
- #define **RTC\_DR\_MT** ((uint32\_t)0x00001000)
- #define **RTC\_DR\_MU** ((uint32\_t)0x00000F00)
- #define **RTC\_DR\_MU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_DR\_MU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_DR\_MU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_DR\_MU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_DR\_DT** ((uint32\_t)0x00000030)
- #define **RTC\_DR\_DT\_0** ((uint32\_t)0x00000010)
- #define **RTC\_DR\_DT\_1** ((uint32\_t)0x00000020)
- #define **RTC\_DR\_DU** ((uint32\_t)0x0000000F)
- #define **RTC\_DR\_DU\_0** ((uint32\_t)0x00000001)

- #define **RTC\_DR\_DU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_DR\_DU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_DR\_DU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_CR\_COE** ((uint32\_t)0x00800000)
- #define **RTC\_CR\_OSEL** ((uint32\_t)0x00600000)
- #define **RTC\_CR\_OSEL\_0** ((uint32\_t)0x00200000)
- #define **RTC\_CR\_OSEL\_1** ((uint32\_t)0x00400000)
- #define **RTC\_CR\_POL** ((uint32\_t)0x00100000)
- #define **RTC\_CR\_COSEL** ((uint32\_t)0x00080000)
- #define **RTC\_CR\_BCK** ((uint32\_t)0x00040000)
- #define **RTC\_CR\_SUB1H** ((uint32\_t)0x00020000)
- #define **RTC\_CR\_ADD1H** ((uint32\_t)0x00010000)
- #define **RTC\_CR\_TSIE** ((uint32\_t)0x00008000)
- #define **RTC\_CR\_WUTIE** ((uint32\_t)0x00004000)
- #define **RTC\_CR\_ALRBIE** ((uint32\_t)0x00002000)
- #define **RTC\_CR\_ALRAIE** ((uint32\_t)0x00001000)
- #define **RTC\_CR\_TSE** ((uint32\_t)0x00000800)
- #define **RTC\_CR\_WUTE** ((uint32\_t)0x00000400)
- #define **RTC\_CR\_ALRBE** ((uint32\_t)0x00000200)
- #define **RTC\_CR\_ALRAE** ((uint32\_t)0x00000100)
- #define **RTC\_CR\_DCE** ((uint32\_t)0x00000080)
- #define **RTC\_CR\_FMT** ((uint32\_t)0x00000040)
- #define **RTC\_CR\_BYPSHAD** ((uint32\_t)0x00000020)
- #define **RTC\_CR\_REFCKON** ((uint32\_t)0x00000010)
- #define **RTC\_CR\_TSEDGE** ((uint32\_t)0x00000008)
- #define **RTC\_CR\_WUCKSEL** ((uint32\_t)0x00000007)
- #define **RTC\_CR\_WUCKSEL\_0** ((uint32\_t)0x00000001)
- #define **RTC\_CR\_WUCKSEL\_1** ((uint32\_t)0x00000002)
- #define **RTC\_CR\_WUCKSEL\_2** ((uint32\_t)0x00000004)
- #define **RTC\_ISR\_RECALPF** ((uint32\_t)0x00010000)
- #define **RTC\_ISR\_TAMP1F** ((uint32\_t)0x00002000)
- #define **RTC\_ISR\_TAMP2F** ((uint32\_t)0x00004000)
- #define **RTC\_ISR\_TSOVF** ((uint32\_t)0x00001000)
- #define **RTC\_ISR\_TSF** ((uint32\_t)0x00000800)
- #define **RTC\_ISR\_WUTF** ((uint32\_t)0x00000400)
- #define **RTC\_ISR\_ALRBF** ((uint32\_t)0x00000200)
- #define **RTC\_ISR\_ALRAF** ((uint32\_t)0x00000100)
- #define **RTC\_ISR\_INIT** ((uint32\_t)0x00000080)
- #define **RTC\_ISR\_INITF** ((uint32\_t)0x00000040)
- #define **RTC\_ISR\_RSF** ((uint32\_t)0x00000020)
- #define **RTC\_ISR\_INITS** ((uint32\_t)0x00000010)
- #define **RTC\_ISR\_SHPF** ((uint32\_t)0x00000008)
- #define **RTC\_ISR\_WUTWF** ((uint32\_t)0x00000004)
- #define **RTC\_ISR\_ALRBWF** ((uint32\_t)0x00000002)
- #define **RTC\_ISR\_ALRAWF** ((uint32\_t)0x00000001)
- #define **RTC\_PRER\_PREDIV\_A** ((uint32\_t)0x007F0000)
- #define **RTC\_PRER\_PREDIV\_S** ((uint32\_t)0x00001FFF)
- #define **RTC\_WUTR\_WUT** ((uint32\_t)0x0000FFFF)
- #define **RTC\_CALIBR\_DCS** ((uint32\_t)0x00000080)
- #define **RTC\_CALIBR\_DC** ((uint32\_t)0x0000001F)
- #define **RTC\_ALRMAR\_MSK4** ((uint32\_t)0x80000000)
- #define **RTC\_ALRMAR\_WDSEL** ((uint32\_t)0x40000000)
- #define **RTC\_ALRMAR\_DT** ((uint32\_t)0x30000000)
- #define **RTC\_ALRMAR\_DT\_0** ((uint32\_t)0x10000000)
- #define **RTC\_ALRMAR\_DT\_1** ((uint32\_t)0x20000000)

- #define **RTC\_ALRMAR\_DU** ((uint32\_t)0x0F000000)
- #define **RTC\_ALRMAR\_DU\_0** ((uint32\_t)0x01000000)
- #define **RTC\_ALRMAR\_DU\_1** ((uint32\_t)0x02000000)
- #define **RTC\_ALRMAR\_DU\_2** ((uint32\_t)0x04000000)
- #define **RTC\_ALRMAR\_DU\_3** ((uint32\_t)0x08000000)
- #define **RTC\_ALRMAR\_MSK3** ((uint32\_t)0x00800000)
- #define **RTC\_ALRMAR\_PM** ((uint32\_t)0x00400000)
- #define **RTC\_ALRMAR\_HT** ((uint32\_t)0x00300000)
- #define **RTC\_ALRMAR\_HT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_ALRMAR\_HT\_1** ((uint32\_t)0x00200000)
- #define **RTC\_ALRMAR\_HU** ((uint32\_t)0x000F0000)
- #define **RTC\_ALRMAR\_HU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_ALRMAR\_HU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_ALRMAR\_HU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_ALRMAR\_HU\_3** ((uint32\_t)0x00080000)
- #define **RTC\_ALRMAR\_MSK2** ((uint32\_t)0x00008000)
- #define **RTC\_ALRMAR\_MNT** ((uint32\_t)0x00007000)
- #define **RTC\_ALRMAR\_MNT\_0** ((uint32\_t)0x00001000)
- #define **RTC\_ALRMAR\_MNT\_1** ((uint32\_t)0x00002000)
- #define **RTC\_ALRMAR\_MNT\_2** ((uint32\_t)0x00004000)
- #define **RTC\_ALRMAR\_MNU** ((uint32\_t)0x0000F00)
- #define **RTC\_ALRMAR\_MNU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_ALRMAR\_MNU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_ALRMAR\_MNU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_ALRMAR\_MNU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_ALRMAR\_MSK1** ((uint32\_t)0x00000080)
- #define **RTC\_ALRMAR\_ST** ((uint32\_t)0x00000070)
- #define **RTC\_ALRMAR\_ST\_0** ((uint32\_t)0x00000010)
- #define **RTC\_ALRMAR\_ST\_1** ((uint32\_t)0x00000020)
- #define **RTC\_ALRMAR\_ST\_2** ((uint32\_t)0x00000040)
- #define **RTC\_ALRMAR\_SU** ((uint32\_t)0x0000000F)
- #define **RTC\_ALRMAR\_SU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_ALRMAR\_SU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_ALRMAR\_SU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_ALRMAR\_SU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_ALRMBR\_MSK4** ((uint32\_t)0x80000000)
- #define **RTC\_ALRMBR\_WDSEL** ((uint32\_t)0x40000000)
- #define **RTC\_ALRMBR\_DT** ((uint32\_t)0x30000000)
- #define **RTC\_ALRMBR\_DT\_0** ((uint32\_t)0x10000000)
- #define **RTC\_ALRMBR\_DT\_1** ((uint32\_t)0x20000000)
- #define **RTC\_ALRMBR\_DU** ((uint32\_t)0x0F000000)
- #define **RTC\_ALRMBR\_DU\_0** ((uint32\_t)0x01000000)
- #define **RTC\_ALRMBR\_DU\_1** ((uint32\_t)0x02000000)
- #define **RTC\_ALRMBR\_DU\_2** ((uint32\_t)0x04000000)
- #define **RTC\_ALRMBR\_DU\_3** ((uint32\_t)0x08000000)
- #define **RTC\_ALRMBR\_MSK3** ((uint32\_t)0x00800000)
- #define **RTC\_ALRMBR\_PM** ((uint32\_t)0x00400000)
- #define **RTC\_ALRMBR\_HT** ((uint32\_t)0x00300000)
- #define **RTC\_ALRMBR\_HT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_ALRMBR\_HT\_1** ((uint32\_t)0x00200000)
- #define **RTC\_ALRMBR\_HU** ((uint32\_t)0x000F0000)
- #define **RTC\_ALRMBR\_HU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_ALRMBR\_HU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_ALRMBR\_HU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_ALRMBR\_HU\_3** ((uint32\_t)0x00080000)

- #define **RTC\_ALRMBR\_MSK2** ((uint32\_t)0x000008000)
- #define **RTC\_ALRMBR\_MNT** ((uint32\_t)0x000007000)
- #define **RTC\_ALRMBR\_MNT\_0** ((uint32\_t)0x000001000)
- #define **RTC\_ALRMBR\_MNT\_1** ((uint32\_t)0x000002000)
- #define **RTC\_ALRMBR\_MNT\_2** ((uint32\_t)0x000004000)
- #define **RTC\_ALRMBR\_MNU** ((uint32\_t)0x00000F00)
- #define **RTC\_ALRMBR\_MNU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_ALRMBR\_MNU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_ALRMBR\_MNU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_ALRMBR\_MNU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_ALRMBR\_MSK1** ((uint32\_t)0x00000080)
- #define **RTC\_ALRMBR\_ST** ((uint32\_t)0x00000070)
- #define **RTC\_ALRMBR\_ST\_0** ((uint32\_t)0x00000010)
- #define **RTC\_ALRMBR\_ST\_1** ((uint32\_t)0x00000020)
- #define **RTC\_ALRMBR\_ST\_2** ((uint32\_t)0x00000040)
- #define **RTC\_ALRMBR\_SU** ((uint32\_t)0x0000000F)
- #define **RTC\_ALRMBR\_SU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_ALRMBR\_SU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_ALRMBR\_SU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_ALRMBR\_SU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_WPR\_KEY** ((uint32\_t)0x000000FF)
- #define **RTC\_SSR\_SS** ((uint32\_t)0x0000FFFF)
- #define **RTC\_SHIFTR\_SUBFS** ((uint32\_t)0x00007FFF)
- #define **RTC\_SHIFTR\_ADD1S** ((uint32\_t)0x80000000)
- #define **RTC\_TSTR\_PM** ((uint32\_t)0x00400000)
- #define **RTC\_TSTR\_HT** ((uint32\_t)0x00300000)
- #define **RTC\_TSTR\_HT\_0** ((uint32\_t)0x00100000)
- #define **RTC\_TSTR\_HT\_1** ((uint32\_t)0x00200000)
- #define **RTC\_TSTR\_HU** ((uint32\_t)0x000F0000)
- #define **RTC\_TSTR\_HU\_0** ((uint32\_t)0x00010000)
- #define **RTC\_TSTR\_HU\_1** ((uint32\_t)0x00020000)
- #define **RTC\_TSTR\_HU\_2** ((uint32\_t)0x00040000)
- #define **RTC\_TSTR\_HU\_3** ((uint32\_t)0x00080000)
- #define **RTC\_TSTR\_MNT** ((uint32\_t)0x00007000)
- #define **RTC\_TSTR\_MNT\_0** ((uint32\_t)0x00001000)
- #define **RTC\_TSTR\_MNT\_1** ((uint32\_t)0x00002000)
- #define **RTC\_TSTR\_MNT\_2** ((uint32\_t)0x00004000)
- #define **RTC\_TSTR\_MNU** ((uint32\_t)0x00000F00)
- #define **RTC\_TSTR\_MNU\_0** ((uint32\_t)0x00000100)
- #define **RTC\_TSTR\_MNU\_1** ((uint32\_t)0x00000200)
- #define **RTC\_TSTR\_MNU\_2** ((uint32\_t)0x00000400)
- #define **RTC\_TSTR\_MNU\_3** ((uint32\_t)0x00000800)
- #define **RTC\_TSTR\_ST** ((uint32\_t)0x00000070)
- #define **RTC\_TSTR\_ST\_0** ((uint32\_t)0x00000010)
- #define **RTC\_TSTR\_ST\_1** ((uint32\_t)0x00000020)
- #define **RTC\_TSTR\_ST\_2** ((uint32\_t)0x00000040)
- #define **RTC\_TSTR\_SU** ((uint32\_t)0x0000000F)
- #define **RTC\_TSTR\_SU\_0** ((uint32\_t)0x00000001)
- #define **RTC\_TSTR\_SU\_1** ((uint32\_t)0x00000002)
- #define **RTC\_TSTR\_SU\_2** ((uint32\_t)0x00000004)
- #define **RTC\_TSTR\_SU\_3** ((uint32\_t)0x00000008)
- #define **RTC\_TSDR\_WDU** ((uint32\_t)0x0000E000)
- #define **RTC\_TSDR\_WDU\_0** ((uint32\_t)0x00002000)
- #define **RTC\_TSDR\_WDU\_1** ((uint32\_t)0x00004000)
- #define **RTC\_TSDR\_WDU\_2** ((uint32\_t)0x00008000)

```
• #define RTC_TSDF_MT ((uint32_t)0x00001000)
• #define RTC_TSDF_MU ((uint32_t)0x00000F00)
• #define RTC_TSDF_MU_0 ((uint32_t)0x00000100)
• #define RTC_TSDF_MU_1 ((uint32_t)0x00000200)
• #define RTC_TSDF_MU_2 ((uint32_t)0x00000400)
• #define RTC_TSDF_MU_3 ((uint32_t)0x00000800)
• #define RTC_TSDF_DT ((uint32_t)0x00000030)
• #define RTC_TSDF_DT_0 ((uint32_t)0x00000010)
• #define RTC_TSDF_DT_1 ((uint32_t)0x00000020)
• #define RTC_TSDF_DU ((uint32_t)0x0000000F)
• #define RTC_TSDF_DU_0 ((uint32_t)0x00000001)
• #define RTC_TSDF_DU_1 ((uint32_t)0x00000002)
• #define RTC_TSDF_DU_2 ((uint32_t)0x00000004)
• #define RTC_TSDF_DU_3 ((uint32_t)0x00000008)
• #define RTC_TSSR_SS ((uint32_t)0x0000FFFF)
• #define RTC_CALR_CALP ((uint32_t)0x00008000)
• #define RTC_CALR_CALW8 ((uint32_t)0x00004000)
• #define RTC_CALR_CALW16 ((uint32_t)0x00002000)
• #define RTC_CALR_CALM ((uint32_t)0x000001FF)
• #define RTC_CALR_CALM_0 ((uint32_t)0x00000001)
• #define RTC_CALR_CALM_1 ((uint32_t)0x00000002)
• #define RTC_CALR_CALM_2 ((uint32_t)0x00000004)
• #define RTC_CALR_CALM_3 ((uint32_t)0x00000008)
• #define RTC_CALR_CALM_4 ((uint32_t)0x00000010)
• #define RTC_CALR_CALM_5 ((uint32_t)0x00000020)
• #define RTC_CALR_CALM_6 ((uint32_t)0x00000040)
• #define RTC_CALR_CALM_7 ((uint32_t)0x00000080)
• #define RTC_CALR_CALM_8 ((uint32_t)0x00000100)
• #define RTC_TAFCR_ALARMOUTTYPE ((uint32_t)0x00040000)
• #define RTC_TAFCR_TSINSEL ((uint32_t)0x00020000)
• #define RTC_TAFCR_TAMPINSEL ((uint32_t)0x00010000)
• #define RTC_TAFCR_TAMPPUDIS ((uint32_t)0x00008000)
• #define RTC_TAFCR_TAMPPRCH ((uint32_t)0x00006000)
• #define RTC_TAFCR_TAMPPRCH_0 ((uint32_t)0x00002000)
• #define RTC_TAFCR_TAMPPRCH_1 ((uint32_t)0x00004000)
• #define RTC_TAFCR_TAMPFLT ((uint32_t)0x00001800)
• #define RTC_TAFCR_TAMPFLT_0 ((uint32_t)0x00000800)
• #define RTC_TAFCR_TAMPFLT_1 ((uint32_t)0x00001000)
• #define RTC_TAFCR_TAMPFREQ ((uint32_t)0x00000700)
• #define RTC_TAFCR_TAMPFREQ_0 ((uint32_t)0x00000100)
• #define RTC_TAFCR_TAMPFREQ_1 ((uint32_t)0x00000200)
• #define RTC_TAFCR_TAMPFREQ_2 ((uint32_t)0x00000400)
• #define RTC_TAFCR_TAMPTS ((uint32_t)0x00000080)
• #define RTC_TAFCR_TAMP2TRG ((uint32_t)0x00000010)
• #define RTC_TAFCR_TAMP2E ((uint32_t)0x00000008)
• #define RTC_TAFCR_TAMPIE ((uint32_t)0x00000004)
• #define RTC_TAFCR_TAMP1TRG ((uint32_t)0x00000002)
• #define RTC_TAFCR_TAMP1E ((uint32_t)0x00000001)
• #define RTC_ALRMASSR_MASKSS ((uint32_t)0x0F000000)
• #define RTC_ALRMASSR_MASKSS_0 ((uint32_t)0x01000000)
• #define RTC_ALRMASSR_MASKSS_1 ((uint32_t)0x02000000)
• #define RTC_ALRMASSR_MASKSS_2 ((uint32_t)0x04000000)
• #define RTC_ALRMASSR_MASKSS_3 ((uint32_t)0x08000000)
• #define RTC_ALRMASSR_SS ((uint32_t)0x000007FFF)
• #define RTC_ALRMBSSR_MASKSS ((uint32_t)0x0F000000)
```

```
• #define RTC_ALRMBSSR_MASKSS_0 ((uint32_t)0x01000000)
• #define RTC_ALRMBSSR_MASKSS_1 ((uint32_t)0x02000000)
• #define RTC_ALRMBSSR_MASKSS_2 ((uint32_t)0x04000000)
• #define RTC_ALRMBSSR_MASKSS_3 ((uint32_t)0x08000000)
• #define RTC_ALRMBSSR_SS ((uint32_t)0x00007FFF)
• #define RTC_BKP0R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP1R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP2R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP3R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP4R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP5R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP6R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP7R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP8R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP9R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP10R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP11R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP12R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP13R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP14R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP15R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP16R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP17R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP18R ((uint32_t)0xFFFFFFFF)
• #define RTC_BKP19R ((uint32_t)0xFFFFFFFF)
• #define SAI_GCR_SYNCIN ((uint32_t)0x00000003)
• #define SAI_GCR_SYNCIN_0 ((uint32_t)0x00000001)
• #define SAI_GCR_SYNCIN_1 ((uint32_t)0x00000002)
• #define SAI_GCR_SYNCOUT ((uint32_t)0x00000030)
• #define SAI_GCR_SYNCOUT_0 ((uint32_t)0x00000010)
• #define SAI_GCR_SYNCOUT_1 ((uint32_t)0x00000020)
• #define SAI_xCR1_MODE ((uint32_t)0x00000003)
• #define SAI_xCR1_MODE_0 ((uint32_t)0x00000001)
• #define SAI_xCR1_MODE_1 ((uint32_t)0x00000002)
• #define SAI_xCR1_PRTCFG ((uint32_t)0x0000000C)
• #define SAI_xCR1_PRTCFG_0 ((uint32_t)0x00000004)
• #define SAI_xCR1_PRTCFG_1 ((uint32_t)0x00000008)
• #define SAI_xCR1_DS ((uint32_t)0x000000E0)
• #define SAI_xCR1_DS_0 ((uint32_t)0x00000020)
• #define SAI_xCR1_DS_1 ((uint32_t)0x00000040)
• #define SAI_xCR1_DS_2 ((uint32_t)0x00000080)
• #define SAI_xCR1_LSBFIRST ((uint32_t)0x00000100)
• #define SAI_xCR1_CKSTR ((uint32_t)0x00000200)
• #define SAI_xCR1_SYNCEN ((uint32_t)0x00000C00)
• #define SAI_xCR1_SYNCEN_0 ((uint32_t)0x00000400)
• #define SAI_xCR1_SYNCEN_1 ((uint32_t)0x00000800)
• #define SAI_xCR1_MONO ((uint32_t)0x00001000)
• #define SAI_xCR1_OUTDRIV ((uint32_t)0x00002000)
• #define SAI_xCR1_SAIEN ((uint32_t)0x00010000)
• #define SAI_xCR1_DMAEN ((uint32_t)0x00020000)
• #define SAI_xCR1_NODIV ((uint32_t)0x00080000)
• #define SAI_xCR1_MCKDIV ((uint32_t)0x00780000)
• #define SAI_xCR1_MCKDIV_0 ((uint32_t)0x00080000)
• #define SAI_xCR1_MCKDIV_1 ((uint32_t)0x00100000)
• #define SAI_xCR1_MCKDIV_2 ((uint32_t)0x00200000)
```

```
• #define SAI_xCR1_MCKDIV_3 ((uint32_t)0x00400000)
• #define SAI_xCR2_FTH ((uint32_t)0x00000003)
• #define SAI_xCR2_FTH_0 ((uint32_t)0x00000001)
• #define SAI_xCR2_FTH_1 ((uint32_t)0x00000002)
• #define SAI_xCR2_FFLUSH ((uint32_t)0x00000008)
• #define SAI_xCR2_TRIS ((uint32_t)0x00000010)
• #define SAI_xCR2_MUTE ((uint32_t)0x00000020)
• #define SAI_xCR2_MUTEVAL ((uint32_t)0x00000040)
• #define SAI_xCR2_MUTECNT ((uint32_t)0x00001F80)
• #define SAI_xCR2_MUTECNT_0 ((uint32_t)0x00000080)
• #define SAI_xCR2_MUTECNT_1 ((uint32_t)0x00000100)
• #define SAI_xCR2_MUTECNT_2 ((uint32_t)0x00000200)
• #define SAI_xCR2_MUTECNT_3 ((uint32_t)0x00000400)
• #define SAI_xCR2_MUTECNT_4 ((uint32_t)0x00000800)
• #define SAI_xCR2_MUTECNT_5 ((uint32_t)0x00001000)
• #define SAI_xCR2_CPL ((uint32_t)0x00002000)
• #define SAI_xCR2_COMP ((uint32_t)0x0000C000)
• #define SAI_xCR2_COMP_0 ((uint32_t)0x00004000)
• #define SAI_xCR2_COMP_1 ((uint32_t)0x00008000)
• #define SAI_xFRCR_FRL ((uint32_t)0x000000FF)
• #define SAI_xFRCR_FRL_0 ((uint32_t)0x00000001)
• #define SAI_xFRCR_FRL_1 ((uint32_t)0x00000002)
• #define SAI_xFRCR_FRL_2 ((uint32_t)0x00000004)
• #define SAI_xFRCR_FRL_3 ((uint32_t)0x00000008)
• #define SAI_xFRCR_FRL_4 ((uint32_t)0x00000010)
• #define SAI_xFRCR_FRL_5 ((uint32_t)0x00000020)
• #define SAI_xFRCR_FRL_6 ((uint32_t)0x00000040)
• #define SAI_xFRCR_FRL_7 ((uint32_t)0x00000080)
• #define SAI_xFRCR_FSALL ((uint32_t)0x00007F00)
• #define SAI_xFRCR_FSALL_0 ((uint32_t)0x00000100)
• #define SAI_xFRCR_FSALL_1 ((uint32_t)0x00000200)
• #define SAI_xFRCR_FSALL_2 ((uint32_t)0x00000400)
• #define SAI_xFRCR_FSALL_3 ((uint32_t)0x00000800)
• #define SAI_xFRCR_FSALL_4 ((uint32_t)0x00001000)
• #define SAI_xFRCR_FSALL_5 ((uint32_t)0x00002000)
• #define SAI_xFRCR_FSALL_6 ((uint32_t)0x00004000)
• #define SAI_xFRCR_FSDEF ((uint32_t)0x00010000)
• #define SAI_xFRCR_FSPOL ((uint32_t)0x00020000)
• #define SAI_xFRCR_FSOFF ((uint32_t)0x00040000)
• #define SAI_xFRCR_FSPO SAI_xFRCR_FSPOL
• #define SAI_xSLOTR_FBOFF ((uint32_t)0x0000001F)
• #define SAI_xSLOTR_FBOFF_0 ((uint32_t)0x00000001)
• #define SAI_xSLOTR_FBOFF_1 ((uint32_t)0x00000002)
• #define SAI_xSLOTR_FBOFF_2 ((uint32_t)0x00000004)
• #define SAI_xSLOTR_FBOFF_3 ((uint32_t)0x00000008)
• #define SAI_xSLOTR_FBOFF_4 ((uint32_t)0x00000010)
• #define SAI_xSLOTR_SLOTsz ((uint32_t)0x000000C0)
• #define SAI_xSLOTR_SLOTsz_0 ((uint32_t)0x00000040)
• #define SAI_xSLOTR_SLOTsz_1 ((uint32_t)0x00000080)
• #define SAI_xSLOTR_NBSLOT ((uint32_t)0x00000F00)
• #define SAI_xSLOTR_NBSLOT_0 ((uint32_t)0x00000100)
• #define SAI_xSLOTR_NBSLOT_1 ((uint32_t)0x00000200)
• #define SAI_xSLOTR_NBSLOT_2 ((uint32_t)0x00000400)
• #define SAI_xSLOTR_NBSLOT_3 ((uint32_t)0x00000800)
• #define SAI_xSLOTR_SLOTEN ((uint32_t)0xFFFF0000)
```

- #define SAI\_xIMR\_OVRUDRIE ((uint32\_t)0x00000001)
- #define SAI\_xIMR\_MUTEDETIE ((uint32\_t)0x00000002)
- #define SAI\_xIMR\_WCKCFGIE ((uint32\_t)0x00000004)
- #define SAI\_xIMR\_FREQIE ((uint32\_t)0x00000008)
- #define SAI\_xIMR\_CNRDYIE ((uint32\_t)0x00000010)
- #define SAI\_xIMR\_AFSDETIE ((uint32\_t)0x00000020)
- #define SAI\_xIMR\_LFSDETIE ((uint32\_t)0x00000040)
- #define SAI\_xSR\_OVRUDR ((uint32\_t)0x00000001)
- #define SAI\_xSR\_MUTEDET ((uint32\_t)0x00000002)
- #define SAI\_xSR\_WCKCFG ((uint32\_t)0x00000004)
- #define SAI\_xSR\_FREQ ((uint32\_t)0x00000008)
- #define SAI\_xSR\_CNRDY ((uint32\_t)0x00000010)
- #define SAI\_xSR\_AFSDET ((uint32\_t)0x00000020)
- #define SAI\_xSR\_LFSDET ((uint32\_t)0x00000040)
- #define SAI\_xSR\_FLVL ((uint32\_t)0x00070000)
- #define SAI\_xSR\_FLVL\_0 ((uint32\_t)0x00010000)
- #define SAI\_xSR\_FLVL\_1 ((uint32\_t)0x00020000)
- #define SAI\_xSR\_FLVL\_2 ((uint32\_t)0x00030000)
- #define SAI\_xCLRFR\_COVRUDR ((uint32\_t)0x00000001)
- #define SAI\_xCLRFR\_CMUTEDET ((uint32\_t)0x00000002)
- #define SAI\_xCLRFR\_CWCKCFG ((uint32\_t)0x00000004)
- #define SAI\_xCLRFR\_CFREQ ((uint32\_t)0x00000008)
- #define SAI\_xCLRFR\_CCNRDY ((uint32\_t)0x00000010)
- #define SAI\_xCLRFR\_CAFSDET ((uint32\_t)0x00000020)
- #define SAI\_xCLRFR\_CLFSDET ((uint32\_t)0x00000040)
- #define SAI\_xDR\_DATA ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_POWER\_PWRCTRL ((uint8\_t)0x03)
- #define SDIO\_POWER\_PWRCTRL\_0 ((uint8\_t)0x01)
- #define SDIO\_CLKCR\_CLKDIV ((uint16\_t)0x00FF)
- #define SDIO\_CLKCR\_CLKEN ((uint16\_t)0x0100)
- #define SDIO\_CLKCR\_PWRSAV ((uint16\_t)0x0200)
- #define SDIO\_CLKCR\_BYPASS ((uint16\_t)0x0400)
- #define SDIO\_CLKCR\_WIDBUS ((uint16\_t)0x1800)
- #define SDIO\_CLKCR\_WIDBUS\_0 ((uint16\_t)0x0800)
- #define SDIO\_CLKCR\_WIDBUS\_1 ((uint16\_t)0x1000)
- #define SDIO\_CLKCR\_NEGEDGE ((uint16\_t)0x2000)
- #define SDIO\_CLKCR\_HWFC\_EN ((uint16\_t)0x4000)
- #define SDIO\_ARG\_CMDARG ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_CMD\_CMDINDEX ((uint16\_t)0x003F)
- #define SDIO\_CMD\_WAITRESP ((uint16\_t)0x00C0)
- #define SDIO\_CMD\_WAITRESP\_0 ((uint16\_t)0x0040)
- #define SDIO\_CMD\_WAITRESP\_1 ((uint16\_t)0x0080)
- #define SDIO\_CMD\_WAITINT ((uint16\_t)0x0100)
- #define SDIO\_CMD\_WAITPEND ((uint16\_t)0x0200)
- #define SDIO\_CMD\_CPSMEN ((uint16\_t)0x0400)
- #define SDIO\_CMD\_SDIOSUSPEND ((uint16\_t)0x0800)
- #define SDIO\_CMD\_ENCMDCOMPL ((uint16\_t)0x1000)
- #define SDIO\_CMD\_NIEN ((uint16\_t)0x2000)
- #define SDIO\_CMD\_CEATACMD ((uint16\_t)0x4000)
- #define SDIO\_RESPCMD\_RESPCMD ((uint8\_t)0x3F)
- #define SDIO\_RESP0\_CARDSTATUS0 ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_RESP1\_CARDSTATUS1 ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_RESP2\_CARDSTATUS2 ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_RESP3\_CARDSTATUS3 ((uint32\_t)0xFFFFFFFF)

- #define SDIO\_RESP4\_CARDSTATUS4 ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_DTIMER\_DATATIME ((uint32\_t)0xFFFFFFFF)
- #define SDIO\_DLEN\_DATALENGTH ((uint32\_t)0x01FFFFFF)
- #define SDIO\_DCTRL\_DTEN ((uint16\_t)0x0001)
- #define SDIO\_DCTRL\_DTDIR ((uint16\_t)0x0002)
- #define SDIO\_DCTRL\_DTMODE ((uint16\_t)0x0004)
- #define SDIO\_DCTRL\_DMAEN ((uint16\_t)0x0008)
- #define SDIO\_DCTRL\_DBLOCKSIZE ((uint16\_t)0x00F0)
- #define SDIO\_DCTRL\_DBLOCKSIZE\_0 ((uint16\_t)0x0010)
- #define SDIO\_DCTRL\_DBLOCKSIZE\_1 ((uint16\_t)0x0020)
- #define SDIO\_DCTRL\_DBLOCKSIZE\_2 ((uint16\_t)0x0040)
- #define SDIO\_DCTRL\_DBLOCKSIZE\_3 ((uint16\_t)0x0080)
- #define SDIO\_DCTRL\_RWSTART ((uint16\_t)0x0100)
- #define SDIO\_DCTRL\_RWSTOP ((uint16\_t)0x0200)
- #define SDIO\_DCTRL\_RWMOD ((uint16\_t)0x0400)
- #define SDIO\_DCTRL\_SDIOEN ((uint16\_t)0x0800)
- #define SDIO\_DCOUNT\_DATACOUNT ((uint32\_t)0x01FFFFFF)
- #define SDIO\_STA\_CCRCFAIL ((uint32\_t)0x00000001)
- #define SDIO\_STA\_DCRCFAIL ((uint32\_t)0x00000002)
- #define SDIO\_STA\_CTIMEOUT ((uint32\_t)0x00000004)
- #define SDIO\_STA\_DTIMEOUT ((uint32\_t)0x00000008)
- #define SDIO\_STA\_TXUNDERR ((uint32\_t)0x00000010)
- #define SDIO\_STA\_RXOVERR ((uint32\_t)0x00000020)
- #define SDIO\_STA\_CMDREND ((uint32\_t)0x00000040)
- #define SDIO\_STA\_CMDSENT ((uint32\_t)0x00000080)
- #define SDIO\_STA\_DATAEND ((uint32\_t)0x00000100)
- #define SDIO\_STA\_STBITERR ((uint32\_t)0x00000200)
- #define SDIO\_STA\_DBCKEND ((uint32\_t)0x00000400)
- #define SDIO\_STA\_CMDACT ((uint32\_t)0x00000800)
- #define SDIO\_STA\_TXACT ((uint32\_t)0x00001000)
- #define SDIO\_STA\_RXACT ((uint32\_t)0x00002000)
- #define SDIO\_STA\_TXFIFOHE ((uint32\_t)0x00004000)
- #define SDIO\_STA\_RXFIFOHF ((uint32\_t)0x00008000)
- #define SDIO\_STA\_TXFIFOF ((uint32\_t)0x00010000)
- #define SDIO\_STA\_RXFIFOF ((uint32\_t)0x00020000)
- #define SDIO\_STA\_TXFIFOE ((uint32\_t)0x00040000)
- #define SDIO\_STA\_RXFIFOE ((uint32\_t)0x00080000)
- #define SDIO\_STA\_TXDAVL ((uint32\_t)0x00100000)
- #define SDIO\_STA\_RXDAVL ((uint32\_t)0x00200000)
- #define SDIO\_STA\_SDIOIT ((uint32\_t)0x00400000)
- #define SDIO\_STA\_CEATAEND ((uint32\_t)0x00800000)
- #define SDIO\_ICR\_CCRCFAILC ((uint32\_t)0x00000001)
- #define SDIO\_ICR\_DCRCFAILC ((uint32\_t)0x00000002)
- #define SDIO\_ICR\_CTIMEOUTC ((uint32\_t)0x00000004)
- #define SDIO\_ICR\_DTIMEOUTC ((uint32\_t)0x00000008)
- #define SDIO\_ICR\_TXUNDERRC ((uint32\_t)0x00000010)
- #define SDIO\_ICR\_RXOVERRRC ((uint32\_t)0x00000020)
- #define SDIO\_ICR\_CMDRENDC ((uint32\_t)0x00000040)
- #define SDIO\_ICR\_CMDSENTC ((uint32\_t)0x00000080)
- #define SDIO\_ICR\_DATAENDC ((uint32\_t)0x00000100)
- #define SDIO\_ICR\_STBITERRC ((uint32\_t)0x00000200)
- #define SDIO\_ICR\_DBCKENDC ((uint32\_t)0x00000400)
- #define SDIO\_ICR\_SDIOITC ((uint32\_t)0x00400000)
- #define SDIO\_ICR\_CEATAENDC ((uint32\_t)0x00800000)
- #define SDIO\_MASK\_CCRCFAILIE ((uint32\_t)0x00000001)

- #define SDIO\_MASK\_DCRCFAILIE ((uint32\_t)0x00000002)
- #define SDIO\_MASK\_CTIMEOUTIE ((uint32\_t)0x00000004)
- #define SDIO\_MASK\_DTIMEOUTIE ((uint32\_t)0x00000008)
- #define SDIO\_MASK\_TXUNDERRIE ((uint32\_t)0x00000010)
- #define SDIO\_MASK\_RXOVERRIE ((uint32\_t)0x00000020)
- #define SDIO\_MASK\_CMDRENDIE ((uint32\_t)0x00000040)
- #define SDIO\_MASK\_CMDSENTIE ((uint32\_t)0x00000080)
- #define SDIO\_MASK\_DATAENDIE ((uint32\_t)0x00000100)
- #define SDIO\_MASK\_STBITERRIE ((uint32\_t)0x00000200)
- #define SDIO\_MASK\_DBCKENDIE ((uint32\_t)0x00000400)
- #define SDIO\_MASK\_CMDACTIE ((uint32\_t)0x00000800)
- #define SDIO\_MASK\_TXACTIE ((uint32\_t)0x00001000)
- #define SDIO\_MASK\_RXACTIE ((uint32\_t)0x00002000)
- #define SDIO\_MASK\_TXFIFOHEIE ((uint32\_t)0x00004000)
- #define SDIO\_MASK\_RXFIFOHFIE ((uint32\_t)0x00008000)
- #define SDIO\_MASK\_RXFIFOFIE ((uint32\_t)0x00010000)
- #define SDIO\_MASK\_RXFIFOFIE ((uint32\_t)0x00020000)
- #define SDIO\_MASK\_RXFIFOEIE ((uint32\_t)0x00040000)
- #define SDIO\_MASK\_RXFIFOEIE ((uint32\_t)0x00080000)
- #define SDIO\_MASK\_TXDAVLIE ((uint32\_t)0x00100000)
- #define SDIO\_MASK\_RXDAVLIE ((uint32\_t)0x00200000)
- #define SDIO\_MASK\_SDIOITIE ((uint32\_t)0x00400000)
- #define SDIO\_MASK\_CEATAENDIE ((uint32\_t)0x00800000)
- #define SDIO\_FIFOCNT\_FIFOCOUNT ((uint32\_t)0x00FFFFFF)
- #define SDIO\_FIFO\_FIFODATA ((uint32\_t)0xFFFFFFFF)
- #define SPI\_CR1\_CPHA ((uint16\_t)0x0001)
- #define SPI\_CR1\_CPOL ((uint16\_t)0x0002)
- #define SPI\_CR1\_MSTR ((uint16\_t)0x0004)
- #define SPI\_CR1\_BR ((uint16\_t)0x0038)
- #define SPI\_CR1\_BR\_0 ((uint16\_t)0x0008)
- #define SPI\_CR1\_BR\_1 ((uint16\_t)0x0010)
- #define SPI\_CR1\_BR\_2 ((uint16\_t)0x0020)
- #define SPI\_CR1\_SPE ((uint16\_t)0x0040)
- #define SPI\_CR1\_LSBFIRST ((uint16\_t)0x0080)
- #define SPI\_CR1\_SSI ((uint16\_t)0x0100)
- #define SPI\_CR1\_SSM ((uint16\_t)0x0200)
- #define SPI\_CR1\_RXONLY ((uint16\_t)0x0400)
- #define SPI\_CR1\_DFF ((uint16\_t)0x0800)
- #define SPI\_CR1\_CRCNEXT ((uint16\_t)0x1000)
- #define SPI\_CR1\_CRCEN ((uint16\_t)0x2000)
- #define SPI\_CR1\_BIDIOE ((uint16\_t)0x4000)
- #define SPI\_CR1\_BIDIODE ((uint16\_t)0x8000)
- #define SPI\_CR2\_RXDMAEN ((uint8\_t)0x01)
- #define SPI\_CR2\_TXDMAEN ((uint8\_t)0x02)
- #define SPI\_CR2\_SSOE ((uint8\_t)0x04)
- #define SPI\_CR2\_ERRIE ((uint8\_t)0x20)
- #define SPI\_CR2\_RXNEIE ((uint8\_t)0x40)
- #define SPI\_CR2\_TXEIE ((uint8\_t)0x80)
- #define SPI\_SR\_RXNE ((uint8\_t)0x01)
- #define SPI\_SR\_TXE ((uint8\_t)0x02)
- #define SPI\_SR\_CHSIDE ((uint8\_t)0x04)
- #define SPI\_SR\_UDR ((uint8\_t)0x08)
- #define SPI\_SR\_CRCERR ((uint8\_t)0x10)
- #define SPI\_SR\_MODF ((uint8\_t)0x20)
- #define SPI\_SR\_OVR ((uint8\_t)0x40)

- #define SPI\_SR\_BSY ((uint8\_t)0x80)
- #define SPI\_DR\_DR ((uint16\_t)0xFFFF)
- #define SPI\_CRCPR\_CRCPOL ((uint16\_t)0xFFFF)
- #define SPI\_RXCRCR\_RXCRC ((uint16\_t)0xFFFF)
- #define SPI\_TXCRCR\_TXCRC ((uint16\_t)0xFFFF)
- #define SPI\_I2SCFGR\_CHLEN ((uint16\_t)0x0001)
- #define SPI\_I2SCFGR\_DATLEN ((uint16\_t)0x0006)
- #define SPI\_I2SCFGR\_DATLEN\_0 ((uint16\_t)0x0002)
- #define SPI\_I2SCFGR\_DATLEN\_1 ((uint16\_t)0x0004)
- #define SPI\_I2SCFGR\_CKPOL ((uint16\_t)0x0008)
- #define SPI\_I2SCFGR\_I2SSTD ((uint16\_t)0x0030)
- #define SPI\_I2SCFGR\_I2SSTD\_0 ((uint16\_t)0x0010)
- #define SPI\_I2SCFGR\_I2SSTD\_1 ((uint16\_t)0x0020)
- #define SPI\_I2SCFGR\_PCMSYNC ((uint16\_t)0x0080)
- #define SPI\_I2SCFGR\_I2SCFG ((uint16\_t)0x0300)
- #define SPI\_I2SCFGR\_I2SCFG\_0 ((uint16\_t)0x0100)
- #define SPI\_I2SCFGR\_I2SCFG\_1 ((uint16\_t)0x0200)
- #define SPI\_I2SCFGR\_I2SE ((uint16\_t)0x0400)
- #define SPI\_I2SCFGR\_I2SMOD ((uint16\_t)0x0800)
- #define SPI\_I2SPR\_I2SDIV ((uint16\_t)0x00FF)
- #define SPI\_I2SPR\_ODD ((uint16\_t)0x0100)
- #define SPI\_I2SPR\_MCKOE ((uint16\_t)0x0200)
- #define SYSCFG\_MEMRMP\_MEM\_MODE ((uint32\_t)0x00000007)
- #define SYSCFG\_MEMRMP\_MEM\_MODE\_0 ((uint32\_t)0x00000001)
- #define SYSCFG\_MEMRMP\_MEM\_MODE\_1 ((uint32\_t)0x00000002)
- #define SYSCFG\_MEMRMP\_MEM\_MODE\_2 ((uint32\_t)0x00000004)
- #define SYSCFG\_MEMRMP\_FB\_MODE ((uint32\_t)0x00000100)
- #define SYSCFG\_MEMRMP\_SWP\_FMC ((uint32\_t)0x00000C00)
- #define SYSCFG\_MEMRMP\_SWP\_FMC\_0 ((uint32\_t)0x00000400)
- #define SYSCFG\_MEMRMP\_SWP\_FMC\_1 ((uint32\_t)0x00000800)
- #define SYSCFG\_PMC\_ADCxDC2 ((uint32\_t)0x00070000)
- #define SYSCFG\_PMC\_ADC1DC2 ((uint32\_t)0x00010000)
- #define SYSCFG\_PMC\_ADC2DC2 ((uint32\_t)0x00020000)
- #define SYSCFG\_PMC\_ADC3DC2 ((uint32\_t)0x00040000)
- #define SYSCFG\_PMC\_MII\_RMII\_SEL ((uint32\_t)0x00800000)
- #define SYSCFG\_PMC\_MII\_RMII SYSCFG\_PMC\_MII\_RMII\_SEL
- #define SYSCFG\_EXTICR1\_EXTI0 ((uint16\_t)0x000F)
- #define SYSCFG\_EXTICR1\_EXTI1 ((uint16\_t)0x00F0)
- #define SYSCFG\_EXTICR1\_EXTI2 ((uint16\_t)0x0F00)
- #define SYSCFG\_EXTICR1\_EXTI3 ((uint16\_t)0xF000)
- #define SYSCFG\_EXTICR1\_EXTI0\_PA ((uint16\_t)0x0000)

*EXTI0 configuration*

- #define SYSCFG\_EXTICR1\_EXTI0\_PB ((uint16\_t)0x0001)
- #define SYSCFG\_EXTICR1\_EXTI0\_PC ((uint16\_t)0x0002)
- #define SYSCFG\_EXTICR1\_EXTI0\_PD ((uint16\_t)0x0003)
- #define SYSCFG\_EXTICR1\_EXTI0\_PE ((uint16\_t)0x0004)
- #define SYSCFG\_EXTICR1\_EXTI0\_PF ((uint16\_t)0x0005)
- #define SYSCFG\_EXTICR1\_EXTI0\_PG ((uint16\_t)0x0006)
- #define SYSCFG\_EXTICR1\_EXTI0\_PH ((uint16\_t)0x0007)
- #define SYSCFG\_EXTICR1\_EXTI0\_PI ((uint16\_t)0x0008)
- #define SYSCFG\_EXTICR1\_EXTI0\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR1\_EXTI0\_PK ((uint16\_t)0x000A)
- #define SYSCFG\_EXTICR1\_EXTI1\_PA ((uint16\_t)0x0000)

*EXTI1 configuration*

- #define SYSCFG\_EXTICR1\_EXTI1\_PB ((uint16\_t)0x0010)
- #define SYSCFG\_EXTICR1\_EXTI1\_PC ((uint16\_t)0x0020)
- #define SYSCFG\_EXTICR1\_EXTI1\_PD ((uint16\_t)0x0030)
- #define SYSCFG\_EXTICR1\_EXTI1\_PE ((uint16\_t)0x0040)
- #define SYSCFG\_EXTICR1\_EXTI1\_PF ((uint16\_t)0x0050)
- #define SYSCFG\_EXTICR1\_EXTI1\_PG ((uint16\_t)0x0060)
- #define SYSCFG\_EXTICR1\_EXTI1\_PH ((uint16\_t)0x0070)
- #define SYSCFG\_EXTICR1\_EXTI1\_PI ((uint16\_t)0x0080)
- #define SYSCFG\_EXTICR1\_EXTI1\_PJ ((uint16\_t)0x0090)
- #define SYSCFG\_EXTICR1\_EXTI1\_PK ((uint16\_t)0x00A0)
- #define SYSCFG\_EXTICR1\_EXTI2\_PA ((uint16\_t)0x0000)

*EXTI2 configuration*

- #define SYSCFG\_EXTICR1\_EXTI2\_PB ((uint16\_t)0x0100)
- #define SYSCFG\_EXTICR1\_EXTI2\_PC ((uint16\_t)0x0200)
- #define SYSCFG\_EXTICR1\_EXTI2\_PD ((uint16\_t)0x0300)
- #define SYSCFG\_EXTICR1\_EXTI2\_PE ((uint16\_t)0x0400)
- #define SYSCFG\_EXTICR1\_EXTI2\_PF ((uint16\_t)0x0500)
- #define SYSCFG\_EXTICR1\_EXTI2\_PG ((uint16\_t)0x0600)
- #define SYSCFG\_EXTICR1\_EXTI2\_PH ((uint16\_t)0x0700)
- #define SYSCFG\_EXTICR1\_EXTI2\_PI ((uint16\_t)0x0800)
- #define SYSCFG\_EXTICR1\_EXTI2\_PJ ((uint16\_t)0x0900)
- #define SYSCFG\_EXTICR1\_EXTI2\_PK ((uint16\_t)0xA000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PA ((uint16\_t)0x0000)

*EXTI3 configuration*

- #define SYSCFG\_EXTICR1\_EXTI3\_PB ((uint16\_t)0x1000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PC ((uint16\_t)0x2000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PD ((uint16\_t)0x3000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PE ((uint16\_t)0x4000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PF ((uint16\_t)0x5000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PG ((uint16\_t)0x6000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PH ((uint16\_t)0x7000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PI ((uint16\_t)0x8000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PJ ((uint16\_t)0x9000)
- #define SYSCFG\_EXTICR1\_EXTI3\_PK ((uint16\_t)0xA000)
- #define SYSCFG\_EXTICR2\_EXTI4 ((uint16\_t)0x000F)
- #define SYSCFG\_EXTICR2\_EXTI5 ((uint16\_t)0x00F0)
- #define SYSCFG\_EXTICR2\_EXTI6 ((uint16\_t)0x0F00)
- #define SYSCFG\_EXTICR2\_EXTI7 ((uint16\_t)0xF000)
- #define SYSCFG\_EXTICR2\_EXTI4\_PA ((uint16\_t)0x0000)

*EXTI4 configuration*

- #define SYSCFG\_EXTICR2\_EXTI4\_PB ((uint16\_t)0x0001)
- #define SYSCFG\_EXTICR2\_EXTI4\_PC ((uint16\_t)0x0002)
- #define SYSCFG\_EXTICR2\_EXTI4\_PD ((uint16\_t)0x0003)
- #define SYSCFG\_EXTICR2\_EXTI4\_PE ((uint16\_t)0x0004)
- #define SYSCFG\_EXTICR2\_EXTI4\_PF ((uint16\_t)0x0005)
- #define SYSCFG\_EXTICR2\_EXTI4\_PG ((uint16\_t)0x0006)
- #define SYSCFG\_EXTICR2\_EXTI4\_PH ((uint16\_t)0x0007)
- #define SYSCFG\_EXTICR2\_EXTI4\_PI ((uint16\_t)0x0008)
- #define SYSCFG\_EXTICR2\_EXTI4\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR2\_EXTI4\_PK ((uint16\_t)0x000A)

- #define SYSCFG\_EXTICR2\_EXTI5\_PA ((uint16\_t)0x0000)  
*EXTI5 configuration*
  - #define SYSCFG\_EXTICR2\_EXTI5\_PB ((uint16\_t)0x0010)
  - #define SYSCFG\_EXTICR2\_EXTI5\_PC ((uint16\_t)0x0020)
  - #define SYSCFG\_EXTICR2\_EXTI5\_PD ((uint16\_t)0x0030)
  - #define SYSCFG\_EXTICR2\_EXTI5\_PE ((uint16\_t)0x0040)
  - #define SYSCFG\_EXTICR2\_EXTI5\_PF ((uint16\_t)0x0050)
  - #define SYSCFG\_EXTICR2\_EXTI5\_PG ((uint16\_t)0x0060)
  - #define SYSCFG\_EXTICR2\_EXTI5\_PH ((uint16\_t)0x0070)
  - #define SYSCFG\_EXTICR2\_EXTI5\_PI ((uint16\_t)0x0080)
  - #define SYSCFG\_EXTICR2\_EXTI5\_PJ ((uint16\_t)0x0090)
  - #define SYSCFG\_EXTICR2\_EXTI5\_PK ((uint16\_t)0x00A0)
  - #define SYSCFG\_EXTICR2\_EXTI6\_PA ((uint16\_t)0x0000)
- #define SYSCFG\_EXTICR2\_EXTI6\_PB ((uint16\_t)0x0100)  
*EXTI6 configuration*
  - #define SYSCFG\_EXTICR2\_EXTI6\_PC ((uint16\_t)0x0200)
  - #define SYSCFG\_EXTICR2\_EXTI6\_PD ((uint16\_t)0x0300)
  - #define SYSCFG\_EXTICR2\_EXTI6\_PE ((uint16\_t)0x0400)
  - #define SYSCFG\_EXTICR2\_EXTI6\_PF ((uint16\_t)0x0500)
  - #define SYSCFG\_EXTICR2\_EXTI6\_PG ((uint16\_t)0x0600)
  - #define SYSCFG\_EXTICR2\_EXTI6\_PH ((uint16\_t)0x0700)
  - #define SYSCFG\_EXTICR2\_EXTI6\_PI ((uint16\_t)0x0800)
  - #define SYSCFG\_EXTICR2\_EXTI6\_PJ ((uint16\_t)0x0900)
  - #define SYSCFG\_EXTICR2\_EXTI6\_PK ((uint16\_t)0xA000)
  - #define SYSCFG\_EXTICR2\_EXTI7\_PA ((uint16\_t)0x0000)
- #define SYSCFG\_EXTICR2\_EXTI7\_PB ((uint16\_t)0x1000)  
*EXTI7 configuration*
  - #define SYSCFG\_EXTICR2\_EXTI7\_PC ((uint16\_t)0x2000)
  - #define SYSCFG\_EXTICR2\_EXTI7\_PD ((uint16\_t)0x3000)
  - #define SYSCFG\_EXTICR2\_EXTI7\_PE ((uint16\_t)0x4000)
  - #define SYSCFG\_EXTICR2\_EXTI7\_PF ((uint16\_t)0x5000)
  - #define SYSCFG\_EXTICR2\_EXTI7\_PG ((uint16\_t)0x6000)
  - #define SYSCFG\_EXTICR2\_EXTI7\_PH ((uint16\_t)0x7000)
  - #define SYSCFG\_EXTICR2\_EXTI7\_PI ((uint16\_t)0x8000)
  - #define SYSCFG\_EXTICR2\_EXTI7\_PJ ((uint16\_t)0x9000)
  - #define SYSCFG\_EXTICR2\_EXTI7\_PK ((uint16\_t)0xA000)
  - #define SYSCFG\_EXTICR3\_EXTI8 ((uint16\_t)0x000F)
  - #define SYSCFG\_EXTICR3\_EXTI9 ((uint16\_t)0x00F0)
  - #define SYSCFG\_EXTICR3\_EXTI10 ((uint16\_t)0x0F00)
  - #define SYSCFG\_EXTICR3\_EXTI11 ((uint16\_t)0xF000)
  - #define SYSCFG\_EXTICR3\_EXTI8\_PA ((uint16\_t)0x0000)
- #define SYSCFG\_EXTICR3\_EXTI8\_PB ((uint16\_t)0x0001)  
*EXTI8 configuration*
  - #define SYSCFG\_EXTICR3\_EXTI8\_PC ((uint16\_t)0x0002)
  - #define SYSCFG\_EXTICR3\_EXTI8\_PD ((uint16\_t)0x0003)
  - #define SYSCFG\_EXTICR3\_EXTI8\_PE ((uint16\_t)0x0004)
  - #define SYSCFG\_EXTICR3\_EXTI8\_PF ((uint16\_t)0x0005)
  - #define SYSCFG\_EXTICR3\_EXTI8\_PG ((uint16\_t)0x0006)
  - #define SYSCFG\_EXTICR3\_EXTI8\_PH ((uint16\_t)0x0007)
  - #define SYSCFG\_EXTICR3\_EXTI8\_PI ((uint16\_t)0x0008)

- #define SYSCFG\_EXTICR3\_EXTI8\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR3\_EXTI9\_PA ((uint16\_t)0x0000)

*EXTI9 configuration*

- #define SYSCFG\_EXTICR3\_EXTI9\_PB ((uint16\_t)0x0010)
- #define SYSCFG\_EXTICR3\_EXTI9\_PC ((uint16\_t)0x0020)
- #define SYSCFG\_EXTICR3\_EXTI9\_PD ((uint16\_t)0x0030)
- #define SYSCFG\_EXTICR3\_EXTI9\_PE ((uint16\_t)0x0040)
- #define SYSCFG\_EXTICR3\_EXTI9\_PF ((uint16\_t)0x0050)
- #define SYSCFG\_EXTICR3\_EXTI9\_PG ((uint16\_t)0x0060)
- #define SYSCFG\_EXTICR3\_EXTI9\_PH ((uint16\_t)0x0070)
- #define SYSCFG\_EXTICR3\_EXTI9\_PI ((uint16\_t)0x0080)
- #define SYSCFG\_EXTICR3\_EXTI9\_PJ ((uint16\_t)0x0090)
- #define SYSCFG\_EXTICR3\_EXTI10\_PA ((uint16\_t)0x0000)

*EXTI10 configuration*

- #define SYSCFG\_EXTICR3\_EXTI10\_PB ((uint16\_t)0x0100)
- #define SYSCFG\_EXTICR3\_EXTI10\_PC ((uint16\_t)0x0200)
- #define SYSCFG\_EXTICR3\_EXTI10\_PD ((uint16\_t)0x0300)
- #define SYSCFG\_EXTICR3\_EXTI10\_PE ((uint16\_t)0x0400)
- #define SYSCFG\_EXTICR3\_EXTI10\_PF ((uint16\_t)0x0500)
- #define SYSCFG\_EXTICR3\_EXTI10\_PG ((uint16\_t)0x0600)
- #define SYSCFG\_EXTICR3\_EXTI10\_PH ((uint16\_t)0x0700)
- #define SYSCFG\_EXTICR3\_EXTI10\_PI ((uint16\_t)0x0800)
- #define SYSCFG\_EXTICR3\_EXTI10\_PJ ((uint16\_t)0x0900)
- #define SYSCFG\_EXTICR3\_EXTI11\_PA ((uint16\_t)0x0000)

*EXTI11 configuration*

- #define SYSCFG\_EXTICR3\_EXTI11\_PB ((uint16\_t)0x1000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PC ((uint16\_t)0x2000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PD ((uint16\_t)0x3000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PE ((uint16\_t)0x4000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PF ((uint16\_t)0x5000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PG ((uint16\_t)0x6000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PH ((uint16\_t)0x7000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PI ((uint16\_t)0x8000)
- #define SYSCFG\_EXTICR3\_EXTI11\_PJ ((uint16\_t)0x9000)
- #define SYSCFG\_EXTICR4\_EXTI12 ((uint16\_t)0x000F)
- #define SYSCFG\_EXTICR4\_EXTI13 ((uint16\_t)0x00F0)
- #define SYSCFG\_EXTICR4\_EXTI14 ((uint16\_t)0x0F00)
- #define SYSCFG\_EXTICR4\_EXTI15 ((uint16\_t)0xF000)
- #define SYSCFG\_EXTICR4\_EXTI12\_PA ((uint16\_t)0x0000)

*EXTI12 configuration*

- #define SYSCFG\_EXTICR4\_EXTI12\_PB ((uint16\_t)0x0001)
- #define SYSCFG\_EXTICR4\_EXTI12\_PC ((uint16\_t)0x0002)
- #define SYSCFG\_EXTICR4\_EXTI12\_PD ((uint16\_t)0x0003)
- #define SYSCFG\_EXTICR4\_EXTI12\_PE ((uint16\_t)0x0004)
- #define SYSCFG\_EXTICR4\_EXTI12\_PF ((uint16\_t)0x0005)
- #define SYSCFG\_EXTICR4\_EXTI12\_PG ((uint16\_t)0x0006)
- #define SYSCFG\_EXTICR4\_EXTI12\_PH ((uint16\_t)0x0007)
- #define SYSCFG\_EXTICR4\_EXTI12\_PI ((uint16\_t)0x0008)
- #define SYSCFG\_EXTICR4\_EXTI12\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR4\_EXTI13\_PA ((uint16\_t)0x0000)

*EXTI13 configuration*

- #define SYSCFG\_EXTICR4\_EXTI13\_PB ((uint16\_t)0x0010)
- #define SYSCFG\_EXTICR4\_EXTI13\_PC ((uint16\_t)0x0020)
- #define SYSCFG\_EXTICR4\_EXTI13\_PD ((uint16\_t)0x0030)
- #define SYSCFG\_EXTICR4\_EXTI13\_PE ((uint16\_t)0x0040)
- #define SYSCFG\_EXTICR4\_EXTI13\_PF ((uint16\_t)0x0050)
- #define SYSCFG\_EXTICR4\_EXTI13\_PG ((uint16\_t)0x0060)
- #define SYSCFG\_EXTICR4\_EXTI13\_PH ((uint16\_t)0x0070)
- #define SYSCFG\_EXTICR4\_EXTI13\_PI ((uint16\_t)0x0008)
- #define SYSCFG\_EXTICR4\_EXTI13\_PJ ((uint16\_t)0x0009)
- #define SYSCFG\_EXTICR4\_EXTI14\_PA ((uint16\_t)0x0000)

*EXTI14 configuration*

- #define SYSCFG\_EXTICR4\_EXTI14\_PB ((uint16\_t)0x0100)
- #define SYSCFG\_EXTICR4\_EXTI14\_PC ((uint16\_t)0x0200)
- #define SYSCFG\_EXTICR4\_EXTI14\_PD ((uint16\_t)0x0300)
- #define SYSCFG\_EXTICR4\_EXTI14\_PE ((uint16\_t)0x0400)
- #define SYSCFG\_EXTICR4\_EXTI14\_PF ((uint16\_t)0x0500)
- #define SYSCFG\_EXTICR4\_EXTI14\_PG ((uint16\_t)0x0600)
- #define SYSCFG\_EXTICR4\_EXTI14\_PH ((uint16\_t)0x0700)
- #define SYSCFG\_EXTICR4\_EXTI14\_PI ((uint16\_t)0x0800)
- #define SYSCFG\_EXTICR4\_EXTI14\_PJ ((uint16\_t)0x0900)
- #define SYSCFG\_EXTICR4\_EXTI15\_PA ((uint16\_t)0x0000)

*EXTI15 configuration*

- #define SYSCFG\_EXTICR4\_EXTI15\_PB ((uint16\_t)0x1000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PC ((uint16\_t)0x2000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PD ((uint16\_t)0x3000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PE ((uint16\_t)0x4000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PF ((uint16\_t)0x5000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PG ((uint16\_t)0x6000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PH ((uint16\_t)0x7000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PI ((uint16\_t)0x8000)
- #define SYSCFG\_EXTICR4\_EXTI15\_PJ ((uint16\_t)0x9000)
- #define SYSCFG\_CMPCR\_CMP\_PD ((uint32\_t)0x00000001)
- #define SYSCFG\_CMPCR\_READY ((uint32\_t)0x00000100)
- #define TIM\_CR1\_CEN ((uint16\_t)0x0001)
- #define TIM\_CR1\_UDIS ((uint16\_t)0x0002)
- #define TIM\_CR1\_URS ((uint16\_t)0x0004)
- #define TIM\_CR1\_OPM ((uint16\_t)0x0008)
- #define TIM\_CR1\_DIR ((uint16\_t)0x0010)
- #define TIM\_CR1\_CMS ((uint16\_t)0x0060)
- #define TIM\_CR1\_CMS\_0 ((uint16\_t)0x0020)
- #define TIM\_CR1\_CMS\_1 ((uint16\_t)0x0040)
- #define TIM\_CR1\_ARPE ((uint16\_t)0x0080)
- #define TIM\_CR1\_CKD ((uint16\_t)0x0300)
- #define TIM\_CR1\_CKD\_0 ((uint16\_t)0x0100)
- #define TIM\_CR1\_CKD\_1 ((uint16\_t)0x0200)
- #define TIM\_CR2\_CCPC ((uint16\_t)0x0001)
- #define TIM\_CR2\_CCUS ((uint16\_t)0x0004)
- #define TIM\_CR2\_CCDS ((uint16\_t)0x0008)
- #define TIM\_CR2\_MMS ((uint16\_t)0x0070)
- #define TIM\_CR2\_MMS\_0 ((uint16\_t)0x0010)
- #define TIM\_CR2\_MMS\_1 ((uint16\_t)0x0020)

- #define **TIM\_CR2\_MMS\_2** ((uint16\_t)0x0040)
- #define **TIM\_CR2\_TI1S** ((uint16\_t)0x0080)
- #define **TIM\_CR2\_OIS1** ((uint16\_t)0x0100)
- #define **TIM\_CR2\_OIS1N** ((uint16\_t)0x0200)
- #define **TIM\_CR2\_OIS2** ((uint16\_t)0x0400)
- #define **TIM\_CR2\_OIS2N** ((uint16\_t)0x0800)
- #define **TIM\_CR2\_OIS3** ((uint16\_t)0x1000)
- #define **TIM\_CR2\_OIS3N** ((uint16\_t)0x2000)
- #define **TIM\_CR2\_OIS4** ((uint16\_t)0x4000)
- #define **TIM\_SMCR\_SMS** ((uint16\_t)0x0007)
- #define **TIM\_SMCR\_SMS\_0** ((uint16\_t)0x0001)
- #define **TIM\_SMCR\_SMS\_1** ((uint16\_t)0x0002)
- #define **TIM\_SMCR\_SMS\_2** ((uint16\_t)0x0004)
- #define **TIM\_SMCR\_TS** ((uint16\_t)0x0070)
- #define **TIM\_SMCR\_TS\_0** ((uint16\_t)0x0010)
- #define **TIM\_SMCR\_TS\_1** ((uint16\_t)0x0020)
- #define **TIM\_SMCR\_TS\_2** ((uint16\_t)0x0040)
- #define **TIM\_SMCR\_MSM** ((uint16\_t)0x0080)
- #define **TIM\_SMCR\_ETF** ((uint16\_t)0x0F00)
- #define **TIM\_SMCR\_ETF\_0** ((uint16\_t)0x0100)
- #define **TIM\_SMCR\_ETF\_1** ((uint16\_t)0x0200)
- #define **TIM\_SMCR\_ETF\_2** ((uint16\_t)0x0400)
- #define **TIM\_SMCR\_ETF\_3** ((uint16\_t)0x0800)
- #define **TIM\_SMCR\_ETPS** ((uint16\_t)0x3000)
- #define **TIM\_SMCR\_ETPS\_0** ((uint16\_t)0x1000)
- #define **TIM\_SMCR\_ETPS\_1** ((uint16\_t)0x2000)
- #define **TIM\_SMCR\_ECE** ((uint16\_t)0x4000)
- #define **TIM\_SMCR\_ETP** ((uint16\_t)0x8000)
- #define **TIM\_DIER\_UIE** ((uint16\_t)0x0001)
- #define **TIM\_DIER\_CC1IE** ((uint16\_t)0x0002)
- #define **TIM\_DIER\_CC2IE** ((uint16\_t)0x0004)
- #define **TIM\_DIER\_CC3IE** ((uint16\_t)0x0008)
- #define **TIM\_DIER\_CC4IE** ((uint16\_t)0x0010)
- #define **TIM\_DIER\_COMIE** ((uint16\_t)0x0020)
- #define **TIM\_DIER\_TIE** ((uint16\_t)0x0040)
- #define **TIM\_DIER\_BIE** ((uint16\_t)0x0080)
- #define **TIM\_DIER\_UDE** ((uint16\_t)0x0100)
- #define **TIM\_DIER\_CC1DE** ((uint16\_t)0x0200)
- #define **TIM\_DIER\_CC2DE** ((uint16\_t)0x0400)
- #define **TIM\_DIER\_CC3DE** ((uint16\_t)0x0800)
- #define **TIM\_DIER\_CC4DE** ((uint16\_t)0x1000)
- #define **TIM\_DIER\_COMDE** ((uint16\_t)0x2000)
- #define **TIM\_DIER\_TDE** ((uint16\_t)0x4000)
- #define **TIM\_SR UIF** ((uint16\_t)0x0001)
- #define **TIM\_SR\_CC1IF** ((uint16\_t)0x0002)
- #define **TIM\_SR\_CC2IF** ((uint16\_t)0x0004)
- #define **TIM\_SR\_CC3IF** ((uint16\_t)0x0008)
- #define **TIM\_SR\_CC4IF** ((uint16\_t)0x0010)
- #define **TIM\_SR\_COMIF** ((uint16\_t)0x0020)
- #define **TIM\_SR\_TIF** ((uint16\_t)0x0040)
- #define **TIM\_SR\_BIF** ((uint16\_t)0x0080)
- #define **TIM\_SR\_CC1OF** ((uint16\_t)0x0200)
- #define **TIM\_SR\_CC2OF** ((uint16\_t)0x0400)
- #define **TIM\_SR\_CC3OF** ((uint16\_t)0x0800)
- #define **TIM\_SR\_CC4OF** ((uint16\_t)0x1000)

- #define TIM\_EGR\_UG ((uint8\_t)0x01)
- #define TIM\_EGR\_CC1G ((uint8\_t)0x02)
- #define TIM\_EGR\_CC2G ((uint8\_t)0x04)
- #define TIM\_EGR\_CC3G ((uint8\_t)0x08)
- #define TIM\_EGR\_CC4G ((uint8\_t)0x10)
- #define TIM\_EGR\_COMG ((uint8\_t)0x20)
- #define TIM\_EGR\_TG ((uint8\_t)0x40)
- #define TIM\_EGR\_BG ((uint8\_t)0x80)
- #define TIM\_CCMR1\_CC1S ((uint16\_t)0x0003)
- #define TIM\_CCMR1\_CC1S\_0 ((uint16\_t)0x0001)
- #define TIM\_CCMR1\_CC1S\_1 ((uint16\_t)0x0002)
- #define TIM\_CCMR1\_OC1FE ((uint16\_t)0x0004)
- #define TIM\_CCMR1\_OC1PE ((uint16\_t)0x0008)
- #define TIM\_CCMR1\_OC1M ((uint16\_t)0x0070)
- #define TIM\_CCMR1\_OC1M\_0 ((uint16\_t)0x0010)
- #define TIM\_CCMR1\_OC1M\_1 ((uint16\_t)0x0020)
- #define TIM\_CCMR1\_OC1M\_2 ((uint16\_t)0x0040)
- #define TIM\_CCMR1\_OC1CE ((uint16\_t)0x0080)
- #define TIM\_CCMR1\_CC2S ((uint16\_t)0x0300)
- #define TIM\_CCMR1\_CC2S\_0 ((uint16\_t)0x0100)
- #define TIM\_CCMR1\_CC2S\_1 ((uint16\_t)0x0200)
- #define TIM\_CCMR1\_OC2FE ((uint16\_t)0x0400)
- #define TIM\_CCMR1\_OC2PE ((uint16\_t)0x0800)
- #define TIM\_CCMR1\_OC2M ((uint16\_t)0x7000)
- #define TIM\_CCMR1\_OC2M\_0 ((uint16\_t)0x1000)
- #define TIM\_CCMR1\_OC2M\_1 ((uint16\_t)0x2000)
- #define TIM\_CCMR1\_OC2M\_2 ((uint16\_t)0x4000)
- #define TIM\_CCMR1\_OC2CE ((uint16\_t)0x8000)
- #define TIM\_CCMR1\_IC1PSC ((uint16\_t)0x000C)
- #define TIM\_CCMR1\_IC1PSC\_0 ((uint16\_t)0x0004)
- #define TIM\_CCMR1\_IC1PSC\_1 ((uint16\_t)0x0008)
- #define TIM\_CCMR1\_IC1F ((uint16\_t)0x00F0)
- #define TIM\_CCMR1\_IC1F\_0 ((uint16\_t)0x0010)
- #define TIM\_CCMR1\_IC1F\_1 ((uint16\_t)0x0020)
- #define TIM\_CCMR1\_IC1F\_2 ((uint16\_t)0x0040)
- #define TIM\_CCMR1\_IC1F\_3 ((uint16\_t)0x0080)
- #define TIM\_CCMR1\_IC2PSC ((uint16\_t)0x0C00)
- #define TIM\_CCMR1\_IC2PSC\_0 ((uint16\_t)0x0400)
- #define TIM\_CCMR1\_IC2PSC\_1 ((uint16\_t)0x0800)
- #define TIM\_CCMR1\_IC2F ((uint16\_t)0xF000)
- #define TIM\_CCMR1\_IC2F\_0 ((uint16\_t)0x1000)
- #define TIM\_CCMR1\_IC2F\_1 ((uint16\_t)0x2000)
- #define TIM\_CCMR1\_IC2F\_2 ((uint16\_t)0x4000)
- #define TIM\_CCMR1\_IC2F\_3 ((uint16\_t)0x8000)
- #define TIM\_CCMR2\_CC3S ((uint16\_t)0x0003)
- #define TIM\_CCMR2\_CC3S\_0 ((uint16\_t)0x0001)
- #define TIM\_CCMR2\_CC3S\_1 ((uint16\_t)0x0002)
- #define TIM\_CCMR2\_OC3FE ((uint16\_t)0x0004)
- #define TIM\_CCMR2\_OC3PE ((uint16\_t)0x0008)
- #define TIM\_CCMR2\_OC3M ((uint16\_t)0x0070)
- #define TIM\_CCMR2\_OC3M\_0 ((uint16\_t)0x0010)
- #define TIM\_CCMR2\_OC3M\_1 ((uint16\_t)0x0020)
- #define TIM\_CCMR2\_OC3M\_2 ((uint16\_t)0x0040)
- #define TIM\_CCMR2\_OC3CE ((uint16\_t)0x0080)
- #define TIM\_CCMR2\_CC4S ((uint16\_t)0x0300)

- #define TIM\_CCMR2\_CC4S\_0 ((uint16\_t)0x0100)
- #define TIM\_CCMR2\_CC4S\_1 ((uint16\_t)0x0200)
- #define TIM\_CCMR2\_OC4FE ((uint16\_t)0x0400)
- #define TIM\_CCMR2\_OC4PE ((uint16\_t)0x0800)
- #define TIM\_CCMR2\_OC4M ((uint16\_t)0x7000)
- #define TIM\_CCMR2\_OC4M\_0 ((uint16\_t)0x1000)
- #define TIM\_CCMR2\_OC4M\_1 ((uint16\_t)0x2000)
- #define TIM\_CCMR2\_OC4M\_2 ((uint16\_t)0x4000)
- #define TIM\_CCMR2\_OC4CE ((uint16\_t)0x8000)
- #define TIM\_CCMR2\_IC3PSC ((uint16\_t)0x000C)
- #define TIM\_CCMR2\_IC3PSC\_0 ((uint16\_t)0x0004)
- #define TIM\_CCMR2\_IC3PSC\_1 ((uint16\_t)0x0008)
- #define TIM\_CCMR2\_IC3F ((uint16\_t)0x00F0)
- #define TIM\_CCMR2\_IC3F\_0 ((uint16\_t)0x0010)
- #define TIM\_CCMR2\_IC3F\_1 ((uint16\_t)0x0020)
- #define TIM\_CCMR2\_IC3F\_2 ((uint16\_t)0x0040)
- #define TIM\_CCMR2\_IC3F\_3 ((uint16\_t)0x0080)
- #define TIM\_CCMR2\_IC4PSC ((uint16\_t)0x0C00)
- #define TIM\_CCMR2\_IC4PSC\_0 ((uint16\_t)0x0400)
- #define TIM\_CCMR2\_IC4PSC\_1 ((uint16\_t)0x0800)
- #define TIM\_CCMR2\_IC4F ((uint16\_t)0xF000)
- #define TIM\_CCMR2\_IC4F\_0 ((uint16\_t)0x1000)
- #define TIM\_CCMR2\_IC4F\_1 ((uint16\_t)0x2000)
- #define TIM\_CCMR2\_IC4F\_2 ((uint16\_t)0x4000)
- #define TIM\_CCMR2\_IC4F\_3 ((uint16\_t)0x8000)
- #define TIM\_CCER\_CC1E ((uint16\_t)0x0001)
- #define TIM\_CCER\_CC1P ((uint16\_t)0x0002)
- #define TIM\_CCER\_CC1NE ((uint16\_t)0x0004)
- #define TIM\_CCER\_CC1NP ((uint16\_t)0x0008)
- #define TIM\_CCER\_CC2E ((uint16\_t)0x0010)
- #define TIM\_CCER\_CC2P ((uint16\_t)0x0020)
- #define TIM\_CCER\_CC2NE ((uint16\_t)0x0040)
- #define TIM\_CCER\_CC2NP ((uint16\_t)0x0080)
- #define TIM\_CCER\_CC3E ((uint16\_t)0x0100)
- #define TIM\_CCER\_CC3P ((uint16\_t)0x0200)
- #define TIM\_CCER\_CC3NE ((uint16\_t)0x0400)
- #define TIM\_CCER\_CC3NP ((uint16\_t)0x0800)
- #define TIM\_CCER\_CC4E ((uint16\_t)0x1000)
- #define TIM\_CCER\_CC4P ((uint16\_t)0x2000)
- #define TIM\_CCER\_CC4NP ((uint16\_t)0x8000)
- #define TIM\_CNT\_CNT ((uint16\_t)0xFFFF)
- #define TIM\_PSC\_PSC ((uint16\_t)0xFFFF)
- #define TIM\_ARR\_ARR ((uint16\_t)0xFFFF)
- #define TIM\_RCR REP ((uint8\_t)0xFF)
- #define TIM\_CCR1\_CCR1 ((uint16\_t)0xFFFF)
- #define TIM\_CCR2\_CCR2 ((uint16\_t)0xFFFF)
- #define TIM\_CCR3\_CCR3 ((uint16\_t)0xFFFF)
- #define TIM\_CCR4\_CCR4 ((uint16\_t)0xFFFF)
- #define TIM\_BDTR\_DTG ((uint16\_t)0x00FF)
- #define TIM\_BDTR\_DTG\_0 ((uint16\_t)0x0001)
- #define TIM\_BDTR\_DTG\_1 ((uint16\_t)0x0002)
- #define TIM\_BDTR\_DTG\_2 ((uint16\_t)0x0004)
- #define TIM\_BDTR\_DTG\_3 ((uint16\_t)0x0008)
- #define TIM\_BDTR\_DTG\_4 ((uint16\_t)0x0010)
- #define TIM\_BDTR\_DTG\_5 ((uint16\_t)0x0020)

- #define TIM\_BDTR\_DTG\_6 ((uint16\_t)0x0040)
- #define TIM\_BDTR\_DTG\_7 ((uint16\_t)0x0080)
- #define TIM\_BDTR\_LOCK ((uint16\_t)0x0300)
- #define TIM\_BDTR\_LOCK\_0 ((uint16\_t)0x0100)
- #define TIM\_BDTR\_LOCK\_1 ((uint16\_t)0x0200)
- #define TIM\_BDTR\_OSSI ((uint16\_t)0x0400)
- #define TIM\_BDTR\_OSSR ((uint16\_t)0x0800)
- #define TIM\_BDTR\_BKE ((uint16\_t)0x1000)
- #define TIM\_BDTR\_BKP ((uint16\_t)0x2000)
- #define TIM\_BDTR\_AOE ((uint16\_t)0x4000)
- #define TIM\_BDTR\_MOE ((uint16\_t)0x8000)
- #define TIM\_DCR\_DBA ((uint16\_t)0x001F)
- #define TIM\_DCR\_DBA\_0 ((uint16\_t)0x0001)
- #define TIM\_DCR\_DBA\_1 ((uint16\_t)0x0002)
- #define TIM\_DCR\_DBA\_2 ((uint16\_t)0x0004)
- #define TIM\_DCR\_DBA\_3 ((uint16\_t)0x0008)
- #define TIM\_DCR\_DBA\_4 ((uint16\_t)0x0010)
- #define TIM\_DCR\_DBL ((uint16\_t)0x1F00)
- #define TIM\_DCR\_DBL\_0 ((uint16\_t)0x0100)
- #define TIM\_DCR\_DBL\_1 ((uint16\_t)0x0200)
- #define TIM\_DCR\_DBL\_2 ((uint16\_t)0x0400)
- #define TIM\_DCR\_DBL\_3 ((uint16\_t)0x0800)
- #define TIM\_DCR\_DBL\_4 ((uint16\_t)0x1000)
- #define TIM\_DMAR\_DMAB ((uint16\_t)0xFFFF)
- #define TIM\_OR\_TI4\_RMP ((uint16\_t)0x00C0)
- #define TIM\_OR\_TI4\_RMP\_0 ((uint16\_t)0x0040)
- #define TIM\_OR\_TI4\_RMP\_1 ((uint16\_t)0x0080)
- #define TIM\_OR\_ITR1\_RMP ((uint16\_t)0x0C00)
- #define TIM\_OR\_ITR1\_RMP\_0 ((uint16\_t)0x0400)
- #define TIM\_OR\_ITR1\_RMP\_1 ((uint16\_t)0x0800)
- #define USART\_SR\_PE ((uint16\_t)0x0001)
- #define USART\_SR\_FE ((uint16\_t)0x0002)
- #define USART\_SR\_NE ((uint16\_t)0x0004)
- #define USART\_SR\_ORE ((uint16\_t)0x0008)
- #define USART\_SR\_IDLE ((uint16\_t)0x0010)
- #define USART\_SR\_RXNE ((uint16\_t)0x0020)
- #define USART\_SR\_TC ((uint16\_t)0x0040)
- #define USART\_SR\_TXE ((uint16\_t)0x0080)
- #define USART\_SR\_LBD ((uint16\_t)0x0100)
- #define USART\_SR\_CTS ((uint16\_t)0x0200)
- #define USART\_DR\_DR ((uint16\_t)0x01FF)
- #define USART\_BRR\_DIV\_Fraction ((uint16\_t)0x000F)
- #define USART\_BRR\_DIV\_Mantissa ((uint16\_t)0xFFFF0)
- #define USART\_CR1\_SBK ((uint16\_t)0x0001)
- #define USART\_CR1\_RWU ((uint16\_t)0x0002)
- #define USART\_CR1\_RE ((uint16\_t)0x0004)
- #define USART\_CR1\_TE ((uint16\_t)0x0008)
- #define USART\_CR1\_IDLEIE ((uint16\_t)0x0010)
- #define USART\_CR1\_RXNEIE ((uint16\_t)0x0020)
- #define USART\_CR1\_TCIE ((uint16\_t)0x0040)
- #define USART\_CR1\_TXEIE ((uint16\_t)0x0080)
- #define USART\_CR1\_PEIE ((uint16\_t)0x0100)
- #define USART\_CR1\_PS ((uint16\_t)0x0200)
- #define USART\_CR1\_PCE ((uint16\_t)0x0400)
- #define USART\_CR1\_WAKE ((uint16\_t)0x0800)

- #define USART\_CR1\_M ((uint16\_t)0x1000)
- #define USART\_CR1\_UE ((uint16\_t)0x2000)
- #define USART\_CR1\_OVER8 ((uint16\_t)0x8000)
- #define USART\_CR2\_ADD ((uint16\_t)0x000F)
- #define USART\_CR2\_LBDL ((uint16\_t)0x0020)
- #define USART\_CR2\_LBDIE ((uint16\_t)0x0040)
- #define USART\_CR2\_LBCL ((uint16\_t)0x0100)
- #define USART\_CR2\_CPHA ((uint16\_t)0x0200)
- #define USART\_CR2\_CPOL ((uint16\_t)0x0400)
- #define USART\_CR2\_CLKEN ((uint16\_t)0x0800)
- #define USART\_CR2\_STOP ((uint16\_t)0x3000)
- #define USART\_CR2\_STOP\_0 ((uint16\_t)0x1000)
- #define USART\_CR2\_STOP\_1 ((uint16\_t)0x2000)
- #define USART\_CR2\_LINE\_N ((uint16\_t)0x4000)
- #define USART\_CR3\_EIE ((uint16\_t)0x0001)
- #define USART\_CR3\_IREN ((uint16\_t)0x0002)
- #define USART\_CR3\_IRLP ((uint16\_t)0x0004)
- #define USART\_CR3\_HDSEL ((uint16\_t)0x0008)
- #define USART\_CR3\_NACK ((uint16\_t)0x0010)
- #define USART\_CR3\_SCEN ((uint16\_t)0x0020)
- #define USART\_CR3\_DMAR ((uint16\_t)0x0040)
- #define USART\_CR3\_DMAT ((uint16\_t)0x0080)
- #define USART\_CR3\_RTSE ((uint16\_t)0x0100)
- #define USART\_CR3\_CTSE ((uint16\_t)0x0200)
- #define USART\_CR3\_CTSIE ((uint16\_t)0x0400)
- #define USART\_CR3\_ONEBIT ((uint16\_t)0x0800)
- #define USART\_GTPR\_PSC ((uint16\_t)0x00FF)
- #define USART\_GTPR\_PSC\_0 ((uint16\_t)0x0001)
- #define USART\_GTPR\_PSC\_1 ((uint16\_t)0x0002)
- #define USART\_GTPR\_PSC\_2 ((uint16\_t)0x0004)
- #define USART\_GTPR\_PSC\_3 ((uint16\_t)0x0008)
- #define USART\_GTPR\_PSC\_4 ((uint16\_t)0x0010)
- #define USART\_GTPR\_PSC\_5 ((uint16\_t)0x0020)
- #define USART\_GTPR\_PSC\_6 ((uint16\_t)0x0040)
- #define USART\_GTPR\_PSC\_7 ((uint16\_t)0x0080)
- #define USART\_GTPR\_GT ((uint16\_t)0xFF00)
- #define WWDG\_CR\_T ((uint8\_t)0x7F)
- #define WWDG\_CR\_T\_0 ((uint8\_t)0x01)
- #define WWDG\_CR\_T\_1 ((uint8\_t)0x02)
- #define WWDG\_CR\_T\_2 ((uint8\_t)0x04)
- #define WWDG\_CR\_T\_3 ((uint8\_t)0x08)
- #define WWDG\_CR\_T\_4 ((uint8\_t)0x10)
- #define WWDG\_CR\_T\_5 ((uint8\_t)0x20)
- #define WWDG\_CR\_T\_6 ((uint8\_t)0x40)
- #define WWDG\_CR\_T0 WWDG\_CR\_T\_0
- #define WWDG\_CR\_T1 WWDG\_CR\_T\_1
- #define WWDG\_CR\_T2 WWDG\_CR\_T\_2
- #define WWDG\_CR\_T3 WWDG\_CR\_T\_3
- #define WWDG\_CR\_T4 WWDG\_CR\_T\_4
- #define WWDG\_CR\_T5 WWDG\_CR\_T\_5
- #define WWDG\_CR\_T6 WWDG\_CR\_T\_6
- #define WWDG\_CR\_WDGA ((uint8\_t)0x80)
- #define WWDG\_CFR\_W ((uint16\_t)0x007F)
- #define WWDG\_CFR\_W\_0 ((uint16\_t)0x0001)
- #define WWDG\_CFR\_W\_1 ((uint16\_t)0x0002)

```
• #define WWDG_CFR_W_2 ((uint16_t)0x0004)
• #define WWDG_CFR_W_3 ((uint16_t)0x0008)
• #define WWDG_CFR_W_4 ((uint16_t)0x0010)
• #define WWDG_CFR_W_5 ((uint16_t)0x0020)
• #define WWDG_CFR_W_6 ((uint16_t)0x0040)
• #define WWDG_CFR_W0 WWDG_CFR_W_0
• #define WWDG_CFR_W1 WWDG_CFR_W_1
• #define WWDG_CFR_W2 WWDG_CFR_W_2
• #define WWDG_CFR_W3 WWDG_CFR_W_3
• #define WWDG_CFR_W4 WWDG_CFR_W_4
• #define WWDG_CFR_W5 WWDG_CFR_W_5
• #define WWDG_CFR_W6 WWDG_CFR_W_6
• #define WWDG_CFR_WDGTB ((uint16_t)0x0180)
• #define WWDG_CFR_WDGTB_0 ((uint16_t)0x0080)
• #define WWDG_CFR_WDGTB_1 ((uint16_t)0x0100)
• #define WWDG_CFR_WDGTB0 WWDG_CFR_WDGTB_0
• #define WWDG_CFR_WDGTB1 WWDG_CFR_WDGTB_1
• #define WWDG_CFR_EWI ((uint16_t)0x0200)
• #define WWDG_SR_EWIF ((uint8_t)0x01)
• #define DBGMCU_IDCODE_DEV_ID ((uint32_t)0x00000FFF)
• #define DBGMCU_IDCODE_REV_ID ((uint32_t)0xFFFF0000)
• #define DBGMCU_CR_DBG_SLEEP ((uint32_t)0x00000001)
• #define DBGMCU_CR_DBG_STOP ((uint32_t)0x00000002)
• #define DBGMCU_CR_DBG_STANDBY ((uint32_t)0x00000004)
• #define DBGMCU_CR_TRACE_IOEN ((uint32_t)0x00000020)
• #define DBGMCU_CR_TRACE_MODE ((uint32_t)0x000000C0)
• #define DBGMCU_CR_TRACE_MODE_0 ((uint32_t)0x00000040)
• #define DBGMCU_CR_TRACE_MODE_1 ((uint32_t)0x00000080)
• #define DBGMCU_APB1_FZ_DBG_TIM2_STOP ((uint32_t)0x00000001)
• #define DBGMCU_APB1_FZ_DBG_TIM3_STOP ((uint32_t)0x00000002)
• #define DBGMCU_APB1_FZ_DBG_TIM4_STOP ((uint32_t)0x00000004)
• #define DBGMCU_APB1_FZ_DBG_TIM5_STOP ((uint32_t)0x00000008)
• #define DBGMCU_APB1_FZ_DBG_TIM6_STOP ((uint32_t)0x00000010)
• #define DBGMCU_APB1_FZ_DBG_TIM7_STOP ((uint32_t)0x00000020)
• #define DBGMCU_APB1_FZ_DBG_TIM12_STOP ((uint32_t)0x00000040)
• #define DBGMCU_APB1_FZ_DBG_TIM13_STOP ((uint32_t)0x00000080)
• #define DBGMCU_APB1_FZ_DBG_TIM14_STOP ((uint32_t)0x00000100)
• #define DBGMCU_APB1_FZ_DBG_RTC_STOP ((uint32_t)0x00000400)
• #define DBGMCU_APB1_FZ_DBG_WWDG_STOP ((uint32_t)0x00000800)
• #define DBGMCU_APB1_FZ_DBG_IWDG_STOP ((uint32_t)0x00001000)
• #define DBGMCU_APB1_FZ_DBG_I2C1_SMBUS_TIMEOUT ((uint32_t)0x00200000)
• #define DBGMCU_APB1_FZ_DBG_I2C2_SMBUS_TIMEOUT ((uint32_t)0x00400000)
• #define DBGMCU_APB1_FZ_DBG_I2C3_SMBUS_TIMEOUT ((uint32_t)0x00800000)
• #define DBGMCU_APB1_FZ_DBG_CAN1_STOP ((uint32_t)0x02000000)
• #define DBGMCU_APB1_FZ_DBG_CAN2_STOP ((uint32_t)0x04000000)
• #define DBGMCU_APB1_FZ_DBG_IWDEG_STOP DBGMCU_APB1_FZ_DBG_IWDG_STOP
• #define DBGMCU_APB1_FZ_DBG_TIM1_STOP ((uint32_t)0x00000001)
• #define DBGMCU_APB1_FZ_DBG_TIM8_STOP ((uint32_t)0x00000002)
• #define DBGMCU_APB1_FZ_DBG_TIM9_STOP ((uint32_t)0x00010000)
• #define DBGMCU_APB1_FZ_DBG_TIM10_STOP ((uint32_t)0x00020000)
• #define DBGMCU_APB1_FZ_DBG_TIM11_STOP ((uint32_t)0x00040000)
• #define ETH_MACCR_WD ((uint32_t)0x00800000) /* Watchdog disable */
• #define ETH_MACCR_JD ((uint32_t)0x00400000) /* Jabber disable */
• #define ETH_MACCR_IFG ((uint32_t)0x000E0000) /* Inter-frame gap */
```

- #define **ETH\_MACCR\_IFG\_96Bit** ((uint32\_t)0x00000000) /\* Minimum IFG between frames during transmission is 96Bit \*/
- #define **ETH\_MACCR\_IFG\_88Bit** ((uint32\_t)0x00020000) /\* Minimum IFG between frames during transmission is 88Bit \*/
- #define **ETH\_MACCR\_IFG\_80Bit** ((uint32\_t)0x00040000) /\* Minimum IFG between frames during transmission is 80Bit \*/
- #define **ETH\_MACCR\_IFG\_72Bit** ((uint32\_t)0x00060000) /\* Minimum IFG between frames during transmission is 72Bit \*/
- #define **ETH\_MACCR\_IFG\_64Bit** ((uint32\_t)0x00080000) /\* Minimum IFG between frames during transmission is 64Bit \*/
- #define **ETH\_MACCR\_IFG\_56Bit** ((uint32\_t)0x000A0000) /\* Minimum IFG between frames during transmission is 56Bit \*/
- #define **ETH\_MACCR\_IFG\_48Bit** ((uint32\_t)0x000C0000) /\* Minimum IFG between frames during transmission is 48Bit \*/
- #define **ETH\_MACCR\_IFG\_40Bit** ((uint32\_t)0x000E0000) /\* Minimum IFG between frames during transmission is 40Bit \*/
- #define **ETH\_MACCR\_CSD** ((uint32\_t)0x00010000) /\* Carrier sense disable (during transmission) \*/
- #define **ETH\_MACCR\_FES** ((uint32\_t)0x00004000) /\* Fast ethernet speed \*/
- #define **ETH\_MACCR\_ROD** ((uint32\_t)0x00002000) /\* Receive own disable \*/
- #define **ETH\_MACCR\_LM** ((uint32\_t)0x00001000) /\* loopback mode \*/
- #define **ETH\_MACCR\_DM** ((uint32\_t)0x00000800) /\* Duplex mode \*/
- #define **ETH\_MACCR\_IPCO** ((uint32\_t)0x00000400) /\* IP Checksum offload \*/
- #define **ETH\_MACCR\_RD** ((uint32\_t)0x00000200) /\* Retry disable \*/
- #define **ETH\_MACCR\_APCS** ((uint32\_t)0x00000080) /\* Automatic Pad/CRC stripping \*/
- #define **ETH\_MACCR\_BL**
- #define **ETH\_MACCR\_BL\_10** ((uint32\_t)0x00000000) /\* k = min (n, 10) \*/
- #define **ETH\_MACCR\_BL\_8** ((uint32\_t)0x00000020) /\* k = min (n, 8) \*/
- #define **ETH\_MACCR\_BL\_4** ((uint32\_t)0x00000040) /\* k = min (n, 4) \*/
- #define **ETH\_MACCR\_BL\_1** ((uint32\_t)0x00000060) /\* k = min (n, 1) \*/
- #define **ETH\_MACCR\_DC** ((uint32\_t)0x00000010) /\* Defferal check \*/
- #define **ETH\_MACCR\_TE** ((uint32\_t)0x00000008) /\* Transmitter enable \*/
- #define **ETH\_MACCR\_RE** ((uint32\_t)0x00000004) /\* Receiver enable \*/
- #define **ETH\_MACFFR\_RA** ((uint32\_t)0x80000000) /\* Receive all \*/
- #define **ETH\_MACFFR\_HPF** ((uint32\_t)0x00000400) /\* Hash or perfect filter \*/
- #define **ETH\_MACFFR\_SAF** ((uint32\_t)0x00000200) /\* Source address filter enable \*/
- #define **ETH\_MACFFR\_SAIF** ((uint32\_t)0x00000100) /\* SA inverse filtering \*/
- #define **ETH\_MACFFR\_PCF** ((uint32\_t)0x000000C0) /\* Pass control frames: 3 cases \*/
- #define **ETH\_MACFFR\_PCF\_BlockAll** ((uint32\_t)0x00000040) /\* MAC filters all control frames from reaching the application \*/
- #define **ETH\_MACFFR\_PCF\_ForwardAll** ((uint32\_t)0x00000080) /\* MAC forwards all control frames to application even if they fail the Address Filter \*/
- #define **ETH\_MACFFR\_PCF\_ForwardPassedAddrFilter** ((uint32\_t)0x000000C0) /\* MAC forwards control frames that pass the Address Filter. \*/
- #define **ETH\_MACFFR\_BFD** ((uint32\_t)0x00000020) /\* Broadcast frame disable \*/
- #define **ETH\_MACFFR\_PAM** ((uint32\_t)0x00000010) /\* Pass all mutlicast \*/
- #define **ETH\_MACFFR\_DAIF** ((uint32\_t)0x00000008) /\* DA Inverse filtering \*/
- #define **ETH\_MACFFR\_HM** ((uint32\_t)0x00000004) /\* Hash multicast \*/
- #define **ETH\_MACFFR\_HU** ((uint32\_t)0x00000002) /\* Hash unicast \*/
- #define **ETH\_MACFFR\_PM** ((uint32\_t)0x00000001) /\* Promiscuous mode \*/
- #define **ETH\_MACHTHR\_HTH** ((uint32\_t)0xFFFFFFFF) /\* Hash table high \*/
- #define **ETH\_MACHTLR\_HTL** ((uint32\_t)0xFFFFFFFF) /\* Hash table low \*/
- #define **ETH\_MACMIIAR\_PA** ((uint32\_t)0x0000F800) /\* Physical layer address \*/
- #define **ETH\_MACMIIAR\_MR** ((uint32\_t)0x000007C0) /\* MII register in the selected PHY \*/
- #define **ETH\_MACMIIAR\_CR** ((uint32\_t)0x0000001C) /\* CR clock range: 6 cases \*/
- #define **ETH\_MACMIIAR\_CR\_Div42** ((uint32\_t)0x00000000) /\* HCLK:60-100 MHz; MDC clock= HCLK/42 \*/

- #define **ETH\_MACMIIAR\_CR\_Div62** ((uint32\_t)0x00000004) /\* HCLK:100-150 MHz; MDC clock= HCLK/62 \*/
 \*/
- #define **ETH\_MACMIIAR\_CR\_Div16** ((uint32\_t)0x00000008) /\* HCLK:20-35 MHz; MDC clock= HCLK/16 \*/
- #define **ETH\_MACMIIAR\_CR\_Div26** ((uint32\_t)0x0000000C) /\* HCLK:35-60 MHz; MDC clock= HCLK/26 \*/
- #define **ETH\_MACMIIAR\_CR\_Div102** ((uint32\_t)0x00000010) /\* HCLK:150-168 MHz; MDC clock= HCLK/102 \*/
- #define **ETH\_MACMIIAR\_MW** ((uint32\_t)0x00000002) /\* MII write \*/
- #define **ETH\_MACMIIAR\_MB** ((uint32\_t)0x00000001) /\* MII busy \*/
- #define **ETH\_MACMIIDR\_MD** ((uint32\_t)0x0000FFFF) /\* MII data: read/write data from/to PHY \*/
- #define **ETH\_MACFCR\_PT** ((uint32\_t)0xFFFF0000) /\* Pause time \*/
- #define **ETH\_MACFCR\_ZQPD** ((uint32\_t)0x00000080) /\* Zero-quanta pause disable \*/
- #define **ETH\_MACFCR\_PLT** ((uint32\_t)0x00000030) /\* Pause low threshold: 4 cases \*/
- #define **ETH\_MACFCR\_PLT\_Minus4** ((uint32\_t)0x00000000) /\* Pause time minus 4 slot times \*/
- #define **ETH\_MACFCR\_PLT\_Minus28** ((uint32\_t)0x00000010) /\* Pause time minus 28 slot times \*/
- #define **ETH\_MACFCR\_PLT\_Minus144** ((uint32\_t)0x00000020) /\* Pause time minus 144 slot times \*/
- #define **ETH\_MACFCR\_PLT\_Minus256** ((uint32\_t)0x00000030) /\* Pause time minus 256 slot times \*/
- #define **ETH\_MACFCR\_UPFD** ((uint32\_t)0x00000008) /\* Unicast pause frame detect \*/
- #define **ETH\_MACFCR\_RFCE** ((uint32\_t)0x00000004) /\* Receive flow control enable \*/
- #define **ETH\_MACFCR\_TFCE** ((uint32\_t)0x00000002) /\* Transmit flow control enable \*/
- #define **ETH\_MACFCR\_FCBBPA** ((uint32\_t)0x00000001) /\* Flow control busy/backpressure activate \*/
- #define **ETH\_MACVLANTR\_VLANTC** ((uint32\_t)0x00010000) /\* 12-bit VLAN tag comparison \*/
- #define **ETH\_MACVLANTR\_VLANTI** ((uint32\_t)0x0000FFFF) /\* VLAN tag identifier (for receive frames) \*/
- #define **ETH\_MACRWUFFR\_D** ((uint32\_t)0xFFFFFFFF) /\* Wake-up frame filter register data \*/
- #define **ETH\_MACPMTCSR\_WFFRPR** ((uint32\_t)0x80000000) /\* Wake-Up Frame Filter Register Pointer Reset \*/
- #define **ETH\_MACPMTCSR\_GU** ((uint32\_t)0x00000200) /\* Global Unicast \*/
- #define **ETH\_MACPMTCSR\_WFR** ((uint32\_t)0x00000040) /\* Wake-Up Frame Received \*/
- #define **ETH\_MACPMTCSR\_MPR** ((uint32\_t)0x00000020) /\* Magic Packet Received \*/
- #define **ETH\_MACPMTCSR\_WFE** ((uint32\_t)0x00000004) /\* Wake-Up Frame Enable \*/
- #define **ETH\_MACPMTCSR\_MPE** ((uint32\_t)0x00000002) /\* Magic Packet Enable \*/
- #define **ETH\_MACPMTCSR\_PD** ((uint32\_t)0x00000001) /\* Power Down \*/
- #define **ETH\_MACSR\_TSTS** ((uint32\_t)0x00000200) /\* Time stamp trigger status \*/
- #define **ETH\_MACSR\_MMCTS** ((uint32\_t)0x00000040) /\* MMC transmit status \*/
- #define **ETH\_MACSR\_MMMCRS** ((uint32\_t)0x00000020) /\* MMC receive status \*/
- #define **ETH\_MACSR\_MMCS** ((uint32\_t)0x00000010) /\* MMC status \*/
- #define **ETH\_MACSR\_PMTS** ((uint32\_t)0x00000008) /\* PMT status \*/
- #define **ETH\_MACIMR\_TSTIM** ((uint32\_t)0x00000020) /\* Time stamp trigger interrupt mask \*/
- #define **ETH\_MACIMR\_PMTIM** ((uint32\_t)0x00000008) /\* PMT interrupt mask \*/
- #define **ETH\_MACA0HR\_MACA0H** ((uint32\_t)0x0000FFFF) /\* MAC address0 high \*/
- #define **ETH\_MACA0LR\_MACA0L** ((uint32\_t)0xFFFFFFFF) /\* MAC address0 low \*/
- #define **ETH\_MACA1HR\_AE** ((uint32\_t)0x80000000) /\* Address enable \*/
- #define **ETH\_MACA1HR\_SA** ((uint32\_t)0x40000000) /\* Source address \*/
- #define **ETH\_MACA1HR\_MBC** ((uint32\_t)0x3F000000) /\* Mask byte control: bits to mask for comparison of the MAC Address bytes \*/
- #define **ETH\_MACA1HR\_MBC\_HBits15\_8** ((uint32\_t)0x20000000) /\* Mask MAC Address high reg bits [15:8] \*/
- #define **ETH\_MACA1HR\_MBC\_HBits7\_0** ((uint32\_t)0x10000000) /\* Mask MAC Address high reg bits [7:0] \*/
- #define **ETH\_MACA1HR\_MBC\_LBits31\_24** ((uint32\_t)0x08000000) /\* Mask MAC Address low reg bits [31:24] \*/
- #define **ETH\_MACA1HR\_MBC\_LBits23\_16** ((uint32\_t)0x04000000) /\* Mask MAC Address low reg bits [23:16] \*/
- #define **ETH\_MACA1HR\_MBC\_LBits15\_8** ((uint32\_t)0x02000000) /\* Mask MAC Address low reg bits [15:8] \*/
- #define **ETH\_MACA1HR\_MBC\_LBits7\_0** ((uint32\_t)0x01000000) /\* Mask MAC Address low reg bits [7:0] \*/

- #define **ETH\_MACA1HR\_MACA1H** ((uint32\_t)0x0000FFFF) /\* MAC address1 high \*/
- #define **ETH\_MACA1LR\_MACA1L** ((uint32\_t)0xFFFFFFFF) /\* MAC address1 low \*/
- #define **ETH\_MACA2HR\_AE** ((uint32\_t)0x80000000) /\* Address enable \*/
- #define **ETH\_MACA2HR\_SA** ((uint32\_t)0x40000000) /\* Source address \*/
- #define **ETH\_MACA2HR\_MBC** ((uint32\_t)0x3F000000) /\* Mask byte control \*/
- #define **ETH\_MACA2HR\_MBC\_HBits15\_8** ((uint32\_t)0x20000000) /\* Mask MAC Address high reg bits [15:8] \*/
- #define **ETH\_MACA2HR\_MBC\_HBits7\_0** ((uint32\_t)0x10000000) /\* Mask MAC Address high reg bits [7:0] \*/
- #define **ETH\_MACA2HR\_MBC\_LBits31\_24** ((uint32\_t)0x08000000) /\* Mask MAC Address low reg bits [31:24] \*/
- #define **ETH\_MACA2HR\_MBC\_LBits23\_16** ((uint32\_t)0x04000000) /\* Mask MAC Address low reg bits [23:16] \*/
- #define **ETH\_MACA2HR\_MBC\_LBits15\_8** ((uint32\_t)0x02000000) /\* Mask MAC Address low reg bits [15:8] \*/
- #define **ETH\_MACA2HR\_MBC\_LBits7\_0** ((uint32\_t)0x01000000) /\* Mask MAC Address low reg bits [7:0] \*/
- #define **ETH\_MACA2HR\_MACA2H** ((uint32\_t)0x0000FFFF) /\* MAC address1 high \*/
- #define **ETH\_MACA2LR\_MACA2L** ((uint32\_t)0xFFFFFFFF) /\* MAC address2 low \*/
- #define **ETH\_MACA3HR\_AE** ((uint32\_t)0x80000000) /\* Address enable \*/
- #define **ETH\_MACA3HR\_SA** ((uint32\_t)0x40000000) /\* Source address \*/
- #define **ETH\_MACA3HR\_MBC** ((uint32\_t)0x3F000000) /\* Mask byte control \*/
- #define **ETH\_MACA3HR\_MBC\_HBits15\_8** ((uint32\_t)0x20000000) /\* Mask MAC Address high reg bits [15:8] \*/
- #define **ETH\_MACA3HR\_MBC\_HBits7\_0** ((uint32\_t)0x10000000) /\* Mask MAC Address high reg bits [7:0] \*/
- #define **ETH\_MACA3HR\_MBC\_LBits31\_24** ((uint32\_t)0x08000000) /\* Mask MAC Address low reg bits [31:24] \*/
- #define **ETH\_MACA3HR\_MBC\_LBits23\_16** ((uint32\_t)0x04000000) /\* Mask MAC Address low reg bits [23:16] \*/
- #define **ETH\_MACA3HR\_MBC\_LBits15\_8** ((uint32\_t)0x02000000) /\* Mask MAC Address low reg bits [15:8] \*/
- #define **ETH\_MACA3HR\_MBC\_LBits7\_0** ((uint32\_t)0x01000000) /\* Mask MAC Address low reg bits [7:0] \*/
- #define **ETH\_MACA3HR\_MACA3H** ((uint32\_t)0x0000FFFF) /\* MAC address3 high \*/
- #define **ETH\_MACA3LR\_MACA3L** ((uint32\_t)0xFFFFFFFF) /\* MAC address3 low \*/
- #define **ETH\_MMCCR\_MCFHP** ((uint32\_t)0x00000020) /\* MMC counter Full-Half preset \*/
- #define **ETH\_MMCCR\_MCP** ((uint32\_t)0x00000010) /\* MMC counter preset \*/
- #define **ETH\_MMCCR\_MCF** ((uint32\_t)0x00000008) /\* MMC Counter Freeze \*/
- #define **ETH\_MMCCR\_ROR** ((uint32\_t)0x00000004) /\* **Reset** on Read \*/
- #define **ETH\_MMCCR\_CSR** ((uint32\_t)0x00000002) /\* Counter Stop Rollover \*/
- #define **ETH\_MMCCR\_CR** ((uint32\_t)0x00000001) /\* Counters **Reset** \*/
- #define **ETH\_MMCRIR\_RGUFS** ((uint32\_t)0x00020000) /\* **Set** when Rx good unicast frames counter reaches half the maximum value \*/
- #define **ETH\_MMCRIR\_RFAES** ((uint32\_t)0x00000040) /\* **Set** when Rx alignment error counter reaches half the maximum value \*/
- #define **ETH\_MMCRIR\_RFCES** ((uint32\_t)0x00000020) /\* **Set** when Rx crc error counter reaches half the maximum value \*/
- #define **ETH\_MMCTIR\_TGFS** ((uint32\_t)0x00200000) /\* **Set** when Tx good frame count counter reaches half the maximum value \*/
- #define **ETH\_MMCTIR\_TGFMSCS** ((uint32\_t)0x00008000) /\* **Set** when Tx good multi col counter reaches half the maximum value \*/
- #define **ETH\_MMCTIR\_TGFSCS** ((uint32\_t)0x00004000) /\* **Set** when Tx good single col counter reaches half the maximum value \*/
- #define **ETH\_MMCRIMR\_RGUFM** ((uint32\_t)0x00020000) /\* Mask the interrupt when Rx good unicast frames counter reaches half the maximum value \*/
- #define **ETH\_MMCRIMR\_RFAEM** ((uint32\_t)0x00000040) /\* Mask the interrupt when when Rx alignment error counter reaches half the maximum value \*/

- #define **ETH\_MMCRIMR\_RFCEM** ((uint32\_t)0x00000020) /\* Mask the interrupt when Rx crc error counter reaches half the maximum value \*/
- #define **ETH\_MMCTIMR\_TGFM** ((uint32\_t)0x00200000) /\* Mask the interrupt when Tx good frame count counter reaches half the maximum value \*/
- #define **ETH\_MMCTIMR\_TGFMSCM** ((uint32\_t)0x00008000) /\* Mask the interrupt when Tx good multi col counter reaches half the maximum value \*/
- #define **ETH\_MMCTIMR\_TGFSCM** ((uint32\_t)0x00004000) /\* Mask the interrupt when Tx good single col counter reaches half the maximum value \*/
- #define **ETH\_MMCTGFSCCR\_TGFSCC** ((uint32\_t)0xFFFFFFFF) /\* Number of successfully transmitted frames after a single collision in Half-duplex mode. \*/
- #define **ETH\_MMCTGFMSCCR\_TGFMSCC** ((uint32\_t)0xFFFFFFFF) /\* Number of successfully transmitted frames after more than a single collision in Half-duplex mode. \*/
- #define **ETH\_MMCTGFCR\_TGFC** ((uint32\_t)0xFFFFFFFF) /\* Number of good frames transmitted. \*/
- #define **ETH\_MMCRFCECR\_RFCEC** ((uint32\_t)0xFFFFFFFF) /\* Number of frames received with **CRC** error. \*/
- #define **ETH\_MMCRFAECR\_RFAEC** ((uint32\_t)0xFFFFFFFF) /\* Number of frames received with alignment (dribble) error \*/
- #define **ETH\_MMCRGUFCR\_RGUFC** ((uint32\_t)0xFFFFFFFF) /\* Number of good unicast frames received. \*/
- #define **ETH\_PTPTSCR\_TSCNT** ((uint32\_t)0x00030000) /\* Time stamp clock node type \*/
- #define **ETH\_PTPTSSR\_TSSMRME** ((uint32\_t)0x00008000) /\* Time stamp snapshot for message relevant to master enable \*/
- #define **ETH\_PTPTSSR\_TSSEME** ((uint32\_t)0x00004000) /\* Time stamp snapshot for event message enable \*/
- #define **ETH\_PTPTSSR\_TSSIPV4FE** ((uint32\_t)0x00002000) /\* Time stamp snapshot for IPv4 frames enable \*/
- #define **ETH\_PTPTSSR\_TSSIPV6FE** ((uint32\_t)0x00001000) /\* Time stamp snapshot for IPv6 frames enable \*/
- #define **ETH\_PTPTSSR\_TSSPTPOEFE** ((uint32\_t)0x00000800) /\* Time stamp snapshot for PTP over ethernet frames enable \*/
- #define **ETH\_PTPTSSR\_TSPTPPSV2E** ((uint32\_t)0x00000400) /\* Time stamp PTP packet snooping for version2 format enable \*/
- #define **ETH\_PTPTSSR\_TSSSR** ((uint32\_t)0x00000200) /\* Time stamp Sub-seconds rollover \*/
- #define **ETH\_PTPTSSR\_TSSARFE** ((uint32\_t)0x00000100) /\* Time stamp snapshot for all received frames enable \*/
- #define **ETH\_PTPTSCR\_TSARU** ((uint32\_t)0x00000020) /\* Addend register update \*/
- #define **ETH\_PTPTSCR\_TSITE** ((uint32\_t)0x00000010) /\* Time stamp interrupt trigger enable \*/
- #define **ETH\_PTPTSCR\_TSSTU** ((uint32\_t)0x00000008) /\* Time stamp update \*/
- #define **ETH\_PTPTSCR\_TSSTI** ((uint32\_t)0x00000004) /\* Time stamp initialize \*/
- #define **ETH\_PTPTSCR\_TSFCU** ((uint32\_t)0x00000002) /\* Time stamp fine or coarse update \*/
- #define **ETH\_PTPTSCR\_TSE** ((uint32\_t)0x00000001) /\* Time stamp enable \*/
- #define **ETH\_PTSSIR\_STSSI** ((uint32\_t)0x000000FF) /\* System time Sub-second increment value \*/
- #define **ETH\_PTPTSHR\_STS** ((uint32\_t)0xFFFFFFFF) /\* System Time second \*/
- #define **ETH\_PTPTSLR\_STPNS** ((uint32\_t)0x80000000) /\* System Time Positive or negative time \*/
- #define **ETH\_PTPTSLR\_STSS** ((uint32\_t)0x7FFFFFFF) /\* System Time sub-seconds \*/
- #define **ETH\_PTPTSHUR\_TSUS** ((uint32\_t)0xFFFFFFFF) /\* Time stamp update seconds \*/
- #define **ETH\_PTPTSLUR\_TSUPNS** ((uint32\_t)0x80000000) /\* Time stamp update Positive or negative time \*/
- #define **ETH\_PTPTSLUR\_TSUSS** ((uint32\_t)0x7FFFFFFF) /\* Time stamp update sub-seconds \*/
- #define **ETH\_PTPTSAR\_TSA** ((uint32\_t)0xFFFFFFFF) /\* Time stamp addend \*/
- #define **ETH\_PTPTTHR\_TTSH** ((uint32\_t)0xFFFFFFFF) /\* Target time stamp high \*/
- #define **ETH\_PTPTTLR\_TTSL** ((uint32\_t)0xFFFFFFFF) /\* Target time stamp low \*/
- #define **ETH\_PTPTSSR\_TSTTR** ((uint32\_t)0x00000020) /\* Time stamp target time reached \*/
- #define **ETH\_PTPTSSR\_TSSO** ((uint32\_t)0x00000010) /\* Time stamp seconds overflow \*/
- #define **ETH\_DMABMR\_AAB** ((uint32\_t)0x02000000) /\* Address-Aligned beats \*/
- #define **ETH\_DMABMR\_FPM** ((uint32\_t)0x01000000) /\* 4xPBL mode \*/

- #define **ETH\_DMABMR\_USP** ((uint32\_t)0x00800000) /\* Use separate PBL \*/
- #define **ETH\_DMABMR\_RDP** ((uint32\_t)0x007E0000) /\* RxDMA PBL \*/
- #define **ETH\_DMABMR\_RDP\_1Beat** ((uint32\_t)0x00020000) /\* maximum number of beats to be transferred in one RxDMA transaction is 1 \*/
- #define **ETH\_DMABMR\_RDP\_2Beat** ((uint32\_t)0x00040000) /\* maximum number of beats to be transferred in one RxDMA transaction is 2 \*/
- #define **ETH\_DMABMR\_RDP\_4Beat** ((uint32\_t)0x00080000) /\* maximum number of beats to be transferred in one RxDMA transaction is 4 \*/
- #define **ETH\_DMABMR\_RDP\_8Beat** ((uint32\_t)0x00100000) /\* maximum number of beats to be transferred in one RxDMA transaction is 8 \*/
- #define **ETH\_DMABMR\_RDP\_16Beat** ((uint32\_t)0x00200000) /\* maximum number of beats to be transferred in one RxDMA transaction is 16 \*/
- #define **ETH\_DMABMR\_RDP\_32Beat** ((uint32\_t)0x00400000) /\* maximum number of beats to be transferred in one RxDMA transaction is 32 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_4Beat** ((uint32\_t)0x01020000) /\* maximum number of beats to be transferred in one RxDMA transaction is 4 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_8Beat** ((uint32\_t)0x01040000) /\* maximum number of beats to be transferred in one RxDMA transaction is 8 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_16Beat** ((uint32\_t)0x01080000) /\* maximum number of beats to be transferred in one RxDMA transaction is 16 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_32Beat** ((uint32\_t)0x01100000) /\* maximum number of beats to be transferred in one RxDMA transaction is 32 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_64Beat** ((uint32\_t)0x01200000) /\* maximum number of beats to be transferred in one RxDMA transaction is 64 \*/
- #define **ETH\_DMABMR\_RDP\_4xPBL\_128Beat** ((uint32\_t)0x01400000) /\* maximum number of beats to be transferred in one RxDMA transaction is 128 \*/
- #define **ETH\_DMABMR\_FB** ((uint32\_t)0x00010000) /\* Fixed Burst \*/
- #define **ETH\_DMABMR\_RTPR** ((uint32\_t)0x0000C000) /\* Rx Tx priority ratio \*/
- #define **ETH\_DMABMR\_RTPR\_1\_1** ((uint32\_t)0x00000000) /\* Rx Tx priority ratio \*/
- #define **ETH\_DMABMR\_RTPR\_2\_1** ((uint32\_t)0x00004000) /\* Rx Tx priority ratio \*/
- #define **ETH\_DMABMR\_RTPR\_3\_1** ((uint32\_t)0x00008000) /\* Rx Tx priority ratio \*/
- #define **ETH\_DMABMR\_RTPR\_4\_1** ((uint32\_t)0x0000C000) /\* Rx Tx priority ratio \*/
- #define **ETH\_DMABMR\_PBL** ((uint32\_t)0x00003F00) /\* Programmable burst length \*/
- #define **ETH\_DMABMR\_PBL\_1Beat** ((uint32\_t)0x00000100) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 1 \*/
- #define **ETH\_DMABMR\_PBL\_2Beat** ((uint32\_t)0x00000200) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 2 \*/
- #define **ETH\_DMABMR\_PBL\_4Beat** ((uint32\_t)0x00000400) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 4 \*/
- #define **ETH\_DMABMR\_PBL\_8Beat** ((uint32\_t)0x00000800) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 8 \*/
- #define **ETH\_DMABMR\_PBL\_16Beat** ((uint32\_t)0x00001000) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 16 \*/
- #define **ETH\_DMABMR\_PBL\_32Beat** ((uint32\_t)0x00002000) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 32 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_4Beat** ((uint32\_t)0x01000100) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 4 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_8Beat** ((uint32\_t)0x01000200) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 8 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_16Beat** ((uint32\_t)0x01000400) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 16 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_32Beat** ((uint32\_t)0x01000800) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 32 \*/
- #define **ETH\_DMABMR\_PBL\_4xPBL\_64Beat** ((uint32\_t)0x01001000) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 64 \*/

- #define **ETH\_DMABMR\_PBL\_4xPBL\_128Beat** ((uint32\_t)0x01002000) /\* maximum number of beats to be transferred in one TxDMA (or both) transaction is 128 \*/
- #define **ETH\_DMABMR\_EDE** ((uint32\_t)0x00000080) /\* Enhanced Descriptor Enable \*/
- #define **ETH\_DMABMR\_DSL** ((uint32\_t)0x0000007C) /\* Descriptor Skip Length \*/
- #define **ETH\_DMABMR\_DA** ((uint32\_t)0x00000002) /\* DMA arbitration scheme \*/
- #define **ETH\_DMABMR\_SR** ((uint32\_t)0x00000001) /\* Software reset \*/
- #define **ETH\_DMATPDR\_TPD** ((uint32\_t)0xFFFFFFF) /\* Transmit poll demand \*/
- #define **ETH\_DMARPDR\_RPD** ((uint32\_t)0xFFFFFFFF) /\* Receive poll demand \*/
- #define **ETH\_DMARDLAR\_SRL** ((uint32\_t)0xFFFFFFFF) /\* Start of receive list \*/
- #define **ETH\_DMATDLAR\_STL** ((uint32\_t)0xFFFFFFFF) /\* Start of transmit list \*/
- #define **ETH\_DMASR\_TSTS** ((uint32\_t)0x20000000) /\* Time-stamp trigger status \*/
- #define **ETH\_DMASR\_PMTS** ((uint32\_t)0x10000000) /\* PMT status \*/
- #define **ETH\_DMASR\_MMCS** ((uint32\_t)0x08000000) /\* MMC status \*/
- #define **ETH\_DMASR\_EBS** ((uint32\_t)0x03800000) /\* Error bits status \*/
- #define **ETH\_DMASR\_EBS\_DescAccess** ((uint32\_t)0x02000000) /\* Error bits 0-data buffer, 1-desc. access \*/
- #define **ETH\_DMASR\_EBS\_ReadTransf** ((uint32\_t)0x01000000) /\* Error bits 0-write trnsf, 1-read transfr \*/
- #define **ETH\_DMASR\_EBS\_DataTransfTx** ((uint32\_t)0x00800000) /\* Error bits 0-Rx DMA, 1-Tx DMA \*/
- #define **ETH\_DMASR\_TPS** ((uint32\_t)0x00700000) /\* Transmit process state \*/
- #define **ETH\_DMASR\_TPS\_Stopped** ((uint32\_t)0x00000000) /\* Stopped - Reset or Stop Tx Command issued \*/
- #define **ETH\_DMASR\_TPS\_Fetching** ((uint32\_t)0x00100000) /\* Running - fetching the Tx descriptor \*/
- #define **ETH\_DMASR\_TPS\_Waiting** ((uint32\_t)0x00200000) /\* Running - waiting for status \*/
- #define **ETH\_DMASR\_TPS\_Reading** ((uint32\_t)0x00300000) /\* Running - reading the data from host memory \*/
- #define **ETH\_DMASR\_TPS\_Suspended** ((uint32\_t)0x00600000) /\* Suspended - Tx Descriptor unavailable \*/
- #define **ETH\_DMASR\_TPS\_Closing** ((uint32\_t)0x00700000) /\* Running - closing Rx descriptor \*/
- #define **ETH\_DMASR\_RPS** ((uint32\_t)0x000E0000) /\* Receive process state \*/
- #define **ETH\_DMASR\_RPS\_Stopped** ((uint32\_t)0x00000000) /\* Stopped - Reset or Stop Rx Command issued \*/
- #define **ETH\_DMASR\_RPS\_Fetching** ((uint32\_t)0x00020000) /\* Running - fetching the Rx descriptor \*/
- #define **ETH\_DMASR\_RPS\_Waiting** ((uint32\_t)0x00060000) /\* Running - waiting for packet \*/
- #define **ETH\_DMASR\_RPS\_Suspended** ((uint32\_t)0x00080000) /\* Suspended - Rx Descriptor unavailable \*/
- #define **ETH\_DMASR\_RPS\_Closing** ((uint32\_t)0x000A0000) /\* Running - closing descriptor \*/
- #define **ETH\_DMASR\_RPS\_Queueing** ((uint32\_t)0x000E0000) /\* Running - queuing the receive frame into host memory \*/
- #define **ETH\_DMASR\_NIS** ((uint32\_t)0x00010000) /\* Normal interrupt summary \*/
- #define **ETH\_DMASR\_AIS** ((uint32\_t)0x00008000) /\* Abnormal interrupt summary \*/
- #define **ETH\_DMASR\_ERS** ((uint32\_t)0x00004000) /\* Early receive status \*/
- #define **ETH\_DMASR\_FBES** ((uint32\_t)0x00002000) /\* Fatal bus error status \*/
- #define **ETH\_DMASR\_ETS** ((uint32\_t)0x00000400) /\* Early transmit status \*/
- #define **ETH\_DMASR\_RWTS** ((uint32\_t)0x00000200) /\* Receive watchdog timeout status \*/
- #define **ETH\_DMASR\_RPSS** ((uint32\_t)0x00000100) /\* Receive process stopped status \*/
- #define **ETH\_DMASR\_RBUS** ((uint32\_t)0x00000080) /\* Receive buffer unavailable status \*/
- #define **ETH\_DMASR\_RS** ((uint32\_t)0x00000040) /\* Receive status \*/
- #define **ETH\_DMASR\_TUS** ((uint32\_t)0x00000020) /\* Transmit underflow status \*/
- #define **ETH\_DMASR\_ROS** ((uint32\_t)0x00000010) /\* Receive overflow status \*/
- #define **ETH\_DMASR\_TJTS** ((uint32\_t)0x00000008) /\* Transmit jabber timeout status \*/
- #define **ETH\_DMASR\_TBUS** ((uint32\_t)0x00000004) /\* Transmit buffer unavailable status \*/
- #define **ETH\_DMASR\_TPSS** ((uint32\_t)0x00000002) /\* Transmit process stopped status \*/
- #define **ETH\_DMASR\_TS** ((uint32\_t)0x00000001) /\* Transmit status \*/
- #define **ETH\_DMAOMR\_DTCEFD** ((uint32\_t)0x04000000) /\* Disable Dropping of TCP/IP checksum error frames \*/

- #define **ETH\_DMAOMR\_RSF** ((uint32\_t)0x02000000) /\* Receive store and forward \*/
- #define **ETH\_DMAOMR\_DFRF** ((uint32\_t)0x01000000) /\* Disable flushing of received frames \*/
- #define **ETH\_DMAOMR\_TSF** ((uint32\_t)0x00200000) /\* Transmit store and forward \*/
- #define **ETH\_DMAOMR\_FTF** ((uint32\_t)0x00100000) /\* Flush transmit FIFO \*/
- #define **ETH\_DMAOMR\_TTC** ((uint32\_t)0x0001C000) /\* Transmit threshold control \*/
- #define **ETH\_DMAOMR\_TTC\_64Bytes** ((uint32\_t)0x00000000) /\* threshold level of the MTL Transmit FIFO is 64 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_128Bytes** ((uint32\_t)0x00004000) /\* threshold level of the MTL Transmit FIFO is 128 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_192Bytes** ((uint32\_t)0x00008000) /\* threshold level of the MTL Transmit FIFO is 192 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_256Bytes** ((uint32\_t)0x0000C000) /\* threshold level of the MTL Transmit FIFO is 256 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_40Bytes** ((uint32\_t)0x00010000) /\* threshold level of the MTL Transmit FIFO is 40 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_32Bytes** ((uint32\_t)0x00014000) /\* threshold level of the MTL Transmit FIFO is 32 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_24Bytes** ((uint32\_t)0x00018000) /\* threshold level of the MTL Transmit FIFO is 24 Bytes \*/
- #define **ETH\_DMAOMR\_TTC\_16Bytes** ((uint32\_t)0x0001C000) /\* threshold level of the MTL Transmit FIFO is 16 Bytes \*/
- #define **ETH\_DMAOMR\_ST** ((uint32\_t)0x00002000) /\* Start/stop transmission command \*/
- #define **ETH\_DMAOMR\_FEF** ((uint32\_t)0x00000080) /\* Forward error frames \*/
- #define **ETH\_DMAOMR\_FUGF** ((uint32\_t)0x00000040) /\* Forward undersized good frames \*/
- #define **ETH\_DMAOMR\_RTC** ((uint32\_t)0x00000018) /\* receive threshold control \*/
- #define **ETH\_DMAOMR\_RTC\_64Bytes** ((uint32\_t)0x00000000) /\* threshold level of the MTL Receive FIFO is 64 Bytes \*/
- #define **ETH\_DMAOMR\_RTC\_32Bytes** ((uint32\_t)0x00000008) /\* threshold level of the MTL Receive FIFO is 32 Bytes \*/
- #define **ETH\_DMAOMR\_RTC\_96Bytes** ((uint32\_t)0x00000010) /\* threshold level of the MTL Receive FIFO is 96 Bytes \*/
- #define **ETH\_DMAOMR\_RTC\_128Bytes** ((uint32\_t)0x00000018) /\* threshold level of the MTL Receive FIFO is 128 Bytes \*/
- #define **ETH\_DMAOMR\_OSF** ((uint32\_t)0x00000004) /\* operate on second frame \*/
- #define **ETH\_DMAOMR\_SR** ((uint32\_t)0x00000002) /\* Start/stop receive \*/
- #define **ETH\_DMAIER\_NISE** ((uint32\_t)0x00010000) /\* Normal interrupt summary enable \*/
- #define **ETH\_DMAIER\_AISE** ((uint32\_t)0x00008000) /\* Abnormal interrupt summary enable \*/
- #define **ETH\_DMAIER\_ERIE** ((uint32\_t)0x00004000) /\* Early receive interrupt enable \*/
- #define **ETH\_DMAIER\_FBEIE** ((uint32\_t)0x00002000) /\* Fatal bus error interrupt enable \*/
- #define **ETH\_DMAIER\_ETIE** ((uint32\_t)0x00000400) /\* Early transmit interrupt enable \*/
- #define **ETH\_DMAIER\_RWTIE** ((uint32\_t)0x00000200) /\* Receive watchdog timeout interrupt enable \*/
- #define **ETH\_DMAIER\_RPSIE** ((uint32\_t)0x00000100) /\* Receive process stopped interrupt enable \*/
- #define **ETH\_DMAIER\_RBUIE** ((uint32\_t)0x00000080) /\* Receive buffer unavailable interrupt enable \*/
- #define **ETH\_DMAIER\_RIE** ((uint32\_t)0x00000040) /\* Receive interrupt enable \*/
- #define **ETH\_DMAIER\_TUIE** ((uint32\_t)0x00000020) /\* Transmit Underflow interrupt enable \*/
- #define **ETH\_DMAIER\_ROIE** ((uint32\_t)0x00000010) /\* Receive Overflow interrupt enable \*/
- #define **ETH\_DMAIER\_TJTIE** ((uint32\_t)0x00000008) /\* Transmit jabber timeout interrupt enable \*/
- #define **ETH\_DMAIER\_TBUIE** ((uint32\_t)0x00000004) /\* Transmit buffer unavailable interrupt enable \*/
- #define **ETH\_DMAIER\_TPSIE** ((uint32\_t)0x00000002) /\* Transmit process stopped interrupt enable \*/
- #define **ETH\_DMAIER\_TIE** ((uint32\_t)0x00000001) /\* Transmit interrupt enable \*/
- #define **ETH\_DMAMFBOCR\_OFOC** ((uint32\_t)0x10000000) /\* Overflow bit for FIFO overflow counter \*/
- #define **ETH\_DMAMFBOCR\_MFA** ((uint32\_t)0x0FFE0000) /\* Number of frames missed by the application \*/
- #define **ETH\_DMAMFBOCR\_OMFC** ((uint32\_t)0x00010000) /\* Overflow bit for missed frame counter \*/
- #define **ETH\_DMAMFBOCR\_MFC** ((uint32\_t)0x0000FFFF) /\* Number of frames missed by the controller \*/

- #define **ETH\_DMACHTDR\_HTDAP** ((uint32\_t)0xFFFFFFFF) /\* Host transmit descriptor address pointer \*/
- #define **ETH\_DMACHRDR\_HRDAP** ((uint32\_t)0xFFFFFFFF) /\* Host receive descriptor address pointer \*/
- #define **ETH\_DMACHTBAR\_HTBAP** ((uint32\_t)0xFFFFFFFF) /\* Host transmit buffer address pointer \*/
- #define **ETH\_DMACHRBAR\_HRBAP** ((uint32\_t)0xFFFFFFFF) /\* Host receive buffer address pointer \*/
- #define **SET\_BIT**(REG, BIT) ((REG) |= (BIT))
- #define **CLEAR\_BIT**(REG, BIT) ((REG) &= ~ (BIT))
- #define **READ\_BIT**(REG, BIT) ((REG) & (BIT))
- #define **CLEAR\_REG**(REG) ((REG) = (0x0))
- #define **WRITE\_REG**(REG, VAL) ((REG) = (VAL))
- #define **READ\_REG**(REG) ((REG))
- #define **MODIFY\_REG**(REG, CLEARMASK, SETMASK) **WRITE\_REG**((REG), (((**READ\_REG**(REG)) & (~(CLEARMASK))) | (SETMASK)))

## Typedefs

- typedef enum **IRQn IRQn\_Type**  
*STM32F4XX Interrupt Number Definition, according to the selected device in [Library configuration section](#).*
- typedef int32\_t **s32**
- typedef int16\_t **s16**
- typedef int8\_t **s8**
- typedef const int32\_t **sc32**
- typedef const int16\_t **sc16**
- typedef const int8\_t **sc8**
- typedef **\_IO** int32\_t **vs32**
- typedef **\_IO** int16\_t **vs16**
- typedef **\_IO** int8\_t **vs8**
- typedef **\_I** int32\_t **vsc32**
- typedef **\_I** int16\_t **vsc16**
- typedef **\_I** int8\_t **vsc8**
- typedef uint32\_t **u32**
- typedef uint16\_t **u16**
- typedef uint8\_t **u8**
- typedef const uint32\_t **uc32**
- typedef const uint16\_t **uc16**
- typedef const uint8\_t **uc8**
- typedef **\_IO** uint32\_t **vu32**
- typedef **\_IO** uint16\_t **vu16**
- typedef **\_IO** uint8\_t **vu8**
- typedef **\_I** uint32\_t **vuc32**
- typedef **\_I** uint16\_t **vuc16**
- typedef **\_I** uint8\_t **vuc8**
- typedef enum **FlagStatus ITStatus**

## Enumerations

- enum **IRQn** {
 **NonMaskableInt\_IRQn** = -14 , **MemoryManagement\_IRQn** = -12 , **BusFault\_IRQn** = -11 , **UsageFault\_IRQn** = -10 ,
 **SVCall\_IRQn** = -5 , **DebugMonitor\_IRQn** = -4 , **PendSV\_IRQn** = -2 , **SysTick\_IRQn** = -1 ,
 **WWDG\_IRQn** = 0 , **PVD\_IRQn** = 1 , **TAMP\_STAMP\_IRQn** = 2 , **RTC\_WKUP\_IRQn** = 3 ,
 **FLASH\_IRQn** = 4 , **RCC\_IRQn** = 5 , **EXTI0\_IRQn** = 6 , **EXTI1\_IRQn** = 7 ,
 **EXTI2\_IRQn** = 8 , **EXTI3\_IRQn** = 9 , **EXTI4\_IRQn** = 10 , **DMA1\_Stream0\_IRQn** = 11 ,
 **DMA1\_Stream1\_IRQn** = 12 , **DMA1\_Stream2\_IRQn** = 13 , **DMA1\_Stream3\_IRQn** = 14 , **DMA1\_Stream4\_IRQn**

```
= 15 ,
DMA1_Stream5_IRQn = 16 , DMA1_Stream6_IRQn = 17 , ADC_IRQn = 18 , EXTI9_5_IRQn = 23 ,
TIM1_BRK_TIM9_IRQn = 24 , TIM1_UP_TIM10_IRQn = 25 , TIM1_TRG_COM_TIM11_IRQn = 26 ,
TIM1_CC_IRQn = 27 ,
TIM2_IRQn = 28 , TIM3_IRQn = 29 , TIM4_IRQn = 30 , I2C1_EV_IRQn = 31 ,
I2C1_ER_IRQn = 32 , I2C2_EV_IRQn = 33 , I2C2_ER_IRQn = 34 , SPI1_IRQn = 35 ,
SPI2_IRQn = 36 , USART1_IRQn = 37 , USART2_IRQn = 38 , EXTI15_10_IRQn = 40 ,
RTC_Alarm_IRQn = 41 , OTG_FS_WKUP_IRQn = 42 , DMA1_Stream7_IRQn = 47 , SDIO_IRQn = 49 ,
TIM5_IRQn = 50 , SPI3_IRQn = 51 , DMA2_Stream0_IRQn = 56 , DMA2_Stream1_IRQn = 57 ,
DMA2_Stream2_IRQn = 58 , DMA2_Stream3_IRQn = 59 , DMA2_Stream4_IRQn = 60 , OTG_FS_IRQn = 67 ,
DMA2_Stream5_IRQn = 68 , DMA2_Stream6_IRQn = 69 , DMA2_Stream7_IRQn = 70 , USART6_IRQn = 71 ,
I2C3_EV_IRQn = 72 , I2C3_ER_IRQn = 73 , FPU_IRQn = 81 , SPI4_IRQn = 84 }
```

*STM32F4XX Interrupt Number Definition, according to the selected device in [Library configuration section](#).*

- enum **FlagStatus** { **RESET** = 0 , **SET** = !**RESET** , **Reset** , **Set** }
- enum **FunctionalState** { **DISABLE** = 0 , **ENABLE** = !**DISABLE** }
- enum **ErrorStatus** { **ERROR** = 0 , **SUCCESS** = !**ERROR** }

### 7.13.1 Detailed Description

CMSIS Cortex-M4 Device Peripheral Access Layer Header File. This file contains all the peripheral register's definitions, bits definitions and memory mapping for STM32F4xx devices.

#### Author

MCD Application Team

#### Version

V1.8.0

#### Date

09-November-2016

The file is the unique include file that the application programmer is using in the C source code, usually in main.c. This file contains:

- Configuration section that allows to select:
  - The device used in the target application
  - To use or not the peripheral's drivers in application code(i.e. code will be based on direct access to peripheral's registers rather than drivers API), this option is controlled by "#define USE\_STDPERIPH\_DRIVER"
  - To change few application-specific parameters such as the HSE crystal frequency
- Data structures and the address mapping for all peripherals
- Peripherals registers declarations and bits definition
- Macros to access peripheral's registers hardware

#### Attention

**© COPYRIGHT 2016 STMicroelectronics**

Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); You may not use this file except in compliance with the License. You may obtain a copy of the License at:

[http://www.st.com/software\\_license\\_agreement\\_liberty\\_v2](http://www.st.com/software_license_agreement_liberty_v2)

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

## 7.14 CMSIS/Inc/system\_stm32f4xx.h File Reference

CMSIS Cortex-M4 Device System Source File for STM32F4xx devices.

This graph shows which files directly or indirectly include this file:



### Functions

- void [SystemInit](#) (void)  
*Setup the microcontroller system Initialize the Embedded Flash Interface, the PLL and update the SystemFrequency variable.*
- void [SystemCoreClockUpdate](#) (void)  
*Update SystemCoreClock variable according to Clock Register Values. The SystemCoreClock variable contains the core clock (HCLK), it can be used by the user application to setup the SysTick timer or configure other parameters.*

### Variables

- uint32\_t [SystemCoreClock](#)

### 7.14.1 Detailed Description

CMSIS Cortex-M4 Device System Source File for STM32F4xx devices.

#### Author

MCD Application Team

#### Version

V1.8.0

#### Date

09-November-2016

#### Attention

© COPYRIGHT 2016 STMicroelectronics

Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); You may not use this file except in compliance with the License. You may obtain a copy of the License at:

[http://www.st.com/software\\_license\\_agreement\\_liberty\\_v2](http://www.st.com/software_license_agreement_liberty_v2)

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

## 7.15 drivers/Inc/Platform\_Types.h File Reference

Defines data types and macros for STM32F401xx microcontrollers.

This graph shows which files directly or indirectly include this file:



## Macros

- `#define CPU_TYPE_8 8`  
*CPU Type Definitions.*
- `#define CPU_TYPE_16 16`
- `#define CPU_TYPE_32 32`
- `#define CPU_TYPE_64 64`
- `#define MSB_FIRST 0`  
*Bit Order Definitions.*
- `#define LSB_FIRST 1`
- `#define HIGH_BYTE_FIRST 0`  
*Byte Order Definitions.*
- `#define LOW_BYTE_FIRST 1`
- `#define CPU_TYPE CPU_TYPE_32`  
*Selected CPU Characteristics.*
- `#define CPU_BIT_ORDER LSB_FIRST`
- `#define CPU_BYTE_ORDER LOW_BYTE_FIRST`
- `#define TRUE 1`  
*Boolean Constants.*
- `#define FALSE 0`
- `#define SET TRUE`
- `#define RESET FALSE`
- `#define FLAG_SET SET`
- `#define FLAG_RESET RESET`

## Typedefs

- `typedef unsigned char boolean`  
*Standard Data Types.*
- `typedef signed char sint8`
- `typedef unsigned char uint8`
- `typedef signed short sint16`
- `typedef unsigned short uint16`
- `typedef signed long sint32`
- `typedef signed long long sint64`
- `typedef unsigned long uint32`
- `typedef unsigned long long uint64`
- `typedef unsigned long uint8_least`  
*Least Type Definitions.*
- `typedef unsigned long uint16_least`
- `typedef unsigned long uint32_least`
- `typedef signed long sint8_least`
- `typedef signed long sint16_least`
- `typedef signed long sint32_least`
- `typedef float float32`  
*Floating-Point Types.*
- `typedef double float64`
- `typedef void * VoidPtr`  
*Pointer Types.*
- `typedef const void * ConstVoidPtr`
- `typedef volatile unsigned char vuint8_t`  
*Volatile Types.*
- `typedef volatile unsigned short vuint16_t`
- `typedef volatile unsigned long vuint32_t`

### 7.15.1 Detailed Description

Defines data types and macros for STM32F401xx microcontrollers.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This header file provides standard data types, CPU-specific types, and macros for use with STM32F401xx series microcontrollers. It includes definitions for CPU bit and byte order, as well as various data type definitions suited for the platform.

#### Note

This file is specifically tailored for the STM32F401xx family. Ensure compatibility with other microcontroller series before use.

#### Copyright

Copyright (c) 2024 Mohamed Ali Haoufa

## 7.16 drivers/Inc/stm32f401xx.h File Reference

Header file containing all the necessary information about the STM32F401xx MCU.

```
#include <stdlib.h>
#include <stdint.h>
#include <stdio.h>
#include "Platform_Types.h"
#include "stm32f401xx_gpio_driver.h"
#include "stm32f401xx_rcc_driver.h"
#include "stm32f401xx_usart_driver.h"
#include "stm32f401xx_i2c_driver.h"
#include "stm32f401xx_spi_driver.h"
#include "stm32f401xx_nvic_driver.h"
#include "stm32f401xx_systick_driver.h"
#include "stm32f401xx_timer_driver.h"
```

Include dependency graph for stm32f401xx.h:



This graph shows which files directly or indirectly include this file:



## Classes

- struct **NVIC\_TypeDef**
  - struct **SCB\_TypeDef**
  - struct **STK\_TypeDef**
  - struct **GPIO\_TypeDef**
    - General Purpose I/O.*
  - struct **RCC\_TypeDef**
    - Reset and Clock Control.*
  - struct **EXTI\_TypeDef**
    - External Interrupt/Event Controller.*
  - struct **SYSCFG\_RegDef\_t**
  - struct **USART\_TypeDef**
    - Universal Synchronous Asynchronous Receiver Transmitter.*
  - struct **SPI\_TypeDef**
    - Serial Peripheral Interface.*
  - struct **I2C\_TypeDef**
    - Inter-integrated Circuit Interface.*
  - struct **CRC\_TypeDef**
    - CRC calculation unit.*
  - struct **TIM1\_TypeDef**

## Macros

- `#define FLASH_MEMORY_BASE 0x08000000UL`  
*Base address of Flash memory.*
  - `#define SYSTEM_MEMORY_BASE 0x1FFFFF000UL`  
*Base address of System memory.*
  - `#define SRAM_MEMORY_BASE 0x20000000UL`  
*Base address of SRAM memory.*
  - `#define PERIPHERALS_BASE 0x40000000UL`  
*Base address of Peripheral registers.*
  - `#define CORTEX_M4_INTERNAL_BASE 0xE0000000UL`  
*Base address of Cortex-M4 internal peripherals.*
  - `#define NVIC_BASE 0xE000E100UL`  
*Base address of NVIC (Nested Vectored Interrupt Controller)*
  - `#define SCB_BASE 0xE000ED00UL`

- #define **STK\_BASE** 0xE000E010UL  
*Base address of System Control Block (SCB)*
- #define **RCC\_BASE** 0x40023800UL  
*Base address of SysTick Timer.*
- #define **CRC\_BASE** 0x40023000UL  
*Base address of RCC (Reset and Clock Control)*
- #define **GPIOA\_BASE** 0x40020000UL  
*Base address of GPIOA (General Purpose I/O port A)*
- #define **GPIOB\_BASE** 0x40020400UL  
*Base address of GPIOB (General Purpose I/O port B)*
- #define **GPIOC\_BASE** 0x40020800UL  
*Base address of GPIOC (General Purpose I/O port C)*
- #define **GPIOD\_BASE** 0x40020C00UL  
*Base address of GPIOD (General Purpose I/O port D)*
- #define **GPIOE\_BASE** 0x40021000UL  
*Base address of GPIOE (General Purpose I/O port E)*
- #define **EXTI\_BASE** 0x40013C00UL  
*Base address of EXTI (External Interrupt/Event Controller)*
- #define **TIM1\_BASE** 0x40010000UL  
*Base address of TIM1 (Timer 1)*
- #define **TIM2\_BASE** 0x40000000UL  
*Base address of TIM2 (Timer 2)*
- #define **USART1\_BASE** 0x40011000UL  
*Base address of USART1 (Universal Synchronous/Asynchronous Receiver Transmitter 1)*
- #define **USART6\_BASE** 0x40011400UL  
*Base address of USART6 (Universal Synchronous/Asynchronous Receiver Transmitter 6)*
- #define **SPI1\_BASE** 0x40013000UL  
*Base address of SPI1 (Serial Peripheral Interface 1)*
- #define **SYSCFG\_BASE** 0x40013800UL  
*Base address of SYSCFG (System Configuration Controller)*
- #define **USART2\_BASE** 0x40004400UL  
*Base address of USART2 (Universal Synchronous/Asynchronous Receiver Transmitter 2)*
- #define **SPI2\_BASE** 0x40003800UL  
*Base address of SPI2 (Serial Peripheral Interface 2)*
- #define **I2C1\_BASE** 0x40005400UL  
*Base address of I2C1 (Inter-Integrated Circuit 1)*
- #define **I2C2\_BASE** 0x40005800UL  
*Base address of I2C2 (Inter-Integrated Circuit 2)*
- #define **NVIC ((NVIC\_TypeDef\*)NVIC\_BASE)**
- #define **SCB ((SCB\_TypeDef\*)SCB\_BASE)**
- #define **STK ((STK\_TypeDef\*)STK\_BASE)**
- #define **GPIOA ((GPIO\_TypeDef\*)GPIOA\_BASE)**
- #define **GPIOB ((GPIO\_TypeDef\*)GPIOB\_BASE)**
- #define **GPIOC ((GPIO\_TypeDef\*)GPIOC\_BASE)**
- #define **GPIOD ((GPIO\_TypeDef\*)GPIOD\_BASE)**
- #define **GPIOE ((GPIO\_TypeDef\*)GPIOE\_BASE)**
- #define **RCC ((RCC\_TypeDef\*)RCC\_BASE)**
- #define **EXTI ((EXTI\_TypeDef\*)EXTI\_BASE)**
- #define **SYSCFG ((SYSCFG\_RegDef\_t\*)SYSCFG\_BASE)**
- #define **TIM1 ((TIM1\_TypeDef\*)TIM1\_BASE)**
- #define **TIM2 ((TIM1\_TypeDef\*)TIM2\_BASE)**

- #define USART1 ((USART\_TypeDef\*)USART1\_BASE)
- #define USART2 ((USART\_TypeDef\*)USART2\_BASE)
- #define USART6 ((USART\_TypeDef\*)USART6\_BASE)
- #define SPI1 ((SPI\_TypeDef\*)SPI1\_BASE)
- #define SPI2 ((SPI\_TypeDef\*)SPI2\_BASE)
- #define I2C1 ((I2C\_TypeDef\*)I2C1\_BASE)
- #define I2C2 ((I2C\_TypeDef\*)I2C2\_BASE)
- #define CRC ((CRC\_TypeDef\*)CRC\_BASE)
- #define I2C\_CR1\_PE\_Pos (0U)

*Position and mask for the Peripheral Enable bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_PE\_Msk (0x1UL << I2C\_CR1\_PE\_Pos)
- #define I2C\_CR1\_PE I2C\_CR1\_PE\_Msk
- #define I2C\_CR1\_SMBUS\_Pos (1U)

*Position and mask for the SMBus Mode bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_SMBUS\_Msk (0x1UL << I2C\_CR1\_SMBUS\_Pos)
- #define I2C\_CR1\_SMBUS I2C\_CR1\_SMBUS\_Msk
- #define I2C\_CR1\_SMBTYPE\_Pos (3U)

*Position and mask for the SMBus Type bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_SMBTYPE\_Msk (0x1UL << I2C\_CR1\_SMBTYPE\_Pos)
- #define I2C\_CR1\_SMBTYPE I2C\_CR1\_SMBTYPE\_Msk
- #define I2C\_CR1\_ENARP\_Pos (4U)

*Position and mask for the ARP Enable bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_ENARP\_Msk (0x1UL << I2C\_CR1\_ENARP\_Pos)
- #define I2C\_CR1\_ENARP I2C\_CR1\_ENARP\_Msk
- #define I2C\_CR1\_ENPEC\_Pos (5U)

*Position and mask for the PEC Enable bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_ENPEC\_Msk (0x1UL << I2C\_CR1\_ENPEC\_Pos)
- #define I2C\_CR1\_ENPEC I2C\_CR1\_ENPEC\_Msk
- #define I2C\_CR1\_ENGC\_Pos (6U)

*Position and mask for the General Call Enable bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_ENGC\_Msk (0x1UL << I2C\_CR1\_ENGC\_Pos)
- #define I2C\_CR1\_ENGC I2C\_CR1\_ENGC\_Msk
- #define I2C\_CR1\_NOSTRETCH\_Pos (7U)

*Position and mask for the Clock Stretching Disable bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_NOSTRETCH\_Msk (0x1UL << I2C\_CR1\_NOSTRETCH\_Pos)
- #define I2C\_CR1\_NOSTRETCH I2C\_CR1\_NOSTRETCH\_Msk
- #define I2C\_CR1\_START\_Pos (8U)

*Position and mask for the Start Generation bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_START\_Msk (0x1UL << I2C\_CR1\_START\_Pos)
- #define I2C\_CR1\_START I2C\_CR1\_START\_Msk
- #define I2C\_CR1\_STOP\_Pos (9U)

*Position and mask for the Stop Generation bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_STOP\_Msk (0x1UL << I2C\_CR1\_STOP\_Pos)
- #define I2C\_CR1\_STOP I2C\_CR1\_STOP\_Msk
- #define I2C\_CR1\_ACK\_Pos (10U)

*Position and mask for the Acknowledge Enable bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_ACK\_Msk (0x1UL << I2C\_CR1\_ACK\_Pos)
- #define I2C\_CR1\_ACK I2C\_CR1\_ACK\_Msk
- #define I2C\_CR1\_POS\_Pos (11U)

*Position and mask for the Acknowledge/PEC Position bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_POS\_Msk (0x1UL << I2C\_CR1\_POS\_Pos)
- #define I2C\_CR1\_POS I2C\_CR1\_POS\_Msk
- #define I2C\_CR1\_PEC\_Pos (12U)

*Position and mask for the Packet Error Checking bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_PEC\_Msk (0x1UL << I2C\_CR1\_PEC\_Pos)
- #define I2C\_CR1\_PEC I2C\_CR1\_PEC\_Msk
- #define I2C\_CR1\_ALERT\_Pos (13U)

*Position and mask for the SMBus Alert bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_ALERT\_Msk (0x1UL << I2C\_CR1\_ALERT\_Pos)
- #define I2C\_CR1\_ALERT I2C\_CR1\_ALERT\_Msk
- #define I2C\_CR1\_SWRST\_Pos (15U)

*Position and mask for the Software Reset bit in the I2C\_CR1 register.*

- #define I2C\_CR1\_SWRST\_Msk (0x1UL << I2C\_CR1\_SWRST\_Pos)
- #define I2C\_CR1\_SWRST I2C\_CR1\_SWRST\_Msk
- #define I2C\_CR2\_FREQ\_Pos (0U)

*Position and mask for the Peripheral Clock Frequency bits in the I2C\_CR2 register.*

- #define I2C\_CR2\_FREQ\_Msk (0x3FUL << I2C\_CR2\_FREQ\_Pos)
- #define I2C\_CR2\_FREQ I2C\_CR2\_FREQ\_Msk
- #define I2C\_CR2\_ITERREN\_Pos (8U)

*Position and mask for the Error Interrupt Enable bit in the I2C\_CR2 register.*

- #define I2C\_CR2\_ITERREN\_Msk (0x1UL << I2C\_CR2\_ITERREN\_Pos)
- #define I2C\_CR2\_ITERREN I2C\_CR2\_ITERREN\_Msk
- #define I2C\_CR2\_IteVTEN\_Pos (9U)

*Position and mask for the Event Interrupt Enable bit in the I2C\_CR2 register.*

- #define I2C\_CR2\_IteVTEN\_Msk (0x1UL << I2C\_CR2\_IteVTEN\_Pos)
- #define I2C\_CR2\_IteVTEN I2C\_CR2\_IteVTEN\_Msk
- #define I2C\_CR2\_ITBUFEN\_Pos (10U)

*Position and mask for the Buffer Interrupt Enable bit in the I2C\_CR2 register.*

- #define I2C\_CR2\_ITBUFEN\_Msk (0x1UL << I2C\_CR2\_ITBUFEN\_Pos)
- #define I2C\_CR2\_ITBUFEN I2C\_CR2\_ITBUFEN\_Msk
- #define I2C\_CR2\_DMAEN\_Pos (11U)

*Position and mask for the DMA Requests Enable bit in the I2C\_CR2 register.*

- #define I2C\_CR2\_DMAEN\_Msk (0x1UL << I2C\_CR2\_DMAEN\_Pos)
- #define I2C\_CR2\_DMAEN I2C\_CR2\_DMAEN\_Msk
- #define I2C\_CR2\_LAST\_Pos (12U)

*Position and mask for the Last DMA Transfer bit in the I2C\_CR2 register.*

- #define I2C\_CR2\_LAST\_Msk (0x1UL << I2C\_CR2\_LAST\_Pos)
- #define I2C\_CR2\_LAST I2C\_CR2\_LAST\_Msk
- #define I2C\_OAR2\_ENDUAL\_Pos (0U)

*Bit definitions for the I2C\_OAR2 register.*

- #define I2C\_OAR2\_ENDUAL\_Msk (0x1UL << I2C\_OAR2\_ENDUAL\_Pos)
- #define I2C\_OAR2\_ENDUAL I2C\_OAR2\_ENDUAL\_Msk
- #define I2C\_OAR2\_ADD2\_Pos (1U)
- #define I2C\_OAR2\_ADD2\_Msk (0x1UL << I2C\_OAR2\_ADD2\_Pos)
- #define I2C\_OAR2\_ADD2 I2C\_OAR2\_ADD2\_Msk
- #define I2C\_SR1\_SB\_Pos (0U)

*Bit definitions for the I2C\_SR1 register.*

- #define I2C\_SR1\_SB\_Msk (0x1UL << I2C\_SR1\_SB\_Pos)
- #define I2C\_SR1\_SB I2C\_SR1\_SB\_Msk
- #define I2C\_SR1\_ADDR\_Pos (1U)
- #define I2C\_SR1\_ADDR\_Msk (0x1UL << I2C\_SR1\_ADDR\_Pos)
- #define I2C\_SR1\_ADDR I2C\_SR1\_ADDR\_Msk
- #define I2C\_SR1\_BTF\_Pos (2U)
- #define I2C\_SR1\_BTF\_Msk (0x1UL << I2C\_SR1\_BTF\_Pos)
- #define I2C\_SR1\_BTF I2C\_SR1\_BTF\_Msk
- #define I2C\_SR1\_ADD10\_Pos (3U)

- #define I2C\_SR1\_ADD10\_Msk (0x1UL << I2C\_SR1\_ADD10\_Pos)
- #define I2C\_SR1\_ADD10 I2C\_SR1\_ADD10\_Msk
- #define I2C\_SR1\_STOPF\_Pos (4U)
- #define I2C\_SR1\_STOPF\_Msk (0x1UL << I2C\_SR1\_STOPF\_Pos)
- #define I2C\_SR1\_STOPF I2C\_SR1\_STOPF\_Msk
- #define I2C\_SR1\_RXNE\_Pos (6U)
- #define I2C\_SR1\_RXNE\_Msk (0x1UL << I2C\_SR1\_RXNE\_Pos)
- #define I2C\_SR1\_RXNE I2C\_SR1\_RXNE\_Msk
- #define I2C\_SR1\_TXE\_Pos (7U)
- #define I2C\_SR1\_TXE\_Msk (0x1UL << I2C\_SR1\_TXE\_Pos)
- #define I2C\_SR1\_TXE I2C\_SR1\_TXE\_Msk
- #define I2C\_SR1\_BERR\_Pos (8U)
- #define I2C\_SR1\_BERR\_Msk (0x1UL << I2C\_SR1\_BERR\_Pos)
- #define I2C\_SR1\_BERR I2C\_SR1\_BERR\_Msk
- #define I2C\_SR1\_ARLO\_Pos (9U)
- #define I2C\_SR1\_ARLO\_Msk (0x1UL << I2C\_SR1\_ARLO\_Pos)
- #define I2C\_SR1\_ARLO I2C\_SR1\_ARLO\_Msk
- #define I2C\_SR1\_AF\_Pos (10U)
- #define I2C\_SR1\_AF\_Msk (0x1UL << I2C\_SR1\_AF\_Pos)
- #define I2C\_SR1\_AF I2C\_SR1\_AF\_Msk
- #define I2C\_SR1\_OVR\_Pos (11U)
- #define I2C\_SR1\_OVR\_Msk (0x1UL << I2C\_SR1\_OVR\_Pos)
- #define I2C\_SR1\_OVR I2C\_SR1\_OVR\_Msk
- #define I2C\_SR1\_PECERR\_Pos (12U)
- #define I2C\_SR1\_PECERR\_Msk (0x1UL << I2C\_SR1\_PECERR\_Pos)
- #define I2C\_SR1\_PECERR I2C\_SR1\_PECERR\_Msk
- #define I2C\_SR1\_TIMEOUT\_Pos (14U)
- #define I2C\_SR1\_TIMEOUT\_Msk (0x1UL << I2C\_SR1\_TIMEOUT\_Pos)
- #define I2C\_SR1\_TIMEOUT I2C\_SR1\_TIMEOUT\_Msk
- #define I2C\_SR1\_SMBALERT\_Pos (15U)
- #define I2C\_SR1\_SMBALERT\_Msk (0x1UL << I2C\_SR1\_SMBALERT\_Pos)
- #define I2C\_SR1\_SMBALERT I2C\_SR1\_SMBALERT\_Msk
- #define I2C\_SR2\_MSL\_Pos (0U)

*Bit definitions for the I2C\_SR2 register.*

- #define I2C\_SR2\_MSL\_Msk (0x1UL << I2C\_SR2\_MSL\_Pos)
- #define I2C\_SR2\_MSL I2C\_SR2\_MSL\_Msk
- #define I2C\_SR2\_BUSY\_Pos (1U)
- #define I2C\_SR2\_BUSY\_Msk (0x1UL << I2C\_SR2\_BUSY\_Pos)
- #define I2C\_SR2\_BUSY I2C\_SR2\_BUSY\_Msk
- #define I2C\_SR2\_TRA\_Pos (2U)
- #define I2C\_SR2\_TRA\_Msk (0x1UL << I2C\_SR2\_TRA\_Pos)
- #define I2C\_SR2\_TRA I2C\_SR2\_TRA\_Msk
- #define I2C\_SR2\_GENCALL\_Pos (4U)
- #define I2C\_SR2\_GENCALL\_Msk (0x1UL << I2C\_SR2\_GENCALL\_Pos)
- #define I2C\_SR2\_GENCALL I2C\_SR2\_GENCALL\_Msk
- #define I2C\_SR2\_SMBDEFAULT\_Pos (5U)
- #define I2C\_SR2\_SMBDEFAULT\_Msk (0x1UL << I2C\_SR2\_SMBDEFAULT\_Pos)
- #define I2C\_SR2\_SMBDEFAULT I2C\_SR2\_SMBDEFAULT\_Msk
- #define I2C\_SR2\_SMBHOST\_Pos (6U)
- #define I2C\_SR2\_SMBHOST\_Msk (0x1UL << I2C\_SR2\_SMBHOST\_Pos)
- #define I2C\_SR2\_SMBHOST I2C\_SR2\_SMBHOST\_Msk
- #define I2C\_SR2\_DUALF\_Pos (7U)
- #define I2C\_SR2\_DUALF\_Msk (0x1UL << I2C\_SR2\_DUALF\_Pos)
- #define I2C\_SR2\_DUALF I2C\_SR2\_DUALF\_Msk

- #define I2C\_SR2\_PEC\_Pos (8U)
- #define I2C\_SR2\_PEC\_Msk (0xFFUL << I2C\_SR2\_PEC\_Pos)
- #define I2C\_SR2\_PEC I2C\_SR2\_PEC\_Msk
- #define I2C\_CCR\_CCR\_Pos (0U)  
*Bit definitions for the I2C\_CCR register.*
- #define I2C\_CCR\_CCR\_Msk (0xFFFFUL << I2C\_CCR\_CCR\_Pos)
- #define I2C\_CCR\_CCR\_I2C\_CCR\_CCR\_Msk
- #define I2C\_CCR\_DUTY\_Pos (14U)
- #define I2C\_CCR\_DUTY\_Msk (0x1UL << I2C\_CCR\_DUTY\_Pos)
- #define I2C\_CCR\_DUTY\_I2C\_CCR\_DUTY\_Msk
- #define I2C\_TRISE\_TRISE\_Pos (0U)  
*Bit definitions for the I2C\_TRISE register.*
- #define I2C\_TRISE\_TRISE\_Msk (0x3FUL << I2C\_TRISE\_TRISE\_Pos)
- #define I2C\_TRISE\_TRISE\_I2C\_TRISE\_TRISE\_Msk
- #define RCC\_CR\_HSION 0
- #define RCC\_CR\_HSIRDY 1
- #define RCC\_CR\_HSITRIM 3
- #define RCC\_CR\_HSICAL 8
- #define RCC\_CR\_HSEON 16
- #define RCC\_CR\_HSERDY 17
- #define RCC\_CR\_HSEBYP 18
- #define RCC\_CR\_CSSON 19
- #define RCC\_CR\_PLLON 24
- #define RCC\_CR\_PLLRDY 25
- #define RCC\_CR\_PLLI2SON 26
- #define RCC\_CR\_PLLI2SRDY 27
- #define RCC\_CR\_PLLSAION 28
- #define RCC\_CR\_PLLSAIRDY 29
- #define RCC\_PLLCFG\_R\_PLLM 0
- #define RCC\_PLLCFG\_R\_PLLN 6
- #define RCC\_PLLCFG\_R\_PLLP 16
- #define RCC\_PLLCFG\_R\_PLLSRC 22
- #define RCC\_PLLCFG\_R\_PLLQ 24
- #define RCC\_CFGR\_SW 0
- #define RCC\_CFGR\_SWS 2
- #define RCC\_CFGR\_HPREF 4
- #define RCC\_CFGR\_PPREF1 10
- #define RCC\_CFGR\_PPREF2 13
- #define RCC\_CFGR\_RTCPPREF 16
- #define RCC\_CFGR\_MCO1 21
- #define RCC\_CFGR\_I2SSRC 23
- #define RCC\_CFGR\_MCO1PPREF 24
- #define RCC\_CFGR\_MCO2PPREF 27
- #define RCC\_CFGR\_MCO2 30
- #define RCC\_CIR\_LSIRDYF 0
- #define RCC\_CIR\_LSERDYF 1
- #define RCC\_CIR\_HSIRDYF 2
- #define RCC\_CIR\_HSERDYF 3
- #define RCC\_CIR\_PLLRDYF 4
- #define RCC\_CIR\_PLLI2SRDYF 5
- #define RCC\_CIR\_PLLSAIRDYF 6
- #define RCC\_CIR\_CSSF 7
- #define RCC\_CIR\_LSIRDYIE 8
- #define RCC\_CIR\_LSERDYIE 9

- #define RCC\_CIR\_HSIRDYIE 10
- #define RCC\_CIR\_HSERDYIE 11
- #define RCC\_CIR\_PLLRDYIE 12
- #define RCC\_CIR\_PLLI2SRDYIE 13
- #define RCC\_CIR\_PLLSAIRDYIE 14
- #define RCC\_CIR\_LSIRDYC 16
- #define RCC\_CIR\_LSERDYC 17
- #define RCC\_CIR\_HSIRDYC 18
- #define RCC\_CIR\_HSERDYC 19
- #define RCC\_CIR\_PLLRDYC 20
- #define RCC\_CIR\_PLLI2SRDYC 21
- #define RCC\_CIR\_PLLSAIRDYC 22
- #define RCC\_AHB1RSTR\_GPIOA 0
- #define RCC\_AHB1RSTR\_GPIOB 1
- #define RCC\_AHB1RSTR\_GPIOC 2
- #define RCC\_AHB1RSTR\_GPIOD 3
- #define RCC\_AHB1RSTR\_GPIOE 4
- #define RCC\_AHB1RSTR\_GPIOF 5
- #define RCC\_AHB1RSTR\_GPIOG 6
- #define RCC\_AHB1RSTR\_GPIOH 7
- #define RCC\_AHB1RSTR\_GPIOI 8
- #define RCC\_AHB1RSTR\_CRC 12
- #define RCC\_AHB1RSTR\_DMA1 21
- #define RCC\_AHB1RSTR\_DMA2 22
- #define RCC\_AHB1RSTR\_ETHMAC 25
- #define RCC\_AHB1RSTR\_OTGHS 29
- #define RCC\_AHB1RSTR\_OTGHSULPI 30
- #define RCC\_AHB2RSTR\_DCMI 0
- #define RCC\_AHB2RSTR\_CRYP 4
- #define RCC\_AHB2RSTR\_HASH 5
- #define RCC\_AHB2RSTR\_RNG 6
- #define RCC\_AHB2RSTR\_OTGFS 7
- #define RCC\_AHB3RSTR\_FSMC 0
- #define RCC\_APB1RSTR\_TIM2 0
- #define RCC\_APB1RSTR\_TIM3 1
- #define RCC\_APB1RSTR\_TIM4 2
- #define RCC\_APB1RSTR\_TIM5 3
- #define RCC\_APB1RSTR\_TIM6 4
- #define RCC\_APB1RSTR\_TIM7 5
- #define RCC\_APB1RSTR\_TIM12 6
- #define RCC\_APB1RSTR\_TIM13 7
- #define RCC\_APB1RSTR\_TIM14 8
- #define RCC\_APB1RSTR\_WWDG 11
- #define RCC\_APB1RSTR\_SPI2 14
- #define RCC\_APB1RSTR\_SPI3 15
- #define RCC\_APB1RSTR\_USART2 17
- #define RCC\_APB1RSTR\_USART3 18
- #define RCC\_APB1RSTR\_UART4 19
- #define RCC\_APB1RSTR\_UART5 20
- #define RCC\_APB1RSTR\_I2C1 21
- #define RCC\_APB1RSTR\_I2C2 22
- #define RCC\_APB1RSTR\_I2C3 23
- #define RCC\_APB1RSTR\_CAN1 25
- #define RCC\_APB1RSTR\_CAN2 26
- #define RCC\_APB1RSTR\_PWR 28

- #define RCC\_APB1RSTR\_DAC 29
- #define RCC\_APB1RSTR\_UART7 30
- #define RCC\_APB1RSTR\_UART8 31
- #define RCC\_APB2RSTR\_TIM1 0
- #define RCC\_APB2RSTR\_TIM8 1
- #define RCC\_APB2RSTR\_USART1 4
- #define RCC\_APB2RSTR\_USART6 5
- #define RCC\_APB2RSTR\_ADC 8
- #define RCC\_APB2RSTR\_SDIO 11
- #define RCC\_APB2RSTR\_SPI1 12
- #define RCC\_APB2RSTR\_SYSCFG 14
- #define RCC\_APB2RSTR\_TIM9 16
- #define RCC\_APB2RSTR\_TIM10 17
- #define RCC\_APB2RSTR\_TIM11 18
- #define RCC\_AHB1LPENR\_GPIOALPEN 0
- #define RCC\_AHB1LPENR\_GPIOBLPEN 1
- #define RCC\_AHB1LPENR\_GPIOCLPEN 2
- #define RCC\_AHB1LPENR\_GPIODLPEN 3
- #define RCC\_AHB1LPENR\_GPIOELPEN 4
- #define RCC\_AHB1LPENR\_GPIOFLPEN 5
- #define RCC\_AHB1LPENR\_GPIOGLPEN 6
- #define RCC\_AHB1LPENR\_GPIOHLPEN 7
- #define RCC\_AHB1LPENR\_GPIOILPEN 8
- #define RCC\_AHB1LPENR\_CRCEN 12
- #define RCC\_AHB1LPENR\_DMA1LPEN 21
- #define RCC\_AHB1LPENR\_DMA2LPEN 22
- #define RCC\_AHB1LPENR\_ETHMACLPEN 25
- #define RCC\_AHB1LPENR\_ETHMACTXLPEN 26
- #define RCC\_AHB1LPENR\_ETHMACRXLPEN 27
- #define RCC\_AHB1LPENR\_ETHMACPTPLPEN 28
- #define RCC\_AHB1LPENR\_OTGHSLPEN 29
- #define RCC\_AHB1LPENR\_OTGHSHULPI 30
- #define RCC\_AHB2LPENR\_DCMILPEN 0
- #define RCC\_AHB2LPENR\_CRYPLPEN 4
- #define RCC\_AHB2LPENR\_HASHLPEN 5
- #define RCC\_AHB2LPENR\_RNGLPEN 6
- #define RCC\_AHB2LPENR\_OTGFSLPEN 7
- #define RCC\_AHB3LPENR\_FSMCLPEN 0
- #define RCC\_APB1LPENR\_TIM2LPEN 0
- #define RCC\_APB1LPENR\_TIM3LPEN 1
- #define RCC\_APB1LPENR\_TIM4LPEN 2
- #define RCC\_APB1LPENR\_TIM5LPEN 3
- #define RCC\_APB1LPENR\_TIM6LPEN 4
- #define RCC\_APB1LPENR\_TIM7LPEN 5
- #define RCC\_APB1LPENR\_TIM12LPEN 6
- #define RCC\_APB1LPENR\_TIM13LPEN 7
- #define RCC\_APB1LPENR\_TIM14LPEN 8
- #define RCC\_APB1LPENR\_WWDGLPEN 11
- #define RCC\_APB1LPENR\_SPI2LPEN 14
- #define RCC\_APB1LPENR\_SPI3LPEN 15
- #define RCC\_APB1LPENR\_USART2LPEN 17
- #define RCC\_APB1LPENR\_USART3LPEN 18
- #define RCC\_APB1LPENR\_UART4LPEN 19
- #define RCC\_APB1LPENR\_UART5LPEN 20
- #define RCC\_APB1LPENR\_I2C1LPEN 21

- #define RCC\_APB1LPENR\_I2C2LPEN 22
- #define RCC\_APB1LPENR\_I2C3LPEN 23
- #define RCC\_APB1LPENR\_CAN1LPEN 25
- #define RCC\_APB1LPENR\_CAN2LPEN 26
- #define RCC\_APB1LPENR\_PWRLPEN 28
- #define RCC\_APB1LPENR\_DACLPEN 29
- #define RCC\_APB1LPENR\_UART7LPEN 30
- #define RCC\_APB1LPENR\_UART8LPEN 31
- #define RCC\_APB2LPENR\_TIM1LPEN 0
- #define RCC\_APB2LPENR\_TIM8LPEN 1
- #define RCC\_APB2LPENR\_USART1LPEN 4
- #define RCC\_APB2LPENR\_USART6LPEN 5
- #define RCC\_APB2LPENR\_ADCLPEN 8
- #define RCC\_APB2LPENR\_SDIOLPEN 11
- #define RCC\_APB2LPENR\_SPI1LPEN 12
- #define RCC\_APB2LPENR\_SYSCFGLPEN 14
- #define RCC\_APB2LPENR\_TIM9LPEN 16
- #define RCC\_APB2LPENR\_TIM10LPEN 17
- #define RCC\_APB2LPENR\_TIM11LPEN 18
- #define RCC\_BDCR\_LSEON 0
- #define RCC\_BDCR\_LSERDY 1
- #define RCC\_BDCR\_LSEBYP 2
- #define RCC\_BDCR\_RTCSEL 8
- #define RCC\_BDCR\_RTCEN 15
- #define RCC\_BDCR\_BDRST 16
- #define RCC\_CSR\_LSION 0
- #define RCC\_CSR\_LSIRDY 1
- #define RCC\_CSR\_RMVF 24
- #define RCC\_CSR\_OBLRSTF 25
- #define RCC\_CSR\_PINRSTF 26
- #define RCC\_CSR\_PORRSTF 27
- #define RCC\_CSR\_SFTRSTF 28
- #define RCC\_CSR\_IWDGRSTF 29
- #define RCC\_CSR\_WWDGRSTF 30
- #define RCC\_CSR\_LPWRRTSF 31
- #define RCC\_SSCGR\_MODPER 0
- #define RCC\_SSCGR\_INCSTEP 13
- #define RCC\_SSCGR\_SPREADSEL 15
- #define RCC\_SSCGR\_SSCGEN 31
- #define RCC\_PLLI2SCFGR\_PLLI2SN 6
- #define RCC\_PLLI2SCFGR\_PLLI2SR 28
- #define GPIO\_BASEADDR\_TO\_CODE(x)

*Macro to convert GPIO base address to port code.*

### 7.16.1 Detailed Description

Header file containing all the necessary information about the STM32F401xx MCU.

#### Author

Mohamed Ali Haoufa

This file provides definitions, memory maps, and register structures for the STM32F401xx series of microcontrollers. It includes base addresses for various memory regions and peripheral registers.

## Version

1.0

Date

2024-09-21

## Attention

This file is designed specifically for the STM32F401xx series microcontrollers. Ensure that all references and addresses are compliant with the specific microcontroller variant being used.

Copyright

(c) 2024

## 7.17 drivers/Inc/stm32f401xx gpio driver.h File Reference

Header file for GPIO driver for STM32F401xx microcontroller.

```
#include "stm32f401xx.h"
Include dependency graph for stm32f401xx_gpio_driver.h:
```



This graph shows which files directly or indirectly include this file:



## Classes

- struct GPIO\_PinConfig t

*Configuration structure for GPIO pins.*

## Macros

- #define **GPIO\_PIN\_0** 0
- #define **GPIO\_PIN\_1** 1
- #define **GPIO\_PIN\_2** 2
- #define **GPIO\_PIN\_3** 3
- #define **GPIO\_PIN\_4** 4
- #define **GPIO\_PIN\_5** 5
- #define **GPIO\_PIN\_6** 6
- #define **GPIO\_PIN\_7** 7
- #define **GPIO\_PIN\_8** 8
- #define **GPIO\_PIN\_9** 9
- #define **GPIO\_PIN\_10** 10
- #define **GPIO\_PIN\_11** 11
- #define **GPIO\_PIN\_12** 12
- #define **GPIO\_PIN\_13** 13
- #define **GPIO\_PIN\_14** 14
- #define **GPIO\_PIN\_15** 15
- #define **GPIO\_PIN\_ALL** ((**uint16**)0xFFFF)
- #define **GPIO\_MODE\_INPUT\_FLO** 0x00000001U
- #define **GPIO\_MODE\_INPUT\_PU** 0x00000002U
- #define **GPIO\_MODE\_INPUT\_PD** 0x00000003U
- #define **GPIO\_MODE\_OUTPUT\_PP** 0x00000004U
- #define **GPIO\_MODE\_OUTPUT\_OD** 0x00000005U
- #define **GPIO\_MODE\_OUTPUT\_AF\_PP** 0x00000006U
- #define **GPIO\_MODE\_OUTPUT\_AF\_OD** 0x00000007U
- #define **GPIO\_MODE\_AF\_INPUT** 0x00000008U
- #define **GPIO\_SPEED\_10M** 0x00000001U
- #define **GPIO\_SPEED\_2M** 0x00000002U
- #define **GPIO\_SPEED\_50M** 0x00000003U
- #define **GPIO\_PIN\_SET** 1
- #define **GPIO\_PIN\_RESET** 0
- #define **GPIO\_RETURN\_LOCK\_OK** 1
- #define **GPIO\_RETURN\_LOCK\_ERROR** 0
- #define **GPIO\_MODE\_IN** 0
- #define **GPIO\_MODE\_OUT** 1
- #define **GPIO\_MODE\_ALTFN** 2
- #define **GPIO\_MODE\_ANALOG** 3
- #define **GPIO\_MODE\_IT\_FT** 4
- #define **GPIO\_MODE\_IT\_RT** 5
- #define **GPIO\_MODE\_IT\_RFT** 6
- #define **GPIO\_SPEED\_LOW** 0
- #define **GPIO\_SPEED\_MEDIUM** 1
- #define **GPIO\_SPEED\_FAST** 2
- #define **GPIO\_SPEED\_HIGH** 3
- #define **GPIO\_NO\_PUPD** 0
- #define **GPIO\_PIN\_PU** 1
- #define **GPIO\_PIN\_PD** 2
- #define **GPIO\_OP\_TYPE\_PP** 0
- #define **GPIO\_OP\_TYPE\_OD** 1

## Functions

- void `MCAL_GPIO_Init (GPIO_TypeDef *GPIOx, GPIO_PinConfig_t *PinConfig)`  
*Initializes the specified GPIO pin according to the provided configuration.*
- void `MCAL_GPIO_DeInit (GPIO_TypeDef *GPIOx)`  
*Resets the specified GPIO port.*
- `uint8 MCAL_GPIO_ReadPin (GPIO_TypeDef *GPIOx, uint16 PinNumber)`  
*Reads the value of a specified GPIO pin.*
- `uint16 MCAL_GPIO_ReadPort (GPIO_TypeDef *GPIOx)`  
*Reads the value of the entire GPIO port.*
- void `MCAL_GPIO_WritePin (GPIO_TypeDef *GPIOx, uint16 PinNumber, uint8 Value)`  
*Writes a value to a specified GPIO pin.*
- void `MCAL_GPIO_WritePort (GPIO_TypeDef *GPIOx, uint16 Value)`  
*Writes a value to the entire GPIO port.*
- void `MCAL_GPIO_TogglePin (GPIO_TypeDef *GPIOx, uint16 PinNumber)`  
*Toggles the state of a specified GPIO pin.*
- void `MCAL_GPIO_TogglePort (GPIO_TypeDef *GPIOx)`  
*Toggles the value of a specific GPIO Port.*
- `uint8 MCAL_GPIO_LockPin (GPIO_TypeDef *GPIOx, uint16 PinNumber)`  
*Locks the configuration of a specific GPIO pin to prevent further changes.*

### 7.17.1 Detailed Description

Header file for GPIO driver for STM32F401xx microcontroller.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file provides the definitions, macros, and function prototypes for configuring and controlling GPIO pins on the STM32F401xx microcontroller.

#### Copyright

Copyright (c) 2024 Mohamed Ali Haoufa

## 7.18 drivers/Inc/stm32f401xx\_i2c\_driver.h File Reference

Header file for STM32F401xx I2C driver.

```
#include "stm32f401xx_gpio_driver.h"
Include dependency graph for stm32f401xx_i2c_driver.h:
```



## Classes

- struct [S\\_I2C\\_Slave\\_address](#)  
*Structure for I2C slave address configuration.*
- struct [S\\_I2C\\_Config\\_t](#)  
*Structure for I2C configuration.*

## Macros

- #define [I2C\\_SCK\\_SM\\_50K](#) (0x500000UL)
- #define [I2C\\_SCK\\_SM\\_100K](#) (1000000UL)
- #define [I2C\\_SCK\\_FM\\_200K](#) (2000000UL)
- #define [I2C\\_SCK\\_FM\\_400K](#) (4000000UL)
- #define [I2C\\_StretchMode\\_enabled](#) 0x00000000U
- #define [I2C\\_StretchMode\\_disabled](#) I2C\_CR1\_NOSTRETCH
- #define [I2C\\_Mode\\_I2C](#) 0
- #define [I2C\\_Mode\\_SMBus](#) I2C\_CR1\_SMBUS
- #define [I2C\\_Addressing\\_Slave\\_7bits](#) 0
- #define [I2C\\_Addressing\\_Slave\\_10bits](#) (uint16\_t)(1<<15)
- #define [I2C\\_Ack\\_Control\\_Enable](#) I2C\_CR1\_ACK
- #define [I2C\\_Ack\\_Control\\_Disable](#) 0
- #define [I2C\\_ENGC\\_Enable](#) I2C\_CR1\_ENGC
- #define [I2C\\_ENGC\\_Disable](#) 0x00

## Enumerations

- enum `Slave_State` {
 `I2C_EV_Stop` , `I2C_Error_AF` , `I2C_Ev_Address_Matched` , `I2C_Ev_Data_Req` , `I2C_Ev_Data_RCV` }
   
*Enumeration for I2C slave states.*
- enum `StopCondition` { `WithStop` , `WithoutStop` }
   
*Enumeration for I2C stop condition.*
- enum `Repeated_Start` { `Start` , `Repeated` }
   
*Enumeration for I2C repeated start condition.*
- enum `Functional_State` { `DISABLE` , `ENABLE` }
   
*Enumeration for functional state.*
- enum `FlagStatus` { `RESET` = 0 , `SET` = !`RESET` , `Reset` , `Set` }
   
*Enumeration for flag status.*
- enum `Status` {
 `I2C_Flag_Busy` , `EV5` , `EV6` , `EV7` , `EV8` , `EV8_1` , `Master_Byte_Transmitting` = (`uint32_t`)(0x00070080) }
   
*Enumeration for I2C status flags.*
- enum `I2C_Direction` { `I2C_Direction_Transmitter` , `I2C_Direction_Receiver` }
   
*Enumeration for I2C direction.*

## Functions

- void `MCAL_I2C_Init` (`I2C_TypeDef` \*`I2Cx`, `S_I2C_Config_t` \*`I2C_Init_Struct`)
   
*Initializes the I2C peripheral.*
- void `MCAL_I2C_Deinit` (`I2C_TypeDef` \*`I2Cx`)
   
*Deinitializes the I2C peripheral.*
- void `MCAL_I2C_Set_GPIO` (`I2C_TypeDef` \*`I2Cx`)
   
*Sets the GPIO configuration for I2C.*
- void `MCAL_I2C_Master_Tx` (`I2C_TypeDef` \*`I2Cx`, `uint16_t` `SlaveAdd`, `uint8_t` \*`dataout`, `uint32_t` `datalen`, `StopCondition` `Stop`, `Repeated_Start` `start`)
   
*Transmits data from the master to the slave.*
- void `MCAL_I2C_Master_Rx` (`I2C_TypeDef` \*`I2Cx`, `uint16_t` `SlaveAdd`, `uint8_t` \*`dataout`, `uint32_t` `datalen`, `StopCondition` `Stop`, `Repeated_Start` `start`)
   
*Receives data from the master.*
- void `MCAL_I2C_Slave_SendData` (`I2C_TypeDef` \*`I2Cx`, `uint8_t` `data`)
   
*Sends data from the slave.*
- `uint8_t MCAL_I2C_SlaveReceiveData` (`I2C_TypeDef` \*`I2Cx`)
   
*Receives data in slave mode.*
- void `I2C_Generate_Start` (`I2C_TypeDef` \*`I2Cx`, `Functional_State` `state`, `Repeated_Start` `start`)
   
*Generates a start condition on the I2C bus.*
- `FlagStatus I2C_Get_FlagStatus` (`I2C_TypeDef` \*`I2Cx`, `Status` `flag`)
   
*Gets the status of a specific flag.*
- void `I2C_SendAddress` (`I2C_TypeDef` \*`I2Cx`, `uint16_t` `SlaveAddress`, `I2C_Direction` `I2C_Direction`)
   
*Sends an address to the I2C bus.*
- void `I2C_Generate_Stop` (`I2C_TypeDef` \*`I2Cx`, `Functional_State` `NewState`)
   
*Generates a stop condition on the I2C bus.*
- void `I2C_ACKnowledgeConfig` (`I2C_TypeDef` \*`I2Cx`, `Functional_State` `NewState`)
   
*Configures the I2C acknowledge feature.*

### 7.18.1 Detailed Description

Header file for STM32F401xx I2C driver.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file provides the interface for initializing and controlling the I2C peripheral on the STM32F401xx microcontroller. It includes definitions for I2C configurations, enumerations for I2C status and control, and function prototypes for I2C operations.

#### Copyright

Copyright (c) 2023 Fam Ayman. All rights reserved.

## 7.19 drivers/Inc/stm32f401xx\_nvic\_driver.h File Reference

Header file for NVIC (Nested Vectored Interrupt Controller) driver for STM32F401xx microcontroller.

```
#include "stm32f401xx.h"
Include dependency graph for stm32f401xx_nvic_driver.h:
```



This graph shows which files directly or indirectly include this file:



## Macros

- `#define NVIC_ISER0 (*(volatile uint32_t *)(<NVIC_BASE> + 0x0))`  
*Interrupt Set Enable Register 0 (ISER0) Used to enable interrupts 0 to 31. Write a 1 to the corresponding bit position to enable an interrupt.*
- `#define NVIC_ISER1 (*(volatile uint32_t *)(<NVIC_BASE> + 0x4))`  
*Interrupt Set Enable Register 1 (ISER1) Used to enable interrupts 32 to 63. Write a 1 to the corresponding bit position to enable an interrupt.*
- `#define NVIC_ISER2 (*(volatile uint32_t *)(<NVIC_BASE> + 0x8))`  
*Interrupt Set Enable Register 2 (ISER2) Used to enable interrupts 64 to 95. Write a 1 to the corresponding bit position to enable an interrupt.*
- `#define NVIC_ICER0 (*(volatile uint32_t *)(<NVIC_BASE> + 0x80))`  
*Interrupt Clear Enable Register 0 (ICER0) Used to disable interrupts 0 to 31. Write a 1 to the corresponding bit position to disable an interrupt.*
- `#define NVIC_ICER1 (*(volatile uint32_t *)(<NVIC_BASE> + 0x84))`  
*Interrupt Clear Enable Register 1 (ICER1) Used to disable interrupts 32 to 63. Write a 1 to the corresponding bit position to disable an interrupt.*
- `#define NVIC_ICER2 (*(volatile uint32_t *)(<NVIC_BASE> + 0x88))`  
*Interrupt Clear Enable Register 2 (ICER2) Used to disable interrupts 64 to 95. Write a 1 to the corresponding bit position to disable an interrupt.*
- `#define SCB_VECTKEY 0x05FA0000UL`  
*Vector key for setting priority grouping in NVIC.*
- `#define SCB_VECTKEY_MASK 0xFFFF0000UL`  
*Mask for vector key.*
- `#define NVIC_PRIGROUP_SET_MASK 0x700UL`  
*Mask for setting NVIC priority grouping.*
- `#define NVIC_PRIGROUP_CLEAR_MASK 0xFFFFF8FFUL`  
*Mask for clearing NVIC priority grouping.*
- `#define NVIC_INTERRUPT_ACTIVE 1UL`  
*Status indicating an active interrupt.*
- `#define NVIC_INTERRUPT_INACTIVE 0UL`  
*Status indicating an inactive interrupt.*
- `#define NVIC_PRIO_16GRP_0SUBGRP 0x300U`  
*Priority grouping configuration for 16 groups and 0 subgroups.*
- `#define NVIC_PRIO_8GRP_2SUBGRP 0x400U`  
*Priority grouping configuration for 8 groups and 2 subgroups.*
- `#define NVIC_PRIO_4GRP_4SUBGRP 0x500U`  
*Priority grouping configuration for 4 groups and 4 subgroups.*
- `#define NVIC_PRIO_2GRP_8SUBGRP 0x600U`  
*Priority grouping configuration for 2 groups and 8 subgroups.*
- `#define NVIC_PRIO_0GRP_8SUBGRP 0x700U`  
*Priority grouping configuration for 0 groups and 8 subgroups.*
- `#define NVIC_PRIO_0000 0x00U`  
*Priority level 0.*
- `#define NVIC_PRIO_0001 0x10U`  
*Priority level 1.*
- `#define NVIC_PRIO_0010 0x20U`  
*Priority level 2.*
- `#define NVIC_PRIO_0011 0x30U`  
*Priority level 3.*
- `#define NVIC_PRIO_0100 0x40U`  
*Priority level 4.*

- #define **NVIC\_PRIO\_0101** 0x50U  
*Priority level 5.*
- #define **NVIC\_PRIO\_0110** 0x60U  
*Priority level 6.*
- #define **NVIC\_PRIO\_0111** 0x70U  
*Priority level 7.*
- #define **NVIC\_PRIO\_1000** 0x80U  
*Priority level 8.*
- #define **NVIC\_PRIO\_1001** 0x90U  
*Priority level 9.*
- #define **NVIC\_PRIO\_1010** 0xA0U  
*Priority level 10.*
- #define **NVIC\_PRIO\_1011** 0xB0U  
*Priority level 11.*
- #define **NVIC\_PRIO\_1100** 0xC0U  
*Priority level 12.*
- #define **NVIC\_PRIO\_1101** 0xD0U  
*Priority level 13.*
- #define **NVIC\_PRIO\_1110** 0xE0U  
*Priority level 14.*
- #define **NVIC\_PRIO\_1111** 0xF0U  
*Priority level 15.*
- #define **EXTI0\_IRQ** 6  
*External Interrupt Request 0.*
- #define **EXTI1\_IRQ** 7  
*External Interrupt Request 1.*
- #define **EXTI2\_IRQ** 8  
*External Interrupt Request 2.*
- #define **EXTI3\_IRQ** 9  
*External Interrupt Request 3.*
- #define **EXTI4\_IRQ** 10  
*External Interrupt Request 4.*
- #define **EXTI5\_IRQ** 23  
*External Interrupt Request 5.*
- #define **EXTI6\_IRQ** 23  
*External Interrupt Request 6.*
- #define **EXTI7\_IRQ** 23  
*External Interrupt Request 7.*
- #define **EXTI8\_IRQ** 23  
*External Interrupt Request 8.*
- #define **EXTI9\_IRQ** 23  
*External Interrupt Request 9.*
- #define **EXTI10\_IRQ** 40  
*External Interrupt Request 10.*
- #define **EXTI11\_IRQ** 40  
*External Interrupt Request 11.*
- #define **EXTI12\_IRQ** 40  
*External Interrupt Request 12.*
- #define **EXTI13\_IRQ** 40  
*External Interrupt Request 13.*
- #define **EXTI14\_IRQ** 40

- External Interrupt Request 14.*
- #define **EXTI15\_IRQ** 40
- External Interrupt Request 15.*
- #define **USART1\_IRQ** 37
- USART1 Interrupt Request.*
- #define **USART2\_IRQ** 38
- USART2 Interrupt Request.*
- #define **USART6\_IRQ** 71
- USART6 Interrupt Request.*
- #define **SPI1\_IRQ** 35
- SPI1 Interrupt Request.*
- #define **SPI2\_IRQ** 36
- SPI2 Interrupt Request.*
- #define **I2C1\_EV\_IRQ** 31
- I2C1 Event Interrupt Request.*
- #define **I2C1\_ER\_IRQ** 32
- I2C1 Error Interrupt Request.*
- #define **I2C2\_EV\_IRQ** 33
- I2C2 Event Interrupt Request.*
- #define **I2C2\_ER\_IRQ** 34
- I2C2 Error Interrupt Request.*
- #define **NVIC IRQ6\_EXTI0\_Enable** (NVIC\_ISERO |= (1<<6))
  - #define **NVIC IRQ7\_EXTI1\_Enable** (NVIC\_ISERO |= (1<<7))
  - #define **NVIC IRQ8\_EXTI2\_Enable** (NVIC\_ISERO |= (1<<8))
  - #define **NVIC IRQ9\_EXTI3\_Enable** (NVIC\_ISERO |= (1<<9))
  - #define **NVIC IRQ10\_EXTI4\_Enable** (NVIC\_ISERO |= (1<<10))
  - #define **NVIC IRQ23\_EXTI5\_9\_Enable** (NVIC\_ISERO |= (1<<23))
  - #define **NVIC IRQ40\_EXTI10\_15\_Enable** (NVIC\_ICER1 |= (1<<8))
  - #define **NVIC IRQ6\_EXTI0\_Disable** (NVIC\_ICERO |= (1<<6))
  - #define **NVIC IRQ7\_EXTI1\_Disable** (NVIC\_ICERO |= (1<<7))
  - #define **NVIC IRQ8\_EXTI2\_Disable** (NVIC\_ICERO |= (1<<8))
  - #define **NVIC IRQ9\_EXTI3\_Disable** (NVIC\_ICERO |= (1<<9))
  - #define **NVIC IRQ10\_EXTI4\_Disable** (NVIC\_ICERO |= (1<<10))
  - #define **NVIC IRQ23\_EXTI5\_9\_Disable** (NVIC\_ICERO |= (1<<23))
  - #define **NVIC IRQ40\_EXTI10\_15\_Disable** (NVIC\_ICER1 |= (1<<8))
  - #define **NVIC IRQ37\_USART1\_Enable** (NVIC\_ISER1 |= 1<<(USART1\_IRQ - 32))
  - #define **NVIC IRQ38\_USART2\_Enable** (NVIC\_ISER1 |= 1<<(USART2\_IRQ - 32))
  - #define **NVIC IRQ39\_USART3\_Enable** (NVIC\_ISER1 |= 1<<(USART3\_IRQ - 32))
  - #define **NVIC IRQ37\_USART1\_Disable** (NVIC\_ICER1 |= 1<<(USART1\_IRQ - 32))
  - #define **NVIC IRQ38\_USART2\_Disable** (NVIC\_ICER1 |= 1<<(USART2\_IRQ - 32))
  - #define **NVIC IRQ39\_USART3\_Disable** (NVIC\_ICER1 |= 1<<(USART3\_IRQ - 32))
  - #define **NVIC IRQ35\_SPI1\_Enable** (NVIC\_ISER1 |= 1<<(SPI1\_IRQ - 32))
  - #define **NVIC IRQ36\_SPI2\_Enable** (NVIC\_ISER1 |= 1<<(SPI2\_IRQ - 32))
  - #define **NVIC IRQ35\_SPI1\_Disable** (NVIC\_ICER1 &= ~(1<<(SPI1\_IRQ - 32)))
  - #define **NVIC IRQ36\_SPI2\_Disable** (NVIC\_ICER1 &= ~(1<<(SPI2\_IRQ - 32)))
  - #define **NVIC IRQ31\_I2C1\_EV\_Enable** (NVIC\_ISER0 |= 1<<(I2C1\_EV\_IRQ))
  - #define **NVIC IRQ32\_I2C1\_ER\_Enable** (NVIC\_ISER1 |= 1<<(I2C1\_ER\_IRQ - 32))
  - #define **NVIC IRQ33\_I2C2\_EV\_Enable** (NVIC\_ISER1 |= 1<<(I2C2\_EV\_IRQ - 32))
  - #define **NVIC IRQ34\_I2C2\_ER\_Enable** (NVIC\_ISER1 |= 1<<(I2C2\_ER\_IRQ - 32))
  - #define **NVIC IRQ31\_I2C1\_EV\_Disable** (NVIC\_ICER0 &= ~(1<<(I2C1\_EV\_IRQ)))
  - #define **NVIC IRQ32\_I2C1\_ER\_Disable** (NVIC\_ICER1 &= ~(1<<(I2C1\_ER\_IRQ - 32)))
  - #define **NVIC IRQ33\_I2C2\_EV\_Disable** (NVIC\_ICER1 &= ~(1<<(I2C2\_EV\_IRQ - 32)))
  - #define **NVIC IRQ34\_I2C2\_ER\_Disable** (NVIC\_ICER1 &= ~(1<<(I2C2\_ER\_IRQ - 32)))

## Functions

- void `MCAL_NVIC_SetPriorityGrouping (uint32 priority_grouping)`  
*Set the priority grouping for the NVIC.*
- `uint32 MCAL_NVIC_GetPriorityGrouping (void)`  
*Get the current priority grouping configuration of the NVIC.*
- void `MCAL_NVIC_EnableIRQ (uint8 IRQn)`  
*Enable a specified IRQ.*
- void `MCAL_NVIC_DisableIRQ (uint8 IRQn)`  
*Disable a specified IRQ.*
- `uint8 MCAL_NVIC_GetPendingIRQ (uint8 IRQn)`  
*Get the pending status of a specified IRQ.*
- void `MCAL_NVIC_SetPendingIRQ (uint8 IRQn)`  
*Set the pending status of a specified IRQ.*
- void `MCAL_NVIC_ClearPendingIRQ (uint8 IRQn)`  
*Clear the pending status of a specified IRQ.*
- `uint8 MCAL_NVIC_GetActive (uint8 IRQn)`  
*Get the active status of a specified IRQ.*
- void `MCAL_NVIC_SetPriority (uint8 IRQn, uint8 priority)`  
*Set the priority of a specified IRQ.*
- `uint8 MCAL_NVIC_GetPriority (uint8 IRQn)`  
*Retrieves the priority level of a specified IRQn.*
- void `MCAL_NVIC_SystemReset (void)`  
*Performs a system reset.*

### 7.19.1 Detailed Description

Header file for NVIC (Nested Vectored Interrupt Controller) driver for STM32F401xx microcontroller.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This header file provides definitions, macros, and function prototypes for interacting with the NVIC of the STM32F401xx microcontroller. It includes functions for configuring interrupt priority, enabling/disabling interrupts, and managing interrupt status.

#### Copyright

Copyright (c) 2024

## 7.20 drivers/Inc/stm32f401xx\_rcc\_driver.h File Reference

Header file for RCC (Reset and Clock Control) driver for STM32F401xx MCU.

```
#include "stm32f401xx.h"
```

Include dependency graph for stm32f401xx\_rcc\_driver.h:



## Macros

- #define **RCC\_PLLCFGR\_PLLSRC\_HSE** ((uint32\_t)0x00400000)
- #define **HSI\_VALUE** 16000000U
- #define **HSE\_VALUE** 8000000U
- #define **RCC\_GPIOA** ((uint8\_t)0x00)
- #define **RCC\_GPIOB** ((uint8\_t)0x01)
- #define **RCC\_GPIOC** ((uint8\_t)0x02)
- #define **RCC\_GPIOD** ((uint8\_t)0x03)
- #define **RCC\_GPIOE** ((uint8\_t)0x04)
- #define **RCC\_USART1** ((uint8\_t)0x08)
- #define **RCC\_USART2** ((uint8\_t)0x09)
- #define **RCC\_USART6** ((uint8\_t)0xA)
- #define **RCC\_SPI1** ((uint8\_t)0xB)
- #define **RCC\_SPI2** ((uint8\_t)0xC)
- #define **RCC\_I2C1** ((uint8\_t)0xD)
- #define **RCC\_I2C2** ((uint8\_t)0xE)
- #define **RCC\_CRC** ((uint8\_t)0xF)
- #define **RCC\_TIM2** ((uint8\_t)0x10)
- #define **RCC\_SYSCFG** ((uint8\_t)0x11)
- #define **HSI\_RC\_CLK** 8000000UL
- #define **HSE\_CLK** 8000000UL
- #define **RCC\_SELECT\_HSI** ((uint8\_t)0x00)
- #define **RCC\_SELECT\_HSE** ((uint8\_t)0x01)
- #define **RCC\_SELECT\_PLL** ((uint8\_t)0x02)

## Functions

- void [MCAL\\_RCC\\_Select\\_Clock](#) (uint8\_t clock)  
*Select the clock source for the MCU.*
- void [MCAL\\_RCC\\_Enable\\_Peripheral](#) (uint8\_t peripheral)  
*Enable the clock for a specific peripheral.*
- void [MCAL\\_RCC\\_Reset\\_Peripheral](#) (uint8\_t peripheral)  
*Reset a specific peripheral.*
- uint32\_t [MCAL\\_RCC\\_GetSYS\\_CLKFreq](#) (void)  
*Get the frequency of the system clock.*
- uint32\_t [MCAL\\_RCC\\_GetHCLKFreq](#) (void)  
*Get the frequency of the AHB bus clock.*
- uint32\_t [MCAL\\_RCC\\_GetPCLK1Freq](#) (void)  
*Get the frequency of the APB1 bus clock.*
- uint32\_t [MCAL\\_RCC\\_GetPCLK2Freq](#) (void)  
*Get the frequency of the APB2 bus clock.*
- uint32\_t [RCC\\_GetPLLOutputClock](#) (void)  
*Get the frequency of the PLL (Phase-Locked Loop) output clock.*

### 7.20.1 Detailed Description

Header file for RCC (Reset and Clock Control) driver for STM32F401xx MCU.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This header file defines the macros, constants, and function prototypes for managing the Reset and Clock Control (RCC) peripheral of the STM32F401xx microcontroller. It includes clock source selection, peripheral enablement, and clock frequency retrieval.

#### Copyright

Copyright (c) 2024 Mohamed Ali Haoufa

## 7.21 drivers/Inc/stm32f401xx\_spi\_driver.h File Reference

This file contains definitions and function prototypes for the STM32F401xx SPI driver.

```
#include "stm32f401xx_gpio_driver.h"
#include "stm32f401xx.h"
```

Include dependency graph for stm32f401xx\_spi\_driver.h:



This graph shows which files directly or indirectly include this file:



## Classes

- struct [S\\_IRQ\\_SRC](#)  
*Structure to identify the source of SPI interrupts.*
- struct [S\\_SPI\\_Config\\_t](#)  
*Configuration structure for SPI.*

## Macros

- #define [SPI\\_Mode\\_Master](#) (0x1<<2)
- #define [SPI\\_Mode\\_Slave](#) (0x00000000U)
- #define [SPI\\_Direction\\_2lines](#) (0x00000000U)
- #define [SPI\\_Direction\\_2lines\\_RX\\_Only](#) (0x1<<10)
- #define [SPI\\_Direction\\_1line\\_Receive\\_only](#) (0x1<<15)
- #define [SPI\\_Direction\\_1line\\_Transmit\\_only](#) ((0x1<<15)|(0x1<<14))
- #define [SPI\\_Payload\\_Length\\_8bit](#) (0x00000000U)
- #define [SPI\\_Payload\\_Length\\_16bit](#) (0x1<<11)
- #define [SPI\\_Frame\\_Format\\_MSB](#) (0x00000000U)

- #define SPI\_Frame\_Format\_LSB (0x1<<7)
- #define SPI\_Clock\_Polarity\_Low\_Idle (0x00000000U)
- #define SPI\_Clock\_Polarity\_High\_Idle (0x1<<1)
- #define SPI\_Clock\_Phase\_Leading (0x00000000U)
- #define SPI\_Clock\_Phase\_Trailing (0x1)
- #define SPI\_NSS\_Hard\_Slave (0x00000000U)
- #define SPI\_NSS\_Hard\_Master\_SS\_Output\_Enable (0x1<<2)
- #define SPI\_NSS\_Hard\_Master\_SS\_No\_output (0x00000000U)
- #define SPI\_NSS\_Internal\_Soft\_Reset (0x1<<9)
- #define SPI\_NSS\_Internal\_Soft\_Set ((0x1<<9)|(0x1<<8))
- #define SPI\_Prescaler\_By2 (0x00000000U)
- #define SPI\_Prescaler\_By4 (0b001<<3)
- #define SPI\_Prescaler\_By8 (0b010<<3)
- #define SPI\_Prescaler\_By16 (0b011<<3)
- #define SPI\_Prescaler\_By32 (0b100<<3)
- #define SPI\_Prescaler\_By64 (0b101<<3)
- #define SPI\_Prescaler\_By128 (0b110<<3)
- #define SPI\_Prescaler\_By256 (0b111<<3)
- #define SPI\_IRQ\_Enable\_None (uint32\_t)(0)
- #define SPI\_IRQ\_Enable\_Tx\_Only (uint32\_t)(1<<7)
- #define SPI\_IRQ\_Enable\_Rx\_Only (uint32\_t)(1<<6)
- #define SPI\_IRQ\_Enable\_Err (uint32\_t)(1<<5)

## Enumerations

- enum SPI\_PollingMechanism { Enabled , Disabled }
- Enumeration for SPI polling mechanisms.*

## Functions

- void MCAL\_SPI\_Init (SPI\_TypeDef \*SPIx, S\_SPI\_Config\_t \*Config)  
*Initializes the SPI peripheral according to the specified configuration.*
- void MCAL\_SPI\_DeInit (SPI\_TypeDef \*SPIx)  
*Deinitializes the SPI peripheral.*
- void MCAL\_SPI\_GPIO\_Set\_Pins (SPI\_TypeDef \*SPIx)  
*Configures the GPIO pins used for SPI communication.*
- void MCAL\_SPI\_SendData (SPI\_TypeDef \*SPIx, uint16\_t \*pTXBuffer, enum SPI\_PollingMechanism Polling\_En)  
*Sends data through SPI.*
- void MCAL\_SPI\_ReceiveData (SPI\_TypeDef \*SPIx, uint16\_t \*pRXBuffer, enum SPI\_PollingMechanism Polling\_En)  
*Receives data from SPI.*
- void MCAL\_SPI\_Tx\_Rx (SPI\_TypeDef \*SPIx, uint16\_t \*TX\_RX\_pBuffer, enum SPI\_PollingMechanism Polling\_En)  
*Transmits and receives data through SPI.*

### **7.21.1 Detailed Description**

This file contains definitions and function prototypes for the STM32F401xx SPI driver.

## Author

Mohamed Ali Haoufa

## Version

0.1

Date

2024-09-21

Copyright

Copyright (c) 2024

This header file provides the definitions and function prototypes required for configuring and using the SPI (Serial Peripheral Interface) peripheral on the STM32F401xx microcontroller. It includes macros for configuration, a structure for SPI configuration, and function prototypes for SPI initialization, data transmission, and reception.

## 7.22 drivers/Inc/stm32f401xx systick driver.h File Reference

Header file for configuring and controlling the SysTick timer in the STM32F401xx MCU. This file contains the necessary structures, macros, and function prototypes for SysTick initialization, configuration, and handling delays.

```
#include "stm32f401xx.h"
Include dependency graph for stm32f401xx_systick_driver.h:
```



This graph shows which files directly or indirectly include this file:



## Classes

- struct **STK\_config\_t**

*SysTick Configuration Structure Definition.*

## Macros

- #define **STK\_INTERRUPT\_MASK** 0x02UL  
*Interrupt enable/disable mask for the SysTick timer.*
- #define **STK\_CLK\_MASK** 0x04UL  
*Clock source mask for the SysTick timer.*
- #define **STK\_RELOAD\_MASK** 0x00FFFFFFUL  
*Reload value mask for the SysTick timer.*
- #define **STK\_FCPU** 8000000UL  
*CPU frequency definition for the SysTick timer.*
- #define **STK\_INTERRUPT\_ENABLED** 0x02UL
- #define **STK\_INTERRUPT\_DISABLED** 0x00UL
- #define **STK\_CLK\_AHB** 0x04UL
- #define **STK\_CLK\_AHB\_8** 0x00UL
- #define **STK\_PERIODIC\_MODE** 0x01U
- #define **STK\_ONE\_SHOT\_MODE** 0x00U

## Functions

- void **MCAL\_STK\_Config** (**STK\_config\_t** \*\_cfg)  
*Configures the SysTick timer with the specified parameters.*
- void **MCAL\_STK\_SetReload** (**uint32** value)  
*Sets the reload value for the SysTick timer.*
- void **MCAL\_STK\_SetCallback** (**void(\*pfCallback)(void)**)  
*Sets the callback function for the SysTick timer interrupt.*
- void **MCAL\_STK\_StartTimer** ()  
*Starts the SysTick timer.*
- void **MCAL\_STK\_StopTimer** ()  
*Stops the SysTick timer.*
- void **MCAL\_STK\_Delay** (**uint32** delay\_ticks)  
*Delays the system by a specified number of ticks using the SysTick timer.*
- void **MCAL\_STK\_Delay1ms** (**uint32** delay\_ms)  
*Delays the system by a specified number of milliseconds.*

### 7.22.1 Detailed Description

Header file for configuring and controlling the SysTick timer in the STM32F401xx MCU. This file contains the necessary structures, macros, and function prototypes for SysTick initialization, configuration, and handling delays.

#### Author

Mohamed Ali Haoufa

## Version

0.1

## Date

2024-09-21

This file is part of the STM32F401xx peripheral driver library, focusing on the SysTick timer. The driver allows users to configure SysTick as a periodic or one-shot timer, handle interrupt configuration, and generate delays.

## Copyright

Copyright (c) 2024 Mohamed Ali Haoufa. All rights reserved. This software is provided "as is," without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose, and noninfringement.

## 7.23 drivers/Inc/stm32f401xx\_timer\_driver.h File Reference

Header file providing timer functionalities for the STM32F401xx MCU. This file contains the necessary definitions, macros, and functions to manage Timer 2 (TIM2) in the STM32F401xx microcontroller.

```
#include "stm32f401xx.h"
#include "stm32f401xx_gpio_driver.h"
```

Include dependency graph for stm32f401xx\_timer\_driver.h:



This graph shows which files directly or indirectly include this file:



## Macros

- `#define RCC_APB1ENR *(volatile uint32 *) (RCC_BASE + 0x40)`  
*Enable the APB1 peripheral clock for TIM2.*
- `#define RCC_APB2ENR *(volatile uint32 *) (RCC_BASE + 0x44)`  
*Enable the APB2 peripheral clock for TIM2.*
- `#define TIM2_TIMER_BASE 0x40000000`  
*TIM2\_Register TIM2 Register Base Addresses and Offsets.*
- `#define TIM2_CR1 *(volatile uint32 *) (TIM2_TIMER_BASE + 0x00)`  
*Control register 1 (CR1) for TIM2.*
- `#define TIM2_DIER *(volatile uint32 *) (TIM2_TIMER_BASE + 0x0C)`  
*DMA/interrupt enable register (DIER) for TIM2.*
- `#define TIM2_SR *(volatile uint32 *) (TIM2_TIMER_BASE + 0x10)`  
*Status register (SR) for TIM2.*
- `#define TIM2_CNT *(volatile uint32 *) (TIM2_TIMER_BASE + 0x24)`  
*Counter register (CNT) for TIM2.*
- `#define TIM2_PSC *(volatile uint32 *) (TIM2_TIMER_BASE + 0x28)`  
*Prescaler register (PSC) for TIM2.*
- `#define TIM2_ARR *(volatile uint32 *) (TIM2_TIMER_BASE + 0x2C)`  
*Auto-reload register (ARR) for TIM2.*

## Functions

- `void Timer2_init (void)`  
*Initialize Timer 2 (TIM2) for basic timing functionalities.*
- `void dus (int us)`  
*Delay execution for a specified number of microseconds.*
- `void dms (int ms)`  
*Delay execution for a specified number of milliseconds.*

### 7.23.1 Detailed Description

Header file providing timer functionalities for the STM32F401xx MCU. This file contains the necessary definitions, macros, and functions to manage Timer 2 (TIM2) in the STM32F401xx microcontroller.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file is part of the STM32F401xx peripheral driver library, which offers low-level control of the MCU's timers, specifically Timer 2 (TIM2). It provides initialization functions for TIM2, along with delay functionalities in microseconds and milliseconds.

#### Copyright

Copyright (c) 2024 Mohamed Ali Haoufa. All rights reserved. This software is provided "as is," without warranty of any kind, express or implied, including but not limited to the warranties of merchantability, fitness for a particular purpose, and noninfringement.

## 7.24 drivers/Inc/stm32f401xx\_usart\_driver.h File Reference

USART driver header file for STM32F401 series microcontrollers.

```
#include "stm32f401xx.h"
#include "stm32f401xx_gpio_driver.h"
#include "stm32f401xx_rcc_driver.h"
#include "stm32f401xx_nvic_driver.h"
Include dependency graph for stm32f401xx_usart_driver.h:
```



This graph shows which files directly or indirectly include this file:



## Classes

- struct `USART_cfg_t`

*Configuration structure for USART (Universal Synchronous Asynchronous Receiver Transmitter) peripheral.*

## Macros

- #define `UART_Mode_RX` ((`uint32_t`)(`1UL << 2`))  
*USART Mode Definitions.*
- #define `UART_Mode_TX` ((`uint32_t`)(`1UL << 3`))
- #define `UART_Mode_TX_RX` ((`uint32_t`)(`1UL << 2 | 1UL << 3`)))
- #define `UART_BaudRate_2400` 2400  
*Baud Rate Definitions.*
- #define `UART_BaudRate_9600` 9600
- #define `UART_BaudRate_19200` 19200
- #define `UART_BaudRate_57600` 57600
- #define `UART_BaudRate_115200` 115200
- #define `UART_BaudRate_230400` 230400
- #define `UART_BaudRate_460800` 460800

- #define **UART\_BaudRate\_921600** 921600
- #define **UART\_BaudRate\_2250000** 2250000
- #define **UART\_BaudRate\_4500000** 4500000
- #define **UART\_Payload\_Length\_8B** ((uint32\_t)(0))
 

*Payload Length Definitions.*
- #define **UART\_Payload\_Length\_9B** ((uint32\_t)(1UL << 12))
- #define **UART\_Parity\_NONE** ((uint32\_t)(0))
 

*Parity Definitions.*
- #define **UART\_Parity\_EVEN** ((uint32\_t)(1UL << 10))
- #define **UART\_Parity\_ODD** ((uint32\_t)(1UL << 10) | (1UL << 9))
- #define **UART\_StopBits\_half** ((uint32\_t)(1 << 12))
 

*Stop Bits Definitions.*
- #define **UART\_StopBits\_1** ((uint32\_t)(0))
- #define **UART\_StopBits\_1\_half** ((uint32\_t)(3 << 12))
- #define **UART\_StopBits\_2** ((uint32\_t)(2 << 12))
- #define **UART\_HwFlowCtl\_NONE** ((uint32\_t)(0))
 

*Hardware Flow Control Definitions.*
- #define **UART\_HwFlowCtl\_RTS** ((uint32\_t)(1UL << 8))
- #define **UART\_HwFlowCtl\_CTS** ((uint32\_t)(1UL << 9))
- #define **UART\_HwFlowCtl\_RTS\_CTS** ((uint32\_t)(1UL << 8 | 1UL << 9))
- #define **UART\_IRQ\_Enable\_NONE** ((uint32\_t)(0))
 

*IRQ Enable Definitions.*
- #define **UART\_IRQ\_Enable\_TXE** ((uint32\_t)(1UL << 7))
- #define **UART\_IRQ\_Enable\_TC** ((uint32\_t)(1UL << 6))
- #define **UART\_IRQ\_Enable\_RXNE** ((uint32\_t)(1UL << 5))
- #define **UART\_IRQ\_Enable\_PE** ((uint32\_t)(1UL << 8))

## Enumerations

- enum **Polling\_Mechanism** { **enable** , **disable** }
- Enumeration for Polling Mechanism.*

## Functions

- void **MCAL\_USART\_Init** (**USART\_TypeDef** \*USARTx, **USART\_cfg\_t** \*USART\_cfg)
 

*Initializes UART (Asynchronous mode only).*
- void **MCAL\_USART\_DeInit** (**USART\_TypeDef** \*USARTx)
 

*Deinitializes UART (Asynchronous mode only).*
- void **MCAL\_USART\_GPIO\_Set\_Pins** (**USART\_TypeDef** \*USARTx)
 

*Initializes GPIO pins for USART.*
- void **MCAL\_USART\_SendData** (**USART\_TypeDef** \*USARTx, **uint16\_t** \*pTxBuffer, **Polling\_Mechanism** PollingEn)
 

*Sends buffer via USART.*
- void **MCAL\_USART\_SendString** (**USART\_TypeDef** \*USARTx, **uint8\_t** \*str, **uint8\_t** str\_len)
 

*Sends a string via USART.*
- void **MCAL\_USART\_ReceiveData** (**USART\_TypeDef** \*USARTx, **uint16\_t** \*pRxBuffer, **Polling\_Mechanism** PollingEn)
 

*Receives buffer from USART.*
- void **MCAL\_USART\_ReceiveBuffer** (**USART\_TypeDef** \*USARTx, **uint16\_t** \*pRxBuffer, **uint8\_t** length)
 

*Receives buffer from USART with specified length.*
- void **MCAL\_USART\_Wait\_TC** (**USART\_TypeDef** \*USARTx)
 

*Waits until transmission is completed by polling on TC flag.*

### 7.24.1 Detailed Description

USART driver header file for STM32F401 series microcontrollers.

#### Author

Mohamed Ali Haoufa

#### Version

1.0

#### Date

2024-09-21

This file contains the configuration and function prototypes for the USART peripheral. It includes macros for configuration, API declarations, and enumeration types.

#### Copyright

Copyright (c) 2024

## 7.25 drivers/Src/stm32f401xx\_gpio\_driver.c File Reference

GPIO driver for STM32F401xx microcontroller.

```
#include "stm32f401xx_gpio_driver.h"
```

Include dependency graph for stm32f401xx\_gpio\_driver.c:



## Functions

- void **MCAL\_GPIO\_Init** (**GPIO\_TypeDef** \*GPIOx, **GPIO\_PinConfig\_t** \*PinConfig)  
*Initializes the specified GPIO pin according to the provided configuration.*
- void **MCAL\_GPIO\_DeInit** (**GPIO\_TypeDef** \*GPIOx)  
*Resets the specified GPIO port.*
- uint8 **MCAL\_GPIO\_ReadPin** (**GPIO\_TypeDef** \*GPIOx, uint16 PinNumber)  
*Reads the value of a specific GPIO pin.*
- uint16 **MCAL\_GPIO\_ReadPort** (**GPIO\_TypeDef** \*GPIOx)  
*Reads the value of a specific GPIO port.*
- void **MCAL\_GPIO\_WritePin** (**GPIO\_TypeDef** \*GPIOx, uint16 PinNumber, uint8 Value)  
*Writes a value to a specific GPIO pin.*
- void **MCAL\_GPIO\_WritePort** (**GPIO\_TypeDef** \*GPIOx, uint16 Value)  
*Writes a value to the entire GPIO port.*
- void **MCAL\_GPIO\_TogglePin** (**GPIO\_TypeDef** \*GPIOx, uint16 PinNumber)  
*Toggles the value of a specific GPIO pin.*
- void **MCAL\_GPIO\_TogglePort** (**GPIO\_TypeDef** \*GPIOx)  
*Toggles the value of a specific GPIO Port.*
- uint8 **MCAL\_GPIO\_LockPin** (**GPIO\_TypeDef** \*GPIOx, uint16 PinNumber)  
*Locks the configuration of a specific GPIO pin.*

### 7.25.1 Detailed Description

GPIO driver for STM32F401xx microcontroller.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file contains the implementations for GPIO operations for the STM32F401xx microcontroller. It includes initialization, de-initialization, and basic operations for GPIO pins and ports.

#### Copyright

Copyright (c) 2024

## 7.26 drivers/Src/stm32f401xx\_i2c\_driver.c File Reference

I2C Peripheral Driver Implementation for STM32F103C6.

```
#include "stm32f401xx_i2c_driver.h"
#include "stm32f401xx_usart_driver.h"
#include "stm32f401xx_rcc_driver.h"
Include dependency graph for stm32f401xx_i2c_driver.c:
```



## Macros

- #define I2C1\_Index 0
- #define I2C2\_Index 1

## Functions

- void `MCAL_I2C_Init (I2C_TypeDef *I2Cx, S_I2C_Config_t *I2C_Init_Struct)`  
*Initializes the I2C peripheral.*
- void `MCAL_I2C_Deinit (I2C_TypeDef *I2Cx)`  
*De-initializes the I2C peripheral.*
- void `MCAL_I2C_Set_GPIO (I2C_TypeDef *I2Cx)`  
*Configures GPIO pins for I2C functionality.*
- void `MCAL_I2C_Master_Tx (I2C_TypeDef *I2Cx, uint16_t SlaveAdd, uint8_t *dataout, uint32_t datalen, StopCondition Stop, Repeated_Start start)`  
*Transmits data from the I2C master to a slave device.*
- void `MCAL_I2C_Master_Rx (I2C_TypeDef *I2Cx, uint16_t SlaveAdd, uint8_t *dataout, uint32_t datalen, StopCondition Stop, Repeated_Start start)`  
*Receives data from an I2C slave device.*
- void `I2C_Generate_Start (I2C_TypeDef *I2Cx, Functional_State state, Repeated_Start start)`  
*Generates a start condition or a repeated start condition.*
- void `I2C_AcknowledgeConfig (I2C_TypeDef *I2Cx, Functional_State NewState)`  
*Configures the acknowledgment feature of the I2C peripheral.*
- `FlagStatus I2C_Get_FlagStatus (I2C_TypeDef *I2Cx, Status flag)`  
*Checks the status of I2C flags.*
- void `I2C_SendAddress (I2C_TypeDef *I2Cx, uint16_t SlaveAddress, I2C_Direction Direction)`  
*Sends a 7-bit slave address to the I2C peripheral.*
- void `I2C_Generate_Stop (I2C_TypeDef *I2Cx, Functional_State NewState)`  
*Generates a stop condition on the I2C bus.*
- void `MCAL_I2C_Slave_SendData (I2C_TypeDef *I2Cx, uint8_t data)`  
*Sends a single byte of data in slave mode.*
- uint8\_t `MCAL_I2C_SlaveReceiveData (I2C_TypeDef *I2Cx)`  
*Receives a single byte of data in slave mode.*

## Variables

- `S_I2C_Config_t Global_I2C_Config [2]`

### 7.26.1 Detailed Description

I2C Peripheral Driver Implementation for STM32F103C6.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file implements the driver functions for the I2C (Inter-Integrated Circuit) peripheral of the STM32F103C6 microcontroller. The driver includes functions for initialization, de-initialization, data transmission, and reception. Additionally, it provides utility functions to facilitate I2C operations.

#### Copyright

Copyright (c) 2023 Fam Ayman. All rights reserved.

## 7.26.2 Macro Definition Documentation

### 7.26.2.1 I2C1\_Index

```
#define I2C1_Index 0
```

Index for I2C1 peripheral.

### 7.26.2.2 I2C2\_Index

```
#define I2C2_Index 1
```

Index for I2C2 peripheral.

## 7.26.3 Variable Documentation

### 7.26.3.1 Global\_I2C\_Config

```
S_I2C_Config_t Global_I2C_Config[2]
```

Global array to hold I2C configurations.

## 7.27 drivers/Src/stm32f401xx\_spi\_driver.c File Reference

Contains the implementation of the SPI driver APIs for STM32F401.

```
#include "stm32f401xx_rcc_driver.h"
#include "stm32f401xx_spi_driver.h"
#include "stm32f401xx.h"
Include dependency graph for stm32f401xx_spi_driver.c:
```



## Macros

- `#define SPI1_Index 0`  
*Macro definitions for SPI indices and status flags.*
- `#define SPI2_Index 1`
- `#define SPI_SR_TXE (uint8_t)(1 << 1)`
- `#define SPI_SR_RXNE (uint8_t)(1 << 0)`

## Functions

- `void MCAL_SPI_Init (SPI_TypeDef *SPIx, S_SPI_Config_t *Config)`  
*Initializes the SPI peripheral.*
- `void MCAL_SPI_DeInit (SPI_TypeDef *SPIx)`  
*Deinitializes the SPI peripheral.*
- `void MCAL_SPI_SendData (SPI_TypeDef *SPIx, uint16_t *pTXBuffer, enum SPI_PollingMechanism Polling_En)`  
*Sends data through the SPI peripheral.*
- `void MCAL_SPI_ReceiveData (SPI_TypeDef *SPIx, uint16_t *pRXBuffer, enum SPI_PollingMechanism Polling_En)`  
*Receives data from the SPI peripheral.*
- `void MCAL_SPI_GPIO_Set_Pins (SPI_TypeDef *SPIx)`  
*Configures GPIO pins for SPI communication based on SPI peripheral.*
- `void MCAL_SPI_Tx_Rx (SPI_TypeDef *SPIx, uint16_t *TX_RX_pBuffer, enum SPI_PollingMechanism Polling_En)`  
*Transmit and receive data through SPI.*
- `void SPI1_IRQHandler (void)`  
*SPI1 interrupt handler.*
- `void SPI2_IRQHandler (void)`  
*SPI2 interrupt handler.*

## Variables

- `S_SPI_Config_t * Global_SPI_Config [2] = {NULL, NULL}`  
*Global array to hold SPI configurations.*

### 7.27.1 Detailed Description

Contains the implementation of the SPI driver APIs for STM32F401.

#### Version

0.1

#### Date

2024-09-21

#### Copyright

Copyright (c) 2024

This file provides the implementation of the APIs for configuring and using the SPI (Serial Peripheral Interface) module of the STM32F401 microcontroller. It includes initialization, deinitialization, data transmission, and reception functions, as well as GPIO pin configuration and IRQ handling.

## 7.27.2 Macro Definition Documentation

### 7.27.2.1 SPI1\_Index

```
#define SPI1_Index 0
```

Macro definitions for SPI indices and status flags.

Index for SPI1 in Global\_SPI\_Config array

### 7.27.2.2 SPI2\_Index

```
#define SPI2_Index 1
```

Index for SPI2 in Global\_SPI\_Config array

### 7.27.2.3 SPI\_SR\_RXNE

```
#define SPI_SR_RXNE (uint8_t)(1 << 0)
```

SPI Status Register RXNE flag

### 7.27.2.4 SPI\_SR\_TXE

```
#define SPI_SR_TXE (uint8_t)(1 << 1)
```

SPI Status Register TXE flag

## 7.27.3 Function Documentation

### 7.27.3.1 SPI1\_IRQHandler()

```
void SPI1_IRQHandler (
    void )
```

SPI1 interrupt handler.

This function handles the interrupt for SPI1. It retrieves the interrupt status (TXE, RXE, and ERRI) and calls the appropriate callback function.

## Return values

*None*

### 7.27.3.2 SPI2\_IRQHandler()

```
void SPI2_IRQHandler (
```

## SPI2 interrupt handler.

This function handles the interrupt for SPI2. It retrieves the interrupt status (TXE, RXE, and ERRI) and calls the appropriate callback function.

## Return values

*None*

#### **7.27.4 Variable Documentation**

#### **7.27.4.1 Global\_SPI\_Config**

```
S_SPI_Config_t* Global_SPI_Config[2] = {NULL, NULL}
```

Global array to hold SPI configurations.

This array holds pointers to SPI configurations for SPI1 and SPI2.

- Index 0: SPI1 configuration
  - Index 1: SPI2 configuration

## 7.28 Inc/app\_states.h File Reference

Header file containing definitions and macros for managing application states on the STM32F401xx MCU.

```
#include "ecu.h"
```

Include dependency graph for app\_states.h:



This graph shows which files directly or indirectly include this file:



## Macros

- `#define STATE_API(_NAME) void ST_##_NAME(void)`  
*Macro to define a state handler function.*
- `#define STATE_NAME(_NAME) ST_##_NAME`  
*Macro to create a state handler function name.*

## Enumerations

- `enum STATES {  
 Init_STATE , Admin_STATE , Idle_STATE , Enter_Gate_STATE ,  
 Exit_Gate_STATE , Full_STATE }`  
*Enum representing various application states.*

## Functions

- `STATE_API (Init_STATE)`  
*Handler function for the initialization state.*
- `STATE_API (Admin_STATE)`  
*Handler function for the administration state.*
- `STATE_API (Idle_STATE)`  
*Handler function for the idle state.*
- `STATE_API (Enter_Gate_STATE)`  
*Handler function for the entering gate state.*
- `STATE_API (Exit_Gate_STATE)`  
*Handler function for the exiting gate state.*
- `STATE_API (Full_STATE)`  
*Handler function for the full state.*

## Variables

- `void(* fp_App_State_Handler)()`  
*Function pointer for the current application state handler.*

### 7.28.1 Detailed Description

Header file containing definitions and macros for managing application states on the STM32F401xx MCU.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file provides definitions for the application states and macros used in managing these states for the STM32F401xx microcontroller. It includes state definitions and function pointer declarations for handling different application states.

#### Copyright

Copyright (c) 2024

## 7.29 Inc/ecu.h File Reference

Header file containing all the necessary information about the STM32F401xx MCU.

```
#include "servo_motor_driver.h"
#include "lcd_driver.h"
#include "led_driver.h"
#include "keypad_driver.h"
#include "eeprom_flash.h"
Include dependency graph for ecu.h:
```



This graph shows which files directly or indirectly include this file:



## Macros

- `#define NO_OF_SLOTS 3`  
*Number of parking slots.*
- `#define USERS_COUNT 3`  
*Total number of users.*
- `#define USER1 0`  
*User 1 ID.*
- `#define USER2 1`  
*User 2 ID.*
- `#define USER3 2`  
*User 3 ID.*
- `#define ENTER_USART_INSTANT USART1`  
*Enter gate USART instance.*
- `#define EXIT_USART_INSTANT USART2`  
*Exit gate USART instance.*
- `#define ENTER_PIR_PORT GPIOA`  
*Enter gate PIR sensor GPIO port.*
- `#define ENTER_PIR_PIN GPIO_PIN_7`  
*Enter gate PIR sensor GPIO pin.*
- `#define EXIT_PIR_PORT GPIOA`  
*Exit gate PIR sensor GPIO port.*
- `#define EXIT_PIR_PIN GPIO_PIN_1`  
*Exit gate PIR sensor GPIO pin.*

## Enumerations

- enum `ID_Check_Result { ID_NOT_Found , ID_Found }`

## Functions

- void `ECU_Init` (void)  
*Initializes all hardware components and peripherals.*
- void `Admin_Init` (void)  
*Initializes the admin settings, including setting up user IDs.*
- void `UserLCD_PrintFreeSlots` (void)  
*Prints the number of free parking slots on the LCD.*
- `ID_Check_Result Check_ID` (`uint8 _ID`)  
*Checks if the given ID exists in the system.*
- `uint8 Check_Flag` (`uint8 _ID`)  
*Returns the status flag associated with the given ID.*
- void `Flag_SET_RESET` (`uint8 _ID`)  
*Toggles the flag associated with the given ID.*
- `uint8 Check_Password` (`uint8 _ID`)  
*Checks if the entered password matches the stored password for the given ID.*
- void `combineArrays` (`uint8_t *array1, int size1, uint8_t *array2, int size2, uint8_t *array3, int size3, uint8_t *array4, int size4, uint8_t *combinedArray`)  
*Combines four arrays into a single array.*
- void `Enter_Gate_Open` (void)  
*Opens the entrance gate and displays the status on the LCD.*
- void `Exit_Gate_Open` (void)  
*Opens the exit gate and displays the status on the LCD.*
- void `Wrong_RFID` (void)  
*Triggers the alarm and prints "UNKNOWN ID!" on the LCD.*
- void `Trigger_Alarm` (`USART_TypeDef *_USART`)  
*Echoes the entered ID via USART and flashes the red LED.*

### 7.29.1 Detailed Description

Header file containing all the necessary information about the STM32F401xx MCU.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file contains the definitions and macros for the STM32F401xx microcontroller peripherals and memory maps. It also provides APIs for the initialization and management of key hardware components and system peripherals used in the application.

#### Copyright

Copyright (c) 2024

## 7.30 Src/app\_states.c File Reference

Application state machine implementation for managing entry/exit gates and parking slots using the STM32F401xx MCU.

```
#include "app_states.h"
```

Include dependency graph for app\_states.c:



## Functions

- **STATE\_API (Init\_STATE)**  
*Initializes the system and sets up the initial state.*
- **STATE\_API (Admin\_STATE)**  
*Admin state to initialize the user IDs and prepare the system.*
- **STATE\_API (Idle\_STATE)**  
*Idle state where the system waits for user input (entry/exit requests).*
- **STATE\_API (Enter\_Gate\_STATE)**  
*Handles the logic for opening the entry gate.*
- **STATE\_API (Exit\_Gate\_STATE)**  
*Handles the logic for opening the exit gate.*
- **STATE\_API (Full\_STATE)**  
*Full state where the parking lot is full, and no entry is allowed.*

## Variables

- volatile uint8 Enter\_Flag  
*Flags and variables used for managing system state.*
- volatile uint8 Exit\_Flag  
*Flags for entry and exit state triggers.*
- uint8 Free\_Slots  
*Available parking slots and LCD print flag.*
- uint8 Print\_Slots\_LCD\_Flag  
*Function pointer to manage current state transitions.*
- STATES\_APP\_Current\_State  
*Current application state.*

### 7.30.1 Detailed Description

Application state machine implementation for managing entry/exit gates and parking slots using the STM32F401xx MCU.

#### Author

Mohamed Ali Haoufa

#### Version

0.1

#### Date

2024-09-21

This file defines the application states and associated functions to manage the parking system, including initializing the system, handling user entry/exit, and updating the number of available parking slots.

#### Copyright

Copyright (c) 2024

## 7.31 Src/ecu.c File Reference

Header file containing all necessary information and functionality for managing STM32F401xx MCU-based peripherals.

```
#include "ecu.h"
Include dependency graph for ecu.c:
```



## Macros

- #define **SIZE1** 3  
*Definitions for combining arrays.*
- #define **SIZE2** 4
- #define **SIZE3** 4
- #define **SIZE4** 4
- #define **TOTAL\_SIZE** (**SIZE1** + **SIZE2** + **SIZE3** + **SIZE4**)

## Functions

- void [Enter\\_UART\\_CallBack \(void\)](#)  
*Callback function for handling entry UART events.*
- void [Exit\\_UART\\_CallBack \(void\)](#)  
*Callback function for handling exit UART events.*
- void [ECU\\_Init \(void\)](#)  
*Initializes all hardware components and peripherals.*
- void [Admin\\_Init \(void\)](#)  
*Initializes user IDs and displays them on the LCD.*
- void [UserLCD\\_PrintFreeSlots \(void\)](#)  
*Prints the number of free slots on the UserLCD.*
- [ID\\_Check\\_Result Check\\_ID \(uint8 \\_ID\)](#)  
*Checks if the given ID is present in the saved IDs.*
- [uint8 Check\\_Flag \(uint8 \\_ID\)](#)  
*Returns the status flag associated with the given ID.*
- void [Flag\\_SET\\_RESET \(uint8 \\_ID\)](#)  
*Toggles the flag associated with the given ID.*
- [uint8 Check\\_Password \(uint8 \\_ID\)](#)  
*Checks if the entered password matches the stored password for the given ID.*
- void [combineArrays \(uint8\\_t \\*array1, int size1, uint8\\_t \\*array2, int size2, uint8\\_t \\*array3, int size3, uint8\\_t \\*array4, int size4, uint8\\_t \\*combinedArray\)](#)  
*Combines four arrays into a single array.*
- void [Enter\\_Gate\\_Open \(void\)](#)  
*Opens the entry gate and displays a message on the LCD.*
- void [Exit\\_Gate\\_Open \(void\)](#)  
*Opens the exit gate and displays a message on the LCD.*
- void [Wrong\\_RFID \(void\)](#)  
*Triggers an alarm and displays an "UNKNOWN ID!" message on the LCD.*
- void [Trigger\\_Alarm \(USART\\_TypeDef \\*\\_USART\)](#)  
*Triggers an alarm by echoing the received ID on UART and flashing the red LED.*

## Variables

- volatile uint8 [Enter\\_Flag](#)  
*Flags and variables used for managing system state.*
- volatile uint8 [Exit\\_Flag](#)
- [uint8 Free\\_Slots = 3](#)
- [uint8 Print\\_Slots\\_LCD\\_Flag](#)

### 7.31.1 Detailed Description

Header file containing all necessary information and functionality for managing STM32F401xx MCU-based peripherals.

Contains the main program logic for managing STM32F401xx MCU-based peripherals.

#### Author

Mohamed Ali Haoufa

**Version**

0.1

**Date**

2024-09-21

This file contains the initialization and control logic for peripherals including LEDs, LCDs, UART, PIR sensors, and servo motors.

**Copyright**

Copyright (c) 2024

**Author**

Mohamed Ali Haoufa

**Version**

0.1

**Date**

2024-09-21

This file includes the initialization and control logic for peripherals such as LEDs, LCDs, UART, PIR sensors, and servo motors. It operates the system based on a state machine, managing various hardware components.

**Copyright**

Copyright (c) 2024 Mohamed Ali Haoufa. All rights reserved.

## 7.32 Src/sysmem.c File Reference

STM32CubeIDE System Memory calls file.

```
#include <errno.h>
#include <stdint.h>
```

Include dependency graph for sysmem.c:



## Functions

- void \* [\\_sbrk](#) (ptrdiff\_t incr)

[\\_sbrk\(\)](#) allocates memory to the newlib heap and is used by malloc and others from the C library

### 7.32.1 Detailed Description

STM32CubeIDE System Memory calls file.

#### Author

Auto-generated by STM32 VS Code Extension

For more information about which C functions  
need which of these lowlevel functions  
please consult the newlib libc manual

#### Attention

Copyright (c) 2023 STMicroelectronics. All rights reserved.

This software is licensed under terms that can be found in the LICENSE file in the root directory of this software component. If no LICENSE file comes with this software, it is provided AS-IS.

### 7.32.2 Function Documentation

#### 7.32.2.1 [\\_sbrk\(\)](#)

```
void* _sbrk (
    ptrdiff_t incr )
```

[\\_sbrk\(\)](#) allocates memory to the newlib heap and is used by malloc and others from the C library

```
* ##### .data # .bss #      newlib heap      #          MSP stack      #
* #      #      #                      # Reserved by _Min_Stack_Size #
* ##### #      ##### #      ##### #      ##### #      ##### #      ##### #
* ^-- RAM start      ^-- _end                  _estack, RAM end --^
*
```

This implementation starts allocating at the '\_end' linker symbol. The '\_Min\_Stack\_Size' linker symbol reserves a memory for the MSP stack. The implementation considers '\_estack' linker symbol to be RAM end. NOTE: If the MSP stack, at any point during execution, grows larger than the reserved size, please increase the '\_Min\_Stack\_Size'.

**Parameters**

|             |             |
|-------------|-------------|
| <i>incr</i> | Memory size |
|-------------|-------------|

**Returns**

Pointer to allocated memory

## 7.33 Src/system\_stm32f4xx.c File Reference

CMSIS Cortex-M4 Device Peripheral Access Layer System Source File. This file contains the system clock configuration for STM32F4xx devices.

```
#include "stm32f4xx.h"
Include dependency graph for system_stm32f4xx.c:
```



## Macros

- #define VECT\_TAB\_OFFSET 0x00
- #define PLL\_Q 7

## Functions

- void [SystemInit](#)(void)  
*Setup the microcontroller system Initialize the Embedded Flash Interface, the PLL and update the SystemFrequency variable.*
- void [SystemInit\\_Old](#)(void)
- void [SystemCoreClockUpdate](#)(void)  
*Update SystemCoreClock variable according to Clock Register Values. The SystemCoreClock variable contains the core clock (HCLK), it can be used by the user application to setup the SysTick timer or configure other parameters.*

## Variables

- `__I uint8_t AHBPrescTable [16] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9}`

### 7.33.1 Detailed Description

CMSIS Cortex-M4 Device Peripheral Access Layer System Source File. This file contains the system clock configuration for STM32F4xx devices.

#### Author

MCD Application Team

#### Version

V1.8.0

#### Date

09-November-2016

1. This file provides two functions and one global variable to be called from user application:
  - `SystemInit()`: Setsups the system clock (System clock source, PLL Multiplier and Divider factors, AHB/APBx prescalers and Flash settings), depending on the configuration made in the clock xls tool. This function is called at startup just after reset and before branch to main program. This call is made inside the "startup\_stm32f4xx.s" file.
  - `SystemCoreClock` variable: Contains the core clock (HCLK), it can be used by the user application to setup the SysTick timer or configure other parameters.
  - `SystemCoreClockUpdate()`: Updates the variable `SystemCoreClock` and must be called whenever the core clock is changed during program execution.
2. After each device reset the HSI (16 MHz) is used as system clock source. Then `SystemInit()` function is called, in "startup\_stm32f4xx.s" file, to configure the system clock before to branch to main program.
3. If the system clock source selected by user fails to startup, the `SystemInit()` function will do nothing and HSI still used as system clock source. User can add some code to deal with this issue inside the `SetSysClock()` function.
4. The default value of HSE crystal is set to 25MHz, refer to "HSE\_VALUE" define in "stm32f4xx.h" file. When HSE is used as system clock source, directly or through PLL, and you are using different crystal you have to adapt the HSE value to your own configuration.

### 7.33.2 5. This file configures the system clock as follows:

=====

7.33.2.1 Supported STM32F40xxx/41xxx devices

7.33.2.2 System Clock source | PLL (HSE)

7.33.2.3 SYSCLK(Hz) | 168000000

7.33.2.4 HCLK(Hz) | 168000000

7.33.2.5 AHB Prescaler | 1

7.33.2.6 APB1 Prescaler | 4

7.33.2.7 APB2 Prescaler | 2

7.33.2.8 HSE Frequency(Hz) | 25000000

7.33.2.9 PLL\_M | 25

7.33.2.10 PLL\_N | 336

7.33.2.11 PLL\_P | 2

7.33.2.12 PLL\_Q | 7

7.33.2.13 PLLI2S\_N | NA

7.33.2.14 PLLI2S\_R | NA

7.33.2.15 I2S input clock | NA

7.33.2.16 VDD(V) | 3.3

7.33.2.17 Main regulator output voltage | Scale1 mode

7.33.2.18 Flash Latency(WS) | 5

7.33.2.19 Prefetch Buffer | ON

7.33.2.20 Instruction cache | ON

7.33.2.21 Data cache | ON

Require 48MHz for USB OTG FS, | Disabled

7.33.2.22 SDIO and RNG clock |

7.33.3 =====

7.33.3.1 Supported STM32F42xxx/43xxx devices

7.33.3.2 System Clock source | PLL (HSE)

7.33.3.3 SYSCLK(Hz) | 180000000

7.33.3.4 HCLK(Hz) | 180000000

7.33.3.5 AHB Prescaler | 1

7.33.3.6 APB1 Prescaler | 4

7.33.3.7 APB2 Prescaler | 2

7.33.3.8 HSE Frequency(Hz) | 25000000

7.33.3.9 PLL\_M | 25

7.33.3.10 PLL\_N | 360

7.33.3.11 PLL\_P | 2

7.33.3.12 PLL\_Q | 7

7.33.3.13 PLLI2S\_N | NA

7.33.3.14 PLLI2S\_R | NA

7.33.3.15 I2S input clock | NA

7.33.3.16 VDD(V) | 3.3

7.33.3.17 Main regulator output voltage | Scale1 mode

7.33.3.18 Flash Latency(WS) | 5

7.33.3.19 Prefetch Buffer | ON

7.33.3.20 Instruction cache | ON

7.33.3.21 Data cache | ON

Require 48MHz for USB OTG FS, | Disabled

7.33.3.22 SDIO and RNG clock |

7.33.4 =====

7.33.4.1 Supported STM32F401xx devices

7.33.4.2 System Clock source | PLL (HSE)

7.33.4.3 SYSCLK(Hz) | 84000000

7.33.4.4 HCLK(Hz) | 84000000

7.33.4.5 AHB Prescaler | 1

7.33.4.6 APB1 Prescaler | 2

7.33.4.7 APB2 Prescaler | 1

7.33.4.8 HSE Frequency(Hz) | 25000000

7.33.4.9 PLL\_M | 25

7.33.4.10 PLL\_N | 336

7.33.4.11 PLL\_P | 4

7.33.4.12 PLL\_Q | 7

7.33.4.13 PLLI2S\_N | NA

7.33.4.14 PLLI2S\_R | NA

7.33.4.15 I2S input clock | NA

7.33.4.16 VDD(V) | 3.3

7.33.4.17 Main regulator output voltage | Scale1 mode

7.33.4.18 Flash Latency(WS) | 2

7.33.4.19 Prefetch Buffer | ON

7.33.4.20 Instruction cache | ON

7.33.4.21 Data cache | ON

Require 48MHz for USB OTG FS, | Disabled

7.33.4.22 SDIO and RNG clock |

7.33.5 =====

7.33.5.1 Supported STM32F411xx/STM32F410xx devices

7.33.5.2 System Clock source | PLL (HSI)

7.33.5.3 SYSCLK(Hz) | 100000000

7.33.5.4 HCLK(Hz) | 100000000

7.33.5.5 AHB Prescaler | 1

7.33.5.6 APB1 Prescaler | 2

7.33.5.7 APB2 Prescaler | 1

7.33.5.8 HSI Frequency(Hz) | 16000000

7.33.5.9 PLL\_M | 16

7.33.5.10 PLL\_N | 400

7.33.5.11 PLL\_P | 4

7.33.5.12 PLL\_Q | 7

7.33.5.13 PLLI2S\_N | NA

7.33.5.14 PLLI2S\_R | NA

7.33.5.15 I2S input clock | NA

7.33.5.16 VDD(V) | 3.3

7.33.5.17 Main regulator output voltage | Scale1 mode

7.33.5.18 Flash Latency(WS) | 3

7.33.5.19 Prefetch Buffer | ON

7.33.5.20 Instruction cache | ON

7.33.5.21 Data cache | ON

Require 48MHz for USB OTG FS, | Disabled

7.33.5.22 SDIO and RNG clock |

## 7.33.6 =====

7.33.6.1 Supported STM32F446xx devices

7.33.6.2 System Clock source | PLL (HSE)

7.33.6.3 SYSCLK(Hz) | 180000000

7.33.6.4 HCLK(Hz) | 180000000

7.33.6.5 AHB Prescaler | 1

7.33.6.6 APB1 Prescaler | 4

7.33.6.7 APB2 Prescaler | 2

7.33.6.8 HSE Frequency(Hz) | 8000000

7.33.6.9 PLL\_M | 8

7.33.6.10 PLL\_N | 360

7.33.6.11 PLL\_P | 2

7.33.6.12 PLL\_Q | 7

7.33.6.13 PLL\_R | NA

7.33.6.14 PLLI2S\_M | NA

7.33.6.15 PLLI2S\_N | NA

7.33.6.16 PLLI2S\_P | NA

7.33.6.17 PLLI2S\_Q | NA

7.33.6.18 PLLI2S\_R | NA

7.33.6.19 I2S input clock | NA

7.33.6.20 VDD(V) | 3.3

7.33.6.21 Main regulator output voltage | Scale1 mode

7.33.6.22 Flash Latency(WS) | 5

7.33.6.23 Prefetch Buffer | ON

7.33.6.24 Instruction cache | ON

7.33.6.25 Data cache | ON

Require 48MHz for USB OTG FS, | Disabled

### 7.33.6.26 SDIO and RNG clock |

---

=====

Attention

© COPYRIGHT 2016 STMicroelectronics

Licensed under MCD-ST Liberty SW License Agreement V2, (the "License"); You may not use this file except in compliance with the License. You may obtain a copy of the License at:

[http://www.st.com/software\\_license\\_agreement\\_liberty\\_v2](http://www.st.com/software_license_agreement_liberty_v2)

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

# Index

\_\_CM4\_CMSIS\_VERSION  
    CMSIS, [398](#)  
\_\_CM4\_CMSIS\_VERSION\_MAIN  
    CMSIS, [398](#)  
\_\_CM4\_CMSIS\_VERSION\_SUB  
    CMSIS, [398](#)  
\_\_CM4\_REV  
    Configuration\_section\_for\CMSIS, [523](#)  
\_\_CORE\_CM4\_H\_DEPENDANT  
    CMSIS, [398](#)  
\_\_CORTEX\_M  
    CMSIS, [399](#)  
\_\_FPU\_PRESENT  
    Configuration\_section\_for\CMSIS, [523](#)  
\_I  
    CMSIS, [399](#)  
\_IO  
    CMSIS, [399](#)  
\_MPU\_PRESENT  
    Configuration\_section\_for\CMSIS, [523](#)  
\_NVIC\_PRIO\_BITS  
    Configuration\_section\_for\CMSIS, [524](#)  
\_O  
    CMSIS, [399](#)  
\_STM32F4XX\_STDPERIPH\_VERSION  
    Library\_configuration\_section, [520](#)  
\_STM32F4XX\_STDPERIPH\_VERSION\_MAIN  
    Library\_configuration\_section, [521](#)  
\_STM32F4XX\_STDPERIPH\_VERSION\_RC  
    Library\_configuration\_section, [521](#)  
\_STM32F4XX\_STDPERIPH\_VERSION\_SUB1  
    Library\_configuration\_section, [521](#)  
\_STM32F4XX\_STDPERIPH\_VERSION\_SUB2  
    Library\_configuration\_section, [521](#)  
\_Vendor\_SysTickConfig  
    Configuration\_section\_for\CMSIS, [524](#)  
\_reserved0  
    ITM Functions, [124, 125](#)  
\_reserved1  
    ITM Functions, [125, 126](#)  
\_sbrk  
    sysmem.c, [1232](#)  
  
ACPR  
    ITM Functions, [126](#)  
ACR  
    CMSIS, [461](#)  
ACTLR  
    ITM Functions, [126](#)  
ADC\_CCR\_ADCPRE  
    Peripheral\_Registers\_Bits\_Definition, [623](#)  
ADC\_CCR\_ADCPRE\_0  
    Peripheral\_Registers\_Bits\_Definition, [623](#)  
ADC\_CCR\_ADCPRE\_1  
    Peripheral\_Registers\_Bits\_Definition, [623](#)  
ADC\_CCR\_DDS  
    Peripheral\_Registers\_Bits\_Definition, [624](#)  
ADC\_CCR\_DELAY  
    Peripheral\_Registers\_Bits\_Definition, [624](#)  
ADC\_CCR\_DELAY\_0  
    Peripheral\_Registers\_Bits\_Definition, [624](#)  
ADC\_CCR\_DELAY\_1  
    Peripheral\_Registers\_Bits\_Definition, [624](#)  
ADC\_CCR\_DELAY\_2  
    Peripheral\_Registers\_Bits\_Definition, [624](#)  
ADC\_CCR\_DELAY\_3  
    Peripheral\_Registers\_Bits\_Definition, [624](#)  
ADC\_CCR\_DMA  
    Peripheral\_Registers\_Bits\_Definition, [624](#)  
ADC\_CCR\_DMA\_0  
    Peripheral\_Registers\_Bits\_Definition, [624](#)  
ADC\_CCR\_DMA\_1  
    Peripheral\_Registers\_Bits\_Definition, [625](#)  
ADC\_CCR\_MULTI  
    Peripheral\_Registers\_Bits\_Definition, [625](#)  
ADC\_CCR\_MULTI\_0  
    Peripheral\_Registers\_Bits\_Definition, [625](#)  
ADC\_CCR\_MULTI\_1  
    Peripheral\_Registers\_Bits\_Definition, [625](#)  
ADC\_CCR\_MULTI\_2  
    Peripheral\_Registers\_Bits\_Definition, [625](#)  
ADC\_CCR\_MULTI\_3  
    Peripheral\_Registers\_Bits\_Definition, [625](#)  
ADC\_CCR\_MULTI\_4  
    Peripheral\_Registers\_Bits\_Definition, [625](#)  
ADC\_CCR\_TSVREFE  
    Peripheral\_Registers\_Bits\_Definition, [625](#)  
ADC\_CCR\_VBATE  
    Peripheral\_Registers\_Bits\_Definition, [626](#)  
ADC\_CDR\_DATA1  
    Peripheral\_Registers\_Bits\_Definition, [626](#)  
ADC\_CDR\_DATA2  
    Peripheral\_Registers\_Bits\_Definition, [626](#)  
ADC\_Common\_TypeDef  
    [999](#)  
ADC\_CR1\_AWDCH  
    Peripheral\_Registers\_Bits\_Definition, [626](#)  
ADC\_CR1\_AWDCH\_0  
    Peripheral\_Registers\_Bits\_Definition, [626](#)  
ADC\_CR1\_AWDCH\_1  
    Peripheral\_Registers\_Bits\_Definition, [626](#)

Peripheral\_Registers\_Bits\_Definition, 626  
ADC\_CR1\_AWDCH\_2  
    Peripheral\_Registers\_Bits\_Definition, 626  
ADC\_CR1\_AWDCH\_3  
    Peripheral\_Registers\_Bits\_Definition, 626  
ADC\_CR1\_AWDCH\_4  
    Peripheral\_Registers\_Bits\_Definition, 627  
ADC\_CR1\_AWDEN  
    Peripheral\_Registers\_Bits\_Definition, 627  
ADC\_CR1\_AWDIE  
    Peripheral\_Registers\_Bits\_Definition, 627  
ADC\_CR1\_AWDSGL  
    Peripheral\_Registers\_Bits\_Definition, 627  
ADC\_CR1\_DISCEN  
    Peripheral\_Registers\_Bits\_Definition, 627  
ADC\_CR1\_DISCNUM  
    Peripheral\_Registers\_Bits\_Definition, 627  
ADC\_CR1\_DISCNUM\_0  
    Peripheral\_Registers\_Bits\_Definition, 627  
ADC\_CR1\_DISCNUM\_1  
    Peripheral\_Registers\_Bits\_Definition, 628  
ADC\_CR1\_DISCNUM\_2  
    Peripheral\_Registers\_Bits\_Definition, 628  
ADC\_CR1\_EOCIE  
    Peripheral\_Registers\_Bits\_Definition, 628  
ADC\_CR1\_JAUTO  
    Peripheral\_Registers\_Bits\_Definition, 628  
ADC\_CR1\_JAWDEN  
    Peripheral\_Registers\_Bits\_Definition, 628  
ADC\_CR1\_JDISCEN  
    Peripheral\_Registers\_Bits\_Definition, 628  
ADC\_CR1\_JEOCIE  
    Peripheral\_Registers\_Bits\_Definition, 628  
ADC\_CR1\_OVRIE  
    Peripheral\_Registers\_Bits\_Definition, 629  
ADC\_CR1\_RES  
    Peripheral\_Registers\_Bits\_Definition, 629  
ADC\_CR1\_RES\_0  
    Peripheral\_Registers\_Bits\_Definition, 629  
ADC\_CR1\_RES\_1  
    Peripheral\_Registers\_Bits\_Definition, 629  
ADC\_CR1\_SCAN  
    Peripheral\_Registers\_Bits\_Definition, 629  
ADC\_CR2\_ADON  
    Peripheral\_Registers\_Bits\_Definition, 629  
ADC\_CR2\_ALIGN  
    Peripheral\_Registers\_Bits\_Definition, 629  
ADC\_CR2\_CONT  
    Peripheral\_Registers\_Bits\_Definition, 630  
ADC\_CR2\_DDS  
    Peripheral\_Registers\_Bits\_Definition, 630  
ADC\_CR2\_DMA  
    Peripheral\_Registers\_Bits\_Definition, 630  
ADC\_CR2\_EOCS  
    Peripheral\_Registers\_Bits\_Definition, 630  
ADC\_CR2\_EXTEN  
    Peripheral\_Registers\_Bits\_Definition, 630  
ADC\_CR2\_EXTEN\_0  
    Peripheral\_Registers\_Bits\_Definition, 630  
ADC\_CR2\_EXTEN\_1  
    Peripheral\_Registers\_Bits\_Definition, 630  
ADC\_CR2\_EXTSEL  
    Peripheral\_Registers\_Bits\_Definition, 631  
ADC\_CR2\_EXTSEL\_0  
    Peripheral\_Registers\_Bits\_Definition, 631  
ADC\_CR2\_EXTSEL\_1  
    Peripheral\_Registers\_Bits\_Definition, 631  
ADC\_CR2\_EXTSEL\_2  
    Peripheral\_Registers\_Bits\_Definition, 631  
ADC\_CR2\_EXTSEL\_3  
    Peripheral\_Registers\_Bits\_Definition, 631  
ADC\_CR2\_JEXTEN  
    Peripheral\_Registers\_Bits\_Definition, 631  
ADC\_CR2\_JEXTEN\_0  
    Peripheral\_Registers\_Bits\_Definition, 631  
ADC\_CR2\_JEXTEN\_1  
    Peripheral\_Registers\_Bits\_Definition, 631  
ADC\_CR2\_JEXTSEL  
    Peripheral\_Registers\_Bits\_Definition, 632  
ADC\_CR2\_JEXTSEL\_0  
    Peripheral\_Registers\_Bits\_Definition, 632  
ADC\_CR2\_JEXTSEL\_1  
    Peripheral\_Registers\_Bits\_Definition, 632  
ADC\_CR2\_JEXTSEL\_2  
    Peripheral\_Registers\_Bits\_Definition, 632  
ADC\_CR2\_JEXTSEL\_3  
    Peripheral\_Registers\_Bits\_Definition, 632  
ADC\_CR2\_JSWSTART  
    Peripheral\_Registers\_Bits\_Definition, 632  
ADC\_CR2\_SWSTART  
    Peripheral\_Registers\_Bits\_Definition, 632  
ADC\_CSR\_AWD1  
    Peripheral\_Registers\_Bits\_Definition, 632  
ADC\_CSR\_AWD2  
    Peripheral\_Registers\_Bits\_Definition, 633  
ADC\_CSR\_AWD3  
    Peripheral\_Registers\_Bits\_Definition, 633  
ADC\_CSR\_EOC1  
    Peripheral\_Registers\_Bits\_Definition, 633  
ADC\_CSR\_EOC2  
    Peripheral\_Registers\_Bits\_Definition, 633  
ADC\_CSR\_EOC3  
    Peripheral\_Registers\_Bits\_Definition, 633  
ADC\_CSR\_JEOC1  
    Peripheral\_Registers\_Bits\_Definition, 633  
ADC\_CSR\_JEOC2  
    Peripheral\_Registers\_Bits\_Definition, 633  
ADC\_CSR\_JEOC3  
    Peripheral\_Registers\_Bits\_Definition, 633  
ADC\_CSR\_JSTRT1  
    Peripheral\_Registers\_Bits\_Definition, 634  
ADC\_CSR\_JSTRT2  
    Peripheral\_Registers\_Bits\_Definition, 634  
ADC\_CSR\_JSTRT3  
    Peripheral\_Registers\_Bits\_Definition, 634  
ADC\_CSR\_OVR1

Peripheral\_Registers\_Bits\_Definition, 634  
ADC\_CSR\_OVR2  
    Peripheral\_Registers\_Bits\_Definition, 634  
ADC\_CSR\_OVR3  
    Peripheral\_Registers\_Bits\_Definition, 634  
ADC\_CSR\_STRT1  
    Peripheral\_Registers\_Bits\_Definition, 634  
ADC\_CSR\_STRT2  
    Peripheral\_Registers\_Bits\_Definition, 634  
ADC\_CSR\_STRT3  
    Peripheral\_Registers\_Bits\_Definition, 635  
ADC\_DR\_ADC2DATA  
    Peripheral\_Registers\_Bits\_Definition, 635  
ADC\_DR\_DATA  
    Peripheral\_Registers\_Bits\_Definition, 635  
ADC\_HTR\_HT  
    Peripheral\_Registers\_Bits\_Definition, 635  
ADC IRQn  
    Configuration\_section\_for\_CMSIS, 525  
ADC\_JDR1\_JDATA  
    Peripheral\_Registers\_Bits\_Definition, 635  
ADC\_JDR2\_JDATA  
    Peripheral\_Registers\_Bits\_Definition, 635  
ADC\_JDR3\_JDATA  
    Peripheral\_Registers\_Bits\_Definition, 635  
ADC\_JDR4\_JDATA  
    Peripheral\_Registers\_Bits\_Definition, 635  
ADC\_JOFR1\_JOFFSET1  
    Peripheral\_Registers\_Bits\_Definition, 636  
ADC\_JOFR2\_JOFFSET2  
    Peripheral\_Registers\_Bits\_Definition, 636  
ADC\_JOFR3\_JOFFSET3  
    Peripheral\_Registers\_Bits\_Definition, 636  
ADC\_JOFR4\_JOFFSET4  
    Peripheral\_Registers\_Bits\_Definition, 636  
ADC\_JSQR\_JL  
    Peripheral\_Registers\_Bits\_Definition, 636  
ADC\_JSQR\_JL\_0  
    Peripheral\_Registers\_Bits\_Definition, 636  
ADC\_JSQR\_JL\_1  
    Peripheral\_Registers\_Bits\_Definition, 636  
ADC\_JSQR\_JSQ1  
    Peripheral\_Registers\_Bits\_Definition, 636  
ADC\_JSQR\_JSQ1\_0  
    Peripheral\_Registers\_Bits\_Definition, 637  
ADC\_JSQR\_JSQ1\_1  
    Peripheral\_Registers\_Bits\_Definition, 637  
ADC\_JSQR\_JSQ1\_2  
    Peripheral\_Registers\_Bits\_Definition, 637  
ADC\_JSQR\_JSQ1\_3  
    Peripheral\_Registers\_Bits\_Definition, 637  
ADC\_JSQR\_JSQ1\_4  
    Peripheral\_Registers\_Bits\_Definition, 637  
ADC\_JSQR\_JSQ2  
    Peripheral\_Registers\_Bits\_Definition, 637  
ADC\_JSQR\_JSQ2\_0  
    Peripheral\_Registers\_Bits\_Definition, 637  
ADC\_JSQR\_JSQ2\_1  
    Peripheral\_Registers\_Bits\_Definition, 637  
ADC\_JSQR\_JSQ2\_2  
    Peripheral\_Registers\_Bits\_Definition, 638  
ADC\_JSQR\_JSQ2\_3  
    Peripheral\_Registers\_Bits\_Definition, 638  
ADC\_JSQR\_JSQ2\_4  
    Peripheral\_Registers\_Bits\_Definition, 638  
ADC\_JSQR\_JSQ3  
    Peripheral\_Registers\_Bits\_Definition, 638  
ADC\_JSQR\_JSQ3\_0  
    Peripheral\_Registers\_Bits\_Definition, 638  
ADC\_JSQR\_JSQ3\_1  
    Peripheral\_Registers\_Bits\_Definition, 638  
ADC\_JSQR\_JSQ3\_2  
    Peripheral\_Registers\_Bits\_Definition, 638  
ADC\_JSQR\_JSQ3\_3  
    Peripheral\_Registers\_Bits\_Definition, 638  
ADC\_JSQR\_JSQ3\_4  
    Peripheral\_Registers\_Bits\_Definition, 639  
ADC\_JSQR\_JSQ4  
    Peripheral\_Registers\_Bits\_Definition, 639  
ADC\_JSQR\_JSQ4\_0  
    Peripheral\_Registers\_Bits\_Definition, 639  
ADC\_JSQR\_JSQ4\_1  
    Peripheral\_Registers\_Bits\_Definition, 639  
ADC\_JSQR\_JSQ4\_2  
    Peripheral\_Registers\_Bits\_Definition, 639  
ADC\_JSQR\_JSQ4\_3  
    Peripheral\_Registers\_Bits\_Definition, 639  
ADC\_JSQR\_JSQ4\_4  
    Peripheral\_Registers\_Bits\_Definition, 639  
ADC\_LTR\_LT  
    Peripheral\_Registers\_Bits\_Definition, 639  
ADC\_SMPR1\_SMP10  
    Peripheral\_Registers\_Bits\_Definition, 640  
ADC\_SMPR1\_SMP10\_0  
    Peripheral\_Registers\_Bits\_Definition, 640  
ADC\_SMPR1\_SMP10\_1  
    Peripheral\_Registers\_Bits\_Definition, 640  
ADC\_SMPR1\_SMP10\_2  
    Peripheral\_Registers\_Bits\_Definition, 640  
ADC\_SMPR1\_SMP11  
    Peripheral\_Registers\_Bits\_Definition, 640  
ADC\_SMPR1\_SMP11\_0  
    Peripheral\_Registers\_Bits\_Definition, 640  
ADC\_SMPR1\_SMP11\_1  
    Peripheral\_Registers\_Bits\_Definition, 640  
ADC\_SMPR1\_SMP11\_2  
    Peripheral\_Registers\_Bits\_Definition, 640  
ADC\_SMPR1\_SMP12  
    Peripheral\_Registers\_Bits\_Definition, 641  
ADC\_SMPR1\_SMP12\_0  
    Peripheral\_Registers\_Bits\_Definition, 641  
ADC\_SMPR1\_SMP12\_1  
    Peripheral\_Registers\_Bits\_Definition, 641  
ADC\_SMPR1\_SMP12\_2  
    Peripheral\_Registers\_Bits\_Definition, 641  
ADC\_SMPR1\_SMP13





Peripheral\_Registers\_Bits\_Definition, 656  
ADC\_SQR2\_SQ8  
    Peripheral\_Registers\_Bits\_Definition, 656  
ADC\_SQR2\_SQ8\_0  
    Peripheral\_Registers\_Bits\_Definition, 656  
ADC\_SQR2\_SQ8\_1  
    Peripheral\_Registers\_Bits\_Definition, 656  
ADC\_SQR2\_SQ8\_2  
    Peripheral\_Registers\_Bits\_Definition, 656  
ADC\_SQR2\_SQ8\_3  
    Peripheral\_Registers\_Bits\_Definition, 656  
ADC\_SQR2\_SQ8\_4  
    Peripheral\_Registers\_Bits\_Definition, 656  
ADC\_SQR2\_SQ9  
    Peripheral\_Registers\_Bits\_Definition, 656  
ADC\_SQR2\_SQ9\_0  
    Peripheral\_Registers\_Bits\_Definition, 657  
ADC\_SQR2\_SQ9\_1  
    Peripheral\_Registers\_Bits\_Definition, 657  
ADC\_SQR2\_SQ9\_2  
    Peripheral\_Registers\_Bits\_Definition, 657  
ADC\_SQR2\_SQ9\_3  
    Peripheral\_Registers\_Bits\_Definition, 657  
ADC\_SQR2\_SQ9\_4  
    Peripheral\_Registers\_Bits\_Definition, 657  
ADC\_SQR3\_SQ1  
    Peripheral\_Registers\_Bits\_Definition, 657  
ADC\_SQR3\_SQ1\_0  
    Peripheral\_Registers\_Bits\_Definition, 657  
ADC\_SQR3\_SQ1\_1  
    Peripheral\_Registers\_Bits\_Definition, 657  
ADC\_SQR3\_SQ1\_2  
    Peripheral\_Registers\_Bits\_Definition, 658  
ADC\_SQR3\_SQ1\_3  
    Peripheral\_Registers\_Bits\_Definition, 658  
ADC\_SQR3\_SQ1\_4  
    Peripheral\_Registers\_Bits\_Definition, 658  
ADC\_SQR3\_SQ2  
    Peripheral\_Registers\_Bits\_Definition, 658  
ADC\_SQR3\_SQ2\_0  
    Peripheral\_Registers\_Bits\_Definition, 658  
ADC\_SQR3\_SQ2\_1  
    Peripheral\_Registers\_Bits\_Definition, 658  
ADC\_SQR3\_SQ2\_2  
    Peripheral\_Registers\_Bits\_Definition, 658  
ADC\_SQR3\_SQ2\_3  
    Peripheral\_Registers\_Bits\_Definition, 658  
ADC\_SQR3\_SQ2\_4  
    Peripheral\_Registers\_Bits\_Definition, 659  
ADC\_SQR3\_SQ3  
    Peripheral\_Registers\_Bits\_Definition, 659  
ADC\_SQR3\_SQ3\_0  
    Peripheral\_Registers\_Bits\_Definition, 659  
ADC\_SQR3\_SQ3\_1  
    Peripheral\_Registers\_Bits\_Definition, 659  
ADC\_SQR3\_SQ3\_2  
    Peripheral\_Registers\_Bits\_Definition, 659  
ADC\_SQR3\_SQ3\_3  
    Peripheral\_Registers\_Bits\_Definition, 659  
    Peripheral\_Registers\_Bits\_Definition, 659  
ADC\_SQR3\_SQ3\_4  
    Peripheral\_Registers\_Bits\_Definition, 659  
ADC\_SQR3\_SQ4  
    Peripheral\_Registers\_Bits\_Definition, 659  
ADC\_SQR3\_SQ4\_0  
    Peripheral\_Registers\_Bits\_Definition, 660  
ADC\_SQR3\_SQ4\_1  
    Peripheral\_Registers\_Bits\_Definition, 660  
ADC\_SQR3\_SQ4\_2  
    Peripheral\_Registers\_Bits\_Definition, 660  
ADC\_SQR3\_SQ4\_3  
    Peripheral\_Registers\_Bits\_Definition, 660  
ADC\_SQR3\_SQ4\_4  
    Peripheral\_Registers\_Bits\_Definition, 660  
ADC\_SQR3\_SQ5  
    Peripheral\_Registers\_Bits\_Definition, 660  
ADC\_SQR3\_SQ5\_0  
    Peripheral\_Registers\_Bits\_Definition, 660  
ADC\_SQR3\_SQ5\_1  
    Peripheral\_Registers\_Bits\_Definition, 660  
ADC\_SQR3\_SQ5\_2  
    Peripheral\_Registers\_Bits\_Definition, 661  
ADC\_SQR3\_SQ5\_3  
    Peripheral\_Registers\_Bits\_Definition, 661  
ADC\_SQR3\_SQ5\_4  
    Peripheral\_Registers\_Bits\_Definition, 661  
ADC\_SQR3\_SQ6  
    Peripheral\_Registers\_Bits\_Definition, 661  
ADC\_SQR3\_SQ6\_0  
    Peripheral\_Registers\_Bits\_Definition, 661  
ADC\_SQR3\_SQ6\_1  
    Peripheral\_Registers\_Bits\_Definition, 661  
ADC\_SQR3\_SQ6\_2  
    Peripheral\_Registers\_Bits\_Definition, 661  
ADC\_SQR3\_SQ6\_3  
    Peripheral\_Registers\_Bits\_Definition, 661  
ADC\_SQR3\_SQ6\_4  
    Peripheral\_Registers\_Bits\_Definition, 662  
ADC\_SR\_AWD  
    Peripheral\_Registers\_Bits\_Definition, 662  
ADC\_SR\_EOC  
    Peripheral\_Registers\_Bits\_Definition, 662  
ADC\_SR\_JEOC  
    Peripheral\_Registers\_Bits\_Definition, 662  
ADC\_SR\_JSTRT  
    Peripheral\_Registers\_Bits\_Definition, 662  
ADC\_SR\_OVR  
    Peripheral\_Registers\_Bits\_Definition, 662  
ADC\_SR\_STRT  
    Peripheral\_Registers\_Bits\_Definition, 662  
ADC\_TypeDef, 999  
Admin\_Init  
    API\_Definitions, 372  
    ECU APIs, 362  
Admin\_STATE  
    Application States, 352  
ADR

ITM Functions, 126  
AFR  
  CMSIS, 461  
  GPIO\_TypeDef, 1017  
AFSR  
  ITM Functions, 126  
AHB Peripherals Base Addresses, 158  
AHB1ENR  
  CMSIS, 461  
  RCC\_TypeDef, 1033  
AHB1LPENR  
  CMSIS, 461  
  RCC\_TypeDef, 1033  
AHB1RSTR  
  CMSIS, 461  
  RCC\_TypeDef, 1034  
AHB2ENR  
  CMSIS, 461  
  RCC\_TypeDef, 1034  
AHB2LPENR  
  CMSIS, 461  
  RCC\_TypeDef, 1034  
AHB2PERIPH\_BASE  
  Peripheral\_memory\_map, 534  
AHB2RSTR  
  CMSIS, 462  
  RCC\_TypeDef, 1034  
AHB3ENR  
  CMSIS, 462  
AHB3LPENR  
  CMSIS, 462  
AHB3RSTR  
  CMSIS, 462  
AIRCR  
  ITM Functions, 127  
  SCB\_TypeDef, 1047  
ALRMAR  
  CMSIS, 462  
ALRMASSR  
  CMSIS, 462  
ALRMBR  
  CMSIS, 462  
ALRMBSSR  
  CMSIS, 462  
AMTCR  
  CMSIS, 463  
APB1 Peripherals Base Addresses, 159  
APB1ENR  
  CMSIS, 463  
  RCC\_TypeDef, 1034  
APB1FZ  
  CMSIS, 463  
APB1LPENR  
  CMSIS, 463  
  RCC\_TypeDef, 1034  
APB1RSTR  
  CMSIS, 463  
  RCC\_TypeDef, 1034  
APB2 Peripherals Base Addresses, 158  
APB2ENR  
  CMSIS, 463  
  RCC\_TypeDef, 1034  
APB2FZ  
  CMSIS, 463  
APB2LPENR  
  CMSIS, 463  
  RCC\_TypeDef, 1035  
APB2RSTR  
  CMSIS, 464  
  RCC\_TypeDef, 1035  
API Function Prototypes, 16, 20, 25, 33, 38, 259, 277, 291, 310, 326, 334, 341, 346  
dms, 342  
dus, 342  
EEPROM\_Init, 16  
EEPROM\_Read\_byte, 17  
EEPROM\_Write\_NBytes, 18  
I2C\_ACKnowledgeConfig, 278  
I2C\_Generate\_Start, 278  
I2C\_Generate\_Stop, 279  
I2C\_Get\_FlagStatus, 279  
I2C\_SendAddress, 280  
keypad\_Get\_Pressed\_Key, 20  
keypad\_init, 21  
LCD\_Init, 25  
LCD\_Send\_Char, 26  
LCD\_Send\_Char\_Pos, 27  
LCD\_Send\_Command, 27  
LCD\_Send\_Enable\_Signal, 28  
LCD\_Send\_String, 29  
LCD\_Send\_String\_Pos, 30  
LCD\_Set\_Cursor, 30  
LED\_Init, 34  
LED\_Toggle, 35  
LED\_TurnOff, 35  
LED\_TurnOn, 36  
MCAL\_GPIO\_DeInit, 259  
MCAL\_GPIO\_Init, 260  
MCAL\_GPIO\_LockPin, 261  
MCAL\_GPIO\_ReadPin, 262  
MCAL\_GPIO\_ReadPort, 263  
MCAL\_GPIO\_TogglePin, 264  
MCAL\_GPIO\_TogglePort, 264  
MCAL\_GPIO\_WritePin, 265  
MCAL\_GPIO\_WritePort, 266  
MCAL\_I2C\_Deinit, 280  
MCAL\_I2C\_Init, 281  
MCAL\_I2C\_Master\_Rx, 282  
MCAL\_I2C\_Master\_Tx, 282  
MCAL\_I2C\_Set\_GPIO, 283  
MCAL\_I2C\_Slave\_SendData, 284  
MCAL\_I2C\_SlaveReceiveData, 284  
MCAL\_NVIC\_ClearPendingIRQ, 292  
MCAL\_NVIC\_DisableIRQ, 293  
MCAL\_NVIC\_EnableIRQ, 293  
MCAL\_NVIC\_GetActive, 294

MCAL\_NVIC\_GetPendingIRQ, 295  
 MCAL\_NVIC\_GetPriority, 295  
 MCAL\_NVIC\_GetPriorityGrouping, 296  
 MCAL\_NVIC\_SetPendingIRQ, 296  
 MCAL\_NVIC\_SetPriority, 298  
 MCAL\_NVIC\_SetPriorityGrouping, 299  
 MCAL\_NVIC\_SystemReset, 299  
 MCAL\_RCC\_Enable\_Peripheral, 311  
 MCAL\_RCC\_GetHCLKFreq, 311  
 MCAL\_RCC\_GetPCLK1Freq, 312  
 MCAL\_RCC\_GetPCLK2Freq, 312  
 MCAL\_RCC\_GetSYS\_CLKFreq, 313  
 MCAL\_RCC\_Reset\_Peripheral, 314  
 MCAL\_RCC\_Select\_Clock, 314  
 MCAL\_SPI\_DeInit, 326  
 MCAL\_SPI\_GPIO\_Set\_Pins, 327  
 MCAL\_SPI\_Init, 328  
 MCAL\_SPI\_ReceiveData, 328  
 MCAL\_SPI\_SendData, 329  
 MCAL\_SPI\_Tx\_Rx, 330  
 MCAL\_STK\_Config, 335  
 MCAL\_STK\_Delay, 336  
 MCAL\_STK\_Delay1ms, 336  
 MCAL\_STK\_SetCallback, 337  
 MCAL\_STK\_SetReload, 338  
 MCAL\_STK\_StartTimer, 338  
 MCAL\_STK\_StopTimer, 339  
 MCAL\_USART\_DeInit, 347  
 MCAL\_USART\_GPIO\_Set\_Pins, 347  
 MCAL\_USART\_Init, 348  
 MCAL\_USART\_ReceiveBuffer, 348  
 MCAL\_USART\_ReceiveData, 349  
 MCAL\_USART\_SendData, 349  
 MCAL\_USART\_SendString, 350  
 MCAL\_USART\_Wait\_TC, 350  
 RCC\_GetPLLOutputClock, 314  
 Servo1\_Entry\_Gate, 39  
 Servo1\_Entry\_Gate\_Init, 39  
 Servo2\_Exit\_Gate, 40  
 Servo2\_Exit\_Gate\_Init, 41  
 Timer2\_init, 343  
 API\_Definitions, 371  
 Admin\_Init, 372  
 Check\_Flag, 373  
 Check\_ID, 373  
 Check\_Password, 373  
 combineArrays, 374  
 ECU\_Init, 375  
 Enter\_Gate\_Open, 375  
 Enter\_UART\_CallBack, 375  
 Exit\_Gate\_Open, 376  
 Exit\_UART\_CallBack, 376  
 Flag\_SET\_RESET, 376  
 Trigger\_Alarm, 377  
 UserLCD\_PrintFreeSlots, 377  
 Wrong\_RFID, 378  
 Application States, 350  
 Admin\_STATE, 352  
 Enter\_Gate\_STATE, 352  
 Exit\_Gate\_STATE, 352  
 fp\_App\_State\_Handler, 354  
 Free\_Slots, 354  
 Full\_STATE, 352  
 Idle\_STATE, 352  
 Init\_STATE, 352  
 STATE\_API, 352, 353  
 STATES, 352  
 APSR\_C\_Msk  
 CMSIS, 399  
 Status and Control Registers, 44  
 APSR\_C\_Pos  
 CMSIS, 399  
 Status and Control Registers, 44  
 APSR\_GE\_Msk  
 CMSIS, 399  
 Status and Control Registers, 44  
 APSR\_GE\_Pos  
 CMSIS, 400  
 Status and Control Registers, 44  
 APSR\_N\_Msk  
 CMSIS, 400  
 Status and Control Registers, 45  
 APSR\_N\_Pos  
 CMSIS, 400  
 Status and Control Registers, 45  
 APSR\_Q\_Msk  
 CMSIS, 400  
 Status and Control Registers, 45  
 APSR\_Q\_Pos  
 CMSIS, 400  
 Status and Control Registers, 45  
 APSR\_Type, 1000  
 APSR\_V\_Msk  
 CMSIS, 400  
 Status and Control Registers, 45  
 APSR\_V\_Pos  
 CMSIS, 400  
 Status and Control Registers, 45  
 APSR\_Z\_Msk  
 CMSIS, 400  
 Status and Control Registers, 45  
 APSR\_Z\_Pos  
 CMSIS, 401  
 Status and Control Registers, 45  
 ARG  
 CMSIS, 464  
 ARR  
 CMSIS, 464  
 TIM1\_TypeDef, 1057  
 AT24C1024B EEPROM Driver, 15  
 AWCR  
 CMSIS, 464  
 b  
 ITM Functions, 127  
 BCCR  
 CMSIS, 464

BDCR CMSIS, 467  
  RCC\_TypeDef, 1035

BDTR CMSIS, 464  
  TIM1\_TypeDef, 1057

BFAR ITM Functions, 127  
  SCB\_TypeDef, 1047

BFCR CMSIS, 464

BGCLUT CMSIS, 465

BGCMAR CMSIS, 465

BGCOLR CMSIS, 465

BGMAR CMSIS, 465

BGOR CMSIS, 465

BGPFCCR CMSIS, 465

BKP0R CMSIS, 465

BKP10R CMSIS, 465

BKP11R CMSIS, 466

BKP12R CMSIS, 466

BKP13R CMSIS, 466

BKP14R CMSIS, 466

BKP15R CMSIS, 466

BKP16R CMSIS, 466

BKP17R CMSIS, 466

BKP18R CMSIS, 466

BKP19R CMSIS, 467

BKP1R CMSIS, 467

BKP2R CMSIS, 467

BKP3R CMSIS, 467

BKP4R CMSIS, 467

BKP5R CMSIS, 467

BKP6R CMSIS, 467

BKP7R CMSIS, 467

BKP8R CMSIS, 468

BKP9R CMSIS, 468

BKPSRAM\_BASE Peripheral\_memory\_map, 534

BKPSRAM\_BB\_BASE Peripheral\_memory\_map, 534

boolean Platform Standard Types, 152

BPCR CMSIS, 468

BRR CMSIS, 468  
  USART\_TypeDef, 1062

bsp/Inc/eeprom\_flash.h, 1065

bsp/Inc/keypad\_driver.h, 1067

bsp/Inc/lcd\_driver.h, 1069

bsp/Inc/led\_driver.h, 1072

bsp/Src/eeprom\_flash.c, 1074

bsp/Src/keypad\_driver.c, 1075

bsp/Src/lcd\_driver.c, 1076

bsp/Src/led\_driver.c, 1078

BSRR GPIO\_TypeDef, 1017

BSRRH CMSIS, 468

BSRRL CMSIS, 468

BTR CMSIS, 468

BusFault\_IRQn Configuration\_section\_for\CMSIS, 524

C ITM Functions, 127, 128

CACR CMSIS, 469

CALIB ITM Functions, 128  
  STK\_TypeDef, 1053

CALIBR CMSIS, 469

Callback\_Function STK\_config\_t, 1052

CALR CMSIS, 469

CAN\_BTR\_BRP Peripheral\_Registers\_Bits\_Definition, 663

CAN\_BTR\_LBKM Peripheral\_Registers\_Bits\_Definition, 663

CAN\_BTR\_SILM Peripheral\_Registers\_Bits\_Definition, 663

CAN\_BTR\_SJW Peripheral\_Registers\_Bits\_Definition, 663

CAN\_BTR\_TS1 Peripheral\_Registers\_Bits\_Definition, 663

CAN\_BTR\_TS2 Peripheral\_Registers\_Bits\_Definition, 663

































Peripheral\_Registers\_Bits\_Definition, 779  
CAN\_FFA1R\_FFA3  
    Peripheral\_Registers\_Bits\_Definition, 779  
CAN\_FFA1R\_FFA4  
    Peripheral\_Registers\_Bits\_Definition, 780  
CAN\_FFA1R\_FFA5  
    Peripheral\_Registers\_Bits\_Definition, 780  
CAN\_FFA1R\_FFA6  
    Peripheral\_Registers\_Bits\_Definition, 780  
CAN\_FFA1R\_FFA7  
    Peripheral\_Registers\_Bits\_Definition, 780  
CAN\_FFA1R\_FFA8  
    Peripheral\_Registers\_Bits\_Definition, 780  
CAN\_FFA1R\_FFA9  
    Peripheral\_Registers\_Bits\_Definition, 780  
CAN\_FIFOMailBox\_TypeDef, 1000  
CAN\_FilterRegister\_TypeDef, 1001  
CAN\_FM1R\_FBM  
    Peripheral\_Registers\_Bits\_Definition, 780  
CAN\_FM1R\_FBM0  
    Peripheral\_Registers\_Bits\_Definition, 780  
CAN\_FM1R\_FBM1  
    Peripheral\_Registers\_Bits\_Definition, 781  
CAN\_FM1R\_FBM10  
    Peripheral\_Registers\_Bits\_Definition, 781  
CAN\_FM1R\_FBM11  
    Peripheral\_Registers\_Bits\_Definition, 781  
CAN\_FM1R\_FBM12  
    Peripheral\_Registers\_Bits\_Definition, 781  
CAN\_FM1R\_FBM13  
    Peripheral\_Registers\_Bits\_Definition, 781  
CAN\_FM1R\_FBM2  
    Peripheral\_Registers\_Bits\_Definition, 781  
CAN\_FM1R\_FBM3  
    Peripheral\_Registers\_Bits\_Definition, 781  
CAN\_FM1R\_FBM4  
    Peripheral\_Registers\_Bits\_Definition, 781  
CAN\_FM1R\_FBM5  
    Peripheral\_Registers\_Bits\_Definition, 782  
CAN\_FM1R\_FBM6  
    Peripheral\_Registers\_Bits\_Definition, 782  
CAN\_FM1R\_FBM7  
    Peripheral\_Registers\_Bits\_Definition, 782  
CAN\_FM1R\_FBM8  
    Peripheral\_Registers\_Bits\_Definition, 782  
CAN\_FM1R\_FBM9  
    Peripheral\_Registers\_Bits\_Definition, 782  
CAN\_FMR\_INIT  
    Peripheral\_Registers\_Bits\_Definition, 782  
CAN\_FS1R\_FSC  
    Peripheral\_Registers\_Bits\_Definition, 782  
CAN\_FS1R\_FSC0  
    Peripheral\_Registers\_Bits\_Definition, 782  
CAN\_FS1R\_FSC1  
    Peripheral\_Registers\_Bits\_Definition, 783  
CAN\_FS1R\_FSC10  
    Peripheral\_Registers\_Bits\_Definition, 783  
CAN\_FS1R\_FSC11  
    Peripheral\_Registers\_Bits\_Definition, 783  
Peripheral\_Registers\_Bits\_Definition, 783  
CAN\_FS1R\_FSC12  
    Peripheral\_Registers\_Bits\_Definition, 783  
CAN\_FS1R\_FSC13  
    Peripheral\_Registers\_Bits\_Definition, 783  
CAN\_FS1R\_FSC2  
    Peripheral\_Registers\_Bits\_Definition, 783  
CAN\_FS1R\_FSC3  
    Peripheral\_Registers\_Bits\_Definition, 783  
CAN\_FS1R\_FSC4  
    Peripheral\_Registers\_Bits\_Definition, 783  
CAN\_FS1R\_FSC5  
    Peripheral\_Registers\_Bits\_Definition, 784  
CAN\_FS1R\_FSC6  
    Peripheral\_Registers\_Bits\_Definition, 784  
CAN\_FS1R\_FSC7  
    Peripheral\_Registers\_Bits\_Definition, 784  
CAN\_FS1R\_FSC8  
    Peripheral\_Registers\_Bits\_Definition, 784  
CAN\_FS1R\_FSC9  
    Peripheral\_Registers\_Bits\_Definition, 784  
CAN\_IER\_BOFIE  
    Peripheral\_Registers\_Bits\_Definition, 784  
CAN\_IER\_EPVIE  
    Peripheral\_Registers\_Bits\_Definition, 784  
CAN\_IER\_ERRIE  
    Peripheral\_Registers\_Bits\_Definition, 784  
CAN\_IER\_EWGIE  
    Peripheral\_Registers\_Bits\_Definition, 785  
CAN\_IER\_FFIE0  
    Peripheral\_Registers\_Bits\_Definition, 785  
CAN\_IER\_FFIE1  
    Peripheral\_Registers\_Bits\_Definition, 785  
CAN\_IER\_FMPIE0  
    Peripheral\_Registers\_Bits\_Definition, 785  
CAN\_IER\_FMPIE1  
    Peripheral\_Registers\_Bits\_Definition, 785  
CAN\_IER\_FOVIE0  
    Peripheral\_Registers\_Bits\_Definition, 785  
CAN\_IER\_FOVIE1  
    Peripheral\_Registers\_Bits\_Definition, 785  
CAN\_IER\_LCIE  
    Peripheral\_Registers\_Bits\_Definition, 785  
CAN\_IER\_SLKIE  
    Peripheral\_Registers\_Bits\_Definition, 786  
CAN\_IER\_TMEIE  
    Peripheral\_Registers\_Bits\_Definition, 786  
CAN\_IER\_WKUIE  
    Peripheral\_Registers\_Bits\_Definition, 786  
CAN\_MCR\_ABOM  
    Peripheral\_Registers\_Bits\_Definition, 786  
CAN\_MCR\_AWUM  
    Peripheral\_Registers\_Bits\_Definition, 786  
CAN\_MCR\_INRQ  
    Peripheral\_Registers\_Bits\_Definition, 786  
CAN\_MCR\_NART  
    Peripheral\_Registers\_Bits\_Definition, 786  
CAN\_MCR\_RESET

- Peripheral\_Registers\_Bits\_Definition, 786  
CAN\_MCR\_RFLM  
  Peripheral\_Registers\_Bits\_Definition, 787  
CAN\_MCR\_SLEEP  
  Peripheral\_Registers\_Bits\_Definition, 787  
CAN\_MCR\_TTCM  
  Peripheral\_Registers\_Bits\_Definition, 787  
CAN\_MCR\_TXFP

Peripheral\_Registers\_Bits\_Definition, 794  
CAN\_TD1R\_DATA7  
    Peripheral\_Registers\_Bits\_Definition, 794  
CAN\_TD2R\_DATA4  
    Peripheral\_Registers\_Bits\_Definition, 794  
CAN\_TD2R\_DATA5  
    Peripheral\_Registers\_Bits\_Definition, 794  
CAN\_TD2R\_DATA6  
    Peripheral\_Registers\_Bits\_Definition, 794  
CAN\_TD2R\_DATA7  
    Peripheral\_Registers\_Bits\_Definition, 794  
CAN\_TDL0R\_DATA0  
    Peripheral\_Registers\_Bits\_Definition, 794  
CAN\_TDL0R\_DATA1  
    Peripheral\_Registers\_Bits\_Definition, 795  
CAN\_TDL0R\_DATA2  
    Peripheral\_Registers\_Bits\_Definition, 795  
CAN\_TDL0R\_DATA3  
    Peripheral\_Registers\_Bits\_Definition, 795  
CAN\_TDL1R\_DATA0  
    Peripheral\_Registers\_Bits\_Definition, 795  
CAN\_TDL1R\_DATA1  
    Peripheral\_Registers\_Bits\_Definition, 795  
CAN\_TDL1R\_DATA2  
    Peripheral\_Registers\_Bits\_Definition, 795  
CAN\_TDL1R\_DATA3  
    Peripheral\_Registers\_Bits\_Definition, 795  
CAN\_TDL2R\_DATA0  
    Peripheral\_Registers\_Bits\_Definition, 795  
CAN\_TDL2R\_DATA1  
    Peripheral\_Registers\_Bits\_Definition, 796  
CAN\_TDL2R\_DATA2  
    Peripheral\_Registers\_Bits\_Definition, 796  
CAN\_TDL2R\_DATA3  
    Peripheral\_Registers\_Bits\_Definition, 796  
CAN\_TDT0R\_DLC  
    Peripheral\_Registers\_Bits\_Definition, 796  
CAN\_TDT0R\_TGT  
    Peripheral\_Registers\_Bits\_Definition, 796  
CAN\_TDT0R\_TIME  
    Peripheral\_Registers\_Bits\_Definition, 796  
CAN\_TDT1R\_DLC  
    Peripheral\_Registers\_Bits\_Definition, 796  
CAN\_TDT1R\_TGT  
    Peripheral\_Registers\_Bits\_Definition, 796  
CAN\_TDT1R\_TIME  
    Peripheral\_Registers\_Bits\_Definition, 797  
CAN\_TDT2R\_DLC  
    Peripheral\_Registers\_Bits\_Definition, 797  
CAN\_TDT2R\_TGT  
    Peripheral\_Registers\_Bits\_Definition, 797  
CAN\_TDT2R\_TIME  
    Peripheral\_Registers\_Bits\_Definition, 797  
CAN\_TI0R\_EXID  
    Peripheral\_Registers\_Bits\_Definition, 797  
CAN\_TI0R\_IDE  
    Peripheral\_Registers\_Bits\_Definition, 797  
CAN\_TI0R\_RTR  
    Peripheral\_Registers\_Bits\_Definition, 797  
Peripheral\_Registers\_Bits\_Definition, 797  
CAN\_TI0R\_STID  
    Peripheral\_Registers\_Bits\_Definition, 797  
CAN\_TI0R\_TXRQ  
    Peripheral\_Registers\_Bits\_Definition, 798  
CAN\_TI1R\_EXID  
    Peripheral\_Registers\_Bits\_Definition, 798  
CAN\_TI1R\_IDE  
    Peripheral\_Registers\_Bits\_Definition, 798  
CAN\_TI1R\_RTR  
    Peripheral\_Registers\_Bits\_Definition, 798  
CAN\_TI1R\_STID  
    Peripheral\_Registers\_Bits\_Definition, 798  
CAN\_TI1R\_TXRQ  
    Peripheral\_Registers\_Bits\_Definition, 798  
CAN\_TI2R\_EXID  
    Peripheral\_Registers\_Bits\_Definition, 798  
CAN\_TI2R\_IDE  
    Peripheral\_Registers\_Bits\_Definition, 798  
CAN\_TI2R\_RTR  
    Peripheral\_Registers\_Bits\_Definition, 799  
CAN\_TI2R\_STID  
    Peripheral\_Registers\_Bits\_Definition, 799  
CAN\_TI2R\_TXRQ  
    Peripheral\_Registers\_Bits\_Definition, 799  
CAN\_TSR\_ABRQ0  
    Peripheral\_Registers\_Bits\_Definition, 799  
CAN\_TSR\_ABRQ1  
    Peripheral\_Registers\_Bits\_Definition, 799  
CAN\_TSR\_ABRQ2  
    Peripheral\_Registers\_Bits\_Definition, 799  
CAN\_TSR\_ALST0  
    Peripheral\_Registers\_Bits\_Definition, 799  
CAN\_TSR\_ALST1  
    Peripheral\_Registers\_Bits\_Definition, 799  
CAN\_TSR\_ALST2  
    Peripheral\_Registers\_Bits\_Definition, 800  
CAN\_TSR\_CODE  
    Peripheral\_Registers\_Bits\_Definition, 800  
CAN\_TSR\_LOW  
    Peripheral\_Registers\_Bits\_Definition, 800  
CAN\_TSR\_LOW0  
    Peripheral\_Registers\_Bits\_Definition, 800  
CAN\_TSR\_LOW1  
    Peripheral\_Registers\_Bits\_Definition, 800  
CAN\_TSR\_LOW2  
    Peripheral\_Registers\_Bits\_Definition, 800  
CAN\_TSR\_RQCP0  
    Peripheral\_Registers\_Bits\_Definition, 800  
CAN\_TSR\_RQCP1  
    Peripheral\_Registers\_Bits\_Definition, 800  
CAN\_TSR\_RQCP2  
    Peripheral\_Registers\_Bits\_Definition, 801  
CAN\_TSR\_TERR0  
    Peripheral\_Registers\_Bits\_Definition, 801  
CAN\_TSR\_TERR1  
    Peripheral\_Registers\_Bits\_Definition, 801  
CAN\_TSR\_TERR2

Peripheral\_Registers\_Bits\_Definition, 801  
CAN\_TSR\_TME  
Peripheral\_Registers\_Bits\_Definition, 801  
CAN\_TSR\_TME0  
Peripheral\_Registers\_Bits\_Definition, 801  
CAN\_TSR\_TME1  
Peripheral\_Registers\_Bits\_Definition, 801  
CAN\_TSR\_TME2  
Peripheral\_Registers\_Bits\_Definition, 801  
CAN\_TSR\_TXOK0  
Peripheral\_Registers\_Bits\_Definition, 802  
CAN\_TSR\_TXOK1  
Peripheral\_Registers\_Bits\_Definition, 802  
CAN\_TSR\_TXOK2  
Peripheral\_Registers\_Bits\_Definition, 802  
CAN\_TxMailBox\_TypeDef, 1001  
CAN\_TypeDef, 1002  
CCER  
CMSIS, 469  
TIM1\_TypeDef, 1057  
CCMDATARAM\_BASE  
Peripheral\_memory\_map, 534  
CCMDATARAM\_BB\_BASE  
Peripheral\_memory\_map, 535  
CCMR1  
CMSIS, 469  
TIM1\_TypeDef, 1057  
CCMR2  
CMSIS, 469  
TIM1\_TypeDef, 1057  
CCR  
CMSIS, 469, 470  
I2C\_TypeDef, 1020  
ITM Functions, 128  
SCB\_TypeDef, 1047  
CCR1  
CMSIS, 470  
TIM1\_TypeDef, 1057  
CCR2  
CMSIS, 470  
TIM1\_TypeDef, 1057  
CCR3  
CMSIS, 470  
TIM1\_TypeDef, 1057  
CCR4  
CMSIS, 470  
TIM1\_TypeDef, 1058  
CDR  
CMSIS, 470  
CDSR  
CMSIS, 470  
CFBAR  
CMSIS, 470  
CFBLNR  
CMSIS, 471  
CFBLR  
CMSIS, 471  
CFGGR  
CMSIS, 471  
CMSIS, 471  
RCC\_TypeDef, 1035  
SYSCFG\_RegDef\_t, 1054  
CFR  
CMSIS, 471  
CFSR  
ITM Functions, 128  
SCB\_TypeDef, 1047  
Check\_Flag  
API\_Definitions, 373  
ECU APIs, 363  
Check\_ID  
API\_Definitions, 373  
ECU APIs, 363  
Check\_Password  
API\_Definitions, 373  
ECU APIs, 364  
CID0  
ITM Functions, 128  
CID1  
ITM Functions, 129  
CID2  
ITM Functions, 129  
CID3  
ITM Functions, 129  
CIR  
CMSIS, 471  
RCC\_TypeDef, 1035  
CKCR  
CMSIS, 471  
CKGATENR  
CMSIS, 471  
CLAIMCLR  
ITM Functions, 129  
CLAIMSET  
ITM Functions, 129  
CLKCR  
CMSIS, 471  
Clock Source Selection, 306  
HSE\_CLK, 306  
HSE\_VALUE, 306  
HSI\_RC\_CLK, 307  
HSI\_VALUE, 307  
RCC\_PLLCFGR\_PLLSRC\_HSE, 307  
RCC\_SELECT\_HSE, 307  
RCC\_SELECT\_HSI, 307  
RCC\_SELECT\_PLL, 307  
clock\_config  
STK\_config\_t, 1052  
Clock\_Phase  
S\_SPI\_Config\_t, 1043  
Clock\_Polarity  
S\_SPI\_Config\_t, 1043  
CLRFR  
CMSIS, 472  
CLUTWR  
CMSIS, 472  
CMD

CMSIS, 472  
CMPCR  
  CMSIS, 472  
  SYSCFG\_RegDef\_t, 1054  
CMSIS, 379  
  \_\_CM4\_CMSIS\_VERSION, 398  
  \_\_CM4\_CMSIS\_VERSION\_MAIN, 398  
  \_\_CM4\_CMSIS\_VERSION\_SUB, 398  
  \_\_CORE\_CM4\_H\_DEPENDANT, 398  
  \_\_CORTEX\_M, 399  
    \_\_I, 399  
    \_\_IO, 399  
    \_\_O, 399  
  ACR, 461  
  AFR, 461  
  AHB1ENR, 461  
  AHB1LPENR, 461  
  AHB1RSTR, 461  
  AHB2ENR, 461  
  AHB2LPENR, 461  
  AHB2RSTR, 462  
  AHB3ENR, 462  
  AHB3LPENR, 462  
  AHB3RSTR, 462  
  ALRMAR, 462  
  ALRMASSR, 462  
  ALRMBMR, 462  
  ALRMBSSR, 462  
  AMTCR, 463  
  APB1ENR, 463  
  APB1FZ, 463  
  APB1LPENR, 463  
  APB1RSTR, 463  
  APB2ENR, 463  
  APB2FZ, 463  
  APB2LPENR, 463  
  APB2RSTR, 464  
  APSR\_C\_Msk, 399  
  APSR\_C\_Pos, 399  
  APSR\_GE\_Msk, 399  
  APSR\_GE\_Pos, 400  
  APSR\_N\_Msk, 400  
  APSR\_N\_Pos, 400  
  APSR\_Q\_Msk, 400  
  APSR\_Q\_Pos, 400  
  APSR\_V\_Msk, 400  
  APSR\_V\_Pos, 400  
  APSR\_Z\_Msk, 400  
  APSR\_Z\_Pos, 401  
  ARG, 464  
  ARR, 464  
  AWCR, 464  
  BCCR, 464  
  BDCR, 464  
  BDTR, 464  
  BFCR, 464  
  BGCLUT, 465  
  BGCMAR, 465  
  BGCOLR, 465  
  BGMAR, 465  
  BGOR, 465  
  BGPFCCR, 465  
  BKP0R, 465  
  BKP10R, 465  
  BKP11R, 466  
  BKP12R, 466  
  BKP13R, 466  
  BKP14R, 466  
  BKP15R, 466  
  BKP16R, 466  
  BKP17R, 466  
  BKP18R, 466  
  BKP19R, 467  
  BKP1R, 467  
  BKP2R, 467  
  BKP3R, 467  
  BKP4R, 467  
  BKP5R, 467  
  BKP6R, 467  
  BKP7R, 467  
  BKP8R, 468  
  BKP9R, 468  
  BPCR, 468  
  BRR, 468  
  BSRRH, 468  
  BSRRL, 468  
  BTR, 468  
  CACR, 469  
  CALIBR, 469  
  CALR, 469  
  CCER, 469  
  CCMR1, 469  
  CCMR2, 469  
  CCR, 469, 470  
  CCR1, 470  
  CCR2, 470  
  CCR3, 470  
  CCR4, 470  
  CDR, 470  
  CDSR, 470  
  CFBAR, 470  
  CFBLNR, 471  
  CFBLR, 471  
  CFGGR, 471  
  CFR, 471  
  CIR, 471  
  CKCR, 471  
  CKGATENR, 471  
  CLKCR, 471  
  CLRFR, 472  
  CLUTWR, 472  
  CMD, 472  
  CMPCR, 472  
  CNT, 472  
  CONTROL\_FPCA\_Msk, 401  
  CONTROL\_FPCA\_Pos, 401

CONTROL\_nPRIV\_Msk, 401  
CONTROL\_nPRIV\_Pos, 401  
CONTROL\_SPSEL\_Msk, 401  
CONTROL\_SPSEL\_Pos, 401  
CoreDebug, 401  
CoreDebug\_BASE, 402  
CoreDebug\_DCRSR\_REGSEL\_Msk, 402  
CoreDebug\_DCRSR\_REGSEL\_Pos, 402  
CoreDebug\_DCRSR\_REGWnR\_Msk, 402  
CoreDebug\_DCRSR\_REGWnR\_Pos, 402  
CoreDebug\_DEMCR\_MON\_EN\_Msk, 402  
CoreDebug\_DEMCR\_MON\_EN\_Pos, 402  
CoreDebug\_DEMCR\_MON\_PEND\_Msk, 403  
CoreDebug\_DEMCR\_MON\_PEND\_Pos, 403  
CoreDebug\_DEMCR\_MON\_REQ\_Msk, 403  
CoreDebug\_DEMCR\_MON\_REQ\_Pos, 403  
CoreDebug\_DEMCR\_MON\_STEP\_Msk, 403  
CoreDebug\_DEMCR\_MON\_STEP\_Pos, 403  
CoreDebug\_DEMCR\_TRCENA\_Msk, 403  
CoreDebug\_DEMCR\_TRCENA\_Pos, 403  
CoreDebug DEMCR\_VC\_BUSERR\_Msk, 404  
CoreDebug DEMCR\_VC\_BUSERR\_Pos, 404  
CoreDebug DEMCR\_VC\_CHKERR\_Msk, 404  
CoreDebug DEMCR\_VC\_CHKERR\_Pos, 404  
CoreDebug DEMCR\_VC\_CORERESET\_Msk, 404  
CoreDebug DEMCR\_VC\_CORERESET\_Pos, 404  
CoreDebug DEMCR\_VC\_HARDERR\_Msk, 404  
CoreDebug DEMCR\_VC\_HARDERR\_Pos, 404  
CoreDebug DEMCR\_VC\_INTERR\_Msk, 405  
CoreDebug DEMCR\_VC\_INTERR\_Pos, 405  
CoreDebug DEMCR\_VC\_MMERR\_Msk, 405  
CoreDebug DEMCR\_VC\_MMERR\_Pos, 405  
CoreDebug DEMCR\_VC\_NOCPERR\_Msk, 405  
CoreDebug DEMCR\_VC\_NOCPERR\_Pos, 405  
CoreDebug DEMCR\_VC\_STATERR\_Msk, 405  
CoreDebug DEMCR\_VC\_STATERR\_Pos, 405  
CoreDebug\_DHCSR\_C\_DEBUGEN\_Msk, 406  
CoreDebug\_DHCSR\_C\_DEBUGEN\_Pos, 406  
CoreDebug\_DHCSR\_C\_HALT\_Msk, 406  
CoreDebug\_DHCSR\_C\_HALT\_Pos, 406  
CoreDebug\_DHCSR\_C\_MASKINTS\_Msk, 406  
CoreDebug\_DHCSR\_C\_MASKINTS\_Pos, 406  
CoreDebug\_DHCSR\_C\_SNAPSTALL\_Msk, 406  
CoreDebug\_DHCSR\_C\_SNAPSTALL\_Pos, 406  
CoreDebug\_DHCSR\_C\_STEP\_Msk, 407  
CoreDebug\_DHCSR\_C\_STEP\_Pos, 407  
CoreDebug\_DHCSR\_DBGKEY\_Msk, 407  
CoreDebug\_DHCSR\_DBGKEY\_Pos, 407  
CoreDebug\_DHCSR\_S\_HALT\_Msk, 407  
CoreDebug\_DHCSR\_S\_HALT\_Pos, 407  
CoreDebug\_DHCSR\_S\_LOCKUP\_Msk, 407  
CoreDebug\_DHCSR\_S\_LOCKUP\_Pos, 407  
CoreDebug\_DHCSR\_S\_REGRDY\_Msk, 408  
CoreDebug\_DHCSR\_S\_REGRDY\_Pos, 408  
CoreDebug\_DHCSR\_S\_RESET\_ST\_Msk, 408  
CoreDebug\_DHCSR\_S\_RESET\_ST\_Pos, 408  
CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Msk, 408  
CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Pos, 408  
CoreDebug\_DHCSR\_S\_SLEEP\_Msk, 408  
CoreDebug\_DHCSR\_S\_SLEEP\_Pos, 408  
CPSR, 472  
CR, 472–474  
CR1, 475  
CR2, 475, 476  
CR3, 476  
CRCPR, 476  
CSGCM0R, 476  
CSGCM1R, 476  
CSGCM2R, 477  
CSGCM3R, 477  
CSGCM4R, 477  
CSGCM5R, 477  
CSGCM6R, 477  
CSGCM7R, 477  
CSGCMCCM0R, 477  
CSGCMCCM1R, 477  
CSGCMCCM2R, 478  
CSGCMCCM3R, 478  
CSGCMCCM4R, 478  
CSGCMCCM5R, 478  
CSGCMCCM6R, 478  
CSGCMCCM7R, 478  
CSR, 478, 479  
CWSIZER, 479  
CWSTRTR, 479  
DCCR, 479  
DCKCFG, 479  
DCKCFG2, 479  
DCOUNT, 479  
DCR, 480  
DCTRL, 480  
DHR12L1, 480  
DHR12L2, 480  
DHR12LD, 480  
DHR12R1, 480  
DHR12R2, 480  
DHR12RD, 480  
DHR8R1, 481  
DHR8R2, 481  
DHR8RD, 481  
DIER, 481  
DIN, 481  
DLEN, 481  
DMACR, 481  
DMAR, 482  
DOR1, 482  
DOR2, 482  
DOUT, 482  
DR, 482, 483  
DTIMER, 483  
DWT, 409  
DWT\_BASE, 409  
DWT\_CPICNT\_CPICNT\_Msk, 409  
DWT\_CPICNT\_CPICNT\_Pos, 409  
DWT\_CTRL\_CPIEVTEA\_Msk, 409

DWT\_CTRL\_CPIEVTEA\_Pos, 409  
 DWT\_CTRL\_CYCCNTENA\_Msk, 409  
 DWT\_CTRL\_CYCCNTENA\_Pos, 410  
 DWT\_CTRL\_CYCEVTENA\_Msk, 410  
 DWT\_CTRL\_CYCEVTENA\_Pos, 410  
 DWT\_CTRL\_CYCTAP\_Msk, 410  
 DWT\_CTRL\_CYCTAP\_Pos, 410  
 DWT\_CTRL\_EXCEVTENA\_Msk, 410  
 DWT\_CTRL\_EXCEVTENA\_Pos, 410  
 DWT\_CTRL\_EXCTRCENA\_Msk, 410  
 DWT\_CTRL\_EXCTRCENA\_Pos, 411  
 DWT\_CTRL\_FOLDEVTENA\_Msk, 411  
 DWT\_CTRL\_FOLDEVTENA\_Pos, 411  
 DWT\_CTRL\_LSUEVTENA\_Msk, 411  
 DWT\_CTRL\_LSUEVTENA\_Pos, 411  
 DWT\_CTRL\_NOCYCCNT\_Msk, 411  
 DWT\_CTRL\_NOCYCCNT\_Pos, 411  
 DWT\_CTRL\_NOEXTTRIG\_Msk, 411  
 DWT\_CTRL\_NOEXTTRIG\_Pos, 412  
 DWT\_CTRL\_NOPRFCNT\_Msk, 412  
 DWT\_CTRL\_NOPRFCNT\_Pos, 412  
 DWT\_CTRL\_NOTRCPKT\_Msk, 412  
 DWT\_CTRL\_NOTRCPKT\_Pos, 412  
 DWT\_CTRL\_NUMCOMP\_Msk, 412  
 DWT\_CTRL\_NUMCOMP\_Pos, 412  
 DWT\_CTRL\_PCSAMPLENA\_Msk, 412  
 DWT\_CTRL\_PCSAMPLENA\_Pos, 413  
 DWT\_CTRL\_POSTINIT\_Msk, 413  
 DWT\_CTRL\_POSTINIT\_Pos, 413  
 DWT\_CTRL\_POSTPRESET\_Msk, 413  
 DWT\_CTRL\_POSTPRESET\_Pos, 413  
 DWT\_CTRL\_SLEEPEVTENA\_Msk, 413  
 DWT\_CTRL\_SLEEPEVTENA\_Pos, 413  
 DWT\_CTRL\_SYNCTAP\_Msk, 413  
 DWT\_CTRL\_SYNCTAP\_Pos, 414  
 DWT\_EXCCNT\_EXCCNT\_Msk, 414  
 DWT\_EXCCNT\_EXCCNT\_Pos, 414  
 DWT\_FOLDCNT\_FOLDCNT\_Msk, 414  
 DWT\_FOLDCNT\_FOLDCNT\_Pos, 414  
 DWT\_FUNCTION\_CYCMATCH\_Msk, 414  
 DWT\_FUNCTION\_CYCMATCH\_Pos, 414  
 DWT\_FUNCTION\_DATAVADDR0\_Msk, 414  
 DWT\_FUNCTION\_DATAVADDR0\_Pos, 415  
 DWT\_FUNCTION\_DATAVADDR1\_Msk, 415  
 DWT\_FUNCTION\_DATAVADDR1\_Pos, 415  
 DWT\_FUNCTION\_DATAVMATCH\_Msk, 415  
 DWT\_FUNCTION\_DATAVMATCH\_Pos, 415  
 DWT\_FUNCTION\_DATAVSIZE\_Msk, 415  
 DWT\_FUNCTION\_DATAVSIZE\_Pos, 415  
 DWT\_FUNCTION\_EMITRANGE\_Msk, 415  
 DWT\_FUNCTION\_EMITRANGE\_Pos, 416  
 DWT\_FUNCTION\_FUNCTION\_Msk, 416  
 DWT\_FUNCTION\_FUNCTION\_Pos, 416  
 DWT\_FUNCTION\_LNK1ENA\_Msk, 416  
 DWT\_FUNCTION\_LNK1ENA\_Pos, 416  
 DWT\_FUNCTION\_MATCHED\_Msk, 416  
 DWT\_FUNCTION\_MATCHED\_Pos, 416  
 DWT\_LSUCNT\_LSUCNT\_Msk, 416  
 DWT\_LSUCNT\_LSUCNT\_Pos, 417  
 DWT\_MASK\_MASK\_Msk, 417  
 DWT\_MASK\_MASK\_Pos, 417  
 DWT\_SLEEPcnt\_SLEEPcnt\_Msk, 417  
 DWT\_SLEEPcnt\_SLEEPcnt\_Pos, 417  
 EGR, 483  
 EMR, 484  
 ESCR, 484  
 ESR, 484  
 ESUR, 484  
 EXTICR, 484  
 FA1R, 484  
 FCR, 484  
 FFA1R, 485  
 FGCLUT, 485  
 FGCMAR, 485  
 FGCOLR, 485  
 FGMAR, 485  
 FGOR, 485  
 FGPFCCR, 485  
 FIFO, 486  
 FIFOcnt, 486  
 FLTR, 486  
 FM1R, 486  
 FMR, 486  
 FR1, 486  
 FR2, 486  
 FRCR, 487  
 FS1R, 487  
 FTSR, 487  
 GCR, 487  
 GTPR, 487  
 HIFCR, 487  
 HISR, 488  
 HR, 488  
 HTR, 488  
 I2SCFGR, 488  
 I2SPR, 488  
 ICR, 488, 489  
 IDCODE, 489  
 IDR, 489  
 IER, 489, 490  
 IFCR, 490  
 IMR, 490  
 IMSCR, 490  
 IPSR\_ISR\_Msk, 417  
 IPSR\_ISR\_Pos, 417  
 ISR, 490, 491  
 ITM, 417  
 ITM\_BASE, 418  
 ITM\_CheckChar, 453  
 ITM\_IMCR\_INTEGRATION\_Msk, 418  
 ITM\_IMCR\_INTEGRATION\_Pos, 418  
 ITM\_IRR\_ATREADYM\_Msk, 418  
 ITM\_IRR\_ATREADYM\_Pos, 418  
 ITM\_IWR\_ATVALIDM\_Msk, 418  
 ITM\_IWR\_ATVALIDM\_Pos, 418  
 ITM\_LSR\_Access\_Msk, 419

ITM\_LSR\_Access\_Pos, 419  
ITM\_LSR\_ByteAcc\_Msk, 419  
ITM\_LSR\_ByteAcc\_Pos, 419  
ITM\_LSR\_Present\_Msk, 419  
ITM\_LSR\_Present\_Pos, 419  
ITM\_ReceiveChar, 453  
ITM\_RxBuffer, 491  
ITM\_RXBUFFER\_EMPTY, 419  
ITM\_SendChar, 453  
ITM\_TCR\_BUSY\_Msk, 419  
ITM\_TCR\_BUSY\_Pos, 420  
ITM\_TCR\_DWTENA\_Msk, 420  
ITM\_TCR\_DWTENA\_Pos, 420  
ITM\_TCR\_GTSFREQ\_Msk, 420  
ITM\_TCR\_GTSFREQ\_Pos, 420  
ITM\_TCR\_ITMENA\_Msk, 420  
ITM\_TCR\_ITMENA\_Pos, 420  
ITM\_TCR\_SWOENA\_Msk, 420  
ITM\_TCR\_SWOENA\_Pos, 421  
ITM\_TCR\_SYNCENA\_Msk, 421  
ITM\_TCR\_SYNCENA\_Pos, 421  
ITM\_TCR\_TraceBusID\_Msk, 421  
ITM\_TCR\_TraceBusID\_Pos, 421  
ITM\_TCR\_TSENA\_Msk, 421  
ITM\_TCR\_TSENA\_Pos, 421  
ITM\_TCR\_TSPrescale\_Msk, 421  
ITM\_TCR\_TSPrescale\_Pos, 422  
ITM\_TPR\_PRIVMASK\_Msk, 422  
ITM\_TPR\_PRIVMASK\_Pos, 422  
IV0LR, 491  
IV0RR, 491  
IV1LR, 491  
IV1RR, 491  
JDR1, 492  
JDR2, 492  
JDR3, 492  
JDR4, 492  
JOFR1, 492  
JOFR2, 492  
JOFR3, 492  
JOFR4, 492  
JSQR, 493  
K0LR, 493  
K0RR, 493  
K1LR, 493  
K1RR, 493  
K2LR, 493  
K2RR, 493  
K3LR, 493  
K3RR, 494  
KEYR, 494  
KR, 494  
LCKR, 494  
LIFCR, 494  
LIPCR, 494  
LISR, 494  
LTR, 495  
LWR, 495  
M0AR, 495  
M1AR, 495  
MASK, 495  
MCR, 495  
MEMRMP, 495  
MISR, 496  
MODER, 496  
MSR, 496  
NDTR, 496  
NLR, 496  
NVIC, 422  
NVIC\_BASE, 422  
NVIC\_ClearPendingIRQ, 454  
NVIC\_DecodePriority, 454  
NVIC\_DisableIRQ, 455  
NVIC\_EnableIRQ, 455  
NVIC\_EncodePriority, 455  
NVIC\_GetActive, 457  
NVIC\_GetPendingIRQ, 457  
NVIC\_GetPriority, 458  
NVIC\_GetPriorityGrouping, 458  
NVIC\_SetPendingIRQ, 458  
NVIC\_SetPriority, 459  
NVIC\_SetPriorityGrouping, 459  
NVIC\_STIR\_INTID\_Msk, 422  
NVIC\_STIR\_INTID\_Pos, 422  
NVIC\_SystemReset, 459  
OAR1, 496  
OAR2, 497  
OCOLR, 497  
ODR, 497  
OMAR, 497  
OOR, 497  
OPFCCR, 497  
OPTCR, 497  
OPTCR1, 498  
OPTKEYR, 498  
OR, 498  
OSPEEDR, 498  
OTYPER, 498  
PAR, 498  
PFCR, 498  
PLLCFGR, 499  
PLL2SCFGR, 499  
PLLSAICFGR, 499  
PMC, 499  
POWER, 499  
PR, 499  
PRER, 500  
PSC, 500  
PUPDR, 500  
RCR, 500  
RDHR, 500  
RDLR, 500  
RDTR, 500  
RESERVED, 501  
RESERVED0, 501, 502  
RESERVED1, 502–504

RESERVED10, 504  
 RESERVED11, 504  
 RESERVED12, 504  
 RESERVED13, 504  
 RESERVED14, 504  
 RESERVED2, 505  
 RESERVED3, 506  
 RESERVED4, 507  
 RESERVED5, 507, 508  
 RESERVED6, 508, 509  
 RESERVED7, 509  
 RESERVED8, 510  
 RESERVED9, 510  
 RESP1, 510  
 RESP2, 510  
 RESP3, 511  
 RESP4, 511  
 RESPCMD, 511  
 RF0R, 511  
 RF1R, 511  
 RIR, 511  
 RISR, 511, 512  
 RLR, 512  
 RTSR, 512  
 RXCRCR, 512  
 SCB, 423  
 SCB\_AIRCR\_ENDIANESS\_Msk, 423  
 SCB\_AIRCR\_ENDIANESS\_Pos, 423  
 SCB\_AIRCR\_PRIGROUP\_Msk, 423  
 SCB\_AIRCR\_PRIGROUP\_Pos, 423  
 SCB\_AIRCR\_SYSRESETREQ\_Msk, 423  
 SCB\_AIRCR\_SYSRESETREQ\_Pos, 423  
 SCB\_AIRCR\_VECTCLRACTIVE\_Msk, 424  
 SCB\_AIRCR\_VECTCLRACTIVE\_Pos, 424  
 SCB\_AIRCR\_VECTKEY\_Msk, 424  
 SCB\_AIRCR\_VECTKEY\_Pos, 424  
 SCB\_AIRCR\_VECTKEYSTAT\_Msk, 424  
 SCB\_AIRCR\_VECTKEYSTAT\_Pos, 424  
 SCB\_AIRCR\_VECTRESET\_Msk, 424  
 SCB\_AIRCR\_VECTRESET\_Pos, 424  
 SCB\_BASE, 425  
 SCB\_CCR\_BFHFMIGN\_Msk, 425  
 SCB\_CCR\_BFHFMIGN\_Pos, 425  
 SCB\_CCR\_DIV\_0\_TRP\_Msk, 425  
 SCB\_CCR\_DIV\_0\_TRP\_Pos, 425  
 SCB\_CCR\_NONBASETHRDENA\_Msk, 425  
 SCB\_CCR\_NONBASETHRDENA\_Pos, 425  
 SCB\_CCR\_STKALIGN\_Msk, 426  
 SCB\_CCR\_STKALIGN\_Pos, 426  
 SCB\_CCR\_UNALIGN\_TRP\_Msk, 426  
 SCB\_CCR\_UNALIGN\_TRP\_Pos, 426  
 SCB\_CCR\_USERSETMPEND\_Msk, 426  
 SCB\_CCR\_USERSETMPEND\_Pos, 426  
 SCB\_CFSR\_BUSFAULTSR\_Msk, 426  
 SCB\_CFSR\_BUSFAULTSR\_Pos, 426  
 SCB\_CFSR\_MEMFAULTSR\_Msk, 427  
 SCB\_CFSR\_MEMFAULTSR\_Pos, 427  
 SCB\_CFSR\_USGFAULTSR\_Msk, 427  
 SCB\_CFSR\_USGFAULTSR\_Pos, 427  
 SCB\_CPUID\_ARCHITECTURE\_Msk, 427  
 SCB\_CPUID\_ARCHITECTURE\_Pos, 427  
 SCB\_CPUID\_IMPLEMENTER\_Msk, 427  
 SCB\_CPUID\_IMPLEMENTER\_Pos, 427  
 SCB\_CPUID\_PARTNO\_Msk, 428  
 SCB\_CPUID\_PARTNO\_Pos, 428  
 SCB\_CPUID\_REVISION\_Msk, 428  
 SCB\_CPUID\_REVISION\_Pos, 428  
 SCB\_CPUID\_VARIANT\_Msk, 428  
 SCB\_CPUID\_VARIANT\_Pos, 428  
 SCB\_DFSR\_BKPT\_Msk, 428  
 SCB\_DFSR\_BKPT\_Pos, 428  
 SCB\_DFSR\_DWTTRAP\_Msk, 429  
 SCB\_DFSR\_DWTTRAP\_Pos, 429  
 SCB\_DFSR\_EXTERNAL\_Msk, 429  
 SCB\_DFSR\_EXTERNAL\_Pos, 429  
 SCB\_DFSR\_HALTED\_Msk, 429  
 SCB\_DFSR\_HALTED\_Pos, 429  
 SCB\_DFSR\_VCATCH\_Msk, 429  
 SCB\_DFSR\_VCATCH\_Pos, 429  
 SCB\_HFSR\_DEBUGEVT\_Msk, 430  
 SCB\_HFSR\_DEBUGEVT\_Pos, 430  
 SCB\_HFSR\_FORCED\_Msk, 430  
 SCB\_HFSR\_FORCED\_Pos, 430  
 SCB\_HFSR\_VECTTBL\_Msk, 430  
 SCB\_HFSR\_VECTTBL\_Pos, 430  
 SCB\_ICSR\_ISRPENDING\_Msk, 430  
 SCB\_ICSR\_ISRPENDING\_Pos, 430  
 SCB\_ICSR\_ISRPREEMPT\_Msk, 431  
 SCB\_ICSR\_ISRPREEMPT\_Pos, 431  
 SCB\_ICSR\_NMIPENDSET\_Msk, 431  
 SCB\_ICSR\_NMIPENDSET\_Pos, 431  
 SCB\_ICSR\_PENDSTCLR\_Msk, 431  
 SCB\_ICSR\_PENDSTCLR\_Pos, 431  
 SCB\_ICSR\_PENDSTSET\_Msk, 431  
 SCB\_ICSR\_PENDSTSET\_Pos, 431  
 SCB\_ICSR\_PENDSVCLR\_Msk, 432  
 SCB\_ICSR\_PENDSVCLR\_Pos, 432  
 SCB\_ICSR\_PENDSVSET\_Msk, 432  
 SCB\_ICSR\_PENDSVSET\_Pos, 432  
 SCB\_ICSR\_RETTOBASE\_Msk, 432  
 SCB\_ICSR\_RETTOBASE\_Pos, 432  
 SCB\_ICSR\_VECTACTIVE\_Msk, 432  
 SCB\_ICSR\_VECTACTIVE\_Pos, 432  
 SCB\_ICSR\_VECTPENDING\_Msk, 433  
 SCB\_ICSR\_VECTPENDING\_Pos, 433  
 SCB\_SCR\_SEVONPEND\_Msk, 433  
 SCB\_SCR\_SEVONPEND\_Pos, 433  
 SCB\_SCR\_SLEEPDEEP\_Msk, 433  
 SCB\_SCR\_SLEEPDEEP\_Pos, 433  
 SCB\_SCR\_SLEEPONEEXIT\_Msk, 433  
 SCB\_SCR\_SLEEPONEEXIT\_Pos, 433  
 SCB\_SHCSR\_BUSFAULTACT\_Msk, 434  
 SCB\_SHCSR\_BUSFAULTACT\_Pos, 434  
 SCB\_SHCSR\_BUSFAULTENA\_Msk, 434  
 SCB\_SHCSR\_BUSFAULTENA\_Pos, 434  
 SCB\_SHCSR\_BUSFAULTPENDED\_Msk, 434

SCB\_SHCSR\_BUSFAULTPENDED\_Pos, 434  
SCB\_SHCSR\_MEMFAULTACT\_Msk, 434  
SCB\_SHCSR\_MEMFAULTACT\_Pos, 434  
SCB\_SHCSR\_MEMFAULTENA\_Msk, 435  
SCB\_SHCSR\_MEMFAULTENA\_Pos, 435  
SCB\_SHCSR\_MEMFAULTPENDED\_Msk, 435  
SCB\_SHCSR\_MEMFAULTPENDED\_Pos, 435  
SCB\_SHCSR\_MONITORACT\_Msk, 435  
SCB\_SHCSR\_MONITORACT\_Pos, 435  
SCB\_SHCSR\_PENDSVACT\_Msk, 435  
SCB\_SHCSR\_PENDSVACT\_Pos, 435  
SCB\_SHCSR\_SVCALLACT\_Msk, 436  
SCB\_SHCSR\_SVCALLACT\_Pos, 436  
SCB\_SHCSR\_SVCALLPENDED\_Msk, 436  
SCB\_SHCSR\_SVCALLPENDED\_Pos, 436  
SCB\_SHCSR\_SYSTICKACT\_Msk, 436  
SCB\_SHCSR\_SYSTICKACT\_Pos, 436  
SCB\_SHCSR\_USGFAULTACT\_Msk, 436  
SCB\_SHCSR\_USGFAULTACT\_Pos, 436  
SCB\_SHCSR\_USGFAULTENA\_Msk, 437  
SCB\_SHCSR\_USGFAULTENA\_Pos, 437  
SCB\_SHCSR\_USGFAULTPENDED\_Msk, 437  
SCB\_SHCSR\_USGFAULTPENDED\_Pos, 437  
SCB\_VTOR\_TBLOFF\_Msk, 437  
SCB\_VTOR\_TBLOFF\_Pos, 437  
SCnSCB, 437  
SCnSCB\_ACTLR\_DISDEFWBUF\_Msk, 437  
SCnSCB\_ACTLR\_DISDEFWBUF\_Pos, 438  
SCnSCB\_ACTLR\_DISFOLD\_Msk, 438  
SCnSCB\_ACTLR\_DISFOLD\_Pos, 438  
SCnSCB\_ACTLR\_DISFPCA\_Msk, 438  
SCnSCB\_ACTLR\_DISFPCA\_Pos, 438  
SCnSCB\_ACTLR\_DISMCYCINT\_Msk, 438  
SCnSCB\_ACTLR\_DISMCYCINT\_Pos, 438  
SCnSCB\_ACTLR\_DISOOFP\_Msk, 438  
SCnSCB\_ACTLR\_DISOOFP\_Pos, 439  
SCnSCB\_ICTR\_INTLINESNUM\_Msk, 439  
SCnSCB\_ICTR\_INTLINESNUM\_Pos, 439  
SCS\_BASE, 439  
sFIFOMailBox, 512  
sFilterRegister, 512  
SHIFTR, 512  
SLOTR, 513  
SMCR, 513  
SMPR1, 513  
SMPR2, 513  
SQR1, 513  
SQR2, 513  
SQR3, 513  
SR, 513–515  
SR1, 515  
SR2, 515  
SRCR, 515  
SSCGR, 516  
SSCR, 516  
SSR, 516  
STA, 516  
STR, 516  
sTxMailBox, 516  
SWIER, 516  
SWTRIGR, 517  
SysTick, 439  
SysTick\_BASE, 439  
SysTick\_CALIB\_NOREF\_Msk, 439  
SysTick\_CALIB\_NOREF\_Pos, 440  
SysTick\_CALIB\_SKEW\_Msk, 440  
SysTick\_CALIB\_SKEW\_Pos, 440  
SysTick\_CALIB\_TENMS\_Msk, 440  
SysTick\_CALIB\_TENMS\_Pos, 440  
SysTick\_Config, 460  
SysTick\_CTRL\_CLKSOURCE\_Msk, 440  
SysTick\_CTRL\_CLKSOURCE\_Pos, 440  
SysTick\_CTRL\_COUNTFLAG\_Msk, 440  
SysTick\_CTRL\_COUNTFLAG\_Pos, 441  
SysTick\_CTRL\_ENABLE\_Msk, 441  
SysTick\_CTRL\_ENABLE\_Pos, 441  
SysTick\_CTRL\_TICKINT\_Msk, 441  
SysTick\_CTRL\_TICKINT\_Pos, 441  
SysTick\_Handler, 460  
SysTick\_LOAD\_RELOAD\_Msk, 441  
SysTick\_LOAD\_RELOAD\_Pos, 441  
SysTick\_VAL\_CURRENT\_Msk, 441  
SysTick\_VAL\_CURRENT\_Pos, 442  
TAFCR, 517  
TDHR, 517  
TDLR, 517  
TDTR, 517  
TIR, 517  
TPI, 442  
TPI\_ACPR\_PRESCALER\_Msk, 442  
TPI\_ACPR\_PRESCALER\_Pos, 442  
TPI\_BASE, 442  
TPI\_DEVID\_AsynClkIn\_Msk, 442  
TPI\_DEVID\_AsynClkIn\_Pos, 442  
TPI\_DEVID\_MANCVALID\_Msk, 443  
TPI\_DEVID\_MANCVALID\_Pos, 443  
TPI\_DEVID\_MinBufSz\_Msk, 443  
TPI\_DEVID\_MinBufSz\_Pos, 443  
TPI\_DEVID\_NrTraceInput\_Msk, 443  
TPI\_DEVID\_NrTraceInput\_Pos, 443  
TPI\_DEVID\_NRZVALID\_Msk, 443  
TPI\_DEVID\_NRZVALID\_Pos, 443  
TPI\_DEVID\_PTINVALID\_Msk, 444  
TPI\_DEVID\_PTINVALID\_Pos, 444  
TPI\_DEVTYPE\_MajorType\_Msk, 444  
TPI\_DEVTYPE\_MajorType\_Pos, 444  
TPI\_DEVTYPE\_SubType\_Msk, 444  
TPI\_DEVTYPE\_SubType\_Pos, 444  
TPI\_FFCR\_EnFCont\_Msk, 444  
TPI\_FFCR\_EnFCont\_Pos, 444  
TPI\_FFCR\_TrigIn\_Msk, 445  
TPI\_FFCR\_TrigIn\_Pos, 445  
TPI\_FFSR\_FInProg\_Msk, 445  
TPI\_FFSR\_FInProg\_Pos, 445  
TPI\_FFSR\_FtNonStop\_Msk, 445  
TPI\_FFSR\_FtNonStop\_Pos, 445

TPI\_FFSR\_FtStopped\_Msk, 445  
TPI\_FFSR\_FtStopped\_Pos, 445  
TPI\_FFSR\_TCPresent\_Msk, 446  
TPI\_FFSR\_TCPresent\_Pos, 446  
TPI\_FIFO0\_ETM0\_Msk, 446  
TPI\_FIFO0\_ETM0\_Pos, 446  
TPI\_FIFO0\_ETM1\_Msk, 446  
TPI\_FIFO0\_ETM1\_Pos, 446  
TPI\_FIFO0\_ETM2\_Msk, 446  
TPI\_FIFO0\_ETM2\_Pos, 446  
TPI\_FIFO0\_ETM\_ATVALID\_Msk, 447  
TPI\_FIFO0\_ETM\_ATVALID\_Pos, 447  
TPI\_FIFO0\_ETM\_bytectcount\_Msk, 447  
TPI\_FIFO0\_ETM\_bytectcount\_Pos, 447  
TPI\_FIFO0\_ITM\_ATVALID\_Msk, 447  
TPI\_FIFO0\_ITM\_ATVALID\_Pos, 447  
TPI\_FIFO0\_ITM\_bytectcount\_Msk, 447  
TPI\_FIFO0\_ITM\_bytectcount\_Pos, 447  
TPI\_FIFO1\_ETM\_ATVALID\_Msk, 448  
TPI\_FIFO1\_ETM\_ATVALID\_Pos, 448  
TPI\_FIFO1\_ETM\_bytectcount\_Msk, 448  
TPI\_FIFO1\_ETM\_bytectcount\_Pos, 448  
TPI\_FIFO1\_ITM0\_Msk, 448  
TPI\_FIFO1\_ITM0\_Pos, 448  
TPI\_FIFO1\_ITM1\_Msk, 448  
TPI\_FIFO1\_ITM1\_Pos, 448  
TPI\_FIFO1\_ITM2\_Msk, 449  
TPI\_FIFO1\_ITM2\_Pos, 449  
TPI\_FIFO1\_ITM\_ATVALID\_Msk, 449  
TPI\_FIFO1\_ITM\_ATVALID\_Pos, 449  
TPI\_FIFO1\_ITM\_bytectcount\_Msk, 449  
TPI\_FIFO1\_ITM\_bytectcount\_Pos, 449  
TPI\_ITATBCTR0\_ATREADY\_Msk, 449  
TPI\_ITATBCTR0\_ATREADY\_Pos, 449  
TPI\_ITATBCTR2\_ATREADY\_Msk, 450  
TPI\_ITATBCTR2\_ATREADY\_Pos, 450  
TPI\_ITCTRL\_Mode\_Msk, 450  
TPI\_ITCTRL\_Mode\_Pos, 450  
TPI\_SPPR\_TXMODE\_Msk, 450  
TPI\_SPPR\_TXMODE\_Pos, 450  
TPI\_TRIGGER\_TRIGGER\_Msk, 450  
TPI\_TRIGGER\_TRIGGER\_Pos, 450  
TR, 517  
TRISE, 517  
TSDR, 518  
TSR, 518  
TSSSR, 518  
TSTR, 518  
TWCR, 518  
TXCRCR, 518  
WHPCR, 518  
WPR, 519  
WUTR, 519  
WVPCR, 519  
xPSR\_C\_Msk, 451  
xPSR\_C\_Pos, 451  
xPSR\_GE\_Msk, 451  
xPSR\_GE\_Pos, 451  
xPSR\_ISR\_Msk, 451  
xPSR\_ISR\_Pos, 451  
xPSR\_IT\_Msk, 451  
xPSR\_IT\_Pos, 451  
xPSR\_N\_Msk, 452  
xPSR\_N\_Pos, 452  
xPSR\_Q\_Msk, 452  
xPSR\_Q\_Pos, 452  
xPSR\_T\_Msk, 452  
xPSR\_T\_Pos, 452  
xPSR\_V\_Msk, 452  
xPSR\_V\_Pos, 452  
xPSR\_Z\_Msk, 453  
xPSR\_Z\_Pos, 453  
CMSIS Core Instruction Interface, 148  
CMSIS Core Register Access Functions, 147  
CMSIS Global Defines, 42  
CMSIS SIMD Intrinsics, 148  
CMSIS/Inc/core\_cm4.h, 1079  
CMSIS/Inc/core\_cmFunc.h, 1089  
CMSIS/Inc/core\_cmlInstr.h, 1090  
CMSIS/Inc/core\_cmSimd.h, 1091  
CMSIS/Inc/stm32f4xx.h, 1092  
CMSIS/Inc/system\_stm32f4xx.h, 1184  
CNT  
    CMSIS, 472  
    TIM1\_TypeDef, 1058  
combineArrays  
    API\_Definitions, 374  
    ECU APIs, 364  
Communication\_Mode  
    S\_SPI\_Config\_t, 1044  
COMP0  
    ITM Functions, 129  
COMP1  
    ITM Functions, 129  
COMP2  
    ITM Functions, 130  
COMP3  
    ITM Functions, 130  
Configuration Macros, 360  
Configuration\_section\_for\CMSIS, 522  
    \_\_CM4\_REV, 523  
    \_\_FPU\_PRESENT, 523  
    \_\_MPU\_PRESENT, 523  
    \_\_NVIC\_PRIO\_BITS, 524  
    Vendor\_SysTickConfig, 524  
ADC IRQn, 525  
BusFault IRQn, 524  
DebugMonitor IRQn, 524  
DMA1\_Stream0 IRQn, 525  
DMA1\_Stream1 IRQn, 525  
DMA1\_Stream2 IRQn, 525  
DMA1\_Stream3 IRQn, 525  
DMA1\_Stream4 IRQn, 525  
DMA1\_Stream5 IRQn, 525  
DMA1\_Stream6 IRQn, 525  
DMA1\_Stream7 IRQn, 526

DMA2\_Stream0\_IRQHandler, 526  
DMA2\_Stream1\_IRQHandler, 526  
DMA2\_Stream2\_IRQHandler, 526  
DMA2\_Stream3\_IRQHandler, 526  
DMA2\_Stream4\_IRQHandler, 526  
DMA2\_Stream5\_IRQHandler, 526  
DMA2\_Stream6\_IRQHandler, 526  
DMA2\_Stream7\_IRQHandler, 526  
EXTI0\_IRQHandler, 525  
EXTI15\_10\_IRQHandler, 526  
EXTI1\_IRQHandler, 525  
EXTI2\_IRQHandler, 525  
EXTI3\_IRQHandler, 525  
EXTI4\_IRQHandler, 525  
EXTI9\_5\_IRQHandler, 525  
FLASH\_IRQHandler, 525  
FPU\_IRQHandler, 526  
I2C1\_ER\_IRQHandler, 525  
I2C1\_EV\_IRQHandler, 525  
I2C2\_ER\_IRQHandler, 526  
I2C2\_EV\_IRQHandler, 526  
I2C3\_ER\_IRQHandler, 526  
I2C3\_EV\_IRQHandler, 526  
IRQn, 524  
MemoryManagement\_IRQHandler, 524  
NonMaskableInt\_IRQHandler, 524  
OTG\_FS\_IRQHandler, 526  
OTG\_FS\_WKUP\_IRQHandler, 526  
PendSV\_IRQHandler, 524  
PVD\_IRQHandler, 525  
RCC\_IRQHandler, 525  
RTC\_Alarm\_IRQHandler, 526  
RTC\_WKUP\_IRQHandler, 525  
SDIO\_IRQHandler, 526  
SPI1\_IRQHandler, 526  
SPI2\_IRQHandler, 526  
SPI3\_IRQHandler, 526  
SPI4\_IRQHandler, 526  
SVCall\_IRQHandler, 524  
SysTick\_IRQHandler, 524  
TAMP\_STAMP\_IRQHandler, 525  
TIM1\_BRK\_TIM9\_IRQHandler, 525  
TIM1\_CC\_IRQHandler, 525  
TIM1\_TRG\_COM\_TIM11\_IRQHandler, 525  
TIM1\_UP\_TIM10\_IRQHandler, 525  
TIM2\_IRQHandler, 525  
TIM3\_IRQHandler, 525  
TIM4\_IRQHandler, 525  
TIM5\_IRQHandler, 526  
UsageFault\_IRQHandler, 524  
USART1\_IRQHandler, 526  
USART2\_IRQHandler, 526  
USART6\_IRQHandler, 526  
WWDG\_IRQHandler, 524  
ConstVoidPtr  
    Platform Standard Types, 152  
CONTROL\_FPCA\_Msk  
    CMSIS, 401  
Status and Control Registers, 46  
CONTROL\_FPCA\_Pos  
    CMSIS, 401  
    Status and Control Registers, 46  
CONTROL\_nPRIV\_Msk  
    CMSIS, 401  
    Status and Control Registers, 46  
CONTROL\_nPRIV\_Pos  
    CMSIS, 401  
    Status and Control Registers, 46  
CONTROL\_SPSEL\_Msk  
    CMSIS, 401  
    Status and Control Registers, 46  
CONTROL\_SPSEL\_Pos  
    CMSIS, 401  
    Status and Control Registers, 46  
CONTROL\_Type, 1003  
Core Debug Registers (CoreDebug), 99  
    CoreDebug\_DCRSR\_REGSEL\_Msk, 101  
    CoreDebug\_DCRSR\_REGSEL\_Pos, 101  
    CoreDebug\_DCRSR\_REGWnR\_Msk, 101  
    CoreDebug\_DCRSR\_REGWnR\_Pos, 101  
    CoreDebug\_DEMCR\_MON\_EN\_Msk, 101  
    CoreDebug\_DEMCR\_MON\_EN\_Pos, 102  
    CoreDebug\_DEMCR\_MON\_PEND\_Msk, 102  
    CoreDebug\_DEMCR\_MON\_PEND\_Pos, 102  
    CoreDebug\_DEMCR\_MON\_REQ\_Msk, 102  
    CoreDebug\_DEMCR\_MON\_REQ\_Pos, 102  
    CoreDebug\_DEMCR\_MON\_STEP\_Msk, 102  
    CoreDebug\_DEMCR\_MON\_STEP\_Pos, 102  
    CoreDebug\_DEMCR\_TRCENA\_Msk, 102  
    CoreDebug\_DEMCR\_TRCENA\_Pos, 103  
    CoreDebug\_DEMCR\_VC\_BUSERR\_Msk, 103  
    CoreDebug\_DEMCR\_VC\_BUSERR\_Pos, 103  
    CoreDebug\_DEMCR\_VC\_CHKERR\_Msk, 103  
    CoreDebug\_DEMCR\_VC\_CHKERR\_Pos, 103  
    CoreDebug\_DEMCR\_VC\_CORERESET\_Msk, 103  
    CoreDebug\_DEMCR\_VC\_CORERESET\_Pos, 103  
    CoreDebug\_DEMCR\_VC\_HARDERR\_Msk, 103  
    CoreDebug\_DEMCR\_VC\_HARDERR\_Pos, 104  
    CoreDebug\_DEMCR\_VC\_INTERR\_Msk, 104  
    CoreDebug\_DEMCR\_VC\_INTERR\_Pos, 104  
    CoreDebug\_DEMCR\_VC\_MMERR\_Msk, 104  
    CoreDebug\_DEMCR\_VC\_MMERR\_Pos, 104  
    CoreDebug\_DEMCR\_VC\_NOCPERR\_Msk, 104  
    CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos, 104  
    CoreDebug\_DEMCR\_VC\_STATERR\_Msk, 104  
    CoreDebug\_DEMCR\_VC\_STATERR\_Pos, 105  
    CoreDebug\_DHCSR\_C\_DEBUGEN\_Msk, 105  
    CoreDebug\_DHCSR\_C\_DEBUGEN\_Pos, 105  
    CoreDebug\_DHCSR\_C\_HALT\_Msk, 105  
    CoreDebug\_DHCSR\_C\_HALT\_Pos, 105  
    CoreDebug\_DHCSR\_C\_MASKINTS\_Msk, 105  
    CoreDebug\_DHCSR\_C\_MASKINTS\_Pos, 105  
    CoreDebug\_DHCSR\_C\_SNAPSTALL\_Msk, 105  
    CoreDebug\_DHCSR\_C\_SNAPSTALL\_Pos, 106  
    CoreDebug\_DHCSR\_C\_STEP\_Msk, 106

CoreDebug\_DHCSR\_C\_STEP\_Pos, 106  
CoreDebug\_DHCSR\_DBGKEY\_Msk, 106  
CoreDebug\_DHCSR\_DBGKEY\_Pos, 106  
CoreDebug\_DHCSR\_S\_HALT\_Msk, 106  
CoreDebug\_DHCSR\_S\_HALT\_Pos, 106  
CoreDebug\_DHCSR\_S\_LOCKUP\_Msk, 106  
CoreDebug\_DHCSR\_S\_LOCKUP\_Pos, 107  
CoreDebug\_DHCSR\_S\_REGRDY\_Msk, 107  
CoreDebug\_DHCSR\_S\_REGRDY\_Pos, 107  
CoreDebug\_DHCSR\_S\_RESET\_ST\_Msk, 107  
CoreDebug\_DHCSR\_S\_RESET\_ST\_Pos, 107  
CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Msk, 107  
CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Pos, 107  
CoreDebug\_DHCSR\_S\_SLEEP\_Msk, 107  
CoreDebug\_DHCSR\_S\_SLEEP\_Pos, 108  
Core Definitions, 108  
CoreDebug, 109  
CoreDebug\_BASE, 109  
DWT, 109  
DWT\_BASE, 109  
ITM, 109  
ITM\_BASE, 109  
NVIC, 110  
NVIC\_BASE, 110  
SCB, 110  
SCB\_BASE, 110  
SCnSCB, 110  
SCS\_BASE, 110  
SysTick, 110  
SysTick\_BASE, 111  
TPI, 111  
TPI\_BASE, 111  
CoreDebug  
  CMSIS, 401  
  Core Definitions, 109  
CoreDebug\_BASE  
  CMSIS, 402  
  Core Definitions, 109  
CoreDebug\_DCRSR\_REGSEL\_Msk  
  CMSIS, 402  
  Core Debug Registers (CoreDebug), 101  
CoreDebug\_DCRSR\_REGSEL\_Pos  
  CMSIS, 402  
  Core Debug Registers (CoreDebug), 101  
CoreDebug\_DCRSR\_REGWnR\_Msk  
  CMSIS, 402  
  Core Debug Registers (CoreDebug), 101  
CoreDebug\_DCRSR\_REGWnR\_Pos  
  CMSIS, 402  
  Core Debug Registers (CoreDebug), 101  
CoreDebug\_DEMCR\_MON\_EN\_Msk  
  CMSIS, 402  
  Core Debug Registers (CoreDebug), 101  
CoreDebug\_DEMCR\_MON\_EN\_Pos  
  CMSIS, 402  
  Core Debug Registers (CoreDebug), 102  
CoreDebug\_DEMCR\_MON\_PEND\_Msk  
  CMSIS, 403  
Core Debug Registers (CoreDebug), 102  
CoreDebug\_DEMCR\_MON\_PEND\_Pos  
  CMSIS, 403  
  Core Debug Registers (CoreDebug), 102  
CoreDebug\_DEMCR\_MON\_REQ\_Msk  
  CMSIS, 403  
  Core Debug Registers (CoreDebug), 102  
CoreDebug\_DEMCR\_MON\_REQ\_Pos  
  CMSIS, 403  
  Core Debug Registers (CoreDebug), 102  
CoreDebug\_DEMCR\_MON\_STEP\_Msk  
  CMSIS, 403  
  Core Debug Registers (CoreDebug), 102  
CoreDebug\_DEMCR\_MON\_STEP\_Pos  
  CMSIS, 403  
  Core Debug Registers (CoreDebug), 102  
CoreDebug\_DEMCR\_TRCENA\_Msk  
  CMSIS, 403  
  Core Debug Registers (CoreDebug), 102  
CoreDebug\_DEMCR\_TRCENA\_Pos  
  CMSIS, 403  
  Core Debug Registers (CoreDebug), 103  
CoreDebug\_DEMCR\_VC\_BUSERR\_Msk  
  CMSIS, 404  
  Core Debug Registers (CoreDebug), 103  
CoreDebug\_DEMCR\_VC\_BUSERR\_Pos  
  CMSIS, 404  
  Core Debug Registers (CoreDebug), 103  
CoreDebug\_DEMCR\_VC\_CHKERR\_Msk  
  CMSIS, 404  
  Core Debug Registers (CoreDebug), 103  
CoreDebug\_DEMCR\_VC\_CHKERR\_Pos  
  CMSIS, 404  
  Core Debug Registers (CoreDebug), 103  
CoreDebug\_DEMCR\_VC\_CORERESET\_Msk  
  CMSIS, 404  
  Core Debug Registers (CoreDebug), 103  
CoreDebug\_DEMCR\_VC\_CORERESET\_Pos  
  CMSIS, 404  
  Core Debug Registers (CoreDebug), 103  
CoreDebug\_DEMCR\_VC\_HARDERR\_Msk  
  CMSIS, 404  
  Core Debug Registers (CoreDebug), 103  
CoreDebug\_DEMCR\_VC\_HARDERR\_Pos  
  CMSIS, 404  
  Core Debug Registers (CoreDebug), 104  
CoreDebug\_DEMCR\_VC\_INTERR\_Msk  
  CMSIS, 405  
  Core Debug Registers (CoreDebug), 104  
CoreDebug\_DEMCR\_VC\_INTERR\_Pos  
  CMSIS, 405  
  Core Debug Registers (CoreDebug), 104  
CoreDebug\_DEMCR\_VC\_MMERR\_Msk  
  CMSIS, 405  
  Core Debug Registers (CoreDebug), 104  
CoreDebug\_DEMCR\_VC\_MMERR\_Pos  
  CMSIS, 405  
  Core Debug Registers (CoreDebug), 104

CoreDebug\_DEMCR\_VC\_NOCPERR\_Msk  
  CMSIS, 405  
  Core Debug Registers (CoreDebug), 104

CoreDebug\_DEMCR\_VC\_NOCPERR\_Pos  
  CMSIS, 405  
  Core Debug Registers (CoreDebug), 104

CoreDebug\_DEMCR\_VC\_STATERR\_Msk  
  CMSIS, 405  
  Core Debug Registers (CoreDebug), 104

CoreDebug\_DEMCR\_VC\_STATERR\_Pos  
  CMSIS, 405  
  Core Debug Registers (CoreDebug), 105

CoreDebug\_DHCSR\_C\_DEBUGEN\_Msk  
  CMSIS, 406  
  Core Debug Registers (CoreDebug), 105

CoreDebug\_DHCSR\_C\_DEBUGEN\_Pos  
  CMSIS, 406  
  Core Debug Registers (CoreDebug), 105

CoreDebug\_DHCSR\_C\_HALT\_Msk  
  CMSIS, 406  
  Core Debug Registers (CoreDebug), 105

CoreDebug\_DHCSR\_C\_HALT\_Pos  
  CMSIS, 406  
  Core Debug Registers (CoreDebug), 105

CoreDebug\_DHCSR\_C\_MASKINTS\_Msk  
  CMSIS, 406  
  Core Debug Registers (CoreDebug), 105

CoreDebug\_DHCSR\_C\_MASKINTS\_Pos  
  CMSIS, 406  
  Core Debug Registers (CoreDebug), 105

CoreDebug\_DHCSR\_C\_SNAPSTALL\_Msk  
  CMSIS, 406  
  Core Debug Registers (CoreDebug), 105

CoreDebug\_DHCSR\_C\_SNAPSTALL\_Pos  
  CMSIS, 406  
  Core Debug Registers (CoreDebug), 106

CoreDebug\_DHCSR\_C\_STEP\_Msk  
  CMSIS, 407  
  Core Debug Registers (CoreDebug), 106

CoreDebug\_DHCSR\_C\_STEP\_Pos  
  CMSIS, 407  
  Core Debug Registers (CoreDebug), 106

CoreDebug\_DHCSR\_DBGKEY\_Msk  
  CMSIS, 407  
  Core Debug Registers (CoreDebug), 106

CoreDebug\_DHCSR\_DBGKEY\_Pos  
  CMSIS, 407  
  Core Debug Registers (CoreDebug), 106

CoreDebug\_DHCSR\_S\_HALT\_Msk  
  CMSIS, 407  
  Core Debug Registers (CoreDebug), 106

CoreDebug\_DHCSR\_S\_HALT\_Pos  
  CMSIS, 407  
  Core Debug Registers (CoreDebug), 106

CoreDebug\_DHCSR\_S\_LOCKUP\_Msk  
  CMSIS, 407  
  Core Debug Registers (CoreDebug), 106

CoreDebug\_DHCSR\_S\_LOCKUP\_Pos  
  CMSIS, 407  
  Core Debug Registers (CoreDebug), 106

CMSIS, 407  
Core Debug Registers (CoreDebug), 107

CoreDebug\_DHCSR\_S\_REGRDY\_Msk  
  CMSIS, 408  
  Core Debug Registers (CoreDebug), 107

CoreDebug\_DHCSR\_S\_REGRDY\_Pos  
  CMSIS, 408  
  Core Debug Registers (CoreDebug), 107

CoreDebug\_DHCSR\_S\_RESET\_ST\_Msk  
  CMSIS, 408  
  Core Debug Registers (CoreDebug), 107

CoreDebug\_DHCSR\_S\_RESET\_ST\_Pos  
  CMSIS, 408  
  Core Debug Registers (CoreDebug), 107

CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Msk  
  CMSIS, 408  
  Core Debug Registers (CoreDebug), 107

CoreDebug\_DHCSR\_S\_RETIRE\_ST\_Pos  
  CMSIS, 408  
  Core Debug Registers (CoreDebug), 107

CoreDebug\_DHCSR\_S\_SLEEP\_Msk  
  CMSIS, 408  
  Core Debug Registers (CoreDebug), 107

CoreDebug\_DHCSR\_S\_SLEEP\_Pos  
  CMSIS, 408  
  Core Debug Registers (CoreDebug), 108

CoreDebug\_Type, 1003

Cortex-M4 Peripherals Base Addresses, 157

CPACR  
  ITM Functions, 130

CPICNT  
  ITM Functions, 130

CPSR  
  CMSIS, 472

CPU\_BIT\_ORDER  
  Platform Standard Types, 150

CPU\_BYTE\_ORDER  
  Platform Standard Types, 150

CPU\_TYPE  
  Platform Standard Types, 150

CPU\_TYPE\_16  
  Platform Standard Types, 150

CPU\_TYPE\_32  
  Platform Standard Types, 150

CPU\_TYPE\_64  
  Platform Standard Types, 150

CPU\_TYPE\_8  
  Platform Standard Types, 150

CPUID  
  ITM Functions, 130  
  SCB\_TypeDef, 1047

CR  
  CMSIS, 472–474  
  CRC\_TypeDef, 1004  
  RCC\_TypeDef, 1035

CR1  
  CMSIS, 475  
  I2C\_TypeDef, 1020

SPI\_TypeDef, 1050  
 TIM1\_TypeDef, 1058  
 USART\_TypeDef, 1063  
**CR2**  
 CMSIS, 475, 476  
 I2C\_TypeDef, 1020  
 SPI\_TypeDef, 1050  
 TIM1\_TypeDef, 1058  
 USART\_TypeDef, 1063  
**CR3**  
 CMSIS, 476  
 USART\_TypeDef, 1063  
**CRC**  
 CRC Instance, 178  
**CRC Instance**, 178  
 CRC, 178  
**CRC Register Map**, 166  
**CRC\_CR\_RESET**  
 Peripheral\_Registers\_Bits\_Definition, 802  
**CRC\_DR\_DR**  
 Peripheral\_Registers\_Bits\_Definition, 802  
**CRC\_IDR\_IDR**  
 Peripheral\_Registers\_Bits\_Definition, 802  
**CRC\_TypeDef**, 1004  
 CR, 1004  
 DR, 1004  
 IDR, 1005  
 INIT, 1005  
 POL, 1005  
 RESERVED, 1005  
 SR, 1005  
**CRCPR**  
 CMSIS, 476  
 SPI\_TypeDef, 1051  
**CRYP\_TypeDef**, 1005  
**CSGCM0R**  
 CMSIS, 476  
**CSGCM1R**  
 CMSIS, 476  
**CSGCM2R**  
 CMSIS, 477  
**CSGCM3R**  
 CMSIS, 477  
**CSGCM4R**  
 CMSIS, 477  
**CSGCM5R**  
 CMSIS, 477  
**CSGCM6R**  
 CMSIS, 477  
**CSGCM7R**  
 CMSIS, 477  
**CSGCMCCM0R**  
 CMSIS, 477  
**CSGCMCCM1R**  
 CMSIS, 477  
**CSGCMCCM2R**  
 CMSIS, 478  
**CSGCMCCM3R**  
 CMSIS, 478  
 CMSIS, 478  
 CSGCMCCM4R  
 CMSIS, 478  
 CSGCMCCM5R  
 CMSIS, 478  
 CSGCMCCM6R  
 CMSIS, 478  
 CSGCMCCM7R  
 CMSIS, 478  
**CSPSR**  
 ITM Functions, 130  
**CSR**  
 CMSIS, 478, 479  
 RCC\_TypeDef, 1035  
**CTRL**  
 ITM Functions, 130, 131  
 STK\_TypeDef, 1053  
**CWSIZER**  
 CMSIS, 479  
**CWSTRTR**  
 CMSIS, 479  
**CYCCNT**  
 ITM Functions, 131  
**D0\_PIN**  
 LCD\_t, 1024  
**D1\_PIN**  
 LCD\_t, 1024  
**D2\_PIN**  
 LCD\_t, 1024  
**D3\_PIN**  
 LCD\_t, 1024  
**D4\_PIN**  
 LCD\_t, 1025  
**D5\_PIN**  
 LCD\_t, 1025  
**D6\_PIN**  
 LCD\_t, 1025  
**D7\_PIN**  
 LCD\_t, 1025  
**DAC\_CR\_BOFF1**  
 Peripheral\_Registers\_Bits\_Definition, 802  
**DAC\_CR\_BOFF2**  
 Peripheral\_Registers\_Bits\_Definition, 802  
**DAC\_CR\_DMAEN1**  
 Peripheral\_Registers\_Bits\_Definition, 803  
**DAC\_CR\_DMAEN2**  
 Peripheral\_Registers\_Bits\_Definition, 803  
**DAC\_CR\_DMAUDRIE1**  
 Peripheral\_Registers\_Bits\_Definition, 803  
**DAC\_CR\_DMAUDRIE2**  
 Peripheral\_Registers\_Bits\_Definition, 803  
**DAC\_CR\_EN1**  
 Peripheral\_Registers\_Bits\_Definition, 803  
**DAC\_CR\_EN2**  
 Peripheral\_Registers\_Bits\_Definition, 803  
**DAC\_CR\_MAMP1**  
 Peripheral\_Registers\_Bits\_Definition, 803  
**DAC\_CR\_MAMP1\_0**

- Peripheral\_Registers\_Bits\_Definition, 803  
DAC\_CR\_MAMP1\_1  
  Peripheral\_Registers\_Bits\_Definition, 804  
DAC\_CR\_MAMP1\_2  
  Peripheral\_Registers\_Bits\_Definition, 804  
DAC\_CR\_MAMP1\_3  
  Peripheral\_Registers\_Bits\_Definition, 804  
DAC\_CR\_MAMP2

DWT\_CTRL\_PCSAMPLENA\_Pos, 84  
DWT\_CTRL\_POSTINIT\_Msk, 84  
DWT\_CTRL\_POSTINIT\_Pos, 84  
DWT\_CTRL\_POSTPRESET\_Msk, 84  
DWT\_CTRL\_POSTPRESET\_Pos, 85  
DWT\_CTRL\_SLEEPEVTENA\_Msk, 85  
DWT\_CTRL\_SLEEPEVTENA\_Pos, 85  
DWT\_CTRL\_SYNCTAP\_Msk, 85  
DWT\_CTRL\_SYNCTAP\_Pos, 85  
DWT\_EXCCNT\_EXCCNT\_Msk, 85  
DWT\_EXCCNT\_EXCCNT\_Pos, 85  
DWT\_FOLDCNT\_FOLDCNT\_Msk, 85  
DWT\_FOLDCNT\_FOLDCNT\_Pos, 86  
DWT\_FUNCTION\_CYCMATCH\_Msk, 86  
DWT\_FUNCTION\_CYCMATCH\_Pos, 86  
DWT\_FUNCTION\_DATAVADDR0\_Msk, 86  
DWT\_FUNCTION\_DATAVADDR0\_Pos, 86  
DWT\_FUNCTION\_DATAVADDR1\_Msk, 86  
DWT\_FUNCTION\_DATAVADDR1\_Pos, 86  
DWT\_FUNCTION\_DATAVMATCH\_Msk, 86  
DWT\_FUNCTION\_DATAVMATCH\_Pos, 87  
DWT\_FUNCTION\_DATAVSIZE\_Msk, 87  
DWT\_FUNCTION\_DATAVSIZE\_Pos, 87  
DWT\_FUNCTION\_EMITRANGE\_Msk, 87  
DWT\_FUNCTION\_EMITRANGE\_Pos, 87  
DWT\_FUNCTION\_FUNCTION\_Msk, 87  
DWT\_FUNCTION\_FUNCTION\_Pos, 87  
DWT\_FUNCTION\_LNK1ENA\_Msk, 87  
DWT\_FUNCTION\_LNK1ENA\_Pos, 88  
DWT\_FUNCTION\_MATCHED\_Msk, 88  
DWT\_FUNCTION\_MATCHED\_Pos, 88  
DWT\_LSUCNT\_LSUCNT\_Msk, 88  
DWT\_LSUCNT\_LSUCNT\_Pos, 88  
DWT\_MASK\_MASK\_Msk, 88  
DWT\_MASK\_MASK\_Pos, 88  
DWT\_SLEEPCNT\_SLEEPCNT\_Msk, 88  
DWT\_SLEEPCNT\_SLEEPCNT\_Pos, 89  
DBGMCU\_CR\_TRACE\_MODE\_0  
Peripheral\_Registers\_Bits\_Definition, 809  
DBGMCU\_CR\_TRACE\_MODE\_1  
Peripheral\_Registers\_Bits\_Definition, 809  
DBGMCU\_TypeDef, 1007  
DCCR  
CMSIS, 479  
DCKCFGR  
CMSIS, 479  
RCC\_TypeDef, 1035  
DCKCFGR2  
CMSIS, 479  
DCMI\_TypeDef, 1008  
DCOUNT  
CMSIS, 479  
DCR  
CMSIS, 480  
TIM1\_TypeDef, 1058  
DCRDR  
ITM Functions, 131  
DCRSR

ITM Functions, 131  
DCTRL  
CMSIS, 480  
DebugMonitor\_IRQHandler  
Configuration\_section\_for\CMSIS, 524  
Defines and Type Definitions, 42  
DEMCR  
ITM Functions, 131  
Device\_Mode  
S\_SPI\_Config\_t, 1044  
DEVID  
ITM Functions, 131  
DEVTYPE  
ITM Functions, 131  
DFR  
ITM Functions, 132  
DFSDM\_CHAWSCDR\_AWFORD  
Peripheral\_Registers\_Bits\_Definition, 809  
DFSDM\_CHAWSCDR\_AWFORD\_0  
Peripheral\_Registers\_Bits\_Definition, 809  
DFSDM\_CHAWSCDR\_AWFORD\_1  
Peripheral\_Registers\_Bits\_Definition, 809  
DFSDM\_CHAWSCDR\_AWFOSR  
Peripheral\_Registers\_Bits\_Definition, 809  
DFSDM\_CHAWSCDR\_BKSCD  
Peripheral\_Registers\_Bits\_Definition, 810  
DFSDM\_CHAWSCDR\_SCDT  
Peripheral\_Registers\_Bits\_Definition, 810  
DFSDM\_CHCFGRI\_CHEN  
Peripheral\_Registers\_Bits\_Definition, 810  
DFSDM\_CHCFGRI\_CHINSEL  
Peripheral\_Registers\_Bits\_Definition, 810  
DFSDM\_CHCFGRI\_CKABEN  
Peripheral\_Registers\_Bits\_Definition, 810  
DFSDM\_CHCFGRI\_CKOUTDIV  
Peripheral\_Registers\_Bits\_Definition, 810  
DFSDM\_CHCFGRI\_CKOUTSRC  
Peripheral\_Registers\_Bits\_Definition, 810  
DFSDM\_CHCFGRI\_DATMPX  
Peripheral\_Registers\_Bits\_Definition, 810  
DFSDM\_CHCFGRI\_DATMPX\_0  
Peripheral\_Registers\_Bits\_Definition, 811  
DFSDM\_CHCFGRI\_DATMPX\_1  
Peripheral\_Registers\_Bits\_Definition, 811  
DFSDM\_CHCFGRI\_DATPACK  
Peripheral\_Registers\_Bits\_Definition, 811  
DFSDM\_CHCFGRI\_DATPACK\_0  
Peripheral\_Registers\_Bits\_Definition, 811  
DFSDM\_CHCFGRI\_DATPACK\_1  
Peripheral\_Registers\_Bits\_Definition, 811  
DFSDM\_CHCFGRI\_DFSDMEN  
Peripheral\_Registers\_Bits\_Definition, 811  
DFSDM\_CHCFGRI\_SCDEN  
Peripheral\_Registers\_Bits\_Definition, 811  
DFSDM\_CHCFGRI\_SITP  
Peripheral\_Registers\_Bits\_Definition, 811  
DFSDM\_CHCFGRI\_SITP\_0  
Peripheral\_Registers\_Bits\_Definition, 812

DFSDM\_CHCFG1\_SITP\_1  
    Peripheral\_Registers\_Bits\_Definition, 812  
DFSDM\_CHCFG1\_SPICKSEL  
    Peripheral\_Registers\_Bits\_Definition, 812  
DFSDM\_CHCFG1\_SPICKSEL\_0  
    Peripheral\_Registers\_Bits\_Definition, 812  
DFSDM\_CHCFG1\_SPICKSEL\_1  
    Peripheral\_Registers\_Bits\_Definition, 812  
DFSDM\_CHCFG2\_DTRBS  
    Peripheral\_Registers\_Bits\_Definition, 812  
DFSDM\_CHCFG2\_OFFSET  
    Peripheral\_Registers\_Bits\_Definition, 812  
DFSDM\_CHDATINR\_INDAT0  
    Peripheral\_Registers\_Bits\_Definition, 812  
DFSDM\_CHDATINR\_INDAT1  
    Peripheral\_Registers\_Bits\_Definition, 813  
DFSDM\_CHWDATR\_WDATA  
    Peripheral\_Registers\_Bits\_Definition, 813  
DFSDM\_FLTAWCFR\_CLRAWHTF  
    Peripheral\_Registers\_Bits\_Definition, 813  
DFSDM\_FLTAWCFR\_CLRAWLTF  
    Peripheral\_Registers\_Bits\_Definition, 813  
DFSDM\_FLTAWHTR\_AWHT  
    Peripheral\_Registers\_Bits\_Definition, 813  
DFSDM\_FLTAWHTR\_BKAWH  
    Peripheral\_Registers\_Bits\_Definition, 813  
DFSDM\_FLTAWLTR\_AWLT  
    Peripheral\_Registers\_Bits\_Definition, 813  
DFSDM\_FLTAWLTR\_BKAWL  
    Peripheral\_Registers\_Bits\_Definition, 813  
DFSDM\_FLTAWSR\_AWHTF  
    Peripheral\_Registers\_Bits\_Definition, 814  
DFSDM\_FLTAWSR\_AWLTF  
    Peripheral\_Registers\_Bits\_Definition, 814  
DFSDM\_FLTCR1\_AWFSEL  
    Peripheral\_Registers\_Bits\_Definition, 814  
DFSDM\_FLTCR1\_DFEN  
    Peripheral\_Registers\_Bits\_Definition, 814  
DFSDM\_FLTCR1\_FAST  
    Peripheral\_Registers\_Bits\_Definition, 814  
DFSDM\_FLTCR1\_JDMAEN  
    Peripheral\_Registers\_Bits\_Definition, 814  
DFSDM\_FLTCR1\_JEXTEN  
    Peripheral\_Registers\_Bits\_Definition, 814  
DFSDM\_FLTCR1\_JEXTEN\_0  
    Peripheral\_Registers\_Bits\_Definition, 815  
DFSDM\_FLTCR1\_JEXTEN\_1  
    Peripheral\_Registers\_Bits\_Definition, 815  
DFSDM\_FLTCR1\_JEXTSEL  
    Peripheral\_Registers\_Bits\_Definition, 815  
DFSDM\_FLTCR1\_JEXTSEL\_0  
    Peripheral\_Registers\_Bits\_Definition, 815  
DFSDM\_FLTCR1\_JEXTSEL\_1  
    Peripheral\_Registers\_Bits\_Definition, 815  
DFSDM\_FLTCR1\_JEXTSEL\_2  
    Peripheral\_Registers\_Bits\_Definition, 815  
DFSDM\_FLTCR1\_JSCAN  
    Peripheral\_Registers\_Bits\_Definition, 815  
DFSDM\_FLTCR1\_JSSTART  
    Peripheral\_Registers\_Bits\_Definition, 815  
DFSDM\_FLTCR1\_JSYNC  
    Peripheral\_Registers\_Bits\_Definition, 816  
DFSDM\_FLTCR1\_RCH  
    Peripheral\_Registers\_Bits\_Definition, 816  
DFSDM\_FLTCR1\_RCONT  
    Peripheral\_Registers\_Bits\_Definition, 816  
DFSDM\_FLTCR1\_RDMAEN  
    Peripheral\_Registers\_Bits\_Definition, 816  
DFSDM\_FLTCR1\_RSWSTART  
    Peripheral\_Registers\_Bits\_Definition, 816  
DFSDM\_FLTCR1\_RSYNC  
    Peripheral\_Registers\_Bits\_Definition, 816  
DFSDM\_FLTCR2\_AWDCH  
    Peripheral\_Registers\_Bits\_Definition, 816  
DFSDM\_FLTCR2\_AWDIE  
    Peripheral\_Registers\_Bits\_Definition, 817  
DFSDM\_FLTCR2\_CKABIE  
    Peripheral\_Registers\_Bits\_Definition, 817  
DFSDM\_FLTCR2\_EXCH  
    Peripheral\_Registers\_Bits\_Definition, 817  
DFSDM\_FLTCR2\_JEOCIE  
    Peripheral\_Registers\_Bits\_Definition, 817  
DFSDM\_FLTCR2\_JOVRIE  
    Peripheral\_Registers\_Bits\_Definition, 817  
DFSDM\_FLTCR2\_REOCIE  
    Peripheral\_Registers\_Bits\_Definition, 817  
DFSDM\_FLTCR2\_ROVRIE  
    Peripheral\_Registers\_Bits\_Definition, 817  
DFSDM\_FLTCR2\_SCDIE  
    Peripheral\_Registers\_Bits\_Definition, 817  
DFSDM\_FLTEXMAX\_EXMAX  
    Peripheral\_Registers\_Bits\_Definition, 818  
DFSDM\_FLTEXMAX\_EXMAXCH  
    Peripheral\_Registers\_Bits\_Definition, 818  
DFSDM\_FLTEXMIN\_EXMIN  
    Peripheral\_Registers\_Bits\_Definition, 818  
DFSDM\_FLTEXMIN\_EXMINCH  
    Peripheral\_Registers\_Bits\_Definition, 818  
DFSDM\_FLTFCR\_FORD  
    Peripheral\_Registers\_Bits\_Definition, 818  
DFSDM\_FLTFCR\_FORD\_0  
    Peripheral\_Registers\_Bits\_Definition, 818  
DFSDM\_FLTFCR\_FORD\_1  
    Peripheral\_Registers\_Bits\_Definition, 818  
DFSDM\_FLTFCR\_FORD\_2  
    Peripheral\_Registers\_Bits\_Definition, 818  
DFSDM\_FLTFCR\_FOSR  
    Peripheral\_Registers\_Bits\_Definition, 819  
DFSDM\_FLTFCR\_IOSR  
    Peripheral\_Registers\_Bits\_Definition, 819  
DFSDM\_FLTICR\_CLRCKABF  
    Peripheral\_Registers\_Bits\_Definition, 819  
DFSDM\_FLTICR\_CLRJOVRF  
    Peripheral\_Registers\_Bits\_Definition, 819

DFSDM\_FLTICR\_CLRROVRF  
     Peripheral\_Registers\_Bits\_Definition, 819

DFSDM\_FLTICR\_CLRSCDF  
     Peripheral\_Registers\_Bits\_Definition, 819

DFSDM\_FLTISR\_AWDF  
     Peripheral\_Registers\_Bits\_Definition, 819

DFSDM\_FLTISR\_CKABF  
     Peripheral\_Registers\_Bits\_Definition, 819

DFSDM\_FLTISR\_JCIP  
     Peripheral\_Registers\_Bits\_Definition, 820

DFSDM\_FLTISR\_JEOCF  
     Peripheral\_Registers\_Bits\_Definition, 820

DFSDM\_FLTISR\_JOVRF  
     Peripheral\_Registers\_Bits\_Definition, 820

DFSDM\_FLTISR\_RCIP  
     Peripheral\_Registers\_Bits\_Definition, 820

DFSDM\_FLTISR\_REOCF  
     Peripheral\_Registers\_Bits\_Definition, 820

DFSDM\_FLTISR\_ROVRF  
     Peripheral\_Registers\_Bits\_Definition, 820

DFSDM\_FLTISR\_SCDF  
     Peripheral\_Registers\_Bits\_Definition, 820

DFSDM\_FLTJCHGR\_JCHG  
     Peripheral\_Registers\_Bits\_Definition, 820

DFSDM\_FLTJDATAR\_JDATA  
     Peripheral\_Registers\_Bits\_Definition, 821

DFSDM\_FLTJDATAR\_JDATACH  
     Peripheral\_Registers\_Bits\_Definition, 821

DFSDM\_FLTRDATAR\_RDATA  
     Peripheral\_Registers\_Bits\_Definition, 821

DFSDM\_FLTRDATAR\_RDATACH  
     Peripheral\_Registers\_Bits\_Definition, 821

DFSDM\_FLTRDATAR\_RPEND  
     Peripheral\_Registers\_Bits\_Definition, 821

DFSR  
     ITM Functions, 132

DHCSR  
     ITM Functions, 132

DHR12L1  
     CMSIS, 480

DHR12L2  
     CMSIS, 480

DHR12LD  
     CMSIS, 480

DHR12R1  
     CMSIS, 480

DHR12R2  
     CMSIS, 480

DHR12RD  
     CMSIS, 480

DHR8R1  
     CMSIS, 481

DHR8R2  
     CMSIS, 481

DHR8RD  
     CMSIS, 481

DIER  
     CMSIS, 481

TIM1\_TypeDef, 1058

DIN  
     CMSIS, 481

DISABLE  
     I2C Driver, 270

Disabled  
     SPI Driver, 316

Display\_Mode  
     LCD\_t, 1025

DLEN  
     CMSIS, 481

DMA1\_Stream0\_IRQHandler  
     Configuration\_section\_for\CMSIS, 525

DMA1\_Stream1\_IRQHandler  
     Configuration\_section\_for\CMSIS, 525

DMA1\_Stream2\_IRQHandler  
     Configuration\_section\_for\CMSIS, 525

DMA1\_Stream3\_IRQHandler  
     Configuration\_section\_for\CMSIS, 525

DMA1\_Stream4\_IRQHandler  
     Configuration\_section\_for\CMSIS, 525

DMA1\_Stream5\_IRQHandler  
     Configuration\_section\_for\CMSIS, 525

DMA1\_Stream6\_IRQHandler  
     Configuration\_section\_for\CMSIS, 525

DMA1\_Stream7\_IRQHandler  
     Configuration\_section\_for\CMSIS, 526

DMA2\_Stream0\_IRQHandler  
     Configuration\_section\_for\CMSIS, 526

DMA2\_Stream1\_IRQHandler  
     Configuration\_section\_for\CMSIS, 526

DMA2\_Stream2\_IRQHandler  
     Configuration\_section\_for\CMSIS, 526

DMA2\_Stream3\_IRQHandler  
     Configuration\_section\_for\CMSIS, 526

DMA2\_Stream4\_IRQHandler  
     Configuration\_section\_for\CMSIS, 526

DMA2\_Stream5\_IRQHandler  
     Configuration\_section\_for\CMSIS, 526

DMA2\_Stream6\_IRQHandler  
     Configuration\_section\_for\CMSIS, 526

DMA2\_Stream7\_IRQHandler  
     Configuration\_section\_for\CMSIS, 526

DMA2D\_AMTCR\_DT  
     Peripheral\_Registers\_Bits\_Definition, 821

DMA2D\_AMTCR\_EN  
     Peripheral\_Registers\_Bits\_Definition, 821

DMA2D\_BASE  
     Peripheral\_memory\_map, 535

DMA2D\_BGCMAR\_MA  
     Peripheral\_Registers\_Bits\_Definition, 821

DMA2D\_BGCOLR\_BLUE  
     Peripheral\_Registers\_Bits\_Definition, 822

DMA2D\_BGCOLR\_GREEN  
     Peripheral\_Registers\_Bits\_Definition, 822

DMA2D\_BGCOLR\_RED  
     Peripheral\_Registers\_Bits\_Definition, 822

DMA2D\_BGMAR\_MA

- Peripheral\_Registers\_Bits\_Definition, [822](#)
- DMA2D\_BGOR\_LO  
        Peripheral\_Registers\_Bits\_Definition, [822](#)
- DMA2D\_BGPFCCR\_ALPHA  
        Peripheral\_Registers\_Bits\_Definition, [822](#)
- DMA2D\_BGPFCCR\_AM  
        Peripheral\_Registers\_Bits\_Definition, [822](#)
- DMA2D\_BGPFCCR\_AM\_0  
        Peripheral\_Registers\_Bits\_Definition, [822](#)
- DMA2D\_BGPFCCR\_AM\_1  
        Peripheral\_Registers\_Bits\_Definition, [823](#)
- DMA2D\_BGPFCCR\_CCM  
        Peripheral\_Registers\_Bits\_Definition, [823](#)
- DMA2D\_BGPFCCR\_CM  
        Peripheral\_Registers\_Bits\_Definition, [823](#)
- DMA2D\_BGPFCCR\_CM\_0  
        Peripheral\_Registers\_Bits\_Definition, [823](#)
- DMA2D\_BGPFCCR\_CM\_1  
        Peripheral\_Registers\_Bits\_Definition, [823](#)
- DMA2D\_BGPFCCR\_CM\_2  
        Peripheral\_Registers\_Bits\_Definition, [823](#)
- DMA2D\_BGPFCCR\_CS  
        Peripheral\_Registers\_Bits\_Definition, [823](#)
- DMA2D\_BGPFCCR\_START  
        Peripheral\_Registers\_Bits\_Definition, [823](#)
- DMA2D\_CR\_ABORT  
        Peripheral\_Registers\_Bits\_Definition, [824](#)
- DMA2D\_CR\_CAEIE  
        Peripheral\_Registers\_Bits\_Definition, [824](#)
- DMA2D\_CR\_CEIE  
        Peripheral\_Registers\_Bits\_Definition, [824](#)
- DMA2D\_CR\_CTCIE  
        Peripheral\_Registers\_Bits\_Definition, [824](#)
- DMA2D\_CR\_MODE  
        Peripheral\_Registers\_Bits\_Definition, [824](#)
- DMA2D\_CR\_START  
        Peripheral\_Registers\_Bits\_Definition, [824](#)
- DMA2D\_CR\_SUSP  
        Peripheral\_Registers\_Bits\_Definition, [824](#)
- DMA2D\_CR\_TCIE  
        Peripheral\_Registers\_Bits\_Definition, [824](#)
- DMA2D\_CR\_TEIE  
        Peripheral\_Registers\_Bits\_Definition, [825](#)
- DMA2D\_CR\_TWIE  
        Peripheral\_Registers\_Bits\_Definition, [825](#)
- DMA2D\_FGCMAR\_MA  
        Peripheral\_Registers\_Bits\_Definition, [825](#)
- DMA2D\_FGCOLR\_BLUE  
        Peripheral\_Registers\_Bits\_Definition, [825](#)
- DMA2D\_FGCOLR\_GREEN  
        Peripheral\_Registers\_Bits\_Definition, [825](#)
- DMA2D\_FGCOLR\_RED  
        Peripheral\_Registers\_Bits\_Definition, [825](#)
- DMA2D\_FGMAR\_MA  
        Peripheral\_Registers\_Bits\_Definition, [825](#)
- DMA2D\_FGOR\_LO  
        Peripheral\_Registers\_Bits\_Definition, [825](#)
- DMA2D\_FGPFCCR\_ALPHA  
        Peripheral\_Registers\_Bits\_Definition, [826](#)
- DMA2D\_FGPFCCR\_AM  
        Peripheral\_Registers\_Bits\_Definition, [826](#)
- DMA2D\_FGPFCCR\_AM\_0  
        Peripheral\_Registers\_Bits\_Definition, [826](#)
- DMA2D\_FGPFCCR\_AM\_1  
        Peripheral\_Registers\_Bits\_Definition, [826](#)
- DMA2D\_FGPFCCR\_CCM  
        Peripheral\_Registers\_Bits\_Definition, [826](#)
- DMA2D\_FGPFCCR\_CM  
        Peripheral\_Registers\_Bits\_Definition, [826](#)
- DMA2D\_FGPFCCR\_CM\_0  
        Peripheral\_Registers\_Bits\_Definition, [826](#)
- DMA2D\_FGPFCCR\_CM\_1  
        Peripheral\_Registers\_Bits\_Definition, [826](#)
- DMA2D\_FGPFCCR\_CM\_2  
        Peripheral\_Registers\_Bits\_Definition, [827](#)
- DMA2D\_FGPFCCR\_CM\_3  
        Peripheral\_Registers\_Bits\_Definition, [827](#)
- DMA2D\_FGPFCCR\_CS  
        Peripheral\_Registers\_Bits\_Definition, [827](#)
- DMA2D\_FGPFCCR\_START  
        Peripheral\_Registers\_Bits\_Definition, [827](#)
- DMA2D\_IFCR\_CAEIF  
        Peripheral\_Registers\_Bits\_Definition, [827](#)
- DMA2D\_IFCR\_CCEIF  
        Peripheral\_Registers\_Bits\_Definition, [827](#)
- DMA2D\_IFCR\_CCTCIF  
        Peripheral\_Registers\_Bits\_Definition, [828](#)
- DMA2D\_IFCR\_CTCIF  
        Peripheral\_Registers\_Bits\_Definition, [828](#)
- DMA2D\_IFCR\_CTEIF  
        Peripheral\_Registers\_Bits\_Definition, [828](#)
- DMA2D\_IFCR\_CTWIF  
        Peripheral\_Registers\_Bits\_Definition, [828](#)
- DMA2D\_IFSR\_CCAEIF  
        Peripheral\_Registers\_Bits\_Definition, [828](#)
- DMA2D\_IFSR\_CCEIF  
        Peripheral\_Registers\_Bits\_Definition, [828](#)
- DMA2D\_IFSR\_CCTCIF  
        Peripheral\_Registers\_Bits\_Definition, [828](#)
- DMA2D\_IFSR\_CTCIF  
        Peripheral\_Registers\_Bits\_Definition, [829](#)
- DMA2D\_IFSR\_CTEIF  
        Peripheral\_Registers\_Bits\_Definition, [829](#)
- DMA2D\_IFSR\_CTWIF  
        Peripheral\_Registers\_Bits\_Definition, [829](#)
- DMA2D\_ISR\_CAEIF  
        Peripheral\_Registers\_Bits\_Definition, [829](#)
- DMA2D\_ISR\_CEIF  
        Peripheral\_Registers\_Bits\_Definition, [829](#)
- DMA2D\_ISR\_CTCIF  
        Peripheral\_Registers\_Bits\_Definition, [829](#)
- DMA2D\_ISR\_TCIF  
        Peripheral\_Registers\_Bits\_Definition, [829](#)
- DMA2D\_ISR\_TEIF  
        Peripheral\_Registers\_Bits\_Definition, [830](#)
- DMA2D\_ISR\_TWIF

Peripheral\_Registers\_Bits\_Definition, 830  
**DMA2D\_LWR\_LW**  
 Peripheral\_Registers\_Bits\_Definition, 830  
**DMA2D\_NLR\_NL**  
 Peripheral\_Registers\_Bits\_Definition, 830  
**DMA2D\_NLR\_PL**  
 Peripheral\_Registers\_Bits\_Definition, 830  
**DMA2D\_OCOLR\_ALPHA\_1**  
 Peripheral\_Registers\_Bits\_Definition, 830  
**DMA2D\_OCOLR\_ALPHA\_3**  
 Peripheral\_Registers\_Bits\_Definition, 830  
**DMA2D\_OCOLR\_ALPHA\_4**  
 Peripheral\_Registers\_Bits\_Definition, 830  
**DMA2D\_OCOLR\_BLUE\_1**  
 Peripheral\_Registers\_Bits\_Definition, 831  
**DMA2D\_OCOLR\_BLUE\_2**  
 Peripheral\_Registers\_Bits\_Definition, 831  
**DMA2D\_OCOLR\_BLUE\_3**  
 Peripheral\_Registers\_Bits\_Definition, 831  
**DMA2D\_OCOLR\_BLUE\_4**  
 Peripheral\_Registers\_Bits\_Definition, 831  
**DMA2D\_OCOLR\_GREEN\_1**  
 Peripheral\_Registers\_Bits\_Definition, 831  
**DMA2D\_OCOLR\_GREEN\_2**  
 Peripheral\_Registers\_Bits\_Definition, 831  
**DMA2D\_OCOLR\_GREEN\_3**  
 Peripheral\_Registers\_Bits\_Definition, 831  
**DMA2D\_OCOLR\_GREEN\_4**  
 Peripheral\_Registers\_Bits\_Definition, 832  
**DMA2D\_OCOLR\_RED\_1**  
 Peripheral\_Registers\_Bits\_Definition, 832  
**DMA2D\_OCOLR\_RED\_2**  
 Peripheral\_Registers\_Bits\_Definition, 832  
**DMA2D\_OCOLR\_RED\_3**  
 Peripheral\_Registers\_Bits\_Definition, 832  
**DMA2D\_OCOLR\_RED\_4**  
 Peripheral\_Registers\_Bits\_Definition, 832  
**DMA2D\_OMAR\_MA**  
 Peripheral\_Registers\_Bits\_Definition, 832  
**DMA2D\_OOR\_LO**  
 Peripheral\_Registers\_Bits\_Definition, 832  
**DMA2D\_OPFCCR\_CM**  
 Peripheral\_Registers\_Bits\_Definition, 833  
**DMA2D\_OPFCCR\_CM\_0**  
 Peripheral\_Registers\_Bits\_Definition, 833  
**DMA2D\_OPFCCR\_CM\_1**  
 Peripheral\_Registers\_Bits\_Definition, 833  
**DMA2D\_OPFCCR\_CM\_2**  
 Peripheral\_Registers\_Bits\_Definition, 833  
**DMA2D\_TypeDef**, 1008  
**DMA\_Stream\_TypeDef**, 1009  
**DMA\_TypeDef**, 1010  
**DMACR**  
 CMSIS, 481  
**DMAR**  
 CMSIS, 482  
 TIM1\_TypeDef, 1058  
**dms**

API Function Prototypes, 342  
**DO1**  
 CMSIS, 482  
**DOR2**  
 CMSIS, 482  
**DOUT**  
 CMSIS, 482  
**DR**  
 CMSIS, 482, 483  
 CRC\_TypeDef, 1004  
 I2C\_TypeDef, 1020  
 SPI\_TypeDef, 1051  
 USART\_TypeDef, 1063  
**drivers/Inc/Platform\_Types.h**, 1185  
**drivers/Inc/stm32f401xx.h**, 1187  
**drivers/Inc/stm32f401xx\_gpio\_driver.h**, 1197  
**drivers/Inc/stm32f401xx\_i2c\_driver.h**, 1200  
**drivers/Inc/stm32f401xx\_nvic\_driver.h**, 1202  
**drivers/Inc/stm32f401xx\_rcc\_driver.h**, 1207  
**drivers/Inc/stm32f401xx\_spi\_driver.h**, 1209  
**drivers/Inc/stm32f401xx\_systick\_driver.h**, 1211  
**drivers/Inc/stm32f401xx\_timer\_driver.h**, 1213  
**drivers/Inc/stm32f401xx\_usart\_driver.h**, 1215  
**drivers/Src/stm32f401xx\_gpio\_driver.c**, 1217  
**drivers/Src/stm32f401xx\_i2c\_driver.c**, 1218  
**drivers/Src/stm32f401xx\_spi\_driver.c**, 1220  
**DTIMER**  
 CMSIS, 483  
**dus**  
 API Function Prototypes, 342  
**DWT**  
 CMSIS, 409  
 Core Definitions, 109  
**DWT\_BASE**  
 CMSIS, 409  
 Core Definitions, 109  
**DWT\_CPICNT\_CPICNT\_Msk**  
 CMSIS, 409  
 Data Watchpoint and Trace (DWT), 80  
**DWT\_CPICNT\_CPICNT\_Pos**  
 CMSIS, 409  
 Data Watchpoint and Trace (DWT), 81  
**DWT\_CTRL\_CPIEVTEA\_Msk**  
 CMSIS, 409  
 Data Watchpoint and Trace (DWT), 81  
**DWT\_CTRL\_CPIEVTEA\_Pos**  
 CMSIS, 409  
 Data Watchpoint and Trace (DWT), 81  
**DWT\_CTRL\_CYCCNTENA\_Msk**  
 CMSIS, 409  
 Data Watchpoint and Trace (DWT), 81  
**DWT\_CTRL\_CYCCNTENA\_Pos**  
 CMSIS, 410  
 Data Watchpoint and Trace (DWT), 81  
**DWT\_CTRL\_CYCEVTENA\_Msk**  
 CMSIS, 410  
 Data Watchpoint and Trace (DWT), 81  
**DWT\_CTRL\_CYCEVTENA\_Pos**

CMSIS, 410  
Data Watchpoint and Trace (DWT), 81  
**DWT\_CTRL\_CYCTAP\_Msk**  
CMSIS, 410  
Data Watchpoint and Trace (DWT), 81  
**DWT\_CTRL\_CYCTAP\_Pos**  
CMSIS, 410  
Data Watchpoint and Trace (DWT), 82  
**DWT\_CTRL\_EXCEVTENA\_Msk**  
CMSIS, 410  
Data Watchpoint and Trace (DWT), 82  
**DWT\_CTRL\_EXCEVTENA\_Pos**  
CMSIS, 410  
Data Watchpoint and Trace (DWT), 82  
**DWT\_CTRL\_EXCTRCENA\_Msk**  
CMSIS, 410  
Data Watchpoint and Trace (DWT), 82  
**DWT\_CTRL\_EXCTRCENA\_Pos**  
CMSIS, 411  
Data Watchpoint and Trace (DWT), 82  
**DWT\_CTRL\_FOLDEVTENA\_Msk**  
CMSIS, 411  
Data Watchpoint and Trace (DWT), 82  
**DWT\_CTRL\_FOLDEVTENA\_Pos**  
CMSIS, 411  
Data Watchpoint and Trace (DWT), 82  
**DWT\_CTRL\_LSUEVTENA\_Msk**  
CMSIS, 411  
Data Watchpoint and Trace (DWT), 82  
**DWT\_CTRL\_LSUEVTENA\_Pos**  
CMSIS, 411  
Data Watchpoint and Trace (DWT), 83  
**DWT\_CTRL\_NOCYCCNT\_Msk**  
CMSIS, 411  
Data Watchpoint and Trace (DWT), 83  
**DWT\_CTRL\_NOCYCCNT\_Pos**  
CMSIS, 411  
Data Watchpoint and Trace (DWT), 83  
**DWT\_CTRL\_NOEXTTRIG\_Msk**  
CMSIS, 411  
Data Watchpoint and Trace (DWT), 83  
**DWT\_CTRL\_NOEXTTRIG\_Pos**  
CMSIS, 412  
Data Watchpoint and Trace (DWT), 83  
**DWT\_CTRL\_NOPRFCNT\_Msk**  
CMSIS, 412  
Data Watchpoint and Trace (DWT), 83  
**DWT\_CTRL\_NOPRFCNT\_Pos**  
CMSIS, 412  
Data Watchpoint and Trace (DWT), 83  
**DWT\_CTRL\_NOTRCPKT\_Msk**  
CMSIS, 412  
Data Watchpoint and Trace (DWT), 83  
**DWT\_CTRL\_NOTRCPKT\_Pos**  
CMSIS, 412  
Data Watchpoint and Trace (DWT), 84  
**DWT\_CTRL\_NUMCOMP\_Msk**  
CMSIS, 412  
Data Watchpoint and Trace (DWT), 84  
Data Watchpoint and Trace (DWT), 84  
**DWT\_CTRL\_NUMCOMP\_Pos**  
CMSIS, 412  
Data Watchpoint and Trace (DWT), 84  
**DWT\_CTRL\_PCSAMPLENA\_Msk**  
CMSIS, 412  
Data Watchpoint and Trace (DWT), 84  
**DWT\_CTRL\_PCSAMPLENA\_Pos**  
CMSIS, 413  
Data Watchpoint and Trace (DWT), 84  
**DWT\_CTRL\_POSTINIT\_Msk**  
CMSIS, 413  
Data Watchpoint and Trace (DWT), 84  
**DWT\_CTRL\_POSTINIT\_Pos**  
CMSIS, 413  
Data Watchpoint and Trace (DWT), 84  
**DWT\_CTRL\_POSTPRESET\_Msk**  
CMSIS, 413  
Data Watchpoint and Trace (DWT), 84  
**DWT\_CTRL\_POSTPRESET\_Pos**  
CMSIS, 413  
Data Watchpoint and Trace (DWT), 85  
**DWT\_CTRL\_SLEEPEVTENA\_Msk**  
CMSIS, 413  
Data Watchpoint and Trace (DWT), 85  
**DWT\_CTRL\_SLEEPEVTENA\_Pos**  
CMSIS, 413  
Data Watchpoint and Trace (DWT), 85  
**DWT\_CTRL\_SYNCTAP\_Msk**  
CMSIS, 413  
Data Watchpoint and Trace (DWT), 85  
**DWT\_CTRL\_SYNCTAP\_Pos**  
CMSIS, 414  
Data Watchpoint and Trace (DWT), 85  
**DWT\_EXCCNT\_EXCCNT\_Msk**  
CMSIS, 414  
Data Watchpoint and Trace (DWT), 85  
**DWT\_EXCCNT\_EXCCNT\_Pos**  
CMSIS, 414  
Data Watchpoint and Trace (DWT), 85  
**DWT\_FOLDCNT\_FOLDCNT\_Msk**  
CMSIS, 414  
Data Watchpoint and Trace (DWT), 85  
**DWT\_FOLDCNT\_FOLDCNT\_Pos**  
CMSIS, 414  
Data Watchpoint and Trace (DWT), 86  
**DWT\_FUNCTION\_CYCMATCH\_Msk**  
CMSIS, 414  
Data Watchpoint and Trace (DWT), 86  
**DWT\_FUNCTION\_CYCMATCH\_Pos**  
CMSIS, 414  
Data Watchpoint and Trace (DWT), 86  
**DWT\_FUNCTION\_DATAVADDR0\_Msk**  
CMSIS, 414  
Data Watchpoint and Trace (DWT), 86  
**DWT\_FUNCTION\_DATAVADDR0\_Pos**  
CMSIS, 415  
Data Watchpoint and Trace (DWT), 86

DWT\_FUNCTION\_DATAVADDR1\_Msk  
 CMSIS, 415  
 Data Watchpoint and Trace (DWT), 86

DWT\_FUNCTION\_DATAVADDR1\_Pos  
 CMSIS, 415  
 Data Watchpoint and Trace (DWT), 86

DWT\_FUNCTION\_DATAVMATCH\_Msk  
 CMSIS, 415  
 Data Watchpoint and Trace (DWT), 86

DWT\_FUNCTION\_DATAVMATCH\_Pos  
 CMSIS, 415  
 Data Watchpoint and Trace (DWT), 87

DWT\_FUNCTION\_DATAVSIZE\_Msk  
 CMSIS, 415  
 Data Watchpoint and Trace (DWT), 87

DWT\_FUNCTION\_DATAVSIZE\_Pos  
 CMSIS, 415  
 Data Watchpoint and Trace (DWT), 87

DWT\_FUNCTION\_EMITRANGE\_Msk  
 CMSIS, 415  
 Data Watchpoint and Trace (DWT), 87

DWT\_FUNCTION\_EMITRANGE\_Pos  
 CMSIS, 416  
 Data Watchpoint and Trace (DWT), 87

DWT\_FUNCTION\_FUNCTION\_Msk  
 CMSIS, 416  
 Data Watchpoint and Trace (DWT), 87

DWT\_FUNCTION\_FUNCTION\_Pos  
 CMSIS, 416  
 Data Watchpoint and Trace (DWT), 87

DWT\_FUNCTION\_LNK1ENA\_Msk  
 CMSIS, 416  
 Data Watchpoint and Trace (DWT), 87

DWT\_FUNCTION\_LNK1ENA\_Pos  
 CMSIS, 416  
 Data Watchpoint and Trace (DWT), 88

DWT\_FUNCTION\_MATCHED\_Msk  
 CMSIS, 416  
 Data Watchpoint and Trace (DWT), 88

DWT\_FUNCTION\_MATCHED\_Pos  
 CMSIS, 416  
 Data Watchpoint and Trace (DWT), 88

DWT\_LSUCNT\_LSUCNT\_Msk  
 CMSIS, 416  
 Data Watchpoint and Trace (DWT), 88

DWT\_LSUCNT\_LSUCNT\_Pos  
 CMSIS, 417  
 Data Watchpoint and Trace (DWT), 88

DWT\_MASK\_MASK\_Msk  
 CMSIS, 417  
 Data Watchpoint and Trace (DWT), 88

DWT\_MASK\_MASK\_Pos  
 CMSIS, 417  
 Data Watchpoint and Trace (DWT), 88

DWT\_SLEEPcnt\_SLEEPcnt\_Msk  
 CMSIS, 417  
 Data Watchpoint and Trace (DWT), 88

DWT\_SLEEPcnt\_SLEEPcnt\_Pos

CMSIS, 417  
 Data Watchpoint and Trace (DWT), 88

CMSIS, 417  
 Data Watchpoint and Trace (DWT), 89

DWT\_Type, 1010

ECU APIs, 361  
 Admin\_Init, 362  
 Check\_Flag, 363  
 Check\_ID, 363  
 Check\_Password, 364  
 combineArrays, 364  
 ECU\_Init, 365  
 Enter\_Gate\_Open, 366  
 Exit\_Gate\_Open, 366  
 Flag\_SET\_RESET, 367  
 Trigger\_Alarm, 367  
 UserLCD\_PrintFreeSlots, 368  
 Wrong\_RFID, 369

ECU Definitions and APIs, 359

ECU\_Init  
 API\_Definitions, 375  
 ECU APIs, 365

EEPROM Constants, 15  
 EEPROM\_Slave\_address, 16

EEPROM\_Init  
 API Function Prototypes, 16

EEPROM\_Read\_byte  
 API Function Prototypes, 17

EEPROM\_Slave\_address  
 EEPROM Constants, 16

EEPROM\_Write\_NBytes  
 API Function Prototypes, 18

EGR  
 CMSIS, 483  
 TIM1\_TypeDef, 1058

EMR  
 CMSIS, 484  
 EXTI\_TypeDef, 1013

EN\_PIN  
 LCD\_t, 1025

ENABLE  
 I2C Driver, 270

Enable\_Dual\_Address  
 S\_I2C\_Slave\_address, 1041

Enabled  
 SPI Driver, 316

Enter\_Gate\_Open  
 API\_Definitions, 375  
 ECU APIs, 366

Enter\_Gate\_STATE  
 Application States, 352

Enter\_UART\_CallBack  
 API\_Definitions, 375

Entry\_Mode  
 LCD\_t, 1025

Enum for specifying the LED mode., 32  
 LED\_Active\_High, 33  
 LED\_Active\_Low, 33  
 LED\_Mode\_max, 33  
 LED\_Mode\_t, 33

Enum representing the result of ID check., [360](#)  
  ID\_Check\_Result, [360](#)  
  ID\_Found, [360](#)  
  ID\_NOT\_Found, [360](#)

Enumeration and Structures for USART, [344](#)

ERRI  
  S\_IRQ\_SRC, [1042](#)

ESCR  
  CMSIS, [484](#)

ESR  
  CMSIS, [484](#)

ESUR  
  CMSIS, [484](#)

ETH\_MACCR\_BL  
  Peripheral\_Registers\_Bits\_Definition, [833](#)

ETH\_TypeDef, [1011](#)

EV5  
  I2C Driver, [271](#)

EV6  
  I2C Driver, [271](#)

EV7  
  I2C Driver, [271](#)

EV8  
  I2C Driver, [271](#)

EV8\_1  
  I2C Driver, [271](#)

EXCCNT  
  ITM Functions, [132](#)

Exit\_Flag  
  Global\_Variables\_Definitions, [371](#)

Exit\_Gate\_Open  
  API\_Definitions, [376](#)  
  ECU APIs, [366](#)

Exit\_Gate\_STATE  
  Application States, [352](#)

Exit\_UART\_CallBack  
  API\_Definitions, [376](#)

Exported\_constants, [539](#)

Exported\_macro, [989](#)

Exported\_types, [527](#)  
  FlagStatus, [529](#)  
  Reset, [530](#)  
  s32, [528](#)  
  sc16, [528](#)  
  sc32, [528](#)  
  sc8, [528](#)  
  Set, [530](#)  
  uc16, [528](#)  
  uc32, [528](#)  
  uc8, [528](#)  
  vsc16, [529](#)  
  vsc32, [529](#)  
  vsc8, [529](#)  
  vuc16, [529](#)  
  vuc32, [529](#)  
  vuc8, [529](#)

EXTI  
  EXTI Instance, [173](#)

  EXTI Instance, [173](#)  
  EXTI, [173](#)

EXTI Register Map, [164](#)

EXTI0\_IRQHandler  
  Configuration\_section\_for\CMSIS, [525](#)

EXTI15\_10\_IRQHandler  
  Configuration\_section\_for\CMSIS, [526](#)

EXTI1\_IRQHandler  
  Configuration\_section\_for\CMSIS, [525](#)

EXTI2\_IRQHandler  
  Configuration\_section\_for\CMSIS, [525](#)

EXTI3\_IRQHandler  
  Configuration\_section\_for\CMSIS, [525](#)

EXTI4\_IRQHandler  
  Configuration\_section\_for\CMSIS, [525](#)

EXTI9\_5\_IRQHandler  
  Configuration\_section\_for\CMSIS, [525](#)

EXTI\_EMR\_MR0  
  Peripheral\_Registers\_Bits\_Definition, [833](#)

EXTI\_EMR\_MR1  
  Peripheral\_Registers\_Bits\_Definition, [833](#)

EXTI\_EMR\_MR10  
  Peripheral\_Registers\_Bits\_Definition, [834](#)

EXTI\_EMR\_MR11  
  Peripheral\_Registers\_Bits\_Definition, [834](#)

EXTI\_EMR\_MR12  
  Peripheral\_Registers\_Bits\_Definition, [834](#)

EXTI\_EMR\_MR13  
  Peripheral\_Registers\_Bits\_Definition, [834](#)

EXTI\_EMR\_MR14  
  Peripheral\_Registers\_Bits\_Definition, [834](#)

EXTI\_EMR\_MR15  
  Peripheral\_Registers\_Bits\_Definition, [834](#)

EXTI\_EMR\_MR16  
  Peripheral\_Registers\_Bits\_Definition, [834](#)

EXTI\_EMR\_MR17  
  Peripheral\_Registers\_Bits\_Definition, [834](#)

EXTI\_EMR\_MR18  
  Peripheral\_Registers\_Bits\_Definition, [835](#)

EXTI\_EMR\_MR19  
  Peripheral\_Registers\_Bits\_Definition, [835](#)

EXTI\_EMR\_MR2  
  Peripheral\_Registers\_Bits\_Definition, [835](#)

EXTI\_EMR\_MR23  
  Peripheral\_Registers\_Bits\_Definition, [835](#)

EXTI\_EMR\_MR3  
  Peripheral\_Registers\_Bits\_Definition, [835](#)

EXTI\_EMR\_MR4  
  Peripheral\_Registers\_Bits\_Definition, [835](#)

EXTI\_EMR\_MR5  
  Peripheral\_Registers\_Bits\_Definition, [835](#)

EXTI\_EMR\_MR6  
  Peripheral\_Registers\_Bits\_Definition, [835](#)

EXTI\_EMR\_MR7  
  Peripheral\_Registers\_Bits\_Definition, [836](#)

EXTI\_EMR\_MR8  
  Peripheral\_Registers\_Bits\_Definition, [836](#)

EXTI\_EMR\_MR9



Peripheral\_Registers\_Bits\_Definition, 843  
EXTI\_PR\_PR5  
  Peripheral\_Registers\_Bits\_Definition, 843  
EXTI\_PR\_PR6  
  Peripheral\_Registers\_Bits\_Definition, 843  
EXTI\_PR\_PR7  
  Peripheral\_Registers\_Bits\_Definition, 843  
EXTI\_PR\_PR8  
  Peripheral\_Registers\_Bits\_Definition, 844  
EXTI\_PR\_PR9  
  Peripheral\_Registers\_Bits\_Definition, 844  
EXTI\_RTSR\_TR0  
  Peripheral\_Registers\_Bits\_Definition, 844  
EXTI\_RTSR\_TR1  
  Peripheral\_Registers\_Bits\_Definition, 844  
EXTI\_RTSR\_TR10  
  Peripheral\_Registers\_Bits\_Definition, 844  
EXTI\_RTSR\_TR11  
  Peripheral\_Registers\_Bits\_Definition, 844  
EXTI\_RTSR\_TR12  
  Peripheral\_Registers\_Bits\_Definition, 844  
EXTI\_RTSR\_TR13  
  Peripheral\_Registers\_Bits\_Definition, 844  
EXTI\_RTSR\_TR14  
  Peripheral\_Registers\_Bits\_Definition, 845  
EXTI\_RTSR\_TR15  
  Peripheral\_Registers\_Bits\_Definition, 845  
EXTI\_RTSR\_TR16  
  Peripheral\_Registers\_Bits\_Definition, 845  
EXTI\_RTSR\_TR17  
  Peripheral\_Registers\_Bits\_Definition, 845  
EXTI\_RTSR\_TR18  
  Peripheral\_Registers\_Bits\_Definition, 845  
EXTI\_RTSR\_TR19  
  Peripheral\_Registers\_Bits\_Definition, 845  
EXTI\_RTSR\_TR2  
  Peripheral\_Registers\_Bits\_Definition, 845  
EXTI\_RTSR\_TR23  
  Peripheral\_Registers\_Bits\_Definition, 845  
EXTI\_RTSR\_TR3  
  Peripheral\_Registers\_Bits\_Definition, 846  
EXTI\_RTSR\_TR4  
  Peripheral\_Registers\_Bits\_Definition, 846  
EXTI\_RTSR\_TR5  
  Peripheral\_Registers\_Bits\_Definition, 846  
EXTI\_RTSR\_TR6  
  Peripheral\_Registers\_Bits\_Definition, 846  
EXTI\_RTSR\_TR7  
  Peripheral\_Registers\_Bits\_Definition, 846  
EXTI\_RTSR\_TR8  
  Peripheral\_Registers\_Bits\_Definition, 846  
EXTI\_RTSR\_TR9  
  Peripheral\_Registers\_Bits\_Definition, 846  
EXTI\_SWIER\_SWIER0  
  Peripheral\_Registers\_Bits\_Definition, 846  
EXTI\_SWIER\_SWIER1  
  Peripheral\_Registers\_Bits\_Definition, 847  
EXTI\_SWIER\_SWIER10  
  Peripheral\_Registers\_Bits\_Definition, 847  
Peripheral\_Registers\_Bits\_Definition, 847  
EXTI\_SWIER\_SWIER11  
  Peripheral\_Registers\_Bits\_Definition, 847  
EXTI\_SWIER\_SWIER12  
  Peripheral\_Registers\_Bits\_Definition, 847  
EXTI\_SWIER\_SWIER13  
  Peripheral\_Registers\_Bits\_Definition, 847  
EXTI\_SWIER\_SWIER14  
  Peripheral\_Registers\_Bits\_Definition, 847  
EXTI\_SWIER\_SWIER15  
  Peripheral\_Registers\_Bits\_Definition, 847  
EXTI\_SWIER\_SWIER16  
  Peripheral\_Registers\_Bits\_Definition, 847  
EXTI\_SWIER\_SWIER17  
  Peripheral\_Registers\_Bits\_Definition, 848  
EXTI\_SWIER\_SWIER18  
  Peripheral\_Registers\_Bits\_Definition, 848  
EXTI\_SWIER\_SWIER19  
  Peripheral\_Registers\_Bits\_Definition, 848  
EXTI\_SWIER\_SWIER2  
  Peripheral\_Registers\_Bits\_Definition, 848  
EXTI\_SWIER\_SWIER23  
  Peripheral\_Registers\_Bits\_Definition, 848  
EXTI\_SWIER\_SWIER3  
  Peripheral\_Registers\_Bits\_Definition, 848  
EXTI\_SWIER\_SWIER4  
  Peripheral\_Registers\_Bits\_Definition, 848  
EXTI\_SWIER\_SWIER5  
  Peripheral\_Registers\_Bits\_Definition, 848  
EXTI\_SWIER\_SWIER6  
  Peripheral\_Registers\_Bits\_Definition, 849  
EXTI\_SWIER\_SWIER7  
  Peripheral\_Registers\_Bits\_Definition, 849  
EXTI\_SWIER\_SWIER8  
  Peripheral\_Registers\_Bits\_Definition, 849  
EXTI\_SWIER\_SWIER9  
  Peripheral\_Registers\_Bits\_Definition, 849  
EXTI\_TypeDef, 1012  
  EMR, 1013  
  FTSR, 1013  
  IMR, 1013  
  PR, 1013  
  RTSR, 1013  
  SWIER, 1014  
EXTICR  
  CMSIS, 484  
  SYSCFG\_RegDef\_t, 1054  
FA1R  
  CMSIS, 484  
FALSE  
  Platform Standard Types, 151  
FCR  
  CMSIS, 484  
FFA1R  
  CMSIS, 485  
FFCR  
  ITM Functions, 132  
FFSR

ITM Functions, 132  
**FGCLUT**  
  CMSIS, 485  
**FGCMAR**  
  CMSIS, 485  
**FGCOLR**  
  CMSIS, 485  
**FGMAR**  
  CMSIS, 485  
**FGOR**  
  CMSIS, 485  
**FGPFCCR**  
  CMSIS, 485  
**FIFO**  
  CMSIS, 486  
**FIFO0**  
  ITM Functions, 132  
**FIFO1**  
  ITM Functions, 133  
**FIFOCNT**  
  CMSIS, 486  
**FLAG\_RESET**  
  Platform Standard Types, 151  
**FLAG\_SET**  
  Platform Standard Types, 151  
**Flag\_Set\_Reset**  
  API\_Definitions, 376  
  ECU APIs, 367  
**FlagStatus**  
  Exported\_types, 529  
  I2C Driver, 269  
**FLASH\_BASE**  
  Peripheral\_memory\_map, 535  
**FLASH\_IRQn**  
  Configuration\_section\_for\_CMSIS, 525  
**FLASH\_TypeDef**, 1014  
**float32**  
  Platform Standard Types, 152  
**float64**  
  Platform Standard Types, 153  
**FLTR**  
  CMSIS, 486  
**FM1R**  
  CMSIS, 486  
**FMR**  
  CMSIS, 486  
**FOLDCNT**  
  ITM Functions, 133  
**fp\_App\_State\_Handler**  
  Application States, 354  
  Prototypes, 356  
**FPCA**  
  ITM Functions, 133  
**FPU\_IRQHandler**  
  Configuration\_section\_for\_CMSIS, 526  
**FR1**  
  CMSIS, 486  
**FR2**

CMSIS, 486  
**Frame\_Format**  
  S\_SPI\_Config\_t, 1044  
**FRCR**  
  CMSIS, 487  
**Free\_Slots**  
  Application States, 354  
  Global\_Variables\_Definitions, 371  
**FS1R**  
  CMSIS, 487  
**FSCR**  
  ITM Functions, 133  
**FTSR**  
  CMSIS, 487  
  EXTI\_TypeDef, 1013  
**Full\_STATE**  
  Application States, 352  
**FUNCTION0**  
  ITM Functions, 133  
**FUNCTION1**  
  ITM Functions, 133  
**FUNCTION2**  
  ITM Functions, 134  
**FUNCTION3**  
  ITM Functions, 134  
**Functional\_State**  
  I2C Driver, 269  
**Functions\_and\_Instructions\_Reference**, 111  
**Functions\_Declarations**, 369  
**GCR**  
  CMSIS, 487  
**GE**  
  ITM Functions, 134  
**General\_Call\_Address\_Detection**  
  S\_I2C\_Config\_t, 1039  
**Global\_I2C\_Config**  
  stm32f401xx\_i2c\_driver.c, 1220  
**Global\_SPI\_Config**  
  stm32f401xx\_spi\_driver.c, 1223  
**Global\_Variables\_Definitions**, 370  
  Exit\_Flag, 371  
  Free\_Slots, 371  
  Print\_Slots\_LCD\_Flag, 371  
  SIZE1, 370  
**GPIO\_Base\_Address\_to\_Code\_Conversion\_Macros**, 246  
  GPIO\_BASEADDR\_TO\_CODE, 246  
**GPIO\_Driver**, 247  
**GPIO\_Instances**, 171  
  GPIOA, 171  
  GPIOB, 171  
  GPIOC, 172  
  GPIOD, 172  
  GPIOE, 172  
**GPIO\_Output\_Speeds**, 255  
  GPIO\_SPEED\_FAST, 256  
  GPIO\_SPEED\_HIGH, 256  
  GPIO\_SPEED\_LOW, 256  
  GPIO\_SPEED\_MEDIUM, 256

GPIO Output Types, 258  
  GPIO\_OP\_TYPE\_OD, 258  
  GPIO\_OP\_TYPE\_PP, 258  
GPIO Pin Modes, 249, 254  
  GPIO\_MODE\_AF\_INPUT, 250  
  GPIO\_MODE\_ALTFN, 254  
  GPIO\_MODE\_ANALOG, 254  
  GPIO\_MODE\_IN, 254  
  GPIO\_MODE\_INPUT\_FLO, 250  
  GPIO\_MODE\_INPUT\_PD, 250  
  GPIO\_MODE\_INPUT\_PU, 250  
  GPIO\_MODE\_IT\_FT, 255  
  GPIO\_MODE\_IT\_RFT, 255  
  GPIO\_MODE\_IT\_RT, 255  
  GPIO\_MODE\_OUT, 255  
  GPIO\_MODE\_OUTPUT\_AF\_OD, 250  
  GPIO\_MODE\_OUTPUT\_AF\_PP, 250  
  GPIO\_MODE\_OUTPUT\_OD, 250  
  GPIO\_MODE\_OUTPUT\_PP, 251  
GPIO Pin Numbers, 248  
GPIO Pin Speeds, 251  
  GPIO\_SPEED\_10M, 251  
  GPIO\_SPEED\_2M, 251  
  GPIO\_SPEED\_50M, 252  
GPIO Pin States, 252  
  GPIO\_PIN\_RESET, 252  
  GPIO\_PIN\_SET, 252  
GPIO Pull-up/Pull-down Configurations, 257  
  GPIO\_NO\_PUPD, 257  
  GPIO\_PIN\_PD, 257  
  GPIO\_PIN\_PU, 257  
GPIO Register Map, 163  
GPIO Return Lock Status, 253  
  GPIO\_RETURN\_LOCK\_ERROR, 253  
  GPIO\_RETURN\_LOCK\_OK, 253  
GPIO\_BASEADDR\_TO\_CODE  
  GPIO Base Address to Code Conversion Macros, 246  
GPIO\_MODE  
  GPIO\_PinConfig\_t, 1015  
GPIO\_MODE\_AF\_INPUT  
  GPIO Pin Modes, 250  
GPIO\_MODE\_ALTFN  
  GPIO Pin Modes, 254  
GPIO\_MODE\_ANALOG  
  GPIO Pin Modes, 254  
GPIO\_MODE\_IN  
  GPIO Pin Modes, 254  
GPIO\_MODE\_INPUT\_FLO  
  GPIO Pin Modes, 250  
GPIO\_MODE\_INPUT\_PD  
  GPIO Pin Modes, 250  
GPIO\_MODE\_INPUT\_PU  
  GPIO Pin Modes, 250  
GPIO\_MODE\_IT\_FT  
  GPIO Pin Modes, 255  
GPIO\_MODE\_IT\_RFT  
  GPIO Pin Modes, 255  
GPIO\_MODE\_IT\_RT  
  GPIO Pin Modes, 255  
GPIO\_MODE\_OUT  
  GPIO Pin Modes, 255  
GPIO\_MODE\_OUTPUT\_AF\_OD  
  GPIO Pin Modes, 250  
GPIO\_MODE\_OUTPUT\_AF\_PP  
  GPIO Pin Modes, 250  
GPIO\_MODE\_OUTPUT\_OD  
  GPIO Pin Modes, 250  
GPIO\_MODE\_OUTPUT\_PP  
  GPIO Pin Modes, 251  
GPIO\_NO\_PUPD  
  GPIO Pull-up/Pull-down Configurations, 257  
GPIO\_OP\_TYPE\_OD  
  GPIO Output Types, 258  
GPIO\_OP\_TYPE\_PP  
  GPIO Output Types, 258  
GPIO\_PIN\_PD  
  GPIO Pull-up/Pull-down Configurations, 257  
GPIO\_PIN\_PU  
  GPIO Pull-up/Pull-down Configurations, 257  
GPIO\_PIN\_RESET  
  GPIO Pin States, 252  
GPIO\_PIN\_SET  
  GPIO Pin States, 252  
GPIO\_PinAltFunMode  
  GPIO\_PinConfig\_t, 1015  
GPIO\_PinConfig\_t, 1014  
  GPIO\_MODE, 1015  
  GPIO\_PinAltFunMode, 1015  
  GPIO\_PinNumber, 1015  
  GPIO\_PinOPType, 1015  
  GPIO\_PinPuPdControl, 1015  
  GPIO\_PinSpeed, 1016  
GPIO\_PinNumber  
  GPIO\_PinConfig\_t, 1015  
GPIO\_PinOPType  
  GPIO\_PinConfig\_t, 1015  
GPIO\_PinPuPdControl  
  GPIO\_PinConfig\_t, 1015  
GPIO\_PinSpeed  
  GPIO\_PinConfig\_t, 1016  
GPIO\_PORT  
  LCD\_t, 1025  
GPIO\_RETURN\_LOCK\_ERROR  
  GPIO Return Lock Status, 253  
GPIO\_RETURN\_LOCK\_OK  
  GPIO Return Lock Status, 253  
GPIO\_SPEED\_10M  
  GPIO Pin Speeds, 251  
GPIO\_SPEED\_2M  
  GPIO Pin Speeds, 251  
GPIO\_SPEED\_50M  
  GPIO Pin Speeds, 252  
GPIO\_SPEED\_FAST  
  GPIO Output Speeds, 256  
GPIO\_SPEED\_HIGH

GPIO Output Speeds, 256  
**GPIO\_SPEED\_LOW**  
 GPIO Output Speeds, 256  
**GPIO\_SPEED\_MEDIUM**  
 GPIO Output Speeds, 256  
**GPIO\_TypeDef**, 1016  
 AFR, 1017  
 BSRR, 1017  
 IDR, 1017  
 LCKR, 1017  
 MODER, 1017  
 ODR, 1017  
 OSPEEDR, 1017  
 OTYPER, 1017  
 PUPDR, 1018  
**GPIOA**  
 GPIO Instances, 171  
**GPIOA\_BASE**  
 Peripheral\_memory\_map, 535  
**GPIOB**  
 GPIO Instances, 171  
**GPIOC**  
 GPIO Instances, 172  
**GPIOD**  
 GPIO Instances, 172  
**GPIOE**  
 GPIO Instances, 172  
**GTPR**  
 CMSIS, 487  
 USART\_TypeDef, 1063  
**HASH\_DIGEST\_TypeDef**, 1018  
**HASH\_TypeDef**, 1018  
**HFSR**  
 ITM Functions, 134  
 SCB\_TypeDef, 1047  
**HIFCR**  
 CMSIS, 487  
**HIGH\_BYTE\_FIRST**  
 Platform Standard Types, 151  
**HISR**  
 CMSIS, 488  
**HR**  
 CMSIS, 488  
**HSE\_CLK**  
 Clock Source Selection, 306  
**HSE\_STARTUP\_TIMEOUT**  
 Library\_configuration\_section, 521  
**HSE\_VALUE**  
 Clock Source Selection, 306  
 Library\_configuration\_section, 521  
**HSI\_RC\_CLK**  
 Clock Source Selection, 307  
**HSI\_VALUE**  
 Clock Source Selection, 307  
 Library\_configuration\_section, 522  
**HTR**  
 CMSIS, 488

I2C Acknowledge Control Definitions, 275  
 I2C\_Ack\_Control\_Disable, 276  
 I2C\_Ack\_Control\_Enable, 276  
**I2C Addressing Modes**, 274  
 I2C\_Addressing\_Slave\_10bits, 275  
 I2C\_Addressing\_Slave\_7bits, 275  
**I2C CCR Register Bit Definitions**, 203  
 I2C\_CCR\_CCR, 204  
 I2C\_CCR\_CCR\_Msk, 204  
 I2C\_CCR\_CCR\_Pos, 204  
 I2C\_CCR\_DUTY, 204  
 I2C\_CCR\_DUTY\_Msk, 204  
 I2C\_CCR\_DUTY\_Pos, 204  
**I2C CR1 Register Bit Definitions**, 180  
 I2C\_CR1\_ACK, 181  
 I2C\_CR1\_ACK\_Msk, 181  
 I2C\_CR1\_ACK\_Pos, 181  
 I2C\_CR1\_ALERT, 182  
 I2C\_CR1\_ALERT\_Msk, 182  
 I2C\_CR1\_ALERT\_Pos, 182  
 I2C\_CR1\_ENARP, 182  
 I2C\_CR1\_ENARP\_Msk, 182  
 I2C\_CR1\_ENARP\_Pos, 182  
 I2C\_CR1\_ENGC, 182  
 I2C\_CR1\_ENGC\_Msk, 183  
 I2C\_CR1\_ENGC\_Pos, 183  
 I2C\_CR1\_ENPEC, 183  
 I2C\_CR1\_ENPEC\_Msk, 183  
 I2C\_CR1\_ENPEC\_Pos, 183  
 I2C\_CR1\_NOSTRETCH, 183  
 I2C\_CR1\_NOSTRETCH\_Msk, 183  
 I2C\_CR1\_NOSTRETCH\_Pos, 184  
 I2C\_CR1\_PE, 184  
 I2C\_CR1\_PE\_Msk, 184  
 I2C\_CR1\_PE\_Pos, 184  
 I2C\_CR1\_PEC, 184  
 I2C\_CR1\_PEC\_Msk, 184  
 I2C\_CR1\_PEC\_Pos, 184  
 I2C\_CR1\_POS, 185  
 I2C\_CR1\_POS\_Msk, 185  
 I2C\_CR1\_POS\_Pos, 185  
 I2C\_CR1\_SMBTYPE, 185  
 I2C\_CR1\_SMBTYPE\_Msk, 185  
 I2C\_CR1\_SMBTYPE\_Pos, 185  
 I2C\_CR1\_SMBUS, 185  
 I2C\_CR1\_SMBUS\_Msk, 186  
 I2C\_CR1\_SMBUS\_Pos, 186  
 I2C\_CR1\_START, 186  
 I2C\_CR1\_START\_Msk, 186  
 I2C\_CR1\_START\_Pos, 186  
 I2C\_CR1\_STOP, 186  
 I2C\_CR1\_STOP\_Msk, 186  
 I2C\_CR1\_STOP\_Pos, 187  
 I2C\_CR1\_SWRST, 187  
 I2C\_CR1\_SWRST\_Msk, 187  
 I2C\_CR1\_SWRST\_Pos, 187  
**I2C CR2 Register Bit Definitions**, 187  
 I2C\_CR2\_DMAEN, 188

I2C\_CR2\_DMAEN\_Msk, 188  
I2C\_CR2\_DMAEN\_Pos, 188  
I2C\_CR2\_FREQ, 189  
I2C\_CR2\_FREQ\_Msk, 189  
I2C\_CR2\_FREQ\_Pos, 189  
I2C\_CR2\_ITBUFEN, 189  
I2C\_CR2\_ITBUFEN\_Msk, 189  
I2C\_CR2\_ITBUFEN\_Pos, 189  
I2C\_CR2\_ITERREN, 189  
I2C\_CR2\_ITERREN\_Msk, 190  
I2C\_CR2\_ITERREN\_Pos, 190  
I2C\_CR2\_IteVTEN, 190  
I2C\_CR2\_IteVTEN\_Msk, 190  
I2C\_CR2\_IteVTEN\_Pos, 190  
I2C\_CR2\_LAST, 190  
I2C\_CR2\_LAST\_Msk, 190  
I2C\_CR2\_LAST\_Pos, 191  
I2C Driver, 267  
DISABLE, 270  
ENABLE, 270  
EV5, 271  
EV6, 271  
EV7, 271  
EV8, 271  
EV8\_1, 271  
FlagStatus, 269  
Functional\_State, 269  
I2C\_Direction, 270  
I2C\_Direction\_Receiver, 270  
I2C\_Direction\_Transmitter, 270  
I2C\_Error\_AF, 270  
I2C\_Ev\_Address\_Matched, 270  
I2C\_Ev\_Data\_RCV, 270  
I2C\_Ev\_Data\_Req, 270  
I2C\_EV\_Stop, 270  
I2C\_Flag\_Busy, 271  
Master\_Byte\_Transmitting, 271  
Repeated, 270  
Repeated\_Start, 270  
Reset, 269  
Set, 269  
Slave\_State, 270  
Start, 270  
Status, 271  
StopCondition, 271  
WithoutStop, 271  
WithStop, 271  
I2C General Call Enable Definitions, 276  
I2C\_ENGC\_Disable, 276  
I2C\_ENGC\_Enable, 277  
I2C Instances, 177  
I2C1, 178  
I2C2, 178  
I2C Mode Definitions, 273  
I2C\_Mode\_I2C, 274  
I2C\_Mode\_SMBus, 274  
I2C OAR2 Register Bit Definitions, 191  
I2C\_OAR2\_ADD2, 191  
I2C\_OAR2\_ADD2\_Msk, 192  
I2C\_OAR2\_ADD2\_Pos, 192  
I2C\_OAR2\_ENDUAL, 192  
I2C\_OAR2\_ENDUAL\_Msk, 192  
I2C\_OAR2\_ENDUAL\_Pos, 192  
I2C Register Map, 166  
I2C Registers, 179  
I2C Speed Definitions, 271  
I2C\_SCK\_FM\_200K, 272  
I2C\_SCK\_FM\_400K, 272  
I2C\_SCK\_SM\_100K, 272  
I2C\_SCK\_SM\_50K, 272  
I2C SR1 Register Bit Definitions, 192  
I2C\_SR1\_ADD10, 193  
I2C\_SR1\_ADD10\_Msk, 194  
I2C\_SR1\_ADD10\_Pos, 194  
I2C\_SR1\_ADDR, 194  
I2C\_SR1\_ADDR\_Msk, 194  
I2C\_SR1\_ADDR\_Pos, 194  
I2C\_SR1\_AF, 194  
I2C\_SR1\_AF\_Msk, 194  
I2C\_SR1\_AF\_Pos, 194  
I2C\_SR1\_ARLO, 195  
I2C\_SR1\_ARLO\_Msk, 195  
I2C\_SR1\_ARLO\_Pos, 195  
I2C\_SR1\_BERR, 195  
I2C\_SR1\_BERR\_Msk, 195  
I2C\_SR1\_BERR\_Pos, 195  
I2C\_SR1\_BTF, 195  
I2C\_SR1\_BTF\_Msk, 195  
I2C\_SR1\_BTF\_Pos, 196  
I2C\_SR1\_OVR, 196  
I2C\_SR1\_OVR\_Msk, 196  
I2C\_SR1\_OVR\_Pos, 196  
I2C\_SR1\_PECERR, 196  
I2C\_SR1\_PECERR\_Msk, 196  
I2C\_SR1\_PECERR\_Pos, 196  
I2C\_SR1\_RXNE, 196  
I2C\_SR1\_RXNE\_Msk, 197  
I2C\_SR1\_RXNE\_Pos, 197  
I2C\_SR1\_SB, 197  
I2C\_SR1\_SB\_Msk, 197  
I2C\_SR1\_SB\_Pos, 197  
I2C\_SR1\_SMBALERT, 197  
I2C\_SR1\_SMBALERT\_Msk, 197  
I2C\_SR1\_SMBALERT\_Pos, 198  
I2C\_SR1\_STOPF, 198  
I2C\_SR1\_STOPF\_Msk, 198  
I2C\_SR1\_STOPF\_Pos, 198  
I2C\_SR1\_TIMEOUT, 198  
I2C\_SR1\_TIMEOUT\_Msk, 198  
I2C\_SR1\_TIMEOUT\_Pos, 198  
I2C\_SR1\_TXE, 198  
I2C\_SR1\_TXE\_Msk, 199  
I2C\_SR1\_TXE\_Pos, 199  
I2C SR2 Register Bit Definitions, 199  
I2C\_SR2\_BUSY, 200  
I2C\_SR2\_BUSY\_Msk, 200

I2C\_SR2\_BUSY\_Pos, 200  
I2C\_SR2\_DUALF, 200  
I2C\_SR2\_DUALF\_Msk, 200  
I2C\_SR2\_DUALF\_Pos, 200  
I2C\_SR2\_GENCALL, 201  
I2C\_SR2\_GENCALL\_Msk, 201  
I2C\_SR2\_GENCALL\_Pos, 201  
I2C\_SR2\_MSL, 201  
I2C\_SR2\_MSL\_Msk, 201  
I2C\_SR2\_MSL\_Pos, 201  
I2C\_SR2\_PEC, 201  
I2C\_SR2\_PEC\_Msk, 202  
I2C\_SR2\_PEC\_Pos, 202  
I2C\_SR2\_SMBDEFAULT, 202  
I2C\_SR2\_SMBDEFAULT\_Msk, 202  
I2C\_SR2\_SMBDEFAULT\_Pos, 202  
I2C\_SR2\_SMBHOST, 202  
I2C\_SR2\_SMBHOST\_Msk, 202  
I2C\_SR2\_SMBHOST\_Pos, 202  
I2C\_SR2\_TRA, 203  
I2C\_SR2\_TRA\_Msk, 203  
I2C\_SR2\_TRA\_Pos, 203  
I2C Stretch Mode Definitions, 273  
I2C\_StretchMode\_disabled, 273  
I2C\_StretchMode\_enabled, 273  
I2C TRISE Register Bit Definitions, 205  
I2C\_TRISE\_TRISE, 205  
I2C\_TRISE\_TRISE\_Msk, 205  
I2C\_TRISE\_TRISE\_Pos, 205  
I2C1  
I2C Instances, 178  
I2C1\_ER\_IRQn  
Configuration\_section\_for\CMSIS, 525  
I2C1\_EV\_IRQn  
Configuration\_section\_for\CMSIS, 525  
I2C1\_Index  
stm32f401xx\_i2c\_driver.c, 1220  
I2C2  
I2C Instances, 178  
I2C2\_ER\_IRQn  
Configuration\_section\_for\CMSIS, 526  
I2C2\_EV\_IRQn  
Configuration\_section\_for\CMSIS, 526  
I2C2\_Index  
stm32f401xx\_i2c\_driver.c, 1220  
I2C3\_ER\_IRQn  
Configuration\_section\_for\CMSIS, 526  
I2C3\_EV\_IRQn  
Configuration\_section\_for\CMSIS, 526  
I2C\_Ack\_Conrtol  
S\_I2C\_Config\_t, 1040  
I2C\_Ack\_Control\_Disable  
I2C Acknowledge Control Definitions, 276  
I2C\_Ack\_Control\_Enable  
I2C Acknowledge Control Definitions, 276  
I2C\_ACKnowledgeConfig  
API Function Prototypes, 278  
I2C\_Addressing\_Mode  
S\_I2C\_Slave\_address, 1041  
I2C\_Addressing\_Slave\_10bits  
I2C Addressing Modes, 275  
I2C\_Addressing\_Slave\_7bits  
I2C Addressing Modes, 275  
I2C\_CCR\_CCR  
I2C CCR Register Bit Definitions, 204  
Peripheral\_Registers\_Bits\_Definition, 849  
I2C\_CCR\_CCR\_Msk  
I2C CCR Register Bit Definitions, 204  
I2C\_CCR\_CCR\_Pos  
I2C CCR Register Bit Definitions, 204  
I2C\_CCR\_DUTY  
I2C CCR Register Bit Definitions, 204  
Peripheral\_Registers\_Bits\_Definition, 849  
I2C\_CCR\_DUTY\_Msk  
I2C CCR Register Bit Definitions, 204  
I2C\_CCR\_DUTY\_Pos  
I2C CCR Register Bit Definitions, 204  
I2C\_CCR\_FS  
Peripheral\_Registers\_Bits\_Definition, 849  
I2C\_CR1\_ACK  
I2C CR1 Register Bit Definitions, 181  
Peripheral\_Registers\_Bits\_Definition, 850  
I2C\_CR1\_ACK\_Msk  
I2C CR1 Register Bit Definitions, 181  
I2C\_CR1\_ACK\_Pos  
I2C CR1 Register Bit Definitions, 181  
I2C\_CR1\_ALERT  
I2C CR1 Register Bit Definitions, 182  
Peripheral\_Registers\_Bits\_Definition, 850  
I2C\_CR1\_ALERT\_Msk  
I2C CR1 Register Bit Definitions, 182  
I2C\_CR1\_ALERT\_Pos  
I2C CR1 Register Bit Definitions, 182  
I2C\_CR1\_ENARP  
I2C CR1 Register Bit Definitions, 182  
Peripheral\_Registers\_Bits\_Definition, 850  
I2C\_CR1\_ENARP\_Msk  
I2C CR1 Register Bit Definitions, 182  
I2C\_CR1\_ENARP\_Pos  
I2C CR1 Register Bit Definitions, 182  
I2C\_CR1\_ENGC  
I2C CR1 Register Bit Definitions, 182  
Peripheral\_Registers\_Bits\_Definition, 850  
I2C\_CR1\_ENGC\_Msk  
I2C CR1 Register Bit Definitions, 183  
I2C\_CR1\_ENGC\_Pos  
I2C CR1 Register Bit Definitions, 183  
I2C\_CR1\_ENPEC  
I2C CR1 Register Bit Definitions, 183  
Peripheral\_Registers\_Bits\_Definition, 850  
I2C\_CR1\_ENPEC\_Msk  
I2C CR1 Register Bit Definitions, 183  
I2C\_CR1\_ENPEC\_Pos  
I2C CR1 Register Bit Definitions, 183  
I2C\_CR1\_NOSTRETCH  
I2C CR1 Register Bit Definitions, 183

Peripheral\_Registers\_Bits\_Definition, 850  
I2C\_CR1\_NOSTRETCH\_Msk  
    I2C CR1 Register Bit Definitions, 183  
I2C\_CR1\_NOSTRETCH\_Pos  
    I2C CR1 Register Bit Definitions, 184  
I2C\_CR1\_PE  
    I2C CR1 Register Bit Definitions, 184  
    Peripheral\_Registers\_Bits\_Definition, 850  
I2C\_CR1\_PE\_Msk  
    I2C CR1 Register Bit Definitions, 184  
I2C\_CR1\_PE\_Pos  
    I2C CR1 Register Bit Definitions, 184  
I2C\_CR1\_PEC  
    I2C CR1 Register Bit Definitions, 184  
    Peripheral\_Registers\_Bits\_Definition, 851  
I2C\_CR1\_PEC\_Msk  
    I2C CR1 Register Bit Definitions, 184  
I2C\_CR1\_PEC\_Pos  
    I2C CR1 Register Bit Definitions, 184  
I2C\_CR1\_POS  
    I2C CR1 Register Bit Definitions, 185  
    Peripheral\_Registers\_Bits\_Definition, 851  
I2C\_CR1\_POS\_Msk  
    I2C CR1 Register Bit Definitions, 185  
I2C\_CR1\_POS\_Pos  
    I2C CR1 Register Bit Definitions, 185  
I2C\_CR1\_SMBTYPE  
    I2C CR1 Register Bit Definitions, 185  
    Peripheral\_Registers\_Bits\_Definition, 851  
I2C\_CR1\_SMBTYPE\_Msk  
    I2C CR1 Register Bit Definitions, 185  
I2C\_CR1\_SMBTYPE\_Pos  
    I2C CR1 Register Bit Definitions, 185  
I2C\_CR1\_SMBUS  
    I2C CR1 Register Bit Definitions, 185  
    Peripheral\_Registers\_Bits\_Definition, 851  
I2C\_CR1\_SMBUS\_Msk  
    I2C CR1 Register Bit Definitions, 186  
I2C\_CR1\_SMBUS\_Pos  
    I2C CR1 Register Bit Definitions, 186  
I2C\_CR1\_START  
    I2C CR1 Register Bit Definitions, 186  
    Peripheral\_Registers\_Bits\_Definition, 851  
I2C\_CR1\_START\_Msk  
    I2C CR1 Register Bit Definitions, 186  
I2C\_CR1\_START\_Pos  
    I2C CR1 Register Bit Definitions, 186  
I2C\_CR1\_STOP  
    I2C CR1 Register Bit Definitions, 186  
    Peripheral\_Registers\_Bits\_Definition, 851  
I2C\_CR1\_STOP\_Msk  
    I2C CR1 Register Bit Definitions, 186  
I2C\_CR1\_STOP\_Pos  
    I2C CR1 Register Bit Definitions, 187  
I2C\_CR1\_SWRST  
    I2C CR1 Register Bit Definitions, 187  
    Peripheral\_Registers\_Bits\_Definition, 851  
I2C\_CR1\_SWRST\_Msk  
    I2C CR1 Register Bit Definitions, 187  
    Peripheral\_Registers\_Bits\_Definition, 852  
I2C\_CR1\_SWRST\_Pos  
    I2C CR1 Register Bit Definitions, 187  
I2C\_CR2\_DMAEN  
    I2C CR2 Register Bit Definitions, 188  
    Peripheral\_Registers\_Bits\_Definition, 852  
I2C\_CR2\_DMAEN\_Msk  
    I2C CR2 Register Bit Definitions, 188  
I2C\_CR2\_DMAEN\_Pos  
    I2C CR2 Register Bit Definitions, 188  
I2C\_CR2\_FREQ  
    I2C CR2 Register Bit Definitions, 189  
    Peripheral\_Registers\_Bits\_Definition, 852  
I2C\_CR2\_FREQ\_0  
    Peripheral\_Registers\_Bits\_Definition, 852  
I2C\_CR2\_FREQ\_1  
    Peripheral\_Registers\_Bits\_Definition, 852  
I2C\_CR2\_FREQ\_2  
    Peripheral\_Registers\_Bits\_Definition, 852  
I2C\_CR2\_FREQ\_3  
    Peripheral\_Registers\_Bits\_Definition, 852  
I2C\_CR2\_FREQ\_4  
    Peripheral\_Registers\_Bits\_Definition, 852  
I2C\_CR2\_FREQ\_5  
    Peripheral\_Registers\_Bits\_Definition, 853  
I2C\_CR2\_FREQ\_Msk  
    I2C CR2 Register Bit Definitions, 189  
I2C\_CR2\_FREQ\_Pos  
    I2C CR2 Register Bit Definitions, 189  
I2C\_CR2\_ITBUFEN  
    I2C CR2 Register Bit Definitions, 189  
    Peripheral\_Registers\_Bits\_Definition, 853  
I2C\_CR2\_ITBUFEN\_Msk  
    I2C CR2 Register Bit Definitions, 189  
I2C\_CR2\_ITBUFEN\_Pos  
    I2C CR2 Register Bit Definitions, 189  
I2C\_CR2\_ITERREN  
    I2C CR2 Register Bit Definitions, 189  
    Peripheral\_Registers\_Bits\_Definition, 853  
I2C\_CR2\_ITERREN\_Msk  
    I2C CR2 Register Bit Definitions, 190  
I2C\_CR2\_ITERREN\_Pos  
    I2C CR2 Register Bit Definitions, 190  
I2C\_CR2\_IteVTEN  
    I2C CR2 Register Bit Definitions, 190  
    Peripheral\_Registers\_Bits\_Definition, 853  
I2C\_CR2\_IteVTEN\_Msk  
    I2C CR2 Register Bit Definitions, 190  
I2C\_CR2\_IteVTEN\_Pos  
    I2C CR2 Register Bit Definitions, 190  
I2C\_CR2\_LAST  
    I2C CR2 Register Bit Definitions, 190  
    Peripheral\_Registers\_Bits\_Definition, 853  
I2C\_CR2\_LAST\_Msk  
    I2C CR2 Register Bit Definitions, 190  
I2C\_CR2\_LAST\_Pos  
    I2C CR2 Register Bit Definitions, 191  
I2C\_Direction

I2C Driver, 270  
I2C\_Direction\_Receiver  
I2C Driver, 270  
I2C\_Direction\_Transmitter  
I2C Driver, 270  
I2C\_DR\_DR  
Peripheral\_Registers\_Bits\_Definition, 853  
I2C\_ENGC\_Disable  
I2C General Call Enable Definitions, 276  
I2C\_ENGC\_Enable  
I2C General Call Enable Definitions, 277  
I2C\_Error\_AF  
I2C Driver, 270  
I2C\_Ev\_Address\_Matched  
I2C Driver, 270  
I2C\_Ev\_Data\_RCV  
I2C Driver, 270  
I2C\_Ev\_Data\_Req  
I2C Driver, 270  
I2C\_EV\_Stop  
I2C Driver, 270  
I2C\_Flag\_Busy  
I2C Driver, 271  
I2C\_FLTR\_ANOFF  
Peripheral\_Registers\_Bits\_Definition, 853  
I2C\_FLTR\_DNF  
Peripheral\_Registers\_Bits\_Definition, 854  
I2C\_Generate\_Start  
API Function Prototypes, 278  
I2C\_Generate\_Stop  
API Function Prototypes, 279  
I2C\_Get\_FlagStatus  
API Function Prototypes, 279  
I2C\_Mode  
S\_I2C\_Config\_t, 1040  
I2C\_Mode\_I2C  
I2C Mode Definitions, 274  
I2C\_Mode\_SMBus  
I2C Mode Definitions, 274  
I2C\_OAR1\_ADD0  
Peripheral\_Registers\_Bits\_Definition, 854  
I2C\_OAR1\_ADD1  
Peripheral\_Registers\_Bits\_Definition, 854  
I2C\_OAR1\_ADD1\_7  
Peripheral\_Registers\_Bits\_Definition, 854  
I2C\_OAR1\_ADD2  
Peripheral\_Registers\_Bits\_Definition, 854  
I2C\_OAR1\_ADD3  
Peripheral\_Registers\_Bits\_Definition, 854  
I2C\_OAR1\_ADD4  
Peripheral\_Registers\_Bits\_Definition, 854  
I2C\_OAR1\_ADD5  
Peripheral\_Registers\_Bits\_Definition, 854  
I2C\_OAR1\_ADD6  
Peripheral\_Registers\_Bits\_Definition, 855  
I2C\_OAR1\_ADD7  
Peripheral\_Registers\_Bits\_Definition, 855  
I2C\_OAR1\_ADD8  
Peripheral\_Registers\_Bits\_Definition, 855  
I2C\_OAR1\_ADD8\_9  
Peripheral\_Registers\_Bits\_Definition, 855  
I2C\_OAR1\_ADD9  
Peripheral\_Registers\_Bits\_Definition, 855  
I2C\_OAR1\_ADDMODE  
Peripheral\_Registers\_Bits\_Definition, 855  
I2C\_OAR2\_ADD2  
I2C OAR2 Register Bit Definitions, 191  
Peripheral\_Registers\_Bits\_Definition, 855  
I2C\_OAR2\_ADD2\_Msk  
I2C OAR2 Register Bit Definitions, 192  
I2C\_OAR2\_ADD2\_Pos  
I2C OAR2 Register Bit Definitions, 192  
I2C\_OAR2\_ENDUAL  
I2C OAR2 Register Bit Definitions, 192  
Peripheral\_Registers\_Bits\_Definition, 855  
I2C\_OAR2\_ENDUAL\_Msk  
I2C OAR2 Register Bit Definitions, 192  
I2C\_OAR2\_ENDUAL\_Pos  
I2C OAR2 Register Bit Definitions, 192  
I2C\_SCK\_FM\_200K  
I2C Speed Definitions, 272  
I2C\_SCK\_FM\_400K  
I2C Speed Definitions, 272  
I2C\_SCK\_SM\_100K  
I2C Speed Definitions, 272  
I2C\_SCK\_SM\_50K  
I2C Speed Definitions, 272  
I2C\_SendAddress  
API Function Prototypes, 280  
I2C\_Slave\_address  
S\_I2C\_Config\_t, 1040  
I2C\_Speed  
S\_I2C\_Config\_t, 1040  
I2C\_SR1\_ADD10  
I2C SR1 Register Bit Definitions, 193  
Peripheral\_Registers\_Bits\_Definition, 856  
I2C\_SR1\_ADD10\_Msk  
I2C SR1 Register Bit Definitions, 194  
I2C\_SR1\_ADD10\_Pos  
I2C SR1 Register Bit Definitions, 194  
I2C\_SR1\_ADDR  
I2C SR1 Register Bit Definitions, 194  
Peripheral\_Registers\_Bits\_Definition, 856  
I2C\_SR1\_ADDR\_Msk  
I2C SR1 Register Bit Definitions, 194  
I2C\_SR1\_ADDR\_Pos  
I2C SR1 Register Bit Definitions, 194  
I2C\_SR1\_AF  
I2C SR1 Register Bit Definitions, 194  
Peripheral\_Registers\_Bits\_Definition, 856  
I2C\_SR1\_AF\_Msk  
I2C SR1 Register Bit Definitions, 194  
I2C\_SR1\_AF\_Pos  
I2C SR1 Register Bit Definitions, 194  
I2C\_SR1\_ARLO  
I2C SR1 Register Bit Definitions, 195

Peripheral\_Registers\_Bits\_Definition, 856  
I2C\_SR1\_ARLO\_Msk  
    I2C SR1 Register Bit Definitions, 195  
I2C\_SR1\_ARLO\_Pos  
    I2C SR1 Register Bit Definitions, 195  
I2C\_SR1\_BERR  
    I2C SR1 Register Bit Definitions, 195  
    Peripheral\_Registers\_Bits\_Definition, 856  
I2C\_SR1\_BERR\_Msk  
    I2C SR1 Register Bit Definitions, 195  
I2C\_SR1\_BERR\_Pos  
    I2C SR1 Register Bit Definitions, 195  
I2C\_SR1\_BTF  
    I2C SR1 Register Bit Definitions, 195  
    Peripheral\_Registers\_Bits\_Definition, 856  
I2C\_SR1\_BTF\_Msk  
    I2C SR1 Register Bit Definitions, 195  
I2C\_SR1\_BTF\_Pos  
    I2C SR1 Register Bit Definitions, 196  
I2C\_SR1\_OVR  
    I2C SR1 Register Bit Definitions, 196  
    Peripheral\_Registers\_Bits\_Definition, 856  
I2C\_SR1\_OVR\_Msk  
    I2C SR1 Register Bit Definitions, 196  
I2C\_SR1\_OVR\_Pos  
    I2C SR1 Register Bit Definitions, 196  
I2C\_SR1\_PECERR  
    I2C SR1 Register Bit Definitions, 196  
    Peripheral\_Registers\_Bits\_Definition, 857  
I2C\_SR1\_PECERR\_Msk  
    I2C SR1 Register Bit Definitions, 196  
I2C\_SR1\_PECERR\_Pos  
    I2C SR1 Register Bit Definitions, 196  
I2C\_SR1\_RXNE  
    I2C SR1 Register Bit Definitions, 196  
    Peripheral\_Registers\_Bits\_Definition, 857  
I2C\_SR1\_RXNE\_Msk  
    I2C SR1 Register Bit Definitions, 197  
I2C\_SR1\_RXNE\_Pos  
    I2C SR1 Register Bit Definitions, 197  
I2C\_SR1\_SB  
    I2C SR1 Register Bit Definitions, 197  
    Peripheral\_Registers\_Bits\_Definition, 857  
I2C\_SR1\_SB\_Msk  
    I2C SR1 Register Bit Definitions, 197  
I2C\_SR1\_SB\_Pos  
    I2C SR1 Register Bit Definitions, 197  
I2C\_SR1\_SMBALERT  
    I2C SR1 Register Bit Definitions, 197  
    Peripheral\_Registers\_Bits\_Definition, 857  
I2C\_SR1\_SMBALERT\_Msk  
    I2C SR1 Register Bit Definitions, 197  
I2C\_SR1\_SMBALERT\_Pos  
    I2C SR1 Register Bit Definitions, 198  
I2C\_SR1\_STOPF  
    I2C SR1 Register Bit Definitions, 198  
    Peripheral\_Registers\_Bits\_Definition, 857  
I2C\_SR1\_STOPF\_Msk  
    I2C SR1 Register Bit Definitions, 198  
I2C\_SR1\_STOPF\_Pos  
    I2C SR1 Register Bit Definitions, 198  
I2C\_SR1\_TIMEOUT  
    I2C SR1 Register Bit Definitions, 198  
    Peripheral\_Registers\_Bits\_Definition, 857  
I2C\_SR1\_TIMEOUT\_Msk  
    I2C SR1 Register Bit Definitions, 198  
I2C\_SR1\_TIMEOUT\_Pos  
    I2C SR1 Register Bit Definitions, 198  
I2C\_SR1\_TXE  
    I2C SR1 Register Bit Definitions, 198  
    Peripheral\_Registers\_Bits\_Definition, 857  
I2C\_SR1\_TXE\_Msk  
    I2C SR1 Register Bit Definitions, 199  
I2C\_SR1\_TXE\_Pos  
    I2C SR1 Register Bit Definitions, 199  
I2C\_SR2\_BUSY  
    I2C SR2 Register Bit Definitions, 200  
    Peripheral\_Registers\_Bits\_Definition, 858  
I2C\_SR2\_BUSY\_Msk  
    I2C SR2 Register Bit Definitions, 200  
I2C\_SR2\_BUSY\_Pos  
    I2C SR2 Register Bit Definitions, 200  
I2C\_SR2\_DUALF  
    I2C SR2 Register Bit Definitions, 200  
    Peripheral\_Registers\_Bits\_Definition, 858  
I2C\_SR2\_DUALF\_Msk  
    I2C SR2 Register Bit Definitions, 200  
I2C\_SR2\_DUALF\_Pos  
    I2C SR2 Register Bit Definitions, 200  
I2C\_SR2\_GENCALL  
    I2C SR2 Register Bit Definitions, 201  
    Peripheral\_Registers\_Bits\_Definition, 858  
I2C\_SR2\_GENCALL\_Msk  
    I2C SR2 Register Bit Definitions, 201  
I2C\_SR2\_GENCALL\_Pos  
    I2C SR2 Register Bit Definitions, 201  
I2C\_SR2\_MSL  
    I2C SR2 Register Bit Definitions, 201  
    Peripheral\_Registers\_Bits\_Definition, 858  
I2C\_SR2\_MSL\_Msk  
    I2C SR2 Register Bit Definitions, 201  
I2C\_SR2\_MSL\_Pos  
    I2C SR2 Register Bit Definitions, 201  
I2C\_SR2\_PEC  
    I2C SR2 Register Bit Definitions, 201  
    Peripheral\_Registers\_Bits\_Definition, 858  
I2C\_SR2\_PEC\_Msk  
    I2C SR2 Register Bit Definitions, 202  
I2C\_SR2\_PEC\_Pos  
    I2C SR2 Register Bit Definitions, 202  
I2C\_SR2\_SMBDEFAULT  
    I2C SR2 Register Bit Definitions, 202  
    Peripheral\_Registers\_Bits\_Definition, 858  
I2C\_SR2\_SMBDEFAULT\_Msk  
    I2C SR2 Register Bit Definitions, 202  
I2C\_SR2\_SMBDEFAULT\_Pos

I2C\_SR2\_Register Bit Definitions, [202](#)  
**I2C\_SR2\_SMBHOST**  
  I2C SR2 Register Bit Definitions, [202](#)  
  Peripheral\_Registers\_Bits\_Definition, [858](#)  
**I2C\_SR2\_SMBHOST\_Msk**  
  I2C SR2 Register Bit Definitions, [202](#)  
**I2C\_SR2\_SMBHOST\_Pos**  
  I2C SR2 Register Bit Definitions, [202](#)  
**I2C\_SR2\_TRA**  
  I2C SR2 Register Bit Definitions, [203](#)  
  Peripheral\_Registers\_Bits\_Definition, [859](#)  
**I2C\_SR2\_TRA\_Msk**  
  I2C SR2 Register Bit Definitions, [203](#)  
**I2C\_SR2\_TRA\_Pos**  
  I2C SR2 Register Bit Definitions, [203](#)  
**I2C\_stretchmode**  
  S\_I2C\_Config\_t, [1040](#)  
**I2C\_StretchMode\_disabled**  
  I2C Stretch Mode Definitions, [273](#)  
**I2C\_StretchMode\_enabled**  
  I2C Stretch Mode Definitions, [273](#)  
**I2C\_TRISE\_TRISE**  
  I2C TRISE Register Bit Definitions, [205](#)  
  Peripheral\_Registers\_Bits\_Definition, [859](#)  
**I2C\_TRISE\_TRISE\_Msk**  
  I2C TRISE Register Bit Definitions, [205](#)  
**I2C\_TRISE\_TRISE\_Pos**  
  I2C TRISE Register Bit Definitions, [205](#)  
**I2C\_TypeDef, 1019**  
  CCR, [1020](#)  
  CR1, [1020](#)  
  CR2, [1020](#)  
  DR, [1020](#)  
  OAR1, [1020](#)  
  OAR2, [1020](#)  
  SR1, [1020](#)  
  SR2, [1021](#)  
  TRISE, [1021](#)  
**I2SCFGR**  
  CMSIS, [488](#)  
  SPI\_TypeDef, [1051](#)  
**I2SPR**  
  CMSIS, [488](#)  
  SPI\_TypeDef, [1051](#)  
**IABR**  
  ITM Functions, [135](#)  
  NVIC\_TypeDef, [1030](#)  
**ICER**  
  ITM Functions, [135](#)  
  NVIC\_TypeDef, [1030](#)  
**ICPR**  
  ITM Functions, [135](#)  
  NVIC\_TypeDef, [1030](#)  
**ICR**  
  CMSIS, [488, 489](#)  
**ICSR**  
  ITM Functions, [135](#)  
  SCB\_TypeDef, [1047](#)  
**ICTR**  
  ITM Functions, [135](#)  
**ID\_Check\_Result**  
  Enum representing the result of ID check., [360](#)  
**ID\_Found**  
  Enum representing the result of ID check., [360](#)  
**ID\_NOT\_Found**  
  Enum representing the result of ID check., [360](#)  
**IDCODE**  
  CMSIS, [489](#)  
**Idle\_STATE**  
  Application States, [352](#)  
**IDR**  
  CMSIS, [489](#)  
  CRC\_TypeDef, [1005](#)  
  GPIO\_TypeDef, [1017](#)  
**IER**  
  CMSIS, [489, 490](#)  
**IFCR**  
  CMSIS, [490](#)  
**IMCR**  
  ITM Functions, [135](#)  
**IMR**  
  CMSIS, [490](#)  
  EXTI\_TypeDef, [1013](#)  
**IMSCR**  
  CMSIS, [490](#)  
**Inc/app\_states.h, 1223**  
**Inc/ecu.h, 1225**  
**Includes, 354**  
**INIT**  
  CRC\_TypeDef, [1005](#)  
**Init\_STATE**  
  Application States, [352](#)  
**Instrumentation Trace Macrocell (ITM), 73**  
  ITM\_IMCR\_INTEGRATION\_Msk, [74](#)  
  ITM\_IMCR\_INTEGRATION\_Pos, [74](#)  
  ITM\_IRR\_ATREADYM\_Msk, [75](#)  
  ITM\_IRR\_ATREADYM\_Pos, [75](#)  
  ITM\_IWR\_ATVALIDDM\_Msk, [75](#)  
  ITM\_IWR\_ATVALIDDM\_Pos, [75](#)  
  ITM\_LSR\_Access\_Msk, [75](#)  
  ITM\_LSR\_Access\_Pos, [75](#)  
  ITM\_LSR\_BytAcc\_Msk, [75](#)  
  ITM\_LSR\_BytAcc\_Pos, [75](#)  
  ITM\_LSR\_Present\_Msk, [76](#)  
  ITM\_LSR\_Present\_Pos, [76](#)  
  ITM\_TCR\_BUSY\_Msk, [76](#)  
  ITM\_TCR\_BUSY\_Pos, [76](#)  
  ITM\_TCR\_DWTENA\_Msk, [76](#)  
  ITM\_TCR\_DWTENA\_Pos, [76](#)  
  ITM\_TCR\_GTSFREQ\_Msk, [76](#)  
  ITM\_TCR\_GTSFREQ\_Pos, [76](#)  
  ITM\_TCR\_ITMENA\_Msk, [77](#)  
  ITM\_TCR\_ITMENA\_Pos, [77](#)  
  ITM\_TCR\_SWOENA\_Msk, [77](#)  
  ITM\_TCR\_SWOENA\_Pos, [77](#)  
  ITM\_TCR\_SYNCENA\_Msk, [77](#)

ITM\_TCR\_SYNCENA\_Pos, 77  
ITM\_TCR\_TraceBusID\_Msk, 77  
ITM\_TCR\_TraceBusID\_Pos, 77  
ITM\_TCR\_TSENA\_Msk, 78  
ITM\_TCR\_TSENA\_Pos, 78  
ITM\_TCR\_TSPPrescale\_Msk, 78  
ITM\_TCR\_TSPPrescale\_Pos, 78  
ITM\_TPR\_PRIVMASK\_Msk, 78  
ITM\_TPR\_PRIVMASK\_Pos, 78  
Interrupt Priorities, 289  
Interrupt Requests, 290  
Interrupt Status, 288  
interrupt\_config  
    STK\_config\_t, 1052  
IP  
    ITM Functions, 135  
    NVIC\_TypeDef, 1030  
IPSR\_ISR\_Msk  
    CMSIS, 417  
    Status and Control Registers, 46  
IPSR\_ISR\_Pos  
    CMSIS, 417  
    Status and Control Registers, 46  
IPSR\_Type, 1021  
IRQ\_Enable  
    S\_SPI\_Config\_t, 1044  
IRQn  
    Configuration\_section\_for\_CMSIS, 524  
IRR  
    ITM Functions, 136  
ISAR  
    ITM Functions, 136  
ISER  
    ITM Functions, 136  
    NVIC\_TypeDef, 1030  
ISPR  
    ITM Functions, 136  
    NVIC\_TypeDef, 1030  
ISR  
    CMSIS, 490, 491  
    ITM Functions, 136, 137  
IT  
    ITM Functions, 137  
ITATBCTR0  
    ITM Functions, 137  
ITATBCTR2  
    ITM Functions, 137  
ITCTRL  
    ITM Functions, 137  
ITM  
    CMSIS, 417  
    Core Definitions, 109  
ITM Functions, 119  
    \_reserved0, 124, 125  
    \_reserved1, 125, 126  
ACPR, 126  
ACTLR, 126  
ADR, 126  
AFSR, 126  
AIRCR, 127  
b, 127  
BFAR, 127  
C, 127, 128  
CALIB, 128  
CCR, 128  
CFSR, 128  
CID0, 128  
CID1, 129  
CID2, 129  
CID3, 129  
CLAIMCLR, 129  
CLAIMSET, 129  
COMP0, 129  
COMP1, 129  
COMP2, 130  
COMP3, 130  
CPACR, 130  
CPICNT, 130  
CPUID, 130  
CSPSR, 130  
CTRL, 130, 131  
CYCCNT, 131  
DCRDR, 131  
DCRSR, 131  
DEMCR, 131  
DEVID, 131  
DEVTYPE, 131  
DFR, 132  
DFSR, 132  
DHCSR, 132  
EXCCNT, 132  
FFCR, 132  
FFSR, 132  
FIFO0, 132  
FIFO1, 133  
FOLDCNT, 133  
FPCA, 133  
FSCR, 133  
FUNCTION0, 133  
FUNCTION1, 133  
FUNCTION2, 134  
FUNCTION3, 134  
GE, 134  
HFSR, 134  
IABR, 135  
ICER, 135  
ICPR, 135  
ICSR, 135  
ICTR, 135  
IMCR, 135  
IP, 135  
IRR, 136  
ISAR, 136  
ISER, 136  
ISPR, 136  
ISR, 136, 137

IT, 137  
 ITATBCTR0, 137  
 ITATBCTR2, 137  
 ITCTRL, 137  
 ITM\_CheckChar, 123  
 ITM\_ReceiveChar, 123  
 ITM\_RxBuffer, 137  
 ITM\_RXBUFFER\_EMPTY, 123  
 ITM\_SendChar, 124  
 IWR, 138  
 LAR, 138  
 LOAD, 138  
 LSR, 138  
 LSUCNT, 138  
 MASK0, 138  
 MASK1, 138  
 MASK2, 139  
 MASK3, 139  
 MMFAR, 139  
 MMFR, 139  
 N, 139, 140  
 nPRIV, 140  
 PCSR, 140  
 PFR, 140  
 PID0, 140  
 PID1, 140  
 PID2, 141  
 PID3, 141  
 PID4, 141  
 PID5, 141  
 PID6, 141  
 PID7, 141  
 PORT, 141  
 Q, 141, 142  
 SCR, 142  
 SHCSR, 142  
 SHP, 142  
 SLEEPCNT, 142  
 SPPR, 143  
 SPSEL, 143  
 SSPSR, 143  
 STIR, 143  
 T, 143  
 TCR, 144  
 TER, 144  
 TPR, 144  
 TRIGGER, 144  
 u16, 144  
 u32, 144, 145  
 u8, 145  
 V, 145  
 VAL, 146  
 VTOR, 146  
 w, 146  
 Z, 146, 147  
 ITM\_BASE  
 CMSIS, 418  
 Core Definitions, 109  
 ITM\_CheckChar  
 CMSIS, 453  
 ITM Functions, 123  
 ITM\_IMCR\_INTEGRATION\_Msk  
 CMSIS, 418  
 Instrumentation Trace Macrocell (ITM), 74  
 ITM\_IMCR\_INTEGRATION\_Pos  
 CMSIS, 418  
 Instrumentation Trace Macrocell (ITM), 74  
 ITM\_IRR\_ATREADYM\_Msk  
 CMSIS, 418  
 Instrumentation Trace Macrocell (ITM), 75  
 ITM\_IRR\_ATREADYM\_Pos  
 CMSIS, 418  
 Instrumentation Trace Macrocell (ITM), 75  
 ITM\_IWR\_ATVALIDM\_Msk  
 CMSIS, 418  
 Instrumentation Trace Macrocell (ITM), 75  
 ITM\_IWR\_ATVALIDM\_Pos  
 CMSIS, 418  
 Instrumentation Trace Macrocell (ITM), 75  
 ITM\_LSR\_Access\_Msk  
 CMSIS, 419  
 Instrumentation Trace Macrocell (ITM), 75  
 ITM\_LSR\_Access\_Pos  
 CMSIS, 419  
 Instrumentation Trace Macrocell (ITM), 75  
 ITM\_LSR\_BytAcc\_Msk  
 CMSIS, 419  
 Instrumentation Trace Macrocell (ITM), 75  
 ITM\_LSR\_BytAcc\_Pos  
 CMSIS, 419  
 Instrumentation Trace Macrocell (ITM), 75  
 ITM\_LSR\_Present\_Msk  
 CMSIS, 419  
 Instrumentation Trace Macrocell (ITM), 76  
 ITM\_LSR\_Present\_Pos  
 CMSIS, 419  
 Instrumentation Trace Macrocell (ITM), 76  
 ITM\_ReceiveChar  
 CMSIS, 453  
 ITM Functions, 123  
 ITM\_RxBuffer  
 CMSIS, 491  
 ITM Functions, 137  
 ITM\_RXBUFFER\_EMPTY  
 CMSIS, 419  
 ITM Functions, 123  
 ITM\_SendChar  
 CMSIS, 453  
 ITM Functions, 124  
 ITM\_TCR\_BUSY\_Msk  
 CMSIS, 419  
 Instrumentation Trace Macrocell (ITM), 76  
 ITM\_TCR\_BUSY\_Pos  
 CMSIS, 420  
 Instrumentation Trace Macrocell (ITM), 76  
 ITM\_TCR\_DWTENA\_Msk

CMSIS, 420  
Instrumentation Trace Macrocell (ITM), 76

ITM\_TCR\_DWTENA\_Pos  
CMSIS, 420  
Instrumentation Trace Macrocell (ITM), 76

ITM\_TCR\_GTSFREQ\_Msk  
CMSIS, 420  
Instrumentation Trace Macrocell (ITM), 76

ITM\_TCR\_GTSFREQ\_Pos  
CMSIS, 420  
Instrumentation Trace Macrocell (ITM), 76

ITM\_TCR\_ITMENA\_Msk  
CMSIS, 420  
Instrumentation Trace Macrocell (ITM), 77

ITM\_TCR\_ITMENA\_Pos  
CMSIS, 420  
Instrumentation Trace Macrocell (ITM), 77

ITM\_TCR\_SWOENA\_Msk  
CMSIS, 420  
Instrumentation Trace Macrocell (ITM), 77

ITM\_TCR\_SWOENA\_Pos  
CMSIS, 421  
Instrumentation Trace Macrocell (ITM), 77

ITM\_TCR\_SYNCENA\_Msk  
CMSIS, 421  
Instrumentation Trace Macrocell (ITM), 77

ITM\_TCR\_SYNCENA\_Pos  
CMSIS, 421  
Instrumentation Trace Macrocell (ITM), 77

ITM\_TCR\_TraceBusID\_Msk  
CMSIS, 421  
Instrumentation Trace Macrocell (ITM), 77

ITM\_TCR\_TraceBusID\_Pos  
CMSIS, 421  
Instrumentation Trace Macrocell (ITM), 77

ITM\_TCR\_TSENA\_Msk  
CMSIS, 421  
Instrumentation Trace Macrocell (ITM), 78

ITM\_TCR\_TSENA\_Pos  
CMSIS, 421  
Instrumentation Trace Macrocell (ITM), 78

ITM\_TCR\_TSPrescale\_Msk  
CMSIS, 421  
Instrumentation Trace Macrocell (ITM), 78

ITM\_TCR\_TSPrescale\_Pos  
CMSIS, 422  
Instrumentation Trace Macrocell (ITM), 78

ITM\_TPR\_PRIVMASK\_Msk  
CMSIS, 422  
Instrumentation Trace Macrocell (ITM), 78

ITM\_TPR\_PRIVMASK\_Pos  
CMSIS, 422  
Instrumentation Trace Macrocell (ITM), 78

ITM\_Type, 1022

IV0LR  
CMSIS, 491

IV0RR  
CMSIS, 491

IV1LR  
CMSIS, 491

IV1RR  
CMSIS, 491

IWDG\_KR\_KEY  
Peripheral\_Registers\_Bits\_Definition, 859

IWDG\_PR\_PR  
Peripheral\_Registers\_Bits\_Definition, 859

IWDG\_PR\_PR\_0  
Peripheral\_Registers\_Bits\_Definition, 859

IWDG\_PR\_PR\_1  
Peripheral\_Registers\_Bits\_Definition, 859

IWDG\_PR\_PR\_2  
Peripheral\_Registers\_Bits\_Definition, 859

IWDG\_RLR\_RL  
Peripheral\_Registers\_Bits\_Definition, 860

IWDG\_SR\_PVU  
Peripheral\_Registers\_Bits\_Definition, 860

IWDG\_SR\_RVU  
Peripheral\_Registers\_Bits\_Definition, 860

IWDG\_TypeDef, 1023

IWR  
ITM Functions, 138

JDR1  
CMSIS, 492

JDR2  
CMSIS, 492

JDR3  
CMSIS, 492

JDR4  
CMSIS, 492

JOFR1  
CMSIS, 492

JOFR2  
CMSIS, 492

JOFR3  
CMSIS, 492

JOFR4  
CMSIS, 492

JSQR  
CMSIS, 493

K0LR  
CMSIS, 493

K0RR  
CMSIS, 493

K1LR  
CMSIS, 493

K1RR  
CMSIS, 493

K2LR  
CMSIS, 493

K2RR  
CMSIS, 493

K3LR  
CMSIS, 493

K3RR  
CMSIS, 494

KEYPAD Driver, 18  
    KEYPAD\_PORT, 19  
keypad\_Get\_Pressed\_Key  
    API Function Prototypes, 20  
keypad\_init  
    API Function Prototypes, 21  
KEYPAD\_PORT  
    KEYPAD Driver, 19  
KEYR  
    CMSIS, 494  
KR  
    CMSIS, 494  
  
LAR  
    ITM Functions, 138  
LCD Commands, 23  
LCD Driver, 22  
    LCD\_2ROWS, 23  
    LCD\_4BIT, 23  
    LCD\_4ROWS, 23  
    LCD\_8BIT, 23  
    LCD\_MODE\_t, 22  
    LCD\_ROWS\_t, 23  
LCD Row Positions, 24  
LCD\_2ROWS  
    LCD Driver, 23  
LCD\_4BIT  
    LCD Driver, 23  
LCD\_4ROWS  
    LCD Driver, 23  
LCD\_8BIT  
    LCD Driver, 23  
LCD\_Init  
    API Function Prototypes, 25  
LCD\_MODE\_t  
    LCD Driver, 22  
LCD\_ROWS\_t  
    LCD Driver, 23  
LCD\_Send\_Char  
    API Function Prototypes, 26  
LCD\_Send\_Char\_Pos  
    API Function Prototypes, 27  
LCD\_Send\_Command  
    API Function Prototypes, 27  
LCD\_Send\_Enable\_Signal  
    API Function Prototypes, 28  
LCD\_Send\_String  
    API Function Prototypes, 29  
LCD\_Send\_String\_Pos  
    API Function Prototypes, 30  
LCD\_Set\_Cursor  
    API Function Prototypes, 30  
LCD\_t, 1023  
    D0\_PIN, 1024  
    D1\_PIN, 1024  
    D2\_PIN, 1024  
    D3\_PIN, 1024  
    D4\_PIN, 1025  
    D5\_PIN, 1025  
  
D6\_PIN, 1025  
D7\_PIN, 1025  
Display\_Mode, 1025  
EN\_PIN, 1025  
Entry\_Mode, 1025  
GPIO\_PORT, 1025  
Mode, 1026  
Rows, 1026  
RS\_PIN, 1026  
  
LCKR  
    CMSIS, 494  
    GPIO\_TypeDef, 1017  
LED Driver, 31  
LED\_Active\_High  
    Enum for specifying the LED mode., 33  
LED\_Active\_Low  
    Enum for specifying the LED mode., 33  
LED\_cfg\_t, 1026  
    LED\_Mode, 1027  
    LED\_Pin, 1027  
    LED\_Port, 1027  
LED\_Init  
    API Function Prototypes, 34  
LED\_Mode  
    LED\_cfg\_t, 1027  
LED\_Mode\_max  
    Enum for specifying the LED mode., 33  
LED\_Mode\_t  
    Enum for specifying the LED mode., 33  
LED\_Pin  
    LED\_cfg\_t, 1027  
LED\_Port  
    LED\_cfg\_t, 1027  
LED\_Toggle  
    API Function Prototypes, 35  
LED\_TurnOff  
    API Function Prototypes, 35  
LED\_TurnOn  
    API Function Prototypes, 36  
Library\_configuration\_section, 520  
    \_\_STM32F4XX\_STDPERIPH\_VERSION, 520  
    \_\_STM32F4XX\_STDPERIPH\_VERSION\_MAIN,  
        521  
    \_\_STM32F4XX\_STDPERIPH\_VERSION\_RC, 521  
    \_\_STM32F4XX\_STDPERIPH\_VERSION\_SUB1,  
        521  
    \_\_STM32F4XX\_STDPERIPH\_VERSION\_SUB2,  
        521  
    HSE\_STARTUP\_TIMEOUT, 521  
    HSE\_VALUE, 521  
    HSI\_VALUE, 522  
  
LIFCR  
    CMSIS, 494  
LIPCR  
    CMSIS, 494  
LISR  
    CMSIS, 494  
LOAD

ITM Functions, [138](#)  
STK\_TypeDef, [1053](#)

LOW\_BYTE\_FIRST  
Platform Standard Types, [151](#)

LSB\_FIRST  
Platform Standard Types, [151](#)

LSR  
ITM Functions, [138](#)

LSUCNT  
ITM Functions, [138](#)

LTDC\_AWCR\_AAH  
Peripheral\_Registers\_Bits\_Definition, [860](#)

LTDC\_AWCR\_AAW  
Peripheral\_Registers\_Bits\_Definition, [860](#)

LTDC\_BCCR\_BCBLUE  
Peripheral\_Registers\_Bits\_Definition, [860](#)

LTDC\_BCCR\_BCGREEN  
Peripheral\_Registers\_Bits\_Definition, [860](#)

LTDC\_BCCR\_BCRED  
Peripheral\_Registers\_Bits\_Definition, [861](#)

LTDC\_BPCR\_AHBP  
Peripheral\_Registers\_Bits\_Definition, [861](#)

LTDC\_BPCR\_AVBP  
Peripheral\_Registers\_Bits\_Definition, [861](#)

LTDC\_CDSR\_HDES  
Peripheral\_Registers\_Bits\_Definition, [861](#)

LTDC\_CDSR\_HSYNCS  
Peripheral\_Registers\_Bits\_Definition, [861](#)

LTDC\_CDSR\_VDES  
Peripheral\_Registers\_Bits\_Definition, [861](#)

LTDC\_CDSR\_VSYNCS  
Peripheral\_Registers\_Bits\_Definition, [861](#)

LTDC\_CPSR\_CXPOS  
Peripheral\_Registers\_Bits\_Definition, [861](#)

LTDC\_CPSR\_CYPOS  
Peripheral\_Registers\_Bits\_Definition, [862](#)

LTDC\_GCR\_DBW  
Peripheral\_Registers\_Bits\_Definition, [862](#)

LTDC\_GCR\_DEN  
Peripheral\_Registers\_Bits\_Definition, [862](#)

LTDC\_GCR\_DEPOL  
Peripheral\_Registers\_Bits\_Definition, [862](#)

LTDC\_GCR\_DGW  
Peripheral\_Registers\_Bits\_Definition, [862](#)

LTDC\_GCR\_DRW  
Peripheral\_Registers\_Bits\_Definition, [862](#)

LTDC\_GCR\_HSPOL  
Peripheral\_Registers\_Bits\_Definition, [862](#)

LTDC\_GCR\_LTDCEN  
Peripheral\_Registers\_Bits\_Definition, [862](#)

LTDC\_GCR\_PCPOL  
Peripheral\_Registers\_Bits\_Definition, [863](#)

LTDC\_GCR\_VSPOL  
Peripheral\_Registers\_Bits\_Definition, [863](#)

LTDC\_ICR\_CFUIF  
Peripheral\_Registers\_Bits\_Definition, [863](#)

LTDC\_ICR\_CLIF  
Peripheral\_Registers\_Bits\_Definition, [863](#)

LTDC\_ICR\_CRRIF  
Peripheral\_Registers\_Bits\_Definition, [863](#)

LTDC\_ICR\_CTERRIF  
Peripheral\_Registers\_Bits\_Definition, [863](#)

LTDC\_IER\_FUIE  
Peripheral\_Registers\_Bits\_Definition, [863](#)

LTDC\_IER\_LIE  
Peripheral\_Registers\_Bits\_Definition, [863](#)

LTDC\_IER\_RRIE  
Peripheral\_Registers\_Bits\_Definition, [864](#)

LTDC\_IER\_TERRIE  
Peripheral\_Registers\_Bits\_Definition, [864](#)

LTDC\_ISR\_FUIF  
Peripheral\_Registers\_Bits\_Definition, [864](#)

LTDC\_ISR\_LIF  
Peripheral\_Registers\_Bits\_Definition, [864](#)

LTDC\_ISR\_RRIF  
Peripheral\_Registers\_Bits\_Definition, [864](#)

LTDC\_ISR\_TERRIF  
Peripheral\_Registers\_Bits\_Definition, [864](#)

LTDC\_Layer\_TypeDef, [1027](#)

LTDC\_LIPCR\_LIPOS  
Peripheral\_Registers\_Bits\_Definition, [864](#)

LTDC\_LxBFCR\_BF1  
Peripheral\_Registers\_Bits\_Definition, [864](#)

LTDC\_LxBFCR\_BF2  
Peripheral\_Registers\_Bits\_Definition, [865](#)

LTDC\_LxCACR\_CONSTA  
Peripheral\_Registers\_Bits\_Definition, [865](#)

LTDC\_LxCFBAR\_CFBADD  
Peripheral\_Registers\_Bits\_Definition, [865](#)

LTDC\_LxCFBLNR\_CFBLNBR  
Peripheral\_Registers\_Bits\_Definition, [865](#)

LTDC\_LxCFBLR\_CFBLL  
Peripheral\_Registers\_Bits\_Definition, [865](#)

LTDC\_LxCFBLR\_CFBP  
Peripheral\_Registers\_Bits\_Definition, [865](#)

LTDC\_LxCKCR\_CKBLUE  
Peripheral\_Registers\_Bits\_Definition, [865](#)

LTDC\_LxCKCR\_CKGREEN  
Peripheral\_Registers\_Bits\_Definition, [865](#)

LTDC\_LxCKCR\_CKRED  
Peripheral\_Registers\_Bits\_Definition, [866](#)

LTDC\_LxCLUTWR\_BLUE  
Peripheral\_Registers\_Bits\_Definition, [866](#)

LTDC\_LxCLUTWR\_CLUTADD  
Peripheral\_Registers\_Bits\_Definition, [866](#)

LTDC\_LxCLUTWR\_GREEN  
Peripheral\_Registers\_Bits\_Definition, [866](#)

LTDC\_LxCLUTWR\_RED  
Peripheral\_Registers\_Bits\_Definition, [866](#)

LTDC\_LxCR\_CLUTEN  
Peripheral\_Registers\_Bits\_Definition, [866](#)

LTDC\_LxCR\_COLKEN  
Peripheral\_Registers\_Bits\_Definition, [866](#)

LTDC\_LxCR\_LEN  
Peripheral\_Registers\_Bits\_Definition, [866](#)

LTDC\_LxDCCR\_DCALPHA

Peripheral\_Registers\_Bits\_Definition, [867](#)  
**LTDC\_LxDCCR\_DCBLUE**  
 Peripheral\_Registers\_Bits\_Definition, [867](#)  
**LTDC\_LxDCCR\_DCGREEN**  
 Peripheral\_Registers\_Bits\_Definition, [867](#)  
**LTDC\_LxDCCR\_DCRED**  
 Peripheral\_Registers\_Bits\_Definition, [867](#)  
**LTDC\_LxPFPCR\_PF**  
 Peripheral\_Registers\_Bits\_Definition, [867](#)  
**LTDC\_LxWHPCR\_WHSPPOS**  
 Peripheral\_Registers\_Bits\_Definition, [867](#)  
**LTDC\_LxWHPCR\_WHSTPOS**  
 Peripheral\_Registers\_Bits\_Definition, [867](#)  
**LTDC\_LxWVPCR\_WVSPPOS**  
 Peripheral\_Registers\_Bits\_Definition, [867](#)  
**LTDC\_LxWVPCR\_WVSTPOS**  
 Peripheral\_Registers\_Bits\_Definition, [868](#)  
**LTDC\_SRCR\_IMR**  
 Peripheral\_Registers\_Bits\_Definition, [868](#)  
**LTDC\_SRCR\_VBR**  
 Peripheral\_Registers\_Bits\_Definition, [868](#)  
**LTDC\_SSCR\_HSW**  
 Peripheral\_Registers\_Bits\_Definition, [868](#)  
**LTDC\_SSCR\_VSH**  
 Peripheral\_Registers\_Bits\_Definition, [868](#)  
**LTDC\_TWCR\_TOTALH**  
 Peripheral\_Registers\_Bits\_Definition, [868](#)  
**LTDC\_TWCR\_TOTALW**  
 Peripheral\_Registers\_Bits\_Definition, [868](#)  
**LTDC\_TypeDef**, [1028](#)  
**LTR**  
 CMSIS, [495](#)  
**LWR**  
 CMSIS, [495](#)  
**M0AR**  
 CMSIS, [495](#)  
**M1AR**  
 CMSIS, [495](#)  
 Macros for the servo motor directions, [38](#)  
 Macros for USART Configuration, [345](#)  
**MASK**  
 CMSIS, [495](#)  
**MASK0**  
 ITM Functions, [138](#)  
**MASK1**  
 ITM Functions, [138](#)  
**MASK2**  
 ITM Functions, [139](#)  
**MASK3**  
 ITM Functions, [139](#)  
**Master\_Byte\_Transmitting**  
 I2C Driver, [271](#)  
**MCAL\_GPIO\_DelInit**  
 API Function Prototypes, [259](#)  
**MCAL\_GPIO\_Init**  
 API Function Prototypes, [260](#)  
**MCAL\_GPIO\_LockPin**  
 API Function Prototypes, [261](#)  
**MCAL\_GPIO\_ReadPin**  
 API Function Prototypes, [262](#)  
**MCAL\_GPIO\_ReadPort**  
 API Function Prototypes, [263](#)  
**MCAL\_GPIO\_TogglePin**  
 API Function Prototypes, [264](#)  
**MCAL\_GPIO\_TogglePort**  
 API Function Prototypes, [264](#)  
**MCAL\_GPIO\_WritePin**  
 API Function Prototypes, [265](#)  
**MCAL\_GPIO\_WritePort**  
 API Function Prototypes, [266](#)  
**MCAL\_I2C\_Deinit**  
 API Function Prototypes, [280](#)  
**MCAL\_I2C\_Init**  
 API Function Prototypes, [281](#)  
**MCAL\_I2C\_Master\_Rx**  
 API Function Prototypes, [282](#)  
**MCAL\_I2C\_Master\_Tx**  
 API Function Prototypes, [282](#)  
**MCAL\_I2C\_Set\_GPIO**  
 API Function Prototypes, [283](#)  
**MCAL\_I2C\_Slave\_SendData**  
 API Function Prototypes, [284](#)  
**MCAL\_I2C\_SlaveReceiveData**  
 API Function Prototypes, [284](#)  
**MCAL\_NVIC\_ClearPendingIRQ**  
 API Function Prototypes, [292](#)  
**MCAL\_NVIC\_DisableIRQ**  
 API Function Prototypes, [293](#)  
**MCAL\_NVIC\_EnableIRQ**  
 API Function Prototypes, [293](#)  
**MCAL\_NVIC\_GetActive**  
 API Function Prototypes, [294](#)  
**MCAL\_NVIC\_GetPendingIRQ**  
 API Function Prototypes, [295](#)  
**MCAL\_NVIC\_GetPriority**  
 API Function Prototypes, [295](#)  
**MCAL\_NVIC\_GetPriorityGrouping**  
 API Function Prototypes, [296](#)  
**MCAL\_NVIC\_SetPendingIRQ**  
 API Function Prototypes, [296](#)  
**MCAL\_NVIC\_SetPriority**  
 API Function Prototypes, [298](#)  
**MCAL\_NVIC\_SetPriorityGrouping**  
 API Function Prototypes, [299](#)  
**MCAL\_NVIC\_SystemReset**  
 API Function Prototypes, [299](#)  
**MCAL\_RCC\_Enable\_Peripheral**  
 API Function Prototypes, [311](#)  
**MCAL\_RCC\_GetHCLKFreq**  
 API Function Prototypes, [311](#)  
**MCAL\_RCC\_GetPCLK1Freq**  
 API Function Prototypes, [312](#)  
**MCAL\_RCC\_GetPCLK2Freq**  
 API Function Prototypes, [312](#)  
**MCAL\_RCC\_GetSYS\_CLKFreq**  
 API Function Prototypes, [313](#)

MCAL\_RCC\_Reset\_Peripheral  
    API Function Prototypes, 314

MCAL\_RCC\_Select\_Clock  
    API Function Prototypes, 314

MCAL\_SPI\_DelInit  
    API Function Prototypes, 326

MCAL\_SPI\_GPIO\_Set\_Pins  
    API Function Prototypes, 327

MCAL\_SPI\_Init  
    API Function Prototypes, 328

MCAL\_SPI\_ReceiveData  
    API Function Prototypes, 328

MCAL\_SPI\_SendData  
    API Function Prototypes, 329

MCAL\_SPI\_Tx\_Rx  
    API Function Prototypes, 330

MCAL\_STK\_Config  
    API Function Prototypes, 335

MCAL\_STK\_Delay  
    API Function Prototypes, 336

MCAL\_STK\_Delay1ms  
    API Function Prototypes, 336

MCAL\_STK\_SetCallback  
    API Function Prototypes, 337

MCAL\_STK\_SetReload  
    API Function Prototypes, 338

MCAL\_STK\_StartTimer  
    API Function Prototypes, 338

MCAL\_STK\_StopTimer  
    API Function Prototypes, 339

MCAL\_USART\_DelInit  
    API Function Prototypes, 347

MCAL\_USART\_GPIO\_Set\_Pins  
    API Function Prototypes, 347

MCAL\_USART\_Init  
    API Function Prototypes, 348

MCAL\_USART\_ReceiveBuffer  
    API Function Prototypes, 348

MCAL\_USART\_ReceiveData  
    API Function Prototypes, 349

MCAL\_USART\_SendData  
    API Function Prototypes, 349

MCAL\_USART\_SendString  
    API Function Prototypes, 350

MCR  
    CMSIS, 495

Memory Base Addresses, 157

MemoryManagement\_IRQn  
    Configuration\_section\_for\CMSIS, 524

MEMRMP  
    CMSIS, 495

SYSCFG\_RegDef\_t, 1055

MISR  
    CMSIS, 496

MMAR  
    SCB\_TypeDef, 1047

MMFAR  
    ITM Functions, 139

MMFR  
    ITM Functions, 139

Mode  
    LCD\_t, 1026

MODER  
    CMSIS, 496

    GPIO\_TypeDef, 1017

MSB\_FIRST  
    Platform Standard Types, 151

MSR  
    CMSIS, 496

N  
    ITM Functions, 139, 140

NDTR  
    CMSIS, 496

Nested Vectored Interrupt Controller (NVIC), 49

    NVIC\_STIR\_INTID\_Msk, 50

    NVIC\_STIR\_INTID\_Pos, 50

NLR  
    CMSIS, 496

NonMaskableInt\_IRQn  
    Configuration\_section\_for\CMSIS, 524

nPRIV  
    ITM Functions, 140

NSS  
    S\_SPI\_Config\_t, 1044

NVIC  
    CMSIS, 422

    Core Definitions, 110

    NVIC Instance, 169

    NVIC Configuration Macros, 287

    NVIC Driver, 285

    NVIC Functions, 112

        NVIC\_ClearPendingIRQ, 113

        NVIC\_DecodePriority, 113

        NVIC\_DisableIRQ, 113

        NVIC\_EnableIRQ, 114

        NVIC\_EncodePriority, 114

        NVIC\_GetActive, 115

        NVIC\_GetPendingIRQ, 115

        NVIC\_GetPriority, 115

        NVIC\_GetPriorityGrouping, 116

        NVIC\_SetPendingIRQ, 116

        NVIC\_SetPriority, 116

        NVIC\_SetPriorityGrouping, 117

        NVIC\_SystemReset, 117

    NVIC Instance, 169

    NVIC, 169

    NVIC IRQ Enable/Disable Macros, 300

        NVIC IRQ10\_EXTI4\_Disable, 301

        NVIC IRQ10\_EXTI4\_Enable, 301

        NVIC IRQ23\_EXTI5\_9\_Disable, 301

        NVIC IRQ23\_EXTI5\_9\_Enable, 302

        NVIC IRQ31\_I2C1\_EV\_Disable, 302

        NVIC IRQ31\_I2C1\_EV\_Enable, 302

        NVIC IRQ32\_I2C1\_ER\_Disable, 302

NVIC\_IRQ32\_I2C1\_ER\_Enable, 302  
 NVIC\_IRQ33\_I2C2\_EV\_Disable, 302  
 NVIC\_IRQ33\_I2C2\_EV\_Enable, 302  
 NVIC\_IRQ34\_I2C2\_ER\_Enable, 303  
 NVIC\_IRQ35\_SPI1\_Disable, 303  
 NVIC\_IRQ35\_SPI1\_Enable, 303  
 NVIC\_IRQ36\_SPI2\_Enable, 303  
 NVIC\_IRQ37\_USART1\_Disable, 303  
 NVIC\_IRQ37\_USART1\_Enable, 303  
 NVIC\_IRQ38\_USART2\_Disable, 303  
 NVIC\_IRQ38\_USART2\_Enable, 304  
 NVIC\_IRQ39\_USART3\_Enable, 304  
 NVIC\_IRQ40\_EXTI10\_15\_Enable, 304  
 NVIC\_IRQ6\_EXTI0\_Disable, 304  
 NVIC\_IRQ6\_EXTI0\_Enable, 304  
 NVIC\_IRQ7\_EXTI1\_Disable, 304  
 NVIC\_IRQ7\_EXTI1\_Enable, 304  
 NVIC\_IRQ8\_EXTI2\_Disable, 305  
 NVIC\_IRQ8\_EXTI2\_Enable, 305  
 NVIC\_IRQ9\_EXTI3\_Disable, 305  
 NVIC\_IRQ9\_EXTI3\_Enable, 305  
 NVIC Register Definitions, 287  
 NVIC Register Map, 161  
 NVIC\_BASE  
     CMSIS, 422  
     Core Definitions, 110  
 NVIC\_ClearPendingIRQ  
     CMSIS, 454  
     NVIC Functions, 113  
 NVIC\_DecodePriority  
     CMSIS, 454  
     NVIC Functions, 113  
 NVIC\_DisableIRQ  
     CMSIS, 455  
     NVIC Functions, 113  
 NVIC\_EnableIRQ  
     CMSIS, 455  
     NVIC Functions, 114  
 NVIC\_EncodePriority  
     CMSIS, 455  
     NVIC Functions, 114  
 NVIC\_GetActive  
     CMSIS, 457  
     NVIC Functions, 115  
 NVIC\_GetPendingIRQ  
     CMSIS, 457  
     NVIC Functions, 115  
 NVIC\_GetPriority  
     CMSIS, 458  
     NVIC Functions, 115  
 NVIC\_GetPriorityGrouping  
     CMSIS, 458  
     NVIC Functions, 116  
 NVIC IRQ10\_EXTI4\_Disable  
     NVIC IRQ Enable/Disable Macros, 301  
 NVIC IRQ10\_EXTI4\_Enable  
     NVIC IRQ Enable/Disable Macros, 301  
 NVIC IRQ23\_EXTI5\_9\_Disable  
     NVIC IRQ Enable/Disable Macros, 301  
 NVIC IRQ23\_EXTI5\_9\_Enable  
     NVIC IRQ Enable/Disable Macros, 302  
 NVIC IRQ31\_I2C1\_EV\_Disable  
     NVIC IRQ Enable/Disable Macros, 302  
 NVIC IRQ31\_I2C1\_EV\_Enable  
     NVIC IRQ Enable/Disable Macros, 302  
 NVIC IRQ32\_I2C1\_ER\_Disable  
     NVIC IRQ Enable/Disable Macros, 302  
 NVIC IRQ32\_I2C1\_ER\_Enable  
     NVIC IRQ Enable/Disable Macros, 302  
 NVIC IRQ33\_I2C2\_EV\_Disable  
     NVIC IRQ Enable/Disable Macros, 302  
 NVIC IRQ33\_I2C2\_EV\_Enable  
     NVIC IRQ Enable/Disable Macros, 302  
 NVIC IRQ34\_I2C2\_ER\_Disable  
     NVIC IRQ Enable/Disable Macros, 302  
 NVIC IRQ34\_I2C2\_ER\_Enable  
     NVIC IRQ Enable/Disable Macros, 303  
 NVIC IRQ35\_SPI1\_Disable  
     NVIC IRQ Enable/Disable Macros, 303  
 NVIC IRQ35\_SPI1\_Enable  
     NVIC IRQ Enable/Disable Macros, 303  
 NVIC IRQ36\_SPI2\_Disable  
     NVIC IRQ Enable/Disable Macros, 303  
 NVIC IRQ37\_USART1\_Disable  
     NVIC IRQ Enable/Disable Macros, 303  
 NVIC IRQ37\_USART1\_Enable  
     NVIC IRQ Enable/Disable Macros, 303  
 NVIC IRQ38\_USART2\_Disable  
     NVIC IRQ Enable/Disable Macros, 304  
 NVIC IRQ38\_USART2\_Enable  
     NVIC IRQ Enable/Disable Macros, 304  
 NVIC IRQ39\_USART3\_Disable  
     NVIC IRQ Enable/Disable Macros, 304  
 NVIC IRQ39\_USART3\_Enable  
     NVIC IRQ Enable/Disable Macros, 304  
 NVIC IRQ40\_EXTI10\_15\_Enable  
     NVIC IRQ Enable/Disable Macros, 304  
 NVIC IRQ6\_EXTI0\_Disable  
     NVIC IRQ Enable/Disable Macros, 304  
 NVIC IRQ6\_EXTI0\_Enable  
     NVIC IRQ Enable/Disable Macros, 304  
 NVIC IRQ7\_EXTI1\_Disable  
     NVIC IRQ Enable/Disable Macros, 304  
 NVIC IRQ7\_EXTI1\_Enable  
     NVIC IRQ Enable/Disable Macros, 304  
 NVIC IRQ8\_EXTI2\_Disable  
     NVIC IRQ Enable/Disable Macros, 305  
 NVIC IRQ8\_EXTI2\_Enable  
     NVIC IRQ Enable/Disable Macros, 305  
 NVIC IRQ9\_EXTI3\_Disable  
     NVIC IRQ Enable/Disable Macros, 305  
 NVIC IRQ9\_EXTI3\_Enable  
     NVIC IRQ Enable/Disable Macros, 305  
 NVIC\_SetPendingIRQ  
     CMSIS, 458  
     NVIC Functions, 116  
 NVIC\_SetPriority  
     CMSIS, 459  
     NVIC Functions, 116  
 NVIC\_SetPriorityGrouping

CMSIS, 459  
NVIC Functions, 117  
NVIC\_STIR\_INTID\_Msk  
  CMSIS, 422  
  Nested Vectored Interrupt Controller (NVIC), 50  
NVIC\_STIR\_INTID\_Pos  
  CMSIS, 422  
  Nested Vectored Interrupt Controller (NVIC), 50  
NVIC\_SystemReset  
  CMSIS, 459  
  NVIC Functions, 117  
NVIC\_Type, 1029  
NVIC\_TypeDef, 1029  
  IABR, 1030  
  ICER, 1030  
  ICPR, 1030  
  IP, 1030  
  ISER, 1030  
  ISPR, 1030  
  RESERVED0, 1030  
  RESERVED1, 1030  
  RESERVED2, 1031  
  RESERVED3, 1031  
  RESERVED4, 1031  
  RESERVED5, 1031  
  STIR, 1031  
  
OAR1  
  CMSIS, 496  
  I2C\_TypeDef, 1020  
  
OAR2  
  CMSIS, 497  
  I2C\_TypeDef, 1020  
  
OCOLR  
  CMSIS, 497  
  
ODR  
  CMSIS, 497  
  GPIO\_TypeDef, 1017  
  
OMAR  
  CMSIS, 497  
  
OOR  
  CMSIS, 497  
  
OPFCCR  
  CMSIS, 497  
  
OPTCR  
  CMSIS, 497  
  
OPTCR1  
  CMSIS, 498  
  
OPTKEYR  
  CMSIS, 498  
  
OR  
  CMSIS, 498  
  TIM1\_TypeDef, 1059  
  
OSPEEDR  
  CMSIS, 498  
  GPIO\_TypeDef, 1017  
  
OTG\_FS IRQn  
  Configuration\_section\_for\_CMSIS, 526  
OTG\_FS\_WKUP IRQn  
  Configuration\_section\_for\_CMSIS, 526  
  
OTYPER  
  CMSIS, 498  
  GPIO\_TypeDef, 1017  
  
P\_IRQ\_CallBack  
  S\_SPI\_Config\_t, 1044  
P\_Slave\_Event\_CallBack  
  S\_I2C\_Config\_t, 1040  
  
PAR  
  CMSIS, 498  
  
Payload\_Length  
  S\_SPI\_Config\_t, 1044  
  
PCSR  
  ITM Functions, 140  
  
PendSV\_IRQn  
  Configuration\_section\_for\_CMSIS, 524  
  
PERIPH\_BASE  
  Peripheral\_memory\_map, 535  
  
PERIPH\_BB\_BASE  
  Peripheral\_memory\_map, 535  
  
Peripheral Instances, 167  
  
Peripheral Register Definitions, 160  
  
Peripheral Selection, 308  
  RCC\_CRC, 308  
  RCC\_GPIOA, 308  
  RCC\_GPIOB, 308  
  RCC\_GPIOC, 309  
  RCC\_GPIOD, 309  
  RCC\_GPIOE, 309  
  RCC\_I2C1, 309  
  RCC\_I2C2, 309  
  RCC\_SPI1, 309  
  RCC\_SPI2, 309  
  RCC\_SYSCFG, 309  
  RCC\_TIM2, 310  
  RCC\_USART1, 310  
  RCC\_USART2, 310  
  RCC\_USART6, 310  
  
Peripheral\_declaration, 536  
  
Peripheral\_memory\_map, 532  
  AHB2PERIPH\_BASE, 534  
  BKPSRAM\_BASE, 534  
  BKPSRAM\_BB\_BASE, 534  
  CCMDATARAM\_BASE, 534  
  CCMDATARAM\_BB\_BASE, 535  
  DMA2D\_BASE, 535  
  FLASH\_BASE, 535  
  GPIOA\_BASE, 535  
  PERIPH\_BASE, 535  
  PERIPH\_BB\_BASE, 535  
  SRAM1\_BASE, 535  
  SRAM1\_BB\_BASE, 536  
  SRAM\_BB\_BASE, 536  
  UART8\_BASE, 536  
  
Peripheral\_Registers\_Bits\_Definition, 539  
  ADC\_CCR\_ADCPRE, 623  
  ADC\_CCR\_ADCPRE\_0, 623  
  ADC\_CCR\_ADCPRE\_1, 623

ADC\_CCR\_DDS, 624  
ADC\_CCR\_DELAY, 624  
ADC\_CCR\_DELAY\_0, 624  
ADC\_CCR\_DELAY\_1, 624  
ADC\_CCR\_DELAY\_2, 624  
ADC\_CCR\_DELAY\_3, 624  
ADC\_CCR\_DMA, 624  
ADC\_CCR\_DMA\_0, 624  
ADC\_CCR\_DMA\_1, 625  
ADC\_CCR\_MULTI, 625  
ADC\_CCR\_MULTI\_0, 625  
ADC\_CCR\_MULTI\_1, 625  
ADC\_CCR\_MULTI\_2, 625  
ADC\_CCR\_MULTI\_3, 625  
ADC\_CCR\_MULTI\_4, 625  
ADC\_CCR\_TSVREFE, 625  
ADC\_CCR\_VBATE, 626  
ADC\_CDR\_DATA1, 626  
ADC\_CDR\_DATA2, 626  
ADC\_CR1\_AWDCH, 626  
ADC\_CR1\_AWDCH\_0, 626  
ADC\_CR1\_AWDCH\_1, 626  
ADC\_CR1\_AWDCH\_2, 626  
ADC\_CR1\_AWDCH\_3, 626  
ADC\_CR1\_AWDCH\_4, 627  
ADC\_CR1\_AWDEN, 627  
ADC\_CR1\_AWDIE, 627  
ADC\_CR1\_AWDSGL, 627  
ADC\_CR1\_DISCEN, 627  
ADC\_CR1\_DISCNUM, 627  
ADC\_CR1\_DISCNUM\_0, 627  
ADC\_CR1\_DISCNUM\_1, 628  
ADC\_CR1\_DISCNUM\_2, 628  
ADC\_CR1\_EOCIE, 628  
ADC\_CR1\_JAUTO, 628  
ADC\_CR1\_JAWDEN, 628  
ADC\_CR1\_JDISCEN, 628  
ADC\_CR1\_JEOCIE, 628  
ADC\_CR1\_OVRIE, 629  
ADC\_CR1\_RES, 629  
ADC\_CR1\_RES\_0, 629  
ADC\_CR1\_RES\_1, 629  
ADC\_CR1\_SCAN, 629  
ADC\_CR2\_ADON, 629  
ADC\_CR2\_ALIGN, 629  
ADC\_CR2\_CONT, 630  
ADC\_CR2\_DDS, 630  
ADC\_CR2\_DMA, 630  
ADC\_CR2\_EOCS, 630  
ADC\_CR2\_EXTEN, 630  
ADC\_CR2\_EXTEN\_0, 630  
ADC\_CR2\_EXTEN\_1, 630  
ADC\_CR2\_EXTSEL, 631  
ADC\_CR2\_EXTSEL\_0, 631  
ADC\_CR2\_EXTSEL\_1, 631  
ADC\_CR2\_EXTSEL\_2, 631  
ADC\_CR2\_EXTSEL\_3, 631  
ADC\_CR2\_JEXTEN, 631  
ADC\_CR2\_JEXTEN\_0, 631  
ADC\_CR2\_JEXTEN\_1, 631  
ADC\_CR2\_JEXTSEL, 632  
ADC\_CR2\_JEXTSEL\_0, 632  
ADC\_CR2\_JEXTSEL\_1, 632  
ADC\_CR2\_JEXTSEL\_2, 632  
ADC\_CR2\_JEXTSEL\_3, 632  
ADC\_CR2\_JSWSTART, 632  
ADC\_CR2\_SWSTART, 632  
ADC\_CSR\_AWD1, 632  
ADC\_CSR\_AWD2, 633  
ADC\_CSR\_AWD3, 633  
ADC\_CSR\_EOC1, 633  
ADC\_CSR\_EOC2, 633  
ADC\_CSR\_EOC3, 633  
ADC\_CSR\_JEOC1, 633  
ADC\_CSR\_JEOC2, 633  
ADC\_CSR\_JEOC3, 633  
ADC\_CSR\_JSTRT1, 634  
ADC\_CSR\_JSTRT2, 634  
ADC\_CSR\_JSTRT3, 634  
ADC\_CSR\_OVR1, 634  
ADC\_CSR\_OVR2, 634  
ADC\_CSR\_OVR3, 634  
ADC\_CSR\_STRT1, 634  
ADC\_CSR\_STRT2, 634  
ADC\_CSR\_STRT3, 635  
ADC\_DR\_ADC2DATA, 635  
ADC\_DR\_DATA, 635  
ADC\_HTR\_HT, 635  
ADC\_JDR1\_JDATA, 635  
ADC\_JDR2\_JDATA, 635  
ADC\_JDR3\_JDATA, 635  
ADC\_JDR4\_JDATA, 635  
ADC\_JOFR1\_JOFFSET1, 636  
ADC\_JOFR2\_JOFFSET2, 636  
ADC\_JOFR3\_JOFFSET3, 636  
ADC\_JOFR4\_JOFFSET4, 636  
ADC\_JSQR\_JL, 636  
ADC\_JSQR\_JL\_0, 636  
ADC\_JSQR\_JL\_1, 636  
ADC\_JSQR\_JSQ1, 636  
ADC\_JSQR\_JSQ1\_0, 637  
ADC\_JSQR\_JSQ1\_1, 637  
ADC\_JSQR\_JSQ1\_2, 637  
ADC\_JSQR\_JSQ1\_3, 637  
ADC\_JSQR\_JSQ1\_4, 637  
ADC\_JSQR\_JSQ2, 637  
ADC\_JSQR\_JSQ2\_0, 637  
ADC\_JSQR\_JSQ2\_1, 637  
ADC\_JSQR\_JSQ2\_2, 638  
ADC\_JSQR\_JSQ2\_3, 638  
ADC\_JSQR\_JSQ2\_4, 638  
ADC\_JSQR\_JSQ3, 638  
ADC\_JSQR\_JSQ3\_0, 638  
ADC\_JSQR\_JSQ3\_1, 638  
ADC\_JSQR\_JSQ3\_2, 638  
ADC\_JSQR\_JSQ3\_3, 638

ADC\_JSQR\_JSQ3\_4, 639  
ADC\_JSQR\_JSQ4, 639  
ADC\_JSQR\_JSQ4\_0, 639  
ADC\_JSQR\_JSQ4\_1, 639  
ADC\_JSQR\_JSQ4\_2, 639  
ADC\_JSQR\_JSQ4\_3, 639  
ADC\_JSQR\_JSQ4\_4, 639  
ADC\_LTR\_LT, 639  
ADC\_SMPR1\_SMP10, 640  
ADC\_SMPR1\_SMP10\_0, 640  
ADC\_SMPR1\_SMP10\_1, 640  
ADC\_SMPR1\_SMP10\_2, 640  
ADC\_SMPR1\_SMP11, 640  
ADC\_SMPR1\_SMP11\_0, 640  
ADC\_SMPR1\_SMP11\_1, 640  
ADC\_SMPR1\_SMP11\_2, 640  
ADC\_SMPR1\_SMP12, 641  
ADC\_SMPR1\_SMP12\_0, 641  
ADC\_SMPR1\_SMP12\_1, 641  
ADC\_SMPR1\_SMP12\_2, 641  
ADC\_SMPR1\_SMP13, 641  
ADC\_SMPR1\_SMP13\_0, 641  
ADC\_SMPR1\_SMP13\_1, 641  
ADC\_SMPR1\_SMP13\_2, 641  
ADC\_SMPR1\_SMP14, 642  
ADC\_SMPR1\_SMP14\_0, 642  
ADC\_SMPR1\_SMP14\_1, 642  
ADC\_SMPR1\_SMP14\_2, 642  
ADC\_SMPR1\_SMP15, 642  
ADC\_SMPR1\_SMP15\_0, 642  
ADC\_SMPR1\_SMP15\_1, 642  
ADC\_SMPR1\_SMP15\_2, 642  
ADC\_SMPR1\_SMP16, 643  
ADC\_SMPR1\_SMP16\_0, 643  
ADC\_SMPR1\_SMP16\_1, 643  
ADC\_SMPR1\_SMP16\_2, 643  
ADC\_SMPR1\_SMP17, 643  
ADC\_SMPR1\_SMP17\_0, 643  
ADC\_SMPR1\_SMP17\_1, 643  
ADC\_SMPR1\_SMP17\_2, 643  
ADC\_SMPR1\_SMP18, 644  
ADC\_SMPR1\_SMP18\_0, 644  
ADC\_SMPR1\_SMP18\_1, 644  
ADC\_SMPR1\_SMP18\_2, 644  
ADC\_SMPR2\_SMP0, 644  
ADC\_SMPR2\_SMP0\_0, 644  
ADC\_SMPR2\_SMP0\_1, 644  
ADC\_SMPR2\_SMP0\_2, 644  
ADC\_SMPR2\_SMP1, 645  
ADC\_SMPR2\_SMP1\_0, 645  
ADC\_SMPR2\_SMP1\_1, 645  
ADC\_SMPR2\_SMP1\_2, 645  
ADC\_SMPR2\_SMP2, 645  
ADC\_SMPR2\_SMP2\_0, 645  
ADC\_SMPR2\_SMP2\_1, 645  
ADC\_SMPR2\_SMP2\_2, 645  
ADC\_SMPR2\_SMP3, 646  
ADC\_SMPR2\_SMP3\_0, 646  
ADC\_SMPR2\_SMP3\_1, 646  
ADC\_SMPR2\_SMP3\_2, 646  
ADC\_SMPR2\_SMP4, 646  
ADC\_SMPR2\_SMP4\_0, 646  
ADC\_SMPR2\_SMP4\_1, 646  
ADC\_SMPR2\_SMP4\_2, 646  
ADC\_SMPR2\_SMP5, 647  
ADC\_SMPR2\_SMP5\_0, 647  
ADC\_SMPR2\_SMP5\_1, 647  
ADC\_SMPR2\_SMP5\_2, 647  
ADC\_SMPR2\_SMP6, 647  
ADC\_SMPR2\_SMP6\_0, 647  
ADC\_SMPR2\_SMP6\_1, 647  
ADC\_SMPR2\_SMP6\_2, 647  
ADC\_SMPR2\_SMP7, 648  
ADC\_SMPR2\_SMP7\_0, 648  
ADC\_SMPR2\_SMP7\_1, 648  
ADC\_SMPR2\_SMP7\_2, 648  
ADC\_SMPR2\_SMP8, 648  
ADC\_SMPR2\_SMP8\_0, 648  
ADC\_SMPR2\_SMP8\_1, 648  
ADC\_SMPR2\_SMP8\_2, 648  
ADC\_SMPR2\_SMP9, 649  
ADC\_SMPR2\_SMP9\_0, 649  
ADC\_SMPR2\_SMP9\_1, 649  
ADC\_SMPR2\_SMP9\_2, 649  
ADC\_SQR1\_L, 649  
ADC\_SQR1\_L\_0, 649  
ADC\_SQR1\_L\_1, 649  
ADC\_SQR1\_L\_2, 649  
ADC\_SQR1\_L\_3, 650  
ADC\_SQR1\_SQ13, 650  
ADC\_SQR1\_SQ13\_0, 650  
ADC\_SQR1\_SQ13\_1, 650  
ADC\_SQR1\_SQ13\_2, 650  
ADC\_SQR1\_SQ13\_3, 650  
ADC\_SQR1\_SQ13\_4, 650  
ADC\_SQR1\_SQ14, 650  
ADC\_SQR1\_SQ14\_0, 651  
ADC\_SQR1\_SQ14\_1, 651  
ADC\_SQR1\_SQ14\_2, 651  
ADC\_SQR1\_SQ14\_3, 651  
ADC\_SQR1\_SQ14\_4, 651  
ADC\_SQR1\_SQ15, 651  
ADC\_SQR1\_SQ15\_0, 651  
ADC\_SQR1\_SQ15\_1, 651  
ADC\_SQR1\_SQ15\_2, 652  
ADC\_SQR1\_SQ15\_3, 652  
ADC\_SQR1\_SQ15\_4, 652  
ADC\_SQR1\_SQ16, 652  
ADC\_SQR1\_SQ16\_0, 652  
ADC\_SQR1\_SQ16\_1, 652  
ADC\_SQR1\_SQ16\_2, 652  
ADC\_SQR1\_SQ16\_3, 652  
ADC\_SQR1\_SQ16\_4, 653  
ADC\_SQR2\_SQ10, 653  
ADC\_SQR2\_SQ10\_0, 653  
ADC\_SQR2\_SQ10\_1, 653

ADC\_SQR2\_SQ10\_2, 653  
ADC\_SQR2\_SQ10\_3, 653  
ADC\_SQR2\_SQ10\_4, 653  
ADC\_SQR2\_SQ11, 653  
ADC\_SQR2\_SQ11\_0, 654  
ADC\_SQR2\_SQ11\_1, 654  
ADC\_SQR2\_SQ11\_2, 654  
ADC\_SQR2\_SQ11\_3, 654  
ADC\_SQR2\_SQ11\_4, 654  
ADC\_SQR2\_SQ12, 654  
ADC\_SQR2\_SQ12\_0, 654  
ADC\_SQR2\_SQ12\_1, 654  
ADC\_SQR2\_SQ12\_2, 655  
ADC\_SQR2\_SQ12\_3, 655  
ADC\_SQR2\_SQ12\_4, 655  
ADC\_SQR2\_SQ7, 655  
ADC\_SQR2\_SQ7\_0, 655  
ADC\_SQR2\_SQ7\_1, 655  
ADC\_SQR2\_SQ7\_2, 655  
ADC\_SQR2\_SQ7\_3, 655  
ADC\_SQR2\_SQ7\_4, 656  
ADC\_SQR2\_SQ8, 656  
ADC\_SQR2\_SQ8\_0, 656  
ADC\_SQR2\_SQ8\_1, 656  
ADC\_SQR2\_SQ8\_2, 656  
ADC\_SQR2\_SQ8\_3, 656  
ADC\_SQR2\_SQ8\_4, 656  
ADC\_SQR2\_SQ9, 656  
ADC\_SQR2\_SQ9\_0, 657  
ADC\_SQR2\_SQ9\_1, 657  
ADC\_SQR2\_SQ9\_2, 657  
ADC\_SQR2\_SQ9\_3, 657  
ADC\_SQR2\_SQ9\_4, 657  
ADC\_SQR3\_SQ1, 657  
ADC\_SQR3\_SQ1\_0, 657  
ADC\_SQR3\_SQ1\_1, 657  
ADC\_SQR3\_SQ1\_2, 658  
ADC\_SQR3\_SQ1\_3, 658  
ADC\_SQR3\_SQ1\_4, 658  
ADC\_SQR3\_SQ2, 658  
ADC\_SQR3\_SQ2\_0, 658  
ADC\_SQR3\_SQ2\_1, 658  
ADC\_SQR3\_SQ2\_2, 658  
ADC\_SQR3\_SQ2\_3, 658  
ADC\_SQR3\_SQ2\_4, 659  
ADC\_SQR3\_SQ3, 659  
ADC\_SQR3\_SQ3\_0, 659  
ADC\_SQR3\_SQ3\_1, 659  
ADC\_SQR3\_SQ3\_2, 659  
ADC\_SQR3\_SQ3\_3, 659  
ADC\_SQR3\_SQ3\_4, 659  
ADC\_SQR3\_SQ4, 659  
ADC\_SQR3\_SQ4\_0, 660  
ADC\_SQR3\_SQ4\_1, 660  
ADC\_SQR3\_SQ4\_2, 660  
ADC\_SQR3\_SQ4\_3, 660  
ADC\_SQR3\_SQ4\_4, 660  
ADC\_SQR3\_SQ5, 660  
ADC\_SQR3\_SQ5\_0, 660  
ADC\_SQR3\_SQ5\_1, 660  
ADC\_SQR3\_SQ5\_2, 661  
ADC\_SQR3\_SQ5\_3, 661  
ADC\_SQR3\_SQ5\_4, 661  
ADC\_SQR3\_SQ6, 661  
ADC\_SQR3\_SQ6\_0, 661  
ADC\_SQR3\_SQ6\_1, 661  
ADC\_SQR3\_SQ6\_2, 661  
ADC\_SQR3\_SQ6\_3, 661  
ADC\_SQR3\_SQ6\_4, 662  
ADC\_SR\_AWD, 662  
ADC\_SR\_EOC, 662  
ADC\_SR\_JEOC, 662  
ADC\_SR\_JSTRT, 662  
ADC\_SR\_OVR, 662  
ADC\_SR\_STRT, 662  
CAN\_BTR\_BRP, 663  
CAN\_BTR\_LBKM, 663  
CAN\_BTR\_SILM, 663  
CAN\_BTR\_SJW, 663  
CAN\_BTR\_TS1, 663  
CAN\_BTR\_TS2, 663  
CAN\_ESR\_BOFF, 663  
CAN\_ESR\_EPVF, 664  
CAN\_ESR\_EWGF, 664  
CAN\_ESR\_LEC, 664  
CAN\_ESR\_LEC\_0, 664  
CAN\_ESR\_LEC\_1, 664  
CAN\_ESR\_LEC\_2, 664  
CAN\_ESR\_REC, 664  
CAN\_ESR\_TEC, 664  
CAN\_F0R1\_FB0, 665  
CAN\_F0R1\_FB1, 665  
CAN\_F0R1\_FB10, 665  
CAN\_F0R1\_FB11, 665  
CAN\_F0R1\_FB12, 665  
CAN\_F0R1\_FB13, 665  
CAN\_F0R1\_FB14, 665  
CAN\_F0R1\_FB15, 665  
CAN\_F0R1\_FB16, 666  
CAN\_F0R1\_FB17, 666  
CAN\_F0R1\_FB18, 666  
CAN\_F0R1\_FB19, 666  
CAN\_F0R1\_FB2, 666  
CAN\_F0R1\_FB20, 666  
CAN\_F0R1\_FB21, 666  
CAN\_F0R1\_FB22, 666  
CAN\_F0R1\_FB23, 667  
CAN\_F0R1\_FB24, 667  
CAN\_F0R1\_FB25, 667  
CAN\_F0R1\_FB26, 667  
CAN\_F0R1\_FB27, 667  
CAN\_F0R1\_FB28, 667  
CAN\_F0R1\_FB29, 667  
CAN\_F0R1\_FB3, 667  
CAN\_F0R1\_FB30, 668  
CAN\_F0R1\_FB31, 668

CAN\_F0R1\_FB4, 668  
CAN\_F0R1\_FB5, 668  
CAN\_F0R1\_FB6, 668  
CAN\_F0R1\_FB7, 668  
CAN\_F0R1\_FB8, 668  
CAN\_F0R1\_FB9, 668  
CAN\_F0R2\_FB0, 669  
CAN\_F0R2\_FB1, 669  
CAN\_F0R2\_FB10, 669  
CAN\_F0R2\_FB11, 669  
CAN\_F0R2\_FB12, 669  
CAN\_F0R2\_FB13, 669  
CAN\_F0R2\_FB14, 669  
CAN\_F0R2\_FB15, 669  
CAN\_F0R2\_FB16, 670  
CAN\_F0R2\_FB17, 670  
CAN\_F0R2\_FB18, 670  
CAN\_F0R2\_FB19, 670  
CAN\_F0R2\_FB2, 670  
CAN\_F0R2\_FB20, 670  
CAN\_F0R2\_FB21, 670  
CAN\_F0R2\_FB22, 670  
CAN\_F0R2\_FB23, 671  
CAN\_F0R2\_FB24, 671  
CAN\_F0R2\_FB25, 671  
CAN\_F0R2\_FB26, 671  
CAN\_F0R2\_FB27, 671  
CAN\_F0R2\_FB28, 671  
CAN\_F0R2\_FB29, 671  
CAN\_F0R2\_FB3, 671  
CAN\_F0R2\_FB30, 672  
CAN\_F0R2\_FB31, 672  
CAN\_F0R2\_FB4, 672  
CAN\_F0R2\_FB5, 672  
CAN\_F0R2\_FB6, 672  
CAN\_F0R2\_FB7, 672  
CAN\_F0R2\_FB8, 672  
CAN\_F0R2\_FB9, 672  
CAN\_F10R1\_FB0, 673  
CAN\_F10R1\_FB1, 673  
CAN\_F10R1\_FB10, 673  
CAN\_F10R1\_FB11, 673  
CAN\_F10R1\_FB12, 673  
CAN\_F10R1\_FB13, 673  
CAN\_F10R1\_FB14, 673  
CAN\_F10R1\_FB15, 673  
CAN\_F10R1\_FB16, 674  
CAN\_F10R1\_FB17, 674  
CAN\_F10R1\_FB18, 674  
CAN\_F10R1\_FB19, 674  
CAN\_F10R1\_FB2, 674  
CAN\_F10R1\_FB20, 674  
CAN\_F10R1\_FB21, 674  
CAN\_F10R1\_FB22, 674  
CAN\_F10R1\_FB23, 675  
CAN\_F10R1\_FB24, 675  
CAN\_F10R1\_FB25, 675  
CAN\_F10R1\_FB26, 675  
CAN\_F10R1\_FB27, 675  
CAN\_F10R1\_FB28, 675  
CAN\_F10R1\_FB29, 675  
CAN\_F10R1\_FB3, 675  
CAN\_F10R1\_FB30, 676  
CAN\_F10R1\_FB31, 676  
CAN\_F10R1\_FB4, 676  
CAN\_F10R1\_FB5, 676  
CAN\_F10R1\_FB6, 676  
CAN\_F10R1\_FB7, 676  
CAN\_F10R1\_FB8, 676  
CAN\_F10R1\_FB9, 676  
CAN\_F10R2\_FB0, 677  
CAN\_F10R2\_FB1, 677  
CAN\_F10R2\_FB10, 677  
CAN\_F10R2\_FB11, 677  
CAN\_F10R2\_FB12, 677  
CAN\_F10R2\_FB13, 677  
CAN\_F10R2\_FB14, 677  
CAN\_F10R2\_FB15, 677  
CAN\_F10R2\_FB16, 678  
CAN\_F10R2\_FB17, 678  
CAN\_F10R2\_FB18, 678  
CAN\_F10R2\_FB19, 678  
CAN\_F10R2\_FB2, 678  
CAN\_F10R2\_FB20, 678  
CAN\_F10R2\_FB21, 678  
CAN\_F10R2\_FB22, 678  
CAN\_F10R2\_FB23, 679  
CAN\_F10R2\_FB24, 679  
CAN\_F10R2\_FB25, 679  
CAN\_F10R2\_FB26, 679  
CAN\_F10R2\_FB27, 679  
CAN\_F10R2\_FB28, 679  
CAN\_F10R2\_FB29, 679  
CAN\_F10R2\_FB3, 679  
CAN\_F10R2\_FB30, 680  
CAN\_F10R2\_FB31, 680  
CAN\_F10R2\_FB4, 680  
CAN\_F10R2\_FB5, 680  
CAN\_F10R2\_FB6, 680  
CAN\_F10R2\_FB7, 680  
CAN\_F10R2\_FB8, 680  
CAN\_F10R2\_FB9, 680  
CAN\_F11R1\_FB0, 681  
CAN\_F11R1\_FB1, 681  
CAN\_F11R1\_FB10, 681  
CAN\_F11R1\_FB11, 681  
CAN\_F11R1\_FB12, 681  
CAN\_F11R1\_FB13, 681  
CAN\_F11R1\_FB14, 681  
CAN\_F11R1\_FB15, 681  
CAN\_F11R1\_FB16, 682  
CAN\_F11R1\_FB17, 682  
CAN\_F11R1\_FB18, 682  
CAN\_F11R1\_FB19, 682  
CAN\_F11R1\_FB2, 682  
CAN\_F11R1\_FB20, 682

CAN\_F11R1\_FB21, 682  
CAN\_F11R1\_FB22, 682  
CAN\_F11R1\_FB23, 683  
CAN\_F11R1\_FB24, 683  
CAN\_F11R1\_FB25, 683  
CAN\_F11R1\_FB26, 683  
CAN\_F11R1\_FB27, 683  
CAN\_F11R1\_FB28, 683  
CAN\_F11R1\_FB29, 683  
CAN\_F11R1\_FB3, 683  
CAN\_F11R1\_FB30, 684  
CAN\_F11R1\_FB31, 684  
CAN\_F11R1\_FB4, 684  
CAN\_F11R1\_FB5, 684  
CAN\_F11R1\_FB6, 684  
CAN\_F11R1\_FB7, 684  
CAN\_F11R1\_FB8, 684  
CAN\_F11R1\_FB9, 684  
CAN\_F11R2\_FB0, 685  
CAN\_F11R2\_FB1, 685  
CAN\_F11R2\_FB10, 685  
CAN\_F11R2\_FB11, 685  
CAN\_F11R2\_FB12, 685  
CAN\_F11R2\_FB13, 685  
CAN\_F11R2\_FB14, 685  
CAN\_F11R2\_FB15, 685  
CAN\_F11R2\_FB16, 686  
CAN\_F11R2\_FB17, 686  
CAN\_F11R2\_FB18, 686  
CAN\_F11R2\_FB19, 686  
CAN\_F11R2\_FB2, 686  
CAN\_F11R2\_FB20, 686  
CAN\_F11R2\_FB21, 686  
CAN\_F11R2\_FB22, 686  
CAN\_F11R2\_FB23, 687  
CAN\_F11R2\_FB24, 687  
CAN\_F11R2\_FB25, 687  
CAN\_F11R2\_FB26, 687  
CAN\_F11R2\_FB27, 687  
CAN\_F11R2\_FB28, 687  
CAN\_F11R2\_FB29, 687  
CAN\_F11R2\_FB3, 687  
CAN\_F11R2\_FB30, 688  
CAN\_F11R2\_FB31, 688  
CAN\_F11R2\_FB4, 688  
CAN\_F11R2\_FB5, 688  
CAN\_F11R2\_FB6, 688  
CAN\_F11R2\_FB7, 688  
CAN\_F11R2\_FB8, 688  
CAN\_F11R2\_FB9, 688  
CAN\_F12R1\_FB0, 689  
CAN\_F12R1\_FB1, 689  
CAN\_F12R1\_FB10, 689  
CAN\_F12R1\_FB11, 689  
CAN\_F12R1\_FB12, 689  
CAN\_F12R1\_FB13, 689  
CAN\_F12R1\_FB14, 689  
CAN\_F12R1\_FB15, 689  
CAN\_F12R1\_FB16, 690  
CAN\_F12R1\_FB17, 690  
CAN\_F12R1\_FB18, 690  
CAN\_F12R1\_FB19, 690  
CAN\_F12R1\_FB2, 690  
CAN\_F12R1\_FB20, 690  
CAN\_F12R1\_FB21, 690  
CAN\_F12R1\_FB22, 690  
CAN\_F12R1\_FB23, 691  
CAN\_F12R1\_FB24, 691  
CAN\_F12R1\_FB25, 691  
CAN\_F12R1\_FB26, 691  
CAN\_F12R1\_FB27, 691  
CAN\_F12R1\_FB28, 691  
CAN\_F12R1\_FB29, 691  
CAN\_F12R1\_FB3, 691  
CAN\_F12R1\_FB30, 692  
CAN\_F12R1\_FB31, 692  
CAN\_F12R1\_FB4, 692  
CAN\_F12R1\_FB5, 692  
CAN\_F12R1\_FB6, 692  
CAN\_F12R1\_FB7, 692  
CAN\_F12R1\_FB8, 692  
CAN\_F12R1\_FB9, 692  
CAN\_F12R2\_FB0, 693  
CAN\_F12R2\_FB1, 693  
CAN\_F12R2\_FB10, 693  
CAN\_F12R2\_FB11, 693  
CAN\_F12R2\_FB12, 693  
CAN\_F12R2\_FB13, 693  
CAN\_F12R2\_FB14, 693  
CAN\_F12R2\_FB15, 693  
CAN\_F12R2\_FB16, 694  
CAN\_F12R2\_FB17, 694  
CAN\_F12R2\_FB18, 694  
CAN\_F12R2\_FB19, 694  
CAN\_F12R2\_FB2, 694  
CAN\_F12R2\_FB20, 694  
CAN\_F12R2\_FB21, 694  
CAN\_F12R2\_FB22, 694  
CAN\_F12R2\_FB23, 695  
CAN\_F12R2\_FB24, 695  
CAN\_F12R2\_FB25, 695  
CAN\_F12R2\_FB26, 695  
CAN\_F12R2\_FB27, 695  
CAN\_F12R2\_FB28, 695  
CAN\_F12R2\_FB29, 695  
CAN\_F12R2\_FB3, 695  
CAN\_F12R2\_FB30, 696  
CAN\_F12R2\_FB31, 696  
CAN\_F12R2\_FB4, 696  
CAN\_F12R2\_FB5, 696  
CAN\_F12R2\_FB6, 696  
CAN\_F12R2\_FB7, 696  
CAN\_F12R2\_FB8, 696  
CAN\_F12R2\_FB9, 696  
CAN\_F13R1\_FB0, 697  
CAN\_F13R1\_FB1, 697

CAN\_F13R1\_FB10, 697  
CAN\_F13R1\_FB11, 697  
CAN\_F13R1\_FB12, 697  
CAN\_F13R1\_FB13, 697  
CAN\_F13R1\_FB14, 697  
CAN\_F13R1\_FB15, 697  
CAN\_F13R1\_FB16, 698  
CAN\_F13R1\_FB17, 698  
CAN\_F13R1\_FB18, 698  
CAN\_F13R1\_FB19, 698  
CAN\_F13R1\_FB2, 698  
CAN\_F13R1\_FB20, 698  
CAN\_F13R1\_FB21, 698  
CAN\_F13R1\_FB22, 698  
CAN\_F13R1\_FB23, 699  
CAN\_F13R1\_FB24, 699  
CAN\_F13R1\_FB25, 699  
CAN\_F13R1\_FB26, 699  
CAN\_F13R1\_FB27, 699  
CAN\_F13R1\_FB28, 699  
CAN\_F13R1\_FB29, 699  
CAN\_F13R1\_FB3, 699  
CAN\_F13R1\_FB30, 700  
CAN\_F13R1\_FB31, 700  
CAN\_F13R1\_FB4, 700  
CAN\_F13R1\_FB5, 700  
CAN\_F13R1\_FB6, 700  
CAN\_F13R1\_FB7, 700  
CAN\_F13R1\_FB8, 700  
CAN\_F13R1\_FB9, 700  
CAN\_F13R2\_FB0, 701  
CAN\_F13R2\_FB1, 701  
CAN\_F13R2\_FB10, 701  
CAN\_F13R2\_FB11, 701  
CAN\_F13R2\_FB12, 701  
CAN\_F13R2\_FB13, 701  
CAN\_F13R2\_FB14, 701  
CAN\_F13R2\_FB15, 701  
CAN\_F13R2\_FB16, 702  
CAN\_F13R2\_FB17, 702  
CAN\_F13R2\_FB18, 702  
CAN\_F13R2\_FB19, 702  
CAN\_F13R2\_FB2, 702  
CAN\_F13R2\_FB20, 702  
CAN\_F13R2\_FB21, 702  
CAN\_F13R2\_FB22, 702  
CAN\_F13R2\_FB23, 703  
CAN\_F13R2\_FB24, 703  
CAN\_F13R2\_FB25, 703  
CAN\_F13R2\_FB26, 703  
CAN\_F13R2\_FB27, 703  
CAN\_F13R2\_FB28, 703  
CAN\_F13R2\_FB29, 703  
CAN\_F13R2\_FB3, 703  
CAN\_F13R2\_FB30, 704  
CAN\_F13R2\_FB31, 704  
CAN\_F13R2\_FB4, 704  
CAN\_F13R2\_FB5, 704  
CAN\_F13R2\_FB6, 704  
CAN\_F13R2\_FB7, 704  
CAN\_F13R2\_FB8, 704  
CAN\_F13R2\_FB9, 704  
CAN\_F1R1\_FB0, 705  
CAN\_F1R1\_FB1, 705  
CAN\_F1R1\_FB10, 705  
CAN\_F1R1\_FB11, 705  
CAN\_F1R1\_FB12, 705  
CAN\_F1R1\_FB13, 705  
CAN\_F1R1\_FB14, 705  
CAN\_F1R1\_FB15, 705  
CAN\_F1R1\_FB16, 706  
CAN\_F1R1\_FB17, 706  
CAN\_F1R1\_FB18, 706  
CAN\_F1R1\_FB19, 706  
CAN\_F1R1\_FB2, 706  
CAN\_F1R1\_FB20, 706  
CAN\_F1R1\_FB21, 706  
CAN\_F1R1\_FB22, 706  
CAN\_F1R1\_FB23, 707  
CAN\_F1R1\_FB24, 707  
CAN\_F1R1\_FB25, 707  
CAN\_F1R1\_FB26, 707  
CAN\_F1R1\_FB27, 707  
CAN\_F1R1\_FB28, 707  
CAN\_F1R1\_FB29, 707  
CAN\_F1R1\_FB3, 707  
CAN\_F1R1\_FB30, 708  
CAN\_F1R1\_FB31, 708  
CAN\_F1R1\_FB4, 708  
CAN\_F1R1\_FB5, 708  
CAN\_F1R1\_FB6, 708  
CAN\_F1R1\_FB7, 708  
CAN\_F1R1\_FB8, 708  
CAN\_F1R1\_FB9, 708  
CAN\_F1R2\_FB0, 709  
CAN\_F1R2\_FB1, 709  
CAN\_F1R2\_FB10, 709  
CAN\_F1R2\_FB11, 709  
CAN\_F1R2\_FB12, 709  
CAN\_F1R2\_FB13, 709  
CAN\_F1R2\_FB14, 709  
CAN\_F1R2\_FB15, 709  
CAN\_F1R2\_FB16, 710  
CAN\_F1R2\_FB17, 710  
CAN\_F1R2\_FB18, 710  
CAN\_F1R2\_FB19, 710  
CAN\_F1R2\_FB2, 710  
CAN\_F1R2\_FB20, 710  
CAN\_F1R2\_FB21, 710  
CAN\_F1R2\_FB22, 710  
CAN\_F1R2\_FB23, 711  
CAN\_F1R2\_FB24, 711  
CAN\_F1R2\_FB25, 711  
CAN\_F1R2\_FB26, 711  
CAN\_F1R2\_FB27, 711  
CAN\_F1R2\_FB28, 711

CAN\_F1R2\_FB29, 711  
CAN\_F1R2\_FB3, 711  
CAN\_F1R2\_FB30, 712  
CAN\_F1R2\_FB31, 712  
CAN\_F1R2\_FB4, 712  
CAN\_F1R2\_FB5, 712  
CAN\_F1R2\_FB6, 712  
CAN\_F1R2\_FB7, 712  
CAN\_F1R2\_FB8, 712  
CAN\_F1R2\_FB9, 712  
CAN\_F2R1\_FB0, 713  
CAN\_F2R1\_FB1, 713  
CAN\_F2R1\_FB10, 713  
CAN\_F2R1\_FB11, 713  
CAN\_F2R1\_FB12, 713  
CAN\_F2R1\_FB13, 713  
CAN\_F2R1\_FB14, 713  
CAN\_F2R1\_FB15, 713  
CAN\_F2R1\_FB16, 714  
CAN\_F2R1\_FB17, 714  
CAN\_F2R1\_FB18, 714  
CAN\_F2R1\_FB19, 714  
CAN\_F2R1\_FB2, 714  
CAN\_F2R1\_FB20, 714  
CAN\_F2R1\_FB21, 714  
CAN\_F2R1\_FB22, 714  
CAN\_F2R1\_FB23, 715  
CAN\_F2R1\_FB24, 715  
CAN\_F2R1\_FB25, 715  
CAN\_F2R1\_FB26, 715  
CAN\_F2R1\_FB27, 715  
CAN\_F2R1\_FB28, 715  
CAN\_F2R1\_FB29, 715  
CAN\_F2R1\_FB3, 715  
CAN\_F2R1\_FB30, 716  
CAN\_F2R1\_FB31, 716  
CAN\_F2R1\_FB4, 716  
CAN\_F2R1\_FB5, 716  
CAN\_F2R1\_FB6, 716  
CAN\_F2R1\_FB7, 716  
CAN\_F2R1\_FB8, 716  
CAN\_F2R1\_FB9, 716  
CAN\_F2R2\_FB0, 717  
CAN\_F2R2\_FB1, 717  
CAN\_F2R2\_FB10, 717  
CAN\_F2R2\_FB11, 717  
CAN\_F2R2\_FB12, 717  
CAN\_F2R2\_FB13, 717  
CAN\_F2R2\_FB14, 717  
CAN\_F2R2\_FB15, 717  
CAN\_F2R2\_FB16, 718  
CAN\_F2R2\_FB17, 718  
CAN\_F2R2\_FB18, 718  
CAN\_F2R2\_FB19, 718  
CAN\_F2R2\_FB2, 718  
CAN\_F2R2\_FB20, 718  
CAN\_F2R2\_FB21, 718  
CAN\_F2R2\_FB22, 718  
CAN\_F2R2\_FB23, 719  
CAN\_F2R2\_FB24, 719  
CAN\_F2R2\_FB25, 719  
CAN\_F2R2\_FB26, 719  
CAN\_F2R2\_FB27, 719  
CAN\_F2R2\_FB28, 719  
CAN\_F2R2\_FB29, 719  
CAN\_F2R2\_FB3, 719  
CAN\_F2R2\_FB30, 720  
CAN\_F2R2\_FB31, 720  
CAN\_F2R2\_FB4, 720  
CAN\_F2R2\_FB5, 720  
CAN\_F2R2\_FB6, 720  
CAN\_F2R2\_FB7, 720  
CAN\_F2R2\_FB8, 720  
CAN\_F2R2\_FB9, 720  
CAN\_F3R1\_FB0, 721  
CAN\_F3R1\_FB1, 721  
CAN\_F3R1\_FB10, 721  
CAN\_F3R1\_FB11, 721  
CAN\_F3R1\_FB12, 721  
CAN\_F3R1\_FB13, 721  
CAN\_F3R1\_FB14, 721  
CAN\_F3R1\_FB15, 721  
CAN\_F3R1\_FB16, 722  
CAN\_F3R1\_FB17, 722  
CAN\_F3R1\_FB18, 722  
CAN\_F3R1\_FB19, 722  
CAN\_F3R1\_FB2, 722  
CAN\_F3R1\_FB20, 722  
CAN\_F3R1\_FB21, 722  
CAN\_F3R1\_FB22, 722  
CAN\_F3R1\_FB23, 723  
CAN\_F3R1\_FB24, 723  
CAN\_F3R1\_FB25, 723  
CAN\_F3R1\_FB26, 723  
CAN\_F3R1\_FB27, 723  
CAN\_F3R1\_FB28, 723  
CAN\_F3R1\_FB29, 723  
CAN\_F3R1\_FB3, 723  
CAN\_F3R1\_FB30, 724  
CAN\_F3R1\_FB31, 724  
CAN\_F3R1\_FB4, 724  
CAN\_F3R1\_FB5, 724  
CAN\_F3R1\_FB6, 724  
CAN\_F3R1\_FB7, 724  
CAN\_F3R1\_FB8, 724  
CAN\_F3R1\_FB9, 724  
CAN\_F3R2\_FB0, 725  
CAN\_F3R2\_FB1, 725  
CAN\_F3R2\_FB10, 725  
CAN\_F3R2\_FB11, 725  
CAN\_F3R2\_FB12, 725  
CAN\_F3R2\_FB13, 725  
CAN\_F3R2\_FB14, 725  
CAN\_F3R2\_FB15, 725  
CAN\_F3R2\_FB16, 726  
CAN\_F3R2\_FB17, 726

CAN\_F3R2\_FB18, 726  
CAN\_F3R2\_FB19, 726  
CAN\_F3R2\_FB2, 726  
CAN\_F3R2\_FB20, 726  
CAN\_F3R2\_FB21, 726  
CAN\_F3R2\_FB22, 726  
CAN\_F3R2\_FB23, 727  
CAN\_F3R2\_FB24, 727  
CAN\_F3R2\_FB25, 727  
CAN\_F3R2\_FB26, 727  
CAN\_F3R2\_FB27, 727  
CAN\_F3R2\_FB28, 727  
CAN\_F3R2\_FB29, 727  
CAN\_F3R2\_FB3, 727  
CAN\_F3R2\_FB30, 728  
CAN\_F3R2\_FB31, 728  
CAN\_F3R2\_FB4, 728  
CAN\_F3R2\_FB5, 728  
CAN\_F3R2\_FB6, 728  
CAN\_F3R2\_FB7, 728  
CAN\_F3R2\_FB8, 728  
CAN\_F3R2\_FB9, 728  
CAN\_F4R1\_FB0, 729  
CAN\_F4R1\_FB1, 729  
CAN\_F4R1\_FB10, 729  
CAN\_F4R1\_FB11, 729  
CAN\_F4R1\_FB12, 729  
CAN\_F4R1\_FB13, 729  
CAN\_F4R1\_FB14, 729  
CAN\_F4R1\_FB15, 729  
CAN\_F4R1\_FB16, 730  
CAN\_F4R1\_FB17, 730  
CAN\_F4R1\_FB18, 730  
CAN\_F4R1\_FB19, 730  
CAN\_F4R1\_FB2, 730  
CAN\_F4R1\_FB20, 730  
CAN\_F4R1\_FB21, 730  
CAN\_F4R1\_FB22, 730  
CAN\_F4R1\_FB23, 731  
CAN\_F4R1\_FB24, 731  
CAN\_F4R1\_FB25, 731  
CAN\_F4R1\_FB26, 731  
CAN\_F4R1\_FB27, 731  
CAN\_F4R1\_FB28, 731  
CAN\_F4R1\_FB29, 731  
CAN\_F4R1\_FB3, 731  
CAN\_F4R1\_FB30, 732  
CAN\_F4R1\_FB31, 732  
CAN\_F4R1\_FB4, 732  
CAN\_F4R1\_FB5, 732  
CAN\_F4R1\_FB6, 732  
CAN\_F4R1\_FB7, 732  
CAN\_F4R1\_FB8, 732  
CAN\_F4R1\_FB9, 732  
CAN\_F4R2\_FB0, 733  
CAN\_F4R2\_FB1, 733  
CAN\_F4R2\_FB10, 733  
CAN\_F4R2\_FB11, 733  
CAN\_F4R2\_FB12, 733  
CAN\_F4R2\_FB13, 733  
CAN\_F4R2\_FB14, 733  
CAN\_F4R2\_FB15, 733  
CAN\_F4R2\_FB16, 734  
CAN\_F4R2\_FB17, 734  
CAN\_F4R2\_FB18, 734  
CAN\_F4R2\_FB19, 734  
CAN\_F4R2\_FB2, 734  
CAN\_F4R2\_FB20, 734  
CAN\_F4R2\_FB21, 734  
CAN\_F4R2\_FB22, 734  
CAN\_F4R2\_FB23, 735  
CAN\_F4R2\_FB24, 735  
CAN\_F4R2\_FB25, 735  
CAN\_F4R2\_FB26, 735  
CAN\_F4R2\_FB27, 735  
CAN\_F4R2\_FB28, 735  
CAN\_F4R2\_FB29, 735  
CAN\_F4R2\_FB3, 735  
CAN\_F4R2\_FB30, 736  
CAN\_F4R2\_FB31, 736  
CAN\_F4R2\_FB4, 736  
CAN\_F4R2\_FB5, 736  
CAN\_F4R2\_FB6, 736  
CAN\_F4R2\_FB7, 736  
CAN\_F4R2\_FB8, 736  
CAN\_F4R2\_FB9, 736  
CAN\_F5R1\_FB0, 737  
CAN\_F5R1\_FB1, 737  
CAN\_F5R1\_FB10, 737  
CAN\_F5R1\_FB11, 737  
CAN\_F5R1\_FB12, 737  
CAN\_F5R1\_FB13, 737  
CAN\_F5R1\_FB14, 737  
CAN\_F5R1\_FB15, 737  
CAN\_F5R1\_FB16, 738  
CAN\_F5R1\_FB17, 738  
CAN\_F5R1\_FB18, 738  
CAN\_F5R1\_FB19, 738  
CAN\_F5R1\_FB2, 738  
CAN\_F5R1\_FB20, 738  
CAN\_F5R1\_FB21, 738  
CAN\_F5R1\_FB22, 738  
CAN\_F5R1\_FB23, 739  
CAN\_F5R1\_FB24, 739  
CAN\_F5R1\_FB25, 739  
CAN\_F5R1\_FB26, 739  
CAN\_F5R1\_FB27, 739  
CAN\_F5R1\_FB28, 739  
CAN\_F5R1\_FB29, 739  
CAN\_F5R1\_FB3, 739  
CAN\_F5R1\_FB30, 740  
CAN\_F5R1\_FB31, 740  
CAN\_F5R1\_FB4, 740  
CAN\_F5R1\_FB5, 740  
CAN\_F5R1\_FB6, 740  
CAN\_F5R1\_FB7, 740

CAN\_F5R1\_FB8, 740  
CAN\_F5R1\_FB9, 740  
CAN\_F5R2\_FB0, 741  
CAN\_F5R2\_FB1, 741  
CAN\_F5R2\_FB10, 741  
CAN\_F5R2\_FB11, 741  
CAN\_F5R2\_FB12, 741  
CAN\_F5R2\_FB13, 741  
CAN\_F5R2\_FB14, 741  
CAN\_F5R2\_FB15, 741  
CAN\_F5R2\_FB16, 742  
CAN\_F5R2\_FB17, 742  
CAN\_F5R2\_FB18, 742  
CAN\_F5R2\_FB19, 742  
CAN\_F5R2\_FB2, 742  
CAN\_F5R2\_FB20, 742  
CAN\_F5R2\_FB21, 742  
CAN\_F5R2\_FB22, 742  
CAN\_F5R2\_FB23, 743  
CAN\_F5R2\_FB24, 743  
CAN\_F5R2\_FB25, 743  
CAN\_F5R2\_FB26, 743  
CAN\_F5R2\_FB27, 743  
CAN\_F5R2\_FB28, 743  
CAN\_F5R2\_FB29, 743  
CAN\_F5R2\_FB3, 743  
CAN\_F5R2\_FB30, 744  
CAN\_F5R2\_FB31, 744  
CAN\_F5R2\_FB4, 744  
CAN\_F5R2\_FB5, 744  
CAN\_F5R2\_FB6, 744  
CAN\_F5R2\_FB7, 744  
CAN\_F5R2\_FB8, 744  
CAN\_F5R2\_FB9, 744  
CAN\_F6R1\_FB0, 745  
CAN\_F6R1\_FB1, 745  
CAN\_F6R1\_FB10, 745  
CAN\_F6R1\_FB11, 745  
CAN\_F6R1\_FB12, 745  
CAN\_F6R1\_FB13, 745  
CAN\_F6R1\_FB14, 745  
CAN\_F6R1\_FB15, 745  
CAN\_F6R1\_FB16, 746  
CAN\_F6R1\_FB17, 746  
CAN\_F6R1\_FB18, 746  
CAN\_F6R1\_FB19, 746  
CAN\_F6R1\_FB2, 746  
CAN\_F6R1\_FB20, 746  
CAN\_F6R1\_FB21, 746  
CAN\_F6R1\_FB22, 746  
CAN\_F6R1\_FB23, 747  
CAN\_F6R1\_FB24, 747  
CAN\_F6R1\_FB25, 747  
CAN\_F6R1\_FB26, 747  
CAN\_F6R1\_FB27, 747  
CAN\_F6R1\_FB28, 747  
CAN\_F6R1\_FB29, 747  
CAN\_F6R1\_FB3, 747  
CAN\_F6R1\_FB30, 748  
CAN\_F6R1\_FB31, 748  
CAN\_F6R1\_FB4, 748  
CAN\_F6R1\_FB5, 748  
CAN\_F6R1\_FB6, 748  
CAN\_F6R1\_FB7, 748  
CAN\_F6R1\_FB8, 748  
CAN\_F6R1\_FB9, 748  
CAN\_F6R2\_FB0, 749  
CAN\_F6R2\_FB1, 749  
CAN\_F6R2\_FB10, 749  
CAN\_F6R2\_FB11, 749  
CAN\_F6R2\_FB12, 749  
CAN\_F6R2\_FB13, 749  
CAN\_F6R2\_FB14, 749  
CAN\_F6R2\_FB15, 749  
CAN\_F6R2\_FB16, 750  
CAN\_F6R2\_FB17, 750  
CAN\_F6R2\_FB18, 750  
CAN\_F6R2\_FB19, 750  
CAN\_F6R2\_FB2, 750  
CAN\_F6R2\_FB20, 750  
CAN\_F6R2\_FB21, 750  
CAN\_F6R2\_FB22, 750  
CAN\_F6R2\_FB23, 751  
CAN\_F6R2\_FB24, 751  
CAN\_F6R2\_FB25, 751  
CAN\_F6R2\_FB26, 751  
CAN\_F6R2\_FB27, 751  
CAN\_F6R2\_FB28, 751  
CAN\_F6R2\_FB29, 751  
CAN\_F6R2\_FB3, 751  
CAN\_F6R2\_FB30, 752  
CAN\_F6R2\_FB31, 752  
CAN\_F6R2\_FB4, 752  
CAN\_F6R2\_FB5, 752  
CAN\_F6R2\_FB6, 752  
CAN\_F6R2\_FB7, 752  
CAN\_F6R2\_FB8, 752  
CAN\_F6R2\_FB9, 752  
CAN\_F7R1\_FB0, 753  
CAN\_F7R1\_FB1, 753  
CAN\_F7R1\_FB10, 753  
CAN\_F7R1\_FB11, 753  
CAN\_F7R1\_FB12, 753  
CAN\_F7R1\_FB13, 753  
CAN\_F7R1\_FB14, 753  
CAN\_F7R1\_FB15, 753  
CAN\_F7R1\_FB16, 754  
CAN\_F7R1\_FB17, 754  
CAN\_F7R1\_FB18, 754  
CAN\_F7R1\_FB19, 754  
CAN\_F7R1\_FB2, 754  
CAN\_F7R1\_FB20, 754  
CAN\_F7R1\_FB21, 754  
CAN\_F7R1\_FB22, 754  
CAN\_F7R1\_FB23, 755  
CAN\_F7R1\_FB24, 755

CAN\_F7R1\_FB25, 755  
CAN\_F7R1\_FB26, 755  
CAN\_F7R1\_FB27, 755  
CAN\_F7R1\_FB28, 755  
CAN\_F7R1\_FB29, 755  
CAN\_F7R1\_FB3, 755  
CAN\_F7R1\_FB30, 756  
CAN\_F7R1\_FB31, 756  
CAN\_F7R1\_FB4, 756  
CAN\_F7R1\_FB5, 756  
CAN\_F7R1\_FB6, 756  
CAN\_F7R1\_FB7, 756  
CAN\_F7R1\_FB8, 756  
CAN\_F7R1\_FB9, 756  
CAN\_F7R2\_FB0, 757  
CAN\_F7R2\_FB1, 757  
CAN\_F7R2\_FB10, 757  
CAN\_F7R2\_FB11, 757  
CAN\_F7R2\_FB12, 757  
CAN\_F7R2\_FB13, 757  
CAN\_F7R2\_FB14, 757  
CAN\_F7R2\_FB15, 757  
CAN\_F7R2\_FB16, 758  
CAN\_F7R2\_FB17, 758  
CAN\_F7R2\_FB18, 758  
CAN\_F7R2\_FB19, 758  
CAN\_F7R2\_FB2, 758  
CAN\_F7R2\_FB20, 758  
CAN\_F7R2\_FB21, 758  
CAN\_F7R2\_FB22, 758  
CAN\_F7R2\_FB23, 759  
CAN\_F7R2\_FB24, 759  
CAN\_F7R2\_FB25, 759  
CAN\_F7R2\_FB26, 759  
CAN\_F7R2\_FB27, 759  
CAN\_F7R2\_FB28, 759  
CAN\_F7R2\_FB29, 759  
CAN\_F7R2\_FB3, 759  
CAN\_F7R2\_FB30, 760  
CAN\_F7R2\_FB31, 760  
CAN\_F7R2\_FB4, 760  
CAN\_F7R2\_FB5, 760  
CAN\_F7R2\_FB6, 760  
CAN\_F7R2\_FB7, 760  
CAN\_F7R2\_FB8, 760  
CAN\_F7R2\_FB9, 760  
CAN\_F8R1\_FB0, 761  
CAN\_F8R1\_FB1, 761  
CAN\_F8R1\_FB10, 761  
CAN\_F8R1\_FB11, 761  
CAN\_F8R1\_FB12, 761  
CAN\_F8R1\_FB13, 761  
CAN\_F8R1\_FB14, 761  
CAN\_F8R1\_FB15, 761  
CAN\_F8R1\_FB16, 762  
CAN\_F8R1\_FB17, 762  
CAN\_F8R1\_FB18, 762  
CAN\_F8R1\_FB19, 762  
CAN\_F8R1\_FB2, 762  
CAN\_F8R1\_FB20, 762  
CAN\_F8R1\_FB21, 762  
CAN\_F8R1\_FB22, 762  
CAN\_F8R1\_FB23, 763  
CAN\_F8R1\_FB24, 763  
CAN\_F8R1\_FB25, 763  
CAN\_F8R1\_FB26, 763  
CAN\_F8R1\_FB27, 763  
CAN\_F8R1\_FB28, 763  
CAN\_F8R1\_FB29, 763  
CAN\_F8R1\_FB3, 763  
CAN\_F8R1\_FB30, 764  
CAN\_F8R1\_FB31, 764  
CAN\_F8R1\_FB4, 764  
CAN\_F8R1\_FB5, 764  
CAN\_F8R1\_FB6, 764  
CAN\_F8R1\_FB7, 764  
CAN\_F8R1\_FB8, 764  
CAN\_F8R1\_FB9, 764  
CAN\_F8R2\_FB0, 765  
CAN\_F8R2\_FB1, 765  
CAN\_F8R2\_FB10, 765  
CAN\_F8R2\_FB11, 765  
CAN\_F8R2\_FB12, 765  
CAN\_F8R2\_FB13, 765  
CAN\_F8R2\_FB14, 765  
CAN\_F8R2\_FB15, 765  
CAN\_F8R2\_FB16, 766  
CAN\_F8R2\_FB17, 766  
CAN\_F8R2\_FB18, 766  
CAN\_F8R2\_FB19, 766  
CAN\_F8R2\_FB2, 766  
CAN\_F8R2\_FB20, 766  
CAN\_F8R2\_FB21, 766  
CAN\_F8R2\_FB22, 766  
CAN\_F8R2\_FB23, 767  
CAN\_F8R2\_FB24, 767  
CAN\_F8R2\_FB25, 767  
CAN\_F8R2\_FB26, 767  
CAN\_F8R2\_FB27, 767  
CAN\_F8R2\_FB28, 767  
CAN\_F8R2\_FB29, 767  
CAN\_F8R2\_FB3, 767  
CAN\_F8R2\_FB30, 768  
CAN\_F8R2\_FB31, 768  
CAN\_F8R2\_FB4, 768  
CAN\_F8R2\_FB5, 768  
CAN\_F8R2\_FB6, 768  
CAN\_F8R2\_FB7, 768  
CAN\_F8R2\_FB8, 768  
CAN\_F8R2\_FB9, 768  
CAN\_F9R1\_FB0, 769  
CAN\_F9R1\_FB1, 769  
CAN\_F9R1\_FB10, 769  
CAN\_F9R1\_FB11, 769  
CAN\_F9R1\_FB12, 769  
CAN\_F9R1\_FB13, 769

CAN\_F9R1\_FB14, 769  
CAN\_F9R1\_FB15, 769  
CAN\_F9R1\_FB16, 770  
CAN\_F9R1\_FB17, 770  
CAN\_F9R1\_FB18, 770  
CAN\_F9R1\_FB19, 770  
CAN\_F9R1\_FB2, 770  
CAN\_F9R1\_FB20, 770  
CAN\_F9R1\_FB21, 770  
CAN\_F9R1\_FB22, 770  
CAN\_F9R1\_FB23, 771  
CAN\_F9R1\_FB24, 771  
CAN\_F9R1\_FB25, 771  
CAN\_F9R1\_FB26, 771  
CAN\_F9R1\_FB27, 771  
CAN\_F9R1\_FB28, 771  
CAN\_F9R1\_FB29, 771  
CAN\_F9R1\_FB3, 771  
CAN\_F9R1\_FB30, 772  
CAN\_F9R1\_FB31, 772  
CAN\_F9R1\_FB4, 772  
CAN\_F9R1\_FB5, 772  
CAN\_F9R1\_FB6, 772  
CAN\_F9R1\_FB7, 772  
CAN\_F9R1\_FB8, 772  
CAN\_F9R1\_FB9, 772  
CAN\_F9R2\_FB0, 773  
CAN\_F9R2\_FB1, 773  
CAN\_F9R2\_FB10, 773  
CAN\_F9R2\_FB11, 773  
CAN\_F9R2\_FB12, 773  
CAN\_F9R2\_FB13, 773  
CAN\_F9R2\_FB14, 773  
CAN\_F9R2\_FB15, 773  
CAN\_F9R2\_FB16, 774  
CAN\_F9R2\_FB17, 774  
CAN\_F9R2\_FB18, 774  
CAN\_F9R2\_FB19, 774  
CAN\_F9R2\_FB2, 774  
CAN\_F9R2\_FB20, 774  
CAN\_F9R2\_FB21, 774  
CAN\_F9R2\_FB22, 774  
CAN\_F9R2\_FB23, 775  
CAN\_F9R2\_FB24, 775  
CAN\_F9R2\_FB25, 775  
CAN\_F9R2\_FB26, 775  
CAN\_F9R2\_FB27, 775  
CAN\_F9R2\_FB28, 775  
CAN\_F9R2\_FB29, 775  
CAN\_F9R2\_FB3, 775  
CAN\_F9R2\_FB30, 776  
CAN\_F9R2\_FB31, 776  
CAN\_F9R2\_FB4, 776  
CAN\_F9R2\_FB5, 776  
CAN\_F9R2\_FB6, 776  
CAN\_F9R2\_FB7, 776  
CAN\_F9R2\_FB8, 776  
CAN\_F9R2\_FB9, 776  
CAN\_FA1R\_FACT, 777  
CAN\_FA1R\_FACT0, 777  
CAN\_FA1R\_FACT1, 777  
CAN\_FA1R\_FACT10, 777  
CAN\_FA1R\_FACT11, 777  
CAN\_FA1R\_FACT12, 777  
CAN\_FA1R\_FACT13, 777  
CAN\_FA1R\_FACT2, 777  
CAN\_FA1R\_FACT3, 778  
CAN\_FA1R\_FACT4, 778  
CAN\_FA1R\_FACT5, 778  
CAN\_FA1R\_FACT6, 778  
CAN\_FA1R\_FACT7, 778  
CAN\_FA1R\_FACT8, 778  
CAN\_FA1R\_FACT9, 778  
CAN\_FFA1R\_FFA, 778  
CAN\_FFA1R\_FFA0, 779  
CAN\_FFA1R\_FFA1, 779  
CAN\_FFA1R\_FFA10, 779  
CAN\_FFA1R\_FFA11, 779  
CAN\_FFA1R\_FFA12, 779  
CAN\_FFA1R\_FFA13, 779  
CAN\_FFA1R\_FFA2, 779  
CAN\_FFA1R\_FFA3, 779  
CAN\_FFA1R\_FFA4, 780  
CAN\_FFA1R\_FFA5, 780  
CAN\_FFA1R\_FFA6, 780  
CAN\_FFA1R\_FFA7, 780  
CAN\_FFA1R\_FFA8, 780  
CAN\_FFA1R\_FFA9, 780  
CAN\_FM1R\_FBM, 780  
CAN\_FM1R\_FBM0, 780  
CAN\_FM1R\_FBM1, 781  
CAN\_FM1R\_FBM10, 781  
CAN\_FM1R\_FBM11, 781  
CAN\_FM1R\_FBM12, 781  
CAN\_FM1R\_FBM13, 781  
CAN\_FM1R\_FBM2, 781  
CAN\_FM1R\_FBM3, 781  
CAN\_FM1R\_FBM4, 781  
CAN\_FM1R\_FBM5, 782  
CAN\_FM1R\_FBM6, 782  
CAN\_FM1R\_FBM7, 782  
CAN\_FM1R\_FBM8, 782  
CAN\_FM1R\_FBM9, 782  
CAN\_FMR\_INIT, 782  
CAN\_FS1R\_FSC, 782  
CAN\_FS1R\_FSC0, 782  
CAN\_FS1R\_FSC1, 783  
CAN\_FS1R\_FSC10, 783  
CAN\_FS1R\_FSC11, 783  
CAN\_FS1R\_FSC12, 783  
CAN\_FS1R\_FSC13, 783  
CAN\_FS1R\_FSC2, 783  
CAN\_FS1R\_FSC3, 783  
CAN\_FS1R\_FSC4, 783  
CAN\_FS1R\_FSC5, 784  
CAN\_FS1R\_FSC6, 784

CAN\_FS1R\_FSC7, 784  
CAN\_FS1R\_FSC8, 784  
CAN\_FS1R\_FSC9, 784  
CAN\_IER\_BOFIE, 784  
CAN\_IER\_EPVIE, 784  
CAN\_IER\_ERRIE, 784  
CAN\_IER\_EWGIE, 785  
CAN\_IER\_FFIE0, 785  
CAN\_IER\_FFIE1, 785  
CAN\_IER\_FMPIE0, 785  
CAN\_IER\_FMPIE1, 785  
CAN\_IER\_FOVIE0, 785  
CAN\_IER\_FOVIE1, 785  
CAN\_IER\_LECIE, 785  
CAN\_IER\_SLKIE, 786  
CAN\_IER\_TMEIE, 786  
CAN\_IER\_WKUIE, 786  
CAN\_MCR\_ABOM, 786  
CAN\_MCR\_AWUM, 786  
CAN\_MCR\_INRQ, 786  
CAN\_MCR\_NART, 786  
CAN\_MCR\_RESET, 786  
CAN\_MCR\_RFLM, 787  
CAN\_MCR\_SLEEP, 787  
CAN\_MCR\_TTCM, 787  
CAN\_MCR\_TXFP, 787  
CAN\_MSR\_ERRI, 787  
CAN\_MSR\_INAK, 787  
CAN\_MSR\_RX, 787  
CAN\_MSR\_RXM, 787  
CAN\_MSR\_SAMP, 788  
CAN\_MSR\_SLAK, 788  
CAN\_MSR\_SLAKI, 788  
CAN\_MSR\_TXM, 788  
CAN\_MSR\_WKUI, 788  
CAN\_RDH0R\_DATA4, 788  
CAN\_RDH0R\_DATA5, 788  
CAN\_RDH0R\_DATA6, 788  
CAN\_RDH0R\_DATA7, 789  
CAN\_RDH1R\_DATA4, 789  
CAN\_RDH1R\_DATA5, 789  
CAN\_RDH1R\_DATA6, 789  
CAN\_RDH1R\_DATA7, 789  
CAN\_RDL0R\_DATA0, 789  
CAN\_RDL0R\_DATA1, 789  
CAN\_RDL0R\_DATA2, 789  
CAN\_RDL0R\_DATA3, 790  
CAN\_RDL1R\_DATA0, 790  
CAN\_RDL1R\_DATA1, 790  
CAN\_RDL1R\_DATA2, 790  
CAN\_RDL1R\_DATA3, 790  
CAN\_RDT0R\_DLC, 790  
CAN\_RDT0R\_FMI, 790  
CAN\_RDT0R\_TIME, 790  
CAN\_RDT1R\_DLC, 791  
CAN\_RDT1R\_FMI, 791  
CAN\_RDT1R\_TIME, 791  
CAN\_RF0R\_FMP0, 791  
CAN\_RF0R\_FOVR0, 791  
CAN\_RF0R\_FULL0, 791  
CAN\_RF0R\_RFOM0, 791  
CAN\_RF1R\_FMP1, 791  
CAN\_RF1R\_FOVR1, 792  
CAN\_RF1R\_FULL1, 792  
CAN\_RF1R\_RFOM1, 792  
CAN\_RI0R\_EXID, 792  
CAN\_RI0R\_IDE, 792  
CAN\_RI0R\_RTR, 792  
CAN\_RI0R\_STID, 792  
CAN\_RI1R\_EXID, 792  
CAN\_RI1R\_IDE, 793  
CAN\_RI1R\_RTR, 793  
CAN\_RI1R\_STID, 793  
CAN\_TDH0R\_DATA4, 793  
CAN\_TDH0R\_DATA5, 793  
CAN\_TDH0R\_DATA6, 793  
CAN\_TDH0R\_DATA7, 793  
CAN\_TDH1R\_DATA4, 793  
CAN\_TDH1R\_DATA5, 794  
CAN\_TDH1R\_DATA6, 794  
CAN\_TDH1R\_DATA7, 794  
CAN\_TDH2R\_DATA4, 794  
CAN\_TDH2R\_DATA5, 794  
CAN\_TDH2R\_DATA6, 794  
CAN\_TDH2R\_DATA7, 794  
CAN\_TDL0R\_DATA0, 794  
CAN\_TDL0R\_DATA1, 795  
CAN\_TDL0R\_DATA2, 795  
CAN\_TDL0R\_DATA3, 795  
CAN\_TDL1R\_DATA0, 795  
CAN\_TDL1R\_DATA1, 795  
CAN\_TDL1R\_DATA2, 795  
CAN\_TDL1R\_DATA3, 795  
CAN\_TDL2R\_DATA0, 795  
CAN\_TDL2R\_DATA1, 796  
CAN\_TDL2R\_DATA2, 796  
CAN\_TDL2R\_DATA3, 796  
CAN\_TDT0R\_DLC, 796  
CAN\_TDT0R\_TGT, 796  
CAN\_TDT0R\_TIME, 796  
CAN\_TDT1R\_DLC, 796  
CAN\_TDT1R\_TGT, 796  
CAN\_TDT1R\_TIME, 797  
CAN\_TDT2R\_DLC, 797  
CAN\_TDT2R\_TGT, 797  
CAN\_TDT2R\_TIME, 797  
CAN\_TI0R\_EXID, 797  
CAN\_TI0R\_IDE, 797  
CAN\_TI0R\_RTR, 797  
CAN\_TI0R\_STID, 797  
CAN\_TI0R\_TXRQ, 798  
CAN\_TI1R\_EXID, 798  
CAN\_TI1R\_IDE, 798  
CAN\_TI1R\_RTR, 798  
CAN\_TI1R\_STID, 798  
CAN\_TI1R\_TXRQ, 798

CAN\_TI2R\_EXID, 798  
CAN\_TI2R\_IDE, 798  
CAN\_TI2R\_RTR, 799  
CAN\_TI2R\_STID, 799  
CAN\_TI2R\_TXRQ, 799  
CAN\_TSR\_ABRQ0, 799  
CAN\_TSR\_ABRQ1, 799  
CAN\_TSR\_ABRQ2, 799  
CAN\_TSR\_ALST0, 799  
CAN\_TSR\_ALST1, 799  
CAN\_TSR\_ALST2, 800  
CAN\_TSR\_CODE, 800  
CAN\_TSR\_LOW, 800  
CAN\_TSR\_LOW0, 800  
CAN\_TSR\_LOW1, 800  
CAN\_TSR\_LOW2, 800  
CAN\_TSR\_RQCP0, 800  
CAN\_TSR\_RQCP1, 800  
CAN\_TSR\_RQCP2, 801  
CAN\_TSR\_TERR0, 801  
CAN\_TSR\_TERR1, 801  
CAN\_TSR\_TERR2, 801  
CAN\_TSR\_TME, 801  
CAN\_TSR\_TME0, 801  
CAN\_TSR\_TME1, 801  
CAN\_TSR\_TME2, 801  
CAN\_TSR\_TXOK0, 802  
CAN\_TSR\_TXOK1, 802  
CAN\_TSR\_TXOK2, 802  
CRC\_CR\_RESET, 802  
CRC\_DR\_DR, 802  
CRC\_IDR\_IDR, 802  
DAC\_CR\_BOFF1, 802  
DAC\_CR\_BOFF2, 802  
DAC\_CR\_DMAEN1, 803  
DAC\_CR\_DMAEN2, 803  
DAC\_CR\_DMAUDRIE1, 803  
DAC\_CR\_DMAUDRIE2, 803  
DAC\_CR\_EN1, 803  
DAC\_CR\_EN2, 803  
DAC\_CR\_MAMP1, 803  
DAC\_CR\_MAMP1\_0, 803  
DAC\_CR\_MAMP1\_1, 804  
DAC\_CR\_MAMP1\_2, 804  
DAC\_CR\_MAMP1\_3, 804  
DAC\_CR\_MAMP2, 804  
DAC\_CR\_MAMP2\_0, 804  
DAC\_CR\_MAMP2\_1, 804  
DAC\_CR\_MAMP2\_2, 804  
DAC\_CR\_MAMP2\_3, 804  
DAC\_CR\_TEN1, 805  
DAC\_CR\_TEN2, 805  
DAC\_CR\_TSEL1, 805  
DAC\_CR\_TSEL1\_0, 805  
DAC\_CR\_TSEL1\_1, 805  
DAC\_CR\_TSEL1\_2, 805  
DAC\_CR\_TSEL2, 805  
DAC\_CR\_TSEL2\_0, 805  
DAC\_CR\_TSEL2\_1, 806  
DAC\_CR\_TSEL2\_2, 806  
DAC\_CR\_WAVE1, 806  
DAC\_CR\_WAVE1\_0, 806  
DAC\_CR\_WAVE1\_1, 806  
DAC\_CR\_WAVE2, 806  
DAC\_CR\_WAVE2\_0, 806  
DAC\_CR\_WAVE2\_1, 806  
DAC\_DHR12L1\_DACC1DHR, 807  
DAC\_DHR12L2\_DACC2DHR, 807  
DAC\_DHR12LD\_DACC1DHR, 807  
DAC\_DHR12LD\_DACC2DHR, 807  
DAC\_DHR12R1\_DACC1DHR, 807  
DAC\_DHR12R2\_DACC2DHR, 807  
DAC\_DHR12RD\_DACC1DHR, 807  
DAC\_DHR12RD\_DACC2DHR, 807  
DAC\_DHR8R1\_DACC1DHR, 808  
DAC\_DHR8R2\_DACC2DHR, 808  
DAC\_DHR8RD\_DACC1DHR, 808  
DAC\_DHR8RD\_DACC2DHR, 808  
DAC\_DOR1\_DACC1DOR, 808  
DAC\_DOR2\_DACC2DOR, 808  
DAC\_SR\_DMAUDR1, 808  
DAC\_SR\_DMAUDR2, 808  
DAC\_SWTRIGR\_SWTRIG1, 809  
DAC\_SWTRIGR\_SWTRIG2, 809  
DBGMCU\_CR\_TRACE\_MODE\_0, 809  
DBGMCU\_CR\_TRACE\_MODE\_1, 809  
DFSDM\_CHAWSCDR\_AWFORD, 809  
DFSDM\_CHAWSCDR\_AWFORD\_0, 809  
DFSDM\_CHAWSCDR\_AWFORD\_1, 809  
DFSDM\_CHAWSCDR\_AWFOSR, 809  
DFSDM\_CHAWSCDR\_BKSCD, 810  
DFSDM\_CHAWSCDR\_SCDT, 810  
DFSDM\_CHCFGR1\_CHEN, 810  
DFSDM\_CHCFGR1\_CHINSEL, 810  
DFSDM\_CHCFGR1\_CKABEN, 810  
DFSDM\_CHCFGR1\_CKOUTDIV, 810  
DFSDM\_CHCFGR1\_CKOUTSRC, 810  
DFSDM\_CHCFGR1\_DATMPX, 810  
DFSDM\_CHCFGR1\_DATMPX\_0, 811  
DFSDM\_CHCFGR1\_DATMPX\_1, 811  
DFSDM\_CHCFGR1\_DATPACK, 811  
DFSDM\_CHCFGR1\_DATPACK\_0, 811  
DFSDM\_CHCFGR1\_DATPACK\_1, 811  
DFSDM\_CHCFGR1\_DFSDMEN, 811  
DFSDM\_CHCFGR1\_SCDEN, 811  
DFSDM\_CHCFGR1\_SITP, 811  
DFSDM\_CHCFGR1\_SITP\_0, 812  
DFSDM\_CHCFGR1\_SITP\_1, 812  
DFSDM\_CHCFGR1\_SPICKSEL, 812  
DFSDM\_CHCFGR1\_SPICKSEL\_0, 812  
DFSDM\_CHCFGR1\_SPICKSEL\_1, 812  
DFSDM\_CHCFGR2\_DTRBS, 812  
DFSDM\_CHCFGR2\_OFFSET, 812  
DFSDM\_CHDATINR\_INDAT0, 812  
DFSDM\_CHDATINR\_INDAT1, 813  
DFSDM\_CHWDATR\_WDATA, 813

DFSDM\_FLTAWCFR\_CLRAWHTF, 813  
DFSDM\_FLTAWCFR\_CLRAWLTF, 813  
DFSDM\_FLTAWHTR\_AWHT, 813  
DFSDM\_FLTAWHTR\_BKAWH, 813  
DFSDM\_FLTAWLTR\_AWLT, 813  
DFSDM\_FLTAWLTR\_BKAWL, 813  
DFSDM\_FLTAWSR\_AWHTF, 814  
DFSDM\_FLTAWSR\_AWLTF, 814  
DFSDM\_FLTCNVTIMR\_CNV\_CNT, 814  
DFSDM\_FLTCR1\_AWFSEL, 814  
DFSDM\_FLTCR1\_DFEN, 814  
DFSDM\_FLTCR1\_FAST, 814  
DFSDM\_FLTCR1\_JDMAEN, 814  
DFSDM\_FLTCR1\_JEXTEN, 814  
DFSDM\_FLTCR1\_JEXTEN\_0, 815  
DFSDM\_FLTCR1\_JEXTEN\_1, 815  
DFSDM\_FLTCR1\_JEXTSEL, 815  
DFSDM\_FLTCR1\_JEXTSEL\_0, 815  
DFSDM\_FLTCR1\_JEXTSEL\_1, 815  
DFSDM\_FLTCR1\_JEXTSEL\_2, 815  
DFSDM\_FLTCR1\_JSCAN, 815  
DFSDM\_FLTCR1\_JSWSTART, 815  
DFSDM\_FLTCR1\_JSYNC, 816  
DFSDM\_FLTCR1\_RCH, 816  
DFSDM\_FLTCR1\_RCONT, 816  
DFSDM\_FLTCR1\_RDMAEN, 816  
DFSDM\_FLTCR1\_RSWSTART, 816  
DFSDM\_FLTCR1\_RSYNC, 816  
DFSDM\_FLTCR2\_AWDCH, 816  
DFSDM\_FLTCR2\_AWDIE, 817  
DFSDM\_FLTCR2\_CKABIE, 817  
DFSDM\_FLTCR2\_EXCH, 817  
DFSDM\_FLTCR2\_JEOCIE, 817  
DFSDM\_FLTCR2\_JOVRIE, 817  
DFSDM\_FLTCR2\_REOCIE, 817  
DFSDM\_FLTCR2\_ROVRIE, 817  
DFSDM\_FLTCR2\_SCDIE, 817  
DFSDM\_FLTEXMAX\_EXMAX, 818  
DFSDM\_FLTEXMAX\_EXMAXCH, 818  
DFSDM\_FLTEXMIN\_EXMIN, 818  
DFSDM\_FLTEXMIN\_EXMINCH, 818  
DFSDM\_FLTFCR\_FORD, 818  
DFSDM\_FLTFCR\_FORD\_0, 818  
DFSDM\_FLTFCR\_FORD\_1, 818  
DFSDM\_FLTFCR\_FORD\_2, 818  
DFSDM\_FLTFCR\_FOSR, 819  
DFSDM\_FLTFCR\_IOSR, 819  
DFSDM\_FLTICR\_CLRCKABF, 819  
DFSDM\_FLTICR\_CLRJOVRF, 819  
DFSDM\_FLTICR\_CLRROVRF, 819  
DFSDM\_FLTICR\_CLRSCSDF, 819  
DFSDM\_FLTISR\_AWDF, 819  
DFSDM\_FLTISR\_CKABF, 819  
DFSDM\_FLTISR\_JCIP, 820  
DFSDM\_FLTISR\_JEOCF, 820  
DFSDM\_FLTISR\_JOVRF, 820  
DFSDM\_FLTISR\_RCIP, 820  
DFSDM\_FLTISR\_ReOcf, 820  
DFSDM\_FLTISR\_ROVRF, 820  
DFSDM\_FLTISR\_SCDF, 820  
DFSDM\_FLTJCHGR\_JCHG, 820  
DFSDM\_FLTJDATAR\_JDATA, 821  
DFSDM\_FLTJDATAR\_JDATACH, 821  
DFSDM\_FLTRDATAR\_RDATA, 821  
DFSDM\_FLTRDATAR\_RDATAL, 821  
DFSDM\_FLTRDATAR\_RPEND, 821  
DMA2D\_AMTCR\_DT, 821  
DMA2D\_AMTCR\_EN, 821  
DMA2D\_BGCMAR\_MA, 821  
DMA2D\_BGCCRL\_BLUE, 822  
DMA2D\_BGCCRL\_GREEN, 822  
DMA2D\_BGCCRL\_RED, 822  
DMA2D\_BGMAR\_MA, 822  
DMA2D\_BGOR\_LO, 822  
DMA2D\_BGPCCR\_ALPHA, 822  
DMA2D\_BGPCCR\_AM, 822  
DMA2D\_BGPCCR\_AM\_0, 822  
DMA2D\_BGPCCR\_AM\_1, 823  
DMA2D\_BGPCCR\_CCM, 823  
DMA2D\_BGPCCR\_CM, 823  
DMA2D\_BGPCCR\_CM\_0, 823  
DMA2D\_BGPCCR\_CM\_1, 823  
DMA2D\_BGPCCR\_CM\_2, 823  
DMA2D\_BGPCCR\_CS, 823  
DMA2D\_BGPCCR\_START, 823  
DMA2D\_CR\_ABORT, 824  
DMA2D\_CR\_CAEIE, 824  
DMA2D\_CR\_CEIE, 824  
DMA2D\_CR\_CTCIE, 824  
DMA2D\_CR\_MODE, 824  
DMA2D\_CR\_START, 824  
DMA2D\_CR\_SUSP, 824  
DMA2D\_CR\_TCIE, 824  
DMA2D\_CR\_TEIE, 825  
DMA2D\_CR\_TWIE, 825  
DMA2D\_FGCMAR\_MA, 825  
DMA2D\_FGCCRL\_BLUE, 825  
DMA2D\_FGCCRL\_GREEN, 825  
DMA2D\_FGCCRL\_RED, 825  
DMA2D\_FGMAR\_MA, 825  
DMA2D\_FGOR\_LO, 825  
DMA2D\_FGPCCR\_ALPHA, 826  
DMA2D\_FGPCCR\_AM, 826  
DMA2D\_FGPCCR\_AM\_0, 826  
DMA2D\_FGPCCR\_AM\_1, 826  
DMA2D\_FGPCCR\_CCM, 826  
DMA2D\_FGPCCR\_CM, 826  
DMA2D\_FGPCCR\_CM\_0, 826  
DMA2D\_FGPCCR\_CM\_1, 826  
DMA2D\_FGPCCR\_CM\_2, 827  
DMA2D\_FGPCCR\_CM\_3, 827  
DMA2D\_FGPCCR\_CS, 827  
DMA2D\_FGPCCR\_START, 827  
DMA2D\_IFCR\_CAEIF, 827  
DMA2D\_IFCR\_CCEIF, 827  
DMA2D\_IFCR\_CCTCIF, 828

DMA2D\_IFCR\_CTCIF, 828  
DMA2D\_IFCR\_CTEIF, 828  
DMA2D\_IFCR\_CTWIF, 828  
DMA2D\_IFSR\_CCAEIF, 828  
DMA2D\_IFSR\_CCEIF, 828  
DMA2D\_IFSR\_CCTCIF, 828  
DMA2D\_IFSR\_CTCIF, 829  
DMA2D\_IFSR\_CTEIF, 829  
DMA2D\_IFSR\_CTWIF, 829  
DMA2D\_ISR\_CAEIF, 829  
DMA2D\_ISR\_CEIF, 829  
DMA2D\_ISR\_CTCIF, 829  
DMA2D\_ISR\_TCIF, 829  
DMA2D\_ISR\_TEIF, 830  
DMA2D\_ISR\_TWIF, 830  
DMA2D\_LWR\_LW, 830  
DMA2D\_NLR\_NL, 830  
DMA2D\_NLR\_PL, 830  
DMA2D\_OCOLR\_ALPHA\_1, 830  
DMA2D\_OCOLR\_ALPHA\_3, 830  
DMA2D\_OCOLR\_ALPHA\_4, 830  
DMA2D\_OCOLR\_BLUE\_1, 831  
DMA2D\_OCOLR\_BLUE\_2, 831  
DMA2D\_OCOLR\_BLUE\_3, 831  
DMA2D\_OCOLR\_BLUE\_4, 831  
DMA2D\_OCOLR\_GREEN\_1, 831  
DMA2D\_OCOLR\_GREEN\_2, 831  
DMA2D\_OCOLR\_GREEN\_3, 831  
DMA2D\_OCOLR\_GREEN\_4, 832  
DMA2D\_OCOLR\_RED\_1, 832  
DMA2D\_OCOLR\_RED\_2, 832  
DMA2D\_OCOLR\_RED\_3, 832  
DMA2D\_OCOLR\_RED\_4, 832  
DMA2D\_OMAR\_MA, 832  
DMA2D\_OOR\_LO, 832  
DMA2D\_OPFCCR\_CM, 833  
DMA2D\_OPFCCR\_CM\_0, 833  
DMA2D\_OPFCCR\_CM\_1, 833  
DMA2D\_OPFCCR\_CM\_2, 833  
ETH\_MACCR\_BL, 833  
EXTI\_EMR\_MR0, 833  
EXTI\_EMR\_MR1, 833  
EXTI\_EMR\_MR10, 834  
EXTI\_EMR\_MR11, 834  
EXTI\_EMR\_MR12, 834  
EXTI\_EMR\_MR13, 834  
EXTI\_EMR\_MR14, 834  
EXTI\_EMR\_MR15, 834  
EXTI\_EMR\_MR16, 834  
EXTI\_EMR\_MR17, 834  
EXTI\_EMR\_MR18, 835  
EXTI\_EMR\_MR19, 835  
EXTI\_EMR\_MR2, 835  
EXTI\_EMR\_MR23, 835  
EXTI\_EMR\_MR3, 835  
EXTI\_EMR\_MR4, 835  
EXTI\_EMR\_MR5, 835  
EXTI\_EMR\_MR6, 835  
EXTI\_EMR\_MR7, 836  
EXTI\_EMR\_MR8, 836  
EXTI\_EMR\_MR9, 836  
EXTI\_FTSR\_TR0, 836  
EXTI\_FTSR\_TR1, 836  
EXTI\_FTSR\_TR10, 836  
EXTI\_FTSR\_TR11, 836  
EXTI\_FTSR\_TR12, 836  
EXTI\_FTSR\_TR13, 837  
EXTI\_FTSR\_TR14, 837  
EXTI\_FTSR\_TR15, 837  
EXTI\_FTSR\_TR16, 837  
EXTI\_FTSR\_TR17, 837  
EXTI\_FTSR\_TR18, 837  
EXTI\_FTSR\_TR19, 837  
EXTI\_FTSR\_TR2, 837  
EXTI\_FTSR\_TR23, 838  
EXTI\_FTSR\_TR3, 838  
EXTI\_FTSR\_TR4, 838  
EXTI\_FTSR\_TR5, 838  
EXTI\_FTSR\_TR6, 838  
EXTI\_FTSR\_TR7, 838  
EXTI\_FTSR\_TR8, 838  
EXTI\_FTSR\_TR9, 838  
EXTI\_IMR\_MR0, 839  
EXTI\_IMR\_MR1, 839  
EXTI\_IMR\_MR10, 839  
EXTI\_IMR\_MR11, 839  
EXTI\_IMR\_MR12, 839  
EXTI\_IMR\_MR13, 839  
EXTI\_IMR\_MR14, 839  
EXTI\_IMR\_MR15, 839  
EXTI\_IMR\_MR16, 840  
EXTI\_IMR\_MR17, 840  
EXTI\_IMR\_MR18, 840  
EXTI\_IMR\_MR19, 840  
EXTI\_IMR\_MR2, 840  
EXTI\_IMR\_MR23, 840  
EXTI\_IMR\_MR3, 840  
EXTI\_IMR\_MR4, 840  
EXTI\_IMR\_MR5, 841  
EXTI\_IMR\_MR6, 841  
EXTI\_IMR\_MR7, 841  
EXTI\_IMR\_MR8, 841  
EXTI\_IMR\_MR9, 841  
EXTI\_PR\_PR0, 841  
EXTI\_PR\_PR1, 841  
EXTI\_PR\_PR10, 841  
EXTI\_PR\_PR11, 842  
EXTI\_PR\_PR12, 842  
EXTI\_PR\_PR13, 842  
EXTI\_PR\_PR14, 842  
EXTI\_PR\_PR15, 842  
EXTI\_PR\_PR16, 842  
EXTI\_PR\_PR17, 842  
EXTI\_PR\_PR18, 842  
EXTI\_PR\_PR19, 843  
EXTI\_PR\_PR2, 843

EXTI\_PR\_PR23, 843  
EXTI\_PR\_PR3, 843  
EXTI\_PR\_PR4, 843  
EXTI\_PR\_PR5, 843  
EXTI\_PR\_PR6, 843  
EXTI\_PR\_PR7, 843  
EXTI\_PR\_PR8, 844  
EXTI\_PR\_PR9, 844  
EXTI\_RTSR\_TR0, 844  
EXTI\_RTSR\_TR1, 844  
EXTI\_RTSR\_TR10, 844  
EXTI\_RTSR\_TR11, 844  
EXTI\_RTSR\_TR12, 844  
EXTI\_RTSR\_TR13, 844  
EXTI\_RTSR\_TR14, 845  
EXTI\_RTSR\_TR15, 845  
EXTI\_RTSR\_TR16, 845  
EXTI\_RTSR\_TR17, 845  
EXTI\_RTSR\_TR18, 845  
EXTI\_RTSR\_TR19, 845  
EXTI\_RTSR\_TR2, 845  
EXTI\_RTSR\_TR23, 845  
EXTI\_RTSR\_TR3, 846  
EXTI\_RTSR\_TR4, 846  
EXTI\_RTSR\_TR5, 846  
EXTI\_RTSR\_TR6, 846  
EXTI\_RTSR\_TR7, 846  
EXTI\_RTSR\_TR8, 846  
EXTI\_RTSR\_TR9, 846  
EXTI\_SWIER\_SWIER0, 846  
EXTI\_SWIER\_SWIER1, 847  
EXTI\_SWIER\_SWIER10, 847  
EXTI\_SWIER\_SWIER11, 847  
EXTI\_SWIER\_SWIER12, 847  
EXTI\_SWIER\_SWIER13, 847  
EXTI\_SWIER\_SWIER14, 847  
EXTI\_SWIER\_SWIER15, 847  
EXTI\_SWIER\_SWIER16, 847  
EXTI\_SWIER\_SWIER17, 848  
EXTI\_SWIER\_SWIER18, 848  
EXTI\_SWIER\_SWIER19, 848  
EXTI\_SWIER\_SWIER2, 848  
EXTI\_SWIER\_SWIER23, 848  
EXTI\_SWIER\_SWIER3, 848  
EXTI\_SWIER\_SWIER4, 848  
EXTI\_SWIER\_SWIER5, 848  
EXTI\_SWIER\_SWIER6, 849  
EXTI\_SWIER\_SWIER7, 849  
EXTI\_SWIER\_SWIER8, 849  
EXTI\_SWIER\_SWIER9, 849  
I2C\_CCR\_CCR, 849  
I2C\_CCR\_DUTY, 849  
I2C\_CCR\_FS, 849  
I2C\_CR1\_ACK, 850  
I2C\_CR1\_ALERT, 850  
I2C\_CR1\_ENARP, 850  
I2C\_CR1\_ENGC, 850  
I2C\_CR1\_ENPEC, 850  
I2C\_CR1\_NOSTRETCH, 850  
I2C\_CR1\_PE, 850  
I2C\_CR1\_PEC, 851  
I2C\_CR1\_POS, 851  
I2C\_CR1\_SMBTYPE, 851  
I2C\_CR1\_SMBUS, 851  
I2C\_CR1\_START, 851  
I2C\_CR1\_STOP, 851  
I2C\_CR1\_SWRST, 851  
I2C\_CR2\_DMAEN, 852  
I2C\_CR2\_FREQ, 852  
I2C\_CR2\_FREQ\_0, 852  
I2C\_CR2\_FREQ\_1, 852  
I2C\_CR2\_FREQ\_2, 852  
I2C\_CR2\_FREQ\_3, 852  
I2C\_CR2\_FREQ\_4, 852  
I2C\_CR2\_FREQ\_5, 853  
I2C\_CR2\_ITBUFEN, 853  
I2C\_CR2\_ITERREN, 853  
I2C\_CR2\_IYTEVTEN, 853  
I2C\_CR2\_LAST, 853  
I2C\_DR\_DR, 853  
I2C\_FLTR\_ANOFF, 853  
I2C\_FLTR\_DNF, 854  
I2C\_OAR1\_ADD0, 854  
I2C\_OAR1\_ADD1, 854  
I2C\_OAR1\_ADD1\_7, 854  
I2C\_OAR1\_ADD2, 854  
I2C\_OAR1\_ADD3, 854  
I2C\_OAR1\_ADD4, 854  
I2C\_OAR1\_ADD5, 854  
I2C\_OAR1\_ADD6, 855  
I2C\_OAR1\_ADD7, 855  
I2C\_OAR1\_ADD8, 855  
I2C\_OAR1\_ADD8\_9, 855  
I2C\_OAR1\_ADD9, 855  
I2C\_OAR1\_ADDMODE, 855  
I2C\_OAR2\_ADD2, 855  
I2C\_OAR2\_ENDUAL, 855  
I2C\_SR1\_ADD10, 856  
I2C\_SR1\_ADDR, 856  
I2C\_SR1\_AF, 856  
I2C\_SR1\_ARLO, 856  
I2C\_SR1\_BERR, 856  
I2C\_SR1\_BTF, 856  
I2C\_SR1\_OVR, 856  
I2C\_SR1\_PECERR, 857  
I2C\_SR1\_RXNE, 857  
I2C\_SR1\_SB, 857  
I2C\_SR1\_SMBALERT, 857  
I2C\_SR1\_STOPF, 857  
I2C\_SR1\_TIMEOUT, 857  
I2C\_SR1\_TXE, 857  
I2C\_SR2\_BUSY, 858  
I2C\_SR2\_DUALF, 858  
I2C\_SR2\_GENCALL, 858  
I2C\_SR2\_MSL, 858  
I2C\_SR2\_PEC, 858

I2C\_SR2\_SMBDEFAULT, 858  
I2C\_SR2\_SMBHOST, 858  
I2C\_SR2\_TRA, 859  
I2C\_TRISE\_TRISE, 859  
IWDG\_KR\_KEY, 859  
IWDG\_PR\_PR, 859  
IWDG\_PR\_PR\_0, 859  
IWDG\_PR\_PR\_1, 859  
IWDG\_PR\_PR\_2, 859  
IWDG\_RLR\_RL, 860  
IWDG\_SR\_PVU, 860  
IWDG\_SR\_RVU, 860  
LTDC\_AWCR\_AAH, 860  
LTDC\_AWCR\_AAW, 860  
LTDC\_BCCR\_BCBLUE, 860  
LTDC\_BCCR\_BCGREEN, 860  
LTDC\_BCCR\_BCRED, 861  
LTDC\_BPCR\_AHBP, 861  
LTDC\_BPCR\_AVBP, 861  
LTDC\_CDSR\_HDES, 861  
LTDC\_CDSR\_HSYNCS, 861  
LTDC\_CDSR\_VDES, 861  
LTDC\_CDSR\_VSYNCS, 861  
LTDC\_CPSR\_CXPOS, 861  
LTDC\_CPSR\_CYPOS, 862  
LTDC\_GCR\_DBW, 862  
LTDC\_GCR\_DEN, 862  
LTDC\_GCR\_DEPOL, 862  
LTDC\_GCR\_DGW, 862  
LTDC\_GCR\_DRW, 862  
LTDC\_GCR\_HSPOL, 862  
LTDC\_GCR\_LTDCEN, 862  
LTDC\_GCR\_PCPOL, 863  
LTDC\_GCR\_VSPOL, 863  
LTDC\_ICR\_CFUIF, 863  
LTDC\_ICR\_CLIF, 863  
LTDC\_ICR\_CRRIF, 863  
LTDC\_ICR\_CTERRIF, 863  
LTDC\_IER\_FUIE, 863  
LTDC\_IER\_LIE, 863  
LTDC\_IER\_RRIE, 864  
LTDC\_IER\_TERRIE, 864  
LTDC\_ISR\_FUIF, 864  
LTDC\_ISR\_LIF, 864  
LTDC\_ISR\_RRIF, 864  
LTDC\_ISR\_TERRIF, 864  
LTDC\_LIPCR\_LIPOS, 864  
LTDC\_LxBFCR\_BF1, 864  
LTDC\_LxBFCR\_BF2, 865  
LTDC\_LxCACR\_CONSTA, 865  
LTDC\_LxCFBAR\_CFBADD, 865  
LTDC\_LxCFBLNR\_CFBLNBR, 865  
LTDC\_LxCFBLR\_CFBLL, 865  
LTDC\_LxCFBLR\_CFBP, 865  
LTDC\_LxCKCR\_CKBLUE, 865  
LTDC\_LxCKCR\_CKGREEN, 865  
LTDC\_LxCKCR\_CKRED, 866  
LTDC\_LxCLUTWR\_BLUE, 866  
LTDC\_LxCLUTWR\_CLUTADD, 866  
LTDC\_LxCLUTWR\_GREEN, 866  
LTDC\_LxCLUTWR\_RED, 866  
LTDC\_LxCR\_CLUTEN, 866  
LTDC\_LxCR\_COLKEN, 866  
LTDC\_LxCR\_LEN, 866  
LTDC\_LxDCCR\_DCALPHA, 867  
LTDC\_LxDCCR\_DCBLUE, 867  
LTDC\_LxDCCR\_DCGREEN, 867  
LTDC\_LxDCCR\_DCRED, 867  
LTDC\_LxFPCR\_PF, 867  
LTDC\_LxWHPCR\_WHSPPOS, 867  
LTDC\_LxWHPCR\_WHSTPOS, 867  
LTDC\_LxWVPCR\_WVSPPPOS, 867  
LTDC\_LxWVPCR\_WVSTPOS, 868  
LTDC\_SRCR\_IMR, 868  
LTDC\_SRCR\_VBR, 868  
LTDC\_SSCR\_HSW, 868  
LTDC\_SSCR\_VSH, 868  
LTDC\_TWCR\_TOTALH, 868  
LTDC\_TWCR\_TOTALW, 868  
PWR\_CR\_ADCDC1, 868  
PWR\_CR\_CSBF, 869  
PWR\_CR\_CWUF, 869  
PWR\_CR\_DBP, 869  
PWR\_CR\_FISSR, 869  
PWR\_CR\_FMSSR, 869  
PWR\_CR\_FPPDS, 869  
PWR\_CR\_LPDS, 869  
PWR\_CR\_LPLVDS, 870  
PWR\_CR\_LPUDS, 870  
PWR\_CR\_MRLVDS, 870  
PWR\_CR\_MRUDS, 870  
PWR\_CR\_ODEN, 870  
PWR\_CR\_ODSWEN, 870  
PWR\_CR\_PDDS, 870  
PWR\_CR\_PLS, 871  
PWR\_CR\_PLS\_0, 871  
PWR\_CR\_PLS\_1, 871  
PWR\_CR\_PLS\_2, 871  
PWR\_CR\_PLSLEV0, 871  
PWR\_CR\_PLSLEV1, 871  
PWR\_CR\_PLSLEV2, 871  
PWR\_CR\_PLSLEV3, 872  
PWR\_CR\_PLSLEV4, 872  
PWR\_CR\_PLSLEV5, 872  
PWR\_CR\_PLSLEV6, 872  
PWR\_CR\_PLSLEV7, 872  
PWR\_CR\_PVDE, 872  
PWR\_CR\_UDEN, 872  
PWR\_CR\_UDEN\_0, 873  
PWR\_CR\_UDEN\_1, 873  
PWR\_CR\_VOS, 873  
PWR\_CR\_VOS\_0, 873  
PWR\_CR\_VOS\_1, 873  
PWR\_CSR\_BRE, 873  
PWR\_CSR\_BRR, 873  
PWR\_CSR\_EWUP, 874

PWR\_CSR\_ODRDY, 874  
PWR\_CSR\_ODSWRDY, 874  
PWR\_CSR\_PVDO, 874  
PWR\_CSR\_SBF, 874  
PWR\_CSR\_UDSWRDY, 874  
PWR\_CSR\_VOSRDY, 874  
PWR\_CSR\_WUF, 875  
PWR\_CSR\_WUPP, 875  
RCC\_CFGR\_HPRE, 875  
RCC\_CFGR\_HPRE\_0, 875  
RCC\_CFGR\_HPRE\_1, 875  
RCC\_CFGR\_HPRE\_2, 875  
RCC\_CFGR\_HPRE\_3, 875  
RCC\_CFGR\_HPRE\_DIV1, 876  
RCC\_CFGR\_HPRE\_DIV128, 876  
RCC\_CFGR\_HPRE\_DIV16, 876  
RCC\_CFGR\_HPRE\_DIV2, 876  
RCC\_CFGR\_HPRE\_DIV256, 876  
RCC\_CFGR\_HPRE\_DIV4, 876  
RCC\_CFGR\_HPRE\_DIV512, 876  
RCC\_CFGR\_HPRE\_DIV64, 876  
RCC\_CFGR\_HPRE\_DIV8, 877  
RCC\_CFGR\_PPREG1, 877  
RCC\_CFGR\_PPREG1\_0, 877  
RCC\_CFGR\_PPREG1\_1, 877  
RCC\_CFGR\_PPREG1\_2, 877  
RCC\_CFGR\_PPREG1\_DIV1, 877  
RCC\_CFGR\_PPREG1\_DIV16, 877  
RCC\_CFGR\_PPREG1\_DIV2, 877  
RCC\_CFGR\_PPREG1\_DIV4, 878  
RCC\_CFGR\_PPREG1\_DIV8, 878  
RCC\_CFGR\_PPREG2, 878  
RCC\_CFGR\_PPREG2\_0, 878  
RCC\_CFGR\_PPREG2\_1, 878  
RCC\_CFGR\_PPREG2\_2, 878  
RCC\_CFGR\_PPREG2\_DIV1, 878  
RCC\_CFGR\_PPREG2\_DIV16, 878  
RCC\_CFGR\_PPREG2\_DIV2, 879  
RCC\_CFGR\_PPREG2\_DIV4, 879  
RCC\_CFGR\_PPREG2\_DIV8, 879  
RCC\_CFGR\_RTCPPREG\_4, 879  
RCC\_CFGR\_SW, 879  
RCC\_CFGR\_SW\_0, 879  
RCC\_CFGR\_SW\_1, 879  
RCC\_CFGR\_SW\_HSE, 879  
RCC\_CFGR\_SW\_HSI, 880  
RCC\_CFGR\_SW\_PLL, 880  
RCC\_CFGR\_SWS, 880  
RCC\_CFGR\_SWS\_0, 880  
RCC\_CFGR\_SWS\_1, 880  
RCC\_CFGR\_SWS\_HSE, 880  
RCC\_CFGR\_SWS\_HSI, 880  
RCC\_CFGR\_SWS\_PLL, 880  
RCC\_CR\_HSICAL\_0, 881  
RCC\_CR\_HSICAL\_1, 881  
RCC\_CR\_HSICAL\_2, 881  
RCC\_CR\_HSICAL\_3, 881  
RCC\_CR\_HSICAL\_4, 881  
RCC\_CR\_HSICAL\_5, 881  
RCC\_CR\_HSICAL\_6, 881  
RCC\_CR\_HSICAL\_7, 882  
RCC\_CR\_HSITRIM\_0, 882  
RCC\_CR\_HSITRIM\_1, 882  
RCC\_CR\_HSITRIM\_2, 882  
RCC\_CR\_HSITRIM\_3, 882  
RCC\_CR\_HSITRIM\_4, 882  
SAI\_GCR\_SYNCIN, 882  
SAI\_GCR\_SYNCIN\_0, 882  
SAI\_GCR\_SYNCIN\_1, 883  
SAI\_GCR\_SYNCOUT, 883  
SAI\_GCR\_SYNCOUT\_0, 883  
SAI\_GCR\_SYNCOUT\_1, 883  
SAI\_xCLRFR\_CAFSDET, 883  
SAI\_xCLRFR\_CCNRDY, 883  
SAI\_xCLRFR\_CFREQ, 883  
SAI\_xCLRFR\_CLFSDET, 884  
SAI\_xCLRFR\_CMUTEDDET, 884  
SAI\_xCLRFR\_COVRUDR, 884  
SAI\_xCLRFR\_CWCKCFG, 884  
SAI\_xCR1\_CKSTR, 884  
SAI\_xCR1\_DMAEN, 884  
SAI\_xCR1\_DS, 884  
SAI\_xCR1\_DS\_0, 885  
SAI\_xCR1\_DS\_1, 885  
SAI\_xCR1\_DS\_2, 885  
SAI\_xCR1\_LSBFIRST, 885  
SAI\_xCR1\_MCKDIV, 885  
SAI\_xCR1\_MCKDIV\_0, 885  
SAI\_xCR1\_MCKDIV\_1, 885  
SAI\_xCR1\_MCKDIV\_2, 886  
SAI\_xCR1\_MCKDIV\_3, 886  
SAI\_xCR1\_MODE, 886  
SAI\_xCR1\_MODE\_0, 886  
SAI\_xCR1\_MODE\_1, 886  
SAI\_xCR1\_MONO, 886  
SAI\_xCR1\_NODIV, 886  
SAI\_xCR1\_OUTDRIV, 887  
SAI\_xCR1\_PRTCFG, 887  
SAI\_xCR1\_PRTCFG\_0, 887  
SAI\_xCR1\_PRTCFG\_1, 887  
SAI\_xCR1\_SAIEN, 887  
SAI\_xCR1\_SYNCEN, 887  
SAI\_xCR1\_SYNCEN\_0, 887  
SAI\_xCR1\_SYNCEN\_1, 888  
SAI\_xCR2\_COMP, 888  
SAI\_xCR2\_COMP\_0, 888  
SAI\_xCR2\_COMP\_1, 888  
SAI\_xCR2\_CPL, 888  
SAI\_xCR2\_FFLUSH, 888  
SAI\_xCR2\_FTH, 888  
SAI\_xCR2\_FTH\_0, 889  
SAI\_xCR2\_FTH\_1, 889  
SAI\_xCR2\_MUTE, 889  
SAI\_xCR2\_MUTECNT, 889  
SAI\_xCR2\_MUTECNT\_0, 889  
SAI\_xCR2\_MUTECNT\_1, 889

SAI\_xCR2\_MUTECNT\_2, 889  
 SAI\_xCR2\_MUTECNT\_3, 890  
 SAI\_xCR2\_MUTECNT\_4, 890  
 SAI\_xCR2\_MUTECNT\_5, 890  
 SAI\_xCR2\_MUTEVAL, 890  
 SAI\_xCR2\_TRIS, 890  
 SAI\_xFRCR\_FRL, 890  
 SAI\_xFRCR\_FRL\_0, 890  
 SAI\_xFRCR\_FRL\_1, 891  
 SAI\_xFRCR\_FRL\_2, 891  
 SAI\_xFRCR\_FRL\_3, 891  
 SAI\_xFRCR\_FRL\_4, 891  
 SAI\_xFRCR\_FRL\_5, 891  
 SAI\_xFRCR\_FRL\_6, 891  
 SAI\_xFRCR\_FRL\_7, 891  
 SAI\_xFRCR\_FSALL, 891  
 SAI\_xFRCR\_FSALL\_0, 892  
 SAI\_xFRCR\_FSALL\_1, 892  
 SAI\_xFRCR\_FSALL\_2, 892  
 SAI\_xFRCR\_FSALL\_3, 892  
 SAI\_xFRCR\_FSALL\_4, 892  
 SAI\_xFRCR\_FSALL\_5, 892  
 SAI\_xFRCR\_FSALL\_6, 892  
 SAI\_xFRCR\_FSDEF, 893  
 SAI\_xFRCR\_FSOFF, 893  
 SAI\_xFRCR\_FSPOL, 893  
 SAI\_xIMR\_AFSDETIE, 893  
 SAI\_xIMR\_CNRDYIE, 893  
 SAI\_xIMR\_FREQIE, 893  
 SAI\_xIMR\_LFSDETIE, 893  
 SAI\_xIMR\_MUTEDETIE, 894  
 SAI\_xIMR\_OVRUDRIE, 894  
 SAI\_xIMR\_WCKCFGIE, 894  
 SAI\_xSLOTR\_FBOFF, 894  
 SAI\_xSLOTR\_FBOFF\_0, 894  
 SAI\_xSLOTR\_FBOFF\_1, 894  
 SAI\_xSLOTR\_FBOFF\_2, 894  
 SAI\_xSLOTR\_FBOFF\_3, 895  
 SAI\_xSLOTR\_FBOFF\_4, 895  
 SAI\_xSLOTR\_NBSLOT, 895  
 SAI\_xSLOTR\_NBSLOT\_0, 895  
 SAI\_xSLOTR\_NBSLOT\_1, 895  
 SAI\_xSLOTR\_NBSLOT\_2, 895  
 SAI\_xSLOTR\_NBSLOT\_3, 895  
 SAI\_xSLOTR\_SLOTEN, 896  
 SAI\_xSLOTR\_SLOTsz, 896  
 SAI\_xSLOTR\_SLOTsz\_0, 896  
 SAI\_xSLOTR\_SLOTsz\_1, 896  
 SAI\_xSR\_AFSDET, 896  
 SAI\_xSR\_CNRDY, 896  
 SAI\_xSR\_FLVL, 896  
 SAI\_xSR\_FLVL\_0, 897  
 SAI\_xSR\_FLVL\_1, 897  
 SAI\_xSR\_FLVL\_2, 897  
 SAI\_xSR\_FREQ, 897  
 SAI\_xSR\_LFSDET, 897  
 SAI\_xSR\_MUTEDET, 897  
 SAI\_xSR\_OVRUDR, 897  
 SAI\_xSR\_WCKCFG, 898  
 SDIO\_ARG\_CMDARG, 898  
 SDIO\_CLKCR\_BYPASS, 898  
 SDIO\_CLKCR\_CLKDIV, 898  
 SDIO\_CLKCR\_CLKEN, 898  
 SDIO\_CLKCR\_HWFC\_EN, 898  
 SDIO\_CLKCR\_NEGEDGE, 898  
 SDIO\_CLKCR\_PWRSAV, 899  
 SDIO\_CLKCR\_WIDBUS, 899  
 SDIO\_CLKCR\_WIDBUS\_0, 899  
 SDIO\_CLKCR\_WIDBUS\_1, 899  
 SDIO\_CMD\_CEATACMD, 899  
 SDIO\_CMD\_CMDINDEX, 899  
 SDIO\_CMD\_CPSMEN, 899  
 SDIO\_CMD\_ENCMDCOMPL, 900  
 SDIO\_CMD\_NIEN, 900  
 SDIO\_CMD\_SDIOSUSPEND, 900  
 SDIO\_CMD\_WAITINT, 900  
 SDIO\_CMD\_WAITPEND, 900  
 SDIO\_CMD\_WAITRESP, 900  
 SDIO\_CMD\_WAITRESP\_0, 900  
 SDIO\_CMD\_WAITRESP\_1, 901  
 SDIO\_DCOUNT\_DATACOUNT, 901  
 SDIO\_DCTRL\_DBLOCKSIZE, 901  
 SDIO\_DCTRL\_DBLOCKSIZE\_0, 901  
 SDIO\_DCTRL\_DBLOCKSIZE\_1, 901  
 SDIO\_DCTRL\_DBLOCKSIZE\_2, 901  
 SDIO\_DCTRL\_DBLOCKSIZE\_3, 901  
 SDIO\_DCTRL\_DMAEN, 901  
 SDIO\_DCTRL\_DTDIR, 902  
 SDIO\_DCTRL\_DTEN, 902  
 SDIO\_DCTRL\_DTMODE, 902  
 SDIO\_DCTRL\_RWMOD, 902  
 SDIO\_DCTRL\_RWSTART, 902  
 SDIO\_DCTRL\_RWSTOP, 902  
 SDIO\_DCTRL\_SDIOEN, 902  
 SDIO\_DLLEN\_DATALENGTH, 903  
 SDIO\_DTIMER\_DATETIME, 903  
 SDIO\_FIFO\_FIFODATA, 903  
 SDIO\_FIFOCNT\_FIFOCOUNT, 903  
 SDIO\_ICR\_CCRCFAILC, 903  
 SDIO\_ICR\_CEATAENDC, 903  
 SDIO\_ICR\_CMDRENDC, 903  
 SDIO\_ICR\_CMDSENTC, 904  
 SDIO\_ICR\_CTIMEUTC, 904  
 SDIO\_ICR\_DATAENDC, 904  
 SDIO\_ICR\_DBCKENDC, 904  
 SDIO\_ICR\_DCRCFAILC, 904  
 SDIO\_ICR\_DTIMEUTC, 904  
 SDIO\_ICR\_RXOVERRC, 904  
 SDIO\_ICR\_SDIOITC, 905  
 SDIO\_ICR\_STBITERRC, 905  
 SDIO\_ICR\_TXUNDERRC, 905  
 SDIO\_MASK\_CCRCFAILIE, 905  
 SDIO\_MASK\_CEATAENDIE, 905  
 SDIO\_MASK\_CMDACTIE, 905  
 SDIO\_MASK\_CMDRENDIE, 905  
 SDIO\_MASK\_CMDSENTIE, 906

SDIO\_MASK\_CTIMEOUTIE, 906  
SDIO\_MASK\_DATAENDIE, 906  
SDIO\_MASK\_DBCKENDIE, 906  
SDIO\_MASK\_DCRCFAILIE, 906  
SDIO\_MASK\_DTIMEOUTIE, 906  
SDIO\_MASK\_RXACTIE, 906  
SDIO\_MASK\_RXDAVLIE, 907  
SDIO\_MASK\_RXFIFOEIE, 907  
SDIO\_MASK\_RXFIFOFIE, 907  
SDIO\_MASK\_RXOVERRIE, 907  
SDIO\_MASK\_SDIOITIE, 907  
SDIO\_MASK\_STBITERRIE, 907  
SDIO\_MASK\_TXACTIE, 908  
SDIO\_MASK\_TXDAVLIE, 908  
SDIO\_MASK\_TXFIFOEIE, 908  
SDIO\_MASK\_TXFIFOFIE, 908  
SDIO\_MASK\_TXFIFOHEIE, 908  
SDIO\_MASK\_TXUNDERRIE, 908  
SDIO\_POWER\_PWRCTRL, 908  
SDIO\_POWER\_PWRCTRL\_0, 909  
SDIO\_POWER\_PWRCTRL\_1, 909  
SDIO\_RESP0\_CARDSTATUS0, 909  
SDIO\_RESP1\_CARDSTATUS1, 909  
SDIO\_RESP2\_CARDSTATUS2, 909  
SDIO\_RESP3\_CARDSTATUS3, 909  
SDIO\_RESP4\_CARDSTATUS4, 909  
SDIO\_RESPCMD\_RESPCMD, 909  
SDIO\_STA\_CCRCFAIL, 910  
SDIO\_STA\_CEATAEND, 910  
SDIO\_STA\_CMDACT, 910  
SDIO\_STA\_CMDREND, 910  
SDIO\_STA\_CMDSENT, 910  
SDIO\_STA\_CTIMEOUT, 910  
SDIO\_STA\_DATAEND, 910  
SDIO\_STA\_DBCKEND, 911  
SDIO\_STA\_DCRCFAIL, 911  
SDIO\_STA\_DTIMEOUT, 911  
SDIO\_STA\_RXACT, 911  
SDIO\_STA\_RXDAVL, 911  
SDIO\_STA\_RXFIFOE, 911  
SDIO\_STA\_RXFIFOF, 911  
SDIO\_STA\_RXFIFOHF, 912  
SDIO\_STA\_RXOVERR, 912  
SDIO\_STA\_SDIOIT, 912  
SDIO\_STA\_STBITERR, 912  
SDIO\_STA\_TXACT, 912  
SDIO\_STA\_TXDAVL, 912  
SDIO\_STA\_TXFIFOE, 912  
SDIO\_STA\_TXFIFOF, 913  
SDIO\_STA\_TXFIFOHE, 913  
SDIO\_STA\_TXUNDERR, 913  
SPI\_CR1\_BIDIMODE, 913  
SPI\_CR1\_BIDIOE, 913  
SPI\_CR1\_BR, 913  
SPI\_CR1\_BR\_0, 913  
SPI\_CR1\_BR\_1, 914  
SPI\_CR1\_BR\_2, 914  
SPI\_CR1\_CPHA, 914  
SPI\_CR1\_CPOL, 914  
SPI\_CR1\_CRCEN, 914  
SPI\_CR1\_CRCNEXT, 914  
SPI\_CR1\_DFF, 914  
SPI\_CR1\_LSBFIRST, 915  
SPI\_CR1\_MSTR, 915  
SPI\_CR1\_RXONLY, 915  
SPI\_CR1\_SPE, 915  
SPI\_CR1\_SSI, 915  
SPI\_CR1\_SSM, 915  
SPI\_CR2\_ERRIE, 915  
SPI\_CR2\_RXDMAEN, 916  
SPI\_CR2\_RXNEIE, 916  
SPI\_CR2\_SSOE, 916  
SPI\_CR2\_RXDMAEN, 916  
SPI\_CR2\_TXEIE, 916  
SPI\_CRCPR\_CRCPOLY, 916  
SPI\_DR\_DR, 916  
SPI\_I2SCFGR\_CHLEN, 917  
SPI\_I2SCFGR\_CKPOL, 917  
SPI\_I2SCFGR\_DATLEN, 917  
SPI\_I2SCFGR\_DATLEN\_0, 917  
SPI\_I2SCFGR\_DATLEN\_1, 917  
SPI\_I2SCFGR\_I2SCFG, 917  
SPI\_I2SCFGR\_I2SCFG\_0, 917  
SPI\_I2SCFGR\_I2SCFG\_1, 918  
SPI\_I2SCFGR\_I2SE, 918  
SPI\_I2SCFGR\_I2SMOD, 918  
SPI\_I2SCFGR\_I2SSTD, 918  
SPI\_I2SCFGR\_I2SSTD\_0, 918  
SPI\_I2SCFGR\_I2SSTD\_1, 918  
SPI\_I2SCFGR\_PCMSYNC, 918  
SPI\_I2SPR\_I2SDIV, 919  
SPI\_I2SPR\_MCKOE, 919  
SPI\_I2SPR\_ODD, 919  
SPI\_RXCRCR\_RXCRC, 919  
SPI\_SR\_BSY, 919  
SPI\_SR\_CHSIDE, 919  
SPI\_SR\_CRCERR, 919  
SPI\_SR\_MODF, 920  
SPI\_SR\_OVR, 920  
SPI\_SR\_RXNE, 920  
SPI\_SR\_TXE, 920  
SPI\_SR\_UDR, 920  
SPI\_TXCRCR\_TXCRC, 920  
SYSCFG\_CMPCR\_CMP\_PD, 920  
SYSCFG\_CMPCR\_READY, 921  
SYSCFG\_EXTICR1\_EXTI0, 921  
SYSCFG\_EXTICR1\_EXTI0\_PA, 921  
SYSCFG\_EXTICR1\_EXTI0\_PB, 921  
SYSCFG\_EXTICR1\_EXTI0\_PC, 921  
SYSCFG\_EXTICR1\_EXTI0\_PD, 921  
SYSCFG\_EXTICR1\_EXTI0\_PE, 921  
SYSCFG\_EXTICR1\_EXTI0\_PF, 922  
SYSCFG\_EXTICR1\_EXTI0\_PG, 922  
SYSCFG\_EXTICR1\_EXTI0\_PH, 922  
SYSCFG\_EXTICR1\_EXTI0\_PI, 922

SYSCFG\_EXTICR1\_EXTI0\_PJ, 922  
SYSCFG\_EXTICR1\_EXTI0\_PK, 922  
SYSCFG\_EXTICR1\_EXTI1, 922  
SYSCFG\_EXTICR1\_EXTI1\_PA, 922  
SYSCFG\_EXTICR1\_EXTI1\_PB, 923  
SYSCFG\_EXTICR1\_EXTI1\_PC, 923  
SYSCFG\_EXTICR1\_EXTI1\_PD, 923  
SYSCFG\_EXTICR1\_EXTI1\_PE, 923  
SYSCFG\_EXTICR1\_EXTI1\_PF, 923  
SYSCFG\_EXTICR1\_EXTI1\_PG, 923  
SYSCFG\_EXTICR1\_EXTI1\_PH, 923  
SYSCFG\_EXTICR1\_EXTI1\_PI, 924  
SYSCFG\_EXTICR1\_EXTI1\_PJ, 924  
SYSCFG\_EXTICR1\_EXTI1\_PK, 924  
SYSCFG\_EXTICR1\_EXTI2, 924  
SYSCFG\_EXTICR1\_EXTI2\_PA, 924  
SYSCFG\_EXTICR1\_EXTI2\_PB, 924  
SYSCFG\_EXTICR1\_EXTI2\_PC, 924  
SYSCFG\_EXTICR1\_EXTI2\_PD, 925  
SYSCFG\_EXTICR1\_EXTI2\_PE, 925  
SYSCFG\_EXTICR1\_EXTI2\_PF, 925  
SYSCFG\_EXTICR1\_EXTI2\_PG, 925  
SYSCFG\_EXTICR1\_EXTI2\_PH, 925  
SYSCFG\_EXTICR1\_EXTI2\_PI, 925  
SYSCFG\_EXTICR1\_EXTI2\_PJ, 925  
SYSCFG\_EXTICR1\_EXTI2\_PK, 925  
SYSCFG\_EXTICR1\_EXTI3, 926  
SYSCFG\_EXTICR1\_EXTI3\_PA, 926  
SYSCFG\_EXTICR1\_EXTI3\_PB, 926  
SYSCFG\_EXTICR1\_EXTI3\_PC, 926  
SYSCFG\_EXTICR1\_EXTI3\_PD, 926  
SYSCFG\_EXTICR1\_EXTI3\_PE, 926  
SYSCFG\_EXTICR1\_EXTI3\_PF, 926  
SYSCFG\_EXTICR1\_EXTI3\_PG, 927  
SYSCFG\_EXTICR1\_EXTI3\_PH, 927  
SYSCFG\_EXTICR1\_EXTI3\_PI, 927  
SYSCFG\_EXTICR1\_EXTI3\_PJ, 927  
SYSCFG\_EXTICR1\_EXTI3\_PK, 927  
SYSCFG\_EXTICR2\_EXTI4, 927  
SYSCFG\_EXTICR2\_EXTI4\_PA, 927  
SYSCFG\_EXTICR2\_EXTI4\_PB, 928  
SYSCFG\_EXTICR2\_EXTI4\_PC, 928  
SYSCFG\_EXTICR2\_EXTI4\_PD, 928  
SYSCFG\_EXTICR2\_EXTI4\_PE, 928  
SYSCFG\_EXTICR2\_EXTI4\_PF, 928  
SYSCFG\_EXTICR2\_EXTI4\_PG, 928  
SYSCFG\_EXTICR2\_EXTI4\_PH, 928  
SYSCFG\_EXTICR2\_EXTI4\_PI, 929  
SYSCFG\_EXTICR2\_EXTI4\_PJ, 929  
SYSCFG\_EXTICR2\_EXTI4\_PK, 929  
SYSCFG\_EXTICR2\_EXTI5, 929  
SYSCFG\_EXTICR2\_EXTI5\_PA, 929  
SYSCFG\_EXTICR2\_EXTI5\_PB, 929  
SYSCFG\_EXTICR2\_EXTI5\_PC, 929  
SYSCFG\_EXTICR2\_EXTI5\_PD, 930  
SYSCFG\_EXTICR2\_EXTI5\_PE, 930  
SYSCFG\_EXTICR2\_EXTI5\_PF, 930  
SYSCFG\_EXTICR2\_EXTI5\_PG, 930  
SYSCFG\_EXTICR2\_EXTI5\_PH, 930  
SYSCFG\_EXTICR2\_EXTI5\_PI, 930  
SYSCFG\_EXTICR2\_EXTI5\_PJ, 930  
SYSCFG\_EXTICR2\_EXTI5\_PK, 930  
SYSCFG\_EXTICR2\_EXTI6, 931  
SYSCFG\_EXTICR2\_EXTI6\_PA, 931  
SYSCFG\_EXTICR2\_EXTI6\_PB, 931  
SYSCFG\_EXTICR2\_EXTI6\_PC, 931  
SYSCFG\_EXTICR2\_EXTI6\_PD, 931  
SYSCFG\_EXTICR2\_EXTI6\_PE, 931  
SYSCFG\_EXTICR2\_EXTI6\_PF, 931  
SYSCFG\_EXTICR2\_EXTI6\_PG, 932  
SYSCFG\_EXTICR2\_EXTI6\_PH, 932  
SYSCFG\_EXTICR2\_EXTI6\_PI, 932  
SYSCFG\_EXTICR2\_EXTI6\_PJ, 932  
SYSCFG\_EXTICR2\_EXTI6\_PK, 932  
SYSCFG\_EXTICR2\_EXTI7, 932  
SYSCFG\_EXTICR2\_EXTI7\_PA, 932  
SYSCFG\_EXTICR2\_EXTI7\_PB, 933  
SYSCFG\_EXTICR2\_EXTI7\_PC, 933  
SYSCFG\_EXTICR2\_EXTI7\_PD, 933  
SYSCFG\_EXTICR2\_EXTI7\_PE, 933  
SYSCFG\_EXTICR2\_EXTI7\_PF, 933  
SYSCFG\_EXTICR2\_EXTI7\_PG, 933  
SYSCFG\_EXTICR2\_EXTI7\_PH, 933  
SYSCFG\_EXTICR2\_EXTI7\_PI, 934  
SYSCFG\_EXTICR2\_EXTI7\_PJ, 934  
SYSCFG\_EXTICR2\_EXTI7\_PK, 934  
SYSCFG\_EXTICR3\_EXTI10, 934  
SYSCFG\_EXTICR3\_EXTI10\_PA, 934  
SYSCFG\_EXTICR3\_EXTI10\_PB, 934  
SYSCFG\_EXTICR3\_EXTI10\_PC, 934  
SYSCFG\_EXTICR3\_EXTI10\_PD, 935  
SYSCFG\_EXTICR3\_EXTI10\_PE, 935  
SYSCFG\_EXTICR3\_EXTI10\_PF, 935  
SYSCFG\_EXTICR3\_EXTI10\_PG, 935  
SYSCFG\_EXTICR3\_EXTI10\_PH, 935  
SYSCFG\_EXTICR3\_EXTI10\_PI, 935  
SYSCFG\_EXTICR3\_EXTI10\_PJ, 935  
SYSCFG\_EXTICR3\_EXTI11, 935  
SYSCFG\_EXTICR3\_EXTI11\_PA, 936  
SYSCFG\_EXTICR3\_EXTI11\_PB, 936  
SYSCFG\_EXTICR3\_EXTI11\_PC, 936  
SYSCFG\_EXTICR3\_EXTI11\_PD, 936  
SYSCFG\_EXTICR3\_EXTI11\_PE, 936  
SYSCFG\_EXTICR3\_EXTI11\_PF, 936  
SYSCFG\_EXTICR3\_EXTI11\_PG, 936  
SYSCFG\_EXTICR3\_EXTI11\_PH, 937  
SYSCFG\_EXTICR3\_EXTI11\_PI, 937  
SYSCFG\_EXTICR3\_EXTI11\_PJ, 937  
SYSCFG\_EXTICR3\_EXTI18, 937  
SYSCFG\_EXTICR3\_EXTI18\_PA, 937  
SYSCFG\_EXTICR3\_EXTI18\_PB, 937  
SYSCFG\_EXTICR3\_EXTI18\_PC, 937  
SYSCFG\_EXTICR3\_EXTI18\_PD, 938  
SYSCFG\_EXTICR3\_EXTI18\_PE, 938  
SYSCFG\_EXTICR3\_EXTI18\_PF, 938  
SYSCFG\_EXTICR3\_EXTI18\_PG, 938

SYSCFG\_EXTICR3\_EXTI8\_PH, 938  
SYSCFG\_EXTICR3\_EXTI8\_PI, 938  
SYSCFG\_EXTICR3\_EXTI8\_PJ, 938  
SYSCFG\_EXTICR3\_EXTI9, 938  
SYSCFG\_EXTICR3\_EXTI9\_PA, 939  
SYSCFG\_EXTICR3\_EXTI9\_PB, 939  
SYSCFG\_EXTICR3\_EXTI9\_PC, 939  
SYSCFG\_EXTICR3\_EXTI9\_PD, 939  
SYSCFG\_EXTICR3\_EXTI9\_PE, 939  
SYSCFG\_EXTICR3\_EXTI9\_PF, 939  
SYSCFG\_EXTICR3\_EXTI9\_PG, 939  
SYSCFG\_EXTICR3\_EXTI9\_PH, 940  
SYSCFG\_EXTICR3\_EXTI9\_PI, 940  
SYSCFG\_EXTICR3\_EXTI9\_PJ, 940  
SYSCFG\_EXTICR4\_EXTI12, 940  
SYSCFG\_EXTICR4\_EXTI12\_PA, 940  
SYSCFG\_EXTICR4\_EXTI12\_PB, 940  
SYSCFG\_EXTICR4\_EXTI12\_PC, 940  
SYSCFG\_EXTICR4\_EXTI12\_PD, 941  
SYSCFG\_EXTICR4\_EXTI12\_PE, 941  
SYSCFG\_EXTICR4\_EXTI12\_PF, 941  
SYSCFG\_EXTICR4\_EXTI12\_PG, 941  
SYSCFG\_EXTICR4\_EXTI12\_PH, 941  
SYSCFG\_EXTICR4\_EXTI12\_PI, 941  
SYSCFG\_EXTICR4\_EXTI12\_PJ, 941  
SYSCFG\_EXTICR4\_EXTI13, 941  
SYSCFG\_EXTICR4\_EXTI13\_PA, 942  
SYSCFG\_EXTICR4\_EXTI13\_PB, 942  
SYSCFG\_EXTICR4\_EXTI13\_PC, 942  
SYSCFG\_EXTICR4\_EXTI13\_PD, 942  
SYSCFG\_EXTICR4\_EXTI13\_PE, 942  
SYSCFG\_EXTICR4\_EXTI13\_PF, 942  
SYSCFG\_EXTICR4\_EXTI13\_PG, 942  
SYSCFG\_EXTICR4\_EXTI13\_PH, 943  
SYSCFG\_EXTICR4\_EXTI13\_PI, 943  
SYSCFG\_EXTICR4\_EXTI13\_PJ, 943  
SYSCFG\_EXTICR4\_EXTI14, 943  
SYSCFG\_EXTICR4\_EXTI14\_PA, 943  
SYSCFG\_EXTICR4\_EXTI14\_PB, 943  
SYSCFG\_EXTICR4\_EXTI14\_PC, 943  
SYSCFG\_EXTICR4\_EXTI14\_PD, 944  
SYSCFG\_EXTICR4\_EXTI14\_PE, 944  
SYSCFG\_EXTICR4\_EXTI14\_PF, 944  
SYSCFG\_EXTICR4\_EXTI14\_PG, 944  
SYSCFG\_EXTICR4\_EXTI14\_PH, 944  
SYSCFG\_EXTICR4\_EXTI14\_PI, 944  
SYSCFG\_EXTICR4\_EXTI14\_PJ, 944  
SYSCFG\_EXTICR4\_EXTI14, 944  
SYSCFG\_EXTICR4\_EXTI15, 945  
SYSCFG\_EXTICR4\_EXTI15\_PA, 945  
SYSCFG\_EXTICR4\_EXTI15\_PB, 945  
SYSCFG\_EXTICR4\_EXTI15\_PC, 945  
SYSCFG\_EXTICR4\_EXTI15\_PD, 945  
SYSCFG\_EXTICR4\_EXTI15\_PE, 945  
SYSCFG\_EXTICR4\_EXTI15\_PF, 945  
SYSCFG\_EXTICR4\_EXTI15\_PG, 945  
SYSCFG\_EXTICR4\_EXTI15\_PH, 946  
SYSCFG\_EXTICR4\_EXTI15\_PI, 946  
SYSCFG\_EXTICR4\_EXTI15\_PJ, 946  
SYSCFG\_MEMRMP\_FB\_MODE, 946  
SYSCFG\_MEMRMP\_MEM\_MODE, 946  
SYSCFG\_MEMRMP\_MEM\_MODE\_0, 946  
SYSCFG\_MEMRMP\_MEM\_MODE\_1, 946  
SYSCFG\_MEMRMP\_MEM\_MODE\_2, 946  
SYSCFG\_MEMRMP\_SWP\_FMC, 947  
SYSCFG\_MEMRMP\_SWP\_FMC\_0, 947  
SYSCFG\_MEMRMP\_SWP\_FMC\_1, 947  
SYSCFG\_PMC\_ADC1DC2, 947  
SYSCFG\_PMC\_ADC2DC2, 947  
SYSCFG\_PMC\_ADC3DC2, 947  
SYSCFG\_PMC\_ADCxDC2, 947  
SYSCFG\_PMC\_MII\_RMII\_SEL, 948  
TIM\_ARR\_ARR, 948  
TIM\_BDTR\_AOE, 948  
TIM\_BDTR\_BKE, 948  
TIM\_BDTR\_BKP, 948  
TIM\_BDTR\_DTG, 948  
TIM\_BDTR\_DTG\_0, 948  
TIM\_BDTR\_DTG\_1, 949  
TIM\_BDTR\_DTG\_2, 949  
TIM\_BDTR\_DTG\_3, 949  
TIM\_BDTR\_DTG\_4, 949  
TIM\_BDTR\_DTG\_5, 949  
TIM\_BDTR\_DTG\_6, 949  
TIM\_BDTR\_DTG\_7, 949  
TIM\_BDTR\_LOCK, 949  
TIM\_BDTR\_LOCK\_0, 950  
TIM\_BDTR\_LOCK\_1, 950  
TIM\_BDTR\_MOE, 950  
TIM\_BDTR\_OSSI, 950  
TIM\_BDTR\_OSSR, 950  
TIM\_CCER\_CC1E, 950  
TIM\_CCER\_CC1NE, 950  
TIM\_CCER\_CC1NP, 951  
TIM\_CCER\_CC1P, 951  
TIM\_CCER\_CC2E, 951  
TIM\_CCER\_CC2NE, 951  
TIM\_CCER\_CC2NP, 951  
TIM\_CCER\_CC2P, 951  
TIM\_CCER\_CC3E, 951  
TIM\_CCER\_CC3NE, 952  
TIM\_CCER\_CC3NP, 952  
TIM\_CCER\_CC3P, 952  
TIM\_CCER\_CC4E, 952  
TIM\_CCER\_CC4NP, 952  
TIM\_CCER\_CC4P, 952  
TIM\_CCMR1\_CC1S, 952  
TIM\_CCMR1\_CC1S\_0, 953  
TIM\_CCMR1\_CC1S\_1, 953  
TIM\_CCMR1\_CC2S, 953  
TIM\_CCMR1\_CC2S\_0, 953  
TIM\_CCMR1\_CC2S\_1, 953  
TIM\_CCMR1\_IC1F, 953  
TIM\_CCMR1\_IC1F\_0, 953  
TIM\_CCMR1\_IC1F\_1, 954  
TIM\_CCMR1\_IC1F\_2, 954  
TIM\_CCMR1\_IC1F\_3, 954

TIM\_CCMR1\_IC1PSC, 954  
TIM\_CCMR1\_IC1PSC\_0, 954  
TIM\_CCMR1\_IC1PSC\_1, 954  
TIM\_CCMR1\_IC2F, 954  
TIM\_CCMR1\_IC2F\_0, 954  
TIM\_CCMR1\_IC2F\_1, 955  
TIM\_CCMR1\_IC2F\_2, 955  
TIM\_CCMR1\_IC2F\_3, 955  
TIM\_CCMR1\_IC2PSC, 955  
TIM\_CCMR1\_IC2PSC\_0, 955  
TIM\_CCMR1\_IC2PSC\_1, 955  
TIM\_CCMR1\_OC1CE, 955  
TIM\_CCMR1\_OC1FE, 956  
TIM\_CCMR1\_OC1M, 956  
TIM\_CCMR1\_OC1M\_0, 956  
TIM\_CCMR1\_OC1M\_1, 956  
TIM\_CCMR1\_OC1M\_2, 956  
TIM\_CCMR1\_OC1PE, 956  
TIM\_CCMR1\_OC2CE, 956  
TIM\_CCMR1\_OC2FE, 957  
TIM\_CCMR1\_OC2M, 957  
TIM\_CCMR1\_OC2M\_0, 957  
TIM\_CCMR1\_OC2M\_1, 957  
TIM\_CCMR1\_OC2M\_2, 957  
TIM\_CCMR1\_OC2PE, 957  
TIM\_CCMR2\_CC3S, 957  
TIM\_CCMR2\_CC3S\_0, 958  
TIM\_CCMR2\_CC3S\_1, 958  
TIM\_CCMR2\_CC4S, 958  
TIM\_CCMR2\_CC4S\_0, 958  
TIM\_CCMR2\_CC4S\_1, 958  
TIM\_CCMR2\_IC3F, 958  
TIM\_CCMR2\_IC3F\_0, 958  
TIM\_CCMR2\_IC3F\_1, 959  
TIM\_CCMR2\_IC3F\_2, 959  
TIM\_CCMR2\_IC3F\_3, 959  
TIM\_CCMR2\_IC3PSC, 959  
TIM\_CCMR2\_IC3PSC\_0, 959  
TIM\_CCMR2\_IC3PSC\_1, 959  
TIM\_CCMR2\_IC4F, 959  
TIM\_CCMR2\_IC4F\_0, 959  
TIM\_CCMR2\_IC4F\_1, 960  
TIM\_CCMR2\_IC4F\_2, 960  
TIM\_CCMR2\_IC4F\_3, 960  
TIM\_CCMR2\_IC4PSC, 960  
TIM\_CCMR2\_IC4PSC\_0, 960  
TIM\_CCMR2\_IC4PSC\_1, 960  
TIM\_CCMR2\_OC3CE, 960  
TIM\_CCMR2\_OC3FE, 960  
TIM\_CCMR2\_OC3M, 961  
TIM\_CCMR2\_OC3M\_0, 961  
TIM\_CCMR2\_OC3M\_1, 961  
TIM\_CCMR2\_OC3M\_2, 961  
TIM\_CCMR2\_OC3PE, 961  
TIM\_CCMR2\_OC4CE, 961  
TIM\_CCMR2\_OC4FE, 961  
TIM\_CCMR2\_OC4M, 962  
TIM\_CCMR2\_OC4M\_0, 962  
TIM\_CCMR2\_OC4M\_1, 962  
TIM\_CCMR2\_OC4M\_2, 962  
TIM\_CCMR2\_OC4PE, 962  
TIM\_CCR1\_CCR1, 962  
TIM\_CCR2\_CCR2, 962  
TIM\_CCR3\_CCR3, 963  
TIM\_CCR4\_CCR4, 963  
TIM\_CNT\_CNT, 963  
TIM\_CR1\_ARPE, 963  
TIM\_CR1\_CEN, 963  
TIM\_CR1\_CKD, 963  
TIM\_CR1\_CKD\_0, 963  
TIM\_CR1\_CKD\_1, 964  
TIM\_CR1\_CMS, 964  
TIM\_CR1\_CMS\_0, 964  
TIM\_CR1\_CMS\_1, 964  
TIM\_CR1\_DIR, 964  
TIM\_CR1\_OPM, 964  
TIM\_CR1\_UDIS, 964  
TIM\_CR1\_URS, 965  
TIM\_CR2\_CCDS, 965  
TIM\_CR2\_CCPC, 965  
TIM\_CR2\_CCUS, 965  
TIM\_CR2\_MMS, 965  
TIM\_CR2\_MMS\_0, 965  
TIM\_CR2\_MMS\_1, 965  
TIM\_CR2\_MMS\_2, 966  
TIM\_CR2\_OIS1, 966  
TIM\_CR2\_OIS1N, 966  
TIM\_CR2\_OIS2, 966  
TIM\_CR2\_OIS2N, 966  
TIM\_CR2\_OIS3, 966  
TIM\_CR2\_OIS3N, 966  
TIM\_CR2\_OIS4, 967  
TIM\_CR2\_TI1S, 967  
TIM\_DCR\_DBAA, 967  
TIM\_DCR\_DBAA\_0, 967  
TIM\_DCR\_DBAA\_1, 967  
TIM\_DCR\_DBAA\_2, 967  
TIM\_DCR\_DBAA\_3, 967  
TIM\_DCR\_DBAA\_4, 968  
TIM\_DCR\_DBBL, 968  
TIM\_DCR\_DBBL\_0, 968  
TIM\_DCR\_DBBL\_1, 968  
TIM\_DCR\_DBBL\_2, 968  
TIM\_DCR\_DBBL\_3, 968  
TIM\_DCR\_DBBL\_4, 968  
TIM\_DIER\_BIE, 968  
TIM\_DIER\_CC1DE, 969  
TIM\_DIER\_CC1IE, 969  
TIM\_DIER\_CC2DE, 969  
TIM\_DIER\_CC2IE, 969  
TIM\_DIER\_CC3DE, 969  
TIM\_DIER\_CC3IE, 969  
TIM\_DIER\_CC4DE, 969  
TIM\_DIER\_CC4IE, 970  
TIM\_DIER\_COMDE, 970  
TIM\_DIER\_COMIE, 970

TIM\_DIER\_TDE, 970  
TIM\_DIER\_TIE, 970  
TIM\_DIER\_UDE, 970  
TIM\_DIER\_UIE, 970  
TIM\_DMAR\_DMAB, 971  
TIM\_EGR\_BG, 971  
TIM\_EGR\_CC1G, 971  
TIM\_EGR\_CC2G, 971  
TIM\_EGR\_CC3G, 971  
TIM\_EGR\_CC4G, 971  
TIM\_EGR\_COMG, 971  
TIM\_EGR\_TG, 972  
TIM\_EGR\_UG, 972  
TIM\_OR\_ITR1\_RMP, 972  
TIM\_OR\_ITR1\_RMP\_0, 972  
TIM\_OR\_ITR1\_RMP\_1, 972  
TIM\_OR\_TI4\_RMP, 972  
TIM\_OR\_TI4\_RMP\_0, 972  
TIM\_OR\_TI4\_RMP\_1, 973  
TIM\_PSC\_PSC, 973  
TIM\_RCR REP, 973  
TIM\_SMCR\_ECE, 973  
TIM\_SMCR ETF, 973  
TIM\_SMCR ETF\_0, 973  
TIM\_SMCR ETF\_1, 973  
TIM\_SMCR ETF\_2, 974  
TIM\_SMCR ETF\_3, 974  
TIM\_SMCR ETP, 974  
TIM\_SMCR ETPLS, 974  
TIM\_SMCR ETPLS\_0, 974  
TIM\_SMCR ETPLS\_1, 974  
TIM\_SMCR MSM, 974  
TIM\_SMCR SMS, 974  
TIM\_SMCR SMS\_0, 975  
TIM\_SMCR SMS\_1, 975  
TIM\_SMCR SMS\_2, 975  
TIM\_SMCR TS, 975  
TIM\_SMCR TS\_0, 975  
TIM\_SMCR TS\_1, 975  
TIM\_SMCR TS\_2, 975  
TIM\_SR\_BIF, 976  
TIM\_SR\_CC1IF, 976  
TIM\_SR\_CC1OF, 976  
TIM\_SR\_CC2IF, 976  
TIM\_SR\_CC2OF, 976  
TIM\_SR\_CC3IF, 976  
TIM\_SR\_CC3OF, 976  
TIM\_SR\_CC4IF, 977  
TIM\_SR\_CC4OF, 977  
TIM\_SR\_COMIF, 977  
TIM\_SR\_TIF, 977  
TIM\_SR\_UIF, 977  
USART\_BRR\_DIV\_Fraction, 977  
USART\_BRR\_DIV\_Mantissa, 977  
USART\_CR1\_IDLEIE, 978  
USART\_CR1\_M, 978  
USART\_CR1\_OVER8, 978  
USART\_CR1\_PCE, 978  
USART\_CR1\_PEIE, 978  
USART\_CR1\_PS, 978  
USART\_CR1\_RE, 978  
USART\_CR1\_RWU, 979  
USART\_CR1\_RXNEIE, 979  
USART\_CR1\_SBK, 979  
USART\_CR1\_TCIE, 979  
USART\_CR1\_TE, 979  
USART\_CR1\_TXEIE, 979  
USART\_CR1\_UE, 979  
USART\_CR1\_WAKE, 980  
USART\_CR2\_ADD, 980  
USART\_CR2\_CLKEN, 980  
USART\_CR2\_CPHA, 980  
USART\_CR2\_CPOL, 980  
USART\_CR2\_LBCL, 980  
USART\_CR2\_LBDIE, 980  
USART\_CR2\_LBDL, 981  
USART\_CR2\_LINEN, 981  
USART\_CR2\_STOP, 981  
USART\_CR2\_STOP\_0, 981  
USART\_CR2\_STOP\_1, 981  
USART\_CR3\_CTSE, 981  
USART\_CR3\_CTSIE, 981  
USART\_CR3\_DMAR, 982  
USART\_CR3\_DMAT, 982  
USART\_CR3\_EIE, 982  
USART\_CR3\_HDSEL, 982  
USART\_CR3\_IREN, 982  
USART\_CR3\_IRLP, 982  
USART\_CR3\_NACK, 982  
USART\_CR3\_ONEBIT, 983  
USART\_CR3\_RTSE, 983  
USART\_CR3\_SCEN, 983  
USART\_DR\_DR, 983  
USART\_GTPR\_GT, 983  
USART\_GTPR\_PSC, 983  
USART\_GTPR\_PSC\_0, 983  
USART\_GTPR\_PSC\_1, 984  
USART\_GTPR\_PSC\_2, 984  
USART\_GTPR\_PSC\_3, 984  
USART\_GTPR\_PSC\_4, 984  
USART\_GTPR\_PSC\_5, 984  
USART\_GTPR\_PSC\_6, 984  
USART\_GTPR\_PSC\_7, 984  
USART\_SR\_CTS, 984  
USART\_SR\_FE, 985  
USART\_SR\_IDLE, 985  
USART\_SR\_LBD, 985  
USART\_SR\_NE, 985  
USART\_SR\_ORE, 985  
USART\_SR\_PE, 985  
USART\_SR\_RXNE, 985  
USART\_SR\_TC, 986  
USART\_SR\_TXE, 986  
WWDG\_CFR\_EWI, 986  
WWDG\_CFR\_W, 986  
WWDG\_CFR\_W\_0, 986

WWDG\_CFR\_W\_1, 986  
 WWDG\_CFR\_W\_2, 986  
 WWDG\_CFR\_W\_3, 987  
 WWDG\_CFR\_W\_4, 987  
 WWDG\_CFR\_W\_5, 987  
 WWDG\_CFR\_W\_6, 987  
 WWDG\_CFR\_WDGTB, 987  
 WWDG\_CFR\_WDGTB\_0, 987  
 WWDG\_CFR\_WDGTB\_1, 987  
 WWDG\_CR\_T, 987  
 WWDG\_CR\_T\_0, 988  
 WWDG\_CR\_T\_1, 988  
 WWDG\_CR\_T\_2, 988  
 WWDG\_CR\_T\_3, 988  
 WWDG\_CR\_T\_4, 988  
 WWDG\_CR\_T\_5, 988  
 WWDG\_CR\_T\_6, 988  
 WWDG\_CR\_WDGA, 988  
 WWDG\_SR\_EWIF, 989  
 Peripheral\_registers\_structures, 530  
 PFCR  
     CMSIS, 498  
 PFR  
     ITM Functions, 140  
 PID0  
     ITM Functions, 140  
 PID1  
     ITM Functions, 140  
 PID2  
     ITM Functions, 141  
 PID3  
     ITM Functions, 141  
 PID4  
     ITM Functions, 141  
 PID5  
     ITM Functions, 141  
 PID6  
     ITM Functions, 141  
 PID7  
     ITM Functions, 141  
 Platform Standard Types, 148  
     boolean, 152  
     ConstVoidPtr, 152  
     CPU\_BIT\_ORDER, 150  
     CPU\_BYTE\_ORDER, 150  
     CPU\_TYPE, 150  
     CPU\_TYPE\_16, 150  
     CPU\_TYPE\_32, 150  
     CPU\_TYPE\_64, 150  
     CPU\_TYPE\_8, 150  
     FALSE, 151  
     FLAG\_RESET, 151  
     FLAG\_SET, 151  
     float32, 152  
     float64, 153  
     HIGH\_BYTE\_FIRST, 151  
     LOW\_BYTE\_FIRST, 151  
     LSB\_FIRST, 151  
     MSB\_FIRST, 151  
     RESET, 152  
     SET, 152  
     sint16, 153  
     sint16\_least, 153  
     sint32, 153  
     sint32\_least, 153  
     sint64, 153  
     sint8, 153  
     sint8\_least, 154  
     TRUE, 152  
     uint16, 154  
     uint16\_least, 154  
     uint32, 154  
     uint32\_least, 154  
     uint64, 154  
     uint8, 154  
     uint8\_least, 154  
     VoidPtr, 155  
     vuInt16\_t, 155  
     vuInt32\_t, 155  
     vuInt8\_t, 155  
 PLLCFG  
     CMSIS, 499  
     RCC\_TypeDef, 1036  
 PLLI2SCFGR  
     CMSIS, 499  
     RCC\_TypeDef, 1036  
 PLLSAICFGR  
     CMSIS, 499  
 PMC  
     CMSIS, 499  
     SYSCFG\_RegDef\_t, 1055  
 POL  
     CRC\_TypeDef, 1005  
 PORT  
     ITM Functions, 141  
 POWER  
     CMSIS, 499  
 PR  
     CMSIS, 499  
     EXTI\_TypeDef, 1013  
 PRER  
     CMSIS, 500  
 PrimaryAddress  
     S\_I2C\_Slave\_address, 1041  
 Print\_Slots\_LCD\_Flag  
     Global\_Variables\_Definitions, 371  
 Priority Groups, 288  
 Prototypes, 356  
     fp\_App\_State\_Handler, 356  
 PSC  
     CMSIS, 500  
     TIM1\_TypeDef, 1059  
 PUPDR  
     CMSIS, 500  
     GPIO\_TypeDef, 1018  
 PVD\_IRQn

- Configuration\_section\_for\CMSIS, 525
- PWR\_CR\_ADCDC1  
    Peripheral\_Registers\_Bits\_Definition, 868
- PWR\_CR\_CSBF  
    Peripheral\_Registers\_Bits\_Definition, 869
- PWR\_CR\_CWUF  
    Peripheral\_Registers\_Bits\_Definition, 869
- PWR\_CR\_DBP  
    Peripheral\_Registers\_Bits\_Definition, 869
- PWR\_CR\_FISSR  
    Peripheral\_Registers\_Bits\_Definition, 869
- PWR\_CR\_FMSSR  
    Peripheral\_Registers\_Bits\_Definition, 869
- PWR\_CR\_LPDS  
    Peripheral\_Registers\_Bits\_Definition, 869
- PWR\_CR\_LPLVDS  
    Peripheral\_Registers\_Bits\_Definition, 870
- PWR\_CR\_LPUDS  
    Peripheral\_Registers\_Bits\_Definition, 870
- PWR\_CR\_MRLVDS  
    Peripheral\_Registers\_Bits\_Definition, 870
- PWR\_CR\_MRUDS  
    Peripheral\_Registers\_Bits\_Definition, 870
- PWR\_CR\_ODEN  
    Peripheral\_Registers\_Bits\_Definition, 870
- PWR\_CR\_ODSWEN  
    Peripheral\_Registers\_Bits\_Definition, 870
- PWR\_CR\_PDDS  
    Peripheral\_Registers\_Bits\_Definition, 870
- PWR\_CR\_PLS  
    Peripheral\_Registers\_Bits\_Definition, 871
- PWR\_CR\_PLS\_0  
    Peripheral\_Registers\_Bits\_Definition, 871
- PWR\_CR\_PLS\_1  
    Peripheral\_Registers\_Bits\_Definition, 871
- PWR\_CR\_PLS\_2  
    Peripheral\_Registers\_Bits\_Definition, 871
- PWR\_CR\_PLS\_LEV0  
    Peripheral\_Registers\_Bits\_Definition, 871
- PWR\_CR\_PLS\_LEV1  
    Peripheral\_Registers\_Bits\_Definition, 871
- PWR\_CR\_PLS\_LEV2  
    Peripheral\_Registers\_Bits\_Definition, 871
- PWR\_CR\_PLS\_LEV3  
    Peripheral\_Registers\_Bits\_Definition, 872
- PWR\_CR\_PLS\_LEV4  
    Peripheral\_Registers\_Bits\_Definition, 872
- PWR\_CR\_PLS\_LEV5  
    Peripheral\_Registers\_Bits\_Definition, 872
- PWR\_CR\_PLS\_LEV6  
    Peripheral\_Registers\_Bits\_Definition, 872
- PWR\_CR\_PLS\_LEV7  
    Peripheral\_Registers\_Bits\_Definition, 872
- PWR\_CR\_PVDE  
    Peripheral\_Registers\_Bits\_Definition, 872
- PWR\_CR\_UDEN  
    Peripheral\_Registers\_Bits\_Definition, 872
- PWR\_CR\_UDEN\_0  
    Peripheral\_Registers\_Bits\_Definition, 873
- PWR\_CR\_UDEN\_1  
    Peripheral\_Registers\_Bits\_Definition, 873
- PWR\_CR\_VOS  
    Peripheral\_Registers\_Bits\_Definition, 873
- PWR\_CR\_VOS\_0  
    Peripheral\_Registers\_Bits\_Definition, 873
- PWR\_CR\_VOS\_1  
    Peripheral\_Registers\_Bits\_Definition, 873
- PWR\_CSR\_BRE  
    Peripheral\_Registers\_Bits\_Definition, 873
- PWR\_CSR\_BRR  
    Peripheral\_Registers\_Bits\_Definition, 873
- PWR\_CSR\_EWUP  
    Peripheral\_Registers\_Bits\_Definition, 874
- PWR\_CSR\_ODRDY  
    Peripheral\_Registers\_Bits\_Definition, 874
- PWR\_CSR\_ODSWRDY  
    Peripheral\_Registers\_Bits\_Definition, 874
- PWR\_CSR\_PVDO  
    Peripheral\_Registers\_Bits\_Definition, 874
- PWR\_CSR\_SBF  
    Peripheral\_Registers\_Bits\_Definition, 874
- PWR\_CSR\_UDSWRDY  
    Peripheral\_Registers\_Bits\_Definition, 874
- PWR\_CSR\_VOSRDY  
    Peripheral\_Registers\_Bits\_Definition, 874
- PWR\_CSR\_WUF  
    Peripheral\_Registers\_Bits\_Definition, 875
- PWR\_CSR\_WUPP  
    Peripheral\_Registers\_Bits\_Definition, 875
- PWR\_TypeDef, 1031
- Q
- ITM Functions, 141, 142
- RCC
- RCC Instance, 173
- RCC Bit Position Definitions, 206
- RCC Driver, 305
- RCC Instance, 172
- RCC, 173
- RCC Register Map, 163
- RCC\_AHB1LPENR Bit Position Definitions, 229
- RCC\_AHB1LPENR\_CRCEN, 229
- RCC\_AHB1LPENR\_DMA1LPEN, 230
- RCC\_AHB1LPENR\_DMA2LPEN, 230
- RCC\_AHB1LPENR\_ETHMACLPEN, 230
- RCC\_AHB1LPENR\_ETHMACPTPLPEN, 230
- RCC\_AHB1LPENR\_ETHMACRXLPEN, 230
- RCC\_AHB1LPENR\_ETHMACTXLPEN, 230
- RCC\_AHB1LPENR\_GPIOALPEN, 230
- RCC\_AHB1LPENR\_GPIOBLPEN, 230
- RCC\_AHB1LPENR\_GPIOCLPEN, 231
- RCC\_AHB1LPENR\_GPIODLPEN, 231
- RCC\_AHB1LPENR\_GPIOELPEN, 231
- RCC\_AHB1LPENR\_GPIOFLPEN, 231

- RCC\_AHB1LPENR\_GPIOGLPEN, [231](#)
- RCC\_AHB1LPENR\_GPIOHLPEN, [231](#)
- RCC\_AHB1LPENR\_GPIOILPEN, [231](#)
- RCC\_AHB1LPENR\_OTGHSHULPI, [231](#)
- RCC\_AHB1LPENR\_OTGHSLPEN, [232](#)
- RCC\_AHB1LPENR\_CRCEN
  - RCC\_AHB1LPENR Bit Position Definitions, [229](#)
- RCC\_AHB1LPENR\_DMA1LPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [230](#)
- RCC\_AHB1LPENR\_DMA2LPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [230](#)
- RCC\_AHB1LPENR\_ETHMACLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [230](#)
- RCC\_AHB1LPENR\_ETHMACPTPLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [230](#)
- RCC\_AHB1LPENR\_ETHMACRXLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [230](#)
- RCC\_AHB1LPENR\_ETHMACTXLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [230](#)
- RCC\_AHB1LPENR\_GPIOALPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [230](#)
- RCC\_AHB1LPENR\_GPIOBLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [230](#)
- RCC\_AHB1LPENR\_GPIOCLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [231](#)
- RCC\_AHB1LPENR\_GPIOFLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [231](#)
- RCC\_AHB1LPENR\_GPIOGLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [231](#)
- RCC\_AHB1LPENR\_GPIOHLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [231](#)
- RCC\_AHB1LPENR\_GPIOILPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [231](#)
- RCC\_AHB1LPENR\_OTGHSHULPI
  - RCC\_AHB1LPENR Bit Position Definitions, [231](#)
- RCC\_AHB1LPENR\_OTGHSLPEN
  - RCC\_AHB1LPENR Bit Position Definitions, [232](#)
- RCC\_AHB1RSTR Bit Position Definitions, [217](#)
  - RCC\_AHB1RSTR\_CRC, [218](#)
  - RCC\_AHB1RSTR\_DMA1, [218](#)
  - RCC\_AHB1RSTR\_DMA2, [218](#)
  - RCC\_AHB1RSTR\_ETHMAC, [218](#)
  - RCC\_AHB1RSTR\_GPIOA, [219](#)
  - RCC\_AHB1RSTR\_GPIOB, [219](#)
  - RCC\_AHB1RSTR\_GPIOC, [219](#)
  - RCC\_AHB1RSTR\_GPIOD, [219](#)
  - RCC\_AHB1RSTR\_GPIOE, [219](#)
  - RCC\_AHB1RSTR\_GPIOF, [219](#)
  - RCC\_AHB1RSTR\_GPIOG, [219](#)
  - RCC\_AHB1RSTR\_GPIOH, [219](#)
  - RCC\_AHB1RSTR\_GPIOI, [220](#)
  - RCC\_AHB1RSTR\_OTGHS, [220](#)
  - RCC\_AHB1RSTR\_OTGHSULPI, [220](#)
- RCC\_AHB1RSTR\_CRC
- RCC\_AHB1RSTR\_BIT POSITION DEFINITIONS
  - RCC\_AHB1RSTR Bit Position Definitions, [218](#)
- RCC\_AHB1RSTR\_DMA1
  - RCC\_AHB1RSTR Bit Position Definitions, [218](#)
- RCC\_AHB1RSTR\_DMA2
  - RCC\_AHB1RSTR Bit Position Definitions, [218](#)
- RCC\_AHB1RSTR\_ETHMAC
  - RCC\_AHB1RSTR Bit Position Definitions, [218](#)
- RCC\_AHB1RSTR\_ETHMACPTPLPEN
  - RCC\_AHB1RSTR Bit Position Definitions, [218](#)
- RCC\_AHB1RSTR\_GPIOA
  - RCC\_AHB1RSTR Bit Position Definitions, [219](#)
- RCC\_AHB1RSTR\_GPIOB
  - RCC\_AHB1RSTR Bit Position Definitions, [219](#)
- RCC\_AHB1RSTR\_GPIOC
  - RCC\_AHB1RSTR Bit Position Definitions, [219](#)
- RCC\_AHB1RSTR\_GPIOD
  - RCC\_AHB1RSTR Bit Position Definitions, [219](#)
- RCC\_AHB1RSTR\_GPIOE
  - RCC\_AHB1RSTR Bit Position Definitions, [219](#)
- RCC\_AHB1RSTR\_GPIOF
  - RCC\_AHB1RSTR Bit Position Definitions, [219](#)
- RCC\_AHB1RSTR\_GPIOG
  - RCC\_AHB1RSTR Bit Position Definitions, [219](#)
- RCC\_AHB1RSTR\_GPIOH
  - RCC\_AHB1RSTR Bit Position Definitions, [219](#)
- RCC\_AHB1RSTR\_OTGHS
  - RCC\_AHB1RSTR Bit Position Definitions, [220](#)
- RCC\_AHB1RSTR\_OTGHSULPI
  - RCC\_AHB1RSTR Bit Position Definitions, [220](#)
- RCC\_AHB2LPENR Bit Position Definitions, [232](#)
  - RCC\_AHB2LPENR\_CRYPLPEN, [232](#)
  - RCC\_AHB2LPENR\_DCMILPEN, [232](#)
  - RCC\_AHB2LPENR\_HASHLPEN, [233](#)
  - RCC\_AHB2LPENR\_OTGFSLPEN, [233](#)
  - RCC\_AHB2LPENR\_RNGLPEN, [233](#)
- RCC\_AHB2LPENR\_CRYPLPEN
  - RCC\_AHB2LPENR Bit Position Definitions, [232](#)
- RCC\_AHB2LPENR\_DCMILPEN
  - RCC\_AHB2LPENR Bit Position Definitions, [232](#)
- RCC\_AHB2LPENR\_HASHLPEN
  - RCC\_AHB2LPENR Bit Position Definitions, [233](#)
- RCC\_AHB2LPENR\_OTGFSLPEN
  - RCC\_AHB2LPENR Bit Position Definitions, [233](#)
- RCC\_AHB2LPENR\_RNGLPEN
  - RCC\_AHB2LPENR Bit Position Definitions, [233](#)
- RCC\_AHB2RSTR Bit Position Definitions, [220](#)
  - RCC\_AHB2RSTR\_CRYP, [221](#)
  - RCC\_AHB2RSTR\_DCMI, [221](#)
  - RCC\_AHB2RSTR\_HASH, [221](#)
  - RCC\_AHB2RSTR\_OTGFS, [221](#)
  - RCC\_AHB2RSTR RNG, [221](#)
- RCC\_AHB2RSTR\_CRYP
  - RCC\_AHB2RSTR Bit Position Definitions, [221](#)
- RCC\_AHB2RSTR\_DCMI
  - RCC\_AHB2RSTR Bit Position Definitions, [221](#)
- RCC\_AHB2RSTR\_HASH
  - RCC\_AHB2RSTR Bit Position Definitions, [221](#)
- RCC\_AHB2RSTR\_OTGFS

- RCC\_AHB2RSTR Bit Position Definitions, [221](#)
- RCC\_AHB2RSTR\_RNG
  - RCC\_AHB2RSTR Bit Position Definitions, [221](#)
- RCC\_AHB3LPENR Bit Position Definitions, [233](#)
  - RCC\_AHB3LPENR\_FSMCLPEN, [234](#)
- RCC\_AHB3LPENR\_FSMCLPEN
  - RCC\_AHB3LPENR Bit Position Definitions, [234](#)
- RCC\_AHB3RSTR Bit Position Definitions, [222](#)
  - RCC\_AHB3RSTR\_FSMC, [222](#)
- RCC\_AHB3RSTR\_FSMC
  - RCC\_AHB3RSTR Bit Position Definitions, [222](#)
- RCC\_APB1LPENR Bit Position Definitions, [234](#)
  - RCC\_APB1LPENR\_CAN1LPEN, [235](#)
  - RCC\_APB1LPENR\_CAN2LPEN, [235](#)
  - RCC\_APB1LPENR\_DACLPEN, [235](#)
  - RCC\_APB1LPENR\_I2C1LPEN, [235](#)
  - RCC\_APB1LPENR\_I2C2LPEN, [235](#)
  - RCC\_APB1LPENR\_I2C3LPEN, [235](#)
  - RCC\_APB1LPENR\_PWRLPEN, [235](#)
  - RCC\_APB1LPENR\_SPI2LPEN, [236](#)
  - RCC\_APB1LPENR\_SPI3LPEN, [236](#)
  - RCC\_APB1LPENR\_TIM12LPEN, [236](#)
  - RCC\_APB1LPENR\_TIM13LPEN, [236](#)
  - RCC\_APB1LPENR\_TIM14LPEN, [236](#)
  - RCC\_APB1LPENR\_TIM2LPEN, [236](#)
  - RCC\_APB1LPENR\_TIM3LPEN, [236](#)
  - RCC\_APB1LPENR\_TIM4LPEN, [236](#)
  - RCC\_APB1LPENR\_TIM5LPEN, [237](#)
  - RCC\_APB1LPENR\_TIM6LPEN, [237](#)
  - RCC\_APB1LPENR\_TIM7LPEN, [237](#)
  - RCC\_APB1LPENR\_UART4LPEN, [237](#)
  - RCC\_APB1LPENR\_UART5LPEN, [237](#)
  - RCC\_APB1LPENR\_UART7LPEN, [237](#)
  - RCC\_APB1LPENR\_UART8LPEN, [237](#)
  - RCC\_APB1LPENR\_USART2LPEN, [237](#)
  - RCC\_APB1LPENR\_USART3LPEN, [238](#)
  - RCC\_APB1LPENR\_WWDGLPEN, [238](#)
- RCC\_APB1LPENR\_CAN1LPEN
  - RCC\_APB1LPENR Bit Position Definitions, [235](#)
- RCC\_APB1LPENR\_CAN2LPEN
  - RCC\_APB1LPENR Bit Position Definitions, [235](#)
- RCC\_APB1LPENR\_DACLPEN
  - RCC\_APB1LPENR Bit Position Definitions, [235](#)
- RCC\_APB1LPENR\_I2C1LPEN
  - RCC\_APB1LPENR Bit Position Definitions, [235](#)
- RCC\_APB1LPENR\_I2C2LPEN
  - RCC\_APB1LPENR Bit Position Definitions, [235](#)
- RCC\_APB1LPENR\_I2C3LPEN
  - RCC\_APB1LPENR Bit Position Definitions, [235](#)
- RCC\_APB1LPENR\_PWRLPEN
  - RCC\_APB1LPENR Bit Position Definitions, [235](#)
- RCC\_APB1LPENR\_SPI2LPEN
  - RCC\_APB1LPENR Bit Position Definitions, [236](#)
- RCC\_APB1LPENR\_SPI3LPEN
  - RCC\_APB1LPENR Bit Position Definitions, [236](#)
- RCC\_APB1LPENR\_TIM12LPEN
  - RCC\_APB1LPENR Bit Position Definitions, [236](#)
- RCC\_APB1RSTR Bit Position Definitions, [222](#)
  - RCC\_APB1RSTR\_CAN1, [223](#)
  - RCC\_APB1RSTR\_CAN2, [223](#)
  - RCC\_APB1RSTR\_DAC, [223](#)
  - RCC\_APB1RSTR\_I2C1, [224](#)
  - RCC\_APB1RSTR\_I2C2, [224](#)
  - RCC\_APB1RSTR\_I2C3, [224](#)
  - RCC\_APB1RSTR\_PWR, [224](#)
  - RCC\_APB1RSTR\_SPI2, [224](#)
  - RCC\_APB1RSTR\_SPI3, [224](#)
  - RCC\_APB1RSTR\_TIM12, [224](#)
  - RCC\_APB1RSTR\_TIM13, [224](#)
  - RCC\_APB1RSTR\_TIM14, [225](#)
  - RCC\_APB1RSTR\_TIM2, [225](#)
  - RCC\_APB1RSTR\_TIM3, [225](#)
  - RCC\_APB1RSTR\_TIM4, [225](#)
  - RCC\_APB1RSTR\_TIM5, [225](#)
  - RCC\_APB1RSTR\_TIM6, [225](#)
  - RCC\_APB1RSTR\_TIM7, [225](#)
  - RCC\_APB1RSTR\_UART4, [225](#)
  - RCC\_APB1RSTR\_UART5, [226](#)
  - RCC\_APB1RSTR\_UART7, [226](#)
  - RCC\_APB1RSTR\_UART8, [226](#)
  - RCC\_APB1RSTR\_USART2, [226](#)
  - RCC\_APB1RSTR\_USART3, [226](#)
  - RCC\_APB1RSTR\_WWDG, [226](#)
- RCC\_APB1RSTR\_CAN1
  - RCC\_APB1RSTR Bit Position Definitions, [223](#)
- RCC\_APB1RSTR\_CAN2
  - RCC\_APB1RSTR Bit Position Definitions, [223](#)

RCC\_APB1RSTR Bit Position Definitions, [223](#)  
RCC\_APB1RSTR\_DAC  
  RCC\_APB1RSTR Bit Position Definitions, [223](#)  
RCC\_APB1RSTR\_I2C1  
  RCC\_APB1RSTR Bit Position Definitions, [224](#)  
RCC\_APB1RSTR\_I2C2  
  RCC\_APB1RSTR Bit Position Definitions, [224](#)  
RCC\_APB1RSTR\_I2C3  
  RCC\_APB1RSTR Bit Position Definitions, [224](#)  
RCC\_APB1RSTR\_PWR  
  RCC\_APB1RSTR Bit Position Definitions, [224](#)  
RCC\_APB1RSTR\_SPI2  
  RCC\_APB1RSTR Bit Position Definitions, [224](#)  
RCC\_APB1RSTR\_SPI3  
  RCC\_APB1RSTR Bit Position Definitions, [224](#)  
RCC\_APB1RSTR\_TIM12  
  RCC\_APB1RSTR Bit Position Definitions, [224](#)  
RCC\_APB1RSTR\_TIM13  
  RCC\_APB1RSTR Bit Position Definitions, [224](#)  
RCC\_APB1RSTR\_TIM14  
  RCC\_APB1RSTR Bit Position Definitions, [225](#)  
RCC\_APB1RSTR\_TIM2  
  RCC\_APB1RSTR Bit Position Definitions, [225](#)  
RCC\_APB1RSTR\_TIM3  
  RCC\_APB1RSTR Bit Position Definitions, [225](#)  
RCC\_APB1RSTR\_TIM4  
  RCC\_APB1RSTR Bit Position Definitions, [225](#)  
RCC\_APB1RSTR\_TIM5  
  RCC\_APB1RSTR Bit Position Definitions, [225](#)  
RCC\_APB1RSTR\_TIM6  
  RCC\_APB1RSTR Bit Position Definitions, [225](#)  
RCC\_APB1RSTR\_TIM7  
  RCC\_APB1RSTR Bit Position Definitions, [225](#)  
RCC\_APB1RSTR\_UART4  
  RCC\_APB1RSTR Bit Position Definitions, [225](#)  
RCC\_APB1RSTR\_UART5  
  RCC\_APB1RSTR Bit Position Definitions, [226](#)  
RCC\_APB1RSTR\_UART7  
  RCC\_APB1RSTR Bit Position Definitions, [226](#)  
RCC\_APB1RSTR\_UART8  
  RCC\_APB1RSTR Bit Position Definitions, [226](#)  
RCC\_APB1RSTR\_USART2  
  RCC\_APB1RSTR Bit Position Definitions, [226](#)  
RCC\_APB1RSTR\_USART3  
  RCC\_APB1RSTR Bit Position Definitions, [226](#)  
RCC\_APB1RSTR\_WWDG  
  RCC\_APB1RSTR Bit Position Definitions, [226](#)  
RCC\_APB2LPENR Bit Position Definitions, [238](#)  
  RCC\_APB2LPENR\_ADCLPEN, [239](#)  
  RCC\_APB2LPENR\_SDOLPEN, [239](#)  
  RCC\_APB2LPENR\_SPI1LPEN, [239](#)  
  RCC\_APB2LPENR\_SYSCFGLPEN, [239](#)  
  RCC\_APB2LPENR\_TIM10LPEN, [239](#)  
  RCC\_APB2LPENR\_TIM11LPEN, [239](#)  
  RCC\_APB2LPENR\_TIM1LPEN, [239](#)  
  RCC\_APB2LPENR\_TIM8LPEN, [240](#)  
  RCC\_APB2LPENR\_TIM9LPEN, [240](#)  
  RCC\_APB2LPENR\_USART1LPEN, [240](#)  
  RCC\_APB2LPENR\_USART6LPEN  
    RCC\_APB2LPENR Bit Position Definitions, [240](#)  
RCC\_APB2LPENR\_ADCLPEN  
  RCC\_APB2LPENR Bit Position Definitions, [239](#)  
RCC\_APB2LPENR\_SDOLPEN  
  RCC\_APB2LPENR Bit Position Definitions, [239](#)  
RCC\_APB2LPENR\_SPI1LPEN  
  RCC\_APB2LPENR Bit Position Definitions, [239](#)  
RCC\_APB2LPENR\_SYSCFGLPEN  
  RCC\_APB2LPENR Bit Position Definitions, [239](#)  
RCC\_APB2LPENR\_TIM10LPEN  
  RCC\_APB2LPENR Bit Position Definitions, [239](#)  
RCC\_APB2LPENR\_TIM11LPEN  
  RCC\_APB2LPENR Bit Position Definitions, [239](#)  
RCC\_APB2LPENR\_TIM1LPEN  
  RCC\_APB2LPENR Bit Position Definitions, [239](#)  
RCC\_APB2LPENR\_TIM8LPEN  
  RCC\_APB2LPENR Bit Position Definitions, [240](#)  
RCC\_APB2LPENR\_TIM9LPEN  
  RCC\_APB2LPENR Bit Position Definitions, [240](#)  
RCC\_APB2LPENR\_USART1LPEN  
  RCC\_APB2LPENR Bit Position Definitions, [240](#)  
RCC\_APB2LPENR\_USART6LPEN  
  RCC\_APB2LPENR Bit Position Definitions, [240](#)  
RCC\_APB2RSTR Bit Position Definitions, [227](#)  
  RCC\_APB2RSTR\_ADC, [227](#)  
  RCC\_APB2RSTR\_SDIO, [227](#)  
  RCC\_APB2RSTR\_SPI1, [227](#)  
  RCC\_APB2RSTR\_SYSCFG, [228](#)  
  RCC\_APB2RSTR\_TIM1, [228](#)  
  RCC\_APB2RSTR\_TIM10, [228](#)  
  RCC\_APB2RSTR\_TIM11, [228](#)  
  RCC\_APB2RSTR\_TIM8, [228](#)  
  RCC\_APB2RSTR\_TIM9, [228](#)  
  RCC\_APB2RSTR\_USART1, [228](#)  
  RCC\_APB2RSTR\_USART6, [228](#)  
RCC\_APB2RSTR\_ADC  
  RCC\_APB2RSTR Bit Position Definitions, [227](#)  
RCC\_APB2RSTR\_SDIO  
  RCC\_APB2RSTR Bit Position Definitions, [227](#)  
RCC\_APB2RSTR\_SPI1  
  RCC\_APB2RSTR Bit Position Definitions, [227](#)  
RCC\_APB2RSTR\_SYSCFG  
  RCC\_APB2RSTR Bit Position Definitions, [228](#)  
RCC\_APB2RSTR\_TIM1  
  RCC\_APB2RSTR Bit Position Definitions, [228](#)  
RCC\_APB2RSTR\_TIM10  
  RCC\_APB2RSTR Bit Position Definitions, [228](#)  
RCC\_APB2RSTR\_TIM11  
  RCC\_APB2RSTR Bit Position Definitions, [228](#)  
RCC\_APB2RSTR\_TIM8  
  RCC\_APB2RSTR Bit Position Definitions, [228](#)  
RCC\_APB2RSTR\_TIM9  
  RCC\_APB2RSTR Bit Position Definitions, [228](#)  
RCC\_APB2RSTR\_USART1  
  RCC\_APB2RSTR Bit Position Definitions, [228](#)  
RCC\_APB2RSTR\_USART6  
  RCC\_APB2RSTR Bit Position Definitions, [228](#)  
RCC\_BDCR Bit Position Definitions, [240](#)

RCC\_BDCR\_BDRST, [241](#)  
RCC\_BDCR\_LSEBYP, [241](#)  
RCC\_BDCR\_LSEON, [241](#)  
RCC\_BDCR\_LSERDY, [241](#)  
RCC\_BDCR\_RTCEN, [241](#)  
RCC\_BDCR\_RTCSEL, [241](#)  
RCC\_BDCR\_BDRST  
    RCC\_BDCR Bit Position Definitions, [241](#)  
RCC\_BDCR\_LSEBYP  
    RCC\_BDCR Bit Position Definitions, [241](#)  
RCC\_BDCR\_LSEON  
    RCC\_BDCR Bit Position Definitions, [241](#)  
RCC\_BDCR\_LSERDY  
    RCC\_BDCR Bit Position Definitions, [241](#)  
RCC\_BDCR\_RTCEN  
    RCC\_BDCR Bit Position Definitions, [241](#)  
RCC\_BDCR\_RTCSEL  
    RCC\_BDCR Bit Position Definitions, [241](#)  
RCC\_CFGR Bit Position Definitions, [211](#)  
    RCC\_CFGR\_HPRE, [212](#)  
    RCC\_CFGR\_I2SSRC, [212](#)  
    RCC\_CFGR\_MCO1, [212](#)  
    RCC\_CFGR\_MCO1PRE, [212](#)  
    RCC\_CFGR\_MCO2, [212](#)  
    RCC\_CFGR\_MCO2PRE, [213](#)  
    RCC\_CFGR\_PPREG1, [213](#)  
    RCC\_CFGR\_PPREG2, [213](#)  
    RCC\_CFGR\_RTCPRE, [213](#)  
    RCC\_CFGR\_SW, [213](#)  
    RCC\_CFGR\_SWS, [213](#)  
RCC\_CFGR\_HPRE  
    Peripheral Registers Bits Definition, [875](#)  
    RCC\_CFGR Bit Position Definitions, [212](#)  
RCC\_CFGR\_HPRE\_0  
    Peripheral Registers Bits Definition, [875](#)  
RCC\_CFGR\_HPRE\_1  
    Peripheral Registers Bits Definition, [875](#)  
RCC\_CFGR\_HPRE\_2  
    Peripheral Registers Bits Definition, [875](#)  
RCC\_CFGR\_HPRE\_3  
    Peripheral Registers Bits Definition, [875](#)  
RCC\_CFGR\_HPRE\_DIV1  
    Peripheral Registers Bits Definition, [876](#)  
RCC\_CFGR\_HPRE\_DIV128  
    Peripheral Registers Bits Definition, [876](#)  
RCC\_CFGR\_HPRE\_DIV16  
    Peripheral Registers Bits Definition, [876](#)  
RCC\_CFGR\_HPRE\_DIV2  
    Peripheral Registers Bits Definition, [876](#)  
RCC\_CFGR\_HPRE\_DIV256  
    Peripheral Registers Bits Definition, [876](#)  
RCC\_CFGR\_HPRE\_DIV4  
    Peripheral Registers Bits Definition, [876](#)  
RCC\_CFGR\_HPRE\_DIV512  
    Peripheral Registers Bits Definition, [876](#)  
RCC\_CFGR\_HPRE\_DIV64  
    Peripheral Registers Bits Definition, [876](#)  
RCC\_CFGR\_HPRE\_DIV8  
    Peripheral Registers Bits Definition, [877](#)  
RCC\_CFGR\_I2SSRC  
    RCC\_CFGR Bit Position Definitions, [212](#)  
RCC\_CFGR\_MCO1  
    RCC\_CFGR Bit Position Definitions, [212](#)  
RCC\_CFGR\_MCO1PRE  
    RCC\_CFGR Bit Position Definitions, [212](#)  
RCC\_CFGR\_MCO2  
    RCC\_CFGR Bit Position Definitions, [212](#)  
RCC\_CFGR\_MCO2PRE  
    RCC\_CFGR Bit Position Definitions, [213](#)  
RCC\_CFGR\_PPREG1  
    Peripheral Registers Bits Definition, [877](#)  
    RCC\_CFGR Bit Position Definitions, [213](#)  
RCC\_CFGR\_PPREG1\_0  
    Peripheral Registers Bits Definition, [877](#)  
RCC\_CFGR\_PPREG1\_1  
    Peripheral Registers Bits Definition, [877](#)  
RCC\_CFGR\_PPREG1\_2  
    Peripheral Registers Bits Definition, [877](#)  
RCC\_CFGR\_PPREG1\_DIV1  
    Peripheral Registers Bits Definition, [877](#)  
RCC\_CFGR\_PPREG1\_DIV16  
    Peripheral Registers Bits Definition, [877](#)  
RCC\_CFGR\_PPREG1\_DIV2  
    Peripheral Registers Bits Definition, [877](#)  
RCC\_CFGR\_PPREG1\_DIV4  
    Peripheral Registers Bits Definition, [878](#)  
RCC\_CFGR\_PPREG1\_DIV8  
    Peripheral Registers Bits Definition, [878](#)  
RCC\_CFGR\_PPREG2  
    Peripheral Registers Bits Definition, [878](#)  
    RCC\_CFGR Bit Position Definitions, [213](#)  
RCC\_CFGR\_PPREG2\_0  
    Peripheral Registers Bits Definition, [878](#)  
RCC\_CFGR\_PPREG2\_1  
    Peripheral Registers Bits Definition, [878](#)  
RCC\_CFGR\_PPREG2\_2  
    Peripheral Registers Bits Definition, [878](#)  
RCC\_CFGR\_PPREG2\_DIV1  
    Peripheral Registers Bits Definition, [878](#)  
RCC\_CFGR\_PPREG2\_DIV16  
    Peripheral Registers Bits Definition, [878](#)  
RCC\_CFGR\_PPREG2\_DIV2  
    Peripheral Registers Bits Definition, [879](#)  
RCC\_CFGR\_PPREG2\_DIV4  
    Peripheral Registers Bits Definition, [879](#)  
RCC\_CFGR\_PPREG2\_DIV8  
    Peripheral Registers Bits Definition, [879](#)  
RCC\_CFGR\_RTCPRE  
    RCC\_CFGR Bit Position Definitions, [213](#)  
RCC\_CFGR\_RTCPRE\_4  
    Peripheral Registers Bits Definition, [879](#)  
RCC\_CFGR\_SW  
    Peripheral Registers Bits Definition, [879](#)  
    RCC\_CFGR Bit Position Definitions, [213](#)  
RCC\_CFGR\_SW\_0  
    Peripheral Registers Bits Definition, [879](#)

RCC\_CFGR\_SW\_1  
  Peripheral\_Registers\_Bits\_Definition, [879](#)  
RCC\_CFGR\_SW\_HSE  
  Peripheral\_Registers\_Bits\_Definition, [879](#)  
RCC\_CFGR\_SW\_HSI  
  Peripheral\_Registers\_Bits\_Definition, [880](#)  
RCC\_CFGR\_SW\_PLL  
  Peripheral\_Registers\_Bits\_Definition, [880](#)  
RCC\_CFGR\_SWS  
  Peripheral\_Registers\_Bits\_Definition, [880](#)  
  RCC\_CFGR Bit Position Definitions, [213](#)  
RCC\_CFGR\_SWS\_0  
  Peripheral\_Registers\_Bits\_Definition, [880](#)  
RCC\_CFGR\_SWS\_1  
  Peripheral\_Registers\_Bits\_Definition, [880](#)  
RCC\_CFGR\_SWS\_HSE  
  Peripheral\_Registers\_Bits\_Definition, [880](#)  
RCC\_CFGR\_SWS\_HSI  
  Peripheral\_Registers\_Bits\_Definition, [880](#)  
RCC\_CFGR\_SWS\_PLL  
  Peripheral\_Registers\_Bits\_Definition, [880](#)  
RCC\_CIR Bit Position Definitions, [214](#)  
  RCC\_CIR\_CSSF, [214](#)  
  RCC\_CIR\_HSERDYC, [215](#)  
  RCC\_CIR\_HSERDYF, [215](#)  
  RCC\_CIR\_HSERDYIE, [215](#)  
  RCC\_CIR\_HSIRDYC, [215](#)  
  RCC\_CIR\_HSIRDYF, [215](#)  
  RCC\_CIR\_HSIRDYIE, [215](#)  
  RCC\_CIR\_LSERDYC, [215](#)  
  RCC\_CIR\_LSERDYF, [215](#)  
  RCC\_CIR\_LSERDYIE, [216](#)  
  RCC\_CIR\_LSIRDYC, [216](#)  
  RCC\_CIR\_LSIRDYF, [216](#)  
  RCC\_CIR\_LSIRDYIE, [216](#)  
  RCC\_CIR\_PLLI2SRDYC, [216](#)  
  RCC\_CIR\_PLLI2SRDYF, [216](#)  
  RCC\_CIR\_PLLI2SRDYIE, [216](#)  
  RCC\_CIR\_PLLRDYC, [216](#)  
  RCC\_CIR\_PLLRDYF, [217](#)  
  RCC\_CIR\_PLLRDYIE, [217](#)  
  RCC\_CIR\_PLLSAIRDYC, [217](#)  
  RCC\_CIR\_PLLSAIRDYF, [217](#)  
  RCC\_CIR\_PLLSAIRDYIE, [217](#)  
RCC\_CIR\_CSSF  
  RCC\_CIR Bit Position Definitions, [214](#)  
RCC\_CIR\_HSERDYC  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_HSERDYF  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_HSERDYIE  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_HSIRDYC  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_HSIRDYF  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_HSIRDYIE  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_HSIRDYC  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_HSIRDYF  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_HSIRDYIE  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_LSERDYC  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_LSERDYF  
  RCC\_CIR Bit Position Definitions, [215](#)  
RCC\_CIR\_LSERDYIE  
  RCC\_CIR Bit Position Definitions, [216](#)  
RCC\_CIR\_LSIRDYC  
  RCC\_CIR Bit Position Definitions, [216](#)  
RCC\_CIR\_LSIRDYF  
  RCC\_CIR Bit Position Definitions, [216](#)  
RCC\_CIR\_LSIRDYIE  
  RCC\_CIR Bit Position Definitions, [216](#)  
RCC\_CIR\_PLLI2SRDYC  
  RCC\_CIR Bit Position Definitions, [216](#)  
RCC\_CIR\_PLLI2SRDYF  
  RCC\_CIR Bit Position Definitions, [216](#)  
RCC\_CIR\_PLLI2SRDYIE  
  RCC\_CIR Bit Position Definitions, [216](#)  
RCC\_CIR\_PLLRDYC  
  RCC\_CIR Bit Position Definitions, [216](#)  
RCC\_CIR\_PLLRDYF  
  RCC\_CIR Bit Position Definitions, [217](#)  
RCC\_CIR\_PLLRDYIE  
  RCC\_CIR Bit Position Definitions, [217](#)  
RCC\_CIR\_PLLSAIRDYC  
  RCC\_CIR Bit Position Definitions, [217](#)  
RCC\_CIR\_PLLSAIRDYF  
  RCC\_CIR Bit Position Definitions, [217](#)  
RCC\_CIR\_PLLSAIRDYIE  
  RCC\_CIR Bit Position Definitions, [217](#)  
RCC\_CR Bit Position Definitions, [207](#)  
  RCC\_CR\_CSSON, [208](#)  
  RCC\_CR\_HSEBYP, [208](#)  
  RCC\_CR\_HSEON, [208](#)  
  RCC\_CR\_HSERDY, [208](#)  
  RCC\_CR\_HSICAL, [208](#)  
  RCC\_CR\_HSION, [209](#)  
  RCC\_CR\_HSIRDY, [209](#)  
  RCC\_CR\_HSITRIM, [209](#)  
  RCC\_CR\_PLLI2SON, [209](#)  
  RCC\_CR\_PLLI2SRDY, [209](#)  
  RCC\_CR\_PLLON, [209](#)  
  RCC\_CR\_PLLRDY, [209](#)  
  RCC\_CR\_PLLSAION, [209](#)  
  RCC\_CR\_PLLSAIRDY, [210](#)  
RCC\_CR\_CSSON  
  RCC\_CR Bit Position Definitions, [208](#)  
RCC\_CR\_HSEBYP  
  RCC\_CR Bit Position Definitions, [208](#)  
RCC\_CR\_HSEON  
  RCC\_CR Bit Position Definitions, [208](#)  
RCC\_CR\_HSERDY  
  RCC\_CR Bit Position Definitions, [208](#)  
RCC\_CR\_HSICAL  
  RCC\_CR Bit Position Definitions, [208](#)  
RCC\_CR\_HSICAL\_0  
  Peripheral\_Registers\_Bits\_Definition, [881](#)  
RCC\_CR\_HSICAL\_1

Peripheral\_Registers\_Bits\_Definition, 881  
RCC\_CR\_HSICAL\_2  
  Peripheral\_Registers\_Bits\_Definition, 881  
RCC\_CR\_HSICAL\_3  
  Peripheral\_Registers\_Bits\_Definition, 881  
RCC\_CR\_HSICAL\_4  
  Peripheral\_Registers\_Bits\_Definition, 881  
RCC\_CR\_HSICAL\_5  
  Peripheral\_Registers\_Bits\_Definition, 881  
RCC\_CR\_HSICAL\_6  
  Peripheral\_Registers\_Bits\_Definition, 881  
RCC\_CR\_HSICAL\_7  
  Peripheral\_Registers\_Bits\_Definition, 882  
RCC\_CR\_HSION  
  RCC\_CR Bit Position Definitions, 209  
RCC\_CR\_HSIRDY  
  RCC\_CR Bit Position Definitions, 209  
RCC\_CR\_HSITRIM  
  RCC\_CR Bit Position Definitions, 209  
RCC\_CR\_HSITRIM\_0  
  Peripheral\_Registers\_Bits\_Definition, 882  
RCC\_CR\_HSITRIM\_1  
  Peripheral\_Registers\_Bits\_Definition, 882  
RCC\_CR\_HSITRIM\_2  
  Peripheral\_Registers\_Bits\_Definition, 882  
RCC\_CR\_HSITRIM\_3  
  Peripheral\_Registers\_Bits\_Definition, 882  
RCC\_CR\_HSITRIM\_4  
  Peripheral\_Registers\_Bits\_Definition, 882  
RCC\_CR\_PLLI2SON  
  RCC\_CR Bit Position Definitions, 209  
RCC\_CR\_PLLI2SRDY  
  RCC\_CR Bit Position Definitions, 209  
RCC\_CR\_PLLON  
  RCC\_CR Bit Position Definitions, 209  
RCC\_CR\_PLLRDY  
  RCC\_CR Bit Position Definitions, 209  
RCC\_CR\_PLLSAION  
  RCC\_CR Bit Position Definitions, 209  
RCC\_CR\_PLLSAIRDY  
  RCC\_CR Bit Position Definitions, 210  
RCC\_CRC  
  Peripheral Selection, 308  
RCC\_CSR Bit Position Definitions, 242  
  RCC\_CSR\_IWDGRSTF, 242  
  RCC\_CSR\_LPWRSTF, 242  
  RCC\_CSR\_LSION, 243  
  RCC\_CSR\_LSIRDY, 243  
  RCC\_CSR\_OBLRSTF, 243  
  RCC\_CSR\_PINRSTF, 243  
  RCC\_CSR\_PORRSTF, 243  
  RCC\_CSR\_RMVF, 243  
  RCC\_CSR\_SFTRSTF, 243  
  RCC\_CSR\_WWDGRSTF, 243  
RCC\_CSR\_IWDGRSTF  
  RCC\_CSR Bit Position Definitions, 242  
RCC\_CSR\_LPWRSTF  
  RCC\_CSR Bit Position Definitions, 242  
RCC\_CSR\_LSION  
  RCC\_CSR Bit Position Definitions, 243  
RCC\_CSR\_LSIRDY  
  RCC\_CSR Bit Position Definitions, 243  
RCC\_CSR\_OBLRSTF  
  RCC\_CSR Bit Position Definitions, 243  
RCC\_CSR\_PINRSTF  
  RCC\_CSR Bit Position Definitions, 243  
RCC\_CSR\_PORRSTF  
  RCC\_CSR Bit Position Definitions, 243  
RCC\_CSR\_RMVF  
  RCC\_CSR Bit Position Definitions, 243  
RCC\_CSR\_SFTRSTF  
  RCC\_CSR Bit Position Definitions, 243  
RCC\_CSR\_WWDGRSTF  
  RCC\_CSR Bit Position Definitions, 243  
RCC\_GetPLLOutputClock  
  API Function Prototypes, 314  
RCC\_GPIOA  
  Peripheral Selection, 308  
RCC\_GPIOB  
  Peripheral Selection, 308  
RCC\_GPIOC  
  Peripheral Selection, 309  
RCC\_GPIOD  
  Peripheral Selection, 309  
RCC\_GPIOE  
  Peripheral Selection, 309  
RCC\_I2C1  
  Peripheral Selection, 309  
RCC\_I2C2  
  Peripheral Selection, 309  
RCC\_IRQn  
  Configuration\_section\_for\_CMSIS, 525  
RCC\_PLLCFG Bit Position Definitions, 210  
  RCC\_PLLCFG\_PLLM, 210  
  RCC\_PLLCFG\_PLLN, 211  
  RCC\_PLLCFG\_PLLP, 211  
  RCC\_PLLCFG\_PLLQ, 211  
  RCC\_PLLCFG\_PLLSRC, 211  
RCC\_PLLCFG\_PLLM  
  RCC\_PLLCFG Bit Position Definitions, 210  
RCC\_PLLCFG\_PLLN  
  RCC\_PLLCFG Bit Position Definitions, 211  
RCC\_PLLCFG\_PLLP  
  RCC\_PLLCFG Bit Position Definitions, 211  
RCC\_PLLCFG\_PLLQ  
  RCC\_PLLCFG Bit Position Definitions, 211  
RCC\_PLLCFG\_PLLSRC  
  RCC\_PLLCFG Bit Position Definitions, 211  
RCC\_PLLCFG\_PLLSRC\_HSE  
  Clock Source Selection, 307  
RCC\_PLLI2SCFGR Bit Position Definitions, 245  
  RCC\_PLLI2SCFGR\_PLLI2SN, 245  
  RCC\_PLLI2SCFGR\_PLLI2SR, 245  
RCC\_PLLI2SCFGR\_PLLI2SN  
  RCC\_PLLI2SCFGR Bit Position Definitions, 245  
RCC\_PLLI2SCFGR\_PLLI2SR

RCC\_PLLI2SCFGR Bit Position Definitions, [245](#)  
**RCC\_SELECT\_HSE**  
 Clock Source Selection, [307](#)  
**RCC\_SELECT\_HSI**  
 Clock Source Selection, [307](#)  
**RCC\_SELECT\_PLL**  
 Clock Source Selection, [307](#)  
**RCC\_SPI1**  
 Peripheral Selection, [309](#)  
**RCC\_SPI2**  
 Peripheral Selection, [309](#)  
**RCC\_SSCGR** Bit Position Definitions, [244](#)  
 RCC\_SSCGR\_INCSTEP, [244](#)  
 RCC\_SSCGR\_MODPER, [244](#)  
 RCC\_SSCGR\_SPREADSEL, [244](#)  
 RCC\_SSCGR\_SSCGEN, [245](#)  
**RCC\_SSCGR\_INCSTEP**  
 RCC\_SSCGR Bit Position Definitions, [244](#)  
**RCC\_SSCGR\_MODPER**  
 RCC\_SSCGR Bit Position Definitions, [244](#)  
**RCC\_SSCGR\_SPREADSEL**  
 RCC\_SSCGR Bit Position Definitions, [244](#)  
**RCC\_SSCGR\_SSCGEN**  
 RCC\_SSCGR Bit Position Definitions, [245](#)  
**RCC\_SYSCFG**  
 Peripheral Selection, [309](#)  
**RCC\_TIM2**  
 Peripheral Selection, [310](#)  
**RCC\_TypeDef**, [1032](#)  
 AHB1ENR, [1033](#)  
 AHB1LPENR, [1033](#)  
 AHB1RSTR, [1034](#)  
 AHB2ENR, [1034](#)  
 AHB2LPENR, [1034](#)  
 AHB2RSTR, [1034](#)  
 APB1ENR, [1034](#)  
 APB1LPENR, [1034](#)  
 APB1RSTR, [1034](#)  
 APB2ENR, [1034](#)  
 APB2LPENR, [1035](#)  
 APB2RSTR, [1035](#)  
 BDCR, [1035](#)  
 CFGR, [1035](#)  
 CIR, [1035](#)  
 CR, [1035](#)  
 CSR, [1035](#)  
 DCKCFGR, [1035](#)  
 PLLCFGR, [1036](#)  
 PLLI2SCFGR, [1036](#)  
 RESERVED0, [1036](#)  
 RESERVED1, [1036](#)  
 RESERVED2, [1036](#)  
 RESERVED3, [1036](#)  
 RESERVED4, [1036](#)  
 RESERVED5, [1036](#)  
 RESERVED6, [1037](#)  
 RESERVED7, [1037](#)  
 SSCGR, [1037](#)  
  
 RCC\_USART1  
 Peripheral Selection, [310](#)  
**RCC\_USART2**  
 Peripheral Selection, [310](#)  
**RCC\_USART6**  
 Peripheral Selection, [310](#)  
**RCR**  
 CMSIS, [500](#)  
 TIM1\_TypeDef, [1059](#)  
**RDHR**  
 CMSIS, [500](#)  
**RDLR**  
 CMSIS, [500](#)  
**RDTR**  
 CMSIS, [500](#)  
**reload\_value**  
 STK\_config\_t, [1053](#)  
**Repeated**  
 I2C Driver, [270](#)  
**Repeated\_Start**  
 I2C Driver, [270](#)  
**RESERVED**  
 CMSIS, [501](#)  
 CRC\_TypeDef, [1005](#)  
 SCB\_TypeDef, [1048](#)  
**Reserved**  
 S\_IRQ\_SRC, [1042](#)  
**RESERVED0**  
 CMSIS, [501, 502](#)  
 NVIC\_TypeDef, [1030](#)  
 RCC\_TypeDef, [1036](#)  
**RESERVED1**  
 CMSIS, [502–504](#)  
 NVIC\_TypeDef, [1030](#)  
 RCC\_TypeDef, [1036](#)  
 SYSCFG\_RegDef\_t, [1055](#)  
**RESERVED10**  
 CMSIS, [504](#)  
**RESERVED11**  
 CMSIS, [504](#)  
**RESERVED12**  
 CMSIS, [504](#)  
**RESERVED13**  
 CMSIS, [504](#)  
**RESERVED14**  
 CMSIS, [504](#)  
**RESERVED2**  
 CMSIS, [505](#)  
 NVIC\_TypeDef, [1031](#)  
 RCC\_TypeDef, [1036](#)  
 SYSCFG\_RegDef\_t, [1055](#)  
**RESERVED3**  
 CMSIS, [506](#)  
 NVIC\_TypeDef, [1031](#)  
 RCC\_TypeDef, [1036](#)  
**RESERVED4**  
 CMSIS, [507](#)  
 NVIC\_TypeDef, [1031](#)

RCC\_TypeDef, 1036  
RESERVED5  
  CMSIS, 507, 508  
  NVIC\_TypeDef, 1031  
  RCC\_TypeDef, 1036  
RESERVED6  
  CMSIS, 508, 509  
  RCC\_TypeDef, 1037  
RESERVED7  
  CMSIS, 509  
  RCC\_TypeDef, 1037  
RESERVED8  
  CMSIS, 510  
RESERVED9  
  CMSIS, 510  
RESET  
  Platform Standard Types, 152  
Reset  
  Exported\_types, 530  
  I2C Driver, 269  
RESP1  
  CMSIS, 510  
RESP2  
  CMSIS, 510  
RESP3  
  CMSIS, 511  
RESP4  
  CMSIS, 511  
RESPCMD  
  CMSIS, 511  
RF0R  
  CMSIS, 511  
RF1R  
  CMSIS, 511  
RIR  
  CMSIS, 511  
RISR  
  CMSIS, 511, 512  
RLR  
  CMSIS, 512  
RNG\_TypeDef, 1037  
Rows  
  LCD\_t, 1026  
RS\_PIN  
  LCD\_t, 1026  
RTC\_Alarm\_IRQHandler  
  Configuration\_section\_for\CMSIS, 526  
RTC\_TypeDef, 1038  
RTC\_WKUP\_IRQHandler  
  Configuration\_section\_for\CMSIS, 525  
RTSR  
  CMSIS, 512  
  EXTI\_TypeDef, 1013  
running\_mode  
  STK\_config\_t, 1053  
RXCRCR  
  CMSIS, 512  
  SPI\_TypeDef, 1051  
RXE  
  S\_IRQ\_SRC, 1042  
s32  
  Exported\_types, 528  
S\_I2C\_Config\_t, 1039  
  General\_Call\_Address\_Detection, 1039  
  I2C\_Ack\_Conrtol, 1040  
  I2C\_Mode, 1040  
  I2C\_Slave\_address, 1040  
  I2C\_Speed, 1040  
  I2C\_stretchmode, 1040  
  P\_Slave\_Event\_CallBack, 1040  
S\_I2C\_Slave\_address, 1041  
  Enable\_Dual\_Address, 1041  
  I2C\_Addressing\_Mode, 1041  
  PrimaryAddress, 1041  
  SecondaryAddress, 1041  
S\_IRQ\_SRC, 1042  
  ERRI, 1042  
  Reserved, 1042  
  RXE, 1042  
  TXE, 1042  
S\_SPI\_Config\_t, 1043  
  Clock\_Phase, 1043  
  Clock\_Polarity, 1043  
  Communication\_Mode, 1044  
  Device\_Mode, 1044  
  Frame\_Format, 1044  
  IRQ\_Enable, 1044  
  NSS, 1044  
  P\_IRQ\_CallBack, 1044  
  Payload\_Length, 1044  
  SPI\_Prescaler, 1044  
SAI\_Block\_TypeDef, 1045  
SAI\_GCR\_SYNCIN  
  Peripheral\_Registers\_Bits\_Definition, 882  
SAI\_GCR\_SYNCIN\_0  
  Peripheral\_Registers\_Bits\_Definition, 882  
SAI\_GCR\_SYNCIN\_1  
  Peripheral\_Registers\_Bits\_Definition, 883  
SAI\_GCR\_SYNCOUT  
  Peripheral\_Registers\_Bits\_Definition, 883  
SAI\_GCR\_SYNCOUT\_0  
  Peripheral\_Registers\_Bits\_Definition, 883  
SAI\_GCR\_SYNCOUT\_1  
  Peripheral\_Registers\_Bits\_Definition, 883  
SAI\_TypeDef, 1045  
SAI\_xCLRFR\_CAFSDET  
  Peripheral\_Registers\_Bits\_Definition, 883  
SAI\_xCLRFR\_CCNRDY  
  Peripheral\_Registers\_Bits\_Definition, 883  
SAI\_xCLRFR\_CFREQ  
  Peripheral\_Registers\_Bits\_Definition, 883  
SAI\_xCLRFR\_CLFSDET  
  Peripheral\_Registers\_Bits\_Definition, 884  
SAI\_xCLRFR\_CMUTEDET  
  Peripheral\_Registers\_Bits\_Definition, 884  
SAI\_xCLRFR\_COVRUDR

Peripheral\_Registers\_Bits\_Definition, 884  
SAI\_xCLRFR\_CWCKCFG  
    Peripheral\_Registers\_Bits\_Definition, 884  
SAI\_xCR1\_CKSTR  
    Peripheral\_Registers\_Bits\_Definition, 884  
SAI\_xCR1\_DMAEN  
    Peripheral\_Registers\_Bits\_Definition, 884  
SAI\_xCR1\_DS  
    Peripheral\_Registers\_Bits\_Definition, 884  
SAI\_xCR1\_DS\_0  
    Peripheral\_Registers\_Bits\_Definition, 885  
SAI\_xCR1\_DS\_1  
    Peripheral\_Registers\_Bits\_Definition, 885  
SAI\_xCR1\_DS\_2  
    Peripheral\_Registers\_Bits\_Definition, 885  
SAI\_xCR1\_LSBFIRST  
    Peripheral\_Registers\_Bits\_Definition, 885  
SAI\_xCR1\_MCKDIV  
    Peripheral\_Registers\_Bits\_Definition, 885  
SAI\_xCR1\_MCKDIV\_0  
    Peripheral\_Registers\_Bits\_Definition, 885  
SAI\_xCR1\_MCKDIV\_1  
    Peripheral\_Registers\_Bits\_Definition, 885  
SAI\_xCR1\_MCKDIV\_2  
    Peripheral\_Registers\_Bits\_Definition, 886  
SAI\_xCR1\_MCKDIV\_3  
    Peripheral\_Registers\_Bits\_Definition, 886  
SAI\_xCR1\_MODE  
    Peripheral\_Registers\_Bits\_Definition, 886  
SAI\_xCR1\_MODE\_0  
    Peripheral\_Registers\_Bits\_Definition, 886  
SAI\_xCR1\_MODE\_1  
    Peripheral\_Registers\_Bits\_Definition, 886  
SAI\_xCR1\_MONO  
    Peripheral\_Registers\_Bits\_Definition, 886  
SAI\_xCR1\_NODIV  
    Peripheral\_Registers\_Bits\_Definition, 886  
SAI\_xCR1\_OUTDRV  
    Peripheral\_Registers\_Bits\_Definition, 887  
SAI\_xCR1\_PRTCFG  
    Peripheral\_Registers\_Bits\_Definition, 887  
SAI\_xCR1\_PRTCFG\_0  
    Peripheral\_Registers\_Bits\_Definition, 887  
SAI\_xCR1\_PRTCFG\_1  
    Peripheral\_Registers\_Bits\_Definition, 887  
SAI\_xCR1\_SAIEN  
    Peripheral\_Registers\_Bits\_Definition, 887  
SAI\_xCR1\_SYNCEN  
    Peripheral\_Registers\_Bits\_Definition, 887  
SAI\_xCR1\_SYNCEN\_0  
    Peripheral\_Registers\_Bits\_Definition, 887  
SAI\_xCR1\_SYNCEN\_1  
    Peripheral\_Registers\_Bits\_Definition, 888  
SAI\_xCR2\_COMP  
    Peripheral\_Registers\_Bits\_Definition, 888  
SAI\_xCR2\_COMP\_0  
    Peripheral\_Registers\_Bits\_Definition, 888  
SAI\_xCR2\_COMP\_1  
    Peripheral\_Registers\_Bits\_Definition, 888  
SAI\_xCR2\_CPL  
    Peripheral\_Registers\_Bits\_Definition, 888  
SAI\_xCR2\_FFLUSH  
    Peripheral\_Registers\_Bits\_Definition, 888  
SAI\_xCR2\_FTH  
    Peripheral\_Registers\_Bits\_Definition, 888  
SAI\_xCR2\_FTH\_0  
    Peripheral\_Registers\_Bits\_Definition, 889  
SAI\_xCR2\_FTH\_1  
    Peripheral\_Registers\_Bits\_Definition, 889  
SAI\_xCR2\_MUTE  
    Peripheral\_Registers\_Bits\_Definition, 889  
SAI\_xCR2\_MUTECNT  
    Peripheral\_Registers\_Bits\_Definition, 889  
SAI\_xCR2\_MUTECNT\_0  
    Peripheral\_Registers\_Bits\_Definition, 889  
SAI\_xCR2\_MUTECNT\_1  
    Peripheral\_Registers\_Bits\_Definition, 889  
SAI\_xCR2\_MUTECNT\_2  
    Peripheral\_Registers\_Bits\_Definition, 889  
SAI\_xCR2\_MUTECNT\_3  
    Peripheral\_Registers\_Bits\_Definition, 890  
SAI\_xCR2\_MUTECNT\_4  
    Peripheral\_Registers\_Bits\_Definition, 890  
SAI\_xCR2\_MUTECNT\_5  
    Peripheral\_Registers\_Bits\_Definition, 890  
SAI\_xCR2\_MUTEVAL  
    Peripheral\_Registers\_Bits\_Definition, 890  
SAI\_xCR2\_TRIS  
    Peripheral\_Registers\_Bits\_Definition, 890  
SAI\_xFRCR\_FRL  
    Peripheral\_Registers\_Bits\_Definition, 890  
SAI\_xFRCR\_FRL\_0  
    Peripheral\_Registers\_Bits\_Definition, 890  
SAI\_xFRCR\_FRL\_1  
    Peripheral\_Registers\_Bits\_Definition, 891  
SAI\_xFRCR\_FRL\_2  
    Peripheral\_Registers\_Bits\_Definition, 891  
SAI\_xFRCR\_FRL\_3  
    Peripheral\_Registers\_Bits\_Definition, 891  
SAI\_xFRCR\_FRL\_4  
    Peripheral\_Registers\_Bits\_Definition, 891  
SAI\_xFRCR\_FRL\_5  
    Peripheral\_Registers\_Bits\_Definition, 891  
SAI\_xFRCR\_FRL\_6  
    Peripheral\_Registers\_Bits\_Definition, 891  
SAI\_xFRCR\_FRL\_7  
    Peripheral\_Registers\_Bits\_Definition, 891  
SAI\_xFRCR\_FSALL  
    Peripheral\_Registers\_Bits\_Definition, 891  
SAI\_xFRCR\_FSALL\_0  
    Peripheral\_Registers\_Bits\_Definition, 892  
SAI\_xFRCR\_FSALL\_1  
    Peripheral\_Registers\_Bits\_Definition, 892  
SAI\_xFRCR\_FSALL\_2  
    Peripheral\_Registers\_Bits\_Definition, 892  
SAI\_xFRCR\_FSALL\_3

Peripheral\_Registers\_Bits\_Definition, 892  
SAI\_xFRCR\_FSALL\_4  
Peripheral\_Registers\_Bits\_Definition, 892  
SAI\_xFRCR\_FSALL\_5  
Peripheral\_Registers\_Bits\_Definition, 892  
SAI\_xFRCR\_FSALL\_6  
Peripheral\_Registers\_Bits\_Definition, 892  
SAI\_xFRCR\_FSDEF  
Peripheral\_Registers\_Bits\_Definition, 893  
SAI\_xFRCR\_FSOFF  
Peripheral\_Registers\_Bits\_Definition, 893  
SAI\_xFRCR\_FSPOL  
Peripheral\_Registers\_Bits\_Definition, 893  
SAI\_xIMR\_AFSDETIE  
Peripheral\_Registers\_Bits\_Definition, 893  
SAI\_xIMR\_CNRDYIE  
Peripheral\_Registers\_Bits\_Definition, 893  
SAI\_xIMR\_FREQIE  
Peripheral\_Registers\_Bits\_Definition, 893  
SAI\_xIMR\_LFSDETIE  
Peripheral\_Registers\_Bits\_Definition, 893  
SAI\_xIMR\_MUTEDETIE  
Peripheral\_Registers\_Bits\_Definition, 894  
SAI\_xIMR\_OVRUDRIE  
Peripheral\_Registers\_Bits\_Definition, 894  
SAI\_xIMR\_WCKCFGIE  
Peripheral\_Registers\_Bits\_Definition, 894  
SAI\_xSLOTR\_FBOFF  
Peripheral\_Registers\_Bits\_Definition, 894  
SAI\_xSLOTR\_FBOFF\_0  
Peripheral\_Registers\_Bits\_Definition, 894  
SAI\_xSLOTR\_FBOFF\_1  
Peripheral\_Registers\_Bits\_Definition, 894  
SAI\_xSLOTR\_FBOFF\_2  
Peripheral\_Registers\_Bits\_Definition, 894  
SAI\_xSLOTR\_FBOFF\_3  
Peripheral\_Registers\_Bits\_Definition, 895  
SAI\_xSLOTR\_FBOFF\_4  
Peripheral\_Registers\_Bits\_Definition, 895  
SAI\_xSLOTR\_NBSLOT  
Peripheral\_Registers\_Bits\_Definition, 895  
SAI\_xSLOTR\_NBSLOT\_0  
Peripheral\_Registers\_Bits\_Definition, 895  
SAI\_xSLOTR\_NBSLOT\_1  
Peripheral\_Registers\_Bits\_Definition, 895  
SAI\_xSLOTR\_NBSLOT\_2  
Peripheral\_Registers\_Bits\_Definition, 895  
SAI\_xSLOTR\_NBSLOT\_3  
Peripheral\_Registers\_Bits\_Definition, 895  
SAI\_xSLOTR\_SLOTEN  
Peripheral\_Registers\_Bits\_Definition, 896  
SAI\_xSLOTR\_SLOTSZ  
Peripheral\_Registers\_Bits\_Definition, 896  
SAI\_xSLOTR\_SLOT SZ\_0  
Peripheral\_Registers\_Bits\_Definition, 896  
SAI\_xSLOTR\_SLOT SZ\_1  
Peripheral\_Registers\_Bits\_Definition, 896  
SAI\_xSR\_AFSDET  
Peripheral\_Registers\_Bits\_Definition, 896  
SAI\_xSR\_CNRDY  
Peripheral\_Registers\_Bits\_Definition, 896  
SAI\_xSR\_FLVL  
Peripheral\_Registers\_Bits\_Definition, 896  
SAI\_xSR\_FLVL\_0  
Peripheral\_Registers\_Bits\_Definition, 897  
SAI\_xSR\_FLVL\_1  
Peripheral\_Registers\_Bits\_Definition, 897  
SAI\_xSR\_FLVL\_2  
Peripheral\_Registers\_Bits\_Definition, 897  
SAI\_xSR\_FREQ  
Peripheral\_Registers\_Bits\_Definition, 897  
SAI\_xSR\_LFSDET  
Peripheral\_Registers\_Bits\_Definition, 897  
SAI\_xSR\_MUTEDET  
Peripheral\_Registers\_Bits\_Definition, 897  
SAI\_xSR\_OVRUDR  
Peripheral\_Registers\_Bits\_Definition, 897  
SAI\_xSR\_WCKCFG  
Peripheral\_Registers\_Bits\_Definition, 898  
sc16  
Exported\_types, 528  
sc32  
Exported\_types, 528  
sc8  
Exported\_types, 528  
SCB  
CMSIS, 423  
Core Definitions, 110  
SCB Instance, 170  
SCB Instance, 169  
SCB, 170  
SCB Register Map, 162  
SCB\_AIRCR\_ENDIANESS\_Msk  
CMSIS, 423  
System Control Block (SCB), 53  
SCB\_AIRCR\_ENDIANESS\_Pos  
CMSIS, 423  
System Control Block (SCB), 53  
SCB\_AIRCR\_PRIGROUP\_Msk  
CMSIS, 423  
System Control Block (SCB), 53  
SCB\_AIRCR\_PRIGROUP\_Pos  
CMSIS, 423  
System Control Block (SCB), 53  
SCB\_AIRCR\_SYSRESETREQ\_Msk  
CMSIS, 423  
System Control Block (SCB), 53  
SCB\_AIRCR\_SYSRESETREQ\_Pos  
CMSIS, 423  
System Control Block (SCB), 54  
SCB\_AIRCR\_VECTCLRACTIVE\_Msk  
CMSIS, 424  
System Control Block (SCB), 54  
SCB\_AIRCR\_VECTCLRACTIVE\_Pos  
CMSIS, 424  
System Control Block (SCB), 54

SCB\_AIRCR\_VECTKEY\_Msk  
CMSIS, 424  
System Control Block (SCB), 54

SCB\_AIRCR\_VECTKEY\_Pos  
CMSIS, 424  
System Control Block (SCB), 54

SCB\_AIRCR\_VECTKEYSTAT\_Msk  
CMSIS, 424  
System Control Block (SCB), 54

SCB\_AIRCR\_VECTKEYSTAT\_Pos  
CMSIS, 424  
System Control Block (SCB), 54

SCB\_AIRCR\_VECTRESET\_Msk  
CMSIS, 424  
System Control Block (SCB), 54

SCB\_AIRCR\_VECTRESET\_Pos  
CMSIS, 424  
System Control Block (SCB), 55

SCB\_BASE  
CMSIS, 425  
Core Definitions, 110

SCB\_CCR\_BFHFNIGN\_Msk  
CMSIS, 425  
System Control Block (SCB), 55

SCB\_CCR\_BFHFNIGN\_Pos  
CMSIS, 425  
System Control Block (SCB), 55

SCB\_CCR\_DIV\_0\_TRP\_Msk  
CMSIS, 425  
System Control Block (SCB), 55

SCB\_CCR\_DIV\_0\_TRP\_Pos  
CMSIS, 425  
System Control Block (SCB), 55

SCB\_CCR\_NONBASETHRDENA\_Msk  
CMSIS, 425  
System Control Block (SCB), 55

SCB\_CCR\_NONBASETHRDENA\_Pos  
CMSIS, 425  
System Control Block (SCB), 55

SCB\_CCR\_STKALIGN\_Msk  
CMSIS, 426  
System Control Block (SCB), 55

SCB\_CCR\_STKALIGN\_Pos  
CMSIS, 426  
System Control Block (SCB), 56

SCB\_CCR\_UNALIGN\_TRP\_Msk  
CMSIS, 426  
System Control Block (SCB), 56

SCB\_CCR\_UNALIGN\_TRP\_Pos  
CMSIS, 426  
System Control Block (SCB), 56

SCB\_CCR\_USERSETMPEND\_Msk  
CMSIS, 426  
System Control Block (SCB), 56

SCB\_CCR\_USERSETMPEND\_Pos  
CMSIS, 426  
System Control Block (SCB), 56

SCB\_CFSR\_BUSFAULTSR\_Msk  
CMSIS, 426  
System Control Block (SCB), 56

SCB\_CFSR\_BUSFAULTSR\_Pos  
CMSIS, 426  
System Control Block (SCB), 56

SCB\_CFSR\_MEMFAULTSR\_Msk  
CMSIS, 427  
System Control Block (SCB), 56

SCB\_CFSR\_MEMFAULTSR\_Pos  
CMSIS, 427  
System Control Block (SCB), 57

SCB\_CFSR\_USGFAULTSR\_Msk  
CMSIS, 427  
System Control Block (SCB), 57

SCB\_CFSR\_USGFAULTSR\_Pos  
CMSIS, 427  
System Control Block (SCB), 57

SCB\_CPUID\_ARCHITECTURE\_Msk  
CMSIS, 427  
System Control Block (SCB), 57

SCB\_CPUID\_ARCHITECTURE\_Pos  
CMSIS, 427  
System Control Block (SCB), 57

SCB\_CPUID\_IMPLEMENTER\_Msk  
CMSIS, 427  
System Control Block (SCB), 57

SCB\_CPUID\_IMPLEMENTER\_Pos  
CMSIS, 427  
System Control Block (SCB), 57

SCB\_CPUID\_PARTNO\_Msk  
CMSIS, 428  
System Control Block (SCB), 57

SCB\_CPUID\_PARTNO\_Pos  
CMSIS, 428  
System Control Block (SCB), 58

SCB\_CPUID\_REVISION\_Msk  
CMSIS, 428  
System Control Block (SCB), 58

SCB\_CPUID\_REVISION\_Pos  
CMSIS, 428  
System Control Block (SCB), 58

SCB\_CPUID\_VARIANT\_Msk  
CMSIS, 428  
System Control Block (SCB), 58

SCB\_CPUID\_VARIANT\_Pos  
CMSIS, 428  
System Control Block (SCB), 58

SCB\_DFSR\_BKPT\_Msk  
CMSIS, 428  
System Control Block (SCB), 58

SCB\_DFSR\_BKPT\_Pos  
CMSIS, 428  
System Control Block (SCB), 58

SCB\_DFSR\_DWTTRAP\_Msk  
CMSIS, 429  
System Control Block (SCB), 58

SCB\_DFSR\_DWTTRAP\_Pos  
CMSIS, 429  
System Control Block (SCB), 58

System Control Block (SCB), 59  
SCB\_DFSR\_EXTERNAL\_Msk  
CMSIS, 429  
System Control Block (SCB), 59  
SCB\_DFSR\_EXTERNAL\_Pos  
CMSIS, 429  
System Control Block (SCB), 59  
SCB\_DFSR\_HALTED\_Msk  
CMSIS, 429  
System Control Block (SCB), 59  
SCB\_DFSR\_HALTED\_Pos  
CMSIS, 429  
System Control Block (SCB), 59  
SCB\_DFSR\_VCATCH\_Msk  
CMSIS, 429  
System Control Block (SCB), 59  
SCB\_DFSR\_VCATCH\_Pos  
CMSIS, 429  
System Control Block (SCB), 59  
SCB\_HFSR\_DEBUGEVT\_Msk  
CMSIS, 430  
System Control Block (SCB), 59  
SCB\_HFSR\_DEBUGEVT\_Pos  
CMSIS, 430  
System Control Block (SCB), 60  
SCB\_HFSR\_FORCED\_Msk  
CMSIS, 430  
System Control Block (SCB), 60  
SCB\_HFSR\_FORCED\_Pos  
CMSIS, 430  
System Control Block (SCB), 60  
SCB\_HFSR\_VECTTBL\_Msk  
CMSIS, 430  
System Control Block (SCB), 60  
SCB\_HFSR\_VECTTBL\_Pos  
CMSIS, 430  
System Control Block (SCB), 60  
SCB\_ICSR\_ISRPENDING\_Msk  
CMSIS, 430  
System Control Block (SCB), 60  
SCB\_ICSR\_ISRPENDING\_Pos  
CMSIS, 430  
System Control Block (SCB), 60  
SCB\_ICSR\_ISRPREEMPT\_Msk  
CMSIS, 431  
System Control Block (SCB), 60  
SCB\_ICSR\_ISRPREEMPT\_Pos  
CMSIS, 431  
System Control Block (SCB), 61  
SCB\_ICSR\_NMIPENDSET\_Msk  
CMSIS, 431  
System Control Block (SCB), 61  
SCB\_ICSR\_NMIPENDSET\_Pos  
CMSIS, 431  
System Control Block (SCB), 61  
SCB\_ICSR\_PENDSTCLR\_Msk  
CMSIS, 431  
System Control Block (SCB), 61  
SCB\_ICSR\_PENDSTCLR\_Pos  
CMSIS, 431  
System Control Block (SCB), 61  
SCB\_ICSR\_PENDSTSET\_Msk  
CMSIS, 431  
System Control Block (SCB), 61  
SCB\_ICSR\_PENDSTSET\_Pos  
CMSIS, 431  
System Control Block (SCB), 61  
SCB\_ICSR\_PENDSVCLR\_Msk  
CMSIS, 432  
System Control Block (SCB), 61  
SCB\_ICSR\_PENDSVCLR\_Pos  
CMSIS, 432  
System Control Block (SCB), 62  
SCB\_ICSR\_PENDSVSET\_Msk  
CMSIS, 432  
System Control Block (SCB), 62  
SCB\_ICSR\_PENDSVSET\_Pos  
CMSIS, 432  
System Control Block (SCB), 62  
SCB\_ICSR\_RETTOBASE\_Msk  
CMSIS, 432  
System Control Block (SCB), 62  
SCB\_ICSR\_RETTOBASE\_Pos  
CMSIS, 432  
System Control Block (SCB), 62  
SCB\_ICSR\_VECTACTIVE\_Msk  
CMSIS, 432  
System Control Block (SCB), 62  
SCB\_ICSR\_VECTACTIVE\_Pos  
CMSIS, 432  
System Control Block (SCB), 62  
SCB\_ICSR\_VECTPENDING\_Msk  
CMSIS, 433  
System Control Block (SCB), 62  
SCB\_ICSR\_VECTPENDING\_Pos  
CMSIS, 433  
System Control Block (SCB), 63  
SCB\_SCR\_SEVONPEND\_Msk  
CMSIS, 433  
System Control Block (SCB), 63  
SCB\_SCR\_SEVONPEND\_Pos  
CMSIS, 433  
System Control Block (SCB), 63  
SCB\_SCR\_SLEEPDEEP\_Msk  
CMSIS, 433  
System Control Block (SCB), 63  
SCB\_SCR\_SLEEPDEEP\_Pos  
CMSIS, 433  
System Control Block (SCB), 63  
SCB\_SCR\_SLEEPONEXIT\_Msk  
CMSIS, 433  
System Control Block (SCB), 63  
SCB\_SCR\_SLEEPONEXIT\_Pos  
CMSIS, 433  
System Control Block (SCB), 63  
SCB\_SHCSR\_BUSFAULTACT\_Msk

CMSIS, 434  
 System Control Block (SCB), 63  
**SCB\_SHCSR\_BUSFAULTACT\_Pos**  
 CMSIS, 434  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_BUSFAULTENA\_Msk**  
 CMSIS, 434  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_BUSFAULTENA\_Pos**  
 CMSIS, 434  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_BUSFAULTPENDED\_Msk**  
 CMSIS, 434  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_BUSFAULTPENDED\_Pos**  
 CMSIS, 434  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_MEMFAULTACT\_Msk**  
 CMSIS, 434  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_MEMFAULTACT\_Pos**  
 CMSIS, 434  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_MEMFAULTENA\_Msk**  
 CMSIS, 435  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_MEMFAULTENA\_Pos**  
 CMSIS, 435  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_MEMFAULTPENDED\_Msk**  
 CMSIS, 435  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_MEMFAULTPENDED\_Pos**  
 CMSIS, 435  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_MONITORACT\_Msk**  
 CMSIS, 435  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_MONITORACT\_Pos**  
 CMSIS, 435  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_PENDSVACT\_Msk**  
 CMSIS, 435  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_PENDSVACT\_Pos**  
 CMSIS, 435  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_SVCALLACT\_Msk**  
 CMSIS, 436  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_SVCALLACT\_Pos**  
 CMSIS, 436  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_SVCALLPENDED\_Msk**  
 CMSIS, 436  
 System Control Block (SCB), 64  
**SCB\_SHCSR\_SVCALLPENDED\_Pos**  
 CMSIS, 436  
**System Control Block (SCB)**, 66  
**SCB\_SHCSR\_SYSTICKACT\_Msk**  
 CMSIS, 436  
 System Control Block (SCB), 66  
**SCB\_SHCSR\_SYSTICKACT\_Pos**  
 CMSIS, 436  
 System Control Block (SCB), 66  
**SCB\_SHCSR\_USGFAULTACT\_Msk**  
 CMSIS, 436  
 System Control Block (SCB), 66  
**SCB\_SHCSR\_USGFAULTACT\_Pos**  
 CMSIS, 436  
 System Control Block (SCB), 66  
**SCB\_SHCSR\_USGFAULTENA\_Msk**  
 CMSIS, 437  
 System Control Block (SCB), 66  
**SCB\_SHCSR\_USGFAULTENA\_Pos**  
 CMSIS, 437  
 System Control Block (SCB), 67  
**SCB\_SHCSR\_USGFAULTPENDED\_Msk**  
 CMSIS, 437  
 System Control Block (SCB), 67  
**SCB\_SHCSR\_USGFAULTPENDED\_Pos**  
 CMSIS, 437  
 System Control Block (SCB), 67  
**SCB\_Type**, 1046  
**SCB\_TypeDef**, 1046  
 AIRCR, 1047  
 BFAR, 1047  
 CCR, 1047  
 CFSR, 1047  
 CPUID, 1047  
 HFSR, 1047  
 ICSR, 1047  
 MMAR, 1047  
 RESERVED, 1048  
 SCR, 1048  
 SHCSR, 1048  
 SHP, 1048  
 VTOR, 1048  
**SCB\_VTOR\_TBLOFF\_Msk**  
 CMSIS, 437  
 System Control Block (SCB), 67  
**SCB\_VTOR\_TBLOFF\_Pos**  
 CMSIS, 437  
 System Control Block (SCB), 67  
**SCnSCB**  
 CMSIS, 437  
 Core Definitions, 110  
**SCnSCB\_ACTLR\_DISDEFWBUF\_Msk**  
 CMSIS, 437  
 System Controls not in SCB (SCnSCB), 68  
**SCnSCB\_ACTLR\_DISDEFWBUF\_Pos**  
 CMSIS, 438  
 System Controls not in SCB (SCnSCB), 68  
**SCnSCB\_ACTLR\_DISFOLD\_Msk**  
 CMSIS, 438  
 System Controls not in SCB (SCnSCB), 68

SCnSCB\_ACTLR\_DISFOLD\_Pos  
  CMSIS, [438](#)  
  System Controls not in SCB (SCnSCB), [68](#)

SCnSCB\_ACTLR\_DISFPCA\_Msk  
  CMSIS, [438](#)  
  System Controls not in SCB (SCnSCB), [69](#)

SCnSCB\_ACTLR\_DISFPCA\_Pos  
  CMSIS, [438](#)  
  System Controls not in SCB (SCnSCB), [69](#)

SCnSCB\_ACTLR\_DISMCYCINT\_Msk  
  CMSIS, [438](#)  
  System Controls not in SCB (SCnSCB), [69](#)

SCnSCB\_ACTLR\_DISMCYCINT\_Pos  
  CMSIS, [438](#)  
  System Controls not in SCB (SCnSCB), [69](#)

SCnSCB\_ACTLR\_DISOOFP\_Msk  
  CMSIS, [438](#)  
  System Controls not in SCB (SCnSCB), [69](#)

SCnSCB\_ACTLR\_DISOOFP\_Pos  
  CMSIS, [439](#)  
  System Controls not in SCB (SCnSCB), [69](#)

SCnSCB\_ICTR\_INTLINESNUM\_Msk  
  CMSIS, [439](#)  
  System Controls not in SCB (SCnSCB), [69](#)

SCnSCB\_ICTR\_INTLINESNUM\_Pos  
  CMSIS, [439](#)  
  System Controls not in SCB (SCnSCB), [69](#)

SCnSCB\_Type, [1048](#)

SCR  
  ITM Functions, [142](#)  
  SCB\_TypeDef, [1048](#)

SCS\_BASE  
  CMSIS, [439](#)  
  Core Definitions, [110](#)

SDIO\_ARG\_CMDARG  
  Peripheral\_Registers\_Bits\_Definition, [898](#)

SDIO\_CLKCR\_BYPASS  
  Peripheral\_Registers\_Bits\_Definition, [898](#)

SDIO\_CLKCR\_CLKDIV  
  Peripheral\_Registers\_Bits\_Definition, [898](#)

SDIO\_CLKCR\_CLKEN  
  Peripheral\_Registers\_Bits\_Definition, [898](#)

SDIO\_CLKCR\_HWFC\_EN  
  Peripheral\_Registers\_Bits\_Definition, [898](#)

SDIO\_CLKCR\_NEGEDGE  
  Peripheral\_Registers\_Bits\_Definition, [898](#)

SDIO\_CLKCR\_PWRSAV  
  Peripheral\_Registers\_Bits\_Definition, [899](#)

SDIO\_CLKCR\_WIDBUS  
  Peripheral\_Registers\_Bits\_Definition, [899](#)

SDIO\_CLKCR\_WIDBUS\_0  
  Peripheral\_Registers\_Bits\_Definition, [899](#)

SDIO\_CLKCR\_WIDBUS\_1  
  Peripheral\_Registers\_Bits\_Definition, [899](#)

SDIO\_CMD\_CEATACMD  
  Peripheral\_Registers\_Bits\_Definition, [899](#)

SDIO\_CMD\_CMDINDEX  
  Peripheral\_Registers\_Bits\_Definition, [899](#)

SDIO\_CMD\_CPSMEN  
  Peripheral\_Registers\_Bits\_Definition, [899](#)

SDIO\_CMD\_ENCMDCOMPL  
  Peripheral\_Registers\_Bits\_Definition, [900](#)

SDIO\_CMD\_NIEN  
  Peripheral\_Registers\_Bits\_Definition, [900](#)

SDIO\_CMD\_SDIOSUSPEND  
  Peripheral\_Registers\_Bits\_Definition, [900](#)

SDIO\_CMD\_WAITINT  
  Peripheral\_Registers\_Bits\_Definition, [900](#)

SDIO\_CMD\_WAITPEND  
  Peripheral\_Registers\_Bits\_Definition, [900](#)

SDIO\_CMD\_WAITRESP  
  Peripheral\_Registers\_Bits\_Definition, [900](#)

SDIO\_CMD\_WAITRESP\_0  
  Peripheral\_Registers\_Bits\_Definition, [900](#)

SDIO\_CMD\_WAITRESP\_1  
  Peripheral\_Registers\_Bits\_Definition, [901](#)

SDIO\_DCOUNT\_DATACOUNT  
  Peripheral\_Registers\_Bits\_Definition, [901](#)

SDIO\_DCTRL\_DBLOCKSIZE  
  Peripheral\_Registers\_Bits\_Definition, [901](#)

SDIO\_DCTRL\_DBLOCKSIZE\_0  
  Peripheral\_Registers\_Bits\_Definition, [901](#)

SDIO\_DCTRL\_DBLOCKSIZE\_1  
  Peripheral\_Registers\_Bits\_Definition, [901](#)

SDIO\_DCTRL\_DBLOCKSIZE\_2  
  Peripheral\_Registers\_Bits\_Definition, [901](#)

SDIO\_DCTRL\_DBLOCKSIZE\_3  
  Peripheral\_Registers\_Bits\_Definition, [901](#)

SDIO\_DCTRL\_DMAEN  
  Peripheral\_Registers\_Bits\_Definition, [901](#)

SDIO\_DCTRL\_DTDIR  
  Peripheral\_Registers\_Bits\_Definition, [902](#)

SDIO\_DCTRL\_DTEN  
  Peripheral\_Registers\_Bits\_Definition, [902](#)

SDIO\_DCTRL\_DTMODE  
  Peripheral\_Registers\_Bits\_Definition, [902](#)

SDIO\_DCTRL\_RWMOD  
  Peripheral\_Registers\_Bits\_Definition, [902](#)

SDIO\_DCTRL\_RWSTART  
  Peripheral\_Registers\_Bits\_Definition, [902](#)

SDIO\_DCTRL\_RWSTOP  
  Peripheral\_Registers\_Bits\_Definition, [902](#)

SDIO\_DCTRL\_SDIOEN  
  Peripheral\_Registers\_Bits\_Definition, [902](#)

SDIO\_DLLEN\_DATALENGTH  
  Peripheral\_Registers\_Bits\_Definition, [903](#)

SDIO\_DTIMER\_DATETIME  
  Peripheral\_Registers\_Bits\_Definition, [903](#)

SDIO\_FIFO\_FIFODATA  
  Peripheral\_Registers\_Bits\_Definition, [903](#)

SDIO\_FIFOCNT\_FIFOCOUNT  
  Peripheral\_Registers\_Bits\_Definition, [903](#)

SDIO\_ICR\_CCRCFAILC  
  Peripheral\_Registers\_Bits\_Definition, [903](#)

SDIO\_ICR\_CEATAENDC  
  Peripheral\_Registers\_Bits\_Definition, [903](#)

SDIO\_ICR\_CMDRENDC  
    Peripheral\_Registers\_Bits\_Definition, 903  
SDIO\_ICR\_CMDSENTC  
    Peripheral\_Registers\_Bits\_Definition, 904  
SDIO\_ICR\_CTIMEOUTC  
    Peripheral\_Registers\_Bits\_Definition, 904  
SDIO\_ICR\_DATAENDC  
    Peripheral\_Registers\_Bits\_Definition, 904  
SDIO\_ICR\_DBCKENDC  
    Peripheral\_Registers\_Bits\_Definition, 904  
SDIO\_ICR\_DCRCFAILC  
    Peripheral\_Registers\_Bits\_Definition, 904  
SDIO\_ICR\_DTIMEOUTC  
    Peripheral\_Registers\_Bits\_Definition, 904  
SDIO\_ICR\_RXOVERRC  
    Peripheral\_Registers\_Bits\_Definition, 904  
SDIO\_ICR\_SDIOITC  
    Peripheral\_Registers\_Bits\_Definition, 905  
SDIO\_ICR\_STBITERRC  
    Peripheral\_Registers\_Bits\_Definition, 905  
SDIO\_ICR\_TXUNDERRC  
    Peripheral\_Registers\_Bits\_Definition, 905  
SDIO IRQn  
    Configuration\_section\_for\CMSIS, 526  
SDIO\_MASK\_CCRCFAILIE  
    Peripheral\_Registers\_Bits\_Definition, 905  
SDIO\_MASK\_CEATAENDIE  
    Peripheral\_Registers\_Bits\_Definition, 905  
SDIO\_MASK\_CMDACTIE  
    Peripheral\_Registers\_Bits\_Definition, 905  
SDIO\_MASK\_CMDRENIE  
    Peripheral\_Registers\_Bits\_Definition, 905  
SDIO\_MASK\_CMDSENTIE  
    Peripheral\_Registers\_Bits\_Definition, 906  
SDIO\_MASK\_CTIMEOUTIE  
    Peripheral\_Registers\_Bits\_Definition, 906  
SDIO\_MASK\_DATAENDIE  
    Peripheral\_Registers\_Bits\_Definition, 906  
SDIO\_MASK\_DBCKENDIE  
    Peripheral\_Registers\_Bits\_Definition, 906  
SDIO\_MASK\_DCRCFAILIE  
    Peripheral\_Registers\_Bits\_Definition, 906  
SDIO\_MASK\_DTIMEOUTIE  
    Peripheral\_Registers\_Bits\_Definition, 906  
SDIO\_MASK\_RXACTIE  
    Peripheral\_Registers\_Bits\_Definition, 906  
SDIO\_MASK\_RXDAVLIE  
    Peripheral\_Registers\_Bits\_Definition, 907  
SDIO\_MASK\_RXFIFOEIE  
    Peripheral\_Registers\_Bits\_Definition, 907  
SDIO\_MASK\_RXFIFOFIE  
    Peripheral\_Registers\_Bits\_Definition, 907  
SDIO\_MASK\_RXFIFOHIE  
    Peripheral\_Registers\_Bits\_Definition, 907  
SDIO\_MASK\_RXOVERRIE  
    Peripheral\_Registers\_Bits\_Definition, 907  
SDIO\_MASK\_SDIOITIE  
    Peripheral\_Registers\_Bits\_Definition, 907  
SDIO\_MASK\_STBITERRIE  
    Peripheral\_Registers\_Bits\_Definition, 907  
SDIO\_MASK\_TXACTIE  
    Peripheral\_Registers\_Bits\_Definition, 908  
SDIO\_MASK\_TXDAVLIE  
    Peripheral\_Registers\_Bits\_Definition, 908  
SDIO\_MASK\_TXFIFOEIE  
    Peripheral\_Registers\_Bits\_Definition, 908  
SDIO\_MASK\_TXFIFOFIE  
    Peripheral\_Registers\_Bits\_Definition, 908  
SDIO\_MASK\_TXFIFOHEIE  
    Peripheral\_Registers\_Bits\_Definition, 908  
SDIO\_MASK\_TXUNDERRIE  
    Peripheral\_Registers\_Bits\_Definition, 908  
SDIO\_POWER\_PWRCTRL  
    Peripheral\_Registers\_Bits\_Definition, 908  
SDIO\_POWER\_PWRCTRL\_0  
    Peripheral\_Registers\_Bits\_Definition, 909  
SDIO\_POWER\_PWRCTRL\_1  
    Peripheral\_Registers\_Bits\_Definition, 909  
SDIO\_RESP0\_CARDSTATUS0  
    Peripheral\_Registers\_Bits\_Definition, 909  
SDIO\_RESP1\_CARDSTATUS1  
    Peripheral\_Registers\_Bits\_Definition, 909  
SDIO\_RESP2\_CARDSTATUS2  
    Peripheral\_Registers\_Bits\_Definition, 909  
SDIO\_RESP3\_CARDSTATUS3  
    Peripheral\_Registers\_Bits\_Definition, 909  
SDIO\_RESP4\_CARDSTATUS4  
    Peripheral\_Registers\_Bits\_Definition, 909  
SDIO\_RESPCMD\_RESPCMD  
    Peripheral\_Registers\_Bits\_Definition, 909  
SDIO\_STA\_CCRCFAIL  
    Peripheral\_Registers\_Bits\_Definition, 910  
SDIO\_STA\_CEATAEND  
    Peripheral\_Registers\_Bits\_Definition, 910  
SDIO\_STA\_CMDACT  
    Peripheral\_Registers\_Bits\_Definition, 910  
SDIO\_STA\_CMDREN  
    Peripheral\_Registers\_Bits\_Definition, 910  
SDIO\_STA\_CMDSENT  
    Peripheral\_Registers\_Bits\_Definition, 910  
SDIO\_STA\_CTIMEOUT  
    Peripheral\_Registers\_Bits\_Definition, 910  
SDIO\_STA\_DATAEND  
    Peripheral\_Registers\_Bits\_Definition, 910  
SDIO\_STA\_DBCKEND  
    Peripheral\_Registers\_Bits\_Definition, 911  
SDIO\_STA\_DCRCFAIL  
    Peripheral\_Registers\_Bits\_Definition, 911  
SDIO\_STA\_DTIMEOUT  
    Peripheral\_Registers\_Bits\_Definition, 911  
SDIO\_STA\_RXACT  
    Peripheral\_Registers\_Bits\_Definition, 911  
SDIO\_STA\_RXDAVL  
    Peripheral\_Registers\_Bits\_Definition, 911  
SDIO\_STA\_RXFIFOE  
    Peripheral\_Registers\_Bits\_Definition, 911

SDIO\_STA\_RXFIFOF  
    Peripheral\_Registers\_Bits\_Definition, 911

SDIO\_STA\_RXFIFOHF  
    Peripheral\_Registers\_Bits\_Definition, 912

SDIO\_STA\_RXOVERR  
    Peripheral\_Registers\_Bits\_Definition, 912

SDIO\_STA\_SDIOIT  
    Peripheral\_Registers\_Bits\_Definition, 912

SDIO\_STA\_STBITERR  
    Peripheral\_Registers\_Bits\_Definition, 912

SDIO\_STA\_TXACT  
    Peripheral\_Registers\_Bits\_Definition, 912

SDIO\_STA\_TXDAVL  
    Peripheral\_Registers\_Bits\_Definition, 912

SDIO\_STA\_TXFIFOE  
    Peripheral\_Registers\_Bits\_Definition, 912

SDIO\_STA\_TXFIFOFOF  
    Peripheral\_Registers\_Bits\_Definition, 913

SDIO\_STA\_TXFIFOHE  
    Peripheral\_Registers\_Bits\_Definition, 913

SDIO\_STA\_TXUNDERR  
    Peripheral\_Registers\_Bits\_Definition, 913

SDIO\_TypeDef, 1049

SecondaryAddress  
    S\_I2C\_Slave\_address, 1041

SERVO MOTOR Driver, 37

Servo1\_Entry\_Gate  
    API Function Prototypes, 39

Servo1\_Entry\_Gate\_Init  
    API Function Prototypes, 39

Servo2\_Exit\_Gate  
    API Function Prototypes, 40

Servo2\_Exit\_Gate\_Init  
    API Function Prototypes, 41

SET  
    Platform Standard Types, 152

Set  
    Exported\_types, 530  
    I2C Driver, 269

sFIFOMailBox  
    CMSIS, 512

sFilterRegister  
    CMSIS, 512

SHCSR  
    ITM Functions, 142  
    SCB\_TypeDef, 1048

SHIFTR  
    CMSIS, 512

SHP  
    ITM Functions, 142  
    SCB\_TypeDef, 1048

sint16  
    Platform Standard Types, 153

sint16\_least  
    Platform Standard Types, 153

sint32  
    Platform Standard Types, 153

sint32\_least

Platform Standard Types, 153

sint64  
    Platform Standard Types, 153

sint8  
    Platform Standard Types, 153

sint8\_least  
    Platform Standard Types, 154

SIZE1  
    Global\_Variables\_Definitions, 370

Slave\_State  
    I2C Driver, 270

SLEEPCNT  
    ITM Functions, 142

SLOTR  
    CMSIS, 513

SMCR  
    CMSIS, 513  
    TIM1\_TypeDef, 1059

SMPR1  
    CMSIS, 513

SMPR2  
    CMSIS, 513

SPI Clock Phase Definitions, 321  
    SPI\_Clock\_Phase\_Leading, 321  
    SPI\_Clock\_Phase\_Trailing, 321

SPI Clock Polarity Definitions, 320  
    SPI\_Clock\_Polarity\_High\_Idle, 320  
    SPI\_Clock\_Polarity\_Low\_Idle, 320

SPI Communication Mode Definitions, 317  
    SPI\_Direction\_1line\_Receive\_only, 318  
    SPI\_Direction\_1line\_Transmit\_only, 318  
    SPI\_Direction\_2lines, 318  
    SPI\_Direction\_2lines\_RX\_Only, 318

SPI Driver, 315  
    Disabled, 316  
    Enabled, 316  
    SPI\_PollingMechanism, 316

SPI Frame Format Definitions, 319  
    SPI\_Frame\_Format\_LSB, 319  
    SPI\_Frame\_Format\_MSB, 320

SPI Instances, 176  
    SPI1, 177  
    SPI2, 177

SPI IRQ Enable Definitions, 325  
    SPI\_IRQ\_Enable\_Err, 325  
    SPI\_IRQ\_Enable\_None, 325  
    SPI\_IRQ\_Enable\_Rx\_Only, 325  
    SPI\_IRQ\_Enable\_Tx\_Only, 325

SPI Mode Definitions, 317  
    SPI\_Mode\_Master, 317  
    SPI\_Mode\_Slave, 317

SPI NSS Definitions, 322  
    SPI\_NSS\_Hard\_Master\_SS\_No\_output, 322  
    SPI\_NSS\_Hard\_Master\_SS\_Output\_Enable, 322  
    SPI\_NSS\_Hard\_Slave, 322  
    SPI\_NSS\_Internal\_Soft\_Reset, 322  
    SPI\_NSS\_Internal\_Soft\_Set, 323

SPI Payload Length Definitions, 318

SPI\_Payload\_Length\_16bit, 319  
 SPI\_Payload\_Length\_8bit, 319  
**SPI Prescaler Definitions, 323**  
 SPI\_Prescaler\_By128, 323  
 SPI\_Prescaler\_By16, 323  
 SPI\_Prescaler\_By2, 324  
 SPI\_Prescaler\_By256, 324  
 SPI\_Prescaler\_By32, 324  
 SPI\_Prescaler\_By4, 324  
 SPI\_Prescaler\_By64, 324  
 SPI\_Prescaler\_By8, 324  
**SPI Register Map, 165**  
**SPI1**  
 SPI Instances, 177  
**SPI1\_Index**  
 stm32f401xx\_spi\_driver.c, 1222  
**SPI1\_IRQHandler**  
 stm32f401xx\_spi\_driver.c, 1222  
**SPI1 IRQn**  
 Configuration\_section\_for\CMSIS, 526  
**SPI2**  
 SPI Instances, 177  
**SPI2\_Index**  
 stm32f401xx\_spi\_driver.c, 1222  
**SPI2\_IRQHandler**  
 stm32f401xx\_spi\_driver.c, 1223  
**SPI2 IRQn**  
 Configuration\_section\_for\CMSIS, 526  
**SPI3\_IRQHandler**  
 Configuration\_section\_for\CMSIS, 526  
**SPI4\_IRQHandler**  
 Configuration\_section\_for\CMSIS, 526  
**SPI\_Clock\_Phase\_Leading**  
 SPI Clock Phase Definitions, 321  
**SPI\_Clock\_Phase\_Trailing**  
 SPI Clock Phase Definitions, 321  
**SPI\_Clock\_Polarity\_High\_Idle**  
 SPI Clock Polarity Definitions, 320  
**SPI\_Clock\_Polarity\_Low\_Idle**  
 SPI Clock Polarity Definitions, 320  
**SPI\_CR1\_BIDIMODE**  
 Peripheral\_Registers\_Bits\_Definition, 913  
**SPI\_CR1\_BIDIOE**  
 Peripheral\_Registers\_Bits\_Definition, 913  
**SPI\_CR1\_BR**  
 Peripheral\_Registers\_Bits\_Definition, 913  
**SPI\_CR1\_BR\_0**  
 Peripheral\_Registers\_Bits\_Definition, 913  
**SPI\_CR1\_BR\_1**  
 Peripheral\_Registers\_Bits\_Definition, 914  
**SPI\_CR1\_BR\_2**  
 Peripheral\_Registers\_Bits\_Definition, 914  
**SPI\_CR1\_CPHA**  
 Peripheral\_Registers\_Bits\_Definition, 914  
**SPI\_CR1\_CPOL**  
 Peripheral\_Registers\_Bits\_Definition, 914  
**SPI\_CR1\_CRCEN**  
 Peripheral\_Registers\_Bits\_Definition, 914  
**SPI\_CR1\_CRCNEXT**  
 Peripheral\_Registers\_Bits\_Definition, 914  
**SPI\_CR1\_DFF**  
 Peripheral\_Registers\_Bits\_Definition, 914  
**SPI\_CR1\_LSBFIRST**  
 Peripheral\_Registers\_Bits\_Definition, 915  
**SPI\_CR1\_MSTR**  
 Peripheral\_Registers\_Bits\_Definition, 915  
**SPI\_CR1\_RXONLY**  
 Peripheral\_Registers\_Bits\_Definition, 915  
**SPI\_CR1\_SPE**  
 Peripheral\_Registers\_Bits\_Definition, 915  
**SPI\_CR1\_SSI**  
 Peripheral\_Registers\_Bits\_Definition, 915  
**SPI\_CR1\_SSM**  
 Peripheral\_Registers\_Bits\_Definition, 915  
**SPI\_CR2\_ERRIE**  
 Peripheral\_Registers\_Bits\_Definition, 915  
**SPI\_CR2\_RXDMAEN**  
 Peripheral\_Registers\_Bits\_Definition, 916  
**SPI\_CR2\_RXNEIE**  
 Peripheral\_Registers\_Bits\_Definition, 916  
**SPI\_CR2\_SSOE**  
 Peripheral\_Registers\_Bits\_Definition, 916  
**SPI\_CR2\_TXDMAEN**  
 Peripheral\_Registers\_Bits\_Definition, 916  
**SPI\_CR2\_TXEIE**  
 Peripheral\_Registers\_Bits\_Definition, 916  
**SPI\_CRCPR\_CRCPOLY**  
 Peripheral\_Registers\_Bits\_Definition, 916  
**SPI\_Direction\_1line\_Receive\_only**  
 SPI Communication Mode Definitions, 318  
**SPI\_Direction\_1line\_Transmit\_only**  
 SPI Communication Mode Definitions, 318  
**SPI\_Direction\_2lines**  
 SPI Communication Mode Definitions, 318  
**SPI\_Direction\_2lines\_RX\_Only**  
 SPI Communication Mode Definitions, 318  
**SPI\_DR\_DR**  
 Peripheral\_Registers\_Bits\_Definition, 916  
**SPI\_Frame\_Format\_LSB**  
 SPI Frame Format Definitions, 319  
**SPI\_Frame\_Format\_MSB**  
 SPI Frame Format Definitions, 320  
**SPI\_I2SCFGR\_CHLEN**  
 Peripheral\_Registers\_Bits\_Definition, 917  
**SPI\_I2SCFGR\_CKPOL**  
 Peripheral\_Registers\_Bits\_Definition, 917  
**SPI\_I2SCFGR\_DATLEN**  
 Peripheral\_Registers\_Bits\_Definition, 917  
**SPI\_I2SCFGR\_DATLEN\_0**  
 Peripheral\_Registers\_Bits\_Definition, 917  
**SPI\_I2SCFGR\_DATLEN\_1**  
 Peripheral\_Registers\_Bits\_Definition, 917  
**SPI\_I2SCFGR\_I2SCFG**  
 Peripheral\_Registers\_Bits\_Definition, 917  
**SPI\_I2SCFGR\_I2SCFG\_0**  
 Peripheral\_Registers\_Bits\_Definition, 917

SPI\_I2SCFGR\_I2SCFG\_1  
    Peripheral\_Registers\_Bits\_Definition, 918

SPI\_I2SCFGR\_I2SE  
    Peripheral\_Registers\_Bits\_Definition, 918

SPI\_I2SCFGR\_I2SMOD  
    Peripheral\_Registers\_Bits\_Definition, 918

SPI\_I2SCFGR\_I2SSTD  
    Peripheral\_Registers\_Bits\_Definition, 918

SPI\_I2SCFGR\_I2SSTD\_0  
    Peripheral\_Registers\_Bits\_Definition, 918

SPI\_I2SCFGR\_I2SSTD\_1  
    Peripheral\_Registers\_Bits\_Definition, 918

SPI\_I2SCFGR\_PCMSYNC  
    Peripheral\_Registers\_Bits\_Definition, 918

SPI\_I2SPR\_I2SDIV  
    Peripheral\_Registers\_Bits\_Definition, 919

SPI\_I2SPR\_MCKOE  
    Peripheral\_Registers\_Bits\_Definition, 919

SPI\_I2SPR\_ODD  
    Peripheral\_Registers\_Bits\_Definition, 919

SPI\_IRQ\_Enable\_Err  
    SPI IRQ Enable Definitions, 325

SPI\_IRQ\_Enable\_None  
    SPI IRQ Enable Definitions, 325

SPI\_IRQ\_Enable\_Rx\_Only  
    SPI IRQ Enable Definitions, 325

SPI\_IRQ\_Enable\_Tx\_Only  
    SPI IRQ Enable Definitions, 325

SPI\_Mode\_Master  
    SPI Mode Definitions, 317

SPI\_Mode\_Slave  
    SPI Mode Definitions, 317

SPI\_NSS\_Hard\_Master\_SS\_No\_output  
    SPI NSS Definitions, 322

SPI\_NSS\_Hard\_Master\_SS\_Output\_Enable  
    SPI NSS Definitions, 322

SPI\_NSS\_Hard\_Slave  
    SPI NSS Definitions, 322

SPI\_NSS\_Internal\_Soft\_Reset  
    SPI NSS Definitions, 322

SPI\_NSS\_Internal\_Soft\_Set  
    SPI NSS Definitions, 323

SPI\_Payload\_Length\_16bit  
    SPI Payload Length Definitions, 319

SPI\_Payload\_Length\_8bit  
    SPI Payload Length Definitions, 319

SPI\_PollingMechanism  
    SPI Driver, 316

SPI\_Prescaler  
    S\_SPI\_Config\_t, 1044

SPI\_Prescaler\_By128  
    SPI Prescaler Definitions, 323

SPI\_Prescaler\_By16  
    SPI Prescaler Definitions, 323

SPI\_Prescaler\_By2  
    SPI Prescaler Definitions, 324

SPI\_Prescaler\_By256  
    SPI Prescaler Definitions, 324

SPI\_Prescaler\_By32  
    SPI Prescaler Definitions, 324

SPI\_Prescaler\_By4  
    SPI Prescaler Definitions, 324

SPI\_Prescaler\_By64  
    SPI Prescaler Definitions, 324

SPI\_Prescaler\_By8  
    SPI Prescaler Definitions, 324

SPI\_RXCRCR\_RXCRC  
    Peripheral\_Registers\_Bits\_Definition, 919

SPI\_SR\_BSY  
    Peripheral\_Registers\_Bits\_Definition, 919

SPI\_SR\_CHSIDE  
    Peripheral\_Registers\_Bits\_Definition, 919

SPI\_SR\_CRCERR  
    Peripheral\_Registers\_Bits\_Definition, 919

SPI\_SR\_MODF  
    Peripheral\_Registers\_Bits\_Definition, 920

SPI\_SR\_OVR  
    Peripheral\_Registers\_Bits\_Definition, 920

SPI\_SR\_RXNE  
    Peripheral\_Registers\_Bits\_Definition, 920  
    stm32f401xx\_spi\_driver.c, 1222

SPI\_SR\_TXE  
    Peripheral\_Registers\_Bits\_Definition, 920  
    stm32f401xx\_spi\_driver.c, 1222

SPI\_SR\_UDR  
    Peripheral\_Registers\_Bits\_Definition, 920

SPI\_TXCRCR\_TXCRC  
    Peripheral\_Registers\_Bits\_Definition, 920

SPI\_TypeDef, 1050

    CR1, 1050

    CR2, 1050

    CRCPR, 1051

    DR, 1051

    I2SCFGR, 1051

    I2SPR, 1051

    RXCRCR, 1051

    SR, 1051

    TXCRCR, 1051

SPPR  
    ITM Functions, 143

SPSEL  
    ITM Functions, 143

SQR1  
    CMSIS, 513

SQR2  
    CMSIS, 513

SQR3  
    CMSIS, 513

SR  
    CMSIS, 513–515

    CRC\_TypeDef, 1005

    SPI\_TypeDef, 1051

    TIM1\_TypeDef, 1059

    USART\_TypeDef, 1063

SR1  
    CMSIS, 515

I2C\_TypeDef, 1020  
SR2  
  CMSIS, 515  
  I2C\_TypeDef, 1021  
SRAM1\_BASE  
  Peripheral\_memory\_map, 535  
SRAM1\_BB\_BASE  
  Peripheral\_memory\_map, 536  
SRAM\_BB\_BASE  
  Peripheral\_memory\_map, 536  
Src/app\_states.c, 1228  
Src/ecu.c, 1229  
Src/sysmem.c, 1231  
Src/system\_stm32f4xx.c, 1233  
SRCR  
  CMSIS, 515  
SSCGR  
  CMSIS, 516  
  RCC\_TypeDef, 1037  
SSCR  
  CMSIS, 516  
SSPSR  
  ITM Functions, 143  
SSR  
  CMSIS, 516  
STA  
  CMSIS, 516  
Start  
  I2C Driver, 270  
State Handlers, 357  
  STATE\_API, 358  
State Macros, 355  
  STATE\_API, 355  
  STATE\_NAME, 355  
STATE\_API  
  Application States, 352, 353  
  State Handlers, 358  
  State Macros, 355  
STATE\_NAME  
  State Macros, 355  
STATES  
  Application States, 352  
Status  
  I2C Driver, 271  
Status and Control Registers, 43  
  APSR\_C\_Msk, 44  
  APSR\_C\_Pos, 44  
  APSR\_GE\_Msk, 44  
  APSR\_GE\_Pos, 44  
  APSR\_N\_Msk, 45  
  APSR\_N\_Pos, 45  
  APSR\_Q\_Msk, 45  
  APSR\_Q\_Pos, 45  
  APSR\_V\_Msk, 45  
  APSR\_V\_Pos, 45  
  APSR\_Z\_Msk, 45  
  APSR\_Z\_Pos, 45  
  CONTROL\_FPCA\_Msk, 46  
  CONTROL\_FPCA\_Pos, 46  
  CONTROL\_nPRIV\_Msk, 46  
  CONTROL\_nPRIV\_Pos, 46  
  CONTROL\_SPSEL\_Msk, 46  
  CONTROL\_SPSEL\_Pos, 46  
  IPSR\_ISR\_Msk, 46  
  IPSR\_ISR\_Pos, 46  
  xPSR\_C\_Msk, 47  
  xPSR\_C\_Pos, 47  
  xPSR\_GE\_Msk, 47  
  xPSR\_GE\_Pos, 47  
  xPSR\_ISR\_Msk, 47  
  xPSR\_ISR\_Pos, 47  
  xPSR\_IT\_Msk, 47  
  xPSR\_IT\_Pos, 47  
  xPSR\_N\_Msk, 48  
  xPSR\_N\_Pos, 48  
  xPSR\_Q\_Msk, 48  
  xPSR\_Q\_Pos, 48  
  xPSR\_T\_Msk, 48  
  xPSR\_T\_Pos, 48  
  xPSR\_V\_Msk, 48  
  xPSR\_V\_Pos, 48  
  xPSR\_Z\_Msk, 49  
  xPSR\_Z\_Pos, 49  
STIR  
  ITM Functions, 143  
  NVIC\_TypeDef, 1031  
STK  
  SysTick Timer Instance, 170  
STK\_CLK\_AHB  
  SysTick Clock Configuration, 333  
STK\_CLK\_AHB\_8  
  SysTick Clock Configuration, 333  
STK\_config\_t, 1052  
  Callback\_Function, 1052  
  clock\_config, 1052  
  interrupt\_config, 1052  
  reload\_value, 1053  
  running\_mode, 1053  
STK\_FCPU  
  SYSTICK Driver, 332  
STK\_INTERRUPT\_DISABLED  
  SysTick Interrupt Configuration, 332  
STK\_INTERRUPT\_ENABLED  
  SysTick Interrupt Configuration, 332  
STK\_ONE\_SHOT\_MODE  
  SysTick Running Mode Configuration, 334  
STK\_PERIODIC\_MODE  
  SysTick Running Mode Configuration, 334  
STK\_TypeDef, 1053  
  CALIB, 1053  
  CTRL, 1053  
  LOAD, 1053  
  VAL, 1054  
STM32F401xx MCU Header File, 156  
stm32f401xx\_i2c\_driver.c  
  Global\_I2C\_Config, 1220

I2C1\_Index, 1220  
I2C2\_Index, 1220  
stm32f401xx\_spi\_driver.c  
    Global\_SPI\_Config, 1223  
    SPI1\_Index, 1222  
    SPI1\_IRQHandler, 1222  
    SPI2\_Index, 1222  
    SPI2\_IRQHandler, 1223  
    SPI\_SR\_RXNE, 1222  
    SPI\_SR\_TXE, 1222  
Stm32f4xx, 519  
Stm32f4xx\_system, 990  
STM32F4xx\_System\_Exported\_Constants, 992  
STM32F4xx\_System\_Exported\_Functions, 992  
    SystemCoreClockUpdate, 993  
    SystemInit, 994  
STM32F4xx\_System\_Exported\_Macros, 992  
STM32F4xx\_System\_Exported\_types, 991  
    SystemCoreClock, 992  
STM32F4xx\_System\_INCLUDES, 991  
STM32F4xx\_System\_Private\_Defines, 995  
    VECT\_TAB\_OFFSET, 995  
STM32F4xx\_System\_Private\_FunctionPrototypes, 996  
STM32F4xx\_System\_Private\_Functions, 996  
    SystemCoreClockUpdate, 997  
    SystemInit, 998  
STM32F4xx\_System\_Private\_INCLUDES, 994  
STM32F4xx\_System\_Private\_MACROS, 995  
STM32F4xx\_System\_Private\_TYPESDefinitions, 994  
STM32F4xx\_System\_Private\_Variables, 996  
StopCondition  
    I2C\_Driver, 271  
STR  
    CMSIS, 516  
Structure for configuring an LED., 33  
sTxMailBox  
    CMSIS, 516  
SVCALL IRQn  
    Configuration\_section\_for\_CMSIS, 524  
SWIER  
    CMSIS, 516  
    EXTI\_TypeDef, 1014  
SWTRIGR  
    CMSIS, 517  
SYSCFG  
    SYSCFG\_Instance, 174  
SYSCFG\_Instance, 174  
    SYSCFG, 174  
SYSCFG\_Register\_Map, 164  
SYSCFG\_CMPPCR\_CMP\_PD  
    Peripheral\_Registers\_Bits\_Definition, 920  
SYSCFG\_CMPPCR\_READY  
    Peripheral\_Registers\_Bits\_Definition, 921  
SYSCFG\_EXTICR1\_EXTI0  
    Peripheral\_Registers\_Bits\_Definition, 921  
SYSCFG\_EXTICR1\_EXTI0\_PA  
    Peripheral\_Registers\_Bits\_Definition, 921  
SYSCFG\_EXTICR1\_EXTI0\_PB  
    Peripheral\_Registers\_Bits\_Definition, 921  
SYSCFG\_EXTICR1\_EXTI0\_PC  
    Peripheral\_Registers\_Bits\_Definition, 921  
SYSCFG\_EXTICR1\_EXTI0\_PD  
    Peripheral\_Registers\_Bits\_Definition, 921  
SYSCFG\_EXTICR1\_EXTI0\_PE  
    Peripheral\_Registers\_Bits\_Definition, 921  
SYSCFG\_EXTICR1\_EXTI0\_PF  
    Peripheral\_Registers\_Bits\_Definition, 922  
SYSCFG\_EXTICR1\_EXTI0\_PG  
    Peripheral\_Registers\_Bits\_Definition, 922  
SYSCFG\_EXTICR1\_EXTI0\_PH  
    Peripheral\_Registers\_Bits\_Definition, 922  
SYSCFG\_EXTICR1\_EXTI0\_PI  
    Peripheral\_Registers\_Bits\_Definition, 922  
SYSCFG\_EXTICR1\_EXTI0\_PJ  
    Peripheral\_Registers\_Bits\_Definition, 922  
SYSCFG\_EXTICR1\_EXTI0\_PK  
    Peripheral\_Registers\_Bits\_Definition, 922  
SYSCFG\_EXTICR1\_EXTI1  
    Peripheral\_Registers\_Bits\_Definition, 922  
SYSCFG\_EXTICR1\_EXTI1\_PA  
    Peripheral\_Registers\_Bits\_Definition, 922  
SYSCFG\_EXTICR1\_EXTI1\_PB  
    Peripheral\_Registers\_Bits\_Definition, 923  
SYSCFG\_EXTICR1\_EXTI1\_PC  
    Peripheral\_Registers\_Bits\_Definition, 923  
SYSCFG\_EXTICR1\_EXTI1\_PD  
    Peripheral\_Registers\_Bits\_Definition, 923  
SYSCFG\_EXTICR1\_EXTI1\_PE  
    Peripheral\_Registers\_Bits\_Definition, 923  
SYSCFG\_EXTICR1\_EXTI1\_PF  
    Peripheral\_Registers\_Bits\_Definition, 923  
SYSCFG\_EXTICR1\_EXTI1\_PG  
    Peripheral\_Registers\_Bits\_Definition, 923  
SYSCFG\_EXTICR1\_EXTI1\_PH  
    Peripheral\_Registers\_Bits\_Definition, 923  
SYSCFG\_EXTICR1\_EXTI1\_PI  
    Peripheral\_Registers\_Bits\_Definition, 924  
SYSCFG\_EXTICR1\_EXTI1\_PJ  
    Peripheral\_Registers\_Bits\_Definition, 924  
SYSCFG\_EXTICR1\_EXTI1\_PK  
    Peripheral\_Registers\_Bits\_Definition, 924  
SYSCFG\_EXTICR1\_EXTI2  
    Peripheral\_Registers\_Bits\_Definition, 924  
SYSCFG\_EXTICR1\_EXTI2\_PA  
    Peripheral\_Registers\_Bits\_Definition, 924  
SYSCFG\_EXTICR1\_EXTI2\_PB  
    Peripheral\_Registers\_Bits\_Definition, 924  
SYSCFG\_EXTICR1\_EXTI2\_PC  
    Peripheral\_Registers\_Bits\_Definition, 924  
SYSCFG\_EXTICR1\_EXTI2\_PD  
    Peripheral\_Registers\_Bits\_Definition, 925  
SYSCFG\_EXTICR1\_EXTI2\_PE  
    Peripheral\_Registers\_Bits\_Definition, 925  
SYSCFG\_EXTICR1\_EXTI2\_PF  
    Peripheral\_Registers\_Bits\_Definition, 925





- Peripheral\_Registers\_Bits\_Definition, [941](#)
- SYSCFG\_EXTICR4\_EXTI12\_PH**
  - Peripheral\_Registers\_Bits\_Definition, [941](#)
- SYSCFG\_EXTICR4\_EXTI12\_PI**
  - Peripheral\_Registers\_Bits\_Definition, [941](#)
- SYSCFG\_EXTICR4\_EXTI12\_PJ**
  - Peripheral\_Registers\_Bits\_Definition, [941](#)
- SYSCFG\_EXTICR4\_EXTI13**
  - Peripheral\_Registers\_Bits\_Definition, [941](#)
- SYSCFG\_EXTICR4\_EXTI13\_PA**
  - Peripheral\_Registers\_Bits\_Definition, [942](#)
- SYSCFG\_EXTICR4\_EXTI13\_PB**
  - Peripheral\_Registers\_Bits\_Definition, [942](#)
- SYSCFG\_EXTICR4\_EXTI13\_PC**
  - Peripheral\_Registers\_Bits\_Definition, [942](#)
- SYSCFG\_EXTICR4\_EXTI13\_PD**
  - Peripheral\_Registers\_Bits\_Definition, [942](#)
- SYSCFG\_EXTICR4\_EXTI13\_PE**
  - Peripheral\_Registers\_Bits\_Definition, [942](#)
- SYSCFG\_EXTICR4\_EXTI13\_PF**
  - Peripheral\_Registers\_Bits\_Definition, [942](#)
- SYSCFG\_EXTICR4\_EXTI13\_PH**
  - Peripheral\_Registers\_Bits\_Definition, [943](#)
- SYSCFG\_EXTICR4\_EXTI13\_PI**
  - Peripheral\_Registers\_Bits\_Definition, [943](#)
- SYSCFG\_EXTICR4\_EXTI13\_PJ**
  - Peripheral\_Registers\_Bits\_Definition, [943](#)
- SYSCFG\_EXTICR4\_EXTI14**
  - Peripheral\_Registers\_Bits\_Definition, [943](#)
- SYSCFG\_EXTICR4\_EXTI14\_PA**
  - Peripheral\_Registers\_Bits\_Definition, [943](#)
- SYSCFG\_EXTICR4\_EXTI14\_PB**
  - Peripheral\_Registers\_Bits\_Definition, [943](#)
- SYSCFG\_EXTICR4\_EXTI14\_PC**
  - Peripheral\_Registers\_Bits\_Definition, [943](#)
- SYSCFG\_EXTICR4\_EXTI14\_PD**
  - Peripheral\_Registers\_Bits\_Definition, [944](#)
- SYSCFG\_EXTICR4\_EXTI14\_PE**
  - Peripheral\_Registers\_Bits\_Definition, [944](#)
- SYSCFG\_EXTICR4\_EXTI14\_PF**
  - Peripheral\_Registers\_Bits\_Definition, [944](#)
- SYSCFG\_EXTICR4\_EXTI14\_PG**
  - Peripheral\_Registers\_Bits\_Definition, [944](#)
- SYSCFG\_EXTICR4\_EXTI14\_PH**
  - Peripheral\_Registers\_Bits\_Definition, [944](#)
- SYSCFG\_EXTICR4\_EXTI14\_PI**
  - Peripheral\_Registers\_Bits\_Definition, [944](#)
- SYSCFG\_EXTICR4\_EXTI14\_PJ**
  - Peripheral\_Registers\_Bits\_Definition, [944](#)
- SYSCFG\_EXTICR4\_EXTI15**
  - Peripheral\_Registers\_Bits\_Definition, [944](#)
- SYSCFG\_EXTICR4\_EXTI15\_PA**
  - Peripheral\_Registers\_Bits\_Definition, [945](#)
- SYSCFG\_EXTICR4\_EXTI15\_PB**
  - Peripheral\_Registers\_Bits\_Definition, [945](#)
- SYSCFG\_EXTICR4\_EXTI15\_PC**
  - Peripheral\_Registers\_Bits\_Definition, [945](#)
- SYSCFG\_EXTICR4\_EXTI15\_PD**
  - Peripheral\_Registers\_Bits\_Definition, [945](#)
- SYSCFG\_EXTICR4\_EXTI15\_PE**
  - Peripheral\_Registers\_Bits\_Definition, [945](#)
- SYSCFG\_EXTICR4\_EXTI15\_PF**
  - Peripheral\_Registers\_Bits\_Definition, [945](#)
- SYSCFG\_EXTICR4\_EXTI15\_PG**
  - Peripheral\_Registers\_Bits\_Definition, [945](#)
- SYSCFG\_EXTICR4\_EXTI15\_PH**
  - Peripheral\_Registers\_Bits\_Definition, [946](#)
- SYSCFG\_EXTICR4\_EXTI15\_PI**
  - Peripheral\_Registers\_Bits\_Definition, [946](#)
- SYSCFG\_EXTICR4\_EXTI15\_PJ**
  - Peripheral\_Registers\_Bits\_Definition, [946](#)
- SYSCFG\_MEMRMP\_FB\_MODE**
  - Peripheral\_Registers\_Bits\_Definition, [946](#)
- SYSCFG\_MEMRMP\_MEM\_MODE**
  - Peripheral\_Registers\_Bits\_Definition, [946](#)
- SYSCFG\_MEMRMP\_MEM\_MODE\_0**
  - Peripheral\_Registers\_Bits\_Definition, [946](#)
- SYSCFG\_MEMRMP\_MEM\_MODE\_1**
  - Peripheral\_Registers\_Bits\_Definition, [946](#)
- SYSCFG\_MEMRMP\_MEM\_MODE\_2**
  - Peripheral\_Registers\_Bits\_Definition, [946](#)
- SYSCFG\_MEMRMP\_SWP\_FMC**
  - Peripheral\_Registers\_Bits\_Definition, [947](#)
- SYSCFG\_MEMRMP\_SWP\_FMC\_0**
  - Peripheral\_Registers\_Bits\_Definition, [947](#)
- SYSCFG\_MEMRMP\_SWP\_FMC\_1**
  - Peripheral\_Registers\_Bits\_Definition, [947](#)
- SYSCFG\_PMC\_ADC1DC2**
  - Peripheral\_Registers\_Bits\_Definition, [947](#)
- SYSCFG\_PMC\_ADC2DC2**
  - Peripheral\_Registers\_Bits\_Definition, [947](#)
- SYSCFG\_PMC\_ADC3DC2**
  - Peripheral\_Registers\_Bits\_Definition, [947](#)
- SYSCFG\_PMC\_ADCxCDC2**
  - Peripheral\_Registers\_Bits\_Definition, [947](#)
- SYSCFG\_PMC\_MII\_RMII\_SEL**
  - Peripheral\_Registers\_Bits\_Definition, [948](#)
- SYSCFG\_RegDef\_t**, [1054](#)
  - CFGR, [1054](#)
  - CMPCR, [1054](#)
  - EXTICR, [1054](#)
  - MEMRMP, [1055](#)
  - PMC, [1055](#)
  - RESERVED1, [1055](#)
  - RESERVED2, [1055](#)
- SYSCFG\_TypeDef**, [1055](#)
- sysmem.c**
  - \_sbrk, [1232](#)
- System Control Block (SCB)**, [50](#)
  - SCB\_AIRCR\_ENDIANESS\_Msk, [53](#)
  - SCB\_AIRCR\_ENDIANESS\_Pos, [53](#)
  - SCB\_AIRCR\_PRIGROUP\_Msk, [53](#)
  - SCB\_AIRCR\_PRIGROUP\_Pos, [53](#)
  - SCB\_AIRCR\_SYSRESETREQ\_Msk, [53](#)

SCB\_AIRCR\_SYSRESETREQ\_Pos, 54  
SCB\_AIRCR\_VECTCLRACTIVE\_Msk, 54  
SCB\_AIRCR\_VECTCLRACTIVE\_Pos, 54  
SCB\_AIRCR\_VECTKEY\_Msk, 54  
SCB\_AIRCR\_VECTKEY\_Pos, 54  
SCB\_AIRCR\_VECTKEYSTAT\_Msk, 54  
SCB\_AIRCR\_VECTKEYSTAT\_Pos, 54  
SCB\_AIRCR\_VECTRESET\_Msk, 54  
SCB\_AIRCR\_VECTRESET\_Pos, 55  
SCB\_CCR\_BFHFNMIGN\_Msk, 55  
SCB\_CCR\_BFHFNMIGN\_Pos, 55  
SCB\_CCR\_DIV\_0\_TRP\_Msk, 55  
SCB\_CCR\_DIV\_0\_TRP\_Pos, 55  
SCB\_CCR\_NONBASETHRDENA\_Msk, 55  
SCB\_CCR\_NONBASETHRDENA\_Pos, 55  
SCB\_CCR\_STKALIGN\_Msk, 55  
SCB\_CCR\_STKALIGN\_Pos, 56  
SCB\_CCR\_UNALIGN\_TRP\_Msk, 56  
SCB\_CCR\_UNALIGN\_TRP\_Pos, 56  
SCB\_CCR\_USERSETMPEND\_Msk, 56  
SCB\_CCR\_USERSETMPEND\_Pos, 56  
SCB\_CFSR\_BUSFAULTSR\_Msk, 56  
SCB\_CFSR\_BUSFAULTSR\_Pos, 56  
SCB\_CFSR\_MEMFAULTSR\_Msk, 56  
SCB\_CFSR\_MEMFAULTSR\_Pos, 57  
SCB\_CFSR\_USGFAULTSR\_Msk, 57  
SCB\_CFSR\_USGFAULTSR\_Pos, 57  
SCB\_CPUID\_ARCHITECTURE\_Msk, 57  
SCB\_CPUID\_ARCHITECTURE\_Pos, 57  
SCB\_CPUID\_IMPLEMENTER\_Msk, 57  
SCB\_CPUID\_IMPLEMENTER\_Pos, 57  
SCB\_CPUID\_PARTNO\_Msk, 57  
SCB\_CPUID\_PARTNO\_Pos, 58  
SCB\_CPUID\_REVISION\_Msk, 58  
SCB\_CPUID\_REVISION\_Pos, 58  
SCB\_CPUID\_VARIANT\_Msk, 58  
SCB\_CPUID\_VARIANT\_Pos, 58  
SCB\_DFSR\_BKPT\_Msk, 58  
SCB\_DFSR\_BKPT\_Pos, 58  
SCB\_DFSR\_DWTTRAP\_Msk, 58  
SCB\_DFSR\_DWTTRAP\_Pos, 59  
SCB\_DFSR\_EXTERNAL\_Msk, 59  
SCB\_DFSR\_EXTERNAL\_Pos, 59  
SCB\_DFSR\_HALTED\_Msk, 59  
SCB\_DFSR\_HALTED\_Pos, 59  
SCB\_DFSR\_VCATCH\_Msk, 59  
SCB\_DFSR\_VCATCH\_Pos, 59  
SCB\_HFSR\_DEBUGEVT\_Msk, 59  
SCB\_HFSR\_DEBUGEVT\_Pos, 60  
SCB\_HFSR\_FORCED\_Msk, 60  
SCB\_HFSR\_FORCED\_Pos, 60  
SCB\_HFSR\_VECTTBL\_Msk, 60  
SCB\_HFSR\_VECTTBL\_Pos, 60  
SCB\_ICSR\_ISRPENDING\_Msk, 60  
SCB\_ICSR\_ISRPENDING\_Pos, 60  
SCB\_ICSR\_ISRPREEMPT\_Msk, 60  
SCB\_ICSR\_ISRPREEMPT\_Pos, 61  
SCB\_ICSR\_NMIPENDSET\_Msk, 61  
SCB\_ICSR\_NMIPENDSET\_Pos, 61  
SCB\_ICSR\_PENDSTCLR\_Msk, 61  
SCB\_ICSR\_PENDSTCLR\_Pos, 61  
SCB\_ICSR\_PENDSTSET\_Msk, 61  
SCB\_ICSR\_PENDSTSET\_Pos, 61  
SCB\_ICSR\_PENDSVCLR\_Msk, 61  
SCB\_ICSR\_PENDSVCLR\_Pos, 62  
SCB\_ICSR\_PENDSVSET\_Msk, 62  
SCB\_ICSR\_PENDSVSET\_Pos, 62  
SCB\_ICSR\_RETTOBASE\_Msk, 62  
SCB\_ICSR\_RETTOBASE\_Pos, 62  
SCB\_ICSR\_VECTACTIVE\_Msk, 62  
SCB\_ICSR\_VECTACTIVE\_Pos, 62  
SCB\_ICSR\_VECTPENDING\_Msk, 62  
SCB\_ICSR\_VECTPENDING\_Pos, 63  
SCB\_SCR\_SEVONPEND\_Msk, 63  
SCB\_SCR\_SEVONPEND\_Pos, 63  
SCB\_SCR\_SLEEPDEEP\_Msk, 63  
SCB\_SCR\_SLEEPDEEP\_Pos, 63  
SCB\_SCR\_SLEEPONEEXIT\_Msk, 63  
SCB\_SCR\_SLEEPONEEXIT\_Pos, 63  
SCB\_SHCSR\_BUSFAULTACT\_Msk, 63  
SCB\_SHCSR\_BUSFAULTACT\_Pos, 64  
SCB\_SHCSR\_BUSFAULTENA\_Msk, 64  
SCB\_SHCSR\_BUSFAULTENA\_Pos, 64  
SCB\_SHCSR\_BUSFAULTPENDED\_Msk, 64  
SCB\_SHCSR\_BUSFAULTPENDED\_Pos, 64  
SCB\_SHCSR\_MEMFAULTACT\_Msk, 64  
SCB\_SHCSR\_MEMFAULTACT\_Pos, 64  
SCB\_SHCSR\_MEMFAULTENA\_Msk, 64  
SCB\_SHCSR\_MEMFAULTENA\_Pos, 65  
SCB\_SHCSR\_MEMFAULTPENDED\_Msk, 65  
SCB\_SHCSR\_MEMFAULTPENDED\_Pos, 65  
SCB\_SHCSR\_MONITORACT\_Msk, 65  
SCB\_SHCSR\_MONITORACT\_Pos, 65  
SCB\_SHCSR\_PENDSVACT\_Msk, 65  
SCB\_SHCSR\_PENDSVACT\_Pos, 65  
SCB\_SHCSR\_SVCALLACT\_Msk, 65  
SCB\_SHCSR\_SVCALLACT\_Pos, 66  
SCB\_SHCSR\_SVCALLPENDED\_Msk, 66  
SCB\_SHCSR\_SVCALLPENDED\_Pos, 66  
SCB\_SHCSR\_SYSTICKACT\_Msk, 66  
SCB\_SHCSR\_SYSTICKACT\_Pos, 66  
SCB\_SHCSR\_USGFAULTACT\_Msk, 66  
SCB\_SHCSR\_USGFAULTACT\_Pos, 66  
SCB\_SHCSR\_USGFAULTENA\_Msk, 66  
SCB\_SHCSR\_USGFAULTENA\_Pos, 67  
SCB\_SHCSR\_USGFAULTPENDED\_Msk, 67  
SCB\_SHCSR\_USGFAULTPENDED\_Pos, 67  
SCB\_VTOR\_TBLOFF\_Msk, 67  
SCB\_VTOR\_TBLOFF\_Pos, 67  
System Controls not in SCB (SCnSCB), 67  
SCnSCB\_ACTLR\_DISDEFWBUF\_Msk, 68  
SCnSCB\_ACTLR\_DISDEFWBUF\_Pos, 68  
SCnSCB\_ACTLR\_DISFOLD\_Msk, 68  
SCnSCB\_ACTLR\_DISFOLD\_Pos, 68  
SCnSCB\_ACTLR\_DISFPCA\_Msk, 69  
SCnSCB\_ACTLR\_DISFPCA\_Pos, 69

SCnSCB\_ACTLR\_DISMCYCINT\_Msk, 69  
 SCnSCB\_ACTLR\_DISMCYCINT\_Pos, 69  
 SCnSCB\_ACTLR\_DISOOFP\_Msk, 69  
 SCnSCB\_ACTLR\_DISOOFP\_Pos, 69  
 SCnSCB\_ICTR\_INTLINESNUM\_Msk, 69  
 SCnSCB\_ICTR\_INTLINESNUM\_Pos, 69

System Tick Timer (SysTick), 70  
 SysTick\_CALIB\_NOREF\_Msk, 71  
 SysTick\_CALIB\_NOREF\_Pos, 71  
 SysTick\_CALIB\_SKEW\_Msk, 71  
 SysTick\_CALIB\_SKEW\_Pos, 71  
 SysTick\_CALIB\_TENMS\_Msk, 71  
 SysTick\_CALIB\_TENMS\_Pos, 71  
 SysTick\_CTRL\_CLKSOURCE\_Msk, 71  
 SysTick\_CTRL\_CLKSOURCE\_Pos, 72  
 SysTick\_CTRL\_COUNTFLAG\_Msk, 72  
 SysTick\_CTRL\_COUNTFLAG\_Pos, 72  
 SysTick\_CTRL\_ENABLE\_Msk, 72  
 SysTick\_CTRL\_ENABLE\_Pos, 72  
 SysTick\_CTRL\_TICKINT\_Msk, 72  
 SysTick\_CTRL\_TICKINT\_Pos, 72  
 SysTick\_LOAD\_RELOAD\_Msk, 72  
 SysTick\_LOAD\_RELOAD\_Pos, 73  
 SysTick\_VAL\_CURRENT\_Msk, 73  
 SysTick\_VAL\_CURRENT\_Pos, 73

SystemCoreClock  
 STM32F4xx\_System\_Exported\_types, 992

SystemCoreClockUpdate  
 STM32F4xx\_System\_Exported\_Functions, 993  
 STM32F4xx\_System\_Private\_Functions, 997

SystemInit  
 STM32F4xx\_System\_Exported\_Functions, 994  
 STM32F4xx\_System\_Private\_Functions, 998

SysTick  
 CMSIS, 439  
 Core Definitions, 110

SysTick Clock Configuration, 333  
 STK\_CLK\_AHB, 333  
 STK\_CLK\_AHB\_8, 333

SYSTICK Driver, 331  
 STK\_FCPU, 332

SysTick Functions, 118  
 SysTick\_Config, 118

SysTick Interrupt Configuration, 332  
 STK\_INTERRUPT\_DISABLED, 332  
 STK\_INTERRUPT\_ENABLED, 332

SysTick Running Mode Configuration, 334  
 STK\_ONE\_SHOT\_MODE, 334  
 STK\_PERIODIC\_MODE, 334

SysTick Timer Instance, 170  
 STK, 170

SysTick Timer Register Map, 162

SysTick\_BASE  
 CMSIS, 439  
 Core Definitions, 111

SysTick\_CALIB\_NOREF\_Msk  
 CMSIS, 439  
 System Tick Timer (SysTick), 71

SysTick\_CALIB\_NOREF\_Pos  
 CMSIS, 440  
 System Tick Timer (SysTick), 71

SysTick\_CALIB\_SKEW\_Msk  
 CMSIS, 440  
 System Tick Timer (SysTick), 71

SysTick\_CALIB\_SKEW\_Pos  
 CMSIS, 440  
 System Tick Timer (SysTick), 71

SysTick\_CALIB\_TENMS\_Msk  
 CMSIS, 440  
 System Tick Timer (SysTick), 71

SysTick\_CALIB\_TENMS\_Pos  
 CMSIS, 440  
 System Tick Timer (SysTick), 71

SysTick\_Config  
 CMSIS, 460  
 SysTick Functions, 118

SysTick\_CTRL\_CLKSOURCE\_Msk  
 CMSIS, 440  
 System Tick Timer (SysTick), 71

SysTick\_CTRL\_CLKSOURCE\_Pos  
 CMSIS, 440  
 System Tick Timer (SysTick), 72

SysTick\_CTRL\_COUNTFLAG\_Msk  
 CMSIS, 440  
 System Tick Timer (SysTick), 72

SysTick\_CTRL\_COUNTFLAG\_Pos  
 CMSIS, 441  
 System Tick Timer (SysTick), 72

SysTick\_CTRL\_ENABLE\_Msk  
 CMSIS, 441  
 System Tick Timer (SysTick), 72

SysTick\_CTRL\_ENABLE\_Pos  
 CMSIS, 441  
 System Tick Timer (SysTick), 72

SysTick\_CTRL\_TICKINT\_Msk  
 CMSIS, 441  
 System Tick Timer (SysTick), 72

SysTick\_CTRL\_TICKINT\_Pos  
 CMSIS, 441  
 System Tick Timer (SysTick), 72

SysTick\_Handler  
 CMSIS, 460

SysTick\_IRQn  
 Configuration\_section\_for\_CMSIS, 524

SysTick\_LOAD\_RELOAD\_Msk  
 CMSIS, 441  
 System Tick Timer (SysTick), 72

SysTick\_LOAD\_RELOAD\_Pos  
 CMSIS, 441  
 System Tick Timer (SysTick), 73

SysTick\_Type, 1056

SysTick\_VAL\_CURRENT\_Msk  
 CMSIS, 441  
 System Tick Timer (SysTick), 73

SysTick\_VAL\_CURRENT\_Pos  
 CMSIS, 442

System Tick Timer (SysTick), 73

T

- ITM Functions, 143
- TAFCR
  - CMSIS, 517
- TAMP\_STAMP\_IRQn
  - Configuration\_section\_for\CMSIS, 525
- TCR
  - ITM Functions, 144
- TDHR
  - CMSIS, 517
- TDLR
  - CMSIS, 517
- TDTR
  - CMSIS, 517
- TER
  - ITM Functions, 144
- TIM1
  - Timer Instances, 175
- TIM1 Register Map, 167
- TIM1\_BRK\_TIM9\_IRQn
  - Configuration\_section\_for\CMSIS, 525
- TIM1\_CC\_IRQn
  - Configuration\_section\_for\CMSIS, 525
- TIM1\_TRG\_COM\_TIM11\_IRQn
  - Configuration\_section\_for\CMSIS, 525
- TIM1\_TypeDef, 1056
  - ARR, 1057
  - BDTR, 1057
  - CCER, 1057
  - CCMR1, 1057
  - CCMR2, 1057
  - CCR1, 1057
  - CCR2, 1057
  - CCR3, 1057
  - CCR4, 1058
  - CNT, 1058
  - CR1, 1058
  - CR2, 1058
  - DCR, 1058
  - DIER, 1058
  - DMAR, 1058
  - EGR, 1058
  - OR, 1059
  - PSC, 1059
  - RCR, 1059
  - SMCR, 1059
  - SR, 1059
- TIM1\_UP\_TIM10\_IRQn
  - Configuration\_section\_for\CMSIS, 525
- TIM2
  - Timer Instances, 175
- TIM2 Register group, 340
  - TIM2\_TIMER\_BASE, 341
- TIM2\_IRQn
  - Configuration\_section\_for\CMSIS, 525
- TIM2\_TIMER\_BASE
  - TIM2 Register group, 341



TIM\_CCMR2\_IC4F  
    Peripheral\_Registers\_Bits\_Definition, 959

TIM\_CCMR2\_IC4F\_0  
    Peripheral\_Registers\_Bits\_Definition, 959

TIM\_CCMR2\_IC4F\_1  
    Peripheral\_Registers\_Bits\_Definition, 960

TIM\_CCMR2\_IC4F\_2  
    Peripheral\_Registers\_Bits\_Definition, 960

TIM\_CCMR2\_IC4F\_3  
    Peripheral\_Registers\_Bits\_Definition, 960

TIM\_CCMR2\_IC4PSC  
    Peripheral\_Registers\_Bits\_Definition, 960

TIM\_CCMR2\_IC4PSC\_0  
    Peripheral\_Registers\_Bits\_Definition, 960

TIM\_CCMR2\_IC4PSC\_1  
    Peripheral\_Registers\_Bits\_Definition, 960

TIM\_CCMR2\_OC3CE  
    Peripheral\_Registers\_Bits\_Definition, 960

TIM\_CCMR2\_OC3FE  
    Peripheral\_Registers\_Bits\_Definition, 960

TIM\_CCMR2\_OC3M  
    Peripheral\_Registers\_Bits\_Definition, 961

TIM\_CCMR2\_OC3M\_1  
    Peripheral\_Registers\_Bits\_Definition, 961

TIM\_CCMR2\_OC3M\_0  
    Peripheral\_Registers\_Bits\_Definition, 961

TIM\_CCMR2\_OC3M\_2  
    Peripheral\_Registers\_Bits\_Definition, 961

TIM\_CCMR2\_OC3PE  
    Peripheral\_Registers\_Bits\_Definition, 961

TIM\_CCMR2\_OC4CE  
    Peripheral\_Registers\_Bits\_Definition, 961

TIM\_CCMR2\_OC4FE  
    Peripheral\_Registers\_Bits\_Definition, 961

TIM\_CCMR2\_OC4M  
    Peripheral\_Registers\_Bits\_Definition, 962

TIM\_CCMR2\_OC4M\_0  
    Peripheral\_Registers\_Bits\_Definition, 962

TIM\_CCMR2\_OC4M\_1  
    Peripheral\_Registers\_Bits\_Definition, 962

TIM\_CCMR2\_OC4M\_2  
    Peripheral\_Registers\_Bits\_Definition, 962

TIM\_CCMR2\_OC4PE  
    Peripheral\_Registers\_Bits\_Definition, 962

TIM\_CCR1\_CCR1  
    Peripheral\_Registers\_Bits\_Definition, 962

TIM\_CCR2\_CCR2  
    Peripheral\_Registers\_Bits\_Definition, 962

TIM\_CCR3\_CCR3  
    Peripheral\_Registers\_Bits\_Definition, 963

TIM\_CCR4\_CCR4  
    Peripheral\_Registers\_Bits\_Definition, 963

TIM\_CNT\_CNT  
    Peripheral\_Registers\_Bits\_Definition, 963

TIM\_CR1\_ARPE  
    Peripheral\_Registers\_Bits\_Definition, 963

TIM\_CR1\_CEN  
    Peripheral\_Registers\_Bits\_Definition, 963

TIM\_CR1\_CKD  
    Peripheral\_Registers\_Bits\_Definition, 963

TIM\_CR1\_CKD\_0  
    Peripheral\_Registers\_Bits\_Definition, 963

TIM\_CR1\_CKD\_1  
    Peripheral\_Registers\_Bits\_Definition, 964

TIM\_CR1\_CMS  
    Peripheral\_Registers\_Bits\_Definition, 964

TIM\_CR1\_CMS\_0  
    Peripheral\_Registers\_Bits\_Definition, 964

TIM\_CR1\_CMS\_1  
    Peripheral\_Registers\_Bits\_Definition, 964

TIM\_CR1\_DIR  
    Peripheral\_Registers\_Bits\_Definition, 964

TIM\_CR1\_OPM  
    Peripheral\_Registers\_Bits\_Definition, 964

TIM\_CR1\_UDIS  
    Peripheral\_Registers\_Bits\_Definition, 964

TIM\_CR1\_URS  
    Peripheral\_Registers\_Bits\_Definition, 965

TIM\_CR2\_CCDS  
    Peripheral\_Registers\_Bits\_Definition, 965

TIM\_CR2\_CCPC  
    Peripheral\_Registers\_Bits\_Definition, 965

TIM\_CR2\_CCUS  
    Peripheral\_Registers\_Bits\_Definition, 965

TIM\_CR2\_MMS  
    Peripheral\_Registers\_Bits\_Definition, 965

TIM\_CR2\_MMS\_0  
    Peripheral\_Registers\_Bits\_Definition, 965

TIM\_CR2\_MMS\_1  
    Peripheral\_Registers\_Bits\_Definition, 965

TIM\_CR2\_MMS\_2  
    Peripheral\_Registers\_Bits\_Definition, 966

TIM\_CR2\_OIS1  
    Peripheral\_Registers\_Bits\_Definition, 966

TIM\_CR2\_OIS1N  
    Peripheral\_Registers\_Bits\_Definition, 966

TIM\_CR2\_OIS2  
    Peripheral\_Registers\_Bits\_Definition, 966

TIM\_CR2\_OIS2N  
    Peripheral\_Registers\_Bits\_Definition, 966

TIM\_CR2\_OIS3  
    Peripheral\_Registers\_Bits\_Definition, 966

TIM\_CR2\_OIS3N  
    Peripheral\_Registers\_Bits\_Definition, 966

TIM\_CR2\_OIS4  
    Peripheral\_Registers\_Bits\_Definition, 967

TIM\_CR2\_TI1S  
    Peripheral\_Registers\_Bits\_Definition, 967

TIM\_DCR\_DBAA  
    Peripheral\_Registers\_Bits\_Definition, 967

TIM\_DCR\_DBAA\_0  
    Peripheral\_Registers\_Bits\_Definition, 967

TIM\_DCR\_DBAA\_1  
    Peripheral\_Registers\_Bits\_Definition, 967

TIM\_DCR\_DBAA\_2  
    Peripheral\_Registers\_Bits\_Definition, 967

TIM\_DCR\_DB\_A\_3  
    Peripheral\_Registers\_Bits\_Definition, 967

TIM\_DCR\_DB\_A\_4  
    Peripheral\_Registers\_Bits\_Definition, 968

TIM\_DCR\_DB\_L  
    Peripheral\_Registers\_Bits\_Definition, 968

TIM\_DCR\_DB\_L\_0  
    Peripheral\_Registers\_Bits\_Definition, 968

TIM\_DCR\_DB\_L\_1  
    Peripheral\_Registers\_Bits\_Definition, 968

TIM\_DCR\_DB\_L\_2  
    Peripheral\_Registers\_Bits\_Definition, 968

TIM\_DCR\_DB\_L\_3  
    Peripheral\_Registers\_Bits\_Definition, 968

TIM\_DCR\_DB\_L\_4  
    Peripheral\_Registers\_Bits\_Definition, 968

TIM\_DIER\_BIE  
    Peripheral\_Registers\_Bits\_Definition, 968

TIM\_DIER\_CC1DE  
    Peripheral\_Registers\_Bits\_Definition, 969

TIM\_DIER\_CC1IE  
    Peripheral\_Registers\_Bits\_Definition, 969

TIM\_DIER\_CC2DE  
    Peripheral\_Registers\_Bits\_Definition, 969

TIM\_DIER\_CC2IE  
    Peripheral\_Registers\_Bits\_Definition, 969

TIM\_DIER\_CC3DE  
    Peripheral\_Registers\_Bits\_Definition, 969

TIM\_DIER\_CC3IE  
    Peripheral\_Registers\_Bits\_Definition, 969

TIM\_DIER\_CC4DE  
    Peripheral\_Registers\_Bits\_Definition, 969

TIM\_DIER\_CC4IE  
    Peripheral\_Registers\_Bits\_Definition, 970

TIM\_DIER\_COMDE  
    Peripheral\_Registers\_Bits\_Definition, 970

TIM\_DIER\_COMIE  
    Peripheral\_Registers\_Bits\_Definition, 970

TIM\_DIER\_TDE  
    Peripheral\_Registers\_Bits\_Definition, 970

TIM\_DIER\_TIE  
    Peripheral\_Registers\_Bits\_Definition, 970

TIM\_DIER\_UDE  
    Peripheral\_Registers\_Bits\_Definition, 970

TIM\_DIER\_UIE  
    Peripheral\_Registers\_Bits\_Definition, 970

TIM\_DMAR\_DMAB  
    Peripheral\_Registers\_Bits\_Definition, 971

TIM\_EGR\_BG  
    Peripheral\_Registers\_Bits\_Definition, 971

TIM\_EGR\_CC1G  
    Peripheral\_Registers\_Bits\_Definition, 971

TIM\_EGR\_CC2G  
    Peripheral\_Registers\_Bits\_Definition, 971

TIM\_EGR\_CC3G  
    Peripheral\_Registers\_Bits\_Definition, 971

TIM\_EGR\_CC4G  
    Peripheral\_Registers\_Bits\_Definition, 971

TIM\_EGR\_COMG  
    Peripheral\_Registers\_Bits\_Definition, 971

TIM\_EGR\_TG  
    Peripheral\_Registers\_Bits\_Definition, 972

TIM\_EGR\_UG  
    Peripheral\_Registers\_Bits\_Definition, 972

TIM\_OR\_ITR1\_RMP  
    Peripheral\_Registers\_Bits\_Definition, 972

TIM\_OR\_ITR1\_RMP\_0  
    Peripheral\_Registers\_Bits\_Definition, 972

TIM\_OR\_ITR1\_RMP\_1  
    Peripheral\_Registers\_Bits\_Definition, 972

TIM\_OR\_TI4\_RMP  
    Peripheral\_Registers\_Bits\_Definition, 972

TIM\_OR\_TI4\_RMP\_0  
    Peripheral\_Registers\_Bits\_Definition, 972

TIM\_OR\_TI4\_RMP\_1  
    Peripheral\_Registers\_Bits\_Definition, 973

TIM\_PSC\_PSC  
    Peripheral\_Registers\_Bits\_Definition, 973

TIM\_RCR REP  
    Peripheral\_Registers\_Bits\_Definition, 973

TIM\_SMCR\_ECE  
    Peripheral\_Registers\_Bits\_Definition, 973

TIM\_SMCR ETF  
    Peripheral\_Registers\_Bits\_Definition, 973

TIM\_SMCR ETF\_0  
    Peripheral\_Registers\_Bits\_Definition, 973

TIM\_SMCR ETF\_1  
    Peripheral\_Registers\_Bits\_Definition, 973

TIM\_SMCR ETF\_2  
    Peripheral\_Registers\_Bits\_Definition, 974

TIM\_SMCR ETF\_3  
    Peripheral\_Registers\_Bits\_Definition, 974

TIM\_SMCR ETP  
    Peripheral\_Registers\_Bits\_Definition, 974

TIM\_SMCR ETSPS  
    Peripheral\_Registers\_Bits\_Definition, 974

TIM\_SMCR ETPS\_0  
    Peripheral\_Registers\_Bits\_Definition, 974

TIM\_SMCR ETPS\_1  
    Peripheral\_Registers\_Bits\_Definition, 974

TIM\_SMCR MSM  
    Peripheral\_Registers\_Bits\_Definition, 974

TIM\_SMCR SMS  
    Peripheral\_Registers\_Bits\_Definition, 974

TIM\_SMCR SMS\_0  
    Peripheral\_Registers\_Bits\_Definition, 975

TIM\_SMCR SMS\_1  
    Peripheral\_Registers\_Bits\_Definition, 975

TIM\_SMCR SMS\_2  
    Peripheral\_Registers\_Bits\_Definition, 975

TIM\_SMCR TS  
    Peripheral\_Registers\_Bits\_Definition, 975

TIM\_SMCR TS\_0  
    Peripheral\_Registers\_Bits\_Definition, 975

TIM\_SMCR TS\_1  
    Peripheral\_Registers\_Bits\_Definition, 975

TIM\_SMCR\_TS\_2  
Peripheral\_Registers\_Bits\_Definition, 975

TIM\_SR\_BIF  
Peripheral\_Registers\_Bits\_Definition, 976

TIM\_SR\_CC1IF  
Peripheral\_Registers\_Bits\_Definition, 976

TIM\_SR\_CC1OF  
Peripheral\_Registers\_Bits\_Definition, 976

TIM\_SR\_CC2IF  
Peripheral\_Registers\_Bits\_Definition, 976

TIM\_SR\_CC2OF  
Peripheral\_Registers\_Bits\_Definition, 976

TIM\_SR\_CC3IF  
Peripheral\_Registers\_Bits\_Definition, 976

TIM\_SR\_CC3OF  
Peripheral\_Registers\_Bits\_Definition, 976

TIM\_SR\_CC4IF  
Peripheral\_Registers\_Bits\_Definition, 977

TIM\_SR\_CC4OF  
Peripheral\_Registers\_Bits\_Definition, 977

TIM\_SR\_COMIF  
Peripheral\_Registers\_Bits\_Definition, 977

TIM\_SR\_TIF  
Peripheral\_Registers\_Bits\_Definition, 977

TIM\_SR\_UIF  
Peripheral\_Registers\_Bits\_Definition, 977

TIM\_TypeDef, 1059

TIMER Driver, 339

Timer Instances, 174

- TIM1, 175
- TIM2, 175

Timer2\_init  
API Function Prototypes, 343

TIR  
CMSIS, 517

TPI  
CMSIS, 442

Core Definitions, 111

TPI\_ACPR\_PRESCALER\_Msk  
CMSIS, 442

Trace Port Interface (TPI), 91

TPI\_ACPR\_PRESCALER\_Pos  
CMSIS, 442

Trace Port Interface (TPI), 91

TPI\_BASE  
CMSIS, 442

Core Definitions, 111

TPI\_DEVID\_AsynClkIn\_Msk  
CMSIS, 442

Trace Port Interface (TPI), 91

TPI\_DEVID\_AsynClkIn\_Pos  
CMSIS, 442

Trace Port Interface (TPI), 91

TPI\_DEVID\_MANCVALID\_Msk  
CMSIS, 443

Trace Port Interface (TPI), 91

TPI\_DEVID\_MANCVALID\_Pos  
CMSIS, 443

Trace Port Interface (TPI), 91

TPI\_DEVID\_MinBufSz\_Msk  
CMSIS, 443

Trace Port Interface (TPI), 91

TPI\_DEVID\_MinBufSz\_Pos  
CMSIS, 443

Trace Port Interface (TPI), 92

TPI\_DEVID\_NrTraceInput\_Msk  
CMSIS, 443

Trace Port Interface (TPI), 92

TPI\_DEVID\_NrTraceInput\_Pos  
CMSIS, 443

Trace Port Interface (TPI), 92

TPI\_DEVID\_NRZVALID\_Msk  
CMSIS, 443

Trace Port Interface (TPI), 92

TPI\_DEVID\_NRZVALID\_Pos  
CMSIS, 443

Trace Port Interface (TPI), 92

TPI\_DEVID\_PTINVALID\_Msk  
CMSIS, 444

Trace Port Interface (TPI), 92

TPI\_DEVID\_PTINVALID\_Pos  
CMSIS, 444

Trace Port Interface (TPI), 92

TPI\_DEVTYPE\_MajorType\_Msk  
CMSIS, 444

Trace Port Interface (TPI), 92

TPI\_DEVTYPE\_MajorType\_Pos  
CMSIS, 444

Trace Port Interface (TPI), 93

TPI\_DEVTYPE\_SubType\_Msk  
CMSIS, 444

Trace Port Interface (TPI), 93

TPI\_DEVTYPE\_SubType\_Pos  
CMSIS, 444

Trace Port Interface (TPI), 93

TPI\_FFCR\_EnFCont\_Msk  
CMSIS, 444

Trace Port Interface (TPI), 93

TPI\_FFCR\_EnFCont\_Pos  
CMSIS, 444

Trace Port Interface (TPI), 93

TPI\_FFCR\_TrigIn\_Msk  
CMSIS, 445

Trace Port Interface (TPI), 93

TPI\_FFCR\_TrigIn\_Pos  
CMSIS, 445

Trace Port Interface (TPI), 93

TPI\_FFSR\_FInProg\_Msk  
CMSIS, 445

Trace Port Interface (TPI), 93

TPI\_FFSR\_FInProg\_Pos  
CMSIS, 445

Trace Port Interface (TPI), 94

TPI\_FFSR\_FtNonStop\_Msk  
CMSIS, 445

Trace Port Interface (TPI), 94

TPI\_FFSR\_FtNonStop\_Pos  
 CMSIS, 445  
 Trace Port Interface (TPI), 94

TPI\_FFSR\_FtStopped\_Msk  
 CMSIS, 445  
 Trace Port Interface (TPI), 94

TPI\_FFSR\_FtStopped\_Pos  
 CMSIS, 445  
 Trace Port Interface (TPI), 94

TPI\_FFSR\_TCPresent\_Msk  
 CMSIS, 446  
 Trace Port Interface (TPI), 94

TPI\_FFSR\_TCPresent\_Pos  
 CMSIS, 446  
 Trace Port Interface (TPI), 94

TPI\_FIFO0\_ETM0\_Msk  
 CMSIS, 446  
 Trace Port Interface (TPI), 94

TPI\_FIFO0\_ETM0\_Pos  
 CMSIS, 446  
 Trace Port Interface (TPI), 95

TPI\_FIFO0\_ETM1\_Msk  
 CMSIS, 446  
 Trace Port Interface (TPI), 95

TPI\_FIFO0\_ETM1\_Pos  
 CMSIS, 446  
 Trace Port Interface (TPI), 95

TPI\_FIFO0\_ETM2\_Msk  
 CMSIS, 446  
 Trace Port Interface (TPI), 95

TPI\_FIFO0\_ETM2\_Pos  
 CMSIS, 446  
 Trace Port Interface (TPI), 95

TPI\_FIFO0\_ETM\_ATVALID\_Msk  
 CMSIS, 447  
 Trace Port Interface (TPI), 95

TPI\_FIFO0\_ETM\_ATVALID\_Pos  
 CMSIS, 447  
 Trace Port Interface (TPI), 95

TPI\_FIFO0\_ETM\_bytecount\_Msk  
 CMSIS, 447  
 Trace Port Interface (TPI), 95

TPI\_FIFO0\_ETM\_bytecount\_Pos  
 CMSIS, 447  
 Trace Port Interface (TPI), 96

TPI\_FIFO0\_ITM\_ATVALID\_Msk  
 CMSIS, 447  
 Trace Port Interface (TPI), 96

TPI\_FIFO0\_ITM\_ATVALID\_Pos  
 CMSIS, 447  
 Trace Port Interface (TPI), 96

TPI\_FIFO0\_ITM\_bytecount\_Msk  
 CMSIS, 447  
 Trace Port Interface (TPI), 96

TPI\_FIFO0\_ITM\_bytecount\_Pos  
 CMSIS, 447  
 Trace Port Interface (TPI), 96

TPI\_FIFO1\_ETM\_ATVALID\_Msk  
 CMSIS, 448  
 Trace Port Interface (TPI), 96

TPI\_FIFO1\_ETM\_ATVALID\_Pos  
 CMSIS, 448  
 Trace Port Interface (TPI), 96

TPI\_FIFO1\_ETM\_bytecount\_Msk  
 CMSIS, 448  
 Trace Port Interface (TPI), 96

TPI\_FIFO1\_ETM\_bytecount\_Pos  
 CMSIS, 448  
 Trace Port Interface (TPI), 97

TPI\_FIFO1\_ITM0\_Msk  
 CMSIS, 448  
 Trace Port Interface (TPI), 97

TPI\_FIFO1\_ITM0\_Pos  
 CMSIS, 448  
 Trace Port Interface (TPI), 97

TPI\_FIFO1\_ITM1\_Msk  
 CMSIS, 448  
 Trace Port Interface (TPI), 97

TPI\_FIFO1\_ITM1\_Pos  
 CMSIS, 448  
 Trace Port Interface (TPI), 97

TPI\_FIFO1\_ITM2\_Msk  
 CMSIS, 449  
 Trace Port Interface (TPI), 97

TPI\_FIFO1\_ITM2\_Pos  
 CMSIS, 449  
 Trace Port Interface (TPI), 97

TPI\_FIFO1\_ITM\_ATVALID\_Msk  
 CMSIS, 449  
 Trace Port Interface (TPI), 97

TPI\_FIFO1\_ITM\_ATVALID\_Pos  
 CMSIS, 449  
 Trace Port Interface (TPI), 98

TPI\_FIFO1\_ITM\_bytecount\_Msk  
 CMSIS, 449  
 Trace Port Interface (TPI), 98

TPI\_FIFO1\_ITM\_bytecount\_Pos  
 CMSIS, 449  
 Trace Port Interface (TPI), 98

TPI\_ITATBCTR0\_ATREADY\_Msk  
 CMSIS, 449  
 Trace Port Interface (TPI), 98

TPI\_ITATBCTR0\_ATREADY\_Pos  
 CMSIS, 449  
 Trace Port Interface (TPI), 98

TPI\_ITATBCTR2\_ATREADY\_Msk  
 CMSIS, 450  
 Trace Port Interface (TPI), 98

TPI\_ITATBCTR2\_ATREADY\_Pos  
 CMSIS, 450  
 Trace Port Interface (TPI), 98

TPI\_ITCTRL\_Mode\_Msk  
 CMSIS, 450  
 Trace Port Interface (TPI), 98

TPI\_ITCTRL\_Mode\_Pos  
 CMSIS, 450

Trace Port Interface (TPI), 99  
TPI\_SPPR\_TXMODE\_Msk  
  CMSIS, 450  
  Trace Port Interface (TPI), 99  
TPI\_SPPR\_TXMODE\_Pos  
  CMSIS, 450  
  Trace Port Interface (TPI), 99  
TPI\_TRIGGER\_TRIGGER\_Msk  
  CMSIS, 450  
  Trace Port Interface (TPI), 99  
TPI\_TRIGGER\_TRIGGER\_Pos  
  CMSIS, 450  
  Trace Port Interface (TPI), 99  
TPI\_Type, 1060  
TPR  
  ITM Functions, 144  
TR  
  CMSIS, 517  
Trace Port Interface (TPI), 89  
  TPI\_ACPR\_PRESCALER\_Msk, 91  
  TPI\_ACPR\_PRESCALER\_Pos, 91  
  TPI\_DEVID\_AsynClkIn\_Msk, 91  
  TPI\_DEVID\_AsynClkIn\_Pos, 91  
  TPI\_DEVID\_MANCVALID\_Msk, 91  
  TPI\_DEVID\_MANCVALID\_Pos, 91  
  TPI\_DEVID\_MinBufSz\_Msk, 91  
  TPI\_DEVID\_MinBufSz\_Pos, 92  
  TPI\_DEVID\_NrTraceInput\_Msk, 92  
  TPI\_DEVID\_NrTraceInput\_Pos, 92  
  TPI\_DEVID\_NRZVALID\_Msk, 92  
  TPI\_DEVID\_NRZVALID\_Pos, 92  
  TPI\_DEVID\_PTINVALIDID\_Msk, 92  
  TPI\_DEVID\_PTINVALIDID\_Pos, 92  
  TPI\_DEVTYPE\_MajorType\_Msk, 92  
  TPI\_DEVTYPE\_MajorType\_Pos, 93  
  TPI\_DEVTYPE\_SubType\_Msk, 93  
  TPI\_DEVTYPE\_SubType\_Pos, 93  
  TPI\_FFCR\_EnFCont\_Msk, 93  
  TPI\_FFCR\_EnFCont\_Pos, 93  
  TPI\_FFCR\_TrigIn\_Msk, 93  
  TPI\_FFCR\_TrigIn\_Pos, 93  
  TPI\_FFSR\_FInProg\_Msk, 93  
  TPI\_FFSR\_FInProg\_Pos, 94  
  TPI\_FFSR\_FtNonStop\_Msk, 94  
  TPI\_FFSR\_FtNonStop\_Pos, 94  
  TPI\_FFSR\_FtStopped\_Msk, 94  
  TPI\_FFSR\_FtStopped\_Pos, 94  
  TPI\_FFSR\_TCPresent\_Msk, 94  
  TPI\_FFSR\_TCPresent\_Pos, 94  
  TPI\_FIFO0\_ETM0\_Msk, 94  
  TPI\_FIFO0\_ETM0\_Pos, 95  
  TPI\_FIFO0\_ETM1\_Msk, 95  
  TPI\_FIFO0\_ETM1\_Pos, 95  
  TPI\_FIFO0\_ETM2\_Msk, 95  
  TPI\_FIFO0\_ETM2\_Pos, 95  
  TPI\_FIFO0\_ETM\_ATVALID\_Msk, 95  
  TPI\_FIFO0\_ETM\_ATVALID\_Pos, 95  
  TPI\_FIFO0\_ETM\_bytecount\_Msk, 95  
  TPI\_FIFO0\_ETM\_bytecount\_Pos, 96  
  TPI\_FIFO0\_ITM\_ATVALID\_Msk, 96  
  TPI\_FIFO0\_ITM\_ATVALID\_Pos, 96  
  TPI\_FIFO0\_ITM\_bytecount\_Msk, 96  
  TPI\_FIFO0\_ITM\_bytecount\_Pos, 96  
  TPI\_FIFO1\_ETM\_ATVALID\_Msk, 96  
  TPI\_FIFO1\_ETM\_ATVALID\_Pos, 96  
  TPI\_FIFO1\_ETM\_bytecount\_Msk, 96  
  TPI\_FIFO1\_ETM\_bytecount\_Pos, 97  
  TPI\_FIFO1\_ITM0\_Msk, 97  
  TPI\_FIFO1\_ITM0\_Pos, 97  
  TPI\_FIFO1\_ITM1\_Msk, 97  
  TPI\_FIFO1\_ITM1\_Pos, 97  
  TPI\_FIFO1\_ITM2\_Msk, 97  
  TPI\_FIFO1\_ITM2\_Pos, 97  
  TPI\_FIFO1\_ITM\_ATVALID\_Msk, 97  
  TPI\_FIFO1\_ITM\_ATVALID\_Pos, 98  
  TPI\_FIFO1\_ITM\_bytecount\_Msk, 98  
  TPI\_FIFO1\_ITM\_bytecount\_Pos, 98  
  TPI\_ITATBCTR0\_ATREADY\_Msk, 98  
  TPI\_ITATBCTR0\_ATREADY\_Pos, 98  
  TPI\_ITATBCTR2\_ATREADY\_Msk, 98  
  TPI\_ITATBCTR2\_ATREADY\_Pos, 98  
  TPI\_ITCTRL\_Mode\_Msk, 98  
  TPI\_ITCTRL\_Mode\_Pos, 99  
  TPI\_SPPR\_TXMODE\_Msk, 99  
  TPI\_SPPR\_TXMODE\_Pos, 99  
  TPI\_TRIGGER\_TRIGGER\_Msk, 99  
  TPI\_TRIGGER\_TRIGGER\_Pos, 99  
TRIGGER  
  ITM Functions, 144  
Trigger\_Alarm  
  API\_Definitions, 377  
  ECU APIs, 367  
TRISE  
  CMSIS, 517  
  I2C\_TypeDef, 1021  
TRUE  
  Platform Standard Types, 152  
TSDR  
  CMSIS, 518  
TSR  
  CMSIS, 518  
TSSR  
  CMSIS, 518  
TSTR  
  CMSIS, 518  
TWCR  
  CMSIS, 518  
TXCRCR  
  CMSIS, 518  
  SPI\_TypeDef, 1051  
TXE  
  S\_IRQ\_SRC, 1042  
u16  
  ITM Functions, 144  
u32  
  ITM Functions, 144, 145

u8  
 ITM Functions, 145  
**UART8\_BASE**  
 Peripheral\_memory\_map, 536  
**uc16**  
 Exported\_types, 528  
**uc32**  
 Exported\_types, 528  
**uc8**  
 Exported\_types, 528  
**uint16**  
 Platform Standard Types, 154  
**uint16\_least**  
 Platform Standard Types, 154  
**uint32**  
 Platform Standard Types, 154  
**uint32\_least**  
 Platform Standard Types, 154  
**uint64**  
 Platform Standard Types, 154  
**uint8**  
 Platform Standard Types, 154  
**uint8\_least**  
 Platform Standard Types, 154  
**UsageFault\_IRQHandler**  
 Configuration\_section\_for\CMSIS, 524  
**USART Driver**, 344  
**USART Instances**, 175  
 USART1, 176  
 USART2, 176  
 USART6, 176  
**USART Register Map**, 165  
**USART1**  
 USART Instances, 176  
**USART1\_IRQHandler**  
 Configuration\_section\_for\CMSIS, 526  
**USART2**  
 USART Instances, 176  
**USART2\_IRQHandler**  
 Configuration\_section\_for\CMSIS, 526  
**USART6**  
 USART Instances, 176  
**USART6\_IRQHandler**  
 Configuration\_section\_for\CMSIS, 526  
**USART\_BRR\_DIV\_Fraction**  
 PeripheralRegisters\_Bits\_Definition, 977  
**USART\_BRR\_DIV\_Mantissa**  
 PeripheralRegisters\_Bits\_Definition, 977  
**USART\_cfg\_t**, 1061  
**USART\_CR1\_IDLEIE**  
 PeripheralRegisters\_Bits\_Definition, 978  
**USART\_CR1\_M**  
 PeripheralRegisters\_Bits\_Definition, 978  
**USART\_CR1\_OVER8**  
 PeripheralRegisters\_Bits\_Definition, 978  
**USART\_CR1\_PCE**  
 PeripheralRegisters\_Bits\_Definition, 978  
**USART\_CR1\_PEIE**  
 PeripheralRegisters\_Bits\_Definition, 978  
**PeripheralRegisters\_Bits\_Definition**, 978  
**USART\_CR1\_PS**  
 PeripheralRegisters\_Bits\_Definition, 978  
**USART\_CR1\_RE**  
 PeripheralRegisters\_Bits\_Definition, 978  
**USART\_CR1\_RWU**  
 PeripheralRegisters\_Bits\_Definition, 979  
**USART\_CR1\_RXNEIE**  
 PeripheralRegisters\_Bits\_Definition, 979  
**USART\_CR1\_SBK**  
 PeripheralRegisters\_Bits\_Definition, 979  
**USART\_CR1\_TCIE**  
 PeripheralRegisters\_Bits\_Definition, 979  
**USART\_CR1\_TE**  
 PeripheralRegisters\_Bits\_Definition, 979  
**USART\_CR1\_TXEIE**  
 PeripheralRegisters\_Bits\_Definition, 979  
**USART\_CR1\_UE**  
 PeripheralRegisters\_Bits\_Definition, 979  
**USART\_CR1\_WAKE**  
 PeripheralRegisters\_Bits\_Definition, 980  
**USART\_CR2\_ADD**  
 PeripheralRegisters\_Bits\_Definition, 980  
**USART\_CR2\_CLKEN**  
 PeripheralRegisters\_Bits\_Definition, 980  
**USART\_CR2\_CPHA**  
 PeripheralRegisters\_Bits\_Definition, 980  
**USART\_CR2\_CPOL**  
 PeripheralRegisters\_Bits\_Definition, 980  
**USART\_CR2\_LBCL**  
 PeripheralRegisters\_Bits\_Definition, 980  
**USART\_CR2\_LBDIE**  
 PeripheralRegisters\_Bits\_Definition, 980  
**USART\_CR2\_LBDL**  
 PeripheralRegisters\_Bits\_Definition, 981  
**USART\_CR2\_LINE\_N**  
 PeripheralRegisters\_Bits\_Definition, 981  
**USART\_CR2\_STOP**  
 PeripheralRegisters\_Bits\_Definition, 981  
**USART\_CR2\_STOP\_0**  
 PeripheralRegisters\_Bits\_Definition, 981  
**USART\_CR2\_STOP\_1**  
 PeripheralRegisters\_Bits\_Definition, 981  
**USART\_CR3\_CTSE**  
 PeripheralRegisters\_Bits\_Definition, 981  
**USART\_CR3\_CTSIE**  
 PeripheralRegisters\_Bits\_Definition, 981  
**USART\_CR3\_DMAR**  
 PeripheralRegisters\_Bits\_Definition, 982  
**USART\_CR3\_DMAT**  
 PeripheralRegisters\_Bits\_Definition, 982  
**USART\_CR3\_EIE**  
 PeripheralRegisters\_Bits\_Definition, 982  
**USART\_CR3\_HDSEL**  
 PeripheralRegisters\_Bits\_Definition, 982  
**USART\_CR3\_IREN**  
 PeripheralRegisters\_Bits\_Definition, 982  
**USART\_CR3\_IRLP**

Peripheral\_Registers\_Bits\_Definition, 982  
USART\_CR3\_NACK  
Peripheral\_Registers\_Bits\_Definition, 982  
USART\_CR3\_ONEBIT  
Peripheral\_Registers\_Bits\_Definition, 983  
USART\_CR3\_RTSE  
Peripheral\_Registers\_Bits\_Definition, 983  
USART\_CR3\_SCEN  
Peripheral\_Registers\_Bits\_Definition, 983  
USART\_DR\_DR  
Peripheral\_Registers\_Bits\_Definition, 983  
USART\_GTPR\_GT  
Peripheral\_Registers\_Bits\_Definition, 983  
USART\_GTPR\_PSC  
Peripheral\_Registers\_Bits\_Definition, 983  
USART\_GTPR\_PSC\_0  
Peripheral\_Registers\_Bits\_Definition, 983  
USART\_GTPR\_PSC\_1  
Peripheral\_Registers\_Bits\_Definition, 984  
USART\_GTPR\_PSC\_2  
Peripheral\_Registers\_Bits\_Definition, 984  
USART\_GTPR\_PSC\_3  
Peripheral\_Registers\_Bits\_Definition, 984  
USART\_GTPR\_PSC\_4  
Peripheral\_Registers\_Bits\_Definition, 984  
USART\_GTPR\_PSC\_5  
Peripheral\_Registers\_Bits\_Definition, 984  
USART\_GTPR\_PSC\_6  
Peripheral\_Registers\_Bits\_Definition, 984  
USART\_GTPR\_PSC\_7  
Peripheral\_Registers\_Bits\_Definition, 984  
USART\_SR\_CTS  
Peripheral\_Registers\_Bits\_Definition, 984  
USART\_SR\_FE  
Peripheral\_Registers\_Bits\_Definition, 985  
USART\_SR\_IDLE  
Peripheral\_Registers\_Bits\_Definition, 985  
USART\_SR\_LBD  
Peripheral\_Registers\_Bits\_Definition, 985  
USART\_SR\_NE  
Peripheral\_Registers\_Bits\_Definition, 985  
USART\_SR\_ORE  
Peripheral\_Registers\_Bits\_Definition, 985  
USART\_SR\_PE  
Peripheral\_Registers\_Bits\_Definition, 985  
USART\_SR\_RXNE  
Peripheral\_Registers\_Bits\_Definition, 985  
USART\_SR\_TC  
Peripheral\_Registers\_Bits\_Definition, 986  
USART\_SR\_TXE  
Peripheral\_Registers\_Bits\_Definition, 986  
USART\_TypeDef, 1062  
BRR, 1062  
CR1, 1063  
CR2, 1063  
CR3, 1063  
DR, 1063  
GTPR, 1063  
SR, 1063  
UserLCD\_PrintFreeSlots  
API\_Definitions, 377  
ECU APIs, 368  
  
V  
ITM Functions, 145  
  
VAL  
ITM Functions, 146  
STK\_TypeDef, 1054  
  
VECT\_TAB\_OFFSET  
STM32F4xx\_System\_Private\_Defines, 995  
  
VoidPtr  
Platform Standard Types, 155  
  
vsc16  
Exported\_types, 529  
  
vsc32  
Exported\_types, 529  
  
vsc8  
Exported\_types, 529  
  
VTOR  
ITM Functions, 146  
SCB\_TypeDef, 1048  
  
vuc16  
Exported\_types, 529  
  
vuc32  
Exported\_types, 529  
  
vuc8  
Exported\_types, 529  
  
vuint16\_t  
Platform Standard Types, 155  
  
vuint32\_t  
Platform Standard Types, 155  
  
vuint8\_t  
Platform Standard Types, 155  
  
W  
ITM Functions, 146  
  
WHPCR  
CMSIS, 518  
  
WithoutStop  
I2C Driver, 271  
  
WithStop  
I2C Driver, 271  
  
WPR  
CMSIS, 519  
  
Wrong\_RFID  
API\_Definitions, 378  
ECU APIs, 369  
  
WUTR  
CMSIS, 519  
  
WVPCR  
CMSIS, 519  
  
WWDG\_CFR\_EWI  
Peripheral\_Registers\_Bits\_Definition, 986  
  
WWDG\_CFR\_W  
Peripheral\_Registers\_Bits\_Definition, 986  
  
WWDG\_CFR\_W\_0  
Peripheral\_Registers\_Bits\_Definition, 986

**WWDG\_CFR\_W\_1**  
 Peripheral\_Registers\_Bits\_Definition, [986](#)  
**WWDG\_CFR\_W\_2**  
 Peripheral\_Registers\_Bits\_Definition, [986](#)  
**WWDG\_CFR\_W\_3**  
 Peripheral\_Registers\_Bits\_Definition, [987](#)  
**WWDG\_CFR\_W\_4**  
 Peripheral\_Registers\_Bits\_Definition, [987](#)  
**WWDG\_CFR\_W\_5**  
 Peripheral\_Registers\_Bits\_Definition, [987](#)  
**WWDG\_CFR\_W\_6**  
 Peripheral\_Registers\_Bits\_Definition, [987](#)  
**WWDG\_CFR\_WDGTB**  
 Peripheral\_Registers\_Bits\_Definition, [987](#)  
**WWDG\_CFR\_WDGTB\_0**  
 Peripheral\_Registers\_Bits\_Definition, [987](#)  
**WWDG\_CFR\_WDGTB\_1**  
 Peripheral\_Registers\_Bits\_Definition, [987](#)  
**WWDG\_CR\_T**  
 Peripheral\_Registers\_Bits\_Definition, [987](#)  
**WWDG\_CR\_T\_0**  
 Peripheral\_Registers\_Bits\_Definition, [988](#)  
**WWDG\_CR\_T\_1**  
 Peripheral\_Registers\_Bits\_Definition, [988](#)  
**WWDG\_CR\_T\_2**  
 Peripheral\_Registers\_Bits\_Definition, [988](#)  
**WWDG\_CR\_T\_4**  
 Peripheral\_Registers\_Bits\_Definition, [988](#)  
**WWDG\_CR\_T\_5**  
 Peripheral\_Registers\_Bits\_Definition, [988](#)  
**WWDG\_CR\_T\_6**  
 Peripheral\_Registers\_Bits\_Definition, [988](#)  
**WWDG\_CR\_WDGA**  
 Peripheral\_Registers\_Bits\_Definition, [988](#)  
**WWDG\_IRQn**  
 Configuration\_section\_for\_CMSIS, [524](#)  
**WWDG\_SR\_EWIF**  
 Peripheral\_Registers\_Bits\_Definition, [989](#)  
**WWDG\_TypeDef**, [1064](#)

**xPSR\_C\_Msk**  
 CMSIS, [451](#)  
 Status and Control Registers, [47](#)  
**xPSR\_C\_Pos**  
 CMSIS, [451](#)  
 Status and Control Registers, [47](#)  
**xPSR\_GE\_Msk**  
 CMSIS, [451](#)  
 Status and Control Registers, [47](#)  
**xPSR\_GE\_Pos**  
 CMSIS, [451](#)  
 Status and Control Registers, [47](#)  
**xPSR\_ISR\_Msk**  
 CMSIS, [451](#)  
 Status and Control Registers, [47](#)  
**xPSR\_ISR\_Pos**  
 CMSIS, [451](#)

**xPSR\_IT\_Msk**  
 CMSIS, [451](#)  
 Status and Control Registers, [47](#)  
**xPSR\_IT\_Pos**  
 CMSIS, [451](#)  
 Status and Control Registers, [47](#)  
**xPSR\_N\_Msk**  
 CMSIS, [452](#)  
 Status and Control Registers, [48](#)  
**xPSR\_N\_Pos**  
 CMSIS, [452](#)  
 Status and Control Registers, [48](#)  
**xPSR\_Q\_Msk**  
 CMSIS, [452](#)  
 Status and Control Registers, [48](#)  
**xPSR\_Q\_Pos**  
 CMSIS, [452](#)  
 Status and Control Registers, [48](#)  
**xPSR\_T\_Msk**  
 CMSIS, [452](#)  
 Status and Control Registers, [48](#)  
**xPSR\_T\_Pos**  
 CMSIS, [452](#)  
 Status and Control Registers, [48](#)  
**xPSR\_Type**, [1064](#)  
**xPSR\_V\_Msk**  
 CMSIS, [452](#)  
 Status and Control Registers, [48](#)  
**xPSR\_V\_Pos**  
 CMSIS, [452](#)  
 Status and Control Registers, [48](#)  
**xPSR\_Z\_Msk**  
 CMSIS, [453](#)  
 Status and Control Registers, [49](#)  
**xPSR\_Z\_Pos**  
 CMSIS, [453](#)  
 Status and Control Registers, [49](#)

**Z**  
 ITM Functions, [146](#), [147](#)