AMD64 Technology

|                  | Registers <sup>1</sup>                    |                                                              |                  | Name         | Implicit Uses                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|------------------|-------------------------------------------|--------------------------------------------------------------|------------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Low 8-Bit        | 16-Bit                                    | 32-Bit                                                       | 64-Bit           | , italiic    |                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| AL               | AX                                        | EAX                                                          | RAX <sup>2</sup> | Accumulator  | <ul> <li>Operand for decimal<br/>arithmetic, multiply, divide,<br/>string, compare-and-<br/>exchange, table-translation,<br/>and I/O instructions.</li> <li>Special accumulator encoding<br/>for ADD, XOR, and MOV<br/>instructions.</li> <li>Used with EDX to hold double-<br/>precision operands.</li> </ul> |  |  |  |  |  |  |
|                  |                                           | <ul> <li>CPUID processor-feature<br/>information.</li> </ul> |                  |              |                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| BL               | BX                                        | EBX                                                          | RBX <sup>2</sup> | Base         | <ul> <li>Address generation in 16-bit<br/>code.</li> <li>Memory address for XLAT<br/>instruction.</li> </ul>                                                                                                                                                                                                   |  |  |  |  |  |  |
|                  |                                           |                                                              |                  |              | <ul> <li>CPUID processor-feature<br/>information.</li> </ul>                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| CL               | сх                                        | ECX                                                          | RCX <sup>2</sup> | Count        | <ul> <li>Bit index for shift and rotate<br/>instructions.</li> <li>Iteration count for loop and<br/>repeated string instructions.</li> <li>Jump conditional if zero.</li> <li>CPUID processor-feature<br/>information.</li> </ul>                                                                              |  |  |  |  |  |  |
| DL               | DX                                        | EDX                                                          | RDX <sup>2</sup> | I/O Address  | <ul> <li>Operand for multiply and divide instructions.</li> <li>Port number for I/O instructions.</li> <li>Used with EAX to hold double-precision operands.</li> <li>CPUID processor-feature information.</li> </ul>                                                                                           |  |  |  |  |  |  |
| SIL <sup>2</sup> | SI                                        | ESI                                                          | RSI <sup>2</sup> | Source Index | <ul> <li>Memory address of source<br/>operand for string instructions.</li> <li>Memory index for 16-bit<br/>addresses.</li> </ul>                                                                                                                                                                              |  |  |  |  |  |  |
|                  | aded registers ha<br>ble only in 64-bit r |                                                              | 95.              |              |                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |

# Table 3-1. Implicit Uses of GPRs

#### AMD64 Technology

|                        | Regis                 | sters <sup>1</sup>     |                      | Name                 | Implicit Uses                                                                                                                          |
|------------------------|-----------------------|------------------------|----------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Low 8-Bit              | 16-Bit                | 32-Bit                 | 64-Bit               | Name                 | implicit 03es                                                                                                                          |
| DIL <sup>2</sup>       | DI                    | EDI                    | RDI <sup>2</sup>     | Destination<br>Index | <ul> <li>Memory address of destination<br/>operand for string instructions.</li> <li>Memory index for 16-bit<br/>addresses.</li> </ul> |
| BPL <sup>2</sup>       | BP                    | EBP                    | RBP <sup>2</sup>     | Base Pointer         | <ul> <li>Memory address of stack-<br/>frame base pointer.</li> </ul>                                                                   |
| SPL <sup>2</sup>       | SP                    | ESP                    | RSP <sup>2</sup>     | Stack Pointer        | <ul> <li>Memory address of last stack<br/>entry (top of stack).</li> </ul>                                                             |
| R8B-R10B <sup>2</sup>  | R8W–R10W <sup>2</sup> | R8D-R10D <sup>2</sup>  | R8–R10 <sup>2</sup>  | None                 | No implicit uses                                                                                                                       |
| R11B <sup>2</sup>      | R11W <sup>2</sup>     | R11D <sup>2</sup>      | R11 <sup>2</sup>     | None                 | <ul> <li>Holds the value of RFLAGS on<br/>SYSCALL/SYSRET.</li> </ul>                                                                   |
| R12B-R15B <sup>2</sup> | R12W–R15W<br>2        | R12D-R15D <sup>2</sup> | R12–R15 <sup>2</sup> | None                 | No implicit uses                                                                                                                       |
| Note:<br>1. Gray-sha   | aded registers ha     | ve no implicit use     | S.                   |                      |                                                                                                                                        |

| Table 3-1. | Implicit Use | s of GPRs | (continued) |
|------------|--------------|-----------|-------------|
|------------|--------------|-----------|-------------|

2. Accessible only in 64-bit mode.

Arithmetic Operations. Several forms of the add, subtract, multiply, and divide instructions use AL or rAX implicitly. The multiply and divide instructions also use the concatenation of rDX:rAX for double-sized results (multiplies) or quotient and remainder (divides).

Sign-Extensions. The instructions that double the size of operands by sign extension (for example, CBW, CWDE, CDQE, CWD, CDQ, CQO) use rAX register implicitly for the operand. The CWD, CDQ, and CQO instructions also uses the rDX register.

**Special MOVs.** The MOV instruction has several opcodes that implicitly use the AL or rAX register for one operand.

String Operations. Many types of string instructions use the accumulators implicitly. Load string, store string, and scan string instructions use AL or rAX for data and rDI or rSI for the offset of a memory address.

I/O-Address-Space Operations. The I/O and string I/O instructions use rAX to hold data that is received from or sent to a device located in the I/O-address space. DX holds the device I/O-address (the port number).

Table Translations. The table translate instruction (XLATB) uses AL for an memory index and rBX for memory base address.

