
CHAPTER 5 EXCEPTION PROCESSING
104
5.4.5 Soft Reset Exception
Cause
A Soft Reset (sometimes called Warm Reset) occurs when the ColdReset* signal remains deasserted
while the Reset* signal goes from assertion for at least 16 MasterClocks to deassertion (for details, see
Chapter 7).
A Soft Reset immediately resets all state machines, and sets the SR bit of the Status register.
Execution begins at the reset vector when the reset is deasserted. This exception is not maskable.
Processing
The CPU provides a special interrupt vector for this exception (same location as Cold Reset):
"
0xBFC0 0000 in 32-bit mode
"
0xFFFF FFFF BFC0 0000 in 64-bit mode
This vector is located within unmapped and uncached address space, so that the cache and TLB need
not be initialized to process this exception. The SR bit of the Status register is set to 1 to distinguish this
exception from a Cold Reset exception.
When this exception occurs, the contents of all registers are preserved except for the following
registers:
"
In the ErrorEPC register, the value of the Program Counter when an exception occurred is set.
"
TS bit of the Status register are cleared to 0.
"
ERL, SR, and BEV bits of the Status register are set to 1.
A Soft Reset can occur when the processor is placed in any state. So, access to the operating cache or
system interface may be aborted. This means that the contents of the cache and memory will be
unpredictable if a Soft Reset occurs.
Servicing
The Soft Reset exception is serviced by:
"
Preserving the current processor states for diagnostic tests
"
Reinitializing the system in the same way as for a Cold Reset exception