Very short answer questions. You must use 10 or fewer words. "True" and "False" are considered very short answers.

Similar documents
Very short answer questions. You must use 10 or fewer words. "True" and "False" are considered very short answers.

Very short answer questions. You must use 10 or fewer words. "True" and "False" are considered very short answers.

(1) Using a different mapping scheme will reduce which type of cache miss? (1) Which type of cache miss can be reduced by using longer lines?

3. (2 pts) Clock rates have grown by a factor of 1000 while power consumed has only grown by a factor of 30. How was this accomplished?

Very short answer questions. "True" and "False" are considered short answers.

4. (2 pts) What is the only valid and unimpeachable measure of performance?

1. (10) True or False: (1) It is possible to have a WAW hazard in a 5-stage MIPS pipeline.

Short Answer: [3] What is the primary difference between Tomasulo s algorithm and Scoreboarding?

ECE 313 Computer Organization FINAL EXAM December 14, This exam is open book and open notes. You have 2 hours.

2. (3 pts) There are two different ways to measure performance. What are they? 3. (3 pts) Why doesn t MIPS have a subtract immediate instruction?

Processor: Multi- Cycle Datapath & Control

THE HONG KONG UNIVERSITY OF SCIENCE & TECHNOLOGY Computer Organization (COMP 2611) Spring Semester, 2014 Final Examination

RISC Processor Design

CPE 335. Basic MIPS Architecture Part II

ECE369. Chapter 5 ECE369

Microprogramming. Microprogramming

Lecture 5 and 6. ICS 152 Computer Systems Architecture. Prof. Juan Luis Aragón

CO Computer Architecture and Programming Languages CAPL. Lecture 18 & 19

LECTURE 6. Multi-Cycle Datapath and Control

RISC Architecture: Multi-Cycle Implementation

RISC Architecture: Multi-Cycle Implementation

Inf2C - Computer Systems Lecture 12 Processor Design Multi-Cycle

Topic #6. Processor Design

Chapter 4. The Processor

Points available Your marks Total 100

CSE 2021 COMPUTER ORGANIZATION

CSE 2021 COMPUTER ORGANIZATION

RISC Design: Multi-Cycle Implementation

Multi-cycle Approach. Single cycle CPU. Multi-cycle CPU. Requires state elements to hold intermediate values. one clock cycle or instruction

COMPUTER ORGANIZATION AND DESIGN. 5 th Edition. The Hardware/Software Interface. Chapter 4. The Processor

Chapter 4. Instruction Execution. Introduction. CPU Overview. Multiplexers. Chapter 4 The Processor 1. The Processor.

ALUOut. Registers A. I + D Memory IR. combinatorial block. combinatorial block. combinatorial block MDR

CC 311- Computer Architecture. The Processor - Control

Processor (I) - datapath & control. Hwansoo Han

4. What is the average CPI of a 1.4 GHz machine that executes 12.5 million instructions in 12 seconds?

Major CPU Design Steps

Initial Representation Finite State Diagram. Logic Representation Logic Equations

ECE 3056: Architecture, Concurrency and Energy of Computation. Single and Multi-Cycle Datapaths: Practice Problems

COMPUTER ORGANIZATION AND DESIGN. 5 th Edition. The Hardware/Software Interface. Chapter 4. The Processor

CS232 Final Exam May 5, 2001

Mapping Control to Hardware

Implementing the Control. Simple Questions

COMPUTER ORGANIZATION AND DESIGN. The Hardware/Software Interface. Chapter 4. The Processor: A Based on P&H

Systems Architecture I

ﻪﺘﻓﺮﺸﻴﭘ ﺮﺗﻮﻴﭙﻣﺎﻛ يرﺎﻤﻌﻣ MIPS يرﺎﻤﻌﻣ data path and ontrol control

Control Unit for Multiple Cycle Implementation

Computer and Information Sciences College / Computer Science Department Enhancing Performance with Pipelining

The Processor. Z. Jerry Shi Department of Computer Science and Engineering University of Connecticut. CSE3666: Introduction to Computer Architecture

