SMU - Security Management Unit
Description
Security Management Unit (SMU) Peripheral API.
SMU forms the control and status/reporting component of bus-level security in EFM32/EFR32 devices.
Peripheral-level protection is provided via the peripheral protection unit (PPU). PPU provides hardware access barrier to any peripheral that is configured to be protected. When an attempt is made to access a peripheral without the required privilege/security level, PPU detects the fault and intercepts the access. No write or read of the peripheral register space occurs, and an all-zero value is returned if the access is a read.
Usage example
| Data Structures | |
| struct | SMU_PrivilegedAccess_TypeDef | 
| SMU peripheral privileged access enablers. | |
| struct | SMU_Init_TypeDef | 
| SMU initialization structure. | |
| Functions | |
| void | SMU_EnablePPU (bool enable) | 
| Enable or disable PPU of SMU. | |
| void | SMU_Init (const SMU_Init_TypeDef *init) | 
| Initialize PPU of SMU. | |
| void | SMU_SetPrivilegedAccess ( SMU_Peripheral_TypeDef peripheral, bool privileged) | 
| Change access settings for a peripheral. | |
| SMU_Peripheral_TypeDef | SMU_GetFaultingPeripheral (void) | 
| Get ID of the peripheral that caused an access fault. | |
| void | SMU_IntClear (uint32_t flags) | 
| Clear one or more pending SMU interrupts. | |
| void | SMU_IntDisable (uint32_t flags) | 
| Disable one or more SMU interrupts. | |
| void | SMU_IntEnable (uint32_t flags) | 
| Enable one or more SMU interrupts. | |
| uint32_t | SMU_IntGet (void) | 
| Get pending SMU interrupts. | |
| uint32_t | SMU_IntGetEnabled (void) | 
| Get enabled and pending SMU interrupt flags. | |
| void | SMU_IntSet (uint32_t flags) | 
| Set one or more pending SMU interrupts from SW. | |
| Macros | |
| #define | SMU_INIT_DEFAULT | 
| Default SMU initialization structure settings. | |
| Enumerations | |
| enum | SMU_Peripheral_TypeDef
         
         { smuPeripheralEMU = _SMU_PPUPATD0_EMU_SHIFT, smuPeripheralCMU = _SMU_PPUPATD0_CMU_SHIFT, smuPeripheralHFXO = _SMU_PPUPATD0_HFXO0_SHIFT, smuPeripheralHFRCO0 = _SMU_PPUPATD0_HFRCO0_SHIFT, smuPeripheralFSRCO = _SMU_PPUPATD0_FSRCO_SHIFT, smuPeripheralDPLL0 = _SMU_PPUPATD0_DPLL0_SHIFT, smuPeripheralLFXO = _SMU_PPUPATD0_LFXO_SHIFT, smuPeripheralLFRCO = _SMU_PPUPATD0_LFRCO_SHIFT, smuPeripheralULFRCO = _SMU_PPUPATD0_ULFRCO_SHIFT, smuPeripheralMSC = _SMU_PPUPATD0_MSC_SHIFT, smuPeripheralICACHE0 = _SMU_PPUPATD0_ICACHE0_SHIFT, smuPeripheralPRS = _SMU_PPUPATD0_PRS_SHIFT, smuPeripheralGPIO = _SMU_PPUPATD0_GPIO_SHIFT, smuPeripheralLDMA = _SMU_PPUPATD0_LDMA_SHIFT, smuPeripheralLDMAXBAR = _SMU_PPUPATD0_LDMAXBAR_SHIFT, smuPeripheralTIMER0 = _SMU_PPUPATD0_TIMER0_SHIFT, smuPeripheralTIMER1 = _SMU_PPUPATD0_TIMER1_SHIFT, smuPeripheralTIMER2 = _SMU_PPUPATD0_TIMER2_SHIFT, smuPeripheralTIMER3 = _SMU_PPUPATD0_TIMER3_SHIFT, smuPeripheralTIMER4 = _SMU_PPUPATD0_TIMER4_SHIFT, smuPeripheralUSART0 = _SMU_PPUPATD0_USART0_SHIFT, smuPeripheralUSART1 = _SMU_PPUPATD0_USART1_SHIFT, smuPeripheralBURTC = _SMU_PPUPATD0_BURTC_SHIFT, smuPeripheralI2C1 = _SMU_PPUPATD0_I2C1_SHIFT, smuPeripheralCHIPTESTCTRL = _SMU_PPUPATD0_CHIPTESTCTRL_SHIFT, smuPeripheralSYSCFGCFGNS = _SMU_PPUPATD0_SYSCFGCFGNS_SHIFT, smuPeripheralSYSCFG = _SMU_PPUPATD0_SYSCFG_SHIFT, smuPeripheralBURAM = _SMU_PPUPATD0_BURAM_SHIFT, smuPeripheralGPCRC = _SMU_PPUPATD0_GPCRC_SHIFT, smuPeripheralRTCC = 32 + _SMU_PPUPATD1_RTCC_SHIFT, smuPeripheralDCDC = 32 + _SMU_PPUPATD1_DCDC_SHIFT, smuPeripheralPDM = 32 + _SMU_PPUPATD1_PDM_SHIFT, smuPeripheralLETIMER0 = 32 + _SMU_PPUPATD1_LETIMER0_SHIFT, smuPeripheralIADC0 = 32 + _SMU_PPUPATD1_IADC0_SHIFT, smuPeripheralI2C0 = 32 + _SMU_PPUPATD1_I2C0_SHIFT, smuPeripheralWDOG0 = 32 + _SMU_PPUPATD1_WDOG0_SHIFT, smuPeripheralAMUXCP0 = 32 + _SMU_PPUPATD1_AMUXCP0_SHIFT, smuPeripheralEUART0 = 32 + _SMU_PPUPATD1_EUART0_SHIFT, smuPeripheralSMU = 32 + _SMU_PPUPATD1_SMU_SHIFT, smuPeripheralSMUCFGNS = 32 + _SMU_PPUPATD1_SMUCFGNS_SHIFT, smuPeripheralCRYPTOACC = 32 + _SMU_PPUPATD1_CRYPTOACC_SHIFT, smuPeripheralEnd } | 
