

# INTRODUCTION TO IA-32

Jo, Heeseung

# IA-32 Processors

---

## Evolutionary design

- Starting in 1978 with 8086
- Added more features as time goes on
- Still support old features, although obsolete
- Totally dominate computer market

## Complex Instruction Set Computer (**CISC**)

- Many different instructions with many different formats
- Hard to match performance of Reduced Instruction Set Computers (RISC)
- But, Intel has done just that!

RISC - Instructions ↓ time ↑

# Intel's Backward Compatibility

Instruction set doesn't change

But they do accrete more instructions



# IA-32 History

## Evolution with backward compatibility

|      |                    |                |
|------|--------------------|----------------|
| 1978 | 8086               | x86 is born    |
| 1980 | 8087               | x87 is born    |
| 1985 | 80386              | "IA-32"        |
| 1995 | Pentium Pro        | PAE            |
| 1997 | Pentium MMX        | MMX            |
| 1999 | Pentium III        | SSE            |
| 2000 | Pentium 4          | SSE2           |
| 2004 | Pentium 4 Prescott | SSE3, Intel 64 |
| 2005 | Pentium 4 662      | Intel VT       |
| 2006 | Core 2             | SSSE3          |
| 2008 | Core 2 Penryn      | SSE4.1         |
| 2008 | Core i7            | SSE4.2         |

# Intel x86 Processors: Overview



IA: often redefined as latest Intel architecture

# Intel x86 Evolution: Milestones

| <i>Name</i> | <i>Date</i> | <i>Transistors</i> | <i>MHz</i>                                                                                                                                                                                                                                   |
|-------------|-------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8086        | 1978        | 29K                | 5-10                                                                                                                                                                                                                                         |
|             |             |                    | <ul style="list-style-type: none"><li>• First 16-bit processor (Basis for IBM PC &amp; DOS)</li><li>• 1MB address space</li></ul>                                                                                                            |
| 386         | 1985        | 275K               | 16-33                                                                                                                                                                                                                                        |
|             |             |                    | <ul style="list-style-type: none"><li>• First 32-bit processor, referred to as IA32</li><li>• Added "flat addressing"</li><li>• Capable of running Unix</li><li>• 32-bit Linux/gcc uses no instructions introduced in later models</li></ul> |
| Pentium 4F  | 2004        | 125M               | 2800-3800                                                                                                                                                                                                                                    |
|             |             |                    | <ul style="list-style-type: none"><li>• First 64-bit processor, referred to as x86-64</li></ul>                                                                                                                                              |
| Core i7     | 2008        | 731M               | 2667-3333                                                                                                                                                                                                                                    |

# Basic Execution Environment

## Application Programming Registers



### Segment registers

|    |               |
|----|---------------|
| 15 | 0             |
| CS | seg. selector |
| DS | seg. selector |
| SS | seg. selector |
| ES | seg. selector |
| FS | seg. selector |
| GS | seg. selector |

### Control registers

|     |   |
|-----|---|
| 31  | 0 |
| CR0 |   |
| CR1 |   |
| CR2 |   |
| CR3 |   |
| CR4 |   |

### System Segment Registers

|      |               |
|------|---------------|
| 15   | 0             |
| TR   | seg. selector |
| LDTR | seg. selector |

### System Table Registers

|      |                     |       |             |   |
|------|---------------------|-------|-------------|---|
| 47   | linear base address | 16 15 | table limit | 0 |
| IDTR | linear base address |       | table limit |   |

# Integer Registers (IA32)



# General-Purpose Registers

EAX, EBX, ECX, EDX, ESI, EDI, ESP, EBP

**EAX:** Accumulator for operands and results data

**EBX:** Pointer to data in the DS segment

**ECX:** Counter for string and loop operations

**EDX:** I/O pointer

**ESI:** Pointer to data in the segment pointed to by the DS register; Source pointer for string operations

**EDI:** Pointer to data in the segment pointed to by the ES register; Destination pointer for string operations

**ESP:** Stack pointer (in the SS segment)

**EBP:** Pointer to data on the stack (in the SS segment)

# EFLAGS Register (1)



S Indicates a Status Flag

C Indicates a Control Flag

X Indicates a System Flag

Reserved bit positions. DO NOT USE.  
Always set to values previously read.

□ → ↗

# EFLAGS Register (2)

## Status flags

**CF (Carry):** set if an arithmetic operation generates a carry or a borrow; indicates an overflow condition for unsigned-integer arithmetic

**PF (Parity):** set if the least-significant byte of the result contains an even number of 1 bits

**AF (Adjust):** set if an arithmetic operation generates a carry or a borrow out of bit 3 of the result; used in binary-coded decimal (BCD) arithmetic

**ZF (Zero):** set if the result is zero

**SF (Sign):** set equal to the most-significant bit of the result

**OF (Overflow):** set if the integer result is too large a positive number or too small a negative number to fit in the destination operand; indicates an overflow condition for signed-integer arithmetic

**DF (Direction):** setting the DF causes the string instructions to auto-decrement; set and cleared by STD/CLD instructions

# Instruction Pointer

---

## EIP Register (Program Counter, PC)

- Contains the offset in the current code segment for the next instruction to be executed
  - Advanced from one instruction boundary to the next in straightline code, or
  - Moved ahead or backwards by instructions such as JMP, Jcc, CALL, RET, and IRET
- Cannot be accessed directly by software
  - EIP is controlled implicitly by control transfer instructions, interrupts, and exceptions
- Because of instruction prefetching, an instruction address read from the bus does not match the value in the EIP register

# Assembly Characteristics (1)

## Minimal data types

- "Integer" data of 1, 2, 4, or 8 bytes
  - Data values
  - Addresses (untyped pointers)
- "Floating point" data of 4, 8, or 10 bytes
- No aggregate types such as arrays or structures
  - Just contiguously allocated bytes in memory
- (cf.) In IA-32, a "word" means 16-bit data



# Assembly Characteristics (2)

---

## Three primitive operations

- Perform an arithmetic/logical function on register or memory data
- Transfer data between memory and register
  - Load data from memory into register
  - Store register data into memory
- Transfer control
  - Unconditional jumps
  - Conditional branches
  - Procedure calls and returns

# IA-32 Reference

---

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

- Volume 1: Basic Architecture
- Volume 2A, 2B: Instruction Set Reference
- Volume 3A, 3B: System Programming Guide