# ECE 3400 Guest Lecture Design Principles and Methodologies in Computer Architecture

**Christopher Batten** 

Computer Systems Laboratory School of Electrical and Computer Engineering Cornell University

Spring 2014



**Design Methodologies** 

### The Computer Engineering Stack



## The Computer Engineering Stack



Sort an array of numbers 2,6,3,8,4,5 -> 2,3,4,5,6,8

#### Insertion sort algorithm

- 1. Find minimum number in input array
- 2. Move minimum number into output array
- 3. Repeat steps 1 and 2 until finished

#### C implementation of insertion sort

```
void isort( int b[], int a[], int n ) {
  for ( int idx, k = 0; k < n; k++ ) {
    int min = 100;
    for ( int i = 0; i < n; i++ ) {
        if ( a[i] < min ) {
            min = a[i];
            idx = i;
            }
        }
        b[k] = min;
        a[idx] = 100;
    }
}</pre>
```

## The Computer Engineering Stack

| Computer Architecture | Application                  |
|-----------------------|------------------------------|
|                       | Algorithm                    |
|                       | Programming Language         |
|                       | Operating System             |
|                       | Instruction Set Architecture |
|                       | Microarchitecture            |
|                       | Register-Transfer Level      |
|                       | Gate Level                   |
|                       | Circuits                     |
|                       | Devices                      |
|                       | Technology                   |
|                       |                              |

#### Mac OS X, Windows, Linux Handles low-level hardware management



#### **MIPS32 Instruction Set**

Instructions that machine executes

| blez      | \$a2, | done       |
|-----------|-------|------------|
| move      | \$a7, | \$zero     |
| <b>li</b> | \$t4, | 99         |
| move      | \$a4, | \$a1       |
| move      | \$v1, | \$zero     |
| li        | \$a3, | 99         |
| lw        | \$a5, | 0(\$a4)    |
| addiu     | \$a4, | \$a4, 4    |
| slt       | \$a6, | \$a5, \$a3 |
| movn      | \$v0, | \$v1, \$a6 |
| addiu     | \$v1, | \$v1, 1    |
| movn      | \$a3, | \$a5, \$a6 |

What is Computer Architecture?

**Design Methodologies** 

## The Computer Engineering Stack



## What is Computer Architecture?



#### **Application Requirements**

- Suggest how to improve architecture
- Provide revenue to fund development

Computer architects provide feedback to guide application and technology research directions

#### **Technology Constraints**

- Restrict what can be done efficiently
- New technologies make new arch possible

In its broadest definition, computer engineering is the development of the abstraction/implementation layers that allow us to execute information processing applications efficiently using available manufacturing technologies

### **Computer Architecture in the ECE/CS Curriculum**



CS 4410 Operating Systems

CS 4420 Compilers

ECE 3140 Embedded Systems

ECE 4750 Computer Architecture

ECE 2300 Digital Logic & Computer Org ECE 4740 Digital VLSI Design

#### Related Graduate Courses

- ECE 5760 Advanced Microcontroller Design
- ECE 5750 Advanced Computer Architecture
- ECE 5730 Memory Systems
- ECE 5770 Resilient Computer Systems
- ECE 5745 Complex Digital ASIC Design
- ECE 5775 High-Level Design Automation

## Logic, State, and Interconnect



Digital systems are implemented with three basic building blocks

- Logic to process data
- State to store data
- Interconnect to move data

### **Processors, Memories, and Networks**



In computer architecture we more generally think of using

- Processors for computation
- Memories for storage
- Networks for communication







## What is Computer Architecture?

## Design Example

μArch

OS

ISA

**Design Principles** 



Gates

Circuits

Devices

Technology

**Design Methodologies** 

ECE 3400

### What do computer architects actually do?





## Example Design Problem: On-Chip Interconnection Network

- Intel Sandybridge E Server-Class Processor
- 435 mm<sup>2</sup> in 32 nm technology with 2.27B transistors running at several GHz
- Eight cores and eight memory banks with an on-chip ring network









## Modeling in Computer Architecture



### Student-Based "Model" of On-Chip Network

- Processor/Memory Student hands packets to appropriate router based on routing algorithm; waits to receive two packets from some other tile, and then raises hand.
- CCW/CW Network Routers Student holds onto packets and hands them to the correct channel; if packet for that router's tile arrives, then hand packet to processor/memory.
- CCW/CW Network Channels Student walks one packet at a time from upstream router to downstream router.





