

## Intel® 64 and IA-32 Architectures Software Developer's Manual

Volume 1: Basic Architecture



Figure 3-2. 64-Bit Mode Execution Environment

- Control registers The five control registers (CR0 through CR4) determine the operating mode of the processor and the characteristics of the currently executing task. See Chapter 2, "System Architecture Overview," in the Intel® 64 and IA-32 Architectures Software Developer's Manual, Volume 3A.
- Memory management registers The GDTR, IDTR, task register, and LDTR specify the locations of data structures used in protected mode memory management. See Chapter 2, "System Architecture Overview," in the Intel® 64 and IA-32 Architectures Software Developer's Manual, Volume 3A.
- Debug registers The debug registers (DR0 through DR7) control and allow monitoring of the processor's debugging operations. See in the Intel® 64 and IA-32 Architectures Software Developer's Manual, Volume 3B.
- Memory type range registers (MTRRs) The MTRRs are used to assign memory types to regions of memory. See the sections on MTRRs in the Intel® 64 and IA-32 Architectures Software Developer's Manual, Volumes 3A & 3B.
- Machine specific registers (MSRs) The processor provides a variety of machine specific registers that are
  used to control and report on processor performance. Virtually all MSRs handle system related functions and
  are not accessible to an application program. One exception to this rule is the time-stamp counter. The MSRs
  are described in Chapter 35, "Model-Specific Registers (MSRs)," of the Intel® 64 and IA-32 Architectures
  Software Developer's Manual, Volume 3C.
- Machine check registers The machine check registers consist of a set of control, status, and errorreporting MSRs that are used to detect and report on hardware (machine) errors. See Chapter 15, "Machine-Check Architecture," of the Intel® 64 and IA-32 Architectures Software Developer's Manual, Volume 3A.
- Performance monitoring counters The performance monitoring counters allow processor performance events to be monitored. See Chapter 23, "Introduction to Virtual-Machine Extensions," in the Intel® 64 and IA-32 Architectures Software Developer's Manual, Volume 3C.

The remainder of this chapter describes the organization of memory and the address space, the basic program execution registers, and addressing modes. Refer to the following chapters in this volume for descriptions of the other program execution resources shown in Figure 3-1:

- x87 FPU registers See Chapter 8, "Programming with the x87 FPU."
- MMX Registers See Chapter 9, "Programming with Intel® MMX™ Technology."
- XMM registers See Chapter 10, "Programming with Streaming SIMD Extensions (SSE)," Chapter 11,
  "Programming with Streaming SIMD Extensions 2 (SSE2)," and Chapter 12, "Programming with SSE3, SSSE3,
  SSE4 and AESNI."
- Stack implementation and procedure calls See Chapter 6, "Procedure Calls, Interrupts, and Exceptions."

Conditional move if parity/Conditional move if parity even

QMOVNP/CMOVPO Conditional move if not parity/Conditional move if parity odd

XCHG Exchange BSWAP Byte swap

XADD Exchange and add

CMPXCHG Compare and exchange

CMPXCHG8B Compare and exchange 8 bytes

PUSH Push onto stack POP Pop off of stack

PUSHA/PUSHAD Push general-purpose registers onto stack POPA/POPAD Pop general-purpose registers from stack

CONVERT word to doubleword/Convert doubleword to quadword

CBW/CWDE

Convert byte to word/Convert word to doubleword in EAX register

MOVSX Move and sign extend MOVZX Move and zero extend

## 5.1.2 Binary Arithmetic Instructions

The binary arithmetic instructions perform basic binary integer computations on byte, word, and doubleword integers located in memory and/or the general purpose registers.

ADD Integer add
ADC Add with carry
SUB Subtract

SBB Subtract with borrow

IMUL Signed multiply
MUL Unsigned multiply
IDIV Signed divide
DIV Unsigned divide

INC Increment