## LE7.2.1 Pipeline Design

4/5 points (ungraded)

Consider the following combinational encryption device constructed from six modules:



The device takes an integer value, X, and computes an encrypted version C(X). In the diagram above, each combinational component is marked with its propagation delay in ns; contamination delays are zero for each component.

In answering the following questions assume that registers added to the circuit introduce no additional delays (i.e., the registers have a contamination and propagation delay of zero, as well as zero setup and hold times). Any modifications must result in a circuit that obeys our rules for a well-formed pipeline and that computes the same results as the combinational circuit above. Remember that our pipeline convention requires that every pipeline stage has a register on its output.

(A) What is the latency of the combinational encryption device?

Latency of device (ns): 9 ✓ Answer: 9

#### **Explanation**

Latency = delay along longest path from input to output = 2 + 3 + 4 = 9.

(B) If we want to increase the throughput of the encryption device, what is the minimum number of registers we need to add?

Explanation

Playing by our pipelining rules, we always add a register to the output. To increase the throughput, we need to add another contour that bisects the circuit. The cheapest place to do this is just before the "4" module, requiring two additional registers.

(C) If we are required to add exactly 5 registers, what is the best throughput we can achieve?

Maximum throughput (1/ns):

1/7

X Answer: 1/5

### Explanation

The best throughput we can achieve with 5 registers is 1/5: place 3 (!) registers on the output and two registers on the arcs leading to the "4" module. If we use 4 registers to divide the circuit between the "2" and "3" modules and place one on the output, the resulting throughput is 1/7.

(D) If we can add as many registers as we like, what is the upper bound on the throughput we can achieve?

Maximum throughput (1/ns):



✓ Answer: 1/4

### Explanation

1/4, because the best we can do by just adding registers is to segregate the "4" module into its own pipeline stage.

(E) If we can add as many registers as we like, what is the lower bound on the latency we can achieve?

Minimum latency (ns):



✓ Answer: 9

#### Explanation

Lower bound on latency = 9. We can never make the latency less by adding pipeline registers; usually the latency increases.

**Submit** 

**1** Answers are displayed within the problem

# LE7.2.2 Pipelining Combinational Logic

2 points possible (ungraded)

A combinational circuit C, built entirely from 2-input NAND gates having a propagation delay of 2 ns, has a propagation delay of 20 ns. You pipeline C for maximum throught using the minimum number of registers necessary; the registers have 1ns setup time and 1ns propagation delay. What would you expect for the latency of the resulting pipeline?

| Latency of pipelined version (ns):      |  |
|-----------------------------------------|--|
| Throughput of pipelined version (1/ns): |  |
| Submit                                  |  |

# LE7.2.3 Building a Pipeline

5 points possible (ungraded)

The top-secret diagram of the NSA's phone call tracking circuitry is shown below. We don't know what the boxes do, but we do know their  $t_{PD}$  (annotated inside each component) and how they are connected.

You've been hired to do a design study looking into pipelining the circuit above. Assume that the pipeline registers have  $t_{CD}=0$ ,  $t_{PD}=0$ ,  $t_{SETUP}=1$ ,  $t_{HOLD}=0$ . Recall that using our pipelining convention, each pipelined circuit must have at least 1 register on the P(X,Y,Z) signal.



What are the latency and throughput of a 1-pipeline implementation?

| Latency: |     |  |  |
|----------|-----|--|--|
|          |     |  |  |
| Throughp | ut: |  |  |

Add pipeline boundaries to the circuit, choosing the boundaries to achieve maximum throughput. Use the minimum number of registers necessary to achieve this throughput. Provide your answer by dragging the correct number of pipeline registers onto each of the dashed square boxes.



What are the latency and throughput of your pipelined circuit?

| Latency:    |  |
|-------------|--|
| Throughput: |  |
| Submit      |  |

# Discussion

Topic: 7. Performance Measures / LE7.2

**Hide Discussion** 

### **Add a Post**

| Sho                     | by recent activ                                                                                                                                                                                                                        | vity 🗸 |
|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| 2                       | If you need help  Watch this lecture if you need some help regarding methodology of pipelining https://nptel.ac.in/co                                                                                                                  | 2      |
| ?                       | registers on the input of NSA's whatever  I got the question right but this contrary to what we have already learned, i.e we learned not to put                                                                                        | 2      |
| Q                       | Why is it required to use a register in the final stage output of a pipeline?  I know it is required to use a register to remember the output in the pipeline middle stage, but why                                                    | 4      |
| <b>∀</b>                | Note that from every input to output path there must be exactly the same number of pipeline registers for your solution to be valid?  Why "Note that from every input to output path there must be exactly the same number of pipeline | 2      |
| <b>∀</b>                | [STAFF] How to calculate tclk and Tpd at various stages of pipelining?  I am absolutely confused on how to calculate Tclk and Tpd at various pipelining stagesNone of m                                                                | 2      |
| <b>∀</b>                | 7.2.1 c and d                                                                                                                                                                                                                          | 2      |
| <b>∀</b>                | [[STAFF]] No. of reg. in pipelining [[STAFF]] I can't figure out how we obtained number of registers during pipeline implementation                                                                                                    | 5      |
| 2                       | count  he best throughput we can achieve with 5 registers is 1/5: place 3 (!) registers on the output and t                                                                                                                            | 10     |
| <b>\( \rightarrow\)</b> | LE7.2.3 Pipelining                                                                                                                                                                                                                     | 5      |
| 2                       | TIS-100  The whole thing starts to look a lot like TIS-100:) I find pipelines to be fairly easy to understand aft                                                                                                                      | 2      |