5.3.1 Embedded Power Controller
The EPC is composed of the following three main modules:
- An event arbitration module that is used to prioritize ON, OFF, WAKE, and SLEEP requests.
- A power state-machine that is used to determine which power sequence to execute based on the system state (supplies, temperature, and so forth) and requested transition (from the event arbitration module).
- A power sequencer that fetches the selected power sequence from OTP and executes the sequence. The power sequencer sets up and controls all resources accordingly, based on the definition of each sequence.
Figure 5-1 shows the EPC block diagram.
The power state-machine is defined through the following states:
NO SUPPLYThe device is not powered by a valid energy source on the system power rail (VCCA < POR).
BACKUPThe device is powered by a valid supply on the system power rail which is above power-on reset (POR) threshold but below the system low threshold (POR < VCCA < VSYS_LO).
OFFThe device is powered by a valid supply on the system power rail (VCCA > VSYS_LO) and is waiting for a start-up event or condition. All device resources, except VRTC, are in the OFF state.
ACTIVEThe device is powered by a valid supply on the system power rail (VCC_SENSE > VSYS_HI) and has received a start-up event. The device has switched to the ACTIVE state and has full capacity to supply the processor and other platform modules.
SLEEPThe device is powered by a valid supply on the system power rail (VCCA > VSYS_LO) and is in low-power mode. All configured resources are set to the low-power mode, which can be ON, SLEEP, or OFF depending on the specific resource setting. If a given resource is maintained active (ON) during low-power mode, then all linked subsystems are automatically maintained active.
Figure 5-2 shows the state diagram for the power control state-machine.
Power sequences define how a resource state switches between the OFF, ACTIVE, and SLEEP states, but these sequences have no effect during the NO SUPPLY or BACKUP states. When the device is brought into the OFF state from a NO SUPPLY or BACKUP state, internal hardware manages the state transition automatically before the EPC takes control of the device power sequencing as the device arrives the OFF state.
The allowed power transitions include the following:
- OFF to ACTIVE (OFF2ACT)
- ACTIVE to OFF (ACT2OFF)
- ACTIVE to SLEEP (ACT2SLP)
- SLEEP to ACTIVE (SLP2ACT)
- SLEEP to OFF (SLP2OFF)
Each power transition consists of a sequence of one or several register accesses that controls the resources according to the EPC supervision. Because these sequences are stored in nonvolatile memory (OTP), these sequences cannot be altered.
An error detection routine of the OTP bit integrity is available with this device. If enabled, this routine is executed to compare the current OTP values with the preprogrammed values at the beginning of every OFF2ACT power sequence. When an OTP bit integrity error is detected, the OTP register, CRC_CONTROL, can be preprogramed to select the following options:
- Skip Error Detection and execute all power sequence
- Execute Error Detection and execute all power-up sequence, even if an error is detected
- Execute Error Detection. If an error is detected, execute power-up sequence until the VIO supply rail is up
- Execute Error Detection. If an error is detected, stop power-up sequence altogether
When an error is detected, an interrupt (INT2.OTP_ERROR) is sent to the host processor regardless of the CRC_CONTROL setting.