COP0 0100 00 |
MFMC0 01 011 |
rt |
12 0110 0 |
0 000 00 |
sc 1 |
0 0 0 |
0 000 |
6 |
5 |
5 |
5 |
5 |
1 |
2 |
3 |
EI rt |
MIPS32 Release 2 |
Enable Interrupts |
Enable Interrupts
To return the previous value of the Status register and enable interrupts. If EI is specified without an argument, GPR r0 is implied, which discards the previous value of the Status register.
GPR[rt] = Status; StatusIE = 1
The current value of the Status register is sign-extended and loaded into general register rt. The Interrupt Enable (IE) bit in the Status register is then set.
If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.
In implementations prior to Release 2 of the architecture, this instruction resulted in a Reserved Instruction exception.
This operation specification is for the general interrupt enable/disable operation, with the sc field as a variable. The individual instructions DI and EI have a specific value for the sc field.
data = Status GPR[rt] = sign_extend(data) StatusIE = 1
Coprocessor Unusable
Reserved Instruction (Release 1 implementations)
The effects of this instruction are identical to those accomplished by the sequence of reading Status into a GPR, setting the IE bit, and writing the result back to Status. Unlike the multiple instruction sequence, however, the EI instruction cannot be aborted in the middle by an interrupt or exception.
This instruction creates an execution hazard between the change to the Status register and the point where the change to the interrupt enable takes effect. This hazard is cleared by the EHB, JALR.HB, JR.HB, or ERET instructions. Software must not assume that a fixed latency will clear the execution hazard.