144 lines
5.4 KiB
C
144 lines
5.4 KiB
C
/******************************************************************************
|
|
* 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.c
|
|
**
|
|
** A detailed description is available at
|
|
** @link RmuGroup RMU description @endlink
|
|
**
|
|
** - 2018-10-28 CDT First version for Device Driver Library of RMU.
|
|
**
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Include files
|
|
******************************************************************************/
|
|
#include "hc32f460_rmu.h"
|
|
#include "hc32f460_utility.h"
|
|
|
|
#if (DDL_RMU_ENABLE == DDL_ON)
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \addtogroup RmuGroup
|
|
******************************************************************************/
|
|
//@{
|
|
|
|
/*******************************************************************************
|
|
* Local type definitions ('typedef')
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Local pre-processor symbols/macros ('#define')
|
|
******************************************************************************/
|
|
#define ENABLE_RMU_REG_WRITE() (M4_SYSREG->PWR_FPRC = 0xa502u)
|
|
#define DISABLE_RMU_REG_WRITE() (M4_SYSREG->PWR_FPRC = 0xa500u)
|
|
|
|
#define RMU_FLAG_TIM ((uint16_t)0x1000u)
|
|
|
|
/*******************************************************************************
|
|
* Global variable definitions (declared in header file with 'extern')
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Local function prototypes ('static')
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Local variable definitions ('static')
|
|
******************************************************************************/
|
|
|
|
/*******************************************************************************
|
|
* Function implementation - global ('extern') and local ('static')
|
|
******************************************************************************/
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Get the chip reset cause.
|
|
**
|
|
** \param [in] pstcData Pointer to return reset cause structure.
|
|
**
|
|
** \retval Ok Get successfully.
|
|
**
|
|
******************************************************************************/
|
|
en_result_t RMU_GetResetCause(stc_rmu_rstcause_t *pstcData)
|
|
{
|
|
uint16_t u16RstCause = 0u;
|
|
stc_sysreg_rmu_rstf0_field_t *RMU_RSTF0_f = NULL;
|
|
|
|
if(NULL == pstcData)
|
|
{
|
|
return ErrorInvalidParameter;
|
|
}
|
|
|
|
u16RstCause = M4_SYSREG->RMU_RSTF0;
|
|
RMU_RSTF0_f = (stc_sysreg_rmu_rstf0_field_t *)(&u16RstCause);
|
|
|
|
pstcData->enMultiRst = (en_flag_status_t)(RMU_RSTF0_f->MULTIRF == 1u);
|
|
pstcData->enXtalErr = (en_flag_status_t)(RMU_RSTF0_f->XTALERF == 1u);
|
|
pstcData->enClkFreqErr = (en_flag_status_t)(RMU_RSTF0_f->CKFERF == 1u);
|
|
pstcData->enRamEcc = (en_flag_status_t)(RMU_RSTF0_f->RAECRF == 1u);
|
|
pstcData->enRamParityErr = (en_flag_status_t)(RMU_RSTF0_f->RAPERF == 1u);
|
|
pstcData->enMpuErr = (en_flag_status_t)(RMU_RSTF0_f->MPUERF == 1u);
|
|
pstcData->enSoftware = (en_flag_status_t)(RMU_RSTF0_f->SWRF == 1u);
|
|
pstcData->enPowerDown = (en_flag_status_t)(RMU_RSTF0_f->PDRF == 1u);
|
|
pstcData->enSwdt = (en_flag_status_t)(RMU_RSTF0_f->SWDRF == 1u);
|
|
pstcData->enWdt = (en_flag_status_t)(RMU_RSTF0_f->WDRF == 1u);
|
|
pstcData->enPvd2 = (en_flag_status_t)(RMU_RSTF0_f->PVD2RF == 1u);
|
|
pstcData->enPvd1 = (en_flag_status_t)(RMU_RSTF0_f->PVD2RF == 1u);
|
|
pstcData->enBrownOut = (en_flag_status_t)(RMU_RSTF0_f->BORF == 1u);
|
|
pstcData->enRstPin = (en_flag_status_t)(RMU_RSTF0_f->PINRF == 1u);
|
|
pstcData->enPowerOn = (en_flag_status_t)(RMU_RSTF0_f->PORF == 1u);
|
|
|
|
return Ok;
|
|
}
|
|
|
|
/**
|
|
*******************************************************************************
|
|
** \brief Clear the reset flag.
|
|
**
|
|
** \param None
|
|
**
|
|
** \retval Ok Clear successfully.
|
|
**
|
|
** \note clear reset flag should be done after read RMU_RSTF0 register.
|
|
******************************************************************************/
|
|
en_result_t RMU_ClrResetFlag(void)
|
|
{
|
|
uint16_t u16status = 0u;
|
|
uint32_t u32timeout = 0u;
|
|
|
|
ENABLE_RMU_REG_WRITE();
|
|
|
|
do
|
|
{
|
|
u32timeout++;
|
|
M4_SYSREG->RMU_RSTF0_f.CLRF = 1u;
|
|
u16status = M4_SYSREG->RMU_RSTF0;
|
|
}while((u32timeout != RMU_FLAG_TIM) && u16status);
|
|
|
|
DISABLE_RMU_REG_WRITE();
|
|
|
|
if(u32timeout >= RMU_FLAG_TIM)
|
|
{
|
|
return ErrorTimeout;
|
|
}
|
|
|
|
return Ok;
|
|
}
|
|
|
|
|
|
//@} // RmuGroup
|
|
|
|
#endif /* DDL_RMU_ENABLE */
|
|
|
|
/*******************************************************************************
|
|
* EOF (not truncated)
|
|
******************************************************************************/
|
|
|