LDL 011010 |
base |
rt |
offset |
6 |
5 |
5 |
16 |
LDL rt, offset(base) |
MIPS64, removed in Release 6 |
Load Doubleword Left |
Load Doubleword Left
To load the most-significant part of a doubleword from an unaligned memory address
GPR[rt] = GPR[rt] MERGE memory[GPR[base] + offset]
The 16-bit signed offset is added to the contents of GPR base to form an effective address (EffAddr). EffAddr is the address of the most-significant of 8 consecutive bytes forming a doubleword (DW) in memory, starting at an arbitrary byte boundary.
A part of DW, the most-significant 1 to 8 bytes, is in the aligned doubleword containing EffAddr. This part of DW is loaded appropriately into the most-significant (left) part of GPR rt, leaving the remainder of GPR rt unchanged.
This instruction has been removed in Release 6.
Release 6 removes the load/store-left/right family of instructions, and requires the system to support misaligned memory accesses.
vAddr = sign_extend(offset) + GPR[base] (pAddr, CCA) = AddressTranslation (vAddr, DATA, LOAD) pAddr = pAddrPSIZE-1..3 || (pAddr2..0 xor ReverseEndian3) if BigEndianMem = 0 then pAddr = pAddrPSIZE-1..3 || 03 endif byte = vAddr2..0 xor BigEndianCPU3 memdoubleword = LoadMemory (CCA, byte, pAddr, vAddr, DATA) GPR[rt] = memdoublworde7+8*byte..0 || GPR[rt]55–8*byte..0
TLB Refill, TLB Invalid, Bus Error, Address Error, Reserved Instruction, Watch