hc32f460_rmu.h 3.9 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
/*****************************************************************************
 * Copyright (C) 2020, Huada Semiconductor Co., Ltd. All rights reserved.
 *
 * This software component is licensed by HDSC under BSD 3-Clause license
 * (the "License"); You may not use this file except in compliance with the
 * License. You may obtain a copy of the License at:
 *                    opensource.org/licenses/BSD-3-Clause
 */
/******************************************************************************/
/** \file hc32f460_rmu.h
 **
 ** A detailed description is available at
 ** @link RmuGroup RMU description @endlink
 **
 **   - 2018-10-28  CDT  First version for Device Driver Library of RMU
 **
 ******************************************************************************/
#ifndef __HC32F460_RMU_H__
#define __HC32F460_RMU_H__

/*******************************************************************************
 * Include files
 ******************************************************************************/
#include "hc32_common.h"
#include "ddl_config.h"

#if (DDL_RMU_ENABLE == DDL_ON)

/* C binding of definitions if building with C++ compiler */
#ifdef __cplusplus
extern "C"
{
#endif

/**
 *******************************************************************************
 ** \defgroup RmuGroup Reset Management Unit(RMU)
 **
 ******************************************************************************/
//@{

/*******************************************************************************
 * Global type definitions ('typedef')
 ******************************************************************************/
/**
 *******************************************************************************
 ** \brief system reset cause flag
 **
 ******************************************************************************/
typedef struct stc_rmu_rstcause
{
    en_flag_status_t   enMultiRst;              ///< Multiply reset cause
    en_flag_status_t   enXtalErr;               ///< Xtal error reset
    en_flag_status_t   enClkFreqErr;            ///< Clk freqence error reset
    en_flag_status_t   enRamEcc;                ///< Ram ECC reset
    en_flag_status_t   enRamParityErr;          ///< Ram parity error reset
    en_flag_status_t   enMpuErr;                ///< Mpu error reset
    en_flag_status_t   enSoftware;              ///< Software reset
    en_flag_status_t   enPowerDown;             ///< Power down reset
    en_flag_status_t   enSwdt;                  ///< Special watchdog timer reset
    en_flag_status_t   enWdt;                   ///< Watchdog timer reset
    en_flag_status_t   enPvd2;                  ///< Program voltage Dectection 2 reset
    en_flag_status_t   enPvd1;                  ///< Program voltage Dectection 1 reset
    en_flag_status_t   enBrownOut;              ///< Brown out reset
    en_flag_status_t   enRstPin;                ///< Reset pin reset
    en_flag_status_t   enPowerOn;               ///< Power on reset
}stc_rmu_rstcause_t;

/*******************************************************************************
 * Global pre-processor symbols/macros ('#define')
 ******************************************************************************/

/*******************************************************************************
 * Global variable definitions ('extern')
 ******************************************************************************/

/*******************************************************************************
 * Global function prototypes (definition in C source)
 ******************************************************************************/
en_result_t RMU_GetResetCause(stc_rmu_rstcause_t *pstcData);
en_result_t RMU_ClrResetFlag(void);

//@} // RmuGroup

#ifdef __cplusplus
}
#endif

#endif /* DDL_RMU_ENABLE */

#endif /* __HC32F460_RMU_H__ */

/*******************************************************************************
 * EOF (not truncated)
 ******************************************************************************/