123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301 |
- #ifndef STM32H7xx_H
- #define STM32H7xx_H
- #ifdef __cplusplus
- extern "C" {
- #endif
- #if !defined (STM32H7)
- #define STM32H7
- #endif
- #if !defined (STM32H743xx) && !defined (STM32H753xx) && !defined (STM32H750xx) && !defined (STM32H742xx) && \
- !defined (STM32H745xx) && !defined (STM32H745xG) && !defined (STM32H755xx) && !defined (STM32H747xx) && !defined (STM32H747xG)&& !defined (STM32H757xx) && \
- !defined (STM32H7A3xx) && !defined (STM32H7A3xxQ) && !defined (STM32H7B3xx) && !defined (STM32H7B3xxQ) && !defined (STM32H7B0xx) && !defined (STM32H7B0xxQ) && \
- !defined (STM32H735xx) && !defined (STM32H733xx) && !defined (STM32H730xx) && !defined (STM32H730xxQ) && !defined (STM32H725xx) && !defined (STM32H723xx)
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- #endif
- #if defined(DUAL_CORE) && !defined(CORE_CM4) && !defined(CORE_CM7)
- #error "Dual core device, please select CORE_CM4 or CORE_CM7"
- #endif
- #if !defined (USE_HAL_DRIVER)
-
- #endif
- #define __STM32H7xx_CMSIS_DEVICE_VERSION_MAIN (0x01)
- #define __STM32H7xx_CMSIS_DEVICE_VERSION_SUB1 (0x0A)
- #define __STM32H7xx_CMSIS_DEVICE_VERSION_SUB2 (0x04)
- #define __STM32H7xx_CMSIS_DEVICE_VERSION_RC (0x00)
- #define __STM32H7xx_CMSIS_DEVICE_VERSION ((__STM32H7xx_CMSIS_DEVICE_VERSION_MAIN << 24)\
- |(__STM32H7xx_CMSIS_DEVICE_VERSION_SUB1 << 16)\
- |(__STM32H7xx_CMSIS_DEVICE_VERSION_SUB2 << 8 )\
- |(__STM32H7xx_CMSIS_DEVICE_VERSION_RC))
- #if defined(STM32H743xx)
- #include "stm32h743xx.h"
- #elif defined(STM32H753xx)
- #include "stm32h753xx.h"
- #elif defined(STM32H750xx)
- #include "stm32h750xx.h"
- #elif defined(STM32H742xx)
- #include "stm32h742xx.h"
- #elif defined(STM32H745xx)
- #include "stm32h745xx.h"
- #elif defined(STM32H745xG)
- #include "stm32h745xg.h"
- #elif defined(STM32H755xx)
- #include "stm32h755xx.h"
- #elif defined(STM32H747xx)
- #include "stm32h747xx.h"
- #elif defined(STM32H747xG)
- #include "stm32h747xg.h"
- #elif defined(STM32H757xx)
- #include "stm32h757xx.h"
- #elif defined(STM32H7B0xx)
- #include "stm32h7b0xx.h"
- #elif defined(STM32H7B0xxQ)
- #include "stm32h7b0xxq.h"
- #elif defined(STM32H7A3xx)
- #include "stm32h7a3xx.h"
- #elif defined(STM32H7B3xx)
- #include "stm32h7b3xx.h"
- #elif defined(STM32H7A3xxQ)
- #include "stm32h7a3xxq.h"
- #elif defined(STM32H7B3xxQ)
- #include "stm32h7b3xxq.h"
- #elif defined(STM32H735xx)
- #include "stm32h735xx.h"
- #elif defined(STM32H733xx)
- #include "stm32h733xx.h"
- #elif defined(STM32H730xx)
- #include "stm32h730xx.h"
- #elif defined(STM32H730xxQ)
- #include "stm32h730xxq.h"
- #elif defined(STM32H725xx)
- #include "stm32h725xx.h"
- #elif defined(STM32H723xx)
- #include "stm32h723xx.h"
- #else
- #error "Please select first the target STM32H7xx device used in your application (in stm32h7xx.h file)"
- #endif
- typedef enum
- {
- RESET = 0,
- SET = !RESET
- } FlagStatus, ITStatus;
- typedef enum
- {
- DISABLE = 0,
- ENABLE = !DISABLE
- } FunctionalState;
- #define IS_FUNCTIONAL_STATE(STATE) (((STATE) == DISABLE) || ((STATE) == ENABLE))
- typedef enum
- {
- SUCCESS = 0,
- ERROR = !SUCCESS
- } ErrorStatus;
- #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)))
- #define POSITION_VAL(VAL) (__CLZ(__RBIT(VAL)))
- #define ATOMIC_SET_BIT(REG, BIT) \
- do { \
- uint32_t val; \
- do { \
- val = __LDREXW((__IO uint32_t *)&(REG)) | (BIT); \
- } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U); \
- } while(0)
- #define ATOMIC_CLEAR_BIT(REG, BIT) \
- do { \
- uint32_t val; \
- do { \
- val = __LDREXW((__IO uint32_t *)&(REG)) & ~(BIT); \
- } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U); \
- } while(0)
- #define ATOMIC_MODIFY_REG(REG, CLEARMSK, SETMASK) \
- do { \
- uint32_t val; \
- do { \
- val = (__LDREXW((__IO uint32_t *)&(REG)) & ~(CLEARMSK)) | (SETMASK); \
- } while ((__STREXW(val,(__IO uint32_t *)&(REG))) != 0U); \
- } while(0)
- #define ATOMIC_SETH_BIT(REG, BIT) \
- do { \
- uint16_t val; \
- do { \
- val = __LDREXH((__IO uint16_t *)&(REG)) | (BIT); \
- } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U); \
- } while(0)
- #define ATOMIC_CLEARH_BIT(REG, BIT) \
- do { \
- uint16_t val; \
- do { \
- val = __LDREXH((__IO uint16_t *)&(REG)) & ~(BIT); \
- } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U); \
- } while(0)
- #define ATOMIC_MODIFYH_REG(REG, CLEARMSK, SETMASK) \
- do { \
- uint16_t val; \
- do { \
- val = (__LDREXH((__IO uint16_t *)&(REG)) & ~(CLEARMSK)) | (SETMASK); \
- } while ((__STREXH(val,(__IO uint16_t *)&(REG))) != 0U); \
- } while(0)
- #if defined (USE_HAL_DRIVER)
- #include "stm32h7xx_hal.h"
- #endif
- #ifdef __cplusplus
- }
- #endif
- #endif
|