Intel 253666-024US Manuel D’Utilisation

Page de 760
3-558 Vol. 2A
LSL—Load Segment Limit
INSTRUCTION SET REFERENCE, A-M
LSL—Load Segment Limit
Description
Loads the unscrambled segment limit from the segment descriptor specified with the 
second operand (source operand) into the first operand (destination operand) and 
sets the ZF flag in the EFLAGS register. The source operand (which can be a register 
or a memory location) contains the segment selector for the segment descriptor 
being accessed. The destination operand is a general-purpose register.
The processor performs access checks as part of the loading process. Once loaded in 
the destination register, software can compare the segment limit with the offset of a 
pointer. 
The segment limit is a 20-bit value contained in bytes 0 and 1 and in the first 4 bits 
of byte 6 of the segment descriptor. If the descriptor has a byte granular segment 
limit (the granularity flag is set to 0), the destination operand is loaded with a byte 
granular value (byte limit). If the descriptor has a page granular segment limit (the 
granularity flag is set to 1), the LSL instruction will translate the page granular limit 
(page limit) into a byte limit before loading it into the destination operand. The trans-
lation is performed by shifting the 20-bit “raw” limit left 12 bits and filling the low-
order 12 bits with 1s.
When the operand size is 32 bits, the 32-bit byte limit is stored in the destination 
operand. When the operand size is 16 bits, a valid 32-bit limit is computed; however, 
the upper 16 bits are truncated and only the low-order 16 bits are loaded into the 
destination operand.
This instruction performs the following checks before it loads the segment limit into 
the destination register: 
Checks that the segment selector is not NULL.
Checks that the segment selector points to a descriptor that is within the limits of 
the GDT or LDT being accessed
Opcode
Instruction
64-Bit 
Mode
Compat/
Leg Mode
Description
0F 03 /r
LSL r16, r16/m16 Valid
Valid
Load: r16 ← segment limit, 
selector r16/m16.
0F 03 /r
LSL r32, r32/m16
*
Valid
Valid
Load: r32  segment limit, 
selector r32/m16.
REX.W + 0F 03 /LSL r64, r32/m16
*
Valid
Valid
Load: r64  segment limit, 
selector r32/m16
NOTES:
* For all loads (regardless of destination sizing), only bits 16-0 are used. Other bits are ignored.