Zim Brightwood
Quiz por , criado more than 1 year ago

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

51
0
0
Zim Brightwood
Criado por Zim Brightwood aproximadamente 8 anos atrás
Fechar

[Final Study] Unit 2 Pipelined CPU

Questão 1 de 49

1

Throughput is

Selecione uma das seguintes:

  • 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

Explicação

Questão 2 de 49

1

Latency is

Selecione uma das seguintes:

  • 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

Explicação

Questão 3 de 49

1

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

Selecione uma das seguintes:

  • 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

Explicação

Questão 4 de 49

1

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

Arraste e solte para completar o texto.

    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

Explicação

Questão 5 de 49

1

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

Arraste e solte para completar o texto.

    in flight
    executing
    latent
    active
    retired
    finished
    complete
    ready

Explicação

Questão 6 de 49

1

The pipeline instructions are executed in order

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 7 de 49

1

Instruction-level parallelism exists between a pair of instructions if

Selecione uma das seguintes:

  • their execution order does not matter

  • their execution order matters

Explicação

Questão 8 de 49

1

The pipeline requires some parallelism

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 9 de 49

1

Dependencies exist if execution order doesn't matter

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 10 de 49

1

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

Selecione uma das seguintes:

  • 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;

Explicação

Questão 11 de 49

1

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

Selecione uma das seguintes:

  • 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;

Explicação

Questão 12 de 49

1

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

Selecione uma das seguintes:

  • 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;

Explicação

Questão 13 de 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.

Arraste e solte para completar o texto.

    Expressing
    Adding
    Mechanizing
    Conflating
    Eating
    Exploiting
    Removing
    Smelling
    Tangential Execution

Explicação

Questão 14 de 49

1

A pipeline hazard exists when

Selecione uma das seguintes:

  • 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

Explicação

Questão 15 de 49

1

We should detect pipeline hazards

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 16 de 49

1

Stalling is one way to handle pipeline hazards

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 17 de 49

1

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

Arraste e solte para completar o texto.

    pipeline stall
    pipeline bubble
    pipeline hazard
    pipeline stage
    pipeline overhead

Explicação

Questão 18 de 49

1

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

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 19 de 49

1

The only control hazards in the Y86 Pipeline are conditional jumps

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 20 de 49

1

To prevent a data hazard by stalling, we can

Selecione uma das seguintes:

  • 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

Explicação

Questão 21 de 49

1

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

Selecione uma das seguintes:

  • 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

Explicação

Questão 22 de 49

1

How would we resolve a return control hazard by stalling?

Selecione uma das seguintes:

  • 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

Explicação

Questão 23 de 49

1

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

Selecione uma ou mais das seguintes:

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

  • examines values across every stage

  • decides whether stage should stall or bubble

Explicação

Questão 24 de 49

1

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

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 25 de 49

1

Where does data forwarding forward its data to?

Selecione uma ou mais das seguintes:

  • D

  • W

  • M

  • E

  • F

Explicação

Questão 26 de 49

1

Where does data forward forward its data from?

Selecione uma ou mais das seguintes:

  • 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

Explicação

Questão 27 de 49

1

Which of these are data hazards?

Selecione uma ou mais das seguintes:

  • register-register hazard

  • load-use hazard

  • register-memory hazard

  • memory-memory hazard

  • use-use hazard

  • load-load hazard

Explicação

Questão 28 de 49

1

Which of these is a register-register hazard?

Selecione uma das seguintes:

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

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

Explicação

Questão 29 de 49

1

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

Selecione uma das seguintes:

  • 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

Explicação

Questão 30 de 49

1

Which of these is a load-use hazard?

Selecione uma das seguintes:

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

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

Explicação

Questão 31 de 49

1

How would we handle a load-use hazard?

Selecione uma das seguintes:

  • 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

Explicação

Questão 32 de 49

1

Jump prediction is not suitable for resolving conditional-jump hazards

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 33 de 49

1

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

Arraste e solte para completar o texto.

    E
    D
    M
    W

Explicação

Questão 34 de 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 .

Arraste e solte para completar o texto.

    not taken
    taken

Explicação

Questão 35 de 49

1

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

Selecione uma das seguintes:

  • 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

Explicação

Questão 36 de 49

1

The homework in this course is much too long

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 37 de 49

1

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

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 38 de 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)

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 39 de 49

1

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

Selecione uma ou mais das seguintes:

  • 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

Explicação

Questão 40 de 49

1

The compiler cares about the ISA's jump predictions

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 41 de 49

1

How do we optimize handling the return hazard?

Selecione uma das seguintes:

  • 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

Explicação

Questão 42 de 49

1

Y86 has indirect jumps

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 43 de 49

1

Indirect jumps are needed for polymorphic dispatch

Selecione uma das opções:

  • VERDADEIRO
  • FALSO

Explicação

Questão 44 de 49

1

CPI =

Selecione uma das seguintes:

  • totalCycles / instructionRetiredCycles

  • instructionRetiredCycles / totalCycles

Explicação

Questão 45 de 49

1

What are the tendencies of deeper pipelines?

Selecione uma ou mais das seguintes:

  • reduce clock period

  • increase CPI

  • makes stalling harder to avoid

Explicação

Questão 46 de 49

1

Which of these are attributes of super-scalar?

Selecione uma ou mais das seguintes:

  • 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?

Explicação

Questão 47 de 49

1

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

Selecione uma ou mais das seguintes:

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

  • CPU does fast switching between threads to hide memory latency

Explicação

Questão 48 de 49

1

What is multi-core?

Selecione uma ou mais das seguintes:

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

  • CPU's execute independent threads from possibly different processes

Explicação

Questão 49 de 49

1

How could Mike do this to us?

Selecione uma das seguintes:

  • Sadism

  • Also sadism

  • And sadism

  • All of the above

Explicação