COP0 010000 |
MTH 00110 |
rt |
rd |
0 0000 0000 |
sel |
6 |
5 |
5 |
5 |
8 |
3 |
MTHC0 rt, rd, sel |
MIPS32 Release 5 |
Move to High Coprocessor 0 |
Move to High Coprocessor 0
To copy a word from a GPR to the upper 32 bits of a CP0 general register that has been extended by 32 bits.
CPR[0, rd, sel][63:32] = GPR[rt]
The contents of general register rt are loaded into the Coprocessor 0 register specified by the combination of rd and
sel. Not all Coprocessor 0 registers support the sel field; the sel field must be set to zero.
When the Coprocessor 0 destination register specified is the EntryLo0 or EntryLo1 register, bits 1:0 of the GPR appear at bits 31:30 of EntryLo0 or EntryLo1. This is to compensate for RI and XI, which were shifted to bits 63:62 by MTC0 to EntryLo0 or EntryLo1. If RI/XI are not supported, the shift must still occur, but an MFHC0 instruction returns 0s for these two fields. The GPR is right-shifted by two to vacate the lower two bits, and two 0s are shifted in from the left.
The result is written to the upper 32 bits of MIPS64 EntryLo0 or EntryLo1, excluding RI/XI, which were placed in bits
63:62, that is, the write must appear atomic, as if both MTC0 and MTHC0 occurred together.
This feature supports MIPS32 backward compatibility of MIPS64 systems.
Pre-Release 6: The results are UNDEFINED if Coprocessor 0 does not contain a register as specified by rd and sel, or if the register exists but is not extended by 32 bits, or the register is extended for XPA, but XPA is not supported or enabled.
Release 6: A write to the high part of a register that is reserved, not implemented for the current core, or that is not extended beyond 32 bits is ignored.
In a 64-bit processor, the MTHC0 instruction writes only the lower 32 bits of register rt into the upper 32 bits of the
Coprocessor register specified by rd and sel if the register is extended as defined by IsCoprocessorRegisterExtended(). The registers extended by Release 5 are those required for the XPA feature. Release 6 extends WatchHi to support MemoryMapID. These registers are identical to the same registers in the MIPS64 Architecture, other than
EntryLo0 and EntryLo1.
if Config5MVH = 0 then SignalException(ReservedInstruction) endif data = GPR[rt] reg = rd if IsCoprocessorRegisterImplemented (0, reg, sel) and IsCoprocessorRegisterExtended (0, reg, sel) then if (reg,sel = EntryLo1 or reg,sel = EntryLo0) then if (Config3LPA = 1 and PageGrainELPA = 1) then // PABITS > 36 CPR[0,reg,sel]31..30 = data1..0 CPR[0,reg,sel]61:32 = data31..2 and ((1<<(PABITS-36))-1) CPR[0,reg,sel]63:62 = 02 else CPR[0, reg, sel][63:32] = data31..0 endif else if ArchitectureRevision() >= 6 then // nop (no exceptions, coprocessor state not modified) else UNDEFINED endif endif
Coprocessor Unusable, Reserved Instruction