123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324 |
- /*
- * Copyright 2020 NXP
- * All rights reserved.
- *
- * SPDX-License-Identifier: BSD-3-Clause
- */
- #ifndef _FSL_CDOG_H_
- #define _FSL_CDOG_H_
- #include "fsl_common.h"
- /*!
- * @addtogroup CDOG
- * @{
- */
- /*! @file */
- /*******************************************************************************
- * Definitions
- *******************************************************************************/
- /*! @name Driver version */
- /*@{*/
- /*! @brief Defines CDOG driver version 2.1.0.
- *
- * Change log:
- * - Version 2.1.0
- * - Rename CWT to CDOG
- * - Version 2.0.2
- * - Fix MISRA-2012 issues
- * - Version 2.0.1
- * - Fix doxygen issues
- * - Version 2.0.0
- * - initial version
- */
- #define FSL_CDOG_DRIVER_VERSION (MAKE_VERSION(2, 1, 0))
- /*@}*/
- typedef struct
- {
- uint8_t lock : 2;
- uint8_t timeout : 3;
- uint8_t miscompare : 3;
- uint8_t sequence : 3;
- uint8_t control : 3;
- uint8_t state : 3;
- uint8_t address : 3;
- uint8_t reserved : 8;
- uint8_t irq_pause : 2;
- uint8_t debug_halt : 2;
- } cdog_config_t;
- enum __cdog_debug_Action_ctrl_enum
- {
- kCDOG_DebugHaltCtrl_Run = 0x1,
- kCDOG_DebugHaltCtrl_Pause = 0x2,
- };
- enum __cdog_irq_pause_ctrl_enum
- {
- kCDOG_IrqPauseCtrl_Run = 0x1,
- kCDOG_IrqPauseCtrl_Pause = 0x2,
- };
- enum __cdog_fault_ctrl_enum
- {
- kCDOG_FaultCtrl_EnableReset = 0x1U,
- kCDOG_FaultCtrl_EnableInterrupt = 0x2U,
- kCDOG_FaultCtrl_NoAction = 0x4U,
- };
- enum __code_lock_ctrl_enum
- {
- kCDOG_LockCtrl_Lock = 0x1,
- kCDOG_LockCtrl_Unlock = 0x2,
- };
- typedef uint32_t secure_counter_t;
- #define SC_ADD(add) \
- do \
- { \
- CDOG->ADD = (secure_counter_t)(add); \
- } while (0)
- #define SC_ADD1 \
- do \
- { \
- CDOG->ADD1 = (secure_counter_t)0x1U; \
- } while (0)
- #define SC_ADD16 \
- do \
- { \
- CDOG->ADD16 = (secure_counter_t)0x1U; \
- } while (0)
- #define SC_ADD256 \
- do \
- { \
- CDOG->ADD256 = (secure_counter_t)0x1U; \
- } while (0)
- #define SC_SUB(sub) \
- do \
- { \
- CDOG->SUB = (secure_counter_t)(sub); \
- } while (0)
- #define SC_SUB1 \
- do \
- { \
- CDOG->SUB1 = (secure_counter_t)0x1U; \
- } while (0)
- #define SC_SUB16 \
- do \
- { \
- CDOG->SUB16 = (secure_counter_t)0x1U; \
- } while (0)
- #define SC_SUB256 \
- do \
- { \
- CDOG->SUB256 = (secure_counter_t)0x1U; \
- } while (0)
- #define SC_CHECK(val) \
- do \
- { \
- CDOG->RESTART = (secure_counter_t)val; \
- } while (0)
- /*******************************************************************************
- * API
- *******************************************************************************/
- extern void CDOG_DriverIRQHandler(void);
- #if defined(__cplusplus)
- extern "C" {
- #endif /* __cplusplus */
- /*!
- * @name CDOG Functional Operation
- * @{
- */
- /*!
- * @brief Initialize CDOG
- *
- * This function initializes CDOG block and setting.
- *
- * @param base CDOG peripheral base address
- * @param conf CDOG configuration structure
- * @return Status of the init operation
- */
- status_t CDOG_Init(CDOG_Type *base, cdog_config_t *conf);
- /*!
- * @brief Deinitialize CDOG
- *
- * This function deinitializes CDOG secure counter.
- *
- * @param base CDOG peripheral base address
- */
- void CDOG_Deinit(CDOG_Type *base);
- /*!
- * @brief Sets the default configuration of CDOG
- *
- * This function initialize CDOG config structure to default values.
- *
- * @param conf CDOG configuration structure
- */
- void CDOG_GetDefaultConfig(cdog_config_t *conf);
- /*!
- * @brief Stops secure counter and instruction timer
- *
- * This function stops instruction timer and secure counter.
- * This also change state od CDOG to IDLE.
- *
- * @param base CDOG peripheral base address
- * @param stop expected value which will be compared with value of secure counter
- */
- void CDOG_Stop(CDOG_Type *base, uint32_t stop);
- /*!
- * @brief Sets secure counter and instruction timer values
- *
- * This function sets value in RELOAD and START registers
- * for instruction timer and secure counter
- *
- * @param base CDOG peripheral base address
- * @param reload reload value
- * @param start start value
- */
- void CDOG_Start(CDOG_Type *base, uint32_t reload, uint32_t start);
- /*!
- * @brief Checks secure counter.
- *
- * This function compares stop value in handler with secure counter value
- * by writting to RELOAD refister.
- *
- * @param base CDOG peripheral base address
- * @param check expected (stop) value
- */
- void CDOG_Check(CDOG_Type *base, uint32_t check);
- /*!
- * @brief Sets secure counter and instruction timer values
- *
- * This function sets value in STOP, RELOAD and START registers
- * for instruction timer and secure counter.
- *
- * @param base CDOG peripheral base address
- * @param stop expected value which will be compared with value of secure counter
- * @param reload reload value for instruction timer
- * @param start start value for secure timer
- */
- void CDOG_Set(CDOG_Type *base, uint32_t stop, uint32_t reload, uint32_t start);
- /*!
- * @brief Add value to secure counter
- *
- * This function add specified value to secure counter.
- *
- * @param base CDOG peripheral base address.
- * @param add Value to be added.
- */
- void CDOG_Add(CDOG_Type *base, uint32_t add);
- /*!
- * @brief Add 1 to secure counter
- *
- * This function add 1 to secure counter.
- *
- * @param base CDOG peripheral base address.
- */
- void CDOG_Add1(CDOG_Type *base);
- /*!
- * @brief Add 16 to secure counter
- *
- * This function add 16 to secure counter.
- *
- * @param base CDOG peripheral base address.
- */
- void CDOG_Add16(CDOG_Type *base);
- /*!
- * @brief Add 256 to secure counter
- *
- * This function add 256 to secure counter.
- *
- * @param base CDOG peripheral base address.
- */
- void CDOG_Add256(CDOG_Type *base);
- /*!
- * brief Substract value to secure counter
- *
- * This function substract specified value to secure counter.
- *
- * param base CDOG peripheral base address.
- * param sub Value to be substracted.
- */
- void CDOG_Sub(CDOG_Type *base, uint32_t sub);
- /*!
- * @brief Substract 1 from secure counter
- *
- * This function substract specified 1 from secure counter.
- *
- * @param base CDOG peripheral base address.
- */
- void CDOG_Sub1(CDOG_Type *base);
- /*!
- * @brief Substract 16 from secure counter
- *
- * This function substract specified 16 from secure counter.
- *
- * @param base CDOG peripheral base address.
- */
- void CDOG_Sub16(CDOG_Type *base);
- /*!
- * @brief Substract 256 from secure counter
- *
- * This function substract specified 256 from secure counter.
- *
- * @param base CDOG peripheral base address.
- */
- void CDOG_Sub256(CDOG_Type *base);
- /*!
- * @brief Set the CDOG persistent word.
- *
- * @param base CDOG peripheral base address.
- * @param value The value to be written.
- */
- void CDOG_WritePersistent(CDOG_Type *base, uint32_t value);
- /*!
- * @brief Get the CDOG persistent word.
- *
- * @param base CDOG peripheral base address.
- * @return The persistent word.
- */
- uint32_t CDOG_ReadPersistent(CDOG_Type *base);
- /*! @}*/
- #if defined(__cplusplus)
- }
- #endif /* __cplusplus */
- /*! @}*/ /* end of group cdog */
- #endif /* _FSL_CDOG_H_ */
|