Zim Brightwood
Quiz by , created more than 1 year ago

Unit 2 of UBC's CS313 course. Get some alcohol.

51
0
0
Zim Brightwood
Created by Zim Brightwood about 8 years ago
Close

[Final Study] Unit 2 Pipelined CPU

Question 1 of 49

1

Throughput is

Select one of the following:

  • the rate at which instructions leave the pipeline

  • total time it takes an instruction to be processed by a stage

  • the rate at which instructions move to the next register

  • total time it takes an instruction to be processed by the entire pipeline

Explanation

Question 2 of 49

1

Latency is

Select one of the following:

  • total time it takes an instruction to be processed by the entire pipeline

  • the rate at which instructions leave the pipeline

  • the rate at which instructions move to the next register

  • total time it takes an instruction to be processed by a stage

Explanation

Question 3 of 49

1

Pretend the pipeline is a cafeteria line in prison. Who is throughput and who is latency?

Select one of the following:

  • Throughput is the security guard concerned with how often people are leaving the line so nobody shanks anybody. Latency is BUBBA watching Skinny Pete make his way through the line so he can shank him after he gets his food.

  • Throughput is the warden watching the prisoners out in the field and latency is the secretary having an affair with the gardener *gasp*~

  • Throughput is the rate at which the soap leaves a prisoners hand in the showers and latency is the total time it takes to pick it up

Explanation

Question 4 of 49

1

Pipeline registers are placed , those registers store , each stage executes working on a different instruction

Drag and drop to complete the text.

    between each stage
    after each stage
    before each stage
    inputs for that stage
    outputs for that stage
    inputs for the next stage
    in parallel
    sequentially

Explanation

Question 5 of 49

1

And instruction is when it is currently being executed by the pipeline. Once the instruction completes the pipeline, it is .

Drag and drop to complete the text.

    in flight
    executing
    latent
    active
    retired
    finished
    complete
    ready

Explanation

Question 6 of 49

1

The pipeline instructions are executed in order

Select one of the following:

  • True
  • False

Explanation

Question 7 of 49

1

Instruction-level parallelism exists between a pair of instructions if

Select one of the following:

  • their execution order does not matter

  • their execution order matters

Explanation

Question 8 of 49

1

The pipeline requires some parallelism

Select one of the following:

  • True
  • False

Explanation

Question 9 of 49

1

Dependencies exist if execution order doesn't matter

Select one of the following:

  • True
  • False

Explanation

Question 10 of 49

1

Consider the variables a and b. A causal dependency is defined as A<B (Instruction A immediately precedes B) if

Select one of the following:

  • B reads value written by A
    Example:
    a = 1;
    b = a;

  • B write to visible location written by A
    Example:
    a = 1;
    a = 2;

  • B write to a location read by A
    Example:
    b = a;
    a = 1;

Explanation

Question 11 of 49

1

Consider the variables a and b. An output dependency is defined as A<B (Instruction A immediately precedes B) if

Select one of the following:

  • B write to visible location written by A
    Example:
    a = 1;
    a = 2;

  • B reads value written by A
    Example:
    a = 1;
    b = a;

  • B write to a location read by A
    Example:
    b = a;
    a = 1;

Explanation

Question 12 of 49

1

Consider the variables a and b. An anti dependency is defined as A<B (Instruction A immediately precedes B) if

Select one of the following:

  • B write to a location read by A
    Example:
    b = a;
    a = 1;

  • B reads value written by A
    Example:
    a = 1;
    b = a;

  • B write to visible location written by A
    Example:
    a = 1;
    a = 2;

Explanation

Question 13 of 49

1

parallelism is how the programmer tells the system that two pieces of code can execute in parallel. parallelism is the system actually executing two pieces of code in parallel.

Drag and drop to complete the text.

    Expressing
    Adding
    Mechanizing
    Conflating
    Eating
    Exploiting
    Removing
    Smelling
    Tangential Execution

Explanation

Question 14 of 49

