CS 382 Fall 2024

## Computer Architecture and Organization

## Lab 8 Report

| First name            |                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Last name             |                                                                                                                                                                                                                                                                                                                                                           |
| Collaborator          |                                                                                                                                                                                                                                                                                                                                                           |
| Pledge                |                                                                                                                                                                                                                                                                                                                                                           |
| 1 Reading             | g a Register File                                                                                                                                                                                                                                                                                                                                         |
| In this part, we      | will test if reading register file works for all four registers.                                                                                                                                                                                                                                                                                          |
| hexadeci              | II, manually set up register values. Click on the grey box in each register, and type two digits of mal to set the data stored in that register. You can pick any value you like, but the four registers ot have any equal values;                                                                                                                        |
| (2) Open tim          | ning diagram from the menu bar, and start simulation. You should be able to see the clock ticking;                                                                                                                                                                                                                                                        |
| able to se<br>diagram | the value of ReadReg1 from 00b, 01b, 10b, to 11b. For each of the value, you should be see the change on RegData1. After changing all four values, take a screenshot of <b>both</b> the timing and the circuit. The diagram should show that the value of RegData1 has been changed four ney also should change immediately after the change of ReadReg1; |
|                       |                                                                                                                                                                                                                                                                                                                                                           |
|                       |                                                                                                                                                                                                                                                                                                                                                           |
|                       |                                                                                                                                                                                                                                                                                                                                                           |
|                       |                                                                                                                                                                                                                                                                                                                                                           |
|                       |                                                                                                                                                                                                                                                                                                                                                           |
|                       |                                                                                                                                                                                                                                                                                                                                                           |
|                       |                                                                                                                                                                                                                                                                                                                                                           |
|                       |                                                                                                                                                                                                                                                                                                                                                           |
| Screen                | shot Here                                                                                                                                                                                                                                                                                                                                                 |

| (4) | Repeat the above step for ReadReg2.                                                                                                                                                                                                 |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     | Screenshot Here                                                                                                                                                                                                                     |
| •   | Writing a Register File                                                                                                                                                                                                             |
| thi | s part, we will test if writing register file works for all four registers.                                                                                                                                                         |
| (1) | First of all, reset the circuit (Menu bar ►Simulate ►Reset simulation). <b>Make sure</b> all four registers now have values of 0;                                                                                                   |
| (2) | Set control signal RegWrite to 1, and change RegDataW to any non-zero number you like;                                                                                                                                              |
| (3) | Open timing diagram from the menu bar, and start simulation. You should be able to see the clock ticking;                                                                                                                           |
| (4) | Change the value of WriteReg from 00b to 11b. Be careful: because writing register is sequential, and so the data will only be updated at rising edge, make sure you wait long enough to change WriteReg;                           |
| (5) | At the end, you should be able to see all four registers have been updated to the same value. Please provide a screenshot below. <b>Note:</b> it has to be timing diagram showing the values – not the grey boxes in the registers; |
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     |                                                                                                                                                                                                                                     |
|     | Screenshot Here                                                                                                                                                                                                                     |

In

| (6) | Now, pause the simulation, and change RegDataW to 0, and set control signal RegWrite to 0. Set WriteReg back to 00b;                                   |
|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| (7) | Restart the simulation, and again change the value of ${\tt WriteReg}$ from ${\tt 00b}$ to ${\tt 11b}$ . Also be aware of the timing of these changes; |
| (8) | At the end, you should not observe any value change of all four registers. Please provide a screenshot of the timing diagram below:                    |
|     |                                                                                                                                                        |
|     |                                                                                                                                                        |
|     |                                                                                                                                                        |
|     | Screenshot Here                                                                                                                                        |

The End  ${\mathfrak G}$