Encoding:

POOL32S

010110

rt

rs

00

sel

DMFC0

10011

POOL32Sxf

111100

6

5

5

2

3

5

6

Format:

DMFGC0 rt, rs, sel

microMIPS64

Doubleword Move from Guest Coprocessor 0

Purpose:

Doubleword Move from Guest Coprocessor 0

To move the contents of a guest coprocessor 0 register to a general purpose register (GPR).

Description:

 GPR[rt] = CPR[0,rs,sel]

The contents of the guest context coprocessor 0 register are loaded into GPR rt. Note that not all guest context coprocessor 0 registers support the sel field. In those instances, the sel field must be zero.

Restrictions:

The results are UNDEFINED if the guest context coprocessor 0 does not contain a register as specified by rs and sel, or if the guest context coprocessor 0 register specified by rd and sel is a 32-bit register.

The guest context does not implement the Virtualization Module. Use of this instruction in guest-kernel mode will result in a Reserved Instruction exception, taken in guest mode.

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled. If access to Coprocessor 0 is enabled but access to 64-bit operations is not enabled, a Reserved Instruction Exception is signaled.

Operation:

if IsCoprocessorEnabled(0) then
   if (Config3VZ = 0) then
      SignalException(ReservedInstruction, 0)
      break
   endif
   if(not Are64bitOperationsEnabled()) then
      SignalException(ReservedInstruction)
   endif
   datadoubleword = Guest.CPR[0,rs,sel]
   GPR[rt] = datadoubleword
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32S

010110

rt

rs

0

00

sel

DMTC0

11011

POOL32Sxf

111100

6

5

5

2

3

5

6

Format:

DMTGC0 rt, rs, sel

microMIPS64

Doubleword Move to Guest Coprocessor 0

Purpose:

Doubleword Move to Guest Coprocessor 0

To move a doubleword from a GPR to a guest context coprocessor 0 register.

Description:

 CPR[0,rs,sel] = GPR[rt]

The contents of GPR rt are loaded into the guest context coprocessor 0 register specified in the rd and sel fields. Note that not all guest context coprocessor 0 registers support the sel field. In those instances, the sel field must be zero.

Restrictions:

The results are UNDEFINED if guest context coprocessor 0 does not contain a register as specified by rs and sel, or if the guest context coprocessor 0 register specified by rd and sel is a 32-bit register or the destination register is the

Guest.Count register.

The guest context does notimplementthe Virtualization Module. Use of this instruction in guest-kernel mode will result in a Reserved Instruction exception, taken in guest mode.

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled. If access to Coprocessor 0 is enabled but access to 64-bit operations is not enabled, a Reserved Instruction Exception is signaled.

Operation:

if IsCoprocessorEnabled(0) then
   if (Config3VZ = 0) then
      SignalException(ReservedInstruction, 0)
      break
   endif
   if(not Are64bitOperationsEnabled()) then
      SignalException(ReservedInstruction)
   endif
   datadoubleword = GPR[rt]
   CPR[0,rs,sel] = datadoubleword
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

rt

rs

00

sel

MFGC0

10011

POOL32AXf

111100

6

5

5

2

3

5

6

Format:

MFGC0 rt, rs, sel

microMIPS

Move from Guest Coprocessor 0

Purpose:

Move from Guest Coprocessor 0

To move the contents of a guest coprocessor 0 register to a general register.

Description:

 GPR[rt] = Guest.CPR[0, rs, sel]

The contents of the guest context coprocessor 0 register speciied by the combination of rs and sel are sign-extended and loaded into general register rt. Note that not all guest context coprocessor 0 registers support the sel ield. In those instances, the sel ield must be zero.

When the guest context coprocessor 0 register speciied is the EntryLo0 or the EntryLo1 register, the RI/XI ields appear at bits 31:30 of the destination register. This feature supports 32-bit addressing mode compatibility on a

MIPS64 system.

Restrictions:

The results are UNDEFINED if the guest context coprocessor 0 does not contain the register speciied by rs and sel.

The guest context does not implement the Virtualization Module. Use of this instruction in guest-kernel mode will result in a Reserved Instruction exception, taken in guest mode.

MFGC0 must behave exactly the same as the corresponding guest MFC0instruction, exceptthatit will not cause exceptions that are speciic to guest, such as GPSI and GSFC. Speciically, if the guest register is replicated in guest context, then the read will return the register value, if the register is Reserved for Architecture/Implementation or is

Not Available,the read returns 0,ifthe registeris Shared (such as WatchHi)then the read will always return the register value except that ields invisible to guest are zeroed out.

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

Operation:

if IsCoprocessorEnabled(0) then
   if (Config3VZ = 0) then
      SignalException(ReservedInstruction, 0)
      break
   endif
   reg = rs
   data = Guest.CPR[0,reg,sel]
   if (reg,sel = EntryLo1 or reg,sel = EntryLo0 then
      GPR[rt]29..0 = data29..0
      GPR[rt]31 = data63
      GPR[rt]30 = data62
      GPR[rt]63..32 = sign_extend(data63)
   else
      GPR[rt] = sign_extend(data)
   endif
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

rt

rs

00

sel

MFHGC0

10011

POOL32P

110100

6

5

5

2

3

5

6

Format:

MFHGC0 rt, rs, sel

microMIPS Release 5

Move from High Guest Coprocessor 0

Purpose:

Move from High Guest Coprocessor 0

To move the contents of the upper 32-bits of a guest coprocessor 0 register, extended by 32-bits, to a general register.

Description:

 GPR[rt] = Guest.CPR[0,rs,sel][63:32]

The contents ofthe guest coprocessor 0 register speciied by the combination of rs and sel are sign-extended and loaded into general register rt. Note that not all coprocessor 0 registers support the sel ield. In those instances, the sel ield must be zero.

When the coprocessor 0 register speciied is the EntryLo0 or the EntryLo1 register, MFHGC0 must undo the effects of MTHGC0. That is, bits 31:30 of the register must be returned as bits 1:0 of the GPR, and bits 32 and those of greater signiicance must be left shifted by 2 and written to bits 31:2 of the GPR.

This feature supports MIPS32 backward compatability on a MIPS64 system.

Restrictions:

The results are UNDEFINED if guest coprocessor 0 does not contain a register as speciied by rs and sel, or the register exists but is not extended by 32-bits, or the register is extended for XPA, but XPA is not enabled. XPA is a

Release 5 feature.

The guest context does notimplementthe Virtualization Module. Use of this instruction in guest-kernel mode will result in a Reserved Instruction exception, taken in guest mode.

MFHGC0 must behave exactly the same as the corresponding guest MFHC0instruction, exceptthatit will not cause exceptions that are speciic to guest, such as GPSI and GSFC. Speciically, if the guest register is replicated in guest context, then the read will return the register value, if the register is Reserved for Architecture/Implementation or is

Not Available,the read returns 0,if the registeris Shared (e.g., WatchHi, butitis not extended)then the read will always return the register value except that ields invisible to guest are zeroed out.

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

Operation:

PABITS isthe total number of physical address bitsimplemented. The term can be found in the deinition of

EntryLo0 and EntryLo1.

if IsCoprocessorEnabled(0) then
   reg = rs
   data = Guest.CPR[0,reg,sel]
   if (reg,sel = EntryLo1 or reg,sel = EntryLo0) then
      if (Root.Config3LPA = 1 and Root.PageGrainELPA = 1) then // PABITS > 36
         GPR[rt]31:0 = data61..30
         GPR[rt]63..32 = (data61)32 // sign-extend
      endif
   else
      GPR[rt] = sign_extend(data63..32)
   endif
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

rt

rs

00

sel

MTGC0

11011

POOL32AXf

111100

6

5

5

2

3

5

6

Format:

MTGC0 rt, rs, sel

microMIPS

Move to Guest Coprocessor 0

Purpose:

Move to Guest Coprocessor 0

To move the contents of a general register to a guest coprocessor 0 register.

Description:

 Guest.CPR[0, rs, sel] = GPR[rt]

The contents of general register rt are loaded into the guest context coprocessor 0 register specified by the combination of rs and sel. Not all guest context coprocessor 0 registers support the sel field. In those instances, the sel field must be set to zero.

When the guest context coprocessor 0 destination register specified is the EntryLo0 or the EntryLo1 register, bits

31:30 appear as the RI/XI fields of the destination register. This feature supports 32-bit addressing mode compatibility on a MIPS64 system.

Restrictions:

The results are UNDEFINED if guest context coprocessor 0 does not contain the register as specified by rs and sel or the destination register is the Guest.Count register, which is read-only

The guest context does notimplementthe Virtualization Module. Use of this instruction in guest-kernel mode will result in a Reserved Instruction exception, taken in guest mode.

MTGC0 must behave exactly the same as the corresponding guest MTC0instruction, exceptthatit will not cause exceptions that are specific to guest, such as GPSI and GSFC. Specifically, if the guest register is replicated in guest context, then the write must complete, if the register is Reserved for Architecture/Implementation or is Not Available, the write is ignored, if the register is Shared (such as WatchHi) then the write always completes but does not effect fields invisible to guest.

In a 64-bit processor, the MTGC0 instruction writes all 64 bits of register rt into the guest context coprocessor register specified by rd and sel if that register is a 64-bit register.

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

Operation:

if IsCoprocessorEnabled(0) then
   if (Config3VZ = 0) then
      SignalException(ReservedInstruction, 0)
      break
   endif
   data = GPR[rt]
   reg = rs
   if (reg,sel = EntryLo1 or reg,sel = EntryLo0) then
      Guest.CPR[0,reg,sel]29..0 = data29..0
      Guest.CPR[0,reg,sel]63 = data31
      Guest.CPR[0,reg,sel]62 = data30
      Guest.CPR[0,reg,sel]61:30 = 032
   else if (Width(CPR[0,reg,sel]) = 64) then
      Guest.CPR[0,reg,sel] = data
   else
   endif
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

rt

rs

00

sel

MTHGC0

11011

POOL32P

110100

6

5

5

2

3

5

6

Format:

MTHGC0 rt, rs, sel

microMIPS Release 5

Move to High Guest Coprocessor 0

Purpose:

Move to High Guest Coprocessor 0

To move the contents of a general register to the upper 32-bits of a guest coprocessor 0 register that has been extended by 32-bits.

Description:

 Guest.CPR[0, rs, sel][63:32] = GPR[rt]

The contents of general register rt are loaded into the guest coprocessor 0 register speciied by the combination of rs and sel. Not all coprocessor 0 registers support the the sel ield. In those instances, the sel ield must be set to zero.

When the guest coprocessor 0 destination register speciied is the EntryLo0 or the EntryLo1 register, bits 1:0 of the

GPR appear at bits 31:30 of EntryLo0 or the EntryLo1 ields. This is to compensate for RI/XI which were shifted to bits 63:62 by MTC0 of EntryLo0 or the EntryLo1.

If RI/XI are not supported,then the shift must still occur, but

MFHC0 willreturn 0s forthese two ields. The GPR is right shifted by 2 to vacate the lower 2-bits, and 2 0s are is written to the upper 32-bits MIPS64 EntryLo0 or EntryLo1, excluding RI/XI shifted in from the left. The result that were placed in bits 63:62 i.e., the write must appear atomic as if both MTC0 and MTHC0 occured together.

This feature supports MIPS32 backward compatability on a MIPS64 system.

Restrictions:

The results are UNDEFINED if guest coprocessor 0 does not contain a register as speciied by rs 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 enabled. XPA is a

Release 5 feature.

MTHGC0 must behave exactly the same as the corresponding guest MTHC0instruction, exceptthatit will not cause exceptions that are speciic to guest, such as GPSI and GSFC. Speciically, if the guest register is replicated in guest context, then the write must complete, if the register is Reserved for Architecture/Implementation or is Not Available, the write is ignored, if the register is Shared (such as WatchHi) then the write always completes but does not effect ields invisible to guest.

In a 64-bit processor, the MTHC0 instruction writes only the lower 32 bits of register rt into the upper 32-bits of the guest coprocessor register speciied by rd and sel if that register is extended by MIPS32 Release 5. Speciically, the only registers extended by MIPS32 Release 5 are those required for the feature XPA, and those registers are identical to the same registers in the MIPS64 architecture, other than EntryLo0 or the EntryLo1.

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

Operation:

if IsCoprocessorEnabled(0) then
   data = GPR[rt]
   reg = rs
   if (reg,sel = EntryLo1 or reg,sel = EntryLo0) then
      if (Root.Config3LPA = 1 and Root.PageGrainELPA = 1) then // PABITS > 36
         Guest.CPR[0,reg,sel]31..30 = data1..0
         Guest.CPR[0,reg,sel]61:32 = data31..2 and ((1<<(PABITS-36))-1)
         Guest.CPR[0,reg,sel]61:32 = 02
      endif
   else
   endif
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

0000000000

TLBGINV

0100000101

POOL32Axf

111100

6

10

10

6

Format:

TLBGINV

microMIPS

Guest TLB Invalidate

Purpose:

Guest TLB Invalidate

Index match. The virtual address isTLBGINV invalidates a set of guest TLB entries based on ASID and guest ignored in the match.

Implementation of the TLBGINV instruction is optional. The implementation of this instruction is indicated by the IE field in Config4.

Implementation of EntryHIEHINV field is required for implementation of TLBGINV instruction.

Support for TLBGINV is recommended for implementations supporting VTLB/FTLB type TLB’s.

Description:

On execution ofthe TLBGINV instruction,the set of guest TLB entries with matching ASID are marked invalid, excluding those guest TLB entries which have their G bit set to 1.

The EntryHIASID field has to be set to the appropriate ASID value before executing the TLBGINV instruction.

Behavior of the TLBGINV instruction applies to all applicable guest TLB entries and is unaffected by the setting of the Guest.Wired register.

For JTLB-based MMU(ConfigMT=1):

All matching entries in the guest JTLB are invalidated. Index is unused.

For VTLB/FTLB -based MMU(ConfigMT=4):

A TLBGINV with Index set in guest VTLB range causes all matching entries in the guest VTLB to be invalidated. A TLBGINV with Index set in guest FTLB range causes all matching entries in the single addressed guest

FTLB set to be invalidated.

If TLB invalidate walk is implemented in software (Config4IE=2), then software must do these steps:

1.one TLBGINV instruction is executed with an index in guest VTLB range (invalidates all matching guest

VTLB entries)

2.a TLBGINV instruction is executed for each guest FTLB set (invalidates all matching entries in guest FTLB set)

If TLB invalidate walk is implemented in hardware (Config4IE=3), then software must do these steps:

1.one TLBGINV instruction is executed (invalidates all matching entries in both guest FTLB & guest VTLB).

In this case, Index is unused.

In an implementation supporting GuestID (GuestCtl0G1=1), matching of guest TLB entries includes comparison of the TLB entry GuestID with the Root GuestID control field, GuestCtl1RID .

Note that the TLBGINV instruction only invalidates guest virtual address translations in the guest TLB, invalidation of guest physical address translations requires execution of the equivalent TLBINV instruction sequence in the root

TLB.

The operation is UNDEFINED if the contents of the Index register are greater than or equal to the number of available TLB entries (for the case of ConfigMT=4).

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

For processors that do not include a TLB, the operation of this instruction is UNDEFINED. The preferred implementation is to signal a Reserved Instruction Exception.

Operation:

   if (Guest.ConfigMT=1 or
      (Guest.ConfigMT=4 & Guest.Cοnfig4IE=2 & Index≤ Guest.Config1MMU_SIZE-1))
      startnum = 0
      endnum = Guest.Config1MMU_SIZE-1
   endif
   // treating VTLB and FTLB as one array
   if (Guest.ConfigMT=4 & Guest.Cοnfig4IE=2 & Index > Guest.Config1MMU_SIZE-1)
      startnum = start of selected Guest FTLB set // implementation specific
      endnum = end of selected Guest FTLB set - 1 //implementation specifc
   endif
   if (Guest.ConfigMT=4 & Guest.Cοnfig4IE=3))
      startnum = 0
      endnum = Guest.Config1MMU_SIZE-1 +
      ((Guest.Config4FTLBWays + 2) * Guest.Config4FTLBSets)
   endif
   if IsCoprocessorEnabled(0) then
      for (i = startnum to endnum)
         if ((Guest.TLB[i]ASID = Guest.EntryHiASID) & (Guest.TLB[i]G = 0))
             if (GuestCtl0G1 = 1)
                if (Guest.TLB[i]GuestID = GuestCtl1RID)
                   Guest.TLB[i]hardware_invalid = 1
                endif
             else
                   Guest.TLB[i]hardware_invalid = 1
             endif
         endif
      endfor
   else
      SignalException(CoprocessorUnusable, 0)
   endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

