
CHAPTER 5 EXCEPTION PROCESSING
113
5.4.13 Coprocessor Unusable Exception
Cause
The Coprocessor Unusable exception occurs when an attempt is made to execute a coprocessor
instruction for either:
"
a corresponding coprocessor unit that has not been marked usable (Status register bit, CU0 = 0),
or
"
CP0 instructions, when the unit has not been marked usable (Status register bit, CU[0] = 0) and the
process executes in User or Supervisor mode.
This exception is not maskable.
Processing
The common exception vector is used for this exception, and the CPU code in the ExcCode field of the
Cause register is set. The CE bit of the Cause register indicates which of the four coprocessors was
referenced.
The EPC register contains the address of the unusable coprocessor instruction unless it is in a branch
delay slot, in which case the EPC register contains the address of the preceding branch instruction and
the BD bit of the Cause register is set to 1.
Servicing
The coprocessor unit to which an attempted reference was made is identified by the CE bit of the Cause
register. One of the following processing is performed by the handler:
"
If the process is entitled access to the coprocessor, the coprocessor is marked usable and the
corresponding state is restored to the coprocessor.
"
If the process is entitled access to the coprocessor, but the coprocessor does not exist or has
failed, interpretation of the coprocessor instruction is possible.
"
If the BD bit is set to 1 in the Cause register, the branch instruction must be interpreted; then the
coprocessor instruction can be emulated and execution resumed with the EPC register advanced
past the coprocessor instruction.
"
If the process is not entitled access to the coprocessor, the kernel reports UNIX
SIGILL/ILL_PRIVIN_FAULT (illegal instruction/privileged instruction fault) signal to the current
process, but the exception is fatal.