Chapter 5 Solutions: For More Practice

ENE 334 Microprocessors

3/12/2014. Single Cycle (Review) CSE 2021: Computer Organization. Single Cycle with Jump. Multi-Cycle Implementation. Why Multi-Cycle?

The Processor: Datapath & Control

Beyond Pipelining. CP-226: Computer Architecture. Lecture 23 (19 April 2013) CADSL

Chapter 4. The Processor

ECE 313 Computer Organization FINAL EXAM December 11, Multicycle Processor Design 30 Points

Chapter 4 The Processor (Part 2)

COMPUTER ORGANIZATION AND DESIGN The Hardware/Software Interface. 5 th. Edition. Chapter 4. The Processor

COMPUTER ORGANIZATION AND DESIGN

Multicycle Approach. Designing MIPS Processor

Chapter 4 The Processor 1. Chapter 4A. The Processor

COMPUTER ORGANIZATION AND DESIGN

LECTURE 3: THE PROCESSOR

Instruction Level Parallelism. Appendix C and Chapter 3, HP5e

COSC 6385 Computer Architecture - Pipelining

CSE 2021: Computer Organization Fall 2010 Solution to Assignment # 3: Multicycle Implementation

CS 351 Exam 2, Fall 2012

Pipelining. CSC Friday, November 6, 2015

Full Datapath. Chapter 4 The Processor 2

Chapter 5: The Processor: Datapath and Control

Single vs. Multi-cycle Implementation

COMP303 - Computer Architecture Lecture 10. Multi-Cycle Design & Exceptions

Digital Design & Computer Architecture (E85) D. Money Harris Fall 2007

COMPUTER ORGANIZATION AND DESI

Lets Build a Processor

ECE 30, Lab #8 Spring 2014

Department of Computer and IT Engineering University of Kurdistan. Computer Architecture Pipelining. By: Dr. Alireza Abdollahpouri

Computer Organization and Structure. Bing-Yu Chen National Taiwan University

Chapter 4. The Processor. Computer Architecture and IC Design Lab

Week 4: Assignment Solutions

EECS150 - Digital Design Lecture 10- CPU Microarchitecture. Processor Microarchitecture Introduction

EECS 151/251A Fall 2017 Digital Design and Integrated Circuits. Instructor: John Wawrzynek and Nicholas Weaver. Lecture 13 EE141

Perfect Student CS 343 Final Exam May 19, 2011 Student ID: 9999 Exam ID: 9636 Instructions Use pencil, if you have one. For multiple choice

Computer Science 324 Computer Architecture Mount Holyoke College Fall Topic Notes: Data Paths and Microprogramming

