beautypg.com

Cmpxchg-compare and exchange, Cmpxchg—compare and exchange – Intel 253666-024US User Manual

Page 196

background image

3-150 Vol. 2A

CMPXCHG—Compare and Exchange

INSTRUCTION SET REFERENCE, A-M

CMPXCHG—Compare and Exchange

Description

Compares the value in the AL, AX, EAX, or RAX register with the first operand (desti-
nation operand). If the two values are equal, the second operand (source operand) is
loaded into the destination operand. Otherwise, the destination operand is loaded
into the AL, AX, EAX or RAX register. RAX register is available only in 64-bit mode.
This instruction can be used with a LOCK prefix to allow the instruction to be
executed atomically. To simplify the interface to the processor’s bus, the destination
operand receives a write cycle without regard to the result of the comparison. The
destination operand is written back if the comparison fails; otherwise, the source
operand is written into the destination. (The processor never produces a locked read
without also producing a locked write.)

Opcode

Instruction

64-Bit

Mode

Compat/

Leg Mode

Description

0F B0/r

CMPXCHG r/m8, r8 Valid

Valid*

Compare AL with r/m8. If

equal, ZF is set and r8 is

loaded into r/m8. Else, clear

ZF and load r/m8 into AL.

REX + 0F B0/r

CMPXCHG

r/m8**,r8

Valid

N.E.

Compare AL with r/m8. If

equal, ZF is set and r8 is

loaded into r/m8. Else, clear

ZF and load r/m8 into AL.

0F B1/r

CMPXCHG r/m16,

r16

Valid

Valid*

Compare AX with r/m16. If

equal, ZF is set and r16 is

loaded into r/m16. Else,

clear ZF and load r/m16

into AX.

0F B1/r

CMPXCHG r/m32,

r32

Valid

Valid*

Compare EAX with r/m32.

If equal, ZF is set and r32 is

loaded into r/m32. Else,

clear ZF and load r/m32

into EAX.

REX.W + 0F B1/r

CMPXCHG r/m64,

r64

Valid

N.E.

Compare RAX with r/m64.

If equal, ZF is set and r64 is

loaded into r/m64. Else,

clear ZF and load r/m64

into RAX.

NOTES:

* See the IA-32 Architecture Compatibility section below.
** In 64-bit mode, r/m8 can not be encoded to access the following byte registers if a REX prefix is

used: AH, BH, CH, DH.