

#### In this lesson:

- Introduce the principles of the RISC and CISC architectures
- Overview of the Berkeley RISCI microprocessor architecture
- Comparison of RISC and CISC architectures
- History of the development of RISC architectures

2

## Reduced Instruction Set Computers (RISC)

#### Principle:

Support high level language structures that are frequently used and have a considerable impact in program execution time. The support to these structures is based on primitives architectural elements that facilitate the implementation of a fast, efficient and simple processor.

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

#### Principle:

Provide support for high level languages moving complex function to the hardware. Facilitate the development of compilers closing the "semantic gap".

#### Semantic Gap



**Semantic gap:** How close is the machine code to the source code.

#### Closing the Semantic Gap on VAX-11

- Case instruction for implementation of Case statements
- Character string instructions for handling character strings
- Call instruction for handling subroutines and functions
- Compare and branch instructions for if/else statements

6

#### **RISC-CISC Controversy**

#### **CISC** supporters:

Microprocessors can be more efficient if they support complex instructions mapping high level language structures (close semantic gap).

#### RISC supporters:

Microprocessors can run faster by supporting simple instruction to implement complex high level language structures faster (open semantic gap).

#### **Controversy resolved**

#### Compatibility, Cost, Size and Energy Consumption decide

- The large majority of microprocessors installed in commercial products are RISC
- On the desktop market the large majority of microprocessors installed are CISC (Intel® 64 and IA-32 Architectures)

8

## RISC vs CISC Characteristics (In the beginning)

|                        | RISC                              | CISC                             |  |  |
|------------------------|-----------------------------------|----------------------------------|--|--|
| Number of Instructions | relatively small/simple           | large/complex                    |  |  |
| Number of Data Type    | small                             | relatively large                 |  |  |
| Registers              | many general purpose              | most have many genera purpose    |  |  |
| Memory Size            | 4G Bytes                          | 4G Bytes or less                 |  |  |
| Memory access          | only with load/store instructions | with many instructions           |  |  |
| Operations (operands)  | immediate or register             | immediate,<br>register or memory |  |  |
| Instruction Formats    | few, fixed size                   | several, variable size           |  |  |
| Addressing Modes       | few                               | many                             |  |  |

#### Berkeley's RISC | Architecture

- 31 instructions
  - Delayed branch
  - Subroutines supported with Register Windows mechanism
- Architectural memory of 2<sup>32</sup> bytes
- Data types: byte, short word (16 bits), long word (32 bits)
- · Addressing mode:

Immediate, Register, Base-Index, Base-Displacement, Relative

- Registers
  - 32 general purpose visible registers (R0=0)
- PC
- PSW
- Register Windows

**RISC I Instruction Set** 

