Assembly:

LHUE rt, offset(rs)

nanoMIPS. Optional, present when Config5.EVA=1. Requires CP0 privilege.

Load Half Unsigned using EVA addressing

Purpose:

Load Half Unsigned using EVA addressing. Load unsigned halfword to register $rt from virtual address $rs + offset, translating the virtual address as though the core is in user mode, although it is actually in kernel mode.

Availability:

nanoMIPS. Optional, present when Config5.EVA=1. Requires CP0 privilege.

Format:

101001

rt

rs

s[8]

0110

0

10

s[7:0]

6

5

5

1

4

1

2

8

Operation:

if not C0.Config5.EVA:
    raise exception('RI')
if not IsCoprocessor0Enabled():
    raise coprocessor_exception(0)
offset = sign_extend(s, from_nbits=9)
va = effective_address(GPR[rs], offset, 'Load', eva=True)
GPR[rt] = read_memory_at_va(va, nbytes=2, eva=True)

Exceptions:

Address Error. Bus Error. Coprocessor Unusable. Reserved Instruction if EVA not implemented. TLB Invalid. TLB Read Inhibit. TLB Refill. Watch.