0000000000

TLBGINVF

0101000101

POOL32Axf

111100

6

10

10

6

Format:

TLBGINVF

microMIPS

Guest TLB Invalidate Flush

Purpose:

Guest TLB Invalidate Flush

TLBGINVF invalidates a set of Guest TLB entries based on Index match. The virtual address and ASID are ignored in the match.

Implementation of the TLBGINVF instruction is optional. The implementation of this instruction is indicated by the

IE ield in Conig4. the EntryHIEHINV ield is required for

Implementation ofimplementation of TLBGINV and TLBGINVF instructions.

Support for TLBGINVF is recommend for implementations supporting VTLB/FTLB type TLB's.

Description:

On execution of the TLBGINVF instruction, all entries within range of guest Index are invalidated.

Behavior of the TLBGINVF instruction applies to all applicable guest TLB entries and is unaffected by the setting of the Wired register.

For JTLB-based MMU(ConigMT=1):

TLBGINVF causes all entries in the guest JTLB to be invalidated. Index is unused.

For VTLB/FTLB-based MMU(ConigMT=4):

TLBINVF with Index in guest VTLB range causes all entries in the guest VTLB to be invalidated.

TLBINVF with Index in guest FTLB range causes all entries in the single corresponding set in the guest FTLB to be invalidated.

