## ECEn 528 Study Guide - ILP Limits

- Read Section 3.10 of H&P
  - O Things to focus on
    - Note in the middle of page 215 how the results in Figure 3.26 are explained using characteristics of the benchmarks. This is good practice
    - Section 3.10 is **very** important to understand
    - Figure 3.27 makes the situation look fairly bleak for ILP; it's actually worse because cache misses and non-unit latencies haven't been taken into account
  - O Clarifications
    - In Figure 3.26, what is being measured is the instructions per cycle (IPC) for the "perfect" processor.
    - Remember that when H&P say "issue", we say "dispatch"
  - O Answer the following questions:
    - 1. Why is the IPC for a perfect processor so low in Figure 3.26? What is the limiting factor?
    - 2. Why does restricting the window size have such a large effect on programs such as tomcaty?
    - 3. Why does imperfect branch prediction limit available ILP?
    - 4. How could compiler improvements relax some of the limits found in this limit study?

| Re<br>O | <ul> <li>ead "Loose Loops Sink Chips,"</li> <li>Things to focus on</li> <li>You need read only sections 1 - 3</li> <li>This idea of loops is a very powerful way about thinking about design decisions when trying to determine the number of stages</li> </ul> |                                                                                                                                                                                                                   |  |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0       | Cla                                                                                                                                                                                                                                                             | You should refer to Figure 2 for the pipeline diagram while reading section 1, but Figure 3 while reading sections 2 and 3.  The dispatch step is called DEC-IQ and the issue step is called IQ-EX in this paper. |  |
| 0       | An                                                                                                                                                                                                                                                              | swer the following questions:                                                                                                                                                                                     |  |
|         | 1.                                                                                                                                                                                                                                                              | Why are loose loops a problem?                                                                                                                                                                                    |  |
|         | 2.                                                                                                                                                                                                                                                              | Register renaming can be thought of as a scheme which changes a frequent loose loop to an infrequent one. In what way is this so?                                                                                 |  |
|         | 3.                                                                                                                                                                                                                                                              | Why is pipelining dispatch less of an problem than pipelining issue?                                                                                                                                              |  |
|         | 4.                                                                                                                                                                                                                                                              | How does forwarding tighten a loose loop?                                                                                                                                                                         |  |
|         |                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                   |  |