# LOCK - Assert LOCK# Signal Prefix

|        |             | Clocks | Description                                  |
|--------|-------------|--------|----------------------------------------------|
| Opcode | Instruction | CIOCKS | Assert LOCK# signal for the next instruction |
| LOCK   | LOCK        | 1      | Assert LOCK# signal for the floor methods    |

## Description

The LOCK prefix causes the LOCK# signal of the i486 processor to be asserted during execution of the instruction that follows it. In a multiprocessor environment, this signal can be used to ensure that the i486 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 i486 processor is the BTS instruction.

The LOCK prefix functions only with the following instructions:

| DTC DTD DTC        | -             | mem, reg/imm |
|--------------------|---------------|--------------|
| BTS, BTR, BTC      |               | reg, mem     |
| XCHG               |               | mem, reg     |
| ADD, OR, ADC, SBB, | AND, SUB, XOR | mem, reg/imm |
| NOT, NEG, INC, DEC |               | mem          |
| NOT, NEO, INC, DEC |               |              |

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.

# Flags Affected

None

# **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

or the next instruction

o be asserted during ironment, this signal any shared memory y used to implement

ised with any instruc-

resence or absence of

t of the memory field.

I in the "Description" ent (locked) instruction

ed in the "Description" it (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



## BTS - Bit Test and Set

| Opcode      | Instruction    | Clocks | Description                    |
|-------------|----------------|--------|--------------------------------|
| OF AB       | BTS r/m16,r16  | 6/13   | Save bit in carry flag and set |
| OF AB       | BTS r/m32,r32  | 6/13   | Save bit in carry flag and set |
| OF BA /5 ib | BTS r/m16,imm8 | 6/8    | Save bit in carry flag and set |
| OF BA /5 ib | BTS r/m32,imm8 | 6/8    | Save bit in carry flag and set |

#### Operation

CF ← BIT[LeftSRC, RightSRC];
BIT[LeftSRC, RightSRC] ← 1;

## 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.

## Flags Affected

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 using the immediate bit offset field in combination with the

ag and set ag and set ag and set

ase (first operand) and 1 in the bit.

llegal memory operand for an illegal address in med memory reference

effective address space

a page fault; #AC for

tant in the instruction is used in the instrucbit offsets is 0..31. This trings, this immediate diate bit offsets larger combination with the displacement field of the memory operand. The low-order 3 to 5 bits of the immediate bit offset are stored in the immediate bit offset field, and the high order 27 to 29 bits are shifted and combined with the byte displacement in the addressing mode.

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.

oprocessor does not ovide an equivalent or detecting an i486

# XCHG - Exchange Register/Memory with Register

| Opcode                                                                            | Instruction                                                                                                                                                        | Clocks                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 90 + r<br>90 + r<br>90 + r<br>90 + r<br>86 /r<br>86 /r<br>87 /r<br>37 /r<br>37 /r | XCHG AX,r16<br>XCHG r16,AX<br>XCHG EAX,r32<br>XCHG r32,EAX<br>XCHG r/m8,r8<br>XCHG r8,r/m8<br>XCHG r/m16,r16<br>XCHG r16,r/m16<br>XCHG r/m32,r32<br>XCHG r32,r/m32 | 3<br>3<br>3<br>3<br>3/5<br>3/5<br>3/5<br>3/5<br>3/5<br>3/5 | Exchange word register with AX Exchange word register with AX Exchange dword register with EAX Exchange dword register with EAX Exchange byte register with EA byte Exchange byte register with EA byte Exchange word register with EA word Exchange word register with EA word Exchange dword register with EA dword Exchange dword register with EA dword Exchange dword register with EA dword |

## Operation

temp ← DEST DEST ← SRC SRC ← temp

### 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.

## Flags Affected

None

## **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