Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

Multiprocessing Wiki 20150330

Download as pdf or txt
Download as pdf or txt
You are on page 1of 96

Multiprocessing

Contents

1 Multiprocessing 1
1.1 Pre-history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.2 Key topics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.2.1 Processor symmetry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.2.2 Instruction and data streams . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.2.3 Processor coupling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.2.4 Multiprocessor Communication Architecture . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3 Flynn’s taxonomy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3.1 SISD multiprocessing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3.2 SIMD multiprocessing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.3.3 MISD multiprocessing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.3.4 MIMD multiprocessing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.4 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1.5 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3

2 Computer multitasking 5
2.1 Multiprogramming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
2.2 Cooperative multitasking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
2.3 Preemptive multitasking . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
2.4 Real time . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2.5 Multithreading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2.6 Memory protection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2.7 Memory swapping . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2.8 Programming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
2.9 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
2.10 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8

3 Symmetric multiprocessing 9
3.1 Design . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
3.2 History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
3.3 Uses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
3.4 Programming . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
3.5 Performance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10

i
ii CONTENTS

3.6 Systems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
3.6.1 Entry-level systems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10
3.6.2 Mid-level systems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
3.7 Alternatives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
3.8 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
3.9 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
3.10 External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12

4 Asymmetric multiprocessing 13
4.1 Background and history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
4.2 Burroughs B5000 and B5500 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
4.3 CDC 6500 and 6700 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
4.4 DECsystem-1055 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
4.5 PDP-11/74 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
4.6 VAX-11/782 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
4.7 Univac 1108-II . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
4.8 IBM System/370 model 168 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
4.9 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
4.10 Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
4.11 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
4.12 External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15

5 Non-uniform memory access 16


5.1 Basic concept . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
5.2 Cache coherent NUMA (ccNUMA) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
5.3 NUMA vs. cluster computing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
5.4 Software support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
5.5 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
5.6 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
5.7 External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18

6 Multi-core processor 19
6.1 Terminology . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
6.2 Development . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
6.2.1 Commercial incentives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
6.2.2 Technical factors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
6.2.3 Advantages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
6.2.4 Disadvantages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
6.3 Hardware . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
6.3.1 Trends . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
6.3.2 Architecture . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
6.4 Software effects . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
CONTENTS iii

6.4.1 Licensing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
6.5 Embedded applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
6.6 Hardware examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
6.6.1 Commercial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
6.6.2 Free . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
6.6.3 Academic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
6.7 Benchmarks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
6.8 Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
6.9 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
6.10 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
6.11 External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26

7 Intel Atom (CPU) 27


7.1 History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
7.2 Instruction set architecture . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
7.2.1 32-bit and 64-bit hardware support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
7.2.2 Intel 64 software support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
7.3 Availability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
7.4 Performance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
7.5 Bonnell microarchitecture . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
7.6 Collaborations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
7.7 Competition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
7.8 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
7.9 Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
7.10 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31
7.11 External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31

8 Intel Core 32
8.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
8.2 Enhanced Pentium M based . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
8.2.1 Core Duo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
8.2.2 Core Solo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32
8.3 64-bit Core microarchitecture based . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
8.3.1 Core 2 Solo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
8.3.2 Core 2 Duo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
8.3.3 Core 2 Quad . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
8.3.4 Core 2 Extreme . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
8.4 Nehalem microarchitecture based . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
8.4.1 Core i3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
8.4.2 Core i5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
8.4.3 Core i7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
8.5 Sandy Bridge microarchitecture based . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
iv CONTENTS

8.5.1 Core i3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
8.5.2 Core i5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
8.5.3 Core i7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
8.6 Ivy Bridge microarchitecture based . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
8.6.1 Core i3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
8.6.2 Core i5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
8.6.3 Core i7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
8.7 Haswell microarchitecture based . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
8.7.1 Core i3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.7.2 Core i5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.7.3 Core i7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.8 Broadwell microarchitecture based . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.8.1 Core i3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.8.2 Core i5 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.8.3 Core i7 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.8.4 Core M . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.9 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.10 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
8.11 External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37

9 List of Intel Core i5 microprocessors 38


9.1 Desktop processors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
9.1.1 Nehalem microarchitecture (1st generation) . . . . . . . . . . . . . . . . . . . . . . . . . 38
9.1.2 Westmere microarchitecture (1st generation) . . . . . . . . . . . . . . . . . . . . . . . . 38
9.1.3 Sandy Bridge microarchitecture (2nd generation) . . . . . . . . . . . . . . . . . . . . . . 38
9.1.4 Ivy Bridge microarchitecture (3rd generation) . . . . . . . . . . . . . . . . . . . . . . . . 39
9.1.5 Haswell microarchitecture (4th generation) . . . . . . . . . . . . . . . . . . . . . . . . . 39
9.2 Mobile processors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
9.2.1 Westmere microarchitecture (1st generation) . . . . . . . . . . . . . . . . . . . . . . . . 39
9.2.2 Sandy Bridge microarchitecture (2nd generation) . . . . . . . . . . . . . . . . . . . . . . 40
9.2.3 Ivy Bridge microarchitecture (3rd generation) . . . . . . . . . . . . . . . . . . . . . . . . 40
9.2.4 Haswell microarchitecture (4th generation) . . . . . . . . . . . . . . . . . . . . . . . . . 40
9.2.5 Broadwell microarchitecture (5th generation) . . . . . . . . . . . . . . . . . . . . . . . . 41
9.3 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
9.4 Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
9.5 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
9.6 External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41

10 Pentium Dual-Core 42
10.1 Processor cores . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
10.1.1 Yonah . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
10.1.2 Allendale . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
CONTENTS v

10.1.3 Merom-2M . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
10.1.4 Wolfdale-3M . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
10.1.5 Penryn-3M . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
10.2 Rebranding . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
10.3 Comparison to the Pentium D . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
10.4 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
10.5 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
10.6 External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44

11 Xeon 45
11.1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
11.2 P6-based Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
11.2.1 Pentium II Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
11.2.2 Pentium III Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
11.3 Netburst-based Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
11.3.1 Xeon (DP) & Xeon MP (32-bit) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
11.3.2 “Gallatin” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
11.3.3 Xeon (DP) & Xeon MP (64-bit) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
11.3.4 Dual-Core Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
11.4 Pentium M (Yonah) based Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
11.4.1 LV (ULV), “Sossaman” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
11.5 Core-based Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
11.5.1 Dual-Core . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
11.5.2 Quad-Core and Multi-Core Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
11.6 Nehalem-based Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
11.6.1 3400-series “Lynnfield” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
11.6.2 3400-series “Clarkdale” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
11.6.3 3500-series “Bloomfield” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
11.6.4 <span id="5500-series “Gainestown"">5500-series “Gainestown” . . . . . . . . . . . . . . 51
11.6.5 <span id="C3500/C5500-Series “Jasper Forest"">C3500/C5500-series “Jasper Forest” . . . 51
11.6.6 3600/5600-series “Gulftown” & “Westmere-EP” . . . . . . . . . . . . . . . . . . . . . . . 51
11.6.7 6500/7500-series “Beckton” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
11.6.8 E7-x8xx-series “Westmere-EX” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
11.7 Sandy Bridge– and Ivy Bridge–based Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
11.7.1 E3-12xx-series “Sandy Bridge” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
11.7.2 E3-12xx v2-series “Ivy Bridge” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
11.7.3 E5-14xx/24xx series “Sandy Bridge-EN” and E5-16xx/26xx/46xx-series “Sandy Bridge-EP” 52
11.7.4 E5-14xx v2/24xx v2 series “Ivy Bridge-EN” and E5-16xx v2/26xx v2/46xx v2 series “Ivy
Bridge-EP” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
11.7.5 E7-28xx v2/48xx v2/88xx v2 series “Ivy Bridge-EX” . . . . . . . . . . . . . . . . . . . . 52
11.8 Haswell-based Xeon . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
11.8.1 E3-12xx v3-series “Haswell” . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
vi CONTENTS

11.8.2 E5-16xx/26xx v3-series “Haswell-EP” . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53


11.9 Supercomputers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
11.10See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
11.11References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
11.12External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54

12 Distributed computing 55
12.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
12.1.1 Architecture . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
12.2 Parallel and distributed computing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
12.3 History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
12.4 Applications . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
12.5 Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
12.6 Theoretical foundations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
12.6.1 Models . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
12.6.2 An example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
12.6.3 Complexity measures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
12.6.4 Other problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
12.6.5 Properties of distributed systems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
12.7 Coordinator election . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
12.7.1 Bully algorithm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
12.7.2 Chang and Roberts algorithm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
12.8 Architectures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
12.9 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
12.10Notes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
12.11References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
12.12Further reading . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
12.13External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63

13 Service-oriented architecture 64
13.1 Definitions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
13.2 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
13.3 SOA framework . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
13.4 Design concept . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
13.5 Principles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
13.5.1 Service architecture . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
13.5.2 Service composition architecture . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
13.5.3 Service inventory architecture . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
13.5.4 Service-oriented enterprise architecture . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
13.6 Web services approach . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
13.7 Web service protocols . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
13.8 Other SOA concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
CONTENTS vii

13.9 Organizational benefits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69


13.10Challenges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
13.11Criticisms . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
13.12SOA Manifesto . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
13.13Extensions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
13.13.1 SOA, Web 2.0, services over the messenger, and mashups . . . . . . . . . . . . . . . . . . 71
13.13.2 Web 2.0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
13.13.3 Digital nervous system . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
13.14See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
13.15References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
13.16External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74

14 Massively multiplayer online game 75


14.1 History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
14.2 Virtual economies . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 76
14.2.1 Technical aspect . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
14.3 Game types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
14.3.1 Role-playing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
14.3.2 First-person shooter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
14.3.3 Real-time strategy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
14.3.4 Turn-based strategy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
14.3.5 Simulations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
14.3.6 Casual . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
14.4 Research . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
14.5 Spending . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
14.6 See also . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
14.7 References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
14.8 External links . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
14.9 Text and image sources, contributors, and licenses . . . . . . . . . . . . . . . . . . . . . . . . . . 82
14.9.1 Text . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
14.9.2 Images . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 86
14.9.3 Content license . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
Chapter 1

Multiprocessing

Multiprocessing is the use of two or more central 1.1 Pre-history


processing units (CPUs) within a single computer
system.[1][2] The term also refers to the ability of a system According to a 1985 article in Byte, possibly the first
to support more than one processor and/or the ability to expression of the idea of multiprocessing is found in
allocate tasks between them.[3] There are many variations the 1842 words of Federico Luigi Menabrea, which said
on this basic theme, and the definition of multiprocessing about Charles Babbage's analytical engine: “The machine
can vary with context, mostly as a function of how CPUs can be brought into play so as to give several results at the
are defined (multiple cores on one die, multiple dies in same time, which will greatly abridge the whole amount
one package, multiple packages in one system unit, etc.). of processes.”[12]
According to some on-line dictionaries, a multiproces-
sor is a computer system having two or more process-
ing units (multiple processors) each sharing main mem- 1.2 Key topics
ory and peripherals, in order to simultaneously process
programs.[4][5] A 2009 textbook defined multiprocessor
system similarly, but noting that the processors may share 1.2.1 Processor symmetry
“some or all of the system’s memory and I/O facilities";
it also gave tightly coupled system as a synonymous In a multiprocessing system, all CPUs may be equal, or
term.[6] some may be reserved for special purposes. A combi-
nation of hardware and operating system software design
At the operating system level, multiprocessing is some- considerations determine the symmetry (or lack thereof)
times used to refer to the execution of multiple concur- in a given system. For example, hardware or software
rent processes in a system as opposed to a single process at considerations may require that only one particular CPU
any one instant.[7][8] When used with this definition, mul- respond to all hardware interrupts, whereas all other work
tiprocessing is sometimes contrasted with multitasking, in the system may be distributed equally among CPUs; or
which may use just a single processor but switch it in time execution of kernel-mode code may be restricted to only
slices between tasks (i.e. a time-sharing system). Multi- one particular CPU, whereas user-mode code may be ex-
processing however means true parallel execution of mul- ecuted in any combination of processors. Multiprocess-
tiple processes using more than one processor.[8] Multi- ing systems are often easier to design if such restrictions
processing doesn't necessarily mean that a single process are imposed, but they tend to be less efficient than sys-
or task uses more than one processor simultaneously; the tems in which all CPUs are utilized.
term parallel processing is generally used to denote that
scenario.[7] Other authors prefer to refer to the operating Systems that treat all CPUs equally are called symmetric
system techniques as multiprogramming and reserve the multiprocessing (SMP) systems. In systems where all
term multiprocessing for the hardware aspect of having CPUs are not equal, system resources may be divided in
more than one processor.[2][9] The remainder of this arti- a number of ways, including asymmetric multiprocessing
cle discusses multiprocessing only in this hardware sense. (ASMP), non-uniform memory access (NUMA) multi-
processing, and clustered multiprocessing.
In Flynn’s taxonomy, multiprocessors as defined above
are MIMD machines.[10][11] As they are normally con-
strued to be tightly coupled (share memory), multipro- 1.2.2 Instruction and data streams
cessors are not the entire class of MIMD machines, which
also contains message passing multicomputer systems.[10] In multiprocessing, the processors can be used to exe-
cute a single sequence of instructions in multiple con-
texts (single-instruction, multiple-data or SIMD, often
used in vector processing), multiple sequences of instruc-
tions in a single context (multiple-instruction, single-data

1
2 CHAPTER 1. MULTIPROCESSING

or MISD, used for redundancy in fail-safe systems and 1.2.4 Multiprocessor Communication Ar-
sometimes applied to describe pipelined processors or chitecture
hyper-threading), or multiple sequences of instructions
in multiple contexts (multiple-instruction, multiple-data Message passing
or MIMD).
Separate address space for each processor.

1.2.3 Processor coupling processors communicate via message passing.


processors have provide memories.
Tightly coupled multiprocessor system
focus attention on costly non-local operations.
Tightly coupled multiprocessor systems contain multiple
CPUs that are connected at the bus level. These CPUs Shared memory
may have access to a central shared memory (SMP or
UMA), or may participate in a memory hierarchy with Processors communicate with shared address space
both local and shared memory (NUMA). The IBM p690
Processors communicate by memory read/write
Regatta is an example of a high end SMP system. Intel
Xeon processors dominated the multiprocessor market Easy on small-scale machines
for business PCs and were the only major x86 option un- Lower latency
til the release of AMD's Opteron range of processors in
2004. Both ranges of processors had their own onboard SMP or NUMA architecture
cache but provided access to shared memory; the Xeon
processors via a common pipe and the Opteron proces-
sors via independent pathways to the system RAM. 1.3 Flynn’s taxonomy
Chip multiprocessors, also known as multi-core comput-
ing, involves more than one processor placed on a sin- 1.3.1 SISD multiprocessing
gle chip and can be thought of the most extreme form
of tightly-coupled multiprocessing. Mainframe systems Main article: SISD
with multiple processors are often tightly-coupled.
In a single-instruction stream, single-data stream com-
Loosely coupled multiprocessor system puter one processor sequentially processes instructions,
each instruction processes one data item. One example is
Main article: shared nothing architecture the “von Neumann” architecture with RISC.

Loosely coupled multiprocessor systems (often referred 1.3.2 SIMD multiprocessing


to as clusters) are based on multiple standalone single or
dual processor commodity computers interconnected via Main article: SIMD
a high speed communication system (Gigabit Ethernet is
common). A Linux Beowulf cluster is an example of a In a single-instruction stream, multiple data stream com-
loosely-coupled system. puter one processor handles a stream of instructions, each
Tightly-coupled systems perform better and are physi- one of which can perform calculations in parallel on mul-
cally smaller than loosely-coupled systems, but have his- tiple data locations.
torically required greater initial investments and may SIMD multiprocessing is well suited to parallel or vector
depreciate rapidly; nodes in a loosely coupled system are processing, in which a very large set of data can be di-
usually inexpensive commodity computers and can be re- vided into parts that are individually subjected to iden-
cycled as independent machines upon retirement from the tical but independent operations. A single instruction
cluster. stream directs the operation of multiple processing units
Power consumption is also a consideration. Tightly cou- to perform the same manipulations simultaneously on po-
pled systems tend to be much more energy efficient than tentially large amounts of data.
clusters. This is because considerable economy can be For certain types of computing applications, this type of
realized by designing components to work together from architecture can produce enormous increases in perfor-
the beginning in tightly coupled systems, whereas looselymance, in terms of the elapsed time required to complete
coupled systems use components that were not necessar- a given task. However, a drawback to this architecture is
ily intended specifically for use in such systems. that a large part of the system falls idle when programs
Loosely-coupled systems have the ability to run different or system tasks are executed that cannot be divided into
operating systems or OS versions on different systems. units that can be processed in parallel.
1.4. SEE ALSO 3

Additionally, programs must be carefully and specially the operating system of a computer but does not require
written to take maximum advantage of the architecture, application changes unless the programs themselves use
and often special optimizing compilers designed to pro- multiple threads (MIMD is transparent to single-threaded
duce code specifically for this environment must be used. programs under most operating systems, if the programs
Some compilers in this category provide special con- do not voluntarily relinquish control to the OS). Both sys-
structs or extensions to allow programmers to directly tem and user software may need to use software con-
specify operations to be performed in parallel (e.g., DO structs such as semaphores (also called locks or gates) to
FOR ALL statements in the version of FORTRAN used prevent one thread from interfering with another if they
on the ILLIAC IV, which was a SIMD multiprocessing should happen to cross paths in referencing the same data.
supercomputer). This gating or locking process increases code complexity,
lowers performance, and greatly increases the amount of
SIMD multiprocessing finds wide use in certain domains
such as computer simulation, but is of little use in general- testing required, although not usually enough to negate
the advantages of multiprocessing.
purpose desktop and business computing environments.
Similar conflicts can arise at the hardware level between
processors (cache contention and corruption, for exam-
1.3.3 MISD multiprocessing ple), and must usually be resolved in hardware, or with a
combination of software and hardware (e.g., cache-clear
Main article: MISD instructions).

MISD multiprocessing offers mainly the advantage of re-


dundancy, since multiple processing units perform the 1.4 See also
same tasks on the same data, reducing the chances of in-
correct results if one of the units fails. MISD architec- • Symmetric multiprocessing
tures may involve comparisons between processing units
to detect failures. Apart from the redundant and fail-safe • Asymmetric multiprocessing
character of this type of multiprocessing, it has few ad-
vantages, and it is very expensive. It does not improve • Multi-core processor
performance. It can be implemented in a way that is
• BMDFM – Binary Modular Dataflow Machine, a
transparent to software. It is used in array processors and
SMP MIMD runtime environment
is implemented in fault tolerant machines.
Another example of MISD is pipelined image processing • Software lockout
where every image pixel is piped through several hard-
• OpenHMPP
ware units performing several steps of image transforma-
tion.

1.5 References
1.3.4 MIMD multiprocessing
[1] Raj Rajagopal (1999). Introduction to Microsoft Win-
Main article: MIMD dows NT Cluster Server: Programming and Administra-
tion. CRC Press. p. 4. ISBN 978-1-4200-7548-9.

MIMD multiprocessing architecture is suitable for a wide [2] Mike Ebbers; John Kettner; Wayne O'Brien; Bill Ogden,
variety of tasks in which completely independent and par- IBM Redbooks (2012). Introduction to the New Main-
allel execution of instructions touching different sets of frame: z/OS Basics. IBM Redbooks. p. 96. ISBN 978-0-
data can be put to productive use. For this reason, and 7384-3534-3.
because it is easy to implement, MIMD predominates in
[3] Chip multiprocessing
multiprocessing.
Processing is divided into multiple threads, each with its [4] http://www.yourdictionary.com/multiprocessor
own hardware processor state, within a single software-
[5] http://www.thefreedictionary.com/multiprocessor
defined process or within multiple processes. Insofar as
a system has multiple threads awaiting dispatch (either [6] Irv Englander (2009). The architecture of Computer Hard-
system or user threads), this architecture makes good use ware and Systems Software. An Information Technology
of hardware resources. Approach. (4th ed.). Wiley. p. 265.
MIMD does raise issues of deadlock and resource con- [7] Deborah Morley; Charles Parker (13 February 2012).
tention, however, since threads may collide in their ac- Understanding Computers: Today and Tomorrow, Com-
cess to resources in an unpredictable way that is difficult prehensive. Cengage Learning. p. 183. ISBN 1-133-
to manage efficiently. MIMD requires special coding in 19024-3.
4 CHAPTER 1. MULTIPROCESSING

[8] Shibu K. V. Introduction to Embedded Systems. Tata


McGraw-Hill Education. p. 402. ISBN 978-0-07-
014589-4.

[9] Ashok Arora (2006). Foundations of Computer Science.


Laxmi Publications. p. 149. ISBN 978-81-7008-971-1.

[10] Ran Giladi (2008). Network Processors: Architecture,


Programming, and Implementation. Morgan Kaufmann.
p. 293. ISBN 978-0-08-091959-1.

[11] Sajjan G. Shiva (20 September 2005). Advanced Com-


puter Architectures. CRC Press. p. 221. ISBN 978-0-
8493-3758-1.

[12] Multiprocessing, BYTE magazine Volume 10, Number


05 (May 1985), p. 169
Chapter 2

Computer multitasking

For other uses, see Multitasking (disambiguation). executed at once (physically, one per CPU or core), mul-
In computing, multitasking is a method where multiple titasking allows many more tasks to be run than there
are CPUs. The term multitasking has become an inter-
national term, as the same word is used in many other
languages such as German, Italian, Dutch, Danish and
Norwegian.
Operating systems may adopt one of many different
scheduling strategies, which generally fall into the follow-
ing categories:

• In multiprogramming systems, the running task


keeps running until it performs an operation that
requires waiting for an external event (e.g. read-
Modern desktop operating systems are capable of handling large ing from a tape) or until the computer’s scheduler
numbers of different processes at the same time. This screenshot forcibly swaps the running task out of the CPU.
shows Linux Mint running simultaneously Xfce desktop environ- Multiprogramming systems are designed to maxi-
ment, Firefox, a calculator program, the built-in calendar, Vim, mize CPU usage.
GIMP, and VLC media player.
• In time-sharing systems, the running task is required
to relinquish the CPU, either voluntarily or by an ex-
tasks (also known as processes) are performed during the
ternal event such as a hardware interrupt. Time shar-
same period of time – they are executed concurrently (in
ing systems are designed to allow several programs
overlapping time periods, new tasks starting before others
to execute apparently simultaneously.
have ended) instead of sequentially (one completing be-
fore the next starts). The tasks share common processing • In real-time systems, some waiting tasks are guar-
resources, such as central processing units (CPUs) and anteed to be given the CPU when an external event
main memory. occurs. Real time systems are designed to control
Multitasking does not necessarily mean that multiple mechanical devices such as industrial robots, which
tasks are executing at exactly the same instant. In other require timely processing.
words, multitasking does not imply parallel execution, but
it does mean that more than one task can be part-way
through execution at the same time, and that more than 2.1 Multiprogramming
one task is advancing over a given period of time.
In the case of a computer with a single CPU, only one task In the early days of computing, CPU time was expensive,
is said to be running at any point in time, meaning that and peripherals were very slow. When the computer ran
the CPU is actively executing instructions for that task. a program that needed access to a peripheral, the central
Multitasking solves the problem by scheduling which task processing unit (CPU) would have to stop executing pro-
may be the one running at any given time, and when an- gram instructions while the peripheral processed the data.
other waiting task gets a turn. The act of reassigning a This was deemed very inefficient.
CPU from one task to another one is called a context The first computer using a multiprogramming system was
switch. When context switches occur frequently enough,the British Leo III owned by J. Lyons and Co. Several
the illusion of parallelism is achieved. different programs in batch were loaded in the computer
Even on multiprocessor or multicore computers, which memory, and the first one began to run. When the first
have multiple CPUs/cores so more than one task can be program reached an instruction waiting for a peripheral,

5
6 CHAPTER 2. COMPUTER MULTITASKING

the context of this program was stored away, and the sec- 2.3 Preemptive multitasking
ond program in memory was given a chance to run. The
process continued until all programs finished running.
The use of multiprogramming was enhanced by the ar-
rival of virtual memory and virtual machine technology,
Main article: Preemption (computing)
which enabled individual programs to make use of mem-
ory and operating system resources as if other concur-
rently running programs were, for all practical purposes, Preemptive multitasking allows the computer system to
non-existent and invisible to them. guarantee more reliably each process a regular “slice”
of operating time. It also allows the system to deal
Multiprogramming doesn't give any guarantee that a pro-
rapidly with important external events like incoming data,
gram will run in a timely manner. Indeed, the very first
which might require the immediate attention of one or an-
program may very well run for hours without needing ac-
other process. Operating systems were developed to take
cess to a peripheral. As there were no users waiting at an
advantage of these hardware capabilities and run mul-
interactive terminal, this was no problem: users handed
tiple processes preemptively. Preemptive multitasking
in a deck of punched cards to an operator, and came back
was supported on DEC’s PDP-8 computers, and imple-
a few hours later for printed results. Multiprogramming
mented in OS/360 MFT in 1967, in MULTICS (1964),
greatly reduced wait times when multiple batches were
and Unix (1969); it is a core feature of all Unix-like op-
being processed.
erating systems, such as Linux, Solaris and BSD with its
derivatives.[2]
At any specific time, processes can be grouped into two
categories: those that are waiting for input or output
2.2 Cooperative multitasking (called "I/O bound"), and those that are fully utilizing the
CPU ("CPU bound"). In primitive systems, the software
would often "poll", or "busywait" while waiting for re-
See also: Nonpreemptive multitasking quested input (such as disk, keyboard or network input).
During this time, the system was not performing useful
The expression “time sharing” usually designated com- work. With the advent of interrupts and preemptive mul-
puters shared by interactive users at terminals, such as titasking, I/O bound processes could be “blocked”, or put
IBM’s TSO, and VM/CMS. The term “time-sharing” is on hold, pending the arrival of the necessary data, allow-
no longer commonly used, having been replaced by “mul- ing other processes to utilize the CPU. As the arrival of
titasking”, following the advent of personal computers the requested data would generate an interrupt, blocked
and workstations rather than shared interactive systems. processes could be guaranteed a timely return to execu-
Early multitasking systems used applications that volun- tion.
tarily ceded time to one another. This approach, which The earliest preemptive multitasking OS available to
was eventually supported by many computer operating home users was Sinclair QDOS on the Sinclair QL, re-
systems, is known today as cooperative multitasking. Al- leased in 1984, but very few people bought the machine.
though it is now rarely used in larger systems except for Commodore’s powerful Amiga, released the following
specific applications such as CICS or the JES2 subsystem, year, was the first commercially successful home com-
cooperative multitasking was once the scheduling scheme puter to use the technology, and its multimedia abilities
employed by Microsoft Windows (prior to Windows 95 make it a clear ancestor of contemporary multitasking
and Windows NT) and Mac OS (prior to OS X) in or- personal computers. Microsoft made preemptive multi-
der to enable multiple applications to be run simultane- tasking a core feature of their flagship operating system
ously. Windows 9x also used cooperative multitasking, in the early 1990s when developing Windows NT 3.1 and
but only for 16-bit legacy applications, much the same then Windows 95. It was later adopted on the Apple Mac-
way as pre-Leopard PowerPC versions of Mac OS X used intosh by Mac OS X that, as a Unix-like operating system,
it for Classic applications. The network operating system uses preemptive multitasking for all native applications.
NetWare used cooperative multitasking up to NetWare A similar model is used in Windows 9x and the Windows
6.5. Cooperative multitasking is still used today on RISC NT family, where native 32-bit applications are multi-
OS systems.[1] tasked preemptively, and legacy 16-bit Windows 3.x pro-
As a cooperatively multitasked system relies on each pro- grams are multitasked cooperatively within a single pro-
cess regularly giving up time to other processes on the sys- cess, although in the NT family it is possible to force a
tem, one poorly designed program can consume all of the 16-bit application to run as a separate preemptively mul-
CPU time for itself, either by performing extensive cal- titasked process.[3] 64-bit editions of Windows, both for
culations or by busy waiting; both would cause the whole the x86-64 and Itanium architectures, no longer provide
system to hang. In a server environment, this is a hazard support for legacy 16-bit applications, and thus provide
that makes the entire environment unacceptably fragile. preemptive multitasking for all supported applications.
2.7. MEMORY SWAPPING 7

2.4 Real time cess attempts to access a memory location outside of its
memory space, the MMU denies the request and signals
Another reason for multitasking was in the design of real- the kernel to take appropriate actions; this usually results
time computing systems, where there are a number of in forcibly terminating the offending process. Depending
possibly unrelated external activities needed to be con- on the software and kernel design and the specific error
trolled by a single processor system. In such systems a hi- in question, the user may receive an access violation error
erarchical interrupt system is coupled with process prior- message such as “segmentation fault”.
itization to ensure that key activities were given a greater In a well designed and correctly implemented multitask-
share of available process time. ing system, a given process can never directly access
memory that belongs to another process. An exception
to this rule is in the case of shared memory; for exam-
2.5 Multithreading ple, in the System V inter-process communication mech-
anism the kernel allocates memory to be mutually shared
by multiple processes. Such features are often used by
As multitasking greatly improved the throughput of com-
database management software such as PostgreSQL.
puters, programmers started to implement applications as
sets of cooperating processes (e. g., one process gathering Inadequate memory protection mechanisms, either due to
input data, one process processing input data, one process flaws in their design or poor implementations, allow for
writing out results on disk). This, however, required some security vulnerabilities that may be potentially exploited
tools to allow processes to efficiently exchange data. by malicious software.
Threads were born from the idea that the most efficient
way for cooperating processes to exchange data would be
to share their entire memory space. Thus, threads are 2.7 Memory swapping
effectively processes that run in the same memory con-
text and share other resources with their parent processes,
such as open files. Threads are described as lightweight Use of a swap file or swap partition is a way for the op-
processes because switching between threads does not in- erating system to provide more memory than is physi-
volve changing the memory context.[4][5][6] cally available by keeping portions of the primary mem-
ory in secondary storage. While multitasking and mem-
While threads are scheduled preemptively, some operat- ory swapping are two completely unrelated techniques,
ing systems provide a variant to threads, named fibers, they are very often used together, as swapping memory
that are scheduled cooperatively. On operating systems allows more tasks to be loaded at the same time. Typ-
that do not provide fibers, an application may implement ically, a multitasking system allows another process to
its own fibers using repeated calls to worker functions. run when the running process hits a point where it has
Fibers are even more lightweight than threads, and some- to wait for some portion of memory to be reloaded from
what easier to program with, although they tend to lose secondary storage.
some or all of the benefits of threads on machines with
multiple processors.
Some systems directly support multithreading in hard-
ware. 2.8 Programming
Processes that are entirely independent are not much trou-
2.6 Memory protection ble to program in a multitasking environment. Most of
the complexity in multitasking systems comes from the
need to share computer resources between tasks and to
Main article: Memory protection
synchronize the operation of co-operating tasks.

Essential to any multitasking system is to safely and effec- Various concurrent computing techniques are used to
tively share access to system resources. Access to mem- avoid potential problems caused by multiple tasks at-
ory must be strictly managed to ensure that no process tempting to access the same resource.
can inadvertently or deliberately read or write to memory Bigger systems were sometimes built with a central pro-
locations outside of the process’s address space. This is cessor(s) and some number of I/O processors, a kind of
done for the purpose of general system stability and data asymmetric multiprocessing.
integrity, as well as data security. Over the years, multitasking systems have been refined.
In general, memory access management is the operating Modern operating systems generally include detailed
system kernel’s responsibility, in combination with hard- mechanisms for prioritizing processes, while symmetric
ware mechanisms (such as the memory management unit multiprocessing has introduced new complexities and ca-
(MMU)) that provide supporting functionalities. If a pro- pabilities.
8 CHAPTER 2. COMPUTER MULTITASKING

2.9 See also


• Process state

2.10 References
[1] “Preemptive multitasking”. riscos.info. 2009-11-03. Re-
trieved 2014-07-27.

[2] “UNIX, Part One”. The Digital Research Initiative. ibib-


lio.org. 2002-01-30. Retrieved 2014-01-09.

[3] Smart Computing Article - Windows 2000 &16-Bit Ap-


plications

[4] Eduardo Ciliendo; Takechika Kunimasa (April 25, 2008).


“Linux Performance and Tuning Guidelines” (PDF). red-
books.ibm.com. IBM. p. 4. Retrieved March 1, 2015.

[5] “Context Switch Definition”. linfo.org. May 28, 2006.


Retrieved February 26, 2015.

[6] “What are threads (user/kernel)?". tldp.org. September 8,


1997. Retrieved February 26, 2015.
Chapter 3

Symmetric multiprocessing

SMP - Symmetric Multiprocessor System


the scalability of SMP using buses or crossbar switches
is the bandwidth and power consumption of the intercon-
Main nect among the various processors, the memory, and the
Memory
disk arrays. Mesh architectures avoid these bottlenecks,
Bus System Bus and provide nearly linear scalability to much higher pro-
Arbiter
cessor counts at the sacrifice of programmability:
Cache Cache Cache I/O

Serious programming challenges remain


Processor Processor Processor
with this kind of architecture because it re-
1 2 n
quires two distinct modes of programming, one
By Ferruccio Zulian - Milan.Italy
for the CPUs themselves and one for the in-
terconnect between the CPUs. A single pro-
Diagram of a symmetric multiprocessing system gramming language would have to be able to
not only partition the workload, but also com-
Symmetric multiprocessing (SMP) involves a prehend the memory locality, which is severe
symmetric multiprocessor system hardware and software in a mesh-based architecture.[1]
architecture where two or more identical processors
connect to a single, shared main memory, have full SMP systems allow any processor to work on any task no
access to all I/O devices, and are controlled by a single matter where the data for that task are located in mem-
operating system instance that treats all processors ory, provided that each task in the system is not in exe-
equally, reserving none for special purposes. Most mul- cution on two or more processors at the same time; with
tiprocessor systems today use an SMP architecture. In proper operating system support, SMP systems can easily
the case of multi-core processors, the SMP architecture move tasks between processors to balance the workload
applies to the cores, treating them as separate processors. efficiently.
SMP systems are tightly coupled multiprocessor systems
with a pool of homogeneous processors running indepen-
dently, each processor executing different programs and 3.2 History
working on different data and with capability of sharing
common resources (memory, I/O device, interrupt sys-
The earliest production system with multiple identical
tem and so on) and connected using a system bus or a
processors was the Burroughs B5000 which was func-
crossbar.
tional in around 1961. However at run-time this was
asymmetric, with one processor restricted to application
programs while the other mainly handled the operating
3.1 Design system and hardware interrupts.
IBM offered dual-processor computer systems based on
SMP systems have centralized shared memory called its System/360 model 65 and the closely related model
Main Memory (MM) operating under a single operating 67.[2] and 67-2[3] The operating systems that ran on these
system with two or more homogeneous processors. Usu- machines were OS/360 M65MP[4] and TSS/360. Other
ally each processor has an associated private high-speed software, developed at universities, used both CPUs—
memory known as cache memory (or cache) to speed-up notably MTS. Both processors could access data channels
the MM data access and to reduce the system bus traffic. and initiate I/O.
Processors may be interconnected using buses, crossbar In OS/360 M65MP, since the operating system kernel ran
switches or on-chip mesh networks. The bottleneck in on both processors (though with a “big lock” around the

9
10 CHAPTER 3. SYMMETRIC MULTIPROCESSING

I/O handler) and peripherals could generally be attached performance increase even when they have been writ-
to either processor.[5] ten for uniprocessor systems. This is because hardware
The MTS supervisor (UMMPS) ran on either or both interrupts that usually suspend program execution while
CPUs of the IBM System/360 model 67-2. Supervisor the kernel handles them can execute on an idle processor
locks were small and were used to protect individual com- instead. The effect in most applications (e.g. games) is
mon data structures that might be accessed simultane- not so much a performance increase as the appearance
ously from either CPU.[6] that the program is running much more smoothly. Some
applications, particularly compilers and some distributed
Digital Equipment Corporation's first multi-processor computing projects, run faster by a factor of (nearly) the
VAX system, the VAX-11/782, was asymmetric,[7] but number of additional processors.
later VAX multiprocessor systems were SMP.[8]
Systems programmers must build support for SMP into
The first commercial Unix SMP implementation was the operating system: otherwise, the additional proces-
the NUMA based Honeywell Information Systems Italy sors remain idle and the system functions as a uniproces-
XPS-100 designed by Dan Gielan of VAST Corporation sor system.
in 1985. Its design supported up to 14 processors al-
though due to electrical limitations the largest marketed SMP systems can also lead to more complexity regard-
version was a dual processor system. The operating sys- ing instruction sets. A homogeneous processor system
tem was derived and ported by VAST Corporation from typically requires extra registers for “special instructions”
AT&T 3B20 Unix SysVr3 code used internally within such as SIMD (MMX, SSE, etc.), while a heterogeneous
AT&T. system can implement different types of hardware for
different instructions/uses.

3.3 Uses
3.5 Performance
Time-sharing and server systems can often use SMP
without changes to applications, as they may have multi- When more than one program executes at the same time,
ple processes running in parallel, and a system with more an SMP system has considerably better performance than
than one process running can run different processes on a uni-processor, because different programs can run on
different processors. different CPUs simultaneously.

On personal computers, SMP is less useful for appli- In cases where an SMP environment processes many
cations that have not been modified. If the system jobs, administrators often experience a loss of hardware
rarely runs more than one process at a time, SMP is efficiency. Software programs have been developed to
useful only for applications that have been modified schedule jobs so that the processor utilization reaches
for multithreaded (multitasked) processing. Custom- its maximum potential. Good software packages can
programmed software can be written or modified to use achieve this maximum potential by scheduling each CPU
multiple threads, so that it can make use of multiple separately, as well as being able to integrate multiple SMP
processors. However, most consumer products such as machines and clusters.
word processors and computer games are written in such Access to RAM is serialized; this and cache coherency
a manner that they cannot gain large benefits from con- issues causes performance to lag slightly behind the num-
current systems. For games this is usually because writ- ber of additional processors in the system.
ing a program to increase performance on SMP systems
can produce a performance loss on uniprocessor systems.
Recently, however, multi-core chips are becoming more
common in new computers, and the balance between in- 3.6 Systems
stalled uni- and multi-core computers may change in the
coming years. 3.6.1 Entry-level systems
Multithreaded programs can also be used in time-sharing
and server systems that support multithreading, allowing Before about 2006, entry-level servers and workstations
them to make more use of multiple processors. with two processors dominated the SMP market. With
the introduction of dual-core devices, SMP is found
in most new desktop machines and in many laptop
machines. The most popular entry-level SMP sys-
3.4 Programming tems use the x86 instruction set architecture and are
based on Intel’s Xeon, Pentium D, Core Duo, and
Uniprocessor and SMP systems require different pro- Core 2 Duo based processors or AMD’s Athlon64 X2,
gramming methods to achieve maximum performance. Quad FX or Opteron 200 and 2000 series processors.
Programs running on SMP systems may experience a Servers use those processors and other readily avail-
3.7. ALTERNATIVES 11

able non-x86 processor choices, including the Sun Mi- of 64 GiB. With the introduction of 64-bit memory ad-
crosystems UltraSPARC, Fujitsu SPARC64 III and later, dressing on the AMD64 Opteron in 2003 and Intel 64
SGI MIPS, Intel Itanium, Hewlett Packard PA-RISC, (EM64T) Xeon in 2005, systems are able to address much
Hewlett-Packard (merged with Compaq, which acquired larger amounts of memory; their addressable limitation
first Digital Equipment Corporation) DEC Alpha, IBM of 16 EiB is not expected to be reached in the foresee-
POWER and PowerPC (specifically G4 and G5 series, as able future.
well as earlier PowerPC 604 and 604e series) processors.
In all cases, these systems are available in uniprocessor
versions as well. 3.7 Alternatives
Earlier SMP systems used motherboards that have two or
more CPU sockets. More recently, microprocessor man-
ufacturers introduced CPU devices with two or more pro- CPU CPU CPU
cessors in one device, for example, the Itanium, POWER, I/O
UltraSPARC, Opteron, Athlon, Core 2, and Xeon all have
System Bus or Crossbar Switch
multi-core variants. Athlon and Core 2 Duo multipro-
cessors are socket-compatible with uniprocessor variants,
so an expensive dual socket motherboard is no longer Memory
needed to implement an entry-level SMP machine. It
should also be noted that dual socket Opteron designs
are technically ccNUMA designs, though they can be Diagram of a typical SMP system. Three processors are con-
programmed as SMP for a slight loss in performance. nected to the same memory module through a system bus or
Software based SMP systems can be created by linking crossbar switch
smaller systems together. An example of this is the soft-
ware developed by ScaleMP. SMP using a single shared system bus represents one of
the earliest styles of multiprocessor machine architec-
With the introduction of ARM Cortex-A9 multi-core tures, typically used for building smaller computers with
SoCs, low-cost symmetric multiprocessing embedded up to 8 processors.
systems began to flourish in the form of smartphones and
tablet computers with a multi-core processor. Larger computer systems might use newer architectures
such as NUMA (Non-Uniform Memory Access), which
dedicates different memory banks to different proces-
sors. In a NUMA architecture, processors may access
3.6.2 Mid-level systems
local memory quickly and remote memory more slowly.
This can dramatically improve memory throughput as
The Burroughs D825 first implemented SMP in
long as the data are localized to specific processes (and
1962.[9][10] It was implemented later on other main-
thus processors). On the downside, NUMA makes the
frames. Mid-level servers, using between four and eight
cost of moving data from one processor to another, as
processors, can be found using the Intel Xeon MP, AMD
in workload balancing, more expensive. The benefits of
Opteron 800 and 8000 series and the above-mentioned
NUMA are limited to particular workloads, notably on
UltraSPARC, SPARC64, MIPS, Itanium, PA-RISC,
servers where the data are often associated strongly with
Alpha and POWER processors. High-end systems, with
certain tasks or users.
sixteen or more processors, are also available with all of
the above processors. Finally, there is computer clustered multiprocessing
(such as Beowulf), in which not all memory is available
Sequent Computer Systems built large SMP machines
to all processors. Clustering techniques are used fairly
using Intel 80386 (and later 80486) processors. Some
extensively to build very large supercomputers.
smaller 80486 systems existed, but the major x86 SMP
market began with the Intel Pentium technology support-
ing up to two processors. The Intel Pentium Pro ex-
panded SMP support with up to four processors natively. 3.8 See also
Later, the Intel Pentium II, and Intel Pentium III proces-
sors allowed dual CPU systems, except for the respective • Asymmetric multiprocessing
Celerons. This was followed by the Intel Pentium II Xeon
• Binary Modular Dataflow Machine
and Intel Pentium III Xeon processors, which could be
used with up to four processors in a system natively. In • Locale (computer hardware)
2001 AMD released their Athlon MP, or MultiProcessor
CPU, together with the 760MP motherboard chipset as • Massively parallel
their first offering in the dual processor marketplace. Al- • Non-Uniform Memory Access
though several much larger systems were built, they were
all limited by the physical memory addressing limitation • Sequent Computer Systems
12 CHAPTER 3. SYMMETRIC MULTIPROCESSING

• Simultaneous multithreading, where functional ele-


ments of a CPU core are allocated across multiple
threads of execution.

• Software lockout
• Xeon Phi

3.9 References
[1] Lina J. Karam, Ismail AlKamal, Alan Gatherer, Gene
A. Frantz, David V. Anderson, Brian L. Evans (2009).
“Trends in Multi-core DSP Platforms”. IEEE Signal Pro-
cessing Magazine, Special Issue on Signal Processing on
Platforms with Multiple Cores.

[2] IBM (September 1968). IBM System/360 Model 65 Func-


tional Characteristics. Fourth Edition. A22-6884-3.

[3] IBM (February 1972). IBM System/360 Model 67 Func-


tional Characteristics. Third Edition. GA27-2719-2.

[4] M65MP: An Experiment in OS/360 multiprocessing

[5] IBM, “OS I/O Supervisor PLM” - GY28-6616-9, Pro-


gram Logic Manual, R21.7, April 1973

[6] Time Sharing Supervisor Programs by Mike Alexander


(May 1971) has information on MTS, TSS, CP/67, and
Multics

[7] VAX Product Sales Guide, pages 1-23 and 1-24: the
VAX-11/782 is described as an asymmetric multiprocess-
ing system in 1982

[8] VAX 8820/8830/8840 System Hardware User’s Guide:


by 1988 the VAX operating system was SMP

[9] 1962

[10] 1964 BRL Report

3.10 External links


• History of Multi-Processing
• Practical Parallel Programming in Pascal

• Linux and Multiprocessing


• Multicore News blog

• AMD
Chapter 4

Asymmetric multiprocessing

Asymmetric multiprocessing (AMP) was a software much less expensive than a CPU that ran twice as fast.
stopgap for handling multiple CPUs before symmetric Also, adding a second CPU was less expensive than a sec-
multiprocessing (SMP) was available. It has also been ond complete computer, which would need its own pe-
used to provide less expensive options[1] on systems ripherals, thus requiring much more floor space and an
where SMP was available. In an asymmetric multipro- increased operations staff.
cessing system, not all CPUs are treated equally; for ex- Notable early offerings by computer manufacturers were
ample, a system might only allow (either at the hardware
the Burroughs B5000, the DECsystem-1055, and the
or operating system level) one CPU to execute operating IBM System/360 model 65MP. There were also dual-
system code or might only allow one CPU to perform I/O
CPU machines built at universities.[3]
operations. Other AMP systems would allow any CPU
to execute operating system code and perform I/O opera- The problem with adding a second CPU to a computer
tions, so that they were symmetric with regard to proces- system was that the operating system had been developed
sor roles, but attached some or all peripherals to partic- for single-CPU systems, and extending it to handle mul-
ular CPUs, so that they were asymmetric with regard to tiple CPUs efficiently and reliably took a long time. To
peripheral attachment. fill the gap, operating systems intended for single CPUs
were initially extended to provide minimal support for a
second CPU. In this minimal support, the operating sys-
tem ran on the “boot” processor, with the other only al-
lowed to run user programs. In the case of the Burroughs
B5000, the second processor’s hardware was not capable
of running “control state” code.[4]
Other systems allowed the operating system to run on all
processors, but either attached all the peripherals to one
Asymmetric multiprocessing processor or attached particular peripherals to particular
processors.
Multiprocessing is the use of more than one CPU in a
computer system. The CPU is the arithmetic and logic
engine that executes user applications; an I/O interface 4.2 Burroughs B5000 and B5500
such as a GPU, even if it is implemented using an em-
bedded processor, does not constitute a CPU because it
An option on the Burroughs B5000 was “Processor B”.
does not run the user’s application program. With multi-
This second processor, unlike “Processor A” had no con-
ple CPUs, more than one set of program instructions can
nection to the peripherals, though the two processors
be executed at the same time. All of the CPUs have the
shared main memory, and Processor B could not run in
same user-mode instruction set, so a running job can be
Control State.[4] The operating system ran only on Pro-
rescheduled from one CPU to another.[2]
cessor A. When there was a user job to be executed, it
might be run on Processor B, but when that job tried to
access the operating system the processor halted and sig-
4.1 Background and history naled Processor A. The requested operating system ser-
vice was then run on Processor A.
For the room-size computers of the 1960s and 1970s, On the B5500, either Processor A or Processor B could
a cost-effective way to increase compute power was to be designated as Processor 1 by a switch on the engineer’s
add a second CPU. Since these computers were al- panel, with the other processor being Processor 2; both
ready close to the fastest available (near the peak of the processors shared main memory and had hardware access
price:performance ratio), two standard-speed CPUs were to the I/O processors hence the peripherals, but only Pro-

13
14 CHAPTER 4. ASYMMETRIC MULTIPROCESSING

cessor 1 could respond to peripheral interrupts.[5] When 4.7 Univac 1108-II


a job on Processor 2 required an operating system ser-
vice it would be rescheduled on Processor 1, which was The Univac 1108-II and its successors had up to three
responsible for both initiating I/O processor activity and CPUs.[13][14] These computers ran the UNIVAC EXEC
responding to interrupts indicating completion. In prac- 8 operating system, but it is not clear from the surviving
tice, this meant that while user jobs could run on either documentation where that operating system was on the
Processor 1 or Processor 2 and could access intrinsic li- path from asymmetric to symmetric multiprocessing.
brary routines that didn't require kernel support, the oper-
ating system would schedule them on the latter whenever
possible.[6]
4.8 IBM System/370 model 168
Two options were available for the IBM System/370
4.3 CDC 6500 and 6700 model 168 for attaching a second processor.[15] One was
the IBM 3062 Attached Processing Unit, in which the
Control Data Corporation offered two configurations of second processor had no access to the channels, and was
its CDC 6000 series that featured two central processors. therefore similar to the B5000’s Processor B or the sec-
The CDC 6500[7] was a CDC 6400 with two central pro- ond processor on a VAX-11/782. The other option of-
cessors. The CDC 6700 was a CDC 6600 with the CDC fered a complete second CPU, and was thus more like
6400 central processor added to it. the System/360 model 65MP.
These systems were organized quite differently from the
other multiprocessors in this article. The operating sys-
tem ran on the peripheral processors, while the user’s ap- 4.9 See also
plication ran on the CPUs. Thus, the terms ASMP and
SMP do not properly apply to these multiprocessors. • 3B20C

• Multi-core (computing)

• Software lockout
4.4 DECsystem-1055
• Giant lock
Digital Equipment Corporation (DEC) offered a dual-
• Symmetric multiprocessing
processor version of its DECsystem-1050 which used two
KA10 processors.[8][9] This offering was extended to later • Heterogeneous computing
processors in the PDP-10 line.
• big.LITTLE

• Tegra 3
4.5 PDP-11/74
Digital Equipment Corporation developed, but never re- 4.10 Notes
leased, a multiprocessor PDP-11, the PDP-11/74,[10]
running a multiprocessor version of RSX-11M.[11] In that [1] IBM (December 1976). IBM System/370 System Sum-
system, either processor could run operating system code, mary. Seventh Edition. pp. 6–12, 6–15–6.16.1.
and could perform I/O, but not all peripherals were acces- GA22·7001·6.
sible to all processors; most peripherals were attached to
[2] Introduction to Multiprocessing: distinguishes “symmet-
one or the other of the CPUs, so that a processor to which ric” from “master/slave”
a peripheral wasn't attached would, when it needed to per-
form an I/O operation on that peripheral, request the pro- [3] Early Computers at Stanford: the dual processor computer
cessor to which the peripheral was attached to perform at the AI lab
the operation.[11]
[4] “Operational Characteristics of the Processors for the
Burroughs B5000”. Burroughs.

[5] “A Narrative Description of the B5500 MCP”. p. 18.


4.6 VAX-11/782
[6] A Narrative Description of the B5500 MCP, pages 29
(initiate routine) and 40 (a note on parallel processing)
DEC’s first multi-processor VAX system, the VAX-
11/782, was an asymmetric dual-processor system; only [7] CONTROL DATA 6400/6500/6600 COMPUTER SYS-
the first processor had access to the I/O devices.[12] TEMS Reference Manual
4.12. EXTERNAL LINKS 15

[8] Introduction to DECsystem-10 Software, section 1.4


(DECsystem-10 Multiprocessing)

[9] DECsystem-10 Technical Summary page 2-1

[10] "(PDP-11) Multiprocessor FAQ”.

[11] “RSX-11M multiprocessing”. Digital Equipment Corpo-


ration.

[12] VAX Product Sales Guide, pages 1-23 and 1-24: the
VAX-11/782 is described as an asymmetric multiprocess-
ing system in 1982

[13] “Univac 1108-II announcement”. Sperry Rand.

[14] “A history of Univac computers and Operating Systems”.

[15] IBM (January 1976). IBM System/370 Model 168 Func-


tional Characteristics. Fifth Edition. GA22·7010-4.

4.11 References
• Bell, C. Gordon, Mudge, J. Craig, McNamara John
E. “The PDP-10 Family”. (1979). Part V of Com-
puter Engineering: A DEC View of Hardware Sys-
tems Design. Digital Equipment Corp.

• Rajkumar Buyya (editor): High Performance Clus-


ter Computing: Architectures and Systems, Volume
1, ISBN 0-13-013784-7, Prentice Hall, NJ, USA,
1999.

• Rajkumar Buyya (editor): High Performance Cluster


Computing: Programming and Applications, Volume
2, ISBN 0-13-013785-5, Prentice Hall, NJ, USA,
1999.

4.12 External links


• OpenMP tutorial for parallel programming

• Multicore News blog


• History of Multi-Processing

• Linux and Multiprocessing


• ASOSI: Asymmetric Operating System Infrastruc-
ture, Proc. 21st Conference on Parallel and Dis-
tributed Computing and Communication Systems,
(PDCCS 2008), New Orleans, Louisiana, pp. 193-
198, 2008
Chapter 5

Non-uniform memory access

For other people or places with the same name as this


P P P P P P P P
abbreviation, see Numa.
BUS BUS
Non-uniform memory access (NUMA) is a computer Memory Memory
memory design used in multiprocessing, where the mem-
ory access time depends on the memory location rela-
tive to the processor. Under NUMA, a processor can ac-
cess its own local memory faster than non-local memory DSM Network
(memory local to another processor or memory shared with Directory
between processors). The benefits of NUMA are limited
to particular workloads, notably on servers where the data
are often associated strongly with certain tasks or users.[1] One possible architecture of a NUMA system. The processors
NUMA architectures logically follow in scaling from connect to the bus or crossbar by connections of varying thick-
symmetric multiprocessing (SMP) architectures. They ness/number. This shows that different CPUs have different ac-
were developed commercially during the 1990s by cess priorities to memory based on their relative location.
Burroughs (later Unisys), Convex Computer (later
Hewlett-Packard), Honeywell Information Systems Italy
(HISI) (later Groupe Bull), Silicon Graphics (later Silicon Limiting the number of memory accesses provided the
Graphics International), Sequent Computer Systems key to extracting high performance from a modern com-
(later IBM), Data General (later EMC), and Digital (later puter. For commodity processors, this meant installing an
Compaq, now HP). Techniques developed by these com- ever-increasing amount of high-speed cache memory and
panies later featured in a variety of Unix-like operating using increasingly sophisticated algorithms to avoid cache
systems, and to an extent in Windows NT. misses. But the dramatic increase in size of the operating
systems and of the applications run on them has gener-
The first commercial implementation of a NUMA-based ally overwhelmed these cache-processing improvements.
Unix system was the Symmetrical Multi Processing XPS- Multi-processor systems without NUMA make the prob-
100 family of servers, designed by Dan Gielan of VAST lem considerably worse. Now a system can starve sev-
Corporation for Honeywell Information Systems Italy. eral processors at the same time, notably because only one
processor can access the computer’s memory at a time.[2]
NUMA attempts to address this problem by providing
5.1 Basic concept separate memory for each processor, avoiding the per-
formance hit when several processors attempt to address
Modern CPUs operate considerably faster than the main the same memory. For problems involving spread data
memory they use. In the early days of computing and data (common for servers and similar applications), NUMA
processing, the CPU generally ran slower than its own can improve the performance over a single shared mem-
memory. The performance lines of processors and mem- ory by a factor of roughly the number of processors (or
ory crossed in the 1960s with the advent of the first su- separate memory banks).[3] Another approach to address-
percomputers. Since then, CPUs increasingly have found ing this problem, utilized mainly by non-NUMA systems,
themselves “starved for data” and having to stall while is the multi-channel memory architecture; multiple mem-
waiting for data to arrive from memory. Many supercom- ory channels are increasing the number of simultaneous
puter designs of the 1980s and 1990s focused on provid- memory accesses.[4]
ing high-speed memory access as opposed to faster pro- Of course, not all data ends up confined to a single task,
cessors, allowing the computers to work on large data sets which means that more than one processor may require
at speeds other systems could not approach. the same data. To handle these cases, NUMA systems

16
5.3. NUMA VS. CLUSTER COMPUTING 17

include additional hardware or software to move data be- As of 2011, ccNUMA systems are multiprocessor sys-
tween memory banks. This operation slows the proces- tems based on the AMD Opteron processor, which can
sors attached to those banks, so the overall speed increase be implemented without external logic, and the Intel
due to NUMA depends heavily on the nature of the run- Itanium processor, which requires the chipset to support
ning tasks.[3] NUMA. Examples of ccNUMA-enabled chipsets are the
Intel announced NUMA compatibility for its x86 and Ita- SGI Shub (Super hub), the Intel E8870, the HP sx2000
nium servers in late 2007 with its Nehalem and Tukwila (used in the Integrity and Superdome servers), and those
CPUs.[5] Both CPU families share a common chipset; the found in NEC Itanium-based systems. Earlier ccNUMA
systems such as those from Silicon Graphics were based
interconnection is called Intel Quick Path Interconnect
(QPI).[6] AMD implemented NUMA with its Opteron on MIPS processors and the DEC Alpha 21364 (EV7)
processor.
processor (2003), using HyperTransport. Freescale’s
NUMA for PowerPC is called CoreNet.

5.3 NUMA vs. cluster computing


5.2 Cache coherent NUMA (cc- One can view NUMA as a tightly coupled form of cluster
NUMA) computing. The addition of virtual memory paging to
a cluster architecture can allow the implementation of
NUMA entirely in software. However, the inter-node
latency of software-based NUMA remains several or-
ders of magnitude greater (slower) than that of hardware-
based NUMA.[1]

5.4 Software support


Since NUMA largely influences memory access perfor-
mance, certain software optimizations are needed to al-
Topology of a ccNUMA Bulldozer server. low scheduling threads and processes close to their in-
memory data.
Nearly all CPU architectures use a small amount of
very fast non-shared memory known as cache to exploit • Microsoft Windows 7 and Windows Server 2008 R2
locality of reference in memory accesses. With NUMA, add support for NUMA architecture over 64 logical
maintaining cache coherence across shared memory has cores.[11]
a significant overhead. Although simpler to design and
• Java 7 added support for NUMA-aware memory al-
build, non-cache-coherent NUMA systems become pro-
locator and garbage collector.[12]
hibitively complex to program in the standard von Neu-
mann architecture programming model.[7] • The Linux kernel 2.5 already had basic support
Typically, ccNUMA uses inter-processor communica- built-in,[13] which was further extended in subse-
tion between cache controllers to keep a consistent mem- quent releases. Linux kernel version 3.8 brought a
ory image when more than one cache stores the same new NUMA foundation which allowed more effi-
memory location. For this reason, ccNUMA may per- cient NUMA policies to be built in the next kernel
form poorly when multiple processors attempt to access releases.[14][15] Linux kernel version 3.13 brought
the same memory area in rapid succession. Support for numerous policies that attempt to put a process near
NUMA in operating systems attempts to reduce the fre- its memory, together with handling of cases such
quency of this kind of access by allocating processors as shared pages between processes, or transparent
and memory in NUMA-friendly ways and by avoiding huge pages; new sysctl settings are allowing NUMA
scheduling and locking algorithms that make NUMA- balancing to be enabled or disabled, as well as var-
unfriendly accesses necessary.[8] ious NUMA memory balancing parameters to be
configured.[16][17][18]
Alternatively, cache coherency protocols such as the
MESIF protocol attempt to reduce the communication • OpenSolaris models NUMA architecture with
required to maintain cache coherency. Scalable Coherent lgroups.
Interface (SCI) is an IEEE standard defining a directory-
based cache coherency protocol to avoid scalability lim-
itations found in earlier multiprocessor systems. For ex- 5.5 See also
ample, SCI is used as the basis for the NumaConnect
technology.[9][10] • Uniform memory access (UMA)
18 CHAPTER 5. NON-UNIFORM MEMORY ACCESS

• Cluster computing [11] NUMA Support (MSDN)

• Symmetric multiprocessing (SMP) [12] Java HotSpot™ Virtual Machine Performance Enhance-
ments
• Cache only memory architecture (COMA)
[13] “Linux Scalability Effort: NUMA Group Homepage”.
• Scratchpad memory (SPM) sourceforge.net. 2002-11-20. Retrieved 2014-02-06.

• Supercomputer [14] “Linux kernel 3.8, Section 1.8. Automatic NUMA bal-
ancing”. kernelnewbies.org. 2013-02-08. Retrieved
• Silicon Graphics (SGI) 2014-02-06.

• HiperDispatch [15] Jonathan Corbet (2012-11-14). “NUMA in a hurry”.


LWN.net. Retrieved 2014-02-06.
• Intel QuickPath Interconnect (QPI)
[16] “Linux kernel 3.13, Section 1.6. Improved performance
• HyperTransport in NUMA systems”. kernelnewbies.org. 2014-01-19. Re-
trieved 2014-02-06.

[17] “Linux kernel documentation: Documenta-


5.6 References tion/sysctl/kernel.txt”. kernel.org. Retrieved 2014-02-06.

[18] Jonathan Corbet (2013-10-01). “NUMA scheduling


[1] Nakul Manchanda; Karan Anand (2010-05-04). “Non- progress”. LWN.net. Retrieved 2014-02-06.
Uniform Memory Access (NUMA)". New York Univer-
sity. Retrieved 2014-01-27.
This article is based on material taken from the Free On-
[2] Sergey Blagodurov; Sergey Zhuravlev; Mohammad line Dictionary of Computing prior to 1 November 2008
Dashti; Alexandra Fedorov (2011-05-02). “A Case and incorporated under the “relicensing” terms of the
for NUMA-aware Contention Management on Multicore GFDL, version 1.3 or later.
Systems” (PDF). Simon Fraser University. Retrieved
2014-01-27.

[3] Zoltan Majo; Thomas R. Gross (2011). “Memory Sys- 5.7 External links
tem Performance in a NUMA Multicore Multiprocessor”
(PDF). ACM. Retrieved 2014-01-27. • NUMA FAQ
[4] “Intel Dual-Channel DDR Memory Architecture White
• Page-based distributed shared memory
Paper” (PDF, 1021 KB) (Rev. 1.0 ed.). Infineon
Technologies North America and Kingston Technology. • OpenSolaris NUMA Project
September 2003. Archived from the original on 2011-
09-29. Retrieved 2007-09-06. • Introduction video for the Alpha EV7 system archi-
tecture
[5] Intel Corp. (2008). Intel QuickPath Architecture [White
paper]. Retrieved from http://www.intel.com/pressroom/ • More videos related to EV7 systems: CPU, IO, etc
archive/reference/whitepaper_QuickPath.pdf
• NUMA optimization in Windows Applications
[6] Intel Corporation. (September 18th, 2007). Gelsinger
Speaks To Intel And High-Tech Industry’s Rapid • NUMA Support in Linux at SGI
Technology Caden[Press release]. Retrieved from
http://www.intel.com/pressroom/archive/releases/2007/ • Intel Tukwila
20070918corp_b.htm
• Intel QPI (CSI) explained
[7] “ccNUMA: Cache Coherent Non-Uniform Memory Ac-
cess”. slideshare.net. 2014. Retrieved 2014-01-27. • current Itanium NUMA systems

[8] Per Stenstromt; Truman Joe; Anoop Gupta (2002).


“Comparative Performance Evaluation of Cache-
Coherent NUMA and COMA Architectures” (PDF).
ACM. Retrieved 2014-01-27.

[9] David B. Gustavson (September 1991). “The Scal-


able Coherent Interface and Related Standards Projects”.
SLAC Publication 5656. Stanford Linear Accelerator Cen-
ter. Retrieved January 27, 2014.

[10] “The NumaChip enables cache coherent low cost shared


memory”. Numascale.com. Retrieved 2014-01-27.
Chapter 6

Multi-core processor

Back side

An AMD Athlon X2 6400+ dual-core processor.

tions at the same time, increasing overall speed for pro-


Front side grams amenable to parallel computing.[2] Manufacturers
typically integrate the cores onto a single integrated cir-
cuit die (known as a chip multiprocessor or CMP), or onto
multiple dies in a single chip package.
Diagram of a generic dual-core processor, with CPU-local level Processors were originally developed with only one core.
1 caches, and a shared, on-die level 2 cache. In the mid 1980s Rockwell International manufactured
versions of the 6502 with two 6502 cores on one chip
as the R65C00, R65C21, and R65C29,[3][4] sharing the
chip’s pins on alternate clock phases. Other multi-core
processors were developed in the early 2000s by Intel,
AMD and others.
Multi-core processors may have two cores (dual-core
CPUs, for example AMD Phenom II X2 and Intel Core
Duo), four cores (quad-core CPUs, for example AMD
Phenom II X4, Intel’s i5 and i7 processors), six cores
(hexa-core CPUs, for example AMD Phenom II X6 and
Intel Core i7 Extreme Edition 980X), eight cores (octo-
core CPUs, for example Intel Xeon E7-2820 and AMD
FX-8350), ten cores (for example, Intel Xeon E7-2850),
An Intel Core 2 Duo E6750 dual-core processor. or more.
A multi-core processor implements multiprocessing in a
A multi-core processor is a single computing compo- single physical package. Designers may couple cores in a
nent with two or more independent actual processing multi-core device tightly or loosely. For example, cores
units (called “cores”), which are the units that read and may or may not share caches, and they may implement
execute program instructions.[1] The instructions are or- message passing or shared memory inter-core communi-
dinary CPU instructions such as add, move data, and cation methods. Common network topologies to inter-
branch, but the multiple cores can run multiple instruc- connect cores include bus, ring, two-dimensional mesh,

19
20 CHAPTER 6. MULTI-CORE PROCESSOR

and crossbar. Homogeneous multi-core systems include 6.2 Development


only identical cores, heterogeneous multi-core systems
have cores that are not identical. Just as with single- While manufacturing technology improves, reducing the
processor systems, cores in multi-core systems may im- size of individual gates, physical limits of semiconductor-
plement architectures such as superscalar, VLIW, vector based microelectronics have become a major design con-
processing, SIMD, or multithreading. cern. These physical limitations can cause significant
Multi-core processors are widely used across many ap- heat dissipation and data synchronization problems. Var-
plication domains including general-purpose, embedded, ious other methods are used to improve CPU perfor-
network, digital signal processing (DSP), and graphics. mance. Some instruction-level parallelism (ILP) methods
such as superscalar pipelining are suitable for many appli-
The improvement in performance gained by the use of a
cations, but are inefficient for others that contain difficult-
multi-core processor depends very much on the software
to-predict code. Many applications are better suited to
algorithms used and their implementation. In particu-
thread level parallelism (TLP) methods, and multiple in-
lar, possible gains are limited by the fraction of the soft-
dependent CPUs are commonly used to increase a sys-
ware that can be run in parallel simultaneously on multi-
tem’s overall TLP. A combination of increased available
ple cores; this effect is described by Amdahl’s law. In the
space (due to refined manufacturing processes) and the
best case, so-called embarrassingly parallel problems may
demand for increased TLP led to the development of
realize speedup factors near the number of cores, or even
multi-core CPUs.
more if the problem is split up enough to fit within each
core’s cache(s), avoiding use of much slower main system
memory. Most applications, however, are not accelerated
so much unless programmers invest a prohibitive amount
6.2.1 Commercial incentives
[5]
of effort in re-factoring the whole problem. The par-
Several business motives drive the development of multi-
allelization of software is a significant ongoing topic of
core architectures. For decades, it was possible to im-
research.
prove performance of a CPU by shrinking the area of
the integrated circuit, which drove down the cost per de-
vice on the IC. Alternatively, for the same circuit area,
more transistors could be used in the design, which in-
creased functionality, especially for CISC architectures.
Clock rates also increased by orders of magnitude in the
decades of the late 20th century, from several megahertz
in the 1980s to several gigahertz in the early 2000s.
6.1 Terminology
As the rate of clock speed improvements slowed, in-
creased use of parallel computing in the form of multi-
core processors has been pursued to improve overall pro-
The terms multi-core and dual-core most commonly re-
cessing performance. Multiple cores were used on the
fer to some sort of central processing unit (CPU), but
same CPU chip, which could then lead to better sales of
are sometimes also applied to digital signal processors
CPU chips with two or more cores. Intel has produced a
(DSP) and system-on-a-chip (SoC). The terms are gener-
48-core processor for research in cloud computing; each
ally used only to refer to multi-core microprocessors that
core has an X86 architecture.[7] Intel has loaded Linux on
are manufactured on the same integrated circuit die; sep-
each core.[8]
arate microprocessor dies in the same package are gener-
ally referred to by another name, such as multi-chip mod-
ule. This article uses the terms “multi-core” and “dual-
core” for CPUs manufactured on the same integrated cir-
6.2.2 Technical factors
cuit, unless otherwise noted.
Since computer manufacturers have long implemented
In contrast to multi-core systems, the term multi-CPU symmetric multiprocessing (SMP) designs using discrete
refers to multiple physically separate processing-units CPUs, the issues regarding implementing multi-core pro-
(which often contain special circuitry to facilitate com- cessor architecture and supporting it with software are
munication between each other). well known.
The terms many-core and massively multi-core are some- Additionally:
times used to describe multi-core architectures with an
especially high number of cores (tens or hundreds).[6]
• Using a proven processing-core design without ar-
Some systems use many soft microprocessor cores placed chitectural changes reduces design risk significantly.
on a single FPGA. Each “core” can be considered a
"semiconductor intellectual property core" as well as a • For general-purpose processors, much of the moti-
CPU core. vation for multi-core processors comes from greatly
6.3. HARDWARE 21

diminished gains in processor performance from in- (FSB). In terms of competing technologies for the avail-
creasing the operating frequency. This is due to able silicon die area, multi-core design can make use of
three primary factors: proven CPU core library designs and produce a product
with lower risk of design error than devising a new wider
1. The memory wall; the increasing gap between core-design. Also, adding more cache suffers from di-
processor and memory speeds. This, in effect, minishing returns.
pushes for cache sizes to be larger in order to
Multi-core chips also allow higher performance at lower
mask the latency of memory. This helps only
energy. This can be a big factor in mobile devices that op-
to the extent that memory bandwidth is not the
erate on batteries. Since each and every core in multi-core
bottleneck in performance.
is generally more energy-efficient, the chip becomes more
2. The ILP wall; the increasing difficulty of find- efficient than having a single large monolithic core. This
ing enough parallelism in a single instruction allows higher performance with less energy. The chal-
stream to keep a high-performance single-core lenge of writing parallel code clearly offsets this benefit.[9]
processor busy.
3. The power wall; the trend of consuming expo-
nentially increasing power with each factorial 6.2.4 Disadvantages
increase of operating frequency. This increase
can be mitigated by "shrinking" the processor Maximizing the usage of the computing resources pro-
by using smaller traces for the same logic. The vided by multi-core processors requires adjustments both
power wall poses manufacturing, system de- to the operating system (OS) support and to existing ap-
sign and deployment problems that have not plication software. Also, the ability of multi-core proces-
been justified in the face of the diminished sors to increase application performance depends on the
gains in performance due to the memory wall use of multiple threads within applications.
and ILP wall. Integration of a multi-core chip drives chip production
yields down and they are more difficult to manage ther-
In order to continue delivering regular performance im- mally than lower-density single-core designs. Intel has
provements for general-purpose processors, manufactur- partially countered this first problem by creating its quad-
ers such as Intel and AMD have turned to multi-core core designs by combining two dual-core on a single die
designs, sacrificing lower manufacturing-costs for higher with a unified cache, hence any two working dual-core
performance in some applications and systems. Multi- dies can be used, as opposed to producing four cores on
core architectures are being developed, but so are the al- a single die and requiring all four to work to produce
ternatives. An especially strong contender for established a quad-core. From an architectural point of view, ulti-
markets is the further integration of peripheral functions mately, single CPU designs may make better use of the
into the chip. silicon surface area than multiprocessing cores, so a de-
velopment commitment to this architecture may carry the
risk of obsolescence. Finally, raw processing power is
6.2.3 Advantages not the only constraint on system performance. Two pro-
cessing cores sharing the same system bus and memory
The proximity of multiple CPU cores on the same die al- bandwidth limits the real-world performance advantage.
lows the cache coherency circuitry to operate at a much It has been claimed that if a single core is close to be-
higher clock-rate than is possible if the signals have to ing memory-bandwidth limited, then going to dual-core
travel off-chip. Combining equivalent CPUs on a sin- might give 30% to 70% improvement; if memory band-
gle die significantly improves the performance of cache width is not a problem, then a 90% improvement can
snoop (alternative: Bus snooping) operations. Put sim- be expected; however, Amdahl’s law makes this claim
ply, this means that signals between different CPUs travel dubious.[10] It would be possible for an application that
shorter distances, and therefore those signals degrade less. used two CPUs to end up running faster on one dual-core
These higher-quality signals allow more data to be sent in if communication between the CPUs was the limiting fac-
a given time period, since individual signals can be shorter tor, which would count as more than 100% improvement.
and do not need to be repeated as often.
Assuming that the die can physically fit into the package,
multi-core CPU designs require much less printed cir-
6.3 Hardware
cuit board (PCB) space than do multi-chip SMP designs.
Also, a dual-core processor uses slightly less power than 6.3.1 Trends
two coupled single-core processors, principally because
of the decreased power required to drive signals external The general trend in processor development has moved
to the chip. Furthermore, the cores share some circuitry, from dual-, tri-, quad-, hex-, oct-core chips to ones with
like the L2 cache and the interface to the front side bus tens or even thousands of cores. In addition, multi-
22 CHAPTER 6. MULTI-CORE PROCESSOR

core chips mixed with simultaneous multithreading, Although threaded applications incur little additional per-
memory-on-chip, and special-purpose “heterogeneous” formance penalty on single-processor machines, the extra
cores promise further performance and efficiency gains, overhead of development has been difficult to justify due
especially in processing multimedia, recognition and net- to the preponderance of single-processor machines. Also,
working applications. There is also a trend of improving serial tasks like decoding the entropy encoding algorithms
energy-efficiency by focusing on performance-per-watt used in video codecs are impossible to parallelize because
with advanced fine-grain or ultra fine-grain power man- each result generated is used to help create the next result
agement and dynamic voltage and frequency scaling (i.e. of the entropy decoding algorithm.
laptop computers and portable media players).
Given the increasing emphasis on multi-core chip design,
stemming from the grave thermal and power consump-
tion problems posed by any further significant increase in
6.3.2 Architecture processor clock speeds, the extent to which software can
be multithreaded to take advantage of these new chips
The composition and balance of the cores in multi-core
is likely to be the single greatest constraint on computer
architecture show great variety. Some architectures use
performance in the future. If developers are unable to
one core design repeated consistently (“homogeneous”),
design software to fully exploit the resources provided by
while others use a mixture of different cores, each opti-
multiple cores, then they will ultimately reach an insur-
mized for a different, "heterogeneous" role.
mountable performance ceiling.
The article “CPU designers debate multi-core future” by
The telecommunications market had been one of the first
Rick Merritt, EE Times 2008,[11] includes these com-
that needed a new design of parallel datapath packet pro-
ments:
cessing because there was a very quick adoption of these
multiple-core processors for the datapath and the control
Chuck Moore [...] suggested computers plane. These MPUs are going to replace[12] the tradi-
should be more like cellphones, using a va- tional Network Processors that were based on proprietary
riety of specialty cores to run modular soft- micro- or pico-code.
ware scheduled by a high-level applications
Parallel programming techniques can benefit from mul-
programming interface.
tiple cores directly. Some existing parallel program-
[...] Atsushi Hasegawa, a senior chief en-
ming models such as Cilk Plus, OpenMP, OpenHMPP,
gineer at Renesas, generally agreed. He sug-
FastFlow, Skandium, MPI, and Erlang can be used on
gested the cellphone’s use of many specialty
multi-core platforms. Intel introduced a new abstraction
cores working in concert is a good model for
for C++ parallelism called TBB. Other research efforts
future multi-core designs.
include the Codeplay Sieve System, Cray’s Chapel, Sun’s
[...] Anant Agarwal, founder and chief ex- Fortress, and IBM’s X10.
ecutive of startup Tilera, took the opposing
view. He said multi-core chips need to be Multi-core processing has also affected the ability of
homogeneous collections of general-purpose modern computational software development. Develop-
cores to keep the software model simple. ers programming in newer languages might find that their
modern languages do not support multi-core functional-
ity. This then requires the use of numerical libraries to ac-
cess code written in languages like C and Fortran, which
6.4 Software effects perform math computations faster than newer languages
like C#. Intel’s MKL and AMD’s ACML are written in
An outdated version of an anti-virus application may cre- these native languages and take advantage of multi-core
ate a new thread for a scan process, while its GUI thread processing. Balancing the application workload across
waits for commands from the user (e.g. cancel the scan). processors can be problematic, especially if they have dif-
In such cases, a multi-core architecture is of little bene- ferent performance characteristics. There are different
fit for the application itself due to the single thread doing conceptual models to deal with the problem, for exam-
all the heavy lifting and the inability to balance the work ple using a coordination language and program building
evenly across multiple cores. Programming truly multi- blocks (programming libraries or higher-order functions).
threaded code often requires complex co-ordination of Each block can have a different native implementation for
threads and can easily introduce subtle and difficult-to- each processor type. Users simply program using these
find bugs due to the interweaving of processing on data abstractions and an intelligent compiler chooses the best
shared between threads (thread-safety). Consequently, implementation based on the context.[13]
such code is much more difficult to debug than single-
Managing concurrency acquires a central role in devel-
threaded code when it breaks. There has been a perceived
oping parallel applications. The basic steps in designing
lack of motivation for writing consumer-level threaded
parallel applications are:
applications because of the relative rarity of consumer-
level demand for maximum use of computer hardware.
6.5. EMBEDDED APPLICATIONS 23

Partitioning The partitioning stage of a design is in- 6.5 Embedded applications


tended to expose opportunities for parallel execu-
tion. Hence, the focus is on defining a large number Embedded computing operates in an area of processor
of small tasks in order to yield what is termed a fine- technology distinct from that of “mainstream” PCs. The
grained decomposition of a problem. same technological drivers towards multi-core apply here
too. Indeed, in many cases the application is a “natural”
Communication The tasks generated by a partition are fit for multi-core technologies, if the task can easily be
intended to execute concurrently but cannot, in gen- partitioned between the different processors.
eral, execute independently. The computation to be In addition, embedded software is typically developed for
performed in one task will typically require data as- a specific hardware release, making issues of software
sociated with another task. Data must then be trans- portability, legacy code or supporting independent devel-
ferred between tasks so as to allow computation to opers less critical than is the case for PC or enterprise
proceed. This information flow is specified in the computing. As a result, it is easier for developers to adopt
communication phase of a design. new technologies and as a result there is a greater variety
of multi-core processing architectures and suppliers.
Agglomeration In the third stage, development moves As of 2010, multi-core network processing devices
from the abstract toward the concrete. Developers have become mainstream, with companies such as
revisit decisions made in the partitioning and com- Freescale Semiconductor, Cavium Networks, Wintegra
munication phases with a view to obtaining an al- and Broadcom all manufacturing products with eight pro-
gorithm that will execute efficiently on some class cessors. For the system developer, a key challenge is how
of parallel computer. In particular, developers con- to exploit all the cores in these devices to achieve maxi-
sider whether it is useful to combine, or agglomer- mum networking performance at the system level, despite
ate, tasks identified by the partitioning phase, so as the performance limitations inherent in an SMP operating
to provide a smaller number of tasks, each of greater system. To address this issue, companies such as 6WIND
size. They also determine whether it is worthwhile provide portable packet processing software designed so
to replicate data and computation. that the networking data plane runs in a fast path environ-
ment outside the OS, while retaining full compatibility
with standard OS APIs.[17]
Mapping In the fourth and final stage of the design
In digital signal processing the same trend applies: Texas
of parallel algorithms, the developers specify where
Instruments has the three-core TMS320C6488 and four-
each task is to execute. This mapping problem does
core TMS320C5441, Freescale the four-core MSC8144
not arise on uniprocessors or on shared-memory
and six-core MSC8156 (and both have stated they are
computers that provide automatic task scheduling.
working on eight-core successors). Newer entries include
the Storm-1 family from Stream Processors, Inc with 40
On the other hand, on the server side, multi-core proces- and 80 general purpose ALUs per chip, all programmable
sors are ideal because they allow many users to connect in C as a SIMD engine and Picochip with three-hundred
to a site simultaneously and have independent threads of processors on a single die, focused on communication ap-
execution. This allows for Web servers and application plications.
servers that have much better throughput.

6.6 Hardware examples


6.4.1 Licensing
6.6.1 Commercial
Vendors may license some software “per processor”. This
can give rise to ambiguity, because a “processor” may • Adapteva Epiphany, a many-core processor archi-
consist either of a single core or of a combination of tecture which allows up to 4096 processors on-chip,
cores. although only a 16 core version has been commer-
cially produced.

• Microsoft has stated that it would treat a socket as a • Aeroflex Gaisler LEON3, a multi-core SPARC that
single processor.[14][15] also exists in a fault-tolerant version.
• Ageia PhysX, a multi-core physics processing unit.
• Oracle Corporation counts an AMD X2 or an In- • Ambric Am2045, a 336-core Massively Parallel
tel dual-core CPU as a single processor but uses Processor Array (MPPA)
other metrics for other types, especially for proces-
sors with more than two cores.[16] • AMD
24 CHAPTER 6. MULTI-CORE PROCESSOR

• A-Series, dual-, triple-, and quad-core of Ac- • POWER4, a dual-core processor, released in
celerated Processor Units (APU). 2001.
• Athlon 64, Athlon 64 FX and Athlon 64 X2 • POWER5, a dual-core processor, released in
family, dual-core desktop processors. 2004.
• Athlon II, dual-, triple-, and quad-core desktop • POWER6, a dual-core processor, released in
processors. 2007.
• FX-Series, quad-, 6-, and 8-core desktop pro- • POWER7, a 4,6,8-core processor, released in
cessors. 2010.
• Opteron, dual-, quad-, 6-, 8-, 12-, and 16-core • POWER8, a 12-core processor, released in
server/workstation processors. 2013.
• Phenom, dual-, triple-, and quad-core proces- • PowerPC 970MP, a dual-core processor, used
sors. in the Apple Power Mac G5.
• Phenom II, dual-, triple-, quad-, and 6-core • Xenon, a triple-core, SMT-capable, PowerPC
desktop processors. microprocessor used in the Microsoft Xbox
• Sempron X2, dual-core entry level processors. 360 game console.

• Turion 64 X2, dual-core laptop processors. • Kalray


• Radeon and FireStream multi-core • MPPA-256, 256-core processor, released
GPU/GPGPU (10 cores, 16 5-issue wide 2012 (256 usable VLIW cores, Network-on-
superscalar stream processors per core) Chip (NoC), 32/64-bit IEEE 754 compliant
• Analog Devices Blackfin BF561, a symmetrical FPU)
dual-core processor • Sony/IBM/Toshiba's Cell processor, a nine-core
• ARM MPCore is a fully synthesizable multi-core processor with one general purpose PowerPC core
container for ARM11 MPCore and ARM Cortex- and eight specialized SPUs (Synergystic Processing
A9 MPCore processor cores, intended for high- Unit) optimized for vector operations used in the
performance embedded and entertainment applica- Sony PlayStation 3
tions. • Infineon Danube, a dual-core, MIPS-based, home
• ASOCS ModemX, up to 128 cores, wireless appli- gateway processor.
cations. • Intel
• Azul Systems • Atom, single and dual-core processors for net-
• Vega 1, a 24-core processor, released in 2005. book systems.
• Vega 2, a 48-core processor, released in 2006. • Celeron Dual-Core, the first dual-core proces-
sor for the budget/entry-level market.
• Vega 3, a 54-core processor, released in 2008.
• Core Duo, a dual-core processor.
• Broadcom SiByte SB1250, SB1255, SB1455; BCM • Core 2 Duo, a dual-core processor.
2836 quad-core ARM SoC (designed for the
Raspberry Pi 2) • Core 2 Quad, 2 dual-core dies packaged in a
multi-chip module.
• ClearSpeed • Core i3, Core i5 and Core i7, a family of multi-
• CSX700, 192-core processor, released in core processors, the successor of the Core 2
2008 (32/64-bit floating point; Integer ALU) Duo and the Core 2 Quad.
• Itanium 2, a dual-core processor.
• Cradle Technologies CT3400 and CT3600, both
multi-core DSPs. • Pentium D, 2 single-core dies packaged in a
multi-chip module.
• Cavium Networks Octeon, a 32-core MIPS MPU. • Pentium Extreme Edition, 2 single-core dies
• Freescale Semiconductor QorIQ series processors, packaged in a multi-chip module.
up to 8 cores, Power Architecture MPU. • Pentium Dual-Core, a dual-core processor.
• Hewlett-Packard PA-8800 and PA-8900, dual core • Teraflops Research Chip (Polaris), a 3.16
PA-RISC processors. GHz, 80-core processor prototype, which the
company originally stated would be released
• IBM by 2011.[18]
6.7. BENCHMARKS 25

• Xeon dual-, quad-, 6-, 8-, 10- and 15-core • SPARC T5, a sixteen-core, 128-concurrent-
processors.[19] thread processor.
• Xeon Phi 57-core, 60-core and 61-core pro- • Texas Instruments
cessors.
• TMS320C80 MVP, a five-core multimedia
• IntellaSys video processor.
• SEAforth 40C18, a 40-core processor[20] • TMS320TMS320C66, 2,4,8 core dsp.
• SEAforth24, a 24-core processor designed by • Tilera
Charles H. Moore
• TILE64, a 64-core 32-bit processor
• NetLogic Microsystems
• TILE-Gx, a 72-core 64-bit processor
• XLP, a 32-core, quad-threaded MIPS64 pro- • XMOS Software Defined Silicon quad-core XS1-
cessor G4
• XLR, an eight-core, quad-threaded MIPS64
processor
• XLS, an eight-core, quad-threaded MIPS64
6.6.2 Free
processor • OpenSPARC
• Nvidia

• GeForce 9 multi-core GPU (8 cores, 16 scalar 6.6.3 Academic


stream processors per core)
• MIT, 16-core RAW processor
• GeForce 200 multi-core GPU (10 cores, 24
scalar stream processors per core) • University of California, Davis, Asynchronous array
• Tesla multi-core GPGPU (10 cores, 24 scalar of simple processors (AsAP)
stream processors per core) • 36-core 610 MHz AsAP
• Parallax Propeller P8X32, an eight-core microcon- • 167-core 1.2 GHz AsAP2
troller.
• University of Washington, Wavescalar processor
• picoChip PC200 series 200–300 cores per device
• University of Texas, Austin, TRIPS processor
for DSP & wireless
• Linköping University, Sweden, ePUMA processor
• Plurality HAL series tightly coupled 16-256 cores,
L1 shared memory, hardware synchronized proces-
sor.
6.7 Benchmarks
• Rapport Kilocore KC256, a 257-core microcon-
troller with a PowerPC core and 256 8-bit “process- The research and development of multicore processors
ing elements”. often compares many options, and benchmarks are de-
• SiCortex “SiCortex node” has six MIPS64 cores on veloped to help such evaluations. Existing benchmarks
a single chip. include SPLASH-2, PARSEC, and COSMIC for hetero-
geneous systems.[21]
• Sun Microsystems

• MAJC 5200, two-core VLIW processor


6.8 Notes
• UltraSPARC IV and UltraSPARC IV+, dual-
core processors. 1. ^ Digital signal processors (DSPs) have used multi-
• UltraSPARC T1, an eight-core, 32-thread pro- core architectures for much longer than high-end
cessor. general-purpose processors. A typical example of a
• UltraSPARC T2, an eight-core, 64- DSP-specific implementation would be a combina-
concurrent-thread processor. tion of a RISC CPU and a DSP MPU. This allows
for the design of products that require a general-
• UltraSPARC T3, a sixteen-core, 128- purpose processor for user interfaces and a DSP
concurrent-thread processor. for real-time data processing; this type of design is
• SPARC T4, an eight-core, 64-concurrent- common in mobile phones. In other applications,
thread processor. a growing number of companies have developed
26 CHAPTER 6. MULTI-CORE PROCESSOR

multi-core DSPs with very large numbers of proces- [5] Aater Suleman (May 20, 2011). “What makes parallel
sors. programming hard?". FutureChips. Retrieved March 6,
2013.
2. ^ Two types of operating systems are able to use
a dual-CPU multiprocessor: partitioned multipro- [6] Programming Many-Core Chips. By András Vajda, page
3
cessing and symmetric multiprocessing (SMP). In a
partitioned architecture, each CPU boots into sep- [7] Ryan Shrout (December 2, 2009). “Intel Shows 48-core
arate segments of physical memory and operate in- x86 Processor as Single-chip Cloud Computer”. Re-
dependently; in an SMP OS, processors work in a trieved March 6, 2013.
shared space, executing threads within the OS inde-
[8] “Intel unveils 48-core cloud computing silicon chip”.
pendently.
BBC. December 3, 2009. Retrieved March 6, 2013.

[9] Aater Suleman (May 19, 2011). “Q & A: Do multicores


6.9 See also save energy? Not really.”. Retrieved March 6, 2013.

[10] Ni, Jun. “Multi-core Programming for Medical Imaging”.


• Race condition Retrieved 17 February 2013.

• Multicore Association [11] Rick Merritt (February 6, 2008). “CPU designers debate
multi-core future”. EE Times. Retrieved March 6, 2013.
• Hyper-threading
[12] Multicore packet processing Forum
• Multitasking
[13] John Darlinton, Moustafa Ghanem, Yike Guo, Hing Wing
• PureMVC MultiCore – a modular programming To (1996), “Guided Resource Organisation in Heteroge-
neous Parallel Computing”, Journal of High Performance
framework
Computing 4 (1): 13–23
• XMTC [14] Multicore Processor Licensing
• Parallel Random Access Machine [15] Compare: “Multi-Core Processor Licensing”. down-
load.microsoft.com. Microsoft Corporation. 2004-10-19.
• Partitioned global address space (PGAS) p. 1. Retrieved 2015-03-05. On October 19, 2004, Mi-
crosoft announced that our server software that is cur-
• Thread rently licensed on a per-processor model will continue to
be licensed on a per-processor, and not on a per-core,
• CPU shielding
model.
• GPGPU [16] Compare: “The Licensing Of Oracle Technology Prod-
ucts”. OMT-CO Operations Management Technology
• CUDA
Consulting GmbH. Retrieved 2014-03-04.
• OpenCL (Open Computing Language) – a frame- [17] Maximizing network stack performance
work for heterogeneous execution
[18] 80-core prototype from Intel
• Ateji PX – an extension of the Java language for par-
allelism [19] 15 core Xeon

[20] “40-core processor with Forth-based IDE tools unveiled”


• BMDFM (Binary Modular Dataflow Machine) –
Multi-core Runtime Environment [21] “COSMIC Heterogeneous Multiprocessor Benchmark
Suite”

6.10 References
6.11 External links
[1] Margaret Rouse (March 27, 2007). “Definition: multi-
core processor”. TechTarget. Retrieved March 6, 2013. • What Is A Processor Core?
[2] CSA Organization • Embedded moves to multicore
[3] “Rockwell R65C00/21 Dual CMOS Microcomputer and • Multicore News blog
R65C29 Dual CMOS Microprocessor”. Rockwell Inter-
national. October 1984. • IEEE: Multicore Is Bad News For Supercomputers
[4] “Rockwell 1985 Data Book”. Rockwell International
Semiconductor Products Division. January 1985.
Chapter 7

Intel Atom (CPU)

This article is about the netbook and MID version of nouncement, outside sources had speculated that Atom
Atom. It is not to be confused with the Atom (system on would compete with AMD's Geode system-on-a-chip
chip) for smartphones and tablets. processors, used by the One Laptop per Child (OLPC)
project, and other cost and power sensitive applications
Intel Atom is the brand name for a line of ultra-low- for x86 processors. However, Intel revealed on 15 Oc-
voltage IA-32 and x86-64 CPUs (or microprocessors) tober 2007 that it was developing another new mo-
from Intel, originally designed in 45 nm complementary bile processor,
[12]
codenamed Diamondville, for OLPC-type
metal–oxide–semiconductor (CMOS) with subsequent devices.
models, codenamed Cedar, using a 32 nm process.[2] “Atom” was the name under which Silverthorne would be
Atom is mainly used in netbooks, nettops, embedded ap- sold, while the supporting chipset formerly code-named
plications ranging from health care to advanced robotics, Menlow was called Centrino Atom.[13]
and mobile Internet devices (MIDs). At Spring Intel Developer Forum (IDF) 2008 in
Atom processors are based on the Bonnell microarchi- Shanghai, Intel officially announced that Silverthorne
tecture.[3][4] On 21 December 2009, Intel announced the and Diamondville are based on the same microarchitec-
Pine Trail platform, including new Atom processor code- ture. Silverthorne would be called the Atom Z5xx se-
named Pineview (Atom N450), with total kit power con- ries and Diamondville would be called the Atom N2xx
sumption down 20%.[5] On 28 December 2011, Intel up- series. The more expensive lower-power Silverthorne
dated the Atom line with the Cedar processors.[2] parts will be used in Intel mobile Internet devices (MIDs)
In December 2012, Intel launched the 64-bit Centerton whereas Diamondville will be used in low-cost desktop
family of Atom CPUs, designed specifically for use in and notebooks. Several Mini-ITX motherboard samples
servers.[6] Centerton adds features previously unavailable have also been revealed.[14] Intel and Lenovo also jointly
in Atom processors, such as Intel VT virtualization tech- announced an Atom powered MID called the IdeaPad
nology and support for ECC memory.[7] On 4 September U8.[15]
2013 Intel launched a 22 nm successor to Centerton, co- In April 2008, a MID development kit was an-
denamed Avoton.[8] nounced by Sophia Systems[16] and the first board called
CoreExpress-ECO was revealed by a German company
In 2012, Intel announced a new system on chip (SoC)
platform designed for smartphones and tablets which LiPPERT Embedded Computers, GmbH.[17] Intel offers
[18][19]
would use the Atom line of CPUs.[9] It is a continuation Atom based motherboards.
of the partnership announced by Intel and Google on 13 In December 2012, Intel released Atom for servers, the
September 2011 to provide support for the Android oper- S1200 series. The primary difference between these pro-
ating system on Intel x86 processors.[10] This range com- cessors and all prior versions, is that ECC memory sup-
petes with existing SoCs developed for the smartphone port has been added, enabling the use of the Atom in
and tablet market from companies like Texas instruments, mission-critical server environments that demand redun-
Nvidia, Qualcomm and Samsung.[11] dancy and memory failure protection.

7.1 History 7.2 Instruction set architecture

Intel Atom is a direct successor of the Intel A100 and 7.2.1 32-bit and 64-bit hardware support
A110 low-power microprocessors (code-named Stealey),
which were built on a 90 nm process, had 512 kB L2 All Atom processors implement the x86 (IA-32) instruc-
cache and ran at 600 MHz/800 MHz with 3 W TDP tion set; however, support for the Intel 64 instruction set
(Thermal Design Power). Prior to the Silverthorne an- was not added until the desktop Diamondville and desktop

27
28 CHAPTER 7. INTEL ATOM (CPU)

and mobile Pineview cores. The Atom N2xx and Z5xx se- and southbridges, onto a mainboard, Atom processors are
ries Atom models cannot run x86-64 code.[21] The Cen- not available to home users or system builders as sep-
terton server processors will support the Intel 64 instruc- arate processors, although they may be obtained prein-
tion set.[7] stalled on some ITX motherboards. The Diamondville
and Pineview[29] Atom is used in the HP Mini Series,
aigo MID Asus N10, Lenovo IdeaPad S10, Acer As-
7.2.2 Intel 64 software support pire One & Packard Bell’s “dot” (ZG5), recent ASUS
Eee PC systems, Sony VAIO M-series, AMtek Elego,
Intel states the Atom supports 64-bit operation only “with Dell Inspiron Mini Series, Gigabyte M912, LG X Series,
a processor, chipset, BIOS” that all support Intel 64. Samsung NC10, Sylvania g Netbook Meso, Toshiba NB
Those Atom systems not supporting all of these cannot series (100, 200, 205, 255, 300, 500, 505), MSI Wind PC
enable Intel 64.[22] As a result, the ability of an Atom- netbooks, RedFox Wizbook 1020i, Sony Vaio X Series,
based system to run 64-bit versions of operating sys- Zenith Z-Book, a range of Aleutia desktops, Magic W3
tems such as Ubuntu or Debian GNU/Linux may vary and the Archos.The Pineview line is also used in multiple
from one motherboard to another. Online retailer mini- AAC devices for the disabled individual who is unable
itx.com has tested Atom-based motherboards made by to speak and the AAC device assists the user in everyday
Intel and Jetway, and while they were able to install 64- communication with dedicated speech software.
bit versions of Linux on Intel-branded motherboards with
D2700 (Pineview) processors, Intel 64 support was not
enabled on a Jetway-branded motherboard with a D2550
(Pineview) processor.[23]
7.4 Performance
Even among Atom-based systems which have Intel 64
The performance of a single core Atom is about half that
enabled, not all are able to run 64-bit versions of
of a Pentium M of the same clock rate. For example, the
Microsoft Windows. For those Pineview processors
Atom N270 (1.60 GHz) found in many netbooks such
which support 64-bit operation, Intel Download Center
as the Eee PC can deliver around 3300 MIPS and 2.1
currently provides 64-bit Windows 7 and Windows Vista
GFLOPS in standard benchmarks,[30] compared to 7400
drivers for Intel GMA 3150 graphics, found in Pineview
MIPS and 3.9 GFLOPS for the similarly clocked (1.73
processors.[24] However, no 64-bit Windows drivers are
GHz) Pentium M 740.[31]
available for Intel Atom Cedarview processors, released
Q3 2011.[25] However, Intel’s Bay Trail-M processors, The Pineview platform has proven to be only slightly
built on the Silvermont microarchitecture and released in faster than the previous Diamondville platform. This is
the second half of 2013, regain 64-bit support, although because the Pineview platform uses the same Bonnell
driver support for Linux and Windows 7 is limited at execution core as Diamondville and is connected to the
launch.[26] memory controller via the FSB, hence memory latency
and performance in CPU-intensive applications are min-
The lack of 64-bit Windows support for Cedarview pro-
imally improved.[32]
cessors appears to be due to a driver issue. A member
of the Intel Enthusiast Team has stated in a series of
posts on enthusiast site Tom’s Hardware that while the
Atom D2700 (Pineview) was designed with Intel 64 sup- 7.5 Bonnell microarchitecture
port, due to a “limitation of the board” Intel had pulled
their previously-available 64-bit drivers for Windows 7 Main article: Bonnell (microarchitecture)
and would not provide any further 64-bit support.[27]
Some system manufacturers have similarly stated that
their motherboards with Atom Cedarview processors lack Intel Atom processors [3][4]
are based on the Bonnell
64-bit support due to a “lack of Intel® 64-bit VGA driver microarchitecture, which can execute up to two in-
support”. [28]
Because all Cedarview processors use the structions per cycle. Like many other x86 micropro-
same Intel GMA 3600 or 3650 graphics as the D2700, cessors, it translates x86-instructions (CISC instructions)
this indicates that Atom Cedarview systems will remain into simpler internal operations (sometimes referred to
unable to run 64-bit versions of Windows, even those as micro-ops, i.e., effectively RISC style instructions)
which have Intel 64 enabled and are able to run 64-bit prior to execution. The majority of instructions pro-
versions of Linux. duce one micro-op when translated, with around 4% of
instructions used in typical programs producing multi-
ple micro-ops. The number of instructions that produce
more than one micro-op is significantly fewer than the P6
7.3 Availability and NetBurst microarchitectures. In the Bonnell microar-
chitecture, internal micro-ops can contain both a memory
Atom processors became available to system manufactur- load and a memory store in connection with an ALU op-
ers in 2008. Because they are soldered, like northbridges eration, thus being more similar to the x86 level and more
7.8. SEE ALSO 29

powerful than the micro-ops used in previous designs.[33] based System on Chip (SoC) that offers a below average
This enables relatively good performance with only two thermal envelope compared to the Atom.
integer ALUs, and without any instruction reordering, Kenton Williston of EE Times said that while Atom will
speculative execution, or register renaming. The Bon- not displace ARM from its current markets, the ability to
nell microarchitecture therefore represents a partial re- apply the PC architecture into smaller, cheaper and lower
vival of the principles used in earlier Intel designs such as power form factors will open up new markets for Intel.[44]
P5 and the i486, with the sole purpose of enhancing the
performance per watt ratio. However, Hyper-Threading ARM has found that Intel’s Atom processors offer less
is implemented in an easy (i.e., low power) way to em- compatibility and lower performance than their chips
ploy the whole pipeline efficiently by avoiding the typical when running Android, and higher power consumption
single thread dependencies.[33] and less battery life for the same tasks under both An-
droid and Windows.[45]
Even AMD is in this competition with the Mullins brand
7.6 Collaborations based on Puma Microarchitecture who offers better
Computing and even better Graphics performance with
In March 2009, Intel announced that it would be col- similar thermal power.
laborating with TSMC for the production of the Atom
processors.[34] The deal was put on hold due to lack of
demand in 2010. 7.8 See also
On 13 September 2011 Intel and Google held a joint
• List of Intel Atom microprocessors
announcement of a partnership to provide support in
Google’s Android operating system for Intel processors • Intel Edison
(beginning with the Atom). This would allow Intel
to supply chips for the growing smartphone and tablet • Intel Quark
market.[35]

7.9 Notes
7.7 Competition
[1] “Intel® Atom™ Processor Z520”. Intel. Archived from
the original on 2011-07-04.
Embedded processors based on the ARM version 7 in-
struction set architecture (such as Nvidia's Tegra 3 series, [2] Anand Lal Shimpi. “Intel’s Atom N2600, N2800 &
TI’s 4 series and Freescale’s i.MX51 based on the Cortex- D2700: Cedar Trail, The Heart of the 2012 Netbook”.
A8 core, or the Qualcomm Snapdragon and Marvell Ar- Archived from the original on 2014-04-29. Retrieved 28
December 2011.
mada 500/600 based on custom ARMv7 implementa-
tions) offer similar performance to the low end Atom [3] Jeff Moriarty (1 April 2008). "'Atom 101' - Deciphering
chipsets but at roughly one quarter the power consump- the Intel codewords around MIDs”. Archived from the
tion, and (like most ARM systems) as a single integrated original on 2012-03-27. Retrieved 4 August 2010.
system on a chip, rather than a two chip solution like the
[4] Anand Lal Shimpi (27 January 2010). “Why Pine Trail
current Atom line. Although the second-generation Atom
Isn't Much Faster Than the First Atom”. Archived from
codenamed “Pineview” should greatly increase its com- the original on 2014-01-04. Retrieved 4 August 2010.
petitiveness in performance/watt, ARM plans to counter
the threat with the multi-core capable Cortex-A9 core [5] “Intel Announces Next-Generation Atom Platform”.
as used in Nvidia’s Tegra 2/3, TI’s OMAP 4 series, and Intel. Archived from the original on 2013-06-06.
Qualcomm's next-generation Snapdragon series, among [6] “Products (Formerly Centerton)". Archived from the
others. original on 2013-10-14. Retrieved 22 March 2013.
The Nano and Nano Dual-Core series from VIA is [7] Ryan Smith (11 December 2012). “Intel Launches Cen-
slightly above the average thermal envelope of the Atom, terton Atom S1200 Family, First Atom for Servers”.
but offers hardware AES support, random number gen- Archived from the original on 2014-05-02. Retrieved 22
erators, and out-of-order execution. Performance com- March 2013.
parisons of the Intel Atom against the Via Nano indi-
[8] Inside Intel’s Atom C2000-series 'Avoton' processors
cate that a single core Intel Atom is easily outperformed
Archived February 9, 2014 at the Wayback Machine
by the Via Nano which is in turn outperformed by a
dual core Intel Atom 330 in tests where multithreading [9] Intel Raises Bar on Smartphones, Tablets and Ultra-
is used. The Core 2 Duo SU7300 outperforms the dual- book™ Devices
core Nano.[36][37][38][39][40][41][42][43]
[10] Antara News : Intel, Google announce partnership for An-
The Xcore86 (also known as the PMX 1000) is x586 droid smartphones
30 CHAPTER 7. INTEL ATOM (CPU)

[11] Sadauskas, Andrew (30 April 2012). “Intel battles ARM [30] “SiSoft Sandra : Atom Benchmarked: 4W Of Perfor-
with new handset”. smartcompany.com.au. Retrieved 29 mance”. Tomshardware.com. 29 July 2008. Retrieved
May 2012. 4 April 2010.

[12] “Intel to unveil OLPC chips in Shanghai next April”. [31] “Intel Pentium M 740 PCSTATS Review - Benchmarks:
InfoWorld. 15 October 2007. Archived from the origi- Office Productivity, SiSoft Sandra 2005”. PCstats.com.
nal on 2012-03-11. Archived from the original on 2013-10-29.

[13] “Intel Announces Atom Brand for Silverthorne, Menlow”. [32] “Why Pine Trail Isn't Much Faster Than the First Atom”.
PC World. Archived from the original on 2008-07-09. AnandTech. Archived from the original on 2010-02-01.
Retrieved 4 April 2010.
[14] “Intel Developer Forum Spring 2008: Day 1 – Hardware
Upgrade”. Hwupgrade.it. 30 July 2005. Archived from [33] “Intel’s Atom Architecture: The Journey Begins”.
the original on 2012-01-12. Retrieved 4 April 2010. AnandTech. Archived from the original on 2009-05-31.
Retrieved 4 April 2010.
[15] “Lenovo exhibits Atom based MID Ideapad U8 at IDF
2008 : Specs, reviews and prices”. Archived from the [34] “TSMC To Build Intel’s Atom-Based Chips”. Forbes. 2
original on 2012-02-23. March 2009. Archived from the original on 2012-10-27.
Retrieved 3 March 2009.
[16] “MID dev kit sports Centrino Atom chipset”. Archived
from the original on 2009-03-02. Retrieved 29 January [35] “Intel, Google announce partnership for Android smart-
2011. phones”. 14 September 2011. Archived from the original
on 2013-12-04.
[17] “Tiny Centrino Atom-based module unveiled”. Archived
from the original on 2009-04-27. Retrieved 29 January [36] “Intel Atom vs. VIA Nano Platform Comparo Introduc-
2011. tion”. TweakTown. 11 August 2008. Archived from the
original on 2014-04-13. Retrieved 4 April 2010.
[18] “Intel Desktop Board D945GCLF – Overview”. Archived
from the original on 2008-08-21. Retrieved 29 January [37] “VIA Nano Dual Core Preview”. 26 December 2010.
2011. Archived from the original on 2014-04-13. Retrieved 26
December 2010.
[19] “Intel offers $80 “Little Falls” Atom mobo”. Archived
from the original on 2009-02-16. Retrieved 29 January [38] Kyle Bennett. “Introduction & Power - Intel Atom vs.VIA
2011. Nano”. Hardocp.com. Archived from the original on
2012-02-19. Retrieved 4 April 2010.
[20] “Products: SPECIFICATIONS: Intel® Atom™ Proces-
sor”. [39] “VIA Nano vs Intel Atom”. TrustedReviews. Archived
from the original on 2009-09-05. Retrieved 4 April 2010.
[21] “Intel Atom Processor Specifications”. Intel.com.
Archived from the original on 2011-03-17. Retrieved 4 [40] “VIA Nano Outperforms Intel Atom in Actual Industry
April 2010. Performance Benchmarking tests”. Mydigitallife.info. 31
July 2008. Archived from the original on 2010-01-02.
[22] “Intel N2600 : Atom Benchmarked: 4W Of Perfor- Retrieved 4 April 2010.
mance”. Intel.com. 28 August 2012. Archived from the
original on 2014-04-21. Retrieved 28 August 2012. [41] “Intel Atom Initial Benchmarking Data vs. Pentium and
Celeron M Processors Before Official Release”. Mydigi-
[23] “mini-itx.com - store - Intel Atom Mini-ITX boards”. tallife.info. 8 March 2008. Archived from the original on
mini-itx.com. Archived from the original on 2013-06-13. 2011-04-08. Retrieved 4 April 2010.
Retrieved 4 March 2013.
[42] “EEE PC vs MSI Wind - Atom vs Celeron CPU Perfor-
[24] “Download Center”. Intel.com. Archived from the origi- mance Benchmark: Netbooks, EEE PC, MSI Wind, As-
nal on 2014-03-18. Retrieved 4 March 2013. pire One and Akoya Resources”. Eeejournal.com. 11
[25] “Logic Supply Cedar View”. logicsupply.com. Archived May 2008. Archived from the original on 2014-04-13.
from the original on 2013-10-26. Retrieved 4 March Retrieved 4 April 2010.
2013. [43] “Intel Atom 230/330/VIA Nano performances con-
[26] “Logic Supply Bay Trail Offers Performance Boost”. log- trasted”. En.hardspell.com. 25 September 2008.
icsupply.com. Archived from the original on 2014-03-17. Archived from the original on 2008-12-20. Retrieved 4
Retrieved 17 March 2013. April 2010.

[27] "[Solved] Atom D2700 (Cedar Trail) 32 bit?". tomshard- [44] “Analysis: The real scoop on Atom-ARM rivalry”.
ware.com. 10 February 2012. Retrieved 4 March 2013. Archived from the original on 2014-02-15. Retrieved 1
January 2012.
[28] “ASRock > AD2700B-ITX”. asrock.com. Retrieved 4
March 2013. [45] Myslewski, Rik (2 May 2014). “ARM tests: Intel
flops on Android compatibility, Windows power”. www.
[29] “HP Mini 210-2072cl PC Product Specifications”. theregister.co.uk (The Register). Archived from the origi-
Archived from the original on 2014-01-08. nal on 2014-05-03. Retrieved 2 May 2014.
7.11. EXTERNAL LINKS 31

7.10 References
• “Intel cranks 45nm ultramobile CPU”. EE Times.
18 April 2007. Retrieved 28 October 2007.
• “Intel reaches back in time for its ultralow power
chips”. 28 January 2008. Retrieved 29 January
2008.

• “New Intel Centrino Atom Processor Technol-


ogy Ushers in 'Best Internet Experience in Your
Pocket'". 2 April 2008.

• “Intel’s Atom Architecture: The Journey Begins”. 2


April 2008.

• “The Battle of Low-Power Processors: Best Choice


for a Nettop”. 27 September 2008.

• linuxdevices.com - Intel announces first Atom chips


• hardwaresecrets.com - Inside Atom Architecture

• computermonger.com - Intel Atom N280 vs N270


Benchmarked

• LinuxTECH.NET - Intel Pineview Atom based


Motherboards Complete Overview

7.11 External links


• Intel - Intel Atom Processor Overview

• Intel Atom Processor


• Intel - Intel Atom Processor Family
Chapter 8

Intel Core

This article is about the Intel processor brand name. For out closely resembled two interconnected Pentium M
the Intel microarchitecture that is the basis for the Core branded CPUs packaged as a single die (piece) silicon
2 processor family, see Intel Core (microarchitecture). chip (IC). Hence, the 32-bit microarchitecture of Core
branded CPUs – contrary to its name – had more in com-
Intel Core is a brand name that Intel uses for var- mon with Pentium M branded CPUs than with the subse-
quent 64-bit Core microarchitecture of Core 2 branded
ious mid-range to high-end consumer and business
microprocessors. These processors replaced the then- CPUs. Despite a major rebranding effort by Intel start-
ing January 2006, some companies continued to market
currently mid to high end Pentium processors, making
them entry level, and bumping the Celeron series of pro- computers with the Yonah core marked as Pentium M.
cessors to low end. Similarly, identical or more capable The Core series is also the first Intel processor used as the
versions of Core processors are also sold as Xeon proces- main CPU in an Apple Macintosh computer. The Core
sors for the server and workstation market. Duo was the CPU for the first generation MacBook Pro,
As of 2015 the current lineup of Core processors included while the Core Solo appeared in Apple’s Mac mini line.
the latest Intel Core i7, Intel Core i5, and Intel Core i3.[1] Core Duo signified the beginning of Apple’s shift to Intel
processors across their entire line.
In 2007, Intel began branding the Yonah core CPUs
8.1 Overview intended for mainstream mobile computers as Pentium
Dual-Core, not to be confused with the desktop 64-bit
Core microarchitecture CPUs also branded as Pentium
Clock speed slowest 1.2 GHz to the fastest 4.0 GHz (In-
Dual-Core.
tel Core i7-4790K) (or 4.4 GHz via Intel Turbo Boost
[3] September 2007 and January 4, 2008 marked the discon-
Technology)
tinuation of a number of Core branded CPUs including
several Core Solo, Core Duo, Celeron and one Core 2
8.2 Enhanced Pentium M based Quad chip.[4][5]

Main article: Enhanced Pentium M (microarchitecture)


For details about the processor core, see Yonah (micro- 8.2.1 Core Duo
processor).
Intel Core Duo[6] (product code 80539) consists of two
cores on one die, a 2 MB L2 cache shared by both cores,
The original Core brand refers to Intel's 32-bit mobile and an arbiter bus that controls both L2 cache and FSB
dual-core x86 CPUs, which derived from the Pentium M (front-side bus) access.
branded processors. The processor family used a more
enhanced version of the Intel P6 microarchitecture. It
emerged in parallel with the NetBurst microarchitecture 8.2.2 Core Solo
(Intel P68) of the Pentium 4 brand, and was a precursor
of the 64-bit Core microarchitecture of Core 2 branded Intel Core Solo[7] (product code 80538) uses the same
CPUs. The Core brand comprised two branches: the Duo two-core die as the Core Duo, but features only one ac-
(dual-core) and Solo (Duo with one disabled core, which tive core. Depending on demand, Intel may also simply
replaced the Pentium M brand of single-core mobile pro- disable one of the cores to sell the chip at the Core Solo
cessor). price—this requires less effort than launching and main-
Intel launched the Core brand on January 6, 2006 with taining a separate line of CPUs that physically only have
the release of the 32-bit Yonah CPU – Intel’s first dual- one core. Intel used the same strategy previously with the
core mobile (low-power) processor. Its dual-core lay- 486 CPU in which early 486SX CPUs were in fact man-

32
8.4. NEHALEM MICROARCHITECTURE BASED 33

ufactured as 486DX CPUs but with the FPU disabled. tively slow ultra-low-power Uxxxx (10 W) and low-power
Lxxxx (17 W) versions, to the more performance ori-
ented Pxxxx (25 W) and Txxxx (35 W) mobile versions
8.3 64-bit Core microarchitecture and the Exxxx (65 W) desktop models. The mobile Core
2 Duo processors with an 'S' prefix in the name are pro-
based duced in a smaller µFC-BGA 956 package, which allows
building more compact laptops.
Main article: Core (microarchitecture) Within each line, a higher number usually refers to a
better performance, which depends largely on core and
The successor to Core is the mobile version of the Intel front-side bus clock frequency and amount of second level
Core 2 line of processors using cores based upon the Intel cache, which are model-specific. Core 2 Duo processors
Core microarchitecture,[8] released on July 27, 2006. typically use the full L2 cache of 2, 3, 4, or 6 MB avail-
The release of the mobile version of Intel Core 2 marks able in the specific stepping of the chip, while versions
the reunification of Intel’s desktop and mobile product with the amount of cache reduced during manufacturing
lines as Core 2 processors were released for desktops and are sold for the low-end consumer market as Celeron or
notebooks, unlike the first Intel Core CPUs that were tar- Pentium Dual-Core processors. Like those processors,
geted only for notebooks (although some small form fac- some low-end Core 2 Duo models disable features such
tor and all-in-one desktops, like the iMac and the Mac as Intel Virtualization Technology.
Mini, also used Core processors).
Unlike the Intel Core, Intel Core 2 is a 64-bit processor, 8.3.3 Core 2 Quad
supporting Intel 64. Another difference between the orig-
inal Core Duo and the new Core 2 Duo is an increase in Core 2 Quad[12][13] processors are multi-chip modules
the amount of Level 2 cache. The new Core 2 Duo has consisting of two dies similar to those used in Core 2
tripled the amount of on-board cache to 6 MB. Core 2 Duo, forming a quad-core processor. This allows twice
also introduced a quad-core performance variant to the the performance of a dual-core processors at the same
single- and dual-core chips, branded Core 2 Quad, as well clock frequency in ideal conditions.
as an enthusiast variant, Core 2 Extreme. All three chips
are manufactured at a 65 nm lithography, and in 2008, Initially, all Core 2 Quad models were versions of Core
a 45 nm lithography and support Front Side Bus speeds 2 Duo desktop processors, Kentsfield derived from Con-
ranging from 533 MHz to 1600 MHz. In addition, the 45 roe and Yorkfield from Wolfdale, but later Penryn-QC
nm die shrink of the Core microarchitecture adds SSE4.1 was added as a high-end version of the mobile dual-core
support to all Core 2 microprocessors manufactured at a Penryn.
45 nm lithography, therefore increasing the calculation The Xeon 32xx and 33xx processors are mostly identical
rate of the processors. versions of the desktop Core 2 Quad processors and can
be used interchangeably.
8.3.1 Core 2 Solo
8.3.4 Core 2 Extreme
The Core 2 Solo,[9] introduced in September 2007, is
the successor to the Core Solo and is available only as Core 2 Extreme processors[14][15] are enthusiast versions
an ultra-low-power mobile processor with 5.5 Watt ther- of Core 2 Duo and Core 2 Quad processors, usually with a
mal design power. The original U2xxx series “Merom-L” higher clock frequency and an unlocked clock multiplier,
used a special version of the Merom chip with CPUID which makes them especially attractive for overclocking.
number 10661 (model 22, stepping A1) that only had a This is similar to earlier Pentium processors labeled as
single core and was also used in some Celeron processors. Extreme Edition. Core 2 Extreme processors were re-
The later SU3xxx are part of Intel’s CULV range of pro- leased at a much higher price than their regular version,
cessors in a smaller µFC-BGA 956 package but contain often $999 or more.
the same Penryn chip as the dual-core variants, with one
of the cores disabled during manufacturing.
8.4 Nehalem microarchitecture
8.3.2 Core 2 Duo based
The majority of the desktop and mobile Core 2 proces-
sor variants are Core 2 Duo[10][11] with two processor Main article: Nehalem (microarchitecture)
cores on a single Merom, Conroe, Allendale, Penryn, or
Wolfdale chip. These come in a wide range of perfor- With the release of the Nehalem microarchitecture
mance and power consumption, starting with the rela- in November 2008,[16] Intel introduced a new naming
34 CHAPTER 8. INTEL CORE

scheme for its Core processors. There are three vari- L3 cache, a DMI bus running at 2.5 GT/s and support for
ants, Core i3, Core i5 and Core i7, but the names no dual-channel DDR3-800/1066/1333 memory and have
longer correspond to specific technical features like the Hyper-threading disabled. The same processors with
number of cores. Instead, the brand is now divided from different sets of features (Hyper-Threading and other
low-level (i3), through mid-range (i5) to high-end per- clock frequencies) enabled are sold as Core i7-8xx and
formance (i7),[17] which correspond to three, four and Xeon 3400-series processors, which should not be con-
five stars in Intel’s Intel Processor Rating[18] following on fused with high-end Core i7-9xx and Xeon 3500-series
from the entry-level Celeron (one star) and Pentium (two processors based on Bloomfield. A new feature called
stars) processors.[19] Common features of all Nehalem Turbo Boost Technology was introduced which maxi-
based processors include an integrated DDR3 memory mizes speed for demanding applications, dynamically ac-
controller as well as QuickPath Interconnect or PCI Ex- celerating performance to match the workload.
press and Direct Media Interface on the processor replac- The Core i5-5xx mobile processors are named
ing the aging quad-pumped Front Side Bus used in all ear-
Arrandale and based on the 32 nm Westmere shrink of
lier Core processors. All these processors have 256 KB the Nehalem microarchitecture. Arrandale processors
L2 cache per core, plus up to 12 MB shared L3 cache.
have integrated graphics capability but only two proces-
Because of the new I/O interconnect, chipsets and main- sor cores. They were released in January 2010, together
boards from previous generations can no longer be used with Core i7-6xx and Core i3-3xx processors based on
with Nehalem based processors. the same chip. The L3 cache in Core i5-5xx processors
is reduced to 3 MB, while the Core i5-6xx uses the full
cache and the Core i3-3xx does not support for Turbo
8.4.1 Core i3 Boost.[31] Clarkdale, the desktop version of Arrandale,
is sold as Core i5-6xx, along with related Core i3 and
Intel intended the Core i3 as the new low end of the per- Pentium brands. It has Hyper-Threading enabled and
formance processor line from Intel, following the retire- the full 4 MB L3 cache.[32]
ment of the Core 2 brand.[20][21]
According to Intel “Core i5 desktop processors and desk-
The first Core i3 processors were launched on January 7, top boards typically do not support ECC memory”,[33] but
2010.[22] information on limited ECC support in the Core i3 sec-
The first Nehalem based Core i3 was Clarkdale-based, tion also applies to Core i5 and i7.
with an integrated GPU and two cores.[23] The same pro-
cessor is also available as Core i5 and Pentium, with
slightly different configurations. 8.4.3 Core i7
The Core i3-3xxM processors are based on Arrandale, Intel Core i7 as an Intel brand name applies to several
the mobile version of the Clarkdale desktop processor. families of desktop and laptop 64-bit x86-64 processors
They are similar to the Core i5-4xx series but running using the Nehalem, Westmere, Sandy Bridge, Ivy Bridge
at lower clock speeds and without Turbo Boost.[24] Ac- and Haswell microarchitectures. The Core i7 brand tar-
cording to an Intel FAQ they do not support Error Cor- gets the business and high-end consumer markets for both
rection Code (ECC) memory.[25] According to moth- desktop and laptop computers,[35] and is distinguished
erboard manufacturer Supermicro, if a Core i3 pro- from the Core i3 (entry-level consumer), Core i5 (main-
cessor is used with a server chipset platform such as stream consumer), and Xeon (server and workstation)
Intel 3400/3420/3450, the CPU supports ECC with brands.
UDIMM.[26] When asked, Intel confirmed that, although
the Intel 5 series chipset supports non-ECC memory only Intel introduced the Core i7 name with the Nehalem-
with the Core i5 or i3 processors, using those processors based Bloomfield Quad-core processor in late
on a motherboard with 3400 series chipsets it supports the 2008.[36][37][38][39] In 2009 new Core i7 models based
ECC function of ECC memory.[27] A limited number of on the Lynnfield (Nehalem-based) desktop quad-core
motherboards by other companies also support ECC with processor and the Clarksfield (Nehalem-based) quad-
Intel Core ix processors; the Asus P8B WS is an exam- core mobile were added,[40] and models based on the
ple, but it does not support ECC memory under Windows Arrandale dual-core mobile processor (also Nehalem-
non-server operating systems.[28] based) were added in January 2010. The first six-core
processor in the Core lineup is the Nehalem-based
Gulftown, which was launched on March 16, 2010.
8.4.2 Core i5 Both the regular Core i7 and the Extreme Edition are
advertised as five stars in the Intel Processor Rating.
The first Core i5 using the Nehalem microarchitec- In each of the first three microarchitecture generations
ture was introduced on September 8, 2009, as a main- of the brand, Core i7 has family members using two dis-
stream variant of the earlier Core i7, the Lynnfield tinct system-level architectures, and therefore two distinct
core.[29][30] Lynnfield Core i5 processors have an 8 MB sockets (for example, LGA 1156 and LGA 1366 with
8.6. IVY BRIDGE MICROARCHITECTURE BASED 35

Nehalem). In each generation, the highest-performing 8.5.2 Core i5


Core i7 processors use the same socket and QPI-based
architecture as the low-end Xeon processors of that gen- In January 2011, Intel released new quad-core Core i5
eration, while lower-performing Core i7 processors use processors based on the “Sandy Bridge” microarchitec-
the same socket and PCIe/DMI/FDI architecture as the ture at CES 2011. New dual-core mobile processors and
Core i5. desktop processors arrived in February 2011.
“Core i7” is a successor to the Intel Core 2 The Core i5-2xxx line of desktop processors are mostly
brand.[41][42][43][44] Intel representatives stated that quad-core chips, with the exception of the dual-core Core
they intend the moniker Core i7 to help consumers i5-2390T, and include integrated graphics, combining the
decide which processor to purchase as Intel releases key features of the earlier Core i5-6xx and Core i5-7xx
newer Nehalem-based products in the future.[45] lines. The suffix after the four-digit model number des-
ignates unlocked multiplier (K), low-power (S) and ultra-
low-power (T).
The desktop CPUs now all have four non-SMT cores (like
the i5-750), with the exception of the i5-2390T. The DMI
8.5 Sandy Bridge microarchitec- bus is running at 5 GT/s.
ture based The mobile Core i5-2xxxM processors are all dual-core
chips like the previous Core i5-5xxM series and share
most the features with that product line.
Main article: Sandy Bridge

In early 2011, Intel introduced a new microarchitecture 8.5.3 Core i7


named Sandy Bridge microarchitecture. It kept all the
existing brands from Nehalem, including Core i3/i5/i7, The Core i7 brand remains the high-end for Intel’s desk-
and introduced new model numbers. The initial set of top and mobile processors, featuring the Sandy Bridge
Sandy Bridge processors includes dual- and quad-core models with the largest amount of L3 cache and the high-
variants, all of which use a single 32 nm die for both the est clock frequency. Most of these models are very sim-
CPU and integrated GPU cores, unlike the earlier mi- ilar to their smaller Core i5 siblings. The quad-core mo-
croarchitectures. All Core i3/i5/i7 processors with the bile Core i7-2xxxQM/XM processors follow the previous
Sandy Bridge microarchitecture have a four-digit model “Clarksfield” Core i7-xxxQM/XM processors, but now
number. With the mobile version, the thermal design also include integrated graphics.
power can no longer be determined from a one- or two-
letter suffix but is encoded into the CPU number. Starting
with Sandy Bridge, Intel no longer distinguishes the code 8.6 Ivy Bridge microarchitecture
names of the processor based on number of cores, socket
or intended usage; they all use the same code name as the based
microarchitecture itself.
Ivy Bridge is the codename for Intel’s 22 nm die shrink Main article: Ivy Bridge (microarchitecture)
of the Sandy Bridge microarchitecture based on tri-gate
(“3D”) transistors, introduced in April 2012.

8.6.1 Core i3
The Ivy Bridge based Core-i3-3xxx line is a minor up-
8.5.1 Core i3 grade to 22 nm process technology and better graphics.

Released on January 20, 2011, the Core i3-2xxx line of


desktop and mobile processors is a direct replacement of
8.6.2 Core i5
the 2010 “Clarkdale” Core i3-5xx and “Arrandale” Core
i3-3xxM models, based on the new microarchitecture. 8.6.3 Core i7
While they require new sockets and chipsets, the user-
visible features of the Core i3 are largely unchanged, in- 8.7 Haswell microarchitecture
cluding the lack of support for Turbo Boost and AES-NI.
Unlike the Sandy Bridge based Celeron and Pentium pro- based
cessors, the Core i3 line does support the new Advanced
Vector Extensions. This particular processor is the entry- Main article: Haswell (microarchitecture)
level processor of this new series of Intel processors.
36 CHAPTER 8. INTEL CORE

8.7.1 Core i3 [10] “Intel Core2 Duo Processor: Upgrade Today”. Intel.com.
Retrieved 2010-12-13.
8.7.2 Core i5 [11] “Intel Core2 Duo Mobile Processor”. Intel.com. Re-
trieved 2010-12-13.
8.7.3 Core i7
[12] “Intel Core2 Quad Processor Overview”. Intel.com. Re-
trieved 2010-12-13.
8.8 Broadwell microarchitecture
[13] “Intel Core2 Quad Mobile Processors – Overview”. In-
based tel.com. Retrieved 2010-12-13.

[14] “Support for the Intel Core2 Extreme Processor”. In-


Main article: Broadwell (microarchitecture) tel.com. Retrieved 2010-12-13.

The Broadwell microarchitecture was released by Intel on [15] “Intel Core2 Extreme Processor”. Intel.com. Retrieved
2010-12-13.
September 6, 2014, and began shipping in late 2014. It
[46]
is the first to use a 14 nm chip. Additional, mobile [16] “Intel Microarchitecture Codenamed Nehalem”. In-
processors were launched in January 2015. [47] tel.com. Retrieved 2010-12-13.

[17] “Public Roadmap Desktop, Mobile & Data Center”


8.8.1 Core i3 (PDF). Intel.com. Retrieved 2010-12-13.

[18] “Intel Processor Ratings”. Intel.com. Retrieved 2011-07-


8.8.2 Core i5 21.

[19] “Processor Ratings”. Intel. 2010-07-09. Retrieved 2010-


8.8.3 Core i7 12-13.

8.8.4 Core M [20] “Intel Quietly Announces Core i5 and Core i3 Branding”.
AnandTech. Retrieved 2010-12-13.

8.9 See also [21] “Intel confirms Core i3 as 'entry-level' Nehalem chip”.
Apcmag.com. 2009-09-14. Retrieved 2010-12-13.
• Centrino [22] “Core i5 and i3 CPUs With On-Chip GPUs Launched”.
Hardware.slashdot.org. 2010-01-04. Retrieved 2010-12-
13.
8.10 References [23] “Intel May Unveil Microprocessors with Integrated
Graphics Cores at Consumer Electronics Show”. Xbit-
[1] “Desktop Processors”. Intel.com. Retrieved 2010-12-13. labs.com. Retrieved 2010-12-13.

[2] http://arstechnica.com/gadgets/2014/09/ [24] “Intel to launch four Arrandale CPUs for mainstream
notebooks in January 2010”. Digitimes.com. 2009-11-
intels-launches-three-core-m-cpus-promises-more-broadwell-early-2015/
13. Retrieved 2010-12-13.
[3] “Intel Launches Devil’s Canyon and Overclockable Pen-
tium: i7-4790K, i5-4690K and G3258”. Anandtech. 3 [25] Intel Core i3 desktop processor frequently asked questions
June 2014. Retrieved 29 June 2014.
[26] Supermicro FAQ on ECC with Core i3
[4] “Intel already phasing out first quad-core CPU”. TG [27] Intel correspondence quoted on silentpcreview forum
Daily. Retrieved 2007-09-07.
[28] Asus P8B WS specification: supports “ECC, Non-ECC,
[5] “Intel to discontinue older Centrino CPUs in Q1 08”. TG un-buffered Memory”, but “Non-ECC, un-buffered mem-
Daily. Retrieved 2007-10-01. ory only support for client OS (Windows 7, Vista and
XP).”
[6] “Support for the Intel Core Duo Processor”. Intel.com.
Retrieved 2010-12-13. [29] “Support for the Intel Core i5 Processor”. Intel.com. Re-
trieved 2010-12-13.
[7] “Support for the Intel Core Solo processor”. Intel.com.
Retrieved 2010-12-13. [30] Anand Lal Shimpi, Intel’s Core i7 870 & i5 750, Lynnfield:
Harder, Better, Faster Stronger, anandtech.com
[8] “Intel Microarchitecture”. Intel.com. Retrieved 2010-12-
13. [31] http://www.digitimes.com/news/a20091113PD209.html

[9] “Intel Core2 Solo Mobile Processor – Overview”. In- [32] Intel E5300( ) |CPU | Core
tel.com. Retrieved 2010-12-13. i5 i3 |IT168 diy
8.11. EXTERNAL LINKS 37

[33] Intel Core i5 desktop processor frequently asked questions

[34] Intel Core i5-430UM processor – CN80617006042AE

[35] “Support for the Intel Core i7 Processor”. Intel.com. Re-


trieved 2010-12-13.

[36] Modine, Austin (2008-11-18). “Intel celebrates Core i7


launch with Dell and Gateway”. The Register. Retrieved
2008-12-06.

[37] “IDF Fall 2008: Intel un-retires Craig Barrett, AMD sets
up anti-IDF camp”. Tigervision Media. 2008-08-11. Re-
trieved 2008-08-11.

[38] “Meet the Bloggers”. Intel Corporation. Retrieved 2008-


08-11.

[39] “Getting to the Core---Intel’s new flagship client brand”.


Intel Corporation. Retrieved 2008-08-11.

[40] "[Intel Roadmap update] Nehalem to enter mainstream


market”. ExpReview. 2008-06-10. Retrieved 2008-08-
11.

[41] “Intel Details Upcoming New Processor Generations”


(Press release). Intel Corporate. 2008-08-11.

[42] “Intel Core i7-920 Processor (8M Cache, 2.66 GHz, 4.80
GT/s Intel QPI)". Intel. Retrieved 2008-12-06.

[43] “Intel Core i7-940 Processor (8M Cache, 2.93 GHz, 4.80
GT/s Intel QPI)". Intel. Retrieved 2008-12-06.

[44] “Intel Core i7-965 Processor Extreme Edition (8M Cache,


3.20 GHz, 6.40 GT/s Intel QPI)". Intel. Retrieved 2008-
12-06.

[45] Technology@Intel · Getting to the Core – Intel’s new flag-


ship client brand

[46] “Intel Discloses Newest Microarchitecture and 14


Nanometer Manufacturing Process Technical Details”.
Intel.com. Intel Corporation. 11 August 2014. Retrieved
6 September 2014.

[47] “Intel launched U-series Broadwell processors”. 10 Jan-


uary 2015. Retrieved 15 February 2015.

8.11 External links


• Intel Core technical specifications at the Wayback
Machine (archived August 9, 2007)
• CPU Database. TechPowerUp.
• Intel Core Duo (Yonah) Performance Preview – Part
II vs AMD 64 X2 and Intel Pentium M. Anandtech.
• Intel Core i7-3960X CPU Performance Compari-
son.
• Intel Centrino Duo Mobile Technology papers. In-
tel.
• Intel Product Information, providing a list of various
processor generations
Chapter 9

List of Intel Core i5 microprocessors

The following is a list of Intel Core i5 brand • Graphics Transistors: 177 million
microprocessors.
• Graphics and Integrated Memory Controller die
size: 114 mm²

9.1 Desktop processors • Stepping: C2, K0

9.1.1 Nehalem microarchitecture (1st gen- 9.1.3 Sandy Bridge microarchitecture


eration) (2nd generation)
“Lynnfield” (45 nm) “Sandy Bridge” (dual-core, 32 nm)

• All models support: MMX, SSE, SSE2, SSE3, SSSE3, • All models support: MMX, SSE, SSE2, SSE3, SSSE3,
SSE4.1, SSE4.2, Enhanced Intel SpeedStep Technol- SSE4.1, SSE4.2, AVX, Enhanced Intel SpeedStep
ogy (EIST), Intel 64, XD bit (an NX bit implementa- Technology (EIST), Intel 64, XD bit (an NX bit im-
tion), Intel VT-x, Turbo Boost, Smart Cache. plementation), TXT, Intel VT-x, Intel VT-d, Hyper-
threading, Turbo Boost, AES-NI, Smart Cache, Intel
• FSB has been replaced with DMI.
Insider, vPro.
• Transistors: 774 million • Transistors: 504 million
• Die size: 296 mm² • Die size: 131 mm²
• Stepping: B1
“Sandy Bridge” (quad-core, 32 nm)
9.1.2 Westmere microarchitecture (1st • All models support: MMX, SSE, SSE2, SSE3, SSSE3,
generation) SSE4.1, SSE4.2, AVX, Enhanced Intel SpeedStep
Technology (EIST), Intel 64, XD bit (an NX bit im-
"Clarkdale" (MCP, 32 nm dual-core) plementation), TXT, Intel VT-x, Intel VT-d, Turbo
Boost, AES-NI, Smart Cache, Intel Insider, vPro.
• All models support: MMX, SSE, SSE2, SSE3, SSSE3,
SSE4.1, SSE4.2, Enhanced Intel SpeedStep Technol- • All models support dual-channel DDR3-1333
ogy (EIST), Intel 64, XD bit (an NX bit implementa- RAM.
tion), TXT, Intel VT-x, Intel VT-d, Hyper-Threading, • Core i5-2300, Core i5-2310, Core i5-2320, Core
Turbo Boost, AES-NI, Smart Cache. i5-2380P, Core i5-2405S, Core i5-2450P, Core i5-
• Core i5-655K, Core i5-661 does not support Intel 2500K and Core i5-2550K does not support Intel
TXT and Intel VT-d.[1] TXT, Intel VT-d, and Intel vPro.[2]
• S processors feature lower-than-normal TDP (65W
• Core i5-655K features an unlocked multiplier.
on 4-core models).
• FSB has been replaced with DMI.
• T processors feature an even lower TDP (45W on
• Contains 45 nm “Ironlake” GPU. 4-core models or 35W on 2-core models).

• Transistors: 382 million • K processors are unlockable and designed for over-
clocking. Other processors will have limited over-
• Die size: 81 mm² clocking due to chipset limitations.[3]

38
9.2. MOBILE PROCESSORS 39

• P processors disable the integrated graphics proces- “Haswell-DT” (dual-core, 22 nm)


sor.
• All models support: MMX, SSE, SSE2, SSE3, SSSE3,
• Transistors: 1.16 billion[4] SSE4.1, SSE4.2, AVX, AVX2, FMA3, Enhanced In-
tel SpeedStep Technology (EIST), Intel 64, XD bit
• Die size: 216 mm² (an NX bit implementation), Intel VT-x, Intel VT-
d, Hyper-threading, Turbo Boost, AES-NI, Smart
Cache, Intel Insider, vPro.
9.1.4 Ivy Bridge microarchitecture (3rd
generation) • Transistors: 1.4 billion

• Die size: 177mm²


"Ivy Bridge" (dual-core, 22 nm)

• All models support: MMX, SSE, SSE2, SSE3, SSSE3, “Haswell-DT” (quad-core, 22 nm)
SSE4.1, SSE4.2, AVX, Enhanced Intel SpeedStep
Technology (EIST), Intel 64, XD bit (an NX bit imple- • All models support: MMX, SSE, SSE2, SSE3, SSSE3,
mentation), Intel VT-x, Intel VT-d, Hyper-threading, SSE4.1, SSE4.2, AVX, AVX2, FMA3, Enhanced In-
Turbo Boost, AES-NI, Smart Cache, Intel Insider. tel SpeedStep Technology (EIST), Intel 64, XD bit
(an NX bit implementation), Intel VT-x, Turbo Boost,
• Die size: 93.6mm² or 118 mm² [5][6] AES-NI, Smart Cache, Intel Insider.

• Intel Core i5-4430, Core i5-4430S, Core i5-4440,


“Ivy Bridge” (quad-core, 22 nm) Core i5-4570, Core i5-4570S, Core i5-4670, Core
i5-4670S, Core i5-4670T, Core i5-4690, Core i5-
• All models support: MMX, SSE, SSE2, SSE3, SSSE3, 4690S, Core i5-4690K support Intel VT-d.
SSE4.1, SSE4.2, AVX, Enhanced Intel SpeedStep
• Intel Core i5-4570, Core i5-4570S, Core i5-4670,
Technology (EIST), Intel 64, XD bit (an NX bit imple-
Core i5-4670S, Core i5-4670T, Core i5-4590, Core
mentation), Intel VT-x, Turbo Boost, AES-NI, Smart
i5-4690 support vPro, Intel TSX, TXT.
Cache, Intel Insider, vPro.
• Intel Core i5-4690K supports Intel TSX unlike its
• S processors feature lower-than-normal TDP (65 W older counterpart, the i5-4670K.
on 4-core models).
• Transistors: 1.4 billion
• T processors feature an even lower TDP (45 W on
4-core models). • Die size: 185mm²

• K processors have unlocked turbo multiplier


“Haswell-H” (MCP, quad-core, 97 nm)
• P processors disable the integrated graphics proces-
sor • All models support: MMX, SSE, SSE2, SSE3, SSSE3,
SSE4.1, SSE4.2, AVX, AVX2, FMA3, Enhanced In-
• i5-3470, i5-3470S, i5-3475S, i5-3550, i5-3550S, i5 tel SpeedStep Technology (EIST), Intel 64, XD bit
3570 and i5-3570T support Intel TXT, Intel VT-d (an NX bit implementation), Intel VT-x, Intel VT-d,
and vPro. Turbo Boost, AES-NI, Smart Cache, Intel Insider.

• i5-3330, i5-3330S, and i5-3350P support Intel VT- • Core i5-4570R and Core i5-4670R also contain
d. “Crystalwell": 128 MiB eDRAM built at (22 nm)
acting as L4 cache
• Non-K processors will have limited turbo overclock- • Transistors: 1.4 billion
ing.
• Die size: 264mm² + 84mm²
• Transistors: 1.4 billion

• Die size: 133 mm² or 160 mm²


9.2 Mobile processors

9.1.5 Haswell microarchitecture (4th gen- 9.2.1 Westmere microarchitecture (1st


eration) generation)
40 CHAPTER 9. LIST OF INTEL CORE I5 MICROPROCESSORS

"Arrandale" (MCP, 32 nm) “Ivy Bridge” (22 nm)

• All models support: MMX, SSE, SSE2, SSE3, SSSE3, • All models support: MMX, SSE, SSE2, SSE3, SSSE3,
SSE4.1, SSE4.2, Enhanced Intel SpeedStep Technol- SSE4.1, SSE4.2, AVX, Enhanced Intel SpeedStep
ogy (EIST), Intel 64, XD bit (an NX bit implementa- Technology (EIST), Intel 64, XD bit (an NX bit imple-
tion), Intel VT-x,[9] Hyper-Threading, Turbo Boost, mentation), Intel VT-x, Intel VT-d, Hyper-threading,
Smart Cache. Turbo Boost, AES-NI, Smart Cache.

• i5-5xx series (i5-520M, i5-520E, i5-540M, • i5-3320M, i5-3360M, i5-3427U, i5-3437U, i5-
i5-560M, i5-580M, i5-520UM, i5-540UM, i5- 3439Y, and i5-3610ME support TXT and vPro.
560UM) supports AES-NI, TXT and Intel VT-d.
[10]
9.2.4 Haswell microarchitecture (4th gen-
• FSB has been replaced with DMI. eration)

• Contains 45 nm “Ironlake” GPU. “Haswell-MB” (dual-core, 22 nm)

• Transistors: 382 million • All models support: MMX, SSE, SSE2, SSE3, SSSE3,
SSE4.1, SSE4.2, AVX, AVX2, FMA3, Enhanced In-
• Die size: 81 mm² tel SpeedStep Technology (EIST), Intel 64, XD bit
(an NX bit implementation), Intel VT-x, Hyper-
• Graphics Transistors: 177 million threading, Turbo Boost, AES-NI, Intel TSX-NI, Smart
Cache.
• Graphics and Integrated Memory Controller die
size: 114 mm² • Core i5-4300M and higher also support Intel VT-d,
Intel vPro, Intel TXT
• Stepping: C2, K0
• Transistors: 1.3 billion
• Core i5-520E has support for ECC memory and PCI
express port bifurcation. • Die size: 181 mm²

“Haswell-ULT” (SiP, dual-core, 22 nm)


9.2.2 Sandy Bridge microarchitecture
(2nd generation) • All models support: MMX, SSE, SSE2, SSE3, SSSE3,
SSE4.1, SSE4.2, AVX, AVX2, FMA3, Enhanced In-
“Sandy Bridge” (32 nm) tel SpeedStep Technology (EIST), Intel 64, XD bit
(an NX bit implementation), Intel VT-x, Hyper-
• All models support: MMX, SSE, SSE2, SSE3, SSSE3, threading, Turbo Boost, AES-NI, Smart Cache.
SSE4.1, SSE4.2, AVX, Enhanced Intel SpeedStep
Technology (EIST), Intel 64, XD bit (an NX bit im- • All models i5-4250U and up support Intel VT-d
plementation), Intel VT-x, Hyper-threading, Turbo • Core i5-43x0U also supports Intel vPro, Intel TXT
Boost, AES-NI, Smart Cache.
• Transistors: 1.3 billion
• All models except Core i5-24xxM support TXT and
Intel VT-d. • Die size: 181 mm²

• Core i5-2430M/i5-2435M and i5-2410M/i5-


2415M can support AES-NI with laptop OEM- “Haswell-ULX” (SiP, dual-core, 22 nm)
supplied BIOS processor configuration update.[11]
• All models support: MMX, SSE, SSE2, SSE3, SSSE3,
• Core i5-2515E has support for ECC memory. SSE4.1, SSE4.2, AVX, AVX2, FMA3, Enhanced In-
tel SpeedStep Technology (EIST), Intel 64, XD bit
• Transistors: 624 million (an NX bit implementation), Intel VT-x, Hyper-
threading, Turbo Boost, AES-NI, Smart Cache.
• Die size: 149 mm²
• Core i5-4300Y and higher also support Intel VT-d,
Intel TSX-NI, Intel vPro, Intel TXT
9.2.3 Ivy Bridge microarchitecture (3rd • Transistors: 1.3 billion
generation)
• Die size: 181 mm²
9.5. REFERENCES 41

“Haswell-H” (dual-core, 22 nm) [2] Turbo describes the available frequency bins (+100 MHz
for processors based on Sandy Bridge, Ivy Bridge and
• All models support: MMX, SSE, SSE2, SSE3, SSSE3, Haswell microarchitectures) of Intel Turbo Boost Tech-
SSE4.1, SSE4.2, AVX, AVX2, FMA3, Enhanced In- nology that are available for 4, 3, 2, 1 active cores respec-
tel SpeedStep Technology (EIST), Intel 64, XD bit tively (depending on the number of CPU cores, included
in the processor).
(an NX bit implementation), Intel VT-x, Intel VT-
d, Hyper-threading, Turbo Boost (except i5-4402EC
and i5-4410E), AES-NI, Intel TSX-NI, Smart Cache.
9.5 References
• Transistors: 1.3 billion
[1] Core i5-655K, Core i5-661 does not support Intel TXT
• Die size: 181 mm² and Intel VT-d

• Embedded models support Intel vPro, ECC memory [2] Core i5-2300, Core i5-2310, Core i5-2320, Core i5-
2380P, Core i5-2405S, Core i5-2450P, Core i5-2500F
and Core i5-2550K do not support Intel TXT and Intel
9.2.5 Broadwell microarchitecture (5th VT-d
generation) [3] Fully unlocked versus “limited” unlocked core

“Broadwell-U” (dual-core, 14 nm) [4] Counting Transistors: Why 1.16B and 995M Are Both
Correct, by Anand Lal Shimpi on 14 September 2011,
• All models support: MMX, SSE, SSE2, SSE3, SSSE3, www.anandtech.com
SSE4.1, SSE4.2, AVX, AVX2, FMA3, Enhanced In- [5] http://www.anandtech.com/show/5876/
tel SpeedStep Technology (EIST), Intel 64, XD bit the-rest-of-the-ivy-bridge-die-sizes
(an NX bit implementation), Intel VT-x, Intel VT-
d, Hyper-threading, Turbo Boost, AES-NI, Smart [6] http://vr-zone.com/articles/
Cache, and configurable TDP (cTDP) down intel-s-broken-ivy-bridge-sku-s-last-to-arrive/15449.
html
• Core i5-5300U and higher also support Intel vPro, [7] Specifications of Haswell Refresh CPUs
Intel TXT, and Intel TSX-NI
[8] Some details of Haswell Refresh CPUs
• Transistors: 1.3-1.9 billion [12]
[9] http://ark.intel.com/Compare.aspx?ids=43544,43560
• Die size: 82-133 mm² [12]
[10] http://ark.intel.com/ProductCollection.aspx?familyId=
43483

9.3 See also [11] “Intel® Core™ i5-2410M Processor”. Intel. Retrieved
2012-01-01.

• Nehalem (microarchitecture) [12] Cyril Kowaliski (2015-01-05). “Intel’s Broadwell-U ar-


rives aboard 15W, 28W mobile processors”. techre-
• Westmere (microarchitecture) port.com. Retrieved 2015-01-12.

• Sandy Bridge

• Ivy Bridge (microarchitecture)


9.6 External links
• Haswell (microarchitecture) • Intel Core i5 desktop processor product order code
table
• List of Intel Core i3 microprocessors
• Intel Core i5 mobile processor product order code
• List of Intel Core i7 microprocessors table
• Search MDDS Database
9.4 Notes • Intel ARK Database

[1] Turbo describes the available frequency bins (+133 MHz


for processors based on Nehalem microarchitecture) of
Intel Turbo Boost Technology that are available for 4, 3,
2, 1 active cores respectively (depending on the number
of CPU cores, included in the processor).
Chapter 10

Pentium Dual-Core

This article is about Pentium Dual-Core branded proces-


sors from 2006 to 2009. For current and other Pentium
processors, see Pentium.
Not to be confused with Pentium D.

The Pentium Dual-Core brand was used for mainstream


x86-architecture microprocessors from Intel from 2006
to 2009 when it was renamed to Pentium. The processors
are based on either the 32-bit Yonah or (with quite differ-
ent microarchitectures) 64-bit Merom-2M, Allendale, and
Wolfdale-3M core, targeted at mobile or desktop comput-
ers.
In terms of features, price and performance at a given
clock frequency, Pentium Dual-Core processors were po-
sitioned above Celeron but below Core and Core 2 micro-
processors in Intel’s product range. The Pentium Dual-
Core was also a very popular choice for overclocking, as
it can deliver high performance (when overclocked) at a
low price.

Pentium Dual-Core E2160 Overclock


10.1 Processor cores

In 2006, Intel announced a plan[1] to return the Pentium


trademark from retirement to the market, as a moniker
of low-cost Core microarchitecture processors based on 10.1.1 Yonah
the single-core Conroe-L but with 1 MiB of cache. The
identification numbers for those planned Pentiums were
similar to the numbers of the latter Pentium Dual-Core
microprocessors, but with the first digit “1”, instead of Main article: Yonah (microprocessor)
“2”, suggesting their single-core functionality. A single-
core Conroe-L with 1 MiB cache was deemed as not The first processors using the brand appeared in note-
strong enough to distinguish the planned Pentiums from book computers in early 2007. Those processors, named
the Celerons, so it was replaced by dual-core CPUs, Pentium T2060, T2080, and T2130,[2] had the 32-bit
adding “Dual-Core” to the line’s name. Throughout 2009, Pentium M-derived Yonah core, and closely resembled
Intel changed the name back from Pentium Dual-Core to the Core Duo T2050 processor with the exception of hav-
Pentium in its publications. Some processors were sold ing 1 MB of L2 cache instead of 2 MB. All three of
under both names, but the newer E5400 through E6800 them had a 533 MHz FSB connecting the CPU with the
desktop and SU4100/T4x00 mobile processors were not memory. Intel developed the Pentium Dual-Core at the
officially part of the Pentium Dual-Core line. request of laptop manufacturers.[3]

42
10.2. REBRANDING 43

10.1.2 Allendale using liquid nitrogen cooling. Intel released the E6500K
model using this core. The model features an unlocked
Main article: Conroe (microprocessor) § Allendale multiplier, but is currently only sold in China.
Subsequently, on June 3, 2007, Intel released the desk-

10.1.5 Penryn-3M
Main article: Penryn (microprocessor) § Penryn-3M

The Penryn core is the successor to the Merom core and


Intel’s 45 nm version of their mobile series of Pentium
Dual-Core microprocessors. The FSB is increased from
667 MHz to 800 MHz and the voltage is lowered. In-
tel released the first Penryn based Pentium Dual-Core,
the T4200, in December 2008. Later, mobile Pentium
T4000, SU2000 and SU4000 processors based on Penryn
were marketed as Pentium.

Intel Pentium E2180 @ 2.00GHz closeup 10.2 Rebranding


top Pentium Dual-Core branded processors[4] known as
the Pentium E2140 and E2160.[5] An E2180 model was See also: Pentium
released later in September 2007. These processors sup-
port the Intel 64 extensions, being based on the newer, 64- The Pentium Dual-Core brand has been discontinued in
bit Allendale core with Core microarchitecture. These early 2010 and replaced by the Pentium name. The Desk-
closely resembled the Core 2 Duo E4300 processor with top E6000 series and the OEM-only mobile Pentium
the exception of having 1 MB of L2 cache instead of 2 SU2000 and all later models were always called Pentium,
MB.[2] Both of them had an 800 MHz FSB. They tar- but the Desktop Pentium Dual-Core E2000 and E5000
geted the budget market above the Intel Celeron (Conroe- series processors had to be rebranded.
L single-core series) processors featuring only 512 KB of
L2 cache. Such a step marked a change in the Pentium
brand, relegating it to the budget segment rather than 10.3 Comparison to the Pentium D
its former position as the mainstream/premium brand.[6]
These CPUs are highly overclockable.[7]
Although using the Pentium name, the desktop Pentium
Dual-Core is based on the Core microarchitecture, which
10.1.3 Merom-2M can clearly be seen when comparing the specification to
the Pentium D, which is based on the NetBurst microar-
Main article: Merom (microprocessor) § Merom-2M chitecture first introduced in the Pentium 4. Below the
2 or 4 MiB of shared-L2-cache-enabled Core 2 Duo, the
desktop Pentium Dual-Core has 1 or 2 MiB of shared
The mobile version of the Allendale processor, the L2 Cache. In contrast, the Pentium D processors have
Merom-2M, was also introduced in 2007, featuring 1MB either 2 or 4 MiB of non-shared L2 cache. Addition-
of L2 cache but only 533 MT/s FSB with the T23xx pro- ally, the fastest-clocked Pentium D has a factory bound-
cessors. The bus clock was subsequently raised to 667 ary of 3.73 GHz, while the fastest-clocked desktop Pen-
MT/s with the T3xxx Pentium processors that are made tium Dual-Core reaches 3.2 GHz. A major difference
from the same dies. among these processors is that the desktop Pentium Dual
Core processors have a TDP of only 65 W while the Pen-
tium D ranges between 95 to 130 W. Despite the reduced
10.1.4 Wolfdale-3M clock speed, and lower amounts of cache, Pentium dual-
core outperfomed Pentium D by a fairly large margin.
Main article: Wolfdale (microprocessor) § Wolfdale-3M

The 45 nm E5200 model was released by Intel on Au- 10.4 See also
gust 31, 2008, with a larger 2MB L2 cache over the 65
nm E21xx series and the 2.5 GHz clock speed. The • Pentium
E5200 model is also a highly overclockable processor,
with some enthusiasts reaching over 6 GHz[8] clock speed • List of Intel Pentium Dual-Core microprocessors
44 CHAPTER 10. PENTIUM DUAL-CORE

• List of Intel Pentium microprocessors

10.5 References
[1] DailyTech – Intel “Conroe-L” Details Unveiled

[2] “Intel Pentium E2140 & E2160 review”. TechSpot. Re-


trieved 2007-06-23.

[3] The multicore era is upon us

[4] “Pentium E/Celeron 400 to be releasing on June 3”.


HKEPC Hardware. Retrieved 2007-03-16.

[5] Shilov, Anton. “Intel Readies Pentium E2000-Series Pro-


cessors”. X-bit labs. Retrieved 2007-03-04.

[6] Intel Processor Numbers chart for Intel Pentium Dual-


Core processors

[7] Schmid, Patrick (12 September 2007). "$89 Pentium


Dual Core that Runs at 3.2 GHz”. Tom’s Hardware. Re-
trieved 2009-09-21.

[8] http://ripping.org/database.php?cpuid=858

10.6 External links


Chapter 11

Xeon

Not to be confused with the ATI Xenos, or Xenon.

The Xeon /ˈziːɒn/ is a brand of x86 microprocessors


designed and manufactured by Intel Corporation, tar-
geted at the non-consumer workstation, server, and
embedded system markets. Primary advantages of the
Xeon CPUs, when compared to the majority of Intel’s
desktop-grade consumer CPUs, are their multi-socket ca-
pabilities, higher core counts, and support for ECC mem-
ory.

11.1 Overview
A 450 MHz Pentium II Xeon with a 512 kB L2 cache. The car-
The Xeon brand has been maintained over several genera- tridge cover has been removed.
tions of x86 and x86-64 processors. Older models added
the Xeon moniker to the end of the name of their corre-
and thus the Pentium II Xeon used a larger slot, Slot 2. It
sponding desktop processor, but more recent models used
was supported by the 440GX dual-processor workstation
the name Xeon on its own. The Xeon CPUs generally have
chipset and the 450NX quad- or octo-processor chipset.
more cache than their desktop counterparts in addition to
multiprocessing capabilities.
11.2.2 Pentium III Xeon
11.2 P6-based Xeon List: List of Intel Xeon microprocessors#"Tanner” (250
nm)
11.2.1 Pentium II Xeon
In 1999, the Pentium II Xeon was replaced by the
List: List of Intel Xeon microprocessors#"Drake” (250 Pentium III Xeon. Reflecting the incremental changes
nm) from the Pentium II "Deschutes" core to the Pentium
The first Xeon-branded processor was the Pentium II III "Katmai" core, the first Pentium III Xeon, named
Xeon (code-named "Drake"). It was released in 1998, "Tanner", was just like its predecessor except for the ad-
replacing the Pentium Pro in Intel’s server lineup. The dition of Streaming SIMD Extensions (SSE) and a few
Pentium II Xeon was a "Deschutes" Pentium II (and cache controller improvements. The product codes for
shared the same product code: 80523) with a full-speed Tanner mirrored that of Katmai; 80525.
512 kB, 1 MB, or 2 MB L2 cache. The L2 cache was
implemented with custom 512 kB SRAMs developed by List: List of Intel Xeon microprocessors#"Cascades”
Intel. The number of SRAMs depended on the amount (180 nm)
of cache. A 512 kB configuration required one SRAM, a
1 MB configuration: two SRAMs, and a 2 MB configura- The second version, named "Cascades", was based on
tion: four SRAMs on both sides of the PCB. Each SRAM the Pentium III "Coppermine" core. The "Cascades"
was a 12.90 mm by 17.23 mm (222.21 mm²) die fabri- Xeon used a 133 MHz bus and relatively small 256 kB
cated in a 0.35 µm four-layer metal CMOS process and on-die L2 cache resulting in almost the same capabilities
packaged in a cavity-down wire-bonded land grid array as the Slot 1 Coppermine processors, which were capable
(LGA).[1] The additional cache required a larger module of dual-processor operation but not quad-processor oper-

45
46 CHAPTER 11. XEON

ation. Prestonia performed much better than its predecessor and


To improve this situation, Intel released another version, noticeably better than Athlon MP. The support of new
officially also named "Cascades", but often referred to features in the E75xx series also gave it a key advantage
as "Cascades 2 MB". That came in two variants: with over the Pentium III Xeon and Athlon MP branded CPUs
1 MB or 2 MB of L2 cache. Its bus speed was fixed at (both stuck with rather old chipsets), and it quickly be-
100 MHz, though in practice the cache was able to offset came the top-selling server/workstation processor.
this. The product code for Cascades mirrored that of
Coppermine; 80526.

11.3.2 “Gallatin”
11.3 Netburst-based Xeon
List: List of Intel Xeon microprocessors#"Gallatin” (130
11.3.1 Xeon (DP) & Xeon MP (32-bit) nm)
List: List of Intel Xeon microprocessors#"Gallatin” MP
Foster (130 nm)

List: List of Intel Xeon microprocessors#"Foster” (180 Subsequent to the Prestonia was the "Gallatin", which
nm) had an L3 cache of 1 MB or 2 MB. Its Xeon MP ver-
List: List of Intel Xeon microprocessors#"Foster MP” sion also performed much better than the Foster MP, and
(180 nm) was popular in servers. Later experience with the 130
nm process allowed Intel to create the Xeon MP branded
Gallatin with 4 MB cache. The Xeon branded Prestonia
In mid-2001, the Xeon brand was introduced (“Pen-
and Gallatin were designated 80532, like Northwood.
tium” was dropped from the name). The initial variant
that used the new NetBurst microarchitecture, "Foster",
was slightly different from the desktop Pentium 4
("Willamette"). It was a decent chip for workstations, but
for server applications it was almost always outperformed 11.3.3 Xeon (DP) & Xeon MP (64-bit)
by the older Cascades cores with a 2 MB L2 cache and
AMD’s Athlon MP. Combined with the need to use ex-
Nocona and Irwindale
pensive Rambus Dynamic RAM, the Foster’s sales were
somewhat unimpressive.
Main article: Pentium 4 § Prescott
At most two Foster processors could be accommodated
List: List of Intel Xeon microprocessors#"Nocona” (90
in a symmetric multiprocessing (SMP) system built with
nm)
a mainstream chipset, so a second version (Foster MP)
List: List of Intel Xeon microprocessors#"Irwindale”
was introduced with a 1 MB L3 cache and the Jackson
(90 nm)
Hyper-Threading capacity. This improved performance
slightly, but not enough to lift it out of third place. It
was also priced much higher than the dual-processor (DP) Due to a lack of success with Intel’s Itanium and Itanium
versions. The Foster shared the 80528 product code with 2 processors, AMD was able to introduce x86-64, a 64-
Willamette. bit extension to the x86 architecture. Intel followed suit
by including Intel 64 (formerly EM64T; it is almost iden-
tical to AMD64) in the 90 nm version of the Pentium
Prestonia 4 ("Prescott"), and a Xeon version codenamed "Nocona"
with 1 MB L2 cache was released in 2004. Released with
List: List of Intel Xeon microprocessors#"Prestonia” it were the E7525 (workstation), E7520 and E7320 (both
(130 nm) server) chipsets, which added support for PCI Express,
DDR-II and Serial ATA. The Xeon was noticeably slower
In 2002 Intel released a 130 nm version of Xeon branded than AMD’s Opteron, although it could be faster in situ-
CPU, codenamed "Prestonia". It supported Intel’s new ations where Hyper-Threading came into play.
Hyper-Threading technology and had a 512 kB L2 cache. A slightly updated core called "Irwindale" was released
This was based on the "Northwood" Pentium 4 core. A in early 2005, with 2 MB L2 cache and the ability to have
new server chipset, E7500 (which allowed the use of its clock speed reduced during low processor demand.
dual-channel DDR SDRAM), was released to support Although it was a bit more competitive than the Nocona
this processor in servers, and soon the bus speed was had been, independent tests showed that AMD’s Opteron
boosted to 533 MT/s (accompanied by new chipsets: the still outperformed Irwindale. Both of these Prescott-
E7501 for servers and the E7505 for workstations). The derived Xeons have the product code 80546.
11.4. PENTIUM M (YONAH) BASED XEON 47

Cranford and Potomac sion of Paxville MP, built on a 65 nm process, with 2


MB of L2 cache (1 MB per core) and up to 16 MB of
Main article: Pentium 4 § Prescott L3 cache. It uses Socket 604 . Tulsa was released in two
List: List of Intel Xeon microprocessors#"Cranford” (90 lines: the N-line uses a 667 MT/s FSB, and the M-line
nm) uses an 800 MT/s FSB. The N-line ranges from 2.5 GHz
List: List of Intel Xeon microprocessors#"Potomac” (90 to 3.5 GHz (model numbers 7110N-7150N), and the M-
nm) line ranges from 2.6 GHz to 3.4 GHz (model numbers
7110M-7140M). L3 cache ranges from 4 MB to 16 MB
[3]
64-bit Xeon MPs were introduced in April 2005. The across the models.
cheaper "Cranford" was an MP version of Nocona, while
the more expensive "Potomac" was a Cranford with 8 5000-series “Dempsey”
MB of L3 cache. Like Nocona and Irwindale, they also
have product code 80546. List: List of Intel Xeon microprocessors#"Dempsey”
(65 nm)
11.3.4 Dual-Core Xeon
On 23 May 2006, Intel released the dual-core CPU
“Paxville DP” (Xeon branded 5000 series) codenamed Dempsey (prod-
uct code 80555). Released as the Dual-Core Xeon 5000-
List: List of Intel Xeon microprocessors#"Paxville DP” series, Dempsey is a NetBurst microarchitecture proces-
(90 nm) sor produced using a 65 nm process, and is virtually iden-
tical to Intel’s "Presler" Pentium Extreme Edition, except
for the addition of SMP support, which lets Dempsey
The first dual-core CPU branded Xeon, codenamed
operate in dual-processor systems. Dempsey ranges be-
Paxville DP, product code 80551, was released by In-
tween 2.50 GHz and 3.73 GHz (model numbers 5020–
tel on 10 October 2005. Paxville DP had NetBurst
5080). Some models have a 667 MT/s FSB, and oth-
microarchitecture, and was a dual-core equivalent of
ers have a 1066 MT/s FSB. Dempsey has 4 MB of L2
the single-core Irwindale (related to the Pentium D
Cache (2 MB per core). A Medium Voltage model, at
branded "Smithfield”") with 4 MB of L2 Cache (2
3.2 GHz and 1066 MT/s FSB (model number 5063), has
MB per core). The only Paxville DP model re-
also been released. Dempsey also introduces a new in-
leased ran at 2.8 GHz, featured an 800 MT/s front
terface for Xeon processors: LGA 771, also known as
side bus, and was produced using a 90 nm process.
Socket J. Dempsey was the first Xeon core in a long time
<sup class="noprint Inline-Template “noprint Inline-
to be somewhat competitive with its Opteron-based coun-
Template"" style="white-space:nowrap;">[check quota-
terparts, although it could not claim a decisive lead in any
tion syntax]
performance metric – that would have to wait for its suc-
cessor, the Woodcrest.
7000-series “Paxville MP”

List: List of Intel Xeon microprocessors#"Paxville MP” 11.4 Pentium M (Yonah) based
(90 nm)
Xeon
An MP-capable version of Paxville DP, codenamed
Paxville MP, product code 80560, was released on 1 11.4.1 LV (ULV), “Sossaman”
November 2005. There are two versions: one with 2 MB
of L2 Cache (1 MB per core), and one with 4 MB of List: List of Intel Xeon microprocessors#"Sossaman”
L2 (2 MB per core). Paxville MP, called the dual-core (65 nm)
Xeon 7000-series, was produced using a 90 nm process.
Paxville MP clock ranges between 2.67 GHz and 3.0 GHz On 14 March 2006, Intel released a dual-core processor
(model numbers 7020–7041), with some models having codenamed Sossaman and branded as Xeon LV (low-
a 667 MT/s FSB, and others having an 800 MT/s FSB. voltage). Subsequently an ULV (ultra-low-voltage) ver-
sion was released. The Sossaman was a low-/ultra-low-
power and double-processor capable CPU (like AMD
7100-series “Tulsa” Quad FX), based on the "Yonah" processor, for ultra-
dense non-consumer environment (i.e. targeted at the
List: List of Intel Xeon microprocessors#"Tulsa” (65 nm) blade-server and embedded markets), and was rated at
a thermal design power (TDP) of 31 W (LV: 1.66 GHz,
Released on 29 August 2006,[2] the 7100 series, code- 2 GHz and 2.16 GHz) and 15 W (ULV: 1.66 GHz).[4]
named Tulsa (product code 80550), is an improved ver- As such, it supported most of the same features as earlier
48 CHAPTER 11. XEON

Xeons: Virtualization Technology, 667 MT/s front side 5100-series “Woodcrest”


bus, and dual-core processing, but did not support 64-
bit operations, so it could not run 64-bit server software, List: List of Intel Xeon microprocessors#"Woodcrest”
such as Microsoft Exchange Server 2007, and therefore (65 nm)
was limited to 16 GB of memory. A planned successor,
codenamed "Merom MP" was to be a drop-in upgrade to
On 26 June 2006, Intel released the dual-core CPU (Xeon
enable Sossaman-based servers to upgrade to 64-bit ca-
branded 5100 series) codenamed Woodcrest (product
pability. However, this was abandoned in favour of low-
code 80556); it was the first Intel Core microarchitec-
voltage versions of the Woodcrest LV processor leaving
ture processor to be launched on the market. It is a server
the Sossaman at a dead-end with no upgrade path.
and workstation version of the Intel Core 2 processor. In-
tel claims that it provides an 80% boost in performance,
while reducing power consumption by 20% relative to the
11.5 Core-based Xeon Pentium D.
Most models have a 1333 MT/s FSB, except for the 5110
11.5.1 Dual-Core and 5120, which have a 1066 MT/s FSB. The fastest pro-
cessor (5160) operates at 3.0 GHz. All Woodcrests use
3000-series “Conroe” LGA 771 and all except two models have a TDP of 65 W.
The 5160 has a TDP of 80 W and the 5148LV (2.33 GHz)
Main article: Conroe (microprocessor) has a TDP of 40 W. The previous generation Xeons had a
List: List of Intel Xeon microprocessors#"Conroe” (65 TDP of 130 W. All models support Intel 64 (Intel’s x86-
nm) 64 implementation), the XD bit, and Virtualization Tech-
nology, with the "Demand Based Switching" power man-
agement option only on Dual-Core Xeon 5140 or above.
The 3000 series, codenamed Conroe (product code Woodcrest has 4 MB of shared L2 Cache.
80557) dual-core Xeon (branded) CPU,[5] released at the
end of September 2006, was the first Xeon for single-
CPU operation. The same processor is branded as Core 2 5200-series “Wolfdale-DP”
Duo or as Pentium Dual-Core and Celeron, with varying
features disabled. They use LGA 775 (Socket T), oper- List: List of Intel Xeon microprocessors#"Wolfdale-DP”
ate on a 1066 MHz front-side bus, support Enhanced Intel (45 nm)
Speedstep Technology and Intel Virtualization Technol-
ogy but do not support Hyper-Threading. Conroe Pro-
cessors with a number ending in “5” have a 1333 MT/s On 11 November 2007, Intel released the dual-core CPU
FSB.[6] (Xeon branded 5200 series) codenamed Wolfdale-DP
(product code 80573).[8] It is built on a 45 nm process like
the desktop Core 2 Duo and Xeon-SP Wolfdale, featur-
• Models marked with a star are not present in Intel’s ing Intel 64 (Intel’s x86-64 implementation), the XD bit,
database[7] and Virtualization Technology. It is unclear whether the
“Demand Based Switching” power management is avail-
able on the L5238.[9] Wolfdale has 6 MB of shared L2
3100-series “Wolfdale” Cache.

Main article: Wolfdale (microprocessor)


List: List of Intel Xeon microprocessors#"Wolfdale” (45 7200-series “Tigerton”
nm)
List: List of Intel Xeon microprocessors#"Wolfdale-CL” Main section: #Tigerton
(45 nm) List: List of Intel Xeon microprocessors#"Tigerton-DC”
(65 nm)
The 3100 series, codenamed Wolfdale (product code
80570) dual-core Xeon (branded) CPU, was just a re- The 7200 series, codenamed Tigerton (product code
branded version of the Intel’s mainstream Core 2 Duo 80564) is an MP-capable processor, similar to the 7300
E7000/E8000 and Pentium Dual-Core E5000 proces- series, but, in contrast, only one core is active on each
sors, featuring the same 45 nm process and 6 MB of silicon chip, and the other one is turned off (blocked),
L2 cache. Unlike most Xeon processors, they only sup- resulting as a dual-core capable processor.
port single-CPU operation. They use LGA 775 (Socket
T), operate on a 1333 MHz front-side bus, support En-
hanced Intel Speedstep Technology and Intel Virtualiza- 11.5.2 Quad-Core and Multi-Core Xeon
tion Technology but do not support Hyper-Threading.
11.5. CORE-BASED XEON 49

3200-series “Kentsfield” branded CPUs (two single-core chips) or the quad-core


Kentsfield. All Clovertowns use the LGA 771 package.
Main article: Kentsfield (microprocessor) The Clovertown has been usually implemented with two
List: List of Intel Xeon microprocessors#"Kentsfield” Woodcrest dies on a multi-chip module, with 8 MB of L2
(65 nm) cache (4 MB per die). Like Woodcrest, lower models use
a 1066 MT/s FSB, and higher models use a 1333 MT/s
FSB. Intel released Clovertown, product code 80563,
Intel released relabeled versions of its quad-core (2×2)
on 14 November 2006[13] with models E5310, E5320,
Core 2 Quad processor as the Xeon 3200-series (product
E5335, E5345, and X5355, ranging from 1.6 GHz to 2.66
code 80562) on 7 January 2007.[10] The 2 × 2 “quad-
GHz. All models support: MMX, SSE, SSE2, SSE3,
core” (dual-die dual-core[11] ) comprised two separate
SSSE3, Intel 64, XD bit (an NX bit implementation), In-
dual-core die next to each other in one CPU package.
tel VT. The E and X designations are borrowed from In-
The models are the X3210, X3220 and X3230, running
tel’s Core 2 model numbering scheme; an ending of −0
at 2.13 GHz, 2.4 GHz and 2.66 GHz, respectively.[12]
implies a 1066 MT/s FSB, and an ending of −5 implies a
Like the 3000-series, these models only support single-
1333 MT/s FSB.[12] All models have a TDP of 80 W with
CPU operation and operate on a 1066 MHz front-side
the exception of the X5355, which has a TDP of 120 W.
bus. It is targeted at the “blade” market. The X3220 is
A low-voltage version of Clovertown with a TDP of 50
also branded and sold as Core2 Quad Q6600, the X3230
W has a model numbers L5310, L5320 and L5335 (1.6
as Q6700.
GHz, 1.86 GHz and 2.0 GHz respectively). The 3.0 GHz
X5365 arrived in July 2007, and became available in the
3300-series “Yorkfield” Apple Mac Pro on 4 April 2007.[14] The X5365 performs
up to around 38 GFLOPS in the LINPACK benchmark.
Main article: Yorkfield (microprocessor)
List: List of Intel Xeon microprocessors#"Yorkfield”
(45 nm)
List: List of Intel Xeon microprocessors#"Yorkfield-CL” 5400-series “Harpertown”
(45 nm)
List: List of Intel Xeon microprocessors#"Harpertown”
Intel released relabeled versions of its quad-core Core (45 nm)
2 Quad Yorkfield Q9400 and Q9x50 processors as the
Xeon 3300-series (product code 80569). This processor On 11 November 2007 Intel presented Yorkfield-based
comprises two separate dual-core dies next to each other Xeons – called Harpertown (product code 80574) – to
in one CPU package and manufactured in a 45 nm pro- the public. This family consists of dual die quad-core
cess. The models are the X3320, X3350, X3360, X3370 CPUs manufactured on a 45 nm process and featuring
and X3380, running at 2.50 GHz, 2.66 GHz, 2.83 GHz, 1066 MHz, 1333 MHz, 1600 MHz front-side buses, with
3.0 GHz, and 3.16 GHz, respectively. The L2 cache is a TDP rated from 40 W to 150 W depending on the model.
unified 6 MB per die (except for the X3320 with a smaller These processors fit in the LGA 771 package. All mod-
3 MB L2 cache per die), and a front-side bus of 1333 els feature Intel 64 (Intel’s x86-64 implementation), the
MHz. All models feature Intel 64 (Intel’s x86-64 imple- XD bit, and Virtualization Technology. All except the
mentation), the XD bit, and Virtualization Technology, E5405 and L5408 also feature Demand Based Switch-
as well as “Demand Based Switching”. ing.[15][16] The supplementary character in front of the
The Yorkfield-CL (product code 80584) variant of these model-number represents the thermal rating: an L depicts
processors are X3323, X3353 and X3363. They have a a TDP of 40 W or 50 W, an E depicts 80 W whereas an X
reduced TDP of 80W and are made for single-CPU LGA is 120 W TDP or above. The speed of 3.00 GHz comes
771 systems instead of LGA 775, which is used in all as four models, two models with 80 W TDP two other
other Yorkfield processors. In all other respects, they are models with 120 W TDP with 1333 MHz or 1600 MHz
identical to their Yorkfield counterparts. front-side bus respectively. The fastest Harpertown is the
X5492 whose TDP of 150 W is higher than those of the
Prescott-based Xeon DP but having twice as many cores.
5300-series “Clovertown” (The X5482 is also sold under the name “Core 2 Extreme
QX9775” for use in the Intel SkullTrail system.)
List: List of Intel Xeon microprocessors#"Clovertown” Intel 1600 MHz front-side bus Xeon processors will drop
(65 nm) into the Intel 5400 (Seaburg) chipset whereas several
mainboards featuring the Intel 5000/5200-chipset are en-
A quad-core (2×2) successor of the Woodcrest for DP abled to run the processors with a 1333 MHz front-side
segment, consisting of two dual-core Woodcrest chips bus speed. Seaburg features support for dual PCIe 2.0
in one package similarly to the dual-core Pentium D x16 slots and up to 128 GB of memory.[17][18]
50 CHAPTER 11. XEON

7300-series “Tigerton” Bloomfield, they are quad-core single-package processors


based on the Nehalem microarchitecture, but were in-
List: List of Intel Xeon microprocessors#"Tigerton” (65 troduced almost a year later, in September 2009. The
nm) same processors are marketed for mid-range to high-end
desktops systems as Core i5 and Core i7. They have two
integrated memory channels as well as PCI Express and
The 7300 series, codenamed Tigerton (product code
Direct Media Interface (DMI) links, but no QuickPath
80565) is a four-socket (packaged in Socket 604) and
Interconnect (QPI) interface.
more capable quad-core processor, consisting of two dual
core Core2 architecture silicon chips on a single ceramic
module, similar to Intel’s Xeon 5300 series Clovertown
processor modules.[19]
11.6.2 3400-series “Clarkdale”
The 7300 series uses Intel’s Caneland (Clarksboro) plat-
form. Main article: Clarkdale (microprocessor)
Intel claims the 7300 series Xeons offer more than twice List: List of Intel Xeon microprocessors#"Clarkdale”
the performance per watt as Intel’s previous generation (MCP, 32 nm)
7100 series. The 7300 series’ Caneland chipset provides
a point to point interface allowing the full front side bus At low end of the 3400-series is not a Lynnfield but a
bandwidth per processor. Clarkdale processor, which is also used in the Core i3-
The 7xxx series is aimed at the large server market, sup- 500 and Core i5-600 processors as well as the Celeron
porting configurations of up to 32 CPUs per host. G1000 and G6000 Pentium series. A single model was
released in March 2010, the Xeon L3406. Compared to
all other Clarkdale-based products, this one does not sup-
7400-series “Dunnington” port integrated graphics, but has a much lower thermal
design power of just 30 W. Compared to the Lynnfield-
List: List of Intel Xeon microprocessors#"Dunnington” based Xeon 3400 models, it only offers two cores.
(45 nm)

Dunnington[20] – the last CPU of the Penryn generation


and Intel’s first multi-core (above two) die – features a 11.6.3 3500-series “Bloomfield”
single-die six- (or hexa-) core design with three unified 3
MB L2 caches (resembling three merged 45 nm dual-core Main article: Bloomfield (microprocessor)
Wolfdale dies), and 96 kB L1 cache (Data) and 16 MB of List: List of Intel Xeon microprocessors#"Bloomfield”
L3 cache. It features 1066 MHz FSB, fits into the Tiger- (45 nm)
ton’s mPGA604 socket, and is compatible with the both
the Intel Caneland, and IBM X4 chipsets. These proces- Bloomfield is the codename for the successor to the Xeon
sors support DDR2-1066 (533 MHz), and have a maxi- Core microarchitecture, is based on the Nehalem mi-
mum TDP below 130 W. They are intended for blades croarchitecture and uses the same 45 nm manufacturing
and other stacked computer systems. Availability was methods as Intel’s Penryn. The first processor released
scheduled for the second half of 2008. It was followed with the Nehalem architecture is the desktop Intel Core
shortly by the Nehalem microarchitecture. Total transis- i7, which was released in November 2008. This is the
tor count is 1.9 billion.[21] server version for single CPU systems. This is a single-
Announced on 15 September 2008.[22] socket Intel Xeon processor. The performance improve-
ments over previous Xeon processors are based mainly
on:
11.6 Nehalem-based Xeon
• Integrated memory controller supporting three
11.6.1 3400-series “Lynnfield” memory channels of DDR3 UDIMM (Unbuffered)
or RDIMM (Registered)
Main article: Lynnfield (microprocessor)
List: List of Intel Xeon microprocessors#"Lynnfield”
(45 nm) • A new point-to-point processor interconnect
QuickPath, replacing the legacy front side bus

Xeon 3400-series processors based on Lynnfield fill the


gap between the previous 3300-series “Yorkfield” pro- • Simultaneous multithreading by multiple cores and
cessors and the newer 3500-series “Bloomfield”. Like hyper-threading (2× per core).
11.6. NEHALEM-BASED XEON 51

11.6.4 <span id="5500-series 11.6.6 3600/5600-series “Gulftown” &


“Gainestown"">5500-series “Westmere-EP”
“Gainestown”
Main article: Gulftown (microprocessor)
List: List of Intel Xeon microprocessors#"Gainestown” List: List of Intel Xeon microprocessors#"Gulftown” (32
(45 nm) nm), List of Intel Xeon microprocessors#"Westmere-
EP” (32 nm)

Gainestown or Nehalem-EP, the successor to the Xeon


Core microarchitecture, is based on the Nehalem mi- Gulftown or Westmere-EP, a six-core 32 nm Westmere-
croarchitecture and uses the same 45 nm manufacturing based processor, is the basis for the Xeon 36xx and 56xx
methods as Intel’s Penryn. The first processor released series and the Core i7−980X. It launched in the first
with the Nehalem microarchitecture is the desktop Intel quarter of 2010. The 36xx-series follows the 35xx-series
Core i7, which was released in November 2008. Server Bloomfield uni-processor model while the 56xx-series
processors of the Xeon 55xx range were first supplied to follows the 55xx-series Gainestown dual-processor model
testers in December 2008.[23] and both are socket compatible to their predecessors.

The performance improvements over previous Xeon pro-


cessors are based mainly on: 11.6.7 6500/7500-series “Beckton”

List: List of Intel Xeon microprocessors#"Beckton” (45


• Integrated memory controller supporting three nm)
memory channels of DDR3 SDRAM.

Beckton or Nehalem-EX (EXpandable server market) is


• A new point-to-point processor interconnect a Nehalem-based processor with up to eight cores and
QuickPath, replacing the legacy front side bus. uses buffering inside the chipset to support up to 16 stan-
Gainestown has two QuickPath interfaces. dard DDR3 DIMMS per CPU socket without requiring
the use of FB-DIMMS.[25] Unlike all previous Xeon MP
processors, Nehalem-EX uses the new LGA 1567 pack-
• Hyper-threading (2× per core, starting from 5518), age, replacing the Socket 604 used in the previous mod-
that was already present in pre-Core Duo processors. els, up to Xeon 7400 “Dunnington”. The 75xx models
have four QuickPath interfaces, so it can be used in up-
to eight-socket configurations, while the 65xx models are
only for up to two sockets. Designed by the Digital En-
11.6.5 <span id="C3500/C5500-Series terprise Group (DEG) Santa Clara and Hudson Design
“Jasper Forest"">C3500/C5500- Teams, Beckton is manufactured on the P1266 (45 nm)
series “Jasper Forest” technology. Its launch in March 2010 coincided with that
of its direct competitor, AMD’s Opteron 6xxx “Magny-
[26]
List: List of Intel Xeon microprocessors#"Jasper Forest” Cours”.
(45 nm) Most models limit the number of cores and QPI links as
well as the L3 Cache size in order to get a broader range
Jasper Forest is a Nehalem-based embedded processor of products out of the single chip design.
with PCI Express connections on-die, core counts from 1
to 4 cores and power envelopes from 23 to 85 watts.[24]
The uni-processor version without QPI comes as LC35xx
11.6.8 E7-x8xx-series “Westmere-EX”
and EC35xx, while the dual-processor version is sold as
LC55xx and EC55xx and uses QPI for communication List: List of Intel Xeon microprocessors#"Westmere-
between the processors. Both versions use a DMI link to EX” (32 nm) Expandable
communicate with the 3420 that is also used in the 3400-
series Lynfield Xeon processors, but use an LGA 1366 Westmere-EX is the follow-on to Beckton/Nehalem-
package that is otherwise used for processors with QPIEX and the first Intel Chip to have ten CPU cores.
but no DMI or PCI Express links. The CPUID code of The microarchitecture is the same as in the six-core
Gulftown/Westmere-EP processor, but it uses the LGA
both Lynnfield and Jasper forest is 106Ex, i.e. family 6,
model 30. 1567 package like Beckton to support up to eight sock-
The Celeron P1053 belongs into the same family as the ets.
LC35xx series, but lacks some RAS features that are Starting with Westmere-EX, the naming scheme has
present in the Xeon version. changed once again, with “E7-xxxx” now signifying the
52 CHAPTER 11. XEON

high-end line of Xeon processors using a package that The Xeon E5-16xx processors follow the previous Xeon
supports larger than two-CPU configurations, formerly 3500/3600-series products as the high-end single-socket
the 7xxx series. Similarly, the 3xxx uniprocessor and platform, using the LGA 2011 package introduced with
5xxx dual-processor series turned into E3-xxxx and E5- this processor. They share the Sandy Bridge-E platform
xxxx, respectively, for later processors. with the single-socket Core i7-38xx and i7-39xx proces-
sors. The CPU chips have no integrated GPU but eight
CPU cores, some of which are disabled in the entry-level
products. The Xeon E5-26xx line has the same features
11.7 Sandy Bridge– and Ivy but also enables multi-socket operation like the earlier
Bridge–based Xeon Xeon 5000-series and Xeon 7000-series processors.

11.7.1 E3-12xx-series “Sandy Bridge”


11.7.4 E5-14xx v2/24xx v2 series “Ivy
Main article: Sandy Bridge Bridge-EN” and E5-16xx v2/26xx
List: List of Intel Xeon microprocessors#"Sandy Bridge” v2/46xx v2 series “Ivy Bridge-EP”
(32 nm)
Main article: Ivy Bridge-EN/EP
The Xeon E3-12xx line of processors, introduced in List: List of Intel Xeon microprocessors#Xeon E5-1xxx
April 2011, uses the Sandy Bridge chips that are also v2 (uniprocessor)
the base for the Core i3/i5/i7-2xxx and Celeron/Pentium List: List of Intel Xeon microprocessors#Xeon E5-2xxx
Gxxx products using the same LGA 1155 socket, but v2 (dual-processor)
with a different set of features disabled. Notably, the List: List of Intel Xeon microprocessors#Xeon E5-4xxx
Xeon variants include support for ECC memory, VT-d v2 (quad-processor)
and trusted execution that are not present on the con-
sumer models, while only some Xeon E3 enable the in- The Xeon E5 v2 line was an update, released in Septem-
tegrated GPU that is present on Sandy Bridge. Like its ber 2013 to replace the original Xeon E5 processors with
Xeon 3400-series predecessors, the Xeon E3 only sup- a variant based on the Ivy Bridge shrink. The maximum
ports operation with a single CPU socket and is targeted number of CPU cores was raised to 12 per processor
at entry-level workstations and servers. The CPUID of module and the total L3 cache was upped to 30 MB.[27][28]
this processor is 0206A7h, the product code is 80623. The consumer version of the Xeon E5-16xx v2 processor
is the Core i7-48xx and 49xx.

11.7.2 E3-12xx v2-series “Ivy Bridge”


11.7.5 E7-28xx v2/48xx v2/88xx v2 series
Main article: Ivy Bridge (microarchitecture)
“Ivy Bridge-EX”
Xeon E3-12xx v2 is a minor update of the Sandy Bridge Main article: Ivy Bridge-EX
based E3-12xx, using the 22 nm shrink, and providing List: List of Intel Xeon microprocessors#Xeon E7-28xx
slightly better performance while remaining backwards v2 (dual-processor)
compatible. They were released in May 2012 and mirror List: List of Intel Xeon microprocessors#Xeon E7-48xx
the desktop Core i3/i5/i7-3xxx parts. v2 (quad-processor)
List: List of Intel Xeon microprocessors#Xeon E7-88xx
v2 (octa-processor)
11.7.3 E5-14xx/24xx series “Sandy
Bridge-EN” and E5- The Xeon E7 v2 line was an update, released in February
16xx/26xx/46xx-series “Sandy 2014 to replace the original Xeon E7 processors with a
Bridge-EP” variant based on the Ivy Bridge shrink. There was no
Sandy Bridge version of these processors.
Main article: Sandy Bridge-E
List: List of Intel Xeon microprocessors#"Sandy Bridge-
E” (32 nm)
List: List of Intel Xeon microprocessors#"Sandy Bridge- 11.8 Haswell-based Xeon
EN” (32 nm) Entry
List: List of Intel Xeon microprocessors#"Sandy Bridge- Main article: Haswell (microarchitecture)
EP” (32 nm) Efficient Performance List: Haswell (microarchitecture) § Server processors
11.9. SUPERCOMPUTERS 53

11.8.1 E3-12xx v3-series “Haswell” core counts, and bigger last level caches (LLCs). Fol-
lowing the already used nomenclature, Xeon E5-26xx v3
series allows multi-socket operation.
One of the new features of this generation is that Xeon
E5 v3 models with more than 10 cores support cluster
on die (COD) operation mode, allowing CPU’s multiple
columns of cores and LLC slices to be logically divided
into what is presented as two non-uniform memory ac-
cess (NUMA) CPUs to the operating system. By keep-
ing data and instructions local to the “partition” of CPU
which is processing them, thus decreasing the LLC ac-
cess latency, COD brings performance improvements to
NUMA-aware operating systems and applications.[29]

11.9 Supercomputers
Intel Xeon E3-1241 v3 CPU, sitting atop the inside part of its
retail box that contains an OEM fan-cooled heatsink By 2013 Xeon processors were ubiquitous in
supercomputers—more than 80% of the Top500
Introduced in May 2013, Xeon E3-12xx v3 is the first machines in 2013 used them. For the very fastest ma-
Xeon series based on the Haswell microarchitecture. It chines, much of the performance comes from compute
uses the new LGA 1150 socket, which was introduced accelerators; Intel’s entry into that market was the Xeon
with the desktop Core i5/i7 Haswell processors, incom- Phi, the first machines using it appeared in the June 2012
patible with the LGA 1155 that was used in Xeon E3 and list and by June 2013 it was used in the fastest computer
E3 v2. As before, the main difference between the desk- in the world.
top and server versions is added support for ECC memory
in the Xeon-branded parts. The main benefit of the new • The first Xeon-based machines in the top-10 ap-
microarchitecture is better power efficiency. peared in November 2002, two clusters at Lawrence
Livermore National Laboratory and at NOAA.

11.8.2 E5-16xx/26xx v3-series “Haswell- • The first Xeon-based machine to be in the first
EP” place of the Top500 was the Chinese Tianhe-IA
in November 2010, which used a mixed Xeon-
nVIDIA GPGPU configuration; it was overtaken by
the Japanese K computer in 2012, but the Tianhe-
2 system using 12-core Xeon E5-2692 processors
and Xeon Phi cards occupied the first place in both
Top500 lists of 2013.
• The SuperMUC system, using 8-core Xeon E5-
2680 processors but no accelerator cards, managed
fourth place in June 2012 and had dropped to tenth
by November 2013

• Xeon processor-based systems are among the top 20


fastest systems by memory bandwidth as measured
by the STREAM benchmark.[30]

Intel Xeon E5-1650 v3 CPU; its retail box contains no OEM • An Intel Xeon virtual SMP system leveraging
heatsink ScaleMP’s Versatile SMP (vSMP) architecture with
128 cores and 1TB RAM.[31] This system aggregates
Introduced in September 2014, Xeon E5-16xx v3 and 16 Stoakley platform (Seaburg chipset) systems with
Xeon E5-26xx v3 series use the new LGA 2011-v3 total of 32 Harpertown processors.
socket, which is incompatible with the LGA 2011 socket
used by earlier Xeon E5 and E5 v2 generations based on
Sandy Bridge and Ivy Bridge microarchitectures. Some 11.10 See also
of the main benefits of this generation, when compared to
the previous one, are improved power efficiency, higher • AMD Opteron
54 CHAPTER 11. XEON

• Intel Xeon Phi, brand name for family of products [21] “Chipzilla unveils six-core 'Dunnington' Xeons”. thereg-
using the Intel MIC architecture ister.co.uk.

• List of Intel Xeon microprocessors [22] “Intel® Xeon® Processor E7 Family”. Intel.

• List of Intel microprocessors [23] AnandTech: Intel Xeon 5570: Smashing SAP records, 16
December 2008

[24] “Intel demos Moorestown, embeds Nehalem”. theregis-


11.11 References ter.co.uk.

[25] “Nehalem-EX: 2.3 billion transistors, eight cores, one


[1] Bateman, B. et al. (February 1998). “A 450MHz die”.
512kB Second-Level Cache with a 3.6GB/s Data
Bandwidth”. ISSCC Digest of Technical Papers. [26] Intel’s next bunch of fun CPUs moves to 2010
doi:10.1109/ISSCC.1998.672528.
[27] Timothy Prickett Morgan (10 September 2013). “Intel
[2] New High-End Intel Server Processors Expand Perfor- carves up Xeon E5-2600 v2 chips for two-socket boxes”.
mance Leadership, Intel News Release. The Register. Retrieved 13 September 2013.

[3] Intel prices up Woodcrest, Tulsa server chips, The In- [28] “Intel Introduces Highly Versatile Datacenter Processor
quirer. Family Architected for New Era of Services”. Press re-
lease. 10 September 2013. Retrieved 13 September 2013.
[4] “Intel drops 32-bit dual-core LV processors”. TG Daily.
Retrieved 2007-07-31. [29] Johan De Gelas (2014-09-08). “Intel Xeon E5 Version 3,
Up to 18 Haswell EP Cores: The Magic Inside the Un-
[5] Intel Adds Low End Xeons to Roadmap, DailyTech core”. AnandTech. Retrieved 2014-09-09.

[6] Intel Readies New Xeons and Price Cuts, WinBeta.org [30] STREAM benchmark, Dr. John D. McCalpin

[7] “ARK - Your Source for Intel® Product Information”. In- [31] “Stream Benchmark Results - Top 20 Set”. virginia.edu.
tel® ARK (Product Specs).

[8] HTN_WDP_Datasheet.book
11.12 External links
[9] Intel bringt neue Prozessoren für den Embedded-Markt
auf Basis seiner 45nm-Fertigungstechnologie • Server processors at the Intel website
[10] Intel Hard-Launches Three New Quad-core Processors, • Intel look inside: Xeon E5 v3 (Grantley) launch,
DailyTech Intel, September 2014
[11] “Intel Clovertowns step up, reduce power”. TG Daily. Re-
trieved 2007-09-05.

[12] Quad-core Xeon Details Unveiled, DailyTech

[13] Intel Ignites Quad-Core Era, Intel News Release.

[14] Intel Readies New Xeons and Price Cuts, DailyTech

[15] Quad-Core Intel Xeon Processor E5405, Intel ARK (Au-


tomated Relational Knowledgebase)

[16] Intel® Xeon® Processor L5408, Intel ARK (Automated


Relational Knowledgebase)

[17] Intel Readies 1600 MHz Front-Side Bus Xeons, Dai-


lyTech

[18] Intel Xeons Coming With 1600MHz FSB, Truste-


dReviews

[19] Intel Launches First Industry-Standard Quad-Core Prod-


ucts for High-End, Multi-Processor Servers, Intel Corpo-
ration, 5 September 2007, retrieved 2010-06-25

[20] Valich, Theo (25 February 2008). “Intel six-core coming


in 2008”. TG Daily (Tigervision Media). Retrieved 2008-
02-26.
Chapter 12

Distributed computing

“Distributed Information Processing” redirects here. For ties, each of which has its own local memory.[7]
the computer company, see DIP Research.
• The entities communicate with each other by
Distributed computing is a field of computer science message passing.[8]
that studies distributed systems. A distributed system
is a software system in which components located on In this article, the computational entities are called com-
networked computers communicate and coordinate their puters or nodes.
actions by passing messages.[1] The components inter-
A distributed system may have a common goal, such as
act with each other in order to achieve a common goal.
solving a large computational problem.[9] Alternatively,
Three significant characteristics of distributed systems
each computer may have its own user with individual
are: concurrency of components, lack of a global clock,
needs, and the purpose of the distributed system is to
and independent failure of components.[1] Examples of
coordinate the use of shared resources or provide com-
distributed systems vary from SOA-based systems to
munication services to the users.[10]
massively multiplayer online games to peer-to-peer ap-
plications. Other typical properties of distributed systems include the
following:
A computer program that runs in a distributed system is
called a distributed program, and distributed program-
ming is the process of writing such programs.[2] There are • The system has to tolerate failures in individual
many alternatives for the message passing mechanism, in- computers.[11]
cluding RPC-like connectors and message queues. An
• The structure of the system (network topology, net-
important goal and challenge of distributed systems is
work latency, number of computers) is not known in
location transparency.
advance, the system may consist of different kinds
Distributed computing also refers to the use of distributed of computers and network links, and the system
systems to solve computational problems. In distributed may change during the execution of a distributed
computing, a problem is divided into many tasks, each program.[12]
of which is solved by one or more computers,[3] which
communicate with each other by message passing.[4] • Each computer has only a limited, incomplete view
of the system. Each computer may know only one
part of the input.[13]
12.1 Introduction
The word distributed in terms such as “distributed sys- 12.1.1 Architecture
tem”, “distributed programming”, and "distributed algo-
rithm" originally referred to computer networks where Client/Server System : The Client-server architecture is a
individual computers were physically distributed within way to provide a service from a central source. There is a
some geographical area.[5] The terms are nowadays used single server that provides a service, and many clients that
in a much wider sense, even referring to autonomous communicate with the server to consume its products. In
processes that run on the same physical computer and in- this architecture, clients and servers have different jobs.
teract with each other by message passing.[4] While there The server’s job is to respond to service requests from
is no single definition of a distributed system,[6] the fol- clients, while a client’s job is to use the data provided in
lowing defining properties are commonly used: response in order to perform some tasks.
Peer-to-Peer System : The term peer-to-peer is used to
• There are several autonomous computational enti- describe distributed systems in which labour is divided

55
56 CHAPTER 12. DISTRIBUTED COMPUTING

between processors.[17]
(a)

• In distributed computing, each processor has its own


private memory (distributed memory). Informa-
tion is exchanged by passing messages between the
(b) Processor processors.[18]

Memory

Processor The figure on the right illustrates the difference between


distributed and parallel systems. Figure (a) is a schematic
view of a typical distributed system; as usual, the sys-
Memory
tem is represented as a network topology in which each
Processor node is a computer and each line connecting the nodes
is a communication link. Figure (b) shows the same dis-
Processor
Memory tributed system in more detail: each computer has its own
local memory, and information can be exchanged only by
Memory passing messages from one node to another by using the
available communication links. Figure (c) shows a paral-
lel system in which each processor has a direct access to
(c) a shared memory.
Processor Processor Processor
The situation is further complicated by the traditional
Memory uses of the terms parallel and distributed algorithm that do
not quite match the above definitions of parallel and dis-
tributed systems; see the section Theoretical foundations
(a)–(b) A distributed system.
(c) A parallel system.
below for more detailed discussion. Nevertheless, as a
rule of thumb, high-performance parallel computation in
a shared-memory multiprocessor uses parallel algorithms
among all the components of the system. All the com- while the coordination of a large-scale distributed system
puters send and receive data, and they all contribute some uses distributed algorithms.
processing power and memory. As a distributed system
increases in size, its capacity of computational resources
increases. In a peer-to-peer system, all components of the
system contribute some processing power and memory to
a distributed computation. 12.3 History

The use of concurrent processes that communicate by


12.2 Parallel and distributed com- message-passing has its roots in operating system archi-
tectures studied in the 1960s.[19] The first widespread
puting distributed systems were local-area networks such as
Ethernet, which was invented in the 1970s.[20]
Distributed systems are groups of networked comput-
ers, which have the same goal for their work. The ARPANET, the predecessor of the Internet, was intro-
terms "concurrent computing", "parallel computing", and duced in the late 1960s, and ARPANET e-mail was in-
“distributed computing” have a lot of overlap, and no vented in the early 1970s. E-mail became the most suc-
clear distinction exists between them.[14] The same sys- cessful application of ARPANET,[21] and it is probably
tem may be characterized both as “parallel” and “dis- the earliest example of a large-scale distributed applica-
tributed"; the processors in a typical distributed system tion. In addition to ARPANET, and its successor, the
run concurrently in parallel.[15] Parallel computing may Internet, other early worldwide computer networks in-
be seen as a particular tightly coupled form of distributed cluded Usenet and FidoNet from 1980s, both of which
computing,[16] and distributed computing may be seen as were used to support distributed discussion systems.
a loosely coupled form of parallel computing.[6] Never-The study of distributed computing became its own
theless, it is possible to roughly classify concurrent sys-
branch of computer science in the late 1970s and early
tems as “parallel” or “distributed” using the following cri-
1980s. The first conference in the field, Symposium on
teria: Principles of Distributed Computing (PODC), dates back
to 1982, and its European counterpart International Sym-
• In parallel computing, all processors may have ac- posium on Distributed Computing (DISC) was first held
cess to a shared memory to exchange information in 1985.
12.6. THEORETICAL FOUNDATIONS 57

12.4 Applications • Real-time process control:

• Aircraft control systems


Reasons for using distributed systems and distributed
computing may include: • Industrial control systems

• Parallel computation:
1. The very nature of an application may require the
use of a communication network that connects sev- • Scientific computing, including cluster
eral computers: for example, data produced in one computing and grid computing and various
physical location and required in another location. volunteer computing projects; see the list of
distributed computing projects
2. There are many cases in which the use of a single
computer would be possible in principle, but the • Distributed rendering in computer graphics
use of a distributed system is beneficial for prac-
tical reasons. For example, it may be more cost-
efficient to obtain the desired level of performance 12.6 Theoretical foundations
by using a cluster of several low-end computers, in
comparison with a single high-end computer. A dis- Main article: Distributed algorithm
tributed system can provide more reliability than a
non-distributed system, as there is no single point of
failure. Moreover, a distributed system may be eas-
ier to expand and manage than a monolithic unipro- 12.6.1 Models
cessor system.[22]
Many tasks that we would like to automate by using a
Ghaemi et al. define a distributed query as a query “that computer are of question–answer type: we would like
selects data from databases located at multiple sites in a to ask a question and the computer should produce an
network” and offer as an SQL example: answer. In theoretical computer science, such tasks are
called computational problems. Formally, a computa-
SELECT ename, dname tional problem consists of instances together with a solu-
FROM company.emp e, com- tion for each instance. Instances are questions that we can
pany.dept@sales.goods d ask, and solutions are desired answers to these questions.
WHERE e.deptno = d.deptno[23] Theoretical computer science seeks to understand which
computational problems can be solved by using a
computer (computability theory) and how efficiently
12.5 Examples (computational complexity theory). Traditionally, it is
said that a problem can be solved by using a computer if
we can design an algorithm that produces a correct solu-
Examples of distributed systems and applications of dis-
tion for any given instance. Such an algorithm can be im-
tributed computing include the following:[24]
plemented as a computer program that runs on a general-
purpose computer: the program reads a problem instance
• Telecommunication networks: from input, performs some computation, and produces
• Telephone networks and cellular networks the solution as output. Formalisms such as random ac-
cess machines or universal Turing machines can be used
• Computer networks such as the Internet as abstract models of a sequential general-purpose com-
• Wireless sensor networks puter executing such an algorithm.
• Routing algorithms The field of concurrent and distributed computing studies
similar questions in the case of either multiple comput-
• Network applications:
ers, or a computer that executes a network of interacting
• World wide web and peer-to-peer networks processes: which computational problems can be solved
in such a network and how efficiently? However, it is not
• Massively multiplayer online games and
at all obvious what is meant by “solving a problem” in
virtual reality communities
the case of a concurrent or distributed system: for exam-
• Distributed databases and distributed database ple, what is the task of the algorithm designer, and what
management systems is the concurrent or distributed equivalent of a sequential
• Network file systems general-purpose computer?
• Distributed information processing systems The discussion below focuses on the case of multiple
such as banking systems and airline reserva- computers, although many of the issues are the same for
tion systems concurrent processes running on a single computer.
58 CHAPTER 12. DISTRIBUTED COMPUTING

Three viewpoints are commonly used: • The graph G is encoded as a string, and the string
is given as input to a computer. The computer pro-
Parallel algorithms in shared-memory model gram finds a coloring of the graph, encodes the col-
oring as a string, and outputs the result.
• All computers have access to a shared memory. The
algorithm designer chooses the program executed by Parallel algorithms
each computer.
• Again, the graph G is encoded as a string. How-
• One theoretical model is the parallel random access
ever, multiple computers can access the same string
machines (PRAM) that are used.[25] However, the
in parallel. Each computer might focus on one part
classical PRAM model assumes synchronous access
of the graph and produce a coloring for that part.
to the shared memory.
• The main focus is on high-performance computa-
• A model that is closer to the behavior of real-world
tion that exploits the processing power of multiple
multiprocessor machines and takes into account
computers in parallel.
the use of machine instructions, such as Compare-
and-swap (CAS), is that of asynchronous shared
memory. There is a wide body of work on this Distributed algorithms
model, a summary of which can be found in the
literature.[26][27] • The graph G is the structure of the computer net-
work. There is one computer for each node of G
Parallel algorithms in message-passing model and one communication link for each edge of G.
Initially, each computer only knows about its imme-
• The algorithm designer chooses the structure of the diate neighbors in the graph G; the computers must
network, as well as the program executed by each exchange messages with each other to discover more
computer. about the structure of G. Each computer must pro-
duce its own color as output.
• Models such as Boolean circuits and sorting net-
works are used.[28] A Boolean circuit can be seen • The main focus is on coordinating the operation of
as a computer network: each gate is a computer that an arbitrary distributed system.
runs an extremely simple computer program. Sim-
ilarly, a sorting network can be seen as a computer While the field of parallel algorithms has a different fo-
network: each comparator is a computer. cus than the field of distributed algorithms, there is a lot
of interaction between the two fields. For example, the
Distributed algorithms in message-passing model Cole–Vishkin algorithm for graph coloring[29] was origi-
nally presented as a parallel algorithm, but the same tech-
• The algorithm designer only chooses the computer nique can also be used directly as a distributed algorithm.
program. All computers run the same program. The Moreover, a parallel algorithm can be implemented ei-
system must work correctly regardless of the struc- ther in a parallel system (using shared memory) or in a
ture of the network. distributed system (using message passing).[30] The tra-
ditional boundary between parallel and distributed algo-
• A commonly used model is a graph with one finite- rithms (choose a suitable network vs. run in any given
state machine per node. network) does not lie in the same place as the boundary
between parallel and distributed systems (shared memory
In the case of distributed algorithms, computational prob- vs. message passing).
lems are typically related to graphs. Often the graph that
describes the structure of the computer network is the
problem instance. This is illustrated in the following ex- 12.6.3 Complexity measures
ample.
In parallel algorithms, yet another resource in addition
to time and space is the number of computers. Indeed,
12.6.2 An example often there is a trade-off between the running time and
the number of computers: the problem can be solved
Consider the computational problem of finding a color- faster if there are more computers running in parallel
ing of a given graph G. Different fields might take the (see speedup). If a decision problem can be solved in
following approaches: polylogarithmic time by using a polynomial number of
processors, then the problem is said to be in the class
Centralized algorithms NC.[31] The class NC can be defined equally well by using
12.7. COORDINATOR ELECTION 59

the PRAM formalism or Boolean circuits – PRAM ma- • Synchronizers can be used to run synchronous algo-
chines can simulate Boolean circuits efficiently and vice rithms in asynchronous systems.[38]
versa.[32]
• Logical clocks provide a causal happened-before or-
In the analysis of distributed algorithms, more attention
dering of events.[39]
is usually paid on communication operations than compu-
tational steps. Perhaps the simplest model of distributed
• Clock synchronization algorithms provide globally
computing is a synchronous system where all nodes op-
consistent physical time stamps.[40]
erate in a lockstep fashion. During each communication
round, all nodes in parallel (1) receive the latest messages
from their neighbours, (2) perform arbitrary local compu-
tation, and (3) send new messages to their neighbours. In
12.6.5 Properties of distributed systems
such systems, a central complexity measure is the number
of synchronous communication rounds required to com- So far the focus has been on designing a distributed system
plete the task.[33] that solves a given problem. A complementary research
problem is studying the properties of a given distributed
This complexity measure is closely related to the diameter system.
of the network. Let D be the diameter of the network. On
the one hand, any computable problem can be solved triv- The halting problem is an analogous example from the
ially in a synchronous distributed system in approximately field of centralised computation: we are given a computer
2D communication rounds: simply gather all information program and the task is to decide whether it halts or runs
in one location (D rounds), solve the problem, and inform forever. The halting problem is undecidable in the gen-
each node about the solution (D rounds). eral case, and naturally understanding the behaviour of a
computer network is at least as hard as understanding the
On the other hand, if the running time of the algorithm behaviour of one computer.
is much smaller than D communication rounds, then the
nodes in the network must produce their output without However, there are many interesting special cases that are
having the possibility to obtain information about distant decidable. In particular, it is possible to reason about
parts of the network. In other words, the nodes must the behaviour of a network of finite-state machines. One
make globally consistent decisions based on informa- example is telling whether a given network of interact-
tion that is available in their local neighbourhood. Many ing (asynchronous and non-deterministic) finite-state ma-
distributed algorithms are known with the running time chines can[41] reach a deadlock. This problem is PSPACE-
much smaller than D rounds, and understanding which complete, i.e., it is decidable, but it is not likely that
problems can be solved by such algorithms is one of the there is an efficient (centralised, parallel or distributed)
central research questions of the field. [34] algorithm that solves the problem in the case of large net-
works.
Other commonly used measures are the total number of
bits transmitted in the network (cf. communication com-
plexity).
12.7 Coordinator election
12.6.4 Other problems Coordinator election (sometimes called leader elec-
tion) is the process of designating a single process as the
Traditional computational problems take the perspective organizer of some task distributed among several com-
that we ask a question, a computer (or a distributed sys- puters (nodes). Before the task is begun, all network
tem) processes the question for a while, and then pro- nodes are either unaware which node will serve as the
duces an answer and stops. However, there are also prob- “coordinator” (or leader) of the task, or unable to com-
lems where we do not want the system to ever stop. Ex- municate with the current coordinator. After a coordina-
amples of such problems include the dining philosophers tor election algorithm has been run, however, each node
problem and other similar mutual exclusion problems. In throughout the network recognizes a particular, unique
these problems, the distributed system is supposed to con- node as the task coordinator.
tinuously coordinate the use of shared resources so that The network nodes communicate among themselves in
no conflicts or deadlocks occur. order to decide which of them will get into the “coor-
There are also fundamental challenges that are unique to dinator” state. For that, they need some method in or-
distributed computing. The first example is challenges der to break the symmetry among them. For example, if
that are related to fault-tolerance. Examples of related each node has unique and comparable identities, then the
problems include consensus problems,[35] Byzantine fault nodes can compare their identities, and decide that the
tolerance,[36] and self-stabilisation.[37] node with the highest identity is the coordinator.
A lot of research is also focused on understanding the The definition of this problem is often attributed to
asynchronous nature of distributed systems: LeLann, who formalized it as a method to create a new
60 CHAPTER 12. DISTRIBUTED COMPUTING

token in a token ring network in which the token has been Input at the client is committed back to the server
lost. when it represents a permanent change.
Coordinator election algorithms are designed to be eco- • 3-tier architecture: Three tier systems move the
nomical in terms of total bytes transmitted, and time. The client intelligence to a middle tier so that stateless
algorithm suggested by Gallager, Humblet, and Spira [42] clients can be used. This simplifies application de-
for general undirected graphs has had a strong impact on ployment. Most web applications are 3-Tier.
the design of distributed algorithms in general, and won
the Dijkstra Prize for an influential paper in distributed • n-tier architecture: n-tier refers typically to web ap-
computing. plications which further forward their requests to
Many other algorithms were suggested for different kind other enterprise services. This type of applica-
of network graphs, such as undirected rings, unidi- tion is the one most responsible for the success of
rectional rings, complete graphs, grids, directed Euler application servers.
graphs, and others. A general method that decouples the • highly coupled (clustered): refers typically to a clus-
issue of the graph family from the design of the coordina- ter of machines that closely work together, running
tor election algorithm was suggested by Korach, Kutten, a shared process in parallel. The task is subdivided
and Moran.[43] in parts that are made individually by each one and
In order to perform coordination, distributed systems em- then put back together to make the final result.
ploy the concept of coordinators. The coordinator elec-
tion problem is to choose a process from among a group • Peer-to-peer: an architecture where there is no spe-
of processes on different processors in a distributed sys- cial machine or machines that provide a service or
tem to act as the central coordinator. Several central co- manage the network resources. Instead all respon-
ordinator election algorithms exist.[44] sibilities are uniformly divided among all machines,
known as peers. Peers can serve both as clients and
servers.
12.7.1 Bully algorithm • Space based: refers to an infrastructure that creates
the illusion (virtualization) of one single address-
When using the Bully algorithm, any process sends a mes-
space. Data are transparently replicated according
sage to the current coordinator. If there is no response
to application needs. Decoupling in time, space and
within a given time limit, the process tries to elect itself
reference is achieved.
as leader.

Another basic aspect of distributed computing architec-


12.7.2 Chang and Roberts algorithm ture is the method of communicating and coordinating
work among concurrent processes. Through various mes-
The Chang and Roberts algorithm (or “Ring Algorithm”) sage passing protocols, processes may communicate di-
is a ring-based election algorithm used to find a process rectly with one another, typically in a master/slave rela-
with the largest unique identification number . tionship. Alternatively, a “database-centric” architecture
can enable distributed computing to be done without any
form of direct inter-process communication, by utilizing
a shared database.[45]
12.8 Architectures
Various hardware and software architectures are used for
distributed computing. At a lower level, it is necessary
12.9 See also
to interconnect multiple CPUs with some sort of net-
work, regardless of whether that network is printed onto • BOINC
a circuit board or made up of loosely coupled devices • Plan 9 from Bell Labs
and cables. At a higher level, it is necessary to intercon-
nect processes running on those CPUs with some sort of • Inferno
communication system.
• Code mobility
Distributed programming typically falls into one of sev-
eral basic architectures or categories: client–server, 3- • Decentralized computing
tier architecture, n-tier architecture, distributed objects,
loose coupling, or tight coupling. • Distributed algorithmic mechanism design

• Distributed cache
• Client–server: Smart client code contacts the server
for data then formats and displays it to the user. • Distributed operating system
12.10. NOTES 61

• Edsger W. Dijkstra Prize in Distributed Computing [17] Papadimitriou (1994), Chapter 15. Keidar (2008).

• Folding@home [18] See references in Introduction.

• Grid computing [19] Andrews (2000), p. 348.

[20] Andrews (2000), p. 32.


• Jungle computing
[21] Peter (2004), The history of email.
• Layered queueing network
[22] Elmasri & Navathe (2000), Section 24.1.2.
• Library Oriented Architecture - LOA
[23] Ghaemi, Reza; Milani Fard, Amin; Tabatabaee, Hamid;
• List of distributed computing conferences Sadeghizadeh, Mahdi (2008). “Evolutionary Query Op-
timization for Heterogeneous Distributed Database Sys-
• List of distributed computing projects tems”. World Academy of Science, Engineering and Tech-
nology (World Academy of Science, Engineering and
• List of important publications in concurrent, paral-
Technology) (19): 43–49. Retrieved 2013-07-16.
lel, and distributed computing
[24] Andrews (2000), p. 10–11. Ghosh (2007), p. 4–6. Lynch
• Parallel distributed processing (1996), p. xix, 1. Peleg (2000), p. xv. Elmasri & Navathe
(2000), Section 24.
• Parallel programming model
[25] Cormen, Leiserson & Rivest (1990), Section 30.
• Service-Oriented Architecture - SOA
[26] Herlihy & Shavit (2008), Chapters 2-6.
• Volunteer computing
[27] Lynch (1996)

[28] Cormen, Leiserson & Rivest (1990), Sections 28 and 29.


12.10 Notes
[29] Cole & Vishkin (1986). Cormen, Leiserson & Rivest
(1990), Section 30.5.
[1] Coulouris, George; Jean Dollimore; Tim Kindberg; Gor-
don Blair (2011). Distributed Systems: Concepts and De- [30] Andrews (2000), p. ix.
sign (5th Edition). Boston: Addison-Wesley. ISBN 0-
132-14301-1. [31] Arora & Barak (2009), Section 6.7. Papadimitriou
(1994), Section 15.3.
[2] Andrews (2000). Dolev (2000). Ghosh (2007), p. 10.
[32] Papadimitriou (1994), Section 15.2.
[3] Godfrey (2002).
[33] Lynch (1996), p. 17–23.
[4] Andrews (2000), p. 291–292. Dolev (2000), p. 5.
[34] Peleg (2000), Sections 2.3 and 7. Linial (1992). Naor &
[5] Lynch (1996), p. 1. Stockmeyer (1995).

[6] Ghosh (2007), p. 10. [35] Lynch (1996), Sections 5–7. Ghosh (2007), Chapter 13.

[7] Andrews (2000), p. 8–9, 291. Dolev (2000), p. 5. Ghosh [36] Lynch (1996), p. 99–102. Ghosh (2007), p. 192–193.
(2007), p. 3. Lynch (1996), p. xix, 1. Peleg (2000), p.
[37] Dolev (2000). Ghosh (2007), Chapter 17.
xv.
[38] Lynch (1996), Section 16. Peleg (2000), Section 6.
[8] Andrews (2000), p. 291. Ghosh (2007), p. 3. Peleg
(2000), p. 4. [39] Lynch (1996), Section 18. Ghosh (2007), Sections 6.2–
6.3.
[9] Ghosh (2007), p. 3–4. Peleg (2000), p. 1.
[40] Ghosh (2007), Section 6.4.
[10] Ghosh (2007), p. 4. Peleg (2000), p. 2.
[41] Papadimitriou (1994), Section 19.3.
[11] Ghosh (2007), p. 4, 8. Lynch (1996), p. 2–3. Peleg
(2000), p. 4. [42] R. G. Gallager, P. A. Humblet, and P. M. Spira (Jan-
uary 1983). “A Distributed Algorithm for Minimum-
[12] Lynch (1996), p. 2. Peleg (2000), p. 1. Weight Spanning Trees”. ACM Transactions on Pro-
gramming Languages and Systems 5 (1): 66–77.
[13] Ghosh (2007), p. 7. Lynch (1996), p. xix, 2. Peleg
doi:10.1145/357195.357200.
(2000), p. 4.
[43] Ephraim Korach, Shay Kutten, Shlomo Moran (1990).
[14] Ghosh (2007), p. 10. Keidar (2008).
“A Modular Technique for the Design of Efficient Dis-
[15] Lynch (1996), p. xix, 1–2. Peleg (2000), p. 1. tributed Leader Finding Algorithms”. ACM Transactions
on Programming Languages and Systems 12 (1): 84–101.
[16] Peleg (2000), p. 1. doi:10.1145/77606.77610.
62 CHAPTER 12. DISTRIBUTED COMPUTING

[44] Hamilton, Howard. “Distributed Algorithms”. Retrieved • Linial, Nathan (1992), “Locality in distributed
2013-03-03. graph algorithms”, SIAM Journal on Computing 21
(1): 193–201, doi:10.1137/0221015.
[45] Lind P, Alm M (2006), “A database-centric virtual
chemistry system”, J Chem Inf Model 46 (3): 1034–9, • Naor, Moni; Stockmeyer, Larry (1995),
doi:10.1021/ci050360b, PMID 16711722. “What can be computed locally?", SIAM
Journal on Computing 24 (6): 1259–1277,
doi:10.1137/S0097539793254571.
12.11 References
Web sites
Books
• Godfrey, Bill (2002). “A primer on distributed
• Andrews, Gregory R. (2000), Foundations of Mul- computing”.
tithreaded, Parallel, and Distributed Programming, • Peter, Ian (2004). “Ian Peter’s History of the Inter-
Addison–Wesley, ISBN 0-201-35752-6. net”. Retrieved 2009-08-04.
• Arora, Sanjeev; Barak, Boaz (2009), Computational
Complexity – A Modern Approach, Cambridge,
ISBN 978-0-521-42426-4. 12.12 Further reading
• Cormen, Thomas H.; Leiserson, Charles E.; Rivest, Books
Ronald L. (1990), Introduction to Algorithms (1st
ed.), MIT Press, ISBN 0-262-03141-8. • Coulouris, George et al. (2011), Distributed Systems:
Concepts and Design (5th Edition), Addison-Wesley
• Dolev, Shlomi (2000), Self-Stabilization, MIT Press,
ISBN 0-132-14301-1.
ISBN 0-262-04178-2.
• Attiya, Hagit and Welch, Jennifer (2004), Dis-
• Elmasri, Ramez; Navathe, Shamkant B. (2000), tributed Computing: Fundamentals, Simulations, and
Fundamentals of Database Systems (3rd ed.), Advanced Topics, Wiley-Interscience ISBN 0-471-
Addison–Wesley, ISBN 0-201-54263-3. 45324-2.
• Ghosh, Sukumar (2007), Distributed Systems – • Faber, Jim (1998), Java Distributed Computing,
An Algorithmic Approach, Chapman & Hall/CRC, O'Reilly: Java Distributed Computing by Jim Faber,
ISBN 978-1-58488-564-1. 1998
• Lynch, Nancy A. (1996), Distributed Algorithms, • Garg, Vijay K. (2002), Elements of Distributed Com-
Morgan Kaufmann, ISBN 1-55860-348-4. puting, Wiley-IEEE Press ISBN 0-471-03600-5.
• Herlihy, Maurice P.; Shavit, Nir N. (2008), The • Tel, Gerard (1994), Introduction to Distributed Algo-
Art of Multiprocessor Programming, Morgan Kauf- rithms, Cambridge University Press
mann, ISBN 0-12-370591-6.
• Chandy, Mani et al., Parallel Program Design
• Papadimitriou, Christos H. (1994), Computational
Complexity, Addison–Wesley, ISBN 0-201-53082- Articles
1.
• Keidar, Idit; Rajsbaum, Sergio, eds. (2000–2009),
• Peleg, David (2000), Distributed Computing: A
“Distributed computing column”, ACM SIGACT
Locality-Sensitive Approach, SIAM, ISBN 0-89871-
News.
464-8.
• Birrell, A. D.; Levin, R.; Schroeder, M. D.;
Articles Needham, R. M. (April 1982). “Grapevine:
An exercise in distributed computing”.
Communications of the ACM 25 (4): 260–274.
• Cole, Richard; Vishkin, Uzi (1986), “Deterministic
doi:10.1145/358468.358487.
coin tossing with applications to optimal parallel list
ranking”, Information and Control 70 (1): 32–53,
doi:10.1016/S0019-9958(86)80023-7. Conference Papers

• Keidar, Idit (2008), “Distributed computing column • C. Rodríguez, M. Villagra and B. Barán,
32 – The year in review”, ACM SIGACT News 39 (4): Asynchronous team algorithms for Boolean
53–54, doi:10.1145/1466390.1466402. Satisfiability, Bionetics2007, pp. 66–69, 2007.
12.13. EXTERNAL LINKS 63

12.13 External links


• Distributed computing at DMOZ

• Distributed computing journals at DMOZ


Chapter 13

Service-oriented architecture

A service-oriented architecture (SOA) is a design pat- Service-orientation is a way of thinking in


tern in which application components provide services terms of services and service-based develop-
to other components via a communications protocol, ment and the outcomes of services.
typically over a network. The principles of service- A service:
orientation are independent of any vendor, product or
Is a logical representation of a re-
technology.[1]
peatable business activity that has a
A service is a self-contained unit of functionality, such as specified outcome (e.g., check cus-
retrieving an online bank statement.[2] By that definition, tomer credit, provide weather data,
a service is a discretely invocable operation. However, in consolidate drilling reports)
the Web Services Description Language (WSDL), a “ser- Is self-contained
vice” is an interface definition that may list several dis- May be composed of other services
crete services or operations. Elsewhere, the term is used
Is a “black box” to consumers of the
for a component that is encapsulated behind an interface.
service
Services can be combined to provide the functionality of
a large software application.[3] SOA makes it easier for
software components on computers connected over a net- 13.2 Overview
work to cooperate. Every computer can run any number
of services, and each service is built in a way that en-
sures that the service can exchange information with any Services are unassociated, loosely coupled units of func-
other service in the network without human interaction tionality that are self-contained. Each service implements
and without the need to make changes to the underlying at least one action, such as submitting an online applica-
program itself. tion for an account, retrieving an online bank statement
or modifying an online booking or airline ticket order.
Within an SOA, services use defined protocols that de-
scribe how services pass and parse messages using de-
13.1 Definitions scription metadata, which in sufficient details describes
not only the characteristics of these services, but also
The OASIS group[4] and the Open Group[5] have both the data that drives them. Programmers have made ex-
created formal definitions. OASIS defines SOA as: tensive use of XML in SOA to structure data that they
wrap in a nearly exhaustive description-container. Analo-
gously, the Web Services Description Language (WSDL)
A paradigm for organizing and utilizing typically describes the services themselves, while SOAP
distributed capabilities that may be under the (originally Simple Object Access Protocol) describes the
control of different ownership domains. It pro- communications protocols. SOA depends on data and
vides a uniform means to offer, discover, in- services that are described by metadata that should meet
teract with and use capabilities to produce de- the following two criteria:
sired effects consistent with measurable pre-
conditions and expectations. 1. The metadata should be provided in a form that soft-
ware systems can use to configure dynamically by
The Open Group’s definition is: discovery and incorporation of defined services, and
also to maintain coherence and integrity. For exam-
ple, metadata could be used by other applications,
Service-Oriented Architecture (SOA) is like a catalogue, to perform auto discovery of ser-
an architectural style that supports service- vices without modifying the functional contract of a
orientation. service.

64
13.4. DESIGN CONCEPT 65

2. The metadata should be provided in a form that sys- 4. Governance - IT strategy is governed to each hori-
tem designers can understand and manage with a zontal layer to achieve required operating and capa-
reasonable expenditure of cost and effort. bility model.

The purpose of SOA is to allow users to combine together


fairly large chunks of functionality to form ad hoc appli- 13.4 Design concept
cations built almost entirely from existing software ser-
vices. The larger the chunks, the fewer the interfaces re-
quired to implement any given set of functionality; how- SOA is based on the concept of a service. Depending
ever, very large chunks of functionality may not prove on the service design approach taken, each SOA service
sufficiently granular for easy reuse. Each interface brings is designed to perform one or more activities by imple-
with it some amount of processing overhead, so there is menting one or more service operations. As a result, each
a performance consideration in choosing the granularity service is built as a discrete piece of code. This makes it
of services. possible to reuse the code in different ways throughout
the application by changing only the way an individual
SOA as an architecture relies on service-orientation as its service interoperates with other services that make up the
fundamental design principle. If a service presents a sim- application, versus making code changes to the service
ple interface that abstracts away its underlying complex- itself. SOA design principles are used during software
ity, then users can access independent services without development and integration.
knowledge of the service’s platform implementation.[6]
SOA generally provides a way for consumers of ser-
vices, such as web-based applications, to be aware of
available SOA-based services. For example, several dis-
13.3 SOA framework parate departments within a company may develop and
deploy SOA services in different implementation lan-
SOA-based solutions endeavour to enable business ob- guages; their respective clients will benefit from a well-
jectives while building an enterprise-quality system. defined interface to access them.
SOA architecture is viewed as five horizontal layers:[7]
SOA defines how to integrate widely disparate applica-
tions for a Web-based environment and uses multiple im-
1. Consumer Interface Layer - These are GUI for end
plementation platforms. Rather than defining an API,
users or apps accessing apps/service interfaces.
SOA defines the interface in terms of protocols and func-
2. Business Process Layer - These are choreographed tionality. An endpoint is the entry point for such a SOA
services representing business use-cases in terms of implementation.
applications. Service-orientation requires loose coupling of services
3. Services - Services are consolidated together for with operating systems and other technologies that un-
whole enterprise in service inventory. derlie applications. SOA separates functions into distinct
units, or services,[8] which developers make accessible
4. Service Components - The components used to over a network in order to allow users to combine and
build the services, like functional and technical li- reuse them in the production of applications. These ser-
braries, technological interfaces etc. vices and their corresponding consumers communicate
with each other by passing data in a well-defined, shared
5. Operational Systems - This layer contains the data format, or by coordinating an activity between two or
models, enterprise data repository, technological more services.[9]
platforms etc.
For some, SOA can be seen in a continuum from older
concepts of distributed computing[8][10] and modular pro-
There are four cross-cutting vertical layers, each of which
gramming, through SOA, and on to current practices of
are applied to and supported by each of horizontal layers:
mashups, SaaS, and cloud computing (which some see as
the offspring of SOA).[11]
1. Integration Layer - starts with platform integration
(protocols support), data integration, service inte-
gration, application integration, leading to enter-
prise application integration supporting B2B and 13.5 Principles
B2C.
2. Quality of Service - Security, availability, perfor- There are no industry standards relating to the exact
mance etc. constitute the quality of service which composition of a service-oriented architecture, although
are configured based on required SLAs, OLAs. many industry sources have published their own princi-
ples. Some of the principles published[12][13][14][15] in-
3. Informational - provide business information. clude the following:
66 CHAPTER 13. SERVICE-ORIENTED ARCHITECTURE

• Standardized service contract: Services adhere to a 13.5.1 Service architecture


communications agreement, as defined collectively
by one or more service-description documents. This is the physical design of an individual service that en-
compasses all the resources used by a service. This would
• Service loose coupling: Services maintain a relation-
normally include databases, software components, legacy
ship that minimizes dependencies and only requires
systems, identity stores, XML schemas and any backing
that they maintain an awareness of each other.
stores, e.g. shared directories. It is also beneficial to in-
• Service abstraction: Beyond descriptions in the ser- clude any service agents employed by the service, as any
vice contract, services hide logic from the outside change in these service agents would affect the message
world. processing capabilities of the service.

• Service reusability: Logic is divided into services The (standardized service contract) design principle,
with the intention of promoting reuse. keeps service contracts independent from their imple-
mentation. The service contract needs to be documented
• Service autonomy: Services have control over the to formalize the required processing resources by the in-
logic they encapsulate, from a Design-time and a dividual service capabilities. Although it is beneficial
Run-time perspective. to document details about the service architecture, the
service abstraction design principle dictates that any in-
• Service statelessness: Services minimize resource
ternal details about the service are invisible to its con-
consumption by deferring the management of state
sumers so that they do not develop any unstated couplings.
information when necessary[16]
The service architecture serves as a point of reference for
• Service discoverability: Services are supplemented evolving the service or gauging the impact of any change
with communicative meta data by which they can in the service.
be effectively discovered and interpreted.
• Service composability: Services are effective com-
13.5.2 Service composition architecture
position participants, regardless of the size and com-
plexity of the composition.
One of the core characteristics of services developed us-
• Service granularity: A design consideration to pro- ing the service-orientation design paradigm is that they
vide optimal scope and right granular level of the are composition-centric. Services with this characteristic
business functionality in a service operation. can potentially address novel requirements by recompos-
ing the same services in different configurations. Service
• Service normalization: Services are decomposed composition architecture is itself a composition of the in-
and/or consolidated to a level of normal form to dividual architectures of the participating services. In the
minimize redundancy. In some cases, services are light of the Service Abstraction principle, this type of ar-
denormalized for specific purposes, such as perfor- chitecture only documents the service contract and any
mance optimization, access, and aggregation.[17] published service-level agreement (SLA); internal details
• Service optimization: All else being equal, high- of each service are not included.
quality services are generally preferable to low- If a service composition is a part of another (parent) com-
quality ones. position, the parent composition can also be referenced
• Service relevance: Functionality is presented at a in the child service composition. The design of service
granularity recognized by the user as a meaningful composition also includes any alternate paths, such as er-
service. ror conditions, which may introduce new services into the
current service composition.
• Service encapsulation: Many services are consoli-
Service composition is also a key technique in soft-
dated for use under the SOA. Often such services
ware integration, including enterprise software integra-
were not planned to be under SOA.
tion, business process composition and workflow compo-
• Service location transparency: This refers to the abil- sition.
ity of a service consumer to invoke a service regard-
less of its actual location in the network. This also
recognizes the discoverability property (one of the 13.5.3 Service inventory architecture
core principle of SOA) and the right of a consumer
to access the service. Often, the idea of service A service inventory is composed of services that auto-
virtualization also relates to location transparency. mate business processes. It is important to account for the
This is where the consumer simply calls a logical ser- combined processing requirements of all services within
vice while a suitable SOA-enabling runtime infras- the service inventory. Documenting the requirements of
tructure component, commonly a service bus, maps services, independently from the business processes that
this logical service call to a physical service. they automate, helps identify processing bottlenecks. The
13.7. WEB SERVICE PROTOCOLS 67

service inventory architecture is documented from the look-up requests, number of listings or accuracy of
service inventory blueprint, so that service candidates[18] the listings. The Universal Description Discovery
can be redesigned before their implementation. and Integration (UDDI) specification defines a way
to publish and discover information about Web ser-
vices. Other service broker technologies include
13.5.4 Service-oriented enterprise archi- (for example) ebXML (Electronic Business using
tecture eXtensible Markup Language) and those based on
the ISO/IEC 11179 Metadata Registry (MDR) stan-
This umbrella architecture incorporates service, compo- dard.
sition, and inventory architectures, plus any enterprise-
2. Service consumer: The service consumer or web ser-
wide technological resources accessed by these architec-
vice client locates entries in the broker registry using
tures e.g. an ERP system. This can be further supple-
various find operations and then binds to the service
mented by including enterprise-wide standards that apply
provider in order to invoke one of its web services.
to the aforementioned architecture types. Any segments
Whichever service the service-consumers need, they
of the enterprise that are not service-oriented can also be
have to take it into the brokers, bind it with respec-
documented in order to consider transformation require-
tive service and then use it. They can access multiple
ments if a service needs to communicate with the busi-
services if the service provides multiple services.
ness processes automated by such segments.SOA’s main
goal is to deliver agility to business

13.7 Web service protocols


13.6 Web services approach
See also: List of web service protocols
Web services can implement a service-oriented
architecture.[19] They make functional building-blocks Implementers commonly build SOAs using web services
accessible over standard Internet protocols indepen- standards (for example, SOAP) that have gained broad
dent of platforms and programming languages. These industry acceptance after recommendation of Version
services can represent either new applications or just 1.2 from the W3C[20] (World Wide Web Consortium)
wrappers around existing legacy systems to make them in 2003. These standards (also referred to as web ser-
network-enabled. vice specifications) also provide greater interoperability
and some protection from lock-in to proprietary ven-
Each SOA building block can play one or both of two dor software. One can, however, implement SOA using
roles: any service-based technology, such as Jini, CORBA or
REST.
1. Service provider: The service provider creates a
web service and possibly publishes its interface and
access information to the service registry. Each 13.8 Other SOA concepts
provider must decide which services to expose, how
to make trade-offs between security and easy avail-
Architectures can operate independently of specific tech-
ability, how to price the services, or (if no charges
nologies and can therefore be implemented using a wide
apply) how/whether to exploit them for other value.
range of technologies, including:
The provider also has to decide what category the
service should be listed in for a given broker ser-
vice and what sort of trading partner agreements • SOAP, RPC
are required to use the service. It registers what • REST
services are available within it, and lists all the po-
tential service recipients. The implementer of the • DCOM
broker then decides the scope of the broker. Pub-
lic brokers are available through the Internet, while • CORBA
private brokers are only accessible to a limited au- • Web services
dience, for example, users of a company intranet.
Furthermore, the amount of the offered informa- • DDS
tion has to be decided. Some brokers specialize in
many listings. Others offer high levels of trust in • Java RMI
the listed services. Some cover a broad landscape of • WCF (Microsoft’s implementation of web services
services and others focus within an industry. Some now forms a part of WCF)
brokers catalog other brokers. Depending on the
business model, brokers can attempt to maximize • Apache Thrift
68 CHAPTER 13. SERVICE-ORIENTED ARCHITECTURE

• SORCER

Implementations can use one or more of these proto-


cols and, for example, might use a file-system mechanism
to communicate data conforming to a defined interface
specification between processes conforming to the SOA
concept. The key is independent services with defined in-
terfaces that can be called to perform their tasks in a stan-
dard way, without a service having foreknowledge of the
calling application, and without the application having or
needing knowledge of how the service actually performs
its tasks.

Service-Oriented Modeling Framework (SOMF) Version 2.0

both be consumed by a common composite application


(or client). Applications running on either platform can
also consume services running on the other as web ser-
vices that facilitate reuse. Managed environments can
also wrap COBOL legacy systems and present them as
software services. This has extended the useful life of
many core legacy systems indefinitely, no matter what
language they originally used.

Elements of SOA, by Dirk Krafzig, Karl Banke, and Dirk SOA can support integration and consolidation activities
Slama[21] within complex enterprise systems, but SOA does not
specify or provide a methodology or framework for doc-
umenting capabilities or services.
We can distinguish the Service Object-Oriented Ar-
chitecture (SOOA), where service providers are net-
work (call/response) objects accepting remote invoca-
tions, from the Service Protocol Oriented Architecture
(SPOA), where a communication (read/write) protocol
is fixed and known beforehand by the provider and re-
questor. Based on that protocol and a service description
obtained from the service registry, the requestor can bind
to the service provider by creating own proxy used for
remote communication over the fixed protocol. If a ser-
vice provider registers its service description by name, the
requestors have to know the name of the service before-
hand. In SOOA, a proxy—an object implementing the
same service interfaces as its service provider—is regis-
tered with the registries and it is always ready for use by
SOA meta-model, The Linthicum Group, 2007
requestors. Thus, in SOOA, the service provider owns
and publishes the proxy as the active surrogate object with
SOA enables the development of applications that are a codebase annotation, e.g., URLs to the code defining
built by combining loosely coupled and interoperable proxy behavior (Jini ERI). In SPOA, by contrast, a pas-
services.[22] sive service description is registered (e.g., an XML docu-
These services inter-operate based on a formal definition ment in WSDL for Web services, or an interface descrip-
(or contract, e.g., WSDL) that is independent of the un- tion in IDL for CORBA); the requestor then has to gener-
derlying platform and programming language. The inter- ate the proxy (a stub forwarding calls to a provider) based
face definition hides the implementation of the language- on a service description and the fixed communication pro-
specific service. SOA-based systems can therefore func- tocol (e.g., SOAP in Web services, IIOP in CORBA).
tion independently of development technologies and plat- This is referred to as a bind operation. The proxy bind-
forms (such as Java, .NET, etc.). Services written in ing operation is not required in SOOA since the requestor
C# running on .NET platforms and services written in holds the active surrogate object obtained via the registry.
Java running on Java EE platforms, for example, can The surrogate object is already bound to the provider that
13.9. ORGANIZATIONAL BENEFITS 69

registered it with its appropriate network configuration talk to other equipment in the network has taken place.
and its code annotations. Web services, OGSA, RMI, and By formally embracing a SOA approach, such systems
CORBA services cannot change the communication pro- can position themselves to stress the importance of well-
tocol between requestors and providers while the SOOA defined, highly inter-operable interfaces.[27]
approach is protocol neutral.[23] Some have questioned whether SOA simply revives con-
High-level languages such as BPEL and specifications cepts like modular programming (1970s), event-oriented
such as WS-CDL and WS-Coordination extend the ser- design (1980s), or interface/component-based design
vice concept by providing a method of defining and sup- (1990s). SOA promotes the goal of separating users
porting orchestration of fine-grained services into more (consumers) from the service implementations. Services
coarse-grained business services, which architects can in can therefore be run on various distributed platforms and
turn incorporate into workflows and business processes be accessed across networks. This can also maximize
implemented in composite applications or portals.[24] reuse of services.
Service-oriented modeling[8] is a SOA framework that A service comprises a stand-alone unit of functionality
identifies the various disciplines that guide SOA practi- available only via a formally defined interface. Services
tioners to conceptualize, analyze, design, and architect can be some kind of “nano-enterprises” that are easy
their service-oriented assets. The Service-oriented mod- to produce and improve. Also services can be “mega-
eling framework (SOMF) offers a modeling language and corporations” constructed as the coordinated work of
a work structure or “map” depicting the various com- subordinate services.
ponents that contribute to a successful service-oriented A mature rollout of SOA effectively defines the API of
modeling approach. It illustrates the major elements that an organization.
identify the “what to do” aspects of a service develop-
ment scheme. The model enables practitioners to craft a Reasons for treating the implementation of services as
project plan and to identify the milestones of a service- separate projects from larger projects include:
oriented initiative. SOMF also provides a common mod-
eling notation to address alignment between business and 1. Separation promotes the concept to the business that
IT organizations. services can be delivered quickly and independently
from the larger and slower-moving projects common
in the organization. The business starts understand-
ing systems and simplified user interfaces calling on
13.9 Organizational benefits services. This advocates agility. That is to say, it
fosters business innovations and speeds up time-to-
Some enterprise architects believe that SOA can market.[28]
help businesses respond more quickly and more cost-
effectively to changing market conditions.[25] This style 2. Separation promotes the decoupling of services
of architecture promotes reuse at the macro (service) level from consuming projects. This encourages good de-
rather than micro (classes) level. It can also simplify in- sign insofar as the service is designed without know-
terconnection to—and usage of—existing IT (legacy) as- ing who its consumers are.
sets. 3. Documentation and test artifacts of the service are
With SOA, the idea is that an organization can look at not embedded within the detail of the larger project.
a problem holistically. A business has more overall con- This is important when the service needs to be
trol. Theoretically there would not be a mass of devel- reused later.
opers using whatever tool sets might please them. But
rather they would be coding to a standard that is set within An indirect benefit of SOA involves dramatically sim-
the business. They can also develop enterprise-wide SOA plified testing. Services are autonomous, stateless, with
that encapsulates a business-oriented infrastructure. SOA fully documented interfaces, and separate from the cross-
has also been illustrated as a highway system providing cutting concerns of the implementation.
efficiency for car drivers. The point being that if ev- If an organization possesses appropriately defined test
eryone had a car, but there was no highway anywhere, data, then a corresponding stub is built that reacts to the
things would be limited and disorganized, in any attempt test data when a service is being built. A full set of regres-
to get anywhere quickly or efficiently. IBM Vice Pres- sion tests, scripts, data, and responses is also captured for
ident of Web Services Michael Liebow says that SOA the service. The service can be tested as a 'black box'
“builds highways”.[26] using existing stubs corresponding to the services it calls.
In some respects, SOA could be regarded as an archi- Test environments can be constructed where the primitive
tectural evolution rather than as a revolution. It captures and out-of-scope services are stubs, while the remainder
many of the best practices of previous software archi- of the mesh is test deployments of full services. As each
tectures. In communications systems, for example, little interface is fully documented with its own full set of re-
development of solutions that use truly static bindings to gression test documentation, it becomes simple to identify
70 CHAPTER 13. SERVICE-ORIENTED ARCHITECTURE

problems in test services. Testing evolves to merely val- Interoperability becomes an important aspect of SOA im-
idate that the test service operates according to its docu-
plementations. The WS-I organization has developed ba-
mentation, and finds gaps in documentation and test cases sic profile (BP) and basic security profile (BSP) to en-
of all services within the environment. Managing the data force compatibility.[31] WS-I has designed testing tools to
state of idempotent services is the only complexity. help assess whether web services conform to WS-I profile
Examples may prove useful to aid in documenting a ser- guidelines. Additionally, another charter has been estab-
vice to the level where it becomes useful. The documen- lished to work on the Reliable Secure Profile.
tation of some APIs within the Java Community Pro- Significant vendor hype surrounds SOA, which can cre-
cess provide good examples. As these are exhaustive, ate exaggerated expectations. Product stacks continue to
staff would typically use only important subsets. The 'os- evolve as early adopters test the development and run-
sjsa.pdf' file within JSR-89 exemplifies such a file.[29] time products with real-world problems. SOA does not
guarantee reduced IT costs, improved systems agility or
shorter time to market. Successful SOA implementations
may realize some or all of these benefits depending on
13.10 Challenges the quality and relevance of the system architecture and
design.[32][33]
One obvious and common challenge faced involves man- Internal IT delivery organizations routinely initiate SOA
aging services metadata. SOA-based environments can efforts, and some do a poor job of introducing SOA con-
include many services that exchange messages to perform cepts to a business with the result that SOA remains mis-
tasks. Depending on the design, a single application may understood within that business. The adoption of SOA
generate millions of messages. Managing and providing starts to meet IT delivery needs instead of those of the
information on how services interact can become com- business, resulting in an organization with, for example,
plex. This becomes even more complicated when these superlative laptop provisioning services, instead of one
services are delivered by different organizations within that can quickly respond to market opportunities. Busi-
the company or even different companies (partners, sup- ness leadership also frequently becomes convinced that
pliers, etc.). This creates huge trust issues across teams; the organization is executing well on SOA.
hence SOA Governance comes into the picture. One of the most important benefits of SOA is its ease of
Another challenge involves the lack of testing in SOA reuse. Therefore accountability and funding models must
space. There are no sophisticated tools that provide ultimately evolve within the organization. A business unit
testability of all headless services (including message and needs to be encouraged to create services that other units
database services along with web services) in a typical will use. Conversely, units must be encouraged to reuse
architecture. Lack of horizontal trust requires that both services. This requires a few new governance compo-
producers and consumers test services on a continuous nents:
basis. SOA’s main goal is to deliver agility to businesses.
Therefore it is important to invest in a testing framework
(build it or buy it) that would provide the visibility re- • Each business unit creating services must have an
quired to find the culprit in the architecture. Business appropriate support structure in place to deliver on
agility requires SOA services to be controlled by the busi- its service-level obligations, and to support enhanc-
ness goals and directives as defined in the business Moti- ing existing services strictly for the benefit of others.
vation Model (BMM).[30] This is typically quite foreign to business leaders.

Another challenge relates to providing appropriate lev-


• Each business unit consuming services accepts the
els of security. Security models built into an application
apparent risk of reusing services outside their own
may no longer suffice when an application exposes its ca-
control, with the attendant external project depen-
pabilities as services that can be used by other applica-
dencies, etc.
tions. That is, application-managed security is not the
right model for securing services. A number of new tech-
nologies and standards have started to emerge and provide • An innovative funding model is needed as incen-
more appropriate models for security in SOA. tive to drive these behaviors above. Business units
normally pay the IT organization to assist dur-
Finally, the impact of changing a service that touches ing projects and then to operate the environment.
multiple business domains will require a higher level of Corporate incentives should discount these costs
change management governance to service providers and create internal revenue
As SOA and the WS-* specifications practitioners ex- streams from consuming business units to the ser-
pand, update and refine their output, they encounter a vice provider.[34] These streams should be less than
shortage of skilled people to work on SOA-based systems, the costs of a consumer simply building it the old-
including the integration of services and construction of fashioned way. This is where SOA deployments can
services infrastructure. benefit from the SaaS monetization architecture.[35]
13.12. SOA MANIFESTO 71

13.11 Criticisms 13.12 SOA Manifesto


In October 2009, at the 2nd International SOA Sympo-
sium, a mixed group of 17 independent SOA practition-
Some criticisms of SOA depend on conflating SOA with ers and vendors, the “SOA Manifesto Working Group”,
Web services.[36] For example, some critics claim SOA announced the publication of the SOA Manifesto.[43] The
results in the addition of XML layers, introducing XML SOA Manifesto is a set of objectives and guiding princi-
parsing and composition.[37] In the absence of native or ples that aim to provide a clear understanding and vision
binary forms of remote procedure call (RPC), applica- of SOA and service-orientation. Its purpose is rescuing
tions could run more slowly and require more process- the SOA concept from an excessive use of the term by the
ing power, increasing costs. Most implementations do vendor community and “a seemingly endless proliferation
incur these overheads, but SOA can be implemented of misinformation and confusion”.
using technologies (for example, Java Business Integra- The manifesto provides a broad definition of SOA, the
tion (JBI), Windows Communication Foundation (WCF) values it represents for the signatories and some guiding
and data distribution service (DDS)) that do not depend principles. The manifesto prioritizes:
on remote procedure calls or translation through XML.
At the same time, emerging open-source XML parsing
• Business value over technical strategy
technologies (such as VTD-XML) and various XML-
compatible binary formats promise to significantly im- • Strategic goals over project-specific benefits
prove SOA performance.[38][39][40]
• Intrinsic interoperability over custom integration
Stateful services require both the consumer and the
provider to share the same consumer-specific context, • Shared services over specific-purpose implementa-
which is either included in or referenced by messages ex- tions
changed between the provider and the consumer. This
constraint has the drawback that it could reduce the • Flexibility over optimization
overall scalability of the service provider if the service- • Evolutionary refinement over pursuit of initial per-
provider needs to retain the shared context for each con- fection
sumer. It also increases the coupling between a service
provider and a consumer and makes switching service
As of September 2010, the SOA Manifesto had been
providers more difficult.[41] Ultimately, some critics feel
signed by more than 700 signatories and had been trans-
that SOA services are still too constrained by applications
[42] lated to nine languages.
they represent.
Another concern relates to the ongoing evolution of WS-
* standards and products (e. g., transaction, security), 13.13 Extensions
and SOA can thus introduce new risks unless properly
managed and estimated with additional budget and con-
tingency for additional proof-of-concept work. There 13.13.1 SOA, Web 2.0, services over the
has even been an attempt to parody the complexity and messenger, and mashups
sometimes-oversold benefits of SOA, in the form of a
'SOA Facts' site that mimics the 'Chuck Norris Facts’ Web 2.0, a perceived “second generation” of web activ-
meme. ity, primarily features the ability of visitors to contribute
information for collaboration and sharing. Web 2.0 ap-
Some critics regard SOA as merely an obvious evolution
plications often use RESTful web APIs and commonly
of currently well-deployed architectures (open interfaces, feature AJAX based user interfaces, utilizing web syndi-
etc.). cation, blogs, and wikis. While there are no set standards
IT system designs sometimes overlook the desirability for Web 2.0, it is characterized by building on the ex-
of modifying systems readily. Many systems, including isting Web server architecture and using services. Web
SOA-based systems, hard-code the operations, goods and 2.0 can therefore be regarded as displaying some SOA
services of the organization, thus restricting their online characteristics.[44][45][46]
service and business agility in the global marketplace. Some commentators also regard mashups as Web 2.0
The next step in the design process covers the definition applications. The term "business mashups" describes
of a service delivery platform (SDP) and its implemen- web applications that combine content from more than
tation. In the SDP design phase one defines the business one source into an integrated user experience that shares
information models, identity management, products, con- many of the characteristics of service-oriented business
tent, devices, and the end-user service characteristics, as applications (SOBAs). SOBAs are applications com-
well as how agile the system is so that it can deal with the posed of services in a declarative manner. There is on-
evolution of the business and its customers. going debate about “the collision of Web 2.0, mashups,
72 CHAPTER 13. SERVICE-ORIENTED ARCHITECTURE

and SOA,” with some stating that Web 2.0 applica- 13.14 See also
tions are a realization of SOA composite and business
applications.[47] • Architecture of Interoperable Information Systems
• Autonomous decentralized system
• Business-agile enterprise
13.13.2 Web 2.0
• Business-driven development
Tim O'Reilly coined the term “Web 2.0” to de- • Business Intelligence 2.0
scribe a perceived, quickly growing set of web-based
applications.[48] A topic that has experienced extensive • Business-oriented architecture
coverage involves the relationship between Web 2.0 and
• Cloud computing
Service-Oriented Architectures (SOAs).
SOA is the philosophy of encapsulating application logic • Communications-enabled application
in services with a uniformly defined interface and making • Comparison of business integration software
these publicly available via discovery mechanisms. The
notion of complexity-hiding and reuse, but also the con- • Component business model
cept of loosely coupling services has inspired researchers
• Enterprise Mashup Markup Language (EMML)
to elaborate on similarities between the two philoso-
phies, SOA and Web 2.0, and their respective applica- • Enterprise messaging system
tions. Some argue Web 2.0 and SOA have significantly
different elements and thus can not be regarded “paral- • Enterprise service bus
lel philosophies”, whereas others consider the two con- • Event-driven programming
cepts as complementary and regard Web 2.0 as the global
SOA.[45] • HATEOAS (Hypermedia as the Engine of Applica-
tion State)
The philosophies of Web 2.0 and SOA serve different
user needs and thus expose differences with respect to the • iLAND project
design and also the technologies used in real-world appli-
cations. However, as of 2008, use-cases demonstrated • Library Oriented Architecture
the potential of combining technologies and principles of • Message-oriented middleware
both Web 2.0 and SOA.[45]
In an "Internet of Services", all people, machines, and • Microservices
goods will have access via the network infrastructure of • Open ESB
tomorrow. The Internet will thus offer services for all ar-
eas of life and business, such as virtual insurance, online • Platform as a service
banking and music, and so on. Those services will re-
• Resource-oriented architecture
quire a complex services infrastructure including service-
delivery platforms bringing together demand and supply. • Robot as Service
Building blocks for the Internet of Services include SOA,
Web 2.0 and semantics on the technology side; as well as • Search-oriented architecture
novel business models, and approaches to systematic and • Semantic service-oriented architecture
community-based innovation.[49]
• Service layer
Even though Oracle indicates that Gartner is coining a
new term, Gartner analysts indicate that they call this ad- • Service-oriented modeling
vanced SOA and refer to it as “SOA 2.0”.[50] Most of the
major middleware vendors (e. g., Red Hat, webMethods, • Service-oriented architecture implementation
TIBCO Software, IBM, Sun Microsystems, and Oracle) framework
have had some form of SOA 2.0 attributes for years. • Service (systems architecture)
• Service virtualization
• SOA governance
13.13.3 Digital nervous system
• SOALIB
SOA implementations have been described as represent- • SORCER
ing a piece of the larger vision known as the digital ner-
vous system[51][52] or the Zero Latency Enterprise.[53] • Web-oriented architecture
13.15. REFERENCES 73

13.15 References [20] “SOAP Version 1.2 (W3C )" (in Japanese).
W3.org. Retrieved 2012-08-13.
[1] Chapter 1: Service Oriented Architecture (SOA).
[21] Enterprise SOA. Prentice Hall, 2005
Msdn.microsoft.com. Retrieved on 2014-05-30.

[2] “What Is SOA?". opengroup. Retrieved 2013-08-19. [22] Cardoso, Jorge; Sheth, Amit P. (2006). “Foreword”. Se-
mantic Web Services, Processes and Applications. SE-
[3] Velte, Anthony T. (2010). Cloud Computing: A Practical MANTIC WEB AND BEYOND: Computing for Human
Approach. McGraw Hill. ISBN 978-0-07-162694-1. Experience. Foreword by Frank Leymann. Springer. xxi.
ISBN 978-0-387-30239-3. The corresponding architec-
[4] SOA Reference Model definition
tural style is called “service-oriented architecture": fun-
[5] “Service Oriented Architecture : What Is SOA?". open- damentally, it describes how service consumers and ser-
group. vice providers can be decoupled via discovery mecha-
nisms resulting in loosely coupled systems. Implementing
[6] Channabasavaiah, Holley and Tuggle, Migrating to a a service-oriented architecture means to deal with hetero-
service-oriented architecture, IBM DeveloperWorks, 16 geneity and interoperability concerns.
December 2003.
[23] Waldo, Jim (2002). “The Source”. Sum Microsystems.
[7] “SOA Reference Architecture Technical Standard : Basic Retrieved 2013-12-11. |chapter= ignored (help)
Concepts”. opengroup. Retrieved 2014-10-10.
[24] “Service selection and workflow mapping for Grids:
[8] Bell, Michael (2008). “Introduction to Service-Oriented
an approach exploiting quality-of-service information”.
Modeling”. Service-Oriented Modeling: Service Analysis,
Concurrency and Computation: Practice and Expe-
Design, and Architecture. Wiley & Sons. p. 3. ISBN
rience (Wiley) 21 (6): 739–766. 22 July 2008.
978-0-470-14111-3.
doi:10.1002/cpe.1343.
[9] Bell_, Michael (2010). SOA Modeling Patterns for
Service-Oriented Discovery and Analysis. Wiley & Sons. [25] Christopher Koch A New Blueprint For The Enterprise,
p. 390. ISBN 978-0-470-48197-4. CIO Magazine, March 1, 2005

[10] Erl, Thomas. About the Principles. Serviceorientation.org, [26] Elizabeth Millard. “Building a Better Process”. Computer
2005–06 User. January 2005. Page 20.

[11] “Application Platform Strategies Blog: SOA is Dead; [27] Bieberstein et al., Service-Oriented Architecture (SOA)
Long Live Services”. Apsblog.burtongroup.com. 2009- Compass: Business Value, Planning, and Enterprise
01-05. Retrieved 2012-08-13. Roadmap (The developerWorks Series) (Hardcover),
IBM Press books, 2005, 978-0131870024
[12] Yvonne Balzer Improve your SOA project plans, IBM, 16
July 2004 [28] Brayan Zimmerli Business Benefits of SOA, University
of Applied Science of Northwestern Switzerland, School of
[13] Microsoft Windows Communication Foundation team
Business, 11 November 2009
(2012). “Principles of Service Oriented Design”.
msdn.microsoft.com. Retrieved September 3, 2012. [29] https://cds.sun.com/is-bin/INTERSHOP.enfinity/
[14] Principles by Thomas Erl of SOA Systems Inc. eight spe- WFS/CDS-CDS_Developer-Site/en_US/-/USD/
cific service-orientation principles ViewProductDetail-Start?ProductRef=7854-oss_
service_activation-1.0-fr-spec-oth-JSpec@CDS-CDS_
[15] M. Hadi Valipour, Bavar AmirZafari, Kh. Niki Maleki, Developer
Negin Daneshpour, A Brief Survey of Software Architec-
ture Concepts and Service Oriented Architecture, in Pro- [30] “From The Business Motivation Model (BMM) To Ser-
ceedings of 2nd IEEE International Conference on Com- vice Oriented Architecture (SOA)". Jot.fm. Retrieved
puter Science and Information Technology, ICCSIT'09, 2013-06-15.
pp 34-38, Aug 2009, China.
[31] WS-I Basic Profile
[16] Services Oriented Architecture (SOA) - Jargon Buster.
Lansa.com. Retrieved on 2014-05-30. [32] Is There Real Business Value Behind the Hype of SOA?,
Computerworld, June 19, 2006.
[17] Tony Shan, “Building a Service-Oriented eBanking Plat-
form”, scc, pp.237-244, First IEEE International Confer- [33] See also: WS-MetadataExchange OWL-S
ence on Services Computing (SCC'04), 2004
[34] “4CaaSt marketplace: An advanced business environ-
[18] “Service Candidate”. ServiceOrientation.com. Retrieved ment for trading cloud services”. Future Generation
17 October 2014. Computer Systems (Elsevier) 41: 104–120. 2014.
doi:10.1016/j.future.2014.02.020.
[19] E. Oliveros et al. (2012), Web Service Specifications Rele-
vant for Service Oriented Infrastructures, Achieving Real- [35] The Overlapping Worlds of SaaS and SOA
Time in Distributed Computing: From Grids to Clouds,
IGI Global, pp. 174–198, doi:10.4018/978-1-60960- [36] McKendrick, Joe. “Bray: SOA too complex; 'just vendor
827-9.ch010 BS'". ZDNet.
74 CHAPTER 13. SERVICE-ORIENTED ARCHITECTURE

[37] M. Riad, Alaa; E. Hassan, Ahmed; F. Hassan, Qusay • SOA reference architecture from IBM
(2009). “Investigating Performance of XML Web Ser-
vices in Real-Time Business Systems”. Journal of Com- • SOA Practitioners Guide Part 2: SOA Reference
puter Science & Systems Biology 02 (05): 266–271. Architecture
doi:10.4172/jcsb.1000041.
• SOA Practitioners Guide Part 3: Introduction to
[38] Index XML documents with VTD-XML Services Lifecycle
[39] The Performance Woe of Binary XML

[40] Manipulate XML Content the Ximple Way

[41] “The Reason SOA Isn’t Delivering Sustainable Software”.


jpmorgenthal.com. 2009-06-19. Retrieved 2009-06-27.

[42] “SOA services still too constrained by applications they


represent”. zdnet.com. 2009-06-27. Retrieved 2009-06-
27.

[43] SOA Manifesto Official Website Date Accessed: 02 Oc-


tober 2010.

[44] Dion Hinchcliffe Is Web 2.0 The Global SOA?, SOA Web
Services Journal, 28 October 2005

[45] Schroth, Christoph ; Janner, Till; (2007). “Web 2.0 and


SOA: Converging Concepts Enabling the Internet of Ser-
vices”. IT Professional 9 (2007), Nr. 3, pp. 36-41, IEEE
Computer Society. Retrieved 2008-02-23.

[46] Hoyer, Volker ; Stanoesvka-Slabeva, Katarina; Janner,


Till; Schroth, Christoph; (2008). “Enterprise Mashups:
Design Principles towards the Long Tail of User Need”.
Proceedings of the 2008 IEEE International Conference
on Services Computing (SCC 2008). Retrieved 2008-07-
08.

[47] Jason Bloomberg Mashups and SOBAs: Which is the Tail


and Which is the Dog?, Zapthink

[48] “What Is Web 2.0”. Tim O'Reilly. 2005-09-30. Re-


trieved 2008-06-10.

[49] Ruggaber, Rainer; (2007). “Internet of Services—A SAP


Research Vision”. IEEE Computer Society. Retrieved
2008-02-23.

[50] Yefim Natis & Roy Schulte Advanced SOA for Advanced
Enterprise Projects, Gartner, July 13, 2006

[51] “From Web to Boarding Area: Delta’s SOA is Ready”.


Retrieved 2009-05-02.

[52] “The Value of An Enterprise Architecture”. Retrieved


2009-05-02.

[53] “Moving Toward the Zero Latency Enterprise”. Retrieved


2009-05-02.

13.16 External links


• A comparison of SOA standards carried out for
Ministry of Defence (United Kingdom) in 2010

• SOA in the real world - Microsoft Developer net-


work
Chapter 14

Massively multiplayer online game

A massively multiplayer online game (also called computer and video game genres, new acronyms started
MMO and MMOG) is a multiplayer video game which to develop, such as MMORTS. MMOG emerged as a
is capable of supporting large numbers of players simulta- generic term to cover this growing class of games.
neously. By necessity, they are played on the Internet.[1]
The debuts of The Realm Online, Meridian 59 (the
MMOs usually have at least one persistent world, how-
first 3D MMORPG), Ultima Online, Underlight and
ever some games differ. These games can be found for EverQuest in the late 1990s popularized the MMORPG
most network-capable platforms, including the personal
genre. The growth in technology meant that where Nev-
computer, video game console, or smartphones and other erwinter Nights in 1991 had been limited to 50 simul-
mobile devices.
taneous players (a number that grew to 500 by 1995), by
MMOGs can enable players to cooperate and compete the year 2000 a multitude of MMORPGs were each serv-
with each other on a large scale, and sometimes to in- ing thousands of simultaneous players and led the way for
teract meaningfully with people around the world. They games such as World of Warcraft and EVE Online.
include a variety of gameplay types, representing many Despite the genre’s focus on multiplayer gaming, AI-
video game genres. controlled characters are still common. NPCs and mobs
who give out quests or serve as opponents are typical in
MMORPGs. AI-controlled characters are not as com-
14.1 History mon in action-based MMOGs.
The popularity of MMOGs was mostly restricted to
Main article: History of massively multiplayer online the computer game market until the sixth-generation
games consoles, with the launch of Phantasy Star Online on
Dreamcast and the emergence and growth of online ser-
vice Xbox Live. There have been a number of con-
The most popular type of MMOG, and the subgenre sole MMOGs, including EverQuest Online Adventures
that pioneered the category,which was launched in late (PlayStation 2), and the multiconsole Final Fantasy XI.
April 1999, is the massively multiplayer online role- On PCs, the MMOG market has always been dominated
playing game (MMORPG), which descended from uni- by successful fantasy MMORPGs.
versity mainframe computer MUD and adventure games
such as Rogue and Dungeon on the PDP-10. These games MMOGs have only recently begun to break into the mo-
predate the commercial gaming industry and the Internet, bile phone market. The first, Samurai Romanesque set in
but still featured persistent worlds and other elements of feudal Japan, was released in 2001 on NTT DoCoMo's
MMOGs still used today. iMode network in Japan.[3] More recent developments
are CipSoft's TibiaME and Biting Bit’s MicroMonster
The first graphical MMOG, and a major milestone in the which features online and bluetooth multiplayer gaming.
creation of the genre, was the multiplayer flight combat SmartCell Technology is in development of Shadow of
simulation game Air Warrior by Kesmai on the GEnie on- Legend, which will allow gamers to continue their game
line service, which first appeared in 1986. Kesmai later on their mobile device when away from their PC.
added 3D graphics to the game, making it the first 3D
MMO. Science fiction has also been a popular theme, featuring
games such as Mankind, Anarchy Online, Eve Online, Star
Commercial MMORPGs gained acceptance in the late Wars Galaxies and The Matrix Online.
1980s and early 1990s. The genre was pioneered by the
GemStone series on GEnie, also created by Kesmai, and MMOGs emerged from the hard-core gamer community
Neverwinter Nights, the first such game to include graph- to the mainstream strongly in December 2003 with an
ics, which debuted on AOL in 1991.[2] analysis in the Financial Times measuring the value of the
virtual property in the then-largest MMOG, Everquest, to
As video game developers applied MMOG ideas to other

75
76 CHAPTER 14. MASSIVELY MULTIPLAYER ONLINE GAME

result in a per-capita GDP of 2,266 dollars which would commitments not available to everyone. As a result, with-
have placed the virtual world of Everquest as the 77th out external acquisition of virtual currency, some players
wealthiest nation, on par with Croatia, Ecuador, Tunisia are severely limited to being able to experience certain
or Vietnam. aspects of the game.
Happy Farm is the most popular MMOG with 228 million The practice of acquiring large volumes of virtual cur-
active users, and 23 million daily users (daily active users rency for the purpose of selling to other individuals for
logging onto the game with a 24-hour period).[4] tangible and real currency is called gold farming. Many
World of Warcraft is a dominant MMOG in the world players who have poured in all of their personal effort re-
with more than 50% of the subscribing player base,[5] sent that there is this exchange between real and virtual
and with 8-9 million monthly subscribers worldwide. The economies since it devalues their own efforts. As a result,
subscriber base dropped by 1 million after the expan- the term 'gold farmer' now has a very negative connota-
sion Wrath of the Lich King, bringing it to 9 million tion within the games and their communities. This slan-
subscribers,[6] though it remains the most popular West- der has unfortunately also extended itself to racial profil-
ern title among MMOGs. In 2008, Western consumer ing and to in-game and forum insulting.
spending on World of Warcraft represented a 58% share The reaction from many of the game companies varies.
of the subscription MMOG market.[7] The title has gen- In games that are substantially less popular and have a
erated over $2.2 billion in cumulative consumer spending small player base, the enforcement of the elimination of
on subscriptions since 2005.[7] 'gold farming' appears less often. Companies in this situ-
ation most likely are concerned with their personal sales
and subscription revenue over the development of their
14.2 Virtual economies virtual economy, as they most likely have a higher prior-
ity to the games viability via adequate funding. Games
with an enormous player base, and consequently much
Main article: Virtual economy
higher sales and subscription income, can take more dras-
tic actions more often and in much larger volumes. This
Within a majority of the MMOGs created, there is vir- account banning could also serve as an economic gain
tual currency where the player can earn and accumulate for these large games, since it is highly likely that, due
money. The uses for such virtual currency are numerous to demand, these 'gold farming' accounts will be recre-
and vary from game to game. The virtual economies cre- ated with freshly bought copies of the game. In Decem-
ated within MMOGs often blur the lines between real and ber 2007, Jagex Ltd., in a successful effort to reduce real
virtual worlds. The result is often seen as an unwanted world trading levels enough so they could continue using
interaction between the real and virtual economies by the credit cards for subscriptions, introduced highly contro-
players and the provider of the virtual world. This prac- versial changes to its MMOG RuneScape to counter the
tice (economy interaction) is mostly seen in this genre of negative effects gold sellers were having on the game on
games. The two seem to come hand in hand with even the all levels.[8]
earliest MMOGs such as Ultima Online having this kind
The virtual goods revenue from online games and social
of trade, real money for virtual things.
networking exceeded US$7 billion in 2010.[9]
The importance of having a working virtual economy
In 2011, it was estimated that up to 100,000 people in
within an MMOG is increasing as they develop. A sign of
China and Vietnam are playing online games to gather
this is CCP Games hiring the first real-life economist for
gold and other items for sale to Western players.[10]
its MMOG Eve Online to assist and analyze the virtual
economy and production within this game. However single player in MMOs is quite viable, espe-
cially in what is called 'player vs environment' gameplay.
The results of this interaction between the virtual econ-
This may result in the player being unable to experience
omy, and our real economy, which is really the interac-
all content, as many of the most significant and poten-
tion between the company that created the game and the
tially rewarding game experiences are events which re-
third-party companies that want to share in the profits
quire large and coordinated teams to complete.
and success of the game. This battle between companies
is defended on both sides. The company originating the Most MMOGs also share other characteristics that make
game and the intellectual property argue that this is in vi- them different from other multiplayer online games.
olation of the terms and agreements of the game as well MMOGs host a large number of players in a single game
as copyright violation since they own the rights to how world, and all of those players can interact with each
the online currency is distributed and through what chan- other at any given time. Popular MMOGs might have
nels. The case that the third-party companies and their thousands of players online at any given time, usually
customers defend, is that they are selling and exchang- on a company owned servers. Non-MMOGs, such as
ing the time and effort put into the acquisition of the cur- Battlefield 1942 or Half-Life usually have fewer than 50
rency, not the digital information itself. They also express players online (per server) and are usually played on pri-
that the nature of many MMOGs is that they require time vate servers. Also, MMOGs usually do not have any sig-
14.3. GAME TYPES 77

nificant mods since the game must work on company Conductor platform included Fighter Wing, Air Attack,
servers. There is some debate if a high head-count is the Fighter Ace, EverNight, Hasbro Em@ail Games (Clue,
requirement to be an MMOG. Some say that it is the size NASCAR and Soccer), Towers of Fallow, The SARAC
of the game world and its capability to support a large Project, VR1 Crossroads and Rumble in the Void.
number of players that should matter. For example, de- One of the bigger problems with the engines has been
spite technology and content constraints, most MMOGs to handle the vast number of players. Since a typical
can fit up to a few thousand players on a single game server can handle around 10,000–12,000 players, 4000–
server at a time. 5000 active simultaneously, dividing the game into sev-
To support all those players, MMOGs need large-scale eral servers has up until now been the solution. This
game worlds, and servers to connect players to those approach has also helped with technical issues, such as
worlds. Some games have all of their servers connected lag, that many players experience. Another difficulty, es-
so all players are connected in a shared universe. Others pecially relevant to real-time simulation games, is time
have copies of their starting game world put on different synchronization across hundreds or thousands of players.
servers, called “shards”, for a sharded universe. Shards Many games rely on time synchronization to drive their
got their name from Ultima Online, where in the story, physics simulation as well as their scoring and damage
the shards of Mondain’s gem created the duplicate worlds. detection.
Still others will only use one part of the universe at any
time. For example, Tribes (which is not an MMOG)
comes with a number of large maps, which are played
in rotation (one at a time). In contrast, the similar title 14.3 Game types
PlanetSide allows all map-like areas of the game to be
reached via flying, driving, or teleporting.
There are several types of massively multiplayer online
MMORPGs usually have sharded universes, as they pro- games.
vide the most flexible solution to the server load problem,
but not always. For example, the space simulation Eve
Online uses only one large cluster server peaking at over
60,000 simultaneous players. 14.3.1 Role-playing
There are also a few more common differences between
MMOGs and other online games. Most MMOGs charge
the player a monthly or bimonthly fee to have access to
the game’s servers, and therefore to online play. Also, the
game state in an MMOG rarely ever resets. This means
that a level gained by a player today will still be there to-
morrow when the player logs back on. MMOGs often
feature in-game support for clans and guilds. The mem-
bers of a clan or a guild may participate in activities with
one another, or show some symbols of membership to the
clan or guild.

14.2.1 Technical aspect


A group photo of a “Linkshell” guild in the roleplaying game Final
It is challenging to develop the database engines that
Fantasy XI.
are needed to run a successful MMOG with millions of
players.[11] Many developers have created their own, but
attempts have been made to create middleware, software Main article: Massively multiplayer online role-playing
that would help game developers concentrate on their game
games more than technical aspects. One such piece of See also: List of MMORPGs
middleware is called BigWorld.
An early, successful entry into the field was VR-1 Enter- Massively multiplayer online role-playing games, known
tainment whose Conductor platform was adopted and en- as MMORPGs, are the most common type of MMOG.
dorsed by a variety of service providers around the world Some MMORPGs are designed as a multiplayer browser
including Sony Communications Network in Japan; the game in order to reduce infrastructure costs and utilise
Bertelsmann Game Channel in Germany; British Tele- a thin client that most users will already have installed.
com’s Wireplay in England; and DACOM and Samsung The acronym BBMMORPGs has sometimes been used to
SDS in South Korea.[12] Games that were powered by the describe these as browser-based.
78 CHAPTER 14. MASSIVELY MULTIPLAYER ONLINE GAME

Bulletin board role-playing games This allows each player to accurately control multiple ve-
hicles and pedestrians in racing or combat.
A large number of games categorize under MMOBBG,
massively multiplayer online bulletin board game, can
also be called MMOBBRPG. These particular type of 14.3.5 Simulations
games are primarily made up of text and descriptions, al-
though images are often used to enhance the game.

14.3.2 First-person shooter


Main article: Massively multiplayer online first-person
shooter game
See also: List of MMOFPSs

MMOFPS is an online gaming genre which features a


persistent world and a large number of simultaneous play-
ers in a first-person shooter fashion.[13][14] These games
provide large-scale, sometimes team-based combat. The
addition of persistence in the game world means that
these games add elements typically found in RPGs, such World War II Online simulation game showing the numbers of
as experience points. However, MMOFPS games em- players during a special event in June 2008. Some 400 people
phasize player skill more than player statistics, as no num- had spawned in for this gathering in this location in the game.
ber of in-game bonuses will compensate for a player’s in-
ability to aim and think tactically.[15] Some MMOGs have been designed to accurately simu-
late certain aspects of the real world. They tend to be
very specific to industries or activities of very large risk
14.3.3 Real-time strategy and huge potential loss, such as rocket science, airplanes,
trucks, battle tanks, submarines etc. Gradually as simu-
Main article: Massively multiplayer online real-time lation technology is getting more mainstream, so too var-
strategy game ious simulators arrive into more mundane industries.
See also: List of MMORTSs
The initial goal of World War II Online was to create a
map (in north western Europe) that had real world physics
Massively multiplayer online real-time strategy games, (gravity, air/water resistance, etc.), and ability for players
also known as “MMORTS”, combine real-time strategy to have some strategic abilities to its basic FPS/RPG role.
(RTS) with a persistent world. Players often assume the While the current version is not quite a true simulated
role of a general, king, or other type of figurehead lead- world, it is very complex and contains a large persistent
ing an army into battle while maintaining the resources world.
needed for such warfare. The titles are often based in a
The MMOG genre of air traffic simulation is one exam-
sci-fi or fantasy universe and are distinguished from sin-
ple, with networks such as VATSIM and IVAO striving
gle or small-scale multiplayer RTSes by the number of
to provide rigorously authentic flight-simulation environ-
players and common use of a persistent world, generally
ments to players in both pilot and air traffic controller
hosted by the game’s publisher, which continues to evolve
roles. In this category of MMOGs, the objective is to
even when the player is offline.
create duplicates of the real world for people who cannot
or do not wish to undertake those experiences in real life.
For example, flight simulation via an MMOG requires far
14.3.4 Turn-based strategy
less expenditure of time and money, is completely risk-
Steve Jackson Games’ UltraCorps is an example of a free, and is far less restrictive (fewer regulations to adhere
MMO turn-based strategy game.[16] Hundreds of play- to, no medical exams to pass, and so on).
ers share the same playing field of conquest. In a “mega” Another specialist area is mobile telecoms operator (car-
game, each turn fleets are built and launched to expand rier) business where billion-dollar investments in net-
one’s personal empire. Turns are usually time-based, with works are needed but marketshares are won and lost on
a “tick” schedule usually daily. All orders are processed, issues from segmentation to handset subsidies. A spe-
and battles resolved, at the same time during the tick. cialist simulation was developed by Nokia called Equi-
Similarly, in Darkwind: War on Wheels, vehicle driving librium/Arbitrage to have over a two-day period five
and combat orders are submitted simultaneously by all teams of top management of one operator/carrier play
players and a “tick” occurs typically once per 30 seconds. a “wargame” against each other, under extremely realis-
14.3. GAME TYPES 79

tic conditions, with one operator an incumbent fixed and games based entirely on puzzle elements. It is usually set
mobile network operator, another a new entrant mobile in a world where the players can access the puzzles around
operator, a third a fixed-line/internet operator etc. Each the world. Most games that are MMOPGs are hybrids
team is measured by outperforming their rivals by market with other genres. Castle Infinity was the first MMOG
expectations of that type of player. Thus each player has developed for children. Its gameplay falls somewhere be-
drastically different goals, but within the simulation, any tween puzzle and adventure.
one team can win. Also to ensure maximum intensity, There are also massively multiplayer collectible card
only one team can win. Telecoms senior executives who games: Alteil, Astral Masters and Astral Tournament.
have taken the Equilibrium/Arbitrage simulation say it is
Other MMOCCGs might exist (Neopets has some CCG
the most intense, and most useful training they have ever elements) but are not as well known.
experienced. It is typical of business use of simulators,
in very senior management training/retraining. Alternate reality games (ARGs) can be massively mul-
tiplayer, allowing thousands of players worldwide to co-
Other online simulation games include War Thunder, operate in puzzle trails and mystery solving. ARGs take
Motor City Online, The Sims Online, and Jumpgate. place in a unique mixture of online and real-world play
that usually does not involve a persistent world, and are
Sports not necessarily multiplayer, making them different from
MMOGs.
A massively multiplayer online sports game is a title
where players can compete in some of the more tra-
Music/Rhythm
ditional major league sports, such as football (soccer),
basketball, baseball, hockey, golf or American football.
Massively multiplayer online music/rhythm games
According to GameSpot.com, Baseball Mogul Online
(MMORGs), sometimes called massively multiplayer
was “the world’s first massively multiplayer online sports
online dance games (MMODGs), are MMOGs that are
game”.[17] Other titles that qualify as MMOSG have been
also music video games. This idea was influenced by
around since the early 2000s, but only after 2010 did they
Dance Dance Revolution. Audition Online is another
start to receive the endorsements of some of the official
casual massively multiplayer online game and it is
major league associations and players.
produced by T3 Entertainment.
Just Dance 2014 has a game mode called World Dance
Racing Floor, which also structures like a MMORPG.

MMOR means massively multiplayer online racing.


Currently there are only a small number of racing based Social
MMOGs, including Kart Rider, Upshift StrikeRacer, Test
Drive Unlimited, Project Torque, Drift City, The Crew, Massively multiplayer online social games focus on so-
Race or Die (iPhone) and Need for Speed: World. The cialization instead of objective-based gameplay. There
Trackmania series is the world’s largest MMO racing is a great deal of overlap in terminology with “online
game and holds the world record for “Most Players in communities” and "virtual worlds". One example that
a Single Online Race”. Although Darkwind: War on has garnered widespread media attention is Linden Lab’s
Wheels is more combat based than racing, it is also con- Second Life, emphasizing socializing, world-building and
sidered an MMOR. an in-world virtual economy that depends on the sale
and purchase of user-created content. It is technically
an MMOSG or Casual Multiplayer Online (CMO) by
14.3.6 Casual definition, though its stated goal was to realize the con-
cept of the Metaverse from Neal Stephenson's novel Snow
Many types of MMO games can be classified as casual, Crash. Instead of being based around combat, one could
because they are designed to appeal to all computer users say that it was based around the creation of virtual ob-
(as opposed to subgroup of frequent game buyers), or jects, including models and scripts. In practice, it has
to fans of another game genre (such as collectible card more in common with Club Caribe than Everquest. It
games). Such games are easy to learn and require a was the first MMO of its kind to achieve widespread suc-
smaller time commitment than other game types. One cess (including attention from mainstream media); how-
example is Racing Frogs, an MMOG that can be played ever, it was not the first (as Club Caribe was released in
with only a small amount of time every day. Other popu- 1988). Competitors in this subgenre (non-combat-based
lar casual games include simple management games such MMORPG) include Active Worlds, There, SmallWorlds,
as The Sims Online, Monopoly City Streets, Virtonomics, Furcadia, Whirled and IMVU.
or Kung Fu Panda World. Many browser based Casual MMOs have begun to spring
MMOPGs, or massively multiplayer puzzle games, are up. This has been made easier because of maturing
80 CHAPTER 14. MASSIVELY MULTIPLAYER ONLINE GAME

of Adobe Flash and the popularity of Club Penguin, than a bonding one, similar to a “third place”. Therefore,
Growtopia, and The Sims Online. MMOs have the capacity and the ability to serve as a com-
munity that effectively socializes users just like a coffee
shop or pub, but conveniently in the comfort of their own
14.4 Research home.[21]

Some recent attempts to build peer-to-peer (P2P)


MMOGs have been made. Outback Online may be the 14.5 Spending
first commercial one,[18] however, so far most of the ef-
forts have been academic studies.[19] A P2P MMOG may British online gamers are outspending their German and
potentially be more scalable and cheaper to build, but no- French counterparts according to a recently released
table issues with P2P MMOGs include security and con- study commissioned by Gamesindustry.com and TNS.
sistency control, which can be difficult to address given The UK MMO-market is now worth £195 million in 2009
that clients are easily hacked. Some MMOGs such as compared to the £165 million and £145 million spent by
Vindictus use P2P networking and client-server network- German and French online gamers.[22]
ing together.
The US gamers spend more, however, spending about
In April 2004, the United States Army announced that $3.8 billion overall on MMO games. $1.8 billion of that
it was developing a massively multiplayer training sim- money is spent on monthly subscription fees. The money
ulation called AWE (asymmetric warfare environment). spent averages out to $15.10 between both subscription
The purpose of AWE is to train soldiers for urban warfare and free-to-play MMO gamers. The study also found that
and there are no plans for a public commercial release. 46% of 46 million players in the US pay real money to
Forterra Systems is developing it for the Army based on play MMO games.[23]
the There engine.[20]
Today’s Gamers MMO Focus Report, published in March
In 2010, Bonnie Nardi published an ethnographic study 2010, was commissioned by TNS and gamesindus-
on World of Warcraft examined with Lev Vygotsky's try.com. A similar study for the UK market-only (UK Na-
activity theory. tional Gamers Survey Report)[24] was released in February
As the field of MMOs grows larger each year, research 2010 by the same groups.
has also begun to investigate the socio-informatic bind
the games create for their users. In 2006, researchers
Constance A. Steinkuehler and Dmitri Williams initiated 14.6 See also
research on such topics. The topic most intriguing to the
pair was to further understand the gameplay, as well as the • List of massively multiplayer online games
virtual world serving as a social meeting place, of popular
MMOs. • Multiplayer online game
To further explore the effects of social capital and so- • Online game
cial relationships on MMOs, Steinkuehler and Williams
combined conclusions from two different MMO research • Social network game
projects: sociocultural perspective on culture and cogni-
tion, and the other on media effects of MMOs. The con- • Virtual world
clusions of the two studies explained how MMOs function
as a new form of a “third place” for informal social inter-
actions much like coffee shops, pubs, and other typical 14.7 References
hangouts. Many scholars, however, such as Oldenburg
(1999), refute the idea of a MMOs serving as a “third [1] What is Massively Multiplayer Online Game (MMOG)? -
place” due to inadequate bridging social capital. His ar- Definition from. Techopedia. Retrieved on 2014-05-25.
gument is challenged by Putnam (2000) who concluded
that MMOs are well suited for the formation of bridging [2] “The Oldest MMORPGs in Gaming History”. Retrieved
social capital, tentative relationships that lack in depth, 2015-03-09.
because it is inclusive and serves as a sociological lubri-
[3] Krikke, J. (2003). “Samurai Romanesque, J2ME,
cant that is shown across the data collected in both of the and the battle for mobile cyberspace”. IEEE
research studies.[21] Computer Graphics and Applications 23: 16–00.
MMOs can also move past the “lubricant” stage and into doi:10.1109/MCG.2003.1159608.
the “superglue” stage known as bonding social capital, a
[4] " : " " - ".
closer relationship that is characterized by stronger con- Game.dayoo.com. Retrieved 2013-08-28.
nections and emotional support. The study concludes
that MMOs function best as a bridging mechanism rather [5] Mmogchart.com
14.8. EXTERNAL LINKS 81

[6] “Blizzard Entertainment:Press Releases”. 14.8 External links


Us.blizzard.com. 2010-10-07. Retrieved 2013-08-
28. • Massive Multiplayer Online at DMOZ
[7] Hardy-Rolls, Piers (2009). Subscription MMOGs: Life Be-
yond World of Warcraft (PDF). Lyndon, UK: Screen Di-
gest. Retrieved 30 March 2009.

[8] Runescape.com

[9] Kevin Kwang (12 July 2011). “Online games, social net-
works drive virtual goods”. ZDNet. Retrieved 27 Novem-
ber 2014.

[10] “Virtual sales provide aid to poorer nations”. BBC. 8 April


2011. Retrieved 27 November 2014.

[11] Building a simple yet powerful MMO game architecture,


Part 1: Introduction. Ibm.com (2008-09-08). Retrieved
on 2014-05-25.

[12] “VR-1 Conductor Technology Suite Endorsed by Leadin-


gOnline Service Providers. | Consumer Products > Com-
puting Products from”. AllBusiness.com. 28 April 1998.
Retrieved 16 March 2009.

[13] “IGN: The Worlds First MMOFPS is nearly complete”.


Uk.games.ign.com. Retrieved 16 March 2009.

[14] Thierry 'Scooter' Nguyen (20 March 2007). “GameSpy:


Huxley Preview”. GameSpy. Retrieved 16 March 2009.

[15] Leon Ryan (May 2007). Beyond the Looking Glass of


MMOG’s. GameAxis Unwired. pp. 27–31. Retrieved
15 March 2009.

[16] “UltraCorps is recommended to anyone interested in a


simplistic, slow-paced sci-fi strategy game.”

[17] “Baseball Mogul Online: The World’s First MMOSG”.


gamespot.com. Retrieved 23 July 2001.

[18] “Yoicks! It’s another virtual world - BizTech - Technol-


ogy”. theage.com.au. 26 February 2007. Retrieved 16
March 2009.

[19] “VAST - Related Work”. Vast.sourceforge.net. 26


November 2008. Retrieved 16 March 2009.

[20] Gonzalez, Lauren (17 January 2008). “Spot On: The


US Army’s There-based simulation - News at GameSpot”.
Gamespot.com. Retrieved 16 March 2009.

[21] Steinkuehler, C. A. and Williams, D. (2006), Where Ev-


erybody Knows Your (Screen) Name: Online Games
as “Third Places”. Journal of Computer-Mediated
Communication, 11: 885–909. doi: 10.1111/j.1083-
6101.2006.00300.x

[22] “MMO Big in Britain But US Still No 1”. Agen-


cynews.net. 20 October 2003.

[23] US Gamers spent $3.8 billion on MMO Gaming in 2009.


“US Gamers spent $3.8 billion on MMO Gaming in 2009
- MMO Hut”. Mmohuts.com. Retrieved 2013-08-28.

[24] “Millions Spent on Casual Gaming”. BBC UK.


10.02.2010. Check date values in: |date= (help)
82 CHAPTER 14. MASSIVELY MULTIPLAYER ONLINE GAME

14.9 Text and image sources, contributors, and licenses


14.9.1 Text
• Multiprocessing Source: http://en.wikipedia.org/wiki/Multiprocessing?oldid=650855157 Contributors: Szopen, The Anome, Andre
Engels, Aldie, Maury Markowitz, Edward, Wapcaplet, Dori, Ahoerstemeier, Ronz, Wernher, Raul654, Chuunen Baka, AlexPlank,
Iain.mcclatchie, DavidCary, AlistairMcMillan, Pgan002, Phe, Dyl, CanisRufus, R. S. Shaw, Guy Harris, Derbeth, FlaBot, BMF81,
Chobot, Mortenoesterlundjoergensen, Borgx, Hairy Dude, Tony1, Rwwww, SmackBot, Hydrogen Iodide, Henriok, Agateller, Paxswill,
Cfallin, Allan McInnes, Nakon, VegaDark, Zac67, Harryboyles, Euchiasmus, Jurohi, Quaeler, Beno1000, Deice, Nczempin, Xaariz,
Kubanczyk, James086, Towopedia, Dgies, TexMurphy, JAnDbot, Arch dude, Hexdump, David Eppstein, GermanX, R'n'B, VolkovBot,
Umar420e, VasilievVV, Slserpent, Chickyfuzz14, SieBot, Gorptree, ClueBot, Rilak, Excirial, Goodone121, PixelBot, HumphreyW, Asaf-
shelly, Чръный человек, G7a, Addbot, Leikfaz, Download, Jasper Deng, Luckas-bot, Amirobot, Goldenthree, MulticoreNerd, Peter Flass,
AnomieBOT, HughesJohn, Xqbot, Julle, Miym, Cyfraw, Glenn Maddox, EmausBot, WikitanvirBot, Ferry24.Milan, Topeil, MaGa, Heyjoy,
Cswierkowski, ClueBot NG, Satellizer, ‫بهاء حجازي‬, Dipankan001, Mrt3366, Tagremover, Someone not using his real name, Sagarsurani
and Anonymous: 96
• Computer multitasking Source: http://en.wikipedia.org/wiki/Computer%20multitasking?oldid=650586294 Contributors: Damian Yer-
rick, Bryan Derksen, The Anome, Ap, Rjstott, Dachshund, Pit, Rp, Theanthrope, Ahoerstemeier, Salsa Shark, Magnus.de, Jessel, Tp-
bradbury, Wernher, Robbot, Tobias Bergemann, Jyril, Lupin, Peruvianllama, AJim, AlistairMcMillan, Nayuki, Edcolins, Wmahan, Tip-
iac, Starblue, Stephan Leclercq, Zhuuu, Beland, QuiTeVexat, Simson, Burschik, Ulmanor, Abdull, Mormegil, CALR, Rich Farmbrough,
Florian Blaschke, Djce, Dmeranda, Bender235, Lou Crazy, CanisRufus, Drhex, Bobo192, R. S. Shaw, Csabo, Wtshymanski, H2g2bob,
Mikenolte, Nuno Tavares, Gimboid13, Palica, Pabix, Guinness2702, Bhadani, GeorgeBills, FlaBot, Chris Purcell, RexNL, YurikBot,
Wavelength, DMahalko, Piet Delport, Zimbricchio, CarlHewitt, Dianne Hackborn, Misza13, DeadEyeArrow, PS2pcGAMER, JakkoW-
esterbeke, Ketsuekigata, Drable, Thomas Blomberg, GrinBot, SmackBot, Reedy, Ixtli, Sparking Spirit, Andy M. Wang, Stevage, Nbarth,
Rrelf, Tsca.bot, AntiVan, Zvar, Jsavit, Radagast83, FormerUser1, Esb, Ozhiker, Harryboyles, BlindWanderer, Loadmaster, Dicklyon,
EdC, Peyre, Iridescent, Tawkerbot2, FatalError, Unixguy, Ale jrb, Phatom87, Xaariz, Kubanczyk, Wikid77, Marek69, AntiVandalBot,
Ad88110, Alphachimpbot, JAnDbot, MER-C, Arch dude, Magioladitis, JNW, Faizhaider, Web-Crawling Stickler, Glen, Manticore,
Maurice Carbonaro, Public Menace, Jesant13, Silas S. Brown, Cometstyles, Jcea, VolkovBot, Mazarin07, HiDrNick, Toyalla, SieBot,
RucasHost, Theaveng, Yerpo, Ixe013, Nskillen, Frappucino, Anchor Link Bot, Mhouston, ClueBot, Ndenison, M4gnum0n, PixelBot,
Estirabot, Sun Creator, Oliverbell99, Fiskegalen92, Andy16666, DumZiBoT, Joel Saks, Kwjbot, Dsimic, Arkantospurple, Deineka, Ak-
shatdabralit, Cst17, CarsracBot, Lightbot, ‫דוד שי‬, Gail, Zorrobot, John.St, Legobot, Luckas-bot, ArchonMagnus, Peter Flass, AnomieBOT,
TwistedText, Materialscientist, GB fan, Xqbot, Julle, Almabot, 399man, RibotBOT, Alan.A.Mick, Rat2, D'ohBot, Mfwitten, Atlantia,
EmausBot, WikitanvirBot, Dewritech, Tolly4bolly, L Kensington, ChuispastonBot, 28bot, ClueBot NG, Scicluna93, Toastyking, Meso-
derm, ScottSteiner, Theopolisme, Compilation finished successfully, Jimperio, GGShinobi, Venera Seyranyan, ANI MARTIROSYAN,
Shaun, BattyBot, FizzixNerd, Wrmattison, Mogism, Jamesx12345, Sriharsh1234, Vcfahrenbruck, OMPIRE, Benjamintf1, 7stone7, Ayan-
Mazumdar91 and Anonymous: 192
• Symmetric multiprocessing Source: http://en.wikipedia.org/wiki/Symmetric%20multiprocessing?oldid=652732259 Contributors: The
Anome, Maury Markowitz, Edward, Alfio, Ronz, Zoicon5, Maximus Rex, Furrykef, Pakaran, AnthonyQBachler, Robbot, RedWolf,
Chris Roy, Rdash, AlistairMcMillan, Jabowery, Neilc, Beland, Vina, Yggdræsil, Deleting Unnecessary Words, Tietew, Bjacob, Qiq,
Urhixidur, Twajn, EagleOne, Pavel Vozenilek, Dyl, CanisRufus, Spearhead, Matt Britt, Ricsi, Bad Byte, Homerjay, Cncxbox, Pearle,
Poweroid, Guy Harris, 119, Rcbarnes, Hns, Wikicaz, Inarius, Nuno Tavares, SKopp, Fred J, Mr Bill, Smithfarm, Hathawayc, FlaBot,
Margosbot, Pathoschild, Ewlyahoocom, BMF81, Butros, Anrie Nord, RobotE, Splash, Gardar Rurak, Hymyly, Aaron Brenneman,
Qviri, Amwebb, Richard Russell, Cffrost, JLaTondre, Rwwww, Plouiche, Jsnx, SmackBot, Henriok, Yuyudevil, Brianski, Chris the
speller, Artoftransformation, Bluebot, Ctrlfreak13, Stephanvaningen, Thumperward, BBCWatcher, Krallja, Tsca.bot, Solarix, Jon-
Harder, Easwarno1, Soosed, Wybot, Vertigo Acid, Autopilot, Harryboyles, Aqualize, Joffeloff, Bjankuloski06en, Jec, DagErlingSmør-
grav, Quaeler, CRGreathouse, Raysonho, Mr Echo, Evilgohan2, Myasuda, Cydebot, Dr unix, GSTQ21C, Kubanczyk, Fatfool, Jayr-
vox, Hcobb, NocNokNeo, Dgies, Stannered, JAnDbot, Arch dude, Jtrob704, Magioladitis, Realg187, Iam8up, Allstarecho, Vinograd19,
R'n'B, Szeder, Daniel.robert.franklin, Khazadum, Alainkaa, ParallelWolverine, AlleborgoBot, EwokiWiki, Gerakibot, Edans.sandes, Jer-
ryobject, MarkMLl, Kntkadosh, Garysixpack, Brian Geppert, Martarius, Rilak, JWA74, Elizium23, Wwskier, DumZiBoT, JRWood-
wardMSW, Jabberwoch, Addbot, Ghettoblaster, Tothwolf, John Sauter, Тиверополник, Victor.gattegno, Yobot, SabbaZ, Goldenthree,
AnomieBOT, Rubinbot, LilHelpa, Xqbot, DataWraith, DSisyphBot, LAMurakami, RibotBOT, W Nowicki, Xcvista, Rocketshiporion,
Jesse V., Slon02, WikitanvirBot, Ecapoccia, Ferry24.Milan, Ipsign, Kalpase, Eemars, Rezabot, MerlIwBot, Wbm1058, BattyBot, Har-
nisch 54667, Npx122sy, Raulizahi and Anonymous: 181
• Asymmetric multiprocessing Source: http://en.wikipedia.org/wiki/Asymmetric%20multiprocessing?oldid=601204820 Contributors: Si-
monP, Delirium, Joy, Giftlite, EagleOne, Sdwood, Sietse Snel, Giraffedata, Guy Harris, Atlant, Firsfron, Woohookitty, Tabletop, Rjwilmsi,
Mbutts, Martin Hinks, YurikBot, SmackBot, Arny, Chris the speller, JennyRad, Nixeagle, Thegathering, CapitalR, CRGreathouse, Ar-
renlex, Cydebot, Xaariz, Thijs!bot, Widefox, RainbowCrane, Sir Link, Cocytus, R'n'B, Player 03, DancesWithPeons, Milan Keršláger,
Azimout, MarkMLl, Huku-chan, Rilak, Чръный человек, Skarebo, TheMoMonez, G7a, Addbot, Mephiston999, John Sauter, Yobot,
AnomieBOT, Pontificalibus, Chatul, Skyerise, Pierre5018, OnePt618, Tech.kyle, MerlIwBot, Helpful Pixie Bot, ‫بهاء حجازي‬, Bvidulich
and Anonymous: 43
• Non-uniform memory access Source: http://en.wikipedia.org/wiki/Non-uniform%20memory%20access?oldid=641981689 Contribu-
tors: AxelBoldt, The Anome, Maury Markowitz, Hfastedge, (, Mulad, Emperorbma, Jharrell, Pedant17, RedWolf, Iain.mcclatchie, Rchan-
dra, Isidore, Beland, MJA, Togo, Bjacob, Hellisp, NegativeK, Plugwash, CanisRufus, Pion, Suruena, SteinbDJ, Kinema, Kglavin, RadioAc-
tive, BenjaminHare, Margosbot, Ewlyahoocom, Jagjag, YurikBot, RussBot, Gardar Rurak, Moop2000, Długosz, Ravedave, Lkcl, Entheta,
SmackBot, Gilliam, Thumperward, Letdorf, BBCWatcher, JonHarder, Fuhghettaboutit, Luís Felipe Braga, Cdills, Pawlex, Benjy613,
Raysonho, CCFreak2K, Cydebot, Dr unix, Thijs!bot, Xycaleth, Arch dude, PhilKnight, .anacondabot, Raanoo, KenSharp, Bigfoot00,
Thad McCotter, Ken g6, Sander van Malssen, GL1zdA, Khazadum, Pleeplee, BotMultichill, VVVBot, Jerryobject, Lightmouse, COBot,
Trustable, Tanvir Ahmmed, Rilak, Arjayay, Dsimic, Addbot, Ramu50, Luckas-bot, Yobot, Vincnet, Amirobot, Zadneram, Winterst, Jone-
sey95, MastiBot, FoxBot, DixonDBot, EmausBot, WikitanvirBot, Wikipelli, Jan Traspe, Zalnas, Ferry24.Milan, Etorus, KentOlsen, Se-
cureDBA, ChrisGualtieri, Electricmuffin11, Becker553, JailaBailaBoo, Psantimauro, K0zka and Anonymous: 73
• Multi-core processor Source: http://en.wikipedia.org/wiki/Multi-core%20processor?oldid=654003153 Contributors: Edward, Mahjongg,
Nixdorf, Ixfd64, 7265, CesarB, Ronz, Julesd, Charles Matthews, Dragons flight, Furrykef, Bevo, Mazin07, Jakohn, Donreed, Altenmann,
14.9. TEXT AND IMAGE SOURCES, CONTRIBUTORS, AND LICENSES 83

Nurg, Auric, Bkell, Ancheta Wis, Centrx, Giftlite, DavidCary, Gracefool, Solipsist, Falcon Kirtaran, Kiteinthewind, Ludootje, Cynical, Qiq,
Ukexpat, GreenReaper, Alkivar, Real NC, MattKingston, Monkeyman, Reinthal, Archer3, Rich Farmbrough, Florian Blaschke, Sapox,
SECProto, Berkut, Dyl, Bender235, Narcisse, RoyBoy, Dennis Brown, Neilrieck, WhiteTimberwolf, Bobo192, Fir0002, SnowRaptor,
Matt Britt, Hectoruk, Gary, Liao, Polarscribe, Guy Harris, Hoary, Evil Prince, Lerdsuwa, Bsadowski1, Gene Nygaard, Marasmusine, Si-
metrical, Woohookitty, Henrik, Mindmatrix, Aaron McDaid, Splintax, Pol098, Vossanova, Qwertyus, Haikupoet, JIP, Ketiltrout, SMC,
Smithfarm, CQJ, Bubba73, Yamamoto Ichiro, Skizatch, Ian Pitchford, Master Thief Garrett, Crazycomputers, Superchad, Dbader, Da-
Gizza, SirGrant, Hairy Dude, TheDoober, Epolk, Stephenb, Rsrikanth05, NawlinWiki, VetteDude, Thiseye, Rbarreira, Anetode, DGJM,
Falcon9x5, Addps4cat, Closedmouth, Fram, Andyluciano, JLaTondre, Carlosguitar, Mark hermeling, SmackBot, Mmernex, Stux, Hen-
riok, JPH-FM, Jagged 85, Powo, Pinpoint23, Thumperward, Swanner, Hibernian, JagSeal, E946, Shalom Yechiel, Frap, KaiserbBot,
AcidPenguin9873, JonHarder, Kcordina, Aldaron, Fuhghettaboutit, Letowskie, DWM, Natamas, Kellyprice, Fitzhugh, Sonic Hog, A5b,
Homo sapiens, Lambiam, Kyle wood, JzG, Pgk1, Littleman TAMU, Ulner, WhartoX, Disavian, Danorux, Soumyasch, Joffeloff, Gorgalore,
Guy2007, Fernando S. Aldado, 16@r, JHunterJ, NJA, Peyre, Vincecate, Hu12, Quaeler, Iridescent, Pvsuresh, Tawkerbot2, CmdrObot,
Plasticboob, CBM, Nczempin, Jesse Viviano, Michaelbarreto, Shandris, Evilgohan2, Neelix, Babylonfive, ScorpSt, Cydebot, Myscrnnm,
Steinj, Drtechmaster, Kozuch, Thijs!bot, Hervegirod, Mwastrod, Bahnpirat, Squater, Dawnseeker2000, Sherbrooke, AlefZet, AntiVandal-
Bot, Widefox, Seaphoto, Shalewagner, DarthShrine, Chaitanya.lala, Leuko, Od1n, Gamer2325, Arch dude, IanOsgood, Stylemaster, Avi-
adbd, Geniac, Coffee2theorems, Ramurf, Vintei, JamesBWatson, CattleGirl, CountingPine, Midgrid, EagleFan, David Eppstein, DerHexer,
Gimpy530, Gwern, Gjd001, Oren0, Bdsatish, Red66, Ehoogerhuis, Sigmajove, Felipe1982, J.delanoy, Jspiegler, GuitarFreak, NerdyNSK,
Techedgeezine, Acalamari, Barts1a, Thucydides411, EMG Blue, Chrisforster, Mikael Häggström, Hubbabridge, LA Songs, SlightlyMad,
Haoao, Remi0o, 28bytes, Monkeyegg, Imperator3733, Smkoehl, Gwib, Klower, Taurius, HuskyHuskie, ITMADOG, Haseo9999, Cmbay,
Nono1234, ParallelWolverine, Mike4ty4, JasonTWL, Vjardin, Winchelsea, Rockstone35, Caltas, Jerryobject, Flyer22, FSHL, Rogergum-
mer, Lord British, Rupert baines, Ddxc, Ttrevers, Noelhurley, Radical.bison, WikipedianMarlith, ClueBot, Binksternet, GorillaWarfare,
Starkiller88, Rilak, Czarkoff, Taroaldo, Wikicat, LizardJr8, Cirt, DragonBot, Drewster1829, Goodone121, Karlhendrikse, Coralmizu,
Alejandrocaro35, Time2zone, Jeffmeisel, Msrill, Versus22, Un Piton, DumZiBoT, Чръный человек, Parallelized, Zodon, Airplaneman,
Dsimic, Thebestofall007, Addbot, Proofreader77, Hcucu, Scientus, CanadianLinuxUser, MrOllie, LaaknorBot, Markuswiki, Jasper Deng,
IOLJeff, Imirman, Tide rolls, Jarble, Ettrig, Legobot, Yobot, SabbaZ, TaBOT-zerem, Jack Boyce, Goldenthree, Danperryy, SwisterTwister,
Mdegive, AnomieBOT, Enisbayramoglu, VanishedUser sdu9aya9fasdsopa, Jim1138, Piano non troppo, DaveRunner, GFauvel, Flewis, Ma-
terialscientist, RobertEves92, Threadman, Gnumer, Joshxyz, MacintoshWriter, LilHelpa, TheAMmollusc, Miym, Abce2, Bikeman333,
Barfolomio, Adavis444, Gordonrox24, Elemesh, Gastonhillar, Prari, Hemant wikikosh, FrescoBot, Picklecolor2, StaticVision, RaulMe-
tumtam, MBbjv, Winterst, Elockid, UkillaJJ, Skyerise, Meaghan, FoxBot, Sulomania, Ellwd, Glenn Maddox, Gal872875, Sreven.Nevets,
NagabhushanReddy, Gg7777, Jesse V., DARTH SIDIOUS 2, Truthordaretoblockme, Beyond My Ken, WildBot, Virtimo, Helwr, Emaus-
Bot, Az29, Keithathaide, Super48paul, P3+J3^u!, Tommy2010, Serketan, Erpert, Alpha Quadrant (alt), NGPriest, Bmmxc damo, Steed-
horse, L Kensington, Donner60, Jsanthara, DASHBotAV, Rmashhadi, Cswierkowski, ClueBot NG, Jeff Song, Gilderien, Chharper1, Brain-
cricket, Widr, MerlIwBot, Nodulation, OpenSystemsPublishing, Minadasa, Cdog44, Hz.tiang, Charlie6WIND, WinampLlama, Op47, Tre-
vayne08, Harizotoh9, Nolansdad95120, Glacialfox, Simonriley, DigitalMediaSage, Sha-256, Michael Anon, Snippy the heavily-templated
snail, NimbusNiner, DavidLeighEllis, Koza1983, Christian CHABRERIE, Geoyo, Aniru919, Lagoset, Sofia Koutsouveli, RoninDusette,
Kyle1009, ComsciStudent, DorothyGAlvarez and Anonymous: 643
• Intel Atom (CPU) Source: http://en.wikipedia.org/wiki/Intel%20Atom%20(CPU)?oldid=653270591 Contributors: David spector, Freck-
lefoot, Llywrch, Cyde, KAMiKAZOW, Julesd, Brigman, Conti, Ehn, Andrewman327, Taxman, Thue, Nurg, Mervyn, Zzyzx, Somercet,
Andries, Digital infinity, Rchandra, Macrakis, Bo102010, Uzume, Chowbok, Elektron, Moxfyre, Imroy, NeuronExMachina, YUL89YYZ,
Roo72, Bender235, Plugwash, ThierryVignaud, PatrikR, Giraffedata, MARQUIS111, Towel401, Jakew, Alansohn, Walter Görlitz, Guy
Harris, Quatermass, Kenyon, Jkt, Richard Arthur Norton (1958- ), Poppafuze, Scjessey, Pol098, Scootey, GregorB, MiG, Rjecina, JamesH-
enstridge, Laurinkus, Pmj, Rjwilmsi, Koavf, PHenry, Jlundell, Traut, Gelma, DirkvdM, X1987x, TheDJ, Jamessnell, Srleffler, Imnot-
minkus, Jpfagerback, Hairy Dude, DMahalko, Jengelh, Manop, Gaius Cornelius, XX55XX, TDogg310, Blitterbug, SixSix, Lucasred-
dinger, Hugo 87, Huangcjz, E Wing, Luk, SmackBot, Henriok, GeneralAntilles, SmackEater, Brianski, Amux, Thumperward, Onesi-
mos, Mdwh, Aleutia, Xaxxon, Colonies Chris, Jeffreyarcand, Dethme0w, Frap, Glloq, Sh0dan, Rrburke, Metageek, Ne0Freedom, Morio,
Daniel.Cardenas, Curly Turkey, Anss123, Joffeloff, JonT, Dr.K., LaMenta3, Dl2000, Hu12, Skorp, Flaming-tubesock, Andrew Hampe,
Sfm 7, Fernvale, Artemgy, FleetCommand, HenkeB, Bungalowbill, CCFreak2K, Steel, Myscrnnm, Rhe br, Clovis Sangrail, Christian75,
DumbBOT, Alaibot, Kozuch, Thijs!bot, Electron9, Humble Scribe, Hcobb, Oldmanbiker, Seaphoto, Lordmetroid, Smartse, CairoTasog-
are, Plainchips, RedWyverex, Tvbinstinct, Dimawik, JAnDbot, MER-C, Mark Grant, BrotherE, Inspector 2211, Peremen, Yosh3000,
Brownout, KJRehberg, Mdulcey, Chocobogamer, Bjornen, Nicsterr, AVRS, Yura.hm, Keith D, R'n'B, CommonsDelinker, Pacdude9,
Jayayess1190, J.delanoy, Whitebox, R!SC, McSly, Austin512, Ef3, Mazemode, Dubhe.sk, Ken g6, Jaimeastorga2000, My wing hk, Mr-
manny09, Mlorimer, DpuTiger, Imperator3733, Bjquinn, Allan kuan1992, TXiKiBoT, Someguy1221, Delv0n2, Bojan PLOJ, Tomaxer,
Winterspan, Andromeda451, Ham Pastrami, Behind The Wall Of Sleep, Oomgosh, Jhdezjr, Sasawat, Callidior, Jfromcanada, Jeo100,
WikipedianMarlith, Chris D Heath, Dsalt, Jetstreak150, ClueBot, Pistazienfresser, Stygiansonic, Rilak, Boing! said Zebedee, Edknol,
DerekMorr, Ykhwong, Technorj, Mewtu, Thingg, Aronzak, HumphreyW, Crowsnest, DumZiBoT, Jdwinx, Nnewton, Bobbozzo, Zodon,
Jabberwoch, ZackMulgrew, Airplaneman, Deineka, Addbot, E-Tiggy, Mortense, Ocdnctx, JoshuaKuo, Scientus, LaaknorBot, Glane23,
Martin0641, Jasper Deng, Abisys, Tide rolls, Lightbot, Cesiumfrog, Chinavation, Z897623, Ajoao4444, Luckas-bot, Yobot, Nghtwlkr,
Helena srilowa, Bryan.burgers, Ganimoth, AnomieBOT, 1exec1, Versus785, Materialscientist, E2eamon, Undefinedsymbol, Jeremonkey,
LilHelpa, Ziggy3055, Xqbot, Iadrian yu, Capricorn42, TecCougar, Trontonic, Locos epraix, User931, Narunetto, DriverDan, DooMMeeR,
Cyfraw, CaptainMorgan, Demysc, 33rogers, Uusijani, MrAronnax, Brunocip, Mark Renier, Wikiphile1603, BrownsRock10, Mikesteele81,
Arndbergmann, Kwns, Dsavi, Krating tong, Hgb asicwizard, Boobarkee, Jus dreamboy, Sailing ralf, Logipedia, Pklec, Wikk3d1, Blardie,
Bobbyus, Txhorw, Mappy wp, MoreNet, Fitoschido, GoingBatty, ExilorX, ValC, Werieth, Cogiati, Algh0022, Rvrcopy, Tomy9510,
Gsarwa, UnknownFork, Ipsign, Uziel302, ClueBot NG, Matthiaspaul, Logic2000, Gilderien, Cntras, RanmaKei, Dein Gregor, Nodulation,
Technical 13, Frantz369, Zapper067, Trilemma2, Ianteraf, Deepender singla, Manguene, Kwokangus, BattyBot, Sallynice, Drbendanillo,
Codename Lisa, PhelperRF, The.power.p, Pragmatool, Rotlink, Noasshats, Shelbystripes, FDMS4, Aeroid, John.Donoghue, Some Gadget
Geek, Pancho507 and Anonymous: 419
• Intel Core Source: http://en.wikipedia.org/wiki/Intel%20Core?oldid=651296137 Contributors: Caltrop, Atlan, Cherkash, Christopher-
woods, Xanzzibar, Thv, Brouhaha, Rchandra, Chowbok, SimonLyall, Thomas Bohn, DmitryKo, Apalsola, Discospinster, Hydrox, Ben-
der235, Guy Harris, PatrickFisher, Velella, Woohookitty, Pol098, Ruud Koot, GregorB, Bubba73, Fivemack, Riki, WikiWikiPhil, DVdm,
Aluvus, MGodwin, Manop, Mike411, Kvn8907, Hunnyhiteshseth, ItsDrewMiller, SmackBot, Reedy, Gilliam, Ohnoitsjamie, Vvarkey,
Smileyborg, TheDamian, Gobonobo, Hvn0413, Agent007bond, Blehfu, Fernvale, MoHaG, HDCase, Augustlilleaas, FleetCommand,
Pseudo-Richard, Fletcher, Yaris678, Dominicanpapi82, Dmws, JAnDbot, DuncanHill, MER-C, Bebo2good1, Trickv, Magioladitis, Khei-
der, Tracer9999, Rettetast, R'n'B, Tgeairn, Joeinwap, Black Kite, Hammersoft, Lexein, Sbjf, Nxavar, Echrei, Anna Lincoln, Jim Peak,
84 CHAPTER 14. MASSIVELY MULTIPLAYER ONLINE GAME

Jaqen, Zuchinni one, ObjectivismLover, CavalloRazzo, Fnagaton, Dawn Bard, Bentogoa, Lord British, Jimthing, Svick, ImageRemoval-
Bot, Martarius, ClueBot, EoGuy, Boing! said Zebedee, Rockfang, Ktr101, Pzoxicuvybtnrm, Antti29, Avoided, Badgernet, Airplaneman,
Dsimic, Addbot, P4p5, Some jerk on the Internet, Damiens.rf, Melwade, Aunva6, Jasper Deng, Yobot, Legobot II, AnomieBOT, Ciphers,
Hairhorn, 1exec1, Flinders Petrie, Intelati, Addihockey10, Johnny Bin, DSisyphBot, Shadowjams, Spazturtle, FrescoBot, Arndbergmann,
Gligoran, Winterst, Notedgrant, LittleWink, Jschnur, Kuyamarco123, Full-date unlinking bot, Cnwilliams, Edo248, TBloemink, The As-
sassin047, Visite fortuitement prolongée, Specs112, Craigdsthompson, Lopifalko, Mmm333k, John of Reading, Heymid, K6ka, ZéroBot,
Badrury, Cogiati, Najazjalal, Dr. A. J. Olivier, Sakurai Harumi, Donner60, Zee991, Ppw0, Azul120, Llightex, 28bot, Alcazar84, Clue-
Bot NG, Smtchahal, Alegh, Luraj, Thompson james, Widr, Zackaback, 42girls, Wolfmmiii, Titodutta, Popish, Killswitch125, Indexal-
lan, Gdowding, Mark Arsten, BenjaminBrock, BattyBot, Hang9417, Chemya, Rally24, Dexbot, Mogism, Pop99999, Etotheb123, TwoT-
woHello, PhelperRF, Isarra (HG), Npx122sy, Frosty, Intelinside13core, OsCeZrCd, MountSynai, Applist, Haminoon, JoshChoi4121, Ran-
dom23423423523423523, Studcameo, JaconaFrere, Boby2000, Vivekvigian, DiscantX, Anonguest, Computerpc0710 and Anonymous:
271
• List of Intel Core i5 microprocessors Source: http://en.wikipedia.org/wiki/List%20of%20Intel%20Core%20i5%20microprocessors?
oldid=651592968 Contributors: F. Delpierre, Alereon, Mindmatrix, Asav, Sdschulze, Vossanova, Bubba73, Mdeegan, G-smooth2k,
SmackBot, Aqualize, Wislam, Briguychau, Strohel, Inspector 2211, Paranoidmage, KenSharp, Gu1dry, CrackDragon, Addbot, Ma-
tushorvath, Luckas-bot, Yobot, AnomieBOT, 1exec1, Erik9bot, Uusijani, FrescoBot, Ralf König, Arndbergmann, Wpguy, Thilinawi-
jesooriya, Blound, Xplosionist, ‫واژه یاد‬, LOTG, Tc80, Blinkiz, Ravbr, Adam J Richter, Aularon, Vitkovskiy Roman, Sakurai Harumi,
SporkBot, Sbmeirow, Asdfsfs, Mystery70, Xxxxxls2, Azul120, Everlasting enigma, Frietjes, Killswitch125, Frze, Trevayne08, Hang9417,
Mahadri, Mhdmj, Latias1290, Extec286 and Anonymous: 150
• Pentium Dual-Core Source: http://en.wikipedia.org/wiki/Pentium%20Dual-Core?oldid=634778879 Contributors: Uzume, Ukexpat,
Djyang, M1ss1ontomars2k4, Guy Harris, Amram99, Denniss, Angelic Wraith, Paul1337, Pauli133, GregorB, Coneslayer, FlaBot, Gurch,
Wrightbus, Chobot, Aluvus, Manop, Mike411, Cybergoth, Spliffy, SmackBot, MalafayaBot, O keyes, Letdorf, Ceecookie, BWCNY,
MureninC, Thomasyen, Morio, Luigi.a.cruz, DHR, Radiant chains, Fernvale, JForget, Nathanbarlow, Alaibot, Ike-bana, Suigi, Jdlowery,
Okki, Myanw, JAnDbot, Mufffin man, Jaakobou, Alex Spade, RP88, Cspan64, Cmichael, STBotD, Pcordes, VolkovBot, Imperator3733,
Rafiko77, Hotdog111, Hellcat fighter, Dauthiwatchman, Iammrysh, André Pessoa, Deepakrawal121084, AlphaPyro, BBOPOPOS,
VVVBot, Ham Pastrami, Yongweiru, Jhdezjr, Anakin101, ClueBot, Supertouch, Czarkoff, Boing! said Zebedee, Otolemur crassicau-
datus, Sinaboy06, Geografia75, DumZiBoT, P40K, C. A. Russell, Airplaneman, Addbot, JoshuaKuo, Belekkaya, LaaknorBot, LAAFan,
Luckas-bot, Yobot, 4th-otaku, Rubinbot, Piano non troppo, Xqbot, Yhljjang, Daram.G, BrownsRock10, Arndbergmann, John of Read-
ing, Spacetronaut, H3llBot, Demonkoryu, ClueBot NG, HMSSolent, Jphill19, Henrytang194, Chepny, Emaifunction1, Gindylow, Julian-
prescott2604juuly, Smashmeerkat and Anonymous: 120
• Xeon Source: http://en.wikipedia.org/wiki/Xeon?oldid=653591763 Contributors: Pnm, Ixfd64, Stevenj, Julesd, Conti, Ehn, Anuchit,
Magnus.de, Tempshill, Wernher, Pengo, David Gerard, DocWatson42, Levin, EJDyksen, Bobblewik, Chowbok, Pgan002, DaveJB,
Kiteinthewind, Mormegil, Imroy, Wfaulk, Rich Farmbrough, Hydrox, Jpk, Jaap, Alistair1978, Bender235, Plugwash, MARQUIS111,
MPerel, Ehurtley, Typobox, Guy Harris, Keyser Söze, CyberSkull, Water Bottle, Denniss, Schapel, Paul1337, Pauli133, Gene Nygaard,
Dan100, Forderud, PdDemeter, Morkork, Jannex, Mindmatrix, LOL, Timharwoodx, Megaslow, ^demon, GregorB, Sega381, Alecv, Fre-
plySpang, Yurik, BorgHunter, Rjwilmsi, Jgp, Bubba73, Tommy Kronkvist, Baryonic Being, Fivemack, RexNL, Aluvus, YurikBot, Borgx,
RobotE, Charles Gaudette, Wengier, Yuhong, Ksyrie, Txuspe, Bovineone, Big Brother 1984, NawlinWiki, AugieWest, Seegoon, Thrashed-
Paranoid, Tony1, Alex43223, Phandel, Chris S, Jayamohan, Cloudbound, Cffrost, VodkaJazz, Pádraic MacUidhir, KnightRider, Smack-
Bot, Saihtam, Henriok, Ayocee, Gary Kirk, Darklock, SigurdMagnusson, Bluebot, Keegan, Big.P, Thumperward, SchfiftyThree, Letdorf,
Kungming2, ABACA, TurboTad, Dethme0w, Drkirkby, Frap, Jacob Poon, А, OzymandiasX, Midnightcomm, Metageek, Aditsu, Irides-
cence, Morio, Ugur Basak Bot, Autopilot, DHR, Pgk1, Hectorpal, Kuru, Joffeloff, Nashif, Slakr, Beetstra, Peyre, Kvng, Dl2000, Domini-
cliam, Lee Carre, Coldpower27, Chovain, A1b2c345, Fernvale, CmdrObot, Mix Bouda-Lycaon, Jesse Viviano, Kamujin, CarrerCrytharis,
Christian75, Jdlowery, Hardchemist, Headbomb, Ldoron, Jpchatt, Scepia, Fellix, Deflective, Davewho2, Arch dude, Belg4mit, Bong-
warrior, Banzai!, Paranoidmage, Indon, Bernd vdB, TimSmall, Retroneo, Edward321, Ftiercel, CommonsDelinker, NerdyNSK, Regani,
Sulimo, AntiSpamBot, GHanson, Sollosonic, DpuTiger, Joeinwap, Gerrit C. Groenenboom, Hammersoft, VolkovBot, KJSatz, Impera-
tor3733, PNG crusade bot, Marskuzz, ScriptedGhost, KP-Adhikari, Thunderbird2, Quantpole, Aednichols, P2501, JonnyJD, Roadrunner
gs, SieBot, Tinkoniko, Vexorg, Pxma, Flyer22, Sherlockindo, Jhdezjr, Lightmouse, Hobartimus, Jamiebalfour04, Anchor Link Bot, Im-
ageRemovalBot, Loren.wilton, Martarius, Sfan00 IMG, ClueBot, Mustafa Mustamann, Rune-san, Mooo993, Rilak, Dogtoy, Paperlan,
Fr3d org, TheTruthForSure, Theodric aethelfrith, BlueLikeYou, MatthieuV, Ykhwong, Pluknet, EPIC MASTER, Wdustbuster, AeonHun,
HumphreyW, DumZiBoT, C. A. Russell, NellieBly, Ebbex, Dsimic, Jeff.science, Addbot, Tmacfan4321, JoshuaKuo, Hardwarefreak,
Munkeevegetable, Tide rolls, Yobot, Koman90, Erikb5, Rvt1000r, ArthurBot, Victor.na, Obersachsebot, Winrarlawl, Miahac, J04n, Mag-
nuspg, Wfischer, W Nowicki, Schafdog, Arndbergmann, Jcheckler, Rick.weber.iii, Jonesey95, A412, Xcvista, HappyCamp23, Perversus,
GoneIn60, SkyMachine, Txt.file, Ecaveh, Rx5674, WCLL HK, Wire306, Dewritech, Minael, ZéroBot, Caseybutt, SCF0, Owenmann,
MainFrame, Vanished 1850, ChuispastonBot, Azul120, ClueBot NG, FeiTeng1000, Snotbot, Xeonisedg, Widr, Gavinstubbs09, Satus-
guy, FlashSWT, Johnadamy, Andrzej w k 2, Lancededcena, Andyspam, BattyBot, Xehroz, Oranjblud, Cerabot, Kingaustin42, Velinath,
Taino19xx, I am One of Many, MaXintoshPro, Applist, Monkbot, Filedelinkerbot, Unician, Sarr Cat and Anonymous: 429
• Distributed computing Source: http://en.wikipedia.org/wiki/Distributed%20computing?oldid=648678556 Contributors: Damian Yer-
rick, TwoOneTwo, Szopen, Koyaanis Qatsi, Snorre, Greg Lindahl, SimonP, Kurt Jansson, Heron, Formulax, Metz2000, Bernfarr, Den-
nisDaniels, Edward, Derek, Marvinfreeman, Lexor, Nixdorf, Kku, Wapcaplet, Ixfd64, Dori, Anonymous56789, SebastianHelm, Alfio,
Nanshu, CatherineMunro, Darkwind, Glenn, Whkoh, Rotem Dan, EdH, Rob Hooft, Ghewgill, Adam Conover, Timwi, Reddi, Ww,
Hao2lian, David Shay, Dbabbitt, Optim, Raul654, Frazzydee, Jni, Donarreiskoffer, Robbot, MrJones, Brent Gulanowski, Fredrik, Ki-
zor, R3m0t, Kristof vt, Vespristiano, Nurg, Kuszi, Hadal, Wikibot, Dbroadwell, Michael2, Giftlite, Dbenbenn, Thv, Herbee, Curps,
Waxmop, Dawidl, Mboverload, Khalid hassani, Matt Crypto, Edcolins, Lupine1647, Barneyboo, Beland, Jacob grace, APH, Maximaxi-
max, Nickptar, M1ss1ontomars2k4, Eggstasy, D6, AlexChurchill, Freakofnurture, Spiffy sperry, Mark Zinthefer, Vague Rant, Chrischan,
YUL89YYZ, Bender235, S.K., Darkness Productions, Evice, Bobdoe, El C, Walden, Drektor2oo3, Gyll, Stesmo, BrokenSegue, Viriditas,
Cmdrjameson, Mrdude, Haham hanuka, Paullaw, Mdd, Wayfarer, Autopilots, Ellisonch, Redxiv, Guy Harris, Atlant, Andrewpmk, DL-
Jessup, Flata, InShaneee, Irdepesca572, Stephan Leeds, Suruena, Evil Monkey, 4c27f8e656bb34703d936fc59ede9a, SimonHova, Nigini,
Nuno Tavares, Daira Hopwood, Decrease789, JonH, Ruud Koot, Jeff3000, AlbertCahalan, Qwertyus, Kbdank71, Iflipti, Rjwilmsi, In-
diedan, Karmachrome, Vary, John Nixon, Pascal76, Brighterorange, AlisonW, Fred Bradstadt, FayssalF, FlaBot, JFromm, Ewlyahoocom,
Bihzad, Glenn L, Chobot, DVdm, Garas, Bgwhite, YurikBot, Wavelength, Mdsmedia, Spl, Bhny, Gaius Cornelius, Bovineone, Carl-
Hewitt, SEWilcoBot, Mkbnett, Ichatz, Neum, Voidxor, Amwebb, Nethgirb, Jeh, Tim Watson, Georgewilliamherbert, Cdiggins, Ninly,
Juliano, Wsiegmund, Wikiant, Joysofpi, JoanneB, Rwwww, SmackBot, Ariedartin, David Woolley, Powo, CrypticBacon, Gilliam, RD-
14.9. TEXT AND IMAGE SOURCES, CONTRIBUTORS, AND LICENSES 85

Brown, PrimeHunter, EncMstr, LaggedOnUser, Scwlong, Allan McInnes, Cybercobra, Rajrajmarley, Kasperd, Dreadstar, Bejnar, How-
doesthiswo, Kuru, Sosodank, Iosef aetos, Statsone, Codepro, Bjankuloski06en, Hazzeryoda, MikeHearn, Beetstra, Trey56, Skabraham, Lee
Carre, Quaeler, Buyya, Tawkerbot2, Flubeca, Gangesmaster, Page Up, Only2sea, Pmerson, WeggeBot, Ezrakilty, SuperMidget, Gortsack,
CaptainMooseInc, Markov12, Stevag, Vanished User jdksfajlasd, D104, Thijs!bot, Hervegirod, Andyjsmith, Ideogram, Hala54, Papipaul,
Alphachimpbot, Sorry Go Fish, JAnDbot, CosineKitty, Magioladitis, Greg Ward, Nyq, SirDuncan, Geozapf, Tedickey, Cic, David Epp-
stein, Jacobko, Unfactual POV, Sahkuhnder, Chocmah, Chtfn, Softguyus, LedgendGamer, Cadence-, Cpiral, McSly, Akiezun, Aervanath,
Shamjithkv, DorganBot, LightningDragon, VolkovBot, Lee.Sailer, AlnoktaBOT, Philip Trueman, DragonLord, ChuckPheatt, Vanishe-
dUserABC, Spinningspark, Palaeovia, Kbrose, YonaBot, EwokiWiki, Ajtouchstone, Monkeypooisgood, Flyer22, JCLately, Hello71, Xe7al,
Dust Filter, WikiLaurent, Vladrassvet, Tanvir Ahmmed, The Thing That Should Not Be, TallMagic, Nonlinear149, Worldwidegrid, Do-
minikiii, Alexbot, Ahmed abbas helmy, WalterGR, Warrior4321, Aitias, SoxBot III, DumZiBoT, Darkicebot, XLinkBot, Wonderfulsnow,
WikHead, Slashem, RealityDysfunction, NonNobisSolum, Addbot, Proofreader77, Ramu50, Some jerk on the Internet, DOI bot, Maria C
Mosak, EjsBot, AkhtaBot, MrOllie, Kisbesbot, Jarble, Frehley, Legobot, PlankBot, Luckas-bot, Yobot, AnomieBOT, Nit634, Citation bot,
ArthurBot, Hahutch298, Xqbot, Capricorn42, Julianhyde, Mika au, Gilo1969, GrabBrain, Miguel in Portugal, Miym, Wizardist, AreThree,
Felix.rivas, Toonsuperlove, Doulos Christos, D'ohBot, Sae1962, Wifione, Jomifica, Neilksomething, Citation bot 1, Guarani.py, I dream of
horses, Jonesey95, Sohil it, RedBot, Île flottante, Jandalhandler, Trappist the monk, Yunshui, Diannaa, Tbhotch, Jesse V., Shafigoldwasser,
TjBot, Eng azza, EmausBot, Kinshuk jpr19, Janakan86, Goudron, JordiGH, Cincybluffa, Wakebrdkid, Unobjectionable, ClueBot NG,
Matthiaspaul, MelbourneStar, Gilderien, Advuser14, Widr, ‫ساجد امجد ساجد‬, Helpful Pixie Bot, Mellorf, BG19bot, Cognitivecarbon, Plas-
maTime, Kitisco, Riley Huntley, Khiladi 2010, Boufal, ChrisGualtieri, Mtriana, Catclock, Frosty, Malhelo, Maxcommejesus, Mario.virtu,
Dudewhereismybike, Narendra22, Dtngo, Ma2369, Spmeu, Meyerjo and Anonymous: 365

• Service-oriented architecture Source: http://en.wikipedia.org/wiki/Service-oriented%20architecture?oldid=653416322 Contributors:


Shd, Christian List, Frecklefoot, Edward, Michael Hardy, Repton, Kku, MartinSpamer, Haakon, Ronz, Arthur Frayn, Julesd, Stefan,
MasterDirk, Chprasad, Fuzheado, Nickg, Rednblu, Pedant17, Maximus Rex, Sboehringer, Bevo, Nnh, Gentgeen, Rfc1394, Texture, Fei-
gling, Caknuck, Bkell, Pengo, Dave6, Jonabbey, Varlaam, Khalid hassani, Pne, Matt Darby, Wmahan, Neilc, Stevietheman, Gadfium,
Metlin, Beland, OwenBlacker, Usrnme h8er, Axelangeli, Lipton, Ziroby, Kustere, Breedlov, Discospinster, William Pietri, Rich Farm-
brough, Rhobite, Avriette, ArnoldReinhold, ESkog, S.K., JoeSmack, Marx Gomes, Kyz, Shanes, Felagund, Simon South, Nigelj, Iain
Cheyne, Polluks, Giraffedata, Cem Basman, BlueNovember, Mdd, Iolar, Kraupu, Pinar, Walter Görlitz, Dethron, Diego Moya, WT-
GDMan1986, M@, Warpsmith, Tayal01, Velella, Bugg, Adoble, SteveLetwin, H2g2bob, Saxifrage, Zntrip, Stuartyeates, Weyes, Angr, Ja-
cobolus, Timosa, Cnb, Stefan Ivanovich, Varco, Mattmcc, GregorB, MauriceKA, Lastorset, ThomasOwens, Rogerd, Erebus555, Phantast,
MZMcBride, Oblivious, Scorpiuss, FayssalF, Kmorozov, Penedo, RobyWayne, Chobot, Sharkface217, Gwernol, YurikBot, Whoisjohn-
galt, RussBot, Bovineone, SamJohnston, Alexliu, SAE1962, Mccready, Brandon, Jpbowen, Tony1, Everyguy, Sneakymoose, Leonard-
Walstad, LandNav, Zzuuzz, WebWombat, Hadipedia, Tvarnoe, JuJube, GraemeL, TBadger, Aarsanjani, LeonardoRob0t, Fram, Back
ache, JLaTondre, DEng, Mbruggen, Halhelms, Rohitcool, Tom Morris, Binuraghavan, Riverawynter, That Guy, From That Show!, Do-
cendoDiscimus, SmackBot, Reedy, McGeddon, Dlwl, Blueshark, Basil.bourque, Elwood j blues, Renesis, Rajah9, Netsql, Ordinant,
Roma emu, Gilliam, Senfo, Ohnoitsjamie, Aamironline, Mdhmdh31, Anwar saadat, Chris the speller, Dlafont, Jjalexand, Thumper-
ward, Philoserf, MalafayaBot, Sadads, Wykis, BBCWatcher, DHN-bot, A. B., Mogman1, Peter Campbell, Jeff DLB, Atr0x, Ashish-
vaid, Cybercobra, Hslayer, Enarceus, Dreadstar, Iskatel, Warren, SeanAhern, Luís Felipe Braga, RayGates, Zbalai, Mrego, Moejorris,
Kuru, Spir, Ebertelsen, Soumyasch, JorisvS, Aleenf1, Martin Wagenleiter, Dfass, Nutcracker, Joe.jackson, Hulmem, Jstrachan, Kom-
pere, Beetstra, George The Dragon, Ehheh, Evmako, Afrab null, Zorabi, Akademy, Olimpiu.pop, ShakingSpirit, Hu12, Meitar, Ba-
nanaFiend, JHP, Jamehealy, IvanLanin, Vocaro, Paul Foxworthy, Igoldste, Dp462090, AGK, Linkspamremover, Tawkerbot2, JeffAd-
kins, CmdrObot, Libin v, Raysonho, Kensall, Nunquam Dormio, Anil Kumar Kartham, Wsibob, Cybernetic, IanDBailey, Bbarthel,
Billhunt, Slp1, Gogo Dodo, ST47, Solidpoint, Odie5533, Tawkerbot4, Torc2, DumbBOT, Dblanchard, Kckid, ErnstRohlicek, Ambitus,
Assentt, IvoTotev, Corycasanave, Thijs!bot, Shuumass, Hervegirod, SReddy, HappyInGeneral, Sprhodes, Z10x, Mschneid@agentos.net,
RichardVeryard, Nick Number, Bob.gourley@comcast.net, Nobar, Peashy, AntiVandalBot, RobotG, Rohit Sood, Nickull, Randybard-
well, Fayenatic london, Spencer, Ozgod, Wayiran, Fbahr, Barek, Yocto42, MER-C, Hasalaka, Michig, Chiya07, BrotherE, Technolo-
gyvoices, Kirrages, Daveh1, Shigdon, Magioladitis, VoABot II, MiguelMunoz, Transcendence, HouKid, Digitalfunda, Akmani, Jen2000,
Tedickey, Maard, Schastain, Snowded, Straxus, Think4yourself, Kristen puckett, Wagnermr14, Hamiltonstone, Wwmbes, Allstarecho,
The Rapper, Cander0000, Muzikman67, ErikTownsend, Curtbeckmann, MartinBot, Sciagent, Davidjcmorris, Axlq, Lmxspice, Ahmadar,
Zzglenm, Exostor, Fpbear, Tr0lll, NetManage, Pharaoh of the Wizards, Mange01, Fioranoweb, Samiam70002, Helon, JVersteeg, Sal-
liesatt, Robert Illes, Monster1218, Marioct, Betswiki, Grshiplett, Tonyshan, Midnight Madness, Arms & Hearts, SJP, Kmittal, Yogishpai,
Doug4, Christopher norton, Cometstyles, Fkroon, Jzupan, Davidslinthicum, Sbvb, Fogartis, HighKing, Sempertinal, Stwomack, Tomerfil-
iba, Malik fairose, Enderminh, Erpgenie, Bramschoenmakers, Hominidx, Digerateur, Dataprit, Parker007, A4bot, Stevers1, SynAsha,
Gabhala, Tiago simoes, Oxfordwang, Lradrama, Q Chris, Graham Berrisford, Maxim, Bansipatel, Hajoworldwide, Jvlock, Jaideco,
Fassihi, Badja, Paladin1979, Rajeevgm, Kbrose, Colm.mcmullan, SieBot, Jzhang2007, LarsHolmberg, Yadoo86, YonaBot, Kgoarany,
Y2ksw, Flyer22, CIOGuru, JCLately, Jojalozzo, CutOffTies, EnOreg, Smet, Svick, Ncw0617, Odcdtd45, Youngfu, HighFlyer12, ManOn-
Pipes, SanderEvers, Escape Orbit, Jvlock527, Dancinggoat, Stevepolyak, ImageRemovalBot, Slwatmough, Sathya sh, Martarius, Cmagu-
ruraj, Sfan00 IMG, Spa015, Techwonder, GarbagEcol, ClueBot, Radharajgopal, Brandguru, Gnanaguru, Nklata, MRqtH2, Mmichaelbell,
Prov519, The Thing That Should Not Be, H.E. Hall, Alksentrs, Malharbarai, Sbono, Drphallus, Gunaseelapandian, SamTheButcher, Vat-
sakatta, StigBot, Ericsenunas, ITBusinessEdge, Rose Booth, Carusus, Dlelash, ShachiDube, Lacomoedia, NuclearWarfare, MkuhbocK,
Swtechwr, ChrisKalt, Razorflame, Bruno rodin, El bot de la dieta, John at Lancelotlinc, Aprock, Bjdehut, Djmackenzie, Mymalland-
news, Defragyourmind, Bpmsoa, GeoffMacartney, Expertjohn, DumZiBoT, Spinner4321, Abrobitroy, Milais, XLinkBot, Xagronaut,
Heather.taylor, OWV, AngelaMartin2008, DamsonDragon, Wintaborn, AnitaRogel, ZooFari, Cesar.obach, Richard.McGuire88, Ad-
dbot, Qiuzhuang.Lian, Sean R Fox, Betterusername, Maria C Mosak, DanielGEllis, Raypereda, AroundLAin80Days, Ddhanasekharan,
Kobakhet, MrOllie, LaaknorBot, Jmilgram, Empathy321, Williamglasby, Ashwineek, Manishpk, Lightbot, OlEnglish, Richard R White,
Ravisriv, Jarble, Blablablob, Yobot, Themfromspace, Bunnyhop11, TaBOT-zerem, Billing geek, Danperryy, Ricky123tony, Mojei, Dactyl-
lic, Lelguea, AncientArk, AnomieBOT, Azambataro, Aaronaberg, HelloSOAWorld, Galoubet, Kingpin13, Sz-iwbot, ItchyDE, Materi-
alscientist, Markcowan, JamesLWilliams2010, Citation bot, Haleyga, Capricorn42, Boaworm, Kiran.kaipa, Yetasoli, Alvin Seville, Soalib,
Mangst, Aligilman, Prari, FrescoBot, Riventree, Mark Renier, Ibspublishing, Sidna, Sae1962, Feravoon, BusinessMashups, HamburgerRa-
dio, Citation bot 1, Nav141174, Winterst, Momergil, JLRedperson, Alinabalint, Gedimin, MHPSM, DavidInCambridge, E.s.cohenlevy,
MertyWiki, Vinaysingla, Taylorrx, Soa101, LogAntiLog, Orangesodakid, Hanay, Darshana.jayasinghe, Vrenator, Allen4names, Crysb,
Randimae, Rjabate, Starfishjones, Nottrobin, Beantowngal, Soaguy, Obankston, Lozw, Projectmbt, Bangsanegara, Jann.poppinga, Fiftytwo
thirty, Quaysea, John of Reading, Faolin42, Sam Tomato, Biskup2010, Jiri Pavelka, Thecheesykid, Bollyjeff, Traxs7, GZ-Bot, Ra-
machandra20, ISresearcher, BioPupil, Kirby2010, Yveschaix, Sunrisesunset12345, ClueBot NG, Ptrb, Roubo, Xeroboxer, Sudhanshuss,
Satellizer, Luis Mailhos, Wambugunet, Anshuman.dwivedi, Madhavan93, Carl presscott, George392, Helpful Pixie Bot, Wbm1058,
86 CHAPTER 14. MASSIVELY MULTIPLAYER ONLINE GAME

GuySh, Taibah U, BG19bot, Wasbeer, Hvh22, Compfreak7, AdventurousSquirrel, Pkkao2, BattyBot, Softwareqa, DucerGraphic, Mtri-
ana, Cj211, Czaftan, Jots and graphs, Baringmo, Mwsobol, Gabby Merger, Lemnaminor, Marinac93, Lasith011, GreggRock, Maura
Driscoll, Comp.arch, Dnader90, Wtsai36, K0zka, Nishsvn, Jpmunz, Beavercreekful, Gorohoroh, Rabdill, Amenychtas, Monkbot, Theen-
terprisearchitect, Aerosteak, Juanchristy, Haloedscape, Tsfto01, Yinongchen and Anonymous: 960
• Massively multiplayer online game Source: http://en.wikipedia.org/wiki/Massively%20multiplayer%20online%20game?oldid=
652933076 Contributors: William Avery, DrBob, Mrwojo, Frecklefoot, Yaroslavvb, Booyabazooka, Fred Bauder, Kidburla, Pnm, Liftarn,
Gabbe, CesarB, Haakon, Netsnipe, Evercat, Conti, Furrykef, K1Bond007, Raul654, Johnleemk, Nufy8, Robbot, MrJones, SmileyChris,
Havatcha, Rasmus Faber, Pengo, Dave6, Centrx, DocWatson42, Jacoplane, Brian Kendig, Everyking, WolfenSilva, Rick Block, Edcolins,
Golbez, Chowbok, Geni, DarkLordSeth, Tzarius, Ratiocinate, Mattb90, Esperant, Orange Goblin, Poccil, Discospinster, Fvdham, Ponder,
WikiPediaAid, Duemellon, Kbh3rd, JoeSmack, Dcrt888, TOR, CanisRufus, MBisanz, Mwanner, Sietse Snel, RoyBoy, Cretog8, Small-
jim, Colorfast, John Vandenberg, ZayZayEM, Kx1186, Pearle, Gsklee, NickCatal, Alansohn, LtNOWIS, Khaim, Jtalledo, Ricky81682,
Hohum, Circuitloss, Super-Magician, TheDotGamer, Drat, Marasmusine, Jeffrey O. Gustafson, OwenX, Carlos Porto, LOL, WadeSim-
Miser, Sega381, Toussaint, DeweyQ, Ajshm, SLWK, Alastair, Qwertyus, Rjwilmsi, Gudeldar, Egberts, Brighterorange, Bryan H Bell,
Yamamoto Ichiro, Algebra, Ian Pitchford, Fyrn, Richdiesal, Coll7, SouthernNights, CarolGray, JYOuyang, RexNL, Intgr, D.brodale,
Terrx, Chobot, Kakurady, NTBot, Caliah, Richard Slater, RadioFan2 (usurped), Cryptic, Bovineone, Wimt, NawlinWiki, Madcoverboy,
Wahooker, Dialectric, Grafen, Jaxl, Matticus78, Mechanized, SFC9394, Wknight94, TheSeer, Blueyoshi321, K.Nevelsteen, Laibcoms,
GraemeL, Vicarious, Fram, Emc2, Lando242, Draconus, JDspeeder1, SmackBot, MattieTK, Numsgil, Bobet, McGeddon, Pgk, Jagged
85, J.J.Sagnella, Premchai, Dhochron, Yellowbounder, Drttm, Carl.bunderson, Keegan, Bangy boongy, Thomasjs, MalafayaBot, Thybag,
Sadads, Viewfinder, ACupOfCoffee, Darth Panda, Kotra, Can't sleep, clown will eat me, Mrn71, Allemannster, Frap, Size J Battery,
Onorem, Spacefed, Xyzzyplugh, Addshore, Mosca, Nayl, Tiliqua, Radagast83, E. Sn0 =31337=, Decltype, Mr Minchin, Squashua, Ea-
gleguy125, Weregerbil, Kalathalan, Funkywizard, Expedion, Dux0r, IonStorm, Dreslough, Bodobodot1, Scientizzle, Heimstern, Aviu-
soraculum, Scetoaux, Aleenf1, Wyxel, Chrisch, MarkSutton, EddieVanZant, SQGibbon, Grandpafootsoldier, Ehheh, Meco, Ryulong,
Zapvet, EmmaPeel007, Kyellan, Nabeth, Tythesly, Dl2000, SubSeven, Gunsmith, Woodroar, Iridescent, Akkhima, Znitrx, Beno1000,
Az1568, Courcelles, Danlev, FairuseBot, Tawkerbot2, Powerslide, Cpryd001, Stupidlegs13, CT456568, SkyWalker, CmdrObot, Mat-
tbr, The Missing Piece, Zarex, Ric36, Tomto, Lesgainous, Nczempin, Mika1h, Leevanjackson, Green caterpillar, Some P. Erson, Wrat-
mann, Erencexor, Nilfanion, Jonursenbach, Cagecrawler, Crossmr, Gogo Dodo, Beefnut, Tawkerbot4, Quibik, Apolaine, Smokeyblues,
Lazyboyholla, Legendps, Kozuch, ErrantX, Omicronpersei8, JodyB, DJBullfish, VPliousnine, Thijs!bot, Biruitorul, Qwyrxian, Jedibob5,
N5iln, Gamer007, ClosedEyesSeeing, Join, Sir Simon Tolhurst, ThirdEchelon, Hcobb, AgentPeppermint, Free2flow8, AntiVandalBot,
Luna Santin, Desdewd, MrNoblet, Charlo blade123, TexMurphy, Jhsounds, Spencer, Oddity-, ChrisLamb, Gökhan, JAnDbot, Husond,
MER-C, CaptSkubba, Xeno, Dream Focus, Filnik, Gogs4795, Tomst, Rocktacity, TylerStacie2005, Azzer007, VoABot II, CattleGirl,
God-Emperor, Dragor, SineWave, Supsupwatz, BrianGV, PIrish, Animum, Ben Ram, Atheria, DerHexer, Kaneva, BTMendenhall, Gwern,
MartinBot, MLeeson, Notmyhandle, Ultraviolet scissor flame, Sm8900, R'n'B, PrestonH, Itanius, J.delanoy, Pharaoh of the Wizards, Trusil-
ver, Reorion, Uncle Dick, RSnook, Xangel, H4xx0r, 1mujin22, SharkD, Dared111, Uranium grenade, Masky, NewEnglandYankee, SJP,
Greeves, LHOO, Akhel, TepesX, Inomyabcs, Stoneface1970, Vanished user 39948282, Bonadea, Useight, Izno, Darthnader37, RJASE1,
Mmovsg, Rd556212, WebAXiSS, Dani210, Bennerhingl, Vranak, Bebietdibibi, VolkovBot, Ugriffin, Yobb, Masaruemoto, Chaos5023,
VasilievVV, Soliloquial, Stealthnh, Havocbean, Minister of loco, Philip Trueman, Stateofshock, TXiKiBoT, Boxkarr, AudiS4BiTurbo,
Subspace Continuum, Kww, Jameseditor, JayC, Rhettdec, Melsaran, LizardPariah, Noformation, Snowbot, Ambard, Butterscotch, Mouse
is back, Kilmer-san, GAM3OV3R, Haseo9999, BlKat, Emodinol, Falcon8765, Celosia, AlleborgoBot, Bob the Rabbid, Hcagri, Hitamaru,
ElsaHZT, Spascu, Amoreno65, Tibullus, SieBot, Duality98765, Balthazar, Sorarules7, Addit, Winchelsea, BloodDoll, Matt Brennen, Catal-
inStroescu, Flyer22, FlyxCutlery, Ezh, Allmightyduck, Kaptns, Drf0053, Svick, Baron9, Mebalzer, JohnnyMrNinja, Order of the Nameless,
Blake, Anchor Link Bot, Xonnex, Cocoapropo, JL-Bot, Empire Of Sports, Chewjacka, Triple3D, Roxorius, Kanonkas, Xxe47, Elathiel,
Martarius, Tylercraig85, ClueBot, LAX, Jordc1991, Snigbrook, Londium, The Thing That Should Not Be, Jordzallmighty, Creovex, Dyee,
Frmorrison, Mofuggin bob, CounterVandalismBot, PMDrive1061, Excirial, Alexbot, Flightsoffancy, MatttK, Powerleveling, TaintedZe-
bra, Carsonius, NuclearWarfare, Dirt Tyrant, OekelWm, Razorflame, Teokk, Randomran, Ark25, Muro Bot, Wyrm419, Thingg, DumZ-
iBoT, Bridies, XLinkBot, Nepenthes, Little Mountain 5, Lstanley1979, Pirateer011, SilvonenBot, Jkbena6212, MystBot, Amazone09,
Fiskbil, CharlesGunnLol, Kestry, RyanCross, Thatguyflint, Ramu50, ConCompS, Apex Glide, Pete35887, Lovepopp, Lord of Ra, EjsBot,
NubXPRESS, EvanVolm, Devrit, Cst17, MrOllie, Chamal N, Glane23, Bassbonerocks, Valkyrx, Reddragonbones, RaumVogel, Say nesh,
Strattonbrazil, Sammyhammy23, Tide rolls, Lightbot, Luckas Blade, PlankBot, Yobot, Taleofyouth, Ptbotgourou, Legobot II, II MusLiM
HyBRiD II, Sandybremer, Groveislet, Bryan.burgers, AnomieBOT, Andrewrp, Cheetah255, Piano non troppo, Kingpin13, Xqbot, Xepra,
Jojoyee, Ecstacy666, Capricorn42, TechBot, Millahnna, Nasnema, DSisyphBot, Anna Frodesiak, Nerrojin, 7h3 3L173, RibotBOT, Lo-
cobot, Shadowjams, Omgtyman, BoomerAB, Paavope, Flapperistic, LSG1-Bot, LDGB1337, Dcdannyf, Sidna, HurricanesFan5, Salta10,
Wetbird15, CoreyDavis787, Jongittens, Evilmidget38, Arasaylaurel, ThatRunescaper, Myrtok, Amadsen80, Seftinho, BRUTE, Jschnur,
RedBot, Writelabor, Leonardo801, Bgiff, Irbisgreif, Lotje, GamerScourge, Dinamik-bot, Ieriv, Savybones, Eshaneman, Ratatatoo, Dark-
ScizorMaster, Reach Out to the Truth, Levininja, Faraz43, Amiteli, DARTH SIDIOUS 2, Bulgun, Vannoboy, Slonenok, Charliemcckidd,
EmausBot, John of Reading, Wolhound, Tallungs, Kumul, Samredfern, RenamedUser01302013, K6ka, Agencyinc, Xubuntero, IVA-
Nis1, Fæ, MithrandirAgain, Wikignom, Zamscob3, Vgmddg, Trimutius, Erianna, KazekageTR, Omomom1, Polisher of Cobwebs, Boxlid,
Longwayaway, ClueBot NG, IndigoMertel, Evergreen17, Wiki helper guy, O.Koslowski, Widr, JaybeeTheHutt, Shovan Luessi, Jeraphine
Gryphon, Mikikian, Oraklus, Kttp3, Run4YourLife, Peresans, Muneil, Mark Arsten, Compfreak7, Coolio665, Workmuch, Andy-roo,
BattyBot, Saígúrun, Khazar2, MadGuy7023, Mogism, Katzand, ABunnell, Graphium, HariBhol, Ganymede2222, Farbodebrahimi, Epic-
genius, NewzooHQ, Hanamanteo, Betino, Tasowiki, Jacobdude5672, Glaisher, Dimitry.grossman, Jccuaki, Skr15081997, Melcous, Blitz-
Greg, Lubieni2, Vasinoz98, Imays76, Poseidon4231, Mediavalia, Krzykoala, MMOPhilosopher, Coolkidlol221 and Anonymous: 895

14.9.2 Images
• File:Ambox_current_red.svg Source: http://upload.wikimedia.org/wikipedia/commons/9/98/Ambox_current_red.svg License: CC0
Contributors: self-made, inspired by Gnome globe current event.svg, using Information icon3.svg and Earth clip art.svg Original artist:
Vipersnake151, penubag, Tkgd2007 (clock)
• File:Ambox_important.svg Source: http://upload.wikimedia.org/wikipedia/commons/b/b4/Ambox_important.svg License: Public do-
main Contributors: Own work, based off of Image:Ambox scales.svg Original artist: Dsmurat (talk · contribs)
• File:Ambox_rewrite.svg Source: http://upload.wikimedia.org/wikipedia/commons/1/1c/Ambox_rewrite.svg License: Public domain
Contributors: self-made in Inkscape Original artist: penubag
14.9. TEXT AND IMAGE SOURCES, CONTRIBUTORS, AND LICENSES 87

• File:Asmp_2.gif Source: http://upload.wikimedia.org/wikipedia/en/0/0b/Asmp_2.gif License: PD Contributors:


Own work
Original artist:
G7a (talk) (Uploads)
• File:Athlon64x2-6400plus.jpg Source: http://upload.wikimedia.org/wikipedia/commons/f/fb/Athlon64x2-6400plus.jpg License: CC
BY 3.0 Contributors: Own work Original artist: Babylonfive David W. Smith
• File:Closeup_of_intel_pentium_E2180.jpg Source: http://upload.wikimedia.org/wikipedia/commons/7/73/Closeup_of_intel_
pentium_E2180.jpg License: CC BY-SA 3.0 Contributors: Own work Original artist: Emaifunction1
• File:Commons-logo.svg Source: http://upload.wikimedia.org/wikipedia/en/4/4a/Commons-logo.svg License: ? Contributors: ? Original
artist: ?
• File:Desktop-Linux-Mint.png Source: http://upload.wikimedia.org/wikipedia/commons/4/41/Desktop-Linux-Mint.png License: CC
BY-SA 4.0 Contributors: Own work Original artist: Benjamintf1
• File:Distributed-parallel.svg Source: http://upload.wikimedia.org/wikipedia/commons/c/c6/Distributed-parallel.svg License: CC BY-
SA 3.0 Contributors: Own work Original artist: Miym
• File:Dual_Core_Generic.svg Source: http://upload.wikimedia.org/wikipedia/commons/e/ec/Dual_Core_Generic.svg License: Public
domain Contributors: Transferred from en.wikipedia; transferred to Commons by User:Liftarn using CommonsHelper. Original artist:
Original uploader was CountingPine at en.wikipedia
• File:E6750bs8.jpg Source: http://upload.wikimedia.org/wikipedia/commons/a/af/E6750bs8.jpg License: Public domain Contributors:
Transferred from en.wikipedia; transferred to Commons by User:Liftarn using CommonsHelper. Original artist: Original uploader was
GuitarFreak at en.wikipedia
• File:Edit-clear.svg Source: http://upload.wikimedia.org/wikipedia/en/f/f2/Edit-clear.svg License: Public domain Contributors: The
Tango! Desktop Project. Original artist:
The people from the Tango! project. And according to the meta-data in the file, specifically: “Andreas Nilsson, and Jakub Steiner (although
minimally).”
• File:En-Service-oriented_architecture.ogg Source: http://upload.wikimedia.org/wikipedia/commons/0/09/En-Service-oriented_
architecture.ogg License: CC BY-SA 3.0 Contributors:
• Derivative of Service-oriented architecture Original artist: Speaker: Mangst
Authors of the article
• File:Folder_Hexagonal_Icon.svg Source: http://upload.wikimedia.org/wikipedia/en/4/48/Folder_Hexagonal_Icon.svg License: Cc-by-
sa-3.0 Contributors: ? Original artist: ?
• File:Hwloc.png Source: http://upload.wikimedia.org/wikipedia/commons/9/95/Hwloc.png License: BSD Contributors: Raysonho @ Open
Grid Scheduler / Grid Engine Original artist: The Portable Hardware Locality (hwloc) Project.
(Screenshot by the Open Source Grid Engine Project)
• File:Intel_Atom.png Source: http://upload.wikimedia.org/wikipedia/en/e/e1/Intel_Atom.png License: Fair use Contributors:
The logo is from the www.intel.com/personal/our-technology/mids/ website. Original artist: ?
• File:Intel_Atom_2009.svg Source: http://upload.wikimedia.org/wikipedia/en/5/50/Intel_Atom_2009.svg License: Fair use Contributors:
The logo is from the http://download.intel.com/products/atom/322868.pdf website. Original artist: ?
• File:Intel_PentiumDC_2008.png Source: http://upload.wikimedia.org/wikipedia/en/6/6f/Intel_PentiumDC_2008.png License: Fair use
Contributors:
The logo is from the http://www.intel.com/products/desktop/processors/pentium.htm website. Original artist: ?
• File:Intel_Pentium_Dual-Core_Overclock.jpg Source: http://upload.wikimedia.org/wikipedia/commons/9/9d/Intel_Pentium_
Dual-Core_Overclock.jpg License: CC BY-SA 4.0 Contributors: Own work Original artist: Julianprescott2604juuly
• File:Intel_Xeon_DP_5110_Woodcrest.jpeg Source: http://upload.wikimedia.org/wikipedia/commons/0/01/Intel_Xeon_DP_5110_
Woodcrest.jpeg License: CC BY-SA 3.0 de Contributors: Own work Original artist: Frank Zheng
• File:Intel_Xeon_E3-1241_v3_CPU.jpg Source: http://upload.wikimedia.org/wikipedia/commons/f/fe/Intel_Xeon_E3-1241_v3_CPU.
jpg License: CC BY-SA 4.0 Contributors: Own work Original artist: Dsimic
• File:Intel_Xeon_E5-1650_v3_CPU.jpg Source: http://upload.wikimedia.org/wikipedia/commons/c/c6/Intel_Xeon_E5-1650_v3_CPU.
jpg License: CC BY-SA 4.0 Contributors: Own work Original artist: Dsimic
• File:Intel_Xeon_E7440_open_die_at_heat_spreader.jpg Source: http://upload.wikimedia.org/wikipedia/commons/f/fa/Intel_Xeon_
E7440_open_die_at_heat_spreader.jpg License: CC BY-SA 4.0 Contributors: Own work Original artist: Andrzej w k 2
• File:Internet_map_1024.jpg Source: http://upload.wikimedia.org/wikipedia/commons/d/d2/Internet_map_1024.jpg License: CC BY
2.5 Contributors: Originally from the English Wikipedia; description page is/was here. Original artist: The Opte Project
• File:LSPic2Smaller.png Source: http://upload.wikimedia.org/wikipedia/en/d/de/LSPic2Smaller.png License: Fair use Contributors:
Created with in-game screen capture mechanic
Original artist: ?
• File:Logo_Pentium_DualCore_thumb2.jpg Source: http://upload.wikimedia.org/wikipedia/en/c/cd/Logo_Pentium_DualCore_
thumb2.jpg License: Fair use Contributors:
The logo may be obtained from Pentium Dual-Core.
Original artist: ?
• File:Memorial_gathering-WW2_Online.jpg Source: http://upload.wikimedia.org/wikipedia/en/d/d1/Memorial_gathering-WW2_
Online.jpg License: Fair use Contributors:
Author Flightsoffancy Original artist: ?
88 CHAPTER 14. MASSIVELY MULTIPLAYER ONLINE GAME

• File:NUMA.svg Source: http://upload.wikimedia.org/wikipedia/commons/1/1f/NUMA.svg License: Public domain Contributors: Own


work Original artist: Moop2000
• File:Pentium_II_Xeon_450_512.jpg Source: http://upload.wikimedia.org/wikipedia/commons/6/66/Pentium_II_Xeon_450_512.jpg
License: CC BY-SA 3.0 Contributors: Transferred from en.wikipedia
Original artist: MARQUIS111 (talk). Original uploader was MARQUIS111 at en.wikipedia
• File:Portal-puzzle.svg Source: http://upload.wikimedia.org/wikipedia/en/f/fd/Portal-puzzle.svg License: Public domain Contributors: ?
Original artist: ?
• File:Question_book-new.svg Source: http://upload.wikimedia.org/wikipedia/en/9/99/Question_book-new.svg License: Cc-by-sa-3.0
Contributors:
Created from scratch in Adobe Illustrator. Based on Image:Question book.png created by User:Equazcion Original artist:
Tkgd2007
• File:SMP_-_Symmetric_Multiprocessor_System.svg Source: http://upload.wikimedia.org/wikipedia/commons/1/1c/SMP_-_
Symmetric_Multiprocessor_System.svg License: CC BY-SA 3.0 Contributors: Own work Original artist: Ferry24.Milan
• File:SOA_Elements.png Source: http://upload.wikimedia.org/wikipedia/commons/d/d4/SOA_Elements.png License: CC BY 2.5 Con-
tributors: Dirk Krafzig, Karl Banke, and Dirk Slama. Enterprise SOA. Prentice Hall, 2005 Original artist: Florian Lindner (designer)
• File:SOA_Metamodel.svg Source: http://upload.wikimedia.org/wikipedia/commons/0/06/SOA_Metamodel.svg License: GFDL Con-
tributors: self-made, based on SOA Meta Model.jpg by David S. Linthicum Original artist: Loïc Corbasson, created with en:OOo Draw
(ODG source file available on request)
• File:SOMF_V_2.0.jpg Source: http://upload.wikimedia.org/wikipedia/en/7/77/SOMF_V_2.0.jpg License: PD Contributors: ? Original
artist: ?
• File:Shared_memory.svg Source: http://upload.wikimedia.org/wikipedia/commons/f/f2/Shared_memory.svg License: CC-BY-SA-3.0
Contributors: en:Image:Shared Memory.jpeg Original artist: en:User:Khazadum, User:Stannered
• File:Sound-icon.svg Source: http://upload.wikimedia.org/wikipedia/commons/4/47/Sound-icon.svg License: LGPL Contributors:
Derivative work from Silsor's versio Original artist: Crystal SVG icon set
• File:Wiki_letter_w_cropped.svg Source: http://upload.wikimedia.org/wikipedia/commons/1/1c/Wiki_letter_w_cropped.svg License:
CC-BY-SA-3.0 Contributors:
• Wiki_letter_w.svg Original artist: Wiki_letter_w.svg: Jarkko Piiroinen
• File:Xeon_X5355_Clovertown.jpg Source: http://upload.wikimedia.org/wikipedia/commons/8/84/Xeon_X5355_Clovertown.jpg Li-
cense: CC BY-SA 3.0 de Contributors: Own work Original artist: Frank Zheng

14.9.3 Content license


• Creative Commons Attribution-Share Alike 3.0

You might also like