If TLB invalidate walk is implemented in software (Conig4IE=2), then software must do these steps:

1.one TLBGINV instruction is executed with an index in guest VTLB range (invalidates all matching guest

VTLB entries)

2.a TLBGINV instruction is executed for each guest FTLB set (invalidates all matching entries in guest FTLB set)

If TLB invalidate walk is implemented in hardware (Conig4IE=3), then software must do these steps:

1.one TLBGINV instruction is executed (invalidates all matching entries in both guest FTLB & guest VTLB).

In this case, Index is unused.

In an implementation supporting GuestID (GuestCtl0G1=1), matching of guest TLB entries includes comparison of the TLB entry GuestID with the Root GuestID control ield, GuestCtl1RID .

Note that the TLBGINVF instruction only invalidates guest virtual address translations in the guest TLB, invalidation of guest physical address translations requires execution of the equivalent TLBINVF instruction sequence in the root

TLB.

Restrictions:

The operation is UNDEFINED if the contents of the Index register are greater than or equal to the number of TLB entries visible as deined by the Conig4 register.

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

For processors that do notinclude the standard TLB MMU, the operation of this instruction is UNDEFINED. The preferred implementation is to signal a Reserved Instruction Exception.

Operation:

   if ( Guest.ConfigMT=1 or
      (Guest.ConfigMT=4 & Guest.Config4IE=2 & Index <= Guest.Config1MMU_SIZE-1))
      startnum = 0
      endnum = Guest.Config1MMU_SIZE-1
   endif
   // treating VTLB and FTLB as one array
   if (Guest.ConfigMT=4 & Guest.Config4IE=2 & Index > Guest.Config1MMU_SIZE-1)
      startnum = start of selected Guest FTLB set // implementation specific
      endnum = end of selected Guest FTLB set - 1 //implementation specifc
   endif
   if (Guest.ConfigMT=4 & Guest.Config4IE=3))
      startnum = 0
      endnum = Guest.Config1MMU_SIZE-1 +
      ((Guest.Config4FTLBWays + 2) * Guest.Config4FTLBSets)
   endif
   if IsCoprocessorEnabled(0) then
      for (i = startnum to endnum)
         if (GuestCtl0G1 = 1)
             if (Guest.TLB[i]GuestID = GuestCtl1RID)
                Guest.TLB[i]hardware_invalid = 1
             endif
         else
                Guest.TLB[i]hardware_invalid = 1
         endif
      endfor
   else
      SignalException(CoprocessorUnusable, 0)
   endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

0

0000000000

TLBGP

0000000101

POOL32AXf

111100

6

10

10

6

Format:

TLBGP

microMIPS

Probe Guest TLB for Matching Entry

Purpose:

Probe Guest TLB for Matching Entry

To ind a matching entry in the Guest TLB, initiated from root mode.

Description:

The Guest.Index register is loaded with the address of the Guest TLB entry whose contents match the contents of the

Guest.EntryHi register. If no Guest TLB entry matches, the high-order bit of the Guest.Index register is set.

In an implementation supporting GuestID (GuestCtl0G1=1), if the GuestID read does not match GuestCtl1RID, then the match fails.

Restrictions:

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

If an implementation detects multiple matches, and does not detect all multiple matches on TLB write, then a TLBGP instruction can take a Machine Check Exception if multiple matches occur.

For processors that do not include a TLB in the guest context, the operation of this instruction is UNDEFINED. The preferred implementation is to signal a Reserved Instruction Exception.

Operation:

if IsCoprocessorEnabled(0) then
   if (Config3VZ = 0) then
       SignalException(ReservedInstruction, 0)
       break
   endif
   Guest.Index = 1 || UNPREDICTABLE31