1

A pipeline hazard exists when

Select one of the following:

  • the processor's execution would violate a data or control dependency

  • the processor's execution would support a data or control dependency

  • the processor's execution would cause a data or control dependency

  • the processor's execution would execute a data or control dependency

Explanation

Question 15 of 49

1

We should detect pipeline hazards

Select one of the following:

  • True
  • False

Explanation

Question 16 of 49

1

Stalling is one way to handle pipeline hazards

Select one of the following:

  • True
  • False

Explanation

Question 17 of 49

1

A is holding an instruction for an extra cycle.
A is when a pipeline stage is forced to do nothing.

Drag and drop to complete the text.

    pipeline stall
    pipeline bubble
    pipeline hazard
    pipeline stage
    pipeline overhead

Explanation

Question 18 of 49

1

The only data hazards in the Y86 Pipeline are causal hazards on register file

Select one of the following:

  • True
  • False

Explanation

Question 19 of 49

1

The only control hazards in the Y86 Pipeline are conditional jumps

Select one of the following:

  • True
  • False

Explanation

Question 20 of 49

1

To prevent a data hazard by stalling, we can

Select one of the following:

  • read registers in decode that are written by instructions in E, M, or W and then stall the instruction in decode until writer is retired

  • read registers in fetch that are written by instructions in E, M, or W and then stall the instruction in fetch until writer is retired

  • read registers in execute that are written by instructions in E, M, or W and then stall the instruction in execute until writer is retired

Explanation

Question 21 of 49

1

How would we resolve a conditional jump control hazard by stalling?

Select one of the following:

  • stall fetch until jump exits execute

  • stall execute until jump exits decode

  • stall fetch and execute until jump exits decode

  • stall fetch, decode, and execute until jump exits memory

  • stall fetch, decode, execute, and memory until jump exits write back

  • just stall everything after fetch indefinitely and go finish off a bottle of wine in one go

Explanation

Question 22 of 49

1

How would we resolve a return control hazard by stalling?

Select one of the following:

  • stall fetch until return exits memory

  • stall decode until return exits memory

  • stall fetch and decode until return exits memory

  • stall fetch, decode, and execute until return exits memory

  • stall fetch, decode, execute, and memory until return exits memory

  • return to cpsc313 in the summer after you fail this midterm

Explanation

Question 23 of 49

1

Check all the statements that are true about the pipeline-control module

Select one or more of the following:

  • it's a hardware component separate from the 5 stages

  • examines values across every stage

  • decides whether stage should stall or bubble

Explanation

Question 24 of 49

1

Data forwarding is a mechanism that forwards values from later pipeline stages to earlier ones

Select one of the following:

  • True
  • False

Explanation

Question 25 of 49

1

Where does data forwarding forward its data to?

Select one or more of the following:

  • D

  • W

  • M

  • E

  • F

Explanation

Question 26 of 49

1

Where does data forward forward its data from?

Select one or more of the following:

  • W - new value from memory or ALU

  • M - new value read from memory or from ALU

  • E - new value from ALU

  • D - new value from registers

  • F - new value from PC determined instruction

Explanation

Question 27 of 49

1

Which of these are data hazards?

Select one or more of the following:

  • register-register hazard

  • load-use hazard

  • register-memory hazard

  • memory-memory hazard

  • use-use hazard

  • load-load hazard

Explanation

Question 28 of 49

1

Which of these is a register-register hazard?

Select one of the following:

  • irmovl $1, %eax
    addl %eax, %ebx

  • irmovl $1, %ecx
    addl %eax, %ebx

Explanation

Question 29 of 49

1

How do we handle a register-register hazard with data forwarding?

Select one of the following:

  • forward to D from E, M, or W

  • forward to F from E, M, or W

  • stall one cycle, then forward to D from E, M, or W

  • stall one cycle, then forward to F from D, E, M, or W

  • stall one cycle, then forward to F from E, M, or W

  • forward to F from D, E, M, or W

