
Volume 4: Base IA-32 Instruction Reference
4:317
POPF/POPFD—Pop Stack into EFLAGS Register
Description
Pops a doubleword (POPFD) from the top of the stack (if the current operand-size
attribute is 32) and stores the value in the EFLAGS register or pops a word from the top
of the stack (if the operand-size attribute is 16) and stores it in the lower 16 bits of the
EFLAGS register. (These instructions reverse the operation of the PUSHF/PUSHFD
instructions.)
The POPF (pop flags) and POPFD (pop flags double) mnemonics reference the same
opcode. The POPF instruction is intended for use when the operand-size attribute is 16
and the POPFD instruction for when the operand-size attribute is 32. Some assemblers
may force the operand size to 16 when POPF is used and to 32 when POPFD is used.
Others may treat these mnemonics as synonyms (POPF/POPFD) and use the current
setting of the operand-size attribute to determine the size of values to be popped from
the stack, regardless of the mnemonic used.
The effect of the POPF/POPFD instructions on the EFLAGS register changes slightly,
depending on the mode of operation of the processor. When the processor is operating
in protected mode at privilege level 0 (or in real-address mode, which is equivalent to
privilege level 0), all the non-reserved flags in the EFLAGS register except the VIP and
VIF flags can be modified. The VIP and VIF flags are cleared.
When operating in protected mode, but with a privilege level greater an 0, all the flags
can be modified except the IOPL field and the VIP and VIF flags. Here, the IOPL flags
are masked and the VIP and VIF flags are cleared.
When operating in virtual-8086 mode, the I/O privilege level (IOPL) must be equal to 3
to use POPF/POPFD instructions and the VM, RF, IOPL, VIP, and VIF flags are masked. If
the IOPL is less than 3, the POPF/POPFD instructions cause a general protection
exception (#GP).
The IOPL is altered only when executing at privilege level 0. The interrupt flag is altered
only when executing at a level at least as privileged as the IOPL. (Real-address mode is
equivalent to privilege level 0.) If a POPF/POPFD instruction is executed with insufficient
privilege, an exception does not occur, but the privileged bits do not change.
Operation
OLD_IF <- IF; OLD_AC <- AC; OLD_TF <- TF;
IF CR0.PE = 0 (*Real Mode *)
THEN
IF OperandSize = 32;
THEN
EFLAGS
Pop();
(* All non-reserved flags except VM, RF, VIP and VIF can be modified; *)
ELSE (* OperandSize = 16 *)
EFLAGS[15:0]
Pop(); (* All non-reserved flags can be modified; *)
FI;
ELSE (*In Protected Mode *)
Opcode
Instruction
Description
9D
POPF
Pop top of stack into EFLAGS
9D
POPFD
Pop top of stack into EFLAGS
Содержание ITANIUM ARCHITECTURE
Страница 1: ......
Страница 7: ...402 Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Страница 199: ...4 192 Volume 4 Base IA 32 Instruction Reference FWAIT Wait See entry for WAIT ...
Страница 269: ...4 262 Volume 4 Base IA 32 Instruction Reference LES Load Full Pointer See entry for LDS LES LFS LGS LSS ...
Страница 270: ...Volume 4 Base IA 32 Instruction Reference 4 263 LFS Load Full Pointer See entry for LDS LES LFS LGS LSS ...
Страница 273: ...4 266 Volume 4 Base IA 32 Instruction Reference LGS Load Full Pointer See entry for LDS LES LFS LGS LSS ...
Страница 288: ...Volume 4 Base IA 32 Instruction Reference 4 281 LSS Load Full Pointer See entry for LDS LES LFS LGS LSS ...
Страница 352: ...Volume 4 Base IA 32 Instruction Reference 4 345 ROL ROR Rotate See entry for RCL RCR ROL ROR ...
Страница 368: ...Volume 4 Base IA 32 Instruction Reference 4 361 SHL SHR Shift Instructions See entry for SAL SAR SHL SHR ...
Страница 373: ...4 366 Volume 4 Base IA 32 Instruction Reference SIDT Store Interrupt Descriptor Table Register See entry for SGDT SIDT ...
Страница 589: ...4 582 Volume 4 IA 32 SSE Instruction Reference ...
Страница 590: ...Index Intel Itanium Architecture Software Developer s Manual Rev 2 3 Index ...
Страница 591: ...Index Intel Itanium Architecture Software Developer s Manual Rev 2 3 ...
Страница 603: ...INDEX Index 12 Index for Volumes 1 2 3 and 4 ...
Страница 604: ......