Note- E~ S. \3 \S U\e. ~ ~s ~. 4. \\ o~ (fw' \i<.t. (~e., 3\0)

Multiple Instruction Issue. Superscalars

CS232 Final Exam May 5, 2001

EECS150 - Digital Design Lecture 9- CPU Microarchitecture. Watson: Jeopardy-playing Computer

Chapter 4. The Processor

Processor (multi-cycle)

CS 61C: Great Ideas in Computer Architecture Pipelining and Hazards

CS3350B Computer Architecture Quiz 3 March 15, 2018

Pipelining. Ideal speedup is number of stages in the pipeline. Do we achieve this? 2. Improve performance by increasing instruction throughput ...

EE557--FALL 1999 MAKE-UP MIDTERM 1. Closed books, closed notes

Computer Architecture Computer Science & Engineering. Chapter 4. The Processor BK TP.HCM

Final Exam Fall 2007

Determined by ISA and compiler. We will examine two MIPS implementations. A simplified version A more realistic pipelined version

Pipelined Processor Design

Processor Design Pipelined Processor (II) Hung-Wei Tseng

ECS 154B Computer Architecture II Spring 2009

Alternative to single cycle. Drawbacks of single cycle implementation. Multiple cycle implementation. Instruction fetch

Transcription:

Very short answer questions. You must use 10 or fewer words. "True" and "False" are considered very short answers. [1] Does peak performance track observed performance? [1] Predicting the direction of a branch is not enough. What else is necessary? [1] Using a different mapping scheme will reduce which type of cache miss? [1] Which type of cache miss can be reduced by using longer lines? [1] Which type of cache miss can be reduced by using shorter lines? [1] If we simply make transistors and wires smaller and smaller but make no other changes to the design, what happens to the power density? [2] There are two main ways to define performance - what are they? [2] What are the two instructions used in RISC machines to support atomicity? [2] What is the main difference between a commodity cluster and a custom cluster? [2] Superscalar and VLIW are 2 ways to increasing ILP. What is the primary difference between them? [2] Give a one-word definition of coherence, and a one-word definition of consistency. -1-

Short Answers (20 or fewer words) [2] Over the years, clock rates have grown by a factor of 1000 while power consumed has only grown by a factor of 30. How was this accomplished without melting the chip? [2] What is a benchmark program? [2] Do benchmark programs remain valid indefinitely? Why orwhy not? [2] Why isitdifficult to come up with benchmarks that will work across all classes of parallel processors? [2] Speculation is a very useful technique for improving performance. However, it is not being used as extensively as it once was - why not? [2] Which is easier to write a program for, ashared memory machine or a message passing machine? Why? [2] Which is more expensive to build - a shared memory machine, or a message passing machine? Why? -2-

[3] Vector machines are an example of a SIMD style of parallel processing. They feature instructions that look like VR0 = VR1 + VR2. Explain briefly what a vector register is, and why these machines are able to fetch and decode many fewer instructions than a tradition processor does. Use pictures if that will help get your point across. [2] What is the definition of a basic block? Why isthere a desire to create a bigger one? [2] MIMD parallel processors are very flexible and cost-effective. However, there are two major challenges to obtaining a substantial decrease in response time when using this approach. What are they? [2] Why is it so difficult for the processing elements on a CMOS-based chip to communicate with things that located off the chip? [3] Supporting precise interrupts in a machine that allows out of order completion is a challenge. What is the definition of a precise interrupt? Why is it important to support them? What hardware structure do modern machines use to accomplish this? -3-

[2] An important program spends 20% of its time doing memory operations (loads and stores). By redesigning the memory hierarchy you can make the memory operations 90% faster (take 10% as long), or you can redesign the hardware to make the rest of the machine 20% faster (take 80% as long). Which should you do and why? (You must show your work to get full credit.) [2] Youare responsible for designing a new embedded processor, and for a variety of reasons you must use a fixed 24 bit instruction size and you must support at least 64 different opcodes. You would like touse a 3-operand instruction format, and have 128 registers. If it is possible to do this, draw what an instruction would look like. If it is not possible explain why, and give at least 2 different ways to solve the problem. [4] The CPI of the Derpster 9000 is 2, assuming a perfect memory system (all references to memory take a single cycle.) Unfortunately, wemust use a more realistic memory system - an instruction cache with a miss rate of 3% and a miss penalty of 100 cycles, and a data cache with a miss rate of 20% and a miss penalty of 100 cycles. If 30% of all instructions are loads or stores, what does the CPI become in this case? [3] What do the following acronyms stand for? SMT SIMD NUMA WAW VLIW SMP -4-

[10] For each technique in the following table, indicate how (on average) the 3 terms of the AMAT equation are affected (assume there is a single L1 cache). The first one is done as an example. (Decreases = "-" or "V"; Increases = "+" or "/\"; leave blank if unaffected). Technique Hit Time Miss Rate Miss Penalty Increasing Line/Block Size - + Increasing Associativity Decreasing Cache Size Hardware Prefetching Compiler Optimizations (excluding prefetch) Non-blocking Cache Virtually Addressed Cache Victim Cache (victim cache and regular cache accessed in parallel) [4] In your first design of a 5-stage pipeline (F,D,E,M,W) F takes 23 time units, D takes 26, E takes 27, M takes 48 and W takes 26. a) What will the clock cycle time be for this pipeline? b) Is it a balanced pipeline? If not, explain what you could do to make itmore balanced. What would the cycle time be now? [6] You have been writing C programs for a high performance, non-pipelined machine. You have recently received apromotion, and now your job is to write C programs for a heavily pipelined, high performance processor. These new programs must execute as fast as possible (the emphasis is on response time, not throughput). Give at least 3 examples of things you should do differently now, and be sure to explain in detail why (what is the problem you are overcoming?) -5-

[7] The MIPS implementation we used in class has a 5-stage pipeline, writes to the register file during the first half of the cycle and reads during the second half, and uses both a branch delay slot and a load delay slot. If the machine is redesigned to be an 8-stage pipeline, with the following stages: F D E1 E2 M1 M2 WB a) Assuming this machine has a branch predictor and the branch condition is calculated by the end of the D stage, how big is the branch penalty (measured in cycles) when the prediction is incorrect? What if the branch condition is not calculated until the end of E2? b) How many load delay slots would this machine need (assuming it has forwarding logic and you are forwarding to E1) assuming the memory returns the value by the end of M3? M2? c) What type of data hazard does the above pipeline need to worry about? d) If the above pipeline were modified to support out of order completion, what new data hazard would be introduced? e) If in addition to completing out of order, instructions were allowed to issue out of order, what new data hazard would be introduced? -6-