Algorithm

PL

OS

ISA

## Agenda

What is Computer Architecture?

Design Example

μArch

**Design Principles** 

RTL

Gates

Circuits





**Design Methodologies** 

### **Design Principle: Modularity**

- Decompose into components with well-defined interfaces
- A modular router design can be decomposed into a control unit and a datapath interconnected with control/status signals



## **Design Principle: Hierarchy**

- Recursively apply modularity principle
- A hierarchical network design can be decomposed into routers, which is in turn decomposed into a control unit and datapath, which is in turn decomposed into queues, muxes, and registers



## **Design Principle: Encapsulation**

- Hide implementation details from interfaces
- An encapsulated router design can hide the latency of the router microarchitecture along with any details related to stalls due to full queues or arbitration



**Design Methodologies** 

## **Design Principle: Regularity**

- Leverage structure at various levels of abstraction
- A regular router design can exploit logical structure to enable a single router to be instantiated eight times
- A regular network and router design can exploit physical structure to simplify the chip floorplan and layout



## **Design Principle: Extensibility**

- Include mechanisms/hooks to simplify future changes
- An extensible network and router design can enable easily implementing ring networks with various numbers of routers
- An extensible network and router design can enable easily changing the routing algorithm



## **Design Principles in Computer Architecture**

- Modularity Decompose into components with well-defined interfaces
- Hierarchy Recursively apply modularity principle
- Encapsulation Hide implementation details from interfaces
- Regularity Leverage structure at various levels of abstraction
- Extensibility Include mechanisms/hooks to simplify future changes



PL

OS

ISA

## Agenda

What is Computer Architecture?

**Design Example** 

μArch

**Design Principles** 



Gates

Circuits

Devices

Technology

**Design Methodologies** 



Design Methodologies 

## Waterfall Development Methodology

- Traditional sequential development methodology; each stage is completed before beginning the next stage
- For example, most of the design is completed before beginning the development, and most of the development is completed before beginning testing



Design Methodologies 

## Agile Development Methodology

- Emerging iterative development methodology; move rapidly through all stages and then iterate back again through the stages
- For example, a component is designed, developed, and tested before moving onto another component; or a minimal yet complete system is designed, developed, and tested before incrementally adding features



## **Agile Argues for Incremental Development**



## **Agile Argues for Test-Driven Development**

#### Test Types

- Unit tests vs. integration tests
- Directed vs. random tests
- Whitebox vs. blackbox tests
- Goal is to write tests first then implement design to pass these tests



- Write tests for higher level of abstraction, refine implementation until passes tests, add new tests
- Capture design bugs with new tests

#### Waterfall vs. Agile Development Methodologies

| Waterfall Methodology        | Agile Methodology          |
|------------------------------|----------------------------|
| Highly critical requirements | Less critical requirements |
| Less experienced engineers   | More experienced engineers |
| Requirements change rarely   | Requirements change often  |
| Large engineering team       | Small engineering team     |

A hybrid approach that includes aspects of both the traditional waterfall methodology and the emerging agile methodology is an attractive option for future hardware design projects.

Application

Algorithm

PL

OS

ISA

μArch

RTL

Gates

Circuits

Devices

Technology

## **Take-Away Points**

- Computer engineering is an iterative process involving designing and modeling systems, evaluating trade-offs between various design alternatives, which in turn motivates designing and modeling new systems
- Design principles such as modularity, hierarchy, modularity, encapsulation, regularity, and extensibility and design methodologies such as waterfall and agile hardware development can help manage the significant complexity inherent in building modern computing systems

## **ECE 4750 Computer Architecture**

http://www.csl.cornell.edu/courses/ece4750

- Part 1: Fundamental Processors FSM processors; pipelined processors; structural, data, and control hazards
- Part 2: Fundamental Memories memory technology; cache hierarchies; pipelined cache microarchitecture
- Part 3: Fundamental Networks torus and butterfly topologies; routing algorithms; flow control; pipelined router microarchitecture



- Part 4: Advanced Processors superscalar execution; branch prediction; out-of-order execution; register renaming; memory disambiguation; VLIW, vector, and multithreaded processors
- Part 5: Advanced Memories non-blocking caches; memory coherence, synchronization, consistency; memory translation, protection, virtualization