mbed library sources. Supersedes mbed-src.

Dependents:   Nucleo_Hello_Encoder BLE_iBeaconScan AM1805_DEMO DISCO-F429ZI_ExportTemplate1 ... more

Revision:
174:b96e65c34a4d
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/targets/TARGET_NUVOTON/TARGET_NANO100/device/StdDriver/nano100_sys.c	Mon Oct 02 15:33:19 2017 +0100
@@ -0,0 +1,198 @@
+/**************************************************************************//**
+ * @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. ***/