[2] Assuming a 23-bit address and a 1k-byte Direct Mapped cache with a linesize=4, show how an address is partitioned/interpreted by the cache. [3] Assuming a 23-bit address and a 128-byte 4-way SA cache with a linesize=8, show how an address is partitioned/interpreted by the cache. [2] Assuming a 34-bit address and a 536-byte FA cache with a linesize=4, show how an address is partitioned/interpreted by the cache. [4] Given a 1 Gigabyte physical memory, a 44 bit Virtual address, and a page size of 2K bytes, write down the number of entries in the Page Table, and the width of each entry. Isthere a problem with this configuration? If so, how can you fix it? -7-

In this question, we are going to wire up a 12-bit processor. The machine is word-addressable, where a word is 12 bits. Immediates are sign extended, Offset is not. The machine has 3 different instruction formats: R, I, and J. Memory takes a single cycle to return a value. R-type: (Arithmetic and logical: rd =rs1 OP rs2) Opcode rd rs1 rs2 funct 11-8 7-6 5-4 3-2 1-0 I-type: (Arithmetic and logical: rd =rs1 OP Immediate) (Load: rd =mem[rs1+immediate]) (Store: mem[rs1+immediate]=rd) (Branch: if (rd OPrs1)=COND, PC=PC+Immediate) Opcode rd rs1 Immediate 11-8 7-6 5-4 3-0 J-type: (Jump: PC =Offset) Opcode Offset 11-8 7-0 The ALU can perform 4 functions, written this way: OP [ALU1 ALU0] XOR [11], ADD [10], AND [01], OR [00] Here are some of the instructions that have been defined: Name Opcode(Funct) Name Opcode(Funct) Name Opcode(Funct) NOP 0000(00) lw 0001(xx) sw 0011(xx) NOT 1000(00) BEQZ 0100(xx) j 0101(xx) AND 1000(01) AND Imm 1001(xx) ADD 1100(01) OR 1000(10) OR Imm 1010(xx) ADD Imm 1101(xx) XOR 1000(11) XOR Imm 1011(xx) SUB 1100(01) Here are the control signals. PCin IRin MDRin MARin Zin RDin Imm PCoutB1 PCoutB2 IRout MDRout Zout RDoutB2 RS1outB1 RS2outB2 MemRead MemWrite #0out #1out ALU0 ALU1-8-

