mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-26 15:37:22 +08:00
156 lines
3.3 KiB
C
156 lines
3.3 KiB
C
/**
|
|
******************************************************************************
|
|
* @brief WWDG functions of the firmware library.
|
|
******************************************************************************
|
|
*/
|
|
|
|
/* Includes ------------------------------------------------------------------*/
|
|
#include "gd32f10x_wwdg.h"
|
|
#include "gd32f10x_rcc.h"
|
|
|
|
/** @addtogroup GD32F10x_Firmware
|
|
* @{
|
|
*/
|
|
|
|
/** @defgroup WWDG
|
|
* @brief WWDG driver modules
|
|
* @{
|
|
*/
|
|
|
|
/** @defgroup WWDG_Private_Variables
|
|
* @{
|
|
*/
|
|
|
|
/* CFR register bit mask */
|
|
#define CFR_PS_MASK ((uint32_t)0xFFFFFE7F)
|
|
#define CFR_WIN_MASK ((uint32_t)0xFFFFFF80)
|
|
#define BIT_MASK ((uint8_t)0x7F)
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/** @defgroup WWDG_Private_Functions
|
|
* @{
|
|
*/
|
|
|
|
/**
|
|
* @brief Reset the WWDG configuration.
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
void WWDG_DeInit(void)
|
|
{
|
|
RCC_APB1PeriphReset_Enable(RCC_APB1PERIPH_WWDG, ENABLE);
|
|
RCC_APB1PeriphReset_Enable(RCC_APB1PERIPH_WWDG, DISABLE);
|
|
}
|
|
|
|
/**
|
|
* @brief Set WWDG prescaler value.
|
|
* @param PrescalerValue: WWDG Prescaler value.
|
|
* This parameter can be one of the following values:
|
|
* @arg WWDG_PRESCALER_1: the time base of watchdog counter = (PCLK1/4096)/1
|
|
* @arg WWDG_PRESCALER_2: the time base of watchdog counter = (PCLK1/4096)/2
|
|
* @arg WWDG_PRESCALER_4: the time base of watchdog counter = (PCLK1/4096)/4
|
|
* @arg WWDG_PRESCALER_8: the time base of watchdog counter = (PCLK1/4096)/8
|
|
* @retval None
|
|
*/
|
|
void WWDG_SetPrescalerValue(uint32_t PrescalerValue)
|
|
{
|
|
uint32_t temp = 0;
|
|
|
|
/* Clear PS[1:0] bits */
|
|
temp = WWDG->CFR & CFR_PS_MASK;
|
|
|
|
/* Set PS[1:0] bits */
|
|
temp |= PrescalerValue;
|
|
WWDG->CFR = temp;
|
|
}
|
|
|
|
/**
|
|
* @brief Set watchdog window value.
|
|
* @param WindowValue: the window value to be compared to the downcounter.
|
|
* @retval None
|
|
*/
|
|
void WWDG_SetWindowValue(uint8_t WindowValue)
|
|
{
|
|
__IO uint32_t temp = 0;
|
|
|
|
/* Clear WIN[6:0] bits */
|
|
temp = WWDG->CFR & CFR_WIN_MASK;
|
|
|
|
/* Set WIN[6:0] bits */
|
|
temp |= WindowValue & (uint32_t) BIT_MASK;
|
|
WWDG->CFR = temp;
|
|
}
|
|
|
|
/**
|
|
* @brief Enable the WWDG Early wakeup interrupt(EWI).
|
|
* @note An interrupt occurs when the counter reaches 0x40 if the bit is set.
|
|
* It's cleared by a hardware reset. A write of 0 has no effect.
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
void WWDG_EnableInt(void)
|
|
{
|
|
WWDG->CFR |= WWDG_CFR_EWI;
|
|
}
|
|
|
|
/**
|
|
* @brief Set the value of the watchdog counter.
|
|
* @param CounterValue: the watchdog counter value.
|
|
* @retval None
|
|
*/
|
|
void WWDG_SetCounterValue(uint8_t CounterValue)
|
|
{
|
|
/* Write to CNT[6:0] bits */
|
|
WWDG->CTLR = CounterValue & BIT_MASK;
|
|
}
|
|
|
|
/**
|
|
* @brief Start the window watchdog counter.
|
|
* @param CounterValue: The value of the watchdog counter.
|
|
* @retval None
|
|
*/
|
|
void WWDG_Enable(uint8_t CounterValue)
|
|
{
|
|
WWDG->CTLR = WWDG_CTLR_WDGEN | CounterValue;
|
|
}
|
|
|
|
/**
|
|
* @brief Check the Early Wakeup interrupt bit state.
|
|
* @param None
|
|
* @retval The new state of the Early Wakeup interrupt (SET or RESET).
|
|
*/
|
|
TypeState WWDG_GetBitState(void)
|
|
{
|
|
if ((WWDG->STR) != (uint32_t)RESET) {
|
|
return SET;
|
|
} else {
|
|
return RESET;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @brief Clear Early Wakeup interrupt flag.
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
void WWDG_ClearBitState(void)
|
|
{
|
|
WWDG->STR = (uint32_t)RESET;
|
|
}
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @}
|
|
*/
|
|
|