COP1 010001 |
CF 00010 |
rt |
fs |
0 000 0000 0000 |
6 |
5 |
5 |
5 |
11 |
CFC1 rt, fs |
MIPS32 |
Move Control Word From Floating Point |
Move Control Word From Floating Point
To copy a word from an FPU control register to a GPR.
GPR[rt] = FP_Control[fs]
Copy the 32-bit word from FP (coprocessor 1) control register fs into GPR rt, sign-extending it to 64 bits.
The definition of this instruction has been extended in Release 5 to support user mode read and write of StatusFR under the control of Config5UFR. This optional feature is meant to facilitate transition from FR=0 to FR=1 floating-point register modes in order to obsolete FR=0 mode in a future architecture release. User code may set and clear StatusFR without kernel intervention, providing kernel explicitly provides permission.
This UFR facility is not supported in Release 6 because Release 6 only allows FR=1 mode. Accessing the UFR and
UNFR registers causes a Reserved Instruction exception in Release 6 because FIRUFRP is always 0.
The definition of this instruction has been extended in Release 6 to allow user code to read and modify the Config5FRE bit. Such modification is allowed when this bit is present (as indicated by FIRUFRP) and user mode
modification of the bit is enabled by the kernel (as indicated by Config5UFE). Setting Config5FRE to 1 causes all floating point instructions which are not compatible with FR=1 mode to take an Reserved Instruction exception. This makes it possible to run pre-Release 6 FR=0 floating point code on a Release 6 core which only supports FR=1 mode, provided the kernel has been set up to trap and emulate FR=0 behavior for these instructions. These instructions include floating-point arithmetic instructions that read/write single-precision registers, LWC1, SWC1, MTC1, and
MFC1 instructions.
The FRE facility uses COP1 register aliases FRE and NFRE to access Config5FRE.
There are a few control registers defined for the floating point unit. Prior to Release 6, the result is UNPREDICTABLE if fs specifies a register that does not exist. In Release 6 and later, a Reserved Instruction exception occurs if fs specifies a register that does not exist.
The result is UNPREDICTABLE if fs specifies the UNFR or NFRE write-only control. Release 6 and later implementations are required to produce a Reserved Instruction exception; software must assume it is UNPREDICTABLE.
if fs = 0 then temp = FIR elseif fs = 1 then /* read UFR (CP1 Register 1) */ if FIRUFRP then if not Config5UFR then SignalException(ReservedInstruction) endif temp = StatusFR else if ConfigAR ≥ 2 SignalException(ReservedInstruction) /* Release 6 traps */ endif temp = UNPREDICTABLE endif elseif fs = 4 then /* read fs=4 UNFR not supported for reading - UFR suffices */ if ConfigAR ≥ 2 SignalException(ReservedInstruction) /* Release 6 traps */ endif temp = UNPREDICTABLE elseif fs=5 then /* user read of FRE, if permitted */ if ConfigAR <= 2 then temp = UNPREDICTABLE else if not Config5UFR then SignalException(ReservedInstruction) endif temp = 031 || Config5FRE endif elseif fs = 25 then /* FCCR */ temp = 024 || FCSR31..25 || FCSR23 elseif fs = 26 then /* FEXR */ temp = 014 || FCSR17..12 || 05 || FCSR6..2 || 02 elseif fs = 28 then /* FENR */ temp = 020 || FCSR11.7 || 04 || FCSR24 || FCSR1..0 elseif fs = 31 then /* FCSR */ temp = FCSR else if Config2AR ≥ 2 SignalException(ReservedInstruction) /*Release 6 traps; includes NFRE*/ endif temp = UNPREDICTABLE endif if Config2AR < 2 then GPR[rt] = sign_extend(temp) endif
Coprocessor Unusable, Reserved Instruction
For the MIPS I, II and III architectures, the contents of GPR rt are UNPREDICTABLE for the instruction immediately following CFC1.
MIPS V and MIPS32 introduced the three control registers that access portions of FCSR. These registers were not available in MIPS I, II, III, or IV.
MIPS32 Release 5 introduced the UFR and UNFR register aliases that allow user level access to StatusFR. Release 6 removes them.