ALP Programming Guide and Reference/Processor Reference
This chapter presents an overview of the instruction set and lists the complete instruction set in alphabetical order. For each instruction, the forms are given for each operand combination, including object code produced, operands required, execution time, and a description. For each instruction, there is an operational description and a summary of exceptions generated.
Intel Instruction Set Overview
This section contains an introduction to the Intel instruction set and presents the terminology necessary to understand the encoding and operation of each individual instruction.
Operand-Size and Address-Size Attributes
When executing an instruction, the processor can address memory using either 16 or 32-bit addresses. Consequently, each instruction that uses memory addresses has associated with it an address-size attribute of either 16 or 32 bits. The use of 16-bit addresses implies both the use of 16-bit displacements in instructions and the generation of 16-bit address offsets (segment relative addresses) as the result of the effective address calculations. 32-bit addresses imply the use of 32-bit displacements and the generation of 32-bit address offsets. Similarly, an instruction that accesses words (16 bits) or doublewords (32 bits) has an operand-size attribute of either 16 or 32 bits.
The attributes are determined by a combination of defaults, instruction prefixes, and (for programs executing in protected mode) size-specification bits in segment descriptors.
Default Segment Attribute
For programs running in protected mode, the D bit in executable-segment descriptors specifies the default attribute for both address size and operand size. These default attributes apply to the execution of all instructions in the segment. A clear D bit sets the default address size and operand size to 16 bits; a set D bit, to 32 bits.
Programs that execute in real mode or virtual-8086 mode have 16-bit addresses and operands by default.
Operand-Size and Address-Size Instruction Prefixes
The internal encoding of an instruction can include two byte-long prefixes: the address-size prefix, 67H, and the operand-size prefix, 66H. (A later section, "Instruction Format", shows the position of the prefixes in an instruction's encoding.) These prefixes override the default segment attributes for the instruction that follows. The following table shows the effect of each possible combination of defaults and overrides.
| Segment Default D = ... | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 
| Operand-Size Prefix 66H | N | N | Y | Y | N | N | Y | Y | 
| Address-Size Prefix 67H | N | Y | N | Y | N | Y | N | Y | 
| Effective Operand Size | 16 | 16 | 32 | 32 | 32 | 32 | 16 | 16 | 
| Effective Address Size | 16 | 32 | 16 | 32 | 32 | 16 | 32 | 16 | 
- Y = Yes, this instruction prefix is present
- N = No, this instruction prefix is not present
Address-Size Attribute for Stack
Instructions that use the stack implicitly (for example: POP EAX) also have a stack address-size attribute of either 16 or 32 bits. Instructions with a stack address-size attribute of 16 use the 16-bit SP stack pointer register; instructions with a stack address-size attribute of 32 bits use the 32-bit ESP register to form the address of the top of the stack.
The stack address-size attribute is controlled by the B bit of the data-segment descriptor in the SS register. A value of zero in the B bit selects a stack address-size attribute of 16; a value of one selects a stack address-size attribute of 32.
Instruction Format
All instruction encodings are subsets of the general instruction format shown in the following figure. Instructions consist of optional instruction prefixes (in any order), one or two primary opcode bytes, possibly an address specifier consisting of the ModR/M byte and the SIB (Scale Index Base) byte, a displacement, if required, and an immediate data field, if required.
| INSTRUCTION PREFIX | ADDRESS-SIZE PREFIX | OPERAND-SIZE PREFIX | SEGMENT OVERRIDE | |
| 0 OR 1 | 0 OR 1 | 0 OR 1 | 0 OR 1 | |
| NUMBER OF BYTES | ||||
| OPCODE | MODR/M | SIB | DISPLACEMENT | IMMEDIATE | 
| 0 OR 1 | 0 OR 1 | 0 OR 1 | 0 OR 1 | 0 OR 1 | 
| NUMBER OF BYTES | ||||
Smaller encoding fields can be defined within the primary opcode or opcodes. These fields define the direction of the operation, the size of the displacements, the register encoding, or sign extension; encoding fields vary depending on the class of operation.
Most instructions that can refer to an operand in memory have an addressing form byte following the primary opcode byte(s). This byte, called the ModR/M byte, specifies the address form to be used. Certain encodings of the ModR/M byte indicate a second addressing byte, the SIB (Scale Index Base) byte, which follows the ModR/M byte and is required to fully specify the addressing form.
Addressing forms can include a displacement immediately following either the ModR/M or SIB byte. If a displacement is present, it can be 8-, 16- or 32-bits.
If the instruction specifies an immediate operand, the immediate operand always follows any displacement bytes. The immediate operand, if specified, is always the last field of the instruction.
Zero or one bytes are reserved for each group of prefixes. The prefixes are grouped as follows:
- Instruction Prefixes: REP, REPE/REPZ, REPNE/REPNZ, LOCK
- Segment Override Prefixes: CS, SS, DS, ES, FS, GS
- Operand Size Override
- Address Size Override
For each instruction, one prefix may be used from each group. The effect of redundant prefixes (more than one prefix from a group) is undefined and may vary from processor to processor. The prefixes may come in any order.
The following are the allowable instruction prefix codes:
F3H REP prefix (used only with string instructions) F3H REPE/REPZ prefix (used only with string instructions) F2H REPNE/REPNZ prefix (used only with string instructions) F0H LOCK prefix
The following are the segment override prefixes:
2EH CS segment override prefix 36H SS segment override prefix 3EH DS segment override prefix 26H ES segment override prefix 64H FS segment override prefix 65H GS segment override prefix 66H Operand-size override 67H Address-size override
ModR/M and SIB Bytes
The ModR/M and SIB bytes follow the opcode byte(s) in many of the processor instructions. They contain the following information:
- The indexing type or register number to be used in the instruction
- The register to be used, or more information to select the instruction
- The base, index, and scale information
The ModR/M byte contains three fields of information:
- The mod field, which occupies the two most significant bits of the byte, combines with the r/m field to form 32 possible values: eight registers and 24 indexing modes.
- The reg field, which occupies the next three bits following the mod field, specifies either a register number or three more bits of opcode information. The meaning of the reg field is determined by the first (opcode) byte of the instruction.
- The r/m field, which occupies the three least significant bits of the byte, can specify a register as the location of an operand, or can form part of the addressing-mode encoding in combination with the mod field as described above.
The based indexed forms of 32-bit addressing require the SIB byte. The presence of the SIB byte is indicated by certain encodings of the ModR/M byte. The SIB byte then includes the following fields:
- The ss field, which occupies the two most significant bits of the byte, specifies the scale factor.
- The index field, which occupies the next three bits following the ss field and specifies the register number of the index register.
- The base field, which occupies the three least significant bits of the byte, specifies the register number of the base register.
ModR/M and SIB Byte Formats
                 MODR/M BYTE
    7     6    5     4     3   2    1     0
  ┌──────────┬────────────────┬──────────────┐
  │  MOD     │   REG/OPCODE   │     R/M      │
  └──────────┴────────────────┴──────────────┘
           SIB (SCALE INDEX BASE) BYTE
    7     6    5     4     3   2    1     0
  ┌──────────┬────────────────┬──────────────┐
  │    SS    │     INDEX      │     BASE     │
  └──────────┴────────────────┴──────────────┘
16-Bit Addressing Forms with the ModR/M Byte
| r8(/r) r16(/r) r32(/r) /digit (Opcode) REG = | AL AX EAX 0 000 | CL CX ECX 1 001 | DL DX EDX 2 010 | BL BX EBX 3 011 | AH SP ESP 4 100 | CH BP EBP 5 101 | DH SI ESI 6 110 | BH DI EDI 7 111 | ||
| Effective Address | MOD | R/M | MODR/M Values in Hexadecimal | |||||||
| [BX+SI] | 00 | 000 | 00 | 08 | 10 | 18 | 20 | 28 | 30 | 38 | 
| [BX+DI] | 001 | 01 | 09 | 11 | 19 | 21 | 29 | 31 | 39 | |
| [BP+SI] | 010 | 02 | 0A | 12 | 1A | 22 | 2A | 32 | 3A | |
| [BP+DI] | 011 | 03 | 0B | 13 | 1B | 23 | 2B | 33 | 3B | |
| [SI] | 100 | 04 | 0C | 14 | 1C | 24 | 2C | 34 | 3C | |
| [DI] | 101 | 05 | 0D | 15 | 1D | 25 | 2D | 35 | 3D | |
| disp16 | 110 | 06 | 0E | 16 | 1E | 26 | 2E | 36 | 3E | |
| [BX] | 111 | 07 | 0F | 17 | 1F | 27 | 2F | 37 | 3F | |
| [BX+SI]+disp8 | 01 | 000 | 40 | 48 | 50 | 58 | 60 | 68 | 70 | 78 | 
| [BX+DI]+disp8 | 001 | 41 | 49 | 51 | 59 | 61 | 69 | 71 | 79 | |
| [BP+SI]+disp8 | 010 | 42 | 4A | 52 | 5A | 62 | 6A | 72 | 7A | |
| [BP+DI]+disp8 | 011 | 43 | 4B | 53 | 5B | 63 | 6B | 73 | 7B | |
| [SI]+disp8 | 100 | 44 | 4C | 54 | 5C | 64 | 6C | 74 | 7C | |
| [DI]+disp8 | 101 | 45 | 4D | 55 | 5D | 65 | 6D | 75 | 7D | |
| [BP]+disp8 | 110 | 46 | 4E | 56 | 5E | 66 | 6E | 76 | 7E | |
| [BX]+disp8 | 111 | 47 | 4F | 57 | 5F | 67 | 6F | 77 | 7F | |
| [BX+SI]+disp16 | 10 | 000 | 80 | 88 | 90 | 98 | A0 | A8 | B0 | B8 | 
| [BX+DI]+disp16 | 001 | 81 | 89 | 91 | 99 | A1 | A9 | B1 | B9 | |
| [BP+SI]+disp16 | 010 | 82 | 8A | 92 | 9A | A2 | AA | B2 | BA | |
| [BP+DI]+disp16 | 011 | 83 | 8B | 93 | 9B | A3 | AB | B3 | BB | |
| [SI]+disp16 | 100 | 84 | 8C | 94 | 9C | A4 | AC | B4 | BC | |
| [DI]+disp16 | 101 | 85 | 8D | 95 | 9D | A5 | AD | B5 | BD | |
| [BP]+disp16 | 110 | 86 | 8E | 96 | 9E | A6 | AE | B6 | BE | |
| [BX]+disp16 | 111 | 87 | 8F | 97 | 9F | A7 | AF | B7 | BF | |
| EAX/AX/AL | 11 | 000 | C0 | C8 | D0 | D8 | E0 | E8 | F0 | F8 | 
| ECX/CX/CL | 001 | C1 | C9 | D1 | D9 | E1 | E9 | F1 | F9 | |
| EDX/DX/DL | 010 | C2 | CA | D2 | DA | E2 | EA | F2 | FA | |
| EBX/BX/BL | 011 | C3 | CB | D3 | DB | E3 | EB | F3 | FB | |
| ESP/SP/AH | 100 | C4 | CC | D4 | DC | E4 | EC | F4 | FC | |
| EBP/BP/CH | 101 | C5 | CD | D5 | DD | E5 | ED | F5 | FD | |
| ESI/SI/DH | 110 | C6 | CE | D6 | DE | E6 | EE | F6 | FE | |
| EDI/DI/BH | 111 | C7 | CF | D7 | DF | E7 | EF | F7 | FF | |
Notes:
- disp8 denotes an 8-bit displacement following the ModR/M byte, to be sign-extended and added to the index.
- disp16 denotes a 16-bit displacement following the ModR/M byte, to be added to the index. Default segment register is SS for the effective addresses containing a BP index, DS for other effective addresses.
32-Bit Addressing Forms with the ModR/M Byte
| r8(/r) r16(/r) r32(/r) /digit (Opcode) REG = | AL AX EAX 0 000 | CL CX ECX 1 001 | DL DX EDX 2 010 | BL BX EBX 3 011 | AH SP ESP 4 100 | CH BP EBP 5 101 | DH SI ESI 6 110 | BH DI EDI 7 111 | ||
| Effective Address | MOD | R/M | MODR/M Values in Hexadecimal | |||||||
| [EAX] | 00 | 000 | 00 | 08 | 10 | 18 | 20 | 28 | 30 | 38 | 
| [ECX] | 001 | 01 | 09 | 11 | 19 | 21 | 29 | 31 | 39 | |
| [EDX] | 010 | 02 | 0A | 12 | 1A | 22 | 2A | 32 | 3A | |
| [EBX] | 011 | 03 | 0B | 13 | 1B | 23 | 2B | 33 | 3B | |
| [--][--] | 100 | 04 | 0C | 14 | 1C | 24 | 2C | 34 | 3C | |
| disp32 | 101 | 05 | 0D | 15 | 1D | 25 | 2D | 35 | 3D | |
| [ESI] | 110 | 06 | 0E | 16 | 1E | 26 | 2E | 36 | 3E | |
| [EDI] | 111 | 07 | 0F | 17 | 1F | 27 | 2F | 37 | 3F | |
| disp8[EAX] | 01 | 000 | 40 | 48 | 50 | 58 | 60 | 68 | 70 | 78 | 
| disp8[ECX] | 001 | 41 | 49 | 51 | 59 | 61 | 69 | 71 | 79 | |
| disp8[EDX] | 010 | 42 | 4A | 52 | 5A | 62 | 6A | 72 | 7A | |
| disp8[EBX] | 011 | 43 | 4B | 53 | 5B | 63 | 6B | 73 | 7B | |
| disp8[--][--] | 100 | 44 | 4C | 54 | 5C | 64 | 6C | 74 | 7C | |
| disp8[EBP] | 101 | 45 | 4D | 55 | 5D | 65 | 6D | 75 | 7D | |
| disp8[ESI] | 110 | 46 | 4E | 56 | 5E | 66 | 6E | 76 | 7E | |
| disp8[EDI] | 111 | 47 | 4F | 57 | 5F | 67 | 6F | 77 | 7F | |
| disp32[EAX] | 10 | 000 | 80 | 88 | 90 | 98 | A0 | A8 | B0 | B8 | 
| disp32[ECX] | 001 | 81 | 89 | 91 | 99 | A1 | A9 | B1 | B9 | |
| disp32[EDX] | 010 | 82 | 8A | 92 | 9A | A2 | AA | B2 | BA | |
| disp32[EBX] | 011 | 83 | 8B | 93 | 9B | A3 | AB | B3 | BB | |
| disp32[--][--] | 100 | 84 | 8C | 94 | 9C | A4 | AC | B4 | BC | |
| disp32[EBP] | 101 | 85 | 8D | 95 | 9D | A5 | AD | B5 | BD | |
| disp32[ESI] | 110 | 86 | 8E | 96 | 9E | A6 | AE | B6 | BE | |
| disp32[EDI] | 111 | 87 | 8F | 97 | 9F | A7 | AF | B7 | BF | |
| EAX/AX/AL | 11 | 000 | C0 | C8 | D0 | D8 | E0 | E8 | F0 | F8 | 
| ECX/CX/CL | 001 | C1 | C9 | D1 | D9 | E1 | E9 | F1 | F9 | |
| EDX/DX/DL | 010 | C2 | CA | D2 | DA | E2 | EA | F2 | FA | |
| EBX/BX/BL | 011 | C3 | CB | D3 | DB | E3 | EB | F3 | FB | |
| ESP/SP/AH | 100 | C4 | CC | D4 | DC | E4 | EC | F4 | FC | |
| EBP/BP/CH | 101 | C5 | CD | D5 | DD | E5 | ED | F5 | FD | |
| ESI/SI/DH | 110 | C6 | CE | D6 | DE | E6 | EE | F6 | FE | |
| EDI/DI/BH | 111 | C7 | CF | D7 | E7 | EF | F7 | FF | ||
Notes:
- [--][--] means a SIB follows the ModR/M byte.
- disp8 denotes an 8-bit displacement following the SIB byte, to be sign-extended and added to the index.
- disp32 denotes a 32-bit displacement following the SIB byte, to be added to the index.
32-Bit Addressing Forms with the SIB Byte
| r32 | EAX | ECX | EDX | EBX | ESP | [*] | ESI | EDI | ||
|---|---|---|---|---|---|---|---|---|---|---|
| Base = | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | ||
| Base = | 000 | 001 | 010 | 011 | 100 | 101 | 110 | 111 | ||
| Scaled Index | SS | Index | SIB Values in Hexadecimal | |||||||
| [EAX] | 00 | 000 | 00 | 01 | 02 | 03 | 04 | 05 | 06 | 07 | 
| [ECX] | 001 | 08 | 09 | 0A | 0B | 0C | 0D | 0E | 0F | |
| [EDX] | 010 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | |
| [EBX] | 011 | 18 | 19 | 1A | 1B | 1C | 1D | 1E | 1F | |
| none | 100 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | |
| [EBP] | 101 | 28 | 29 | 2A | 2B | 2C | 2D | 2E | 2F | |
| [ESI] | 110 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | |
| [EDI] | 111 | 38 | 39 | 3A | 3B | 3C | 3D | 3E | 3F | |
| [EAX*2] | 01 | 000 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 | 
| [ECX*2] | 001 | 48 | 49 | 4A | 4B | 4C | 4D | 4E | 4F | |
| [EDX*2] | 010 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | |
| [EBX*2] | 011 | 58 | 59 | 5A | 5B | 5C | 5D | 5E | 5F | |
| none | 100 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | 67 | |
| [EBP*2] | 101 | 68 | 69 | 6A | 6B | 6C | 6D | 6E | 6F | |
| [ESI*2] | 110 | 70 | 71 | 72 | 73 | 74 | 75 | 76 | 77 | |
| [EDI*2] | 111 | 78 | 79 | 7A | 7B | 7C | 7D | 7E | 7F | |
| [EAX*4] | 10 | 000 | 80 | 81 | 82 | 83 | 84 | 85 | 86 | 87 | 
| [ECX*4] | 001 | 88 | 89 | 8A | 8B | 8C | 8D | 8E | 8F | |
| [EDX*4] | 010 | 90 | 91 | 92 | 93 | 94 | 95 | 96 | 97 | |
| [EBX*4] | 011 | 98 | 89 | 9A | 9B | 9C | 9D | 9E | 9F | |
| none | 100 | A0 | A1 | A2 | A3 | A4 | A5 | A6 | A7 | |
| [EBP*4] | 101 | A8 | A9 | AA | AB | AC | AD | AE | AF | |
| [ESI*4] | 110 | B0 | B1 | B2 | B3 | B4 | B5 | B6 | B7 | |
| [EDI*4] | 111 | B8 | B9 | BA | BB | BC | BD | BE | BF | |
| [EAX*8] | 11 | 000 | C0 | C1 | C2 | C3 | C4 | C5 | C6 | C7 | 
| [ECX*8] | 001 | C8 | C9 | CA | CB | CC | CD | CE | CF | |
| [EDX*8] | 010 | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | |
| [EBX*8] | 011 | D8 | D9 | DA | DB | DC | DD | DE | DF | |
| none | 100 | E0 | E1 | E2 | E3 | E4 | E5 | E6 | E7 | |
| [EBP*8] | 101 | E8 | E9 | EA | EB | EC | ED | EE | EF | |
| [ESI*8] | 110 | F0 | F1 | F2 | F3 | F4 | F5 | F6 | F7 | |
| [EDI*8] | 111 | F8 | F9 | FA | FB | FC | FD | FE | FF | |
Notes: [*] means a disp32 with no base if MOD is 00, [EBP] otherwise. This provides the following addressing modes:
disp32[index] (MOD=00) disp8[EBP][index] (MOD=01) disp32[EBP][index] (MOD=10)
How to Read the Instruction Set Pages
The following sections describe how to interpret the description pages for each instruction listed in the Intel Instruction Set section. Each instruction family is introduced by a descriptive heading such as the following:
- CMC-Complement Carry Flag
Each instruction family may be accompanied by descriptive sections labeled as follows: Details Table, Operation, Flags Affected, Protected Mode Exceptions, Real Address Mode Exceptions, Virtual-8086 Mode Exceptions, and optionally, a Notes section. The following sections explain the notational conventions and abbreviations used in these paragraphs of the instruction descriptions.
Details Table
For each instruction family, a table is given to list the details of each individual instruction. The following is an example of this table:
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F5 | CMC | 2 | 2 | 2 | 2 | 2 | 2 | Complement carry flag | 
The Encoding, Instruction, and Description columns are described in the following sections. The columns labeled 0, 1, 2, 3, 4, and 5 are collectively described in the Clocks section. A timing entry appearing in one of these columns is an indication that the associated processor implements that particular instruction variation. The column names are abbreviated, and are described as follows:
- 0 The 8088/8086/8087 Processor Family
- 1 The 80186/8087 Processor Family
- 2 The 80286/80287 Processor Family
- 3 The 80386/80387 Processor Family
- 4 The 80486 Processor Family
- 5 The Pentium Processor Family
Encoding Column
The "Encoding" column gives the complete object code produced for each form of the instruction. When possible, the codes are given as hexadecimal bytes, in the same order in which they appear in memory. Definitions of entries other than hexadecimal bytes are as follows:
- /digit: (digit is between 0 and 7) indicates that the ModR/M byte of the instruction uses only the r/m (register or memory) operand. The reg field contains the digit that provides an extension to the instruction's opcode.
- /r: indicates that the ModR/M byte of the instruction contains both a register operand and an r/m operand.
- cb, cw, cd, cp: a 1-byte (cb), 2-byte (cw), 4-byte (cd) or 6-byte (cp) value following the opcode that is used to specify a code offset and possibly a new value for the code segment register.
- ib, iw, id: a 1-byte (ib), 2-byte (iw), or 4-byte (id) immediate operand to the instruction that follows the opcode, ModR/M bytes or scale-indexing bytes. The opcode determines if the operand is a signed value. All words and doublewords are given with the low-order byte first.
- +rb, +rw, +rd: a register code, from 0 through 7, added to the hexadecimal byte given at the left of the plus sign to form a single opcode byte. The codes are:
| rb | rw | rd | 
|---|---|---|
| AL = 0 | AX = 0 | EAX = 0 | 
| CL = 1 | CX = 1 | ECX = 1 | 
| DL = 2 | DX = 2 | EDX = 2 | 
| BL = 3 | BX = 3 | EBX = 3 | 
| AH = 4 | SP = 4 | ESP = 4 | 
| CH = 5 | BP = 5 | EBP = 5 | 
| DH = 6 | SI = 6 | ESI = 6 | 
| BH = 7 | DI = 7 | EDI = 7 | 
- +i: used in floating-point instructions when one of the operands is ST(i) from the FPU register stack. The number i (which can range from 0 to 7) is added to the hexadecimal byte given at the left of the plus sign to form a single opcode byte.
Instruction Column
The "Instruction" column gives the syntax of the instruction statement as it would appear in an assembler program. The following is a list of the symbols used to represent operands in the instruction statements:
- rel8
- A relative address in the range from 128 bytes before the end of the instruction to 127 bytes after the end of the instruction.
- rel16
- A relative address in the range from 32768 bytes before the end of the instruction to 32767 bytes after the end of the instruction. Applies to instructions with an operand-size attribute of 16 bits, and must be within the same code segment as the instruction assembled.
- rel32
- A relative address in the range from 2147483648 bytes before the end of the instruction to 2147483647 bytes after the end of the instruction. Applies to instructions with an operand-size attribute of 32 bits, and must be within the same code segment as the instruction assembled.
- ptr16
- 16:A far pointer, typically in a code segment different from that of the instruction. The notation 16:16 indicates that the value of the pointer has two parts. The value to the left of the colon is a 16-bit selector or value destined for the code segment register. The value to the right reflects the operand-size attribute of the instruction (16 bits) and corresponds to the offset within the destination segment.
- ptr16:32
- A far pointer, typically in a code segment different from that of the instruction. The notation 16:32 indicates that the value of the pointer has two parts. The value to the left of the colon is a 16-bit selector or value destined for the code segment register. The value to the right reflects the operand-size attribute of the instruction (32 bits) and corresponds to the offset within the destination segment.
- r8
- One of the byte registers AL, CL, DL, BL, AH, CH, DH, or BH.
- r16
- One of the word registers AX, CX, DX, BX, SP, BP, SI, or DI.
- r32
- One of the doubleword registers EAX, ECX, EDX, EBX, ESP, EBP, ESI, or EDI.
- imm8
- An immediate byte value. imm8 is a signed number between -128 and +127 inclusive. For instructions in which imm8 is combined with a word or doubleword operand, the immediate value is sign-extended to form a word or doubleword. The upper byte of the word is filled with the topmost bit of the immediate value.
- imm16
- An immediate word value used for instructions whose operand-size attribute is 16 bits. This is a number between -32768 and +32767 inclusive.
- imm32
- An immediate doubleword value used for instructions whose operand-size attribute is 32-bits. It allows the use of a number between +2147483647 and -2147483648 inclusive.
- r/m8
- A one-byte operand that is either the contents of a byte register (AL, BL, CL, DL, AH, BH, CH, DH), or a byte from memory.
- r/m16
- A word register or memory operand used for instructions whose operand-size attribute is 16 bits. The word registers are: AX, BX, CX, DX, SP, BP, SI, DI. The contents of memory are found at the address provided by the effective address computation.
- r/m32
- A doubleword register or memory operand used for instructions whose operand-size attribute is 32-bits. The doubleword registers are: EAX, EBX, ECX, EDX, ESP, EBP, ESI, EDI. The contents of memory are found at the address provided by the effective address computation.
- r/m64
- A quadword register or memory operand used for instructions whose operand- size attribute is 64-bits. The reg/opcode field represents the opcode. The contents of memory are found at the address provided by the effective address computation.
- m
- A 16 or 32-bit memory operand.
- m8
- A memory byte addressed by DS:[E]SI or ES:[E]DI (used only by string instructions).
- m16
- A memory word addressed by DS:[E]SI or ES:[E]DI (used only by string instructions).
- m32
- A memory doubleword addressed by DS:[E]SI or ES:[E]DI (used only by string instructions).
- m16:16
- A memory operand containing a far pointer composed of two numbers. The number to the left of the colon corresponds to the pointer's segment selector. The number to the right corresponds to its offset.
- m16:32
- A memory operand containing a far pointer composed of two numbers. The number to the left of the colon corresponds to the pointer's segment selector. The number to the right corresponds to its offset.
- m16&16
- A memory operand consisting of data item pairs whose sizes are indicated on the left and the right side of the ampersand. All memory addressing modes are allowed. Used by the BOUND instruction to provide an operand containing an upper and lower bounds for array indices.
- m16&32
- A memory operand consisting of data item pairs whose sizes are indicated on the left and the right side of the ampersand. All memory addressing modes are allowed. Used by the by LIDT and LGDT to provide a word with which to load the limit field, and a doubleword with which to load the base field of the corresponding Global and Interrupt Descriptor Table Registers.
- m32&32
- A memory operand consisting of data item pairs whose sizes are indicated on the left and the right side of the ampersand. All memory addressing modes are allowed. Used by the BOUND instruction to provide an operand containing an upper and lower bounds for array indices.
- moffs8
- The memory offset of a BYTE variable used in some variants of the MOV instruction. The actual address is given by a simple offset relative to the segment base. No ModR/M byte is used in the instruction. The address- size attribute of the instruction determines the size of the offset data.
- moffs16
- The memory offset of a WORD variable used in some variants of the MOV instruction. The actual address is given by a simple offset relative to the segment base. No ModR/M byte is used in the instruction. The address- size attribute of the instruction determines the size of the offset data.
- moffs32
- The memory offset of a DWORD variable used in some variants of the MOV instruction. The actual address is given by a simple offset relative to the segment base. No ModR/M byte is used in the instruction. The address- size attribute of the instruction determines the size of the offset data.
- Sreg
- A segment register. The segment register bit assignments are ES=0, CS=1, SS=2, DS=3, FS=4, and GS=5.
- m32real
- A single-precision floating-point operand in memory.
- m64real
- A double-precision floating-point operand in memory.
- m80real
- An extended-precision floating-point operand in memory.
- m80bcd
- A 80 byte binary-coded decimal operand in memory.
- m16int
- A word integer operand in memory. Used in some floating-point instructions.
- m32int
- A short integer operand in memory. Used in some floating-point instructions.
- m64int
- A long integer operand in memory. Used in some floating-point instructions.
- m14byte
- A 14-byte floating-point operand in memory.
- m28byte
- A 28-byte floating-point operand in memory.
- m94byte
- A 94-byte floating-point operand in memory.
- m108byte
- A 108-byte floating-point operand in memory.
- ST or ST(0)
- Top element of the FPU register stack.
- ST(i)
- ith element from the top of the FPU register stack. (i=0..7)
Clocks Columns
Each "Clocks" column gives the approximate number of clock cycles the instruction takes to execute on that particular processor. The clock count calculations makes the following assumptions:
- Data and instruction accesses hit in the cache.
- The target of a jump instruction is in the cache.
- No invalidate cycles contend with the instruction for use of the cache.
- Page translation hits in the TLB.
- Memory operands are aligned.
- Effective address calculations use a base register which is not the destination register of the preceding instruction.
- No exceptions are detected during execution.
- There are no write-buffer delays.
The following symbols are used in the clock count specifications:
- n, which represents a number of repetitions.
- m, which represents the number of components in the next instruction executed, where the entire displacement (if any) counts as one component, the entire immediate data (if any) counts as one component, and every other byte of the instruction and prefix(es) each counts as one component.
- pm:, a clock count that applies when the instruction executes in Protected Mode. pm: is not given when the clock counts are the same for Protected and Real Address Modes.
When an exception occurs during the execution of an instruction and the exception handler is in another task, the instruction execution time is increased by the number of clocks to effect a task switch. This parameter depends on several factors:
- The type of TSS used to represent the new task (32 bit TSS or 16 bit TSS).
- Whether the current task is in V86 mode.
- Whether the new task is in V86 mode.
- Whether accesses hit in the cache.
- Whether a task gate on an interrupt/trap gate is used.
The following table summarizes the task switch times for exceptions, assuming cache hits and the use of task gates.
Task Switch Times for Exceptions
| OLD TASK | NEW TASK | ||
| TO 32 BIT TSS | TO 16 BIT TSS | TO VM TSS | |
| VM/32 bit/16 bit TSS | 85 | 87 | 71 | 
Description Column
The "Description" column following the "Clocks" columns briefly explains the various forms of the instruction. The "Operation" and "Description" sections contain more details of the instruction's operation.
Description
The "Description" section contains further explanation of the instruction's operation.
Operation
The "Operation" section contains an algorithmic description of the instruction which uses a notation similar to the Algol or Pascal language. The algorithms are composed of the following elements:
- Comments are enclosed within the symbol pairs "(*" and "*)".
- Compound statements are enclosed between the keywords of the "if" statement (IF, THEN, ELSE, FI) or of the "do" statement (DO, OD), or of the "case" statement (CASE ... OF, ESAC).
- Execution continues until the END statement is encountered.
- A register name implies the contents of the register. A register name enclosed in brackets implies the contents of the location whose address is contained in that register. For example, ES:[DI] indicates the contents of the location whose ES segment relative address is in register DI. [SI] indicates the contents of the address contained in register SI relative to SI's default segment (DS) or overridden segment.
- Brackets are also used for memory operands, where they mean that the contents of the memory location is a segment-relative offset. For example, [SRC] indicates that the contents of the source operand is a segment- relative offset.
- A ← B; indicates that the value of B is assigned to A.
- The symbols =, <>, ò, and ó are relational operators used to compare two values, meaning equal, not equal, greater or equal, less or equal, respectively. A relational expression such as A = B is TRUE if the value of A is equal to B; otherwise it is FALSE.
- A * B indicates that the value of A is multiplied by the value of B.
The following identifiers are used in the algorithmic descriptions:
- OperandSize represents the operand-size attribute of the instruction, which is either 16 or 32 bits. AddressSize represents the address-size attribute, which is either 16 or 32 bits. For example,
IF instruction = CMPSW THEN OperandSize ← 16; ELSE IF instruction = CMPSD THEN OperandSize ← 32; FI; FI;
indicates that the operand-size attribute depends on the form of the CMPS instruction used. Refer to the explanation of address-size and operand-size attributes at the beginning of this chapter for general guidelines on how these attributes are determined.
- StackAddrSize represents the stack address-size attribute associated with the instruction, which has a value of 16 or 32 bits, as explained earlier in the chapter.
- SRC represents the source operand. When there are two operands, SRC is the one on the right.
- DEST represents the destination operand. When there are two operands, DEST is the one on the left.
- LeftSRC, RightSRC distinguishes between two operands when both are source operands.
- eSP represents either the SP register or the ESP register depending on the setting of the B-bit for the current stack segment.
The following functions are used in the algorithmic descriptions:
- Truncate to 16 bits(value) reduces the size of the value to fit in 16 bits by discarding the uppermost bits as needed.
- Addr(operand) returns the effective address of the operand (the result of the effective address calculation prior to adding the segment base).
- ZeroExtend(value) returns a value zero-extended to the operand-size attribute of the instruction. For example, if OperandSize = 32, ZeroExtend of a byte value of -10 converts the byte from F6H to doubleword with hexadecimal value 000000F6H. If the value passed to ZeroExtend and the operand-size attribute are the same size, ZeroExtend returns the value unaltered.
- SignExtend(value) returns a value sign-extended to the operand-size attribute of the instruction. For example, if OperandSize = 32, SignExtend of a byte containing the value -10 converts the byte from F6H to a doubleword with hexadecimal value FFFFFFF6H. If the value passed to SignExtend and the operand-size attribute are the same size, SignExtend returns the value unaltered.
- Push(value) pushes a value onto the stack. The number of bytes pushed is determined by the operand-size attribute of the instruction. The action of Push is as follows:
IF StackAddrSize = 16 
THEN 
  IF OperandSize = 16 
  THEN
     SP ← SP -2;
     SS:[SP] ← value; (* 2 bytes assigned starting at byte address in SP *)
  ELSE (* OperandSize = 32 *)
     SP ← SP -4;
     SS:[SP] ← value; (* 4 bytes assigned starting at byte address in SP *)
  FI;
ELSE (* StackAddrSize = 32 *)
  IF OperandSize = 16 
  THEN
  ESP ← ESP -2;
     SS:[ESP] ← value; (* 2 bytes assigned starting at byte address in ESP*)
  ELSE (* OperandSize = 32 *)
     ESP ← ESP -4;
     SS:[ESP] ← value; (* 4 bytes assigned starting at byte address in ESP*)
  FI;
FI;
- Pop(value) removes the value from the top of the stack and returns it. The statement EAX ← Pop( ); assigns to EAX the 32-bit value that Pop took from the top of the stack. Pop will return either a word or a doubleword depending on the operand-size attribute. The action of Pop is as follows:
IF StackAddrSize = 16 
THEN 
  IF OperandSize = 16 
  THEN
     ret val ← SS:[SP]; (* 2-byte value *)
     SP ← SP + 2;
  ELSE (* OperandSize = 32 *)
     ret val ← SS:[SP]; (* 4-byte value *)
     SP ← SP + 4;
  FI;
ELSE (* StackAddrSize = 32 *)
  IF OperandSize = 16 
  THEN
     ret val ← SS:[ESP]; (* 2 byte value *)
     ESP ← ESP + 2;
  ELSE (* OperandSize = 32 *)
     ret val ← SS:[ESP]; (* 4 byte value *)
     ESP ← ESP + 4;
  FI;
FI;
RETURN(ret val); (*returns a word or doubleword*)
Pop ST is used on floating-point instruction pages to mean pop the FPU register stack.
- Bit[BitBase, BitOffset] returns the value of a bit within a bit string, which is a sequence of bits in memory or a register. Bits are numbered from low-order to high-order within registers and within memory bytes. In memory, the two bytes of a word are stored with the low-order byte at the lower address.
If the base operand is a register, the offset can be in the range 0..31. This offset addresses a bit within the indicated register. An example, 'BIT [EAX, 21]' is illustrated in the following figure.
Bit Offset for BIT[EAX,21]
  31            21                            0
┌──────────────┬──┬────────────────────────────┐
└──────────────┴──┴────────────────────────────┘
                 ↑                             ↑
                 │                             │
                 └────────BITOFFSET=21─────────┘
If BitBase is a memory address, BitOffset can range from -2 gigabits to 2 gigabits. The addressed bit is numbered (Offset MOD 8) within the byte at address (BitBase + (BitOffset DIV 8)), where DIV is signed division with rounding towards negative infinity, and MOD returns a positive number. This is illustrated in the following figure.
Memory Bit Indexing
 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0
 ┌──┬──┬────────┬────────────────┬──────────────┐
 └──┴──┴────────┴────────────────┴──────────────┘
 │  BITBASE+1   │    BITBASE     │   BITBASE-1  │
     ↑                           │
     └──────OFFSET=+13───────────┘
 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 0
 ┌──────────────┬────────────────┬──────────────┐
 └──────────────┴────────────────┴──────────────┘
 │  BITBASE     │   BITBASE-1    │   BITBASE-2  │
                │                      ↑
                └─────OFFSET=-11───────┘
- I-O-Permission(I-O-Address, width) returns TRUE or FALSE depending on the I/O permission bitmap and other factors. This function is defined as follows:
IF TSS type is 16-bit THEN RETURN FALSE; FI; Ptr← [TSS+66]; (* fetch bitmap pointer *) BitStringAddr ← SHR (I-O-Address, 3) + Ptr; MaskShift ← I-O-Address AND 7; CASE width OF: BYTE: nBitMask ← 1; WORD: nBitMask ← 3; DWORD: nBitMask ← 15; ESAC; mask ← SHL (nBitMask, MaskShift); CheckString ← [BitStringAddr] AND mask; IF CheckString = 0 THEN RETURN (TRUE); ELSE RETURN (FALSE); FI;
- Switch-Tasks is described in detail in the Intel documentation.
Flags Affected
Pages describing basic instructions have a "Flags Affected" section the contains a flags information table similar to the following:
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| 0 | * | * | ? | * | 0 | 
The first row of the table lists the mnemonic identifiers for the various flags. The entries in the second row are filled in according to how the flag is affected by the instruction:
| VALUE | MEANING | 
|---|---|
| <blank> | Instruction does not affect flag | 
| 0 | Instruction clears the flag | 
| 1 | Instruction sets the flag | 
| ? | Instruction's effect on the flag is undefined | 
| * | Instruction modifies the flag (either sets or clears depending on operands) | 
The following table lists the mnemonic identifier, full name, and purpose of the flags that are applicable to all processor families and that are most commonly used from within application-level programs. Not all flags are included in this table; see the Intel documentation for a more complete description of flag usage from within systems-level programs.
| MNEMONIC | FLAG NAME | PURPOSE | 
|---|---|---|
| OF | Overflow | Result exceeds positive or negative limit of number range | 
| DF | Direction | Setting the DF flag causes string instructions to auto-decrement, that is, to process strings from high addresses. Clearing the DF flag causes string instructions to auto-increment, or to process strings from low addresses to high addresses. | 
| IF | Interrupt Enable | Controls the acceptance of external interrupts signalled via the INTR pin. | 
| SF | Sign | Result is negative (less than zero) | 
| ZF | Zero | Result is zero | 
| AF | Auxiliary carry | Carry out of bit position 3 (used for BCD) | 
| PF | Parity | Low byte of result has even parity (even number of set bits) | 
| CF | Carry | Carry out of most significant bit of result | 
The flags information table is usually followed by a paragraph description of how the flags are affected:
- If a flag is always cleared or always set by the instruction, the value is given (0 or 1) after the flag name. Arithmetic and logical instructions usually assign values to the status flags in a uniform manner. Nonconventional assignments are described in the Operation section.
- The values of flags listed as "undefined" may be changed by the instruction in an indeterminate manner.
All flags not listed are unchanged by the instruction.
FPU Flags Affected
The floating-point instruction pages have a section called "FPU Flags Affected," which tells how each instruction can affect the four condition code bits of the FPU status word. These pages contain a condition code information table similar to the following:
| C0 | C1 | C2 | C3 | 
|---|---|---|---|
| ? | * | ? | ? | 
The first row of the table lists the names of the floating-point condition code flags. The entries in the second row are filled in according to how the flag is affected by the instruction:
| VALUE | MEANING | 
|---|---|
| <blank> | Instruction does not affect flag | 
| 0 | Instruction clears the flag | 
| 1 | Instruction sets the flag | 
| ? | Instruction's effect on the flag is undefined | 
| * | Instruction modifies the flag (either sets or clears depending on operands) | 
The four FPU condition code bits (C0, C1, C2, and C3) are similar to the flags in a CPU; the processor updates these bits to reflect the outcome of arithmetic operations. The effect of these instructions on the condition code bits is summarized in the following table:
| INSTRUCTION | C0 | C3 | C2 | C1 | 
|---|---|---|---|---|
| FCOM, FCOMP, FCOMPP, FTST, FUCOMPP, FICOM, FICOMP | Result of Comparison | Operands is not Comparable | Zero or O/U# | |
| FXAM | Operand class | Sign or O/U# | ||
| FPREM, FPREM1 | Q2 | Q1 | 0=reduction complete 1=reduction incomplete | Q0 or O/U# | 
| FIST, FBSTP, FRINDINT, FST, FSTP, FADD, FMUL, FDIV, FDIVR, FSUB, FSUBR, FSCALE, FSQRT, FPATAN, F2XM1, FYL2X, FYL2XP1 | UNDEFINED | Roundup or O/U# | ||
| FPTAN, FSIN, FCOS, FSINCOS | UNDEFINED | 0=reduction complete 1=reduction incomplete | Roundup or O/U# (UNDEFINED if C2=1) | |
| FCHS, FABS, FXCH, FINCSTP, FDECSTP, Constant Loads, FXTRACT, FLD, FILD, FBLD, FSTP (ext. real) | UNDEFINED | Zero or O/U# | ||
| FLDENV, FRSTOR | Each bit loaded from memory | |||
| FLDCW, FSTENV, FSTCW, FSTSW, FCLEX | UNDEFINED | |||
| FINIT, FSAVE | Zero | Zero | Zero | Zero | 
NOTES: O/U# When both IE and SF bits of status word are set, this bit distinguishes between stack overflow (C1=1) and underflow (C1=0).
Reduction If FPREM and FPREM1 produces a remainder that is less than the modulus, reduction is complete. When reduction is incomplete the value at the top of the stack is a parial remainder, which can be used as input to further reduction. For FPTAN, FSIN, FCOS and FSINCOS, the reduction bit is set if the operand at the top of the stack is too large. In this case, the original operand remains at the top of the stack.
Roundup When the PE bit of the status word is set, this bit indicates whether the last rounding in the instruction was upward.
UNDEFINED Do not rely on any specific value in these bits.
The condition code bits are used primarily for conditional branching. The FSTSW AX instruction stores the FPU status word directly into the AX register, allowing these condition codes to be inspected efficiently. The SAHF instruction can copy C3 - C0 directly to the CPU's flag bits to simplify conditional branching. The following table shows the mapping of these bits to the CPU flag bits.
| FPU FLAG | IU FLAG | 
|---|---|
| C0 | CF | 
| C1 | (None) | 
| C2 | PF | 
| C3 | ZF | 
Numeric Exceptions
For floating-point instruction pages, this section lists the exception flags of the FPU status word that each instruction can set. Exceptions are listed in abbreviated form, and are defined as follows:
- IS Invalid operand due to stack overflow/underflow
- I Invalid operand due to other cause
- D Denormalized operand
- Z Divide by zero
- O Numeric overflow
- U Numeric underflow
- P Inexact result (precision)
Protected Mode Exceptions
This section lists the exceptions that can occur when the instruction is executed in protected mode. The exception names are a pound sign (#) followed by two letters and an optional error code in parentheses. For example, #GP(0) denotes a general protection exception with an error code of 0. The following table associates each two-letter name with the corresponding interrupt number.
| MNEMONIC | INTERRUPT | DESCRIPTION | 
|---|---|---|
| #UD | 6 | Invalid opcode | 
| #NM | 7 | Device not available | 
| #DF | 8 | Double fault | 
| #TS | 10 | Invalid TSS | 
| #NP | 11 | Segment or gate not present | 
| #SS | 12 | Stack fault | 
| #GP | 13 | General protection fault | 
| #PF | 14 | Page fault | 
| #MF | 16 | Floating-point error | 
| #AC | 17 | Alignment check | 
Refer to the Intel documentation for a description of the exceptions and the processor state upon entry to the exception. Application programmers should consult the documentation provided with their operating systems to determine the actions taken when exceptions occur.
Real Address Mode Exceptions
Because less error checking is performed by the processor in Real Address Mode, this mode has fewer exception conditions. Refer to the Intel documentation for further information on these exceptions.
Virtual-8086 Mode Exceptions
Virtual 8086 tasks provide the ability to simulate Virtual 8086 machines. Virtual 8086 Mode exceptions are similar to those for the 8086 processor, but there are some differences. Refer to the Intel documentation for complete information on Virtual Mode exceptions.
Intel Instruction Set
The following section describes the individual processor instructions in detail.
AAA - ASCII Adjust after Addition
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 37 | AAA | X | X | X | X | X | X | ASCII adjust AL after addition | 
- Description
Run the AAA instruction only following an ADD instruction that leaves a byte result in the AL register. The lower nibbles of the operands of the ADD instruction should be in the range 0 through 9 (BCD digits). In this case, the AAA instruction adjusts the AL register to contain the correct decimal digit result. If the addition produced a decimal carry, the AH register is incremented, and the CF and AF flags are set. If this same addition also produced FH in the upper nibble of AL then AH is incremented again. If there was no decimal carry, the CF and AF flags are cleared and the AH register is unchanged. In either case, the AL register is left with its top nibble set to 0. To convert the AL register to an ASCII result, follow the AAA instruction with OR AL, 30H.
- Operation
ALcarry ← AL > 0F9H; (* 1 if true *) IF ((AL AND 0FH) > 9) OR (AF = 1) THEN AL ← (AL + 6) AND 0FH; AH ← AH + 1 + ALcarry; AF ← 1; CF ← 1; ELSE AF ← 0; CF ← 0; AL ← AL AND 0FH; FI;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| ? | ? | ? | * | ? | * | 
The AF and CF flags are set if there is a decimal carry, cleared if there is no decimal carry; the OF, SF, ZF, and PF flags are undefined.
AAD - ASCII Adjust AX before Division
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D5 0A | AAD | X | X | X | X | X | X | ASCII adjust before division | 
- Description
The AAD instruction is used to prepare two unpacked BCD digits (the least-significant digit in the AL register, the most-significant digit in the AH register) for a division operation that will yield an unpacked result. This is accomplished by setting the AL register to AL+ (second byte of opcode * AH), and then clearing the AH register. The AX register is then equal to the binary equivalent of the original unpacked two-digit number.
- Operation
regAL = AL; regAH = AH; AL ← (regAH * imm8 + regAL) AND OFFH; AH ← 0;
Note: imm8 has the value of the instruction's second byte. The second byte under normally assembly of this instruction will be 0A, however, explicit modification of this byte will result in the operation described above and may alter results.
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| ? | * | * | ? | * | ? | 
The SF, ZF, and PF flags are set according to the result; the OF, AF, and CF flags are undefined.
AAM - ASCII Adjust AX after Multiply
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D4 0A | AAM | X | X | X | X | X | X | ASCII adjust AX after | 
- Description
Run the AAM instruction only after running a MUL instruction between two unpacked BCD digits that leaves the result in the AX register. Because the result is less than 100, it is contained entirely in the AL register. The AAM instruction unpacks the AL result by dividing AL by the second byte of the opcode, leaving the quotient (most-significant digit) in the AH register and the remainder (least-significant digit) in the AL register.
- Operation
regAL ← AL; AH ← regAL / imm8; AL ← regAL MOD imm8;
Note: imm8 has the value of the instruction's second byte. The second byte under normally assembly of this instruction will be 0A., however, explicit modification of this byte will result in the operation described above and may alter results.
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
| ? | * | * | ? | * | ? | 
The SF, ZF, and PF flags are set according to the result; the OF, AF, and CF flags are undefined.
AAS - ASCII Adjust AL after Subtraction
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 3F | AAS | X | X | X | X | X | X | ASCII adjust AL after subtraction | 
- Description
Run the AAS instruction only after a SUB instruction that leaves the byte result in the AL register. The lower nibbles of the operands of the SUB instruction must have been in the range of 0 through 9 (BCD digits). In this case, the AAS instruction adjusts the AL register so it contains the correct decimal digit result. If the subtraction produced a decimal carry, the AH register is decremented, and the CF and AF flags are set. If no decimal carry occurred, the CF and AF flags are cleared, and the AH register is unchanged. In either case, the AL register is left with its top nibble set to 0. To convert the AL result to an ASCII result, follow the AAS instruction with OR AL, 30H.
- Operation
ALborrow ← AL < 6; (* 1 if true *) IF (AL AND 0FH) > 9 OR AF = 1 THEN AL ← (AL - 6) AND 0FH; AH ← AH - 1 - ALborrow; AF ← 1; CF ← 1; ELSE CF ← 0; AF ← 0; AL ← AL AND 0FH FI;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
| ? | ? | ? | * | ? | * | 
The AF and CF flags are set if there is a decimal carry, cleared if there is no decimal carry; the OF, SF, ZF, and PF flags are undefined.
ADC - Add with Carry
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 14 ib | ADC AL,imm8 | X | X | X | X | X | X | Add with carry immediate byte to AL | 
| 15 iw | ADC AX,imm16 | X | X | X | X | X | X | Add with carry immediate word to AX | 
| 15 id | ADC EAX,imm32 | X | X | X | Add with carry immediate dword to EAX | |||
| 80 /2 ib | ADC r/m8,imm8 | X | X | X | X | X | X | Add with carry immediate byte to r/m byte | 
| 81 /2 iw | ADC r/m16,imm16 | X | X | X | X | X | X | Add with carry immediate word to r/m word | 
| 81 /2 id | ADC r/m32,imm32 | X | X | X | Add with carry immediate dword to r/m dword | |||
| 83 /2 ib | ADC r/m16,imm8 | X | X | X | X | X | X | Add with carry sign-extended immediate byte to r/m word | 
| 83 /2 ib | ADC r/m32,imm8 | X | X | X | Add with carry sign-extended immediate byte into r/m dword | |||
| 10 /r | ADC r/m8,r8 | X | X | X | X | X | X | Add with carry byte register to r/m byte | 
| 11 /r | ADC r/m16,r16 | X | X | X | X | X | X | Add with carry word register to r/m word | 
| 11 /r | ADC r/m32,r32 | X | X | X | Add with carry dword register to r/m word | |||
| 12 /r | ADC r8,r/m8 | X | X | X | X | X | X | Add with carry r/m byte to byte register | 
| 13 /r | ADC r16,r/m16 | X | X | X | X | X | X | Add with carry r/m word to word register | 
| 13 /r | ADC r32,r/m32 | X | X | X | Add with carry r/m dword to dword register | 
- Description
The ADC instruction performs an integer addition of the two operands DEST and SRC and the carry flag, CF. The result of the addition is assigned to the first operand (DEST), and the flags are set accordingly. The ADC instruction is usually run as part of a multi-byte or multi-word addition operation. When an immediate byte value is added to a word or doubleword operand, the immediate value is first sign-extended to the size of the word or doubleword operand.
- Operation
DEST ← DEST + SRC + CF;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| * | * | * | * | * | * | 
The OF, SF, ZF, AF, CF, and PF flags are set according to the result.
- Protected Mode Exceptions
\#GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
ADD - Add
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 04 ib | ADD AL,imm8 | X | X | X | X | X | X | Add immediate byte to AL | 
| 05 iw | ADD AX,imm16 | X | X | X | X | X | X | Add immediate word to AX | 
| 05 id | ADD EAX,imm32 | X | X | X | Add immediate dword to EAX | |||
| 80 /0 ib | ADD r/m8,imm8 | X | X | X | X | X | X | Add immediate byte to r/m byte | 
| 81 /0 iw | ADD r/m16,imm16 | X | X | X | X | X | X | Add immediate word to r/m word | 
| 81 /0 id | ADD r/m32,imm32 | X | X | X | Add immediate dword to r/m dword | |||
| 83 /0 ib | ADD r/m16,imm8 | X | X | X | X | X | X | Add sign-extended immediate byte to r/m word | 
| 83 /0 ib | ADD r/m32,imm8 | X | X | X | Add sign-extended immediate byte to r/m dword | |||
| 00 /r | ADD r/m8,r8 | X | X | X | X | X | X | Add byte register to r/m byte | 
| 01 /r | ADD r/m16,r16 | X | X | X | X | X | X | Add word register to r/m word | 
| 01 /r | ADD r/m32,r32 | X | X | X | Add dword register to r/m dword | |||
| 02 /r | ADD r8,r/m8 | X | X | X | X | X | X | Add r/m byte to byte register | 
| 03 /r | ADD r16,r/m16 | X | X | X | X | X | X | Add r/m word to word register | 
| 03 /r | ADD r32,r/m32 | X | X | X | Add r/m dword to dword register | 
- Description
The ADD instruction performs an integer addition of the two operands (DEST and SRC). The result of the addition is assigned to the first operand (DEST ), and the flags are set accordingly. When an immediate byte is added to a word or doubleword operand, the immediate value is sign-extended to the size of the word or doubleword operand.
- Operation
DEST ← DEST + SRC;
- Flags Affected
OF|DF|IF|SF|ZF|AF|PF|CF --+--+--+--+--+--+--+-- * | | |* |* |* |* |*
The OF, SF, ZF, AF, CF, and PF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) is the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
AND - Logical AND
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 24 ib | AND AL,imm8 | X | X | X | X | X | X | AND immediate byte to AL | 
| 25 iw | AND AX,imm16 | X | X | X | X | X | X | AND immediate word to AX | 
| 25 id | AND EAX,imm32 | X | X | X | AND immediate dword to EAX | |||
| 80 /r ib | AND r/m8,imm8 | X | X | X | X | X | X | AND immediate byte to r/m byte | 
| 81 /4 iw | AND r/m16,imm16 | X | X | X | X | X | X | AND immediate word to r/m word | 
| 81 /r id | AND r/m32,imm32 | X | X | X | AND immediate dword to r/m dword | |||
| 83 /4 ib | AND r/m16,imm8 | X | X | X | AND sign-extended immediate byte to r/m word | |||
| 83 /4 ib | AND r/m32,imm8 | X | X | X | AND sign-extended immediate byte with r/m dword | |||
| 20 /r | AND r/m8,r8 | X | X | X | X | X | X | AND byte register to r/m byte | 
| 21 /r | AND r/m16,r16 | X | X | X | X | X | X | AND word register to r/m word | 
| 21 /r | AND r/m32,r32 | X | X | X | AND dword register to r/m dword | |||
| 22 /r | AND r8,r/m8 | X | X | X | X | X | X | AND r/m byte to byte register | 
| 23 /r | AND r16,r/m16 | X | X | X | X | X | X | AND r/m word to word register | 
| 23 /r | AND r32,r/m32 | X | X | X | AND r/m dword to dword register | 
- Description
Each bit of the result of the AND instruction is a 1 if both corresponding bits of the operands are 1; otherwise, it becomes a 0.
- Operation
DEST ← DEST AND SRC; CF ← 0; OF ← 0;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| 0 | * | * | ? | * | 0 | 
The CF and OF flags are cleared; the PF, SF, and ZF flags are set according to the result; the AF flag is undefined.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
ARPL - Adjust RPL Field of Selector
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 63 /r | ARPL r/m16,r16 | X | X | X | X | Adjust RPL of r/m16 to not less than RPL of r16 | 
- Description
The ARPL instruction has two operands. The first operand is a 16-bit memory variable or word register that contains the value of a selector. The second operand is a word register. If the RPL field ("requested privilege level" - bottom two bits) of the first operand is less than the RPL field of the second operand, the ZF flag is set and the RPL field of the first operand is increased to match the second operand. Otherwise, the ZF flag is cleared and no change is made to the first operand. The ARPL instruction appears in operating system software, not in application programs. It is used to guarantee that a selector parameter to a subroutine does not request more privilege than the caller is allowed. The second operand of the ARPL instruction is normally a register that contains the CS selector value of the caller.
- Operation
IF RBL bits(0,1) of DEST < RPL bits(0,1) of SRC THEN ZF ← 1; RPL bits(0,1) of DEST ← RPL bits (0,1) of SRC; ELSE ZF ← 0; FI;
- Flags Affected
OF|DF|IF|SF|ZF|AF|PF|CF --+--+--+--+--+--+--+-- | | | |* | | |
The ZF flag is set if the RPL field of the first operand is less than that of the second operand, otherwise ZF is cleared.
- Protected Mode Exceptions
- GP(0) if the result is a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 6; the ARPL instruction is not recognized in Real Address Mode.
- Virtual 8086 Mode Exceptions
Interrupt 6; the ARPL instruction is not recognized in Virtual 8086 Mode.
BOUND - Check Array Index Against Bounds
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 62 /r | BOUND r16,m16&16 | X | X | X | X | X | Check if r16 is within m16&16 bounds (passes test) | |
| 62 /r | BOUND r32,m32&32 | X | X | X | Check if r32 is within m32&32 bounds (passes test) | 
- Description
The BOUND instruction ensures that a signed array index is within the limits specified by a block of memory consisting of an upper and a lower bound. Each bound uses one word when the operand-size attribute is 16-bits and a doubleword when the operand-size attribute is 32-bits. The first operand (a register) must be greater than or equal to the first bound in memory (lower bound), and less than or equal to the second bound in memory (upper bound) plus the number of bytes occupied for the operand size. If the register is not within bounds, an Interrupt 5 occurs; the return EIP points to the BOUND instruction. The bounds limit data structure is usually placed just before the array itself, making the limits addressable via a constant offset from the beginning of the array.
- Operation
IF (LeftSRC < [RightSRC] OR LeftSRC > [RightSRC + OperandSize/8]) (* Under lower bound or over upper bound *) THEN Interrupt 5; FI;
- Protected Mode Exceptions
Interrupt 5 if the bounds test fails, as described above; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3. The second operand must be a memory operand, not a register. If the BOUND instruction is run with a ModR/M byte representing a register as the second operand, #UD occurs.
- Real Address Mode Exceptions
Interrupt 5 if the bounds test fails; Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH; Interrupt 6 if the second operand is a register.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
BSF - Bit Scan Forward
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F BC | BSF r16,r/m16 | X | X | X | Bit scan forward on r/m word | |||
| 0F BC | BSF r32,r/m32 | X | X | X | Bit scan forward on r/m dword | 
- Description
The BSF instruction scans the bits in the second word or doubleword operand starting with bit 0. The ZF flag is set if all the bits are 0; otherwise, the ZF flag is cleared and the destination register is loaded with the bit index of the first set bit.
- Operation
IF r/m = 0
THEN
   ZF ← 1;
   register ← UNDEFINED;
ELSE
   temp ← 0;
   ZF ← 0;
   WHILE BIT[r/m,temp] = 0
   DO
      temp ← temp + 1;
      register ← temp;
  OD;
FI;
- Flags Affected
OF|DF|IF|SF|ZF|AF|PF|CF --+--+--+--+--+--+--+-- ? | | |? |* |? |? |?
The ZF flag is set if all bits are 0; otherwise, the ZF flag is cleared. OF , SF, AF, PF, CF = undefined.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
BSR-Bit Scan Reverse
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F BD | BSR r16,r/m16 | X | X | X | Bit scan reverse on r/m word | |||
| 0F BD | BSR r32,r/m32 | X | X | X | Bit scan reverse on r/m dword | 
- Description
The BSR instruction scans the bits in the second word or doubleword operand from the most significant bit to the least significant bit. The ZF flag is set if all the bits are 0; otherwise, the ZF flag is cleared and the destination register is loaded with the bit index of the first set bit found when scanning in the reverse direction.
- Operation
IF r/m = 0 
THEN 
   ZF ← 1;
   register ← UNDEFINED;
ELSE 
   temp ← OperandSize =1;
   ZF ← 0;
   WHILE BIT[r/m,temp] = 0 
   DO 
      temp ← temp - 1;
      register ← temp;
  OD;
FI;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| ? | ? | * | ? | ? | ? | 
The ZF flag is set if all bits are 0; otherwise, the ZF flag is cleared. OS , SF, AF, PF, CF = undefined.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
BSWAP - Byte Swap
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F C8+rd | BSWAP r32 | X | X | Swap bytes to convert little/big endian data in a 32-bit register to big/little endian form | 
- Description
The BSWAP instruction reverses the byte order of a 32-bit register, converting a value in little/big endian form to big/little endian form. When BSWAP is used with 16-bit operand size, the result left in the destination register is undefined.
- Operation
TEMP ← r32 r32(7..0) ← TEMP(31..24) r32(15..8) ← TEMP(23..16) r32(23..16) ← TEMP(15..8) r32(31..24) ← TEMP(7.0)
- Notes
BSWAP is not supported on Intel386 processors. Include functionally-equivalent code for Intel386 CPUs.
BT - Bit Test
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F A3 | BT r/m16,r16 | X | X | X | Save bit in carry flag | |||
| 0F A3 | BT r/m32,r32 | X | X | X | Save bit in carry flag | |||
| 0F BA /4 ib | BT r/m16,imm8 | X | X | X | Save bit in carry flag | |||
| 0F BA /4 ib | BT r/m32,imm8 | X | X | X | Save bit in carry flag | 
- Description
The BT instruction saves the value of the bit indicated by the base (first operand) and the bit offset (second operand) into the CF flag.
- Operation
CF ← BIT [LeftSRC, RightSRC];
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- | | | | | | | |*
The CF flag contains the value of the selected bit.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
The index of the selected bit can be given by the immediate constant in the instruction or by a value in a general register. Only an 8-bit immediate value is used in the instruction. This operand is taken modulo 32, so the range of immediate bit offsets is 0..31. This allows any bit within a register to be selected. For memory bit strings, this immediate field gives only the bit offset within a word or doubleword. Immediate bit offsets larger than 31 are supported by some assemblers by using the immediate bit offset field in combination with the displacement field of the memory operand. In this case, the low-order 3 to 5 bits (3 for 16 bit operands, 5 for 32-bit operands) of the immediate bit offset are stored in the immediate bit offset field, and the high-order bits are shifted and combined with the byte displacement in the addressing mode by the assembler. The processor will ignore the high-order bits if they are not zero. When accessing a bit in memory, the processor may access four bytes starting from the memory address given by:
- Effective Address + (4* (BitOffset DIV 32))
for a 32-bit operand size, or two bytes starting from the memory address given by:
- Effective Address + (2 * (BitOffset DIV 16))
for a 16-bit operand size. It may do so even when only a single byte needs to be accessed in order to reach the given bit. You must therefore avoid referencing areas of memory close to address space holes. In particular, avoid references to memory-mapped I/O registers. Instead, use the MOV instructions to load from or store to these addresses, and use the register form of these instructions to manipulate the data.
BTC - Bit Test and Complement
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F BB | BTC r/m16,r16 | X | X | X | Save bit in carry flag and complement | |||
| 0F BB | BTC r/m32,r32 | X | X | X | Save bit in carry flag and complement | |||
| 0F BA /7 ib | BTC r/m16,imm8 | X | X | X | Save bit in carry flag and complement | |||
| 0F BA /7 ib | BTC r/m32,imm8 | X | X | X | Save bit in carry flag and complement | 
- Description
The BTC instruction saves the value of the bit indicated by the base (first operand) and the bit offset (second operand) into the CF flag and then complements the bit.
- Operation
CF ← BIT[LeftSRC, RightSRC]; BIT[LeftSRC, RightSRC] ← NOT BIT[LeftSrc, RightSRC];
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- | | | | | | | |*
The CF flag contains the complement of the selected bit.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, and GS segments; # SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
The index of the selected bit can be given by the immediate constant in the instruction or by a value in a general register. Only an 8-bit immediate value may be used in the instruction. This operand is taken modulo 32, so the range of immediate bit offsets is 0..31. This allows any bit within a register to be selected. For memory bit strings, this immediate field gives only the bit offset within a word or doubleword. Immediate bit offsets larger then 31 are supported by some assemblers by using the immediate bit offset field in combination with the displacement field of the memory operand. In this case, the low-order 3 to 5 bits (3 for 16-bit operands, 5 for 32-bit operands) of the immediate bit offset are stored in the immediate bit offset field, and the high-order bits are shifted and combined with the byte displacement in the addressing mode by the assembler. The processor will ignore the high order bits if they are not zero. When accessing a bit in memory, the processor may access four bytes starting from the memory address given by:
- Effective Address + (4 * (BitOffset DIV 32))
for a 32-bit operand size, or two bytes starting from the memory address given by:
- Effective Address + (2 * (BitOffset DIV 16))
for a 16-bit operand size. It may do so even when only a single byte needs to be accessed in order to reach the given bit. Therefore, referencing areas of memory close to address space holes should be avoided. In particular, avoid references to memory-mapped I/O registers. Instead, use the MOV instructions to load from or store to these addresses, and use the register form of these instructions to manipulate the data.
BTR-Bit Test and Reset
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F B3 | BTR r/m16,r16 | X | X | X | Save bit in carry flag and reset | |||
| 0F B3 | BTR r/m32,r32 | X | X | X | Save bit in carry flag and reset | |||
| 0F BA /6 ib | BTR r/m16,imm8 | X | X | X | Save bit in carry flag and reset | |||
| 0F BA /6 ib | BTR r/m32,imm8 | X | X | X | Save bit in carry flag and reset | 
- Description
The BTR instruction saves the value of the bit indicated by the base (first operand) and the bit offset (second operand) into the CF flag and then stores 0 in the bit.
- Operation
CF ← BIT[LeftSRC, RightSRC]; BIT[LeftSRC, RightSRC] ← 0;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| | | | | | | | |* |
The CF flag contains the value of the selected bit.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
The index of the selected bit can be given by the immediate constant in the instruction or by a value in a general register. Only an 8-bit immediate value is used in the instruction. This operand is taken modulo 32, so the range of immediate bit offsets is 0..31. This allows any bit within a register to be selected. For memory bit strings, this immediate field gives only the bit offset within a word or doubleword. Immediate bit offsets larger than 31 are supported by some assemblers by using the immediate bit offset field in combination with the displacement field of the memory operand. In this case, the low-order 3 to 5-bits (3 for 16-bit operands, 5 for 32-bit operands) of the immediate bit offset are stored in the immediate bit offset field, and the high-order bits are shifted and combined with the byte displacement in the addressing mode by the assembler. The processor will ignore the high-order bits if they are not zero. When accessing a bit in memory, the processor may access four bytes starting from the memory address given by:
- Effective Address + 4 * (BitOffset DIV 32)
for a 32-bit operand size, or two bytes starting from the memory address given by:
- Effective Address + 2 * (BitOffset DIV 16)
for a 16-bit operand size. It may do so even when only a single byte needs to be accessed in order to reach the given bit. You must therefore avoid referencing areas of memory close to address space holes. In particular, avoid references to memory-mapped I/O registers. Instead, use the MOV instructions to load from or store to these addresses, and use the register form of these instructions to manipulate the data.
BTS-Bit Test and Set
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F AB | BTS r/m16,r16 | X | X | X | Save bit in carry flag and set | |||
| 0F AB | BTS r/m32,r32 | X | X | X | Save bit in carry flag and set | |||
| 0F BA /5 ib | BTS r/m16,imm8 | X | X | X | Save bit in carry flag and set | |||
| 0F BA /5 ib | BTS r/m32,imm8 | X | X | X | Save bit in carry flag and set | 
- Description
The BTS instruction saves the value of the bit indicated by the base (first operand) and the bit offset (second operand) into the CF flag and then stores 1 in the bit.
- Operation
CF ← BIT[LeftSRC, RightSRC]; BIT[LeftSRC, RightSRC] ← 1;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- | | | | | | | |*
The CF flag contains the value of the selected bit.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
The index of the selected bit can be given by the immediate constant in the instruction or by a value in a general register. Only an 8-bit immediate value is used in the instruction. This operand is taken modulo 32, so the range of immediate bit offsets is 0..31. This allows any bit within a register to be selected. For memory bit strings, this immediate field gives only the bit offset within a word or doubleword. Immediate bit offsets larger than 31 are supported by some assemblers by using the immediate bit offset field in combination with the displacement field of the memory operand. In this case, the low-order 3 to 5 bits (3 for 16-bit operands, 5 for 32-bit operands) of the immediate bit offset are stored in the immediate bit offset field, and the high-order bits are shifted and combined with the byte displacement in the addressing mode by the assembler. The processor will ignore the high-order bits if they are not zero. When accessing a bit in memory, the processor may access four bytes starting from the memory address given by:
Effective Address + (4 * (BitOffset DIV 32))
for a 32-bit operand size, or two bytes starting from the memory address given by:
Effective Address + (2 * (BitOffset DIV 16))
for a 16-bit operand size. It may do this even when only a single byte needs to be accessed in order to get at the given bit. You must therefore be careful to avoid referencing areas of memory close to address space holes. In particular, avoid references to memory-mapped I/O registers. Instead, use the MOV instructions to load from or store to these addresses, and use the register form of these instructions to manipulate the data.
CALL - Call Procedure
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| E8 cw | CALL rel16 | X | X | X | X | X | X | Call near, displacement relative to next instruction | 
| FF /2 | CALL r/m16 | X | X | X | X | X | X | Call near, register indirect/memory indirect | 
| 9A cd | CALL ptr16:16 | X | X | X | X | X | X | Call intersegment, to full pointer given | 
| 9A cd | CALL ptr16:16 | X | X | X | X | Call gate, same privilege | ||
| 9A cd | CALL ptr16:16 | X | X | X | X | Call gate, more privilege, no parameters | ||
| 9A cd | CALL ptr16:16 | X | X | X | X | Call gate, more privilege, x parameters | ||
| 9A cd | CALL ptr16:16 | X | X | X | X | Call to task (via task state segment/task gate for 286) | ||
| FF /3 | CALL m16:16 | X | X | X | X | X | X | Call intersegment, address at r/m dword | 
| FF /3 | CALL m16:16 | X | X | X | X | Call gate, same privilege | ||
| FF /3 | CALL m16:16 | X | X | X | X | Call gate, more privilege, no parameters | ||
| FF /3 | CALL m16:16 | X | X | X | X | Call gate, more privilege, x parameters | ||
| FF /3 | CALL m16:16 | X | X | X | X | Call to task (via task state segment/task gate for 286) | ||
| E8 cd | CALL rel32 | X | X | X | Call near, displacement relative to next instruction | |||
| FF /2 | CALL r/m32 | X | X | X | Call near, register indirect/memory indirect | |||
| 9A cp | CALL ptr16:32 | X | X | X | Call intersegment, to full pointer given | |||
| 9A cp | CALL ptr16:32 | X | X | X | Call gate, same privilege | |||
| 9A cp | CALL ptr16:32 | X | X | X | Call gate, more privilege, no parameters | |||
| 9A cp | CALL ptr16:32 | X | X | X | Call gate, more privilege, x parameters | |||
| 9A cp | CALL ptr16:32 | X | X | X | Call to task | |||
| FF /3 | CALL m16:32 | X | X | X | Call intersegment, address at r/m fword | |||
| FF /3 | CALL m16:32 | X | X | X | Call gate, same privilege | |||
| FF /3 | CALL m16:32 | X | X | X | Call gate, more privilege, no parameters | |||
| FF /3 | CALL m16:32 | X | X | X | Call gate, more privilege, x parameters | |||
| FF /3 | CALL m16:32 | X | X | X | Call to task | 
- Description
The CALL instruction causes the procedure named in the operand to be run. When the procedure is complete (a return instruction is run within the procedure), processing continues at the instruction that follows the CALL instruction. The action of the different forms of the instruction are described below. Near calls are those with destination of type r/m16, r/m32, rel16, rel32; changing or saving the segment register value is not necessary. The CALL rel16 and CALL rel32 forms add a signed offset to the address of the instruction following the CALL instruction to determine the destination. The rel16 form is used when the instruction's operand-size attribute is 16- bits; rel32 is used when the operand-size attribute is 32-bits. The result is stored in the 32-bit EIP register. With rel16, the upper 16-bits of the EIP register are cleared, resulting in an offset whose value does not exceed 16-bits. CALL r/m16 and CALL r/m32 specify a register or memory location from which the absolute segment offset is fetched. The offset fetched from r/m is 32-bits for an operand-size attribute of 32 (r/m32), or 16-bits for an operand-size of 16 (r/m16). The offset of the instruction following the CALL instruction is pushed onto the stack. It will be popped by a near RET instruction within the procedure. The CS register is not changed by this form of CALL. The far calls, CALL ptr:16 and CALL ptr16:32, use a four-byte or six-byte operand as a long pointer to the procedure called. The CALL m16:16 and m16: 32 forms fetch the long pointer from the memory location specified (indirection). In Real Address Mode or Virtual 8086 Mode, the long pointer provides 16-bits for the CS register and 16 or 32-bits for the EIP register (depending on the operand-size attribute). These forms of the instruction push both the CS and IP or EIP registers as a return address. In Protected Mode, both long pointer forms consult the AR byte in the descriptor indexed by the selector part of the long pointer. Depending on the value of the AR byte, the call will perform one of the following types of control transfers:
- A far call to the same protection level
- An inter-protection level far call
- A task switch
A CALL-indirect-thru-memory, which uses the stack pointer (ESP) as a base register, references memory before the CALL. The base used is the value of the ESP before the instruction runs. For more information on Protected Mode control transfers, refer to the Intel documentation.
- Operation
IF rel/16 or rel32 type of call 
THEN (* near relative call *)
   IF OperandSize = 16 
   THEN 
      Push(IP);
      EIP ← (EIP + rel16) AND 0000FFFFH;
   ELSE (* OperandSize = 32 *)
      Push(EIP);
      EIP ← EIP + rel32;
   FI;
FI;
IF r/m16 or r/m32 type of call 
THEN (* near absolute call *)
IF OperandSize = 16 
   THEN 
      Push(IP);
      EIP ← [r/m16] AND 0000FFFFH;
   ELSE (*OperandSize = 32 *)
      Push(EIP);
      EIP ←[r/m32]
   FI;
FI 
IF (PE = 0 OR (PE = 1 AND VM = 1))
(* real mode or virtual 8086 mode *)
   AND instruction = far CALL 
     (* i.e., operand type is m16:16, m16:32, ptr16:16, ptr16:32*)
THEN 
    IF OperandSize = 16 
    THEN 
      Push(CS);
      Push(IP); (* address of next instruction; 16 bits *)
    ELSE 
      Push(CS); (* padded with 16 high-order bits *)
      Push(EIP); (* address of next instruction; 32 bits *)
FI;
IF operand type is m16:16 or m16:32
THEN (* indirect far call *)
   IF OperandSize = 16 
   THEN 
      CS:IP ← [m16:16];
   EIP ← EIP AND 0000FFFFH; (* clear upper 16 bits *)
   ELSE (* OperandSize = 32 *)
      CS:EIP ← [m16:32[;
   FI;
FI;
IF operand type is ptr:16 or ptr16:32
THEN (* direct far call *)
   IF OperandSize = 16 
   THEN 
      CS:IP ← ptr:16;
      EIP ← EIP AND 0000FFFFH; (* clear upper 16 bits *)
   ELSE (* OperandSize = 32 *)
      CS:EIP ← ptr16:32;
   FI;
 FI;
FI;
IF (PE = 1 AND VM = 0) (* Protected mode, not V86 mode *)
 AND instruction = far CALL  
THEN 
 If indirect, then check access of EA doubleword;
   #GP(0) if limit violation;
 New CS selector must not be null else #GP(0);
 Check that new CS selector index is within its 
   descriptor table limits; else #GP(new CS selector);
 Examine AR byte of selected descriptor for various legal values;
   depending on value:
   go to CONFORMING-CODE-SEGMENT;
   go to NONCONFORMING-CODE-SEGMENT;
   go to CALL-GATE;
   go to TASK-GATE;
   go to TASK-STATE-SEGMENT;
 ELSE #GP(code segment selector);
FI;
CONFORMING-CODE-SEGMENT: DPL must be ó CPL ELSE #GP(code segment selector); Segment must be present ELSE #NP(code segment selector); Stack must be big enough for return address ELSE #SS(0); Instruction pointer must be in code segment limit ELSE #GP(0); Load code segment descriptor into CS register; Load CS with new code segment selector; Load EIP with zero-extend(new offset); IF OperandSize=16 THEN EIP ← EIP AND 0000FFFFH; FI;
NONCONFORMING-CODE-SEGMENT: RPL must be ó CPL ELSE #GP(code segment selector) DPL must be = CPL ELSE #GP(code segment selector) Segment must be present ELSE #NP(code segment selector) Stack must be big enough for return address ELSE #SS(0) Instruction pointer must be in code segment limit ELSE #GP(0) Load code segment descriptor into CS register Load CS with new code segment selector Set RPL of CS to CPL Load EIP with zero-extend(new offset); IF OperandSize=16 THEN EIP ← EIP AND 0000FFFFH; FI;
 CALL-GATE
 Call gate DPL must be ò CPL ELSE #GP(call gate elector)
 Call gate DPL must be ò RPL ELSE #GP(call gate elector)
 Call gate just be present ELSE #NP(call gate selector)
 Examine code segment selector in call gate descriptor:
   Selector must not be null ELSE #GP(0)
   Selector must be within its descriptor table 
     limits ELSE #GP(code segment selector)
   AR byte of selected descriptor must indicate code 
     segment ELSE #GP(code segment selector)
   DPL of selected descriptor must be ó CPL ELSE 
     #GP(code segment selector)
   IF non-conforming code segment AND DPL < CPL 
   THEN go to MORE-PRIVILEGE
   ELSE go to SAME-PRIVILEGE
   FI;
MORE-PRIVILEGE:
 Get new SS selector for new privilege level from TSS 
   Check selector and descriptor for new SS:
     Selector must not be null ELSE #TS(0)
     Selector index must be within its descriptor 
       table limits ELSE #TS(SS selector)
     Selector's RPL must equal DPL of code segment 
       ELSE #TS(SS selector)
     Stack segment DPL must equal DPL of code 
       segment ELSE #TS(SS selector)
     Descriptor must indicate writable data segment 
       ELSE #TS(SS selector)
     Segment present ELSE #SS(SS selector)
IF OperandSize=32
 THEN 
     New stack must have room for parameters plus 16 bytes 
       ELSE #SS(SS selector)
     EIP must be in code segment limit ELSE #GP(0)
     Load new SS:eSP value from TSS 
     Load new CS:EIP value from gate 
 ELSE 
   New stack must have room for parameters plus 8 bytes 
     ELSE #SS(SS selector)
   IP must be in code segment limit ELSE #GP(0)
   Load new SS:eSP value from TSS 
   Load new CS:IP value from gate 
 FI;
 Load CS descriptor 
 Load SS descriptor 
 Push long pointer of old stack onto new stack 
 Get word count from call gate, mask to 5 bits 
 Copy parameters from old stack onto new stack 
 Push return address onto new stack 
 Set CPL to stack segment DPL 
 Set RPL of CS to CPL 
SAME-PRIVILEGE:
 IF OperandSize=32
 THEN 
   Stack must have room for 6-byte return address (padded to 8 bytes)
     ELSE #SS(0)
   EIP must be within code segment limit ELSE #GP(0)
   Load CS:EIP from gate 
 ELSE 
   Stack must have room for 4-byte return address ELSE #SS(0)
   IP must be within code segment limit ELSE #GP(0)
   Load CS:IP from gate 
FI;
Push return address onto stack 
Load code segment descriptor into CS register 
Set RPL of CS to CPL 
TASK-GATE:
   Task gate DPL must be ó CPL ELSE #TS(gate selector)
   Task gate DPL must be ó RPL ELSE #TS(gate selector)
   Task Gate must be present ELSE #NP(gate selector)
   Examine selector to TSS, given in Task Gate descriptor:
     Must specify global in the local/global bit ELSE #TS(TSS selector)
     Index must be within GDT limits ELSE #TS(TSS selector)
     TSS descriptor AR byte must specify nonbusy TSS 
       ELSE #TS(Tss selector)
     Task State Segment must be present ELSE #NP(TSS selector)
 SWITCH-TASKS (with nesting) to TSS 
 IP must be in code segment limit ELSE #TS(0)
TASK-STATE-SEGMENT
 TSS DPL must be ó CPL ELSE #TS(TSS selector)
 TSS DPL must be ó RPL ELSE #TS(TSS selector)
 TSS descriptor AR byte must specify available TSS 
    ELSE #TS(TSS selector)
 Task State Segment must be present ELSE #NP(TSS selector)
 SWITCH-TASKS (with nesting) to TSS 
 IP must be in code segment limit ELSE #TS(0)
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| | | | | | | | | |
All flags are affected if a task switch occurs; no flags are affected if a task switch does not occur.
- Protected Mode Exceptions
For far calls: #GP, #NP, #SS, and #TS, as indicated in the "Operation" section. For near direct calls: #GP(0) if procedure location is beyond the code segment limits; #SS(0) if pushing the return address exceeds the bounds of the stack segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3. For a near indirect call: #GP(0) for an illegal memory operand effective address is the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #GP(0) if the indirect offset obtained is beyond the code segment limits; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
Any far call from a 32-bit code segment to a 16-bit code segment should be made from the first 64 Kbytes of the 32-bit code segment, because the operand-size attribute of the instruction is set to 16, allowing only a 16- bit return address offset to be saved.
CBW/CWDE-Convert Byte to Word/Convert Word to Doubleword
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 98 | CBW | X | X | X | X | X | X | AX ← sign extend of AL | 
| 98 | CWDE | X | X | X | EAX ← sign-extend of AX | 
- Description
The CBW instruction converts the signed byte in the AL register to a signed word in the AX register by extending the most significant bit of the AL register (the sign bit) into all of the bits of the AH register. The CWDE instruction converts the signed word in the AX register to a doubleword in the EAX register by extending the most significant bit of the AX register into the two most significant bytes of the EAX register. Note that the CWDE instruction is different from the CWD instruction. The CWD instruction uses the DX:AX register pair rather than the EAX register as a destination.
- Operation
IF OperandSize = 16 (* instruction = CBW *) THEN AX ← Sign Extend(AL); ELSE (* OperandSize = 32, instruction = CWDE *) EAX ← Sign Extend(AX); FI;
CDQ - Convert Double to Quad
See entry for CWD/CDQ-Convert Word to Double/Convert Double to Quad.
CLC - Clear Carry Flag
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F8 | CLC | X | X | X | X | X | X | Clear carry flag | 
- Description
The CLC instruction clears the CF flag. It does not affect other flags or registers.
- Operation
CF ← 0;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
| 0 | 
The CF flag is cleared.
CLD - Clear Direction Flag
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| FC | CLD | X | X | X | X | X | X | Clear direction flag | 
- Description
The CLD instruction clears the direction flag. No other flags or registers are affected. After a CLD instruction is run, string operations will increment the index registers (SI and/or DI) that they use.
- Operation
DF ← 0;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
| 0 | 
The DF flag is cleared.
CLI - Clear Interrupt Flag
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| FA | CLI | X | X | X | X | X | X | Clear interrupt flag; interrupts disabled when interrupt flag cleared | 
- Description
The CLI instruction clears the IF flag if the current privilege level is at least as privileged as IOPL. No other flags are affected. External interrupts are not recognized at the end of the CLI instruction from that point on until the IF flag is set.
- Operation
IF PE = 0 
THEN 
  IF ←0;
ELSE 
  IF VM = 0 (* Running in protected Mode *)
  THEN
     IF IOPL = 3 
     THEN IF ← 0;
     ELSE IF CPL ó IOPL 
               THEN IF ← 0;
               ELSE #GP(0);
               FI;
     FI;
  ELSE (* Running in Virtual-8086 mode *)
     IF IOPL = 3 
     THEN IF ← 
     ELSE #GP(0);
     FI;
  FI;
FI;
- Decision Table
The following decision table indicates which action in the lower portion of the table is taken given the conditions in the upper portion of the table.
| PE = | 0 | 1 | 1 | 1 | 1 | 
| VM = | - | 0 | - | 0 | 1 | 
| CPL | - | óIOPL | - | >IOPL | - | 
| IOPL | - | - | = 3 | - | < 3 | 
| IF ← 0 | Y | Y | Y | ||
| #GP(0) | Y | Y | 
Notes: - Don't care Blank Action Not Taken Y Action in Column 1 taken
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| | | |0 | | | | | |
IF cleared.
- Protected Mode Exceptions
- GP(0) if the current privilege level is greater (has less privilege) than the I/O privilege level in the flags register. The I/O privilege level specifies the least privileged level at which I/O can be performed.
- Virtual 8086 Mode Exceptions
- GP(0) as for protected mode.
CLTS - Clear Task-Switched Flag in CR0
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 06 | CLTS | X | X | X | X | Clear task-switched flag | 
- Description
The CLTS instruction clears the task-switched (TS) flag in the CR0 register. This flag is set by the processor every time a task switch occurs. The TS flag is used to manage processor extensions as follows:
- Every processing of an ESC instruction is trapped if the TS flag is set.
- Processing of a WAIT instruction is trapped if the MP flag and the TS flag are both set.
Thus, if a task switch was made after an ESC instruction was begun, the floating-point unit's context may need to be saved before a new ESC instruction can be issued. The fault handler saves the context and clears the TS flag. The CLTS instruction appears in operating system software, not in application programs. It is a privileged instruction that can only be run at privilege level 0.
- Operation
TS Flag in CR0 ← 0;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| | | | | | | | | |
The TS flag is cleared (the TS flag is in the CR0 register, not the flags register).
- Protected Mode Exceptions
- GP(0) if the CLTS instruction is run with a current privilege level other than 0.
- Real Address Mode Exceptions
None (valid in Real Address Mode to allow initialization for Protected Mode ).
- Virtual 8086 Mode Exceptions
Same exceptions as in Protected Mode.
CMC - Complement Carry Flag
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F5 | CMC | X | X | X | X | X | X | Complement carry flag | 
- Description
The CMC instruction reverses the setting of the CF flag. No other flags are affected.
- Operation
CF ← NOT CF;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- | | | | | | | |*
The CF flag contains the complement of its original value.
CMP - Compare Two Operands
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 3C ib | CMP AL,imm8 | X | X | X | X | X | X | Compare immediate byte to AL | 
| 3D iw | CMP AX,imm16 | X | X | X | X | X | X | Compare immediate word to AX | 
| 3D id | CMP EAX,imm32 | X | X | X | Compare immediate dword to EAX | |||
| 80 /7 ib | CMP r/m8,imm8 | X | X | X | X | X | X | Compare immediate byte to r/m byte | 
| 81 /7 iw | CMP r/m16,imm16 | X | X | X | X | X | X | Compare immediate word to r/m word | 
| 81 /7 id | CMP r/m32,imm32 | X | X | X | Compare immediate dword to r/m dword | |||
| 83 /7 ib | CMP r/m16,imm8 | X | X | X | X | X | X | Compare sign-extended immediate byte to r/m word | 
| 83 /7 ib | CMP r/m32,imm8 | X | X | X | Compare sign-extended immediate byte to r/m dword | |||
| 38 /r | CMP r/m8,r8 | X | X | X | X | X | X | Compare byte register to r/m byte | 
| 39 /r | CMP r/m16,r16 | X | X | X | X | X | X | Compare word register to r/m word | 
| 39 /r | CMP r/m32,r32 | X | X | X | Compare dword register to r/m dword | |||
| 3A /r | CMP r8,r/m8 | X | X | X | X | X | X | Compare r/m byte to byte register | 
| 3B /r | CMP r16,r/m16 | X | X | X | X | X | X | Compare r/m word to word register | 
| 3B /r | CMP r32,r/m32 | X | X | X | Compare r/m dword to dword register | 
- Description
The CMP instruction subtracts the second operand from the first but, unlike the SUB instruction, does not store the result; only the flags are changed. The CMP instruction is typically used in conjunction with conditional jumps and the SETcc instruction. (Refer to Appendix D for the list of signed and unsigned flag tests provided.) If an operand greater than one byte is compared to an immediate byte, the byte value is first sign-extended.
- Operation
LeftSRC - SignExtend(RightSRC);
(* CMP does not store a result; its purpose is to set the flags *)
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- |* | | |* |* |* |* |*
The OF, SF, ZF, AF, PF, and CF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
,Real Address Mode Exceptions Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
CMPS/CMPSB/CMPSW/CMPSD - Compare String Operands
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| A6 | CMPS m8,m8 | X | X | X | X | X | X | Compare bytes ES:[(E)DI] (second operand) with [(E)SI] (first operand) | 
| A7 | CMPS m16,m16 | X | X | X | X | X | X | Compare words ES:[(E)DI] (second operand) with [(E)SI] (first operand) | 
| A7 | CMPS m32,m32 | X | X | X | Compare dwords ES:[(E)DI] (second operand) with [(E)SI] (first operand) | |||
| A6 | CMPSB | X | X | X | X | X | X | Compare bytes ES:[(E)DI] with DS:[(E)SI] | 
| A7 | CMPSW | X | X | X | X | X | X | Compare words ES:[(E)DI] with DS:[(E)SI] | 
| A7 | CMPSD | X | X | X | Compare dwords ES:[(E)DI] with DS:[(E)SI] | 
- Description
The CMPS instruction compares the byte, word, or doubleword pointed to by the source-index register with the byte, word, or doubleword pointed to by the destination-index register. If the address-size attribute of this instruction of 16-bits, the SI and DI registers will be used for source- and destination-index registers; otherwise the ESI and EDI registers will be used. Load the correct index values into the SI and DI (or ESI and EDI) registers before running the CMPS instruction. The comparison is done by subtracting the operand indexed by the destination-index register from the operand indexed by the source-index register. Note that the direction of subtraction for the CMPS instruction is [SI] - [ DI] or [ESI] - [EDI]. The left operand (SI or ESI) is the source and the right operand (DI or EDI) is the destination. This is the reverse of the usual Intel convention in which the left operand is the destination and the right operand is the source. The result of the subtraction is not stored; only the flags reflect the change. The types of the operands determine whether bytes, words, or doublewords are compared. For the first operand (SI or ESI), the DS register is used, unless a segment override byte is present. The second operand (DI or EDI) must be addressable from the ES register; no segment override is possible. After the comparison is made, both the source-index register and destination-index register are automatically advanced. If the DF flag is 0 (a CLD instruction was run), the registers increment; if the DF flag is 1 (an STD instruction was run), the registers decrement. The registers increment or decrement by 1 if a byte is compared, by 2 if a word is compared, or by 4 if a doubleword is compared. The CMPSB, CMPSW and CMPSD instructions are synonyms for the byte, word, and doubleword CMPS instructions, respectively. The CMPS instruction can be preceded by the REPE or REPNE prefix for block comparison of CX or ECX bytes, words, or doublewords. Refer to the description of the REP instruction for more information on this operation.
- Operation
IF (instruction = CMPSD) OR
   (instruction has operands of type DWORD)
THEN OperandSize ← 32;
ELSE OperandSize ← 16;
FI;
IF AddressSize = 16
THEN
  use SI for source-index and DI for destination-index
ELSE (* AddressSize = 32 *)
  use ESI for source-index and EDI for destination-index;
FI;
IF byte type of instruction
THEN
  set ZF based on
  [source-index] - [destination-index] ; (* byte comparison *)
  IF DF = 0 THEN IncDec ← 1 ELSE IncDec ← -1; FI;
ELSE
  IF OperandSize = 16
  THEN
     set ZF based on
     [source-index] - [destination-index] ; (* word comparison *)
     IF DF = 0 THEN IncDec ← 2 ELSE IncDec ← -2; FI;
  ELSE (* OperandSize = 32 *)
     set ZF based on
     [source-index] - [destination-index] ; (* dword comparison *)
     IF DF = 0 THEN IncDec ← 4 ELSE IncDec ← -4; FI;
  FI;
FI;
source-index = source-index + IncDec;
destination-index = destination-index + IncDec;
| OF | DF | IF | SF | ZF | AF | PF | CF | 
| * | * | * | * | * | * | 
The OF, SF, ZF, AF, PF, and CF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
CMPXCHG - Compare and Exchange
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F B0 /r | CMPXCHG r/m8,r8 | X | X | Compare AL with r/m byte. If equal, set ZF and load byte reg into r/m byte. Else, clear ZF and load r/m byte into AL | ||||
| 0F B1 /r | CMPXCHG r/m16,r16 | X | X | Compare AX with r/m word. If equal, set ZF and load word reg into r/m word. Else, clear ZF and load r/m word into AX | ||||
| 0F B1 /r | CMPXCHG r/m32,r32 | X | X | Compare EAX with r/m dword. If equal, set ZF and load dword reg into r/m dword. Else, clear ZF and load r/m dword into EAX. | 
- Description
The CMPXCHG instruction compares the accumulator (AL, AX, or EAX register) with DEST. If they are equal, SRC is loaded into DEST. Otherwise, DEST is loaded into the accumulator.
- Operation
IF accumulator=DEST
         ZF ← 1 
         DEST ← SRC 
ELSE 
         ZF ← 0 
         accumulator ← DEST 
| OF | DF | IF | SF | ZF | AF | PF | CF | 
| * | * | * | * | * | * | 
The CF, PF, AF, SF, and OF flags are affected as if a CMP instruction had been run with DEST and the accumulator as operands. The ZF flag is set if the destination operand and the accumulator are equal; otherwise it is cleared.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF (fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF (fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
This instruction can be used with a LOCK prefix. In order to simplify interface to the processor's bus, the destination operand receives a write cycle without regard to the result of the comparison. DEST is written back if the comparison fails, and SRC is written into the destination otherwise. (The processor never produces a locked read without also producing a locked write.) This instruction is not supported on Intel386 processors.
CMPXCHG8B - Compare and Exchange 8 Bytes
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F C7 /1 | CMPXCHG8B r/m64 | X | Compare EDX:EAX with r/m qword. If equal, set ZF and load ECX:EBX into r/m qword. Else, clear ZF and load r/m qword into EDX:EAX | 
- Description
The CMPXCHG8B instruction compares the 64-bit value in EDX:EAX with DEST. EDX contains the high-order 32 bits, and EAX contains the low-order 32 bits of 64-bit value. If they are equal, the 64-bit value in ECX:EBX is stored into DEST. ECX contains the high-order 32 bits and EBX contains the low- order 32 bits. Otherwise, DEST is loaded into EDX:EAX.
- Operation
IF EDX:EAX=DEST
         ZF ← 1 
         DEST ← ECX:EBX
ELSE 
         ZF ← 0 
         EDX:EAX ← DEST 
| OF | DF | IF | SF | ZF | AF | PF | CF | 
| * | 
The ZF flag is set if the destination operand and EDX:EAX are equal; otherwise it is cleared. The CF, PF, AF, SF, and OF flags are unaffected.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF (fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
The destination operand must be a memory operand, not a register. If the CMPXCHG8B instruction is run with a modr/m byte representing a register as the destination operand, #UD occurs.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF (fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3. #UD if modr/m byte represents a register as the destination.
- Notes
This instruction can be used with a LOCK prefix. In order to simplify interface to the processor's bus, the destination operand receives a write cycle without regard to the result of the comparison. DEST is written back if the comparison fails, and SRC is written into the destination otherwise. (The processor never produces a locked read without also producing a locked write.) The "r/m64" syntax had previously been used only in the context of floating point operations. It indicates a 64-bit value, in memory at an address determined by the modr/m byte. This instruction is not supported on Intel486 processors.
CPUID - CPU Identification
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F A2 | CPUID | X | EAX ← CPU identification information | 
- Description
The CPUID instruction provides information to software about the vendor, family, model, and stepping of microprocessor on which it is running. An input value loaded into the EAX register for this instruction indicates what information should be returned by the CPUID instruction. Following processing of the CPUID instruction with a zero in EAX, the EAX register contains the highest input value understood by the CPUID instruction. For the Pentium processor, the value in EAX will be a one. Also included in the output of this instruction with an input value of zero in EAX is a vendor identification string contained in the EBX, EDX, and ECX registers. EBX contains the first four characters, EDX contains the next four characters and ECX contains the last four characters. For Intel processors, the vendor identification string is "GenuineIntel" as follows:
EBX ← 756e6547h (* "Genu", with G in the low nibble of BL *) EDX ← 49656e69h (* "ineI", with i in the low nibble of DL *) ECX ← 6c65746eh (* "ntel", with n in the low nibble of CL *)
Following processing of the CPUID instruction with an input value of one loaded into the EAX register, EAX[3:0] contains the stepping id of the microprocessor, EAX[7:4] contains the model (the first model will be indicated by 0001B in these bits) and EAX[11:8] contains the family (5 for the Pentium processor family). EAX[31:12] are reserved, as well as EBX, and ECX. The Pentium processor sets the feature register, EDX, to 1BFH indicating which features the Pentium processor supports. A feature flag set to one indicates that the corresponding feature is supported. The feature set register is defined as follows:
EDX[0:0] FPU on chip EDX[6:1] Refer to the Intel documentation EDX[7:7] Machine Check Exception EDX[8:8] CMPXCHG8B Instruction EDX[31:9] Reserved
Software should determine the vendor identification in order to properly interpret the feature register flag bits. For more information on the feature set register, see the Intel documentation.
- Operation
switch (EAX)
  case 0:
      EAX ← hv;(* hv=1 for the Pentium processor *)
                      (* hv is the highest input value that is understood by CPUID. *)
      EBX ← Vendor identification string;
      EDX ← Vendor identification string;
      ECX ← Vendor identification string;
      break;
  case 1:
      EAX[3:0] ← Stepping ID;
      EAX[7:4] ← Model;
      EAX[11:8] ← Family;
      EAX[31:12] ← Reserved;
      EBX ← reserved;      (* 0 *)
      ECX ← reserved;      (* 0 *)
      EBX ← feature flags;
      break;
  default:  (* EAX > hv *)
      EAX ← reserved, undefined;
      EBX ← reserved, undefined;
      ECX ← reserved, undefined;
      EDX ← reserved, undefined;
      break;
end-of-switch
CWD/CDQ - Convert Word to Double/Convert Double to Quad
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 99 | CWD | X | X | X | X | X | X | DX ← sign-extend of AX | 
| 99 | CDQ | X | X | X | EDX ← sign-extend of EAX | 
- Description
CWD and CDQ double the size of the source operand. The CWD instruction copies the sign (bit 15) of the word in the AX register into every bit position in the DX register. The CDQ instruction copies the sing (bit 31) of the doubleword in the EAX register into every bit position in the EDX register. The CWD instruction can be used to produce a doubleword dividend from a word before a word division, and the CDQ instruction can be used to produce a quadword dividend from a doubleword before doubleword division. The CWD and CDQ instructions are different mnemonics for the same opcode. Which one gets run is determined by whether it is in a 16- or 32-bit segment and the presence of any operand-size override prefixes.
- Operation
IF OperandSize = 16 (* instruction = CWD *) THEN DX ← SignExtend(AX); ELSE (* OperandSize = 32, instruction = CDQ *) EDX ←SignExtend(EAX); FI;
CWDE - Convert Word to Doubleword
See entry for CBW/CWDE-Convert Byte to Word/Convert Word to Doubleword.
DAA - Decimal Adjust AL after Addition
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+-------------------------------- |27 |DAA |X|X|X|X|X|X|Decimal adjust AL after addition
- Description
Run the DAA instruction only after running an ADD instruction that leaves a two-BCD-digit byte result in the AL register. The ADD operands should consist of two packaged BCD digits. The DAA instruction adjusts the AL register to contain the correct two-digit packed decimal result.
- Operation
IF (((AL AND 0FH) > 09H) or EFLAGS.AF = 1) THEN AL ← AL + 06H; FI; IF (((AL AND 0F0H) > 90H) or EFLAGS.CF = 1) THEN AL ← AL + 60H; CF ← 1; FI;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| |? | | |* |* |* |* |* |
The AF and CF flags are set if there is a decimal carry, cleared if there is no decimal carry; the SF, ZF and PF flags are set according to the result. The OF flag is undefined.
DAS - Decimal Adjust AL after Subtraction
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |---------+-------------+-+-+-+-+-+-+---------------------------------- |2F |DAS |X|X|X|X|X|X|Decimal adjust AL after subtraction
- Description
Run the DAS instruction only after a subtraction instruction that leaves a two-BCD-digit byte result in the AL register. The operands should consist of two packed BCD digits. The DAS instruction adjusts the AL register to contain the correct packed two-digit decimal result.
- Operation
tmpCF ← 0; tmpAL ← AL; IF (((tmpAL AND 0FH) > 9H) or AF = 1) THEN AF ← 1; AL ← AL - 6H; tmpCF ← (AL < 0) OR CF; FI; IF ((tmpAL > 99H) or CF = 1) THEN AL ← AL - 60H; tmpCF ← 1; FI; CF ← tmpCF;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| |? | | |* |* |* |* |* |
The AF and CF flags are set if there is a decimal borrow, cleared if there is no decimal borrow; the SF, ZF and PF flags are set according to the result. The OF flag is undefined.
DEC - Decrement by 1
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| FE /1 | DEC r/m8 | X | X | X | X | X | X | Decrement r/m byte by 1 | 
| FF /1 | DEC r/m16 | X | X | X | X | X | X | Decrement r/m word by 1 | 
| FF /1 | DEC r/m32 | X | X | X | Decrement r/m dword by 1 | |||
| 48+rw | DEC r16 | X | X | X | X | X | X | Decrement word register by 1 | 
| 48+rd | DEC r32 | X | X | X | Decrement dword register by 1 | 
- Description
The DEC instruction subtracts 1 from the operand. The DEC instruction does not change the CF flag. To affect the CF flag, use the SUB instruction with an immediate operand of 1.
- Operation
DEST ← DEST - 1;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| * | * | * | * | * | 
The OF, SF, ZF, AF, and PF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) if the result is a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
DIV - Unsigned Divide
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F6 /6 | DIV r/m8 | X | X | X | X | X | X | Unsigned divide AX by r/m byte (AL=Quotient, AH=Remainder) | 
| F7 /6 | DIV r/m16 | X | X | X | X | X | X | Unsigned divide DX:AX by r/m word (AX=Quotient, DX=Remainder) | 
| F7 /6 | DIV r/m32 | X | X | X | Unsigned divide EDX:EAX by r/m dword (EAX=Quotient, EDX=Remainder) | 
- Description
The DIV instruction performs an unsigned division. The dividend is implicit ; only the divisor is given as an operand. The remainder is always less than the divisor. The type of the divisor determines which registers to use as follows:
| SIZE | DIVIDEND | DIVISOR | QUOTIENT | REMAINDER | 
|---|---|---|---|---|
| byte | AX | r/m8 | AL | AH | 
| word | DX:AX | r/m16 | AX | DX | 
| dword | EDX:EAX | r/m32 | EAX | EDX | 
- Operation
temp ← dividend / divisor; IF temp does not fit in quotient THEN Interrupt 0; ELSE quotient ← temp; remainder ← dividend MOD (r/m); FI;
Note: Divisions are unsigned. The divisor is given by the r/m operand. The dividend, quotient, and remainder use implicit registers. Refer to the table under "Description".
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| |? | | |? |? |? |? |? |
The OF, SF, ZF, AF, PF, and CF flags are undefined.
- Protected Mode Exceptions
Interrupt 0 if the quotient is too large to fit in the designated register (AL, AX, or EAX), or if the divisor is 0; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 0 if the quotient is too big to fit in the designated register (AL, AX, or EAX), or if the divisor is 0; Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
ENTER - Make Stack Frame for Procedure Parameters
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| C8 iw 00 | ENTER imm16,0 | X | X | X | X | X | Make procedure stack frame | |
| C8 iw 01 | ENTER imm16,1 | X | X | X | X | X | Make stack frame for procedure parameters | |
| C8 iw ib | ENTER imm16,imm8 | X | X | X | X | X | Make stack frame for procedure parameters | 
- Description
The ENTER instruction creates the stack frame required by most block- structured high-level languages. The first operand specifies the number of bytes of dynamic storage allocated on the stack for the routine being entered. The second operand gives the lexical nesting level (0 to 31) of the routine within the high-level language source code. It determines the number of stack frame pointers copied into the new stack frame from the preceding frame. Both the operand-size attribute and the stack-size attribute are used to determine whether BP or EBP is used for the current frame pointer and SP or ESP is used for the stack pointer. If the operand-size attribute is 16-bits, the processor uses the BP register as the frame pointer and the SP register as the stack pointer, unless the stack-size attribute is 32-bits in which case it uses EBP for the frame pointer and ESP for the stack pointer. If the operand-size attribute is 32-bits, the processor uses the EBP register for the frame pointer and the ESP register for the stack pointer, unless the stack-size attribute is 16-bits in which case it uses BP for the frame pointer and SP for the stack pointer. If the second operand is 0, the ENTER instruction pushes the frame pointer (BP or EBP register) onto the stack; the ENTER instruction then subtracts the first operand from the stack pointer and sets the frame pointer to the current stack-pointer value. For example, a procedure with 12 bytes of local variables would have an ENTER 12,0 instruction at its entry point and a LEAVE instruction before every RET instruction. The 12 local bytes would be addressed as negative offsets from the frame pointer.
- Operation
level ← level MOD 32 
2ndOperand <- 2ndOperand MOD 32 
IF operand_size = 16 THEN Push(bp) ELSE Push(ebp) FI;
IF stkSize = 16 THEN framePtr = sp ELSE framePtr = esp FI;
FOR i ← 1 TO (2ndOperand - 1)
DO 
  IF oprand_size = 16 
  THEN
      IF stkSize = 16 
      THEN
        bp = bp - 2 
        Push([bp]) (* word push *)
      ELSE (* stkSize = 32 *)
        ebp = ebp - 2 
        Push([ebp]) (* word push *)
      FI;
  ELSE (* operand_size = 32 *)
      IF stkSize = 16 
        bp = bp - 4 
        Push([bp]) (* doubleword push *)
      ELSE (* stkSize = 32 *)
        ebp = ebp - 4 
        Push([ebp]) (* doubleword push *)
      FI;
  FI;
OD;
IF stkSize = 16 
THEN Push(framePtr); (* word push *)
ELSE Pushd(framePtr); (* doubleword push *)
FI;
IF stkSize = 16 
THEN 
  bp = framePtr 
  sp = sp - 1stOperand 
ELSE 
  ebp = framePtr 
  esp = esp - 1stOperand 
FI;
- Protected Mode Exceptions
- SS(0) if the SP or ESP value would exceed the stack limit at any point during instruction processing; #PF(fault-code) for a page fault.
F2XM1 - Compute (2 to the power of X) minus 1
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+------------------------- |D9 F0 |F2XM1 |X|X|X|X|X|X|Replace ST with (2ST - 1)
- Description
F2XM1 replaces the contents of ST with (2ST-1). ST must lie in the range -1 < ST < 1.
- Operation
ST ← (2ST-1);
- Numeric Exceptions
P, U, D, I, IS.
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
If the operand is outside the acceptable range, the result of F2XM1 is undefined. Values other than 2 can be exponentiated using the formula xy = 2(y * log2x) The instructions FLDL2T and FLDL2E load the constants log210 and log2e, respectively. FYL2X can be used to calculate y * log2x for arbitrary positive x.
FABS - Absolute Value
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+---------------------------------- |D9 E1 |FABS |X|X|X|X|X|X|Replace ST with its absolute value
- Description
The absolute value instruction clears the sign bit of ST. This operation leaves a positive value unchanged, or replaces a negative value with a positive value of equal magnitude.
- Operation
sign bit of ST ← 0
- Numeric Exceptions
IS
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
The invalid-operation exception is raised only on stack underflow. No exception is raised if the operand is a signalling NaN or is in an unsupported format.
FADD/FADDP/FIADD - Add
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| DE C1 | FADD | X | X | X | X | X | X | Add ST to ST(1) and pop ST | 
| D8 C0+i | FADD ST,ST(i) | X | X | X | X | X | X | Add ST(i) to ST | 
| DC C0+i | FADD ST(i),ST | X | X | X | X | X | X | Add ST to ST(i) | 
| D8 /0 | FADD m32real | X | X | X | X | X | X | Add m32real to ST | 
| DC /0 | FADD m64real | X | X | X | X | X | X | Add m64real to ST | 
| DE C0+i | FADDP ST(i),ST | X | X | X | X | X | X | Add ST to ST(i) and pop ST | 
| DE /0 | FIADD m16int | X | X | X | X | X | X | Add m16int to ST | 
| DA /0 | FIADD m32int | X | X | X | X | X | X | Add m32int to ST | 
- Description
The addition instructions add the source and destination operands and return the sum to the destination. The operand at the stack top can be doubled by coding: FADD ST, ST(0)
- Operation
DEST ← DEST +SRC; If instruction = FADDP THEN pop ST FI;
- Numeric Exceptions
P, U, O, D, I, IS.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF ( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF (fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
- If the source operand is in memory, it is automatically converted to the extended-real format.
FBLD - Load Binary Coded Decimal
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+------------------------------ |DF /4 |FBLD m80bcd |X|X|X|X|X|X|Push m80bcd onto the FPU stack
- Description
FBLD converts the BCD source operand into extended-real format, and pushes it onto the FPU stack. See Figure 6-10 for BCD data layout.
- Operation
Decrement FPU stack-top pointer; ST(0) ← SRC;
- Numeric Exceptions
IS.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF ( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF (fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
The source is loaded without rounding error. The sign of the source is preserved, including the case where the value is negative zero. The packed decimal digits are assumed to be in the range 0-9. The instruction does not check for invalid digits (A-FH), and the result of attempting to load an invalid encoding is undefined. ST(7) must be empty to avoid causing an invalid-operation exception.
FBSTP - Store Binary Coded Decimal and Pop
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+----------------------------- |DF /6 |FBSTP m80bcd |X|X|X|X|X|X|Store ST in m80bcd and pop ST
- Description
FBSTP converts the value in ST into a packed decimal integer, stores the result at the destination in memory, and pops ST. Non-integral values are first rounded according to the RC field of the control word. See Figure 6- 10 for BCD data layout.
- Operation
DEST ← ST(0); pop ST;
- Numeric Exceptions
P, I, IS.
- Protected Mode Exceptions
- GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF (fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF (fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
FCHS - Change Sign
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+-------------------------- |D9 E0 |FCHS |X|X|X|X|X|X|Replace ST with a value of | | | | | | | | |opposite sign
- Description
The change sign instruction inverts the sign bit of ST. This operation replaces a positive value with a negative value of equal magnitude, or vice -versa.
- Operation
sign bit of ST ← NOT (sign bit of ST)
- Numeric Exceptions
IS
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CRO is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
The invalid-operation exception is raised only on stack underflow, even if the operand is signalling NaN or is an unsupported format.
FCLEX/FNCLEX - Clear Exceptions
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9B DB E2 | FCLEX | X | X | X | X | X | X | Clear FP exception flags after checking for FP error conditions | 
| DB E2 | FNCLEX | X | X | X | X | X | X | Clear FP exeption flags without checking for FP error conditions | 
- Description
FCLEX clears the exception flags, the exception status flag, and the busy flag of the FPU status word.
- Operation
SW[0..7] ← 0; SW[15] ← 0;
- Numeric Exceptions
- None
- Protected Mode Exceptions
- #NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
- Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- #NM if either EM or TS in CR0 is set.
- Notes
- FCLEX checks for unmasked floating-point error conditions before clearing the exception flags, FNCLEX does not.
FCOM/FCOMP/FCOMPP - Compare Real
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D8 D1 | FCOM | X | X | X | X | X | X | Compare ST with ST(1) | 
| D8 D0+i | FCOM ST(i) | X | X | X | X | X | X | Compare ST with ST(i) | 
| D8 /2 | FCOM m32real | X | X | X | X | X | X | Compare ST with m32real | 
| DC /2 | FCOM m64real | X | X | X | X | X | X | Compare ST with m64real | 
| D8 D9 | FCOMP | X | X | X | X | X | X | Compare ST with ST(1) and pop ST | 
| D8 D8+i | FCOMP ST(i) | X | X | X | X | X | X | Compare ST with ST(i) and pop ST | 
| D8 /3 | FCOMP m32real | X | X | X | X | X | X | Compare ST with m32real and pop ST | 
| DC /3 | FCOMP m64real | X | X | X | X | X | X | Compare ST with m64real and pop ST | 
| DE D9 | FCOMPP | X | X | X | X | X | X | Compare ST with ST(1) and pop ST twice | 
- Description
The compare real instructions compare the stack top to the source, which can be a register or a single- or double-real memory operand. If no operand is encoded, ST is compared to ST(1). Following the instruction, the condition codes reflect the relation between ST and the source operand.
- Operation
Case (relation of operands) OF Not comparable: C3, C2, C0 ← 111; ST > SRC: C3, C2, C0 ← 000; ST < SRC: C3, C2, C0 ← 001; ST = SRC: C3, C2, C0 ← 100; If instruction = FCOMP THEN pop ST; Fl; If instruction = FCOMPP THEN pop ST; pop ST; Fl;
- FPU Flags Affected
FPU FLAGS |EFLAGS ----------+------ C0 |CF ----------+------ C1 |None ----------+------ C2 |PF ----------+------ C3 |ZF
C1 as described in FPU Flags Affected; C0, C2, C3 as specified above.
- Numeric Exceptions
D, I, IS.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF ( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would like outside effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF (fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
If either operand is NaN or is in an undefined format, or if a stack fault occurs, the invalid-operation exception is raised, and the condition bits are set to "unordered." The sign of zero is ignored, so that -0.0 =-+0.0.
FCOS - Cosine
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+-------------------------- |D9 FF |FCOS | | | |X|X|X|Replace ST with its cosine
- Description
The cosine instruction replaces the contents of ST with cos(ST). ST, expressed in radians, must lie in the range 101 < 2 63.
- Operation
IF operand is in range 
THEN 
    C2 ← 0;
    ST ← cos(ST);
ELSE 
    C2 ← 1;
FI;
- FPU Flags Affected
|C0|C1|C2|C3| |--+--+--+--| |? |* |? |* |
C1, C2 as described in FPU Flags Affected; C0, C3 undefined.
- Numeric Exceptions
- P,D,I,IS.
- Protected Mode Exceptions
- #NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
- Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- #NM if either EM or TS in CR0 is set.
- Notes
- If the operand is outside the acceptable range, the C2 flag is set, and ST remains unchanged. It is the programmer's responsibility to reduce the operand to an absolute value smaller than 263 by subtracting an appropriate integer multiple of 2ã. See the Intel documentation for discussion of the proper value to use for ã in performing such reductions.
FDECSTP - Decrement Stack-Top Pointer
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 F6 | FDECSTP | X | X | X | X | X | X | Decrement top-of-stack pointer for FPU register stack | 
- Description
FDESCSTP subtracts one (without carry) from the three-bit TOP field of the FPU status word.
- Operation
IF TOP=0 THEN TOP ← 7; ELSE TOP ← TOP-1; FI;
- Numeric Exceptions
None.
- Protected Mode Exceptions
.#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Notes
The effect of FDECSTP is to rotate the stack. It does not alter register tags or contents, nor does it transfer data.
FDISI/FNDISI - Disable Interrupts
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9B DB E1 | FDISI | X | X | Sets the interrupt enable mask in the control word | ||||
| DB E1 | FNDISI | X | X | Sets the interrupt enable mask in the control word | 
- Description
- Operation
- FPU Flags Affected
C0|C1|C2|C3 --+--+--+-- | | |
- Numeric Exceptions
- Protected Mode Exceptions
- Real Address Mode Exceptions
- Notes
FDIV/FDIVP/FIDIV - Divide
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D8 /6 | FDIV m32real | X | X | X | X | X | X | Replace ST with ST ö m32real | 
| DC /6 | FDIV m64real | X | X | X | X | X | X | Replace ST with ST ö m64real | 
| D8 F0+i | FDIV ST,ST(i) | X | X | X | X | X | X | Replace ST with ST ö ST(i) | 
| DC F8+i | FDIV ST(i),ST | X | X | X | X | X | X | Replace ST(i) with ST(i) ö ST | 
| DE F8+i | FDIVP ST(i),ST | X | X | X | X | X | X | Replace ST(i) with ST(i) ö ST; pop ST | 
| DE F9 | FDIV | X | X | X | X | X | X | Replace ST(1) with ST(1) ö ST; pop ST | 
| DE /6 | FIDIV m16int | X | X | X | X | X | X | Replace ST with ST ö m16int | 
| DA /6 | FIDIV m32int | X | X | X | X | X | X | Replace ST with ST ö m32int | 
- Description
The division instructions divide the stack top by other operand and return the quotient to the destination.
- Operation
FDIV DEST, SRC DEST ← DEST ö SRC If instruction = FDIVP THEN pop ST FI;
- Numeric Exceptions
P, U, O, Z, D, I, IS.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
If the source operand is in memory, it is automatically converted to the extended-real format. The performance of the division instructions depends on the PC (Precision Control) field of the FPU control word. If PC specifies a precision of 53 bits, the division instructions will run in 33 clocks. If the specified precision is 24 bits, the division instructions will take only 19 clocks.
FDIVR/FDIVRP/FIDIVR - Reverse Divide
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D8 /7 | FDIVR m32real | X | X | X | X | X | X | Replace ST with m32real ö ST | 
| DC /7 | FDIVR m64real | X | X | X | X | X | X | Replace ST with m64real ö ST | 
| D8 F8+i | FDIVR ST,ST(i) | X | X | X | X | X | X | Replace ST with ST(i) ö ST | 
| DC F0+i | FDIVR ST(i),ST | X | X | X | X | X | X | Replace ST(i) with ST ö ST(i) | 
| DE F0+i | FDIVRP ST(i),ST | X | X | X | X | X | X | Replace ST(i) with ST ö ST(i); pop ST | 
| DE F1 | FDIVR | X | X | X | X | X | X | Replace ST(1) with ST ö ST(1); pop ST | 
| DE /7 | FIDIVR m16int | X | X | X | X | X | X | Replace ST with m16int ö ST | 
| DA /7 | FIDIVR m32int | X | X | X | X | X | X | Replace ST with m32int ö ST | 
- Description
The division instructions divide the other operand by the stack top and return the quotient to the destination.
- Operation
FDIVR DEST, SRC DEST ← SRC ö DEST IF instruction = FDIVRP THEN pop ST FI;
- Numeric Exceptions
P, U, O, Z, D, I, IS.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
If the source operand is in memory, it is automatically converted to the extended-real format. The performance of the division instructions depends on the PC (Precision Control) field of the FPU control word. If PC specifies a precision of 53 bits, the reverse division instructions will run in 33 clocks. If the specified precision is 24 bits, the reverse division instructions will take only 19 clocks.
FENI/FNENI - Enable Interrupts
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9B DB E0 | FENI | X | X | Clears the interrupt control mask in the control word | ||||
| DB E0 | FNENI | X | X | Clears the interrupt enable mask in the control word | 
- Description
- Operation
- FPU Flags Affected
|C0|C1|C2|C3 |--+--+--+-- | | | |
- Numeric Exceptions
- Protected Mode Exceptions
- Real Address Mode Exceptions
- Notes
FFREE - Free Floating-Point Register
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| DD C0+i | FFREE ST(i) | X | X | X | X | X | X | Tag ST(i) as empty | 
- Description
FFREE tags the destination register as empty.
- Operation
TAG(i) ← 11B;
- Numeric Exceptions
None
- Protected Mode Exceptions
.#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
.#NM if either EM or TS in CR0 is set.
- Notes
- FFREE does not affect the contents of the destination register. The floating-point stack pointer (TOP) is also unaffected.
FICOM/FICOMP - Compare Integer
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| DE /2 | FICOM m16int | X | X | X | X | X | X | Compare ST with m16int | 
| DA /2 | FICOM m32int | X | X | X | X | X | X | Compare ST with m32int | 
| DE /3 | FICOMP m16int | X | X | X | X | X | X | Compare ST with m16int and pop ST | 
| DA /3 | FICOMP m32int | X | X | X | X | X | X | Compare ST with m32int and pop ST | 
- Description
The compare integer instructions compare the stack top to the source. Following the instruction, the condition codes reflect the relation between ST and the source operand.
- Operation
CASE (relation of operands) OF Not comparable: C3, C2, C0 ← 111; ST > SRC: C3, C2, C0 ← 000; ST < SRC: C3, C2, C0 ← 001; ST = SRC: C3, C2, C0 ← 100; If instruction = FICOMP THEN pop ST; FI;
- FPU Flags Affected
FPU FLAGS |EFLAGS -----------+------ C0 |CF -----------+------ C1 |(none) -----------+------ C2 |PF -----------+------ C3 |ZF
C1 as described in FPU Flags Affected; C0, C2, C3 as specified above.
- Numeric Exceptions
D, I, IS.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
The memory operand is converted to extended-real format before the comparison performed. If either operand is a NaN or is in an undefined format, of if a stack fault occurs, the invalid operation exception is raised, and the condition bits are set to "unordered".
FILD - Load Integer
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| DF /0 | FILD m16int | X | X | X | X | X | X | Push m16int onto the FPU stack | 
| DB /0 | FILD m32int | X | X | X | X | X | X | Push m32int onto the FPU stack | 
| DF /5 | FILD m64int | X | X | X | X | X | X | Push m64int onto the FPU stack | 
- Description
FILD converts the source signed integer operand into extended-real format, and pushes it onto the FPU stack.
- Operation
Decrement FPU stack-top pointer; ST(0) ← SRC;
- Numeric Exceptions
IS.
- Protected Mode Exceptions
.#GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
The source is loaded without rounding error. ST(7) must be empty to avoid causing an invalid-operation exception.
FINCSTP - Increment Stack-Top Pointer
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 F7 | FINCSTP | X | X | X | X | X | X | Increment top-of-stack pointer for FPU register stack | 
- Description
FINCSTP adds one (without carry) to the three-bit TOP field of the FPU status word.
- Operation
IF TOP = 7 THEN TOP ← 0; ELSE TOP ← TOP + 1; FI;
- Numeric Exceptions
None
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM is either EM or TS in CR0 is set.
- Notes
The effect of FINCSTP is to rotate the stack. It does not alter register tags or contents, nor does it transfer data. It is not equivalent to popping the stack, because it does not set the tag of the old stack-top to empty.
FINIT/FNINIT - Initialize Floating-Point Unit
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9B DB E3 | FINIT | X | X | X | X | X | X | Initialize FPU after checking for unmasked FP error condition | 
| DB E3 | FNINIT | X | X | X | X | X | X | Initialize FPU without checking for unmasked FP error condition | 
- Description
The initialization instructions set the FPU into a known state, unaffected by any previous activity. The FPU control word is set to 037FH (round to nearest, all exceptions masked, 64-bit precision). The status word is cleared (no exception flags set, stack register R0=stack-top). The stack registers are all tagged as empty. The error pointers (both instruction and data) are cleared.
- Operation
CW ← 037FH; (* Control word *) SW ← 0; (*Status word*) TW ← FFFFH; (* Tag word *) FEA ← 0; FDS ← 0; (* Data pointer *) FIP ← 0; FOP ← 0; FCS ← 0; (* Instruction pointer *)
- FPU Flags Affected
C0|C1|C2|C3 --+--+--+-- 0 |0 |0 |0
C0, C1, C2, C3 cleared.
- Numeric Exceptions
None
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
FINIT checks for unmasked floating-point error conditions before performing the initialization; FNINIT does not. On the Pentium processor, unlike the Intel387 math coprocessor, FINIT and FNINIT clear the error pointers.
FIST/FISTP-Store Integer
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| DF /2 | FIST m16int | X | X | X | X | X | X | Store ST in m16int | 
| DB /2 | FIST m32int | X | X | X | X | X | X | Store ST in m32int | 
| DF /3 | FISTP m16int | X | X | X | X | X | X | Store ST in m16int and pop ST | 
| DB /3 | FISTP m32int | X | X | X | X | X | X | Store ST in m32int and pop ST | 
| DF /7 | FISTP m64int | X | X | X | X | X | X | Store ST in m64int and pop ST | 
- Description
FIST converts the value in ST into a signed integer according to the RC field of the control word and transfers the result to the destination. ST remains unchanged. FIST accepts word and short integer destinations; FISTP accepts these and long integers as well.
- Operation
DEST ← ST(0); IF instruction = FISTP THEN pop ST FI;
- Numeric Exceptions
P, I, IS.
- Protected Mode Exceptions
- GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
Negative zero is stored with the same encoding (00..00) as positive zero. If the value is too large to represent as an integer, an I exception is raised. The masked response is to write the most negative integer to memory.
FLD-Load Real
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 /0 | FLD m32real | X | X | X | X | X | X | Push m32real onto the FPU stack | 
| DD /0 | FLD m64real | X | X | X | X | X | X | Push m64real onto the FPU stack | 
| DB /5 | FLD m80real | X | X | X | X | X | X | Push m80real onto the FPU stack | 
| D9 C0+i | FLD ST(i) | X | X | X | X | X | X | Push ST(i) onto the FPU stack | 
- Description
FLD pushes the source operand onto the FPU stack. If the source is a register, the register number used is that before the stack-top pointer is decremented. In particular, coding FLD ST(0) duplicates the stack top.
- Operation
Decrement FPU stack-top pointer; ST(0) ← SRC;
- Numeric Exceptions
D, I, IS.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
If the source operand is single- or double-real format, it is automatically converted to the extended-real format. Loading an extended-real operand does not require conversion, so the I and D exceptions will not occur in this case. ST(7) must be empty to avoid causing an invalid-operation exception.
FLD1/FLDL2T/FLDL2E/FLDPI/FLDLG2/FLDLN2/FLDZ - Load Constant
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 E8 | FLD1 | X | X | X | X | X | X | Push +1.0 onto the FPU Stack | 
| D9 E9 | FLDL2T | X | X | X | X | X | X | Push log210 onto the FPU stack | 
| D9 EA | FLDL2E | X | X | X | X | X | X | Push log2e onto the FPU stack | 
| D9 EB | FLDPI | X | X | X | X | X | X | Load ã (pi) onto the FPU stack | 
| D9 EC | FLDLG2 | X | X | X | X | X | X | Push log102 onto the FPU stack | 
| D9 ED | FLDLN2 | X | X | X | X | X | X | Push loge2 onto the FPU stack | 
| D9 EE | FLDZ | X | X | X | X | X | X | Push +0.0 onto the FPU stack | 
- Description
Each of the constant instructions pushes a commonly-used constant (in extended-real format) onto the FPU stack.
- Operation
Decrement FPU stack-top pointer; ST(0) ← CONSTANT;
- Numeric Exceptions
IS
- Protected Mode Exceptions
.#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
.#NM if either EM or TS in CR0 is set.
- Notes
ST(7) must be empty to avoid an invalid exception. An internal 66-bit constant is used and rounded to external-real format (as specified by the RC bit of the control words). The precision exception is not raised.
FLDCW - Load Control Word
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+------------------------------ |D9 /5 |FLDCW m16 |X|X|X|X|X|X|Load FPU control word from m16
- Description
FLDCW replaces the current value of the FPU control word with the value contained in the specified memory word.
- Operation
CW ← SRC;
- Numeric Exceptions
None, except for unmasking an existing exception.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
FLDCW is typically used to establish or change the FPU's mode of operation. If an exception bit in the status word is set, loading a new control word that unmasks that exception will result in a floating-point error condition. When changing modes, the recommended procedure is to clear any pending exceptions before loading the new control word.
FLDENV - Load FPU Environment
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 /4 | FLDENV m14byte/m28byte | X | X | X | X | X | X | Load FPU environment from m14byte or m28byte | 
| D9 /4 | FLDENVW m14byte | X | X | X | Load FPU environment from m14byte | |||
| D9 /4 | FLDENVD m28byte | X | X | X | Load FPU environment from m28byte | 
- Description
FLDENV reloads the FPU environment from the memory area defined by the source operand. This data should have been written by previous FSTENV or FNSTENV instruction. The FPU environment conists of the FPU control word, status word, tag word, and error pointers (both data and instruction). The environment layout in memory depends on both the operand size and the current operating mode of the processor. The USE attribute of the current code segment determines the operand size: The 14-byte operand applies to a USE16 segment, and the 28- byte operand applies to a USE32 segment. Refer to the Intel documentation for figures of the environment layouts for both operand sizes in both real mode and protected mode. (In virtual-8086 mode, the real mode layout is used.) FLDENV should be run in the same operating mode as the corresponding FSTENV or FNSTENV.
- Operation
FPU environment ← SRC;
- Numeric Exceptions
- None, except for loading an unmasked exception.
- Protected Mode Exceptions
- #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
- Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
- If the environment image contains an unmasked exception, loading it will result in a floating-point error condition.
FMUL/FMULP/FIMUL - Multiply
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| DE C9 | FMUL | X | X | X | X | X | X | Multiply ST(1) by ST and pop ST | 
| D8 /1 | FMUL m32real | X | X | X | X | X | X | Multiply ST by m32real | 
| DC /1 | FMUL m64real | X | X | X | X | X | X | Multiply ST by m64real | 
| D8 C8+i | FMUL ST,ST(i) | X | X | X | X | X | X | Multiply ST by ST(i) | 
| DC C8+i | FMUL ST(i),ST | X | X | X | X | X | X | Multiply ST(i) by ST | 
| DE C8+i | FMULP ST(i),ST | X | X | X | X | X | X | Multiply ST(i) by ST and pop ST | 
| DE /1 | FIMUL m16int | X | X | X | X | X | X | Multiply ST by m16int | 
| DA /1 | FIMUL m32int | X | X | X | X | X | X | Multiply ST by m32int | 
- Description
The multiplication instructions multiply the destination operand by the source operand and return the product to the destination.
- Operation
DEST ← DEST * SRC; IF instruction = FMULP THEN pop ST FI;
- Numeric Exceptions
P, U, O, D, I.
- Protected Mode Exceptions
#GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
If the source operand is in memory, it is automatically converted to the extended-real format.
FNOP-No Operation
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 D0 | FNOP | X | X | X | X | X | X | No operation is performed | 
- Description
FNOP performs no operation. It affects nothing except instruction pointers.
- Numeric Exceptions
None
- Protected Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
#NM if either EM or TS in CR0 is set.
FPATAN-Partial Arctangent
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 F3 | FPATAN | X | X | X | X | X | X | Replaces ST(1) with arctan(ST(1) ö ST) and pop ST | 
- Description
The partial arctangent instruction computes the arctangent of ST(1) ö ST, and returns computed value, expressed in radians, to ST(1). It then pops ST. The result has the same sign as the operand from ST(1), and a magnitude less than ã.
- Operation
ST(1) ← arctan(ST(1) ö ST); pop ST;
- Numeric Exceptions
P, U, D, I, IS.
- Protected Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Notes
There is no restriction on the range of arguments that FPATAN can accept. The fact that FPATAN takes two arguments and computes the arctangent of their ratio simplifies the calculation of other trigonometric functions. For instance, arcsin(x) (which is the arctangent of x ö û(1-xý)) can be computed using the following sequence of operations: Push x onto the FPU stack; compute û(1-xý) and push the resulting value onto the stack; run FPATAN.
FPREM-Partial Remainder
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 F8 | FPREM | X | X | X | X | X | X | Replace ST with the remainder obtained on dividing ST by ST(1) | 
- Description
The partial remainder instruction computes the remainder obtained on dividing ST by ST(1), and leaves the result in ST. The sign of the remainder is the same as the sign of the original dividend in ST. The magnitude of the remainder is less than that of the modulus.
- Operation
EXPDIF ← exponent(ST) - exponent(ST(1));
IF EXPDIF < 64 
THEN 
   Q ← integer obtained by chopping ST ö ST(1) toward zero;
   ST ← ST - (ST(1) * Q);
   C2 ← 0;
   C0, C1, C3 ← three least-significant bits of Q; (* Q2, Q1, Q0 *)
ELSE 
   C2 ← 1;
   N ← a number between 32 and 63;
   QQ ← integer obtained by chopping (ST ö ST(1)) ö 2EXPDIF-N
       toward zero;
   ST ← ST - (ST(1) * QQ * 2EXPDIF-N;
FI;
- Numeric Exceptions
U, D, I, IS.
- Protected Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Notes
FREM produces an exact result; the precision (inexact) exception does not occur and the rounding control has no effect. The FPREM instruction is not the remainder operation specified in IEEE Std 754. To get that remainder, the FPREM1 instruction should be used. FPREM is supported for compatibility with the 8087 and Intel287 math coprocessors. FPREM works by iterative subtraction, can reduce the exponent of ST by no more than 63 in one execution. If FPREM succeeds in producing a remainder that is less than the modulus, the function is complete and the C2 flag is cleared. Otherwise, C2 is set, and the result in ST is called the partial remainder. The exponent of the partial remainder is less than the exponent of the original dividend by at least 32. Software can run the instruction again (using the partial remainder in ST as the dividend) until C2 is cleared. A higher-priority interrupting routine that needs the FPU can force a context switch between the instructions in the remainder loop. An important use of FPREM is to reduce the arguments of periodic functions. When reduction is complete, FPREM provides the three least-significant bits of the quotient in flags C3, C1, and C0. This is important in argument reduction for the tangent function (using a modulus of ã/4), because it locates the original angle in the correct one of eight sectors of the unit circle.
FPREM1 - Partial Remainder
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 F5 | FPREM1 | X | X | X | Replace ST with the remainder obtained on dividing ST by ST(1) | 
- Description
The partial remainder instruction computes the remainder obtained on dividing ST by ST(1), and leaves the result in ST. The magnitude of the remainder is less than that of the modulus.
- Operation
EXPDIF ← exponent(ST) - exponent(ST(1));
IF EXPDIF < 64
THEN
  Q ← integer obtained by rounding ST ö ST(1) to the nearest integer;
      (*or the nearest even integer if the result is exactly halfway between 2 integers *)
  ST ← ST - (ST(1) * Q);
  C2 ← 0;
  Q ← ST - (ST(1) * Q);
  C0, C1, C3 ← three least-significant bits of Q; (* Q2, Q1, Q0 *)
  C2 ← 0;
  C0, C1, C3 ← three least-significant bits of Q; (* Q2, Q1, Q0 *)
ELSE
  C2 ← 1;
  N ← a number between 32 and 63;
  QQ ← integer obtained by chopping (ST ö ST(1)) ö 2EXPDIF-N;
      toward zero;
  ST ← ST - (ST(1) * QQ * 2EXPDIF-N
FI;
- Numeric Exceptions
U, D, I, IS.
- Protected Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Notes
FPREM1 produces an exact result; the precision (inexact) exception does not occur and the rounding control has no effect. The FPREM1 instruction is not the remainder operation specified in IEEE Std 754. It differs from FPREM in the way it rounds the quotient of ST and ST(1), when the exponent difference of exp(ST) -exp(ST)1 is less than 64. FPREM1 works by iterative subtraction, can reduce the exponent of ST by no more than 63 in one execution. If FPREM1 succeeds in producing a remainder that is less than one half the modulus, the function is complete and the C2 flag is cleared. Otherwise, C2 is set, and the result in ST is called the partial remainder. The exponent of the partial remainder is less than the exponent of the original dividend by at least 32. Software can run the instruction again (using the partial remainder in ST as the dividend) until C2 is cleared. A higher-priority interrupting routine that needs the FPU can force a context switch between the instructions in the remainder loop. An important use of FPREM1 is to reduce the arguments of periodic functions. When reduction is complete, FPREM1 provides the three least-significant bits of the quotient in flags C3, C1, and C0. This is important in argument reduction for the tangent function (using a modulus of ã/4), because it locates the original angle in the correct one of eight sectors of the unit circle.
FPTAN-Partial Tangent
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 F2 | FPTAN | X | X | X | X | X | X | Replace ST with its tangent and push 1 onto the FPU stack | 
- Description
The partial tangent instruction replaces the contents of ST with tan(ST), and then pushes 1.0 onto the FPU stack. ST, expressed in radians, must lie in the range |0| < 263.
- Operation
IF operand is in range THEN C2 ← 0; ST ← tan(ST); Decrement stack-top pointer; ST ← 1.0; ELSE C2 ← 1; FI;
- FPU Flags Affected
|C0|C1|C2|C3| |--+--+--+--| |? |* |* |? |
C1, C2 as described in FPU Flags Affected; C0, C3 undefined.
- Numeric Exceptions
P, U, D, I, IS.
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
If the operand is outside the acceptable range, the C2 flag is set, and ST remains unchanged. It is the programmer's responsibility to reduce the operand to an absolute value smaller than 263 by subtracting an appropriate integer multiple of 2ã. Refer to the Intel documentation 6 for a discussion of the proper value to use for ã in performing such reductions. The fact that FPTAN pushes 1.0 onto the FPU stack after computing tan(ST) maintains compatibility with the 8087 and Intel287 math coprocessors, and simplifies the calculation of other trigonometric functions. For instance, the cotangent (which is the reciprocal of the tangent) can be computed by running FDIVR after FPTAN. ST(7) must be empty to avoid an invalid-operation exception.
FRNDINT-Round to Integer
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 FC | FRNDINT | X | X | X | X | X | X | Round ST to an integer | 
- Description
The round to integer instruction rounds the value in ST to an integer according to the RC field of the FPU control word.
- Operation
ST ← rounded ST;
- Numeric Exceptions
P, D, I, IS.
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
FRSTOR/FRSTRW/FRSTRD - Restore FRU State
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| DD /4 | FRSTOR m94byte/m108byte | X | X | X | X | X | X | Load FPU state from m94byte or m108byte | 
| DD /5 | FRSTORW m94byte | X | X | X | Load FPU state from m94byte | |||
| DD /4 | FRSTORD m108byte | X | X | X | Load FPU state from m108byte | 
- Description
- FRSTOR reloads the FPU state (environment and register stack) from the memory area defined by the source operand. This data should have been written by a previous FSAVE or FNSAVE instruction.
- The FPU environment consists of the FPU control word, status word, tag word, and error pointers (both data and instruction). The environment layout in memory depends on both the operand size and the current operating mode of the processor. The USE attribute of the current code segment determines the operand size: the 14-byte operand applies to a USE16 segment, and the 28- byte operand applies to a USE32 segment. Refer to the Intel documentation for the environment layouts for both operand sizes in both real mode and protected mode. (In virtual-8086 mode, the real mode layout is used.) The stack registers, beginning with ST and ending with ST(7), are in the 80 bytes that immediately follow the environment image. FRSTOR should be run in the same operating mode as the corresponding FSAVE or FNSAVE.
- Operation
FPU state ← SRC;
- Numeric Exceptions
- None, except for loading an unmasked exception.
- Protected Mode Exceptions
- #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
- Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
- If the state image contains an unmasked exception, loading it will result in a floating-point error condition.
FSAVE/FNSAVE-Store FPU State
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9B DD /6 | FSAVE m94byte/m108byte | X | X | X | X | X | X | Store FPU state to m94byte or m108byte after checking for unmasked FP error condition; then re-initialize the CPU | 
| 9B DD /6 | FSAVEW m94byte | X | X | X | Store FPU state to m94byte after checking for unmasked FP error condition; then re-initialize the FPU | |||
| 9B DD /6 | FSAVED m108byte | X | X | X | Store FPU state to m108byte after checking for unmasked FP error condition; then re-initialize the FPU | |||
| DD /6 | FNSAVE m94byte/ | X | X | X | X | X | X | Store FPU environment to m94byte or m108byte without checking for unmasked FP error condition; then re-initialize the FPU | 
| DD /6 | FNSAVEW m94byte | X | X | X | Store FPU environment to m94byte without checking for unmasked FP error condition; then re-initialize the FPU | |||
| DD /6 | FNSAVED m108byte | X | X | X | Store FPU environment to m108byte without checking for unmasked FP error condition; then re-initialize the FPU | 
- Description
The save instructions write the current FPU state (environment and register stack) to the specified destination, and then re-initialize the FPU. The environment consists of the FPU control word, status word, tag word, and error pointers (both data and instruction).
The state layout in memory depends on both operand size and the current operating mode of the processor. The USE attribute of the current code segment determines the operand size: the 94-byte operand applies to USE16 segment, and the 108-byte operand applies to a USE32 segment.
Refer to the Intel documentation for the environment layouts for both operand sizes in both real mode and protected mode. (In virtual-8086 mode, the real mode layout is used.) The stack registers, beginning with ST and ending with ST( 7), are stored in the 80 bytes that immediately follow the environment image.
- Operation
DEST ← FPU state; initialize FPU; (* Equivalent to FNINIT *)
- FPU Flags Affected
|C0|C1|C2|C3| |--+--+--+--| |0 |0 |0 |0 |
C0, C1, C2, C3 cleared.
- Numeric Exceptions
None
- Protected Mode Exceptions
- GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
FSAVE and FNSAVE do not store the FPU state until all FPU activity is complete. Thus, the saved image reflects the state of the FPU after any previously decoded instruction has been run. If a program is to read from the memory image of the state following a save instruction, it must issue an FWAIT instruction to ensure that the storage is complete. The save instructions are typically used when an operating system needs to perform a context switch, or an exception handler needs to use the FPU, or an application program wants to pass a "clean" FPU to a subroutine.
FSCALE-Scale
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 FD | FSCALE | X | X | X | X | X | X | Scale ST by ST(1) | 
- Description
The scale instruction inteprets the value in (ST(1) as an integer, and adds this integer to the exponent of ST. Thus, FSCALE provides rapid multiplication or division by integral powers of 2.
- Operation
ST ← ST * 2ST(1);
- Numeric Exceptions
P, U, O, D, I, IS.
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
FSCALE can be used as an inverse to FXTRACT. Because FSCALE does not pop the exponent part, however, FSCALE must be followed by FSTP ST(1) in order to completely undo the effect of a preceding FXTRACT. There is no limit on the range of the scale factor in ST(1). If the value is not integral, FSCALE uses the nearest integer smaller in magnitude; i.e. , it chops the value toward 0. If the resulting integer is zero, the value in ST is not changed.
FSETPM-Set Protected Mode
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| DB E4 | FSETPM | X | Sets the operating mode of the 80287 to protected virtual address mode | 
- Description
Sets the operating mode of the 80287 to Protected Virtual-Address mode. When the 80287 is first initialized following hardware RESET, it operates in Real-Address mode, just as does the 80286 CPU. Once the 80287 NPX has been set into Protected mode, only a hardware RESET can return the NPX to operation in Real-Address mode. When the 80287 operates in Protected mode, the NPX exception pointers are represented differently than they are in Real-Address mode (see the FSAVE and FSTENV instructions). This distinction is evident primarily to writers of numeric exception handlers, however. For general application programmers, the operating mode of the 80287 need not be a concern.
- Operation
- FPU Flags Affected
| C0 | C1 | C2 | C3 | 
|---|---|---|---|
- Numeric Exceptions
- Protected Mode Exceptions
- Real Address Mode Exceptions
FSIN-Sine
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+------------------------ |D9 FE |FSIN | | | |X|X|X|Replace ST with its sine
- Description
The sine instruction replaces the contents of ST with sin(ST). ST, expressed in radians, must lie in the range |01| < 263.
- Operation
If operand is in range THEN C2 ← 0; ELSE C2 ← 1; FI:
- FPU Flags Affected
|C0|C1|C2|C3| |--+--+--+--| |? |* |* |? |
C1, C2 as described in FPU Flags Affected; C0, C3 undefined.
- Numeric Exceptions
P, U, D, I, IS.
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
If the operand is outside the acceptable range, the C2 flag is set, and ST remains unchanged. It is the programmer's responsibility to reduce the operand to an absolute value smaller than 263 by subtracting an appropriate integer multiple of 2ã. Refer to the Intel documentation for a discussion of the proper value to use the ã in performing such reductions.
FSINCOS-Sine and Cosine
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 FB | FSINCOS | X | X | X | Compute the sine and cosine of ST; replace ST with the sine, then push the cosine onto the FPU stack | 
- Description
FSINCOS computes both sin(ST) and cos(ST), replaces ST with the sine and then pushes the cosine onto the FPU stack. ST, expressed in radians, must lie in the range |0| < 263.
- Operation
IF operand is in range THEN C2 ← 0; TEMP ← cos(ST); ST ← sin(ST); Decrement FPU stack-top pointer; ST ← TEMP; ELSE C2 ← 1; FI:
- FPU Flags Affected
C0|C1|C2|C3 --+--+--+-- ? |* |* |?
C1, C2 as described in FPU Flags Affected; C0, C3 undefined.
- Numeric Exceptions
P, U, D, I, IS.
- Protected Mode Exceptions
.#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
.#NM if either EM or TS in CR0 is set.
- Notes
If the operand is outside the acceptable range, the C2 flag is set, and ST remains unchanged. It is the programmer's responsibility to reduce the operand to an absolute value smaller than 263 by subtracting an appropriate integer multiple of 2ã. Refer to the Intel documentation for a discussion of the proper value to use for ã in performing such reductions. It is faster to run FSINCOS than to run both FSIN and FCOS.
FSQRT-Square Root
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 FA | FSQRT | X | X | X | X | X | X | Replace ST with its square root | 
- Description
The square root instruction replaces the value in ST with its square root.
- Operation
ST ← square root of ST;
- Numeric Exceptions
P, D, I, IS.
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
The square root of -0 is -0.
FST/FSTP-Store Real
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 /2 | FST m32real | X | X | X | X | X | X | Copy ST to m32real | 
| DD /2 | FST m64real | X | X | X | X | X | X | Copy ST to m64real | 
| DD D0+i | FST ST(i) | X | X | X | X | X | X | Copy ST to ST(i) | 
| D9 /3 | FSTP m32real | X | X | X | X | X | X | Copy ST to m32real and pop ST | 
| DD /3 | FSTP m64real | X | X | X | X | X | X | Copy ST to m64real and pop ST | 
| DB /7 | FSTP m80real | X | X | X | X | X | X | Copy ST to m80real and pop ST | 
| DD D8+i | FSTP ST(i) | X | X | X | X | X | X | Copy ST to ST(i) and pop ST | 
- Description
FST copies the current value in the ST register to the destination, which can be another register or a single- or double-real memory operand. FSTP copies and then pops ST; it accepts extended-real memory operands as well as the types accepted by FST. If the source is register, the register number used is that before the stack is popped.
- Operation
DEST ← ST(0); IF instruction = FSTP THEN pop ST FI;
- Numeric Exceptions
- Register or extended-real destinations: IS
- Single- or double-real destinations: P, U, O, I, IS
- Protected Mode Exceptions
- GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
If the destination is single- or double-real, the significand is rounded to the width of the destination according to the RC field of the control word, and the exponent is converted to the width and bias of the destination format. The over/underflow condition is checked for as well. If ST contains zero, ñì, or a NaN, then the significand is not rounded, but chopped (on the right) to fit the destination. Nor is the exponent converted; it too is chopped on the right. These operations preserve the value's identity as ì or NaN (exponent all ones). The invalid-operation exception is not raised when the destination is a nonempty stack element. A denormal operand in ST(0) causes an underflow. No denormal operand exception is raised.
FSTCW/FNSTCW-Store Control Word
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9B D9 /7 | FSTCW m16 | X | X | X | X | X | X | Store FPU control word to m16 after checking for unmasked FP error condition | 
| D9 /7 | FNSTCW m16 | X | X | X | X | X | X | Store FPU control word to m16 without checking for unmasked FP error condition | 
- Description
FSTCW and FNSTCW write the current value of the FPU control word to the specified destination.
- Operation
DEST ← CW;
- Numeric Exceptions
- None
- Protected Mode Exceptions
- #GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
- Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- Same exceptions as in Real Address Mode; #PF(fault-code for a page fault; # AC for unaligned memory reference if the current privilege level is 3.
- Notes
- FSTCW checks for unmasked floating-point error conditions before storing the control word FNSTCW does not.
FSTENV/FNSTENV-Store FPU Environment
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9B D9 /6 | FSTENV m14byte/m28byte | X | X | X | X | X | X | Store FPU environment to m14byte or m28byte after checking for unmasked FP error condition; then mask all FP exceptions. | 
| 9B D9 /6 | FSTENVW m14byte | X | X | X | Store FPU environment to m14byte after checking for unmasked FP error condition; then mask all FP exceptions | |||
| 9B D9 /6 | FSTENVD m28byte | X | X | X | Store FPU environment to m28byte after checking for unmasked FP error condition; then mask all FP exceptions | |||
| D9 /6 | FNSTENV m14byte/m28byte | X | X | X | X | X | X | Store FPU environment to m14byte or m28byte without checking for unmasked FP error condition; then mask all FP exceptions | 
| D9 /6 | FNSTENVW m14byte | X | X | X | Store FPU environment to m14byte without checking for unmasked FP error condition; then mask all FP exceptions | |||
| D9 /6 | FNSTENVD m28byte | X | X | X | Store FPU environment to m28byte without checking for unmasked FP error condition; then mask all FP exceptions | 
- Description
- The store environment instructions write the current FPU environment to the specified destination, and then mask all floating-point exceptions. The FPU environment consists of the FPU control word, status word, tag word, and error pointer (both data and instruction).
- The environment layout in memory depends on both the operand size and the current operating mode of the processor. The USE attribute of the current code segment determines the operand size: the 14-byte operand applies to a USE16 segment, and the 28-byte operand applies to a USE32 segment. Figures 6-6 through 6-8 show the environment layouts for both operand sizes in both real mode and protected mode. (In virtual-8086 mode, the real mode layout is used).
- Operation
DEST ← FPU environment; CW[0..5] ← 111111B;
- Numeric Exceptions
- None
- Protected Mode Exceptions
- #GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
- Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
- FSTENV and FNSTENV do not store the environment until FPU activity is complete. Thus, the save environment reflects the state of the FPU after any previously decoded instruction has been run.
- The store environment instructions are often used by exception handlers because they provide access to the FPU error pointers. The environment is typically saved onto the memory stack. After saving the environment, FSTENV and FNSTENV sets all the exception masks in the FPU control word. This prevents floating-point errors from interrupting the exception handler.
- FSTENV checks for unmasked floating-point error conditions before storing the FPU environment; FNSTENV does not.
FSTSW/FNSTSW-Store Status Word
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9B DF /7 | FSTSW m16 | X | X | X | X | X | X | Store FPU status word to m16 after checking for unmasked FP error condition | 
| 9B DF E0 | FSTSW AX | X | X | X | X | Store FPU status word to AX register after checking for unmasked FP error condition | ||
| DF /7 | FNSTSW m16 | X | X | X | X | X | X | Store FPU status word to m16 without checking for unmasked FP error condition | 
| DF E0 | FNSTSW AX | X | X | X | X | Store FPU status word to AX register without checking for unmasked FP error condition | 
- Description
FSTSW and FNSTSW write the current value of the FPU status word to the specified destination, which can be either a two-byte location in memory or the AX register.
- Operation
DEST ← SW;
- Numeric Exceptions
None
- Protected Mode Exceptions
- GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
FSTSW checks for unmasked floating-point error conditions before storing the status word; FNSTSW does not. FSTSW and FNSTSW are used primarily in conditional branching (after a comparison, FPREM, FPREM1, or FXAM instruction). They can also be used to invoke exception handlers (by polling the exception bits) in environments that do not use interrupts. When FNSTSW AX is run, the AX register is updated before the processor runs any further instructions. The status stored is that from the completion of the prior ESC instruction.
FSUB/FSUBP/FISUB-Subtract
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D8 /4 | FSUB m32real | X | X | X | X | X | X | Replace ST with ST - m32real | 
| DC /4 | FSUB m64real | X | X | X | X | X | X | Replace ST with ST - m64real | 
| D8 E0+i | FSUB ST,ST(i) | X | X | X | X | X | X | Replace ST with ST - ST(i) | 
| DC E8+i | FSUB ST(i),ST | X | X | X | X | X | X | Replace ST(i) with ST(i) - ST | 
| DE E8+i | FSUBP ST(i),ST | X | X | X | X | X | X | Replace ST(i) with ST - ST(i); pop ST | 
| DE E9 | FSUB | X | X | X | X | X | X | Replace ST(1) with ST - ST(1); pop ST | 
| DE /4 | FISUB m16int | X | X | X | X | X | X | Replace ST with ST - m16int | 
| DA /4 | FISUB m32int | X | X | X | X | X | X | Replace ST with ST - m32int | 
- Description
The subtraction instructions subtract the other operand from the stack top and return the difference to the destination.
- Operation
DEST ← ST - Other Operand; IF instruction = FSUBP THEN pop ST FI;
- Numeric Exceptions
P, U, O, D, I, IS.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
If the source operand is in memory, it is automatically converted to the extended-real format.
FSUBR/FSUBRP/FISUBR-Reverse Subtract
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D8 /5 | FSUBR m32real | X | X | X | X | X | X | Replace ST with m32real - ST | 
| DC /5 | FSUBR m64real | X | X | X | X | X | X | Replace ST with m64real - ST | 
| D8 E8+i | FSUBR ST,ST(i) | X | X | X | X | X | X | Replace ST with ST(i) - ST | 
| DC E0+i | FSUBR ST(i),ST | X | X | X | X | X | X | Replace ST(i) with ST - ST(i) | 
| DE E0+i | FSUBRP ST(i),ST | X | X | X | X | X | X | Replace ST(i) with ST - ST(i) | 
| DE E1 | FSUBR | X | X | X | X | X | X | Replace ST(1) with ST - ST(1); pop ST | 
| DE /5 | FISUBR m16int | X | X | X | X | X | X | Replace ST with m16int - ST | 
| DA /5 | FISUBR m32int | X | X | X | X | X | X | Replace ST with m32int - ST | 
- Description
The reverse subtraction instructions subtract the stack top from the other operand and return the difference to the destination.
- Operation
DEST ← Other Operand - ST; IF instruction = FSUBRP THEN pop ST FI;
- Numeric Exceptions
P, U, O, D, I, IS.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in SS segment; #PF(fault- code) for a page fault; #NM if either EM or TS in CR0 is set; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH; Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
If the source operand is in memory, it is automatically converted to the extended-real format.
FTST-Test
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+------------------- |D9 E4 |FTST |X|X|X|X|X|X|Compare ST with 0.0
- Description
The test instruction compares the stack top to 0.0. Following the instruction, the condition codes reflect the result of the comparison.
- Operation
CASE (relation of operands) OF 
     Not comparable:   C3, C2, C0 ← 111;
     ST > SRC:         C3, C2, C0 ← 000;
     ST < SRC:         C3, C2, C0 ← 001;
     ST = SRC:         C3, C2, C0 ← 100;
- FPU Flags Affected
|FPU FLAGS |EFLAGS |------------+------ |C0 |CF |------------+------ |C1 |(none) |------------+------ |C2 |PF |------------+------ |C3 |ZF
C1 as described in FPU Flags Affected; C0, C2, C3 as specified above.
- Numeric Exceptions
D, I, IS.
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
If ST contains a NaN or an object of undefined format, or if a stack fault occurs, the invalid-operation exception is raised, and the condition bits are set to "unordered." The sign of zero is ignored, so that -0.0=+0.0.
FUCOM/FUCOMP/FUCOMPP-Unordered Compared Real
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| DD E1 | FUCOM | X | X | X | Compare ST with ST(1) | |||
| DD E0+i | FUCOM ST(i) | X | X | X | Compare ST with ST(i) | |||
| DD E9 | FUCOMP | X | X | X | Compare ST with ST(1) and pop ST | |||
| DD E8+i | FUCOMP ST(i) | X | X | X | Compare ST with ST(i) and pop ST | |||
| DA E9 | FUCOMPP | X | X | X | Compare ST with ST(1) and pop ST twice | 
- Description
- The unordered compare real instructions compare the stack top to the source , which must be a register. If no operand is encoded, ST is compared to ST( 1). Following the instruction, the condition codes reflect the relation between ST and the source operand.
- Operation
CASE (relation of operands) OF
     Not comparable:   C3, C2, C0 ← 111;
     ST > SRC:         C3, C2, C0 ← 000;
     ST < SRC:         C3, C2, C0 ← 001;
     ST = SRC:         C3, C2, C0 ← 100;
IF instruction = FUCOMP THEN pop ST; FI;
IF instruction = FUCOMPP THEN pop ST; pop ST; FI;
- FPU Flags Affected
| FPU FLAGS | EFLAGS | 
|---|---|
| C0 | CF | 
| C1 | (none) | 
| C2 | PF | 
| C3 | ZF | 
C1 as described in FPU Flags Affected; C0, C2, C3 as specified above.
- Numeric Exceptions
- D, I, IS.
- Protected Mode Exceptions
- #NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
- Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- #NM if either EM or TS in CR0 is set.
- Notes
- If either operand is an SNaN or is in an undefined format, or if a stack fault occurs, the invalid-operation exception is raised, and the condition bits are set to "unordered".
- If either operand is a QNaN, the condition bits are set to "unordered." Unlike the ordinary compare instructions (FCOM, etc.), the unordered compare instructions do not raise the invalid-operation exception on account of a QNaN operand.
- The sign of zero is ignored, so that -0.0=+0.0.
FWAIT-Wait
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |---------+--------------+-+-+-+-+-+-+-------------- |9B |FWAIT |X|X|X|X|X|X|Alias for WAIT
- Description
FWAIT causes the processor to check for pending unmasked numeric exceptions before proceeding.
- Numeric Exceptions
None
- Protected Mode Exceptions
- NM if both MP and TS in CR0 are set.
- Real Address Mode Exceptions
Interrupt 7 if both MP and TS in CR0 are set.
- Virtual 8086 Mode Exceptions
- NM if both MP and TS in CR0 are set.
- Notes
As its opcode shows, FWAIT is not actually an ESC instruction, but an alternate mnemonic for WAIT. Coding FWAIT after an ESC instruction ensures that any unmasked floating-point exceptions the instruction may cause are handled before the processor has a chance to modify the instruction's results. Refer to the Intel documentation for more information about when to use FWAIT.
FXAM-Examine
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 E5 | FXAM | X | X | X | X | X | X | Report the type of object in the ST register | 
- Description
The examine instruction reports the type of object contained in the ST register by setting the FPU Flags.
- Operation
C1 ← sign bit of ST; (* 0 for positive, 1 for negative *)
CASE (type of object in ST) OF 
     Unsupported:  C3, C2, C0 ← 000;
     NaN:         C3, C2, C0 ← 001;
     Normal:      C3, C2, C0 ← 010;
     Infinity:    C3, C2, C0 ← 011;
     Zero:        C3, C2, C0 ← 100;
     Empty:       C3, C2, C0 ← 101;
     Denormal:    C3, C2, C0 ← 110;
- FPU Flags Affected
| FPU FLAGS | EFLAGS | 
|---|---|
| C0 | CF | 
| C1 | (none) | 
| C2 | PF | 
| C3 | ZF | 
C0, C1, C2, C3 as shown above.
- Numeric Exceptions
None
- Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
C1 bit represents the sign of ST(0) regardless of whether ST(0) is empty or full.
FXCH-Exchange Register Contents
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 C9 | FXCH | X | X | X | X | X | X | Exchange the contents of ST and ST(1) | 
| D9 C8+i | FXCH ST(i) | X | X | X | X | X | X | Exchange the contents of ST and ST(i) | 
- Description
FXCH swaps the contents of the destination and stack-top registers. If the destination is not coded explicitly, ST(1) is used.
- Operation
TEMP ← ST; ST ← DEST; DEST ← TEMP;
- Numeric Exceptions
IS.
- Protected Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Notes
Many numeric instructions operate only on the stack top; FXCH provides a simple means for using these instructions on lower stack elements. For example, the following sequence takes the square root of the third register from the top (assuming that ST is nonempty):
FXCH ST (3) FSQRT FXCH ST (3)
FXCH can be paired with some floating point instructions (i.e., FADD, FSUB, FMUL, FLD, FCOM, FUCOM, FCHS, FTST, FABS, FDIV. This set also includes the FADDP, FSUBRP, etc., instructions). When paired, the FXCH gets run in parallel, and does not take any additional clocks.
FXTRACT-Extract Exponent and Significand
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D9 F4 | FXTRACT | X | X | X | X | X | X | Separate ST into its exponent and significand; replace ST with exponent then push significand onto FPU stack | 
- Description
FXTRACT splits the value in ST into its exponent and significand. The exponent replaces the original operand on the stack and the significand is pushed onto the stack. Following execution of FXTRACT, ST (the new stack top) contains the value of the original significand expressed as a real number: its sign is the same as the operand's, its exponent is 0 true (16, 383 or 3FFFH biased), and its significand is identical to the original operand's. ST(1) contains the value of the original operand's true (unbiased) exponent expressed as a real number. To illustrate the operation of FXTRACT, assume that ST contains a number whose true exponent is +4 (i.e., its exponent field contains 4003H). After running FXTRACT, ST(1) will contain the real number +4.0; its sign will be positive, its exponent field will contain 4001H (+2 true) and its significand field will contain 1ë00...00B. In other words, the value in ST( 1) will be 1.0 * 2ý = 4. If ST contains an operand whose true exponent is - 7 (i.e., its exponent field contains 3FF8H), then FXTRACT will return an "exponent" of -7.0; after the instruction runs, ST(1)'s sign and exponent fields will contain C001H (negative sign, true exponent of 2), and its significand will be 1ë1100...00B. In other words, the value in ST(1) will be -1.75 * 2ý=-7.0. In both cases, following FXTRACT, ST's sign and significand fields will be the same as the original operand's, and its exponent field will contain 3FFFH (0 true).
- Operation
TEMP ← significand of ST; ST ← exponent of ST; Decrement FPU stack-top pointer; ST ← TEMP;
- Numeric Exceptions
Z, D, I, IS.
- Protected Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Real Address Mode Exceptions
Interrupt 7 if either EM or TS in CR0 is set.
- Virtual 8086 Mode Exceptions
#NM if either EM or TS in CR0 is set.
- Notes
FXTRACT (extract exponent and significand) performs a superset of the IEEE- recommended logb(x) function. If the original operand is zero, FXTRACT leaves -ì in ST(1) (the exponent) while ST is assigned the value zero with a sign equal to that of the original operand. The zero-divide exception is raised in this case, as well. ST(7) must be empty to avoid the invalid-operation exception. FXTRACT is useful for power and range scaling operations. Both FXTRACT and the base 2 exponential instruction F2XM1 are needed to perform a general power operation. Converting numbers in extended-real format to decimal representations (e.g., for printing or displaying) requires not only FBSTP but also FXTRACT to allow scaling that does not overflow the range of the extended format. FXTRACT can also be useful for debugging, because it allows the exponent and significand parts of a real number to be examined separately.
FYL2X-Compute y * log2x
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+---------------------------------- |D9 F1 |FYL2X |X|X|X|X|X|X|Replace ST with ST(1) * log2ST and | | | | | | | | |pop ST
- Description
FYL2X computes the base-2 logarithm of ST, multiplies the logarithm by ST(1 ), and returns the resulting value to ST(1). It then pops ST. The operand in ST must not be negative or zero.
- Operation
ST(1) ← ST(1) * log2ST; pop ST;
- Numeric Exceptions
P, U, O, Z, D, I, IS. Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
Real Address Mode Exceptions Interrupt 7 if either EM or TS in CR0 is set. Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
If the operand in ST is negative, the invalid-operation exception is raised. The FYL2X instruction is designed with a built-in multiplication to optimize the calculation of logarithms with arbitrary positive base: logbx = (log2b) -1 * log2x The instructions FLDL2T and FLDL2E load the constants log210 and log2e, respectively.
FYL2XP1-Compute y * log2(x + 1)
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+------------------------------- |D9 F9 |FYL2XP1 |X|X|X|X|X|X|Replace ST(1) with ST(1) * log2 | | | | | | | | |(ST+1.0) and pop ST
- Description
FYL2XP1 computes the base-2 logarithm of (ST+1.0), multiples the logarithm by ST(1), and returns the resulting value to ST(1). It then pops ST. The operand in ST must be in the range -(1-(û2 / 2)) ó ST ó û2 -1
- Operation
ST(1) ← ST(1) * log2(ST+1.0); pop ST;
- Numeric Exceptions
P, U, D, I, IS. Protected Mode Exceptions
- NM if either EM or TS in CR0 is set.
Real Address Mode Exceptions Interrupt 7 if either EM or TS in CR0 is set. Virtual 8086 Mode Exceptions
- NM if either EM or TS in CR0 is set.
- Notes
If the operand in ST is outside the acceptable range, the result of FYL2XP1 is undefined. The FYL2XP1 instruction provides improved accuracy over FYL2X when computing the logarithms of numbers very close to 1. When î is small, more significant digits can be retained by providing î as an argument to FYL2XP1 than by providing 1+î as an argument to FYL2X.
HLT-Halt
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F4 | HLT | X | X | X | X | X | X | Halt | 
- Description
The HLT instruction stops instruction processing and places the processor in a HALT state. An enabled interrupt, NMI, or a reset will resume execution. If an interrupt (including NMI) is used to resume execution after a HLT instruction, the saved CS:IP (or CS:EIP) value points to the instruction following the HLT instruction.
- Operation
Enter Halt state;
- Protected Mode Exceptions
The HLT instruction is a privileged instruction; #GP(0) if the current privilege level is not 0.
- Virtual 8086 Mode Exceptions
#GP(0); the HLT instruction is a privileged instruction.
IDIV-Signed Divide
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F6 /7 | IDIV r/m8 | X | X | X | X | X | X | Signed divide AX (where AH must contain sign-extension of AL) by r/m byte (results: AL=Quotient, AH=Remainder) | 
| F7 /7 | IDIV r/m16 | X | X | X | X | X | X | Signed divide DX:AX (where DX must contain sign-extension of AX) by r/m word (results: AX=Quotient, DX=Remainder) | 
| F7 /7 | IDIV r/m32 | X | X | X | Signed divide EDX:EAX (where EDX must contain sign-extension of EAX) by r/m dword (results: EAX=Quotient, EDX=Remainder) | 
- Description
The IDIV instruction performs a signed division. The dividend, quotient, and remainder are implicitly allocated to fixed registers. Only the divisor is given as an explicit r/m operand. The type of the divisor determines which registers to use as follows:
| SIZE | DIVIDEND | DIVISOR | QUOTIENT | REMAINDER | 
|---|---|---|---|---|
| byte | AX | r/m8 | AL | AH | 
| word | DX:AX | r/m16 | AX | DX | 
| dword | EDX:EAX | r/m32 | EAX | EDX | 
If the resulting quotient is too large to fit in the destination, or if the divisor is 0, an Interrupt 0 is generated. Nonintegral quotients are truncated toward 0. The remainder has the same sign as the dividend and the absolute value of the remainder is always less than the absolute value of the divisor.
- Operation
temp ← dividend / divisor; IF temp does not fit in quotient THEN Interrupt 0; ELSE quotient ← temp; remainder ← dividend MOD (r/m); FI;
Note: Divisions are signed. The dividend must be sign-extended. The divisor is given by the r/m operand. The dividend, quotient, and remainder use implicit registers. Refer to the table under "Description."
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| |? | | |? |? |? |? |? |
The OF, SF, ZF, AF, PF, and CF flags are undefined.
- Protected Mode Exceptions
Interrupt 0 if the quotient is too large to fit in the designated register (AL or AX), or if the divisor is 0; #GP (0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 0 if the quotient is too large to fit in the designated register (AL or AX), or if the divisor is 0; Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
IMUL-Signed Multiply
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F6 /5 | IMUL r/m8 | X | X | X | X | X | X | AX ← AL * r/m byte | 
| F7 /5 | IMUL r/m16 | X | X | X | X | X | X | DX:AX ← AX * r/m word | 
| F7 /5 | IMUL r/m32 | X | X | X | EDX:EAX ← EAX * r/m dword | |||
| 0F AF /r | IMUL r16,r/m16 | X | X | X | r16 ← r16 * r/m word | |||
| 0F AF /r | IMUL r32,r/m32 | X | X | X | r32 ← r32 * r/m dword | |||
| 6B /r ib | IMUL r16,r/m16,imm8 | X | X | X | X | X | r16 ← r/m word * sign-extended immediate byte | |
| 6B /r ib | IMUL r32,r/m32,imm8 | X | X | X | r32 ← r/m dword * sign-extended immediate byte | |||
| 6B /r ib | IMUL r16,imm8 | X | X | X | X | X | r16 ← r16 * sign-extended immediate byte | |
| 6B /r ib | IMUL r32,imm8 | X | X | X | r32 ← r32 * sign-extended immediate byte | |||
| 69 /r iw | IMUL r16,r/m16,imm16 | X | X | X | X | X | r16 ← r/m word * immediate word | |
| 69 /r id | IMUL r32,r/m32,imm32 | X | X | X | r32 ← r/m dword * immediate dword | |||
| 69 /r iw | IMUL r16,imm16 | X | X | X | X | X | r16 ← r16 * immediate word | |
| 69 /r id | IMUL r32,imm32 | X | X | X | r32 ← r32 * immediate dword | 
- Description
The IMUL instruction performs signed multiplication. Some forms of the instruction use implicit register operands. The operand combinations for all forms of the instruction are shown in the "Description" column above. The IMUL instruction clears the OF and CF flags under the following conditions (otherwise the CF and OF flags are set):
| INSTRUCTION FORM | CONDITION FOR CLEARING CR AND OF | 
|---|---|
| r/m8 | AL = sign-extend of AL to 16-bits | 
| r/m16 | AX = sign-extend of AX to 32-bits | 
| r/m32 | EDX:EAX = sign-extend of EAX to 32-bits | 
| r16,r/m16 | Result exactly fits within r16 | 
| r32,r/m32 | Result exactly fits within r32 | 
| r16,r/m16,imm16 | Result exactly fits within r16 | 
| r32,r/m32,imm32 | Result exactly fits within r32 | 
- Operation
result ← multiplicand * multiplier;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| |* | | |? |? |? |? |* |
The OF and CF flags as described in the table in the "Description" section above; the SF, ZF, AF, and PF flags are undefined.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
When using the accumulator forms (IMUL r/m8, IMUL rm16, or IMUL r/m32), the result of the multiplication is available even if the overflow flag is set because the result is twice the size of the multiplicand and multiplier. This is large enough to handle any possible result.
IN-Input from Port
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| E4 ib | IN AL,imm8 | X | X | X | X | X | X | Input byte from port imm8 into AL | 
| E5 ib | IN AX,imm8 | X | X | X | X | X | X | Input word from port imm8 into AX | 
| E5 ib | IN EAX,imm8 | X | X | X | Input dword from port imm8 into EAX | |||
| EC | IN AL,DX | X | X | X | X | X | X | Input byte from port DX into AL | 
| ED | IN AX,DX | X | X | X | X | X | X | Input word from port DX into AX | 
| ED | IN EAX,DX | X | X | X | Input dword from port DX into EAX | 
- Description
The IN instruction transfers a data byte or data word from the port numbered by the second operand into the register (AL, AX, or EAX) specified by the first operand. Access any port from 0 to 65535 by placing the port number in the DX register and using an IN instruction with the DX register as the second parameter. These I/O instructions can be shortened by using an 8-bit port I/O in the instruction. The upper eight bits of the port address will be 0 when 8-bit port I/O is used.
- Operation
IF (PE = 1) AND ((VM = 1) OR (CPL>IOPL)) THEN (* Virtual 8086 mode, or protected mode with CPL>IOPL *) IF NOT I-O-Permission (SRC, width(SRC)) THEN #GP(0); FI; FI; DEST ← [SRC]; (* Reads from I/O address space *)
- Protected Mode Exceptions
- GP(0) if the current privilege level is larger (has less privilege) than the I/O privilege level and any of the corresponding I/O permission bits in TSS equals 1.
- Virtual 8086 Mode Exceptions
- GP(0) fault if any of the corresponding I/O permission bits in TSS equals 1.
INC-Increment by 1
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| FE /0 | INC r/m8 | X | X | X | X | X | X | Increment r/m byte by 1 | 
| FF /0 | INC r/m16 | X | X | X | X | X | X | Increment r/m word by 1 | 
| FF /0 | INC r/m32 | X | X | X | Increment r/m dword by 1 | |||
| 40+rw | INC r16 | X | X | X | X | X | X | Increment word register by 1 | 
| 40+rd | INC r32 | X | X | X | Increment dword register by 1 | 
- Description
The INC instruction adds 1 to the operand. It does not change the CF flag. To affect the CF flag, use the ADD instruction with a second operand of 1.
- Operation
DEST ← DEST + 1;
- Flags Affected
OF|DF|IF|SF|ZF|AF|PF|CF --+--+--+--+--+--+--+-- * | | |* |* |* |* |
The OF, SF, ZF, AF, and PF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) if the operand is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
INS/INSB/INSW/INSD-Input from Port to String
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 6C | INS r/m8,DX | X | X | X | X | X | Input byte from port DX into ES:[(E)DI] | |
| 6D | INS r/m16,DX | X | X | X | X | X | Input word from port DX into ES:[(E)DI] | |
| 6D | INS r/m32,DX | X | X | X | Input dword from port DX into ES:[(E)DI] | |||
| 6C | INSB | X | X | X | X | X | Input byte from port DX into ES:[(E)DI] | |
| 6D | INSW | X | X | X | X | X | Input word from port DX into ES:[(E)DI] | |
| 6D | INSD | X | X | X | Input dword from port DX into ES:[(E)DI] | 
- Description
The INS instruction transfers data from the input port numbered by the DX register to the memory byte or word at ES:dest-index. The memory operand must be addressable from the ES register; no segment override is possible. The destination register is the DI register if the address-size attribute of the instruction is 16-bits, or the EDI register if the address-size attribute is 32-bits. The INS instruction does not allow the specification of the port number as an immediate value. The port must be addressed through the DX register value. Load the correct value into the DX register before running the INS instruction. The destination address is determined by the contents of the destination index register. Load the correct index into the destination index register before running the INS instruction. After the transfer is made, the DI or EDI register advances automatically. If the DF flag is 0 (a CLD instruction was run), the DI or EDI register increments; if the DF flag is 1 (an STD instruction was run), the DI or EDI register decrements. The DI register increments or decrements by 1 if a byte is input, by 2 if a word is input, or by 4 if a doubleword is input. The INSB, INSW and INSD instructions are synonyms of the byte, word, and doubleword INS instructions. The INS instruction can be preceded by the REP prefix for block input of CX bytes or words. Refer to the REP instruction for details of this operation.
- Operation
IF AddressSize = 16 THEN use DI for dest-index; ELSE (* AddressSize = 32 *) use EDI for dest-index; FI; IF (PE = 1) AND ((VM = 1) OR (CPL>IOPL)) THEN (* Virtual 8086 mode, or protected mode with CPL>IOPL *) IF NOT I-O-Permission (SRC, width(SRC)) THEN #GP(0); FI; FI; IF byte type of instruction THEN ES:[dest-index] ← [DX]; (* Reads byte at DX from I/O address space *) IF DF = 0 THEN IncDec ← 1 ELSE IncDec ← -1; FI; FI; IF OperandSize = 16 THEN ES:[dest-index] ← [DX]; (* Reads byte at DX from I/O address space *) IF DF = 0 THEN IncDec ← 2 ELSE IncDec ← -2; FI; FI; IF OperandSize = 32 THEN ES:[dest-index] ← [DX]; (* Reads dword at DX from I/O address space *) IF DF = 0 THEN IncDec ← 4 ELSE IncDec ← -4; FI; FI; dest-index ← dest-index + IncDec;
- Protected Mode Exceptions
- GP(0) if the current privilege level is numerically greater than the I/O privilege level and any of the corresponding I/O permission bits in TSS equals 1; #GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the ES, segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
- GP(0) fault if any of the corresponding I/O permission bits in TSS equals 1; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
INT/INTO-Call to Interrupt Procedure
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| CC | INT 3 | X | X | X | X | X | X | Interrupt 3; Trap to debugger | 
| CC | INT 3 | X | X | X | X | Interrupt 3; Protected Mode, same privilege | ||
| CC | INT 3 | X | X | X | X | Interrupt 3; Protected Mode, more privilege | ||
| CC | INT 3 | X | X | X | Interrupt 3; from V86 mode to PL 0 | |||
| CC | INT 3 | X | X | X | X | Interrupt 3; Protected Mode, via task gate | ||
| CC ib | INT imm8 | X | X | X | X | X | X | Interrupt numbered by immediate byte | 
| CD ib | INT imm8 | X | X | X | X | Interrupt imm8; Protected Mode, same privilege | ||
| CD ib | INT imm8 | X | X | X | X | Interrupt imm8; Protected Mode, more privilege | ||
| CD ib | INT imm8 | X | X | X | Interrupt imm8; from V86 mode to PL 0 | |||
| CD ib | INT imm8 | X | X | X | X | Interrupt imm8; Protected Mode, via task gate | ||
| CE | INTO | X | X | X | X | X | X | Interrupt 4 if Overflow flag is 1 | 
| CE | INTO | X | X | X | X | Interrupt 4 if Overflow flag is 1; Protected Mode, same privilege | ||
| CE | INTO | X | X | X | X | Interrupt 4 if Overflow flag is 1; Protected Mode, more privilege | ||
| CE | INTO | X | X | X | Interrupt 4 if Overflow flag is 1; from V86 mode to PL 0 | |||
| CE | INTO | X | X | X | X | Interrupt 4 if Overflow flag is 1; Protected Mode, via task gate | 
- Description
The INT n instruction generates a call to an interrupt handler. The immediate operand, from 0 to 255, gives the index number into the Interrupt Descriptor Table (IDT) of the interrupt routine to be called. In protected mode, the IDT consists of an array of eight-byte descriptors; the descriptor for the interrupt invoked must indicate an interrupt, trap, or task gate. In real-address mode, the IDT is an array of four byte-long pointers. In protected and real-address modes, the base linear address of the IDT is defined by the contents of the IDTR. The initial value of IDTR is zero upon reset into real-address mode. When the processor is running in virtual-8086 mode (VM=1), the IOPL determines whether the INT n causes a general protection exception (IOPL<3) or runs a protected mode interrupt to privilege level 0. The interrupt gate's DPL must be set to three and the target CPL of the interrupt service routine must be zero to run the protected mode interrupt to privilege level 0. The INTO conditional software instruction is identical to the INT n interrupt instruction except that the interrupt number is implicitly 4, and the interrupt is made only if the overflow flag is set. The first 32 interrupts are reserved by Intel for system use. Some of these interrupts are used for internally generated exceptions. The INT n instruction generally behaves like a far call except that the flags register is pushed onto the stack before the return address. Interrupt procedures return via the IRET instruction, which pops the flags and return address from the stack. In Real Address Mode, the INT n instruction pushes the flags, the CS register, and the return IP onto the stack, in that order, then jumps to the long pointer indexed by the interrupt number.
- Operation
Note: The following operational description applies not only to the above instructions but also to external interrupts and exceptions.
IF PE = 0 
THEN CALL REAL-ADDRESS-MODE;
ELSE 
 CALL PROTECTED-MODE;
 IF task gate 
 THEN CALL TASK-GATE;
 ELSE 
 CALL TRAP-OR-INT-GATE; (* PE=1, int/trap gate *)
 IF code segment is non-conforming AND DPL < CPL 
 THEN 
   IF VM=0
   THEN CALL INT-TO-INNER-PRIV; (*PE=1,int/trap gate,DPL<CPL,VM=0*)
   ELSE CALL INT-FROM-V86-MODE; (* PE=1, int/trap gate, DPL<CPL,
                 VM=1 *)
   FI;
   ELSE (* PE=1, int/trap gate, DPL ò CPL *)
     IF code segment is conforming OR code segment DPL = CPL 
   THEN CALL INT-TO-SAME-PRIV;
   ELSE #GP(CS selector + EXT); (* PE=1, int/trap gate, DPL>CPL *)
     FI;
     FI;
   FI;
FI;
END;
REAL-ADDRESS-MODE PROC Push (FLAGS); IF ← 0; (* Clear interrupt flag *) TF ← 0; (* Clear trap flag *) Push(CS); Push(IP); (* No error codes are pushed *) CS ← IDT[Interrupt number * 4].selector; IP ← IDT[Interrupt number * 4].offset; (* Start processing in real address mode *) REAL-ADDRESS-MODE ENDPROC
PROTECTED-MODE PROC 
 Interrupt vector must be within IDT table limits,
    else #GP(vector number * 8+2+EXT);
 Descriptor AR byte must indicate interrupt gate, trap gate, or task gate,
    else #GP(vector number * 8+2+EXT);
 IF software interrupt (* i.e. caused by INT n, INT 3, or INTO *)
 THEN 
   IF gate descriptor DPL<CPL
   THEN #GP(vector number * 8+2+EXT); (* PE=1, DPL<CPL, software interrupt *)
   FI;
 FI;
 Gate must be present, else #NP(vector number * 8+2+EXT);
PROTECTED-MODE ENDPROC 
TRAP-OR-INT-GATE PROC Examine CS selector and descriptor given in the gate descriptor; Selector must be non-null, else #GP (EXT); Selector must be within its descriptor table limits ELSE #GP(selector+EXT); Descriptor AR byte must indicate code segment ELSE #GP(selector + EXT); Segment must be present, else #NP(selector+EXT); TRAP-OR-INT-GATE ENDPROC
INT-TO-INNER-PRIV PROC 
 (* PE=1, DPL<CPL and non-conforming, (* PE=1, int/trap gate, DPL<CPL, VM=0 *)
 Check selector and descriptor for new stack in current TSS;
   Selector must be non-null, else #TS(EXT);
   Selector index must be within its descriptor table limits 
     ELSE #TS(SS selector+EXT);
   Selector's RPL must equal DPL of code segment, else #TS(SS
     selector+EXT);
   Stack segment DPL must equal DPL of code segment, else #TS(SS
     selector+EXT);
   Descriptor must indicate writable data segment, else #TS(SS
     selector+EXT);
   Segment must be present, else #SS (SS selector+EXT);
 If 32-bit gate 
 THEN New stack must have room for 20 bytes else #SS(0)
 ELSE New stack must have room for 10 bytes else #SS(0)
 FI;
 Instruction pointer must be within CS segment boundaries else #GP(0);
 Load new SS and eSP value from TSS;
 If 32-bit gate 
   THEN CS:EIP ← selector:offset from gate;
 ELSE CS:IP ← selector:offset from gate;
 FI;
 Load CS descriptor into invisible portion of CS register;
 Load SS descriptor into invisible portion of SS register;
 IF 32-bit gate 
THEN 
   Push (long pointer to old stack) (* 3 words padded to 4 *);
   Push (EFLAGS);
   Push (long pointer to return location) (* 3 words padded to 4 *);
ELSE 
   Push (long pointer to old stack) (* 2 words *);
   Push (FLAGS);
   Push (long pointer to return location) (* 2 words *);
 FI;
 Set CPL to new code segment DPL;
 Set RPL of CS to CPL;
 IF interrupt gate THEN IF ← 0 (* interrupt flag to 0 (disable) *); FI;
 TF ← 0;
 NT ← 0;
INT-FROM-INNER-PRIV ENDPROC 
INT-FROM-V86-MODE PROC 
 Check selector and descriptor for new stack in current TSS;
 Selector must be non-null, else #TS(EXT);
 Selector index must be within its descriptor table limits 
   ELSE #TS(SS selector+EXT);
 Selector's RPL must equal DPL of code segment, else #TS(SS
   selector+EXT);
 Stack segment DPL must equal DPL of code segment, else #TS(SS
   selector+EXT);
 Descriptor must indicate writable data segment, else #TS(SS
   selector+EXT);
 Segment must be present, else #SS(SS selector+EXT);
 IF 32-bit gate 
   THEN New stack must have room for 20 bytes else #SS(0)
   ELSE New stack must have room for 10 bytes else #SS(0)
 FI;
 Instruction pointer must be within CS segment boundaries else #GP(0);
 IF IOPL < 3 
 THEN 
   #GP(0); (*V86 monitor trap: PE=1,int/trap gate, DPL<CPL, VM=1, IOPL<3*)
 ELSE (* IOPL=3 *)
   IF GATE'S_DPL = 3 
   THEN 
     IF TARGET'S_CPL <> 0 
     THEN #GP(0);
     ELSE 
       TempEFlags ← EFLAGS;
       VM ← 0;
       TF ← 0;
       IF service through Interrupt Gate 
           THEN IF ← 0;
       FI;
       TempSS ← SS;
       TempESP ← ESP;
       SS ← TSS.SS0; (* Change to level 0 stack segment *)
   ESP ← TSS.ESP0; (* Change to level 0 stack pointer *)
   Push(GS); (* padded to two words *)
       Push(FS); (* padded to two words *)
   Push(DS); (* padded to two words *)
   Push(ES); (* padded to two words *)
   GS ← 0; (* segment registers nullified - invalid in 
      protected mode *)
       FS ← 0;
   DS ← 0;
   ES ← 0;
   Push(TempSS); (* Padded to two words *)
   Push(TempESP);
   Push(TempEFlags);
   Push(CS); (* Padded to two words *)
   Push(EIP);
       CS:EIP ← selector:offset from interrupt gate;
       (* Starts processing of new routine in Protected Mode *)
     FI;
  ELSE (* GATE'S_DPL <> 3 *)
     #GP(0);
   FI;
 FI;
INT-FROM-V86-MODE ENDPROC
INT-TO-SAME-PRIV PROC (* PE=1, DPL=CPL or conforming segment *) IF 32-bit gate THEN Current stack limits must allow pushing 10 bytes, else #SS(0); ELSE Current stack limits must allow pushing 6 bytes, else #SS(0); FI;
IF interrupt was caused by exception with error code THEN Stack limits must allow push to two more bytes; ELSE #SS(0); FI; Instruction pointer must be in CS limit, else #GP(0); IF 32-bit gate THEN Push (EFLAGS); Push (long pointer to return location); (* 3 words padded to 4 *) CS:EIP ← selector:offset from gate; ELSE (* 16-bit gate *) Push (FLAGS); Push (long pointer to return location); (* 2 words *) CS:IP ← selector:offset from gate; FI; Load CS descriptor into invisible portion of CS register; Set the RPL field of CS to CPL; Push (error code); (* if any *) IF interrupt gate THEN IF ← 0; FI; TF ← 0; NT ← 0; INT-TO-SAME-PRIV ENDPROC
TASK-GATE PROC (* PE=1, task gate *)
 Examine selector to TSS, given in task gate descriptor;
   Must specify global in the local/global bit, else #TS(TSS selector);
   Index must be within GDT limits, else #TS(TSS selector);
   AR byte must specify available TSS (bottom bits 00001);
     else #TS(TSS selector);
   TSS must be present, else #NP(TSS selector);
 SWITCH-TASKS with nesting to TSS;
 IF interrupt was caused by fault with error code 
 THEN 
   Stack limits must allow push of two more bytes, else #SS(0);
   Push error code onto stack;
 FI;
 Instruction pointer must be in CS limit, else #GP(0);
TASK-GATE ENDPROC 
- Decision Table
The following decision table indicates which action in the lower portion of the table is taken given the conditions in the upper portion of the table. Each Y in the lower section of the decision table represents a procedure defined above in the Operation section for this instruction (except #GP(0)) and the number following the Y indicates the order in which the procedure is run.
| PE | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 
| VM | - | - | - | - | - | 0 | 1 | 1 | 
| IOPL | - | - | - | - | - | - | <3 | =3 | 
| DPL/CPL RELATIONSHIP | - | DPL < CPL | - | DPL > CPL | DPL = CPL or C | DPL < CPL & NC | - | - | 
| INTERRUPT TYPE | - | S/W | - | - | - | - | - | - | 
| GATE TYPE | - | - | Task or Int | Trap or Int | Trap or Int | Trap or Int | Trap or Int | Trap or Int | 
| REAL-ADDRESS-MODE | Y | |||||||
| PROTECTED-MODE | Y1 | Y1 | Y1 | Y1 | Y1 | Y1 | Y1 | |
| TRAP-OR-INT-GATE | Y2 | Y2 | Y2 | Y2 | Y2 | |||
| INT-TO-INNER-PRIV | Y3 | |||||||
| INT-TO-SAME-PRIV | Y3 | |||||||
| INT-FROM-V86-MODE | Y3 | |||||||
| TASK-GATE | Y2 | |||||||
| #GP | Y2 | Y3 | Y3 | 
Notes: - Don't Care Yx Yes, Action Taken, x = the order of processing Blank Action Not Taken
- Flags Affected
OF|DF|IF|SF|ZF|AF|PF|CF --+--+--+--+--+--+--+-- | |0 | | | | |
None
- Protected Mode Exceptions
- GP, #NP, #SS, and #TS as indicated under "Operation" above.
- Real Address Mode Exceptions
None; if the SP or ESP register is 1, 3, or 5 before running the INT or INTO instruction, the processor will shut down due to insufficient stack space.
- Virtual 8086 Mode Exceptions
- GP(0) fault if IOPL is less than 3, for the INT n instruction only, to permit emulation; Interrupt 3 (0CCH) generates a breakpoint exception; the INTO instruction generates an overflow exception if the OF flag is set.
INVD-Invalidate Cache
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |---------+------------+-+-+-+-+-+-+----------------------- |0F 08 |INVD | | | | |X|X|Invalidate entire cache
- Description
The internal cache is invalidated, and a special-function bus cycle is issued which indicates that external caches should also be invalidated. Data held in write-back external caches is not instructed to be written back.
- Operation
INVALIDATE INTERNAL CACHE SIGNAL EXTERNAL CACHE TO INVALIDATE
- Protected Mode Exceptions
The INVD instruction is a privileged instruction; #GP(0) if the current privilege level is not 0.
- Virtual 8086 Mode Exceptions
#GP(0); the INVD instruction is a privileged instruction.
- Notes
INVD should be used with care. It does not write back modified cache lines; therefore, it can cause the data cache to become inconsistent with other memories in the system. Unless there is a specific requirement or benefit to invalidate a cache without writing back the modified lines (i.e., testing or fault recovery where cache coherency with main memory is not a concern), software should use the WBINVD instruction. This instruction is implementation-dependent; its function may be implemented differently on future Intel processors. This instruction does not wait for the external cache to complete its invalidation before the processor proceeds. It is the responsibility of hardware to respond to the external cache invalidation indication. This instruction is not supported on Intel386 processors. See the Intel documentation for CPUID detection at runtime. See the WBINVD description to write back dirty data to memory. See the Intel documentation for information on disabling the cache.
INVLPG-Invalidate TLB Entry
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
| 0F 01 /7 | INVLPG m | X | X | Invalidate TLB entry | 
- Description
The INVLPG instruction is used to ensure there are no invalid entries in the TLB, the cache used for page table entries. If the TLB contains a valid entry, which maps the address of the memory operand, all of the relevant TLB entries are marked invalid.
- Operation
INVALIDATE RELEVANT TLB ENTRY(S)
- Protected Mode Exceptions
The INVLPG instruction is a privileged instruction; #GP(0) if the current privilege level is not 0. An invalid-opcode exception is generated when used with a register operand. Virtual 8086 Mode Exceptions An invalid-opcode exception is generated when used with a register operand. #GP(0); the INVLPG instruction is a privileged instruction.
- Notes
This instruction is not supported on Intel386 processors. See the Intel documentation for information on detecting the processor type at runtime. See the Intel documentation for information on disabling the cache.
IRET/IRETD-Interrupt Return
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| CF | IRET | X | X | X | X | X | X | Interrupt return (far return and pop flags) | 
| CF | IRET | X | X | X | X | Interrupt return to lesser privilege | ||
| CF | IRET | X | X | X | X | Interrupt return, different task (NT=1) | ||
| CF | IRET | X | X | X | Interrupt return from Real or V86 mode | |||
| CF | IRETD | X | X | X | Interrupt return (far return and pop flags) | |||
| CF | IRETD | X | X | X | Interrupt return to lesser privilege | |||
| CF | IRETD | X | X | X | Interrupt return, different task (NT=1) | 
- Description
In Real Address Mode, the IRET instruction pops the instruction pointer, the CS register, and the flags register from the stack and resumes the interrupted routine. In Protected Mode, the action of the IRET instruction depends on the setting of the nested task flag (NT) bit in the flag register. When the new flag image is popped from the stack, the IOPL bits in the flag register are changed only when CPL equals 0. If the NT flag is cleared, the IRET instruction returns from an interrupt procedure without a task switch. The code returned to must be equally or less privileged than the interrupt routine (as indicated by the RPL bits of the CS selector popped from the stack). If the destination code is less privileged, the IRET instruction also pops the stack pointer and SS from the stack. If the NT flag is set, the IRET instruction reverses the operation of a CALL or INT that caused a task switch. The updated state of the task running the IRET instruction is saved in its task state segment. If the task is reentered later, the code that follows the IRET instruction is run.
- Operation
IF PE = 0 
 THEN GOTO REAL_ADDRESS_MODE:;
 ELSE GOTO PROTECTED_MODE;
FI;
REAL_ADDRESS_MODE;
 IF OperandSize = 32 (* Instruction = IRETD *)
 THEN EIP ← Pop ();
 ELSE (* Instruction = IRET *)
 IP ← Pop();
 FI;
 CS ← Pop ();
 IF OperandSize = 32 (* Instruction = IRETD *)
 THEN Pop(); EFLAGS ← Pop();
 ELSE (* Instruction = IRET *)
 FLAGS ← Pop();
 FI;
 END;
PROTECTED_MODE:
 IF VM = 1 (* Virtual mode:PE=1, VM=1 *)
 THEN GOTO STACK_RETURN_FROM_V86; (* PE=1, VM=1 *)
 ELSE 
 IF NT=1
 THEN GOTO TASK_RETURN; (* PE=1, VM=1, NT=1 *)
 ELSE 
   IF VM=1 in flags image on stack 
     THEN GOTO STACK_RETURN_TO_V86; (* PE=1, VM=1 in flags 
                    inage *)
     ELSE GOTO STACK_RETURN; (* PE=1, VM=0 in flags image *)
   FI;
 FI;
FI;
STACK_RETURN_FROM_V86:
 IF IOPL=3 (* Virtual mode: PE=1, VM=1, IOPL=3 *)
 THEN 
   IF OperandSize = 16 
      IP ← Pop();(* 16-bit pops *)
      CS ← Pop();
      FLAGS ←Pop();
   ELSE (* OperandSize = 32 *)
      EIP ← Pop(); (* 32-bit pops *)
      CS ← Pop();
      EFLAGS ←Pop(); (*VM,IOPL,VIP,and VIF EFLAG bits are not modified by IRETD*)
   FI;
 ELSE #GP(0); (* trap to virtual-8086 monitor: PE=1, VM=1, IOPL<3 *)
 FI;
END;
STACK_RETURN_TO_V86: (* Interrupted procedure was in V86 mode:
PE=1, VM=1 in flags image *)
 IF top 36 bytes of stack not within limits 
 THEN #SS(0);
 FI;
 IF instruction pointer not within code segment limit  THEN #GP(0);
 FI;
 EFLAGS ← SS:[ESP + 8]; (* Sets VM in interrupted routine *)
 EIP ← Pop();
 CS ← Pop(); (* CS behaves as in 8086, due to VM=1 *)
 throwaway ← Pop(); (* pop away EFLAGS already read *)
 TempESP ← Pop();
 TempSS ← Pop();
 ES ← Pop(); (* pop 2 words; throw away high-order word *)
 DS ← Pop(); (* pop 2 words; throw away high-order word *)
 FS ← Pop(); (* pop 2 words; throw away high-order word *)
 GS ← Pop(); (* pop 2 words; throw away high-order word *)
  SS:ESP ← TempSS:TempESP;
 (* Resume processing in Virtual 8086 mode *)
 END;
TASK-RETURN: (* PE=1, VM=1, NT=1 *)
 Examine Back Link Selector in TSS addressed by the current task 
   register:
   Must specify global in the local/global bit, else #TS(new TSS selector);
   Index must be within GDT limits, else #TS(new TSS selector);
   AR byte must specify TSS, else #TS(new TSS selector);
   New TSS must be busy, else #TS(new TSS selector);
   TSS must be present, else #NP(new TSS selector);
 SWITCH-TASKS without nesting to TSS specified by back link selector;
 Mark the task just abandoned as NOT BUSY;
 Instruction pointer must be within code segment limit ELSE #GP(0);
 END;
STACK-RETURN: (* PE=1, VM=0 in flags image *) IF OperandSize=32 THEN Third word on stack must be within stack limits, else #SS(0); ELSE Second word on stack must be within stack limits, else #SS(0); FI; Return CS selector RPL must be ò CPL, else #GP(Return selector); IF return selector RPL = CPL THEN GOTO RETURN-SAME-LEVEL; ELSE GOTO RETURN-OTHER-LEVEL; FI;
RETURN-SAME-LEVEL: (* PE=1, VM=0 in flags image, RPL=CPL *)
 IF OperandSize=32
 THEN 
   Top 12 bytes on stack must be within limits, else #SS(0);
   Return CS selector (at eSP+4) must be non-null, else #GP(0);
 ELSE 
   Top 6 bytes on stack must be within limits, else #SS(0);
   Return CS selector (at eSP+2) must be non-null, else #GP(0);
 FI;
 Selector index must be within its descriptor table limits, else #GP
   (Return selector);
 AR byte must indicate code segment, else #GP(Return selector);
 IF non-conforming
 THEN code segment DPL must = CPL;
 ELSE #GP(Return selector); (* PE=1, VM=0 in flags image,
 RPL=CPL,non-conforming,DPL<> CPL *)
 FI;
 IF conforming 
   THEN IF DPL>CPL
     #GP(Return selector); (* PE=1, VM=0 in flags image,
     RPL=CPL,conforming,DPL>CPL *)
 Segment must be present, else #NP(Return selector);
 Instruction pointer must be within code segment boundaries, else #GP(0);
 FI;
 IF OperandSize=32 put comments here 
 THEN 
   Load CS:EIP from stack;
   Load CS-register with new code segment descriptor;
   Load EFLAGS with third doubleword from stack;
   Increment eSP by 12;
 ELSE 
   Load CS-register with new code segment descriptor;
   Load FLAGS with third word on stack;
   Increment eSP by 6;
 FI;
 END;
RETURN-OUTER-LEVEL:
IF OperandSize=32
 THEN Top 20 bytes on stack must be within limits, else #SS(0);
 ELSE Top 10 bytes on stack must be within limits, else #SS(0);
FI;
Examine return CS selector and associated descriptor:
 Selector must be non-null, ELSE #GP(0);
 Selector index must be within its descriptor table limits;
   ELSE #GP(Return selector);
 AR byte must indicate code segment, else #GP(Return selector);
IF non-conforming
 THEN code segment DPL must = CS selector RPL;
 ELSE #GP(Return selector);
 FI;
IF conforming 
 THEN code segment DPL must be > CPL;
 ELSE #GP(Return selector);
 FI;
 Segment must be present, else #NP(Return selector);
Examine return SS selector and associated descriptor:
 Selector must be non-null, else #GP(0);
 Selector index must be within its descriptor table limits 
   ELSE #GP(SS selector);
 Selector RPL must equal the RPL of the return CS selector 
   ELSE #GP(SS selector);
 AR byte must indicate a writable data segment, else #GP(SS selector);
 Stack segment DPL must equal the RPL of the return CS selector 
   ELSE #GP(SS selector);
 SS must be present, else #NP(SS selector);
Instruction pointer must be within code segment limit ELSE #GP(0);
 IF OperandSize=32
 THEN 
   Load CS:EIP from stack;
   Load EFLAGS with values at (eSP+8);
 ELSE 
   Load CS:IP from stack;
   Load FLAGS with values at (eSP+4);
 FI;
 Load SS:eSP from stack;
 Set CPL to the RPL of the return CS selector;
 Load the CS register with the CS descriptor;
 Load the SS register with the SS descriptor;
 FOR each of ES, FS, GS, and DS 
 DO;
   IF the current value of the register is not valid for the outer level;
   THEN zero the register and clear the valid flag;
   FI;
   To be valid, the register setting must satisfy the following properties:
     Selector index must be within descriptor table limits;
     AR byte must indicate data or readable code segment;
     IF segment is data or non-conforming code,
     THEN DPL must be > CPL, or DPL must be < RPL;
 OD;
 END:
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| * | * | * | * | * | * | * | * | 
All flags are affected; the flags register is popped from stack.
- Protected Mode Exceptions
- GP, #NP, or #SS, as indicated under "Operation" above; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand being popped lies beyond address 0FFFFH.
- Virtual 8086 Mode Exceptions
- GP(0) fault occurs if the I/O privilege level is less than 3, to permit emulation; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
Jcc - Jump if Condition is Met
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 77 cb | JA rel8 | X | X | X | X | X | X | Jump short if above (CF=0 and ZF=0) | 
| 73 cb | JAE rel8 | X | X | X | X | X | X | Jump short if above or equal (CF=0) | 
| 72 cb | JB rel8 | X | X | X | X | X | X | Jump short if below (CF=1) | 
| 76 cb | JBE rel8 | X | X | X | X | X | X | Jump short if below or equal (CF=1 or ZF=1) | 
| 72 cb | JC rel8 | X | X | X | X | X | X | Jump short if carry (CF=1) | 
| E3 cb | JCXZ rel8 | X | X | X | X | X | X | Jump short if CX register is 0 | 
| E3 cb | JECXZ rel8 | X | X | X | Jump short if ECX register is 0 | |||
| 74 cb | JE rel8 | X | X | X | X | X | X | Jump short if equal (ZF=1) | 
| 74 cb | JG rel8 | X | X | X | X | X | X | Jump short if zero (ZF=1) | 
| 7D cb | JGE rel8 | X | X | X | X | X | X | Jump short if greater or equal (SF=OF) | 
| 7C cb | JL rel8 | X | X | X | X | X | X | Jump short if less (SF<>OF) | 
| 7E cb | JLE rel8 | X | X | X | X | X | X | Jump short if less or equal (ZF=1 and SF<>OF) | 
| 76 cb | JNA rel8 | X | X | X | X | X | X | Jump short if not above (CF=1 or ZF=1) | 
| 72 cb | JNAE rel8 | X | X | X | X | X | X | Jump short if not above or equal (CF=1) | 
| 73 cb | JNB rel8 | X | X | X | X | X | X | Jump short if not below (CF=0) | 
| 77 cb | JNBE rel8 | X | X | X | X | X | X | Jump short if not below or equal (CF=0 and ZF=0) | 
| 73 cb | JNC rel8 | X | X | X | X | X | X | Jump short if not carry (CF=0) | 
| 75 cb | JNE rel8 | X | X | X | X | X | X | Jump short if not equal (ZF=0) | 
| 7E cb | JNG rel8 | X | X | X | X | X | X | Jump short if not greater (ZF=1 or SF<>OF) | 
| 7C cb | JNGE rel8 | X | X | X | X | X | X | Jump short if not greater or equal (SF<>OF) | 
| 7D cb | JNL rel8 | X | X | X | X | X | X | Jump short if not less (SF=OF) | 
| 7F cb | JNLE rel8 | X | X | X | X | X | X | Jump short if not less or equal (ZF=0 and SF=OF) | 
| 71 cb | JNO rel8 | X | X | X | X | X | X | Jump short if not overflow (OF=0) | 
| 7B cb | JNP rel8 | X | X | X | X | X | X | Jump short if not parity (PF=0) | 
| 79 cb | JNS rel8 | X | X | X | X | X | X | Jump short if not sign (SF=0) | 
| 75 cb | JNZ rel8 | X | X | X | X | X | X | Jump short if not zero (ZF=0) | 
| 70 cb | JO rel8 | X | X | X | X | X | X | Jump short if overflow (OF=1) | 
| 7A cb | JP rel8 | X | X | X | X | X | X | Jump short if parity (PF=1) | 
| 7A cb | JPE rel8 | X | X | X | X | X | X | Jump short if parity even (PF=1) | 
| 7B cb | JPO rel8 | X | X | X | X | X | X | Jump short if parity odd (PF=0) | 
| 78 cb | JS rel8 | X | X | X | X | X | X | Jump short if sign (SF=1) | 
| 74 cb | JZ rel8 | X | X | X | X | X | X | Jump short if zero (ZF=1) | 
| 0F 87 cw/cd | JA rel16/rel32 | X | X | X | Jump near if above (CF=0 and ZF=0) | |||
| 0F 83 cw/cd | JAE rel16/rel32 | X | X | X | Jump near if above or equal (CF=0) | |||
| 0F 82 cw/cd | JB rel16/rel32 | X | X | X | Jump near if below (CF=1) | |||
| 0F 86 cw/cd | JBE rel16/rel32 | X | X | X | Jump near if below or equal (CF=1 or ZF=1) | |||
| 0F 82 cw/cd | JC rel16/rel32 | X | X | X | Jump near if carry (CF=1) | |||
| 0F 84 cw/cd | JE rel16/rel32 | X | X | X | Jump near if equal (ZF=1) | |||
| 0F 8F cw/cd | JG rel16/rel32 | X | X | X | Jump near if zero (ZF=1) | |||
| 0F 8D cw/cd | JGE rel16/rel32 | X | X | X | Jump near if greater or equal (SF=OF) | |||
| 0F 8C cw/cd | JL rel16/rel32 | X | X | X | Jump near if less (SF<>OF) | |||
| 0F 8E cw/cd | JLE rel16/rel32 | X | X | X | Jump near if less or equal (ZF=1 and SF<>OF) | |||
| 0F 86 cw/cd | JNA rel16/rel32 | X | X | X | Jump near if not above (CF=1 or ZF=1) | |||
| 0F 82 cw/cd | JNAE rel16/rel32 | X | X | X | Jump near if not above or equal (CF=1) | |||
| 0F 83 cw/cd | JNB rel16/rel32 | X | X | X | Jump near if not below (CF=0) | |||
| 0F 87 cw/cd | JNBE rel16/rel32 | X | X | X | Jump near if not below or equal (CF=0 and ZF=0) | |||
| 0F 83 cw/cd | JNC rel16/rel32 | X | X | X | Jump near if not carry (CF=0) | |||
| 0F 85 cw/cd | JNE rel16/rel32 | X | X | X | Jump near if not equal (ZF=0) | |||
| 0F 8E cw/cd | JNG rel16/rel32 | X | X | X | Jump near if not greater (ZF=1 or SF<>OF) | |||
| 0F 8C cw/cd | JNGE rel16/rel32 | X | X | X | Jump near if not greater or equal (SF<>OF) | |||
| 0F 8D cw/cd | JNL rel16/rel32 | X | X | X | Jump near if not less (SF=OF) | |||
| 0F 8F cw/cd | JNLE rel16/rel32 | X | X | X | Jump near if not less or equal (ZF=0 and SF=OF) | |||
| 0F 81 cw/cd | JNO rel16/rel32 | X | X | X | Jump near if not overflow (OF=0) | |||
| 0F 8B cw/cd | JNP rel16/rel32 | X | X | X | Jump near if not parity (PF=0) | |||
| 0F 89 cw/cd | JNS rel16/rel32 | X | X | X | Jump near if not sign (SF=0) | |||
| 0F 85 cw/cd | JNZ rel16/rel32 | X | X | X | Jump near if not zero (ZF=0) | |||
| 0F 80 cw/cd | JO rel16/rel32 | X | X | X | Jump near if overflow (OF=1) | |||
| 0F 8A cw/cd | JP rel16/rel32 | X | X | X | Jump near if parity (PF=1) | |||
| 0F 8A cw/cd | JPE rel16/rel32 | X | X | X | Jump near if parity even (PF=1) | |||
| 0F 8B cw/cd | JPO rel16/rel32 | X | X | X | Jump near if parity odd (PF=0) | |||
| 0F 88 cw/cd | JS rel16/rel32 | X | X | X | Jump near if sign (SF=1) | |||
| 0F 84 cw/cd | JZ rel16/rel32 | X | X | X | Jump near if zero (ZF=1) | 
- Description
Conditional jumps (except the JCXZ instruction) test the flags that have been set by a previous instruction. The conditions for each mnemonic are given in parentheses after each description above. The terms "less" and "greater"; are used for comparisons of signed integers; "above" and "below" are used for unsigned integers. If the given condition is true, a jump is made to the location provided as the operand. Instruction coding is most efficient when the target for the conditional jump is in the current code segment and within -128 to +127 bytes of the next instruction's first byte. The jump can also target -32768 thru +32767 (segment size attribute 16) or -231 thru +231 - 1 (segment size attribute 32) relative to the next instruction's first byte. When the target for the conditional jump is in a different segment, use the opposite case of the jump instruction (i.e., the JE and JNE instructions), and then access the target with an unconditional far jump to the other segment. For example, you cannot code
JZ FARLABEL
You must instead code
JNZ BEYOND JMP FARLABEL BEYOND:
Because there can be several ways to interpret a particular state of the flags, ASM386 provides more than one mnemonic for most of the conditional jump opcodes. For example, if you compared two characters in AX and want to jump if they are equal, use the JE instructions; or, if you ANDed the AX register with a bit field mask and only want to jump if the result is 0, use the JZ instruction, a synonym for the JE instruction. The JCXZ instruction differs from other conditional jumps because it tests the contents of the CX or ECX register for 0, not the flags. The JCXZ instruction is useful at the beginning of a conditional loop that terminates with a conditional loop instruction (such as LOOPNE TARGET LABEL. The JCXZ instruction prevents entering the loop with the CX or ECX register equal to zero, which would cause the loop to run 64K or 23ý times instead of zero times.
- Operation
IF condition THEN EIP ← EIP + SignExtend(rel8/16/32); IF OperandSize = 16 THEN EIP ← EIP AND 0000FFFFH; FI; FI;
- Protected Mode Exceptions
#GP(0) if the offset jumped to is beyond the limits of the code segment.
- Notes
The JCXZ instruction takes longer to run than a two-instruction sequence, which compares the count register to zero and jumps if the count is zero. All branches are converted into 16-byte code fetches regardless of jump address or cacheability.
JMP - Jump
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| EB cb | JMP rel8 | X | X | X | X | X | X | Jump short, displacement relative to next instruction | 
| E9 cw | JMP rel16 | X | X | X | X | X | X | Jump near, displacement relative to next instruction | 
| FF /4 | JMP r/m16 | X | X | X | X | X | X | Jump near indirect | 
| EA cd | JMP ptr16:16 | X | X | X | X | X | X | Jump intersegment, 4-byte immediate address | 
| EA cd | JMP ptr16:16 | X | X | X | X | Jump to call gate, same privilege | ||
| EA cd | JMP ptr16:16 | X | X | X | X | Jump via task state segment | ||
| EA cd | JMP ptr16:16 | X | X | X | X | Jump via task gate | ||
| FF /5 | JMP m16:16 | X | X | X | X | X | X | Jump intersegment, dword address at r/m word | 
| FF /5 | JMP m16:16 | X | X | X | X | Jump to call gate, same privilege | ||
| FF /5 | JMP m16:16 | X | X | X | X | Jump via task state segment | ||
| FF /5 | JMP m16:16 | X | X | X | X | Jump via task gate | ||
| E9 cd | JMP rel32 | X | X | X | Jump near, displacement relative to next instruction | |||
| FF /4 | JMP r/m32 | X | X | X | Jump near indirect | |||
| EA cp | JMP ptr16:32 | X | X | X | Jump intersegment, 6-byte immediate address | |||
| EA cp | JMP ptr16:32 | X | X | X | Jump to call gate, same privilege | |||
| EA cp | JMP ptr16:32 | X | X | X | Jump via task state segment | |||
| EA cp | JMP ptr16:32 | X | X | X | Jump via task gate | |||
| FF /5 | JMP m16:32 | X | X | X | Jump intersegment, fword address at r/m dword | |||
| FF /5 | JMP m16:32 | X | X | X | Jump to call gate, same privilege | |||
| FF /5 | JMP m16:32 | X | X | X | Jump via task state segment | |||
| FF /5 | JMP m16:32 | X | X | X | Jump via task gate | 
- Description
The JMP instruction transfers control to a different point in the instruction stream without recording return information. The action of the various forms of the instruction are shown below. Jumps with destinations of type r/m16, r/m32, rel16,, and rel32 are near jumps and do not involve changing the segment register value. The JMP rel16 and JMP rel32 forms of the instruction add an offset to the address of the instruction following the JMP to determine the destination. The rel16 form is used when the instruction's operand-size attribute is 16- bits (segment size attribute 16 only); rel32 is used when the operand-size attribute is 32-bits (segment size attribute 32 only). The result is stored in the 32-bit EIP register. With rel16, the upper 16-bits of the EIP register are cleared, which results in an offset whose value does not exceed 16-bits. The JMP r/m16 and JMP r/m32 forms specify a register or memory location from which the absolute offset from the procedure is fetched. The offset fetched from r/m is 32-bits for an operand-size attribute of 32-bits (r/m32 ), or 16-bits for an operand-size attribute of 16-bits (r/m16). The JMP ptr16:16 and ptr16:32 forms of the instruction use a four-byte or six-byte operand as a long pointer to the destination. The JMP m16:16 and m16:32 forms fetch the long pointer from the memory location specified ( indirection). In Real Address Mode or Virtual 8086 Mode, the long pointer provides 16-bits for the CS register and 16 or 32-bits for the EIP register (depending on the operand-size attribute). In Protected Mode, both long pointer forms consult the Access Rights (AR) byte in the descriptor indexed by the selector part of the long pointer. Depending on the value of the AR byte, the jump will perform one of the following types of control transfers :
- A jump to a code segment at the same privilege level
- A task switch
For more information on protected mode control transfers, refer to the Intel documentation.
- Operation
IF instruction = relative JMP  (* i.e. operand is rel8, rel16, or rel32 *)
THEN 
 EIP ← EIP + rel18/16/32;
 IF OperandSize = 16 
 THEN EIP ← EIP AND 0000FFFFH;
 FI;
FI;
IF instruction = near indirect JMP 
 (* i.e. operand is r/m16 or r/m32 *)
THEN 
 IF OperandSize = 16 
 THEN 
   EIP ← [r/m16] AND 0000FFFFH;
 ELSE (* OperandSize = 32 *)
   EIP ← [r/m32;
 FI;
FI;
IF (PE = 0 OR (PE = 1 AND VM = 1)) (* real mode or V86 mode *)
 AND instruction = far JMP 
 (* i.e., operand type is m16:16, m16:32, ptr16:16, ptr16:32 *)
THEN GOTO REAL-OR-V86-MODE;
 IF operand type = m16:16 or m16:32
 THEN (* indirect *)
  IF OperandSize = 16 
  THEN
    CS:IP ← [m16:16];
    EIP ← EIP AND 0000FFFFH; (* clear upper 16 bits *)
  ELSE (* OperandSize = 32 *)
    CS:EIP ← [m16:32];
  FI;
 FI;
 IF operand type = ptr16:16 or ptr16:32
 THEN 
   IF OperandSize = 16 
   THEN 
     CS:IP ← ptr16:16;
     EIP ← EIP AND 0000FFFFH; (* clear upper 16 bits *)
   ELSE (* OperandSize = 32 *)
     CS:EIP ← ptr16:32;
   FI;
 FI;
FI;
IF (PE = 1 AND VM = 0) (* Protected mode, not V86 mode *) AND instruction = far JMP THEN IF operand type = m16:16 or m16:32 THEN (* indirect *) check access of EA dword; #GP(0) or #SS(0) IF limit violation; FI; Destination selector is not null ELSE #GP(0) Destination selector index is within its descriptor table limits ELSE #GP(selector) Depending on AR byte of destination descriptor; GOTO CONFORMING-CODE-SEGMENT; GOTO NONCONFORMING-CODE-SEGMENT; GOTO CALL-GATE; GOTO TASK-GATE; GOTO TASK-STATE-SEGMENT; ELSE #GP(selector); (* illegal AR byte in descriptor *) FI;
CONFORMING-CODE-SEGMENT: Descriptor DPL must be ó CPL ELSE #GP(selector); Segment must be present ELSE #NP(selector); Instruction pointer must be within code-segment limit ELSE #GP(0); IF OperandSize = 32 THEN Load CS:EIP from destination pointer; ELSE Load CS:IP from destination pointer; FI; Load CS register with new segment descriptor;
NONCONFORMING-CODE-SEGMENT: RPL of destination selector must be ò CPL ELSE #GP(selector); Descriptor DPL must be = CPL ELSE #GP(selector); Segment must be present ELSE #NP(selector); Instruction pointer must be within code-segment limit ELSE #GP(0); IF OperandSize = 32 THEN Load CS:EIP from destination pointer; ELSE Load CS:IP from destination pointer; FI; Load CS register with new segment descriptor; Set RPL field of CS register to CPL;
CALL-GATE:
 Descriptor DPL must be ò CPL ELSE #GP(gate selector);
 Descriptor DPL must be ò gate selector RPL ELSE #GP(gate selector);
 Gate must be present ELSE #NP(gate selector);
 Examine selector to code segment given in call gate descriptor:
   Selector must not be null ELSE #GP(0);
   Selector must be within its descriptor table limits ELSE 
     #GP(CS selector);
   Descriptor AR byte must indicate code segment 
     ELSE #GP(CS selector);
   IF non-conforming
   THEN code-segment descriptor DPL must = CPL 
   ELSE #GP(CS selector);
   FI;
   IF conforming 
   THEN code-segment descriptor DPL must be ó CPL;
   ELSE #GP(CS selector);
   Code segment must be present ELSE #NP(CS selector);
   Instruction pointer must be within code-segment limit ELSE #GP(0);
   IF OperandSize = 32 
   THEN Load CS:EIP from call gate;
   ELSE Load CS:IP from call gate;
   FI;
 Load CS register with new code-segment descriptor;
 Set RPL of CS to CPL 
TASK-GATE:
 Gate descriptor DPL must be ò CPL ELSE #GP(gate selector);
 Gate descriptor DPL must be ò gate selector RPL ELSE #GP(gate selector);
 Task Gate must be present ELSE #NP(gate selector);
 Examine selector to TSS, given in Task Gate descriptor:
   Must specify global in the local/global bit ELSE #GP(TSS selector);
   Index must be within GDT limits ELSE #GP(TSS selector);
   Descriptor AR byte must specify available TSS (bottom bits 00001);
     ELSE #GP(TSS selector);
   Task State Segment must be present ELSE #NP(TSS selector);
 SWITCH-TASKS (without nesting) to TSS;
 Instruction pointer must be within code-segment limit ELSE #GP(0);
TASK-STATE-SEGMENT: TSS DPL must be ò CPL ELSE #GP(TSS selector); TSS DPL must be ò TSS selector RPL ELSE #GP(TSS selector); Descriptor AR byte must specify available TSS (bottom bits 00001) ELSE #GP(TSS selector); Task State Segment must be present ELSE #NP(TSS selector); SWITCH-TASKS (without nesting) to TSS; Instruction pointer must be within code-segment limit ELSE #GP(0);
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| | | | | | | | | |
All if a task switch takes place; none if no task switch occurs.
- Protected Mode Exceptions
Far jumps: #GP, #NP, #SS, and #TS, as indicated in the list above. Near direct jumps: #GP(0) if procedure location is beyond the code segment limits; #AC for unaligned memory reference if the current privilege level is 3. Near indirect jumps: #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments: #SS(0) for an illegal address in the SS segment; #GP if the indirect offset obtained is beyond the code segment limits; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would be outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as under Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
All branches are converted into 16-byte code fetches regardless of jump address or cacheability.
LAHF - Load Flags into AH Register
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9F | LAHF | X | X | X | X | X | X | AH ← flags (SF,ZF,xx,AF,xx,PF,xx,CF) | 
- Description
The LAHF instruction transfers the low byte of the flags word to the AH register. The bits, from MSB to LSB, are sign, zero, indeterminate, auxiliary, carry, indeterminate, parity, indeterminate, and carry.
- Operation
AH ← SF:ZF:xx:AF:xx:PF:xx:CF;
- Related Information
LAR-Load Access Rights Byte
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 02 /r | LAR r16,r/m16 | X | X | X | X | r16 ← r/m16 masked by FF00 | ||
| 0F 02 /r | LAR r32,r/m32 | X | X | X | r32 ← r/m32 masked by 00F?FF00 | 
- Description
The LAR instruction stores a marked form of the second doubleword of the descriptor for the source selector if the selector is visible at the current privilege level (modified by the selector's RPL) and is a valid descriptor type within the descriptor limits. The destination register is loaded with the high-order doubleword of the descriptor masked by 00FxFF00, and the ZF flag is set. The x indicates that the four bits corresponding to the upper four bits of the limit are undefined in the value loaded by the LAR instruction. If the selector is invisible or of the wrong type, the ZF flag is cleared. If the 32-bit operand size is specified, the entire 32-bit value is loaded into the 32-bit destination register. If the 16-bit operand size is specified, the lower 16-bits of this value are stored in the 16-bit destination register. All code and data segment descriptors are valid for the LAR instruction. The valid special segment and gate descriptor types for the LAR instruction are given in the following table:
| TYPE | NAME | VALID/INVALID | 
|---|---|---|
| 0 | Invalid | Invalid | 
| 1 | Available 16-bit TSS | Valid | 
| 2 | LDT | Valid | 
| 3 | Busy 16-bit TSS | Valid | 
| 4 | 16-bit call gate | Valid | 
| 5 | 16-bit/32-bit task gate | Valid | 
| 6 | 16-bit trap gate | Invalid | 
| 7 | 16-bit interrupt gate | Invalid | 
| 8 | Invalid | Invalid | 
| 9 | Available 32-bit TSS | Valid | 
| A | Invalid | Invalid | 
| B | Busy 32-bit TSS | Valid | 
| C | 32-bit call gate | Valid | 
| D | Invalid | Invalid | 
| E | 32-bit trap gate | Invalid | 
| F | 32-bit interrupt gate | Invalid | 
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| * | 
The ZF flag is set unless the selector is invisible or of the wrong type, in which case the ZF flag is cleared.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 6; the LAR instruction is unrecognized in Real Address Mode.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode.
LDS/LES/LFS/LGS/LSS-Load Full Pointer
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| C5 /r | LDS r16,m16:16 | X | X | X | X | X | X | DS:r16 ← pointer from memory dword | 
| C5 /r | LDS r32,m16:32 | X | X | X | DS:r32 ← pointer from memory fword | |||
| C4 /r | LES r16,m16:16 | X | X | X | X | X | X | ES:r16 ← pointer from memory dword | 
| C4 /r | LES r32,m16:32 | X | X | X | ES:r32 ← pointer from memory fword | |||
| 0F B4 /r | LFS r16,m16:16 | X | X | X | FS:r16 ← pointer from memory dword | |||
| 0F B4 /r | LFS r32,m16:32 | X | X | X | FS:r32 ← pointer from memory fword | |||
| 0F B5 /r | LGS r16,m16:16 | X | X | X | GS:r16 ← pointer from memory dword | |||
| 0F B5 /r | LGS r32,m16:32 | X | X | X | GS:r32 ← pointer from memory fword | |||
| 0F B2 /r | LSS r16,m16:16 | X | X | X | SS:r16 ← pointer from memory dword | |||
| 0F B2 /r | LSS r32,m16:32 | X | X | X | SS:r32 ← pointer from memory fword | 
- Description
The LGS, LSS, LDS, LES, and LFS instructions read a full pointer from memory and store it in the selected segment register:register pair. The full pointer loads 16-bits into the segment register SS, DS, ES, FS, or GS. The other register loads 32-bits if the operand-size attribute is 32-bits, or loads 16-bits if the operand-size attribute is 16-bits. The other 16- or 32-bit register to be loaded is determined by the r16 or r32 register operand specified. When an assignment is made to one of the segment registers, the descriptor is also loaded into the segment register. The data for the register is obtained from the descriptor table entry for the selector given. A null selector (values 0000-0003) can be loaded into DS, ES, FS, or GS registers without causing a protection exception. (Any subsequent reference to a segment whose corresponding segment register is loaded with a null selector to address memory causes a #GP(0) exception. No memory reference to the segement occurs.) The following is a listing of the Protected Mode checks and actions taken in the loading of a segment register:
IF SS is loaded; IF selector is null THEN #GP(0); FI; Selector index must be within its descriptor table limits ELSE #GP(selector); Selector's RPL must equal CPL ELSE #GP(selector); AR byte must indicate a writable data segment ELSE #GP(selector); DPL in the AR byte must equal CPL ELSE #GP(selector); Segment must be marked present ELSE #SS(selector); Load SS with selector; Load SS with descriptor;
IF DS, ES, FS, or GS is loaded with non-null selector: Selector index must be within its descriptor table limits ELSE #GP(selector); AR byte must indicate data or readable code segment ELSE #GP(selector); IF data or nonconforming code THEN both the RPL and the CPL must be less than or equal to DPL in AR byte; ELSE #GP(selector); Segment must be marked present ELSE #NP(selector); Load segment register with selector and RPL bits; Load segment register with descriptor;
IF DS, ES, FS or GS is loaded with a null selector: Load segment register with selector; Clear descriptor valid bit;
- Operation
CASE instruction OF LSS: Sreg is SS; (* Load SS register *) LDS: Sreg is DS; (* Load DS register *) LES: Sreg is ES; (* Load ES register *) LFS: Sreg is FS; (* Load FS register *) LGS: Sreg is DS; (* Load GS register *) ESAC; IF (OperandSize = 16) THEN r16 ← [Effective Address]; (* 16-bit transfer *) Sreg ← [Effective Address + 2]; (* 16-bit transfer *) (* In Protected Mode, load the descriptor into the segment register *) ELSE (* OperandSize = 32 *) r32 ← [Effective Address]; (* 32-bit transfer *) Sreg ← [Effective Address + 4]; (* 16-bit transfer *) (* In Protected Mode, load the descriptor into the segment register *) FI;
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; the second operand must be a memory operand, not a register-if a register then #UD Fault; #GP(0) if a null selector is loaded into SS; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
The second operand must be a memory operand, not a register, Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
LEA-Load Effective Address
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 8D /r | LEA r16,m | X | X | X | X | X | X | r16 ← effective address for m | 
| 8D /r | LEA r32,m | X | X | X | r32 ← effective address for m | 
- Description
The LEA instruction calculates the effective address (offset part) and stores it in the specified register. The operand-size attribute of the instruction (represented by OperandSize in the algorithm under "Operation" above) is determined by the chosen register. The address-size attribute ( represented by AddressSize) is determined by the attribute of the code segment. (See Operand-Size and Address-Size Attributes.) The address-size and operand-size attributes affect the action performed by the LEA instruction, as follows:
| OPERAND SIZE | ADDRESS SIZE | ACTION PERFORMED | 
|---|---|---|
| 16 | 16 | 16-bit effective address is calculated and stored in requested 16-bit register destination. | 
| 16 | 32 | 32-bit effective address is calculated. The lower 16-bits of the address are stored in the requested 16-bit register destination. | 
| 32 | 16 | 16-bit effective address is calculated. The 16-bit address is zero-extended and stored in the requested 32-bit register destination. | 
| 32 | 32 | 32-bit effective address is calculated and stored in the requested 32-bit register destination. | 
- Operation
IF OperandSize = 16 AND AddressSize = 16 
THEN r16 ← Addr(m);
ELSE 
  IF OperandSize = 16 AND AddressSize = 32 
  THEN 
    r16 ← Truncate_to_16bits(Addr(m));  (* 32-bit address *)
  ELSE 
    IF OperandSize = 32 AND AddressSize = 16 
    THEN 
      r32 ← Truncate_to_16bits(Addr(m)) and zero extend;
    ELSE 
      IF OperandSize = 32 AND AddressSize = 32 
      THEN  r32 ← Addr(m);
      FI;
    FI;
  FI;
FI;
- Protected Mode Exceptions
- #UD if the second operand is a register.
- Real Address Mode Exceptions
- Interrupt 6 if the second operand is a register.
- Virtual 8086 Mode Exceptions
- Same exceptions as in Real Address Mode.
- Notes
Different assemblers may use different algorithms based on the size attribute and symbolic reference of the second operand.
LEAVE-High Level Procedure Exit
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| C9 | LEAVE | X | X | X | X | X | Set SP to BP, then pop BP | |
| C9 | LEAVE | X | X | X | Set ESP to EBP, then pop EBP | 
- Description
The LEAVE instruction reverses the actions of the ENTER instruction. By copying the frame pointer to the stack pointer, the LEAVE instruction releases the stack space used by a procedure for its local variables. The old frame pointer is popped into the BP or EBP register, restoring the caller's frame. A subsequent RET nn instruction removes any arguments pushed onto the stack of the exiting procedure.
- Operation
IF StackAddrSize = 16 THEN SP ← BP; ELSE (* StackAddrSize = 32 *) ESP ← EBP; FI; IF OperandSize = 16 THEN BP ← Pop(); ELSE (* OperandSize = 32 *) EBP ← Pop(); FI;
- Protected Mode Exceptions
- #SS(0) if the BP register does not point to a location within the limits of the current stack segment.
- Real Address Mode Exceptions
- Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
- Same exceptions as in Real Address Mode.
LES-Load Full Pointer
See entry for LDS/LES/LFS/LGS/LSS.
LFS-Load Full Pointer
See entry for LDS/LES/LFS/LGS/LSS.
LGDT/LIDT-Load Global/Interrupt Descriptor Table Register
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+----------------------------- |0F 01 /2 |LGDT m16&32 | | |X|X|X|X|GDTR ← memory fword (6 bytes) |----------+--------------------+-+-+-+-+-+-+----------------------------- |0F 01 /3 |LIDT m16&32 | | |X|X|X|X|IDTR ← memory fword (6 bytes)
- Description
The LGDT and LIDT instructions load a linear base address and limit value from a six-byte data operand in memory into the GDTR or IDTR, respectively. If a 16-bit operand is used with the LGDT or LIDT instruction, the register is loaded with a 16-bit limit and a 24-bit base, and the high-order eight bits of the six-byte data operand are not used. If a 32-bit operand is used , a 16-bit limit and a 32-bit base is loaded; the high-order eight bits of the six-byte operand are used as high-order base address bits. The SGDT and SIDT instructions always store into all 48 bits of the six- byte data operand. With the 16-bit processors, the upper eight bits are undefined after the SGDT or SIDT instruction is run. With the 32-bit processors, the upper right eight bits are written with the high-order eight address bits, for both a 16-bit operand and a 32-bit operand. If the LGDT or LIDT instruction is used with a 16-bit operand to load the register stored by the SGDT or SIDT instruction, the upper eight bits are stored as zeros. The LGDT and LIDT instructions appear in operating system software; they are not used in application programs. They are the only instructions that directly load a linear address (i.e., not a segment relative address) in Protected Mode.
- Operation
IF instruction = LIDT THEN IF OperandSize = 16 THEN IDTR.Limit:Base ← m16:24 (* 24-bits of base loaded *) ELSE IDTR.Limit:Base ← m16:32 FI; ELSE (* instruction = LGDT *) IF OperandSize = 16 THEN GDTR.Limit:Base ← m16:24 (* 24-bits of base loaded *) ELSE GDTR.Limit:Base ← m16:32; FI; FI;
- Protected Mode Exceptions
- #GP(0) if the current privilege level is not 0; #UD if the source operand is a register; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault.
- Real Address Mode Exceptions
- Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH; Interrupt 6 if the source operand is a register.
Note: These instructions are valid in Real Address Mode to allow power-up initialization for Protected Mode.
- Virtual 8086 Mode Exceptions
- Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault.
LGS-Load Full Pointer
See entry for LDS/LES/LFS/LGS/LSS.
LLDT-Load Local Descriptor Table Register
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 00 /2 | LLDT r/m16 | X | X | X | X | LDTR ← r/m16 selector | 
- Description
The LLDT instruction loads the Local Descriptor Table register (LDTR). The word operand (memory or register) to the LLDT instruction should contain a selector to the Global Descriptor Table (GDT). The GDT entry should be a Local Descriptor Table. If so, then the LDTR is loaded from the entry. The descriptor registers DS, ES, SS, FS, GS, and CS are not affected. The LDT field in the task state segment does not change. The selector operand can be 0; if so, the LDTR is marked invalid. All descriptor references (except by the LAR, VERR, VERW or LSL instructions) cause a #GP fault. The LLDT instruction is used in operating system software; it is not used in application programs.
- Operation
LDTR ← SRC;
- Protected Mode Exceptions
- GP(0) if the current privilege level is not 0; #GP(selector) if the selector operand does not point into the Global Descriptor Table, or if the entry in the GDT is not a Local Descriptor Table; #NP(selector) if the LDT descriptor is not present; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault.
- Real Address Mode Exceptions
Interrupt 6; the LLDT instruction is not recognized in Real Address Mode.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode (because the instruction is not recognized, it will not run or perform a memory reference).
- Note
The operand-size attribute has no effect on this instruction.
LIDT - Load Interrupt Descriptor Table Register
See entry for LGDT/LIDT-Load Global Descriptor Table Register/Load Interrupt Descriptor Table Register.
LMSW - Load Machine Status Word
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 01 /6 | LMSW r/m16 | X | X | X | X | Load r/m16 into machine status word | 
- Description
The LMSW instruction loads the machine status word (part of the CR0 register) from the source operand. This instruction can be used to switch to Protected Mode; if so, it must be followed by an intrasegment jump to flush the instruction queue. The LMSW instruction will not switch back to Real Address Mode. The LMSW instruction is used only in operating system software. It is not used in application programs.
- Operation
MSW ← r/m16;
(* 16 bits is stored in the machine status word *)
- Protected Mode Exceptions
- GP(0) if the current privilege level is not 0; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Protected Mode.
- Notes
The operand-size attribute has no effect on this instruction. This instruction is provided for compatibility with the Intel286 processor; programs for the Intel386, Intel486, and Pentium processors should use the MOV CR0, ... instruction instead. The LMSW instruction does not affect the PG, ET, or NE bits, and it cannot be used to clear the PE bit.
LOCK - Assert LOCK# Signal Prefix
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F0 | LOCK | X | X | X | X | X | X | Assert LOCK# signal for next instruction | 
- Description
The LOCK prefix causes the LOCK# signal of the processor to be asserted during processing of the instruction that follows it. In a multiprocessor environment, this signal can be used to ensure that the processor has exclusive use of any shared memory while LOCK# is asserted. The read-modify -write sequence typically used to implement test-and-set on the Pentium processor is the BTS instruction. The LOCK prefix functions only with the following instructions:
| BTS, BTR, BTC | mem, reg/imm | 
| XCHG | reg, mem | 
| XCHG | mem, reg | 
| ADD, OR, ADC, SBB, AND, SUB, XOR | mem, reg/imm | 
| NOT, NEG, INC, DEC | mem | 
| CMPXCHG, XADD | 
An undefined opcode trap will be generated if a LOCK prefix is used with any instruction not listed above. The XCHG instruction always asserts LOCK# regardless of the presence or absence of the LOCK prefix. The integrity of the LOCK prefix is not affected by the alignment of the memory field. Memory locking is observed for arbitrarily misaligned fields.
- Protected Mode Exceptions
'#UD if the LOCK prefix is used with an instruction not listed in the "Description"; section above; other exceptions can be generated by the subsequent (locked) instruction.
- Real Address Mode Exceptions
Interrupt 6 if the LOCK prefix is used with an instruction not listed in the "Description" section above; exceptions can still be generated by the subsequent (locked) instruction.
- Virtual 8086 Mode Exceptions
'#UD if the LOCK prefix is used with an instruction not listed in the "Description" section above; exceptions can still be generated by the subsequent (locked) instruction.
LODS/LODSB/LODSW/LODSD-Load String Operand
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| AC | LODS m8 | X | X | X | X | X | X | AL ← byte at [(E)SI] | 
| AD | LODS m16 | X | X | X | X | X | X | AX ← word at [(E)SI] | 
| AD | LODS m32 | X | X | X | EAX ← dword at [(E)SI] | |||
| AC | LODSB | X | X | X | X | X | X | AL ← byte at DS:[(E)SI] | 
| AD | LODSW | X | X | X | X | X | X | AX ← word at DS:[(E)SI] | 
| AD | LODSD | X | X | X | EAX ← dword at DS:[(E)SI] | 
- Description
The LODS instruction loads the AL, AX, or EAX register with the memory byte, word, or doubleword at the location pointed to by the source-index register. After the transfer is made, the source-index register is automatically advanced. If the DF flag is 0 (the CLD instruction was run), the source index increments; if the DF flag is 1 (the STD instruction was run), it decrements. The increment or decrement is 1 if a byte is loaded, 2 if a word is loaded, or 4 if a doubleword is loaded. If the address-size attribute for this instruction is 16-bits, the SI register is used for the source-index register; otherwise the address-size attribute is 32-bits, and the ESI register is used. The address of the source data is determined solely by the contents of the ESI or SI register. Load the correct index value into the SI register before running the LODS instruction. The LODSB, LODSW, and LODSD instructions are synonyms for the byte, word, and doubleword LODS instructions. The LODS instruction can be preceded by the REP prefix; however, the LODS instruction is used more typically within a LOOP construct, because further processing of the data moved into the EAX, AX, or AL register is usually necessary.
- Operation
AddressSize = 16 THEN use SI for source-index ELSE (* AddressSize = 32 *) use ESI for source-index; FI; IF byte type of instruction THEN AL ←[source-index]; (* byte load *) IF DF = 0 THEN IncDec ← 1 ELSE IncDec ← -1; FI; ELSE IF OperandSize = 16 THEN AX ← [source-index]; (* word load *) IF DF = 0 THEN IncDec ← 2 ELSE IncDec ← -2; FI; ELSE (* OperandSize = 32 *) FAX ← [source-index]; (* dword load *) IF DF = 0 THEN IncDec ← 4 ELSE IncDec ← -4; FI; FI; FI; source-index ← source-index + IncDec
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
LOOP/LOOPcond-Loop Control with CX Counter
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| E2 cb | LOOP rel8 | X | X | X | X | X | X | DEC (E)CX; jump if (E)CX <> 0 | 
| E2 cb | LOOPW rel8 | X | X | X | DEC CX; jump if CX <> 0 | |||
| E2 cb | LOOPD rel8 | X | X | X | DEC ECX; jump if ECX <> 0 | |||
| E1 cb | LOOPE rel8 | X | X | X | X | X | X | DEC (E)CX, jump if (E)CX <> 0 and ZF=1 | 
| E1 cb | LOOPEW rel8 | X | X | X | DEC CX, jump if CX <> 0 and ZF=1 | |||
| E1 cb | LOOPED rel8 | X | X | X | DEC ECX; jump if ECX <> 0 and ZF=1 | |||
| E1 cb | LOOPZ rel8 | X | X | X | X | X | X | DEC (E)CX; jump if (E)CX <> 0 and ZF=1 | 
| E1 cb | LOOPZW rel8 | X | X | X | DEC CX; jump if CX <> 0 and ZF=1 | |||
| E1 cb | LOOPZD rel8 | X | X | X | DEC ECX; jump if ECX <> 0 and ZF=1 | |||
| E0 cb | LOOPNE rel8 | X | X | X | X | X | X | DEC (E)CX; jump if (E)CX <> 0 and ZF=0 | 
| E0 cb | LOOPNEW rel8 | X | X | X | DEC CX; jump if CX <> 0 and ZF=0 | |||
| E0 cb | LOOPNED rel8 | X | X | X | DEC ECX; jump if ECX <> 0 and ZF=0 | |||
| E0 cb | LOOPNZ rel8 | X | X | X | X | X | X | DEC (E)CX; jump if (E)CX <> 0 and ZF=0 | 
| E0 cb | LOOPNZW rel8 | X | X | X | DEC CX; jump if CX <> 0 and ZF=0 | |||
| E0 cb | LOOPNZD rel8 | X | X | X | DEC ECX; jump if ECX <> 0 and ZF=0 | 
- Description
The LOOP instruction decrements the count register without changing any of the flags. Conditions are then checked for the form of the LOOP instruction being used. If the conditions are met, a short jump is made to the label given by the operand to the LOOP instruction. If the address-size attribute is 16-bits, the CX register is used as the count register; otherwise the ECX register is used. The operand of the LOOP instruction must be in the range from 128 (decimal) bytes before the instruction to 127 bytes ahead of the instruction. The LOOP instructions provide iteration control and combine loop index management with conditional branching. Use the LOOP instruction by loading an unsigned iteration count into the count register, then code the LOOP instruction at the end of a series of instructions to be iterated. The destination of the LOOP instruction is a label that points to the beginning of the iteration.
- Operation
IF AddressSize = 16 THEN CountReg is CX ELSE CountReg is ECX; FI;
CountReg ← CountReg - 1;
IF instruction<> LOOP 
THEN 
   IF (instruction = LOOPE) OR (instruction = LOOPZ)
   THEN BranchCond ← (ZF = 1) AND (CountReg <> 0);
   FI;
   IF (instruction = LOOPNE) OR (instruction = LOOPNZ)
   THEN BranchCond ← (ZF = 0) AND (CountReg <> 0);
   FI;
FI;
IF BranchCond 
THEN 
   IF OperandSize = 16 
   THEN
     IP ← IP + SignExtend(rel8);
   ELSE (* OperandSize = 32 *)
     EIP ← EIP + SignExtend(rel8);
   FI;
FI;
- Protected Mode Exceptions
- GP(0) if the offset jumped to is beyond the limits of the current code segment.
- Notes
The unconditional LOOP instruction takes longer to run than a two- instruction sequence, which decrements the counter register and jumps if the count does not equal zero. All branches are converted into 16-byte code fetches regardless of jump address or cacheability.
LSL - Load Segment Limit
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 03 /r | LSL r16,r/m16 | X | X | X | X | r16 ← byte granular segment limit for selector r/m16 | ||
| 0F 03 /r | LSL r32,r/m32 | X | X | X | r32 ← byte granular segment limit for selector r/m32 | |||
| 0F 03 /r | LSL r16,r/m16 | X | X | X | X | r16 ← page granular segment limit for selector r/m16 | ||
| 0F 03 /r | LSL r32,r/m32 | X | X | X | r32 ← page granular segment limit for selector r/m32 | 
- Description
The LSL instruction loads a register with an unscrambled segment limit, and sets the ZF flag, provided that the source selector is visible at the current privilege level and RPL, within the descriptor table, and that the descriptor is a type accepted by the LSL instruction. Otherwise, the ZF flag is cleared, and the destination register is unchanged. The segment limit is loaded as a byte granular value. If the descriptor has a page granular segment limit, the LSL instruction will translate it to a byte limit before loading it in the destination register (shift left 12 the 20- bit "raw" limit from descriptor, then OR with 00000FFFH). The 32-bit forms of the LSL instruction store the 32-bit byte granular limit in the 32-bit destination register. For 16-bit operand sizes, the limit is computed to form a valid 32-bit limit. However, the upper 16 bits are chopped and only the low-order 16 bits are loaded into the destination operand. Code and data segment descriptors are valid for the LSL instruction. The valid special segment and gate descriptor types for the LSL instruction are given in the following table:
| TYPE | NAME | VALID/INVALID | 
|---|---|---|
| 0 | Invalid | Invalid | 
| 1 | Available 16-bit TSS | Valid | 
| 2 | LDT | Valid | 
| 3 | Busy 16-bit TSS | Valid | 
| 4 | 16-bit call gate | Invalid | 
| 5 | 16-bit/32-bit task gate | Invalid | 
| 6 | 16-bit trap gate | Invalid | 
| 7 | 16-bit interrupt gate | Invalid | 
| 8 | Invalid | Invalid | 
| 9 | Available 32-bit TSS | Valid | 
| A | Invalid | Invalid | 
| B | Busy 32-bit TSS | Valid | 
| C | 32-bit call gate | Invalid | 
| D | Invalid | Invalid | 
| E | 32-bit trap gate | Invalid | 
| F | 32-bit interrupt gate | Invalid | 
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- | | | | |* | | |
The ZF flag is set unless the selector is invisible or of the wrong type, in which case the ZF flag is cleared.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments: #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 6; the LSL instruction is not recognized in Real Address Mode.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode (because the instruction is not recognized, it will not run or perform a memory reference).
LSS-Load Full Pointer
See entry for LDS/LES/LFS/LGS/LSS.
LTR-Load Task Register
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 00 /3 | LTR r/m16 | X | X | X | X | Load EA word into task register | 
- Description
The LTR instruction loads the task register with a selector from the source register or memory location specified by the operand. The loaded TSS is marked busy. A task switch does not occur. The LTR instruction is used only in operating system software; it is not used in application programs.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #GP(0) if the current privilege level is not 0; #GP(selector) if the object named by the source selector is not a TSS or is already busy; #NP(selector) if the TSS is marked "not present;" #PF(fault-code) for a page fault.
- Real Address Mode Exceptions
Interrupt 6; the LTR instruction is not recognized in Real Address Mode.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode.
- Notes
The operand-size attribute has no effect on this instruction.
MOV - Move Data
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 88 /r | MOV r/m8,r8 | X | X | X | X | X | X | Move byte register to r/m byte | 
| 89 /r | MOV r/m16,r16 | X | X | X | X | X | X | Move word register to r/m word | 
| 89 /r | MOV r/m32,r32 | X | X | X | Move dword register to r/m dword | |||
| 8A /r | MOV r8,r/m8 | X | X | X | X | X | X | Move r/m byte to byte register | 
| 8B /r | MOV r16,r/m16 | X | X | X | X | X | X | Move r/m word to word register | 
| 8B /r | MOV r32,r/m32 | X | X | X | Move r/m dword to dword register | |||
| 8C /r | MOV r/m16,Sreg | X | X | X | X | X | X | Move segment register to r/m word | 
| 8E /r | MOV Sreg,r/m16 | X | X | X | X | X | X | Move r/m word to segment register | 
| A0 | MOV AL,moffs8 | X | X | X | X | X | X | Move byte at (seg:offset) to AL | 
| A1 | MOV AX,moffs16 | X | X | X | X | X | X | Move word at (seg:offset) to AX | 
| A1 | MOV EAX,moffs32 | X | X | X | Move dword at (seg:offset) to EAX | |||
| A2 | MOV moffs8,AL | X | X | X | X | X | X | Move AL to (seg:offset) | 
| A3 | MOV moffs16,AX | X | X | X | X | X | X | Move AX to (seg:offset) | 
| A3 | MOV moffs32,EAX | X | X | X | Move EAX to (seg:offset) | |||
| B0+rb | MOV r8,imm8 | X | X | X | X | X | X | Move immediate byte to byte register | 
| B8+rw | MOV r16,imm16 | X | X | X | X | X | X | Move immediate word to word register | 
| B8+rd | MOV r32,imm32 | X | X | X | Move immediate dword to dword register | |||
| C6 /0 | MOV r/m8,imm8 | X | X | X | X | X | X | Move immediate byte to r/m byte | 
| C7 /0 | MOV r/m16,imm16 | X | X | X | X | X | X | Move immediate word to r/m word | 
| C7 /0 | MOV r/m32,imm32 | X | X | X | Move immediate dword to r/m dword | 
- Description
The MOV instruction copies the second operand to the first operand. If the destination operand is a segment register (DS, ES, SS, etc.), then data from a descriptor is also loaded into the shadow portion of the register. The data for the register is obtained from the descriptor table entry for the selector given. A null selector (values 0000-0003) can be loaded into the DS, ES, FS, and GS registers without causing an exception; however, use of these registers causes a #GP(0) exception, and no memory reference occurs. A MOV into SS instruction inhibits all interrupts until after the processing of the next instruction (which should be a MOV into ESP instruction). Loading a segment register under Protected Mode results in special checks and actions, as described in the following listing:
IF SS is loaded;
THEN 
   IF selector is null THEN #GP(0);
   Selector index must be within its descriptor table limits else #GP(selector);
   Selector's RPL must equal CPL else #GP(selector);
   AR byte must indicate a writable data segment else #GP(selector);
   DPL in the AR byte must equal CPL else #GP(selector);
   Segment must be marked present else #SS(selector);
   Load SS with selector;
   Load SS with descriptor.
FI;
IF DS, ES, FS or GS is loaded with non-null selector;
THEN 
   Selector index must be within its descriptor table limits 
      else #GP(selector);
   AR byte must indicate data or readable code segment else #GP(selector);
   IF data or nonconforming code segment 
   THEN both the RPL and the CPL must be less than or equal to DPL in AR byte;
   ELSE #GP(selector);
   FI;
   Segment must be marked present else #NP(selector);
   Load segment register with selector;
   Load segment register with descriptor;
FI;
IF DS, ES, FS or GS is loaded with a null selector;
THEN 
   Load segment register with selector;
   Clear descriptor valid bit;
FI;
- Operation
DEST ← SRC;
- Protected Mode Exceptions
- GP, #SS, and #NP if a segment register is being loaded; otherwise, #GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
MOV - Move to/from Control Registers
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 22 /r | MOV CR0,r32 | X | X | X | Move r32 to control register 0 | |||
| 0F 22 /r | MOV CR2,r32 | X | X | X | Move r32 to control register 2 | |||
| 0F 22 /r | MOV CR3,r32 | X | X | X | Move r32 to control register 3 | |||
| 0F 22 /r | MOV CR4,r32 | X | Move r32 to control register 4 | |||||
| 0F 20 /r | MOV r32,CR0 | X | X | X | Move control register 0 to r32 | |||
| 0F 20 /r | MOV r32,CR2 | X | X | X | Move control register 2 to r32 | |||
| 0F 20 /r | MOV r32,CR3 | X | X | X | Move control register 3 to r32 | |||
| 0F 20 /r | MOV r32,CR4 | X | Move control register 4 to r32 | 
- Description
The above forms of the MOV instruction store or load CR0, CR2, CR3, and CR4 to or from a general purpose register. Thirty-two bit operands are always used with these instructions, regardless of the operand-size attribute. Operation
DEST ← SRC;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| ? | ? | ? | ? | ? | ? | 
The OF, SF, ZF, AF, PF, and CF flags are undefined.
- Protected Mode Exceptions
- GP(0) if the current privilege level is not 0. #GP(0) if an attempt is made to write a 1 to any reserved bits of CR4.
- Real Address Mode Exceptions
Interrupt 13 if an attempt is made to write a 1 to any reserved bits of CR4.
- Virtual 8086 Mode Exceptions
- GP(0) if instruction processing is attempted.
- Notes
The reg field within the ModR/M byte specifies which of the special registers in each category is involved. The two bits in the mod field are always 11. The r/m field specifies the general register involved. Always set undefined or reserved bits to the value previously read.
MOV-Move to/from Debug Registers
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 21 /r | MOV r32,DR0-3 | X | X | X | Move debug register (0,1,2, or 3) to r32 | |||
| 0F 21 /r | MOV r32,DR4/DR5 | X | Move debug register (4 or 5) to r32 | |||||
| 0F 21 /r | MOV r32,DR6/DR7 | X | X | X | Move debug register (6 or 7) to r32 | |||
| 0F 23 /r | MOV DR0-DR3,r32 | X | X | X | Move r32 to debug register (0,1,2, or 3) | |||
| 0F 23 /r | MOV DR4/DR5,r32 | X | Move r32 to debug register (4 or 5) | |||||
| 0F 23 /r | MOV DR6/DR7,r32 | X | X | X | Move r32 to debug register (6 or 7) | 
- Description
The above forms of the MOV instruction store or load the DR0, DR1, DR2, DR3 , DR6 and DR7 debug resisters to or from a general purpose register. Thirty-two bit operands are always used with these instructions, regardless of the operand-size attribute. When the DE (Debug Extension) bit in CR4 is clear, MOV instructions using debug registers operate in a manner that is compatible with Intel386 and Intel486 CPUs. References to DR4 and DR5 refer to DR6 and DR7, respectively. When the DE bit in CR4 is set, attempts to run MOV instructions using DR4 and DR5 result in an Undefined Opcode (#UD) exception.
- Operation
IF ((DE = 1) and (SRC or DEST = DR4 or DR5)) THEN #UD; ELSE DEST ← SRC;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| ? | ? | ? | ? | ? | ? | 
The OF, SF, ZF, AF, PF, and CF flags are undefined.
- Protected Mode Exceptions
- GP(0) if the current privilege level is not 0. #UD if the DE (Debug Extensions) bit of CR4 is set and a MOV instruction is run using DR4 or DR5.
- Real Address Mode Exceptions
- GP(0) if an attempt is made to write a 1 to any reserved bits of CR4. #UD if the DE (Debug Extensions) bit of CR4 is set and a MOV instruction is run using DR4 or DR5.
- Virtual 8086 Mode Exceptions
- GP(0) if instruction processing is attempted.
- Notes
The instructions must be run at privilege level 0 or in real-address mode; otherwise, a protection exception will be raised. The reg field within the ModR/M byte specifies which of the special registers in each category is involved. The two bits in the mod field are always 11. The r/m field specifies the general register involved. Always set undefined or reserved bits to the value previously read.
MOV-Move to/from Test Registers
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 24 /r | MOV r32,TR3 | X | Move test register (3) to r32 | |||||
| 0F 24 /r | MOV r32,TR4/TR5 | X | Move test register (4 or 5) to r32 | |||||
| 0F 24 /r | MOV r32,TR6/TR7 | X | X | Move test register (6 or 7) to r32 | ||||
| 0F 26 /r | MOV TR3,r32 | X | Move r32 to test register (3) | |||||
| 0F 26 /r | MOV TR4/TR5,r32 | X | Move r32 to test register (4 or 5) | |||||
| 0F 26 /r | MOV TR6/TR7,r32 | X | X | Move r32 to test register (6 or 7) | 
- Description
The above forms of the MOV instruction store or load TR3, TR4, TR5, TR6, and TR7 to or from a general purpose register. Thirty-two bit operands are always used with these instructions, regardless of the operand-size attribute.
- Operation
DEST ← SRC;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- |? | | |? |? |? |? |?
The OF, SF, ZF, AF, PF, and CF flags are undefined.
- Protected Mode Exceptions
- GP(0) if the current privilege level is not 0. #GP(0) if an attempt is made to write a 1 to any reserved bits of CR4.
- Real Address Mode Exceptions
Interrupt 13 if an attempt is made to write a 1 to any reserved bits of CR4.
- Virtual 8086 Mode Exceptions
- GP(0) if instruction processing is attempted.
- Notes
The instructions must be run at privilege level 0 or in real-address mode; otherwise, a protection exception will be raised. The reg field within the ModR/M byte specifies which of the special registers in each category is involved. The two bits in the mod field are always 11. The r/m field specifies the general register involved. Always set undefined or reserved bits to the value previously read.
MOVS/MOVSB/MOVSW/MOVSD - Move Data from String to String
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| A4 | MOVS m8,m8 | X | X | X | X | X | X | Move byte [(E)SI] to ES:[(E)DI] | 
| A5 | MOVS m16,m16 | X | X | X | X | X | X | Move word [(E)SI] to ES:[(E)DI] | 
| A5 | MOVS m32,m32 | X | X | X | Move dword [(E)SI] to ES:[(E)DI] | |||
| A4 | MOVSB | X | X | X | X | X | X | Move byte DS:[(E)SI] to ES:[(E)DI] | 
| A5 | MOVSW | X | X | X | X | X | X | Move word DS:[(E)SI] to ES:[(E)DI] | 
| A5 | MOVSD | X | X | X | Move dword DS:[(E)SI] to ES:[(E)DI] | 
- Description
The MOVS instruction copies the byte or word at [(E)SI] to the byte or word at ES:[(E)DI]. The destination operand must be addressable from the ES register; no segment override is possible for the destination. A segment override can be used for the source operand; the default is the DS register. The addresses of the source and destination are determined solely by the contents of the (E)SI and (E)DI registers. Load the correct index values into the (E)SI and (E)DI registers before running the MOVS instruction. The MOVSB, MOVSW, and MOVSD instructions are synonyms for the byte, word, and doubleword MOVS instructions. After the data is moved, both the (E)SI and (E)DI registers are advanced automatically. If the DF flag is 0 (the CLD instruction was run), the registers are incremented; if the DF flag is 1 (the STD instruction was run ), the registers are decremented. The registers are incremented or decremented by 1 if a byte was moved, 2 if a word was moved, or 4 if a doubleword was moved. The MOVS instruction can be preceded by the REP prefix for block movement of ECX bytes or words. Refer to the REP instruction for details of this operation.
- Operation
IF (instruction = MOVSD) OR (instruction has doubleword operands)
THEN OperandSize ← 32;
ELSE OperandSize ← 16;
IF AddressSize = 16 
THEN use SI for source-index and DI for destination-index;
ELSE (* AddressSize = 32 *)
  use ESI for source-index and EDI for destination-index;
FI;
IF byte type of instruction 
THEN 
  [destination-index] ← [source-index]; (* byte assignment *)
  IF DF = 0 THEN IncDec ← 1 ELSE IncDec ← -1; FI;
ELSE 
  IF OperandSize = 16 
  THEN
     [destination-index] ← [source-index]; (* word assignment *)
     IF DF = 0 THEN IncDec ← 2 ELSE IncDec ← -2; FI;
  ELSE (* OperandSize = 32 *)
     [destination-index] ← [source-index]; (* doubleword assignment *)
     IF DF = 0 THEN IncDec ← 4 ELSE IncDec ← -4; FI;
  FI;
FI;
source-index ← source-index + IncDec;
destination-index ← destination-index + IncDec;
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
MOVSX - Move with Sign-Extend
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F BE /r | MOVSX r16,r/m8 | X | X | X | r16 ← sign-extended r/m byte | |||
| 0F BE /r | MOVSX r32,r/m8 | X | X | X | r32 ← sign-extended r/m byte | |||
| 0F BF /r | MOVSX r32,r/m16 | X | X | X | r32 ← sign-extended r/m word | 
- Description
The MOVSX instruction reads the contents of the effective address or register as a byte or a word, sign-extends the value to the operand-size attribute of the instruction (16 or 32 bits), and stores the result in the destination register.
- Operation
DEST ← SignExtend(SRC);
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
MOVZX - Move with Zero-Extend
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F B6 /r | MOVZX r16,r/m8 | X | X | X | r16 ← zero-extended r/m byte | |||
| 0F B6 /r | MOVZX r32,r/m8 | X | X | X | r32 ← zero-extended r/m byte | |||
| 0F B7 /r | MOVZX r32,r/m16 | X | X | X | r32 ← zero-extended r/m word | 
- Description
The MOVZX instruction reads the contents of the effective address or register as a byte or a word, zero extends the value to the operand-size attribute of the instruction (16 or 32 bits), and stores the result in the destination register.
- Operation
DEST ←ZeroExtend(SRC);
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same Exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
MUL - Unsigned Multiplication of AL, AX, or EAX
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F6 /r | MUL r/m8 | X | X | X | X | X | X | Unsigned multiply (AX ← AL * r/m byte) | 
| F7 /4 | MUL r/m16 | X | X | X | X | X | X | Unsigned multiply (DX:AX ← AX * r/m word) | 
| F7 /4 | MUL r/m32 | X | X | X | Unsigned multiply (EDX:EAX ← EAX * r/m dword) | 
- Description
The MUL instruction performs unsigned multiplication. Its actions depend on the size of its operand, as follows:
- A byte operand is multiplied by the AL value; the result is left in the AX register. The CF and OF flags are cleared if the AH value is 0; otherwise, they are set.
- A word operand is multiplied by the AX value; the result is left in the DX :AX register pair. The DX register contains the high-order 16-bits of the product. The CF and OF flags are cleared if the DX value is 0; otherwise, they are set.
- A doubleword operand is multiplied by the EAX value and the result is left in the EDX:EAX register. The EDX register contains the high-order 32-bits of the product. The CF and OF flags are cleared if the EDX value is 0; otherwise, they are set.
- Operation
IF byte-size operation 
THEN AX ← AL * r/m8
ELSE (* word or doubleword operation *)
   IF OperandSize = 16 
   THEN DX:AX ← AX * r/m16
   ELSE (* OperandSize = 32 *)
      EDX:EAX ← EAX * r/m32
   FI;
FI;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- |* | | |? |? |? |? |*
The OF and CF flags are cleared if the upper half of the result is 0; otherwise they are set; the SF, ZF, AF, and PF flags are undefined.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
NEG-Two's Complement Negation
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F6 /3 | NEG r/m8 | X | X | X | X | X | X | Two's complement negate r/m byte | 
| F7 /3 | NEG r/m16 | X | X | X | X | X | X | Two's complement negate r/m word | 
| F7 /3 | NEG r/m32 | X | X | X | Two's complement negate r/m dword | 
- Description
The NEG instruction replaces the value of a register or memory operand with its two's complement. The operand is subtracted from zero, and the result is placed in the operand. The CF flag is set, unless the operand is zero, in which case the CF flag is cleared.
- Operation
IF r/m = 0 THEN CF ← 0 ELSE CF ← 1; FI; r/m ← - r/m
- Flags Affected
OF|DF|IF|SF|ZF|AF|PF|CF --+--+--+--+--+--+--+-- * | | |* |* |* |* |*
The CF flag is set unless the operand is zero, in which case the CF flag is cleared; the OF, SF, ZF, and PF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
NOP - No Operation
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 90 | NOP | X | X | X | X | X | X | No operation | 
- Description
The NOP instruction performs no operation. The NOP instruction is a one- byte instruction that takes up space but affects none of the machine context except the (E)IP register. The NOP instruction is an alias mnemonic for the XCHG (E)AX, (E)AX instruction.
NOT - One's Complement Negation
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F6 /2 | NOT r/m8 | X | X | X | X | X | X | Reverse each bit of r/m byte | 
| F7 /2 | NOT r/m16 | X | X | X | X | X | X | Reverse each bit of r/m word | 
| F7 /2 | NOT r/m32 | X | X | X | Reverse each bit of r/m dword | 
- Description
The NOT instruction inverts the operand; every 1 becomes a 0, and vice versa.
- Operation
r/m ← NOT r/m
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
OR-Logical Inclusive OR
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0C ib | OR AL,imm8 | X | X | X | X | X | X | OR immediate byte to AL | 
| 0D iw | OR AX,imm16 | X | X | X | X | X | X | OR immediate word to AX | 
| 0D id | OR EAX,imm32 | X | X | X | OR immediate dword to EAX | |||
| 80 /1 ib | OR r/m8,imm8 | X | X | X | X | X | X | OR immediate byte to r/m byte | 
| 81 /1 iw | OR r/m16,imm16 | X | X | X | X | X | X | OR immediate word to r/m word | 
| 81 /1 id | OR r/m32,imm32 | X | X | X | OR immediate dword to r/m dword | |||
| 83 /1 ib | OR r/m16,imm8 | X | X | X | OR sign-extended immediate byte with r/m word | |||
| 81 /1 ib | OR r/m32,imm8 | X | X | X | OR sign-extended immediate byte with r/m dword | |||
| 08 /r | OR r/m8,r8 | X | X | X | X | X | X | OR byte register to r/m byte | 
| 09 /r | OR r/m16,r16 | X | X | X | X | X | X | OR word register to r/m word | 
| 09 /r | OR r/m32,r32 | X | X | X | OR dword register to r/m dword | |||
| 0A /r | OR r8,r/m8 | X | X | X | X | X | X | OR byte register to r/m byte | 
| 0B /r | OR r16,r/m16 | X | X | X | X | X | X | OR word register to r/m word | 
| 0B /r | OR r32,r/m32 | X | X | X | OR dword register to r/m dword | 
- Description
The OR instruction computes the inclusive OR of its two operands and places the result in the first operand. Each bit of the result if 0 if both corresponding bits of the operands are 0; otherwise, each bit is 1.
- Operation
DEST ← DEST OR SRC; CF ← 0; OF ← 0
- Flags Affected
OF|DF|IF|SF|ZF|AF|PF|CF --+--+--+--+--+--+--+-- 0 | | |* |* |? |* |0
The OF and CF flags are cleared; the SF, ZF, and PF flags are set according to the result; the AF flag is undefined.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
OUT - Output to Port
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| E6 ib | OUT imm8,AL | X | X | X | X | X | X | Output byte from AL to port imm8 | 
| E7 ib | OUT imm8,AX | X | X | X | X | X | X | Output word from AX to port imm8 | 
| E7 ib | OUT imm8,EAX | X | X | X | Output dword from EAX to port imm8 | |||
| EE | OUT DX,AL | X | X | X | X | X | X | Output byte from AL to port number in DX | 
| EF | OUT DX,AX | X | X | X | X | X | X | Output word from AX to port number in DX | 
| EF | OUT DX,EAX | X | X | X | Output dword from EAX to port number in DX | 
- Description
The OUT instruction transfers a data byte or data word from the register (AL, AX, or EAX) given as the second operand to the output port numbered by the first operand. Output to any port from 0 to 65535 is performed by placing the port number in the DX register and then using an OUT instruction with the DX register as the first operand. If the instruction contains an eight-bit port ID, that value is zero-extended to 16-bits.
- Operation
IF (PE = 1) AND ((VM = 1) OR (CPL > IOPL)) THEN (* Virtual 8086 mode, or protected mode with CPL > IOPL *) IF NOT I-O-Permission (DEST, width(DEST)) THEN #GP(0); FI; FI; [DEST] ← SRC; (* I/O address space used *)
- Protected Mode Exceptions
- GP(0) if the current privilege level is higher (has less privilege) than the I/O privilege level and any of the corresponding I/O permission bits in the TSS equals 1.
- Virtual 8086 Mode Exceptions
- GP(0) fault if any of the corresponding I/O permission bits in the TSS equals 1.
- Notes
After the OUT or OUTS instructions are run, the Pentium processor ensures that the EWBE# has been sampled active before beginning to run the next instruction. Note that the instruction may be prefetched if EWBE# is not active, but it will not run until EWBE# is sampled active.
OUTS/OUTSB/OUTSW/OUTSD - Output String to Port
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 6E | OUTS DX,r/m8 | X | X | X | X | X | Output byte [(E)SI] to port in DX | |
| 6F | OUTS DX,r/m16 | X | X | X | X | X | Output word [(E)SI] to port in DX | |
| 6F | OUTS DX,r/m32 | X | X | X | Output dword [(E)SI] to port in DX | |||
| 6E | OUTSB | X | X | X | X | X | Output byte [DS:(E)SI] to port in DX | |
| 6F | OUTSW | X | X | X | X | X | Output word [DS:(E)SI] to port in DX | |
| 6F | OUTSD | X | X | X | Output dword [DS:(E)SI] to port in DX | 
- Description
The OUTS instruction transfers data from the memory byte, word, or doubleword at the source-index register to the output port addressed by the DX register. If the address-size attribute for this instruction is 16-bits, the SI register is used for the source-index register; otherwise, the address-size attribute is 32-bits, and the ESI register is used for the source-index register. The OUTS instruction does not allow specification of the port number as an immediate value. The port must be addressed through the DX register value. Load the correct value into the DX register before running the OUTS instruction. The address of the source data is determined by the contents of source- index register. Load the correct index value into the SI or ESI register before running the OUTS instruction. After the transfer, source-index register is advanced automatically. If the DF flag is 0 (the CLD instruction was run), the source-index register is incremented; if the DF flag is 1 (the STD instruction was run), it is decremented. The amount of the increment or decrement is 1 if a byte is output, 2 if a word is output, or 4 if a doubleword is output. The OUTSB, OUTSW, and OUTSD instructions are synonyms for the byte, word, and doubleword OUTS instructions. The OUTS instruction can be preceded by the REP prefix for block output of ECX bytes or words. Refer to the REP instruction for details on this operation.
- Operation
IF AddressSize = 16 THEN use SI for source-index; ELSE (* AddressSize = 32 *) use ESI for source-index; FI; IF (PE = 1) AND ((VM = 1) OR (CPL > IOPL)) THEN (* Virtual 8086 mode, or protected mode with CPL > IOPL *) IF NOT I-O-Permission (DEST, width(DEST)) THEN #GP(0); FI; FI; IF byte type of instruction THEN [DX] ← [source-index]; (* Write byte at DX I/O address *) IF DF = 0 THEN IncDec ← 1 ELSE IncDec ← -1; FI; FI; IF OperandSize = 16 THEN [DX] ← [source-index]; (* Write word at DX I/O address *) IF DF = 0 THEN IncDec ← 2 ELSE IncDec ← -2; FI; FI; IF OperandSize = 32 THEN [DX] ← [source-index]; (* Write dword at DX I/O address *) IF DF = THEN IncDec ← 4 ELSE IncDec ← -4; FI; FI; FI; source-index ← source-index + IncDec;
- Protected Mode Exceptions
- #GP(0) if the current privilege level is greater than the I/O privilege level and any of the corresponding I/O permission bits in TSS equals 1; #GP (0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault- code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
- GP(0) fault if any of the corresponding I/O permission bits in TSS equals 1; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
After the OUT or OUTS instructions are run, the Pentium processor ensures that the EWBE# has been sampled active before beginning to run the next instruction. Note that the instruction may be prefetched if EWBE# is not active, but it will not run until EWBE# is sampled active.
POP - Pop a Word from the Stack
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 58+rw | POP r16 | X | X | X | X | X | X | Pop top of stack into word register | 
| 58+rd | POP r32 | X | X | X | Pop top of stack into dword register | |||
| 8F /0 | POP m16 | X | X | X | X | X | X | Pop top of stack into memory word | 
| 8F /0 | POP m32 | X | X | X | Pop top of stack into memory dword | |||
| 1F | POP DS | X | X | X | X | X | X | Pop top of stack into DS | 
| 07 | POP ES | X | X | X | X | X | X | Pop top of stack into ES | 
| 0F A1 | POP FS | X | X | X | Pop top of stack into FS | |||
| 0F A9 | POP GS | X | X | X | Pop top of stack into GS | |||
| 17 | POP SS | X | X | X | X | X | X | Pop top of stack into SS | 
- Description
The POP instruction replaces the previous contents of the memory, the register, or the segment register operand with the word on the top of the processor stack, addressed by SS:SP (address-size attribute of 16 bits) or SS:ESP (address-size attribute of 32 bits). The stack pointer SP is incremented by 2 for an operand-size of 16 bits or by 4 for an operand-size of 32 bits. It then points to the new top of stack. The POP CS instruction is not a processor instruction. Popping from the stack into the CS register is accomplished with a RET instruction. If the destination operand is a segment register (DS, ES, FS, GS, or SS), the value popped must be a selector. In protected mode, loading the selector initiates automatic loading of the descriptor information associated with that selector into the hidden part of the segment register; loading also initiates validation of both the selector and the descriptor information. A null value (0000-0003) may be popped into the DS, ES, FS, or GS register without causing a protection exception. An attempt to reference a segment whose corresponding segment register is loaded with a null value causes a # GP(0) exception. No memory reference occurs. The saved value of the segment register is null. A POP SS instruction inhibits all interrupts, including NMI, until after processing of the next instruction. This allows sequential processing of POP SS and MOV eSP, eBP instructions without danger of having an invalid stack during an interrupt. However, use of the LSS instruction is the preferred method of loading the SS and eSP registers. A POP-to-memory instruction, which uses the stack pointer (ESP) as a base register, references memory after the POP. The base used is the value of the ESP after the instruction runs. Loading a segment register while in protected mode results in special checks and actions, as described in the following listing:
IF SS is loaded:
   IF selector is null THEN #GP(0);
   Selector index must be within its descriptor table limits ELSE 
      #GP(selector);
   Selector's RPL must equal CPL ELSE #GP(selector);
   AR byte must indicate a writable data segment ELSE #GP(selector);
   DPL in the AR byte must equal CPL ELSE #GP(selector);
   Segment must be marked present ELSE #SS(selector);
   Load SS register with selector;
   Load SS register with descriptor;
IF DS, ES, FS or GS is loaded with non-null selector:
   AR byte must indicate data or readable code segment ELSE 
      #GP(selector);
   IF data or nonconforming code 
   THEN both the RPL and the CPL must be less than or equal to DPL in 
   AR byte 
   ELSE #GP(selector);
   FI;
   Segment must be marked present ELSE #NP(selector);
   Load segment register with selector;
   Load segment register with descriptor;
IF DS, ES, FS, or GS is loaded with a null selector:
   Load segment register with selector 
   Clear valid bit in invisible portion of register 
- Operation
IF StackAddrSize = 16 
THEN 
   IF OperandSize = 16 
   THEN
      DEST ← (SS:SP); (* copy a word *)
      SP ← SP + 2;
   ELSE (* OperandSize = 32 *)
      DEST ← (SS:SP); (* copy a dword *)
      SP ← SP + 4;
   FI;
ELSE (* StackAddrSize = 32 *)
   IF OperandSize = 16 
   THEN
      DEST ← (SS:ESP); (* copy a word *)
      ESP ← ESP + 2;
   ELSE (* OperandSize = 32 *)
      DEST ← (SS:ESP); (* copy a dword *)
      ESP ← ESP + 4;
   FI;
FI;
- Protected Mode Exceptions
- GP, #SS, and #NP if a segment register is being loaded, #SS(0) if the current top of stack is not within the stack segment; #GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
Back-to-back PUSH/POP instruction sequences are allowed without incurring an additional clock. The stack segment descriptor's B bit will determine the size of Stack Addr Size. Pop ESP instructions increments the stack pointer (ESP) before data at the old top of stack is written into the destination.
POPA/POPAD-Pop all General Registers
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 61 | POPA | X | X | X | X | X | Pop DI, SI, BP, BX, DX, CX, and AX | |
| 61 | POPAD | X | X | X | Pop EDI, ESI, EBP, EBX, EDX, ECX, and EAX | 
- Description
The POPA instruction pops the eight 16-bit general registers. However, the SP value is discarded instead of loaded into the SP register. The POPA instruction reverses a previous PUSHA instruction, restoring the general registers to their values before the PUSHA instruction was run. The first register popped is the DI register. The POPAD instruction pops the eight 32-bit general registers. The ESP value is discarded instead of loaded into the ESP register. The POPAD instruction reverses the previous PUSHAD instruction, restoring the general registers to their values before the PUSHAD instruction was run. The first register popped is the EDI register.
- Operation
IF OperandSize = 16 (* instruction = POPA *) THEN DI ← Pop(); SI ← Pop(); BP ← Pop(); increment SP by 2 (* skip next 2 bytes of stack *) BX ← Pop(); DX ← Pop(); CX ← Pop(); AX ← Pop(); ELSE (* OperandSize = 32, instruction = POPAD *) EDI ← Pop(); ESI ← Pop(); EBP ← Pop(); increment SP by 4 (* skip next 4 bytes of stack *) EBX ← Pop(); EDX ← Pop(); ECX ← Pop(); EAX ← Pop(); FI;
- Protected Mode Exceptions
- SS(0) if the starting or ending stack address is not within the stack segment; #PF(fault-code) for a page fault.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF(fault-code) for a page fault.
POPF/POPFD - Pop Stack into FLAGS or EFLAGS Register
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9D | POPF | X | X | X | X | X | X | Pop top of stack into FLAGS | 
| 9D | POPFD | X | X | X | Pop top of stack into EFLAGS | 
- Description
The POPF and POPFD instructions pop the word or doubleword on the top of the stack and store the value in the FLAGS register. If the operand-size attribute of the instruction is 16 bits, then a word is popped and the value is stored in the FLAGS register. If the operand-size attribute is 32 bits, then a doubleword is popped and the value is stored in the EFLAGS register. When the IOPL is less than 3 in virtual-8086 mode, the POPF instruction causes a general protection exception. When the IOPL is equal to 3 while running in virtual-8086 mode, POPF pops a word into the FLAGS register. Refer to the Intel documentation for information about the FLAGS and EFLAGS registers. Note that bits 16 and 17 of the EFLAGS register, called the VM and RF flags, respectively, are not affected by the POPF or POPFD instruction. The I/O privilege level is altered only when running at privilege level 0. The interrupt flag is altered only when running at a level at least as privileged as the I/O privilege level. (Real-address mode is equivalent to privilege level 0.) If a POPF instruction is run with insufficient privilege, an exception does not occur, but the privileged bits do not change.
- Operation
IF VM=0 (* Not in Virtual-8086 Mode *)
THEN 
   IF OperandSize=32;
   THEN EFLAGS ← Pop() AND 277FD7H;
   ELSE FLAGE ← Pop();
   FI;
ELSE (* In Virtual-8086 Mode *)
   IF IOPL=3
   THEN
      IF OperandSize=32
      THEN 
         TempEflags ← Pop();
         EFLAGS ← ((EFLAGS AND 1B3000H) OR (TempEflags AND ~ 1B3000H))
                            (* VM, RF, IOPL, VIP, and VIF of EGLAGS bits are 
                               not modified by POPFD *)
      ELSE 
        FLAGS ← Pop()
      FI;
   ELSE
      #GP(0); (* trap to virtual-8086 monitor *)
   FI;
FI;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- |* |* |* |* |* |* |* |*
All flags except the VM, RF, IOPL, VIF and VIP flags.
- Protected Mode Exceptions
- SS(0) if the top of stack is not within the stack segment.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
- GP(0) fault if the I/O privilege level is less than 3 in order to permit emulation. #GP(0) if an attempt is made to run POPF with an operand-size override prefix.
PUSH - Push Operand onto the Stack
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 50+rw | PUSH r16 | X | X | X | X | X | X | Push register word | 
| 50+rd | PUSH r32 | X | X | X | Push register dword | |||
| FF /6 | PUSH m16 | X | X | X | X | X | X | Push memory word | 
| FF /6 | PUSH m32 | X | X | X | Push memory dword | |||
| 6A | PUSH imm8 | X | X | X | X | X | Push immediate byte | |
| 68 | PUSH imm16 | X | X | X | X | X | Push immediate word | |
| 68 | PUSH imm32 | X | X | X | Push immediate dword | |||
| 0E | PUSH CS | X | X | X | X | X | X | Push CS | 
| 1E | PUSH DS | X | X | X | X | X | X | Push DS | 
| 06 | PUSH ES | X | X | X | X | X | X | Push ES | 
| 0F A0 | PUSH FS | X | X | X | Push FS | |||
| 0F A8 | PUSH GS | X | X | X | Push GS | |||
| 16 | PUSH SS | X | X | X | X | X | X | Push SS | 
- Description
The PUSH instruction decrements the stack pointer by 2 if the operand-size attribute of the instruction is 16 bits; otherwise, it decrements the stack pointer by 4. The PUSH instruction then places the operand on the new top of stack, which is pointed to by the stack pointer. The PUSH ESP instruction pushes the value of the ESP register as it existed before the instruction. This differs from the 8086, where the PUSH SP instruction pushes the new value (decremented by 2). Likewise, a PUSH-from-memory instruction, which uses the stack pointer (ESP ) as a base register, references memory before the PUSH. The base used is the value of the ESP before the instruction runs.
- Operation
IF StackAddrSize = 16 
THEN 
   IF OperandSize = 16 THEN 
      SP ← SP - 2;
      (SS:SP) ← (SOURCE); (* word assignment *)
   ELSE
      SP ← SP - 4;
      (SS:SP) ← (SOURCE); (* dword assignment *)
   FI;
ELSE (* StackAddrSize = 32 *)
   IF OperandSize = 16 
   THEN
      ESP ← ESP -2;
      (SS:ESP) ← (SOURCE); (* word assignment *)
   ELSE
      ESP ← ESP -4;
      (SS:ESP) ← (SOURCE); (* dword assignment *)
  FI;
FI;
- Protected Mode Exceptions
- SS(0) if the new value of the SP or ESP register is outside the stack segment limit; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
None; if the SO or ESP register is 1, the processor shuts down due to a lack of stack space.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
When used with an operand in memory, the PUSH instruction takes longer to run than a two-instruction sequence, which moves the operand through a register. Back-to-back PUSH/POP instruction sequences are allowed without incurring an additional clock. Selective pushes write only the top of the stack.
PUSHA/PUSHAD - Push all General Registers
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 60 | PUSHA | X | X | X | X | Push AX, CX, DX, BX, SP, BP, SI, and DI | ||
| 60 | PUSHAD | X | X | X | Push EAX, ECX, EDX, EBX, ESP, EBP, ESI, and EDI | 
- Description
The PUSHA and PUSHAD instructions save the 16-bit or 32-bit general registers, respectively, on the processor stack. The PUSHA instruction decrements the stack pointer (SP) by 16 to hold the eight word values. The PUSHAD instruction decrements the stack pointer (ESP) by 32 to hold the eight doubleword values. Because the registers are pushed onto the stack in the order in which they were given, they appear in the 16 or 32 new stack bytes in reverse order. The last register pushed is the DI or EDI register.
- Operation
IF OperandSize = 16 (* PUSHA instruction *) THEN Temp ← (SP); Push(AX); Push(CX); Push(DX); Push(BX); Push(Temp); Push(BP); Push(SI); Push(DI); ELSE (* OperandSize = 31, PUSHAD instruction *) Temp ← (ESP); Push(EAX); Push(ECX); Push(EDX); Push(EBX); Push(Temp); Push(EPS); Push(ESI); Push(EDI); FI;
- Protected Mode Exceptions
- SS(0) if the starting or ending stack address is outside the stack segment limit; #PF(fault-code) for a page fault.
- Real Address Mode Exceptions
Before running the PUSHA or PUSHAD instruction, the Pentium processor shuts down if the SP or ESP register equals 1, 3, or 5; if the SP or ESP register equals 7, 9, 11, 13, or 15, exception 13 occurs.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF(fault-code) for a page fault.
PUSHF/PUSHFD-Push Flags Register onto the Stack
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9C | PUSHF | X | X | X | X | X | X | Push FLAGS | 
| 9C | PUSHFD | X | X | X | Push EFLAGS | 
- Description
The PUSHF instruction decrements the stack pointer by 2 and copies the FLAGS register to the new top of stack; the PUSHFD instruction decrements the stack pointer by 4, and the EFLAGS register is copied to the new top of stack, which is pointed to by SS:ESP. Refer to the Intel documentation for information on the EFLAGS register.
- Operation
IF VM=0 (* Not in Virtual-8086 Mode *)
THEN 
   IF OperandSize = 32 
   THEN push(EFLAGS AND 0FCFFFFH); (* VM and RF EFLAG bits are cleared *)
   ELSE push(FLAGS);
   FI;
ELSE (* In Virtual-8086 Mode *)
   IF IOPL=3
   THEN
      IF OperandSize = 32 
      THEN push(EFLAGS AND 0FCFFFFH); (* VM and RF EFLAGS bits are cleared *)
      ELSE push(FLAGS);
      FI;
   ELSE
      #GP(0); (* Trap to virtual-8086 monitor *)
   FI;
FI;
- Protected Mode Exceptions
- SS(0) if the new value of the ESP register is outside the stack segment boundaries.
- Real Address Mode Exceptions
None; the processor shuts down due to a lack of stack space.
- Virtual 8086 Mode Exceptions
- GP(0) fault if the I/O privilege level is less than 3, to permit emulation.
RCL/RCR/ROL/ROR - Rotate
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D0 /2 | RCL r/m8,1 | X | X | X | X | X | X | Rotate 9 bits (CF, r/m byte) left once | 
| D2 /2 | RCL r/m8,CL | X | X | X | X | X | X | Rotate 9 bits (CF, r/m byte) left CL times | 
| C0 /2 ib | RCL r/m8,imm8 | X | X | X | X | X | Rotate 9 bits (CF, r/m byte) left imm8 times | |
| D1 /2 | RCL r/m16,1 | X | X | X | X | X | X | Rotate 17 bits (CF, r/m word) left once | 
| D3 /2 | RCL r/m16,CL | X | X | X | X | X | X | Rotate 17 bits (CF, r/m word) left CL times | 
| C1 /2 ib | RCL r/m16,imm8 | X | X | X | X | X | Rotate 17 bits (CF, r/m word) left imm8 times | |
| D1 /2 | RCL r/m32,1 | X | X | X | Rotate 33 bits (CF, r/m dword) left once | |||
| D3 /2 | RCL r/m32,CL | X | X | X | Rotate 33 bits (CF, r/m dword) left CL times | |||
| C1 /2 ib | RCL r/m32,imm8 | X | X | X | Rotate 33 bits (CF, r/m dword) left imm8 times | |||
| D0 /3 | RCR r/m8,1 | X | X | X | X | X | X | Rotate 9 bits (CF, r/m byte) right once | 
| D2 /3 | RCR r/m8,CL | X | X | X | X | X | X | Rotate 9 bits (CF, r/m byte) right CL times | 
| C0 /3 ib | RCR r/m8,imm8 | X | X | X | X | X | Rotate 9 bits (CF, r/m byte) right imm8 times | |
| D1 /3 | RCR r/m16,1 | X | X | X | X | X | X | Rotate 17 bits (CF, r/m word) right once | 
| D3 /3 | RCR r/m16,CL | X | X | X | X | X | X | Rotate 17 bits (CF, r/m word) right CL times | 
| C1 /3 ib | RCR r/m16,imm8 | X | X | X | X | X | Rotate 17 bits (CF, r/m word) right imm8 times | |
| D1 /3 | RCR r/m32,1 | X | X | X | Rotate 33 bits (CF, r/m dword) right once | |||
| D3 /3 | RCR r/m32,CL | X | X | X | Rotate 33 bits (CF, r/m dword) right CL times | |||
| C1 /3 ib | RCR r/m32,imm8 | X | X | X | Rotate 33 bits (CF, r/m dword) right imm8 times | |||
| D0 /0 | ROL r/m8,1 | X | X | X | X | X | X | Rotate 8 bits (r/m byte) left once | 
| D2 /0 | ROL r/m8,CL | X | X | X | X | X | X | Rotate 8 bits (r/m byte) left CL times | 
| C0 /0 ib | ROL r/m8,imm8 | X | X | X | X | X | Rotate 8 bits (r/m byte) left imm8 times | |
| D1 /0 | ROL r/m16,1 | X | X | X | X | X | X | Rotate 16 bits (r/m word) left once | 
| D3 /0 | ROL r/m16,CL | X | X | X | X | X | X | Rotate 16 bits (r/m word) left CL times | 
| C1 /0 ib | ROL r/m16,imm8 | X | X | X | X | X | Rotate 16 bits (r/m word) left imm8 times | |
| D1 /0 | ROL r/m32,1 | X | X | X | Rotate 32 bits (r/m dword) left once | |||
| D3 /0 | ROL r/m32,CL | X | X | X | Rotate 32 bits (r/m dword) left CL times | |||
| C1 /0 ib | ROL r/m32,imm8 | X | X | X | Rotate 32 bits (r/m dword) left imm8 times | |||
| D0 /1 | ROR r/m8,1 | X | X | X | X | X | X | Rotate 8 bits (r/m byte) right once | 
| D2 /1 | ROR r/m8,CL | X | X | X | X | X | X | Rotate 8 bits (r/m byte) right CL times | 
| C0 /1 ib | ROR r/m8,imm8 | X | X | X | X | X | Rotate 8 bits (r/m byte) right imm8 times | |
| D1 /1 | ROR r/m16,1 | X | X | X | X | X | X | Rotate 16 bits (r/m word) right once | 
| D3 /1 | ROR r/m16,CL | X | X | X | X | X | X | Rotate 16 bits (r/m word) right CL times | 
| C1 /1 ib | ROR r/m16,imm8 | X | X | X | X | X | Rotate 16 bits (r/m word) right imm8 times | |
| D1 /1 | ROR r/m32,1 | X | X | X | Rotate 32 bits (r/m dword) right once | |||
| D3 /1 | ROR r/m32,CL | X | X | X | Rotate 32 bits (r/m dword) right CL times | |||
| C1 /1 ib | ROR r/m32,imm8 | X | X | X | Rotate 32 bits (r/m dword) right imm8 times | 
- Description
Each rotate instruction shifts the bits of the register or memory operand given. The left rotate instructions shift all the bits upward, except for the top bit, which is returned to the bottom. The right rotate instructions do the reverse: the bits shift downward until the bottom bit arrives at the top. For the RCL and RCR instructions, the CF flag is part of the rotated quantity. The RCL instruction shifts the CF flag into the bottom bit and shifts the top bit into the CF flag; the RCR instruction shifts the CF flag into the top bit and shifts the bottom bit into the CF flag. For the ROL and ROR instructions, the original value of the CF flag is not a part of the result, but the CF flag receives a copy of the bit that was shifted from one end to the other. The rotate is repeated the number of times indicated by the second operand, which is either an immediate number or the contents of the CL register. To reduce the maximum instruction processing time, the Pentium processor does not allow rotation counts greater than 31. If a rotation count greater than 31 is attempted, only the bottom five bits of the rotation are used. The 8086 does not mask rotation counts. The Pentium processor in Virtual 8086 Mode does mask rotation counts. The OF flags is defined only for the single-rotate forms of the instructions (second operand is a 1). It is undefined in all other cases. For left shifts/rotates, the CF bit after the shift is XORed with the high- order result bit. For right shifts/rotates, the high-order two bits of the result are XORed to get the OF flag.
- Operation
(* ROL - Rotate Left *) temp ← COUNT; WHILE (temp <> 0) DO
tmpcf ← high-order bit of (r/m); r/m ← r/m * 2 + (tmpcf); temp ← temp - 1;
OD; IF COUNT = 1 THEN
IF high-order bit of r/m <> CF THEN OF ← 1; ELSE OF ← 0; FI;
ELSE OF ← undefined; FI; (* ROR - Rotate Right *) temp ← COUNT; WHILE (temp <> 0) DO
tmpcf ← low-order bit of (r/m); r/m ← r/m / 2 + (tmpcf * 2widty(r/m)); temp ← temp - 1;
DO; IF COUNT = 1 THEN
IF (high-order bit of r/m) <> (bit next to high-order bit of r/m) THEN OF ← 1; ELSE OF ← 0; FI;
ELSE OF ← undefined; FI;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- |* | | | | | | |*
The OF flag is affected only for single-bit rotates; the OF flag is undefined for multi-bit rotates; the CF flag contains the value of the bit shifted into it; the SF, ZF, AF, and PF flags are not affected.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
RDMSR - Read from Model Specific Register
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 32 | RDMSR | X | Read Model Specific Register indicated by ECX into EDX:EAX | 
- Description
The value in ECX specifies one of the 64-bit Model Specific Registers of the Pentium processor. The content of that Model-Specific Register is copied into EDX:EAX. EDX is loaded with the high-order 32 bits, and EAX is loaded with the low-order 32 bits. The following values are used to select model specific registers on the Pentium processor.
| VALUE | REGISTER NAME | DESCRIPTION | 
|---|---|---|
| 00H | Machine Check Address | Stores address of cycle causing the exception | 
| 01H | Machine Check Type | Stores type of cycle causing the exception | 
For other values used to perform cache, TLB, and BTB testing and performance monitoring, see the Intel documentation.
- Operation
EDX:EAX ← MSR[ECX];
- Protected Mode Exceptions
- GP(0) if either the current privilege level is not 0 or the value in ECX does not specify a Model-Specific Register that is implemented in the Pentium processor.
- Real Address Mode Exceptions
- GP if the value in ECX does not specify a Model-Specific Register that is implemented in the Pentium processor.
- Virtual 8086 Mode Exceptions
- GP(0) if instruction processing is attempted.
- Notes
This instruction must be run at privilege level 0 or in real-address mode; otherwise, a protection exception will be generated. If less than 64 bits are implemented in a model specific register, the value returned to EDX:EAX, in the locations corresponding to the unimplemented bits, is unpredictable. RDMSR is used to read the content of Model-Specific Registers that control functions for testability, execution tracing, performance monitoring and machine check errors. Refer to the Pentium(TM) Processor Data Book for more information. The values 3H, 0FH, and values above 13H are reserved. Do not run RDMSR with reserved values in ECX.
RDTSC - Read Time Stamp Counter
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 31 | RDTSC | X | Read Time Stamp Counter int EDX:EAX | 
- Description
- Operation
- Protected Mode Exceptions
- Real Address Mode Exceptions
- Virtual 8086 Mode Exceptions
REP/REPE/REPZ/REPNE/REPNZ - Repeat Following String Operation
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| F3 6C | REP INS r/m8,DX | X | X | X | X | X | Input (E)CX bytes from port DX into ES:[(E)DI] | |
| F3 6D | REP INS r/m16,DX | X | X | X | X | X | Input (E)CX words from port DX into ES:[(E)DI] | |
| F3 6D | REP INS r/m32,DX | X | X | X | Input (E)CX dwords from port DX into ES:[(E)DI] | |||
| F3 AC | REP LODS AL | X | X | X | X | X | X | Load (E)CX bytes from [(E)SI] to EDX | 
| F3 AD | REP LODS AX | X | X | X | X | X | X | Load (E)CX words from [(E)SI] to EDX | 
| F3 AD | REP LODS EAX | X | X | X | Load (E)CX dwords from [(E)SI] to EDX | |||
| F3 A4 | REP MOVS m8,m8 | X | X | X | X | X | X | Move (E)CX bytes from [(E)SI] to ES:[(E)DI] | 
| F3 A5 | REP MOVS m16,m16 | X | X | X | X | X | X | Move (E)CX words from [(E)SI] to ES:[(E)DI] | 
| F3 A5 | REP MOVS m32,m32 | X | X | X | Move (E)CX dwords from [(E)SI] to ES:[(E)DI] | |||
| F3 6E | REP OUTS DX,r/m8 | X | X | X | X | X | Output (E)CX bytes from [(E)SI] to port DX | |
| F3 6F | REP OUTS DX,r/m16 | X | X | X | X | X | Output (E)CX words from [(E)SI] to port DX | |
| F3 6F | REP OUTS DX,r/m32 | X | X | X | Output (E)CX dwords from [(E)SI] to port DX | |||
| F3 AA | REP STOS m8 | X | X | X | X | X | X | Store (E)CX bytes at ES:[(E)DI] from AL | 
| F3 AB | REP STOS m16 | X | X | X | X | X | X | Store (E)CX words at ES:[(E)DI] from AX | 
| F3 AB | REP STOS m32 | X | X | X | Store (E)CX dwords at ES:[(E)DI] from EAX | |||
| F3 A6 | REPE CMPS m8,m8 | X | X | X | X | X | X | Find nonmatching bytes in ES:[(E)DI] and [(E)SI] | 
| F3 A7 | REPE CMPS m16,m16 | X | X | X | X | X | X | Find nonmatching words in ES:[(E)DI] and [(E)SI] | 
| F3 A7 | REPE CMPS m32,m32 | X | X | X | Find nonmatching dwords in ES:[(E)DI] and [(E)SI] | |||
| F3 AE | REPE SCAS m8,m8 | X | X | X | X | X | X | Find non-AL byte starting at ES:[(E)DI] | 
| F3 AF | REPE SCAS m16,m16 | X | X | X | X | X | X | Find non-AX word starting at ES:[(E)DI] | 
| F3 AF | REPE SCAS m32,m32 | X | X | X | Find non-EAX dword starting at ES:[(E)DI] | |||
| F2 A6 | REPNE CMPS m8,m8 | X | X | X | X | X | X | Find matching bytes in ES:[(E)DI] and [(E)SI] | 
| F2 A7 | REPNE CMPS m16,m16 | X | X | X | X | X | X | Find matching words in ES:[(E)DI] and [(E)SI] | 
| F2 A7 | REPNE CMPS m32,m32 | X | X | X | Find matching dwords in ES:[(E)DI] and [(E)SI] | |||
| F2 AE | REPNE SCAS m8,m8 | X | X | X | X | X | X | Find AL, starting at ES:[(E)DI] | 
| F2 AF | REPNE SCAS m16,m16 | X | X | X | X | X | X | Find AX, starting at ES:[(E)DI] | 
| F2 AF | REPNE SCAS m32,m32 | X | X | X | Find EAX, starting at ES:[(E)DI] | 
- Description
The REP, REPE (repeat while equal), and REPNE (repeat while not equal) prefixes are applied to string operation. Each prefix causes the string instruction that follows to be repeated the number of times indicated in the count register or (for the REPE and REPNE prefixes) until the indicated condition in the ZF flag is no longer met. Synonymous forms of the REPE and REPNE prefixes are the REPZ and REPNZ prefixes, respectively. The REP prefixes apply only to one string instruction at a time. To repeat a block of instructions, use the LOOP instruction or another looping construct. The precise action for each iteration is as follows:
- If the address-size attribute is 16 bits, use the CX register for the count register; if the address-size attribute is 32 bits, use the ECX register for the count register.
- Check the count register. If it is zero, exit the iteration, and move to the next instruction.
- Acknowledge any pending interrupts.
- Perform the string operation once.
- Decrement the CX or count register by one; no flags are modified.
- Check the ZF flag is the string operation is a SCAS or CMPS instruction. If the repeat condition does not hold, exit the iteration and move to the next instruction. Exit the iteration if the prefix if REPE and the ZF flag is 0 (the last comparison was not equal), or if the prefix is REPNE and the ZF flag is one (the last comparison was equal).
- Return to step 2 for the next iteration.
Repeated CMPS and SCAS instructions can be exited if the count is exhausted or if the ZF flag fails the repeat condition. These two cases can be distinguished by using either the JCXZ instruction, or by using the conditional jumps that test the ZF flag (the JZ, JNZ, and JNE instructions).
- Operation
IF AddressSize = 16 
THEN use CX for CountReg;
ELSE (* AddressSize = 32 *) use ECX for CountReg;
FI;
WHILE CountReg <> 0 
DO 
  service pending interrupts (if any);
  perform primitive string instruction;
  CountReg ← CountReg -1;
  IF primitive operation is CMPSB, CMPSW, CMPSD, SCASB,
  SCASW, or SCASD 
  THEN
     IF (instruction is REP/REPE/REPZ) AND (ZF=0)
     THEN exit WHILE loop 
     ELSE 
        IF (instruction if REPNZ or REPNE) AND (ZF=1)
        THEN exit WHILE loop;
        FI;
     FI;
 FO;
OD;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| | | | | |* | | | |
The ZF flag is affected by the REP CMPS and REP SCAS as described above.
- Notes
Not all I/O ports can handle the rate at which the REP INS and REP OUTS instructions run. Do not use the REP prefix with the LOOP instruction. Proper LOOP operation is not guaranteed when used with the REP prefix and the effect of this combination is unpredictable. The behavior of the REP prefix is undefined when used with non-string instructions. When a page fault occurs during CMPS or SCAS instructions that are prefixed with REPNE, the EFLAGS value is restored to the state prior to the processing of the instruction. Because SCAS and CMPS do not use EFLAGS as an input, the processor can resume the instruction after the page fault handler.
RET - Return from Procedure
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| C3 | RET/RETN | X | X | X | X | X | X | Return (near) to caller | 
| CB | RET/RETF | X | X | X | X | X | X | Return (far) to caller, same privilege | 
| CB | RET/RETF | X | X | X | X | Return (far), lesser privilege, switch stacks | ||
| C2 iw | RET/RETN imm16 | X | X | X | X | X | X | Return (near), pop imm16 bytes | 
| CA iw | RET/RETF imm16 | X | X | X | X | X | X | Return (far), same privilege, pop imm16 bytes | 
| CA iw | RET/RETF imm16 | X | X | X | X | Return (far), lesser privilege, pop imm16 bytes | 
- Description
The RET instruction transfers control to a return address located on the stack. The address is usually placed on the stack by a CALL instruction, and the return is made to the instruction that follows the CALL instruction. The optional numeric parameter to the RET instruction gives the number of stack bytes (OperandMode=16) or words (OperandMode=32) to be released after the return address is popped. These items are typically used as input parameters to the procedure called. For the intrasegment (near) return, the address on the stack is a segment offset, which is popped into the instruction pointer. The CS register is unchanged. For the intersegment (far) return, the address on the stack is a long pointer. The offset is popped first, followed by the selector. In real mode, the CS and IP registers are loaded directly. In Protected Mode, an intersegment return causes the processor to check the descriptor addressed by the return selector. The AR byte of the descriptor must indicate a code segment of equal or lesser privilege (or greater or equal numeric value) than the current privilege level. Returns to a lesser privilege level cause the stack to be reloaded from the value saved beyond the parameter block. The DS, ES, FS, and GS segment registers can be cleared by the RET instruction during an interlevel transfer. If there registers refer to segments that cannot be used by the new privilege level, they are cleared to prevent unauthorized access from the new privilege level.
- Operation
IF instruction = near RET 
THEN;
  IF OperandSize = 16 
  THEN
     IP ← Pop();
     EIP ← EIP AND 0000FFFFH;
  ELSE (* OperandSize = 32 *)
     EIP ← Pop();
 FI;
 IF instruction has immediate operand THEN eSP ← eSP + imm16; FI;
 FI;
IF (PE = 0 OR (PE = 1 AND VM = 1))
  (* real mode or virtual 8086 mode *)
  AND instruction = far RET 
THEN;
  IF OperandSize = 16 
  THEN
     IP ← Pop();
     EIP ← EIP AND 0000FFFFH;
     CS ← Pop(); (* 16-bit pop *)
  ELSE (* OperandSize = 32 *)
     EIP ← Pop ();
     CS ← Pop(); (* 32-bit pop, high-order 16-bits discarded *)
  FI;
  IF instruction has immediate operand THEN eSP ← eSP + imm16; FI;
FI;
IF (PE = 1 AND VM = 0) (* Protected mode, not V86 mode *) AND instruction = far RET THEN IF OperandSize=32 THEN Third word on stack must be within stack limits else #SS(0); ELSE Second word on stack must be within stack limits else #SS(0); FI; Return selector RPL must be ó CPL ELSE #GP(return selector) IF return selector RPL = CPL THEN GOTO SAME-LEVEL; ELSE GOTO OUTER-PRIVILEGE-LEVEL; FI; FI;
SAME-LEVEL:
  Return selector must be non-null ELSE #GP(0)
  Selector index must be within its descriptor table limits ELSE 
     #GP(selector)
  Descriptor AR byte must indicate code segment ELSE #GP(selector)
  IF non-conforming
  THEN code segment DPL must equal CPL;
  ELSE #GP(selector);
  FI;
  IF conforming 
  THEN code segment DPL must be ó CPL;
  ELSE #GP(selector);
  FI;
  Code segment must be present ELSE #NP(selector);
  Top word on stack must be within stack limits ELSE #SS(0);
  IP must be in code segment limit ELSE #GP(0);
  IF OperandSize=32
  THEN
     Load CS:EIP from stack 
     Load CS register with descriptor 
     Increment eSP by 8 plus the immediate offset if it exists 
  ELSE (* OperandSize=16 *)
     Load CS:IP from stack 
     Load CS register with descriptor 
     Increment eSP by 4 plus the immediate offset if it exists 
  FI;
OUTER-PRIVILEGE-LEVEL:
  IF OperandSize=32
  THEN Top (16+immediate) bytes on stack must be within stack limits 
     ELSE #SS(0);
  ELSE Top (8+immmediate) bytes on stack must be within stack limits ELSE 
     #SS(0);
  FI;
  Examine return CS selector and associated descriptor:
     Selector must be non-null ELSE #GP(0);
     Selector index must be within its descriptor table limits ELSE 
        #GP(selector)
     Descriptor AR byte must indicate code segment ELSE #GP(selector);
     IF non-conforming
     THEN code segment DPL must equal return selector RPL 
     ELSE #GP(selector);
     FI;
     IF conforming 
     THEN code segment DPL must be ó return selector RPL;
     ELSE #GP(selector);
     FI;
     Segment must be present ELSE #NP(selector)
  Examine return SS selector and associated descriptor:
     Selector must be non-null ELSE #GP(0);
     Selector index must be within its descriptor table limits 
        ELSE #GP(selector);
     Selector RPL must equal the RPL of the return CS selector ELSE 
        #GP(selector);
     Descriptor AR byte must indicate a writable data segment ELSE 
        #GP(selector);
     Descriptor DPL must equal the RPL of the return CS selector ELSE 
        #GP(selector);
     Segment must be present ELSE #NP(selector);
  IP must be in code segment limit ELSE #GP(0);
  Set CPL to the RPL of the return CS selector;
  IF OperandSize=32
  THEN
     Load CS:EIP from stack;
     Set CS RPL to CPL;
     Increment eSP by 8 plus the immediate offset if it exists;
     Load SS:eSP from stack;
  ELSE (* OperandSize=16 *)
     Load CS:IP from stack;
     Set CS RPL to CPL;
     Increment eSP by 4 plus the immediate offset if it exists;
     Load SS:eSP from stack;
  FI;
  Load the CS register with the return CS descriptor;
  Load the SS register with the return SS descriptor;
  For each of ES, FS, GS, and DS 
  DO
     IF the current register setting is not valid for the outer level,
        set the register to null (selector ← AR ← 0);
     To be valid, the register setting must satisfy the following properties:
        Selector index must be within descriptor table limits;
        Descriptor AR byte must indicate data or readable code segment;
        IF segment is data or non-conforming code, THEN 
           DPL must be ò CPL, or DPL must be ò RPL;
        FI;
  OD;
- Protected Mode Exceptions
#GP, #NP, or #SS, as described under "Operation" above; #PF(fault-code) for a page fault.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would be outside the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault.
ROL/ROR - Rotate
See entry for RCL/RCR/ROL/ROR.
RSM - Resume from System Management Mode
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F AA | RSM | X | Resume operation of interrupted program | 
- Description
The processor state is restored from the dump created upon entrance to SMM. Note, however, that the contents of the model-specific registers are not affected. The processor leaves SMM and returns control to the interrupted application or operating system. If the processor detects any invalid state information, it enters the shutdown state. This happens in any of the following situations:
- The value stored in the State Dump Base field is not a 32Kbyte aligned address.
- Any reserved bit of CR4 is set to 1.
- Any combination of bits in CR0 is illegal; namely, (PG=1 and PE=0) or (NW= 1 and CD=0).
- Operation
Resume operation of a program interrupted by a System Management Mode interrupt.
Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| * | * | * | * | * | * | * | * | 
All
- Protected Mode Exceptions
- UD if an attempt is made to run this instruction when the processor is not in System Management Mode.
- Real Address Mode Exceptions
- UD if an attempt is made to run this instruction when the processor is not in System Management Mode.
- Virtual 8086 Mode Exceptions
- UD if an attempt is made to run this instruction when the processor is not in System Management Mode.
- Notes
Refer to the Intel documentation for more information about System Management Mode and the behavior of the RSM instruction.
SAHF - Store AH into Flags
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9E | SAHF | X | X | X | X | X | X | Store AH into flags (SF, ZF, xx, AF, xx, PF, xx, CF) | 
Description The SAHF instruction loads the SF, ZF, AF, PF,A and CF flags with values from the AH register, from bits 7, 6, 4, 2, and 0, respectively.
- Operation
SF:ZF:xx:AF:xx:PF:xx:CF← AH;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| * | * | * | * | * | 
The SF, ZF, AF, PF, and CF flags are loaded with values from the AH register.
SAL/SAR/SHL/SHR - Shift Instructions
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D0 /4 | SAL r/m8,1 | X | X | X | X | X | X | Multiply r/m byte by 2, once | 
| D2 /4 | SAL r/m8,CL | X | X | X | X | X | X | Multiply r/m byte by 2, CL times | 
| C0 /5 ib | SAL r/m8,imm8 | X | X | X | X | X | Multiply r/m byte by 2, imm8 times | |
| D1 /4 | SAL r/m16,1 | X | X | X | X | X | X | Multiply r/m word by 2, once | 
| D1 /4 | SAL r/m32,1 | X | X | X | Multiply r/m dword by 2, once | |||
| D3 /4 | SAL r/m16,CL | X | X | X | X | X | X | Multiply r/m word by 2, CL times | 
| D3 /4 | SAL r/m32,CL | X | X | X | Multiply r/m dword by 2, CL times | |||
| C1 /4 ib | SAL r/m16,imm8 | X | X | X | X | X | Multiply r/m word by 2, imm8 times | |
| C1 /4 ib | SAL r/m32,imm8 | X | X | X | Multiply r/m dword by 2, imm8 times | |||
| D0 /7 | SAR r/m8,1 | X | X | X | X | X | X | Signed divide r/m byte by 2, once | 
| D2 /7 | SAR r/m8,CL | X | X | X | X | X | X | Signed divide r/m byte by 2, CL times | 
| C0 /7 ib | SAR r/m8,imm8 | X | X | X | X | X | Signed divide r/m byte by 2, imm8 times | |
| D1 /7 | SAR r/m16,1 | X | X | X | X | X | X | Signed divide r/m word by 2, once | 
| D1 /7 | SAR r/m32,1 | X | X | X | Signed divide r/m dword by 2, once | |||
| D3 /7 | SAR r/m16,CL | X | X | X | X | X | X | Signed divide r/m word by 2, CL times | 
| D3 /7 | SAR r/m32,CL | X | X | X | Signed divide r/m dword by 2, CL times | |||
| C1 /7 ib | SAR r/m16,imm8 | X | X | X | X | X | Signed divide r/m word by 2, imm8 times | |
| C1 /7 ib | SAR r/m32,imm8 | X | X | X | Signed divide r/m dword by 2, imm8 times | |||
| D0 /4 | SHL r/m8,1 | X | X | X | X | X | X | Multiply r/m byte by 2, once | 
| D0 /4 | SHL r/m8,CL | X | X | X | X | X | X | Multiply r/m byte by 2, CL times | 
| C0 /4 ib | SHL r/m8,imm8 | X | X | X | X | X | Multiply r/m byte by 2, imm8 times | |
| D1 /4 | SHL r/m16,1 | X | X | X | X | X | X | Multiply r/m word by 2, once | 
| D1 /4 | SHL r/m32,1 | X | X | X | Multiply r/m dword by 2, once | |||
| D3 /4 | SHL r/m16,CL | X | X | X | X | X | X | Multiply r/m word by 2, CL times | 
| D3 /4 | SHL r/m32,CL | X | X | X | Multiply r/m dword by 2, CL times | |||
| C1 /4 ib | SHL r/m16,imm8 | X | X | X | X | X | Multiply r/m word by 2, imm8 times | |
| C1 /4 ib | SHL r/m32,imm8 | X | X | X | Multiply r/m dword by 2, imm8 times | |||
| D0 /5 | SHR r/m8,1 | X | X | X | X | X | X | Signed divide r/m byte by 2, once | 
| D2 /5 | SHR r/m8,CL | X | X | X | X | X | X | Signed divide r/m byte by 2, CL times | 
| C0 /5 ib | SHR r/m8,imm8 | X | X | X | X | X | Signed divide r/m byte by 2, imm8 times | |
| D1 /5 | SHR r/m16,1 | X | X | X | X | X | X | Signed divide r/m word by 2, once | 
| D1 /5 | SHR r/m32,1 | X | X | X | Signed divide r/m dword by 2, once | |||
| D3 /5 | SHR r/m16,CL | X | X | X | X | X | X | Signed divide r/m word by 2, CL times | 
| D3 /5 | SHR r/m32,CL | X | X | X | Signed divide r/m dword by 2, CL times | |||
| C1 /5 ib | SHR r/m16,imm8 | X | X | X | X | X | Signed divide r/m word by 2, imm8 times | |
| C1 /5 ib | SHR r/m32,imm8 | X | X | X | Signed divide r/m dword by 2, imm8 times | 
Description The SAL instruction (or its synonym, SHL) shifts the bits of the operand upward. The high-order bit is shifted into the CF flag, and the low-order bit is cleared. The SAR and SHR instructions shift the bits of the operand downward. The low-order bit is shifted into the CF flag. The effect is to divide the operand by two. The SAR instruction performs a signed divide with rounding toward negative infinity (not the same as the IDIV instruction); the high-order bit remains the same. The SHR instruction performs an unsigned divide ; the high-order bit is cleared. The shift is repeated the number of times indicated by the second operand, which is either an immediate number or the contents of the CL register. To reduce the maximum processing time, the Pentium processor does not allow shift counts greater than 31. If a shift count greater than 31 is attempted , only the bottom five bits of the shift count are used. (The 8086 uses all eight bits of the shift count.) The OF flag is affected only if the single-shift forms of the instructions are used. For left shifts, the OF flag is cleared if the high bit of the answer is the same as the result of the CF flag (i.e., the top two bits of the original operand were the same); the OF flag is set if they are different. For the SAR instruction, the OF flag is cleared for all single shifts. For the SHR instruction, the OF flag is set for the high-order bit of the original operand.
- Operation
(* COUNT is the second parameter *)
(temp) ← COUNT; WHILE (temp<> 0) DO IF instruction is SAL or SHL THEN CF ← high-order bit of r/m; FI; IF instruction is SAR or SHR THEN CF ← low-order bit of r/m; FI; IF instruction = SAL or SHL THEN r/m ← r/m * 2; FI; IF instruction = SAR THEN r/m ← r/m ;2 (*Signed divide, rounding toward negative infinity*); FI; IF instruction = SHR THEN r/m ← r/m / 2; (* Unsigned divide *); FI; temp ← temp - 1; OD;
- Determine overflow for the various instructions *)
IF COUNT = 1 THEN IF instruction is SAL or SHL THEN OF ← high-order bit of r/m <> (CF); FI; IF instruction is SAR THEN OF ← 0; FI; IF instruction is SHR THEN OF ← high-order bit of operand; FI; ELSE OF ← undefined; FI;
Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- |* | | |* |* |? |* |*
If count = 0, the flags are not affected. The CF flag contains the value of the last bit shifted out. The CF flag is undefined for SHL and SHR instructions in which the shift lengths are greater than or equal to the size of the operand to be shifted. The OF flag is affected for single shifts; the OF flag is undefined for multiple shifts; the CF, ZF, PF, and SF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
SBB - Integer Subtraction with Borrow
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 1C ib | SBB AL,imm8 | X | X | X | X | X | X | Subtract with borrow, immediate byte from AL | 
| 1D iw | SBB AX,imm16 | X | X | X | X | X | X | Subtract with borrow, immediate word AX | 
| 1D id | SBB EAX,imm32 | X | X | X | Subtract with borrow, immediate dword from EAX | |||
| 80 /3 ib | SBB r/m8,imm8 | X | X | X | X | X | X | Subtract with borrow, immediate byte from r/m byte | 
| 81 /3 iw | SBB r/m16,imm16 | X | X | X | X | X | X | Subtract with borrow, immediate word from r/m word | 
| 81 /3 id | SBB r/m32,imm32 | X | X | X | Subtract with borrow, immediate dword from r/m dword | |||
| 83 /3 ib | SBB r/m16,imm8 | X | X | X | X | X | X | Subtract with borrow, sign-extended immediate byte from r/m word | 
| 83 /3 ib | SBB r/m32,imm8 | X | X | X | Subtract with borrow, sign-extended immediate byte from r/m dword | |||
| 18 /r | SBB r/m8,r8 | X | X | X | X | X | X | Subtract with borrow, byte register from r/m byte | 
| 19 /r | SBB r/m16,r16 | X | X | X | X | X | X | Subtract with borrow, word register from r/m word | 
| 19 /r | SBB r/m32,r32 | X | X | X | Subtract with borrow, dword register from r/m dword | |||
| 1A /r | SBB r8,r/m8 | X | X | X | X | X | X | Subtract with borrow, r/m byte from byte register | 
| 1B /r | SBB r16,r/m16 | X | X | X | X | X | X | Subtract with borrow, r/m word from word register | 
| 1B /r | SBB r32,r/m32 | X | X | X | Subtract with borrow, r/m dword from dword register | 
- Description
The SBB instruction adds the second operand (SRC) to the CF flag and subtracts the result from the first operand (DEST). The result of the subtraction is assigned to the first operand (DEST), and the flags are set accordingly. When an immediate byte value is subtracted from a word operand, the immediate value is first sign-extended.
- Operation
F SRC is a byte and DEST is a word or dword THEN DEST = DEST - (SignExtend(SRC) + CF) ELSE DEST ← DEST - (SRC + CF);
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- |* | | |* |* |* |* |*
The OF, SF, ZF, AF, PF, and CF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
SCAS/SCASB/SCASW/SCASD - Compare String Data
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| AE | SCAS m8 | X | X | X | X | X | X | Compare AL with byte at ES:[(E)DI], update [(E)DI] | 
| AF | SCAS m16 | X | X | X | X | X | X | Compare AX with word at ES:[(E)DI], update [(E)DI] | 
| AF | SCAS m32 | X | X | X | Compare EAX with dword at ES:[(E)DI], update [(E)DI] | |||
| AE | SCASB | X | X | X | X | X | X | Compare AL with byte at ES:[(E)DI], update [(E)DI] | 
| AF | SCASW | X | X | X | X | X | X | Compare AX with word at ES:[(E)DI], update [(E)DI] | 
| AF | SCASD | X | X | X | Compare EAX with dword at ES:[(E)DI], update [(E)DI] | 
- Description
The SCAS instruction subtracts the memory byte or word at the destination register from the AL, AX or EAX register. The result is discarded; only the flags are set. The operand must be addressable from the ES segment; no segment override is possible. If the address-size attribute for this instruction is 16 bits, the DI register is used as the destination register, otherwise, the address-size attribute is 32 bits and the EDI register is used. The address of the memory data being compared is determined solely by the contents of the destination register, not by the operand to the SCAS instruction. The operand validates ES segment addressability and determines the data type. Load the correct index value into the DI or EDI register before running the SCAS instruction. After the comparison is made, the destination register is automatically updated. If the direction flag is 0 (the CLD instruction was run), the destination register is incremented; if the direction flag is 1 (the STD instruction was run), it is decremented. The increments or decrements are by 1 if bytes are compared, by 2 if words are compared, or by 4 if doublewords are compared. The SCASB, SCASW, and SCASD instructions are synonyms for the byre, word and doubleword SCAS instructions that don't require operands. They are simpler to code, but provide no type or segment checking. The SCAS instruction can be preceded by the REPE or REPNE prefix for a block search of CX or ECX bytes or words. Refer to the REP instruction for further details.
- Operation
IF AddressSize = 16THEN use DI for dest-index;ELS
E (* AddressSize = 32 *) use EDI for dest-index;
FI;
If byte type of instruction 
THEN 
  AL - [dest-index]; (* Compare byte in AL and dest *)
  IF DF = 0 THEN IncDec ← 1 ELSE IncDec ← -1; FI;
ELSE 
  IF OperandSize = 16 
  THEN
     AX - [dest-index]; (* compare word in AL and dest *)
     IF DF = 0 THEN IncDec ← 2 ELSE IncDec ← -2; FI;
  ELSE (* OperandSize = 32 *)
     EAX - [dest-index];(* compare dword in EAX and dest *)
     IF DF = 0 THEN IncDec ← 4 ELSE IncDec ← -4; FI;
  FI;
FI;
dest-index = dest-index + IncDec 
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF |--+--+--+--+--+--+--+-- |* | | |* |* |* |* |*
The OF, SF, ZF, AF, PF, and CF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the ES segment; # PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
SETcc-Byte Set on Condition
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 97 | SETA r/m8 | X | X | X | Set byte if above (CF=0 and ZF=0) | |||
| 0F 93 | SETAE r/m8 | X | X | X | Set byte if above or equal (CF=0) | |||
| 0F 92 | SETB r/m8 | X | X | X | Set byte if below (CF=1) | |||
| 0F 96 | SETBE r/m8 | X | X | X | Set byte if below or equal (CF=1 or ZF=1) | |||
| 0F 92 | SETC r/m8 | X | X | X | Set byte if carry (CF=1) | |||
| 0F 94 | SETE r/m8 | X | X | X | Set byte if equal (ZF=1) | |||
| 0F 9F | SETG r/m8 | X | X | X | Set byte if greater (ZF=0 or SF=OF) | |||
| 0F 9D | SETGE r/m8 | X | X | X | Set byte if greater or equal (SF=OF) | |||
| 0F 9C | SETL r/m8 | X | X | X | Set byte if less (SF<>OF) | |||
| 0F 9E | SETLE r/m8 | X | X | X | Set byte if less or equal (ZF=1 and SF<>OF) | |||
| 0F 96 | SETNA r/m8 | X | X | X | Set byte if not above (CF=1) | |||
| 0F 92 | SETNAE r/m8 | X | X | X | Set byte if not above or equal (CF=1) | |||
| 0F 93 | SETNB r/m8 | X | X | X | Set byte if not below (CF=0) | |||
| 0F 97 | SETNBE r/m8 | X | X | X | Set byte if not below or equal (CF=0 and ZF=0) | |||
| 0F 93 | SETNC r/m8 | X | X | X | Set byte if not carry (CF=0) | |||
| 0F 95 | SETNE r/m8 | X | X | X | Set byte if not equal (ZF=0) | |||
| 0F 9E | SETNG r/m8 | X | X | X | Set byte if not greater (ZF=1 or SF<>OF) | |||
| 0F 9C | SETNGE r/m8 | X | X | X | Set byte if not greater or equal (SF<>OF) | |||
| 0F 9D | SETNL r/m8 | X | X | X | Set byte if not less (SF=OF) | |||
| 0F 9F | SETNLE r/m8 | X | X | X | Set byte if not less or equal (ZF=1 and SF<>OF) | |||
| 0F 91 | SETNO r/m8 | X | X | X | Set byte if not overflow (OF=0) | |||
| 0F 9B | SETNP r/m8 | X | X | X | Set byte if not parity (PF=0) | |||
| 0F 99 | SETNS r/m8 | X | X | X | Set byte if not sign (SF=0) | |||
| 0F 95 | SETNZ r/m8 | X | X | X | Set byte if not zero (ZF=0) | |||
| 0F 90 | SETO r/m8 | X | X | X | Set byte if overflow (OF=1) | |||
| 0F 9A | SETP r/m8 | X | X | X | Set byte if parity (PF=1) | |||
| 0F 9A | SETPE r/m8 | X | X | X | Set byte if parity even (PF=1) | |||
| 0F 9B | SETPO r/m8 | X | X | X | Set byte if parity odd (PF=0) | |||
| 0F 98 | SETS r/m8 | X | X | X | Set byte if sign (SF=1) | |||
| 0F 94 | SETZ r/m8 | X | X | X | Set byte if zero (ZF=1) | 
- Description
The SETcc instruction stores a 1 byte at the destination specified by the effective address or register if the condition is met, or a 0 byte if the condition is not met.
- Operation
IF condition THEN r/m8 ← 1 ELSE r/m8 ← 0; FI;
- Protected Mode Exceptions
- GP(0) if the result is in a non-writable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault.
SGDT/SIDT - Store Global/Interrupt Descriptor Table Register
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 01 /0 | SGDT m | X | X | X | X | Store GDTR to m (6 bytes) | ||
| 0F 01 /1 | SIDT m | X | X | X | X | Store IDTR to m (6 bytes) | 
- Description
The SGDT and SIDT instructions copy the contents of the descriptor table register to the six bytes of memory indicated by the operand. The LIMIT field of the register is assigned to the first word at the effective address. If the operand-size attribute is 16 bits, the next three bytes are assigned the BASE field of the register, and the fourth byte is undefined. Otherwise, if the operand-size attribute is 32 bits, the next four bytes are assigned the 32-bit BASE field of the register. The SGDT and SIDT instructions are used only in operating system software; they are not used in application programs.
- Operation
DEST ← 48-bit BASE/LIMIT register contents;
- Protected Mode Exceptions
Interrupt 6 if the destination operand is a register; #GP(0) if the destination is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 6 if the destination operand is a register; Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Compatibility Note
The 16-bit forms of the SGDT and SIDT instruction are compatible with the Intel 286 processor, if the value in the upper eight bits is not referenced. The Intel 286 processor stores 1's in these upper bits, whereas the 32- bit processors store 0's if the operand-size attribute is 16 bits. These bits were specified as undefined by the SGDT and SIDT instructions in the 80286 Programming Reference Manual (Intel Order No. 210498).
SHL/SHR - Shift Instruction
See entry for SAL/SAR/SHL/SHR.
SHLD - Double Precision Shift Left
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F A4 | SHLD r/m16,r16,imm8 | X | X | X | r/m16 ← SHL or r/m16 concatenated with r16 | |||
| 0F A4 | SHLD r/m32,r32,imm8 | X | X | X | r/m32 ← SHL of r/m32 concatenated with r32 | |||
| 0F A5 | SHLD r/m16,r16,CL | X | X | X | r/m16 ← SHL of r/m16 concatenated with r16 | |||
| 0F A5 | SHLD r/m32,r32,CL | X | X | X | r/m32 ← SHL of r/m32 concatenated with r32 | 
- Description
The SHLD instruction shifts the first operand provided by the r/m field to the left as many bits as specified by the count operand. The second operand (r16 or r32) provides the bits to shift in from the right (starting with bit 0). The result is stored back into the r/m operand. The register remains unaltered. The count operand is provided by either an immediate byte or the contents of the CL register. These operands are taken MODULO 32 to provide a number between 0 and 31 by which to shift. Because the bits to shift are provided by the specified registers, the operation is useful for multi-precision shifts (64 bits or more). The SF, ZF and PF flags are set according to the value of the result. The CF flag is set to the value of the last bit shifted out. The OF and AF flags are left undefined.
- Operation
(* count is an unsigned integer corresponding to the last operand of the instruction, 
   either an immediate byte or the byte in register CL *)
ShiftAmt ← count MOD 32;
inBits ← register; (* Allow overlapped operands *)
IF ShiftAmt = 0 
THEN no operation
ELSE
 IF ShiftAmt ò OperandSize
 THEN (* Bad parameters *)
   r/m ← UNDEFINED;
   CF, OF, SF, ZF, AF, PF ← UNDEFINED;
 ELSE (* Perform the shift *)
   CF ← BIT[Base, OperandSize - ShiftAmt];
     (* Last bit shifted out on exit *)
   FOR i ← OperandSize - 1 DOWNTO ShiftAmt 
   DO 
     BIT[Base, i] ← BIT[Base, i - ShiftAmt];
   OF;
   FOR i ← ShiftAmt - 1 DOWNTO 0 
   DO 
     BIT[Base, i] ← BIT[inBits, i - ShiftAmt + OperandSize];
   OD;
   Set SF, ZF, PF (r/m);
     (* SF, ZF, PF are set according to the value of the result *)
   AF ← UNDEFINED;
 FI;
FI;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| |? | | |* |* |? |* |* |
If count = 0, the flags are not affected. The SF, ZF, and PF flags are set according to the result; the CF flag is set to the value of the last bit shifted out; after a shift of one bit position, the OF flag is set if a sign change occurred, otherwise it is cleared; after a shift of more than one bit position, the OF flag is undefined; the AF flag is undefined, except for a shift count of zero, which does not affect any flags.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
SHRD - Double Precision Shift Right
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F AC | SHRD r/m16,r16,imm8 | X | X | X | r/m16 ← SHR of r/m16 concatenated with r16 | |||
| 0F AC | SHRD r/m32,r32,imm8 | X | X | X | r/m32 ← SHR of r/m32 concatenated with r32 | |||
| 0F AD | SHRD r/m16,r16,CL | X | X | X | r/m16 ← SHR of r/m16 concatenated with r16 | |||
| 0F AD | SHRD r/m32,r32,CL | X | X | X | r/m32 ← SHR of r/m32 concatenated with r32 | 
- Description
The SHRD instruction shifts the first operand provided by the r/m field to the right as many bits as specified by the count operand. The second operand (r16 or r32) provides the bits to shift in from the left (starting with bit 31). The result is stored back into the r/m operand. The register remains unaltered. The count operand is provided by either an immediate byte or the contents of the CL register. These operands are taken MODULO 32 to provide a number between 0 and 31 by which to shift. Because the bits to shift are provided by the specified register, the operation is useful for multi-precision shifts (64 bits or more). The SF, ZF and PF flags are set according to the value of the result. The CF flag is set to the value of the last bit shifted out. The OF and AF flags are left undefined.
- Operation
(* count is an unsigned integer corresponding to the last operand of the instruction, either an immediate byte or the byte in register CL *)
ShiftAmt ← count MOD 32;
inBits ← register; (* Allow overlapped operands *)
IF ShiftAmt = 0 
THEN no operation 
ELSE 
 IF ShiftAmt ò OperandSize 
 THEN (* Bad parameters *)
   r/m ← UNDEFINED;
   CF, OF, SF, ZF, AF, PF ← UNDEFINED;
 ELSE (* Perform the shift *)
   CF ← BIT[r/m, ShiftAmt - 1]; (* last bit shifted out on exit *)
   FOR i ← 0 TO OperandSize - 1 - ShiftAmt 
   DO 
     BIT[r/m, i] ← BIT[r/m, i - ShiftAmt];
   OD;
   FOR i ← OperandSize - ShiftAmt TO OperandSize-1
   DO 
     BIT[r/m,i] ← BIT[inBits,i+ShiftAmt - OperandSize];
   OD;
     (* SF, ZF, PF are set according to the value of the result *)
   Set SF, ZF, PF (r/m);
   AF ←UNDEFINED;
 FI;
FI;
Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| ? | * | * | ? | * | * | 
If count = 0, the flags are not affected. The SF, ZF, and PF flags are set according to the result; the CF flag is set to the value of the last bit shifted out; after a shift of one bit position, the OF flag is set if a sign change occurred, otherwise it is cleared; after a shift of more than one bit position, the OF flag is undefined; the AF flag is undefined, except for a shift count of zero, which does not affect any flags. Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
Real Address Mode Exceptions Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH. Virtual 8086 Mode Exceptions Same exceptions as in Real Address Mode; #AC for unaligned memory reference if the current privilege level is 3.
SIDT - Store Interrupt Descriptor Table Register
See entry for SGDT/SIDT.
SLDT - Store Local Descriptor Table Register
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 00 /0 | SLDT r/m16 | X | X | X | X | Store LDTR to EA word | 
- Description
The SLDT instruction stores the Local Descriptor Table Register (LDTR) in the two-byte register or memory location indicated by the effective address operand. This register is a selector that points into the Global Descriptor Table. The SLDT instruction is used only in operating system software. It is not used in application programs.
- Operation
r/m16 ← LDTR;
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 6; the SLDT instruction is not recognized in Real Address Mode.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode (because the instruction is not recognized, it will not run or perform a memory reference).
- Notes
When the destination is a 32-bit register, the 16-bit source operand is copied into the lower 16 bits of the destination register, and the upper 16 bits of the register are undefined. With a 16-bit register operand, only the lower 16 bits of the destination are affected (the upper 16 bits remain unchanged). With a memory operand, the source is written to memory as a 16- bit quantity, regardless of operand size. As a result, 32-bit software should always treat the destination as 16-bits and mask bits 16-31, if necessary.
SMSW - Store Machine Status Word
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 01 /4 | SMSW r/m16 | X | X | X | X | Store machine status word to EA word | 
- Description
The SMSW instruction stores the machine status word (part of the CR0 register) in the two-byte register or memory location indicated by the effective address operand.
- Operation
r/m16 ← MSW;
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode, #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
This instruction is provided for compatibility with the Intel 286 processor; programs for the Pentium processor should use the MOV ..., CR0 instruction. When the destination is a 32-bit register, the 16-bit source operand is copied into the lower 16 bits of the destination register, and the upper 16 bits of the register are undefined. With a 16-bit register operand, only the lower 16 bits of the destination are affected (the upper 16 bits remain unchanged). With a memory operand, the source is written to memory as a 16- bit quantity, regardless of operand size. As a result, 32-bit software should always treat the destination as 16-bits and mask bits 16-31, if necessary.
STC - Set Carry Flag
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------------+-+-+-+-+-+-+-------------- |F9 |STC |X|X|X|X|X|X|Set carry flag
- Description
- The STC instruction sets the CF flag.
- Operation
CF ← 1;
- Flags Affected
|OF|DF|IF|SF|ZF|AF|PF|CF| |--+--+--+--+--+--+--+--| | | | | | | | |1 |
The CF flag is set.
STD - Set Direction Flag
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| FD | STD | X | X | X | X | X | X | Set direction flag so that [(E)SI] and/or [(E)DI] decrement | 
- Description
The STD instruction sets the direction flag, causing all subsequent string operations to decrement the index registers, (E)SI and/or (E)DI, on which they operate.
- Operation
DF ← 1;
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| 1 | 
The DF flag is set.
STI - Set Interrupt Flag
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| FB | STI | X | X | X | X | X | X | Set interrupt flag | 
- Description
The STI instruction sets the IF. The processor then responds to external interrupts after running the next instruction if the next instruction allows the IF flag to remain enabled. If external interrupts are disabled and the STI instruction is followed by the RET instruction (such as at the end of a subroutine), the RET instruction is allowed to run before external interrupts are recognized. Also, if external interrupts are disabled and the STI instruction is followed by a CLI instruction, which clears the IF flag, then external interrupts are not recognized because the CLI instruction clears the IF flag during its processing.
- Operation
IF PE=0 (* Running in real-address mode *)
THEN 
 IF ← 1; (* Set Interrupt Flag *)
ELSE (* Running in protected mode or virtual-8086 mode *)
 IF VM=0 (* Running in protected mode *)
 THEN 
   IF IOPL=3
   THEN IF ← 1; (* Set Interrupt Flag *)
   ELSE IF CPL òIOPL
     THEN IF ← 1;
     ELSE #GP(0);
     FI;
   FI;
 ELSE (* Running in Virtual-8086 mode *)
   #GP(0); (* Trap to virtual-8086 monitor *)
 FI;
FI;
- Decision Table
The following decision table indicates which action in the lower portion of the table is taken given the conditions in the upper portion of the table.
| PE = | 0 | 1 | 1 | 1 | 
| VM = | - | 0 | 0 | 1 | 
| CPL | - | ò IOPL | > IOPL | = 3 | 
| IOPL | - | - | - | = 3 | 
| IF ← 1 | Y | Y | Y | |
| #GP(0) | Y | 
Notes: - Don't care Blank Action not taken Y Action in Column 1 taken
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| 1 | 
The IF flag is set.
- Protected Mode Exceptions
- GP(0) if the current privilege level is greater (has less privilege) than the I/O privilege level.
- Virtual 8086 Mode Exceptions
- GP(0) as for protected mode.
- Notes
In case of an NMI, trap, or fault following STI the interrupt will be taken before running the next sequential instruction in the code. For information on this instruction when using virtual mode extensions, see the Intel documentation.
STOS/STOSB/STOSW/STOSD - Store String Data
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| AA | STOS m8 | X | X | X | X | X | X | Store AL in byte at ES:[(E)DI], update [(E)DI] | 
| AB | STOS m16 | X | X | X | X | X | X | Store AX in word at ES:[(E)DI], update [(E)DI] | 
| AB | STOS m32 | X | X | X | Store EAX in dword at ES:[(E)DI], update [(E)DI] | |||
| AA | STOSB | X | X | X | X | X | X | Store AL in byte at ES:[(E)DI], update [(E)DI] | 
| AB | STOSW | X | X | X | X | X | X | Store AX in word at ES:[(E)DI], update [(E)DI] | 
| AB | STOSD | X | X | X | Store EAX in dword at ES:[(E)DI], update [(E)DI] | 
- Description
The STOS instruction transfers the contents of the AL, AX, or EAX register to the memory byte or word given by the destination register relative to the ES segment. The destination register is the DI register for an address- size attribute of 16 bits or the EDI register for an address-size attribute of 32 bits. The destination operand must be addressable from the ES register. A segment override is not possible. The address of the destination is determined by the contents of the destination register, not by the explicit operand of the STOS instruction. This operand is used only to validate ES segment addressability and to determine the data type. Load the correct index value into the destination register before running the STOS instruction. After the transfer is made, the (E)DI register is automatically updated. If the DF flag is 0 (the CLD instruction was run), the (E)DI register is incremented; if the DF flag is 1 (the STD instruction was executed), the (E )DI register is decremented. The (E)DI register is incremented or decremented by 1 if a byte is stored, by 2 if a word is stored, or by 4 if a doubleword is stored. The STOSB, STOSW, and STOSD instructions are synonyms for the byte, word, and doubleword STOS instructions, that do not require an operand. They are simpler to use, but provide no type or segment checking. The STOS instruction can be preceded by the REP prefix for a block fill of CX or ECX bytes, words, or doublewords. Refer to the REP instruction for further details.
- Operation
IF AddressSize = 16 
THEN use ES:DI for DestReg 
ELSE (* AddressSize = 32 *) use ES:EDI for DestReg;
FI;
IF byte type of instruction 
THEN 
  (ES:DestReg) ← AL;
  IF DF = 0 
  THEN DestReg ← DestReg + 1;
  ELSE DestReg ← DestReg - 1;
  FI;
ELSE IF OperandSize = 16 
  THEN 
    (ES:DestReg) ← AX;
    IF DF = 0 
    THEN DestReg ← DestReg + 2;
    ELSE DestReg ← DestReg - 2;
    FI;
  ELSE (* OperandSize = 32 *)
    (ES:DestReg) ← EAX;
    IF DF = 0 
    THEN DestReg ← DestReg + 4;
    ELSE DestReg ← DestReg - 4;
    FI;
  FI;
FI;
Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the ES segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
Real Address Mode Exceptions Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH. Virtual 8086 Mode Exceptions Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
STR - Store Task Register
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 00 /1 | STR r/m16 | X | X | X | X | Store task register to EA word | 
- Description
The contents of the task register are copied to the two-byte register or memory location indicated by the effective address operand. The STR instruction is used only in operating system software. It is not used in application programs.
- Operation
r/m ← task register;
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
Real Address Mode Exceptions Interrupt 6; the STR instruction is not recognized in Real Address Mode. Virtual 8086 Mode Exceptions Same exceptions as in Real Address Mode.
- Notes
When the destination is a 32-bit register, the 16-bit source operand is copied into the lower 16 bits of the destination register, and the upper 16 bits of the register are undefined. With a 16-bit register operand, only the lower 16 bits of the destination are affected (the upper 16 bits remain unchanged). With a memory operand, the source is written to memory as a 16- bit quantity, regardless of operand size. As a result, 32-bit software should always treat the destination as 16-bits and mask bits 16-31, if necessary.
SUB - Integer Subtraction
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 2C ib | SUB AL,imm8 | X | X | X | X | X | X | AL < AL - immediate byte | 
| 2D iw | SUB AX,imm16 | X | X | X | X | X | X | AX < AX - immediate word | 
| 2D id | SUB EAX,imm32 | X | X | X | EAX < EAX - immediate dword | |||
| 80 /5 ib | SUB r/m8,imm8 | X | X | X | X | X | X | r/m8 < r/m8 - immediate byte | 
| 81 /5 iw | SUB r/m16,imm16 | X | X | X | X | X | X | r/m16 < r/m16 - immediate word | 
| 81 /5 id | SUB r/m32,imm32 | X | X | X | r/m32 < r/m32 - immediate dword | |||
| 83 /5 ib | SUB r/m16,imm8 | X | X | X | X | X | X | r/m16 < r/m16 - sign-extended immediate byte | 
| 83 /5 ib | SUB r/m32,imm8 | X | X | X | r/m32 < r/m32 - sign-extended immediate byte | |||
| 28 /r | SUB r/m8,r8 | X | X | X | X | X | X | r/m8 < r/m8 - byte register | 
| 29 /r | SUB r/m16,r16 | X | X | X | X | X | X | r/m16 < r/m16 - word register | 
| 29 /r | SUB r/m32,r32 | X | X | X | r/m32 < r/m32 - dword register | |||
| 2A /r | SUB r8,r/m8 | X | X | X | X | X | X | r8 < r8 - r/m byte | 
| 2B /r | SUB r16,r/m16 | X | X | X | X | X | X | r16 < r16 - r/m word | 
| 2B /r | SUB r32,r/m32 | X | X | X | r32 < r32 - r/m dword | 
- Description
The SUB instruction subtracts the second operand (SRC) from the first operand (DEST). The first operand is assigned the result of the subtraction, and the flags are set accordingly. When an immediate byte value is subtracted from a word operand, the immediate value is first sign-extended to the size of the destination operand.
- Operation
IF SRC is a byte and DEST is a word or dword THEN DEST = DEST - SignExtend(SRC); ELSE DEST ← DEST - SRC; FI;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| * | * | * | * | * | * | 
The OF, SF, ZF, AF, PF, and CF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
TEST - Logical Compare
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| A8 ib | TEST AL,imm8 | X | X | X | X | X | X | AND immediate byte with AL | 
| A9 iw | TEST AX,imm16 | X | X | X | X | X | X | AND immediate word with AX | 
| A9 id | TEST EAX,imm32 | X | X | X | AND immediate dword with EAX | |||
| F6 /0 ib | TEST r/m8,imm8 | X | X | X | X | X | X | AND immediate byte with r/m byte | 
| F7 /0 iw | TEST r/m16,imm16 | X | X | X | X | X | X | AND immediate word with r/m word | 
| F7 /0 id | TEST r/m32,imm32 | X | X | X | AND immediate dword with r/m dword | |||
| 84 /r | TEST r/m8,r8 | X | X | X | X | X | X | AND byte register with r/m byte | 
| 85 /r | TEST r/m16,r16 | X | X | X | X | X | X | AND word register with r/m word | 
| 85 /r | TEST r/m32,r32 | X | X | X | AND dword register with r/m dword | 
- Description
The TEST instruction computes the bit-wise logical AND of its two operands. Each bit of the result is 1 if both of the corresponding bits of the operands are 1; otherwise, each bit is 0. The result of the operation is discarded and only the flags are modified.
- Operation
DEST : = LeftSRC AND RightSRC; CF ← 0; OF ← 0;
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
| 0 | * | * | ? | * | 0 | 
The OF and CF flags are cleared; the SF, ZF, and PF flags are set according to the result.
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
VERR, VERW - Verify a Segment for Reading or Writing
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 00 /4 | VERR r/m16 | X | X | X | X | Set ZF=1 if segment can be read, selector in r/m16 | ||
| 0F 00 /5 | VERW r/m16 | X | X | X | X | Set ZF=1 if segment can be written, selector in r/m16 | 
- Description
The two-byte register or memory operand of the VERR and VERW instructions contains the value of a selector. The VERR and VERW instructions determine whether the segment denoted by the selector is reachable from the current privilege level and whether the segment is readable (VERR) or writeable (VERW). If the segment is accessible, the ZF flag is set; if the segment is not accessible, the ZF flag is cleared. To set the ZF flag, the following conditions must be met:
- The selector must denote a descriptor within the bounds of the table (GDT or LDT); the selector must be "defined."
- The selector must denote the descriptor of a code or data segment (not that of a task state segment, LDT, or a gate).
- For the VERR instruction, the segment must be readable. For the VERW instruction, the segment must be a writeable data segment.
- If the code segment is readable and conforming, the descriptor privilege level (DPL) can be any value for the VERR instruction. Otherwise, the DPL must be greater than or equal to (have less or the same privilege as) both the current privilege level and the selector's RPL.
The validation performed is the same as if the segment were loaded into the DS, ES, FS, or GS register, and the indicated access (read or write) were performed. The ZF flag receives the result of the validation. The selector' s value cannot result in a protection exception, enabling the software to anticipate possible segment access problems.
- Operation
IF segment with selector at (r/m) is accessible with current protection level AND ((segment is readable for VERR) OR (segment is writable for VERW)) THEN ZF ← 1; ELSE ZF ← 0; FI;
- Flags Affected
OF|DF|IF|SF|ZF|AF|PF|CF | | | |* | | |
The ZF flag is set if the segment is accessible, cleared if it is not.
- Protected Mode Exceptions
Faults generated by illegal addressing of the memory operand that contains the selector; the selector is not loaded into any segment register, and no faults attributable to the selector operand are generated.
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments;
- SS(0) for an illegal address in the SS segment; #PF( fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
 
- Real Address Mode Exceptions
Interrupt 6; the VERR and VERW instructions are not recognized in Real Address Mode.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #AC for unaligned memory reference if the current privilege level is 3.
WAIT - Wait
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 9B | WAIT | X | X | X | X | X | X | Causes processor to check for numeric exceptions | 
- Description
WAIT causes the processor to check for pending unmasked numeric exceptions before proceeding.
- Protected Mode Exceptions
.#NM if both MP and TS in CR0 are set.
- Real Address Mode Exceptions
Interrupt 7 if both MP and TS is CR0 are set.
- Virtual 8086 Mode Exceptions
.#NM if both MP and TS in CR0 are set.
- Notes
- Coding WAIT after an ESC instruction ensures that any unmasked floating- point exceptions the instruction may cause are handled before the processor has a chance to modify the instruction's results.
- FWAIT is an alternate mnemonic for WAIT.
- Refer to the Intel documentation for more information about when to use WAIT (FWAIT).
WBINVD - Write-Back and Invalidate Cache
- Details Table
|Encoding |Instruction |0|1|2|3|4|5|Description |----------+--------------+-+-+-+-+-+-+-------------------------------------- |0F 09 |WBINVD | | | | |X|X|Write-back and invalidate entire cache
- Description
The internal cache is flushed, and a special-function bus cycle is issued, which indicates that external cache should write-back its contents to main memory. Another special-function bus cycle follows, directing the external cache to flush itself.
- Operation
FLUSH INTERNAL CACHE SIGNAL EXTERNAL CACHE TO WRITE-BACK SIGNAL EXTERNAL CACHE TO FLUSH
- Protected Mode Exceptions
The WBINVD instruction is a privileged instruction; #GP(0) if the current privilege level is not 0.
- Virtual 8086 Mode Exceptions
- GP(0); the WBINVD instruction is a privileged instruction.
- Notes
INVD should be used with care. It does not write back modified cache lines; therefore, it can cause the data cache to become inconsistent with other memories in the system. Unless there is a specific requirement or benefit to invalidate a cache without writing back the modified lines (i.e., testing or fault recovery where cache coherency with main memory is not a concern), software should use the WBINVD instruction. This instruction is implementation-dependent; its function may be implemented differently on future Intel processors. It is the responsibility of hardware to respond to the external cache write -back and flush indications. This instruction is not supported on Intel386 processors. See the Intel documentation for information on detecting the processor type at runtime. See the Intel documentation for information on disabling the cache.
WRMSR - Write to Model Specific Register
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F 30 | WRMSR | X | Write the value in EDX:EAX to Model Specific Register indicated by ECX | 
- Description
The value in ECX specifies one of the 64-bit Model Specific Registers of the Pentium processor. The contents of EDX:EAX is copied into that Model-Specific Register. The high-order 32 bits are copied from EDX and the low-order 32 bits are copied from EAX. The following values are used to select model specific registers on the Pentium processor:
| VALUE | REGISTER NAME | DESCRIPTION | 
|---|---|---|
| 00H | Machine Check Address | Stores address of cycle causing the exception | 
| 01H | Machine Check Type | Stores cycle type of cycle causing the exception | 
For other values used to perform cache, TLB, and BTB testing and performance monitoring, see the Intel documentation.
- Operation
MSR[ECX] ← EDX:EAX;
- Protected Mode Exceptions
- GP(0) if either the current privilege level is not 0 or the value in ECX does not specify a Model-Specific Register that is implemented in the Pentium processor.
- Real Address Mode Exceptions
- GP(0) if the value in ECX does not specify a Model-Specific Register that is implemented in the Pentium processor. No error code is pushed.
- Virtual 8086 Mode Exceptions
- GP(0) if instruction execution is attempted.
- Notes
Always set undefined or reserved bits to the value previously read. WRMSR is used to write the content of Model-Specific Registers that control functions for testability, execution tracing, performance monitoring, and machine check errors. Refer to the Pentium(TM) Processor Data Book for more information. The values 3H, 0FH, and values above 13H are reserved. Do not execute WRMSR with reserved values in ECX.
XADD - Exchange and Add
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 0F C0 /r | XADD r/m8,r8 | X | X | Exchange byte register and r/m byte; load sum into r/m byte | ||||
| 0F C1 /r | XADD r/m16,r16 | X | X | Exchange word register and r/m word; load sum into r/m word | ||||
| 0F C1 /r | XADD r/m32,r32 | X | X | Exchange dword register and r/m dword; load sum into r/m dword | 
- Description
The XADD instruction loads DEST into SRC, and then loads the sum of DEST and the original value of SRC into DEST.
- Operation
TEMP ← SRC + DEST SRC ← DEST DEST ← TEMP
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| * | * | * | * | * | * | 
The CF, PF, AF, SF, ZF, and OF flags are affected as if an ADD instruction had been executed.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #NM if either EM or TS in CR0 is set, #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in real-address mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Notes
This instruction can be used with a LOCK prefix. The Intel386 DX microprocessor does not implement this instruction. If this instruction is used, you should provide an equivalent code sequence that runs on an Intel386 DX processor as well. See the Intel documentation for details on how to detect a particular processor at runtime.
XCHG - Exchange Register/Memory with Register
- Details Table
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 90+rw | XCHG AX,r16 | X | X | X | X | X | X | Exchange word register with AX | 
| 90+rd | XCHG EAX,r32 | X | X | X | Exchange dword register with EAX | |||
| 90+rw | XCHG r16,AX | X | X | X | X | X | X | Exchange word register with AX | 
| 90+rd | XCHG r32,EAX | X | X | X | Exchange dword register with EAX | |||
| 86 /r | XCHG r/m8,r8 | X | X | X | X | X | X | Exchange byte register with EA byte | 
| 86 /r | XCHG r8,r/m8 | X | X | X | X | X | X | Exchange byte register with EA byte | 
| 87 /r | XCHG r/m16,r16 | X | X | X | X | X | X | Exchange word register with EA word | 
| 87 /r | XCHG r/m32,r32 | X | X | X | Exchange dword register with EA dword | |||
| 87 /r | XCHG r16,r/m16 | X | X | X | X | X | X | Exchange word register with EA word | 
| 87 /r | XCHG r32,r/m32 | X | X | X | Exchange dword register with EA dword | 
- Description
The XCHG instruction exchanges two operands. The operands can be in either order. If a memory operand is involved, the LOCK# signal is asserted for the duration of the exchange, regardless of the presence or absence of the LOCK prefix or of the value of the IOPL.
- Operation
temp ← DEST DEST ← SRC SRC ← temp
- Protected Mode Exceptions
- GP(0) if either operand is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Note
XCHG can be used for BSWAP for 16-bit data.
XLAT/XLATB - Table Look-up Translation
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| D7 | XLAT m8 | X | X | X | X | X | X | Set AL to memory byte DS:[(E)BX + unsigned AL] | 
| D7 | XLATB | X | X | X | X | X | X | Set AL to memory byte DS:[(E)BX + unsigned AL] | 
- Description
The XLAT instruction changes the AL register from the table index to the table entry. The AL register should be the unsigned index into a table addressed by the DS:BX register pair (for an address-size attribute of 16 bits) or the DS:EBX register pair (for an address-size attribute of 32 bits ). The operand to the XLAT instruction allows for the possibility of a segment override. The XLAT instruction uses the contents of the BX register even if they differ from the offset of the operand. The offset of the operand should have been moved into the BX or EBX register with a previous instruction. The no-operand form, the XLATB instruction, can be used if the BX or EBX table will always reside in the DS segment.
- Operation
IF AddressSize = 16 THEN AL ← (BX + ZeroExtend(AL)) ELSE (* AddressSize = 32 *) AL ← (EBX + ZeroExtend(AL)); FI;
- Protected Mode Exceptions
- GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS(0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
XOR - Logical Exclusive OR
| Encoding | Instruction | 0 | 1 | 2 | 3 | 4 | 5 | Description | 
|---|---|---|---|---|---|---|---|---|
| 34 ib | XOR AL,imm8 | X | X | X | X | X | X | Exclusive-OR immediate byte to AL | 
| 35 iw | XOR AX,imm16 | X | X | X | X | X | X | Exclusive-OR immediate word to AX | 
| 35 id | XOR EAX,imm32 | X | X | X | Exclusive-OR immediate dword to EAX | |||
| 80 /6 ib | XOR r/m8,imm8 | X | X | X | X | X | X | Exclusive-OR immediate byte to r/m byte | 
| 81 /6 iw | XOR r/m16,imm16 | X | X | X | X | X | X | Exclusive-OR immediate word to r/mword | 
| 81 /6 id | XOR r/m32,imm32 | X | X | X | Exclusive-OR immediate dword to r/m dword | |||
| 83 /6 ib | XOR r/m16,imm8 | X | X | X | XOR sign-extended immediate byte to r/m word | |||
| 83 /6 ib | XOR r/m32,imm8 | X | X | X | XOR sign-extended immediate byte with r/m dword | |||
| 30 /r | XOR r/m8,r8 | X | X | X | X | X | X | Exclusive-OR byte register to r/m byte | 
| 31 /r | XOR r/m16,r16 | X | X | X | X | X | X | Exclusive-OR word register to r/m word | 
| 31 /r | XOR r/m32,r32 | X | X | X | Exclusive-OR dword register to r/m dword | |||
| 32 /r | XOR r8,r/m8 | X | X | X | X | X | X | Exclusive-OR r/m byte to byte register | 
| 33 /r | XOR r16,r/m16 | X | X | X | X | X | X | Exclusive-OR r/m word to word register | 
| 33 /r | XOR r32,r/m32 | X | X | X | Exclusive-OR r/m dword to dword register | 
- Description
The XOR instruction computes the exclusive OR of the two operands. Each bit of the result is 1 if the corresponding bits of the operands are different; each bit is 0 if the corresponding bits are the same. The answer replaces the first operand.
- Operation
DEST ← LeftSRC XOR RightSRC CF ← 0 OF ← 0
- Flags Affected
| OF | DF | IF | SF | ZF | AF | PF | CF | 
|---|---|---|---|---|---|---|---|
| 0 | * | * | ? | * | 0 | 
The CF and OF flags are cleared; the SF, ZF, and PF flags are set according to the result; the AF flag is undefined.
- Protected Mode Exceptions
- GP(0) if the result is in a nonwritable segment; #GP(0) for an illegal memory operand effective address in the CS, DS, ES, FS, or GS segments; #SS (0) for an illegal address in the SS segment; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.
- Real Address Mode Exceptions
Interrupt 13 if any part of the operand would lie outside of the effective address space from 0 to 0FFFFH.
- Virtual 8086 Mode Exceptions
Same exceptions as in Real Address Mode; #PF(fault-code) for a page fault; #AC for unaligned memory reference if the current privilege level is 3.