X86 Assembly/X86 Instructions

These pages will discuss, in detail, the different instructions available in the basic x86 instruction set. For ease, and to decrease the page size, the different instructions will be broken up into groups, and discussed individually.


 * Data Transfer Instructions
 * Control Flow Instructions
 * Arithmetic Instructions
 * Logic Instructions
 * Shift and Rotate Instructions
 * Other Instructions
 * x86 Interrupts

For more info, see the resources section.

Conventions
The following template will be used for instructions that take no operands:

The following template will be used for instructions that take 1 operand:

The following template will be used for instructions that take 2 operands. Notice how the format of the instruction is different for different assemblers.

The following template will be used for instructions that take 3 operands. Notice how the format of the instruction is different for different assemblers.

Suffixes
Some instructions, especially when built for non-Windows platforms (i.e. Unix, Linux, etc.), require the use of suffixes to specify the size of the data which will be the subject of the operation. Some possible suffixes are:


 * (byte) = 8 bits.
 * (word) = 16 bits.
 * (long) = 32 bits.
 * (quad) = 64 bits.

An example of the usage with the mov instruction on a 32-bit architecture, GAS syntax:

On Intel Syntax you don't have to use the suffix. Based on the register name and the used immediate value the compiler knows which data size to use.

X86アセンブラ/x86の命令