1 /**
2   ******************************************************************************
3   * @file    stm32h7xx.h
4   * @author  MCD Application Team
5   * @brief   CMSIS STM32H7xx Device Peripheral Access Layer Header File.
6   *
7   *          The file is the unique include file that the application programmer
8   *          is using in the C source code, usually in main.c. This file contains:
9   *           - Configuration section that allows to select:
10   *              - The STM32H7xx device used in the target application
11   *              - To use or not the peripheral's drivers in application code(i.e.
12   *                code will be based on direct access to peripheral's registers
13   *                rather than drivers API), this option is controlled by
14   *                "#define USE_HAL_DRIVER"
15   *
16   ******************************************************************************
17   * @attention
18   *
19   * Copyright (c) 2017 STMicroelectronics.
20   * All rights reserved.
21   *
22   * This software is licensed under terms that can be found in the LICENSE file
23   * in the root directory of this software component.
24   * If no LICENSE file comes with this software, it is provided AS-IS.
25   *
26   ******************************************************************************
27   */
28 
29 /** @addtogroup CMSIS
30   * @{
31   */
32 
33 /** @addtogroup stm32h7xx
34   * @{
35   */
36 
37 #ifndef STM32H7xx_H
38 #define STM32H7xx_H
39 
40 #ifdef __cplusplus
41  extern "C" {
42 #endif /* __cplusplus */
43 
44 /** @addtogroup Library_configuration_section
45   * @{
46   */
47 
48 /**
49   * @brief STM32 Family
50   */
51 #if !defined  (STM32H7)
52 #define STM32H7
53 #endif /* STM32H7 */
54 
55 
56 /* Uncomment the line below according to the target STM32H7 device used in your
57    application
58   */
59 
60 #if !defined (STM32H743xx) && !defined (STM32H753xx)  && !defined (STM32H750xx) && !defined (STM32H742xx) && \
61     !defined (STM32H745xx) && !defined (STM32H745xG)  && !defined (STM32H755xx)  && !defined (STM32H747xx) && !defined (STM32H747xG)&& !defined (STM32H757xx) && \
62     !defined (STM32H7A3xx) && !defined (STM32H7A3xxQ) && !defined (STM32H7B3xx) && !defined (STM32H7B3xxQ) && !defined (STM32H7B0xx)  && !defined (STM32H7B0xxQ) && \
63     !defined (STM32H735xx) && !defined (STM32H733xx)  && !defined (STM32H730xx) && !defined (STM32H730xxQ)  && !defined (STM32H725xx) && !defined (STM32H723xx)
64   /* #define STM32H742xx */   /*!< STM32H742VI, STM32H742ZI, STM32H742AI, STM32H742II, STM32H742BI, STM32H742XI Devices */
65   /* #define STM32H743xx */   /*!< STM32H743VI, STM32H743ZI, STM32H743AI, STM32H743II, STM32H743BI, STM32H743XI Devices */
66   /* #define STM32H753xx */   /*!< STM32H753VI, STM32H753ZI, STM32H753AI, STM32H753II, STM32H753BI, STM32H753XI Devices */
67   /* #define STM32H750xx */   /*!< STM32H750V, STM32H750I, STM32H750X Devices */
68   /* #define STM32H747xx */   /*!< STM32H747ZI, STM32H747AI, STM32H747II, STM32H747BI, STM32H747XI Devices */
69   /* #define STM32H747xG */   /*!< STM32H747AG, STM32H747IG, STM32H747BG, STM32H747XG */
70   /* #define STM32H757xx */   /*!< STM32H757ZI, STM32H757AI, STM32H757II, STM32H757BI, STM32H757XI Devices */
71   /* #define STM32H745xx */   /*!< STM32H745ZI, STM32H745II, STM32H745BI, STM32H745XI Devices  */
72   /* #define STM32H745xG */   /*!< STM32H745ZG, STM32H745IG, STM32H745BG, STM32H745XG Devices  */
73   /* #define STM32H755xx */   /*!< STM32H755ZI, STM32H755II, STM32H755BI, STM32H755XI Devices  */
74   /* #define STM32H7B0xx */   /*!< STM32H7B0ABIxQ, STM32H7B0IBTx, STM32H7B0RBTx, STM32H7B0VBTx, STM32H7B0ZBTx, STM32H7B0IBKxQ */
75   /* #define STM32H7A3xx */   /*!< STM32H7A3IIK6, STM32H7A3IIT6, STM32H7A3NIH6, STM32H7A3RIT6, STM32H7A3VIH6, STM32H7A3VIT6, STM32H7A3ZIT6 */
76   /* #define STM32H7A3xxQ */  /*!< STM32H7A3QIY6Q, STM32H7A3IIK6Q, STM32H7A3IIT6Q, STM32H7A3LIH6Q, STM32H7A3VIH6Q, STM32H7A3VIT6Q, STM32H7A3AII6Q, STM32H7A3ZIT6Q */
77   /* #define STM32H7B3xx */   /*!< STM32H7B3IIK6, STM32H7B3IIT6, STM32H7B3NIH6, STM32H7B3RIT6, STM32H7B3VIH6, STM32H7B3VIT6, STM32H7B3ZIT6 */
78   /* #define STM32H7B3xxQ */  /*!< STM32H7B3QIY6Q, STM32H7B3IIK6Q, STM32H7B3IIT6Q, STM32H7B3LIH6Q, STM32H7B3VIH6Q, STM32H7B3VIT6Q, STM32H7B3AII6Q, STM32H7B3ZIT6Q */
79   /* #define STM32H735xx */   /*!< STM32H735AGI6, STM32H735IGK6, STM32H735RGV6, STM32H735VGT6, STM32H735VGY6, STM32H735ZGT6 Devices */
80   /* #define STM32H733xx */   /*!< STM32H733VGH6, STM32H733VGT6, STM32H733ZGI6, STM32H733ZGT6, Devices */
81   /* #define STM32H730xx */   /*!< STM32H730VBH6, STM32H730VBT6, STM32H730ZBT6, STM32H730ZBI6 Devices */
82   /* #define STM32H730xxQ */  /*!< STM32H730IBT6Q, STM32H730ABI6Q, STM32H730IBK6Q Devices */
83   /* #define STM32H725xx */   /*!< STM32H725AGI6, STM32H725IGK6, STM32H725IGT6, STM32H725RGV6, STM32H725VGT6, STM32H725VGY6, STM32H725ZGT6, STM32H725REV6, SM32H725VET6, STM32H725ZET6, STM32H725AEI6, STM32H725IET6, STM32H725IEK6  Devices */
84   /* #define STM32H723xx */   /*!< STM32H723VGH6, STM32H723VGT6, STM32H723ZGI6, STM32H723ZGT6, STM32H723VET6, STM32H723VEH6, STM32H723ZET6, STM32H723ZEI6 Devices */
85 #endif
86 
87 /*  Tip: To avoid modifying this file each time you need to switch between these
88         devices, you can define the device in your toolchain compiler preprocessor.
89   */
90 
91 #if defined(DUAL_CORE) && !defined(CORE_CM4) && !defined(CORE_CM7)
92  #error "Dual core device, please select CORE_CM4 or CORE_CM7"
93 #endif
94 
95 #if !defined  (USE_HAL_DRIVER)
96 /**
97  * @brief Comment the line below if you will not use the peripherals drivers.
98    In this case, these drivers will not be included and the application code will
99    be based on direct access to peripherals registers
100    */
101   /*#define USE_HAL_DRIVER */
102 #endif /* USE_HAL_DRIVER */
103 
104 /**
105   * @brief CMSIS Device version number V1.10.3
106   */
107 #define __STM32H7xx_CMSIS_DEVICE_VERSION_MAIN   (0x01) /*!< [31:24] main version */
108 #define __STM32H7xx_CMSIS_DEVICE_VERSION_SUB1   (0x0A) /*!< [23:16] sub1 version */
109 #define __STM32H7xx_CMSIS_DEVICE_VERSION_SUB2   (0x03) /*!< [15:8]  sub2 version */
110 #define __STM32H7xx_CMSIS_DEVICE_VERSION_RC     (0x00) /*!< [7:0]  release candidate */
111 #define __STM32H7xx_CMSIS_DEVICE_VERSION        ((__STM32H7xx_CMSIS_DEVICE_VERSION_MAIN     << 24)\
112                                       |(__STM32H7xx_CMSIS_DEVICE_VERSION_SUB1 << 16)\
113                                       |(__STM32H7xx_CMSIS_DEVICE_VERSION_SUB2 << 8 )\
114                                       |(__STM32H7xx_CMSIS_DEVICE_VERSION_RC))
115 
116 /**
117   * @}
118   */
119 
120 /** @addtogroup Device_Included
121   * @{
122   */
123 
124 #if defined(STM32H743xx)
125   #include "stm32h743xx.h"
126 #elif defined(STM32H753xx)
127   #include "stm32h753xx.h"
128 #elif defined(STM32H750xx)
129   #include "stm32h750xx.h"
130 #elif defined(STM32H742xx)
131   #include "stm32h742xx.h"
132 #elif defined(STM32H745xx)
133   #include "stm32h745xx.h"
134 #elif defined(STM32H745xG)
135   #include "stm32h745xg.h"
136 #elif defined(STM32H755xx)
137   #include "stm32h755xx.h"
138 #elif defined(STM32H747xx)
139   #include "stm32h747xx.h"
140 #elif defined(STM32H747xG)
141   #include "stm32h747xg.h"
142 #elif defined(STM32H757xx)
143   #include "stm32h757xx.h"
144 #elif defined(STM32H7B0xx)
145   #include "stm32h7b0xx.h"
146 #elif defined(STM32H7B0xxQ)
147   #include "stm32h7b0xxq.h"
148 #elif defined(STM32H7A3xx)
149   #include "stm32h7a3xx.h"
150 #elif defined(STM32H7B3xx)
151   #include "stm32h7b3xx.h"
152 #elif defined(STM32H7A3xxQ)
153   #include "stm32h7a3xxq.h"
154 #elif defined(STM32H7B3xxQ)
155   #include "stm32h7b3xxq.h"
156 #elif defined(STM32H735xx)
157   #include "stm32h735xx.h"
158 #elif defined(STM32H733xx)
159   #include "stm32h733xx.h"
160 #elif defined(STM32H730xx)
161   #include "stm32h730xx.h"
162 #elif defined(STM32H730xxQ)
163   #include "stm32h730xxq.h"
164 #elif defined(STM32H725xx)
165   #include "stm32h725xx.h"
166 #elif defined(STM32H723xx)
167   #include "stm32h723xx.h"
168 #else
169  #error "Please select first the target STM32H7xx device used in your application (in stm32h7xx.h file)"
170 #endif
171 
172 /**
173   * @}
174   */
175 
176 /** @addtogroup Exported_types
177   * @{
178   */
179 typedef enum
180 {
181   RESET = 0,
182   SET = !RESET
183 } FlagStatus, ITStatus;
184 
185 typedef enum
186 {
187   DISABLE = 0,
188   ENABLE = !DISABLE
189 } FunctionalState;
190 #define IS_FUNCTIONAL_STATE(STATE) (((STATE) == DISABLE) || ((STATE) == ENABLE))
191 
192 typedef enum
193 {
194   SUCCESS = 0,
195   ERROR = !SUCCESS
196 } ErrorStatus;
197 
198 /**
199   * @}
200   */
201 
202 
203 /** @addtogroup Exported_macros
204   * @{
205   */
206 #define SET_BIT(REG, BIT)     ((REG) |= (BIT))
207 
208 #define CLEAR_BIT(REG, BIT)   ((REG) &= ~(BIT))
209 
210 #define READ_BIT(REG, BIT)    ((REG) & (BIT))
211 
212 #define CLEAR_REG(REG)        ((REG) = (0x0))
213 
214 #define WRITE_REG(REG, VAL)   ((REG) = (VAL))
215 
216 #define READ_REG(REG)         ((REG))
217 
218 #define MODIFY_REG(REG, CLEARMASK, SETMASK)  WRITE_REG((REG), (((READ_REG(REG)) & (~(CLEARMASK))) | (SETMASK)))
219 
220 #define POSITION_VAL(VAL)     (__CLZ(__RBIT(VAL)))
221 
222 /* Use of CMSIS compiler intrinsics for register exclusive access */
223 /* Atomic 32-bit register access macro to set one or several bits */
224 #define ATOMIC_SET_BIT(REG, BIT)                             \
225   do {                                                       \
226     uint32_t val;                                            \
227     do {                                                     \
228       val = __LDREXW((__IO uint32_t *)&(REG)) | (BIT);       \
229     } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U); \
230   } while(0)
231 
232 /* Atomic 32-bit register access macro to clear one or several bits */
233 #define ATOMIC_CLEAR_BIT(REG, BIT)                           \
234   do {                                                       \
235     uint32_t val;                                            \
236     do {                                                     \
237       val = __LDREXW((__IO uint32_t *)&(REG)) & ~(BIT);      \
238     } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U); \
239   } while(0)
240 
241 /* Atomic 32-bit register access macro to clear and set one or several bits */
242 #define ATOMIC_MODIFY_REG(REG, CLEARMSK, SETMASK)                          \
243   do {                                                                     \
244     uint32_t val;                                                          \
245     do {                                                                   \
246       val = (__LDREXW((__IO uint32_t *)&(REG)) & ~(CLEARMSK)) | (SETMASK); \
247     } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U);               \
248   } while(0)
249 
250 /* Atomic 16-bit register access macro to set one or several bits */
251 #define ATOMIC_SETH_BIT(REG, BIT)                            \
252   do {                                                       \
253     uint16_t val;                                            \
254     do {                                                     \
255       val = __LDREXH((__IO uint16_t *)&(REG)) | (BIT);       \
256     } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U); \
257   } while(0)
258 
259 /* Atomic 16-bit register access macro to clear one or several bits */
260 #define ATOMIC_CLEARH_BIT(REG, BIT)                          \
261   do {                                                       \
262     uint16_t val;                                            \
263     do {                                                     \
264       val = __LDREXH((__IO uint16_t *)&(REG)) & ~(BIT);      \
265     } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U); \
266   } while(0)
267 
268 /* Atomic 16-bit register access macro to clear and set one or several bits */
269 #define ATOMIC_MODIFYH_REG(REG, CLEARMSK, SETMASK)                         \
270   do {                                                                     \
271     uint16_t val;                                                          \
272     do {                                                                   \
273       val = (__LDREXH((__IO uint16_t *)&(REG)) & ~(CLEARMSK)) | (SETMASK); \
274     } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U);               \
275   } while(0)
276 
277 /**
278   * @}
279   */
280 
281 #if defined (USE_HAL_DRIVER)
282  #include "stm32h7xx_hal.h"
283 #endif /* USE_HAL_DRIVER */
284 
285 
286 #ifdef __cplusplus
287 }
288 #endif /* __cplusplus */
289 
290 #endif /* STM32H7xx_H */
291 /**
292   * @}
293   */
294 
295 /**
296   * @}
297   */
298 
299 
300 
301 
302