| Arithmetic<br>& Logic |                                                     | ADD, ADDC, SUB, SUBC, SUBR,<br>SUBRC, AND, OR, XOR |       |      | Rd € | ← Rs1 op S2         | A and B |   |
|-----------------------|-----------------------------------------------------|----------------------------------------------------|-------|------|------|---------------------|---------|---|
| Shift                 | SLL,S                                               | SLL,SRL,SRA                                        |       |      | Rd € | ← Rs1 shifted by S2 | A and B |   |
| Load                  | LDL,L                                               | LDL,LDSU,LDSS,LDBU,LDDBS                           |       |      | Rd € | ← M[Rs1 + S2]       | A and B |   |
| Store                 | STL,S1                                              | STL,STS,STB                                        |       |      | M[F  | Rs1+S2] ← Rd        | A and B |   |
| Control               | JMP, JMPR, CALL, CALLR, RET, RETINT, CALLINT, GTLPC |                                                    |       | Vari | ous  | A, B, o C           | :       |   |
| Other                 | LDHI,GETPSW,PUTPSW                                  |                                                    |       | Vari | ous  | A or C              |         |   |
| 31                    | 2524                                                | 23                                                 | 19 18 | . 1  | 413  | 12                  | 5 4     | ( |
| Opcode                | 9 5                                                 | Rd                                                 |       | Rs1  | 0    |                     | Rs2     |   |
| Opcode                | e S                                                 | Rd                                                 |       | Rs1  | 1    | Immediate           | e13     |   |
| 31                    | 2524                                                | 23                                                 | 19 18 |      |      |                     |         |   |

**Architectures Comparison** 

|                        | RISC I                  | VAX-11                                 | ARM                     |  |
|------------------------|-------------------------|----------------------------------------|-------------------------|--|
| Number of Instructions | 31 simple               | 130 simple & complex                   | 140+ simple & complex   |  |
| Number of Data Type    | 3                       | 9                                      | 3                       |  |
| Registers              | 32 GPR                  | 16 GPR                                 | 16 GPR                  |  |
| Memory Size            | 4G Bytes                | 4G Bytes                               | 4G Bytes                |  |
| Memory access          | Load/Store instructions | Many<br>instructions                   | Load/Store instructions |  |
| Operations (operands)  | Immediate or register   | Immediate, register or register memory |                         |  |
| Instruction Formats    | 3 fixed sixe            | 5 variable size                        | 10 fixed size           |  |
| Addressing Modes       | 4                       | 13                                     | 19                      |  |

#### RISC: What's left

- · Large number of registers
- Operations with operands kept in registers
- Memory accesses exclusively with load/store instructions
- Fixed-size instructions

13

#### Fallacies about RISC Architectures

- Reduced number of instructions
- Simple instructions

Not reduced instruction set computers by any standard

1

#### First RISC Architectures

#### **Pioneers**

- IBM 801
- · Berkeley RISC I
- Stanford MIPS

#### First Commercial Generation

- SPARC
- DEC Alpha
- HP Precision
- IBM Power
- IBM RT

#### **History of RISC Development**

#### Pre RISC Era

#### **History of RISC Development**

#### Beginning of RISC Era

IBM produces the first RISC microprocessor, but does not make it public.

David Paterson and Carlo H. Sequin, fromUC Berkeley, present the RISC I microprocessor and coin the RISC concept.

John Hennessy, from Stanford, presents the MIPS microprocessor

The ARM (Advanced RISC Machine) architecture is born  ${}^{\rm I}_{\rm In}$  England.

1981 1982 1983 1985

#### **History of RISC Development**

#### Beginning of Commercial RISC Era

IR2000, the first comercial MIPS microprocessor is developed. Eventually used in Silicon Graphics workstations.

IBM introduces the IBM RT, the first RISC commercial workstation (very short life).

HP sells computers with the Precision Architecture

ISun introduces workstations with SPARC microprocessors I(based on Berkeley's RISC II architecture). First successful Icommercial RISC computer.

1985 1986 1987

# History of RISC Development The 90s IIBM introduces de Power architecture (R6000 microprocessor). Digital introduces Alpha, the fastest microprocessor then. Die relatively soon. PowerPC is born. Developed by Apple, IBM, Motorola consortion | Hitachi introduces the SH-1 (Super H), a 16 bit microprocessor. | Atmel introduces the first AVR microprocessor, an 8-bit architecture developed by Alf-Egil Bogen[2] and Vegard Wollan, students of the Norwegian Institute of Technology. 1990 1992 1994 1997

# The most successful, alive and well: One British (ARM) Three from USA (MIPS, PowerPC and Power) One Norwegian (Atmel AVR) One Japannese (Hitachi SuperH) Most with 64-bit architectures.

# Microprocessor Applications ARM PALM, Nintendo DS, Game Boy Advance, iPhone, iPod Touch, iPad, iPhone, Android smart phone MIPS PlayStation Portable and routers PowerPC Playstation 3, Xbox 360 y Wii, IBM Sequuia Hitachi SuperH Consumer electronics Atmel AVR Xbox handheld controllers and BMW cars IBM R6000 servers and supercomputers

# Understand the difference between the original RISC and CISC principles. Knowthe key characteristics of the RISC I architectures Name the pioneer RISC architectures and the first commercial RISC microprocessors and their developers. Name some of the contemporary commercial RISC microprocessors. Knowthe fundamental characteristics that contemporary RISC architectures preserve (What's left). Have a good idea of the timeline of the development of RISC architectures.