**Compares and Exchanges.** Compare and exchange instructions (CMPXCHG) use the AL or rAX register for one operand.

**Decimal Arithmetic.** The decimal arithmetic instructions (AAA, AAD, AAM, AAS, DAA, DAS) that adjust binary-coded decimal (BCD) operands implicitly use the AL and AH register for their operations.

**Shifts and Rotates.** Shift and rotate instructions can use the CL register to specify the number of bits an operand is to be shifted or rotated.

**Conditional Jumps.** Special conditional-jump instructions use the rCX register instead of flags. The JCXZ and JrCXZ instructions check the value of the rCX register and pass control to the target instruction when the value of rCX register reaches 0.

**Repeated String Operations.** With the exception of I/O string instructions, all string operations use rSI as the source-operand pointer and rDI as the destination-operand pointer. I/O string instructions use rDX to specify the input-port or output-port number. For repeated string operations (those preceded with a repeat-instruction prefix), the rSI and rDI registers are incremented or decremented as the string elements are moved from the source location to the destination. Repeat-string operations also use rCX to hold the string length, and decrement it as data is moved from one location to the other.

**Stack Operations.** Stack operations make implicit use of the rSP register, and in some cases, the rBP register. The rSP register is used to hold the top-of-stack pointer (or simply, stack pointer). rSP is decremented when items are pushed onto the stack, and incremented when they are popped off the stack. The ENTER and LEAVE instructions use rBP as a stack-frame base pointer. Here, rBP points to the last entry in a data structure that is passed from one block-structured procedure to another.

The use of rSP or rBP as a base register in an address calculation implies the use of SS (stack segment) as the default segment. Using any other GPR as a base register without a segment-override prefix implies the use of the DS data segment as the default segment.

The push all and pop all instructions (PUSHA, PUSHAD, POPA, POPAD) implicitly use all of the GPRs.

**CPUID Information.** The CPUID instruction makes implicit use of the EAX, EBX, ECX, and EDX registers. Software loads a function code into EAX, executes the CPUID instruction, and then reads the associated processor-feature information in EAX, EBX, ECX, and EDX.

### 3.1.4 Flags Register

Figure 3-5 on page 34 shows the 64-bit RFLAGS register and the flag bits visible to application software. Bits 15–0 are the FLAGS register (accessed in legacy real and virtual-8086 modes), bits 31–0 are the EFLAGS register (accessed in legacy protected mode and compatibility mode), and bits 63–0 are the RFLAGS register (accessed in 64-bit mode). The name *rFLAGS* refers to any of the three register widths, depending on the current software context.

## 

AMD64 Technology

| 63   |          |                             |            |    |        |        |   |   |        |        |   |        |   |        |   | 32     |
|------|----------|-----------------------------|------------|----|--------|--------|---|---|--------|--------|---|--------|---|--------|---|--------|
|      |          | Rese                        | erved, RAZ |    |        |        |   |   |        |        |   |        |   |        |   |        |
| 31   |          |                             |            | 12 | 11     | 10     | 9 | 8 | 7      | 6      | 5 | 4      | 3 | 2      | 1 | 0      |
|      | Se       | e Volume 2 for System Flags |            |    | O<br>F | D<br>F |   |   | S<br>F | Z<br>F |   | A<br>F |   | P<br>F |   | C<br>F |
| Bits | Mnemonic | Description                 | R/W        |    |        |        |   |   |        |        |   |        |   |        |   |        |
| 11   | OF       | Overflow Flag               | R/W        |    |        |        |   |   |        |        |   |        |   |        |   |        |
| 10   | DF       | Direction Flag              | R/W        |    |        |        |   |   |        |        |   |        |   |        |   |        |
| 7    | SF       | Sign Flag                   | R/W        |    |        |        |   |   |        |        |   |        |   |        |   |        |
| 6    | ZF       | Zero Flag                   | R/W        |    |        |        |   |   |        |        |   |        |   |        |   |        |
| 4    | AF       | Auxiliary Carry Flag        | R/W        |    |        |        |   |   |        |        |   |        |   |        |   |        |
|      |          | De vite a Elle a            | R/W        |    |        |        |   |   |        |        |   |        |   |        |   |        |
| 2    | PF       | Parity Flag                 | n/ v v     |    |        |        |   |   |        |        |   |        |   |        |   |        |

### Figure 3-5. rFLAGS Register—Flags Visible to Application Software

The low 16 bits (FLAGS portion) of rFLAGS are accessible by application software and hold the following flags:

- One control flag (the direction flag DF).
- Six status flags (carry flag CF, parity flag PF, auxiliary carry flag AF, zero flag ZF, sign flag SF, and overflow flag OF).

The direction flag (DF) flag controls the direction of string operations. The status flags provide result information from logical and arithmetic operations and control information for conditional move and jump instructions.

Bits 31–16 of the rFLAGS register contain flags that are accessible only to system software. These flags are described in "System Registers" in Volume 2. The highest 32 bits of RFLAGS are reserved. In 64-bit mode, writes to these bits are ignored. They are read as zeros (RAZ). The rFLAGS register is initialized to 02h on reset, so that all of the programmable bits are cleared to zero.

The effects that rFLAGS bit-values have on instructions are summarized in the following places:

- Conditional Moves (CMOV*cc*)—Table 3-4 on page 43.
- Conditional Jumps (*Jcc*)—Table 3-5 on page 55.
- Conditional Sets (SETcc)—Table 3-6 on page 59.

The effects that instructions have on rFLAGS bit-values are summarized in "Instruction Effects on RFLAGS" in Volume 3.