The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

mbed 2

This is the mbed 2 library. If you'd like to learn about Mbed OS please see the mbed-os docs.

Committer:
AnnaBridge
Date:
Wed Nov 08 17:18:06 2017 +0000
Revision:
156:ff21514d8981
Child:
159:7130f322cb7e
Reverting back to release 154 of the mbed library

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 156:ff21514d8981 1 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 2 * @file em_emu.h
AnnaBridge 156:ff21514d8981 3 * @brief Energy management unit (EMU) peripheral API
AnnaBridge 156:ff21514d8981 4 * @version 5.1.2
AnnaBridge 156:ff21514d8981 5 *******************************************************************************
AnnaBridge 156:ff21514d8981 6 * @section License
AnnaBridge 156:ff21514d8981 7 * <b>Copyright 2016 Silicon Laboratories, Inc. http://www.silabs.com</b>
AnnaBridge 156:ff21514d8981 8 *******************************************************************************
AnnaBridge 156:ff21514d8981 9 *
AnnaBridge 156:ff21514d8981 10 * Permission is granted to anyone to use this software for any purpose,
AnnaBridge 156:ff21514d8981 11 * including commercial applications, and to alter it and redistribute it
AnnaBridge 156:ff21514d8981 12 * freely, subject to the following restrictions:
AnnaBridge 156:ff21514d8981 13 *
AnnaBridge 156:ff21514d8981 14 * 1. The origin of this software must not be misrepresented; you must not
AnnaBridge 156:ff21514d8981 15 * claim that you wrote the original software.
AnnaBridge 156:ff21514d8981 16 * 2. Altered source versions must be plainly marked as such, and must not be
AnnaBridge 156:ff21514d8981 17 * misrepresented as being the original software.
AnnaBridge 156:ff21514d8981 18 * 3. This notice may not be removed or altered from any source distribution.
AnnaBridge 156:ff21514d8981 19 *
AnnaBridge 156:ff21514d8981 20 * DISCLAIMER OF WARRANTY/LIMITATION OF REMEDIES: Silicon Labs has no
AnnaBridge 156:ff21514d8981 21 * obligation to support this Software. Silicon Labs is providing the
AnnaBridge 156:ff21514d8981 22 * Software "AS IS", with no express or implied warranties of any kind,
AnnaBridge 156:ff21514d8981 23 * including, but not limited to, any implied warranties of merchantability
AnnaBridge 156:ff21514d8981 24 * or fitness for any particular purpose or warranties against infringement
AnnaBridge 156:ff21514d8981 25 * of any proprietary rights of a third party.
AnnaBridge 156:ff21514d8981 26 *
AnnaBridge 156:ff21514d8981 27 * Silicon Labs will not be liable for any consequential, incidental, or
AnnaBridge 156:ff21514d8981 28 * special damages, or any other relief, or for any claim by any third party,
AnnaBridge 156:ff21514d8981 29 * arising from your use of this Software.
AnnaBridge 156:ff21514d8981 30 *
AnnaBridge 156:ff21514d8981 31 ******************************************************************************/
AnnaBridge 156:ff21514d8981 32
AnnaBridge 156:ff21514d8981 33 #ifndef EM_EMU_H
AnnaBridge 156:ff21514d8981 34 #define EM_EMU_H
AnnaBridge 156:ff21514d8981 35
AnnaBridge 156:ff21514d8981 36 #include "em_device.h"
AnnaBridge 156:ff21514d8981 37 #if defined( EMU_PRESENT )
AnnaBridge 156:ff21514d8981 38
AnnaBridge 156:ff21514d8981 39 #include <stdbool.h>
AnnaBridge 156:ff21514d8981 40 #include "em_bus.h"
AnnaBridge 156:ff21514d8981 41
AnnaBridge 156:ff21514d8981 42 #ifdef __cplusplus
AnnaBridge 156:ff21514d8981 43 extern "C" {
AnnaBridge 156:ff21514d8981 44 #endif
AnnaBridge 156:ff21514d8981 45
AnnaBridge 156:ff21514d8981 46 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 47 * @addtogroup emlib
AnnaBridge 156:ff21514d8981 48 * @{
AnnaBridge 156:ff21514d8981 49 ******************************************************************************/
AnnaBridge 156:ff21514d8981 50
AnnaBridge 156:ff21514d8981 51 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 52 * @addtogroup EMU
AnnaBridge 156:ff21514d8981 53 * @{
AnnaBridge 156:ff21514d8981 54 ******************************************************************************/
AnnaBridge 156:ff21514d8981 55
AnnaBridge 156:ff21514d8981 56 /*******************************************************************************
AnnaBridge 156:ff21514d8981 57 ******************************** ENUMS ************************************
AnnaBridge 156:ff21514d8981 58 ******************************************************************************/
AnnaBridge 156:ff21514d8981 59
AnnaBridge 156:ff21514d8981 60 #if defined( _EMU_EM4CONF_OSC_MASK )
AnnaBridge 156:ff21514d8981 61 /** EM4 duty oscillator */
AnnaBridge 156:ff21514d8981 62 typedef enum
AnnaBridge 156:ff21514d8981 63 {
AnnaBridge 156:ff21514d8981 64 /** Select ULFRCO as duty oscillator in EM4 */
AnnaBridge 156:ff21514d8981 65 emuEM4Osc_ULFRCO = EMU_EM4CONF_OSC_ULFRCO,
AnnaBridge 156:ff21514d8981 66 /** Select LFXO as duty oscillator in EM4 */
AnnaBridge 156:ff21514d8981 67 emuEM4Osc_LFXO = EMU_EM4CONF_OSC_LFXO,
AnnaBridge 156:ff21514d8981 68 /** Select LFRCO as duty oscillator in EM4 */
AnnaBridge 156:ff21514d8981 69 emuEM4Osc_LFRCO = EMU_EM4CONF_OSC_LFRCO
AnnaBridge 156:ff21514d8981 70 } EMU_EM4Osc_TypeDef;
AnnaBridge 156:ff21514d8981 71 #endif
AnnaBridge 156:ff21514d8981 72
AnnaBridge 156:ff21514d8981 73 #if defined( _EMU_BUCTRL_PROBE_MASK )
AnnaBridge 156:ff21514d8981 74 /** Backup Power Voltage Probe types */
AnnaBridge 156:ff21514d8981 75 typedef enum
AnnaBridge 156:ff21514d8981 76 {
AnnaBridge 156:ff21514d8981 77 /** Disable voltage probe */
AnnaBridge 156:ff21514d8981 78 emuProbe_Disable = EMU_BUCTRL_PROBE_DISABLE,
AnnaBridge 156:ff21514d8981 79 /** Connect probe to VDD_DREG */
AnnaBridge 156:ff21514d8981 80 emuProbe_VDDDReg = EMU_BUCTRL_PROBE_VDDDREG,
AnnaBridge 156:ff21514d8981 81 /** Connect probe to BU_IN */
AnnaBridge 156:ff21514d8981 82 emuProbe_BUIN = EMU_BUCTRL_PROBE_BUIN,
AnnaBridge 156:ff21514d8981 83 /** Connect probe to BU_OUT */
AnnaBridge 156:ff21514d8981 84 emuProbe_BUOUT = EMU_BUCTRL_PROBE_BUOUT
AnnaBridge 156:ff21514d8981 85 } EMU_Probe_TypeDef;
AnnaBridge 156:ff21514d8981 86 #endif
AnnaBridge 156:ff21514d8981 87
AnnaBridge 156:ff21514d8981 88 #if defined( _EMU_PWRCONF_PWRRES_MASK )
AnnaBridge 156:ff21514d8981 89 /** Backup Power Domain resistor selection */
AnnaBridge 156:ff21514d8981 90 typedef enum
AnnaBridge 156:ff21514d8981 91 {
AnnaBridge 156:ff21514d8981 92 /** Main power and backup power connected with RES0 series resistance */
AnnaBridge 156:ff21514d8981 93 emuRes_Res0 = EMU_PWRCONF_PWRRES_RES0,
AnnaBridge 156:ff21514d8981 94 /** Main power and backup power connected with RES1 series resistance */
AnnaBridge 156:ff21514d8981 95 emuRes_Res1 = EMU_PWRCONF_PWRRES_RES1,
AnnaBridge 156:ff21514d8981 96 /** Main power and backup power connected with RES2 series resistance */
AnnaBridge 156:ff21514d8981 97 emuRes_Res2 = EMU_PWRCONF_PWRRES_RES2,
AnnaBridge 156:ff21514d8981 98 /** Main power and backup power connected with RES3 series resistance */
AnnaBridge 156:ff21514d8981 99 emuRes_Res3 = EMU_PWRCONF_PWRRES_RES3,
AnnaBridge 156:ff21514d8981 100 } EMU_Resistor_TypeDef;
AnnaBridge 156:ff21514d8981 101 #endif
AnnaBridge 156:ff21514d8981 102
AnnaBridge 156:ff21514d8981 103 #if defined( BU_PRESENT )
AnnaBridge 156:ff21514d8981 104 /** Backup Power Domain power connection */
AnnaBridge 156:ff21514d8981 105 typedef enum
AnnaBridge 156:ff21514d8981 106 {
AnnaBridge 156:ff21514d8981 107 /** No connection between main and backup power */
AnnaBridge 156:ff21514d8981 108 emuPower_None = EMU_BUINACT_PWRCON_NONE,
AnnaBridge 156:ff21514d8981 109 /** Main power and backup power connected through diode,
AnnaBridge 156:ff21514d8981 110 allowing current from backup to main only */
AnnaBridge 156:ff21514d8981 111 emuPower_BUMain = EMU_BUINACT_PWRCON_BUMAIN,
AnnaBridge 156:ff21514d8981 112 /** Main power and backup power connected through diode,
AnnaBridge 156:ff21514d8981 113 allowing current from main to backup only */
AnnaBridge 156:ff21514d8981 114 emuPower_MainBU = EMU_BUINACT_PWRCON_MAINBU,
AnnaBridge 156:ff21514d8981 115 /** Main power and backup power connected without diode */
AnnaBridge 156:ff21514d8981 116 emuPower_NoDiode = EMU_BUINACT_PWRCON_NODIODE,
AnnaBridge 156:ff21514d8981 117 } EMU_Power_TypeDef;
AnnaBridge 156:ff21514d8981 118 #endif
AnnaBridge 156:ff21514d8981 119
AnnaBridge 156:ff21514d8981 120 /** BOD threshold setting selector, active or inactive mode */
AnnaBridge 156:ff21514d8981 121 typedef enum
AnnaBridge 156:ff21514d8981 122 {
AnnaBridge 156:ff21514d8981 123 /** Configure BOD threshold for active mode */
AnnaBridge 156:ff21514d8981 124 emuBODMode_Active,
AnnaBridge 156:ff21514d8981 125 /** Configure BOD threshold for inactive mode */
AnnaBridge 156:ff21514d8981 126 emuBODMode_Inactive,
AnnaBridge 156:ff21514d8981 127 } EMU_BODMode_TypeDef;
AnnaBridge 156:ff21514d8981 128
AnnaBridge 156:ff21514d8981 129 #if defined( _EMU_EM4CTRL_EM4STATE_MASK )
AnnaBridge 156:ff21514d8981 130 /** EM4 modes */
AnnaBridge 156:ff21514d8981 131 typedef enum
AnnaBridge 156:ff21514d8981 132 {
AnnaBridge 156:ff21514d8981 133 /** EM4 Hibernate */
AnnaBridge 156:ff21514d8981 134 emuEM4Hibernate = EMU_EM4CTRL_EM4STATE_EM4H,
AnnaBridge 156:ff21514d8981 135 /** EM4 Shutoff */
AnnaBridge 156:ff21514d8981 136 emuEM4Shutoff = EMU_EM4CTRL_EM4STATE_EM4S,
AnnaBridge 156:ff21514d8981 137 } EMU_EM4State_TypeDef;
AnnaBridge 156:ff21514d8981 138 #endif
AnnaBridge 156:ff21514d8981 139
AnnaBridge 156:ff21514d8981 140
AnnaBridge 156:ff21514d8981 141 #if defined( _EMU_EM4CTRL_EM4IORETMODE_MASK )
AnnaBridge 156:ff21514d8981 142 typedef enum
AnnaBridge 156:ff21514d8981 143 {
AnnaBridge 156:ff21514d8981 144 /** No Retention: Pads enter reset state when entering EM4 */
AnnaBridge 156:ff21514d8981 145 emuPinRetentionDisable = EMU_EM4CTRL_EM4IORETMODE_DISABLE,
AnnaBridge 156:ff21514d8981 146 /** Retention through EM4: Pads enter reset state when exiting EM4 */
AnnaBridge 156:ff21514d8981 147 emuPinRetentionEm4Exit = EMU_EM4CTRL_EM4IORETMODE_EM4EXIT,
AnnaBridge 156:ff21514d8981 148 /** Retention through EM4 and wakeup: call EMU_UnlatchPinRetention() to
AnnaBridge 156:ff21514d8981 149 release pins from retention after EM4 wakeup */
AnnaBridge 156:ff21514d8981 150 emuPinRetentionLatch = EMU_EM4CTRL_EM4IORETMODE_SWUNLATCH,
AnnaBridge 156:ff21514d8981 151 } EMU_EM4PinRetention_TypeDef;
AnnaBridge 156:ff21514d8981 152 #endif
AnnaBridge 156:ff21514d8981 153
AnnaBridge 156:ff21514d8981 154 /** Power configurations. DCDC-to-DVDD is currently the only supported mode. */
AnnaBridge 156:ff21514d8981 155 typedef enum
AnnaBridge 156:ff21514d8981 156 {
AnnaBridge 156:ff21514d8981 157 /** DCDC is connected to DVDD */
AnnaBridge 156:ff21514d8981 158 emuPowerConfig_DcdcToDvdd,
AnnaBridge 156:ff21514d8981 159 } EMU_PowerConfig_TypeDef;
AnnaBridge 156:ff21514d8981 160
AnnaBridge 156:ff21514d8981 161
AnnaBridge 156:ff21514d8981 162 #if defined( _EMU_DCDCCTRL_MASK )
AnnaBridge 156:ff21514d8981 163 /** DCDC operating modes */
AnnaBridge 156:ff21514d8981 164 typedef enum
AnnaBridge 156:ff21514d8981 165 {
AnnaBridge 156:ff21514d8981 166 /** DCDC regulator bypass */
AnnaBridge 156:ff21514d8981 167 emuDcdcMode_Bypass = EMU_DCDCCTRL_DCDCMODE_BYPASS,
AnnaBridge 156:ff21514d8981 168 /** DCDC low-noise mode */
AnnaBridge 156:ff21514d8981 169 emuDcdcMode_LowNoise = EMU_DCDCCTRL_DCDCMODE_LOWNOISE,
AnnaBridge 156:ff21514d8981 170 #if defined(_EMU_DCDCLPEM01CFG_MASK)
AnnaBridge 156:ff21514d8981 171 /** DCDC low-power mode */
AnnaBridge 156:ff21514d8981 172 emuDcdcMode_LowPower = EMU_DCDCCTRL_DCDCMODE_LOWPOWER,
AnnaBridge 156:ff21514d8981 173 #endif
AnnaBridge 156:ff21514d8981 174 } EMU_DcdcMode_TypeDef;
AnnaBridge 156:ff21514d8981 175 #endif
AnnaBridge 156:ff21514d8981 176
AnnaBridge 156:ff21514d8981 177 #if defined( _EMU_DCDCCTRL_MASK )
AnnaBridge 156:ff21514d8981 178 /** DCDC conduction modes */
AnnaBridge 156:ff21514d8981 179 typedef enum
AnnaBridge 156:ff21514d8981 180 {
AnnaBridge 156:ff21514d8981 181 /** DCDC Low-Noise Continuous Conduction Mode (CCM). EFR32 interference minimization
AnnaBridge 156:ff21514d8981 182 features are available in this mode. */
AnnaBridge 156:ff21514d8981 183 emuDcdcConductionMode_ContinuousLN,
AnnaBridge 156:ff21514d8981 184 /** DCDC Low-Noise Discontinuous Conduction Mode (DCM). This mode should be used for EFM32 or
AnnaBridge 156:ff21514d8981 185 when the EFR32 radio is not enabled. */
AnnaBridge 156:ff21514d8981 186 emuDcdcConductionMode_DiscontinuousLN,
AnnaBridge 156:ff21514d8981 187 } EMU_DcdcConductionMode_TypeDef;
AnnaBridge 156:ff21514d8981 188 #endif
AnnaBridge 156:ff21514d8981 189
AnnaBridge 156:ff21514d8981 190 #if defined( _EMU_PWRCTRL_MASK )
AnnaBridge 156:ff21514d8981 191 /** DCDC to DVDD mode analog peripheral power supply select */
AnnaBridge 156:ff21514d8981 192 typedef enum
AnnaBridge 156:ff21514d8981 193 {
AnnaBridge 156:ff21514d8981 194 /** Select AVDD as analog power supply. Typically lower noise, but less energy efficient. */
AnnaBridge 156:ff21514d8981 195 emuDcdcAnaPeripheralPower_AVDD = EMU_PWRCTRL_ANASW_AVDD,
AnnaBridge 156:ff21514d8981 196 /** Select DCDC (DVDD) as analog power supply. Typically more energy efficient, but more noise. */
AnnaBridge 156:ff21514d8981 197 emuDcdcAnaPeripheralPower_DCDC = EMU_PWRCTRL_ANASW_DVDD
AnnaBridge 156:ff21514d8981 198 } EMU_DcdcAnaPeripheralPower_TypeDef;
AnnaBridge 156:ff21514d8981 199 #endif
AnnaBridge 156:ff21514d8981 200
AnnaBridge 156:ff21514d8981 201 #if defined( _EMU_DCDCMISCCTRL_MASK )
AnnaBridge 156:ff21514d8981 202 /** DCDC Forced CCM and reverse current limiter control. Positive values have unit mA. */
AnnaBridge 156:ff21514d8981 203 typedef int16_t EMU_DcdcLnReverseCurrentControl_TypeDef;
AnnaBridge 156:ff21514d8981 204
AnnaBridge 156:ff21514d8981 205 /** High efficiency mode. EMU_DCDCZDETCTRL_ZDETILIMSEL is "don't care". */
AnnaBridge 156:ff21514d8981 206 #define emuDcdcLnHighEfficiency -1
AnnaBridge 156:ff21514d8981 207
AnnaBridge 156:ff21514d8981 208 /** Default reverse current for fast transient response mode (low noise). */
AnnaBridge 156:ff21514d8981 209 #define emuDcdcLnFastTransient 160
AnnaBridge 156:ff21514d8981 210 #endif
AnnaBridge 156:ff21514d8981 211
AnnaBridge 156:ff21514d8981 212
AnnaBridge 156:ff21514d8981 213 #if defined( _EMU_DCDCCTRL_MASK )
AnnaBridge 156:ff21514d8981 214 /** DCDC Low-noise RCO band select */
AnnaBridge 156:ff21514d8981 215 typedef enum
AnnaBridge 156:ff21514d8981 216 {
AnnaBridge 156:ff21514d8981 217 /** Set RCO to 3MHz */
AnnaBridge 156:ff21514d8981 218 emuDcdcLnRcoBand_3MHz = 0,
AnnaBridge 156:ff21514d8981 219 /** Set RCO to 4MHz */
AnnaBridge 156:ff21514d8981 220 emuDcdcLnRcoBand_4MHz = 1,
AnnaBridge 156:ff21514d8981 221 /** Set RCO to 5MHz */
AnnaBridge 156:ff21514d8981 222 emuDcdcLnRcoBand_5MHz = 2,
AnnaBridge 156:ff21514d8981 223 /** Set RCO to 6MHz */
AnnaBridge 156:ff21514d8981 224 emuDcdcLnRcoBand_6MHz = 3,
AnnaBridge 156:ff21514d8981 225 /** Set RCO to 7MHz */
AnnaBridge 156:ff21514d8981 226 emuDcdcLnRcoBand_7MHz = 4,
AnnaBridge 156:ff21514d8981 227 /** Set RCO to 8MHz */
AnnaBridge 156:ff21514d8981 228 emuDcdcLnRcoBand_8MHz = 5,
AnnaBridge 156:ff21514d8981 229 /** Set RCO to 9MHz */
AnnaBridge 156:ff21514d8981 230 emuDcdcLnRcoBand_9MHz = 6,
AnnaBridge 156:ff21514d8981 231 /** Set RCO to 10MHz */
AnnaBridge 156:ff21514d8981 232 emuDcdcLnRcoBand_10MHz = 7,
AnnaBridge 156:ff21514d8981 233 } EMU_DcdcLnRcoBand_TypeDef;
AnnaBridge 156:ff21514d8981 234
AnnaBridge 156:ff21514d8981 235 /** @cond DO_NOT_INCLUDE_WITH_DOXYGEN */
AnnaBridge 156:ff21514d8981 236 /* Deprecated. */
AnnaBridge 156:ff21514d8981 237 #define EMU_DcdcLnRcoBand_3MHz emuDcdcLnRcoBand_3MHz
AnnaBridge 156:ff21514d8981 238 #define EMU_DcdcLnRcoBand_4MHz emuDcdcLnRcoBand_4MHz
AnnaBridge 156:ff21514d8981 239 #define EMU_DcdcLnRcoBand_5MHz emuDcdcLnRcoBand_5MHz
AnnaBridge 156:ff21514d8981 240 #define EMU_DcdcLnRcoBand_6MHz emuDcdcLnRcoBand_6MHz
AnnaBridge 156:ff21514d8981 241 #define EMU_DcdcLnRcoBand_7MHz emuDcdcLnRcoBand_7MHz
AnnaBridge 156:ff21514d8981 242 #define EMU_DcdcLnRcoBand_8MHz emuDcdcLnRcoBand_8MHz
AnnaBridge 156:ff21514d8981 243 #define EMU_DcdcLnRcoBand_9MHz emuDcdcLnRcoBand_9MHz
AnnaBridge 156:ff21514d8981 244 #define EMU_DcdcLnRcoBand_10MHz emuDcdcLnRcoBand_10MHz
AnnaBridge 156:ff21514d8981 245 /** @endcond */
AnnaBridge 156:ff21514d8981 246 #endif
AnnaBridge 156:ff21514d8981 247
AnnaBridge 156:ff21514d8981 248
AnnaBridge 156:ff21514d8981 249 #if defined( _EMU_DCDCCTRL_MASK )
AnnaBridge 156:ff21514d8981 250 /** DCDC Low Noise Compensator Control register. */
AnnaBridge 156:ff21514d8981 251 typedef enum
AnnaBridge 156:ff21514d8981 252 {
AnnaBridge 156:ff21514d8981 253 /** DCDC capacitor is 1uF. */
AnnaBridge 156:ff21514d8981 254 emuDcdcLnCompCtrl_1u0F,
AnnaBridge 156:ff21514d8981 255 /** DCDC capacitor is 4.7uF. */
AnnaBridge 156:ff21514d8981 256 emuDcdcLnCompCtrl_4u7F,
AnnaBridge 156:ff21514d8981 257 } EMU_DcdcLnCompCtrl_TypeDef;
AnnaBridge 156:ff21514d8981 258 #endif
AnnaBridge 156:ff21514d8981 259
AnnaBridge 156:ff21514d8981 260
AnnaBridge 156:ff21514d8981 261 #if defined( EMU_STATUS_VMONRDY )
AnnaBridge 156:ff21514d8981 262 /** VMON channels */
AnnaBridge 156:ff21514d8981 263 typedef enum
AnnaBridge 156:ff21514d8981 264 {
AnnaBridge 156:ff21514d8981 265 emuVmonChannel_AVDD,
AnnaBridge 156:ff21514d8981 266 emuVmonChannel_ALTAVDD,
AnnaBridge 156:ff21514d8981 267 emuVmonChannel_DVDD,
AnnaBridge 156:ff21514d8981 268 emuVmonChannel_IOVDD0
AnnaBridge 156:ff21514d8981 269 } EMU_VmonChannel_TypeDef;
AnnaBridge 156:ff21514d8981 270 #endif /* EMU_STATUS_VMONRDY */
AnnaBridge 156:ff21514d8981 271
AnnaBridge 156:ff21514d8981 272 #if defined( _SILICON_LABS_GECKO_INTERNAL_SDID_80 )
AnnaBridge 156:ff21514d8981 273 /** Bias mode configurations */
AnnaBridge 156:ff21514d8981 274 typedef enum
AnnaBridge 156:ff21514d8981 275 {
AnnaBridge 156:ff21514d8981 276 emuBiasMode_1KHz,
AnnaBridge 156:ff21514d8981 277 emuBiasMode_4KHz,
AnnaBridge 156:ff21514d8981 278 emuBiasMode_Continuous
AnnaBridge 156:ff21514d8981 279 } EMU_BiasMode_TypeDef;
AnnaBridge 156:ff21514d8981 280 #endif
AnnaBridge 156:ff21514d8981 281
AnnaBridge 156:ff21514d8981 282 #if defined( _EMU_CMD_EM01VSCALE0_MASK )
AnnaBridge 156:ff21514d8981 283 /** Supported EM0/1 Voltage Scaling Levels */
AnnaBridge 156:ff21514d8981 284 typedef enum
AnnaBridge 156:ff21514d8981 285 {
AnnaBridge 156:ff21514d8981 286 /** High-performance voltage level. HF clock can be set to any frequency. */
AnnaBridge 156:ff21514d8981 287 emuVScaleEM01_HighPerformance = _EMU_STATUS_VSCALE_VSCALE2,
AnnaBridge 156:ff21514d8981 288 /** Low-power optimized voltage level. The HF clock must be limited
AnnaBridge 156:ff21514d8981 289 to @ref CMU_VSCALEEM01_LOWPOWER_VOLTAGE_CLOCK_MAX Hz at this voltage.
AnnaBridge 156:ff21514d8981 290 EM0/1 voltage scaling is applied when the core clock frequency is
AnnaBridge 156:ff21514d8981 291 changed from @ref CMU or when calling @ref EMU_EM01Init() when the HF
AnnaBridge 156:ff21514d8981 292 clock is already below the limit. */
AnnaBridge 156:ff21514d8981 293 emuVScaleEM01_LowPower = _EMU_STATUS_VSCALE_VSCALE0,
AnnaBridge 156:ff21514d8981 294 } EMU_VScaleEM01_TypeDef;
AnnaBridge 156:ff21514d8981 295 #endif
AnnaBridge 156:ff21514d8981 296
AnnaBridge 156:ff21514d8981 297 #if defined( _EMU_CTRL_EM23VSCALE_MASK )
AnnaBridge 156:ff21514d8981 298 /** Supported EM2/3 Voltage Scaling Levels */
AnnaBridge 156:ff21514d8981 299 typedef enum
AnnaBridge 156:ff21514d8981 300 {
AnnaBridge 156:ff21514d8981 301 /** Fast-wakeup voltage level. */
AnnaBridge 156:ff21514d8981 302 emuVScaleEM23_FastWakeup = _EMU_CTRL_EM23VSCALE_VSCALE2,
AnnaBridge 156:ff21514d8981 303 /** Low-power optimized voltage level. Using this voltage level in EM2 and 3
AnnaBridge 156:ff21514d8981 304 adds 20-25us to wakeup time if the EM0 and 1 voltage must be scaled
AnnaBridge 156:ff21514d8981 305 up to @ref emuVScaleEM01_HighPerformance on EM2 or 3 exit. */
AnnaBridge 156:ff21514d8981 306 emuVScaleEM23_LowPower = _EMU_CTRL_EM23VSCALE_VSCALE0,
AnnaBridge 156:ff21514d8981 307 } EMU_VScaleEM23_TypeDef;
AnnaBridge 156:ff21514d8981 308 #endif
AnnaBridge 156:ff21514d8981 309
AnnaBridge 156:ff21514d8981 310 #if defined( _EMU_CTRL_EM4HVSCALE_MASK )
AnnaBridge 156:ff21514d8981 311 /** Supported EM4H Voltage Scaling Levels */
AnnaBridge 156:ff21514d8981 312 typedef enum
AnnaBridge 156:ff21514d8981 313 {
AnnaBridge 156:ff21514d8981 314 /** Fast-wakeup voltage level. */
AnnaBridge 156:ff21514d8981 315 emuVScaleEM4H_FastWakeup = _EMU_CTRL_EM4HVSCALE_VSCALE2,
AnnaBridge 156:ff21514d8981 316 /** Low-power optimized voltage level. Using this voltage level in EM4H
AnnaBridge 156:ff21514d8981 317 adds 20-25us to wakeup time if the EM0 and 1 voltage must be scaled
AnnaBridge 156:ff21514d8981 318 up to @ref emuVScaleEM01_HighPerformance on EM4H exit. */
AnnaBridge 156:ff21514d8981 319 emuVScaleEM4H_LowPower = _EMU_CTRL_EM4HVSCALE_VSCALE0,
AnnaBridge 156:ff21514d8981 320 } EMU_VScaleEM4H_TypeDef;
AnnaBridge 156:ff21514d8981 321 #endif
AnnaBridge 156:ff21514d8981 322
AnnaBridge 156:ff21514d8981 323 #if defined(_EMU_EM23PERNORETAINCTRL_MASK)
AnnaBridge 156:ff21514d8981 324 /** Peripheral EM2 and 3 retention control */
AnnaBridge 156:ff21514d8981 325 typedef enum
AnnaBridge 156:ff21514d8981 326 {
AnnaBridge 156:ff21514d8981 327 emuPeripheralRetention_LEUART0 = _EMU_EM23PERNORETAINCTRL_LEUART0DIS_MASK, /* Select LEUART0 retention control */
AnnaBridge 156:ff21514d8981 328 emuPeripheralRetention_CSEN = _EMU_EM23PERNORETAINCTRL_CSENDIS_MASK, /* Select CSEN retention control */
AnnaBridge 156:ff21514d8981 329 emuPeripheralRetention_LESENSE0 = _EMU_EM23PERNORETAINCTRL_LESENSE0DIS_MASK, /* Select LESENSE0 retention control */
AnnaBridge 156:ff21514d8981 330 emuPeripheralRetention_LETIMER0 = _EMU_EM23PERNORETAINCTRL_LETIMER0DIS_MASK, /* Select LETIMER0 retention control */
AnnaBridge 156:ff21514d8981 331 emuPeripheralRetention_ADC0 = _EMU_EM23PERNORETAINCTRL_ADC0DIS_MASK, /* Select ADC0 retention control */
AnnaBridge 156:ff21514d8981 332 emuPeripheralRetention_IDAC0 = _EMU_EM23PERNORETAINCTRL_IDAC0DIS_MASK, /* Select IDAC0 retention control */
AnnaBridge 156:ff21514d8981 333 emuPeripheralRetention_VDAC0 = _EMU_EM23PERNORETAINCTRL_DAC0DIS_MASK, /* Select DAC0 retention control */
AnnaBridge 156:ff21514d8981 334 emuPeripheralRetention_I2C1 = _EMU_EM23PERNORETAINCTRL_I2C1DIS_MASK, /* Select I2C1 retention control */
AnnaBridge 156:ff21514d8981 335 emuPeripheralRetention_I2C0 = _EMU_EM23PERNORETAINCTRL_I2C0DIS_MASK, /* Select I2C0 retention control */
AnnaBridge 156:ff21514d8981 336 emuPeripheralRetention_ACMP1 = _EMU_EM23PERNORETAINCTRL_ACMP1DIS_MASK, /* Select ACMP1 retention control */
AnnaBridge 156:ff21514d8981 337 emuPeripheralRetention_ACMP0 = _EMU_EM23PERNORETAINCTRL_ACMP0DIS_MASK, /* Select ACMP0 retention control */
AnnaBridge 156:ff21514d8981 338 #if defined( _EMU_EM23PERNORETAINCTRL_PCNT1DIS_MASK )
AnnaBridge 156:ff21514d8981 339 emuPeripheralRetention_PCNT2 = _EMU_EM23PERNORETAINCTRL_PCNT2DIS_MASK, /* Select PCNT2 retention control */
AnnaBridge 156:ff21514d8981 340 emuPeripheralRetention_PCNT1 = _EMU_EM23PERNORETAINCTRL_PCNT1DIS_MASK, /* Select PCNT1 retention control */
AnnaBridge 156:ff21514d8981 341 #endif
AnnaBridge 156:ff21514d8981 342 emuPeripheralRetention_PCNT0 = _EMU_EM23PERNORETAINCTRL_PCNT0DIS_MASK, /* Select PCNT0 retention control */
AnnaBridge 156:ff21514d8981 343
AnnaBridge 156:ff21514d8981 344 emuPeripheralRetention_D1 = _EMU_EM23PERNORETAINCTRL_LETIMER0DIS_MASK
AnnaBridge 156:ff21514d8981 345 | _EMU_EM23PERNORETAINCTRL_PCNT0DIS_MASK
AnnaBridge 156:ff21514d8981 346 | _EMU_EM23PERNORETAINCTRL_ADC0DIS_MASK
AnnaBridge 156:ff21514d8981 347 | _EMU_EM23PERNORETAINCTRL_ACMP0DIS_MASK
AnnaBridge 156:ff21514d8981 348 | _EMU_EM23PERNORETAINCTRL_LESENSE0DIS_MASK,/* Select all peripherals in domain 1 */
AnnaBridge 156:ff21514d8981 349 emuPeripheralRetention_D2 = _EMU_EM23PERNORETAINCTRL_ACMP1DIS_MASK
AnnaBridge 156:ff21514d8981 350 | _EMU_EM23PERNORETAINCTRL_IDAC0DIS_MASK
AnnaBridge 156:ff21514d8981 351 | _EMU_EM23PERNORETAINCTRL_DAC0DIS_MASK
AnnaBridge 156:ff21514d8981 352 | _EMU_EM23PERNORETAINCTRL_CSENDIS_MASK
AnnaBridge 156:ff21514d8981 353 | _EMU_EM23PERNORETAINCTRL_LEUART0DIS_MASK
AnnaBridge 156:ff21514d8981 354 #if defined( _EMU_EM23PERNORETAINCTRL_PCNT1DIS_MASK )
AnnaBridge 156:ff21514d8981 355 | _EMU_EM23PERNORETAINCTRL_PCNT1DIS_MASK
AnnaBridge 156:ff21514d8981 356 | _EMU_EM23PERNORETAINCTRL_PCNT2DIS_MASK
AnnaBridge 156:ff21514d8981 357 #endif
AnnaBridge 156:ff21514d8981 358 | _EMU_EM23PERNORETAINCTRL_I2C0DIS_MASK
AnnaBridge 156:ff21514d8981 359 | _EMU_EM23PERNORETAINCTRL_I2C1DIS_MASK, /* Select all peripherals in domain 2 */
AnnaBridge 156:ff21514d8981 360 emuPeripheralRetention_ALL = emuPeripheralRetention_D1
AnnaBridge 156:ff21514d8981 361 | emuPeripheralRetention_D2, /* Select all peripherals with retention control */
AnnaBridge 156:ff21514d8981 362 } EMU_PeripheralRetention_TypeDef;
AnnaBridge 156:ff21514d8981 363 #endif
AnnaBridge 156:ff21514d8981 364
AnnaBridge 156:ff21514d8981 365 /*******************************************************************************
AnnaBridge 156:ff21514d8981 366 ******************************* STRUCTS ***********************************
AnnaBridge 156:ff21514d8981 367 ******************************************************************************/
AnnaBridge 156:ff21514d8981 368
AnnaBridge 156:ff21514d8981 369 #if defined( _EMU_CMD_EM01VSCALE0_MASK )
AnnaBridge 156:ff21514d8981 370 /** EM0 and 1 initialization structure. Voltage scaling is applied when
AnnaBridge 156:ff21514d8981 371 the core clock frequency is changed from @ref CMU. EM0 an 1 emuVScaleEM01_HighPerformance
AnnaBridge 156:ff21514d8981 372 is always enabled. */
AnnaBridge 156:ff21514d8981 373 typedef struct
AnnaBridge 156:ff21514d8981 374 {
AnnaBridge 156:ff21514d8981 375 bool vScaleEM01LowPowerVoltageEnable; /**< EM0/1 low power voltage status */
AnnaBridge 156:ff21514d8981 376 } EMU_EM01Init_TypeDef;
AnnaBridge 156:ff21514d8981 377 #endif
AnnaBridge 156:ff21514d8981 378
AnnaBridge 156:ff21514d8981 379 #if defined( _EMU_CMD_EM01VSCALE0_MASK )
AnnaBridge 156:ff21514d8981 380 /** Default initialization of EM0 and 1 configuration */
AnnaBridge 156:ff21514d8981 381 #define EMU_EM01INIT_DEFAULT \
AnnaBridge 156:ff21514d8981 382 { \
AnnaBridge 156:ff21514d8981 383 false /** Do not scale down in EM0/1 */ \
AnnaBridge 156:ff21514d8981 384 }
AnnaBridge 156:ff21514d8981 385 #endif
AnnaBridge 156:ff21514d8981 386
AnnaBridge 156:ff21514d8981 387 /** EM2 and 3 initialization structure */
AnnaBridge 156:ff21514d8981 388 typedef struct
AnnaBridge 156:ff21514d8981 389 {
AnnaBridge 156:ff21514d8981 390 bool em23VregFullEn; /**< Enable full VREG drive strength in EM2/3 */
AnnaBridge 156:ff21514d8981 391 #if defined( _EMU_CTRL_EM23VSCALE_MASK )
AnnaBridge 156:ff21514d8981 392 EMU_VScaleEM23_TypeDef vScaleEM23Voltage; /**< EM2/3 voltage scaling level */
AnnaBridge 156:ff21514d8981 393 #endif
AnnaBridge 156:ff21514d8981 394 } EMU_EM23Init_TypeDef;
AnnaBridge 156:ff21514d8981 395
AnnaBridge 156:ff21514d8981 396 /** Default initialization of EM2 and 3 configuration */
AnnaBridge 156:ff21514d8981 397 #if defined( _EMU_CTRL_EM4HVSCALE_MASK )
AnnaBridge 156:ff21514d8981 398 #define EMU_EM23INIT_DEFAULT \
AnnaBridge 156:ff21514d8981 399 { \
AnnaBridge 156:ff21514d8981 400 false, /* Reduced voltage regulator drive strength in EM2/3 */ \
AnnaBridge 156:ff21514d8981 401 emuVScaleEM23_FastWakeup, /* Do not scale down in EM2/3 */ \
AnnaBridge 156:ff21514d8981 402 }
AnnaBridge 156:ff21514d8981 403 #else
AnnaBridge 156:ff21514d8981 404 #define EMU_EM23INIT_DEFAULT \
AnnaBridge 156:ff21514d8981 405 { \
AnnaBridge 156:ff21514d8981 406 false, /* Reduced voltage regulator drive strength in EM2/3 */ \
AnnaBridge 156:ff21514d8981 407 }
AnnaBridge 156:ff21514d8981 408 #endif
AnnaBridge 156:ff21514d8981 409
AnnaBridge 156:ff21514d8981 410 #if defined( _EMU_EM4CONF_MASK ) || defined( _EMU_EM4CTRL_MASK )
AnnaBridge 156:ff21514d8981 411 /** EM4 initialization structure */
AnnaBridge 156:ff21514d8981 412 typedef struct
AnnaBridge 156:ff21514d8981 413 {
AnnaBridge 156:ff21514d8981 414 #if defined( _EMU_EM4CONF_MASK )
AnnaBridge 156:ff21514d8981 415 /* Init parameters for platforms with EMU->EM4CONF register (Series 0) */
AnnaBridge 156:ff21514d8981 416 bool lockConfig; /**< Lock configuration of regulator, BOD and oscillator */
AnnaBridge 156:ff21514d8981 417 bool buBodRstDis; /**< When set, no reset will be asserted due to Brownout when in EM4 */
AnnaBridge 156:ff21514d8981 418 EMU_EM4Osc_TypeDef osc; /**< EM4 duty oscillator */
AnnaBridge 156:ff21514d8981 419 bool buRtcWakeup; /**< Wake up on EM4 BURTC interrupt */
AnnaBridge 156:ff21514d8981 420 bool vreg; /**< Enable EM4 voltage regulator */
AnnaBridge 156:ff21514d8981 421 #elif defined( _EMU_EM4CTRL_MASK )
AnnaBridge 156:ff21514d8981 422 /* Init parameters for platforms with EMU->EM4CTRL register (Series 1) */
AnnaBridge 156:ff21514d8981 423 bool retainLfxo; /**< Disable the LFXO upon EM4 entry */
AnnaBridge 156:ff21514d8981 424 bool retainLfrco; /**< Disable the LFRCO upon EM4 entry */
AnnaBridge 156:ff21514d8981 425 bool retainUlfrco; /**< Disable the ULFRCO upon EM4 entry */
AnnaBridge 156:ff21514d8981 426 EMU_EM4State_TypeDef em4State; /**< Hibernate or shutoff EM4 state */
AnnaBridge 156:ff21514d8981 427 EMU_EM4PinRetention_TypeDef pinRetentionMode; /**< EM4 pin retention mode */
AnnaBridge 156:ff21514d8981 428 #endif
AnnaBridge 156:ff21514d8981 429 #if defined( _EMU_CTRL_EM4HVSCALE_MASK )
AnnaBridge 156:ff21514d8981 430 EMU_VScaleEM4H_TypeDef vScaleEM4HVoltage;/**< EM4H voltage scaling level */
AnnaBridge 156:ff21514d8981 431 #endif
AnnaBridge 156:ff21514d8981 432 } EMU_EM4Init_TypeDef;
AnnaBridge 156:ff21514d8981 433 #endif
AnnaBridge 156:ff21514d8981 434
AnnaBridge 156:ff21514d8981 435 #if defined( _EMU_EM4CONF_MASK )
AnnaBridge 156:ff21514d8981 436 /** Default initialization of EM4 configuration (Series 0) */
AnnaBridge 156:ff21514d8981 437 #define EMU_EM4INIT_DEFAULT \
AnnaBridge 156:ff21514d8981 438 { \
AnnaBridge 156:ff21514d8981 439 false, /* Dont't lock configuration after it's been set */ \
AnnaBridge 156:ff21514d8981 440 false, /* No reset will be asserted due to BOD in EM4 */ \
AnnaBridge 156:ff21514d8981 441 emuEM4Osc_ULFRCO, /* Use default ULFRCO oscillator */ \
AnnaBridge 156:ff21514d8981 442 true, /* Wake up on EM4 BURTC interrupt */ \
AnnaBridge 156:ff21514d8981 443 true, /* Enable VREG */ \
AnnaBridge 156:ff21514d8981 444 }
AnnaBridge 156:ff21514d8981 445
AnnaBridge 156:ff21514d8981 446 #elif defined( _EMU_CTRL_EM4HVSCALE_MASK )
AnnaBridge 156:ff21514d8981 447 /** Default initialization of EM4 configuration (Series 1 with VSCALE) */
AnnaBridge 156:ff21514d8981 448 #define EMU_EM4INIT_DEFAULT \
AnnaBridge 156:ff21514d8981 449 { \
AnnaBridge 156:ff21514d8981 450 false, /* Retain LFXO configuration upon EM4 entry */ \
AnnaBridge 156:ff21514d8981 451 false, /* Retain LFRCO configuration upon EM4 entry */ \
AnnaBridge 156:ff21514d8981 452 false, /* Retain ULFRCO configuration upon EM4 entry */ \
AnnaBridge 156:ff21514d8981 453 emuEM4Shutoff, /* Use EM4 shutoff state */ \
AnnaBridge 156:ff21514d8981 454 emuPinRetentionDisable, /* Do not retain pins in EM4 */ \
AnnaBridge 156:ff21514d8981 455 emuVScaleEM4H_FastWakeup, /* Do not scale down in EM4H */ \
AnnaBridge 156:ff21514d8981 456 }
AnnaBridge 156:ff21514d8981 457
AnnaBridge 156:ff21514d8981 458 #elif defined( _EMU_EM4CTRL_MASK )
AnnaBridge 156:ff21514d8981 459 /** Default initialization of EM4 configuration (Series 1 without VSCALE) */
AnnaBridge 156:ff21514d8981 460 #define EMU_EM4INIT_DEFAULT \
AnnaBridge 156:ff21514d8981 461 { \
AnnaBridge 156:ff21514d8981 462 false, /* Retain LFXO configuration upon EM4 entry */ \
AnnaBridge 156:ff21514d8981 463 false, /* Retain LFRCO configuration upon EM4 entry */ \
AnnaBridge 156:ff21514d8981 464 false, /* Retain ULFRCO configuration upon EM4 entry */ \
AnnaBridge 156:ff21514d8981 465 emuEM4Shutoff, /* Use EM4 shutoff state */ \
AnnaBridge 156:ff21514d8981 466 emuPinRetentionDisable, /* Do not retain pins in EM4 */ \
AnnaBridge 156:ff21514d8981 467 }
AnnaBridge 156:ff21514d8981 468 #endif
AnnaBridge 156:ff21514d8981 469
AnnaBridge 156:ff21514d8981 470 #if defined( BU_PRESENT )
AnnaBridge 156:ff21514d8981 471 /** Backup Power Domain Initialization structure */
AnnaBridge 156:ff21514d8981 472 typedef struct
AnnaBridge 156:ff21514d8981 473 {
AnnaBridge 156:ff21514d8981 474 /* Backup Power Domain power configuration */
AnnaBridge 156:ff21514d8981 475
AnnaBridge 156:ff21514d8981 476 /** Voltage probe select, selects ADC voltage */
AnnaBridge 156:ff21514d8981 477 EMU_Probe_TypeDef probe;
AnnaBridge 156:ff21514d8981 478 /** Enable BOD calibration mode */
AnnaBridge 156:ff21514d8981 479 bool bodCal;
AnnaBridge 156:ff21514d8981 480 /** Enable BU_STAT status pin for active BU mode */
AnnaBridge 156:ff21514d8981 481 bool statusPinEnable;
AnnaBridge 156:ff21514d8981 482
AnnaBridge 156:ff21514d8981 483 /* Backup Power Domain connection configuration */
AnnaBridge 156:ff21514d8981 484 /** Power domain resistor */
AnnaBridge 156:ff21514d8981 485 EMU_Resistor_TypeDef resistor;
AnnaBridge 156:ff21514d8981 486 /** BU_VOUT strong enable */
AnnaBridge 156:ff21514d8981 487 bool voutStrong;
AnnaBridge 156:ff21514d8981 488 /** BU_VOUT medium enable */
AnnaBridge 156:ff21514d8981 489 bool voutMed;
AnnaBridge 156:ff21514d8981 490 /** BU_VOUT weak enable */
AnnaBridge 156:ff21514d8981 491 bool voutWeak;
AnnaBridge 156:ff21514d8981 492 /** Power connection, when not in Backup Mode */
AnnaBridge 156:ff21514d8981 493 EMU_Power_TypeDef inactivePower;
AnnaBridge 156:ff21514d8981 494 /** Power connection, when in Backup Mode */
AnnaBridge 156:ff21514d8981 495 EMU_Power_TypeDef activePower;
AnnaBridge 156:ff21514d8981 496 /** Enable backup power domain, and release reset, enable BU_VIN pin */
AnnaBridge 156:ff21514d8981 497 bool enable;
AnnaBridge 156:ff21514d8981 498 } EMU_BUPDInit_TypeDef;
AnnaBridge 156:ff21514d8981 499
AnnaBridge 156:ff21514d8981 500 /** Default Backup Power Domain configuration */
AnnaBridge 156:ff21514d8981 501 #define EMU_BUPDINIT_DEFAULT \
AnnaBridge 156:ff21514d8981 502 { \
AnnaBridge 156:ff21514d8981 503 emuProbe_Disable, /* Do not enable voltage probe */ \
AnnaBridge 156:ff21514d8981 504 false, /* Disable BOD calibration mode */ \
AnnaBridge 156:ff21514d8981 505 false, /* Disable BU_STAT pin for backup mode indication */ \
AnnaBridge 156:ff21514d8981 506 \
AnnaBridge 156:ff21514d8981 507 emuRes_Res0, /* RES0 series resistance between main and backup power */ \
AnnaBridge 156:ff21514d8981 508 false, /* Don't enable strong switch */ \
AnnaBridge 156:ff21514d8981 509 false, /* Don't enable medium switch */ \
AnnaBridge 156:ff21514d8981 510 false, /* Don't enable weak switch */ \
AnnaBridge 156:ff21514d8981 511 \
AnnaBridge 156:ff21514d8981 512 emuPower_None, /* No connection between main and backup power (inactive mode) */ \
AnnaBridge 156:ff21514d8981 513 emuPower_None, /* No connection between main and backup power (active mode) */ \
AnnaBridge 156:ff21514d8981 514 true /* Enable BUPD enter on BOD, enable BU_VIN pin, release BU reset */ \
AnnaBridge 156:ff21514d8981 515 }
AnnaBridge 156:ff21514d8981 516 #endif
AnnaBridge 156:ff21514d8981 517
AnnaBridge 156:ff21514d8981 518 #if defined( _EMU_DCDCCTRL_MASK )
AnnaBridge 156:ff21514d8981 519 /** DCDC initialization structure */
AnnaBridge 156:ff21514d8981 520 typedef struct
AnnaBridge 156:ff21514d8981 521 {
AnnaBridge 156:ff21514d8981 522 EMU_PowerConfig_TypeDef powerConfig; /**< Device external power configuration.
AnnaBridge 156:ff21514d8981 523 @ref emuPowerConfig_DcdcToDvdd is currently the only supported mode. */
AnnaBridge 156:ff21514d8981 524 EMU_DcdcMode_TypeDef dcdcMode; /**< DCDC regulator operating mode in EM0/1 */
AnnaBridge 156:ff21514d8981 525 uint16_t mVout; /**< Target output voltage (mV) */
AnnaBridge 156:ff21514d8981 526 uint16_t em01LoadCurrent_mA; /**< Estimated average load current in EM0/1 (mA).
AnnaBridge 156:ff21514d8981 527 This estimate is also used for EM1 optimization,
AnnaBridge 156:ff21514d8981 528 so if EM1 current is expected to be higher than EM0,
AnnaBridge 156:ff21514d8981 529 then this parameter should hold the higher EM1 current. */
AnnaBridge 156:ff21514d8981 530 uint16_t em234LoadCurrent_uA; /**< Estimated average load current in EM2 (uA).
AnnaBridge 156:ff21514d8981 531 This estimate is also used for EM3 and 4 optimization,
AnnaBridge 156:ff21514d8981 532 so if EM3 or 4 current is expected to be higher than EM2,
AnnaBridge 156:ff21514d8981 533 then this parameter should hold the higher EM3 or 4 current. */
AnnaBridge 156:ff21514d8981 534 uint16_t maxCurrent_mA; /**< Maximum average DCDC output current (mA).
AnnaBridge 156:ff21514d8981 535 This can be set to the maximum for the power source,
AnnaBridge 156:ff21514d8981 536 for example the maximum for a battery. */
AnnaBridge 156:ff21514d8981 537 EMU_DcdcAnaPeripheralPower_TypeDef
AnnaBridge 156:ff21514d8981 538 anaPeripheralPower; /**< Select analog peripheral power in DCDC-to-DVDD mode */
AnnaBridge 156:ff21514d8981 539 EMU_DcdcLnReverseCurrentControl_TypeDef
AnnaBridge 156:ff21514d8981 540 reverseCurrentControl; /**< Low-noise reverse current control.
AnnaBridge 156:ff21514d8981 541 NOTE: this parameter uses special encoding:
AnnaBridge 156:ff21514d8981 542 >= 0 is forced CCM mode where the parameter is used as the
AnnaBridge 156:ff21514d8981 543 reverse current threshold in mA.
AnnaBridge 156:ff21514d8981 544 -1 is encoded as emuDcdcLnHighEfficiencyMode (EFM32 only) */
AnnaBridge 156:ff21514d8981 545 EMU_DcdcLnCompCtrl_TypeDef dcdcLnCompCtrl; /**< DCDC Low-noise mode compensator control. */
AnnaBridge 156:ff21514d8981 546 } EMU_DCDCInit_TypeDef;
AnnaBridge 156:ff21514d8981 547
AnnaBridge 156:ff21514d8981 548 /** Default DCDC initialization */
AnnaBridge 156:ff21514d8981 549 #if defined( _EFM_DEVICE )
AnnaBridge 156:ff21514d8981 550 #if defined(_SILICON_LABS_GECKO_INTERNAL_SDID_80)
AnnaBridge 156:ff21514d8981 551 #define EMU_DCDCINIT_DEFAULT \
AnnaBridge 156:ff21514d8981 552 { \
AnnaBridge 156:ff21514d8981 553 emuPowerConfig_DcdcToDvdd, /* DCDC to DVDD */ \
AnnaBridge 156:ff21514d8981 554 emuDcdcMode_LowNoise, /* Low-niose mode in EM0 */ \
AnnaBridge 156:ff21514d8981 555 1800, /* Nominal output voltage for DVDD mode, 1.8V */ \
AnnaBridge 156:ff21514d8981 556 5, /* Nominal EM0/1 load current of less than 5mA */ \
AnnaBridge 156:ff21514d8981 557 10, /* Nominal EM2/3/4 load current less than 10uA */ \
AnnaBridge 156:ff21514d8981 558 200, /* Maximum average current of 200mA
AnnaBridge 156:ff21514d8981 559 (assume strong battery or other power source) */ \
AnnaBridge 156:ff21514d8981 560 emuDcdcAnaPeripheralPower_DCDC,/* Select DCDC as analog power supply (lower power) */ \
AnnaBridge 156:ff21514d8981 561 emuDcdcLnHighEfficiency, /* Use high-efficiency mode */ \
AnnaBridge 156:ff21514d8981 562 emuDcdcLnCompCtrl_1u0F, /* 1uF DCDC capacitor */ \
AnnaBridge 156:ff21514d8981 563 }
AnnaBridge 156:ff21514d8981 564 #else
AnnaBridge 156:ff21514d8981 565 #define EMU_DCDCINIT_DEFAULT \
AnnaBridge 156:ff21514d8981 566 { \
AnnaBridge 156:ff21514d8981 567 emuPowerConfig_DcdcToDvdd, /* DCDC to DVDD */ \
AnnaBridge 156:ff21514d8981 568 emuDcdcMode_LowPower, /* Low-power mode in EM0 */ \
AnnaBridge 156:ff21514d8981 569 1800, /* Nominal output voltage for DVDD mode, 1.8V */ \
AnnaBridge 156:ff21514d8981 570 5, /* Nominal EM0/1 load current of less than 5mA */ \
AnnaBridge 156:ff21514d8981 571 10, /* Nominal EM2/3/4 load current less than 10uA */ \
AnnaBridge 156:ff21514d8981 572 200, /* Maximum average current of 200mA
AnnaBridge 156:ff21514d8981 573 (assume strong battery or other power source) */ \
AnnaBridge 156:ff21514d8981 574 emuDcdcAnaPeripheralPower_DCDC,/* Select DCDC as analog power supply (lower power) */ \
AnnaBridge 156:ff21514d8981 575 emuDcdcLnHighEfficiency, /* Use high-efficiency mode */ \
AnnaBridge 156:ff21514d8981 576 emuDcdcLnCompCtrl_4u7F, /* 4.7uF DCDC capacitor */ \
AnnaBridge 156:ff21514d8981 577 }
AnnaBridge 156:ff21514d8981 578 #endif
AnnaBridge 156:ff21514d8981 579
AnnaBridge 156:ff21514d8981 580 #else /* EFR32 device */
AnnaBridge 156:ff21514d8981 581 #if defined(_SILICON_LABS_GECKO_INTERNAL_SDID_80)
AnnaBridge 156:ff21514d8981 582 #define EMU_DCDCINIT_DEFAULT \
AnnaBridge 156:ff21514d8981 583 { \
AnnaBridge 156:ff21514d8981 584 emuPowerConfig_DcdcToDvdd, /* DCDC to DVDD */ \
AnnaBridge 156:ff21514d8981 585 emuDcdcMode_LowNoise, /* Low-niose mode in EM0 */ \
AnnaBridge 156:ff21514d8981 586 1800, /* Nominal output voltage for DVDD mode, 1.8V */ \
AnnaBridge 156:ff21514d8981 587 15, /* Nominal EM0/1 load current of less than 15mA */ \
AnnaBridge 156:ff21514d8981 588 10, /* Nominal EM2/3/4 load current less than 10uA */ \
AnnaBridge 156:ff21514d8981 589 200, /* Maximum average current of 200mA
AnnaBridge 156:ff21514d8981 590 (assume strong battery or other power source) */ \
AnnaBridge 156:ff21514d8981 591 emuDcdcAnaPeripheralPower_DCDC,/* Select DCDC as analog power supply (lower power) */ \
AnnaBridge 156:ff21514d8981 592 160, /* Maximum reverse current of 160mA */ \
AnnaBridge 156:ff21514d8981 593 emuDcdcLnCompCtrl_1u0F, /* 1uF DCDC capacitor */ \
AnnaBridge 156:ff21514d8981 594 }
AnnaBridge 156:ff21514d8981 595 #else
AnnaBridge 156:ff21514d8981 596 #define EMU_DCDCINIT_DEFAULT \
AnnaBridge 156:ff21514d8981 597 { \
AnnaBridge 156:ff21514d8981 598 emuPowerConfig_DcdcToDvdd, /* DCDC to DVDD */ \
AnnaBridge 156:ff21514d8981 599 emuDcdcMode_LowNoise, /* Low-niose mode in EM0 */ \
AnnaBridge 156:ff21514d8981 600 1800, /* Nominal output voltage for DVDD mode, 1.8V */ \
AnnaBridge 156:ff21514d8981 601 15, /* Nominal EM0/1 load current of less than 15mA */ \
AnnaBridge 156:ff21514d8981 602 10, /* Nominal EM2/3/4 load current less than 10uA */ \
AnnaBridge 156:ff21514d8981 603 200, /* Maximum average current of 200mA
AnnaBridge 156:ff21514d8981 604 (assume strong battery or other power source) */ \
AnnaBridge 156:ff21514d8981 605 emuDcdcAnaPeripheralPower_DCDC,/* Select DCDC as analog power supply (lower power) */ \
AnnaBridge 156:ff21514d8981 606 160, /* Maximum reverse current of 160mA */ \
AnnaBridge 156:ff21514d8981 607 emuDcdcLnCompCtrl_4u7F, /* 4.7uF DCDC capacitor */ \
AnnaBridge 156:ff21514d8981 608 }
AnnaBridge 156:ff21514d8981 609 #endif
AnnaBridge 156:ff21514d8981 610 #endif
AnnaBridge 156:ff21514d8981 611 #endif
AnnaBridge 156:ff21514d8981 612
AnnaBridge 156:ff21514d8981 613 #if defined( EMU_STATUS_VMONRDY )
AnnaBridge 156:ff21514d8981 614 /** VMON initialization structure */
AnnaBridge 156:ff21514d8981 615 typedef struct
AnnaBridge 156:ff21514d8981 616 {
AnnaBridge 156:ff21514d8981 617 EMU_VmonChannel_TypeDef channel; /**< VMON channel to configure */
AnnaBridge 156:ff21514d8981 618 int threshold; /**< Trigger threshold (mV) */
AnnaBridge 156:ff21514d8981 619 bool riseWakeup; /**< Wake up from EM4H on rising edge */
AnnaBridge 156:ff21514d8981 620 bool fallWakeup; /**< Wake up from EM4H on falling edge */
AnnaBridge 156:ff21514d8981 621 bool enable; /**< Enable VMON channel */
AnnaBridge 156:ff21514d8981 622 bool retDisable; /**< Disable IO0 retention when voltage drops below threshold (IOVDD only) */
AnnaBridge 156:ff21514d8981 623 } EMU_VmonInit_TypeDef;
AnnaBridge 156:ff21514d8981 624
AnnaBridge 156:ff21514d8981 625 /** Default VMON initialization structure */
AnnaBridge 156:ff21514d8981 626 #define EMU_VMONINIT_DEFAULT \
AnnaBridge 156:ff21514d8981 627 { \
AnnaBridge 156:ff21514d8981 628 emuVmonChannel_AVDD, /* AVDD VMON channel */ \
AnnaBridge 156:ff21514d8981 629 3200, /* 3.2 V threshold */ \
AnnaBridge 156:ff21514d8981 630 false, /* Don't wake from EM4H on rising edge */ \
AnnaBridge 156:ff21514d8981 631 false, /* Don't wake from EM4H on falling edge */ \
AnnaBridge 156:ff21514d8981 632 true, /* Enable VMON channel */ \
AnnaBridge 156:ff21514d8981 633 false /* Don't disable IO0 retention */ \
AnnaBridge 156:ff21514d8981 634 }
AnnaBridge 156:ff21514d8981 635
AnnaBridge 156:ff21514d8981 636 /** VMON Hysteresis initialization structure */
AnnaBridge 156:ff21514d8981 637 typedef struct
AnnaBridge 156:ff21514d8981 638 {
AnnaBridge 156:ff21514d8981 639 EMU_VmonChannel_TypeDef channel; /**< VMON channel to configure */
AnnaBridge 156:ff21514d8981 640 int riseThreshold; /**< Rising threshold (mV) */
AnnaBridge 156:ff21514d8981 641 int fallThreshold; /**< Falling threshold (mV) */
AnnaBridge 156:ff21514d8981 642 bool riseWakeup; /**< Wake up from EM4H on rising edge */
AnnaBridge 156:ff21514d8981 643 bool fallWakeup; /**< Wake up from EM4H on falling edge */
AnnaBridge 156:ff21514d8981 644 bool enable; /**< Enable VMON channel */
AnnaBridge 156:ff21514d8981 645 } EMU_VmonHystInit_TypeDef;
AnnaBridge 156:ff21514d8981 646
AnnaBridge 156:ff21514d8981 647 /** Default VMON Hysteresis initialization structure */
AnnaBridge 156:ff21514d8981 648 #define EMU_VMONHYSTINIT_DEFAULT \
AnnaBridge 156:ff21514d8981 649 { \
AnnaBridge 156:ff21514d8981 650 emuVmonChannel_AVDD, /* AVDD VMON channel */ \
AnnaBridge 156:ff21514d8981 651 3200, /* 3.2 V rise threshold */ \
AnnaBridge 156:ff21514d8981 652 3200, /* 3.2 V fall threshold */ \
AnnaBridge 156:ff21514d8981 653 false, /* Don't wake from EM4H on rising edge */ \
AnnaBridge 156:ff21514d8981 654 false, /* Don't wake from EM4H on falling edge */ \
AnnaBridge 156:ff21514d8981 655 true /* Enable VMON channel */ \
AnnaBridge 156:ff21514d8981 656 }
AnnaBridge 156:ff21514d8981 657 #endif /* EMU_STATUS_VMONRDY */
AnnaBridge 156:ff21514d8981 658
AnnaBridge 156:ff21514d8981 659 /*******************************************************************************
AnnaBridge 156:ff21514d8981 660 ***************************** PROTOTYPES **********************************
AnnaBridge 156:ff21514d8981 661 ******************************************************************************/
AnnaBridge 156:ff21514d8981 662
AnnaBridge 156:ff21514d8981 663 #if defined( _EMU_CMD_EM01VSCALE0_MASK )
AnnaBridge 156:ff21514d8981 664 void EMU_EM01Init(const EMU_EM01Init_TypeDef *em01Init);
AnnaBridge 156:ff21514d8981 665 #endif
AnnaBridge 156:ff21514d8981 666 void EMU_EM23Init(const EMU_EM23Init_TypeDef *em23Init);
AnnaBridge 156:ff21514d8981 667 #if defined( _EMU_EM4CONF_MASK ) || defined( _EMU_EM4CTRL_MASK )
AnnaBridge 156:ff21514d8981 668 void EMU_EM4Init(const EMU_EM4Init_TypeDef *em4Init);
AnnaBridge 156:ff21514d8981 669 #endif
AnnaBridge 156:ff21514d8981 670 void EMU_EnterEM2(bool restore);
AnnaBridge 156:ff21514d8981 671 void EMU_EnterEM3(bool restore);
AnnaBridge 156:ff21514d8981 672 void EMU_Restore(void);
AnnaBridge 156:ff21514d8981 673 void EMU_EnterEM4(void);
AnnaBridge 156:ff21514d8981 674 #if defined( _EMU_EM4CTRL_MASK )
AnnaBridge 156:ff21514d8981 675 void EMU_EnterEM4H(void);
AnnaBridge 156:ff21514d8981 676 void EMU_EnterEM4S(void);
AnnaBridge 156:ff21514d8981 677 #endif
AnnaBridge 156:ff21514d8981 678 void EMU_MemPwrDown(uint32_t blocks);
AnnaBridge 156:ff21514d8981 679 void EMU_RamPowerDown(uint32_t start, uint32_t end);
AnnaBridge 156:ff21514d8981 680 #if defined(_EMU_EM23PERNORETAINCTRL_MASK)
AnnaBridge 156:ff21514d8981 681 void EMU_PeripheralRetention(EMU_PeripheralRetention_TypeDef periMask, bool enable);
AnnaBridge 156:ff21514d8981 682 #endif
AnnaBridge 156:ff21514d8981 683 void EMU_UpdateOscConfig(void);
AnnaBridge 156:ff21514d8981 684 #if defined( _EMU_CMD_EM01VSCALE0_MASK )
AnnaBridge 156:ff21514d8981 685 void EMU_VScaleEM01ByClock(uint32_t clockFrequency, bool wait);
AnnaBridge 156:ff21514d8981 686 void EMU_VScaleEM01(EMU_VScaleEM01_TypeDef voltage, bool wait);
AnnaBridge 156:ff21514d8981 687 #endif
AnnaBridge 156:ff21514d8981 688 #if defined( BU_PRESENT )
AnnaBridge 156:ff21514d8981 689 void EMU_BUPDInit(const EMU_BUPDInit_TypeDef *bupdInit);
AnnaBridge 156:ff21514d8981 690 void EMU_BUThresholdSet(EMU_BODMode_TypeDef mode, uint32_t value);
AnnaBridge 156:ff21514d8981 691 void EMU_BUThresRangeSet(EMU_BODMode_TypeDef mode, uint32_t value);
AnnaBridge 156:ff21514d8981 692 #endif
AnnaBridge 156:ff21514d8981 693 #if defined( _EMU_DCDCCTRL_MASK )
AnnaBridge 156:ff21514d8981 694 bool EMU_DCDCInit(const EMU_DCDCInit_TypeDef *dcdcInit);
AnnaBridge 156:ff21514d8981 695 void EMU_DCDCModeSet(EMU_DcdcMode_TypeDef dcdcMode);
AnnaBridge 156:ff21514d8981 696 void EMU_DCDCConductionModeSet(EMU_DcdcConductionMode_TypeDef conductionMode, bool rcoDefaultSet);
AnnaBridge 156:ff21514d8981 697 bool EMU_DCDCOutputVoltageSet(uint32_t mV, bool setLpVoltage, bool setLnVoltage);
AnnaBridge 156:ff21514d8981 698 void EMU_DCDCOptimizeSlice(uint32_t mALoadCurrent);
AnnaBridge 156:ff21514d8981 699 void EMU_DCDCLnRcoBandSet(EMU_DcdcLnRcoBand_TypeDef band);
AnnaBridge 156:ff21514d8981 700 bool EMU_DCDCPowerOff(void);
AnnaBridge 156:ff21514d8981 701 #endif
AnnaBridge 156:ff21514d8981 702 #if defined( EMU_STATUS_VMONRDY )
AnnaBridge 156:ff21514d8981 703 void EMU_VmonInit(const EMU_VmonInit_TypeDef *vmonInit);
AnnaBridge 156:ff21514d8981 704 void EMU_VmonHystInit(const EMU_VmonHystInit_TypeDef *vmonInit);
AnnaBridge 156:ff21514d8981 705 void EMU_VmonEnable(EMU_VmonChannel_TypeDef channel, bool enable);
AnnaBridge 156:ff21514d8981 706 bool EMU_VmonChannelStatusGet(EMU_VmonChannel_TypeDef channel);
AnnaBridge 156:ff21514d8981 707 #endif
AnnaBridge 156:ff21514d8981 708
AnnaBridge 156:ff21514d8981 709 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 710 * @brief
AnnaBridge 156:ff21514d8981 711 * Enter energy mode 1 (EM1).
AnnaBridge 156:ff21514d8981 712 ******************************************************************************/
AnnaBridge 156:ff21514d8981 713 __STATIC_INLINE void EMU_EnterEM1(void)
AnnaBridge 156:ff21514d8981 714 {
AnnaBridge 156:ff21514d8981 715 /* Enter sleep mode */
AnnaBridge 156:ff21514d8981 716 SCB->SCR &= ~SCB_SCR_SLEEPDEEP_Msk;
AnnaBridge 156:ff21514d8981 717 __WFI();
AnnaBridge 156:ff21514d8981 718 }
AnnaBridge 156:ff21514d8981 719
AnnaBridge 156:ff21514d8981 720
AnnaBridge 156:ff21514d8981 721 #if defined( _EMU_STATUS_VSCALE_MASK )
AnnaBridge 156:ff21514d8981 722 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 723 * @brief
AnnaBridge 156:ff21514d8981 724 * Wait for voltage scaling to complete
AnnaBridge 156:ff21514d8981 725 ******************************************************************************/
AnnaBridge 156:ff21514d8981 726 __STATIC_INLINE void EMU_VScaleWait(void)
AnnaBridge 156:ff21514d8981 727 {
AnnaBridge 156:ff21514d8981 728 while (BUS_RegBitRead(&EMU->STATUS, _EMU_STATUS_VSCALEBUSY_SHIFT));
AnnaBridge 156:ff21514d8981 729 }
AnnaBridge 156:ff21514d8981 730 #endif
AnnaBridge 156:ff21514d8981 731
AnnaBridge 156:ff21514d8981 732 #if defined( _EMU_STATUS_VSCALE_MASK )
AnnaBridge 156:ff21514d8981 733 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 734 * @brief
AnnaBridge 156:ff21514d8981 735 * Get current voltage scaling level
AnnaBridge 156:ff21514d8981 736 *
AnnaBridge 156:ff21514d8981 737 * @return
AnnaBridge 156:ff21514d8981 738 * Current voltage scaling level
AnnaBridge 156:ff21514d8981 739 ******************************************************************************/
AnnaBridge 156:ff21514d8981 740 __STATIC_INLINE EMU_VScaleEM01_TypeDef EMU_VScaleGet(void)
AnnaBridge 156:ff21514d8981 741 {
AnnaBridge 156:ff21514d8981 742 EMU_VScaleWait();
AnnaBridge 156:ff21514d8981 743 return (EMU_VScaleEM01_TypeDef)((EMU->STATUS & _EMU_STATUS_VSCALE_MASK)
AnnaBridge 156:ff21514d8981 744 >> _EMU_STATUS_VSCALE_SHIFT);
AnnaBridge 156:ff21514d8981 745 }
AnnaBridge 156:ff21514d8981 746 #endif
AnnaBridge 156:ff21514d8981 747
AnnaBridge 156:ff21514d8981 748 #if defined( _EMU_STATUS_VMONRDY_MASK )
AnnaBridge 156:ff21514d8981 749 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 750 * @brief
AnnaBridge 156:ff21514d8981 751 * Get the status of the voltage monitor (VMON).
AnnaBridge 156:ff21514d8981 752 *
AnnaBridge 156:ff21514d8981 753 * @return
AnnaBridge 156:ff21514d8981 754 * Status of the VMON. True if all the enabled channels are ready, false if
AnnaBridge 156:ff21514d8981 755 * one or more of the enabled channels are not ready.
AnnaBridge 156:ff21514d8981 756 ******************************************************************************/
AnnaBridge 156:ff21514d8981 757 __STATIC_INLINE bool EMU_VmonStatusGet(void)
AnnaBridge 156:ff21514d8981 758 {
AnnaBridge 156:ff21514d8981 759 return BUS_RegBitRead(&EMU->STATUS, _EMU_STATUS_VMONRDY_SHIFT);
AnnaBridge 156:ff21514d8981 760 }
AnnaBridge 156:ff21514d8981 761 #endif /* _EMU_STATUS_VMONRDY_MASK */
AnnaBridge 156:ff21514d8981 762
AnnaBridge 156:ff21514d8981 763 #if defined( _EMU_IF_MASK )
AnnaBridge 156:ff21514d8981 764 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 765 * @brief
AnnaBridge 156:ff21514d8981 766 * Clear one or more pending EMU interrupts.
AnnaBridge 156:ff21514d8981 767 *
AnnaBridge 156:ff21514d8981 768 * @param[in] flags
AnnaBridge 156:ff21514d8981 769 * Pending EMU interrupt sources to clear. Use one or more valid
AnnaBridge 156:ff21514d8981 770 * interrupt flags for the EMU module (EMU_IFC_nnn).
AnnaBridge 156:ff21514d8981 771 ******************************************************************************/
AnnaBridge 156:ff21514d8981 772 __STATIC_INLINE void EMU_IntClear(uint32_t flags)
AnnaBridge 156:ff21514d8981 773 {
AnnaBridge 156:ff21514d8981 774 EMU->IFC = flags;
AnnaBridge 156:ff21514d8981 775 }
AnnaBridge 156:ff21514d8981 776
AnnaBridge 156:ff21514d8981 777
AnnaBridge 156:ff21514d8981 778 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 779 * @brief
AnnaBridge 156:ff21514d8981 780 * Disable one or more EMU interrupts.
AnnaBridge 156:ff21514d8981 781 *
AnnaBridge 156:ff21514d8981 782 * @param[in] flags
AnnaBridge 156:ff21514d8981 783 * EMU interrupt sources to disable. Use one or more valid
AnnaBridge 156:ff21514d8981 784 * interrupt flags for the EMU module (EMU_IEN_nnn).
AnnaBridge 156:ff21514d8981 785 ******************************************************************************/
AnnaBridge 156:ff21514d8981 786 __STATIC_INLINE void EMU_IntDisable(uint32_t flags)
AnnaBridge 156:ff21514d8981 787 {
AnnaBridge 156:ff21514d8981 788 EMU->IEN &= ~flags;
AnnaBridge 156:ff21514d8981 789 }
AnnaBridge 156:ff21514d8981 790
AnnaBridge 156:ff21514d8981 791
AnnaBridge 156:ff21514d8981 792 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 793 * @brief
AnnaBridge 156:ff21514d8981 794 * Enable one or more EMU interrupts.
AnnaBridge 156:ff21514d8981 795 *
AnnaBridge 156:ff21514d8981 796 * @note
AnnaBridge 156:ff21514d8981 797 * Depending on the use, a pending interrupt may already be set prior to
AnnaBridge 156:ff21514d8981 798 * enabling the interrupt. Consider using EMU_IntClear() prior to enabling
AnnaBridge 156:ff21514d8981 799 * if such a pending interrupt should be ignored.
AnnaBridge 156:ff21514d8981 800 *
AnnaBridge 156:ff21514d8981 801 * @param[in] flags
AnnaBridge 156:ff21514d8981 802 * EMU interrupt sources to enable. Use one or more valid
AnnaBridge 156:ff21514d8981 803 * interrupt flags for the EMU module (EMU_IEN_nnn).
AnnaBridge 156:ff21514d8981 804 ******************************************************************************/
AnnaBridge 156:ff21514d8981 805 __STATIC_INLINE void EMU_IntEnable(uint32_t flags)
AnnaBridge 156:ff21514d8981 806 {
AnnaBridge 156:ff21514d8981 807 EMU->IEN |= flags;
AnnaBridge 156:ff21514d8981 808 }
AnnaBridge 156:ff21514d8981 809
AnnaBridge 156:ff21514d8981 810
AnnaBridge 156:ff21514d8981 811 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 812 * @brief
AnnaBridge 156:ff21514d8981 813 * Get pending EMU interrupt flags.
AnnaBridge 156:ff21514d8981 814 *
AnnaBridge 156:ff21514d8981 815 * @note
AnnaBridge 156:ff21514d8981 816 * The event bits are not cleared by the use of this function.
AnnaBridge 156:ff21514d8981 817 *
AnnaBridge 156:ff21514d8981 818 * @return
AnnaBridge 156:ff21514d8981 819 * EMU interrupt sources pending. Returns one or more valid
AnnaBridge 156:ff21514d8981 820 * interrupt flags for the EMU module (EMU_IF_nnn).
AnnaBridge 156:ff21514d8981 821 ******************************************************************************/
AnnaBridge 156:ff21514d8981 822 __STATIC_INLINE uint32_t EMU_IntGet(void)
AnnaBridge 156:ff21514d8981 823 {
AnnaBridge 156:ff21514d8981 824 return EMU->IF;
AnnaBridge 156:ff21514d8981 825 }
AnnaBridge 156:ff21514d8981 826
AnnaBridge 156:ff21514d8981 827
AnnaBridge 156:ff21514d8981 828 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 829 * @brief
AnnaBridge 156:ff21514d8981 830 * Get enabled and pending EMU interrupt flags.
AnnaBridge 156:ff21514d8981 831 * Useful for handling more interrupt sources in the same interrupt handler.
AnnaBridge 156:ff21514d8981 832 *
AnnaBridge 156:ff21514d8981 833 * @note
AnnaBridge 156:ff21514d8981 834 * Interrupt flags are not cleared by the use of this function.
AnnaBridge 156:ff21514d8981 835 *
AnnaBridge 156:ff21514d8981 836 * @return
AnnaBridge 156:ff21514d8981 837 * Pending and enabled EMU interrupt sources
AnnaBridge 156:ff21514d8981 838 * The return value is the bitwise AND of
AnnaBridge 156:ff21514d8981 839 * - the enabled interrupt sources in EMU_IEN and
AnnaBridge 156:ff21514d8981 840 * - the pending interrupt flags EMU_IF
AnnaBridge 156:ff21514d8981 841 ******************************************************************************/
AnnaBridge 156:ff21514d8981 842 __STATIC_INLINE uint32_t EMU_IntGetEnabled(void)
AnnaBridge 156:ff21514d8981 843 {
AnnaBridge 156:ff21514d8981 844 uint32_t ien;
AnnaBridge 156:ff21514d8981 845
AnnaBridge 156:ff21514d8981 846 ien = EMU->IEN;
AnnaBridge 156:ff21514d8981 847 return EMU->IF & ien;
AnnaBridge 156:ff21514d8981 848 }
AnnaBridge 156:ff21514d8981 849
AnnaBridge 156:ff21514d8981 850
AnnaBridge 156:ff21514d8981 851 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 852 * @brief
AnnaBridge 156:ff21514d8981 853 * Set one or more pending EMU interrupts
AnnaBridge 156:ff21514d8981 854 *
AnnaBridge 156:ff21514d8981 855 * @param[in] flags
AnnaBridge 156:ff21514d8981 856 * EMU interrupt sources to set to pending. Use one or more valid
AnnaBridge 156:ff21514d8981 857 * interrupt flags for the EMU module (EMU_IFS_nnn).
AnnaBridge 156:ff21514d8981 858 ******************************************************************************/
AnnaBridge 156:ff21514d8981 859 __STATIC_INLINE void EMU_IntSet(uint32_t flags)
AnnaBridge 156:ff21514d8981 860 {
AnnaBridge 156:ff21514d8981 861 EMU->IFS = flags;
AnnaBridge 156:ff21514d8981 862 }
AnnaBridge 156:ff21514d8981 863 #endif /* _EMU_IF_MASK */
AnnaBridge 156:ff21514d8981 864
AnnaBridge 156:ff21514d8981 865
AnnaBridge 156:ff21514d8981 866 #if defined( _EMU_EM4CONF_LOCKCONF_MASK )
AnnaBridge 156:ff21514d8981 867 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 868 * @brief
AnnaBridge 156:ff21514d8981 869 * Enable or disable EM4 lock configuration
AnnaBridge 156:ff21514d8981 870 * @param[in] enable
AnnaBridge 156:ff21514d8981 871 * If true, locks down EM4 configuration
AnnaBridge 156:ff21514d8981 872 ******************************************************************************/
AnnaBridge 156:ff21514d8981 873 __STATIC_INLINE void EMU_EM4Lock(bool enable)
AnnaBridge 156:ff21514d8981 874 {
AnnaBridge 156:ff21514d8981 875 BUS_RegBitWrite(&(EMU->EM4CONF), _EMU_EM4CONF_LOCKCONF_SHIFT, enable);
AnnaBridge 156:ff21514d8981 876 }
AnnaBridge 156:ff21514d8981 877 #endif
AnnaBridge 156:ff21514d8981 878
AnnaBridge 156:ff21514d8981 879 #if defined( _EMU_STATUS_BURDY_MASK )
AnnaBridge 156:ff21514d8981 880 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 881 * @brief
AnnaBridge 156:ff21514d8981 882 * Halts until backup power functionality is ready
AnnaBridge 156:ff21514d8981 883 ******************************************************************************/
AnnaBridge 156:ff21514d8981 884 __STATIC_INLINE void EMU_BUReady(void)
AnnaBridge 156:ff21514d8981 885 {
AnnaBridge 156:ff21514d8981 886 while(!(EMU->STATUS & EMU_STATUS_BURDY))
AnnaBridge 156:ff21514d8981 887 ;
AnnaBridge 156:ff21514d8981 888 }
AnnaBridge 156:ff21514d8981 889 #endif
AnnaBridge 156:ff21514d8981 890
AnnaBridge 156:ff21514d8981 891 #if defined( _EMU_ROUTE_BUVINPEN_MASK )
AnnaBridge 156:ff21514d8981 892 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 893 * @brief
AnnaBridge 156:ff21514d8981 894 * Disable BU_VIN support
AnnaBridge 156:ff21514d8981 895 * @param[in] enable
AnnaBridge 156:ff21514d8981 896 * If true, enables BU_VIN input pin support, if false disables it
AnnaBridge 156:ff21514d8981 897 ******************************************************************************/
AnnaBridge 156:ff21514d8981 898 __STATIC_INLINE void EMU_BUPinEnable(bool enable)
AnnaBridge 156:ff21514d8981 899 {
AnnaBridge 156:ff21514d8981 900 BUS_RegBitWrite(&(EMU->ROUTE), _EMU_ROUTE_BUVINPEN_SHIFT, enable);
AnnaBridge 156:ff21514d8981 901 }
AnnaBridge 156:ff21514d8981 902 #endif
AnnaBridge 156:ff21514d8981 903
AnnaBridge 156:ff21514d8981 904 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 905 * @brief
AnnaBridge 156:ff21514d8981 906 * Lock the EMU in order to protect its registers against unintended
AnnaBridge 156:ff21514d8981 907 * modification.
AnnaBridge 156:ff21514d8981 908 *
AnnaBridge 156:ff21514d8981 909 * @note
AnnaBridge 156:ff21514d8981 910 * If locking the EMU registers, they must be unlocked prior to using any
AnnaBridge 156:ff21514d8981 911 * EMU API functions modifying EMU registers, excluding interrupt control
AnnaBridge 156:ff21514d8981 912 * and regulator control if the architecture has a EMU_PWRCTRL register.
AnnaBridge 156:ff21514d8981 913 * An exception to this is the energy mode entering API (EMU_EnterEMn()),
AnnaBridge 156:ff21514d8981 914 * which can be used when the EMU registers are locked.
AnnaBridge 156:ff21514d8981 915 ******************************************************************************/
AnnaBridge 156:ff21514d8981 916 __STATIC_INLINE void EMU_Lock(void)
AnnaBridge 156:ff21514d8981 917 {
AnnaBridge 156:ff21514d8981 918 EMU->LOCK = EMU_LOCK_LOCKKEY_LOCK;
AnnaBridge 156:ff21514d8981 919 }
AnnaBridge 156:ff21514d8981 920
AnnaBridge 156:ff21514d8981 921
AnnaBridge 156:ff21514d8981 922 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 923 * @brief
AnnaBridge 156:ff21514d8981 924 * Unlock the EMU so that writing to locked registers again is possible.
AnnaBridge 156:ff21514d8981 925 ******************************************************************************/
AnnaBridge 156:ff21514d8981 926 __STATIC_INLINE void EMU_Unlock(void)
AnnaBridge 156:ff21514d8981 927 {
AnnaBridge 156:ff21514d8981 928 EMU->LOCK = EMU_LOCK_LOCKKEY_UNLOCK;
AnnaBridge 156:ff21514d8981 929 }
AnnaBridge 156:ff21514d8981 930
AnnaBridge 156:ff21514d8981 931
AnnaBridge 156:ff21514d8981 932 #if defined( _EMU_PWRLOCK_MASK )
AnnaBridge 156:ff21514d8981 933 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 934 * @brief
AnnaBridge 156:ff21514d8981 935 * Lock the EMU regulator control registers in order to protect against
AnnaBridge 156:ff21514d8981 936 * unintended modification.
AnnaBridge 156:ff21514d8981 937 ******************************************************************************/
AnnaBridge 156:ff21514d8981 938 __STATIC_INLINE void EMU_PowerLock(void)
AnnaBridge 156:ff21514d8981 939 {
AnnaBridge 156:ff21514d8981 940 EMU->PWRLOCK = EMU_PWRLOCK_LOCKKEY_LOCK;
AnnaBridge 156:ff21514d8981 941 }
AnnaBridge 156:ff21514d8981 942
AnnaBridge 156:ff21514d8981 943
AnnaBridge 156:ff21514d8981 944 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 945 * @brief
AnnaBridge 156:ff21514d8981 946 * Unlock the EMU power control registers so that writing to
AnnaBridge 156:ff21514d8981 947 * locked registers again is possible.
AnnaBridge 156:ff21514d8981 948 ******************************************************************************/
AnnaBridge 156:ff21514d8981 949 __STATIC_INLINE void EMU_PowerUnlock(void)
AnnaBridge 156:ff21514d8981 950 {
AnnaBridge 156:ff21514d8981 951 EMU->PWRLOCK = EMU_PWRLOCK_LOCKKEY_UNLOCK;
AnnaBridge 156:ff21514d8981 952 }
AnnaBridge 156:ff21514d8981 953 #endif
AnnaBridge 156:ff21514d8981 954
AnnaBridge 156:ff21514d8981 955
AnnaBridge 156:ff21514d8981 956 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 957 * @brief
AnnaBridge 156:ff21514d8981 958 * Block entering EM2 or higher number energy modes.
AnnaBridge 156:ff21514d8981 959 ******************************************************************************/
AnnaBridge 156:ff21514d8981 960 __STATIC_INLINE void EMU_EM2Block(void)
AnnaBridge 156:ff21514d8981 961 {
AnnaBridge 156:ff21514d8981 962 BUS_RegBitWrite(&(EMU->CTRL), _EMU_CTRL_EM2BLOCK_SHIFT, 1U);
AnnaBridge 156:ff21514d8981 963 }
AnnaBridge 156:ff21514d8981 964
AnnaBridge 156:ff21514d8981 965 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 966 * @brief
AnnaBridge 156:ff21514d8981 967 * Unblock entering EM2 or higher number energy modes.
AnnaBridge 156:ff21514d8981 968 ******************************************************************************/
AnnaBridge 156:ff21514d8981 969 __STATIC_INLINE void EMU_EM2UnBlock(void)
AnnaBridge 156:ff21514d8981 970 {
AnnaBridge 156:ff21514d8981 971 BUS_RegBitWrite(&(EMU->CTRL), _EMU_CTRL_EM2BLOCK_SHIFT, 0U);
AnnaBridge 156:ff21514d8981 972 }
AnnaBridge 156:ff21514d8981 973
AnnaBridge 156:ff21514d8981 974 #if defined( _EMU_EM4CTRL_EM4IORETMODE_MASK )
AnnaBridge 156:ff21514d8981 975 /***************************************************************************//**
AnnaBridge 156:ff21514d8981 976 * @brief
AnnaBridge 156:ff21514d8981 977 * When EM4 pin retention is set to emuPinRetentionLatch, then pins are retained
AnnaBridge 156:ff21514d8981 978 * through EM4 entry and wakeup. The pin state is released by calling this function.
AnnaBridge 156:ff21514d8981 979 * The feature allows peripherals or GPIO to be re-initialized after EM4 exit (reset),
AnnaBridge 156:ff21514d8981 980 * and when the initialization is done, this function can release pins and return control
AnnaBridge 156:ff21514d8981 981 * to the peripherals or GPIO.
AnnaBridge 156:ff21514d8981 982 ******************************************************************************/
AnnaBridge 156:ff21514d8981 983 __STATIC_INLINE void EMU_UnlatchPinRetention(void)
AnnaBridge 156:ff21514d8981 984 {
AnnaBridge 156:ff21514d8981 985 EMU->CMD = EMU_CMD_EM4UNLATCH;
AnnaBridge 156:ff21514d8981 986 }
AnnaBridge 156:ff21514d8981 987 #endif
AnnaBridge 156:ff21514d8981 988
AnnaBridge 156:ff21514d8981 989 #if defined( _SILICON_LABS_GECKO_INTERNAL_SDID_80 )
AnnaBridge 156:ff21514d8981 990 void EMU_SetBiasMode(EMU_BiasMode_TypeDef mode);
AnnaBridge 156:ff21514d8981 991 #endif
AnnaBridge 156:ff21514d8981 992
AnnaBridge 156:ff21514d8981 993 /** @} (end addtogroup EMU) */
AnnaBridge 156:ff21514d8981 994 /** @} (end addtogroup emlib) */
AnnaBridge 156:ff21514d8981 995
AnnaBridge 156:ff21514d8981 996 #ifdef __cplusplus
AnnaBridge 156:ff21514d8981 997 }
AnnaBridge 156:ff21514d8981 998 #endif
AnnaBridge 156:ff21514d8981 999
AnnaBridge 156:ff21514d8981 1000 #endif /* defined( EMU_PRESENT ) */
AnnaBridge 156:ff21514d8981 1001 #endif /* EM_EMU_H */