Explanation

Question 30 of 49

1

Which of these is a load-use hazard?

Select one of the following:

  • mrmovl (esi), %eax
    addl %eax, %ebx

  • rmmovl %eax, (esi)
    addl %eax, %ebx

Explanation

Question 31 of 49

1

How would we handle a load-use hazard?

Select one of the following:

  • Stall use one cycle, forward to D from M or W

  • Stall use one cycle, forward to D from E or M

  • Stall use one cycle, forward to E from D, M, or W

  • Stall use one cycle, forward to E from M or W

Explanation

Question 32 of 49

1

Jump prediction is not suitable for resolving conditional-jump hazards

Select one of the following:

  • True
  • False

Explanation

Question 33 of 49

1

We know whether the jump is taken or not taken once the jump finishes in stage .

Drag and drop to complete the text.

    E
    D
    M
    W

Explanation

Question 34 of 49

1

valC is the address for the jump as if it were and valP is the address for the jump as if it were .

Drag and drop to complete the text.

    not taken
    taken

Explanation

Question 35 of 49

1

When a mis-predicted jump is in M, what should we do?

Select one of the following:

  • shootdown D and E to prevent them from doing damage

  • shootdown F and D to prevent them from doing damage

  • shootdown M and W to prevent them from doing damage

Explanation

Question 36 of 49

1

The homework in this course is much too long

Select one of the following:

  • True
  • False

Explanation

Question 37 of 49

1

We could avoid stalling in a load-use hazard by forwarding m.valM to the beginning of E

Select one of the following:

  • True
  • False

Explanation

Question 38 of 49

1

We could have one fewer bubble in a misprediction if we compute when conditional jump is in M, reading m.bch (the branch condition)

Select one of the following:

  • True
  • False

Explanation

Question 39 of 49

1

In regards to static jump prediction, what could the compiler know?

Select one or more of the following:

  • a jump's taken tendency

  • for loops, it can decide to use a continue condition or exit condition

  • for if statements it might be able to spot error tests

  • what it sees in the program text

Explanation

Question 40 of 49

1

The compiler cares about the ISA's jump predictions

Select one of the following:

  • True
  • False

Explanation

Question 41 of 49

1

How do we optimize handling the return hazard?

Select one of the following:

  • Keep a stack of return addresses for future use

  • Guess the return address based on the value in predPC

  • Guess the return address based on the value in PC

  • Guess the return address based on the valP in D

Explanation

Question 42 of 49

1

Y86 has indirect jumps

Select one of the following:

  • True
  • False

Explanation

Question 43 of 49

1

Indirect jumps are needed for polymorphic dispatch

Select one of the following:

  • True
  • False

Explanation

Question 44 of 49

1

CPI =

Select one of the following:

  • totalCycles / instructionRetiredCycles

  • instructionRetiredCycles / totalCycles

Explanation

Question 45 of 49

1

What are the tendencies of deeper pipelines?

Select one or more of the following:

  • reduce clock period

  • increase CPI

  • makes stalling harder to avoid

Explanation

Question 46 of 49

1

Which of these are attributes of super-scalar?

Select one or more of the following:

  • multiple pipelines that run in parallel

  • issue multiple instructions on each cycle

  • instructions execute in parallel and can even bypass each other

  • if I shut my eyes tight enough, will the midterm disappear?

Explanation

Question 47 of 49

1

What does hyper-threading consist of? (Only one of the following is correct)

Select one or more of the following:

  • OS loads multiple runnable threads into CPU, usually from the same process

  • CPU does fast switching between threads to hide memory latency

Explanation

Question 48 of 49

1

What is multi-core?

Select one or more of the following:

  • multiple CPUs per chip, each pipelined, super-scalar, etc

  • CPU's execute independent threads from possibly different processes

Explanation

Question 49 of 49

1

How could Mike do this to us?

Select one of the following:

  • Sadism

  • Also sadism

  • And sadism

  • All of the above

Explanation