68 lines
2.6 KiB
C
68 lines
2.6 KiB
C
|
/**************************************************************************//**
|
||
|
* @file wdt.c
|
||
|
* @brief NUC980 series WDT driver source file
|
||
|
*
|
||
|
* SPDX-License-Identifier: Apache-2.0
|
||
|
* @copyright (C) 2018 Nuvoton Technology Corp. All rights reserved.
|
||
|
*****************************************************************************/
|
||
|
#include "nu_wdt.h"
|
||
|
|
||
|
/** @addtogroup Standard_Driver Standard Driver
|
||
|
@{
|
||
|
*/
|
||
|
|
||
|
/** @addtogroup WDT_Driver WDT Driver
|
||
|
@{
|
||
|
*/
|
||
|
|
||
|
/** @addtogroup WDT_EXPORTED_FUNCTIONS WDT Exported Functions
|
||
|
@{
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @brief Initialize WDT and start counting
|
||
|
*
|
||
|
* @param[in] u32TimeoutInterval Time-out interval period of WDT module. Valid values are:
|
||
|
* - \ref WDT_TIMEOUT_2POW4
|
||
|
* - \ref WDT_TIMEOUT_2POW6
|
||
|
* - \ref WDT_TIMEOUT_2POW8
|
||
|
* - \ref WDT_TIMEOUT_2POW10
|
||
|
* - \ref WDT_TIMEOUT_2POW12
|
||
|
* - \ref WDT_TIMEOUT_2POW14
|
||
|
* - \ref WDT_TIMEOUT_2POW16
|
||
|
* - \ref WDT_TIMEOUT_2POW18
|
||
|
* * \ref WDT_TIMEOUT_2POW20
|
||
|
* @param[in] u32ResetDelay Configure WDT time-out reset delay period. Valid values are:
|
||
|
* - \ref WDT_RESET_DELAY_1026CLK
|
||
|
* - \ref WDT_RESET_DELAY_130CLK
|
||
|
* - \ref WDT_RESET_DELAY_18CLK
|
||
|
* - \ref WDT_RESET_DELAY_3CLK
|
||
|
* @param[in] u32EnableReset Enable WDT time-out reset system function. Valid values are TRUE and FALSE.
|
||
|
* @param[in] u32EnableWakeup Enable WDT time-out wake-up system function. Valid values are TRUE and FALSE.
|
||
|
*
|
||
|
* @return None
|
||
|
*
|
||
|
* @details This function makes WDT module start counting with different time-out interval, reset delay period and choose to \n
|
||
|
* enable or disable WDT time-out reset system or wake-up system.
|
||
|
* @note Please make sure that Register Write-Protection Function has been disabled before using this function.
|
||
|
*/
|
||
|
void WDT_Open(UINT32 u32TimeoutInterval,
|
||
|
UINT32 u32ResetDelay,
|
||
|
UINT32 u32EnableReset,
|
||
|
UINT32 u32EnableWakeup)
|
||
|
{
|
||
|
|
||
|
outpw(REG_WDT_ALTCTL, u32ResetDelay);
|
||
|
outpw(REG_WDT_CTL, u32TimeoutInterval | 0x80 |
|
||
|
(u32EnableReset << 1) |
|
||
|
(u32EnableWakeup << 4));
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
/*@}*/ /* end of group WDT_EXPORTED_FUNCTIONS */
|
||
|
|
||
|
/*@}*/ /* end of group WDT_Driver */
|
||
|
|
||
|
/*@}*/ /* end of group Standard_Driver */
|
||
|
|