123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329 |
- #ifndef _FSL_LLWU_H_
- #define _FSL_LLWU_H_
- #include "fsl_common.h"
- #define FSL_LLWU_DRIVER_VERSION (MAKE_VERSION(2, 0, 1))
- typedef enum _llwu_external_pin_mode
- {
- kLLWU_ExternalPinDisable = 0U,
- kLLWU_ExternalPinRisingEdge = 1U,
- kLLWU_ExternalPinFallingEdge = 2U,
- kLLWU_ExternalPinAnyEdge = 3U
- } llwu_external_pin_mode_t;
- typedef enum _llwu_pin_filter_mode
- {
- kLLWU_PinFilterDisable = 0U,
- kLLWU_PinFilterRisingEdge = 1U,
- kLLWU_PinFilterFallingEdge = 2U,
- kLLWU_PinFilterAnyEdge = 3U
- } llwu_pin_filter_mode_t;
- #if (defined(FSL_FEATURE_LLWU_HAS_VERID) && FSL_FEATURE_LLWU_HAS_VERID)
- typedef struct _llwu_version_id
- {
- uint16_t feature;
- uint8_t minor;
- uint8_t major;
- } llwu_version_id_t;
- #endif
- #if (defined(FSL_FEATURE_LLWU_HAS_PARAM) && FSL_FEATURE_LLWU_HAS_PARAM)
- typedef struct _llwu_param
- {
- uint8_t filters;
- uint8_t dmas;
- uint8_t modules;
- uint8_t pins;
- } llwu_param_t;
- #endif
- #if (defined(FSL_FEATURE_LLWU_HAS_PIN_FILTER) && FSL_FEATURE_LLWU_HAS_PIN_FILTER)
- typedef struct _llwu_external_pin_filter_mode
- {
- uint32_t pinIndex;
- llwu_pin_filter_mode_t filterMode;
- } llwu_external_pin_filter_mode_t;
- #endif
- #if defined(__cplusplus)
- extern "C" {
- #endif
- #if (defined(FSL_FEATURE_LLWU_HAS_VERID) && FSL_FEATURE_LLWU_HAS_VERID)
- static inline void LLWU_GetVersionId(LLWU_Type *base, llwu_version_id_t *versionId)
- {
- *((uint32_t *)versionId) = base->VERID;
- }
- #endif
- #if (defined(FSL_FEATURE_LLWU_HAS_PARAM) && FSL_FEATURE_LLWU_HAS_PARAM)
- static inline void LLWU_GetParam(LLWU_Type *base, llwu_param_t *param)
- {
- *((uint32_t *)param) = base->PARAM;
- }
- #endif
- #if (defined(FSL_FEATURE_LLWU_HAS_EXTERNAL_PIN) && FSL_FEATURE_LLWU_HAS_EXTERNAL_PIN)
- void LLWU_SetExternalWakeupPinMode(LLWU_Type *base, uint32_t pinIndex, llwu_external_pin_mode_t pinMode);
- bool LLWU_GetExternalWakeupPinFlag(LLWU_Type *base, uint32_t pinIndex);
- void LLWU_ClearExternalWakeupPinFlag(LLWU_Type *base, uint32_t pinIndex);
- #endif
- #if (defined(FSL_FEATURE_LLWU_HAS_INTERNAL_MODULE) && FSL_FEATURE_LLWU_HAS_INTERNAL_MODULE)
- static inline void LLWU_EnableInternalModuleInterruptWakup(LLWU_Type *base, uint32_t moduleIndex, bool enable)
- {
- if (enable)
- {
- base->ME |= 1U << moduleIndex;
- }
- else
- {
- base->ME &= ~(1U << moduleIndex);
- }
- }
- #if (!(defined(FSL_FEATURE_LLWU_HAS_NO_INTERNAL_MODULE_WAKEUP_FLAG_REG) && \
- FSL_FEATURE_LLWU_HAS_NO_INTERNAL_MODULE_WAKEUP_FLAG_REG))
- #if (defined(FSL_FEATURE_LLWU_REG_BITWIDTH) && (FSL_FEATURE_LLWU_REG_BITWIDTH == 32))
- #if (defined(FSL_FEATURE_LLWU_HAS_MF) && FSL_FEATURE_LLWU_HAS_MF)
- #define INTERNAL_WAKEUP_MODULE_FLAG_REG MF
- #else
- #error "Unsupported internal module flag register."
- #endif
- #else
- #if (defined(FSL_FEATURE_LLWU_HAS_MF) && FSL_FEATURE_LLWU_HAS_MF)
- #define INTERNAL_WAKEUP_MODULE_FLAG_REG MF5
- #elif(defined(FSL_FEATURE_LLWU_HAS_PF) && FSL_FEATURE_LLWU_HAS_PF)
- #define INTERNAL_WAKEUP_MODULE_FLAG_REG PF3
- #elif(!(defined(FSL_FEATURE_LLWU_HAS_EXTERNAL_PIN) && (FSL_FEATURE_LLWU_HAS_EXTERNAL_PIN > 16)))
- #define INTERNAL_WAKEUP_MODULE_FLAG_REG F3
- #else
- #error "Unsupported internal module flag register."
- #endif
- #endif
- static inline bool LLWU_GetInternalWakeupModuleFlag(LLWU_Type *base, uint32_t moduleIndex)
- {
- return ((1U << moduleIndex) == (base->INTERNAL_WAKEUP_MODULE_FLAG_REG & (1U << moduleIndex)));
- }
- #endif
- #endif
- #if (defined(FSL_FEATURE_LLWU_HAS_DMA_ENABLE_REG) && FSL_FEATURE_LLWU_HAS_DMA_ENABLE_REG)
- static inline void LLWU_EnableInternalModuleDmaRequestWakup(LLWU_Type *base, uint32_t moduleIndex, bool enable)
- {
- if (enable)
- {
- base->DE |= 1U << moduleIndex;
- }
- else
- {
- base->DE &= ~(1U << moduleIndex);
- }
- }
- #endif
- #if (defined(FSL_FEATURE_LLWU_HAS_PIN_FILTER) && FSL_FEATURE_LLWU_HAS_PIN_FILTER)
- void LLWU_SetPinFilterMode(LLWU_Type *base, uint32_t filterIndex, llwu_external_pin_filter_mode_t filterMode);
- bool LLWU_GetPinFilterFlag(LLWU_Type *base, uint32_t filterIndex);
- void LLWU_ClearPinFilterFlag(LLWU_Type *base, uint32_t filterIndex);
- #endif
- #if (defined(FSL_FEATURE_LLWU_HAS_RESET_ENABLE) && FSL_FEATURE_LLWU_HAS_RESET_ENABLE)
- void LLWU_SetResetPinMode(LLWU_Type *base, bool pinEnable, bool enableInLowLeakageMode);
- #endif
- #if defined(__cplusplus)
- }
- #endif
- #endif
|