/**************************************************************************//** * @file sys.c * @version V1.00 * $Revision: 8 $ * $Date: 15/06/17 4:49p $ * @brief NANO100 series SYS driver source file * * @note * Copyright (C) 2013 Nuvoton Technology Corp. All rights reserved. *****************************************************************************/ #include "Nano100Series.h" /** @addtogroup NANO100_Device_Driver NANO100 Device Driver @{ */ /** @addtogroup NANO100_SYS_Driver SYS Driver @{ */ /** @addtogroup NANO100_SYS_EXPORTED_FUNCTIONS SYS Exported Functions @{ */ /** * @brief This function clear the selected system reset source * @param[in] u32Src is system reset source * @return None */ void SYS_ClearResetSrc(uint32_t u32Src) { SYS->RST_SRC |= u32Src; } /** * @brief This function get Brown-out detector output status * @param None * @return 0: System voltage is higher than BOD_VL setting or BOD_EN is 0. * 1: System voltage is lower than BOD_VL setting. * Note : If the BOD_EN is 0, this function always return 0. */ uint32_t SYS_GetBODStatus() { return (SYS->BODSTS); } /** * @brief This function get the system reset source register value * @param None * @return Reset source */ uint32_t SYS_GetResetSrc(void) { return (SYS->RST_SRC); } /** * @brief This function check register write-protection bit setting * @param None * @return 0: Write-protection function is disabled. * 1: Write-protection function is enabled. */ uint32_t SYS_IsRegLocked(void) { return !(SYS->RegLockAddr & SYS_RegLockAddr_RegUnLock_Msk); } /** * @brief This function get product ID. * @param None * @return Product ID */ uint32_t SYS_ReadPDID(void) { return SYS->PDID; } /** * @brief This function reset chip. * @param None * @return None */ void SYS_ResetChip(void) { SYS->IPRST_CTL1 |= SYS_IPRST_CTL1_CHIP_RST_Msk; } /** * @brief This function reset CPU. * @param None * @return None */ void SYS_ResetCPU(void) { SYS->IPRST_CTL1 |= SYS_IPRST_CTL1_CPU_RST_Msk; } /** * @brief This function reset selected modules. * @param[in] u32ModuleIndex is module index. Including : * - \ref CHIP_RST * - \ref CPU_RST * - \ref DMA_RST * - \ref EBI_RST * - \ref SC1_RST * - \ref SC0_RST * - \ref I2S_RST * - \ref ADC_RST * - \ref USBD_RST * - \ref DAC_RST * - \ref PWM1_RST * - \ref PWM0_RST * - \ref UART1_RST * - \ref UART0_RST * - \ref SPI2_RST * - \ref SPI1_RST * - \ref SPI0_RST * - \ref I2C1_RST * - \ref I2C0_RST * - \ref TMR3_RST * - \ref TMR2_RST * - \ref TMR1_RST * - \ref TMR0_RST * - \ref GPIO_RST * @return None */ void SYS_ResetModule(uint32_t u32ModuleIndex) { *(volatile uint32_t *)((uint32_t)&(SYS->IPRST_CTL1) + (u32ModuleIndex>>24)) |= 1<<(u32ModuleIndex & 0x00ffffff); *(volatile uint32_t *)((uint32_t)&(SYS->IPRST_CTL1) + (u32ModuleIndex>>24)) &= ~(1<<(u32ModuleIndex & 0x00ffffff)); } /** * @brief This function configure BOD function. * Configure BOD reset or interrupt mode and set Brown-out voltage level. * Enable Brown-out function * @param[in] i32Mode is reset or interrupt mode. Including : * - \ref SYS_BODCTL_BOD25_RST_EN_Msk or \ref SYS_BODCTL_BOD25_INT_EN_Msk * - \ref SYS_BODCTL_BOD20_RST_EN_Msk or \ref SYS_BODCTL_BOD20_INT_EN_Msk * - \ref SYS_BODCTL_BOD17_RST_EN_Msk or \ref SYS_BODCTL_BOD17_INT_EN_Msk * @param[in] u32BODLevel is Brown-out voltage level. Including : * - \ref SYS_BODCTL_BOD25_EN_Msk * - \ref SYS_BODCTL_BOD20_EN_Msk * - \ref SYS_BODCTL_BOD17_EN_Msk * * @return None */ void SYS_EnableBOD(int32_t i32Mode, uint32_t u32BODLevel) { SYS->BODCTL = (SYS->BODCTL & ~0xFFF) | (i32Mode | u32BODLevel); } /** * @brief This function disable BOD function. * @param None * @return None */ void SYS_DisableBOD(void) { SYS->BODCTL = SYS->BODCTL & ~(SYS_BODCTL_BOD25_EN_Msk | SYS_BODCTL_BOD20_EN_Msk | SYS_BODCTL_BOD17_EN_Msk); } /** * @brief This function enable HIRC trim function. * @param[in] u32TrimSel is trim frequency selection. Including : * - \ref SYS_IRCTRIMCTL_TRIM_11_0592M * - \ref SYS_IRCTRIMCTL_TRIM_12M * - \ref SYS_IRCTRIMCTL_TRIM_12_288M * @param[in] u32TrimEnInt is HIRC trim interrupt selection. Including : * - \ref SYS_IRCTRIMIEN_FAIL_EN * - \ref SYS_IRCTRIMIEN_32KERR_EN * - \ref SYS_IRCTRIMIEN_DISABLE * @return None */ void SYS_EnableIRCTrim(uint32_t u32TrimSel,uint32_t u32TrimEnInt) { SYS->IRCTRIMIEN = (SYS->IRCTRIMIEN & ~(SYS_IRCTRIMIEN_TRIM_FAIL_IEN_Msk|SYS_IRCTRIMIEN_32K_ERR_IEN_Msk)) | u32TrimEnInt; SYS->IRCTRIMCTL = (SYS->IRCTRIMCTL & ~SYS_IRCTRIMCTL_TRIM_SEL_Msk)|u32TrimSel; } /** * @brief This function disable HIRC trim function. * @param None * @return None */ void SYS_DisableIRCTrim(void) { SYS->IRCTRIMCTL = 0; } /*@}*/ /* end of group NANO100_SYS_EXPORTED_FUNCTIONS */ /*@}*/ /* end of group NANO100_SYS_Driver */ /*@}*/ /* end of group NANO100_Device_Driver */ /*** (C) COPYRIGHT 2013 Nuvoton Technology Corp. ***/