| SMU peripheral identifiers. | |
Function Documentation
◆ SMU_EnablePPU()
| 
 | inline | 
Enable or disable PPU of SMU.
- Parameters
- 
         [in] enableSet to true to enable PPU; set to false otherwise. 
◆ SMU_Init()
| 
 | inline | 
Initialize PPU of SMU.
- Parameters
- 
         [in] initPointer to initialization structure that defines which peripherals should only be accessed from privileged mode, and if PPU should be enabled. 
◆ SMU_SetPrivilegedAccess()
| 
 | inline | 
Change access settings for a peripheral.
Set to limit access of a peripheral from privileged mode.
- Parameters
- 
         [in] peripheralID of the peripheral to change access settings for. [in] privilegedSet to true if the peripheral should only be accessed from privileged mode; set to false otherwise. 
◆ SMU_GetFaultingPeripheral()
| 
 | inline | 
Get ID of the peripheral that caused an access fault.
- Note
- The return value is only valid if SMU_IF_PPUPRIV interrupt flag is set.
- Returns
- ID of the peripheral that caused an access fault.
◆ SMU_IntClear()
| 
 | inline | 
Clear one or more pending SMU interrupts.
- Parameters
- 
         [in] flagsBitwise logic OR of SMU interrupt sources to clear. 
◆ SMU_IntDisable()
| 
 | inline | 
Disable one or more SMU interrupts.
- Parameters
- 
         [in] flagsSMU interrupt sources to disable. 
◆ SMU_IntEnable()
| 
 | inline | 
Enable one or more SMU interrupts.
- Note
- Depending on the use, a pending interrupt may already be set prior to enabling the interrupt. To ignore a pending interrupt, consider using SMU_IntClear() prior to enabling the interrupt.
- Parameters
- 
         [in] flagsSMU interrupt sources to enable. 
◆ SMU_IntGet()
| 
 | inline | 
Get pending SMU interrupts.
- Returns
- SMU interrupt sources pending.
◆ SMU_IntGetEnabled()
| 
 | inline | 
Get enabled and pending SMU interrupt flags.
Useful for handling more interrupt sources in the same interrupt handler.
- Note
- Interrupt flags are not cleared by this function.
- Returns
- 
         Pending and enabled SMU interrupt sources. The return value is the bitwise AND combination of
         - the OR combination of enabled interrupt sources in SMU_IEN register and
- the OR combination of valid interrupt flags in SMU_IF register.
 
◆ SMU_IntSet()
| 
 | inline | 
Set one or more pending SMU interrupts from SW.
- Parameters
- 
         [in] flagsSMU interrupt sources to set to pending. 
Macro Definition Documentation
◆ SMU_INIT_DEFAULT
| #define SMU_INIT_DEFAULT | 
Default SMU initialization structure settings.
Enumeration Type Documentation
◆ SMU_Peripheral_TypeDef
SMU peripheral identifiers.