// If a set-associative TLB is used, then a single set may be probed.
for i in 0...Guest.TLBEntries-1
      if (((Guest.TLB[i]VPN2 and ~(Guest.TLB[i]Mask)) =
             (Guest.EntryHiVPN2 and ~(Guest.TLB[i]Mask))) and
             (Guest.TLB[i]R = Guest.EntryHiR) and
             ((Config4IE >= 2)and not TLB[i]hardware_invalid) and
             (Guest.TLB[i]G or (Guest.TLB[i]ASID = Guest.EntryHiASID))) then
                   if (GuestCtl0G1 = 1)
                          if (Guest.TLB[i]GuestID = GuestCtl1RID)
                                 Guest.Index = i
                          endif
                   else
                       Guest.Index = i
                endif
         endif
   endfor
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Machine Check (implementation dependent)

Reserved Instruction

Encoding:

POOL32A

000000

0

0000000000

TLBGR

0001000101

POOL32AXf

111100

6

10

10

6

Format:

TLBGR

microMIPS

Read Indexed Guest TLB Entry

Purpose:

Read Indexed Guest TLB Entry

To read an entry from the Guest TLB into the guest context, initiated from root mode.

Description:

The Guest.EntryHi, Guest.EntryLo0, Guest.EntryLo1, and Guest.PageMask registers are loaded with the conthe Guest.Index tents of the Guest TLB entry pointed to by register. Note that the value written to the

Guest.EntryHi, Guest.EntryLo0, and Guest.EntryLo1 registers may be different from that originally written to the

TLB via these registers in that:

The value returned in the VPN2 ield of the EntryHi register may have those bits set to zero corresponding to the

The value returned in the PFN ield of the EntryLo0 and EntryLo1 registers may have those bits set to zero cor-

The value returned in the G bit in both the EntryLo0 and EntryLo1 registers comes from the single G bit in the

In an implementation supporting GuestID,if the TLB entry is not marked invalid, with the GuestID of the TLB entry read.

Restrictions:

The operation is UNDEFINED if the contents of the Guest.Index register are greater than or equal to the number of

TLB entries in the guest context.

If root-mode access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

The guest context does notimplementthe Virtualization Module. Use of this instruction in guest-kernel mode will result in a Reserved Instruction exception, taken in guest mode.

For processors that do not include a TLB in the guest context, the operation of this instruction is UNDEFINED. The preferred implementation is to signal a Reserved Instruction Exception.

Operation:

if IsCoprocessorEnabled(0) then
   if (Config3VZ = 0) then
      SignalException(ReservedInstruction, 0)
      break
   endif
   i = Guest.Index
   if i > (Guest.TLBEntries - 1) then
      UNDEFINED
   endif
   if (Config4IE >= 2 && Guest.TLB[i]EHINV = 1) then
      GuestCtl1RID = 0
      Guest.PagemaskMask = 0
      Guest.EntryHi = 0
      Guest.EntryLo1 = 0
      Guest.EntryLo0 = 0
      Guest.EntryHiEHINV = 1
      break
   endif
   if (GuestCtl0G1 = 1)
      GuestCtl1RID = Guest.TLB[i]GuestID
   endif
   Guest.PageMaskMask = Guest.TLB[i]Mask
   Guest.EntryHi = Guest.TLB[i]R || 0Fill ||
         (Guest.TLB[i]VPN2 and not Guest.TLB[i]Mask) || # Masking impl dependent
         05 || Guest.TLB[i]ASID
   Guest.EntryLo1 = 0Fill ||
         (Guest.TLB[i]PFN1 and not Guest.TLB[i]Mask) || # Masking impl dependent
         Guest.TLB[i]C1 || Guest.TLB[i]D1 || Guest.TLB[i]V1 || Guest.TLB[i]G
   Guest.EntryLo0 = 0Fill ||
         (Guest.TLB[i]PFN0 and not Guest.TLB[i]Mask) || # Masking impl dependent
         Guest.TLB[i]C0 || Guest.TLB[i]D0 || Guest.TLB[i]V0 || Guest.TLB[i]G
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

0000000000

TLBGWI

0010000101

POOL32Axf

111100

6

10

10

6

Format:

TLBGWI

microMIPS

Write Indexed Guest TLB Entry

Purpose:

Write Indexed Guest TLB Entry

To write a Guest TLB entry indexed by the Index register, initiated from root mode.

Description:

The Guest TLB entry pointed to by the Guest.Index registerthe Guest.EntryHi, is written from the contents of

Guest.EntryLo0, Guest.EntryLo1, and Guest.PageMask registers. The information written to the Guest TLB

entry may be different from that in the Guest.EntryHi, Guest.EntryLo0, and Guest.EntryLo1 registers, in that:

TLB write.

TLB write.

The single G bit in the TLB entry is set from the logical AND of the G bits in the EntryLo0 and EntryLo1 regis-

In an implementation supporting GuestID, GuestCtl1RID is written in the TLB entry.

TLB entry pointed to by the Guest.Index register is marked invalid when guest EntryHIEHINV=1.

When EntryHIEHINV=1, no machine check generating error conditions exist.

Implementation of the TLBGWI invalidate feature is required if the TLBGINV and TLBGINVF instructions are implemented, optional otherwise.

Restrictions:

The operation is UNDEFINED if the contents of the Guest.Index register are greater than or equal to the number of

TLB entries in the guest context.

If access to the root Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

On an FTLB enabled system, if Guest.Index is in FTLB range and the page size speciied does not match FTLB page size, recommended behavior is that the write not complete and a Machine Check Exception be signaled.

