beautypg.com

Intel 253666-024US User Manual

Page 588

background image

3-542 Vol. 2A

LGDT/LIDT—Load Global/Interrupt Descriptor Table Register

INSTRUCTION SET REFERENCE, A-M

IDTR(Limit) ← SRC[0:15];

IDTR(Base) ← SRC[16:47];

FI;

ELSE IF 64-bit Operand Size (* In 64-Bit Mode *)

THEN

IDTR(Limit) ← SRC[0:15];

IDTR(Base) ← SRC[16:79];

FI;

FI;

ELSE (* Instruction is LGDT *)

IF OperandSize

=

16

THEN

GDTR(Limit) ← SRC[0:15];

GDTR(Base) ← SRC[16:47] AND 00FFFFFFH;

ELSE IF 32-bit Operand Size

THEN

GDTR(Limit) ← SRC[0:15];

GDTR(Base) ← SRC[16:47];

FI;

ELSE IF 64-bit Operand Size (* In 64-Bit Mode *)

THEN

GDTR(Limit) ← SRC[0:15];

GDTR(Base) ← SRC[16:79];

FI;

FI;

FI;

Flags Affected

None.

Protected Mode Exceptions

#UD

If source operand is not a memory location.
If the LOCK prefix is used.

#GP(0)

If the current privilege level is not 0.
If a memory operand effective address is outside the CS, DS,

ES, FS, or GS segment limit.

If the DS, ES, FS, or GS register is used to access memory and it

contains a NULL segment selector.

#SS(0)

If a memory operand effective address is outside the SS

segment limit.

#PF(fault-code)

If a page fault occurs.