



- 1. Basic Functionality
  - O Issue queue
  - @ Hazard cheek
- 2. Basic Blocks.

a. Issue queve



control eignel

The issue queue has 16 entries. It contains several points.



#### b. Hazard Checker



In I



# Stage 1 (3)

c. control logic



Truth Table:

|           | Entry    | Select            |  |  |
|-----------|----------|-------------------|--|--|
| 3-bit fee | dback    | selected entries. |  |  |
| 0 0       | • 0      | 1,2,3,4           |  |  |
| 0 0       |          | 2, 3, 4, 5        |  |  |
| 0 1       | 0        | 1, 3, 4, 5        |  |  |
| 0 1       | <u>t</u> | 3, 4, 5, 6        |  |  |
| 1 0       | D        | 1, 2, 4, 5        |  |  |
| 10        | 1        | 2, 4, 5, 6        |  |  |
| 1 1       | 0        | 1, 4, 5, 6        |  |  |
| 1 1       | 1        | 4, 5, 6, 7.       |  |  |

| 1      |
|--------|
| ontrol |
|        |

|       |       |   |   | 1    |
|-------|-------|---|---|------|
| entry | e-1,4 | 2 | 3 | rest |
| 0     | 1     | 1 | 1 |      |
| 1     | 0     | 2 | 2 | 2    |
| 2     | 1     | 0 | 2 | 2    |
| 3     | 0     | 0 | 3 | 3    |
| 4     | 1     | D | 0 | 3    |
| 5     | 0     | 2 | 0 | 3    |
| 6     |       | 0 | 0 | 3    |
| 7     | 0     | 0 | 0 | 4.   |

d. Put it all together.



### Stage 2 DECOPE (1)

- 1. Basic Functionality
  - 1 Decode
  - @ Access Register File
  - 3 Branch control
- 2. Basic Blocks.
  - O Ctrl. (combinational)
    - a. input and output interfaces



instri- decode\_i (16-20) -> instri-source)

instri-decode-i (0-5) -> instri-source 2.

instri-decode-i (21~25) - instri- des

#### if (BNE)

instri- devode\_i (16~20) -> instri\_ source 1

instri\_decode\_ (21~25) -> instri- source 2

 $\times \times \times \longrightarrow instri_des$ 

#### Stage 2 DEWDE (2)

if (LD)

instri-decode-i(16~20) \rightarrow instri-source1.

\[
\times \times \times \rightarrow \righ

3 Register File

a, input a output interfaces



16 entries.

## Stage 2 DECODE (3)

3 branch control unit.

a. input and output interfaces.



b. microarchitecture



- @ if equal, output 0.
- 3) if more than I branches mispredict, use priority encoder to choose the first mispredicted branch, set flush signal and flush all the instructions offer that branch.

### Stage 3 EXECUTION

- 1. Basic Functionality.
  - O For LD/SD instructions, add the imm and the source to get the memory address
  - For ADD instructions, add the data from two source registers to get the result for the destination register.
  - 3) To speculate the branch, store the data, corresponding destination and branch id. After a branch is resolved, if it predicted correctly, the data can be committed, otherwise these data should be flushed.

#### 2. Basic Blocks.

O ALU



### Stage 3 (2)

@ Buffer.

a. Input a output interfaces.