On an FTLB enabled system, for a write in FTLB range, if the VPN is inconsistent with Index, it is recommended that a Machine Check Exception be signaled.

Itisimplementation dependent whether multiple TLB matches are detected on a TLBGWI,though itisrecommended. If a TLB write detects multiple matches, but not necessarily all multiple matches, then it is recommended that a TLB lookup or TLB probe operation signal a Machine Check Exception on detection of multiple matches.

If multiple match detection is implemented,then on detection,itis recommended thatthe multiple match be invalidated and the write completed. It is recommended that no Machine Check Exception be signaled.

The guest context does notimplementthe Virtualization Module. Use of this instruction in guest-kernel mode will result in a Reserved Instruction Exception, taken in guest mode.

For processors that do not include a TLB in the guest context, the operation of this instruction is UNDEFINED. The preferred implementation is to signal a Reserved Instruction Exception.

Operation:

if IsCoprocessorEnabled(0) then
   if (Config3VZ = 0) then
      SignalException(ReservedInstruction, 0)
      break
   endif
   i = Guest.Index
   if (Config4IE >= 2) then
      Guest.TLB[i]hardware_invalid = 0
      if ( EntryHIEHINV=1 ) then
         Guest.TLB[i]hardware_invalid = 1
      endif
   endif
   Guest.TLB[i]Mask = Guest.PageMaskMask
   Guest.TLB[i]R = Guest.EntryHiR
   Guest.TLB[i]VPN2 = Guest.EntryHiVPN2 and not Guest.PageMaskMask # Impl dependent
   Guest.TLB[i]ASID = Guest.EntryHiASID
   Guest.TLB[i]G = Guest.EntryLo1G and Guest.EntryLo0G
   Guest.TLB[i]PFN1 = Guest.EntryLo1PFN and not Guest.PageMaskMask # Impl dependent
   Guest.TLB[i]C1 = Guest.EntryLo1C
   Guest.TLB[i]D1 = Guest.EntryLo1D
   Guest.TLB[i]V1 = Guest.EntryLo1V
   Guest.TLB[i]PFN0 = Guest.EntryLo0PFN and not Guest.PageMaskMask # Impl dependent
   Guest.TLB[i]C0 = Guest.EntryLo0C
   Guest.TLB[i]D0 = Guest.EntryLo0D
   Guest.TLB[i]V0 = Guest.EntryLo0V
   if (GuestCtl0G1) then
      Guest.TLB[i]GuestID = GuestCtl1RID
   endif
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Machine Check (disabled if guest EntryHIEHINV=1.)

Encoding:

POOL32A

000000

0000000000

TLBGWR

0011000101

POOL32Axf

111100

6

10

10

6

Format:

TLBGWR

microMIPS

Write Random Guest TLB Entry

Purpose:

Write Random Guest TLB Entry

To write a Guest TLB entry indexed by the Random register, initiated from root mode.

Description:

The Guest TLB entry pointed to by the Guest.Random register is written from the contents of the Guest.EntryHi,

Guest.EntryLo0, Guest.EntryLo1, and Guest.PageMask registers.

The information written to the Guest TLB entry may be different from that in the Guest.EntryHi, Guest.EntryLo0, and Guest.EntryLo1 registers, in that:

The single G bit in the Guest TLB entry is set from the logical AND of the G bits in the Guest.EntryLo0 and

In an implementation supporting GuestID, GuestCtl1RID is written in the TLB entry.

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

On an VTLB/FTLB enabled implementation, if the Pagemask register contains a page size differing from the FTLB page size deined in Conig4, then the write goes into a random entry in the VTLB.

Itis implementation dependent whether multiple TLB matches are detected on a TLBGWR,though itis recommended. If a TLB write detects multiple matches, but not necessarily all multiple matches, then a TLB lookup or TLB probe operation should signal a Machine Check Exception on detection of multiple matches.

If multiple match detection is implemented, then on detection, the multiple match should be invalidated and the write completed. No Machine Check Exception should be signaled.

The guest context does notimplementthe Virtualization Module. Use of this instruction in guest-kernel mode will result in a Reserved Instruction exception, taken in guest mode.

For processors that do not include a TLB in the guest context, the operation of this instruction is UNDEFINED. The preferred implementation is to signal a Reserved Instruction Exception.

Operation:

if IsCoprocessorEnabled(0) then
      SignalException(ReservedInstruction, 0)
      break
   endif
   i = Guest.Random
   if (Config4IE >= 2) then
      Guest.TLB[i]hardware_invalid = 0
      if ( EntryHIEHINV=1 ) then
         Guest.TLB[i]hardware_invalid = 1
      endif
   endif
   Guest.TLB[i]Mask = Guest.PageMaskMask
   Guest.TLB[i]R = Guest.EntryHiR
   Guest.TLB[i]VPN2 = Guest.EntryHiVPN2 and not Guest.PageMaskMask # Impl. dependent
   Guest.TLB[i]ASID = Guest.EntryHiASID
   Guest.TLB[i]G = Guest.EntryLo1G and Guest.EntryLo0G
   Guest.TLB[i]PFN1 = Guest.EntryLo1PFN and not PageMaskMask # Impl. dependent
   Guest.TLB[i]C1 = Guest.EntryLo1C
   Guest.TLB[i]D1 = Guest.EntryLo1D
   Guest.TLB[i]V1 = Guest.EntryLo1V
   Guest.TLB[i]PFN0 = Guest.EntryLo0PFN and not PageMaskMask # Impl. dependent
   Guest.TLB[i]C0 = Guest.EntryLo0C
   Guest.TLB[i]D0 = Guest.EntryLo0D
   Guest.TLB[i]V0 = Guest.EntryLo0V
   if (GuestCtl0G1) then
      Guest.TLB[i]GuestID = GuestCtl1RID
   endif
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Machine Check (implementation dependent)