Here is a diagram of the machine. Register File RDoutB2 PCin PCoutB1 PCoutB2 PC IRout IR IRin IR[5 4] IR[3 2] IR[7 6] Src 1 Src 2 Dest RS1outB1 RS2outB2 RDin #0 #0out #1 #1out 0000 11 8 7 0 12 B1 MDRin 12 3 0 B2 MDR MAR MARin SE MDRout Imm 1 (mux) 0 Instruction/Data Memory MemRead MemWrite ALU0 ALU1 ALU Zin Z Zout [6] Fill in the microcode steps necessary to perform an instruction fetch (incrementing the PC is considered part of fetch). Assume the memory can respond in a single cycle. 12 S P I M M R Z I P P M Z R R R # # A A M M I t C R A D D i R C C D o D S S 0 1 L L r e m e i i R R i n o o o R u o 1 2 o o U U e m m p n n i i n u u u o t u o o u u 1 0 a W n n t t t u t u u t t d r B B t B t t i 1 2 2 B B t 1 2 e 0 1 2 3 4-9-

[6] Now that you have done the instruction fetch, fill in the microcode steps necessary to perform the following instruction: SW R3, -4(R2) S P I M M R Z I P P M Z R R R # # A A M M I t C R A D D i R C C D o D S S 0 1 L L r e m e i i R R i n o o o R u o 1 2 o o U U e m m p n n i i n u u u o t u o o u u 1 0 a W n n t t t u t u u t t d r B B t B t t i 1 2 2 B B t 1 2 e 0 1 2 3 4 [8] Your company is considering adding a register indirect mode to this machine. It would work as follows: rd = mem[mem[rs1+immediate]], and brackets would be used to indicate the addressing mode should be used. Given this information, write the microcode for this new instruction: LW R1, [8(R0)] S P I M M R Z I P P M Z R R R # # A A M M I t C R A D D i R C C D o D S S 0 1 L L r e m e i i R R i n o o o R u o 1 2 o o U U e m m p n n i i n u u u o t u o o u u 1 0 a W n n t t t u t u u t t d r B B t B t t i 1 2 2 B B t 1 2 e 0 1 2 3 4 5-10-

Here is the state diagram for a "random" machine: 0 ALUSrcB=01, MemRead, IRWrite PCWrite 2 ALUSrcB=10, ALUSrcA Opcode=0101 3 MemRead, IorD Opcode=01x1 Opcode=0111 Opcode=1001 9 PCSource=10, PCWrite 5 MemWrite, IorD 1 ALUSrcB=11 Op=11x1 Opcode=0010 6 ALUOp=10, ALUSrcA 7 RegWrite, RegDst 8 ALUSrcA, PCWriteCond, PCSource=01, ALUOp=01 4 MemtoReg, RegWrite [3] Assuming there are 4 state variables (Y3-Y0), that State0 = Y3*Y2*Y1*Y0 (0000) and State15 = Y3*Y2*Y1*Y0 (1111), write down the exact boolean equation for the PCWrite signal. [2] Assuming the same situation as in the previous question, write down the exact boolean equation for NextState9. [2] If you were to use a simple, unoptimized microcode memory to implement the 16 control signals for this machine, how big would it be? (how many entries, how wide is each entry?) -11-

[5] Here is a code sequence. load R1, 0(R10) store R1, 4(R10) sub R1, R2, R3 load R4, 10(R8) a) Indicate all dependencies (draw lines/arrows between them, and write beside each line/arrow which hazard is involved). b) There are things the static scheduler does not know which makes guaranteeing correctness difficult. What if, at execution time, R10=40 and R8=34? Will your dependency graph and ability to schedule this code change? If so, explain/show how. [2] Look at the figure below, then write below each machine if it uses a message passing or a shared memory design. Memory Interconnection Network Interconnection Network Mem Mem Mem Mem $ $ $ $ $ $ $ $ CPU CPU CPU CPU CPU CPU CPU CPU Design Approach A Design Approach B -12-

[14] Here is a code sequence. and R10, R7, R4 load R2, 0(R10) add R3, R2, R6 sub R9, R7, R9 add R9, R4, R7 Assuming a standard 5-stage pipeline that does not support hazard detection and does no forwarding, a) Indicate all dependencies (draw lines/arrows between them, and write beside each line/arrow which hazard is involved). b) Insert as many No Operations (NOPS) as required in order to ensure this code runs correctly. (Remember, writes to the register file occur on the first half of the cycle, and reads occur during the second half). c) Circle the NOPs that can be removed ifforwarding and hazard detection logic is implemented. d) Assuming the pipeline has been modified so that it does support hazard detection and forwarding, schedule the code to remove as many stalls as possible. Assume there are no hazards through the memory system. How many NOPS are left? -13-

