## CS2100 Computer Organization Tutorial 4: Data and Control Path

(Week 6: 18 Sep – 22 Sep 2023)

1. [Past-year's exam question]

An ISA has 16-bit instructions and 5-bit addresses. There are two classes of instructions: class *A* instructions have one address, while class *B* instructions have two addresses. Both classes exist and the encoding space for opcode is completely utilized.

- (a) What is the minimum total number of instructions?
- (b) What is the maximum total number of instructions?
- 2. You have seen how **blt** ("branch less than") can be implemented in the lecture slides. MIPS assembly also allows for "pseudo-instructions" which the assembler will expand to multiple instructions to implement the functionality. Show how the following pseudo-instructions are implemented using real MIPS instructions:
  - (a) bgt \$r1, \$r2, L ("bgt = branch greater than")
  - (b) **bge** \$r1, \$r2, L ("bge = branch greater than or equal")
  - (c) ble \$r1, \$r2, L ("ble = branch less than or equal")
  - (d) li \$r, imm ("load immediate" where the immediate can be any length up to 32-bits)
  - (e) **nop** ("No operation", i.e., a null operation)

**Questions 3 and 4** refer to the complete datapath and control design covered in lectures #11 and #12. Please use the diagram in Lecture #12 slide 29 or in the COD MIPS 4<sup>th</sup> edition textbook, Figure 4.17. For your convenience, Lecture #12 slide 29 is also included at the end of this tutorial sheet.

3. Let us perform a complete trace to understand the working of the complete datapath and control implementation. Given the following three hexadecimal representations of MIPS instructions:

```
i. lw $24, 0($15)
```

For each instruction encoding, do the following:

(a) Give the binary representation for the instruction.

(b) Fill in the tables below. The first table concerns with the various data (information) at each of the datapath elements, while the second table records the control signals generated. Use the notation \$8 to represent register number 8, [\$8] to represent the content of register number 8 and Mem(X) to represent the memory data at address X.

| Registers File |     |    |    | ALU  |      | Data Memory |            |  |
|----------------|-----|----|----|------|------|-------------|------------|--|
| RR1            | RR2 | WR | WD | Opr1 | Opr2 | Address     | Write Data |  |
|                |     |    |    |      |      |             |            |  |
|                |     |    |    |      |      |             |            |  |
|                |     |    |    |      |      |             |            |  |

[Wr = Write; Rd = Read; M = Mem; R = Reg]

| RegDst | RegWr | ALUSrc | MRd | MWr | MToR | Brch | ALUop | ALUctrl |
|--------|-------|--------|-----|-----|------|------|-------|---------|
|        |       |        |     |     |      |      |       |         |
|        |       |        |     |     |      |      |       |         |
|        |       |        |     |     |      |      |       |         |

(c) Indicate the value of the PC after the instruction is executed.

4. We shall now estimate the latency (time needed for a task) for the various type of instructions. Given below are the resource latencies of the various hardware components (ps = picoseconds =  $10^{-12}$  second):

| Inst-<br>Mem | Adder | MUX  | ALU   | Reg-File | Data-<br>Mem | Control/<br>ALUControl | Left-shift/Sign-<br>Extend/AND |
|--------------|-------|------|-------|----------|--------------|------------------------|--------------------------------|
| 400ps        | 100ps | 30ps | 120ps | 200ps    | 350ps        | 100ps                  | 20ps                           |

Give the estimated latencies for the following MIPS instructions:

(a) "SUB" instruction (e.g. **sub** \$25, \$20, \$5)

(b) "LW" instruction (e.g. lw \$24, 0 (\$15))

What do you think the **cycle time** should be for this particular processor implementation?

*Hint:* First, you need to find out the **critical path** of an instruction, i.e. the path that takes the longest time to complete. Note that there could be several <u>parallel paths</u> that work more or less simultaneously