Encoding:

POOL32A

000000

0000000000

TLBINV

0100001101

POOL32Axf

111100

6

10

10

6

Format:

TLBINV

microMIPS

TLB Invalidate

Purpose:

TLB Invalidate

Description:

The TLBINV instruction is unmodiied from the base architectural deinition, except in an implementation supporting

GuestID:

When executing in Guest mode, if the GuestID read does not match GuestCtl1ID, then the TLB entry is not

When executing in Root mode, if the GuestID read does not match GuestCtl1RID, then the TLB entry is not

Restrictions:

Unchanged from the base architecture.

Exceptions:

Unchanged from the base architecture.

Encoding:

POOL32A

000000

0000000000

TLBINV

0101001101

POOL32Axf

111100

6

10

10

6

Format:

TLBINVF

microMIPS

TLB Invalidate Flush

Purpose:

TLB Invalidate Flush

Description:

The TLBINVF instruction is unmodiied from the base architectural deinition, except in an implementation supporting GuestID:

When executing in Guest mode, if the GuestID read does not match GuestCtl1ID, then the TLB entry is not

When executing in Root mode, if the GuestID read does not match GuestCtl1RID, then the TLB entry is not

Restrictions:

Unchanged from the base architecture.

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

0

0000000000

TLBP

0000001101

POOL32AXf

111100

6

10

10

6

Format:

TLBP

microMIPS

Probe TLB for Matching Entry

Purpose:

Probe TLB for Matching Entry

To ind a matching entry in the TLB.

Description:

The TLBP instruction is unmodiied from the base architectural deinition, exceptin an implementation supporting

GuestID:

When executing in Guest mode, if the GuestID read does not match GuestCtl1ID, then the match fails.

Restrictions:

Unchanged from the base architecture.

Operation:

if IsCoprocessorEnabled(0) then
Index = 1 || UNPREDICTABLE31
for i in 0...TLBEntries-1
if ((TLB[i]VPN2 & ~(TLB[i]Mask)) = (EntryHiVPN2 & ~(TLB[i]Mask))) and
(TLB[i]R = EntryHiR) and
(Config4IE >= 2 && TLB[i]hardware_invalid != 1) and
((IsRootMode() and (TLB[i]GuestID = GuestCtl1RID)) or
(IsGuestMode() and (TLB[i]GuestID = GuestCtl1ID))) and
((TLB[i]G = 1) or (TLB[i]ASID = EntryHiASID)) then
Index = i
endif
endfor
else
SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Machine Check (implementation deined)

Encoding:

POOL32A

000000

0

0000000000

TLBR

0001001101

POOL32AXf

111100

6

10

10

6

Format:

TLBR

microMIPS

Read Indexed TLB Entry

Purpose:

Read Indexed TLB Entry

To read an entry from the TLB.

Description:

The TLBR instruction is unmodiied from the base architectural deinition, exceptin an implementation supporting

GuestID:

When executing in Guest mode, if the GuestID read does not match GuestCtl1ID, then the TLB related CP0 reg-

When executing in Root mode and the TLB entry is not marked as invalid, GuestCtl1RID is set to the GuestID of

Restrictions:

The operation is UNDEFINED if the contents of the Index register are greater than or equal to the number of TLB entries in the processor.

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

For processors that do notinclude the standard TLB MMU, the operation of this instruction is UNDEFINED. The preferred implementation is to signal a Reserved Instruction Exception.

Operation:

if IsCoprocessorEnabled(0) then
   i = Index
   if i > (TLBEntries - 1) then
      UNDEFINED
   endif
   if (Config4IE >= 2 && TLB[i]hardware_invalid=1) then
      if GuestCtl0G1=1
         if (GuestCtl0GM=0 or (GuestCtl0GM=1 and (Root.DebugDM=1 or
             Root.StatusERL=1 or Root.StatusEXL=1))) then
                GuestCtl1RID = 0 // RID only updated in root mode
         endif
      endif
      // Remaining state is handled similarly in root and guest modes.
      PagemaskMask = 0
      EntryHi = 0
      EntryLo1 = 0
      EntryLo0 = 0
      EntryHiEHINV = 1
      break
   endif
   PageMaskMask = TLB[i]Mask
   EntryHi = TLB[i]R || 0Fill ||
             (TLB[i]VPN2 and not TLB[i]Mask) || # Masking implementation dependent
   EntryLo1 = 0Fill ||
             (TLB[i]PFN1 and not TLB[i]Mask) || # Masking mplementation dependent
             TLB[i]C1 || TLB[i]D1 || TLB[i]V1 || TLB[i]G
   EntryLo0 = 0Fill ||
             (TLB[i]PFN0 and not TLB[i]Mask) || # Masking mplementation dependent
             TLB[i]C0 || TLB[i]D0 || TLB[i]V0 || TLB[i]G
   # if in guest mode, if the TLB entry guest id != guest id then zero the result
   if (GuestCtl0G1 = 1)
      if (GuestCtl0GM=1) and (Root.DebugDM=0) and
         (Root.StatusERL=0) and (Root.StatusEXL=0) then
             if (TLB[i]ID != GuestCtl1ID) then
                PagemaskMask = 0
                EntryHi = 0
                EntryLo1 = 0
                EntryLo0 = 0
                EntryHiEHINV = 1
             endif
      else #in root mode, RID with GuestID
         GuestCtl1RID = TLB[i]GuestID
      endif
   endif
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Encoding:

