# How do modern processors work?

Under the hood of the Intel Core 2 Duo

vasko.anton@gmail.com

#### **Description**

- dual core
- 64-bit (EMT64 = AMD64)
- 4-issue
- out-of-order
- 32 KB L1 instruction cache
- 2 x 32 KB dual ported L1 data cache
- shared 4MB L2 cache
- clock about 3GHz



#### Sub-blocks

Front end

Out-of-order Engine

Memory Subsystem

#### **The Front End**



## **Macro-op Fusion**



## µ-ops Fusion

- if some instructions requires two operations => 2 μops
- sometimes they can be fused into 1 µop
- 1 record through the pipeline, split before execution units/memory
- Macro-ops fusion for different class of instruction

## **Out-of-order Engine**



False dependency:mm0 = mm1 + mm2, mm2 = mm3 - mm1

#### **Execution Units**



SSE instructions are executed in one cycle only!

## **Memory System**



## Features of Memory System

- Prefetching (software, hardware)
- Directly data transfer between cores' L1 data caches
- Shared L2 cache
- Memory Reorder Buffer (MOB)

## **Memory Aliasing Problem**

only out-of-order CPU



#### **Old solution**

- 1. All loads are delayed if a store is in-flight with an unknown address
- 2. Loads cannot proceed ahead of an aliased store data µop
- 3. A store cannot be moved in front of another store
- safe but pessimistic

#### **New solution**

- 97+% of loads and stores do not alias ([1])
- dynamic alias predictor
- loads can be speculative moved
- if bad prediction -> exception and flush of the pipeline (stall)

#### Conclusion

- Many features are already available in AMD processors
- SSE is becoming important (1 cycle)
- 32-bit CPUs are history AMD64, EMT64
- Not speed, but parallelism:
- 1. Logical SSE
- 2. Physical dual core, quad core ...

## **Bibliography**

- 1. http://www.realworldtech.com/includes/templates/articles.cfm?ArticleID=RWT030906143144
- 2. http://www.chiparchitect.com/news/2003\_09\_21\_Detailed\_Arc hitecture\_of\_AMDs\_64bit\_Core.html
- 3. http://www.svethardware.cz/art\_doc-3B56A5C905E08771C125715E00793B42.html

## Thank you for your attention!

vasko.anton@gmail.com