beautypg.com

Intel 253666-024US User Manual

Page 146

background image

3-100 Vol. 2A

CALL—Call Procedure

INSTRUCTION SET REFERENCE, A-M

(* Segment descriptor information also loaded *)
Push(oldSS:oldESP); (* From calling procedure *)
Push(oldCS:oldEIP); (* Return address to calling procedure *)

FI;

FI;
CPL ← CodeSegment(DPL)

CS(RPL) ← CPL

END;

SAME-PRIVILEGE:

IF CallGateSize

= 3

2

THEN

IF stack does not have room for 8 bytes

THEN #SS(0); FI;

IF CallGate(InstructionPointer) not within code segment limit

THEN #GP(0); FI;

CS:EIP ← CallGate(CS:EIP) (* Segment descriptor information also loaded *)

Push(oldCS:oldEIP); (* Return address to calling procedure *)

ELSE

If CallGateSize

=

16

THEN

IF stack does not have room for 4 bytes

THEN #SS(0); FI;

IF CallGate(InstructionPointer) not within code segment limit

THEN #GP(0); FI;

CS:IP ← CallGate(CS:instruction pointer);

(* Segment descriptor information also loaded *)
Push(oldCS:oldIP); (* Return address to calling procedure *)

ELSE (* CallGateSize = 64)

IF pushing 16 bytes on the stack touches non-canonical addresses

THEN #SS(0); FI;

IF RIP non-canonical

THEN #GP(0); FI;

CS:IP ← CallGate(CS:instruction pointer);

(* Segment descriptor information also loaded *)
Push(oldCS:oldIP); (* Return address to calling procedure *)

FI;

FI;
CS(RPL) ← CPL

END;

TASK-GATE:

IF task gate DPL < CPL or RPL