POOL32A

000000

0000000000

TLBWI

0010001101

POOL32Axf

111100

6

10

10

6

Format:

TLBWI

microMIPS

Write Indexed TLB Entry

Purpose:

Write Indexed TLB Entry

To write a TLB entry indexed by the Index register.

Description:

The TLBWI instruction is unmodiied from the base architecture, except in an implementation supporting GuestID:

When executing in Guest mode, GuestCtl1ID is written in the guest TLB entry.

If EHINV is implemented, the TLBWI instruction also acts as an explicit TLB entry invalidate operation. The TLB entry pointed to by the Index register is marked invalid when EntryHIEHINV=1.

When EntryHIEHINV=1, no machine check generating error conditions exist.

Restrictions:

Unmodiied from the base architecture.

Operation:

if IsCoprocessorEnabled(0) then
   i = Index
   if ( Config4IE >= 2) then
      TLB[i]hardware_invalid = 0
      if (EntryHIEHINV=1) then
         TLB[i]hardware_invalid = 1
      endif
   endif
   TLB[i]Mask = PageMaskMask
   TLB[i]R = EntryHiR
   TLB[i]VPN2 = EntryHiVPN2 and not PageMaskMask # Implementation dependent
   TLB[i]ASID = EntryHiASID
   if (GuestCtl0G1) then
         if ((GuestCtl0RAD=0) and IsRootMode() and (GuestCtl1RID != 0))
             TLB[i]G = 1
         else
             TLB[i]G = EntryLo1G and EntryLo0G
         endif
   else
         TLB[i]G = EntryLo1G and EntryLo0G
   endif
   if ( IsRootMode() ) then
      TLB[i]GuestID = GuestCtl1RID
      TLB[i]GuestID = GuestCtl1ID
   endif
   TLB[i]PFN1 = EntryLo1PFN and not PageMaskMask # Implementation dependent
   TLB[i]C1 = EntryLo1C
   TLB[i]D1 = EntryLo1D
   TLB[i]V1 = EntryLo1V
   TLB[i]PFN0 = EntryLo0PFN and not PageMaskMask # Implementation dependent
   TLB[i]C0 = EntryLo0C
   TLB[i]D0 = EntryLo0D
   TLB[i]V0 = EntryLo0V
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Unmodiied from the base architecture.

Encoding:

POOL32A

000000

0000000000

TLBWR

0011001101

POOL32Axf

111100

6

10

10

6

Format:

TLBWR

microMIPS

Write Random TLB Entry

Purpose:

Write Random TLB Entry

To write a TLB entry indexed by the Random register.

Description:

The TLB entry pointed to by the Random register is written from the contents of the EntryHi, EntryLo0, EntryLo1, and PageMask registers.

The information written to the TLB entry may be different from that in the EntryHi, EntryLo0, and EntryLo1 registers, in that:

TLB write.

TLB write.

The single G bit in the TLB entry is set from the logical AND of the G bits in the EntryLo0 and EntryLo1 reg-

In an implementation supporting GuestID, GuestCtl1RID is written in the TLB entry.

Restrictions:

If access to Coprocessor 0 is not enabled, a Coprocessor Unusable Exception is signaled.

On an VTLB/FTLB enabled implementation, if the Pagemask register contains a page size differing from the FTLB page size deined in Conig4, then the write goes into a random entry in the VTLB.

It is implementation dependent whether multiple TLB matches are detected on a TLBWR, though it is recommended.

If a TLB write detects multiple matches, but not necessarily all multiple matches,then a TLB lookup or TLB probe operation should signal a Machine Check Exception on detection of multiple matches.

If multiple match detection is implemented, then on detection, the multiple match should be invalidated and the write completed. No Machine Check Exception should be signaled.

Operation:

if IsCoprocessorEnabled(0) then
   if (Config3VZ = 0) then
      SignalException(ReservedInstruction, 0)
      break
   endif
   if (Config4IE = 1) then
      TLB[i]hardware_invalid = 0
      if ( EntryHIEHINV=1 ) then
         TLB[i]hardware_invalid = 1
      endif
   endif
   TLB[i]Mask = PageMaskMask
   TLB[i]R = EntryHiR
   TLB[i]VPN2 = EntryHiVPN2 and not PageMaskMask # Impl. dependent
   TLB[i]ASID = EntryHiASID
   if (GuestCtl0G1) then
      if ((GuestCtl0RAD=0) and IsRootMode() and (GuestCtl1RID != 0))
         TLB[i]G = 1
      else
         TLB[i]G = EntryLo1G and EntryLo0G
      endif
   else
      TLB[i]G = EntryLo1G and EntryLo0G
   endif
   TLB[i]PFN1 = EntryLo1PFN and not PageMaskMask # Impl. dependent
   TLB[i]C1 = EntryLo1C
   TLB[i]D1 = EntryLo1D
   TLB[i]V1 = EntryLo1V
   TLB[i]PFN0 = EntryLo0PFN and not PageMaskMask # Impl. dependent
   TLB[i]C0 = EntryLo0C
   TLB[i]D0 = EntryLo0D
   TLB[i]V0 = EntryLo0V
   if (GuestCtl0G1) then
      TLB[i]GuestID = GuestCtl1RID
   endif
else
   SignalException(CoprocessorUnusable, 0)
endif

Exceptions:

Coprocessor Unusable

Reserved Instruction

Machine Check (implementation dependent)