[10] Here is a code sequence. add R1, R2, R3 sub R1, R5, R1 xor R11, R12, R13 Label: lw R4, 0(R10) add R6, R6, R4 and R4, R8, R5 breq R5,R6,Label ;branch to Label if R5-R6=0 (R5=R6) Assuming a 7-stage pipeline (F,D,E1,E2,M1,M2,WB) that does not support hazard detection, does no forwarding, and does not use a branch delay slot, a) Indicate all dependencies (draw lines/arrows between them, and write beside each line/arrow which hazard is involved). b) Insert as many No Operations (NOPS) as required in order to ensure this code runs correctly. (Remember, writes to the register file occur on the first half of the cycle, and reads occur during the second half). c) Circle the NOPs that can be removed if forwarding and hazard detection logic is implemented. Assume data on a read returns at the end of M2, and is needed at the beginning of E1. Also assume that on an arithmetic instruction, data is ready at the end of E2, but not at the end of E1. d) Assuming the pipeline has been modified so that it does support hazard detection and forwarding, schedule the code to remove as many stalls as possible. Assume there are no hazards through memory. How many NOPS are left? -14-

[6] Suppose I have a 4-issue multithreaded machine, and there are 3 threads - A, B, and C. Assuming: The number of independent instructions Thread A can find (in order): 1, then 2, then 0, then 2 The number of independent instructions Thread B can find (in order): 1, then 2, then 3, then 1 The number of independent instructions Thread C can find (in order): 2, then 0, then 1, then 1 Fill in the following table if fine-grained scheduling is being used. Time Slot1 Slot2 Slot3 Slot4 0 1 2 3 Now fill in the following table assuming the use of course-grained scheduling. Time Slot1 Slot2 Slot3 Slot4 0 1 2 3 Now, repeat the process assuming simultaneous multithreading is being used. Time Slot1 Slot2 Slot3 Slot4 0 1 2 3-15-

[5] In class, we talked about the cycle by cycle steps that occur on different interrupts. For example, here is what happens if there is an illegal operand interrupt generated by instruction i (note this machine has a 7 stage pipeline and supports imprecise interrupts. RR stands for Register Read): 1 2 3 4 5 6 7 8 9 10 11 12 i IF ID RR EX M1 M2 WB <-Interrupt detected i+1 IF ID RR EX M1 M2 WB <- Instruction Squashed i+2 IF ID RR EX M1 M2 WB <- Trap Handler fetched i+3 IF ID RR EX M1 M2 WB i+4 IF ID RR EX M1 M2 WB Fill out the following table if for the same machine, instruction i+1 experiences a fault in the EX stage (page fault, for example): 1 2 3 4 5 6 7 8 9 10 i IF ID RR EX M1 M2 WB i+1 IF ID RR EX M1 M2 WB i+2 IF ID RR EX M1 M2 WB i+3 IF ID RR EX M1 M2 WB i+4 IF ID RR EX M1 M2 WB i+5 IF ID RR EX M1 M2 WB i+6 IF ID RR EX M1 M2 WB i+7 IF ID RR EX M1 M2 WB Assuming precise interrupts are being supported, what happens in this case? 1 2 3 4 5 6 7 8 9 10 i IF ID RR EX M1 M2 WB <-EXstage has page fault i+1 IF ID RR EX M1 M2 WB <- Inst Decode has Illegal Instruction i+2 IF ID RR EX M1 M2 WB i+3 IF ID RR EX M1 M2 WB <- IF stage has page fault i+4 IF ID RR EX M1 M2 WB i+5 IF ID RR EX M1 M2 WB i+6 IF ID RR EX M1 M2 WB i+7 IF ID RR EX M1 M2 WB What is the maximum number of exceptions that could happen at a single time in the above machine? Explain how you got your answer. -16-